summaryrefslogtreecommitdiffstats
path: root/generic/tclExecute.c
diff options
context:
space:
mode:
authorMiguel Sofer <miguel.sofer@gmail.com>2007-06-09 20:12:53 (GMT)
committerMiguel Sofer <miguel.sofer@gmail.com>2007-06-09 20:12:53 (GMT)
commita4338c631ef67bfe928e7764ab1fc89d0a3a2e62 (patch)
treec9cb6877f88fcbfad1512aa0fd12c16dc9738a77 /generic/tclExecute.c
parentc17b51664c1993d118f7a0611afc339d8e84d1c3 (diff)
downloadtcl-a4338c631ef67bfe928e7764ab1fc89d0a3a2e62.zip
tcl-a4338c631ef67bfe928e7764ab1fc89d0a3a2e62.tar.gz
tcl-a4338c631ef67bfe928e7764ab1fc89d0a3a2e62.tar.bz2
* generic/tclBasic.c: Split TEOv in two, by separating a
processor for non-TCL_OK returns. Also spli TEOvI in a full version that handles non-existing and traced commands, and a separate shorter version for the regular case. * generic/tclBasic.c: Moved the generation of command strings for * generic/tclTrace.c: traces: previously in Tcl_EvalObjv(), now in TclCheck[Interp|Execution]Traces(). Also insured that the strings are properly nul terminated at the correct length [Bug 1693986] * generic/tclBasic.c: Extend usage of TclLimitReady() and * generic/tclExecute.c: (new) TclLimitExceeded() macros. * generic/tclInt.h: * generic/tclInterp.c: * generic/tclInt.h: New TclCleanupCommandMacro for core usage. * generic/tclBasic.c: * generic/tclExecute.c: * generic/tclObj.c:
Diffstat (limited to 'generic/tclExecute.c')
-rw-r--r--generic/tclExecute.c45
1 files changed, 3 insertions, 42 deletions
diff --git a/generic/tclExecute.c b/generic/tclExecute.c
index 7531b99..f08333d 100644
--- a/generic/tclExecute.c
+++ b/generic/tclExecute.c
@@ -12,7 +12,7 @@
* See the file "license.terms" for information on usage and redistribution of
* this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
- * RCS: @(#) $Id: tclExecute.c,v 1.286 2007/06/05 17:50:55 msofer Exp $
+ * RCS: @(#) $Id: tclExecute.c,v 1.287 2007/06/09 20:12:55 msofer Exp $
*/
#include "tclInt.h"
@@ -343,26 +343,6 @@ long tclObjsShared[TCL_MAX_SHARED_OBJ_STATS] = { 0, 0, 0, 0, 0 };
#endif
/*
- * Inline version of Tcl_LimitReady() to limit number of calls out of this
- * file in the critical path. Note that this code isn't particularly readable;
- * the non-inline version (in tclInterp.c) is much easier to understand. Note
- * also that this macro takes different args (iPtr->limit) to the non-inline
- * version.
- */
-
-#define TclLimitReady(limit) \
- (((limit).active == 0) ? 0 : \
- (++(limit).granularityTicker, \
- ((((limit).active & TCL_LIMIT_COMMANDS) && \
- (((limit).cmdGranularity == 1) || \
- ((limit).granularityTicker % (limit).cmdGranularity == 0))) \
- ? 1 : \
- (((limit).active & TCL_LIMIT_TIME) && \
- (((limit).timeGranularity == 1) || \
- ((limit).granularityTicker % (limit).timeGranularity == 0)))\
- ? 1 : 0)))
-
-/*
* Custom object type only used in this file; values of its type should never
* be seen by user scripts.
*/
@@ -1646,26 +1626,7 @@ TclExecuteByteCode(
iPtr->cmdCount += TclGetUInt4AtPtr(pc+5);
if (!checkInterp) {
instStartCmdOK:
-#if 0 && !TCL_COMPILE_DEBUG
- /*
- * Peephole optimisations: check if there are several
- * INST_START_CMD in a row. Many commands start by pushing a
- * literal argument or command name; optimise that case too.
- *
- * TODO: Compiler no longer generates sequences of INST_START_CMD,
- * so maybe take some of this peephole out.
- */
-
- while (*(pc += 9) == INST_START_CMD) {
- iPtr->cmdCount += TclGetUInt4AtPtr(pc+5);
- }
- if (*pc == INST_PUSH1) {
- goto instPush1Peephole;
- }
- NEXT_INST_F(0, 0, 0);
-#else
NEXT_INST_F(9, 0, 0);
-#endif
} else if (((codePtr->compileEpoch == iPtr->compileEpoch)
&& (codePtr->nsEpoch == namespacePtr->resolverEpoch))
|| (codePtr->flags & TCL_BYTECODE_PRECOMPILED)) {
@@ -1959,7 +1920,7 @@ TclExecuteByteCode(
iPtr->ensembleRewrite.sourceObjs = NULL;
result = (*cmdPtr->objProc)(cmdPtr->objClientData, interp,
objc, objv);
- TclCleanupCommand(cmdPtr);
+ TclCleanupCommandMacro(cmdPtr);
if (Tcl_AsyncReady()) {
result = Tcl_AsyncInvoke(interp, result);
}
@@ -6613,7 +6574,7 @@ TclExecuteByteCode(
* is not exceeded) or we get to the top-level.
*/
- if (Tcl_LimitExceeded(interp)) {
+ if (TclLimitExceeded(iPtr->limit)) {
#ifdef TCL_COMPILE_DEBUG
if (traceInstructions) {
fprintf(stdout, " ... limit exceeded, returning %s\n",