mirror of
https://github.com/nasa/trick.git
synced 2025-01-05 04:44:16 +00:00
144 lines
5.5 KiB
Markdown
144 lines
5.5 KiB
Markdown
|
|
### 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.
|
|
|
|
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.
|
|
|
|
The command syntax for the ICG is as follows (with restrictions outlined afterward):
|
|
|
|
```
|
|
<b>UNIX Prompt></b> ICG [-d] [-D <define>] [-U <undefine>] <filename>.h
|
|
<b>UNIX Prompt></b> ICG -u
|
|
```
|
|
|
|
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.
|
|
|
|
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.
|
|
|
|
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.
|
|
|
|
In general, the following items are not processed by the ICG:
|
|
1. global parameters decalred outside of a struct, union, or enum typedef,
|
|
1. 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),
|
|
1. all parameters that have a "**" in the measurement units field of the parameter comment, and
|
|
1. all function declarations.
|
|
|
|
The ICG will always give the "ICG complete." message upon successful completion of processing.
|
|
|
|
### 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.
|
|
|
|
#### 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:
|
|
|
|
```
|
|
<b>UNIX Prompt></b> make_build [lib <lib_name>]
|
|
```
|
|
|
|
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.
|
|
|
|
#### 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:
|
|
|
|
```
|
|
<b>UNIX Prompt></b> make help
|
|
```
|
|
|
|
Additional documentation for make can be found in UNIX manuals for your workstation.
|
|
|
|
#### 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.
|
|
|
|
```
|
|
<b>UNIX Prompt></b> sie [-nocase] <search string>
|
|
```
|
|
|
|
As an example, if you know the parameter name contains clock but don't know
|
|
anything else, try:
|
|
|
|
```
|
|
<b>UNIX Prompt></b> 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.
|
|
|
|
### kill_sim
|
|
|
|
The following command will kill all simulations and their children that you own.
|
|
|
|
```
|
|
<b>UNIX Prompt></b> kill_sim
|
|
```
|
|
|
|
### Current Trick Version
|
|
|
|
The following command echoes the installed %Trick version release:
|
|
|
|
```
|
|
<b>UNIX Prompt></b> trick_version
|
|
```
|
|
|
|
### Checksumming
|
|
|
|
Trick comes with a file that contains checksums for the %Trick package. You may run:
|
|
|
|
```
|
|
<b>UNIX Prompt></b> 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.
|
|
|
|
[Continue to Python Variable Server Client](Python-Variable-Server-Client)
|