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.
- 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.