D 2020-11-27T00:04:46.117
L Command-line\sarguments
P ea269e1019e924218f4d1c234608b998497a04af
U anonymous
W 3013
(This is currently a draft and is subject to being changed.)
The syntax is: heromesh [switches] basename [resources...]
Switches are listed below. You can have more than one switch after a minus sign, if in the same argument.
The basename is the puzzle set name, including path if not in the current directory, but without the extension (there are four files, each with a different extension but the same basename).
Resources are relative to the puzzle set base (not the root node of the resource manager). See [.heromeshrc] for a list of the possible resources. These override resources in the .heromeshrc file.
Switches
* -c - Only load the .class file and check for errors. In this case, it will not complain if the .xclass and .level and .solution files do not exist.
* -C - Dump all compiled class codes to stdout. This is used mainly for testing.
* -e - Start the level editor, rather than play game.
* -H - Dump the hash table to stdout. This is used mainly for testing.
* -L - Meant for use with -c; lists all tokens it reads from the .class file (including macro expansions), rather than trying to parse it afterward. It does not check for any errors other than those in the lexer and macro preprocessor.
* -M - Meant for use with -c; display details of the macro system working.
* -T - Undocumented testing mode. This is meant for testing Free Hero Mesh itself.
* -t - Enable tracing.
* -v - Verbose logging mode.
* -x - Execute SQL statements from stdin. For example, you can use this to make a report of the levels or to convert levels from another file format.
Dot commands
When the -x switch is specified, it reads SQL statements from stdin. However, you can also use a line beginning with # as a comment, or a line beginning with . as a special command (neither works if an incomplete SQL statement has been read).
Valid dot commands are:
* .b0 - Disable bail mode. SQL errors are ignored, but will prevent the current statement from executing, and any other statements on the same line.
* .b1 - Enable bail mode (default). Any SQL errors are fatal.
* .f - Release memory and flush the SQLite cache.
* .i - Tell you the filename of the user cache database.
* .q - Quit.
* .u - Flush the user cache, causing the .level and .solution files to be rewritten if there are any pending changes. Should not be used while a transaction is active.
* .x0 - Disable the LOAD_EXTENSION() function (default).
* .x1 - Enable the LOAD_EXTENSION() function.
It also quits on EOF, but will complain if EOF occurs in the middle of a SQL statement.
Any result rows of SQL statements are written to stdout, with a vertical bar between columns and line breaks after each row.
Z d59077136aeab3c405d5fb427eeaf611