CINT(1) CINT(1)
NAME
cint - C/C++ interpreter
DESCRIPTION
"cint" is a C/C++ interpreter. About 95% of ANSI C and
90% of C++ features are covered. (Data abstraction, class
inheritance, virtual function, function and operator over-
loading, default parameter, template, etc...) Cint has
source code debugger for interpreted source code and it
has sufficient capability for debugging a C++ script.
CINT AND MAKECINT
Cint can be used just as it is, but it is recommended to
use makecint. Makecint can encapsulate native C/C++
objects into Cint as precompiled libraries. User defined
precompiled objects can be accessed from the interpreter
and a user application can invoke C/C++ interpreter as
interactive interface. It provides seamless compiler/interpreter
scripting environment. Precompiled libraries can be dynamically
loaded/unloaded if they are configured as Dynamic Link Library
(DLL). SEE ALSO MAKECINT(1)
SYNOPSIS
cint <[options]> <[sourcefiles]|[suboption]> <[arguments]>
[options] (* : used only with makecint or -c option)
-A : ANSI C++ mode(default)
-b [line] : set break line
* -c -1: make C++ precompiled interface method files
* -c -2: make C precompiled interface method files
* -c -10: make C++ precompiled interface method files. Default link off
* -c -20: make C precompiled interface method files. Default link off
* -c -11: make C++ precompiled interface method files. Default link on
* -c -21: make C precompiled interface method files. Default link on
-C : copy src to $TMPDIR so that src can be change during cint run
-d [dumpfile] : dump function call history
-D [macro] : define macro symbol for #ifdef
-e : Not ignore extern declarations
-E : Dump core at error
-E -E : Exit process at error and uncaught exception
-f [file] : set break file
-F [assignement] : set global variable
-G [tracedmp] : dump exec trace into file
-i : interactively return undefined symbol value
-I [includepath] : set include file search path
-j [0|1]: Create multi-thread safe DLL(experimental)
-J[0-4] : Display nothing(0)/error(1)/warning(2)/note(3)/all(4)
-K : C mode
-l [dynamiclinklib] : link dynamic link library
-m : Support 8bit char comment (Disable multi-byte char)
* -n [linkname] : Specify precompiled interface method filename
* -N [DLL_name] : Specify DLL interface method name
-O [0~4] : Loop compiler on(1~5) off(0). Default on(4)
-Q : Quiet mode (no prompt)
-p : use preprocessor prior to interpretation
-q [security] : Set security level(default 0)
-r : revision and linked function/global info
-R : display input file at break point
-s : step execution mode
-S : step execution mode, First stop in main()
-t : trace execution
-T : trace from pre-run
* -u [undefout] : listup possible undefined typenames
* -U [dir] : directory to disable interface method generation
* -V : Generate symbols for non-public member with -c option
-v : Bytecode compiler debug mode
-X [readlinedumpfile] : Execute readline dumpfile
-x 'main() {...}' : Execute argument as source code
-Y [0|1] : ignore(1) not ignore(0) std namespace
-Z [0|1]: auto loading of std hdr files with DLL
--'command': Execute interactive command and terminate Cint
[sourcefiles]
Cint directly accepts C/C++ source file. If you give mul-
tiple source files, main() function must be included in
the last one. If source file is omitted or main() function
is not found in given source file, cint automatically
starts interactive interface.
Cint reads source file on-the-fly from the file system.
Do not change the active source files during cint run.
[suboptions] (* : used only with makecint or -c option)
Suboptions are options which appears in between source files.
+V : turn on class title comment mode for following source fies
-V : turn off class title comment mode for following source fies
+P : turn on preprocessor for following source files
-P : turn off preprocessor for following source files
* +STUB : stub function header begin
* -STUB : stub function header end
[arguments]
Arguments to main(int argc,char *argv[]) function.
EXAMPLE
$ cint
$ cint lib1.c lib2.c source.c
$ cint -S -I../include -DDEBUG source.c
$ cint -x 'main(int argc,char *argv[]){printf("%s\n",argv[1]);}'
$ cint -qlevel1 myprog.C
LANGUAGE LIMITATIONS
Refer to doc/limitati.txt
DEBUG MODE
Cint starts debug mode at following situation.
* main() function is not included in the given source file.
* Step execution mode (-S,-s option)
* Program reaches to a break point
* Keyboard interrupt (CTL-C or Break)
* Explicit call of interactive interface function G__pause().
* Bus error or segmentation violation occurred.
# GNU readline
GNU readline library , if exists, is used as command line
front-end processor. It can perform command line editing
and name completion.
# Debug mode command
You can perform step and trace execution, locate as many
break points as you want, look into function/vari-
able/class information tables, etc... Use of following
debug mode commands enables you to do these things.
Cint's debug mode can only debug interpreted source code.
You need to use a binary level debugger to debug pre-com-
piled library. Cint can be used with any kind of binary
level debugger such as xdb,gdb.
cint (C/C++ interpreter) debugger usage:
Dump: n [file] : create new readline dumpfile and start dump
y [file] : append readline dump to [file]
z : stop readline dump
< [file] : execute readline dumpfile
> [file] : output redirect to [file]
2> [file] : error redirect to [file]
. : switch command input mode
Help: ? : help
help : help
/[keyword] : help information for keyword
Completion: [nam][Tab] : complete symbol name start with [nam]
[nam][Tab][Tab] : list up all symbol name start with [nam]]
Shell: ![shell] : execute shell command
Source: v <[line]>: view source code <around [line]>
V [stack] : view source code in function call stack
t : show function call stack
f [file] : select file to debug
T : turn on/off trace mode for all source
J [stat] : Set warning level [0-5]
A [1|0] : allowing automatic variable on/off
trace <classname> : turn on trace mode for class
deltrace <classname> : turn off trace mode for class
break [classname] : set break point at every [classname]
memberfunc
delbreak [classname] : turn off memberfunc break point
Evaluation: p [expr] : evaluate expression
(no declaration/loop/condition)
s [expr] : step into expression
(no declaration/loop/condition)
S [expr] : step over expression
(no declaration/loop/condition)
{[statements]} : evaluate statement (any kind)
x [file] : load [file] and evaluate {statements} in the
file
X [file] : load [file] and execute function [file]
(wo extension)
E <[file]>: open editor and evaluate {statements} in the
file
Load/Unload: L [file] : load [file]
La [file] : reload all files loaded after [file]
U [file] : unload [file]
C [1|0] : copy source to $TMPDIR (on/off)
reset : reset interpreter environment
undo : undo previous declarations
lang : local langguage (EUC,SJIS,EUROPEAN,UNKNOWN)
Monitor: g <[var]> : list global variable
l <[var]> : list local variable
proto <[scope]::>[func] : show function prototype
class <[name]> : show class definition (one level)
Class <[name]> : show class definition (all level)
typedef <name> : show typedefs
function : show interpreted functions
macro : show macro functions
template : show templates
include : show include paths
file : show loaded files
where : show current file position
security : show security level
refcount : reference count control on/off
garbage : show garbage collection buffer
Garbage : Do garbage collection
cover [file] : save trace coverage
return [val] : return undefined symbol value
Run: S : step over function/loop
s : step into function/loop
i : ignore and step over
c <[line]>: continue <to [line]>
e : step out from function
f [file] : select file to debug
b [line] : set break point
db [line] : delete break point
a [assert]: break only if assertion is true
O [0~4] : Set bytecode compiler mode
debug : bytecode status display on/off
asmstep : bytecode step mode on/off
status : show bytecode exec flags
dasm : disassembler
Quit: q : quit cint
qqq : quit cint - mandatory
ENVIRONMENT VARIABLE
You need to set following environment variables. If you
install cint into /usr/local/cint directory, for example,
ksh/bsh
CINTSYSDIR=/usr/local/cint
export CINTSYSDIR
# or where you have installed cint
csh
setenv CINTSYSDIR /usr/local/cint
# or where you have installed cint
CINT INSTALLATION
Refer to $CINTSYSDIR/README.txt and $CINTSYSDIR/plat-
form/README.txt.
SEE ALSO
doc/makecint.txt
AUTHOR
Masaharu Goto (root-cint@cern.ch)
Copyright (c) 1995~2000 Masaharu Goto