Index: ChangeLog =================================================================== diff -u -r86b45d1aba7bf53648f1de40b6975696e603bf89 -re308078f0e97d3ab61462fa52333f97f32a72ca7 --- ChangeLog (.../ChangeLog) (revision 86b45d1aba7bf53648f1de40b6975696e603bf89) +++ ChangeLog (.../ChangeLog) (revision e308078f0e97d3ab61462fa52333f97f32a72ca7) @@ -1,3 +1,9 @@ +2010-08-29 + * Fixed bug in filters reported by Kristoffer Lawson. When a + filter chain reaches its end without finding the invoked method, + the unknown state was not resetted correctly and affected + method invocations in the filter after "next". + 2009-11-13 * Release of XOTcl 1.6.6 Index: generic/xotcl.c =================================================================== diff -u -r1ffc14ff17a11e88e2796f196e5538d636bdd6ab -re308078f0e97d3ab61462fa52333f97f32a72ca7 --- generic/xotcl.c (.../xotcl.c) (revision 1ffc14ff17a11e88e2796f196e5538d636bdd6ab) +++ generic/xotcl.c (.../xotcl.c) (revision e308078f0e97d3ab61462fa52333f97f32a72ca7) @@ -5681,7 +5681,15 @@ methodName, frameType)) == TCL_ERROR) { result = XOTclErrInProc(interp, cmdName, cl ? cl->object.cmdName : NULL, methodName); } - unknown = RUNTIME_STATE(interp)->unknown; + + if (RUNTIME_STATE(interp)->unknown && (frameType & XOTCL_CSC_TYPE_ACTIVE_FILTER)) { + /*fprintf(stderr, "use saved unknown %d frameType %.6x\n", + RUNTIME_STATE(interp)->unknown, frameType);*/ + unknown = 1; + } else { + unknown = 0; + } + } else { unknown = 1; } @@ -5699,11 +5707,11 @@ */ XOTclObject *obj = (XOTclObject*)cd; ALLOC_ON_STACK(Tcl_Obj*, objc+1, tov); - /* - fprintf(stderr,"calling unknown for %s %s, flgs=%02x,%02x isClass=%d %p %s\n", - ObjStr(obj->cmdName), ObjStr(objv[1]), flags, XOTCL_CM_NO_UNKNOWN, - XOTclObjectIsClass(obj), obj, ObjStr(obj->cmdName)); - */ + + /*fprintf(stderr,"... calling unknown for %s %s, flgs=%02x,%02x isClass=%d %p %s\n", + ObjStr(obj->cmdName), ObjStr(objv[1]), flags, XOTCL_CM_NO_UNKNOWN, + XOTclObjectIsClass(obj), obj, ObjStr(obj->cmdName));*/ + tov[0] = obj->cmdName; tov[1] = XOTclGlobalObjects[XOTE_UNKNOWN]; if (objc>1)