/* * itcl.h -- * * This file contains definitions for the C-implemeted part of a Itcl * this version of [incr Tcl] (Itcl) is a completely new implementation * based on TclOO extension of Tcl 8.5 * It tries to provide the same interfaces as the original implementation * of Michael J. McLennan * Some small pieces of code are taken from that implementation * * Copyright (c) 2007 by Arnulf P. Wiedemann * * See the file "license.terms" for information on usage and redistribution of * this file, and for a DISCLAIMER OF ALL WARRANTIES. */ /* * ------------------------------------------------------------------------ * PACKAGE: [incr Tcl] * DESCRIPTION: Object-Oriented Extensions to Tcl * * [incr Tcl] provides object-oriented extensions to Tcl, much as * C++ provides object-oriented extensions to C. It provides a means * of encapsulating related procedures together with their shared data * in a local namespace that is hidden from the outside world. It * promotes code re-use through inheritance. More than anything else, * it encourages better organization of Tcl applications through the * object-oriented paradigm, leading to code that is easier to * understand and maintain. * * ADDING [incr Tcl] TO A Tcl-BASED APPLICATION: * * To add [incr Tcl] facilities to a Tcl application, modify the * Tcl_AppInit() routine as follows: * * 1) Include this header file near the top of the file containing * Tcl_AppInit(): * * #include "itcl.h" * * 2) Within the body of Tcl_AppInit(), add the following lines: * * if (Itcl_Init(interp) == TCL_ERROR) { * return TCL_ERROR; * } * * 3) Link your application with libitcl.a * * NOTE: An example file "tclAppInit.c" containing the changes shown * above is included in this distribution. * *--------------------------------------------------------------------- */ #ifndef ITCL_H_INCLUDED #define ITCL_H_INCLUDED #include #if (TCL_MAJOR_VERSION == 8) && (TCL_MINOR_VERSION < 6) # error Itcl 4 build requires tcl.h from Tcl 8.6 or later #endif /* * For C++ compilers, use extern "C" */ #ifdef __cplusplus extern "C" { #endif #ifndef TCL_ALPHA_RELEASE # define TCL_ALPHA_RELEASE 0 #endif #ifndef TCL_BETA_RELEASE # define TCL_BETA_RELEASE 1 #endif #ifndef TCL_FINAL_RELEASE # define TCL_FINAL_RELEASE 2 #endif #define ITCL_MAJOR_VERSION 4 #define ITCL_MINOR_VERSION 0 #define ITCL_RELEASE_LEVEL TCL_FINAL_RELEASE #define ITCL_RELEASE_SERIAL 3 #define ITCL_VERSION "4.0" #define ITCL_PATCH_LEVEL "4.0.3" /* * A special definition used to allow this header file to be included from * windows resource files so that they can obtain version information. * RC_INVOKED is defined by default by the windows RC tool. * * Resource compilers don't like all the C stuff, like typedefs and function * declarations, that occur below, so block them out. */ #ifndef RC_INVOKED #define ITCL_NAMESPACE "::itcl" #ifndef ITCLAPI # if defined(BUILD_itcl) # define ITCLAPI MODULE_SCOPE # else # define ITCLAPI extern # undef USE_ITCL_STUBS # define USE_ITCL_STUBS 1 # endif #endif #if defined(BUILD_itcl) && !defined(STATIC_BUILD) # define ITCL_EXTERN extern DLLEXPORT #else # define ITCL_EXTERN extern #endif ITCL_EXTERN int Itcl_Init(Tcl_Interp *interp); ITCL_EXTERN int Itcl_SafeInit(Tcl_Interp *interp); /* * Protection levels: * * ITCL_PUBLIC - accessible from any namespace * ITCL_PROTECTED - accessible from namespace that imports in "protected" mode * ITCL_PRIVATE - accessible only within the namespace that contains it */ #define ITCL_PUBLIC 1 #define ITCL_PROTECTED 2 #define ITCL_PRIVATE 3 #define ITCL_DEFAULT_PROTECT 4 /* * Generic stack. */ typedef struct Itcl_Stack { ClientData *values; /* values on stack */ int len; /* number of values on stack */ int max; /* maximum size of stack */ ClientData space[5]; /* initial space for stack data */ } Itcl_Stack; #define Itcl_GetStackSize(stackPtr) ((stackPtr)->len) /* * Generic linked list. */ struct Itcl_List; typedef struct Itcl_ListElem { struct Itcl_List* owner; /* list containing this element */ ClientData value; /* value associated with this element */ struct Itcl_ListElem *prev; /* previous element in linked list */ struct Itcl_ListElem *next; /* next element in linked list */ } Itcl_ListElem; typedef struct Itcl_List { int validate; /* validation stamp */ int num; /* number of elements */ struct Itcl_ListElem *head; /* previous element in linked list */ struct Itcl_ListElem *tail; /* next element in linked list */ } Itcl_List; #define Itcl_FirstListElem(listPtr) ((listPtr)->head) #define Itcl_LastListElem(listPtr) ((listPtr)->tail) #define Itcl_NextListElem(elemPtr) ((elemPtr)->next) #define Itcl_PrevListElem(elemPtr) ((elemPtr)->prev) #define Itcl_GetListLength(listPtr) ((listPtr)->num) #define Itcl_GetListValue(elemPtr) ((elemPtr)->value) /* * Token representing the state of an interpreter. */ typedef struct Itcl_InterpState_ *Itcl_InterpState; /* * Include all the public API, generated from itcl.decls. */ #include "itclDecls.h" #ifdef ITCL_PRESERVE_DEBUG #undef Itcl_PreserveData #undef Itcl_ReleaseData void ItclDbgPreserveData(ClientData cdata, int line, const char *file); void ItclDbgReleaseData(ClientData cdata, int line, const char *file); #define Itcl_PreserveData(addr) ItclDbgPreserveData(addr, __LINE__, __FILE__) #define Itcl_ReleaseData(addr) ItclDbgReleaseData(addr, __LINE__, __FILE__) #endif #endif /* RC_INVOKED */ /* * end block for C++ */ #ifdef __cplusplus } #endif #endif /* ITCL_H_INCLUDED */