mirror of
https://github.com/nasa/trick.git
synced 2025-01-07 13:48:43 +00:00
165 lines
6.5 KiB
Plaintext
165 lines
6.5 KiB
Plaintext
/**
|
||
@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
|
||
<tt><b>UNIX Prompt></b> ICG [-d] [-D <define>] [-U <undefine>] <filename>.h</tt><br>
|
||
<tt><b>UNIX Prompt></b> ICG -u</tt>
|
||
|
||
@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_<file_name>.c; where “io_” is a
|
||
standard prefix for all ICG generated files, and <file_name> 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:
|
||
|
||
<tt><b>UNIX Prompt></b> make_build [lib <lib_name>]</tt>
|
||
|
||
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 <lib_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:
|
||
|
||
<tt><b>UNIX Prompt></b> make help</tt>
|
||
|
||
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.
|
||
|
||
<tt><b>UNIX Prompt></b> sie [-nocase] <search string></tt>
|
||
|
||
As an example, if you know the parameter name contains clock but don’t know
|
||
anything else, try:
|
||
|
||
<tt><b>UNIX Prompt></b> sie clock</tt>
|
||
|
||
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.
|
||
|
||
<tt><b>UNIX Prompt></b> kill_sim</tt>
|
||
|
||
@section LEVEL2 Current Trick Version
|
||
|
||
The following command echoes the installed %Trick version release:
|
||
|
||
<tt><b>UNIX Prompt></b> trick_version</tt>
|
||
|
||
@section LEVEL2 Checksumming
|
||
|
||
%Trick comes with a file that contains checksums for the %Trick package. You may run:
|
||
|
||
<tt><b>UNIX Prompt></b> trick_verify_checksums</tt>
|
||
|
||
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.
|
||
|
||
|
||
*/
|