X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=Data%2FChar.hs;h=76eb39c1a7781c8ea562c2610707f6d7720d9e96;hb=3683967ba8a4d13226eefed9f137e3b1b413f1bd;hp=001c83fcc515501ba46da86506f108456b5e01b2;hpb=14c3d7f368a6ec5e760b2fd57218171eeaf53a29;p=ghc-base.git diff --git a/Data/Char.hs b/Data/Char.hs index 001c83f..76eb39c 100644 --- a/Data/Char.hs +++ b/Data/Char.hs @@ -6,7 +6,7 @@ -- License : BSD-style (see the file libraries/base/LICENSE) -- -- Maintainer : libraries@haskell.org --- Stability : provisional +-- Stability : stable -- Portability : portable -- -- The Char type and associated operations. @@ -17,23 +17,33 @@ module Data.Char ( Char - , isAscii, isLatin1, isControl - , isPrint, isSpace, isUpper - , isLower, isAlpha, isDigit - , isOctDigit, isHexDigit, isAlphaNum -- :: Char -> Bool + , String + + -- * Character classification + -- | Unicode characters are divided into letters, numbers, marks, + -- punctuation, symbols, separators (including spaces) and others + -- (including control characters). + -- The full set of Unicode character attributes is not accessible + -- in this library. + , isAscii, isLatin1, isControl, isSpace + , isLower, isUpper, isAlpha, isAlphaNum, isPrint + , isDigit, isOctDigit, isHexDigit -- :: Char -> Bool + -- * Case conversion , toUpper, toLower -- :: Char -> Char + -- * Single digit characters , digitToInt -- :: Char -> Int , intToDigit -- :: Int -> Char + -- * Numeric representations , ord -- :: Char -> Int , chr -- :: Int -> Char - , readLitChar -- :: ReadS Char + + -- * String representations , showLitChar -- :: Char -> ShowS , lexLitChar -- :: ReadS String - - , String + , readLitChar -- :: ReadS Char -- Implementation checked wrt. Haskell 98 lib report, 1/99. ) where @@ -56,7 +66,10 @@ import Prelude(Char,String) import Char #endif - +-- | Convert a single digit 'Char' to the corresponding 'Int'. +-- This function fails unless its argument satisfies 'isHexDigit', +-- but recognises both upper and lower-case hexadecimal digits +-- (i.e. @\'0\'@..@\'9\'@, @\'a\'@..@\'f\'@, @\'A\'@..@\'F\'@). digitToInt :: Char -> Int digitToInt c | isDigit c = ord c - ord '0'