xe - Man Page
evaluate expressions
Examples (TL;DR)
- Run a command once for each line of input data as arguments:
arguments_source | xe command
- Execute the commands, replacing any occurrence of the placeholder (marked as
{}
) with the input line:arguments_source | xe command {} optional_extra_arguments
- Execute a shellscript, joining every
N
lines into a single call:echo -e 'a\nb' | xe -N2 -s 'echo $2 $1'
- Delete all files with a
.backup
extension:find . -name '*.backup' | xe rm -v
- Run up to
max-jobs
processes in parallel; the default is 1. Ifmax-jobs
is 0, xe will run as many processes as cpu cores:arguments_source | xe -j max-jobs command
Synopsis
xe [Options] EXPRESSION [TYPE NAME VALUE]...
Description
xe prints the value of EXPRESSION to standard output. EXPRESSION may refer variables defined as a TYPE NAME VALUE triplet. TYPE may be one of cardinal (integral, positive), integer (integral), real (real) and text (string).
Options
- -P, --print
Print the parsed expression instead its value.
- -t, --type
Print the expression type instead its value.
- --list
List functions and exit.
- --list-1
List unary operators and exit.
- --list-2
List binary operators and exit.
- --list-2h
List binary operators and exit.
- --list-3
List ternary operators and exit.
- --list-3h
List ternary operators and exit.
- --help
Print a usage message and exit with a status code indicating success.
- --version
Print version information on standard output then exit.
Syntax
The allowed expression syntax is similar to that of C expressions. It allows for prefix unary and common syntax binary operators, functions and variables. There are four supported types: cardinal (integral, positive), integer (integral), real (real) and text (string).
The available functions are mathematical or text generalities, among which:
- real Gacos(real x);
is the in degrees specified arc cosine of x
- real Gadiff(real x, real y);
is the in degrees specified smallest angle between degrees x and degrees y (or something)
- real Garccos(real x);
is same as Gacos(x)
- real Garcctg2(real x, real y);
is the in degrees specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result (same as Gatan2(y, x))
- real Garcdiff(real x, real y);
is same as Gadiff(x, y)
- real Garcsin(real x);
is same as Gasin(x)
- real Garctg(real x);
is same as Gatan(x)
- real Garctg2(real y, real x);
is same as Gatan2(y, x)
- real Gasin(real x);
is the in degrees specified arc sine of x
- real Gatan(real x);
is the in degrees specified arc tangent of x
- real Gatan2(real y, real x);
is the in degrees specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result
- real Gcos(real x);
is the cosine of degrees x
- real Gparcctg2(real x, real y);
is the positively defined, in radians specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result (same as Gpatan2(y, x))
- real Gparctg2(real y, real x);
is same as Gpatan2(y, x)
- real Gpatan2(real y, real x);
is the positively defined, in degrees specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result
- real Gsin(real x);
is the sine of degrees x
- real Gtan(real x);
is the tangent of degrees x
- real Gtg(real x);
is same as Gtan(x)
- integer abs(integer m);
is the absolute value of m
- real acos(real x);
is the in radians specified arc cosine of x
- real adiff(real x, real y);
is the in radians specified smallest angle between radians x and radians y (or something)
- real arccos(real x);
is same as acos(x)
- real arcctg2(real x, real y);
is the in radians specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result (same as atan2(y, x))
- real arcdiff(real x, real y);
is same as adiff(x, y)
- real arcsin(real x);
is same as asin(x)
- real arctg(real x);
is same as atan(x)
- real arctg2(real y, real x);
is same as atan2(y, x)
- real asin(real x);
is the in radians specified arc sine of x
- real atan(real x);
is the in radians specified arc tangent of x
- real atan2(real y, real x);
is the in radians specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result
- integer base2(integer m);
is the greatest power of 2 less than or equal to m if m is not less than zero, some undefined value otherwise
- integer bcount(integer m);
is the m bit count (i.e. the number of bits set in m)
- real ceil(real x);
is the up rounded value of x
- cardinal cardinal(cardinal z);
is z
- integer character(text s, integer m);
is the (positively defined value of the) mth character of s, if such character exists, 0 otherwise (negative position indications are interpreted with respect to the end of string)
- integer compare(text s, text t);
is 0 if s is (case sensitive) same as t, less than 0 if s is less than t and greater than 0 if s is greater than t
- real cos(real x);
is the cosine of radians x
- integer deck2(integer m);
is the lesser power of 2 greater than or equal to m if m is not less than zero, some undefined value otherwise
- integer drand(integer m);
is a pseudo-random integer between inclusive 0 and m
- text echo(text s);
is s
- real exp(real x);
is the value of e (the base of natural logarithms) raised to the power of x
- real exp2(real x);
is the value of 2 raised to the power of x
- real fabs(real x);
is the absolute value of x
- real fclip(real min, real x, real max);
is the minimum between max and the maximum between x and min
- integer ffs(integer m);
is the 1 based position of the first (least significant) bit set in m if any, 0 otherwise
- real floor(real x);
is the down rounded value of x
- integer fls(integer m);
is the 1 based position of the last (most significant) bit set in m if any, 0 otherwise
- real fmax(real x, real y);
is the maximum of x and y
- real fmin(real x, real y);
is the minimum of x and y
- real fmod(real x, real y);
is the remainder of dividing x by y, more specifically x - n * y, where n is the quotient of x / y, rounded toward zero to an integer
- real fmodf(real x);
is the same sign as x fractional part of x
- integer frame(text s, integer c);
is the position of the last occurrence of the c non zero character in the s string if any, -1 otherwise
- real frand(void);
is a pseudo-random real between 0 and 1
- real frexp(real x, integer &e);
is the (-1; -0.5], [0.5; 1) normalized fraction that multiplied by the power of two to which e is set retrieves x
- real fsign(real x);
is -1 if x is negative, 0 of x is zero, 1 otherwise
- integer gcd(integer m, integer n);
is the greatest common denominator of m and n
- real gclip(real x, real min, real max);
is the minimum between max and the maximum between x and min
- integer iclip(integer min, integer m, integer max);
is the minimum between max and the maximum between m and min
- real imodf(real x);
is the same sign as x integral part of x
- integer integer(integer m);
is m
- integer irand(integer m, integer n);
is a pseudo-random integer between inclusive m and n
- integer jclip(integer m, integer min, integer max);
is the minimum between max and the maximum between m and min
- integer kfs(integer m, integer k);
is the 0 based position of the first kth (least significant) bit set in m if any, the number of bits in m otherwise (kfs(m, 0) is equivalent with xfs(m))
- integer kls(integer m, integer k);
is the 0 based position of the last kth (most significant) bit set in m if any, the number of bits in m otherwise (kls(m, 0) is equivalent with xls(m))
- integer length(text s);
is the length of s
- real limit(real x);
is the away from zero rounded value of x
- real ln(real x);
is same as log(x)
- real log(real x);
is the natural logarithm of x
- real log10(real x);
is the base 10 logarithm of x
- real log2(real x);
is the base 2 logarithm of x
- real lrand(void);
is a pseudo-random real between -1 and 1
- integer lz(integer m);
is the m leading zero bits count, same as xls(m)
- integer match(text s, text t);
is 0 if t wild card (case sensitive) matches the s pattern (the * and ? literal sign are interpreted as for their shell pattern equivalents), non 0 otherwise
- integer max(integer m, integer n);
is the maximum of m and n
- integer min(integer m, integer n);
is the minimum of m and n
- real modf(real x, real &y);
is the same sign as x fractional part of x, y is the same sign as x integral part of x
- real parcctg2(real x, real y);
is the positively defined, in radians specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result (same as patan2(y, x))
- real parctg2(real y, real y);
is same as patan2(y, x)
- real patan2(real y, real x);
is the positively defined, in radians specified arc tangent of y / x, signs of both x and y being used to determine the quadrant of the result
- integer place(text s, integer c);
is the position of the first occurrence of the c non zero character in the s string if any, -1 otherwise
- real pow(real x, real y);
is the value of x raised to the power of y
- text project(text s, integer m);
is s after position m (negative position indications are interpreted with respect to the end of string)
- real real(real x);
is x
- real round(real x);
is the towards nearest integer, half cases away from zero rounded value of x
- integer sign(integer m);
is -1 if m is negative, 0 of m is zero, 1 otherwise
- integer signed(cardinal z);
is z
- real sin(real x);
is the sine of radians x
- real sq(real x);
is the square of x
- real sqrt(real x);
is the square root of x
- real tan(real x);
is the tangent of radians x
- real tg(real x);
is same as tan(x)
- real track(real x);
is the towards zero rounded value of x
- integer tz(integer m);
is the m trailing zero bits count, same as xfs(m)
- cardinal unsigned(integer m);
is m
- integer xfs(integer m);
is the 0 based position of the first (least significant) bit set in m if any, the number of bits in m otherwise (same as tz(m))
- integer xls(integer m);
is the 0 based position of the last (most significant) bit set in m if any, the number of bits in m otherwise (same as lz(m))
Most of prefix unary and common syntax binary C operators are supported (including unary !, +, - and ~ and binary *, /, %, +, -, <<, >>, <, >, <=, >=, !=, ==, &, ^, |, &&, ||, =, +=, -=, *=, /=, %=, &=, ^=, |=, <<= and >>=), the semantics and precedence being the same or at least very close to those of their C counterparts.
Authors
Ciprian Niculescu