{-# LANGUAGE MagicHash,DeriveDataTypeable #-}
module Data.Encoding.CP860(CP860(..)) where
import Data.Encoding.Base
import Data.Encoding.ByteSource
import Data.Encoding.ByteSink
import Data.Encoding.Exception
import Data.CharMap
import Data.Array.Static
import Data.Map.Static
import Control.Throws
import Prelude hiding (lookup)
import Data.Word
import Data.Typeable
data CP860 = CP860
deriving (Int -> CP860 -> ShowS
[CP860] -> ShowS
CP860 -> String
(Int -> CP860 -> ShowS)
-> (CP860 -> String) -> ([CP860] -> ShowS) -> Show CP860
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> CP860 -> ShowS
showsPrec :: Int -> CP860 -> ShowS
$cshow :: CP860 -> String
show :: CP860 -> String
$cshowList :: [CP860] -> ShowS
showList :: [CP860] -> ShowS
Show,CP860 -> CP860 -> Bool
(CP860 -> CP860 -> Bool) -> (CP860 -> CP860 -> Bool) -> Eq CP860
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: CP860 -> CP860 -> Bool
== :: CP860 -> CP860 -> Bool
$c/= :: CP860 -> CP860 -> Bool
/= :: CP860 -> CP860 -> Bool
Eq,Typeable)
decoding_array_CP860 :: StaticArray Word8 e
decoding_array_CP860 = Word8 -> Word8 -> Addr# -> StaticArray Word8 e
forall i e. i -> i -> Addr# -> StaticArray i e
StaticArray (Word8
0) (Word8
255) Addr#
"\0\0\0\0\1\0\0\0\2\0\0\0\3\0\0\0\4\0\0\0\5\0\0\0\6\0\0\0\7\0\0\0\8\0\0\0\9\0\0\0\10\0\0\0\11\0\0\0\12\0\0\0\13\0\0\0\14\0\0\0\15\0\0\0\16\0\0\0\17\0\0\0\18\0\0\0\19\0\0\0\20\0\0\0\21\0\0\0\22\0\0\0\23\0\0\0\24\0\0\0\25\0\0\0\26\0\0\0\27\0\0\0\28\0\0\0\29\0\0\0\30\0\0\0\31\0\0\0\32\0\0\0\33\0\0\0\34\0\0\0\35\0\0\0\36\0\0\0\37\0\0\0\38\0\0\0\39\0\0\0\40\0\0\0\41\0\0\0\42\0\0\0\43\0\0\0\44\0\0\0\45\0\0\0\46\0\0\0\47\0\0\0\48\0\0\0\49\0\0\0\50\0\0\0\51\0\0\0\52\0\0\0\53\0\0\0\54\0\0\0\55\0\0\0\56\0\0\0\57\0\0\0\58\0\0\0\59\0\0\0\60\0\0\0\61\0\0\0\62\0\0\0\63\0\0\0\64\0\0\0\65\0\0\0\66\0\0\0\67\0\0\0\68\0\0\0\69\0\0\0\70\0\0\0\71\0\0\0\72\0\0\0\73\0\0\0\74\0\0\0\75\0\0\0\76\0\0\0\77\0\0\0\78\0\0\0\79\0\0\0\80\0\0\0\81\0\0\0\82\0\0\0\83\0\0\0\84\0\0\0\85\0\0\0\86\0\0\0\87\0\0\0\88\0\0\0\89\0\0\0\90\0\0\0\91\0\0\0\92\0\0\0\93\0\0\0\94\0\0\0\95\0\0\0\96\0\0\0\97\0\0\0\98\0\0\0\99\0\0\0\100\0\0\0\101\0\0\0\102\0\0\0\103\0\0\0\104\0\0\0\105\0\0\0\106\0\0\0\107\0\0\0\108\0\0\0\109\0\0\0\110\0\0\0\111\0\0\0\112\0\0\0\113\0\0\0\114\0\0\0\115\0\0\0\116\0\0\0\117\0\0\0\118\0\0\0\119\0\0\0\120\0\0\0\121\0\0\0\122\0\0\0\123\0\0\0\124\0\0\0\125\0\0\0\126\0\0\0\127\0\0\0\199\0\0\0\252\0\0\0\233\0\0\0\226\0\0\0\227\0\0\0\224\0\0\0\193\0\0\0\231\0\0\0\234\0\0\0\202\0\0\0\232\0\0\0\205\0\0\0\212\0\0\0\236\0\0\0\195\0\0\0\194\0\0\0\201\0\0\0\192\0\0\0\200\0\0\0\244\0\0\0\245\0\0\0\242\0\0\0\218\0\0\0\249\0\0\0\204\0\0\0\213\0\0\0\220\0\0\0\162\0\0\0\163\0\0\0\217\0\0\0\167\32\0\0\211\0\0\0\225\0\0\0\237\0\0\0\243\0\0\0\250\0\0\0\241\0\0\0\209\0\0\0\170\0\0\0\186\0\0\0\191\0\0\0\210\0\0\0\172\0\0\0\189\0\0\0\188\0\0\0\161\0\0\0\171\0\0\0\187\0\0\0\145\37\0\0\146\37\0\0\147\37\0\0\2\37\0\0\36\37\0\0\97\37\0\0\98\37\0\0\86\37\0\0\85\37\0\0\99\37\0\0\81\37\0\0\87\37\0\0\93\37\0\0\92\37\0\0\91\37\0\0\16\37\0\0\20\37\0\0\52\37\0\0\44\37\0\0\28\37\0\0\0\37\0\0\60\37\0\0\94\37\0\0\95\37\0\0\90\37\0\0\84\37\0\0\105\37\0\0\102\37\0\0\96\37\0\0\80\37\0\0\108\37\0\0\103\37\0\0\104\37\0\0\100\37\0\0\101\37\0\0\89\37\0\0\88\37\0\0\82\37\0\0\83\37\0\0\107\37\0\0\106\37\0\0\24\37\0\0\12\37\0\0\136\37\0\0\132\37\0\0\140\37\0\0\144\37\0\0\128\37\0\0\177\3\0\0\223\0\0\0\147\3\0\0\192\3\0\0\163\3\0\0\195\3\0\0\181\0\0\0\196\3\0\0\166\3\0\0\152\3\0\0\169\3\0\0\180\3\0\0\30\34\0\0\198\3\0\0\181\3\0\0\41\34\0\0\97\34\0\0\177\0\0\0\101\34\0\0\100\34\0\0\32\35\0\0\33\35\0\0\247\0\0\0\72\34\0\0\176\0\0\0\25\34\0\0\183\0\0\0\26\34\0\0\127\32\0\0\178\0\0\0\160\37\0\0\160\0\0\0"#
encoding_map_CP860 :: CharMap
encoding_map_CP860 :: CharMap
encoding_map_CP860 = StaticMap Char Word8 -> CharMap
LeafMap1 (StaticArray Int Char
-> StaticArray Int Word8 -> StaticMap Char Word8
forall i e. StaticArray Int i -> StaticArray Int e -> StaticMap i e
StaticMap (Int -> Int -> Addr# -> StaticArray Int Char
forall i e. i -> i -> Addr# -> StaticArray i e
StaticArray (Int
1) (Int
256) Addr#
"\160\0\0\0\64\0\0\0\195\3\0\0\32\0\0\0\96\0\0\0\217\0\0\0\86\37\0\0\16\0\0\0\48\0\0\0\80\0\0\0\112\0\0\0\191\0\0\0\243\0\0\0\2\37\0\0\102\37\0\0\8\0\0\0\24\0\0\0\40\0\0\0\56\0\0\0\72\0\0\0\88\0\0\0\104\0\0\0\120\0\0\0\177\0\0\0\202\0\0\0\231\0\0\0\152\3\0\0\41\34\0\0\52\37\0\0\94\37\0\0\132\37\0\0\4\0\0\0\12\0\0\0\20\0\0\0\28\0\0\0\36\0\0\0\44\0\0\0\52\0\0\0\60\0\0\0\68\0\0\0\76\0\0\0\84\0\0\0\92\0\0\0\100\0\0\0\108\0\0\0\116\0\0\0\124\0\0\0\170\0\0\0\186\0\0\0\195\0\0\0\210\0\0\0\224\0\0\0\236\0\0\0\249\0\0\0\177\3\0\0\167\32\0\0\101\34\0\0\24\37\0\0\82\37\0\0\90\37\0\0\98\37\0\0\106\37\0\0\145\37\0\0\2\0\0\0\6\0\0\0\10\0\0\0\14\0\0\0\18\0\0\0\22\0\0\0\26\0\0\0\30\0\0\0\34\0\0\0\38\0\0\0\42\0\0\0\46\0\0\0\50\0\0\0\54\0\0\0\58\0\0\0\62\0\0\0\66\0\0\0\70\0\0\0\74\0\0\0\78\0\0\0\82\0\0\0\86\0\0\0\90\0\0\0\94\0\0\0\98\0\0\0\102\0\0\0\106\0\0\0\110\0\0\0\114\0\0\0\118\0\0\0\122\0\0\0\126\0\0\0\162\0\0\0\172\0\0\0\181\0\0\0\188\0\0\0\193\0\0\0\200\0\0\0\205\0\0\0\212\0\0\0\220\0\0\0\226\0\0\0\233\0\0\0\241\0\0\0\245\0\0\0\252\0\0\0\166\3\0\0\181\3\0\0\198\3\0\0\26\34\0\0\97\34\0\0\33\35\0\0\16\37\0\0\36\37\0\0\80\37\0\0\84\37\0\0\88\37\0\0\92\37\0\0\96\37\0\0\100\37\0\0\104\37\0\0\108\37\0\0\140\37\0\0\147\37\0\0\1\0\0\0\3\0\0\0\5\0\0\0\7\0\0\0\9\0\0\0\11\0\0\0\13\0\0\0\15\0\0\0\17\0\0\0\19\0\0\0\21\0\0\0\23\0\0\0\25\0\0\0\27\0\0\0\29\0\0\0\31\0\0\0\33\0\0\0\35\0\0\0\37\0\0\0\39\0\0\0\41\0\0\0\43\0\0\0\45\0\0\0\47\0\0\0\49\0\0\0\51\0\0\0\53\0\0\0\55\0\0\0\57\0\0\0\59\0\0\0\61\0\0\0\63\0\0\0\65\0\0\0\67\0\0\0\69\0\0\0\71\0\0\0\73\0\0\0\75\0\0\0\77\0\0\0\79\0\0\0\81\0\0\0\83\0\0\0\85\0\0\0\87\0\0\0\89\0\0\0\91\0\0\0\93\0\0\0\95\0\0\0\97\0\0\0\99\0\0\0\101\0\0\0\103\0\0\0\105\0\0\0\107\0\0\0\109\0\0\0\111\0\0\0\113\0\0\0\115\0\0\0\117\0\0\0\119\0\0\0\121\0\0\0\123\0\0\0\125\0\0\0\127\0\0\0\161\0\0\0\163\0\0\0\171\0\0\0\176\0\0\0\178\0\0\0\183\0\0\0\187\0\0\0\189\0\0\0\192\0\0\0\194\0\0\0\199\0\0\0\201\0\0\0\204\0\0\0\209\0\0\0\211\0\0\0\213\0\0\0\218\0\0\0\223\0\0\0\225\0\0\0\227\0\0\0\232\0\0\0\234\0\0\0\237\0\0\0\242\0\0\0\244\0\0\0\247\0\0\0\250\0\0\0\147\3\0\0\163\3\0\0\169\3\0\0\180\3\0\0\192\3\0\0\196\3\0\0\127\32\0\0\25\34\0\0\30\34\0\0\72\34\0\0\100\34\0\0\32\35\0\0\0\37\0\0\12\37\0\0\20\37\0\0\28\37\0\0\44\37\0\0\60\37\0\0\81\37\0\0\83\37\0\0\85\37\0\0\87\37\0\0\89\37\0\0\91\37\0\0\93\37\0\0\95\37\0\0\97\37\0\0\99\37\0\0\101\37\0\0\103\37\0\0\105\37\0\0\107\37\0\0\128\37\0\0\136\37\0\0\144\37\0\0\146\37\0\0\160\37\0\0\0\0\0\0"#) (Int -> Int -> Addr# -> StaticArray Int Word8
forall i e. i -> i -> Addr# -> StaticArray i e
StaticArray (Int
1) (Int
256) Addr#
"\255\64\229\32\96\157\183\16\48\80\112\168\162\179\203\8\24\40\56\72\88\104\120\241\137\135\233\239\193\198\220\4\12\20\28\36\44\52\60\68\76\84\92\100\108\116\124\166\167\142\169\133\141\151\224\158\242\217\213\200\182\216\176\2\6\10\14\18\22\26\30\34\38\42\46\50\54\58\62\66\70\74\78\82\86\90\94\98\102\106\110\114\118\122\126\155\170\230\172\134\146\139\140\154\131\130\164\148\129\232\238\237\251\240\245\191\180\205\201\212\189\204\209\208\206\221\178\1\3\5\7\9\11\13\15\17\19\21\23\25\27\29\31\33\35\37\39\41\43\45\47\49\51\53\55\57\59\61\63\65\67\69\71\73\75\77\79\81\83\85\87\89\91\93\95\97\99\101\103\105\107\109\111\113\115\117\119\121\123\125\127\173\156\174\248\253\250\175\171\145\143\128\144\152\165\159\153\150\225\160\132\138\136\161\149\147\246\163\226\228\234\235\227\231\252\249\236\247\243\244\196\218\192\195\194\197\186\214\184\187\211\190\188\199\181\185\210\207\202\215\223\219\222\177\254\0"#))
instance Encoding CP860 where
decodeChar :: forall (m :: * -> *). ByteSource m => CP860 -> m Char
decodeChar CP860
_ = do
Word8
w <- m Word8
forall (m :: * -> *). ByteSource m => m Word8
fetchWord8
() -> m ()
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
case StaticArray Word8 (Maybe Char)
forall {e}. StaticArray Word8 e
decoding_array_CP860StaticArray Word8 (Maybe Char) -> Word8 -> Maybe Char
forall e i. (StaticElement e, Ix i) => StaticArray i e -> i -> e
!Word8
w of
Maybe Char
Nothing -> DecodingException -> m Char
forall a. DecodingException -> m a
forall e (m :: * -> *) a. Throws e m => e -> m a
throwException (DecodingException -> m Char) -> DecodingException -> m Char
forall a b. (a -> b) -> a -> b
$ Word8 -> DecodingException
IllegalCharacter (Word8 -> DecodingException) -> Word8 -> DecodingException
forall a b. (a -> b) -> a -> b
$ Word8 -> Word8
forall a b. (Integral a, Num b) => a -> b
fromIntegral Word8
w
Just Char
c -> Char -> m Char
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return Char
c
encodeChar :: forall (m :: * -> *). ByteSink m => CP860 -> Char -> m ()
encodeChar CP860
_ Char
c = Char -> CharMap -> m ()
forall (m :: * -> *). ByteSink m => Char -> CharMap -> m ()
mapEncode Char
c CharMap
encoding_map_CP860
encodeable :: CP860 -> Char -> Bool
encodeable CP860
_ Char
c = Char -> CharMap -> Bool
mapMember Char
c CharMap
encoding_map_CP860