Copyright | © Oren Ben-Kiki 2007 © Herbert Valerio Riedel 2015-2018 |
---|---|
License | GPL-2.0-or-later |
Safe Haskell | Safe |
Language | Haskell2010 |
Tokenizer for the YAML 1.2 syntax as defined in http://yaml.org/spec/1.2/spec.html.
Synopsis
- tokenize :: ByteString -> Bool -> [Token]
- data Token = Token {}
- data Code
- = Bom
- | Text
- | Meta
- | Break
- | LineFeed
- | LineFold
- | Indicator
- | White
- | Indent
- | DirectivesEnd
- | DocumentEnd
- | BeginEscape
- | EndEscape
- | BeginComment
- | EndComment
- | BeginDirective
- | EndDirective
- | BeginTag
- | EndTag
- | BeginHandle
- | EndHandle
- | BeginAnchor
- | EndAnchor
- | BeginProperties
- | EndProperties
- | BeginAlias
- | EndAlias
- | BeginScalar
- | EndScalar
- | BeginSequence
- | EndSequence
- | BeginMapping
- | EndMapping
- | BeginPair
- | EndPair
- | BeginNode
- | EndNode
- | BeginDocument
- | EndDocument
- | BeginStream
- | EndStream
- | Error
- | Unparsed
- | Detected
- data Encoding
Documentation
tokenize :: ByteString -> Bool -> [Token] Source #
converts the Unicode input
(using the UTF-8, UTF-16 (LE or BE), or UTF-32 (LE or BE) encoding)
to a list of tokenize
input emit_unparsedToken
according to the YAML 1.2 specification.
Errors are reported as tokens with
, and the
unparsed text following an error may be attached as a final Error
:: Code
Unparsed
token
(if the emit_unparsed argument is True
). Note that tokens are available
"immediately", allowing for streaming of large YAML files with
memory requirements depending only on the YAML nesting level.
Parsed token.
Instances
Show Token Source # | |
Generic Token Source # | |
NFData Token Source # | Since: 0.2.0 |
Defined in Data.YAML.Token | |
type Rep Token Source # | |
Defined in Data.YAML.Token type Rep Token = D1 (MetaData "Token" "Data.YAML.Token" "HsYAML-0.2.0.0-Lc2Xi1g9LKMImTc3Ihoid7" False) (C1 (MetaCons "Token" PrefixI True) ((S1 (MetaSel (Just "tByteOffset") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 Int) :*: (S1 (MetaSel (Just "tCharOffset") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 Int) :*: S1 (MetaSel (Just "tLine") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 Int))) :*: (S1 (MetaSel (Just "tLineChar") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 Int) :*: (S1 (MetaSel (Just "tCode") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 Code) :*: S1 (MetaSel (Just "tText") NoSourceUnpackedness SourceStrict DecidedStrict) (Rec0 String))))) |
Token
codes.
Bom | BOM, contains " |
Text | Content text characters. |
Meta | Non-content (meta) text characters. |
Break | Separation line break. |
LineFeed | Line break normalized to content line feed. |
LineFold | Line break folded to content space. |
Indicator | Character indicating structure. |
White | Separation white space. |
Indent | Indentation spaces. |
DirectivesEnd | Document start marker. |
DocumentEnd | Document end marker. |
BeginEscape | Begins escape sequence. |
EndEscape | Ends escape sequence. |
BeginComment | Begins comment. |
EndComment | Ends comment. |
BeginDirective | Begins directive. |
EndDirective | Ends directive. |
BeginTag | Begins tag. |
EndTag | Ends tag. |
BeginHandle | Begins tag handle. |
EndHandle | Ends tag handle. |
BeginAnchor | Begins anchor. |
EndAnchor | Ends anchor. |
BeginProperties | Begins node properties. |
EndProperties | Ends node properties. |
BeginAlias | Begins alias. |
EndAlias | Ends alias. |
BeginScalar | Begins scalar content. |
EndScalar | Ends scalar content. |
BeginSequence | Begins sequence content. |
EndSequence | Ends sequence content. |
BeginMapping | Begins mapping content. |
EndMapping | Ends mapping content. |
BeginPair | Begins mapping key:value pair. |
EndPair | Ends mapping key:value pair. |
BeginNode | Begins complete node. |
EndNode | Ends complete node. |
BeginDocument | Begins document. |
EndDocument | Ends document. |
BeginStream | Begins YAML stream. |
EndStream | Ends YAML stream. |
Error | Parsing error at this point. |
Unparsed | Unparsed due to errors (or at end of test). |
Detected | Detected parameter (for testing). |
Instances
Recognized Unicode encodings. As of YAML 1.2 UTF-32 is also required.
UTF8 | UTF-8 encoding (or ASCII) |
UTF16LE | UTF-16 little endian |
UTF16BE | UTF-16 big endian |
UTF32LE | UTF-32 little endian |
UTF32BE | UTF-32 big endian |
Instances
Eq Encoding Source # | |
Show Encoding Source # |
|
Generic Encoding Source # | |
NFData Encoding Source # | Since: 0.2.0 |
Defined in Data.YAML.Token.Encoding | |
type Rep Encoding Source # | |
Defined in Data.YAML.Token.Encoding type Rep Encoding = D1 (MetaData "Encoding" "Data.YAML.Token.Encoding" "HsYAML-0.2.0.0-Lc2Xi1g9LKMImTc3Ihoid7" False) ((C1 (MetaCons "UTF8" PrefixI False) (U1 :: Type -> Type) :+: C1 (MetaCons "UTF16LE" PrefixI False) (U1 :: Type -> Type)) :+: (C1 (MetaCons "UTF16BE" PrefixI False) (U1 :: Type -> Type) :+: (C1 (MetaCons "UTF32LE" PrefixI False) (U1 :: Type -> Type) :+: C1 (MetaCons "UTF32BE" PrefixI False) (U1 :: Type -> Type)))) |