/**
@page LEVEL1 Other Trick Tools
@section LEVEL3 Interface Code Generator - ICG
ICG is the processor that %Trick uses to parse header files. It is normally called
internally from the main %Trick processor, CP. However, it may be used manually by
developers.
@par
The ICG parses developer created data structure definition files and generates
runtime executive input/output source code. The source code generated is compiled
into a simulation which uses the types parsed.
@par
The command syntax for the ICG is as follows (with restrictions outlined afterward):
@par
UNIX Prompt> ICG [-d] [-D ] [-U ] .h
UNIX Prompt> ICG -u
@par
The ICG can process multiple files at a
time and does accept UNIX wild card character designations (*.h) in the filename. The
optional ‘-d’ (for debug) argument tells the ICG to echo every character successfully
parsed from the file; if a syntax error occurs in the file, the user will know the exact
character which caused the problem. The optional ‘-D’ and ‘-U’ arguments are compiler
directives, used in concert with #defines, #undefs etc. and work like their CFLAGS
counterparts. The optional ‘-u’ argument tells ICG to display the current measurement
units primitives allowed in the parameter comment fields of the data structure definition
files.
@par
The ICG generates one source code file for each data structure definition file it
processes, with a file name in the form of io_src/io_.c; where “io_” is a
standard prefix for all ICG generated files, and is the original data
structure definition file name.
@par
Any characters or statements the ICG recognizes as valid syntax, but does not process,
will be echoed to the screen with an informative message on why it did not process the
parameter.
@par
In general, the following items are not processed by the ICG:
-# global parameters decalred outside of a struct, union, or enum typedef,
-# all parameter declarations of a type other than the basic C types listed in the
Parameter Data Types section or the types contained within the data structure and
enumerated type databases (structure and enumerated types previously processed by the ICG),
-# all parameters that have a ‘**’ in the measurement units field of the parameter comment, and
-# all function declarations.
@par
The ICG will always give the “ICG complete.” message upon successful completion of processing.
@section LEVEL3 Building Model Source
%Trick’s main processor, CP handles building models from a high level. However,
developers may desire to build a local cache of source and include files in a model
directory. Or the developer may want to build a library from a model directory of
source and include files. %Trick’s make_build and UNIX’s make may be used for these
purposes.
@section LEVEL4 Makefile Generator - make_build
The make_build processor takes the src and include files in a model directory and
autogenerates a Makefile. Note that make_build will work for mixed *.c and *.h files
in the same directory or for src and include subdirectories. make_build generates a
complete dependency list for the source and header files processed. make_build should
only be run after the ICG processor has been run on all appropriate data structure
definition files. This ensures the io_*.c files created by ICG are processed by
make_build. The command syntax for make_build is as follows:
UNIX Prompt> make_build [lib ]
The lib argument causes make_build to generate Makefile syntax for building an
archived (UNIX ar) library for the object files and give the library the name .
The make_build command is rarely used.
@section LEVEL4 Make Processor - make
Developers will be running GNU make on Makefiles in the SIM directory or model
directories. Running make in a SIM_ directory with a Makefile generated by CP will
result, hopefully, in a simulation. Running make in a model directory with a
Makefile generated by make_build will result in either object code for the model
source local to that directory or a library.
Makefile options may be found by typing in:
UNIX Prompt> make help
Additional documentation for make can be found in UNIX manuals for your workstation.
@section LEVEL2 Pickling And Unpickling A Simulation
Ever wanted to go to a sim directory and type in a command to get a tar-zipped file
of all simulation source necessary to run/build a simulation?
Welcome to pickle.
“pickle” is a script that does just that.
Here is an example of how to pickle a previously built simulation:
-# Build your simulation
-# cd ${HOME}/trick_sims
-# pickle SIM_ball_L2
This will create a file called SIM_ball_L2.tgz.
To “unpickle” your SIM_ball_L2.tgz and build it somewhere else, you take the following steps.
-# Untar and decompress the *.tgz file
-# source SIM_ball_L2_includes.csh (to get your TRICK_CFLAGS set)
-# cd SIM_ball_L2
-# CP
Caveat: Pickle will not search your input file for #includes on the system.
As long as you have all dependent input parameters in the SIM directory, it will
grab that.
@section LEVEL2 Viewing Parameters In SIE Database
Sometimes you are trying to remember the name of a parameter.... “Ummm. Let’s see.
It’s errr. Uhhh. clock something...” Try running this in your built simulation
directory where the S_sie.resource file is located.
UNIX Prompt> sie [-nocase]
As an example, if you know the parameter name contains clock but don’t know
anything else, try:
UNIX Prompt> sie clock
The search returns each %Trick processed variable (including %Trick’s “sys” variables)
from your simulation that contains the search string. Beneath each variable returned
is information from its header file definition: user supplied description, type,
input/output spec, and units spec.
For a case-insensitive search (e.g., to find occurrences of “clock” and “Clock”),
simply specify the -nocase option.
@section LEVEL2 kill_sim
The following command will kill all simulations and their children that you own.
UNIX Prompt> kill_sim
@section LEVEL2 Current Trick Version
The following command echoes the installed %Trick version release:
UNIX Prompt> trick_version
@section LEVEL2 Checksumming
%Trick comes with a file that contains checksums for the %Trick package. You may run:
UNIX Prompt> trick_verify_checksums
at any time to see what, if any, files have changed from the original package. The checksum is
done on source files, not object code.
*/