diff options
| author | andreask@activestate.com <andreas_kupries> | 2008-07-22 21:40:03 (GMT) |
|---|---|---|
| committer | andreask@activestate.com <andreas_kupries> | 2008-07-22 21:40:03 (GMT) |
| commit | 4f36cf3dcfdb87284f5154580b01735c2cac5357 (patch) | |
| tree | cef9d19da7d093c66b64a11ba40714de761a2840 /generic/tclCompile.h | |
| parent | 875b561cd1d61a30573b9ca77ffed32f9c094709 (diff) | |
| download | tcl-4f36cf3dcfdb87284f5154580b01735c2cac5357.zip tcl-4f36cf3dcfdb87284f5154580b01735c2cac5357.tar.gz tcl-4f36cf3dcfdb87284f5154580b01735c2cac5357.tar.bz2 | |
* generic/tclBasic.c: Reworked the handling of bytecode literals
* generic/tclCompile.c: for #280 to fix the abysmal performance
* generic/tclCompile.h: for deep recursion, replaced the linear
* generic/tclExecute.c: search through the whole stack with
* generic/tclInt.h: another hashtable and simplified the data
structure used by the compiler (array instead of hashtable).
Incidentially this also fixes the memory leak reported via [Bug
2024937].
Diffstat (limited to 'generic/tclCompile.h')
| -rw-r--r-- | generic/tclCompile.h | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/generic/tclCompile.h b/generic/tclCompile.h index 8192aa4..adde52c 100644 --- a/generic/tclCompile.h +++ b/generic/tclCompile.h @@ -9,7 +9,7 @@ * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclCompile.h,v 1.33.2.3 2008/07/21 19:37:43 andreas_kupries Exp $ + * RCS: @(#) $Id: tclCompile.h,v 1.33.2.4 2008/07/22 21:40:31 andreas_kupries Exp $ */ #ifndef _TCLCOMPILATION @@ -146,12 +146,10 @@ typedef struct ExtCmdLoc { ECL* loc; /* Command word locations (lines) */ int nloc; /* Number of allocated entries in 'loc' */ int nuloc; /* Number of used entries in 'loc' */ - Tcl_HashTable litIndex; /* HashValue is ExtIndex* */ + ExtIndex* eiloc; + int neiloc; + int nueiloc; } ExtCmdLoc; -typedef struct ExtIndex { - int pc; /* Instruction pointer of the command in ExtCmdLoc.loc[.] */ - int word; /* Index of word in ExtCmdLoc.loc[cmd]->line[.] */ -} ExtIndex; EXTERN void TclEnterCmdWordIndex _ANSI_ARGS_(( ExtCmdLoc *eclPtr, Tcl_Obj* obj, int pc, int word)); |
