Safe Haskell | None |
---|
Type classes to allow for XML handling functions to be generalized to work with different document types.
- data XMLDeclaration text = XMLDeclaration text (Maybe text) (Maybe Bool)
- data DocumentTypeDeclaration c tag text = DocumentTypeDeclaration
- data Misc text
- = Comment !text
- | ProcessingInstruction !text !text
- type family NodeType d :: (* -> *) -> * -> * -> *
- class (Functor c, List c, NodeClass (NodeType d) c) => DocumentClass d c where
- getXMLDeclaration :: d c tag text -> Maybe (XMLDeclaration text)
- getDocumentTypeDeclaration :: d c tag text -> Maybe (DocumentTypeDeclaration c tag text)
- getTopLevelMiscs :: d c tag text -> c (Misc text)
- getRoot :: d c tag text -> NodeType d c tag text
- mkDocument :: Maybe (XMLDeclaration text) -> Maybe (DocumentTypeDeclaration c tag text) -> c (Misc text) -> NodeType d c tag text -> d c tag text
- mkPlainDocument :: DocumentClass d c => NodeType d c tag text -> d c tag text
- modifyXMLDeclaration :: DocumentClass d c => (Maybe (XMLDeclaration text) -> Maybe (XMLDeclaration text)) -> d c tag text -> d c tag text
- modifyDocumentTypeDeclaration :: DocumentClass d c => (Maybe (DocumentTypeDeclaration c tag text) -> Maybe (DocumentTypeDeclaration c tag text)) -> d c tag text -> d c tag text
- modifyTopLevelMiscs :: DocumentClass d c => (c (Misc text) -> c (Misc text)) -> d c tag text -> d c tag text
- modifyRoot :: DocumentClass d c => (NodeType d c tag text -> NodeType d c tag text) -> d c tag text -> d c tag text
Documentation
data XMLDeclaration text Source
XML declaration, consisting of version, encoding and standalone.
The formatting functions always outputs only UTF-8, regardless of what encoding is specified here. If you want to produce a document in a different encoding, then set the encoding here, format the document, and then convert the output text from UTF-8 to your desired encoding using some text conversion library.
XMLDeclaration text (Maybe text) (Maybe Bool) |
Eq text => Eq (XMLDeclaration text) | |
Show text => Show (XMLDeclaration text) |
data DocumentTypeDeclaration c tag text Source
Stub for future expansion.
Eq (DocumentTypeDeclaration c tag text) | |
Show (DocumentTypeDeclaration c tag text) |
Comment !text | |
ProcessingInstruction !text !text |
class (Functor c, List c, NodeClass (NodeType d) c) => DocumentClass d c whereSource
getXMLDeclaration :: d c tag text -> Maybe (XMLDeclaration text)Source
Get the XML declaration for this document.
getDocumentTypeDeclaration :: d c tag text -> Maybe (DocumentTypeDeclaration c tag text)Source
Get the Document Type Declaration (DTD) for this document.
getTopLevelMiscs :: d c tag text -> c (Misc text)Source
Get the top-level Misc
nodes for this document.
getRoot :: d c tag text -> NodeType d c tag textSource
Get the root element for this document.
mkDocument :: Maybe (XMLDeclaration text) -> Maybe (DocumentTypeDeclaration c tag text) -> c (Misc text) -> NodeType d c tag text -> d c tag textSource
Make a document with the specified fields.
(Functor c, List c) => DocumentClass (DocumentG ann) c |
mkPlainDocument :: DocumentClass d c => NodeType d c tag text -> d c tag textSource
Make a document with the specified root node and all other information set to defaults.
modifyXMLDeclaration :: DocumentClass d c => (Maybe (XMLDeclaration text) -> Maybe (XMLDeclaration text)) -> d c tag text -> d c tag textSource
modifyDocumentTypeDeclaration :: DocumentClass d c => (Maybe (DocumentTypeDeclaration c tag text) -> Maybe (DocumentTypeDeclaration c tag text)) -> d c tag text -> d c tag textSource
modifyTopLevelMiscs :: DocumentClass d c => (c (Misc text) -> c (Misc text)) -> d c tag text -> d c tag textSource
modifyRoot :: DocumentClass d c => (NodeType d c tag text -> NodeType d c tag text) -> d c tag text -> d c tag textSource