Thanks Rob! So its all about ASCII.
Nice to hear that php6 will address this issue. I wonder what there will
be implemented...
In addition to that, i hope there will be a really good default solution
for processing multibyte-strings, but thats another story... :)
--
Greetings,
drysler
Rob Nicholson schrieb:
drysler,
So you are asking about what PHP6 calls "script_encoding". PHP5 does not
have this concept.
PHP5 does not know the character set that your script is encoded in. The
script can be encoded in any character set that is "ASCII compatible".
ASCII compatible encodings have the property that any byte value which has
a meaning as an ASCII character has the same meaning in the
character set. iso-8859-1 or utf-8 both have this property whereas utf-16
for example does not. There are rules about
what characters can be used in identifiers, (see
http://uk.php.net/manual/en/language.functions.php#functions.user-defined)
but you'll see that
these are described in terms of byte values. Thus when you define an
identifier or string literal in a script it is simply treated as a series
of byte
values by PHP without any understanding of the meaning of those byte
values other than if they happen to represent ASCII characters.
Rob.
drysler <[EMAIL PROTECTED]> wrote on 27/09/2007 20:32:09:
On 9/27/07, drysler <[EMAIL PROTECTED]> wrote:
Hello,
i am practising with charsets at the moment and so i thought:
-> How does PHP know the charset i use in my source-code?
-> Are php-sources limited to specific charsets?
-> In which areas you have to be aware of the source-code-charset?
Perhaps somebody here on the list can tell something about these
issues?
Thanks!
Unless I'm mistaken, PHP expects the source files to be in the
internal charset, which is ISO-8859-1. If you use the mbstring
extension, you can use different internal encodings. See:
http://www.php.net/mbstring
Another good read on charset vs. PHP is:
http://www.phpwact.org/php/i18n/charsets?s=utf
--
troels
I think, the problem may be divided into 2 areas:
1) handling charsets of data (e.g. regex or string functions)
------------------------------------------------------------------------
No unsolvable problem. You have to know (and/or validate) the charset of
the data you process, no matter if typed in in the source code or loaded
from other data sources. There are "tools and workarounds" available, to
do the things right.
2) paying attention to the charset of the source code
------------------------------------------------------------------------
This is the main issue, i wanted to address with my posting.
I asked myself, if there can be characters i use as source code, which
php perhaps can not recognize because of the charset i used in the
source-code-document.
Or perhaps in php are only characters "allowed", which are represented
all the same in all supported charsets, so there might be a list of
charsets, you can safely use when scripting php.
I mean, is there a difference (bytes?) writing the following in
iso-8859-1 or utf-8?
public function foo($bar = true) {
return self::SOME_CONSTANT;
}
And if there is a difference, how php knows what i typed?
So many questions .... :)
--
Greetings,
drysler
--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php
Unless stated otherwise above:
IBM United Kingdom Limited - Registered in England and Wales with number
741598.
Registered office: PO Box 41, North Harbour, Portsmouth, Hampshire PO6 3AU
--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php