Provided by: hexec_0.2.1-3_amd64 bug

NAME

       hexec - a process execution hooking tool

SYNOPSIS

       hexec <OPTIONS> [expr] [cmd] [args...]

DESCRIPTION

       hexec  is  a  tool  to  hook  into process exececution calls (exec family of syscalls). You can define an
       expression that is executed against any hooked exec call. This expression may also contain a  replacement
       exec call.

OPTIONS SUMMARY

       Here is a summary of the options to hexec.

         --help    | -h        Print a options/expr summary page
         --version | -v        Print hexec version
         --log-out | -lo       set output file for error and -print output

OPTIONS

       -h     Print a options/expr summary page

       --help Print a options/expr summary page

       -lo    Set  the output file for error and -print output.  This can be required if writing to stderr could
              cause malfunction because some processes read from stderr and expect a well defined output.

EXPRESSIONS

       The expression is executed against all process execution calls.  If  the  expression  returns  true,  the
       original call is skipped.

       <expr> -and <expr>

       <expr> -a <expr>

       <expr> <expr>
              Returns  true  if both expressions return true. If the left returns false, the right expression is
              never executed.

       <expr> -or <expr>

       <expr> -o <expr>
              Returns true if one of both expressions  returns  true.  If  the  left  returns  true,  the  right
              expression is never executed.

       -path <pattern>
              Returns  true if the path of the executable matches <pattern>. <pattern> is a bash compatible wild
              card pattern.

       -ipath <pattern>
              Same as -path, but case insensitive.

       -name <pattern>
              Returns true if the base name of the executable matches <pattern>. <pattern> is a bash  compatible
              wild card pattern.

       -iname <pattern>
              Same as -name, but case insensitive.

       -contains <str>
              Returns true if the path of the executable containes the string <str>.

       -icontains <str>
              Same as -contains, but case insensitive.

       -print Print all arguments to the called process. Returns always true.

       -exec <cmd> [args...] ;
              Executes  <cmd>  with [args...] as arguments. This expression must be terminated with a semicolon.
              You can use argument placeholders in <cmd> and  [args...]  (see  below).  This  expression  always
              returns true.
              NOTE:  Please  be  aware  that  you  may  need to escape or quote the terminating semicolon to not
              confuse your shell.

       -sh <script>
              Interprets <script> as a shell script by invoking /bin/sh with the arguments  -c  '<script>'.  You
              can use argument placeholders inside <script>. Please note that -sh only expects a single argument
              and not a variable list of arguments (as -exec does). Using -sh is the same as using -exec  sh  -c
              <script>.

PLACEHOLDERS FOR -exec EXPRESSION

       Every  -exec expression can use placeholders in the argument list to obtain information from the original
       exec call. Each placeholder starts with { and ends with }. Use \{ if you want to use a { in your argument
       list. The placeholders are replaced when the -exec expression is evaluated.

       Placeholder types:

       {n}    Will be replaced with the number of arguments in the original call.

       {<idx>}
              Will  be  replaced  with  the  original argument at index <idx>. Example: {1} would give the first
              argument. You can prepend <idx> with placeholder flags.

       {}     Will be replaced with all arguments from the original call. Each  argument  is  seperated  with  a
              space. You can use placeholder flags.

       NOTE:  The  executable  name is also considered as argument. This means that a call like "echo test" will
       result in two arguments, "echo" and "test".

PLACEHOLDER FLAGS

       s      Every argument is inserted as single argument instead of concatenating all arguments.
              Consider the arguments 'a', 'b' and 'c'. Without s, -exec {} \; would result in -exec 'a b c'  \;,
              which  in  many cases is not what you want. -exec {s} \; howewer would result in -exec 'a' 'b' 'c'
              \;.

       q      Quote every single argument.

       e      Escape all non alpha-numeric characters. This flag is very useful when using a "sh  -c  <...>"  in
              the -exec expression.

       Examples

       -exec echo {} \; with the call 'a' 'b' 'c'
              results in: 'echo' 'a b c'

       -exec echo {q} \; with the call 'a' 'b' 'c'
              results in: 'echo' 'a' 'b' 'c'

       -exec sh -c 'echo {}; {}' \; with the call 'sh' '-c' 'gcc d.c >> log.txt'
              results in: 'sh' '-c' 'echo sh -c gcc d.c >> log.txt; sh -c gcc d.c >> log.txt'
              Please note that this will not do what you may expect, as the >> is handled wrong in this case.

       -exec sh -c 'echo {e}; {}' \; with the call 'sh' '-c' 'gcc d.c >> log.txt'
              results in: 'sh' '-c' 'echo sh \-c gcc\ d\.c\ \>\>\ log\.txt; sh -c gcc d.c >> log.txt'

CHANGES TO PROCESSES

       hexec will add some environment variables to the hooked processes.  These are (may not be complete):

       LD_PRELOAD
              hexec adds libhexec-hook.so to the list of preloaded libraries.

       HEXEC_EXPR_SHM
              Contains the name of the internal shared memory object.

       HEXEC_LOG_FD
              Contains the file descriptor for error and -print output.

       Please  do never modify these environment variables. Also take care when you use these variables, because
       the name and content of the variables may change in the future.

EXAMPLES

       hexec -name 'gcc' -exec ccache {s} \; make
              Calls make, which will then call gcc several times. The executable name  of  each  hooked  process
              execution is tested against the file pattern "gcc" and "ccache {s}" is called each time a match is
              found. '{s}' will be replaced with the original (the hooked) call. In this example, a call to "gcc
              -o test.o test.c" would be replaced with "ccache gcc -o test.o test.c"

HOW IT WORKS

       TODO

BUGS

       I'm sure there are alot...it's still beta :)

AUTHOR

       hexec was written by Alexander Block http://blocksoftware.net/

       If you wish to report a problem or make a suggestion then please email ablock@blocksoftware.net

       hexec  is  released  under the GNU General Public License version 2 or later. Please see the file COPYING
       for license details.

                                                  November 2008                                         hexec(1)