Rocksolid Light

News from da outaworlds

mail  files  register  groups  login

Message-ID:  

Today is the first day of the rest of the mess.


comp / comp.lang.tcl / Re: Differing namespace behavior in Tcl 9.0b2

SubjectAuthor
* Differing namespace behavior in Tcl 9.0b2Andrew Mangogna
+- Re: Differing namespace behavior in Tcl 9.0b2et99
+- Re: Differing namespace behavior in Tcl 9.0b2Ashok
+- Re: Differing namespace behavior in Tcl 9.0b2Ashok
`* Re: Differing namespace behavior in Tcl 9.0b2Andreas Leitgeb
 `- Re: Differing namespace behavior in Tcl 9.0b2Andrew Mangogna

1
Subject: Differing namespace behavior in Tcl 9.0b2
From: Andrew Mangogna
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Tue, 16 Jul 2024 21:52 UTC
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: amangogna@modelrealization.com (Andrew Mangogna)
Newsgroups: comp.lang.tcl
Subject: Differing namespace behavior in Tcl 9.0b2
Date: Tue, 16 Jul 2024 21:52:17 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 55
Message-ID: <v76q2g$1ej2c$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Injection-Date: Tue, 16 Jul 2024 23:52:17 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="0e94d130bdfe5cf40b047552c0c7fba2";
logging-data="1526860"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18x68s/9yG4LWd30EhD+gllnds/23zgEEw="
User-Agent: Pan/0.155 (Kherson; fc5a80b8)
Cancel-Lock: sha1:WBaHwLlBWHZwU1G58M9CEPB5Nxg=
View all headers

I have been out of the Tcl loop for a while, but have been porting an old
"C" based extension of mine to Tcl 9.0b2. The port went well, required
very few changes, but I have some differing behavior that I'm trying to
track down. The package consists of an ensemble command, "ral" which
has three subcommands implemented in the "::ral" namespace. Each of
the subcommands is also exported from the namespace. The following shows
the problems:

For Tcl 8.6:

% info patchlevel
8.6.11
% package require ral
0.12.2
% info commands ral
ral
% namespace export
% ral relvar names
% relvar names
invalid command name "relvar" <- expected
% namespace import ::ral::*
% relvar names
% namespace export
%

For Tcl 9.0b2:

% info patchlevel
9.0b2
% package require ral
0.13.0 <- new port to Tcl 9
% info commands ral
ral
% namespace export
tuple relation relvar <- unexpected -- ral exports these commands
<- but they shouldn't appear in the global
<- namespace
% ral relvar names
% relvar names
invalid command name "relvar" <- expected, just as Tcl 8.6
% namespace import ::ral::*
% relvar names
invalid command name "relvar" <- unexpected
% namespace export
tuple relation relvar <- again, not sure why these appear

So my question is, "Is there some namespace / ensemble changes that I've
not been able to track down?" It appears that the ensemble works
correctly, but that the exported commands are no longer exported or
available.

Thanks,

Andrew Mangogna

Subject: Re: Differing namespace behavior in Tcl 9.0b2
From: et99
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 17 Jul 2024 03:17 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: et99@rocketship1.me (et99)
Newsgroups: comp.lang.tcl
Subject: Re: Differing namespace behavior in Tcl 9.0b2
Date: Tue, 16 Jul 2024 20:17:38 -0700
Organization: A noiseless patient Spider
Lines: 75
Message-ID: <v77d4i$1lkhh$1@dont-email.me>
References: <v76q2g$1ej2c$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 17 Jul 2024 05:17:39 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="491e001921467151fa3dad403392e323";
logging-data="1757745"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18hUcBDrdZelD1wsInaqTtJ"
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101
Thunderbird/102.6.1
Cancel-Lock: sha1:yYfgHowO5vsdUe4J3MnPUkUnzeU=
Content-Language: en-US
In-Reply-To: <v76q2g$1ej2c$1@dont-email.me>
View all headers

