NAME
IMCC - running
VERSION
OVERVIEW
This document describes imcc's command line options.
SYNOPSIS
imcc [-options] <file> [arguments ...]
OPTIONS
Imcc options
- -a, --pasm
-
Assume PASM input on stdin.
- -c, --pbc
-
Assume PBC file on stdin, run it.
- -d, --debug [hexbits]
-
Tbe -d switch takes an optional argument, which is considered to hold a hex value of debug bits. Without a value, debug is set to 1.
The individual bits are:
DEBUG_PARROT 0x0001 DEBUG_LEXER 0x0002 DEBUG_PARSER 0x0004 DEBUG_IMC 0x0008 DEBUG_CFG 0x0010 DEBUG_OPT1 0x0020 DEBUG_OPT2 0x0040 DEBUG_PBC 0x1000 DEBUG_PBC_CONST 0x2000 DEBUG_PBC_FIXUP 0x4000
To produce really huge output on stderr run "imcc -d 0ffff ...". Note: if the argument is separated by whitespace from the -d switch, it has to start with a number.
- -h --help
- -o outputfile
-
Act like assembler. Don't run code, except -r is given too. If the outputfile ends with .pbc a PBC file is written. If it ends with .pasm a PASM output is generated, even from PASM input. This canbe handy to check various optimizations including -Op.
- -r, --run-pbc
- -v, --verbose
-
One -v shows, which files are worked on, two give you a summary over register usage and optimization stats perl compilation unit.
- -y, --yydebug
-
Turn on yydebug in yacc/bison.
- -V, --version
- -Ox
-
Optimize
-O0 no opimization (default) -O1 optimizations w/o life info (e.g. branches) -O2 optimizations with life info -Op rewrite I and N PASM registers most used first
This will probably change.
Parrot Options
s. parrot -h for description, used, when running a program inside imcc.
<file>
If the file ends in .pbc it will be interpreted immediately. If the file ends in .pasm it is parsed as PASM code else as PIR code then it get's run, except -o was given. If the file is a single dash, input from stdin is read.
Generated files
If debugging is enabled these files are generated:
file.stabs.s ... stabsfile for the program
file.o ... object file with debug information
EVAL_n ... source of B<compile> op nr. I<N>
EVAL_n.stabs.s ... stabsfile for this block
EVAL_n.o ... object file with debug information
[arguments ...]
Optional arguments passed to the running program as ARGV, only useful for running the program.
Operation table
Commandline Action Output
---------------------------------------------
imcc x.imc run
imcc x.pasm run
imcc x.pbc run
-o x.pasm x.imc ass x.pasm
-o x.pasm y.pasm ass x.pasm
-o x.pbc x.imc ass x.pbc
-o x.pbc x.pasm ass x.pbc
-o x.pbc -r x.pasm ass/run x.pbc
BUGS
The long imcc options are unimplemented.
FILES
main.c
AUTHOR
Leopold Toetsch <lt@toetsch.at>
2 POD Errors
The following errors were encountered while parsing the POD:
- Around line 29:
'=item' outside of any '=over'
- Around line 92:
You forgot a '=back' before '=head2'