It came to my attention that [namespace import -force nx::*] is a requirement and not an option, otherwise things don't work right. Example:
nx::Class create C C method init args {puts [self]; next} C create c #error, commands "self" and "next" do not exist, but if I first do [namespace import -force nx::*], everything works fine.
This is not how I thought the namespaced commands should work. Is this a feature or a bug? If not a bug, then it needs to be clearly documented.
On 08.12.10 05:40, Victor Mayevski wrote:
It came to my attention that [namespace import -force nx::*] is a requirement and not an option, otherwise things don't work right. Example:
nx::Class create C C method init args {puts [self]; next} C create c #error, commands "self" and "next" do not exist, but if I first do [namespace import -force nx::*], everything works fine.
well, if i take the first sentence literally, this is not true. there are several options:
if one uses a plain tcl shell, one can use
a) package req nx
nx::Class create C C method init args {puts [nx::self]; nx::next} C create c
b) package req nx namespace path nx
nx::Class create C C method init args {puts [self]; next} C create c
c) package req nx namespace import nx::*
nx::Class create C C method init args {puts [self]; next} C create c
Concerning (c): there is no need to use "-force", except these commands were already imported (e.g. from some other package).
One can use alternatively the "nxsh" (tcl-file, which does a package req nx namespace import nx::* automatically) and then in the script file just
nx::Class create C C method init args {puts [self]; next} C create c
This is not how I thought the namespaced commands should work. Is this a feature or a bug? If not a bug, then it needs to be clearly documented.
I don't understand, what you expected. If you use just (a) then Tcl has no indication, what "self" or "next" should be used. For unprefixed names, Tcl requires to have to use either "namespace import" or "namespace path".
The behavior is the same as in XOTcl 1. XOTcl/nx do not play any magic games with namespaces, they just use the standard tcl behaviour.
-gustaf neumann
Thank you Gustaf,
I guess I just expected that things will be automatically tracked no matter in which namespace I invoked the nx::Class command. I have not used xotcl::Class before that's why I never seen this behaviour. The namespace "nx" is so short so it made it very convenient to just enter "nx::Class" on command line instead of using "namespace import". Nevertheless, it was very educational. Thanks again.
On Tue, Dec 7, 2010 at 9:39 PM, Gustaf Neumann neumann@wu-wien.ac.at wrote:
On 08.12.10 05:40, Victor Mayevski wrote:
It came to my attention that [namespace import -force nx::*] is a requirement and not an option, otherwise things don't work right. Example:
nx::Class create C C method init args {puts [self]; next} C create c #error, commands "self" and "next" do not exist, but if I first do [namespace import -force nx::*], everything works fine.
well, if i take the first sentence literally, this is not true. there are several options:
if one uses a plain tcl shell, one can use
a) package req nx
nx::Class create C C method init args {puts [nx::self]; nx::next} C create c
b) package req nx namespace path nx
nx::Class create C C method init args {puts [self]; next} C create c
c) package req nx namespace import nx::*
nx::Class create C C method init args {puts [self]; next} C create c
Concerning (c): there is no need to use "-force", except these commands were already imported (e.g. from some other package).
One can use alternatively the "nxsh" (tcl-file, which does a package req nx namespace import nx::* automatically) and then in the script file just
nx::Class create C C method init args {puts [self]; next} C create c
This is not how I thought the namespaced commands should work. Is this a feature or a bug? If not a bug, then it needs to be clearly documented.
I don't understand, what you expected. If you use just (a) then Tcl has no indication, what "self" or "next" should be used. For unprefixed names, Tcl requires to have to use either "namespace import" or "namespace path".
The behavior is the same as in XOTcl 1. XOTcl/nx do not play any magic games with namespaces, they just use the standard tcl behaviour.
-gustaf neumann
Xotcl mailing list Xotcl@alice.wu-wien.ac.at http://alice.wu-wien.ac.at/mailman/listinfo/xotcl
On 08.12.10 07:35, Victor Mayevski wrote:
Thank you Gustaf,
I guess I just expected that things will be automatically tracked no matter in which namespace I invoked the nx::Class command.
maybe your assumption was that since you create a class ::C with "nx::Class", then init of C will run in the "nx" namespace; ... but it is not, it is running in ::.
The reason, why using nx there is probably not a good idea is a follows: Consider that one might want to create e.g. other cmds (objects/procs/...) from a method without explicit namespaces. If the current namespace would be nx, these cmds would be created in the nx namespace, probably not always desired.
XOTcl/nx tries to follow Tcl with the namespace rules. If a proc foo is contained in a namespace X (place of definition), then the current namespace in foo is X. For objects/classes this is not so obvious, but similar. If a class is created in a namespace X, its methods are executed in that namespace.
============================================ package req nx
# # your application namespace # namespace eval ::app { proc foo {} {puts proc-current=[namespace current]}
nx::Class create C C method init args {puts current=[namespace current]} }
# # using the definitions # ::app::foo ::app::C create c1 ============================================
The behavior is the same if ::app::foo or ::app::C are created from some other namespace (eg the toplevel namespace) with the explicit namespace in the name. So, not the namespace of the invocation is important, but the namespace of the definition (which certainly might be the same).
Btw, one can use "namespace import ::nx" or "namespace path" not only in the global namespace, but in the namespace of definition.
============================================ package req nx
# # your application namespace # namespace eval ::app { namespace path ::nx
nx::Class create C C method init args {puts self=[self]; next} }
# # using the definitions # ::app::C create c1 ============================================
Hope, this helps a little....
-gustaf neumann