Class Tools.Standalone.process_files
- Description
 Boilerplate to quickly whip up rsif-like hacks for creating file processing to churn away at stdin, or files and/or directories provided on the command line, recursively or not, creating backup files or not, listing the paths of all files action was taken for, and returning an exit status of how many files that would have been taken action on which could not be written back.
The all-round quickest way of making one of these tools is nicking the top portion of lib/modules/Tools.pmod/Standalone.pmod/process_files.pike or copying rsif.pike from the same directory. (The latter is 20 lines long, including docs, or about four lines of code.) Inherit process_files, and define your own version, description, usage, process, and, if you want arguments, want_args.
- Variable default_flag_docs
 stringTools.Standalone.process_files.default_flag_docs- Description
 Flag docs to append to your usage description. Explains default options.
- Variable description
 stringTools.Standalone.process_files.description- Description
 One-liner that gets shown for this tool when running pike -x without additional options. (Assuming your tool resides in Standalone.pmod.) Does not include the name of the tool itself; just provide a nice, terse description, ending with a period for conformity.
- Inherit process_files
 inheritToole.Standalone.process_files: process_files
- Variable overwrite
 boolTools.Standalone.process_files.overwrite- Description
 0 to make backups, 1 to overwrite (default)
- Variable recursive
 boolTools.Standalone.process_files.recursive- Description
 1 to recurse into directories, 0 not to (default)
- Variable usage
 stringTools.Standalone.process_files.usage- Description
 Long description of the purpose and usage of your tool, for --help and the case where not enough options are given on the command line. Its invocation mode (for instance "pike -x yourtool", when invoked that way) is prepended, and a list of available flags appended to this description.
- Variable verbosity
 int(0..)Tools.Standalone.process_files.verbosity- Description
 0 in quiet mode, 1 by default, above = more output
- Variable version
 stringTools.Standalone.process_files.version- Description
 Your hack's version number. If you version control your file with cvs, we suggest you set the contents of this variable to something that that will automatically expand to a number for every new revision, for instance
- Example
 string version = sprintf("%d.%d.%d",(int)__REAL_VERSION__,__REAL_MINOR__,__REAL_BUILD__);
- Variable want_args
 intTools.Standalone.process_files.want_args- Description
 The number of (mandatory) command-line options your hack needs and which your process callback wants (beside the input file). By default 0.