On 7/16/2024 2:52 PM, Andrew Mangogna wrote:
> I have been out of the Tcl loop for a while, but have been porting an old
> "C" based extension of mine to Tcl 9.0b2. The port went well, required
> very few changes, but I have some differing behavior that I'm trying to
> track down. The package consists of an ensemble command, "ral" which
> has three subcommands implemented in the "::ral" namespace. Each of
> the subcommands is also exported from the namespace. The following shows
> the problems:
>
> For Tcl 8.6:
>
> % info patchlevel
> 8.6.11
> % package require ral
> 0.12.2
> % info commands ral
> ral
> % namespace export
> % ral relvar names
> % relvar names
> invalid command name "relvar" <- expected
> % namespace import ::ral::*
> % relvar names
> % namespace export
> %
>
> For Tcl 9.0b2:
>
> % info patchlevel
> 9.0b2
> % package require ral
> 0.13.0 <- new port to Tcl 9
> % info commands ral
> ral
> % namespace export
> tuple relation relvar <- unexpected -- ral exports these commands
> <- but they shouldn't appear in the global
> <- namespace
> % ral relvar names
> % relvar names
> invalid command name "relvar" <- expected, just as Tcl 8.6
> % namespace import ::ral::*
> % relvar names
> invalid command name "relvar" <- unexpected
> % namespace export
> tuple relation relvar <- again, not sure why these appear
>
> So my question is, "Is there some namespace / ensemble changes that I've
> not been able to track down?" It appears that the ensemble works
> correctly, but that the exported commands are no longer exported or
> available.
>
> Thanks,
>
> Andrew Mangogna
>

I Don't know if this is your issue, but there is one incompatibility I know of in 9.0 from the release notes:

important Incompatibilities in Tcl 9.0

Namespace varname resolution: Current namespace, not global.

As far as I can tell, by looking up the manual for 9.0 from an internet search and finding

https://www.tcl-lang.com/man/tcl9.0/TclCmd/namespace.html

the manual entry on name resolution is not changed there from 8.6. However, I do know that some code I've used under 9.0 had to be changed when it assumed the old way. In particular some of the tcl_* globals needed to add :: in front of the variable names since it would no longer find them in the global namespace when used inside of a namespace without the ::tcl_*.

Subject: Re: Differing namespace behavior in Tcl 9.0b2
From: Ashok
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 17 Jul 2024 06:04 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: apnmbx-public@yahoo.com (Ashok)
Newsgroups: comp.lang.tcl
Subject: Re: Differing namespace behavior in Tcl 9.0b2
Date: Wed, 17 Jul 2024 11:34:30 +0530
Organization: A noiseless patient Spider
Lines: 14
Message-ID: <v77mte$1n7rp$1@dont-email.me>
References: <v76q2g$1ej2c$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 17 Jul 2024 08:04:30 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="22ae9d642df1ed3887cae4a911e079ef";
logging-data="1810297"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/Q3H4/1y6s3FVaFLoQFLN3"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:hMrl4hFgPEuuNDS6SQx8opMj93A=
Content-Language: en-US
In-Reply-To: <v76q2g$1ej2c$1@dont-email.me>
View all headers

See the "Change in variable name resolution" section in
https://core.tcl-lang.org/tcl/wiki?name=Migrating+scripts+to+Tcl+9&p

On 7/17/2024 3:22 AM, Andrew Mangogna wrote:
> So my question is, "Is there some namespace / ensemble changes that I've
> not been able to track down?" It appears that the ensemble works
> correctly, but that the exported commands are no longer exported or
> available.
>
> Thanks,
>
> Andrew Mangogna
>

Subject: Re: Differing namespace behavior in Tcl 9.0b2
From: Ashok
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 17 Jul 2024 06:07 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: apnmbx-public@yahoo.com (Ashok)
Newsgroups: comp.lang.tcl
Subject: Re: Differing namespace behavior in Tcl 9.0b2
Date: Wed, 17 Jul 2024 11:37:47 +0530
Organization: A noiseless patient Spider
Lines: 14
Message-ID: <v77n3j$1n7rp$2@dont-email.me>
References: <v76q2g$1ej2c$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 17 Jul 2024 08:07:47 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="22ae9d642df1ed3887cae4a911e079ef";
logging-data="1810297"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19eJuz9OsniCyv2paEC8uDk"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:twilHCjG2FhjNotPgvt39WN/VQI=
Content-Language: en-US
In-Reply-To: <v76q2g$1ej2c$1@dont-email.me>
View all headers

Sorry, my previous post might be irrelevant. I thought your issue was
related to variable name resolution, not command ensembles.

