From 7adef0c61321a004bf93d0fb3c1241b75a4a44c1 Mon Sep 17 00:00:00 2001
From: Daniel Ehrenberg <ehrenbed@carleton.edu>
Date: Fri, 21 Mar 2008 14:01:50 -0400
Subject: [PATCH] Completing 8-bit changes

---
 extra/io/encodings/8-bit/8-bit-tests.factor |   1 +
 extra/io/encodings/8-bit/8-bit.factor       |  18 +-
 extra/io/encodings/8-bit/GSM0338.TXT        | 239 --------------------
 3 files changed, 12 insertions(+), 246 deletions(-)
 delete mode 100644 extra/io/encodings/8-bit/GSM0338.TXT

diff --git a/extra/io/encodings/8-bit/8-bit-tests.factor b/extra/io/encodings/8-bit/8-bit-tests.factor
index 316e496219..5dbe28cb14 100644
--- a/extra/io/encodings/8-bit/8-bit-tests.factor
+++ b/extra/io/encodings/8-bit/8-bit-tests.factor
@@ -7,3 +7,4 @@ IN: io.encodings.8-bit.tests
 
 [ "bar" ] [ "bar" iso-8859-1 decode ] unit-test
 [ { CHAR: b 233 CHAR: r } ] [ { CHAR: b 233 CHAR: r } iso-8859-1 decode >array ] unit-test
+[ { HEX: fffd HEX: 20AC } ] [ { HEX: 81 HEX: 80 } windows-1252 decode >array ] unit-test
diff --git a/extra/io/encodings/8-bit/8-bit.factor b/extra/io/encodings/8-bit/8-bit.factor
index ff0e6ec8bf..2cc6b2e57c 100644
--- a/extra/io/encodings/8-bit/8-bit.factor
+++ b/extra/io/encodings/8-bit/8-bit.factor
@@ -3,7 +3,7 @@
 USING: math.parser arrays io.encodings sequences kernel
 assocs hashtables io.encodings.ascii combinators.cleave
 generic parser tuples words io io.files splitting namespaces
-classes quotations ;
+classes quotations math compiler.units ;
 IN: io.encodings.8-bit
 
 <PRIVATE
@@ -25,20 +25,22 @@ IN: io.encodings.8-bit
     { "iso-8859-15" "8859-15" }
     { "iso-8859-16" "8859-16" }
     { "koi8-r" "KOI8-R" }
-!    { "windows-1252" "CP1252" }
-!    { "ebcdic" "CP037" }
+    { "windows-1252" "CP1252" }
+    { "ebcdic" "CP037" }
     { "mac-roman" "ROMAN" }
-!    { "gsm-03.38" "GSM0338" }
 } ;
 
 : full-path ( file-name -- path )
     "extra/io/encodings/8-bit/" ".TXT"
     swapd 3append resource-path ;
 
+: tail-if ( seq n -- newseq )
+    2dup swap length <= [ tail ] [ drop ] if ;
+
 : process-contents ( lines -- assoc )
     [ "#" split first ] map
     [ empty? not ] subset
-    [ "\t " split 2 head [ 2 tail hex> ] map ] map ;
+    [ "\t " split 2 head [ 2 tail-if hex> ] map ] map ;
 
 : byte>ch ( assoc -- array )
     256 replacement-char <array>
@@ -73,7 +75,9 @@ IN: io.encodings.8-bit
     \ encode-char [ encode-8-bit ] method-with-data ;
 
 : decode-8-bit ( stream encoding array -- char/f )
-    nip swap stream-read1 [ swap nth ] [ drop f ] if* ;
+    nip swap stream-read1
+    [ swap nth [ replacement-char ] unless* ]
+    [ drop f ] if* ;
 
 : define-decode-char ( class array -- )
     \ decode-char [ decode-8-bit ] method-with-data ;
@@ -86,4 +90,4 @@ IN: io.encodings.8-bit
 
 PRIVATE>
 
