CINT(API) 


CAUTION:  Please refer to doc/ref.txt. This file is getting old.


 This document describes CINT C/C++ interpreter API functions.



CINT API functions
        Following  functions  are  supplied by cint for debugging
       and source code analysis purposes.

            char *G__input(const char *prompt);
            int G__pause();
            int G__tracemode(int on_off);
            int G__setbreakpoint(char *breakline,char *breakfile);
            int G__stepmode(int on_off);
            [anytype] G__calc(const char *expression);
            [anytype] G__exec_tempfile(const char *file);
            int G__loadfile(const char *file);
            int G__unloadfile(const char *file);
            int G__reloadfile(const char *file);
            char *G__search_next_member(const char *name,int state);
            void *G__what_type(const char *name,char *type,char *tagname,char *typename);
            int G__lock_variable(char *varname);
            int G__unlock_variable(char *varname);
            G__graph(double xdata[],double ydata[],int ndata,char *title,int mode);

# char *G__input(const char *prompt);

        G__input() reads keyboard input. It  returns  pointer  to
       char  declared  as  static  opject  in G__pause(). So, the
       returned pointer must not be freed.

            main() {  // example program
                 char *command;
                 while(1) {
                      command = G__input("input command > ");
                      if(strcmp(command,"exit")==0) exit();
                      system(command);
                 }
            }

# int G__pause();

       When  G__pause()  is  called,  interactive  interface  is
       started.   Debug commands can be used.  G__pause() returns
       1 if 'I' command is given.   So  you  can  repeat  calling
       G__pause() until 'i' input by following example.

         while(G__pause()==0);

# int G__tracemode(int on_off);

      G__tracemode() sets trace mode.

# int G__breakline(int line);

      G__breakline()  sets break point.  If 0 is given as argument, 
      break point is cleared.

# int G__stepmode(int on_off);

       G__stepmode() switchs on/off step execution mode.


# [anytype] G__calc(char *expression);

        G__calc() evaluates C expression.  It returns the type of
       object  the  argument  expression  returns.  Variables and
       function calls can be used in  the  expression.   Declara-
       tion,  loop  and  conditional statement can not be used in
       the expression.

            int i;
            double a;
            i = G__calc("1+2+3");  // returns int
            a = G__calc("3.14*i");  // returns double

# [anytype] G__exec_tempfile(char *file);

        G__exec_tempfile() opens temporal source file and execute
       it  in  the  current  context.   The tempfile can contain,
       variable   declaration,   struct,union,enum    definition.
       expression,  loop and control statement and cannot contain
       function definition.  G__exec_tempfile() executes a state-
       ment or statement list surrounded by '{' , '}' and returns
       the last evaluated value.

            {    // example of tempfile
                 int i;
                 double ary[100];
                 for(i=0;i<100;i++) ary[i] = i;
            }

       Then in the main program, you can execute above  statement
       by G__exec_tempfile.


# int G__loadfile(const char *file);

        G__loadfile() incrementally loads source file. If file

# int G__unloadfile(const char *file);

        G__unloadfile()  unloads source file. If any of the func-
       tions  included  in  the  file  is  busy,  G__unloadfile()
       returns error code (-1) and won't unload it.

# int G__reloadfile(const char *file);

        G__reloadfile() does G__unloadfile() and G__loadfile() at
       once.

# char *G__search_next_member(const char *name,int state);

        G__search_next_member() searches for function  and  vari-
       able  name in current scope which start with name. state=0
       must be given at the first call of G__search_next_member()
       for  initialization.  In consequitive calls, state must be 1.
        G__search_next_member() returns malloced pointer. If  you
       call  this  function, you must free() the returned pointer
       afterwards.

# void *G__what_type(const char *name,char *type,char  *tagname
                     ,char *typename);

        G__what_type()  returns  pointer  and type information of
       the object of name.  Sufficient length of  string  pointer
       must be given to typa,tagname and typename argument.

# int  G__lock_variable(char  *varname); 
# int G__unlock_variable(char *varname);

       (THIS CAPABILITY IS OBSOLETED IN CINT-5.14.5)
        G__lock_variable()   and   G__unlock_variable()   control
       assignment  locking.  Assignement to specific variable can
       be locked/unlocked.

