Safe Haskell | Safe |
---|---|
Language | Haskell2010 |
Data types for working with the metadata of epub documents
This module defines the Metadata structure which contains most of the taxonomic information about the literary work. Metadata is probably the most important data structure in this library.
Both commonly-used versions of epub (2.x and 3.x) are supported by these types.
- data Metadata = Metadata {
- metaIds :: [Identifier]
- metaTitles :: [Title]
- metaLangs :: [String]
- metaContributors :: [Creator]
- metaCreators :: [Creator]
- metaDates :: [Date]
- metaModified :: Maybe String
- metaSource :: Maybe String
- metaType :: Maybe String
- metaCoverages :: [String]
- metaDescriptions :: [Description]
- metaFormats :: [String]
- metaPublishers :: [String]
- metaRelations :: [String]
- metaRights :: [String]
- metaSubjects :: [String]
- data Identifier = Identifier {}
- data Title = Title {}
- data Creator = Creator {}
- data Date = Date (Maybe String) String
- data Description = Description (Maybe String) String
- data Refinement = Refinement {}
- emptyMetadata :: Metadata
- refineIdentifier :: [Refinement] -> Identifier -> Identifier
- refineTitle :: [Refinement] -> (String, Title) -> Title
- getModified :: [Refinement] -> Maybe String
- refineCreator :: [Refinement] -> (String, Creator) -> Creator
Documentation
package/metadata tag
This is perhaps the most useful data structure in this library. It contains most of the information tools will want to use to organize epub documents.
Metadata | |
|
package/metadata/dc:title tag
package/metadata/dc:creator or package/metadata/dc:contributor tags
This structure is used for both contributor and creator as they are exactly the same.
Creator | |
|
package/metadata/dc:date tag, opf:event attribute, text
data Description Source #
package/metadata/dc:description tag, xml:lang attribute, text
data Refinement Source #
Refinements represent meta tags within the metadata section that refine other tags. These are used during the parsing phase and are discarded as their information is slotted into the data they refine (CreatorS, TitleS, IdentifierS, etc..)
This is specific to epub3
emptyMetadata :: Metadata Source #
Note: This isn't valid as-is, some required values are empty lists!
refineIdentifier :: [Refinement] -> Identifier -> Identifier Source #
Used internally by Codec.Epub.Parse.Metadata to merge epub3 meta tag info into the data gathered from an identifier tag
refineTitle :: [Refinement] -> (String, Title) -> Title Source #
Used internally by Codec.Epub.Parse.Metadata to merge epub3 meta tag info into the data gathered from a title tag
getModified :: [Refinement] -> Maybe String Source #
Used internally by Codec.Epub.Parse.Metadata to populate the metadata modified field with data extracted from the epub3 meta tag with property dcterms:modified
refineCreator :: [Refinement] -> (String, Creator) -> Creator Source #
Used internally by Codec.Epub.Parse.Metadata to merge epub3 meta tag info into the data gathered from contributor and creator tags