/* -*- Mode: c++ -*- * $Id: xotclTrace.c,v 1.8 2006/09/27 08:12:40 neumann Exp $ * * Extended Object Tcl (XOTcl) * * Copyright (C) 1999-2008 Gustaf Neumann, Uwe Zdun * * * xotclTrace.c -- * * Tracing facilities for XOTcl * */ #include "xotclInt.h" #include "xotclAccessInt.h" void XOTclStackDump(Tcl_Interp *interp) { Interp *iPtr = (Interp *)interp; CallFrame *f = iPtr->framePtr, *v = iPtr->varFramePtr; Tcl_Obj *varCmdObj; XOTclNewObj(varCmdObj); fprintf (stderr, " TCL STACK:\n"); if (f == 0) fprintf(stderr, "- "); while (f) { Tcl_Obj *cmdObj; XOTclNewObj(cmdObj); fprintf(stderr, "\tFrame=%p ", f); if (f && f->isProcCallFrame && f->procPtr && f->procPtr->cmdPtr) { fprintf(stderr,"caller %p ",Tcl_CallFrame_callerPtr(f)); fprintf(stderr,"callerV %p ",Tcl_CallFrame_callerVarPtr(f)); Tcl_GetCommandFullName(interp, (Tcl_Command) f->procPtr->cmdPtr, cmdObj); fprintf(stderr, "%s (%p) lvl=%d\n", ObjStr(cmdObj), f->procPtr->cmdPtr, f->level); DECR_REF_COUNT(cmdObj); } else { if (f && f->varTablePtr) { fprintf(stderr, "var_table = %p ",f->varTablePtr); } fprintf(stderr, "- \n"); } f = f->callerPtr; } fprintf (stderr, " VARFRAME:\n"); fprintf(stderr, "\tFrame=%p ", v); if (v) { fprintf(stderr, "caller %p var_table %p ", v->callerPtr, v->varTablePtr); /* if (v->varTablePtr) panic(0, "testing");*/ } if (v && v->isProcCallFrame && v->procPtr && v->procPtr->cmdPtr) { Tcl_GetCommandFullName(interp, (Tcl_Command) v->procPtr->cmdPtr, varCmdObj); if (varCmdObj) { fprintf(stderr, " %s (%d)\n", ObjStr(varCmdObj), v->level); } } else fprintf(stderr, "- \n"); DECR_REF_COUNT(varCmdObj); } void XOTclPrintObjv(char *string, int objc, Tcl_Obj *CONST objv[]) { int j; fprintf(stderr, "%s", string); for (j = 0; j < objc; j++) { /*fprintf(stderr, " objv[%d]=%s, ",j, objv[j] ? ObjStr(objv[j]) : "NULL");*/ fprintf(stderr, " objv[%d]=%s %p, ",j, objv[j] ? ObjStr(objv[j]) : "NULL", objv[j]); } fprintf(stderr, "\n"); } #ifdef XOTCL_MEM_COUNT void XOTclMemCountAlloc(char *id, void *p) { int new; XOTclMemCounter *entry; Tcl_HashTable *table = &xotclMemCount; Tcl_HashEntry *hPtr; hPtr = Tcl_CreateHashEntry(table, id, &new); #ifdef XOTCL_MEM_TRACE fprintf(stderr, "+++ alloc %s %p\n",id,p); #endif /*fprintf(stderr,"+++alloc '%s'\n",id);*/ if (new) { entry = (XOTclMemCounter*)ckalloc(sizeof(XOTclMemCounter)); entry->count = 1; entry->peak = 1; Tcl_SetHashValue(hPtr, entry); } else { entry = (XOTclMemCounter*) Tcl_GetHashValue(hPtr); entry->count++; if (entry->count > entry->peak) entry->peak = entry->count; } } void XOTclMemCountFree(char *id, void *p) { XOTclMemCounter *entry; Tcl_HashTable *table = &xotclMemCount; Tcl_HashEntry *hPtr; #ifdef XOTCL_MEM_TRACE fprintf(stderr, "+++ free %s %p\n",id,p); #endif hPtr = Tcl_FindHashEntry(table, id); if (!hPtr) { fprintf(stderr, "******** MEM COUNT ALERT: Trying to free <%s>, but was not allocated\n", id); return; } entry = (XOTclMemCounter *)Tcl_GetHashValue(hPtr); entry->count--; } void XOTclMemCountDump() { Tcl_HashTable *table = &xotclMemCount; Tcl_HashSearch search; Tcl_HashEntry *hPtr; int count = 0; xotclMemCountInterpCounter--; if (xotclMemCountInterpCounter != 0) { return; } fprintf(stderr, "******** XOTcl MEM Count *********\n* count peak\n"); for (hPtr = Tcl_FirstHashEntry(table, &search); hPtr != NULL; hPtr = Tcl_NextHashEntry(&search)) { char *id = Tcl_GetHashKey(table, hPtr); XOTclMemCounter *entry = (XOTclMemCounter*) Tcl_GetHashValue(hPtr); count += entry->count; fprintf(stderr, "* %4d %6d %s\n", entry->count, entry->peak, id); ckfree ((char*) entry); } Tcl_DeleteHashTable(table); fprintf(stderr, "******** Count Overall = %d\n", count); } #endif