On 7/17/2024 3:22 AM, Andrew Mangogna wrote:
> So my question is, "Is there some namespace / ensemble changes that I've
> not been able to track down?" It appears that the ensemble works
> correctly, but that the exported commands are no longer exported or
> available.
>
> Thanks,
>
> Andrew Mangogna
>

Subject: Re: Differing namespace behavior in Tcl 9.0b2
From: Andreas Leitgeb
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 17 Jul 2024 08:04 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: avl@logic.at (Andreas Leitgeb)
Newsgroups: comp.lang.tcl
Subject: Re: Differing namespace behavior in Tcl 9.0b2
Date: Wed, 17 Jul 2024 08:04:13 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 33
Message-ID: <slrnv9eunt.1l9n7.avl@logic.at>
References: <v76q2g$1ej2c$1@dont-email.me>
Reply-To: avl@logic.at
Injection-Date: Wed, 17 Jul 2024 10:04:13 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="27f5daf1c0338e6034a2765519da7d32";
logging-data="1841433"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+Q0bL3WOwzNwFDjvyfRzws"
User-Agent: slrn/1.0.3 (Linux)
Cancel-Lock: sha1:jnDVvPd+5Mt9/wo1VJKmcRdFP6w=
View all headers

Andrew Mangogna <amangogna@modelrealization.com> wrote:
> I have been out of the Tcl loop for a while, but have been porting an old
> "C" based extension of mine to Tcl 9.0b2. The port went well, required
> very few changes, but I have some differing behavior that I'm trying to
> track down. The package consists of an ensemble command, "ral" which
> has three subcommands implemented in the "::ral" namespace. Each of
> the subcommands is also exported from the namespace. The following shows
> the problems:

The behaviour looks buggy to me, but without knowing what
your package ral really does, it's hard to judge.

The only commonly known change w.r.t. namespaces in Tcl9 is
that change about variable lookup (already mentioned in other
replies).

Could you try to reproduce it with a simple package, that
exhibits the same difference 8.6 vs 9.0 ?

> % namespace export
> tuple relation relvar <- unexpected -- ral exports these commands
> <- but they shouldn't appear in the global
> <- namespace

Maybe your code does an export on these commands, but only in Tcl9 it
effectively does the "export" from global namespace...

That *might* be a Tcl9 bug, but it would be very interesting how
that is triggered.

Btw., a command does not need to exist in a particular namespace to
be "export"-able from there.

Subject: Re: Differing namespace behavior in Tcl 9.0b2
From: Andrew Mangogna
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 17 Jul 2024 18:09 UTC
References: 1 2
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: amangogna@modelrealization.com (Andrew Mangogna)
Newsgroups: comp.lang.tcl
Subject: Re: Differing namespace behavior in Tcl 9.0b2
Date: Wed, 17 Jul 2024 11:09:01 -0700
Organization: A noiseless patient Spider
Lines: 136
Message-ID: <v791bu$1uodl$1@dont-email.me>
References: <v76q2g$1ej2c$1@dont-email.me> <slrnv9eunt.1l9n7.avl@logic.at>
Reply-To: amangogna@modelrealization.com
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 17 Jul 2024 20:09:02 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="7be667e3939551746f6db4d0920ef25c";
logging-data="2056629"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+bCVj747+0Sp7FxBtwV8F7PJZnD54AZ1c="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:PTK5rtc9Qxj3StLYlJ4kOTvPbqQ=
Content-Language: en-US
In-Reply-To: <slrnv9eunt.1l9n7.avl@logic.at>
View all headers

On 7/17/24 01:04, Andreas Leitgeb wrote:
> Andrew Mangogna <amangogna@modelrealization.com> wrote:
>> I have been out of the Tcl loop for a while, but have been porting an old
>> "C" based extension of mine to Tcl 9.0b2. The port went well, required
>> very few changes, but I have some differing behavior that I'm trying to
>> track down. The package consists of an ensemble command, "ral" which
>> has three subcommands implemented in the "::ral" namespace. Each of
>> the subcommands is also exported from the namespace. The following shows
>> the problems:
>
> The behaviour looks buggy to me, but without knowing what
> your package ral really does, it's hard to judge.
>
> The only commonly known change w.r.t. namespaces in Tcl9 is
> that change about variable lookup (already mentioned in other
> replies).
>
> Could you try to reproduce it with a simple package, that
> exhibits the same difference 8.6 vs 9.0 ?
>
>> % namespace export
>> tuple relation relvar <- unexpected -- ral exports these commands
>> <- but they shouldn't appear in the global
>> <- namespace
>
> Maybe your code does an export on these commands, but only in Tcl9 it
> effectively does the "export" from global namespace...
>
> That *might* be a Tcl9 bug, but it would be very interesting how
> that is triggered.
>
> Btw., a command does not need to exist in a particular namespace to
> be "export"-able from there.
>

