forked from leahneukirchen/xe
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
167 lines (127 loc) · 6.96 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
XE(1) General Commands Manual XE(1)
NAME
xe – execute a command for every argument
SYNOPSIS
xe [-0FLRnqv] [-I replace-arg] [-N maxargs] [-j maxjobs] command ...
xe [flags ...] -p pattern command ... [+ pattern command ...]...
xe [flags ...] -f argfile command ...
xe [flags ...] -s shellscript
xe [flags ...] -a command ... -- args ...
xe [flags ...] -A argsep command ... argsep args ...
DESCRIPTION
The xe utility constructs command lines from specified arguments,
combining some of the best features of xargs(1) and apply(1).
xe means “execute for every ...”.
xe supports different methods to specify arguments to commands:
command ...
By default, arguments - separated by newlines - are read from the
standard input. The resulting command is constructed from the
command line parameters, replacing replace-arg with the read
argument, and is executed with execvp(3).
In this mode, no shell is involved and replace-arg must appear as
a word on its own, i.e. ‘foo {} bar’ will work, but ‘foo{} bar’
will not, where {} is the default value for replace-arg.
If no argument is specified, the default is ‘printf %s\n’.
-f argfile
Read arguments from argfile, instead of the standard input.
This does not close the standard input for execution, it is
passed to the forked process.
-s shellscript
In this mode, the single parameter shellscript is executed using
sh -c. In the script, the specified arguments can be accessed
using $1, $2, ...
For example:
echo 'a\nb' | xe -N2 -s 'echo $2 $1'
-a command ... -- args ...
In this mode, everything after -- is passed as args to command.
-A argsep command ... argsep args ...
Same as -a, but the custom argument separator argsep is used to
distinguish between command and its args.
The options are as follows:
-0 Input arguments are separated by NUL bytes (instead of newlines,
which is the default).
-F Fatal: stop and exit when a command execution fails.
-L Run the resulting commands with line-buffered output; lines from
two jobs will not interleave. When used twice, or with -vv, also
prefix each line with the number of the job (see ENVIRONMENT) in
such a manner that the output can be piped to ‘sort -snk1’ to
group it.
-R Return with status 122 when no arguments have been specified
(instead of 0, the default). xe never executes a command when no
arguments are specified.
-n Dry run: don't run the resulting commands, just print them.
-q Quiet mode: redirect standard output and standard error of
commands to /dev/null.
-v Verbose: print commands to standard error before running them.
When used twice, also print job id and exit status for each
command.
-p Enable make(1)-style percent rules. The first argument of
command ... is regarded as a pattern, see PERCENT RULES below.
Patterns without a slash (or ‘**’) are matched against the
basenames only.
Multiple runs of patterns and commands are separated by ‘+’.
Only the first matching percent rule is executed; in case no
pattern matches, no command is run.
-I replace-arg
Replace first occurrence of replace-arg (default: {}) in the
resulting command with the argument(s). Pass an empty
replace-arg to disable the replace function. Contrary to
xargs(1) this will expand into multiple arguments when needed.
-N maxargs
Pass up to maxargs arguments to each command (default: 1).
Using -N0 will pass as many arguments as possible.
-j maxjobs
Run up to maxjobs processes concurrently. Using -j0 will run as
many processes as there are CPU cores running. If maxjobs ends
with an ‘x’, it is regarded as a multiplier of the number of
running CPU cores (rounded down, but using at least one core).
PERCENT RULES
The percent rules of xe are similar to the globs of sh(1) or fnmatch(3):
‘?’ matches a single character that is not ‘/’. ‘/’ matches one or
multiple ‘/’ in the string. ‘*’ matches zero or more characters, but
never ‘/’. ‘**’ matches zero or more characters, including ‘/’. Note
that all of these also match leading dots in file names.
‘{a,b,c}’ matches either a, b or c. ‘[abc]’ matches one of the
characters abc (but never ‘/’). ‘[!abc]’ matches all characters but abc.
Alternatively, ‘[^abc]’ can be used too. ‘[a-c]’ matches any character
in the range between a and c inclusive. In character ranges, characters
can be escaped using a backslash.
In the pattern, a single occurrence of ‘%’ matches one or more
characters, and replaces the first occurrence of ‘%’ with the matched
string in the remaining arguments, which are then used as the command to
be executed.
ENVIRONMENT
The environment variable ITER is passed to the child process and
incremented on each command execution.
EXIT STATUS
xe follows the convention of GNU and OpenBSD xargs:
0 on success
123 if any invocation of the command exited with status 1 to 254.
124 if the command exited with status 255
125 if the command was killed by a signal
126 if the command cannot be run
127 if the command was not found
1 if some other error occurred
Additionally, 122 is returned when -R was passed and the command was
never executed.
EXAMPLES
Compress all .c files in the current directory, using all CPU cores:
xe -a -j0 gzip -- *.c
Remove all empty files, using lr(1):
lr -U -t 'size == 0' | xe -N0 rm
Convert .mp3 to .ogg, using all CPU cores:
xe -a -j0 -s 'ffmpeg -i "${1}" "${1%.mp3}.ogg"' -- *.mp3
Same, using percent rules:
xe -a -j0 -p %.mp3 ffmpeg -i %.mp3 %.ogg -- *.mp3
Similar, but hiding output of ffmpeg, instead showing spawned jobs:
xe -ap -j0 -vvq '%.{m4a,ogg,opus}' ffmpeg -y -i {} out/%.mp3 -- *
SEE ALSO
apply(1), parallel(1), xapply(1), xargs(1)
AUTHORS
Leah Neukirchen <[email protected]>
LICENSE
xe is in the public domain.
To the extent possible under law, the creator of this work has waived all
copyright and related or neighboring rights to this work.
http://creativecommons.org/publicdomain/zero/1.0/
Void Linux August 1, 2023 Void Linux