# G__graph(double  xdata[],double   ydata[],int   ndata,char *title,int mode);

        G__graph()  uses  xgraph  to  plot 2 dimentinal graph. If
       mode is 0, G__graph() waits for xgraph process to be  ter-
       minated. If mode is 1, xgraph becomes a background job. If
       mode is 3, G__graph() appends x and y data  to  "G__graph"
       file and will not invoke xgraph process.



# ERTTI (Extensive Run Time Type Identification)
        Many people are interested in Cint as basement for build-
       ing class browser or program analyzer. For  those  people,
       ERTTI  API which gives an access to Cint's symbol table is
       a useful interface. Information about ERTTI is  documented
       in doc/ref.txt



# pragma compile
        Source  file  can  be partially compiled by '#pragma com-
       pile' statement.  In the following example, 'int globals;'
       and  'func()'  are  compiled  when they are updated.  When
       this program  is  first  executed  by  cint,  makecint  is
       invoked  and  source  code surrounded by '#pragma compile'
       and '#pragma endcompile' will be compiled into  a  dynamic
       link library 'G__autocc.sl'. The G__autocc.sl is automati-
       cally loaded and compiled version of 'func()' will be exe-
       cuted.
        This feature is only available on HP-UX 8.0 or later ver-
       sion.

            // #pragma disablecomppile
            #pragma compile
            int globals; /* this global variable is compiled */
            #pragma endcompile

            main(int argc,char **argv) {
                 func(argv[1]);
            }

            #pragma compile
            int func(char *string)
            {
                 /* this function is compiled and dynamically linked */
            }


    #pragma compile
        Specifies beginning of compiled  section  which  must  be
       ended by '#pragma endcompile'. Multiple compile,endcompile
       pair can appear in the source code.

    #pragma endcompile
        Specifies end of compiled section.

    #pragma disablecompile
        Turn off '#pragma compile'. Pragma compile is  turned  on
       by  default. '#pragma disablecompile' must be described if
       you turn off the mode.

    #pragma enablecompile
        Turn on '#pragma compile'.




Undeclared symbol
        Cint can execute C code which  includes  undeclared  sym-
       bols.   Undeclared  symbols  are  detected  and handled by
       interpreter at run time.  As cint detects undeclared  sym-
       bols, warning message is printed out and execution will be
       continued.

       Assigning to undeclared variable:
        If assignment to undeclared variable appears, cint  allo-
       cates  automatic  variable.  If assignment value is double
       or float, double type variable is  allocated.   Otherwise,
       int  type  variable  is allocated.  For example, following
       program works as intended.

            main() {
                 double dat[10];
                 for(i=0;i<10;i++) {    /* i allocated as int */
                      dat[i]=i;
                      sum += dat[i]; /* sum allocated as double */
                 }
                 printf("sum=%g\n",sum);
            }

       If undeclared symbol first appears as array form, array of
       appropriate  size  will  be  allocated.   For  example, if
       'data[1][10]=3.14' appears without declaration of 'data' ,
       'double  data[2][11]'  is allocated and 'data[1][10]=3.14'
       is assigned.  Array can not be expanded  after  the  auto-
       matic  allocation.  So, 'data[2][15]=15;' will be rejected
       because array index is out of range.

            main() {
                 data[1][10]=3.14;  // double data[2][11]; data[1][10]=3.14;
                 data[0][3]=153.3;  // OK
                 data[2][15]=-15.0; // rejected, array can not be expanded
            }

       Pointer to automatically allocated  variable  can  not  be
       used.   If  undeclared  variable  appears with referencing
       operator '*' or '&', these operators are ignored.

       Referencing undeclared variable:
        If undeclared variable is referenced, cint  returns  NULL
       or zero as its value.

       Undeclared function:
        If  undeclared  function is called, it is simply skipped.
       Parameter list will be evaluated.

            main() {
                 int i=0;
                 undeclaredfunc(i++); // function call skipped
                 // i is 1 here because i++ was evaluated above
            }





BUGS
        Report  bugs  and  requirements  to root-cint@cern.ch. Bugs
       tend to be fixed very quickly. Any  kind  of  comments  or
       messages will be appreciated.

SEE ALSO
            doc/makecint.txt 


AUTHOR
       Masaharu Goto  (root-cint@cern.ch)
       Copyright  (c)  1995~1999 Masaharu Goto
















































2                            function                           6