I didn't want to drop a big pile of code, but here is the package init
function where the commands and ensemble are created. This is old code,
most of it dating from 2014.

-----------
DLLEXPORT
int
ral_Init(
Tcl_Interp *interp)
{ static char const tupleCmdName[] = "::ral::tuple" ;
static char const tupleStr[] = "tuple" ;
static char const relationCmdName[] = "::ral::relation" ;
static char const relationStr[] = "relation" ;
static char const relvarCmdName[] = "::ral::relvar" ;
static char const relvarStr[] = "relvar" ;
static char const pkgNamespace[] = "::ral" ;

Ral_RelvarInfo rInfo ;
Tcl_Obj *mapObj ;
Tcl_Command ensembleCmdToken ;
Tcl_Namespace *ralNs ;

if (Tcl_InitStubs(interp, TCL_VERSION, 0) == NULL) {
return TCL_ERROR ;
}
if (Tcl_TomMath_InitStubs(interp, TCL_VERSION) == NULL) {
return TCL_ERROR ;
}
/*
* Create the namespace in which the package command reside.
*/
ralNs = Tcl_CreateNamespace(interp, pkgNamespace, NULL, NULL) ;
/*
* Create the package commands.
* First the "tuple" command.
*/
mapObj = Tcl_NewDictObj() ;
Tcl_CreateObjCommand(interp, tupleCmdName, tupleCmd, NULL, NULL) ;
if (Tcl_Export(interp, ralNs, tupleStr, 0) != TCL_OK) {
goto errorout ;
}
if (Tcl_DictObjPut(interp, mapObj,
Tcl_NewStringObj(tupleStr, -1),
Tcl_NewStringObj(tupleCmdName, -1)) != TCL_OK) {
goto errorout ;
}
/*
* Next the "relation" command.
*/
Tcl_CreateObjCommand(interp, relationCmdName, relationCmd, NULL,
NULL) ;
if (Tcl_Export(interp, ralNs, relationStr, 0) != TCL_OK) {
goto errorout ;
}
if (Tcl_DictObjPut(interp, mapObj,
Tcl_NewStringObj(relationStr, -1),
Tcl_NewStringObj(relationCmdName, -1)) != TCL_OK) {
goto errorout ;
}
/*
* Finally, the "relvar" command.
*/
rInfo = Ral_RelvarNewInfo(ral_pkgname, interp) ;
Tcl_CreateObjCommand(interp, relvarCmdName, relvarCmd, rInfo, NULL) ;
if (Tcl_Export(interp, ralNs, relvarStr, 0) != TCL_OK) {
goto errorout ;
}
if (Tcl_DictObjPut(interp, mapObj,
Tcl_NewStringObj(relvarStr, -1),
Tcl_NewStringObj(relvarCmdName, -1)) != TCL_OK) {
} /*
* Create an ensemble command on the namespace.
*/
ensembleCmdToken = Tcl_CreateEnsemble(interp, "::ral", ralNs, 0) ;
/*
* Following the pattern in Tcl sources, we set the mapping dictionary
* of the ensemble. This will allow the ensemble to be extended
* at the script level.
*/
if (Tcl_SetEnsembleMappingDict(interp, ensembleCmdToken, mapObj) !=
TCL_OK) {
goto errorout ;
}
/*
* Support for package configuration.
*/
Tcl_RegisterConfig(interp, ral_pkgname, ral_config, "iso8859-1") ;

Tcl_PkgProvide(interp, ral_pkgname, ral_version) ;

return TCL_OK ;

errorout:
Tcl_DecrRefCount(mapObj) ;
return TCL_ERROR ;
} -----------

Andrew Mangogna

1

rocksolid light 0.9.8
clearnet tor