Index: TODO =================================================================== diff -u -r156a002c09a06c6602f12d6f2f73038fa100b66e -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- TODO (.../TODO) (revision 156a002c09a06c6602f12d6f2f73038fa100b66e) +++ TODO (.../TODO) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -4997,6 +4997,7 @@ and we could not find any script that uses this - renamed "-methodprefix" to "-prefix" in nx, since the prefix can be applied as well applied to a cmd. +- use nx rather than xotcl2 terminology in nsf::method::forward nsf.c: - de-spaghetti precedence computations for multiple inheritance and Index: generic/nsf.c =================================================================== diff -u -r156a002c09a06c6602f12d6f2f73038fa100b66e -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- generic/nsf.c (.../nsf.c) (revision 156a002c09a06c6602f12d6f2f73038fa100b66e) +++ generic/nsf.c (.../nsf.c) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -127,7 +127,7 @@ int hasNonposArgs; int nr_args; Tcl_Obj *args; - int objframe; + int frame; #if defined(NSF_FORWARD_WITH_ONERROR) Tcl_Obj *onerror; #endif @@ -315,7 +315,7 @@ nonnull(1); static int ForwardProcessOptions(Tcl_Interp *interp, Tcl_Obj *nameObj, Tcl_Obj *withDefault, int withEarlybinding, Tcl_Obj *withMethodprefix, - int withObjframe, int withVerbose, + int withFrame, int withVerbose, Tcl_Obj *target, int objc, Tcl_Obj * CONST objv[], ForwardCmdClientData **tcdPtr) nonnull(1) nonnull(2) nonnull(8) nonnull(10); @@ -13178,7 +13178,7 @@ methodObj = paramPtr->nameObj; result = ForwardProcessOptions(interp, methodObj, NULL /*withDefault*/, 0 /*withEarlybinding*/, - NULL /*withMethodprefix*/, 0 /*withObjframe*/, + NULL /*withMethodprefix*/, 0 /*withFrame*/, 0 /*withVerbose*/, nobjv[0], nobjc-1, nobjv+1, &tcd); if (result != TCL_OK) { @@ -14225,7 +14225,7 @@ static int ForwardProcessOptions(Tcl_Interp *interp, Tcl_Obj *nameObj, Tcl_Obj *withDefault, int withEarlybinding, Tcl_Obj *withMethodprefix, - int withObjframe, int withVerbose, + int withFrame, int withVerbose, Tcl_Obj *target, int objc, Tcl_Obj * CONST objv[], ForwardCmdClientData **tcdPtr) { ForwardCmdClientData *tcd; @@ -14257,7 +14257,7 @@ INCR_REF_COUNT(tcd->onerror); } #endif - tcd->objframe = withObjframe; + tcd->frame = withFrame; tcd->verbose = withVerbose; tcd->needobjmap = 0; tcd->cmdName = target; @@ -14285,10 +14285,10 @@ /*fprintf(stderr, "+++ cmdName = %s, args = %s, # = %d\n", ObjStr(tcd->cmdName), tcd->args?ObjStr(tcd->args):"NULL", tcd->nr_args);*/ - if (tcd->objframe) { + if (tcd->frame == FrameObjectIdx) { /* * When we evaluating objscope, and define ... - * o forward append -objframe append + * o forward append -frame object append * a call to * o append ... * would lead to a recursive call; so we add the appropriate namespace. @@ -16891,7 +16891,7 @@ NsfLog(interp, NSF_LOG_NOTICE, "forwarder calls '%s'", ObjStr(cmd)); DECR_REF_COUNT(cmd); } - if (tcd->objframe) { + if (tcd->frame == FrameObjectIdx) { Nsf_PushFrameObj(interp, object, framePtr); } if (tcd->objProc) { @@ -16910,7 +16910,7 @@ result = Tcl_EvalObjv(interp, objc, objv, 0); } - if (tcd->objframe) { + if (tcd->frame == FrameObjectIdx) { Nsf_PopFrameObj(interp, framePtr); } @@ -18427,7 +18427,7 @@ if (tcd->objProc) { Tcl_ListObjAppendElement(interp, listObj, Tcl_NewStringObj("-earlybinding", -1)); } - if (tcd->objframe) { + if (tcd->frame == FrameObjectIdx) { Tcl_ListObjAppendElement(interp, listObj, Tcl_NewStringObj("-frame", 6)); Tcl_ListObjAppendElement(interp, listObj, Tcl_NewStringObj("object", 6)); } @@ -18445,7 +18445,7 @@ static void AppendMethodRegistration(Tcl_Interp *interp, Tcl_Obj *listObj, CONST char *registerCmdName, NsfObject *object, CONST char *methodName, Tcl_Command cmd, - int withObjframe, int withPer_object, int withProtection) { + int withObjFrame, int withPer_object, int withProtection) { Tcl_ListObjAppendElement(interp, listObj, object->cmdName); if (withProtection) { Tcl_ListObjAppendElement(interp, listObj, @@ -18462,7 +18462,7 @@ Tcl_ListObjAppendElement(interp, listObj, Tcl_NewStringObj(registerCmdName, -1)); Tcl_ListObjAppendElement(interp, listObj, Tcl_NewStringObj(methodName, -1)); - if (withObjframe) { + if (withObjFrame) { Tcl_ListObjAppendElement(interp, listObj, Tcl_NewStringObj("-frame", 6)); Tcl_ListObjAppendElement(interp, listObj, Tcl_NewStringObj("object", 6)); } @@ -20721,14 +20721,13 @@ /* cmd method::forward NsfMethodForwardCmd { {-argName "object" -required 1 -type object} - {-argName "-per-object"} + {-argName "-per-object" -required 0 -nrargs 0 -type switch} {-argName "method" -required 1 -type tclobj} - {-argName "-default" -nrargs 1 -type tclobj} - {-argName "-earlybinding"} - {-argName "-methodprefix" -nrargs 1 -type tclobj} - {-argName "-objframe"} - {-argName "-onerror" -nrargs 1 -type tclobj} - {-argName "-verbose"} + {-argName "-default" -type tclobj} + {-argName "-earlybinding" -nrargs 0} + {-argName "-prefix" -type tclobj} + {-argName "-frame" -nrargs 1 -type "object|method|default" -default default} + {-argName "-verbose" -nrargs 0} {-argName "target" -type tclobj} {-argName "args" -type args} } @@ -20738,14 +20737,14 @@ NsfObject *object, int withPer_object, Tcl_Obj *methodObj, Tcl_Obj *withDefault, int withEarlybinding, Tcl_Obj *withMethodprefix, - int withObjframe, int withVerbose, + int withFrame, int withVerbose, Tcl_Obj *target, int nobjc, Tcl_Obj *CONST nobjv[]) { ForwardCmdClientData *tcd = NULL; int result; result = ForwardProcessOptions(interp, methodObj, withDefault, withEarlybinding, withMethodprefix, - withObjframe, withVerbose, + withFrame, withVerbose, target, nobjc, nobjv, &tcd); if (result == TCL_OK) { Index: generic/nsfAPI.decls =================================================================== diff -u -r5a7f6e086d300a9d0ad9178d7ea934b697708c07 -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- generic/nsfAPI.decls (.../nsfAPI.decls) (revision 5a7f6e086d300a9d0ad9178d7ea934b697708c07) +++ generic/nsfAPI.decls (.../nsfAPI.decls) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -146,8 +146,8 @@ {-argName "method" -required 1 -type tclobj} {-argName "-default" -type tclobj} {-argName "-earlybinding" -nrargs 0} - {-argName "-methodprefix" -type tclobj} - {-argName "-objframe" -nrargs 0} + {-argName "-prefix" -type tclobj} + {-argName "-frame" -nrargs 1 -type "object|method|default" -default default} {-argName "-verbose" -nrargs 0} {-argName "target" -type tclobj} {-argName "args" -type args} Index: generic/nsfAPI.h =================================================================== diff -u -r5a7f6e086d300a9d0ad9178d7ea934b697708c07 -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- generic/nsfAPI.h (.../nsfAPI.h) (revision 5a7f6e086d300a9d0ad9178d7ea934b697708c07) +++ generic/nsfAPI.h (.../nsfAPI.h) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -434,7 +434,7 @@ static int NsfMethodAssertionCmd(Tcl_Interp *interp, NsfObject *object, int subcmd, Tcl_Obj *arg); static int NsfMethodCreateCmd(Tcl_Interp *interp, NsfObject *object, int withCheckalways, int withInner_namespace, int withPer_object, NsfObject *withReg_object, Tcl_Obj *methodName, Tcl_Obj *arguments, Tcl_Obj *body, Tcl_Obj *withPrecondition, Tcl_Obj *withPostcondition); static int NsfMethodDeleteCmd(Tcl_Interp *interp, NsfObject *object, int withPer_object, Tcl_Obj *methodName); -static int NsfMethodForwardCmd(Tcl_Interp *interp, NsfObject *object, int withPer_object, Tcl_Obj *method, Tcl_Obj *withDefault, int withEarlybinding, Tcl_Obj *withMethodprefix, int withObjframe, int withVerbose, Tcl_Obj *target, int nobjc, Tcl_Obj *CONST nobjv[]); +static int NsfMethodForwardCmd(Tcl_Interp *interp, NsfObject *object, int withPer_object, Tcl_Obj *method, Tcl_Obj *withDefault, int withEarlybinding, Tcl_Obj *withPrefix, int withFrame, int withVerbose, Tcl_Obj *target, int nobjc, Tcl_Obj *CONST nobjv[]); static int NsfMethodPropertyCmd(Tcl_Interp *interp, NsfObject *object, int withPer_object, Tcl_Obj *methodName, int methodProperty, Tcl_Obj *value); static int NsfMethodRegisteredCmd(Tcl_Interp *interp, Tcl_Obj *handle); static int NsfMethodSetterCmd(Tcl_Interp *interp, NsfObject *object, int withPer_object, Tcl_Obj *parameter); @@ -1472,13 +1472,13 @@ Tcl_Obj *method = (Tcl_Obj *)pc.clientData[2]; Tcl_Obj *withDefault = (Tcl_Obj *)pc.clientData[3]; int withEarlybinding = (int )PTR2INT(pc.clientData[4]); - Tcl_Obj *withMethodprefix = (Tcl_Obj *)pc.clientData[5]; - int withObjframe = (int )PTR2INT(pc.clientData[6]); + Tcl_Obj *withPrefix = (Tcl_Obj *)pc.clientData[5]; + int withFrame = (int )PTR2INT(pc.clientData[6]); int withVerbose = (int )PTR2INT(pc.clientData[7]); Tcl_Obj *target = (Tcl_Obj *)pc.clientData[8]; assert(pc.status == 0); - return NsfMethodForwardCmd(interp, object, withPer_object, method, withDefault, withEarlybinding, withMethodprefix, withObjframe, withVerbose, target, objc-pc.lastObjc, objv+pc.lastObjc); + return NsfMethodForwardCmd(interp, object, withPer_object, method, withDefault, withEarlybinding, withPrefix, withFrame, withVerbose, target, objc-pc.lastObjc, objv+pc.lastObjc); } else { return TCL_ERROR; @@ -2912,8 +2912,8 @@ {"method", NSF_ARG_REQUIRED, 1, Nsf_ConvertTo_Tclobj, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, {"-default", 0, 1, Nsf_ConvertTo_Tclobj, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, {"-earlybinding", 0, 0, Nsf_ConvertTo_String, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, - {"-methodprefix", 0, 1, Nsf_ConvertTo_Tclobj, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, - {"-objframe", 0, 0, Nsf_ConvertTo_String, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, + {"-prefix", 0, 1, Nsf_ConvertTo_Tclobj, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, + {"-frame", 0|NSF_ARG_IS_ENUMERATION, 1, ConvertToFrame, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, {"-verbose", 0, 0, Nsf_ConvertTo_String, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, {"target", 0, 1, Nsf_ConvertTo_Tclobj, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}, {"args", 0, 1, ConvertToNothing, NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL}} Index: library/nx/nx.tcl =================================================================== diff -u -r156a002c09a06c6602f12d6f2f73038fa100b66e -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- library/nx/nx.tcl (.../nx.tcl) (revision 156a002c09a06c6602f12d6f2f73038fa100b66e) +++ library/nx/nx.tcl (.../nx.tcl) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -344,26 +344,21 @@ } { array set "" [:__resolve_method_path $methodName] set arguments [lrange [::nsf::current args] 1 end] - set nrPreArgs [expr {[llength $arguments]-[llength $args]}] - if {[info exists prefix]} { - set p [lsearch -exact [lrange $arguments 0 $nrPreArgs] -prefix] - # search for "-prefix" in the arguments before $args and replace it - if {$p > -1} {set arguments [lreplace $arguments $p $p -methodprefix]} + if {[info exists target] && [string range $target 0 0] eq "-"} { + error "target '$target' must not start with a dash" } - if {[info exists frame]} { - if {$frame ne "object"} { error "value of parameter -frame must be 'object'" } - set p [lsearch -exact [lrange $arguments 0 $nrPreArgs] -frame] - # search for "-frame" in the arguments before $args and replace it - if {$p > -1} {set arguments [lreplace $arguments $p $p+1 -objframe]} - incr nrPreArgs -1 + if {[info exists frame] && $frame ni {object default}} { + error "value of parameter -frame must be 'object' or 'default'" } if {[info exists returns]} { + set nrPreArgs [expr {[llength $arguments]-[llength $args]}] # search for "-returns" in the arguments before $args and remove it set p [lsearch -exact [lrange $arguments 0 $nrPreArgs] -returns] if {$p > -1} {set arguments [lreplace $arguments $p $p+1]} } set r [::nsf::method::forward $(object) $(methodName) {*}$arguments] + ::nsf::method::property $(object) $r call-protected \ [::nsf::dispatch $(object) __default_method_call_protection] if {[info exists returns]} {::nsf::method::property $(object) $r returns $returns} @@ -547,20 +542,15 @@ } { array set "" [:__resolve_method_path -per-object $methodName] set arguments [lrange [::nsf::current args] 1 end] - set nrPreArgs [expr {[llength $arguments]-[llength $args]}] - if {[info exists prefix]} { - set p [lsearch -exact [lrange $arguments 0 $nrPreArgs] -prefix] - # search for "-prefix" in the arguments before $args and replace it - if {$p > -1} {set arguments [lreplace $arguments $p $p -methodprefix]} + + if {[info exists target] && [string range $target 0 0] eq "-"} { + error "target '$target' must not start with a dash" } - if {[info exists frame]} { - if {$frame ne "object"} { error "value of parameter -frame must be 'object'" } - set p [lsearch -exact [lrange $arguments 0 $nrPreArgs] -frame] - # search for "-frame" in the arguments before $args and replace it - if {$p > -1} {set arguments [lreplace $arguments $p $p+1 -objframe]} - incr nrPreArgs -1 + if {[info exists frame] && $frame ni {object default}} { + error "value of parameter '-frame' must be 'object' or 'default'" } if {[info exists returns]} { + set nrPreArgs [expr {[llength $arguments]-[llength $args]}] # search for "-returns" in the arguments before $args ... set p [lsearch -exact [lrange $arguments 0 $nrPreArgs] -returns] # ... and remove it if found Index: library/xotcl/library/xotcl2.tcl =================================================================== diff -u -r156a002c09a06c6602f12d6f2f73038fa100b66e -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- library/xotcl/library/xotcl2.tcl (.../xotcl2.tcl) (revision 156a002c09a06c6602f12d6f2f73038fa100b66e) +++ library/xotcl/library/xotcl2.tcl (.../xotcl2.tcl) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -341,10 +341,13 @@ target:optional args } { set arglist [list] + if {[info exists target] && [string range $target 0 0] eq "-"} { + error "target '$target' must not start with a dash" + } if {[info exists default]} {lappend arglist -default $default} - if {$earlybinding} {lappend arglist "-earlybinding"} - if {[info exists methodprefix]} {lappend arglist -methodprefix $methodprefix} - if {$objscope} {lappend arglist "-objframe"} + if {$earlybinding} {lappend arglist -earlybinding} + if {[info exists methodprefix]} {lappend arglist -prefix $methodprefix} + if {$objscope} {lappend arglist -frame object} if {[info exists onerror]} {lappend arglist -onerror $onerror} if {$verbose} {lappend arglist -verbose} if {[info exists target]} {lappend arglist $target} @@ -359,10 +362,13 @@ target:optional args } { set arglist [list] + if {[info exists target] && [string range $target 0 0] eq "-"} { + error "target '$target' must not start with a dash" + } if {[info exists default]} {lappend arglist -default $default} - if {$earlybinding} {lappend arglist "-earlybinding"} - if {[info exists methodprefix]} {lappend arglist -methodprefix $methodprefix} - if {$objscope} {lappend arglist "-objframe"} + if {$earlybinding} {lappend arglist -earlybinding} + if {[info exists methodprefix]} {lappend arglist -prefix $methodprefix} + if {$objscope} {lappend arglist -frame object} if {[info exists onerror]} {lappend arglist -onerror $onerror} if {$verbose} {lappend arglist -verbose} if {[info exists target]} {lappend arglist $target} Index: tests/forward.test =================================================================== diff -u -r156a002c09a06c6602f12d6f2f73038fa100b66e -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- tests/forward.test (.../forward.test) (revision 156a002c09a06c6602f12d6f2f73038fa100b66e) +++ tests/forward.test (.../forward.test) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -6,256 +6,256 @@ # trivial object delegation ########################################### nx::test case delegation { - nx::Object create dog + nx::Object create dog nx::Object create tail { :public object method wag args { return $args } :public object method nxwag args { return $args } } dog public object forward wag tail %proc dog public object forward nxwag tail %method - + ? {dog wag 100} 100 ? {dog nxwag 100} 100 } ########################################### -# evaluating in scope +# evaluating in scope ########################################### nx::test case inscope { - nx::Class create X { - :property {x 1} - :public forward Incr -frame object incr - } + nx::Class create X { + :property {x 1} + :public forward Incr -frame object incr + } - X create x1 -x 100 - x1 Incr x - x1 Incr x - x1 Incr x - ? {x1 cget -x} 103 + X create x1 -x 100 + x1 Incr x + x1 Incr x + x1 Incr x + ? {x1 cget -x} 103 } ########################################### -# adding +# adding ########################################### nx::test case adding { - nx::Object create obj { - :public object forward addOne expr 1 + - } + nx::Object create obj { + :public object forward addOne expr 1 + + } - ? {obj addOne 5} 6 + ? {obj addOne 5} 6 } ########################################### # more arguments ########################################### nx::test case multiple-args { - nx::Object create target { - :public object method foo args {return $args} - } - nx::Object create obj { - :public object forward foo target %proc %self a1 a2 - } + nx::Object create target { + :public object method foo args {return $args} + } + nx::Object create obj { + :public object forward foo target %proc %self a1 a2 + } - ? {obj foo x1 x2} [list ::obj a1 a2 x1 x2] + ? {obj foo x1 x2} [list ::obj a1 a2 x1 x2] - obj public object forward foo target %proc %self %%self %%p - ? {obj foo x1 x2} [list ::obj %self %p x1 x2] + obj public object forward foo target %proc %self %%self %%p + ? {obj foo x1 x2} [list ::obj %self %p x1 x2] } ########################################### # mixin example ########################################### nx::test case mixin-via-forward { - nx::Object create mixin { - :object method unknown {m args} {return [concat [current] $m $args]} - } + nx::Object create mixin { + :object method unknown {m args} {return [concat [current] $m $args]} + } - nx::Object create obj { - :public object forward Mixin mixin %1 %self - } + nx::Object create obj { + :public object forward Mixin mixin %1 %self + } - ? {obj Mixin add M1} [list ::mixin add ::obj M1] - ? {catch {obj Mixin}} 1 - - obj public object forward Mixin mixin "%1 {Getter Setter}" %self - ? {obj Mixin add M1} [list ::mixin add ::obj M1] - ? {obj Mixin M1} [list ::mixin Setter ::obj M1] - ? {obj Mixin} [list ::mixin Getter ::obj] + ? {obj Mixin add M1} [list ::mixin add ::obj M1] + ? {catch {obj Mixin}} 1 + + obj public object forward Mixin mixin "%1 {Getter Setter}" %self + ? {obj Mixin add M1} [list ::mixin add ::obj M1] + ? {obj Mixin M1} [list ::mixin Setter ::obj M1] + ? {obj Mixin} [list ::mixin Getter ::obj] } ########################################### # sketching extensibe info ########################################### nx::test case info-via-forward { - nx::Object create Info { - :public object method @mixin {o} { - $o info mixin - } - :public object method @class {o} { ;# without prefix, doing here a [Info class] wod be wrong - $o info class - } - :public object method @help {o} { ;# define a new subcommand for info - foreach c [:info object methods] {lappend result [string range $c 1 end]} - return $result - } + nx::Object create Info { + :public object method @mixin {o} { + $o info mixin } - nx::Object public forward Info -prefix @ Info %1 %self - - nx::Class create X { - :create x1 + :public object method @class {o} { ;# without prefix, doing here a [Info class] wod be wrong + $o info class } - ? {x1 Info class} ::X - ? {x1 Info help} [list help mixin class] + :public object method @help {o} { ;# define a new subcommand for info + foreach c [:info object methods] {lappend result [string range $c 1 end]} + return $result + } + } + nx::Object public forward Info -prefix @ Info %1 %self + + nx::Class create X { + :create x1 + } + ? {x1 Info class} ::X + ? {x1 Info help} [list help mixin class] } ########################################### # variations of placement of options ########################################### nx::test case incr { - nx::Object create obj { - set :x 1 - :public object forward i1 -frame object incr x - } + nx::Object create obj { + set :x 1 + :public object forward i1 -frame object incr x + } - ? {obj i1} 2 + ? {obj i1} 2 } ########################################### # introspeciton options ########################################### nx::test case introspection { - nx::Class create C { - :public forward Info -prefix @ Info %1 %self - } + nx::Class create C { + :public forward Info -prefix @ Info %1 %self + } - ? {C info methods -type forwarder} Info - C public forward XXXo x - ? {lsort [C info methods -type forwarder]} [list Info XXXo] + ? {C info methods -type forwarder} Info + C public forward XXXo x + ? {lsort [C info methods -type forwarder]} [list Info XXXo] - ? {C info methods -type forwarder X*} [list XXXo] - ? {lsort [C info methods -type forwarder *o]} [list Info XXXo] + ? {C info methods -type forwarder X*} [list XXXo] + ? {lsort [C info methods -type forwarder *o]} [list Info XXXo] - # delete the forwarder - C method XXXo {} {} - ? {C info methods -type forwarder} [list Info] + # delete the forwarder + C method XXXo {} {} + ? {C info methods -type forwarder} [list Info] - # get the definition of a instforwarder - ? {C info method definition Info} [list ::C public forward Info -prefix @ Info %1 %self] + # get the definition of a instforwarder + ? {C info method definition Info} [list ::C public forward Info -prefix @ Info %1 %self] - # check introspection for objects - nx::Object create obj { - :public object forward i1 -frame object incr x - :public object forward Mixin mixin %1 %self - :public object forward foo target %proc %self %%self %%p - :public object forward addOne expr 1 + - } + # check introspection for objects + nx::Object create obj { + :public object forward i1 -frame object incr x + :public object forward Mixin mixin %1 %self + :public object forward foo target %proc %self %%self %%p + :public object forward addOne expr 1 + + } - ? {lsort [obj info object methods -type forwarder]} "Mixin addOne foo i1" - ? {obj info object method definition Mixin} "::obj public object forward Mixin mixin %1 %self" - ? {obj info object method definition addOne} "::obj public object forward addOne expr 1 +" - ? {obj info object method definition foo} "::obj public object forward foo target %proc %self %%self %%p" - ? {obj info object method definition i1} "::obj public object forward i1 -frame object ::incr x" + ? {lsort [obj info object methods -type forwarder]} "Mixin addOne foo i1" + ? {obj info object method definition Mixin} "::obj public object forward Mixin mixin %1 %self" + ? {obj info object method definition addOne} "::obj public object forward addOne expr 1 +" + ? {obj info object method definition foo} "::obj public object forward foo target %proc %self %%self %%p" + ? {obj info object method definition i1} "::obj public object forward i1 -frame object ::incr x" } ########################################### # test serializer ########################################### package require nx::serializer nx::test case serializer { - nx::Object create obj { - :object method test {} {puts "i am [current method]"} - } - set ::a [Serializer deepSerialize obj] - #puts <<$::a>> - eval $::a - ? {set ::a} [Serializer deepSerialize obj] + nx::Object create obj { + :object method test {} {puts "i am [current method]"} + } + set ::a [Serializer deepSerialize obj] + #puts <<$::a>> + eval $::a + ? {set ::a} [Serializer deepSerialize obj] } ########################################### # test optional target cmd ########################################### nx::test case optional-target { - nx::Object create obj { - set :x 2 - :public object forward append -frame object - } - ? {obj append x y z} 2yz + nx::Object create obj { + set :x 2 + :public object forward append -frame object + } + ? {obj append x y z} 2yz - nx::Object create n; nx::Object create n::x {:public object method current {} {current}} - nx::Object create o - o public object forward ::n::x - ? {o x current} ::n::x + nx::Object create n; nx::Object create n::x {:public object method current {} {current}} + nx::Object create o + o public object forward ::n::x + ? {o x current} ::n::x } ########################################### # arg including instvar ########################################### nx::test case percent-cmd { - nx::Object create obj { - set :x 10 - :public object forward x* expr {%:eval {set :x}} * - } - ? {obj x* 10} "100" + nx::Object create obj { + set :x 10 + :public object forward x* expr {%:eval {set :x}} * + } + ? {obj x* 10} "100" } ########################################### # positional arguments ########################################### nx::test case positioning-args { - nx::Object create obj - obj public object forward @end-13 list {%@end 13} - ? {obj @end-13 1 2 3 } [list 1 2 3 13] + nx::Object create obj + obj public object forward @end-13 list {%@end 13} + ? {obj @end-13 1 2 3 } [list 1 2 3 13] - obj public object forward @-1-13 list {%@-1 13} - ? {obj @-1-13 1 2 3 } [list 1 2 13 3] + obj public object forward @-1-13 list {%@-1 13} + ? {obj @-1-13 1 2 3 } [list 1 2 13 3] - obj public object forward @1-13 list {%@1 13} - ? {obj @1-13 1 2 3 } [list 13 1 2 3] - ? {obj @1-13} [list 13] + obj public object forward @1-13 list {%@1 13} + ? {obj @1-13 1 2 3 } [list 13 1 2 3] + ? {obj @1-13} [list 13] - obj public object forward @2-13 list {%@2 13} - ? {obj @2-13 1 2 3 } [list 1 13 2 3] + obj public object forward @2-13 list {%@2 13} + ? {obj @2-13 1 2 3 } [list 1 13 2 3] - obj public object forward @list 10 {%@0 list} {%@end 99} - ? {obj @list} [list 10 99] - ? {obj @list a b c} [list 10 a b c 99] + obj public object forward @list 10 {%@0 list} {%@end 99} + ? {obj @list} [list 10 99] + ? {obj @list a b c} [list 10 a b c 99] - obj public object forward @list {%@end 99} {%@0 list} 10 - ? {obj @list} [list 10 99] - ? {obj @list a b c} [list 10 a b c 99] - - obj public object forward @list {%@2 2} {%@1 1} {%@0 list} - ? {obj @list} [list 1 2] - ? {obj @list a b c} [list 1 2 a b c] - - obj public object forward @list x y z {%@0 list} {%@1 1} {%@2 2} - ? {obj @list} [list 1 2 x y z] - ? {obj @list a b c} [list 1 2 x y z a b c] - - obj public object forward @list x y z {%@2 2} {%@1 1} {%@0 list} - ? {obj @list} [list x 1 y 2 z] - ? {obj @list a b c} [list x 1 y 2 z a b c] - - # adding some test cases which cover the interactions - # between %@POS and %1 substitutions - # - - obj public object forward @end-13 list {%@end 13} %1 %self - ? {obj @end-13 1 2 3 } [list 1 ::obj 2 3 13] - - obj public object forward @end-13 list %1 {%@end 13} %self - ? {obj @end-13 1 2 3 } [list 1 ::obj 2 3 13] - - obj public object forward @end-13 list {%@end 13} %1 %1 %1 %self - ? {obj @end-13 1 2 3 } [list 1 1 1 ::obj 2 3 13] - - obj public object forward @end-13 list {%@-1 13} %1 %self - ? {obj @end-13 1 2 3 } [list 1 ::obj 2 13 3] - - obj public object forward @end-13 list {%@1 13} %1 %self - ? {obj @end-13 1 2 3 } [list 13 1 ::obj 2 3] + obj public object forward @list {%@end 99} {%@0 list} 10 + ? {obj @list} [list 10 99] + ? {obj @list a b c} [list 10 a b c 99] + + obj public object forward @list {%@2 2} {%@1 1} {%@0 list} + ? {obj @list} [list 1 2] + ? {obj @list a b c} [list 1 2 a b c] + + obj public object forward @list x y z {%@0 list} {%@1 1} {%@2 2} + ? {obj @list} [list 1 2 x y z] + ? {obj @list a b c} [list 1 2 x y z a b c] + + obj public object forward @list x y z {%@2 2} {%@1 1} {%@0 list} + ? {obj @list} [list x 1 y 2 z] + ? {obj @list a b c} [list x 1 y 2 z a b c] + + # adding some test cases which cover the interactions + # between %@POS and %1 substitutions + # + + obj public object forward @end-13 list {%@end 13} %1 %self + ? {obj @end-13 1 2 3 } [list 1 ::obj 2 3 13] + + obj public object forward @end-13 list %1 {%@end 13} %self + ? {obj @end-13 1 2 3 } [list 1 ::obj 2 3 13] + + obj public object forward @end-13 list {%@end 13} %1 %1 %1 %self + ? {obj @end-13 1 2 3 } [list 1 1 1 ::obj 2 3 13] + + obj public object forward @end-13 list {%@-1 13} %1 %self + ? {obj @end-13 1 2 3 } [list 1 ::obj 2 13 3] + + obj public object forward @end-13 list {%@1 13} %1 %self + ? {obj @end-13 1 2 3 } [list 13 1 ::obj 2 3] } nx::test case forwarder-basics { @@ -269,18 +269,26 @@ ## ? {obj info object methods foo} "" - obj public object forward ::ns1::foo + obj public object forward ::ns1::foo ? {obj info object methods foo} "foo" ? {obj foo X} {invalid command name "::ns1::foo"} namespace eval ::ns1 {proc foo {p} {return $p}} ? {obj foo X} "X" obj public object forward ::ns1::foo %method %method ? {namespace eval ::ns1 { ::obj foo }} "foo" + # make sure, old-style arguments don't get moved into argument + # delegatee cmd (called target) + ? {obj public object forward x1 -methodprefix @ -verbose %self X} \ + "target '-methodprefix' must not start with a dash" + ? {obj public object forward x2 -prefix @ -verbose %self X} \ + "::obj::x2" + ? {obj x2 a b c} "::obj: unable to dispatch method '@X'" + ## ## argclindex ## - + obj public object forward foo list {%argclindex {A B C}} ? {obj foo} A ? {obj foo _} "B _" @@ -331,16 +339,16 @@ } nx::test case positioning-arg-extended { - - nx::Object create obj + + nx::Object create obj obj public object forward foo list {%@end %self} ? {obj foo 1 2 3} [list 1 2 3 ::obj] obj public object forward foo list {%@end %method} ? {obj foo 1 2 3} [list 1 2 3 foo] obj public object forward foo list {%@end %%} ? {obj foo 1 2 3} [list 1 2 3 %] - + obj public object forward foo list {%obj foo} ? {obj foo 1 2 3} "too many nested evaluations (infinite loop?)" @@ -355,190 +363,191 @@ obj public object forward foo list {%@{} %obj} ? {obj foo 1 2 3} "forward: invalid index specified in argument %@{} %obj" - obj public object forward foo list {%@ %obj} - ? {obj foo 1 2 3} "forward: invalid index specified in argument %@ %obj" + obj public object forward foo list {%@ %obj} + ? {obj foo 1 2 3} "forward: invalid index specified in argument %@ %obj" - ## - ## resolving name conflicts between Tcl commands & predefined - ## placeholder names -> use fully qualified names - ## + ## + ## resolving name conflicts between Tcl commands & predefined + ## placeholder names -> use fully qualified names + ## - obj public object forward foo list {%@end %::proc} - ? {obj foo 1 2 3} {wrong # args: should be "::proc name args body"} + obj public object forward foo list {%@end %::proc} + ? {obj foo 1 2 3} {wrong # args: should be "::proc name args body"} - # the next test does not work unless called from nxsh, which imports ::nx::self - #obj public object forward foo list {%@end %::self} - #? {obj foo 1 2 3} [list 1 2 3 ::obj] + # the next test does not work unless called from nxsh, which imports ::nx::self + #obj public object forward foo list {%@end %::self} + #? {obj foo 1 2 3} [list 1 2 3 ::obj] - obj public object forward foo list {%@end %::nx::self} - ? {obj foo 1 2 3} [list 1 2 3 ::obj] "fully qualified self" + obj public object forward foo list {%@end %::nx::self} + ? {obj foo 1 2 3} [list 1 2 3 ::obj] "fully qualified self" - obj public object forward foo list {%@end %::1} - ? {obj foo 1 2 3} {invalid command name "::1"} + obj public object forward foo list {%@end %::1} + ? {obj foo 1 2 3} {invalid command name "::1"} - ## - ## position prefixes are interpreted in a context-dependent manner: - ## + ## + ## position prefixes are interpreted in a context-dependent manner: + ## - obj public object forward foo list {%@1 %@1} - ? {obj foo 1 2 3} {invalid command name "@1"} + obj public object forward foo list {%@1 %@1} + ? {obj foo 1 2 3} {invalid command name "@1"} - if {![string length "ISSUES"]} { - - - ## list protection makes this fail - obj public object forward foo list {%@end {%argclindex {A B C D}}} - ? {obj foo 1 2 3} [list 1 2 3 D] - - ## positioned "complex" cmd substitution (cmd + args) not working because of list protection - obj public object forward foo list {%@end {%list 1}} - ? {obj foo 1 2 3} [list 1 2 3 A] - - ## Why not %1 not working with positioning working? - obj public object forward foo list {%@end %1} - ? {obj foo 1 2 3} [list 1 2 3 1] - - ## - ## Should this be caught somehow? How would this be treated when list protection would not interfere? - ## - obj public object forward foo list {%@1 {%@1 "x"}} - ? {obj foo 1 2 3} "forward: invalid index specified in argument %@{} %obj" - } + if {![string length "ISSUES"]} { + + + ## list protection makes this fail + obj public object forward foo list {%@end {%argclindex {A B C D}}} + ? {obj foo 1 2 3} [list 1 2 3 D] + + ## positioned "complex" cmd substitution (cmd + args) not working because of list protection + obj public object forward foo list {%@end {%list 1}} + ? {obj foo 1 2 3} [list 1 2 3 A] + + ## Why not %1 not working with positioning working? + obj public object forward foo list {%@end %1} + ? {obj foo 1 2 3} [list 1 2 3 1] + + ## + ## Should this be caught somehow? How would this be treated when list protection would not interfere? + ## + obj public object forward foo list {%@1 {%@1 "x"}} + ? {obj foo 1 2 3} "forward: invalid index specified in argument %@{} %obj" + } } ############################################### # substitution depending on number of arguments ############################################### nx::test case num-args { - nx::Object create obj { - :public object forward f %self [list %argclindex [list a b c]] - :object method a args {return [list [current method] $args]} - :object method b args {return [list [current method] $args]} - :object method c args {return [list [current method] $args]} - } - ? {obj f} [list a {}] - ? {obj f 1 } [list b 1] - ? {obj f 1 2} [list c {1 2}] - ? {catch {obj f 1 2 3}} 1 + nx::Object create obj { + :public object forward f %self [list %argclindex [list a b c]] + :object method a args {return [list [current method] $args]} + :object method b args {return [list [current method] $args]} + :object method c args {return [list [current method] $args]} + } + ? {obj f} [list a {}] + ? {obj f 1 } [list b 1] + ? {obj f 1 2} [list c {1 2}] + ? {catch {obj f 1 2 3}} 1 } ############################################### # option earlybinding ############################################### nx::test case earlybinding { - nx::Object create obj { - #:public object forward s -earlybinding ::set ::X - :public object forward s ::set ::X + nx::Object create obj { + #:public object forward s -earlybinding ::set ::X + :public object forward s ::set ::X + } + ? {obj s 100} 100 + ? {obj s} 100 + + nx::Object public method f args { next } + + nx::Class create NS + nx::Class create NS::Main { + :public object method m1 {} { :m2 } + :public object method m2 {} { + ? {namespace eval :: {nx::Object create toplevelObj1}} ::toplevelObj1 + + ? [list set _ [namespace current]] ::NS + ? [list set _ [NS create m1]] ::NS::m1 + NS filter f + ? [list set _ [NS create m2]] ::NS::m2 + NS filter "" + + namespace eval ::test { + ? [list set _ [NS create m3]] ::test::m3 + NS filter f + ? [list set _ [NS create m4]] ::test::m4 + NS filter "" + } + + namespace eval test { + ? [list set _ [NS create m5]] ::NS::test::m5 + NS filter f + ? [list set _ [NS create m6]] ::NS::test::m6 + NS filter "" + } } - ? {obj s 100} 100 - ? {obj s} 100 - nx::Object public method f args { next } + :public method i1 {} { :i2 } + :public method i2 {} { + ? {namespace eval :: {nx::Object create toplevelObj2}} ::toplevelObj2 - nx::Class create NS - nx::Class create NS::Main { - :public object method m1 {} { :m2 } - :public object method m2 {} { - ? {namespace eval :: {nx::Object create toplevelObj1}} ::toplevelObj1 - - ? [list set _ [namespace current]] ::NS - ? [list set _ [NS create m1]] ::NS::m1 - NS filter f - ? [list set _ [NS create m2]] ::NS::m2 - NS filter "" + ? [list set _ [namespace current]] ::NS + ? [list set _ [NS create i1]] ::NS::i1 + NS filter f + ? [list set _ [NS create i2]] ::NS::i2 + NS filter "" - namespace eval ::test { - ? [list set _ [NS create m3]] ::test::m3 - NS filter f - ? [list set _ [NS create m4]] ::test::m4 - NS filter "" - } - - namespace eval test { - ? [list set _ [NS create m5]] ::NS::test::m5 - NS filter f - ? [list set _ [NS create m6]] ::NS::test::m6 - NS filter "" - } - } + namespace eval ::test { + ? [list set _ [NS create i3]] ::test::i3 + NS filter f + ? [list set _ [NS create i4]] ::test::i4 + NS filter "" + } - :public method i1 {} { :i2 } - :public method i2 {} { - ? {namespace eval :: {nx::Object create toplevelObj2}} ::toplevelObj2 - - ? [list set _ [namespace current]] ::NS - ? [list set _ [NS create i1]] ::NS::i1 - NS filter f - ? [list set _ [NS create i2]] ::NS::i2 - NS filter "" + namespace eval test { + ? [list set _ [NS create i5]] ::NS::test::i5 + NS filter f + ? [list set _ [NS create i6]] ::NS::test::i6 + NS filter "" + } - namespace eval ::test { - ? [list set _ [NS create i3]] ::test::i3 - NS filter f - ? [list set _ [NS create i4]] ::test::i4 - NS filter "" - } - - namespace eval test { - ? [list set _ [NS create i5]] ::NS::test::i5 - NS filter f - ? [list set _ [NS create i6]] ::NS::test::i6 - NS filter "" - } - - } } - - #puts ==== - NS::Main m1 - NS::Main create m - m i1 + } - #puts ==== - ? [list set _ [NS create n1]] ::n1 + #puts ==== + NS::Main m1 + NS::Main create m + m i1 + + #puts ==== + ? [list set _ [NS create n1]] ::n1 + NS filter f + ? [list set _ [NS create n2]] ::n2 + NS filter "" + + #puts ==== + namespace eval test { + ? [list set _ [NS create n1]] ::test::n1 + ? [list set _ [NS create n3]] ::test::n3 NS filter f - ? [list set _ [NS create n2]] ::n2 + ? [list set _ [NS create n4]] ::test::n4 NS filter "" - - #puts ==== - namespace eval test { - ? [list set _ [NS create n1]] ::test::n1 - ? [list set _ [NS create n3]] ::test::n3 - NS filter f - ? [list set _ [NS create n4]] ::test::n4 - NS filter "" - } + } } + ########################################### # forward to expr + callstack ########################################### nx::test case callstack { - nx::Object public forward expr -frame object + nx::Object public forward expr -frame object - nx::Class create C { - :method xx {} {current} - :public object method t {o expr} { - return [$o expr $expr] - } + nx::Class create C { + :method xx {} {current} + :public object method t {o expr} { + return [$o expr $expr] } - C create c1 + } + C create c1 - ? {c1 expr {[current]}} ::c1 - ? {c1 expr {[current] eq "::c1"}} 1 - ? {c1 expr {[:xx]}} ::c1 - ? {c1 expr {[:info class]}} ::C - ? {c1 expr {[:info has type C]}} 1 - ? {c1 expr {[:info has type ::C]}} 1 + ? {c1 expr {[current]}} ::c1 + ? {c1 expr {[current] eq "::c1"}} 1 + ? {c1 expr {[:xx]}} ::c1 + ? {c1 expr {[:info class]}} ::C + ? {c1 expr {[:info has type C]}} 1 + ? {c1 expr {[:info has type ::C]}} 1 - ? {C t ::c1 {[current]}} ::c1 - ? {C t ::c1 {[current] eq "::c1"}} 1 - ? {C t ::c1 {[:xx]}} ::c1 - ? {C t ::c1 {[:info class]}} ::C - ? {C t ::c1 {[:info has type C]}} 1 - ? {C t ::c1 {[:info has type ::C]}} 1 + ? {C t ::c1 {[current]}} ::c1 + ? {C t ::c1 {[current] eq "::c1"}} 1 + ? {C t ::c1 {[:xx]}} ::c1 + ? {C t ::c1 {[:info class]}} ::C + ? {C t ::c1 {[:info has type C]}} 1 + ? {C t ::c1 {[:info has type ::C]}} 1 - nx::Object method expr {} {} + nx::Object method expr {} {} } Index: tests/methods.test =================================================================== diff -u -r8776580a91fa04fd52378dd37143f6c27769c8ab -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- tests/methods.test (.../methods.test) (revision 8776580a91fa04fd52378dd37143f6c27769c8ab) +++ tests/methods.test (.../methods.test) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -863,6 +863,7 @@ ? {o a b} "a b" ? {o a c} "a c" ? {o set x 1} 1 + ? {o eval {info exists :x}} 1 ? {o copy p} ::p ? {lsort [::p info object methods -path]} "{a b} {a c} foo fwd set" @@ -873,6 +874,7 @@ #package require nx::serializer #puts stderr [o serialize] #puts stderr [p serialize] + ? {p eval {info exists :x}} 1 ? {p set x} 1 } Index: tests/parameters.test =================================================================== diff -u -r5a7f6e086d300a9d0ad9178d7ea934b697708c07 -r714fdeeeeca44ee6f77d93349a0afec4c4b139cc --- tests/parameters.test (.../parameters.test) (revision 5a7f6e086d300a9d0ad9178d7ea934b697708c07) +++ tests/parameters.test (.../parameters.test) (revision 714fdeeeeca44ee6f77d93349a0afec4c4b139cc) @@ -620,7 +620,7 @@ "query instparams for scripted method 'method'" ? {nx::Object info method parameters ::nsf::method::forward} \ - "object:object -per-object:switch method -default -earlybinding:switch -methodprefix -objframe:switch -verbose:switch target:optional args" \ + "object:object -per-object:switch method -default -earlybinding:switch -prefix -frame -verbose:switch target:optional args" \ "query parameter for C-defined cmd 'nsf::forward'" nx::Object require method autoname