Copyright | (c) Edward Kmett 2011 |
---|---|
License | BSD3 |
Maintainer | ekmett@gmail.com |
Stability | experimental |
Portability | non-portable |
Safe Haskell | None |
Language | Haskell2010 |
Parsers for character streams
Originally in parsers
package.
Synopsis
- oneOf :: CharParsing m => [Char] -> m Char
- noneOf :: CharParsing m => [Char] -> m Char
- spaces :: CharParsing m => m ()
- space :: CharParsing m => m Char
- newline :: CharParsing m => m Char
- tab :: CharParsing m => m Char
- upper :: CharParsing m => m Char
- lower :: CharParsing m => m Char
- alphaNum :: CharParsing m => m Char
- letter :: CharParsing m => m Char
- digit :: CharParsing m => m Char
- hexDigit :: CharParsing m => m Char
- octDigit :: CharParsing m => m Char
- satisfyRange :: CharParsing m => Char -> Char -> m Char
- class Parsing m => CharParsing m where
- integral :: (CharParsing m, Integral a) => m a
- munch1 :: CharParsing m => (Char -> Bool) -> m String
- munch :: CharParsing m => (Char -> Bool) -> m String
- skipSpaces1 :: CharParsing m => m ()
- module Distribution.Compat.Parsing
Combinators
oneOf :: CharParsing m => [Char] -> m Char #
oneOf cs
succeeds if the current character is in the supplied
list of characters cs
. Returns the parsed character. See also
satisfy
.
vowel = oneOf "aeiou"
noneOf :: CharParsing m => [Char] -> m Char #
As the dual of oneOf
, noneOf cs
succeeds if the current
character is not in the supplied list of characters cs
. Returns the
parsed character.
consonant = noneOf "aeiou"
spaces :: CharParsing m => m () #
Skips zero or more white space characters. See also skipMany
.
space :: CharParsing m => m Char #
Parses a white space character (any character which satisfies isSpace
)
Returns the parsed character.
newline :: CharParsing m => m Char #
Parses a newline character ('\n'). Returns a newline character.
tab :: CharParsing m => m Char #
Parses a tab character ('\t'). Returns a tab character.
upper :: CharParsing m => m Char #
Parses an upper case letter. Returns the parsed character.
lower :: CharParsing m => m Char #
Parses a lower case character. Returns the parsed character.
alphaNum :: CharParsing m => m Char #
Parses a letter or digit. Returns the parsed character.
letter :: CharParsing m => m Char #
Parses a letter (an upper case or lower case character). Returns the parsed character.
digit :: CharParsing m => m Char #
Parses a digit. Returns the parsed character.
hexDigit :: CharParsing m => m Char #
Parses a hexadecimal digit (a digit or a letter between 'a' and 'f' or 'A' and 'F'). Returns the parsed character.
octDigit :: CharParsing m => m Char #
Parses an octal digit (a character between '0' and '7'). Returns the parsed character.
satisfyRange :: CharParsing m => Char -> Char -> m Char #
Class
class Parsing m => CharParsing m where #
Additional functionality needed to parse character streams.
satisfy :: (Char -> Bool) -> m Char #
Parse a single character of the input, with UTF-8 decoding
notChar c
parses any single character other than c
. Returns the parsed
character.
This parser succeeds for any character. Returns the parsed character.
string :: String -> m String #
string s
parses a sequence of characters given by s
. Returns
the parsed string (i.e. s
).
divOrMod = string "div" <|> string "mod"
text t
parses a sequence of characters determined by the text t
Returns
the parsed text fragment (i.e. t
).
Using OverloadedStrings
:
divOrMod = text "div" <|> text "mod"
Instances
CharParsing ParsecParser # | |
satisfy :: (Char -> Bool) -> ParsecParser Char # char :: Char -> ParsecParser Char # notChar :: Char -> ParsecParser Char # anyChar :: ParsecParser Char # string :: String -> ParsecParser String # text :: Text -> ParsecParser Text # | |
(CharParsing m, MonadPlus m) => CharParsing (IdentityT m) # | |
(CharParsing m, MonadPlus m) => CharParsing (StateT s m) # | |
(CharParsing m, MonadPlus m) => CharParsing (StateT s m) # | |
(CharParsing m, MonadPlus m, Monoid w) => CharParsing (WriterT w m) # | |
(CharParsing m, MonadPlus m, Monoid w) => CharParsing (WriterT w m) # | |
t ~ Char => CharParsing (Parser r t) # | |
(CharParsing m, MonadPlus m) => CharParsing (ReaderT e m) # | |
Stream s m Char => CharParsing (ParsecT s u m) # | |
(CharParsing m, MonadPlus m, Monoid w) => CharParsing (RWST r w s m) # | |
(CharParsing m, MonadPlus m, Monoid w) => CharParsing (RWST r w s m) # | |
Cabal additions
integral :: (CharParsing m, Integral a) => m a #
munch1 :: CharParsing m => (Char -> Bool) -> m String #
Greedily munch characters while predicate holds. Require at least one character.
munch :: CharParsing m => (Char -> Bool) -> m String #
Greedely munch characters while predicate holds. Always succeeds.
skipSpaces1 :: CharParsing m => m () #
module Distribution.Compat.Parsing