2024-07-24 12:02:54 +02:00
|
|
|
.Dd July 24, 2024
|
2024-07-19 13:40:45 +02:00
|
|
|
.Dt tagger 1
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm tagger
|
2024-07-21 20:30:51 +02:00
|
|
|
.Nd Show and edit file system tags, stored as extended attribute
|
2024-07-19 13:40:45 +02:00
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm
|
|
|
|
.Fl h
|
|
|
|
.Nm
|
|
|
|
.Fl \-version
|
|
|
|
.Nm
|
2024-07-21 20:30:51 +02:00
|
|
|
.Op Fl a Ar tag
|
|
|
|
.Op Fl d Ar tag
|
|
|
|
.Op Fl c Ar tag Fl i Ar tag
|
|
|
|
.Op Fl l
|
|
|
|
.Op Fl s
|
2024-07-22 11:09:22 +02:00
|
|
|
.Ar
|
2024-07-19 13:40:45 +02:00
|
|
|
.Sh DESCRIPTION
|
2024-07-21 20:30:51 +02:00
|
|
|
On Linux file systems that support extended attributes, the XDG desktop uses the
|
|
|
|
attribute `user.xdg.tags' to store a comma-separated list of user-defined tags.
|
|
|
|
File browsers such as Dolphin on KDE have user interface to manipulate them.
|
|
|
|
Unfortunately, it is inconvenient if one wishes to change tags for many files or
|
|
|
|
directories at once.
|
2024-07-19 13:40:45 +02:00
|
|
|
The
|
|
|
|
.Nm
|
2024-07-21 20:30:51 +02:00
|
|
|
tool allows you to list and/or edit tags in bulk, with a convenient command line
|
|
|
|
interface.
|
2024-07-19 13:40:45 +02:00
|
|
|
.Pp
|
2024-07-22 09:42:12 +02:00
|
|
|
If you add, change, and delete tags from files and/or directories in a single
|
|
|
|
command,
|
|
|
|
.Nm
|
|
|
|
will first delete tags, then apply changes, and finally add tags, in that order.
|
|
|
|
.Pp
|
2024-07-19 13:40:45 +02:00
|
|
|
The options are as follows:
|
2024-07-21 20:30:51 +02:00
|
|
|
.Ss General Options
|
2024-07-19 13:40:45 +02:00
|
|
|
.Bl -tag -width Ds
|
|
|
|
.It Fl h, \-help
|
|
|
|
Print help text and exit.
|
|
|
|
.It Fl \-version
|
|
|
|
Print version info and exit.
|
|
|
|
.El
|
2024-07-21 20:30:51 +02:00
|
|
|
.Ss Listing tags
|
|
|
|
.Bl -tag -width Ds
|
|
|
|
.It Fl l, \-list
|
|
|
|
List tags.
|
|
|
|
If you also specify any
|
|
|
|
.Sx Editing Options
|
|
|
|
(see below),
|
|
|
|
.Nm
|
|
|
|
reports tags before and after applying any changes.
|
2024-07-24 12:02:54 +02:00
|
|
|
.Pp
|
|
|
|
If you don't specify any
|
|
|
|
.Sx Editing Options
|
|
|
|
the
|
|
|
|
.Fl l
|
|
|
|
option is implied, and can be omitted.
|
2024-07-21 20:30:51 +02:00
|
|
|
.El
|
|
|
|
.Ss Editing Options
|
|
|
|
.Bl -tag -width Ds
|
|
|
|
.It Fl a, \-add Ar tag
|
|
|
|
Add the specified tag.
|
|
|
|
This option can be used multiple times.
|
|
|
|
.It Fl c, \-change Ar tag
|
|
|
|
Change the given tag, into a new value supplied as an argument for the
|
|
|
|
.Fl i
|
|
|
|
option (see below).
|
|
|
|
.It Fl i, \-into Ar tag
|
|
|
|
Change the value given with the last
|
|
|
|
.Fl c
|
|
|
|
option into the new value given here.
|
|
|
|
These pairs of
|
|
|
|
.Fl c
|
|
|
|
and
|
|
|
|
.Fl i
|
|
|
|
options can be used multiple times.
|
|
|
|
.It Fl d, \-delete Ar tag
|
|
|
|
Delete the given tag, if it exists.
|
|
|
|
This option can be used multiple times.
|
|
|
|
.It Fl s, \-sort
|
2024-07-22 09:43:50 +02:00
|
|
|
With this flag, changes will be written back for the file or directory in
|
2024-07-21 20:30:51 +02:00
|
|
|
alphabetically sorted order.
|
|
|
|
.El
|
|
|
|
.Sh ENVIRONMENT
|
|
|
|
.Nm
|
|
|
|
uses libscterm for its color output support, and as such honors the NO_COLOR
|
2024-07-22 09:42:12 +02:00
|
|
|
environment variable, if defined and non-empty.
|
2024-07-21 20:30:51 +02:00
|
|
|
Color output is also automatically suppressed when it is not written to a tty,
|
|
|
|
such as when writing to a pipe, or when using output redirection.
|
2024-07-19 13:40:45 +02:00
|
|
|
.Sh EXIT STATUS
|
|
|
|
.Nm
|
|
|
|
exits 0 on success, and 1 if an error occurs.
|
2024-07-22 09:42:12 +02:00
|
|
|
.Sh EXAMPLES
|
|
|
|
To change `Biografie' into `Biography' in all files in the current directory,
|
|
|
|
but only if present:
|
|
|
|
.Pp
|
|
|
|
.Dl tagger -c Biografie -i Biography *
|
|
|
|
.Pp
|
|
|
|
List the tags in a file named `MyMovie.mp4':
|
|
|
|
.Pp
|
|
|
|
.Dl tagger -l MyMovie.mp4
|
|
|
|
.Pp
|
2024-07-25 07:54:58 +02:00
|
|
|
or, simply:
|
|
|
|
.Pp
|
|
|
|
.Dl tagger MyMovie.mp4
|
|
|
|
.Pp
|
2024-07-22 09:42:12 +02:00
|
|
|
To delete all `foo' and `bar' tags from files, if present:
|
|
|
|
.Pp
|
|
|
|
.Dl tagger -d foo -d bar *
|
|
|
|
.Pp
|
2024-07-19 13:40:45 +02:00
|
|
|
.\" .Sh DIAGNOSTICS
|
|
|
|
.\" For sections 1, 4, 6, 7, 8, and 9 printf/stderr messages only.
|
2024-07-21 20:30:51 +02:00
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr xattr 7
|
2024-07-19 13:40:45 +02:00
|
|
|
.Sh AUTHORS
|
|
|
|
Bob Polis
|