[Openmcl-devel] *default-external-format* and encoding and decoding strings.
Ron Garret
ron at flownet.com
Mon Mar 7 15:09:45 PST 2016
On Mar 7, 2016, at 2:37 PM, Dmitry Igrishin <dfigrish at gmail.com> wrote:
>> > (in-package :ccl)
>> >
>> > (let ((ccl::*warn-if-redefine-kernel* nil))
>> > (defun lookup-character-encoding (name)
>> > (gethash (or name *default-external-format*) *character-encodings*)))
>>
>> I don't think I can apply this.
>>
>> The issue is that nil is a valid character encoding name: it's a documented synonym for :iso-8859-1.
>
> Just curious, why is so? Doesn't the "nil" means "unknown" or "false"? And if something that means
> the "default" is "unknown" or "false" should by treated as exceptional situation?
It’s to maintain backwards-compatibility with CCL before *default-external-format* was introduced, when :ISO-8859-1 was hard-coded as the default. There was a big discussion over whether or not to change this, and *default-external-format* was introduced as a backwards-compatible compromise.
rg
More information about the Openmcl-devel
mailing list