-! << mappings [ define-8-bit-encoding ] assoc-each >>
+[ mappings [ define-8-bit-encoding ] assoc-each ] with-compilation-unit
diff --git a/extra/io/encodings/8-bit/GSM0338.TXT b/extra/io/encodings/8-bit/GSM0338.TXT
deleted file mode 100644
index ae804d635a..0000000000
--- a/extra/io/encodings/8-bit/GSM0338.TXT
+++ /dev/null
@@ -1,239 +0,0 @@
-#
-#	Name:             GSM 03.38 to Unicode
-#	Unicode version:  3.0
-#	Table version:    1.1
-#	Table format:     Format A
-#	Date:             2000 May 30
-#	Authors:          Ken Whistler
-#                         Kent Karlsson
-#                         Markus Kuhn
-#
-#	Copyright (c) 2000 Unicode, Inc.  All Rights reserved.
-#
-#	This file is provided as-is by Unicode, Inc. (The Unicode Consortium).
-#	No claims are made as to fitness for any particular purpose.  No
-#	warranties of any kind are expressed or implied.  The recipient
-#	agrees to determine applicability of information provided.  If this
-#	file has been provided on optical media by Unicode, Inc., the sole
-#	remedy for any claim will be exchange of defective media within 90
-#	days of receipt.
-#
-#	Unicode, Inc. hereby grants the right to freely use the information
-#	supplied in this file in the creation of products supporting the
-#	Unicode Standard, and to make copies of this file in any form for
-#	internal or external distribution as long as this notice remains
-#	attached.
-#
-#	General notes:
-#
-#	This table contains the data the Unicode Consortium has on how
-#       ETSI GSM 03.38 7-bit default alphabet characters map into Unicode.
-#	This mapping is based on ETSI TS 100 900 V7.2.0 (1999-07), with
-#	a correction of 0x09 to *small* c-cedilla, instead of *capital*
-#	C-cedilla.
-#
-#	Format:  Three tab-separated columns
-#		 Column #1 is the ETSI GSM 03.38 7-bit default alphabet 
-#                             code (in hex as 0xXX, or 0xXXXX for double-byte
-#                             sequences)
-#		 Column #2 is the Unicode scalar value (in hex as 0xXXXX)
-#		 Column #3 the Unicode name (follows a comment sign, '#')
-#
-#	The entries are in ETSI GSM 03.38 7-bit default alphabet code order.
-#
-#       Note that ETSI GSM 03.38 also allows for the use of UCS-2 (UTF-16
-#       restricted to the BMP) in GSM/SMS messages.
-#
-#	Note also that there are commented Greek mappings for some 
-#	capital Latin characters. This follows from the clear intent
-#	of the ETSI GSM 03.38 to have glyph coverage for the uppercase
-#	Greek alphabet by reusing Latin letters that have the same 
-#	form as an uppercase Greek letter. Conversion implementations 
-#	should be aware of this fact.
-#
-#       The ETSI GSM 03.38 specification shows an uppercase C-cedilla
-#       glyph at 0x09. This may be the result of limited display
-#       capabilities for handling characters with descenders. However, the
-#       language coverage intent is clearly for the lowercase c-cedilla, as shown
-#       in the mapping below. The mapping for uppercase C-cedilla is shown
-#       in a commented line in the mapping table.
-#
-#	The ESC character 0x1B is
-#	mapped to the no-break space character, unless it is part of a
-#	valid ESC sequence, to facilitate round-trip compatibility in
-#	the presence of unknown ESC sequences.
-#
-#	0x00 is NULL (when followed only by 0x00 up to the
-#	end of (fixed byte length) message, possibly also up to
-#	FORM FEED.  But 0x00 is also the code for COMMERCIAL AT
-#	when some other character (CARRIAGE RETURN if nothing else)
-#	comes after the 0x00.
-#
-#	Version history
-#	1.0 version: first creation
-#	1.1 version: fixed problem with the wrong line being a comment,
-#			added text regarding 0x00's interpretation,
-#                       added second mapping for C-cedilla,
-#                       added mapping of 0x1B escape to NBSP for display.
-#
-#	Updated versions of this file may be found in:
-#		<ftp://ftp.unicode.org/Public/MAPPINGS/>
-#
-#	Any comments or problems, contact <errata@unicode.org>
-#	Please note that <errata@unicode.org> is an archival address;
-#	notices will be checked, but do not expect an immediate response.
-#
-0x00	0x0040	#	COMMERCIAL AT
-#0x00	0x0000	#	NULL (see note above)
-0x01	0x00A3	#	POUND SIGN
-0x02	0x0024	#	DOLLAR SIGN
-0x03	0x00A5	#	YEN SIGN
-0x04	0x00E8	#	LATIN SMALL LETTER E WITH GRAVE
-0x05	0x00E9	#	LATIN SMALL LETTER E WITH ACUTE
-0x06	0x00F9	#	LATIN SMALL LETTER U WITH GRAVE
-0x07	0x00EC	#	LATIN SMALL LETTER I WITH GRAVE
-0x08	0x00F2	#	LATIN SMALL LETTER O WITH GRAVE
-0x09	0x00E7	#	LATIN SMALL LETTER C WITH CEDILLA
-#0x09	0x00C7	#	LATIN CAPITAL LETTER C WITH CEDILLA (see note above)
-0x0A	0x000A	#	LINE FEED
-0x0B	0x00D8	#	LATIN CAPITAL LETTER O WITH STROKE
-0x0C	0x00F8	#	LATIN SMALL LETTER O WITH STROKE
-0x0D	0x000D	#	CARRIAGE RETURN
-0x0E	0x00C5	#	LATIN CAPITAL LETTER A WITH RING ABOVE
-0x0F	0x00E5	#	LATIN SMALL LETTER A WITH RING ABOVE
-0x10	0x0394	#	GREEK CAPITAL LETTER DELTA
-0x11	0x005F	#	LOW LINE
-0x12	0x03A6	#	GREEK CAPITAL LETTER PHI
-0x13	0x0393	#	GREEK CAPITAL LETTER GAMMA
-0x14	0x039B	#	GREEK CAPITAL LETTER LAMDA
-0x15	0x03A9	#	GREEK CAPITAL LETTER OMEGA
-0x16	0x03A0	#	GREEK CAPITAL LETTER PI
-0x17	0x03A8	#	GREEK CAPITAL LETTER PSI
-0x18	0x03A3	#	GREEK CAPITAL LETTER SIGMA
-0x19	0x0398	#	GREEK CAPITAL LETTER THETA
-0x1A	0x039E	#	GREEK CAPITAL LETTER XI
-0x1B	0x00A0	#	ESCAPE TO EXTENSION TABLE (or displayed as NBSP, see note above)
-0x1B0A	0x000C	#	FORM FEED
-0x1B14	0x005E	#	CIRCUMFLEX ACCENT
-0x1B28	0x007B	#	LEFT CURLY BRACKET
-0x1B29	0x007D	#	RIGHT CURLY BRACKET
-0x1B2F	0x005C	#	REVERSE SOLIDUS
-0x1B3C	0x005B	#	LEFT SQUARE BRACKET
-0x1B3D	0x007E	#	TILDE
-0x1B3E	0x005D	#	RIGHT SQUARE BRACKET
-0x1B40	0x007C	#	VERTICAL LINE
-0x1B65	0x20AC	#	EURO SIGN
-0x1C	0x00C6	#	LATIN CAPITAL LETTER AE
-0x1D	0x00E6	#	LATIN SMALL LETTER AE
-0x1E	0x00DF	#	LATIN SMALL LETTER SHARP S (German)
-0x1F	0x00C9	#	LATIN CAPITAL LETTER E WITH ACUTE
-0x20	0x0020	#	SPACE
-0x21	0x0021	#	EXCLAMATION MARK
-0x22	0x0022	#	QUOTATION MARK
-0x23	0x0023	#	NUMBER SIGN
-0x24	0x00A4	#	CURRENCY SIGN
-0x25	0x0025	#	PERCENT SIGN
-0x26	0x0026	#	AMPERSAND
-0x27	0x0027	#	APOSTROPHE
-0x28	0x0028	#	LEFT PARENTHESIS
-0x29	0x0029	#	RIGHT PARENTHESIS
-0x2A	0x002A	#	ASTERISK
-0x2B	0x002B	#	PLUS SIGN
-0x2C	0x002C	#	COMMA
-0x2D	0x002D	#	HYPHEN-MINUS
-0x2E	0x002E	#	FULL STOP
-0x2F	0x002F	#	SOLIDUS
-0x30	0x0030	#	DIGIT ZERO
-0x31	0x0031	#	DIGIT ONE
-0x32	0x0032	#	DIGIT TWO
-0x33	0x0033	#	DIGIT THREE
-0x34	0x0034	#	DIGIT FOUR
-0x35	0x0035	#	DIGIT FIVE
-0x36	0x0036	#	DIGIT SIX
-0x37	0x0037	#	DIGIT SEVEN
-0x38	0x0038	#	DIGIT EIGHT
-0x39	0x0039	#	DIGIT NINE
-0x3A	0x003A	#	COLON
-0x3B	0x003B	#	SEMICOLON
-0x3C	0x003C	#	LESS-THAN SIGN
-0x3D	0x003D	#	EQUALS SIGN
-0x3E	0x003E	#	GREATER-THAN SIGN
-0x3F	0x003F	#	QUESTION MARK
-0x40	0x00A1	#	INVERTED EXCLAMATION MARK
-0x41	0x0041	#	LATIN CAPITAL LETTER A
-#0x41	0x0391	#	GREEK CAPITAL LETTER ALPHA
-0x42	0x0042	#	LATIN CAPITAL LETTER B
-#0x42	0x0392	#	GREEK CAPITAL LETTER BETA
-0x43	0x0043	#	LATIN CAPITAL LETTER C
-0x44	0x0044	#	LATIN CAPITAL LETTER D
-0x45	0x0045	#	LATIN CAPITAL LETTER E
-#0x45	0x0395	#	GREEK CAPITAL LETTER EPSILON
-0x46	0x0046	#	LATIN CAPITAL LETTER F
-0x47	0x0047	#	LATIN CAPITAL LETTER G
-0x48	0x0048	#	LATIN CAPITAL LETTER H
-#0x48	0x0397	#	GREEK CAPITAL LETTER ETA
-0x49	0x0049	#	LATIN CAPITAL LETTER I
-#0x49	0x0399	#	GREEK CAPITAL LETTER IOTA
-0x4A	0x004A	#	LATIN CAPITAL LETTER J
-0x4B	0x004B	#	LATIN CAPITAL LETTER K
-#0x4B	0x039A	#	GREEK CAPITAL LETTER KAPPA
-0x4C	0x004C	#	LATIN CAPITAL LETTER L
-0x4D	0x004D	#	LATIN CAPITAL LETTER M
-#0x4D	0x039C	#	GREEK CAPITAL LETTER MU
-0x4E	0x004E	#	LATIN CAPITAL LETTER N
-#0x4E	0x039D	#	GREEK CAPITAL LETTER NU
-0x4F	0x004F	#	LATIN CAPITAL LETTER O
-#0x4F	0x039F	#	GREEK CAPITAL LETTER OMICRON
-0x50	0x0050	#	LATIN CAPITAL LETTER P
-#0x50	0x03A1	#	GREEK CAPITAL LETTER RHO
-0x51	0x0051	#	LATIN CAPITAL LETTER Q
-0x52	0x0052	#	LATIN CAPITAL LETTER R
-0x53	0x0053	#	LATIN CAPITAL LETTER S
-0x54	0x0054	#	LATIN CAPITAL LETTER T
-#0x54	0x03A4	#	GREEK CAPITAL LETTER TAU
-0x55	0x0055	#	LATIN CAPITAL LETTER U
-#0x55	0x03A5	#	GREEK CAPITAL LETTER UPSILON
-0x56	0x0056	#	LATIN CAPITAL LETTER V
-0x57	0x0057	#	LATIN CAPITAL LETTER W
-0x58	0x0058	#	LATIN CAPITAL LETTER X
-#0x58	0x03A7	#	GREEK CAPITAL LETTER CHI
-0x59	0x0059	#	LATIN CAPITAL LETTER Y
-0x5A	0x005A	#	LATIN CAPITAL LETTER Z
-#0x5A	0x0396	#	GREEK CAPITAL LETTER ZETA
-0x5B	0x00C4	#	LATIN CAPITAL LETTER A WITH DIAERESIS
-0x5C	0x00D6	#	LATIN CAPITAL LETTER O WITH DIAERESIS
-0x5D	0x00D1	#	LATIN CAPITAL LETTER N WITH TILDE
-0x5E	0x00DC	#	LATIN CAPITAL LETTER U WITH DIAERESIS
-0x5F	0x00A7	#	SECTION SIGN
-0x60	0x00BF	#	INVERTED QUESTION MARK
-0x61	0x0061	#	LATIN SMALL LETTER A
-0x62	0x0062	#	LATIN SMALL LETTER B
-0x63	0x0063	#	LATIN SMALL LETTER C
-0x64	0x0064	#	LATIN SMALL LETTER D
-0x65	0x0065	#	LATIN SMALL LETTER E
-0x66	0x0066	#	LATIN SMALL LETTER F
-0x67	0x0067	#	LATIN SMALL LETTER G
-0x68	0x0068	#	LATIN SMALL LETTER H
-0x69	0x0069	#	LATIN SMALL LETTER I
-0x6A	0x006A	#	LATIN SMALL LETTER J
-0x6B	0x006B	#	LATIN SMALL LETTER K
-0x6C	0x006C	#	LATIN SMALL LETTER L
-0x6D	0x006D	#	LATIN SMALL LETTER M
-0x6E	0x006E	#	LATIN SMALL LETTER N
-0x6F	0x006F	#	LATIN SMALL LETTER O
-0x70	0x0070	#	LATIN SMALL LETTER P
-0x71	0x0071	#	LATIN SMALL LETTER Q
-0x72	0x0072	#	LATIN SMALL LETTER R
-0x73	0x0073	#	LATIN SMALL LETTER S
-0x74	0x0074	#	LATIN SMALL LETTER T
-0x75	0x0075	#	LATIN SMALL LETTER U
-0x76	0x0076	#	LATIN SMALL LETTER V
-0x77	0x0077	#	LATIN SMALL LETTER W
-0x78	0x0078	#	LATIN SMALL LETTER X
-0x79	0x0079	#	LATIN SMALL LETTER Y
-0x7A	0x007A	#	LATIN SMALL LETTER Z
-0x7B	0x00E4	#	LATIN SMALL LETTER A WITH DIAERESIS
-0x7C	0x00F6	#	LATIN SMALL LETTER O WITH DIAERESIS
-0x7D	0x00F1	#	LATIN SMALL LETTER N WITH TILDE
-0x7E	0x00FC	#	LATIN SMALL LETTER U WITH DIAERESIS
-0x7F	0x00E0	#	LATIN SMALL LETTER A WITH GRAVE