Rocksolid Light

News from da outaworlds

mail  files  register  groups  login

Message-ID:  

BOFH excuse #176: vapors from evaporating sticky-note adhesives


comp / comp.lang.tcl / Re: Tcl9: source files are interpreted as utf-8 by default

SubjectAuthor
* Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
+* Re: Tcl9: source files are interpreted as utf-8 by defaultHarald Oehlmann
|`- Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
`* Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
 +* Re: Tcl9: source files are interpreted as utf-8 by defaultHarald Oehlmann
 |`* Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
 | `* Re: Tcl9: source files are interpreted as utf-8 by defaultHarald Oehlmann
 |  `* Re: Tcl9: source files are interpreted as utf-8 by defaultHarald Oehlmann
 |   `- Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
 `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
  `* Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
   `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
    `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
     `* Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
      `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
       `* Re: Tcl9: source files are interpreted as utf-8 by defaultRich
        `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
         `* Re: Tcl9: source files are interpreted as utf-8 by defaultRich
          +* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
          |+- Re: Tcl9: source files are interpreted as utf-8 by defaultted@loft.tnolan.com (Ted Nolan
          |`* Re: Tcl9: source files are interpreted as utf-8 by defaultRich
          | `* Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
          |  `* Re: Tcl9: source files are interpreted as utf-8 by defaultRich
          |   +* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
          |   |`* Re: Tcl9: source files are interpreted as utf-8 by defaultRich
          |   | `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
          |   |  `* Re: Tcl9: source files are interpreted as utf-8 by defaulteric
          |   |   `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
          |   |    `- Re: Tcl9: source files are interpreted as utf-8 by defaultRich
          |   `- Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
          `* Re: Tcl9: source files are interpreted as utf-8 by defaultsaito
           `* Re: Tcl9: source files are interpreted as utf-8 by defaultRich
            `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
             `* Re: Tcl9: source files are interpreted as utf-8 by defaultRich
              `* Re: Tcl9: source files are interpreted as utf-8 by defaultLuc
               +* Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
               |`* Re: Tcl9: source files are interpreted as utf-8 by defaultHarald Oehlmann
               | `* Re: Tcl9: source files are interpreted as utf-8 by defaultUwe Schmitz
               |  `- Re: Tcl9: source files are interpreted as utf-8 by defaultHarald Oehlmann
               `- Re: Tcl9: source files are interpreted as utf-8 by defaultRich

Pages:12
Subject: Tcl9: source files are interpreted as utf-8 by default
From: Uwe Schmitz
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Fri, 13 Dec 2024 15:02 UTC
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: schmitzu@mail.de (Uwe Schmitz)
Newsgroups: comp.lang.tcl
Subject: Tcl9: source files are interpreted as utf-8 by default
Date: Fri, 13 Dec 2024 16:02:51 +0100
Organization: A noiseless patient Spider
Lines: 23
Message-ID: <vjhiar$3f9go$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Fri, 13 Dec 2024 16:02:51 +0100 (CET)
Injection-Info: dont-email.me; posting-host="ec8d9bb9db8e7a75e054905540d9655e";
logging-data="3647000"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+nfGth0h7XS3zN9azWkvamUyuL33DfM7E="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:FQifrQHj+f14uVAM3IgS255u5A0=
Content-Language: de-DE
View all headers

Folks,

is it possible in Tcl9 to get the old (8.x) behaviour back,
that tcl files are read with system encoding instead of
utf-8?
Is there e.g. an environment variable or a configure
switch to change this?

I found:

--with-encoding encoding for configuration values (default: utf-8)

but, what is meant with "configuration values"?

I've the problem that almost all of my sources contain some
umlauts and are, for legacy reasons, in iso8859-1. If it's
not possible to get the old behavior back, I have to
edit every pkgIndex.tcl and every tclsh <script> call
before I'm able to migrate.

Thanks in advance
Uwe

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Harald Oehlmann
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Fri, 13 Dec 2024 15:17 UTC
References: 1
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: wortkarg3@yahoo.com (Harald Oehlmann)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Fri, 13 Dec 2024 16:17:48 +0100
Organization: A noiseless patient Spider
Lines: 35
Message-ID: <vjhj6r$3b13l$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 8bit
Injection-Date: Fri, 13 Dec 2024 16:17:48 +0100 (CET)
Injection-Info: dont-email.me; posting-host="2fc26accfba6307eda4cfd286a51c198";
logging-data="3507317"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX196xLqitXNdPlLldkj1nFkn"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:wV2ER6Dqcr1V9I73nGEtVnW9KHY=
In-Reply-To: <vjhiar$3f9go$1@dont-email.me>
Content-Language: en-GB
View all headers

Am 13.12.2024 um 16:02 schrieb Uwe Schmitz:
> Folks,
>
> is it possible in Tcl9 to get the old (8.x) behaviour back,
> that tcl files are read with system encoding instead of
> utf-8?
> Is there e.g. an environment variable or a configure
> switch to change this?
>
> I found:
>
> --with-encoding         encoding for configuration values (default: utf-8)
>
> but, what is meant with "configuration values"?
>
> I've the problem that almost all of my sources contain some
> umlauts and are, for legacy reasons, in iso8859-1. If it's
> not possible to get the old behavior back, I have to
> edit every pkgIndex.tcl and every tclsh <script> call
> before I'm able to migrate.
>
> Thanks in advance
> Uwe
>

Hi Uwe,
source -encoding iso8859-1 $file

I put those in the package index files which source the package files.
Remark that msgcat message files are always in utf-8.

The great TCL9 migration helper by Ashok tries to find the related files.

Take care,
Harald

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Uwe Schmitz
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Fri, 13 Dec 2024 15:41 UTC
References: 1 2
Path: eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: schmitzu@mail.de (Uwe Schmitz)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Fri, 13 Dec 2024 16:41:45 +0100
Organization: A noiseless patient Spider
Lines: 60
Message-ID: <vjhkjo$3f9go$2@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vjhj6r$3b13l$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 8bit
Injection-Date: Fri, 13 Dec 2024 16:41:44 +0100 (CET)
Injection-Info: dont-email.me; posting-host="ec8d9bb9db8e7a75e054905540d9655e";
logging-data="3647000"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/Y5QbycuEW8loYPWYWa0lX7VlKz5mbyak="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:i2zc4rBmTMw5ff3YO3yLVAVNgJE=
In-Reply-To: <vjhj6r$3b13l$1@dont-email.me>
Content-Language: de-DE
View all headers

Hi Harald,

> source -encoding iso8859-1 $file
>
> I put those in the package index files which source the package files.
> Remark that msgcat message files are always in utf-8.

I was worried that I would have to add this to all
my packages. However, that seems manageable.

I'm more worried that I also have to add the encoding
to all my ksh/bash scripts that call Tcl via
tclsh <scriptfile>.

I've already made a note of Ashok's migration helper.
I wanted to use it in the next step. I didn't expect
to run into migration problems during installation
(where some simple Tcl scripts are used, e.g. for
documentation purposes).

Thanks for your answer!
Uwe

Am 13.12.2024 um 16:17 schrieb Harald Oehlmann:
> Am 13.12.2024 um 16:02 schrieb Uwe Schmitz:
>> Folks,
>>
>> is it possible in Tcl9 to get the old (8.x) behaviour back,
>> that tcl files are read with system encoding instead of
>> utf-8?
>> Is there e.g. an environment variable or a configure
>> switch to change this?
>>
>> I found:
>>
>> --with-encoding         encoding for configuration values (default: utf-8)
>>
>> but, what is meant with "configuration values"?
>>
>> I've the problem that almost all of my sources contain some
>> umlauts and are, for legacy reasons, in iso8859-1. If it's
>> not possible to get the old behavior back, I have to
>> edit every pkgIndex.tcl and every tclsh <script> call
>> before I'm able to migrate.
>>
>> Thanks in advance
>> Uwe
>>
>
> Hi Uwe,
> source -encoding iso8859-1 $file
>
> I put those in the package index files which source the package files.
> Remark that msgcat message files are always in utf-8.
>
> The great TCL9 migration helper by Ashok tries to find the related files.
>
> Take care,
> Harald

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Uwe Schmitz
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Tue, 7 Jan 2025 17:00 UTC
References: 1
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: schmitzu@mail.de (Uwe Schmitz)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Tue, 7 Jan 2025 18:00:15 +0100
Organization: A noiseless patient Spider
Lines: 56
Message-ID: <vljmj2$29vdo$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 8bit
Injection-Date: Tue, 07 Jan 2025 18:00:19 +0100 (CET)
Injection-Info: dont-email.me; posting-host="3511bd66db0b1206656c0f9efda30f8a";
logging-data="2424248"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19pb5qMyvxTG9/NIOfnyHwFFbAb0vgCx+0="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:+LkN3qJi8Qfv1+zbrrsaeWl8AlA=
Content-Language: de-DE
In-Reply-To: <vjhiar$3f9go$1@dont-email.me>
View all headers

Sorry that I have to come back to this issue.

As stated before, we use iso8859-1 as system encoding.
With Tcl9 we now got errors reading source files with e.g. umlauts,
because Tcl9 interprets all sources as utf-8 by
default. That means we have to add "-encoding iso8859-1"
to ALL source and ALL tclsh calls in ALL scripts.
So far, so good(or bad?).

What initially seems quite doable, looks more and more scary
to me. First, if we ever may switch encoding to utf-8 we
have to alter all those lines again. Either we switch them to utf-8 or
we remove the -encoding and went back
to the state before Tcl9.

Another point: we have MANY scripts only for development needs.
Coded quickNdirty for code generation, documentation, packaging, etc.
Most of them called by "tclsh helperScript.tcl ..." (they have no shebang or
whatever). They now have to be called by
"tclsh -encoding iso8859-1 helperScript.tcl ..."

Thats a lot more typing.

Some of them have a usage message like:
usage: tclsh helperScript.tcl arg1 arg2
....

Do we now have to change it to:
usage: tclsh -encoding iso8859-1 helperScript.tcl arg1 arg2
....
?

Side note: The open command, which opens a file with the
system encoding by default, has thankfully not changed
in the same manner as source and tclsh :-).

Now my suggestion:
Wouldn't it be convenient for Tcl9 to have a global switch
(e.g. Environment variable) to get back the Tcl8 encoding
behaviour?
Or, isn't it best to keep the old encoding mimik in Tcl9.
I see no advantage in the new behavior. Even if you have
all sources in utf-8, you might also have choosen utf-8 as
system encoding.

Do we have (or can we have) a magic comment or something else
with which we can choose the encoding of a source file in
the file itself?
Python e.g. has https://peps.python.org/pep-0263/.

Maybe I’m missing something crucial...

Thanks in advance
Uwe

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Harald Oehlmann
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Tue, 7 Jan 2025 17:20 UTC
References: 1 2
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: wortkarg3@yahoo.com (Harald Oehlmann)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Tue, 7 Jan 2025 18:20:08 +0100
Organization: A noiseless patient Spider
Lines: 74
Message-ID: <vljno8$24ig0$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 8bit
Injection-Date: Tue, 07 Jan 2025 18:20:09 +0100 (CET)
Injection-Info: dont-email.me; posting-host="5cf8727bd422c46aed9cbb6e4afe058a";
logging-data="2247168"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+idZzf62GmKsMzVo1IQXDe"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:W5pTkgEwp2UDSFxHD43EApJXNi8=
Content-Language: en-GB
In-Reply-To: <vljmj2$29vdo$1@dont-email.me>
View all headers

Am 07.01.2025 um 18:00 schrieb Uwe Schmitz:
> Sorry that I have to come back to this issue.
>
> As stated before, we use iso8859-1 as system encoding.
> With Tcl9 we now got errors reading source files with e.g. umlauts,
> because Tcl9 interprets all sources as utf-8 by
> default. That means we have to add "-encoding iso8859-1"
> to ALL source and ALL tclsh calls in ALL scripts.
> So far, so good(or bad?).
>
> What initially seems quite doable, looks more and more scary
> to me. First, if we ever may switch encoding to utf-8 we
> have to alter all those lines again. Either we switch them to utf-8 or
> we remove the -encoding and went back
> to the state before Tcl9.
>
> Another point: we have MANY scripts only for development needs.
> Coded quickNdirty for code generation, documentation, packaging, etc.
> Most of them called by "tclsh helperScript.tcl ..." (they have no
> shebang or
> whatever). They now have to be called by
> "tclsh -encoding iso8859-1 helperScript.tcl ..."
>
> Thats a lot more typing.
>
> Some of them have a usage message like:
> usage: tclsh helperScript.tcl arg1 arg2
> ...
>
> Do we now have to change it to:
> usage: tclsh -encoding iso8859-1 helperScript.tcl arg1 arg2
> ...
> ?
>
> Side note: The open command, which opens a file with the
> system encoding by default, has thankfully not changed
> in the same manner as source and tclsh :-).
>
> Now my suggestion:
> Wouldn't it be convenient for Tcl9 to have a global switch
> (e.g. Environment variable) to get back the Tcl8 encoding
> behaviour?
> Or, isn't it best to keep the old encoding mimik in Tcl9.
> I see no advantage in the new behavior. Even if you have
> all sources in utf-8, you might also have choosen utf-8 as
> system encoding.
>
> Do we have (or can we have) a magic comment or something else
> with which we can choose the encoding of a source file in
> the file itself?
> Python e.g. has https://peps.python.org/pep-0263/.
>
> Maybe I’m missing something crucial...
>
> Thanks in advance
> Uwe
>
>

THanks, Uwe.
Sorry, for the inconvenience.

For me, this is a big step forward.

With tcl 8.6, I always have to type:
source -encoding utf-8 script.tcl
as I don't know the system encoding.
It is not setable for me.
So, this change is a big advantage, as now, I can type:
source script.tcl.

Sorry,
Harald

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Tue, 7 Jan 2025 19:08 UTC
References: 1 2
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Tue, 7 Jan 2025 16:08:10 -0300
Organization: A noiseless patient Spider
Lines: 19
Message-ID: <20250107160810.07ddbbe6@lud1.home>
References: <vjhiar$3f9go$1@dont-email.me>
<vljmj2$29vdo$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Tue, 07 Jan 2025 20:08:10 +0100 (CET)
Injection-Info: dont-email.me; posting-host="5827139485d3613087275ba5503a9269";
logging-data="2470057"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19WxMs5FfYwjAvdvldskqisqr28okMANK0="
Cancel-Lock: sha1:fvYZeHaoLtgKfJ1KztT9qWaFVtw=
View all headers

On Tue, 7 Jan 2025 18:00:15 +0100, Uwe Schmitz wrote:

>They now have to be called by
>"tclsh -encoding iso8859-1 helperScript.tcl ..."
>
>Thats a lot more typing.
>
**************************

The lot more typing problem can be solved with a shell alias.

In Tcl, using 'source,' you can create an alias too.

Not exactly what you wanted, but readily available here and now.

--
Luc
>>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Uwe Schmitz
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 10:35 UTC
References: 1 2 3
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: schmitzu@mail.de (Uwe Schmitz)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 11:35:10 +0100
Organization: A noiseless patient Spider
Lines: 34
Message-ID: <vllkcu$2nvqo$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
<vljno8$24ig0$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 11:35:10 +0100 (CET)
Injection-Info: dont-email.me; posting-host="16d4f685a9efab1420a04f2d2c4b5643";
logging-data="2883416"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+7AuHfwbBSDVesQjFozEMKanU2qh70SgE="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:rEUzVEPDbu3G+qHLIXCmbC4/IJY=
Content-Language: de-DE
In-Reply-To: <vljno8$24ig0$1@dont-email.me>
View all headers

Harald,

> THanks, Uwe.
> Sorry, for the inconvenience.
>
> For me, this is a big step forward.
>
> With tcl 8.6, I always have to type:
> source -encoding utf-8 script.tcl
> as I don't know the system encoding.
> It is not setable for me.
> So, this change is a big advantage, as now, I can type:
> source script.tcl.
>
on all the systems I've worked on so far, I've been able to
to set the system encoding, even as a normal user.
Users of our in-house software stack (similar to BAWT, but only
for Linux) are advised to set iso8859-1 encoding, before running
any programs.

Anyhow, what we should have at least is a magic comment as described
in my other post. This would give you the option of placing
the encoding where it really belongs. And this would avoid
having to include the encoding with every source/tclsh call.
If you ever change the encoding, you have to find all this places
and correct them. Good luck to find them all...

To summarize, I am more and more getting to the opinion,
that Tcl9 forces developers to encode their source codes in utf-8.
Otherwise you end up in an encoding nightmare.

Best regards,
Uwe

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Uwe Schmitz
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 10:54 UTC
References: 1 2 3
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: schmitzu@mail.de (Uwe Schmitz)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 11:54:34 +0100
Organization: A noiseless patient Spider
Lines: 39
Message-ID: <vlllha$2nvqo$2@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 11:54:34 +0100 (CET)
Injection-Info: dont-email.me; posting-host="16d4f685a9efab1420a04f2d2c4b5643";
logging-data="2883416"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX188rfmfWRG+Ldv9DSxe1iiDDthxrxOwZ/U="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:18Me93sH/k9hdISfA9e+XUTvAKU=
Content-Language: de-DE
In-Reply-To: <20250107160810.07ddbbe6@lud1.home>
View all headers

Thanks for your suggestions!

I know that there are ways to work around the typing effort.

Aliases are a good start, but you have to deploy them to
other users/developers. And it's getting more cpomlicated if
you have heterogenous operating systems (thinking of Windows).

Redefining the source command is another one. In the past, I was always
very careful when it came to overwriting BuiltIns. In small
applications, this is usually manageable. But when the
applications get bigger, it's easy to lose track and
shoot yourself in the foot.

However, before I consider any of the above options,
I try to solve problems as close to the actual cause as possible.

Best regards,
Uwe

Am 07.01.2025 um 20:08 schrieb Luc:
> On Tue, 7 Jan 2025 18:00:15 +0100, Uwe Schmitz wrote:
>
>> They now have to be called by
>> "tclsh -encoding iso8859-1 helperScript.tcl ..."
>>
>> Thats a lot more typing.
>>
> **************************
>
> The lot more typing problem can be solved with a shell alias.
>
> In Tcl, using 'source,' you can create an alias too.
>
> Not exactly what you wanted, but readily available here and now.
>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Harald Oehlmann
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 10:58 UTC
References: 1 2 3 4
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: wortkarg3@yahoo.com (Harald Oehlmann)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 11:58:08 +0100
Organization: A noiseless patient Spider
Lines: 49
Message-ID: <vlllo0$2llov$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
<vljno8$24ig0$1@dont-email.me> <vllkcu$2nvqo$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 11:58:08 +0100 (CET)
Injection-Info: dont-email.me; posting-host="2478bf1b0e4e52711e6a09f7e3b46e96";
logging-data="2807583"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/zkPUOEtqZnv0mGwk9CZ0Y"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:Yo/OUb4EXxHzXUY12dY8M05Rcdc=
Content-Language: en-GB
In-Reply-To: <vllkcu$2nvqo$1@dont-email.me>
View all headers

Am 08.01.2025 um 11:35 schrieb Uwe Schmitz:
> Harald,
>
>> THanks, Uwe.
>> Sorry, for the inconvenience.
>>
>> For me, this is a big step forward.
>>
>> With tcl 8.6, I always have to type:
>> source -encoding utf-8 script.tcl
>> as I don't know the system encoding.
>> It is not setable for me.
>> So, this change is a big advantage, as now, I can type:
>> source script.tcl.
>>
> on all the systems I've worked on so far, I've been able to
> to set the system encoding, even as a normal user.
> Users of our in-house software stack (similar to BAWT, but only
> for Linux) are advised to set iso8859-1 encoding, before running
> any programs.
>
> Anyhow, what we should have at least is a magic comment as described
> in my other post. This would give you the option of placing
> the encoding where it really belongs. And this would avoid
> having to include the encoding with every source/tclsh call.
> If you ever change the encoding, you have to find all this places
> and correct them. Good luck to find them all...
>
> To summarize, I am more and more getting to the opinion,
> that Tcl9 forces developers to encode their source codes in utf-8.
> Otherwise you end up in an encoding nightmare.
>
> Best regards,
> Uwe

Sorry, I am MS-Windows only.
I can only set the system encoding system wide (well, the answer is more
complicated - it depends on the application manifest and the system wide
system encoding).
As I distribute my software worldwide, I am not in control of the system
encoding.

Sorry, different use-case, different answer.

If you want this feature, please file a bug report at the bug tracker.

Take care,
Harald

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Harald Oehlmann
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 12:01 UTC
References: 1 2 3 4 5
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: wortkarg3@yahoo.com (Harald Oehlmann)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 13:01:54 +0100
Organization: A noiseless patient Spider
Lines: 59
Message-ID: <vllpfi$2llov$2@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
<vljno8$24ig0$1@dont-email.me> <vllkcu$2nvqo$1@dont-email.me>
<vlllo0$2llov$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 13:01:54 +0100 (CET)
Injection-Info: dont-email.me; posting-host="2478bf1b0e4e52711e6a09f7e3b46e96";
logging-data="2807583"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+X5oPO7dqf3z+yS3Z5HFcq"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:8e/vF1BrvgYZbaiWjlo/wGNflyc=
Content-Language: en-GB
In-Reply-To: <vlllo0$2llov$1@dont-email.me>
View all headers

Am 08.01.2025 um 11:58 schrieb Harald Oehlmann:
> Am 08.01.2025 um 11:35 schrieb Uwe Schmitz:
>> Harald,
>>
>>> THanks, Uwe.
>>> Sorry, for the inconvenience.
>>>
>>> For me, this is a big step forward.
>>>
>>> With tcl 8.6, I always have to type:
>>> source -encoding utf-8 script.tcl
>>> as I don't know the system encoding.
>>> It is not setable for me.
>>> So, this change is a big advantage, as now, I can type:
>>> source script.tcl.
>>>
>> on all the systems I've worked on so far, I've been able to
>> to set the system encoding, even as a normal user.
>> Users of our in-house software stack (similar to BAWT, but only
>> for Linux) are advised to set iso8859-1 encoding, before running
>> any programs.
>>
>> Anyhow, what we should have at least is a magic comment as described
>> in my other post. This would give you the option of placing
>> the encoding where it really belongs. And this would avoid
>> having to include the encoding with every source/tclsh call.
>> If you ever change the encoding, you have to find all this places
>> and correct them. Good luck to find them all...
>>
>> To summarize, I am more and more getting to the opinion,
>> that Tcl9 forces developers to encode their source codes in utf-8.
>> Otherwise you end up in an encoding nightmare.
>>
>> Best regards,
>> Uwe
>
> Sorry, I am MS-Windows only.
> I can only set the system encoding system wide (well, the answer is more
> complicated - it depends on the application manifest and the system wide
> system encoding).
> As I distribute my software worldwide, I am not in control of the system
> encoding.
>
> Sorry, different use-case, different answer.
>
> If you want this feature, please file a bug report at the bug tracker.
>
> Take care,
> Harald
>

And you may change the behaviour in the automatically sourced startup
file in your home folder or wherever, Linux folks may help.

rename source source2
proc source args {
source2 -encoding iso8859-1 {*}$args
}

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 14:35 UTC
References: 1 2 3 4
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 11:35:19 -0300
Organization: A noiseless patient Spider
Lines: 16
Message-ID: <20250108113519.42eb3746@lud1.home>
References: <vjhiar$3f9go$1@dont-email.me>
<vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home>
<vlllha$2nvqo$2@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 15:35:20 +0100 (CET)
Injection-Info: dont-email.me; posting-host="7d95cffd09224c3a95ae5f2e61a7045f";
logging-data="2974980"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18sH9hYrLUXJ81eRn5ZjtLAvTH+ipxObfQ="
Cancel-Lock: sha1:ZSCyzHxYFzSiQ1YgfQuyRhpwvhA=
View all headers

On Wed, 8 Jan 2025 11:54:34 +0100, Uwe Schmitz wrote:

>However, before I consider any of the above options,
>I try to solve problems as close to the actual cause as possible.
**************************

I can get my encoding in the ::env array on Linux. Can you on Windows?
If so, maybe you can use that to set the encoding in the beginning
of all scripts and never have to change it because it will adjust
automatically.

--
Luc
>>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 14:42 UTC
References: 1 2 3 4 5
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 11:42:54 -0300
Organization: A noiseless patient Spider
Lines: 17
Message-ID: <20250108114254.7f56f049@lud1.home>
References: <vjhiar$3f9go$1@dont-email.me>
<vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home>
<vlllha$2nvqo$2@dont-email.me>
<20250108113519.42eb3746@lud1.home>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 15:42:55 +0100 (CET)
Injection-Info: dont-email.me; posting-host="7d95cffd09224c3a95ae5f2e61a7045f";
logging-data="2977805"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/6trtxezsWrO5mlR3X3TofLFp5DakDTsg="
Cancel-Lock: sha1:h+B0yvpxId5lJHEKltflv1qAo1U=
View all headers

On Wed, 8 Jan 2025 11:35:19 -0300, Luc wrote:

>I can get my encoding in the ::env array on Linux. Can you on Windows?
>If so, maybe you can use that to set the encoding in the beginning
>of all scripts and never have to change it because it will adjust
>automatically.
**************************

Another idea: force all scripts to source a set_encoding.tcl file
stored somewhere. If you ever have to change, you change the one file
and move on. You could even make it blank if convenient or necessary.

--
Luc
>>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Uwe Schmitz
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 14:56 UTC
References: 1 2 3 4 5 6
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: schmitzu@mail.de (Uwe Schmitz)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 15:56:15 +0100
Organization: A noiseless patient Spider
Lines: 9
Message-ID: <vlm3mf$2qvor$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
<vljno8$24ig0$1@dont-email.me> <vllkcu$2nvqo$1@dont-email.me>
<vlllo0$2llov$1@dont-email.me> <vllpfi$2llov$2@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 15:56:16 +0100 (CET)
Injection-Info: dont-email.me; posting-host="16d4f685a9efab1420a04f2d2c4b5643";
logging-data="2981659"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/1FJv0LLn+d1hdMjYYB2NLE3CkmKbRQTA="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:SQpE7k+mH1Em9Nc2xDmS9AEFMfQ=
Content-Language: de-DE
In-Reply-To: <vllpfi$2llov$2@dont-email.me>
View all headers

>
> And you may change the behaviour in the automatically sourced startup file in your home folder or wherever, Linux folks may help.
>
> rename source source2
> proc source args {
> source2 -encoding iso8859-1 {*}$args
> }
>
Yes, but this only works for interactive tclsh's.

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Uwe Schmitz
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 15:04 UTC
References: 1 2 3 4 5 6
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: schmitzu@mail.de (Uwe Schmitz)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 16:04:26 +0100
Organization: A noiseless patient Spider
Lines: 16
Message-ID: <vlm45q$2qvor$2@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home> <vlllha$2nvqo$2@dont-email.me>
<20250108113519.42eb3746@lud1.home> <20250108114254.7f56f049@lud1.home>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 16:04:27 +0100 (CET)
Injection-Info: dont-email.me; posting-host="16d4f685a9efab1420a04f2d2c4b5643";
logging-data="2981659"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+0k7Mp5MAzj4jDPKgMSMvTPAEH73DJKrE="
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:R7+ol+Vj3J1694RfIy8Ka9sKF9U=
Content-Language: de-DE
In-Reply-To: <20250108114254.7f56f049@lud1.home>
View all headers

Am 08.01.2025 um 15:42 schrieb Luc:
> On Wed, 8 Jan 2025 11:35:19 -0300, Luc wrote:
>
>> I can get my encoding in the ::env array on Linux. Can you on Windows?
>> If so, maybe you can use that to set the encoding in the beginning
>> of all scripts and never have to change it because it will adjust
>> automatically.
> **************************
>
> Another idea: force all scripts to source a set_encoding.tcl file
> stored somewhere. If you ever have to change, you change the one file
> and move on. You could even make it blank if convenient or necessary.
>
>
Nice try, but I don't think it's possible to set the encoding within the file.
And that for one simple reason: the file has already been read.

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 15:40 UTC
References: 1 2 3 4 5 6 7
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 12:40:55 -0300
Organization: A noiseless patient Spider
Lines: 25
Message-ID: <20250108124055.15c92a05@lud1.home>
References: <vjhiar$3f9go$1@dont-email.me>
<vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home>
<vlllha$2nvqo$2@dont-email.me>
<20250108113519.42eb3746@lud1.home>
<20250108114254.7f56f049@lud1.home>
<vlm45q$2qvor$2@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 16:40:57 +0100 (CET)
Injection-Info: dont-email.me; posting-host="7d95cffd09224c3a95ae5f2e61a7045f";
logging-data="2997818"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1/+mG+NcwvJRm0r5fKzYh4sfq4fvr6t9L0="
Cancel-Lock: sha1:Y5wHo1RBdC9OYupzo6r/idPvI6o=
View all headers

On Wed, 8 Jan 2025 16:04:26 +0100, Uwe Schmitz wrote:

>> Another idea: force all scripts to source a set_encoding.tcl file
>> stored somewhere. If you ever have to change, you change the one file
>> and move on. You could even make it blank if convenient or necessary.
>>
>>
>Nice try, but I don't think it's possible to set the encoding within the
>file. And that for one simple reason: the file has already been read.
**************************

That doesn't sound quite true to me. Why is there an 'encoding' command
then? Is it useless because whenever you use it it's too late because
the file has already been read? Unlikely.

Source the set_encoding.tcl file before anything else, before you even
try to read anything. If you can set the encoding on the command line,
you can set it on the first line of the script that command line is
supposed to run.

--
Luc
>>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Rich
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 17:04 UTC
References: 1 2 3 4 5 6 7 8
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: rich@example.invalid (Rich)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 17:04:26 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 41
Message-ID: <vlmb6q$2sblj$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me> <20250107160810.07ddbbe6@lud1.home> <vlllha$2nvqo$2@dont-email.me> <20250108113519.42eb3746@lud1.home> <20250108114254.7f56f049@lud1.home> <vlm45q$2qvor$2@dont-email.me> <20250108124055.15c92a05@lud1.home>
Injection-Date: Wed, 08 Jan 2025 18:04:27 +0100 (CET)
Injection-Info: dont-email.me; posting-host="bfc47b907fca7cd15e0f04fd46849852";
logging-data="3026611"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+FJHknT4rCIj9IQdyVAbZJ"
User-Agent: tin/2.6.1-20211226 ("Convalmore") (Linux/5.15.139 (x86_64))
Cancel-Lock: sha1:NDWOiZ79LawkexL3xzCQEickLaA=
View all headers

Luc <luc@sep.invalid> wrote:
> On Wed, 8 Jan 2025 16:04:26 +0100, Uwe Schmitz wrote:
>
>>> Another idea: force all scripts to source a set_encoding.tcl file
>>> stored somewhere. If you ever have to change, you change the one file
>>> and move on. You could even make it blank if convenient or necessary.
>>>
>>>
>>Nice try, but I don't think it's possible to set the encoding within the
>>file. And that for one simple reason: the file has already been read.
> **************************
>
> That doesn't sound quite true to me. Why is there an 'encoding' command
> then? Is it useless because whenever you use it it's too late because
> the file has already been read? Unlikely.
>
> Source the set_encoding.tcl file before anything else, before you even
> try to read anything. If you can set the encoding on the command line,
> you can set it on the first line of the script that command line is
> supposed to run.

Uwe's issue is two part:

1) encoding for scripts his 'main' script itself sources. Your
suggestion for renaming 'source' early would avoid having to change
every [source] invocation from that point forward in the main script
or in any script it sources.

2) encoding for the 'main' script itself (the very first one loaded
when his application is started). This one is "sourced" by the main
Tcl interpreter, and is read in and parsed using the default
character encoding the interpreter is using, before any commands in
that script are run. So this situation creates a chicken-or-the-egg
situation. If the script is iso-8859 encoded, but Tcl's default
parsing reads it as UTF-8, then all of the iso-8859 characters
inside are already corrupted *before* even the first command in the
script is executed. So there's no way to "source" a
"set_encoding.tcl" /in the main script itself/, that would adjust
the encoding before the main script is parsed using the wrong
encoding.

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 19:23 UTC
References: 1 2 3 4 5 6 7 8 9
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 16:23:39 -0300
Organization: A noiseless patient Spider
Lines: 32
Message-ID: <20250108162339.7c04023e@lud1.home>
References: <vjhiar$3f9go$1@dont-email.me>
<vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home>
<vlllha$2nvqo$2@dont-email.me>
<20250108113519.42eb3746@lud1.home>
<20250108114254.7f56f049@lud1.home>
<vlm45q$2qvor$2@dont-email.me>
<20250108124055.15c92a05@lud1.home>
<vlmb6q$2sblj$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 20:23:40 +0100 (CET)
Injection-Info: dont-email.me; posting-host="7d95cffd09224c3a95ae5f2e61a7045f";
logging-data="3074891"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18GrifuitnQCvr3VlE12i6srTPJteW3PTg="
Cancel-Lock: sha1:k485wRknt5+HSRQJM7Sq/07+4mA=
View all headers

On Wed, 8 Jan 2025 17:04:26 -0000 (UTC), Rich wrote:

> situation. If the script is iso-8859 encoded, but Tcl's default
> parsing reads it as UTF-8, then all of the iso-8859 characters
> inside are already corrupted *before* even the first command in the
> script is executed. So there's no way to "source" a
> "set_encoding.tcl" /in the main script itself/, that would adjust
> the encoding before the main script is parsed using the wrong
> encoding.
>
**************************

I see.

How about trading places?

Instead of main.tcl sourcing set_encoding.tcl, starter.tcl runs some
'encoding' command then sources main.tcl. Basically, a wrapper.

Do we have a cigar?

Another option is to run 'iconv' recursively on all those source files.

I did something like that some 15 years ago. But my case involved a
migration. I had a ton of legacy iso-8859 files on a system-wide
utf-8 Linux system. That caused me problems too, but iconv fixed it.

--
Luc
>>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Rich
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 19:32 UTC
References: 1 2 3 4 5 6 7 8 9 10
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: rich@example.invalid (Rich)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 19:32:24 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 41
Message-ID: <vlmjs8$2tu2l$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me> <20250107160810.07ddbbe6@lud1.home> <vlllha$2nvqo$2@dont-email.me> <20250108113519.42eb3746@lud1.home> <20250108114254.7f56f049@lud1.home> <vlm45q$2qvor$2@dont-email.me> <20250108124055.15c92a05@lud1.home> <vlmb6q$2sblj$1@dont-email.me> <20250108162339.7c04023e@lud1.home>
Injection-Date: Wed, 08 Jan 2025 20:32:25 +0100 (CET)
Injection-Info: dont-email.me; posting-host="bfc47b907fca7cd15e0f04fd46849852";
logging-data="3078229"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19DJFtOdQ69c7RrXc1CI5f9"
User-Agent: tin/2.6.1-20211226 ("Convalmore") (Linux/5.15.139 (x86_64))
Cancel-Lock: sha1:ZhTOVSWj08yk38iq9+iKnI5lPbM=
View all headers

Luc <luc@sep.invalid> wrote:
> On Wed, 8 Jan 2025 17:04:26 -0000 (UTC), Rich wrote:
>
>> situation. If the script is iso-8859 encoded, but Tcl's default
>> parsing reads it as UTF-8, then all of the iso-8859 characters
>> inside are already corrupted *before* even the first command in the
>> script is executed. So there's no way to "source" a
>> "set_encoding.tcl" /in the main script itself/, that would adjust
>> the encoding before the main script is parsed using the wrong
>> encoding.
>>
> **************************
>
> I see.
>
> How about trading places?
>
> Instead of main.tcl sourcing set_encoding.tcl, starter.tcl runs some
> 'encoding' command then sources main.tcl. Basically, a wrapper.

Yes, that works. But then Uwe has to go and "wrapperize" all the
various scripts, on all the various client systems. So he's back in
the same boat of "major modifications need be made now" as changing all
the launching instances to launch with "-encoding iso-8859".

> Another option is to run 'iconv' recursively on all those source files.

I've resisted pointing this one out, but long term, yes, updating all
the scripts to be utf-8 encoded is the right, long term, answer. But
that belies all the current, short term effort, involved in doing so.

> I did something like that some 15 years ago. But my case involved a
> migration. I had a ton of legacy iso-8859 files on a system-wide
> utf-8 Linux system. That caused me problems too, but iconv fixed it.

In my case, I used the \uxxxx escapes for anything that was not plain
ASCII, so all my scripts are both "basic 8859" and "utf-8" at the same
time, and having Tcl 9 source them as utf-8 won't cause an issue. But
it sounds like Uwe directly entered the extended 8859 characters into
the scripts. Which very well may have made perfect sense if he had
more than one or two of them per script.

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 20:23 UTC
References: 1 2 3 4 5 6 7 8 9 10 11
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 17:23:12 -0300
Organization: A noiseless patient Spider
Lines: 60
Message-ID: <20250108172312.253b829c@lud1.home>
References: <vjhiar$3f9go$1@dont-email.me>
<vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home>
<vlllha$2nvqo$2@dont-email.me>
<20250108113519.42eb3746@lud1.home>
<20250108114254.7f56f049@lud1.home>
<vlm45q$2qvor$2@dont-email.me>
<20250108124055.15c92a05@lud1.home>
<vlmb6q$2sblj$1@dont-email.me>
<20250108162339.7c04023e@lud1.home>
<vlmjs8$2tu2l$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 21:23:13 +0100 (CET)
Injection-Info: dont-email.me; posting-host="7d95cffd09224c3a95ae5f2e61a7045f";
logging-data="3093168"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19jdKzR6CWiHDb/dLdPeshw0ziv6d70pd0="
Cancel-Lock: sha1:NiBQI+z+t+T4jLg9MJH75R/af2A=
View all headers

On Wed, 8 Jan 2025 19:32:24 -0000 (UTC), Rich wrote:

>> Instead of main.tcl sourcing set_encoding.tcl, starter.tcl runs some
>> 'encoding' command then sources main.tcl. Basically, a wrapper.
>
>Yes, that works. But then Uwe has to go and "wrapperize" all the
>various scripts, on all the various client systems. So he's back in
>the same boat of "major modifications need be made now" as changing all
>the launching instances to launch with "-encoding iso-8859".

True, but he has considered that kind of effort. His words:

"That means we have to add "-encoding iso8859-1"
to ALL source and ALL tclsh calls in ALL scripts.
So far, so good(or bad?)."

"What initially seems quite doable, looks more and more scary
to me. First, if we ever may switch encoding to utf-8 we
have to alter all those lines again."

So in my mind, the "customer" accepts (though grudgingly) making
large scale changes, but is concerned with possible new changes
in the future. A wrapper can handle the future quite gracefully.

>I've resisted pointing this one out, but long term, yes, updating all
>the scripts to be utf-8 encoded is the right, long term, answer. But
>that belies all the current, short term effort, involved in doing so.

Actually, when I mentioned my migration case, I was also thinking that
I could afford to do it because I was migrating to Linux and utf-8 was
not even the future anymore, it was pretty much the present. But maybe
running iconv wouldn't be acceptable because Uwe is (I assume) on
Windows. Does a Windows user want to convert his files to utf-8?
Won't that cause problems if the system is iso-8859-1? Windows still
uses iso-8859-1, right?

So yes, I guess Tcl9 causes trouble to 8859-1 users. Yes, sounds like
it needs some fixing.

More suggestions: how about not using Tcl9 just yet? I'm stil on 8.6
and the water is fine. Early adopters tend to pay a price. In my case,
absent packages.

I have my own special case, I use Debian 9 which only ships 8.6.6 so
I had to build 8.6.15 from source because I really need Unicode.
But for some time I used Freewrap as a single-file batteries included
Tcl/Tk interpreter. So maybe Uwe should just use a different interpreter,
likely just a slightly older version of Tcl/Tk and embrace Tcl9 later.

I wonder if one can hack the encoding issue on the Tcl9 source and
rebuild it.

--
Luc
>>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: ted@loft.tnolan.com
Newsgroups: comp.lang.tcl
Organization: loft
Date: Wed, 8 Jan 2025 22:06 UTC
References: 1 2 3 4
Path: news.eternal-september.org!eternal-september.org!feeder3.eternal-september.org!fu-berlin.de!uni-berlin.de!individual.net!not-for-mail
From: @ednolan (ted@loft.tnolan.com (Ted Nolan)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: 8 Jan 2025 22:06:24 GMT
Organization: loft
Lines: 250
Message-ID: <lu8b6vFhjecU1@mid.individual.net>
References: <vjhiar$3f9go$1@dont-email.me> <20250108162339.7c04023e@lud1.home> <vlmjs8$2tu2l$1@dont-email.me> <20250108172312.253b829c@lud1.home>
X-Trace: individual.net 2tpKOQqHAljVXJHcn7fs0gnR9qmqMD7Q+MJ4InieJvLEoPAs5N
X-Orig-Path: not-for-mail
Cancel-Lock: sha1:Tm2LTrsPsNAlT3TNGKer5rtQWGM= sha256:dU4cAaJG289/sFajoSRNQ42fQFG0miDNl440jWdIprY=
X-Newsreader: trn 4.0-test76 (Apr 2, 2001)
View all headers

In article <20250108172312.253b829c@lud1.home>, Luc <luc@sep.invalid> wrote:
>On Wed, 8 Jan 2025 19:32:24 -0000 (UTC), Rich wrote:
>
>>> Instead of main.tcl sourcing set_encoding.tcl, starter.tcl runs some
>>> 'encoding' command then sources main.tcl. Basically, a wrapper.
>>
>>Yes, that works. But then Uwe has to go and "wrapperize" all the
>>various scripts, on all the various client systems. So he's back in
>>the same boat of "major modifications need be made now" as changing all
>>the launching instances to launch with "-encoding iso-8859".
>
>True, but he has considered that kind of effort. His words:
>
>
>"That means we have to add "-encoding iso8859-1"
>to ALL source and ALL tclsh calls in ALL scripts.
>So far, so good(or bad?)."
>
>"What initially seems quite doable, looks more and more scary
>to me. First, if we ever may switch encoding to utf-8 we
>have to alter all those lines again."
>
>
>So in my mind, the "customer" accepts (though grudgingly) making
>large scale changes, but is concerned with possible new changes
>in the future. A wrapper can handle the future quite gracefully.
>
>
>>I've resisted pointing this one out, but long term, yes, updating all
>>the scripts to be utf-8 encoded is the right, long term, answer. But
>>that belies all the current, short term effort, involved in doing so.
>
>Actually, when I mentioned my migration case, I was also thinking that
>I could afford to do it because I was migrating to Linux and utf-8 was
>not even the future anymore, it was pretty much the present. But maybe
>running iconv wouldn't be acceptable because Uwe is (I assume) on
>Windows. Does a Windows user want to convert his files to utf-8?
>Won't that cause problems if the system is iso-8859-1? Windows still
>uses iso-8859-1, right?
>
>So yes, I guess Tcl9 causes trouble to 8859-1 users. Yes, sounds like
>it needs some fixing.
>
>More suggestions: how about not using Tcl9 just yet? I'm stil on 8.6
>and the water is fine. Early adopters tend to pay a price. In my case,
>absent packages.
>
>I have my own special case, I use Debian 9 which only ships 8.6.6 so
>I had to build 8.6.15 from source because I really need Unicode.
>But for some time I used Freewrap as a single-file batteries included
>Tcl/Tk interpreter. So maybe Uwe should just use a different interpreter,
>likely just a slightly older version of Tcl/Tk and embrace Tcl9 later.
>
>I wonder if one can hack the encoding issue on the Tcl9 source and
>rebuild it.
>
>
>--
>Luc
>>>
>

FWIW, could check if a source file is utf-8 easily enough. I wrote
a command to do that based on some code from the web a while ago and
it seemed to work OK for what I needed it for.

So read your suspect file in binary mode, call "string_is_utf" on it and
if it is, you're good to source it.

(If it isn't you can probably apply some more heuristics on the
string to guess what it actually is).

==
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include <tcl.h>

#ifdef WIN32
#include <io.h>
#define TCL_API __declspec(dllexport)
#else
#include <unistd.h>
#define TCL_API
#endif

#ifdef WIN32
#define dup _dup
#define fileno _fileno
#define fdopen _fdopen
#define close _close
#endif

static char rcsid[] = "$Id$ TN";

/*
* Function prototypes
*/
TCL_API int Isutf_Init(Tcl_Interp *interp);

static int isutf_string_is_utf(ClientData clientData, Tcl_Interp *interp,
int objc, Tcl_Obj *CONST objv[]);

/*
* This decoder by Bjoern Hoermann is the simplest I've found. It also works
* by feeding it a single byte, as well as keeping a state. The state is
* very useful for parsing UTF8 coming in in chunks over the network.
*
* http://bjoern.hoehrmann.de/utf-8/decoder/dfa/
*
*/

// Copyright (c) 2008-2009 Bjoern Hoehrmann <bjoern@hoehrmann.de>
// See http://bjoern.hoehrmann.de/utf-8/decoder/dfa/ for details.

#define UTF8_ACCEPT 0
#define UTF8_REJECT 1

static const uint8_t utf8d[] = {

0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 00..1f
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 20..3f
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 40..5f
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, // 60..7f
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, // 80..9f
7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, // a0..bf
8,8,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2, // c0..df
0xa,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x3,0x4,0x3,0x3, // e0..ef
0xb,0x6,0x6,0x6,0x5,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8,0x8, // f0..ff
0x0,0x1,0x2,0x3,0x5,0x8,0x7,0x1,0x1,0x1,0x4,0x6,0x1,0x1,0x1,0x1, // s0..s0
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,1,1,0,1,0,1,1,1,1,1,1, // s1..s2
1,2,1,1,1,1,1,2,1,2,1,1,1,1,1,1,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1, // s3..s4
1,2,1,1,1,1,1,1,1,2,1,1,1,1,1,1,1,1,1,1,1,1,1,3,1,3,1,1,1,1,1,1, // s5..s6
1,3,1,1,1,1,1,3,1,3,1,1,1,1,1,1,1,3,1,1,1,1,1,1,1,1,1,1,1,1,1,1, // s7..s8
};

#if 0
static uint32_t decode(uint32_t* state, uint32_t* codep, uint32_t byte) {

uint32_t type = utf8d[byte];

*codep = (*state != UTF8_ACCEPT) ?
(byte & 0x3fu) | (*codep << 6) :
(0xff >> type) & (byte);

*state = utf8d[256 + *state*16 + type];

return *state;
} #endif

/*
*
* A simple validator/detector doesn't need the code point,
* so it could be written like this (Initial state is set to UTF8_ACCEPT):
*
*/
static uint32_t validate_utf8(uint32_t *state, unsigned char *str, size_t len) {

size_t i;
uint32_t type;

for (i = 0; i < len; i++) {
// We don't care about the codepoint, so this is
// a simplified version of the decode function.
type = utf8d[(uint8_t)str[i]];
*state = utf8d[256 + (*state) * 16 + type];

if (*state == UTF8_REJECT)
break;
}

return *state;
}

/*
* If the text is valid utf8 UTF8_ACCEPT is returned. If it's
* invalid UTF8_REJECT. If more data is needed, some other integer is returned.
*
*/

/*
* Init everything
*/

int Isutf_Init(Tcl_Interp *interp){

#ifdef USE_TCL_STUBS
Tcl_InitStubs(interp, "8.6", 0);
#endif
Tcl_CreateObjCommand(interp, "string_is_utf",
isutf_string_is_utf, (ClientData)NULL,
(Tcl_CmdDeleteProc *) NULL);

Tcl_PkgProvide(interp,"Isutf", "1.0");

return 0;
}

static int isutf_string_is_utf(ClientData clientData,
Tcl_Interp *interp, int objc, Tcl_Obj *CONST objv[])
{

unsigned char *bytes;
int bytelen;
char buf[1024];
Tcl_Obj *resultPtr;
uint32_t state = UTF8_ACCEPT;

resultPtr = Tcl_GetObjResult(interp);

if(objc != 2){
Tcl_WrongNumArgs(interp, 1, objv,
"Usage: string_is_utf binary_string");
return TCL_ERROR;
}

bytes = Tcl_GetByteArrayFromObj(objv[1], &bytelen);

#if 0
if(bytelen == 0) {

sprintf(buf, "0 bytes in object!");
Tcl_SetStringObj(resultPtr, buf, -1);
return TCL_ERROR;
}
#endif

if (validate_utf8(&state, bytes, bytelen) == UTF8_REJECT) {
sprintf(buf, "Invalid UTF8 data!");
Tcl_SetStringObj(resultPtr, buf, -1);
Tcl_SetIntObj(resultPtr, 0);
return TCL_OK;
}

Tcl_SetIntObj(resultPtr, 1);
return TCL_OK;
} --
columbiaclosings.com
What's not in Columbia anymore..

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: saito
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 22:36 UTC
References: 1 2 3 4 5 6 7 8 9 10 11
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: saitology9@gmail.com (saito)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 17:36:28 -0500
Organization: A noiseless patient Spider
Lines: 24
Message-ID: <vlmulc$3025m$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home> <vlllha$2nvqo$2@dont-email.me>
<20250108113519.42eb3746@lud1.home> <20250108114254.7f56f049@lud1.home>
<vlm45q$2qvor$2@dont-email.me> <20250108124055.15c92a05@lud1.home>
<vlmb6q$2sblj$1@dont-email.me> <20250108162339.7c04023e@lud1.home>
<vlmjs8$2tu2l$1@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 7bit
Injection-Date: Wed, 08 Jan 2025 23:36:29 +0100 (CET)
Injection-Info: dont-email.me; posting-host="4780325df47bf7be2593fcde0ad9658e";
logging-data="3147958"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19rqiquwe5XNwprbOcBPMQB"
User-Agent: Mozilla Thunderbird
Cancel-Lock: sha1:H5rVGbFCVgMCx4rgs7JeBpkTxVQ=
Content-Language: en-US
In-Reply-To: <vlmjs8$2tu2l$1@dont-email.me>
View all headers

On 1/8/2025 2:32 PM, Rich wrote:
>
>> I did something like that some 15 years ago. But my case involved a
>> migration. I had a ton of legacy iso-8859 files on a system-wide
>> utf-8 Linux system. That caused me problems too, but iconv fixed it.
>
> In my case, I used the \uxxxx escapes for anything that was not plain
> ASCII, so all my scripts are both "basic 8859" and "utf-8" at the same
> time, and having Tcl 9 source them as utf-8 won't cause an issue. But
> it sounds like Uwe directly entered the extended 8859 characters into
> the scripts. Which very well may have made perfect sense if he had
> more than one or two of them per script.

Interesting thread.

Is there a way check a script file for such incompatibilities ahead of time?

Would this work as a solution? You build your own Tcl/Tk and add or
duplicate the source command from an earlier version that you are happy
with. Then you start up your app as you do currenly, and once it is
loaded, you switch the source command to the new version and change the
system encoding.

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Rich
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 22:53 UTC
References: 1 2 3 4 5 6 7 8 9 10 11 12
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: rich@example.invalid (Rich)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 22:53:40 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 133
Message-ID: <vlmvlj$3025n$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me> <20250107160810.07ddbbe6@lud1.home> <vlllha$2nvqo$2@dont-email.me> <20250108113519.42eb3746@lud1.home> <20250108114254.7f56f049@lud1.home> <vlm45q$2qvor$2@dont-email.me> <20250108124055.15c92a05@lud1.home> <vlmb6q$2sblj$1@dont-email.me> <20250108162339.7c04023e@lud1.home> <vlmjs8$2tu2l$1@dont-email.me> <20250108172312.253b829c@lud1.home>
Injection-Date: Wed, 08 Jan 2025 23:53:41 +0100 (CET)
Injection-Info: dont-email.me; posting-host="bfc47b907fca7cd15e0f04fd46849852";
logging-data="3147959"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX1+iHynaKq/p1IcD0e2GbbLg"
User-Agent: tin/2.6.1-20211226 ("Convalmore") (Linux/5.15.139 (x86_64))
Cancel-Lock: sha1:cUyIAUs8Y7FUxso7n5L7rjfLRY4=
View all headers

Luc <luc@sep.invalid> wrote:
> On Wed, 8 Jan 2025 19:32:24 -0000 (UTC), Rich wrote:
>
>>> Instead of main.tcl sourcing set_encoding.tcl, starter.tcl runs some
>>> 'encoding' command then sources main.tcl. Basically, a wrapper.
>>
>>Yes, that works. But then Uwe has to go and "wrapperize" all the
>>various scripts, on all the various client systems. So he's back in
>>the same boat of "major modifications need be made now" as changing all
>>the launching instances to launch with "-encoding iso-8859".
>
> True, but he has considered that kind of effort. His words:
>
>
> "That means we have to add "-encoding iso8859-1"
> to ALL source and ALL tclsh calls in ALL scripts.
> So far, so good(or bad?)."
>
> "What initially seems quite doable, looks more and more scary
> to me. First, if we ever may switch encoding to utf-8 we
> have to alter all those lines again."
>
>
> So in my mind, the "customer" accepts (though grudgingly) making
> large scale changes, but is concerned with possible new changes
> in the future. A wrapper can handle the future quite gracefully.

Uwe's reality is likely that at some point a "mass migration" may very
well have to be done. There's at least two possibilities:

1) Tcl9 remains as it is today, loading all scripts as UTF-8 unless
told otherwise by a user provided option. Either all iso-8859 scripts
have to be modifed to become:
1a) UTF-8 encoded;
1b) modified pass the -encoding parameter to [source]
1c) a wrapper deployed that 'adjusts' things such that the main
script, and all sourced scripts use -encoding to source as iso-8859

All appear to be substantial work based on Uwe's statements so far, and
all have a risk of overlooking one or more that should have been
modified.

2) Tcl9 patch X reverts to using "system encoding" (and the user's of
these scripts are on systems where "system encoding" is presently
returning iso-8859). So things work again, with no changes, for the
moment. But then Windows version 1Y.Z changes things such that it now
uses a system encoding of UTF-8. Suddenly, the same problem from 1
returns unless the user's have the abilty to adjust their system
encoding back (and if 'system encoding' is an "administrator
controlled" setting these users, then this option is not available).

So my two cents, for what it is worth, given that I suspect this change
will eventually 'force itself' no matter what Tcl9 patch level X might
do, would be to begin the process of migrating all of these scripts to
UTF-8 encoding. It will be hard, but once done, it likely will be
stable again for the future.

>>I've resisted pointing this one out, but long term, yes, updating all
>>the scripts to be utf-8 encoded is the right, long term, answer. But
>>that belies all the current, short term effort, involved in doing so.
>
> Actually, when I mentioned my migration case, I was also thinking that
> I could afford to do it because I was migrating to Linux and utf-8 was
> not even the future anymore, it was pretty much the present. But maybe
> running iconv wouldn't be acceptable because Uwe is (I assume) on
> Windows.

From his posts on this thread, we can assume that his scripts are being
used on windows systems. That does not imply much about where Uwe
develops those same scripts. I have lots of my own scripts that I use
on $work's windows machine, but all of them are written on Linux.

> Does a Windows user want to convert his files to utf-8?

The average/median windows user does not even know what UTF-8 means nor
why it is significant. They just expect that when the launch "icon X"
that expected program X appears, and that the text inside is as
expected. So it is much more likely the work/effort of "convert to
utf-8" will fall on Uwe, as it is very likely the windows users know
nothing of any of this (or if they 'know' anything, it is something
simple for them, such as: "set this selection box in this windows
config pane to say Y" and that ends their knowledge).

> Won't that cause problems if the system is iso-8859-1?

Only if windows tries to interpret the UTF-8 data as iso-8859
characters. But as far as the Tcl scripts go, once the scripts are
UTF-8, and [source] is using UTF-8 to read them, the fact that windows
system might be iso-8859 is irrelivant.

> Windows still uses iso-8859-1, right?

Honestly I have no idea. The *only* windows machine I use is $work's
windows machine, and the 'administrator' controls most of it so I can
only adjust things in a very narrow band (very irritating at times, but
their machine, their rules).

> So yes, I guess Tcl9 causes trouble to 8859-1 users.

Only if they directly entered any codepoints that were beyond plain
ASCII. Code points 0 through 127 are identical between 8859 and UTF-8.
If the files used plain ASCII, and the \uXXXX escapes, there would be
no trouble at all. Of course if one is using a lot of non-English
characters for non-English languages, seeing the actual characters in
the scripts vs. walls of \u00b0 \u00a0 \u2324 everywhere makes for an
easier development effort.

> Yes, sounds like it needs some fixing.

Agreed. Uwe may be able to put off the fixig for some more time, but
this change is going to arrive one day. He will likely have to make it
at some point.

> I have my own special case, I use Debian 9 which only ships 8.6.6 so
> I had to build 8.6.15 from source because I really need Unicode.

8.6.6 handled Unicode fine. In fact, 8.5 handled Unicode (so long as
one stuck to the BMP) just fine.

> But for some time I used Freewrap as a single-file batteries included
> Tcl/Tk interpreter. So maybe Uwe should just use a different interpreter,
> likely just a slightly older version of Tcl/Tk and embrace Tcl9 later.

That is another option, a custom build that defaults to iso-8859.

> I wonder if one can hack the encoding issue on the Tcl9 source and
> rebuild it.

The answer is likely a "yes". But I've not looked at the code to know
that for sure. But this just feels like a "one line change" followed
by a recompile. But now one has to also deliver that custom runtime
as well as the scripts that go with it.

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Rich
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 23:00 UTC
References: 1 2 3 4 5 6 7 8 9 10 11 12
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: rich@example.invalid (Rich)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 23:00:09 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 38
Message-ID: <vln01p$3025n$2@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me> <20250107160810.07ddbbe6@lud1.home> <vlllha$2nvqo$2@dont-email.me> <20250108113519.42eb3746@lud1.home> <20250108114254.7f56f049@lud1.home> <vlm45q$2qvor$2@dont-email.me> <20250108124055.15c92a05@lud1.home> <vlmb6q$2sblj$1@dont-email.me> <20250108162339.7c04023e@lud1.home> <vlmjs8$2tu2l$1@dont-email.me> <vlmulc$3025m$1@dont-email.me>
Injection-Date: Thu, 09 Jan 2025 00:00:10 +0100 (CET)
Injection-Info: dont-email.me; posting-host="56600ca97f577695361942a23d15a79b";
logging-data="3147959"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19ioE5iGgI5BTCiZef+JQD4"
User-Agent: tin/2.6.1-20211226 ("Convalmore") (Linux/5.15.139 (x86_64))
Cancel-Lock: sha1:0gfT7nWfRRbk15DEOxVW/7ATkWA=
View all headers

saito <saitology9@gmail.com> wrote:
> On 1/8/2025 2:32 PM, Rich wrote:
>>
>>> I did something like that some 15 years ago. But my case involved a
>>> migration. I had a ton of legacy iso-8859 files on a system-wide
>>> utf-8 Linux system. That caused me problems too, but iconv fixed it.
>>
>> In my case, I used the \uxxxx escapes for anything that was not plain
>> ASCII, so all my scripts are both "basic 8859" and "utf-8" at the same
>> time, and having Tcl 9 source them as utf-8 won't cause an issue. But
>> it sounds like Uwe directly entered the extended 8859 characters into
>> the scripts. Which very well may have made perfect sense if he had
>> more than one or two of them per script.
>
> Interesting thread.
>
> Is there a way check a script file for such incompatibilities ahead
> of time?

Detecting 'character encodings' reliably is a fickle business. One
could run a UTF-8 validator (which it appears Ted posted in another
post) that validates that all the bytes in a script are valid UTF-8
encodings. That implies it is UTF-8, and is likely mostly reliable.
But I suppose if one wanted to do so one could come up with chimera
file that is valid UTF-8 encoding but also valid for some other
character encoding. Then "UTF-8" encoding valid may not be the correct
interpretation for the file.

> Would this work as a solution? You build your own Tcl/Tk and add or
> duplicate the source command from an earlier version that you are happy
> with. Then you start up your app as you do currenly, and once it is
> loaded, you switch the source command to the new version and change the
> system encoding.

That would likey work -- but would add the burden of distributing and
maintaining that custom patched version into the future, which Uwe may
not want to take on.

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Luc
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Wed, 8 Jan 2025 23:28 UTC
References: 1 2 3 4 5 6 7 8 9 10 11 12 13
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: luc@sep.invalid (Luc)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Wed, 8 Jan 2025 20:28:51 -0300
Organization: A noiseless patient Spider
Lines: 36
Message-ID: <20250108202851.4dbb65c8@lud1.home>
References: <vjhiar$3f9go$1@dont-email.me>
<vljmj2$29vdo$1@dont-email.me>
<20250107160810.07ddbbe6@lud1.home>
<vlllha$2nvqo$2@dont-email.me>
<20250108113519.42eb3746@lud1.home>
<20250108114254.7f56f049@lud1.home>
<vlm45q$2qvor$2@dont-email.me>
<20250108124055.15c92a05@lud1.home>
<vlmb6q$2sblj$1@dont-email.me>
<20250108162339.7c04023e@lud1.home>
<vlmjs8$2tu2l$1@dont-email.me>
<vlmulc$3025m$1@dont-email.me>
<vln01p$3025n$2@dont-email.me>
MIME-Version: 1.0
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit
Injection-Date: Thu, 09 Jan 2025 00:28:52 +0100 (CET)
Injection-Info: dont-email.me; posting-host="7bdff13c850ce1be844b69f0292685e7";
logging-data="3171128"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18sKFc1y98RiieJLn2FmV7FiBc+69qPK4A="
Cancel-Lock: sha1:Yrh7qMOl6xbfrZ3ZR+OHwcfuicY=
View all headers

On Wed, 8 Jan 2025 22:53:40 -0000 (UTC), Rich wrote:

>> Won't that cause problems if the system is iso-8859-1?
>
>Only if windows tries to interpret the UTF-8 data as iso-8859
>characters. But as far as the Tcl scripts go, once the scripts are
>UTF-8, and [source] is using UTF-8 to read them, the fact that windows
>system might be iso-8859 is irrelivant.

I was thinking that if the Windows user edits the file on Windows,
maybe Windows will write it as iso-8859. I honestly don't know.

>8.6.6 handled Unicode fine. In fact, 8.5 handled Unicode (so long as
>one stuck to the BMP) just fine.

I am positive that 8.6.6 only partially supports Unicode. I found many
characters that would not display correctly on a text widget and would
be saved as garbled content if captured in the widget and written to
file. I even had problems with glob and other commands when applied to
some file names. For example, some html page I had downloaded from
somewhere had something to do with countries and the page title had
Unicode flags in the title, so the title and the flags carried over
to the file name when I saved it. The complete implementation of
Unicode begins in 8.6.10 or 8.6.13, I can't remember which, I think
it's 8.6.13.

I know that is specifically mentioned in a wikit page, I can't
remember which one but that is not terribly relevant right now.

--
Luc
>>

Subject: Re: Tcl9: source files are interpreted as utf-8 by default
From: Rich
Newsgroups: comp.lang.tcl
Organization: A noiseless patient Spider
Date: Thu, 9 Jan 2025 03:57 UTC
References: 1 2 3 4 5 6 7 8 9 10 11 12 13 14
Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: rich@example.invalid (Rich)
Newsgroups: comp.lang.tcl
Subject: Re: Tcl9: source files are interpreted as utf-8 by default
Date: Thu, 9 Jan 2025 03:57:14 -0000 (UTC)
Organization: A noiseless patient Spider
Lines: 61
Message-ID: <vlnheq$36t4o$1@dont-email.me>
References: <vjhiar$3f9go$1@dont-email.me> <vljmj2$29vdo$1@dont-email.me> <20250107160810.07ddbbe6@lud1.home> <vlllha$2nvqo$2@dont-email.me> <20250108113519.42eb3746@lud1.home> <20250108114254.7f56f049@lud1.home> <vlm45q$2qvor$2@dont-email.me> <20250108124055.15c92a05@lud1.home> <vlmb6q$2sblj$1@dont-email.me> <20250108162339.7c04023e@lud1.home> <vlmjs8$2tu2l$1@dont-email.me> <vlmulc$3025m$1@dont-email.me> <vln01p$3025n$2@dont-email.me> <20250108202851.4dbb65c8@lud1.home>
Injection-Date: Thu, 09 Jan 2025 04:57:16 +0100 (CET)
Injection-Info: dont-email.me; posting-host="56600ca97f577695361942a23d15a79b";
logging-data="3372184"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19zR1A0XvQB/M0z2s+NoRlH"
User-Agent: tin/2.6.1-20211226 ("Convalmore") (Linux/5.15.139 (x86_64))
Cancel-Lock: sha1:+K9F1y+MudcOXKRP5xDiy7znDGk=
View all headers

Luc <luc@sep.invalid> wrote:
> On Wed, 8 Jan 2025 22:53:40 -0000 (UTC), Rich wrote:
>
>>> Won't that cause problems if the system is iso-8859-1?
>>
>>Only if windows tries to interpret the UTF-8 data as iso-8859
>>characters. But as far as the Tcl scripts go, once the scripts are
>>UTF-8, and [source] is using UTF-8 to read them, the fact that windows
>>system might be iso-8859 is irrelivant.
>
> I was thinking that if the Windows user edits the file on Windows,
> maybe Windows will write it as iso-8859. I honestly don't know.

I don't know what windows does either. A /reasonable/ approach (which
likely means windows deliberately does not do this) is to write it as
the "system encoding" unless the user explicitly says to use something
else, or unless something in the file indicated it was originally some
other encoding.

>>8.6.6 handled Unicode fine. In fact, 8.5 handled Unicode (so long as
>>one stuck to the BMP) just fine.
>
> I am positive that 8.6.6 only partially supports Unicode.

What were the codepoint values at issue? 8.6.6 worked fine with the
BMP (code points 0000 to FFFF) characters.

> I found many characters that would not display correctly on a text
> widget

Display depends upon whether your font being used had a glyph for the
codepoint - no glyph in the font, no display in the text widget (even
though 8.6.6 likely transparently handled the code point properly,
assuming it was within the BMP).

> and would be saved as garbled content if captured in the widget and
> written to file.

That also depends upon what your system encoding was set to, and
whether you forced a specific encoding when writing the file. If the
code points were in the BMP, and you explicitly set utf-8 encoding
before writing to the file, then the file's contents were properly
encoded even as far back as 8.5 (I know this one because I processed
millions of utf-8 files with only BMP code points through 8.5 for $work
with zero utf-8 encoding issues).

> I even had problems with glob and other commands when applied to
> some file names. For example, some html page I had downloaded from
> somewhere had something to do with countries and the page title had
> Unicode flags in the title, so the title and the flags carried over
> to the file name when I saved it.

Country flags are very likely characters that are beyond the BMP, and
yes, 8.6.6 likely did not handle those properly.

> The complete implementation of Unicode begins in 8.6.10 or 8.6.13, I
> can't remember which, I think it's 8.6.13.

That is probably when support for the extended Unicode characters
(planes beyond the BMP) started to be added.

Pages:12

rocksolid light 0.9.8
clearnet tor