Index: TODO =================================================================== diff -u -ra774481bc677369c7b0f7d1fcf3275ee1afd4fba -r515bb4c0ed4a2dad74c4a29c940b57a3e911845d --- TODO (.../TODO) (revision a774481bc677369c7b0f7d1fcf3275ee1afd4fba) +++ TODO (.../TODO) (revision 515bb4c0ed4a2dad74c4a29c940b57a3e911845d) @@ -4490,8 +4490,15 @@ other traces for the same operations. - extended regression test +- added partly implementation for slots with traces+types for classes + ======================================================================== TODO: +- # configure-trace-class-type (in cget.test) + # (a) the error message would contain the lower-level message + # (b) the error would be generated earlier (not on object creation) + # (c) the error should not be generated when an actual value is provided +- add configure-trace-object-type - fix property inheritance in traits (nx-traits.tcl) - maybe remove unneeded values, align naming in enumeration of first arg of *::info::objectparameter and *::info::method Index: generic/nsf.c =================================================================== diff -u -r216b4dd29425d7f4307b94ee8cd428a5dd7a361e -r515bb4c0ed4a2dad74c4a29c940b57a3e911845d --- generic/nsf.c (.../nsf.c) (revision 216b4dd29425d7f4307b94ee8cd428a5dd7a361e) +++ generic/nsf.c (.../nsf.c) (revision 515bb4c0ed4a2dad74c4a29c940b57a3e911845d) @@ -12801,7 +12801,7 @@ ObjStr(paramPtr->nameObj), ObjStr(newValue), result);*/ if (likely(result == TCL_OK)) { - if (paramPtr->flags & NSF_ARG_INITCMD && RUNTIME_STATE(interp)->doKeepinitcmd) { + if (paramPtr->flags & NSF_ARG_CMD && RUNTIME_STATE(interp)->doKeepinitcmd) { Tcl_ObjSetVar2(interp, paramPtr->nameObj, NULL, newValue, TCL_LEAVE_ERR_MSG|TCL_PARSE_PART1); } } @@ -16855,7 +16855,7 @@ */ if ((unlikely((doCheckArguments & NSF_ARGPARSE_CHECK) == 0) && (pPtr->flags & (NSF_ARG_IS_CONVERTER)) == 0 - ) || (pPtr->flags & (NSF_ARG_INITCMD|NSF_ARG_CMD))) { + ) || (pPtr->flags & (NSF_ARG_CMD))) { /* fprintf(stderr, "*** omit argument check for arg %s flags %.6x\n", pPtr->name, pPtr->flags); */ *clientData = ObjStr(objPtr); return TCL_OK; @@ -17020,7 +17020,8 @@ */ if (pPtr->type || unlikely(pPtr->flags & NSF_ARG_MULTIVALUED)) { int mustDecrList = 0; - if (unlikely(ArgumentCheck(interp, newValue, pPtr, + if (unlikely((pPtr->flags & NSF_ARG_INITCMD) == 0 && + ArgumentCheck(interp, newValue, pPtr, RUNTIME_STATE(interp)->doCheckArguments, &mustDecrList, &checkedData, &pcPtr->objv[i]) != TCL_OK)) { if (mustDecrNewValue) { Index: library/nx/nx.tcl =================================================================== diff -u -ra774481bc677369c7b0f7d1fcf3275ee1afd4fba -r515bb4c0ed4a2dad74c4a29c940b57a3e911845d --- library/nx/nx.tcl (.../nx.tcl) (revision a774481bc677369c7b0f7d1fcf3275ee1afd4fba) +++ library/nx/nx.tcl (.../nx.tcl) (revision 515bb4c0ed4a2dad74c4a29c940b57a3e911845d) @@ -1333,11 +1333,15 @@ set options [:getParameterOptions -withMultiplicity true -forObjectParameter true] if {[info exists :initcmd]} { - lappend options initcmd if {[info exists :default]} { + if {[llength $options] > 0} { + ::nsf::is -complain [join $options ,] ${:default} + #puts stderr "::nsf::is -complain [join $options ,] ${:default} ==> OK" + } append initcmd "\n::nsf::var::set \[::nsf::self\] ${:name} [list ${:default}]\n" #puts stderr ================append-default-to-initcmd-old=<${:initcmd}> } + lappend options initcmd append initcmd ${:initcmd} set :parameterSpec [list [:namedParameterSpec $prefix ${:name} $options] $initcmd] #puts stderr ================${:parameterSpec} @@ -1902,6 +1906,7 @@ if {${:per-object}} { ${:domain} eval $__initcmd } + #puts stderr initcmd=$__initcmd set :initcmd $__initcmd } } Index: tests/cget.test =================================================================== diff -u -ra774481bc677369c7b0f7d1fcf3275ee1afd4fba -r515bb4c0ed4a2dad74c4a29c940b57a3e911845d --- tests/cget.test (.../cget.test) (revision a774481bc677369c7b0f7d1fcf3275ee1afd4fba) +++ tests/cget.test (.../cget.test) (revision 515bb4c0ed4a2dad74c4a29c940b57a3e911845d) @@ -297,4 +297,60 @@ ? {o cget -B} 1000 ? {o configure -B 1001} "" ? {o cget -B} 1002 +} + + + +nx::Test case configure-trace-class-type { + + # + # class case with type and no default + # + nx::Class create C + C property p:integer { + set :valuechangedcmd { + #puts stderr "C.p valuechangedcmd $obj $var +1" + ::nsf::var::set $obj $var [expr [list [::nsf::var::set $obj $var] + 1]] + } + } + + C create c1 + + ? {c1 eval {info exists :p}} 0 + ? {c1 cget -p} {can't read "p": no such variable} + ? {c1 configure -p a} {expected integer but got "a" for parameter "-p"} + ? {c1 eval {info exists :p}} 0 + ? {c1 configure -p 1} "" + ? {c1 eval {info exists :p}} 1 + ? {c1 cget -p} "2" + + # + # class case with type and default + # + puts stderr ====1 + C property {q:integer aaa} { + set :valuechangedcmd { + #puts stderr "C.q valuechangedcmd $obj $var +1" + ::nsf::var::set $obj $var [expr [list [::nsf::var::set $obj $var] + 1]] + } + } + # TODO: it would be nicer, if + # (a) the error message would contain the lower-level message + # (b) the error would be generated earlier (not on object creation) + # (c) the error should not be generated when an actual value is provided + ? {C create c2} "objectparameter: ::C::slot::q getParameterSpec returned error" + ? {C create c2 -q 111} "objectparameter: ::C::slot::q getParameterSpec returned error" + + ? {C property {q:integer 100} { + set :valuechangedcmd { + #puts stderr "C.q valuechangedcmd $obj $var +1" + ::nsf::var::set $obj $var [expr [list [::nsf::var::set $obj $var] + 1]] + } + }} "" + C create c2 + + ? {c2 eval {info exists :q}} 1 + ? {c2 cget -q} 100 + ? {c2 configure -q 101} "" + ? {c2 cget -q} "102" } \ No newline at end of file