2017-01-14 10:29:12 +01:00
|
|
|
{-
|
2017-04-17 10:04:20 +02:00
|
|
|
Copyright (C) 2012-2017 John MacFarlane <jgm@berkeley.edu>
|
2017-01-14 10:29:12 +01:00
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
-}
|
2017-04-17 10:04:20 +02:00
|
|
|
{-# LANGUAGE DeriveDataTypeable #-}
|
|
|
|
{-# LANGUAGE DeriveGeneric #-}
|
2017-01-14 10:29:12 +01:00
|
|
|
|
|
|
|
{- |
|
|
|
|
Module : Text.Pandoc.Extensions
|
2017-04-17 10:04:20 +02:00
|
|
|
Copyright : Copyright (C) 2012-2017 John MacFarlane
|
2017-01-14 10:29:12 +01:00
|
|
|
License : GNU GPL, version 2 or above
|
|
|
|
|
|
|
|
Maintainer : John MacFarlane <jgm@berkeley.edu>
|
|
|
|
Stability : alpha
|
|
|
|
Portability : portable
|
|
|
|
|
|
|
|
Data structures and functions for representing markup extensions.
|
|
|
|
-}
|
|
|
|
module Text.Pandoc.Extensions ( Extension(..)
|
2017-01-14 13:06:27 +01:00
|
|
|
, Extensions
|
|
|
|
, emptyExtensions
|
|
|
|
, extensionsFromList
|
2017-04-17 10:04:20 +02:00
|
|
|
, parseFormatSpec
|
2017-01-14 13:06:27 +01:00
|
|
|
, extensionEnabled
|
|
|
|
, enableExtension
|
|
|
|
, disableExtension
|
2017-04-17 10:04:20 +02:00
|
|
|
, getDefaultExtensions
|
2017-01-14 10:29:12 +01:00
|
|
|
, pandocExtensions
|
|
|
|
, plainExtensions
|
|
|
|
, strictExtensions
|
|
|
|
, phpMarkdownExtraExtensions
|
|
|
|
, githubMarkdownExtensions
|
|
|
|
, multimarkdownExtensions )
|
|
|
|
where
|
2017-06-24 13:20:30 +02:00
|
|
|
import Data.Bits (clearBit, setBit, testBit, (.|.))
|
2017-01-14 10:29:12 +01:00
|
|
|
import Data.Data (Data)
|
|
|
|
import Data.Typeable (Typeable)
|
|
|
|
import GHC.Generics (Generic)
|
2017-04-17 10:04:20 +02:00
|
|
|
import Text.Pandoc.Shared (safeRead)
|
|
|
|
import Text.Parsec
|
2017-01-14 10:29:12 +01:00
|
|
|
|
2017-01-15 22:52:14 +01:00
|
|
|
newtype Extensions = Extensions Integer
|
|
|
|
deriving (Show, Read, Eq, Ord, Data, Typeable, Generic)
|
2017-01-14 13:06:27 +01:00
|
|
|
|
2017-06-24 13:20:30 +02:00
|
|
|
instance Monoid Extensions where
|
|
|
|
mempty = Extensions 0
|
|
|
|
mappend (Extensions a) (Extensions b) = Extensions (a .|. b)
|
|
|
|
|
2017-01-14 13:06:27 +01:00
|
|
|
extensionsFromList :: [Extension] -> Extensions
|
|
|
|
extensionsFromList = foldr enableExtension emptyExtensions
|
|
|
|
|
|
|
|
emptyExtensions :: Extensions
|
|
|
|
emptyExtensions = Extensions 0
|
|
|
|
|
|
|
|
extensionEnabled :: Extension -> Extensions -> Bool
|
|
|
|
extensionEnabled x (Extensions exts) = testBit exts (fromEnum x)
|
|
|
|
|
|
|
|
enableExtension :: Extension -> Extensions -> Extensions
|
|
|
|
enableExtension x (Extensions exts) = Extensions (setBit exts (fromEnum x))
|
|
|
|
|
|
|
|
disableExtension :: Extension -> Extensions -> Extensions
|
|
|
|
disableExtension x (Extensions exts) = Extensions (clearBit exts (fromEnum x))
|
2017-01-14 10:29:12 +01:00
|
|
|
|
|
|
|
-- | Individually selectable syntax extensions.
|
|
|
|
data Extension =
|
|
|
|
Ext_footnotes -- ^ Pandoc/PHP/MMD style footnotes
|
|
|
|
| Ext_inline_notes -- ^ Pandoc-style inline notes
|
|
|
|
| Ext_pandoc_title_block -- ^ Pandoc title block
|
|
|
|
| Ext_yaml_metadata_block -- ^ YAML metadata block
|
|
|
|
| Ext_mmd_title_block -- ^ Multimarkdown metadata block
|
|
|
|
| Ext_table_captions -- ^ Pandoc-style table captions
|
|
|
|
| Ext_implicit_figures -- ^ A paragraph with just an image is a figure
|
|
|
|
| Ext_simple_tables -- ^ Pandoc-style simple tables
|
|
|
|
| Ext_multiline_tables -- ^ Pandoc-style multiline tables
|
|
|
|
| Ext_grid_tables -- ^ Grid tables (pandoc, reST)
|
|
|
|
| Ext_pipe_tables -- ^ Pipe tables (as in PHP markdown extra)
|
|
|
|
| Ext_citations -- ^ Pandoc/citeproc citations
|
|
|
|
| Ext_raw_tex -- ^ Allow raw TeX (other than math)
|
|
|
|
| Ext_raw_html -- ^ Allow raw HTML
|
|
|
|
| Ext_tex_math_dollars -- ^ TeX math between $..$ or $$..$$
|
|
|
|
| Ext_tex_math_single_backslash -- ^ TeX math btw \(..\) \[..\]
|
|
|
|
| Ext_tex_math_double_backslash -- ^ TeX math btw \\(..\\) \\[..\\]
|
|
|
|
| Ext_latex_macros -- ^ Parse LaTeX macro definitions (for math only)
|
|
|
|
| Ext_fenced_code_blocks -- ^ Parse fenced code blocks
|
|
|
|
| Ext_fenced_code_attributes -- ^ Allow attributes on fenced code blocks
|
|
|
|
| Ext_backtick_code_blocks -- ^ GitHub style ``` code blocks
|
|
|
|
| Ext_inline_code_attributes -- ^ Allow attributes on inline code
|
2017-06-22 23:38:42 +02:00
|
|
|
| Ext_raw_attribute -- ^ Allow explicit raw blocks/inlines
|
2017-01-14 10:29:12 +01:00
|
|
|
| Ext_markdown_in_html_blocks -- ^ Interpret as markdown inside HTML blocks
|
|
|
|
| Ext_native_divs -- ^ Use Div blocks for contents of <div> tags
|
|
|
|
| Ext_native_spans -- ^ Use Span inlines for contents of <span>
|
|
|
|
| Ext_bracketed_spans -- ^ Bracketed spans with attributes
|
|
|
|
| Ext_markdown_attribute -- ^ Interpret text inside HTML as markdown
|
|
|
|
-- iff container has attribute 'markdown'
|
|
|
|
| Ext_escaped_line_breaks -- ^ Treat a backslash at EOL as linebreak
|
|
|
|
| Ext_link_attributes -- ^ link and image attributes
|
|
|
|
| Ext_mmd_link_attributes -- ^ MMD style reference link attributes
|
|
|
|
| Ext_autolink_bare_uris -- ^ Make all absolute URIs into links
|
|
|
|
| Ext_fancy_lists -- ^ Enable fancy list numbers and delimiters
|
|
|
|
| Ext_lists_without_preceding_blankline -- ^ Allow lists without preceding blank
|
|
|
|
| Ext_startnum -- ^ Make start number of ordered list significant
|
|
|
|
| Ext_definition_lists -- ^ Definition lists as in pandoc, mmd, php
|
|
|
|
| Ext_compact_definition_lists -- ^ Definition lists without
|
|
|
|
-- space between items, and disallow laziness
|
|
|
|
| Ext_example_lists -- ^ Markdown-style numbered examples
|
|
|
|
| Ext_all_symbols_escapable -- ^ Make all non-alphanumerics escapable
|
|
|
|
| Ext_angle_brackets_escapable -- ^ Make < and > escapable
|
|
|
|
| Ext_intraword_underscores -- ^ Treat underscore inside word as literal
|
|
|
|
| Ext_blank_before_blockquote -- ^ Require blank line before a blockquote
|
|
|
|
| Ext_blank_before_header -- ^ Require blank line before a header
|
2017-03-20 21:51:29 +01:00
|
|
|
| Ext_space_in_atx_header -- ^ Require space between # and header text
|
2017-01-14 10:29:12 +01:00
|
|
|
| Ext_strikeout -- ^ Strikeout using ~~this~~ syntax
|
|
|
|
| Ext_superscript -- ^ Superscript using ^this^ syntax
|
|
|
|
| Ext_subscript -- ^ Subscript using ~this~ syntax
|
|
|
|
| Ext_hard_line_breaks -- ^ All newlines become hard line breaks
|
|
|
|
| Ext_ignore_line_breaks -- ^ Newlines in paragraphs are ignored
|
|
|
|
| Ext_east_asian_line_breaks -- ^ Newlines in paragraphs are ignored between
|
|
|
|
-- East Asian wide characters
|
|
|
|
| Ext_literate_haskell -- ^ Enable literate Haskell conventions
|
|
|
|
| Ext_abbreviations -- ^ PHP markdown extra abbreviation definitions
|
|
|
|
| Ext_emoji -- ^ Support emoji like :smile:
|
|
|
|
| Ext_auto_identifiers -- ^ Automatic identifiers for headers
|
|
|
|
| Ext_ascii_identifiers -- ^ ascii-only identifiers for headers
|
|
|
|
| Ext_header_attributes -- ^ Explicit header attributes {#id .class k=v}
|
|
|
|
| Ext_mmd_header_identifiers -- ^ Multimarkdown style header identifiers [myid]
|
|
|
|
| Ext_implicit_header_references -- ^ Implicit reference links for headers
|
|
|
|
| Ext_line_blocks -- ^ RST style line blocks
|
|
|
|
| Ext_epub_html_exts -- ^ Recognise the EPUB extended version of HTML
|
|
|
|
| Ext_shortcut_reference_links -- ^ Shortcut reference links
|
2017-01-14 18:27:06 +01:00
|
|
|
| Ext_smart -- ^ "Smart" quotes, apostrophes, ellipses, dashes
|
2017-01-14 21:00:22 +01:00
|
|
|
| Ext_old_dashes -- ^ -- = em, - before number = en
|
2017-05-25 12:50:43 +02:00
|
|
|
| Ext_spaced_reference_links -- ^ Allow space between two parts of ref link
|
2017-01-14 10:29:12 +01:00
|
|
|
deriving (Show, Read, Enum, Eq, Ord, Bounded, Data, Typeable, Generic)
|
|
|
|
|
2017-04-17 10:04:20 +02:00
|
|
|
-- | Extensions to be used with pandoc-flavored markdown.
|
2017-01-14 13:06:27 +01:00
|
|
|
pandocExtensions :: Extensions
|
|
|
|
pandocExtensions = extensionsFromList
|
2017-01-14 10:29:12 +01:00
|
|
|
[ Ext_footnotes
|
|
|
|
, Ext_inline_notes
|
|
|
|
, Ext_pandoc_title_block
|
|
|
|
, Ext_yaml_metadata_block
|
|
|
|
, Ext_table_captions
|
|
|
|
, Ext_implicit_figures
|
|
|
|
, Ext_simple_tables
|
|
|
|
, Ext_multiline_tables
|
|
|
|
, Ext_grid_tables
|
|
|
|
, Ext_pipe_tables
|
|
|
|
, Ext_citations
|
|
|
|
, Ext_raw_tex
|
|
|
|
, Ext_raw_html
|
|
|
|
, Ext_tex_math_dollars
|
|
|
|
, Ext_latex_macros
|
|
|
|
, Ext_fenced_code_blocks
|
|
|
|
, Ext_fenced_code_attributes
|
|
|
|
, Ext_backtick_code_blocks
|
|
|
|
, Ext_inline_code_attributes
|
2017-06-22 23:38:42 +02:00
|
|
|
, Ext_raw_attribute
|
2017-01-14 10:29:12 +01:00
|
|
|
, Ext_markdown_in_html_blocks
|
|
|
|
, Ext_native_divs
|
|
|
|
, Ext_native_spans
|
|
|
|
, Ext_bracketed_spans
|
|
|
|
, Ext_escaped_line_breaks
|
|
|
|
, Ext_fancy_lists
|
|
|
|
, Ext_startnum
|
|
|
|
, Ext_definition_lists
|
|
|
|
, Ext_example_lists
|
|
|
|
, Ext_all_symbols_escapable
|
|
|
|
, Ext_intraword_underscores
|
|
|
|
, Ext_blank_before_blockquote
|
|
|
|
, Ext_blank_before_header
|
2017-03-20 21:51:29 +01:00
|
|
|
, Ext_space_in_atx_header
|
2017-01-14 10:29:12 +01:00
|
|
|
, Ext_strikeout
|
|
|
|
, Ext_superscript
|
|
|
|
, Ext_subscript
|
|
|
|
, Ext_auto_identifiers
|
|
|
|
, Ext_header_attributes
|
|
|
|
, Ext_link_attributes
|
|
|
|
, Ext_implicit_header_references
|
|
|
|
, Ext_line_blocks
|
|
|
|
, Ext_shortcut_reference_links
|
2017-01-15 20:42:00 +01:00
|
|
|
, Ext_smart
|
2017-01-14 10:29:12 +01:00
|
|
|
]
|
|
|
|
|
2017-05-25 12:50:43 +02:00
|
|
|
-- | Extensions to be used with plain text output.
|
2017-01-14 13:06:27 +01:00
|
|
|
plainExtensions :: Extensions
|
|
|
|
plainExtensions = extensionsFromList
|
2017-01-14 10:29:12 +01:00
|
|
|
[ Ext_table_captions
|
|
|
|
, Ext_implicit_figures
|
|
|
|
, Ext_simple_tables
|
|
|
|
, Ext_multiline_tables
|
|
|
|
, Ext_grid_tables
|
|
|
|
, Ext_latex_macros
|
|
|
|
, Ext_fancy_lists
|
|
|
|
, Ext_startnum
|
|
|
|
, Ext_definition_lists
|
|
|
|
, Ext_example_lists
|
|
|
|
, Ext_intraword_underscores
|
|
|
|
, Ext_blank_before_blockquote
|
|
|
|
, Ext_blank_before_header
|
|
|
|
, Ext_strikeout
|
|
|
|
]
|
|
|
|
|
2017-04-17 10:04:20 +02:00
|
|
|
-- | Extensions to be used with github-flavored markdown.
|
2017-01-14 13:06:27 +01:00
|
|
|
phpMarkdownExtraExtensions :: Extensions
|
|
|
|
phpMarkdownExtraExtensions = extensionsFromList
|
2017-01-14 10:29:12 +01:00
|
|
|
[ Ext_footnotes
|
|
|
|
, Ext_pipe_tables
|
|
|
|
, Ext_raw_html
|
|
|
|
, Ext_markdown_attribute
|
|
|
|
, Ext_fenced_code_blocks
|
|
|
|
, Ext_definition_lists
|
|
|
|
, Ext_intraword_underscores
|
|
|
|
, Ext_header_attributes
|
|
|
|
, Ext_link_attributes
|
|
|
|
, Ext_abbreviations
|
|
|
|
, Ext_shortcut_reference_links
|
2017-05-25 12:50:43 +02:00
|
|
|
, Ext_spaced_reference_links
|
2017-01-14 10:29:12 +01:00
|
|
|
]
|
|
|
|
|
2017-04-17 10:04:20 +02:00
|
|
|
-- | Extensions to be used with github-flavored markdown.
|
2017-01-14 13:06:27 +01:00
|
|
|
githubMarkdownExtensions :: Extensions
|
|
|
|
githubMarkdownExtensions = extensionsFromList
|
2017-01-14 10:29:12 +01:00
|
|
|
[ Ext_angle_brackets_escapable
|
|
|
|
, Ext_pipe_tables
|
|
|
|
, Ext_raw_html
|
|
|
|
, Ext_fenced_code_blocks
|
|
|
|
, Ext_auto_identifiers
|
|
|
|
, Ext_ascii_identifiers
|
|
|
|
, Ext_backtick_code_blocks
|
|
|
|
, Ext_autolink_bare_uris
|
2017-03-20 21:51:29 +01:00
|
|
|
, Ext_space_in_atx_header
|
2017-01-14 10:29:12 +01:00
|
|
|
, Ext_intraword_underscores
|
|
|
|
, Ext_strikeout
|
|
|
|
, Ext_emoji
|
|
|
|
, Ext_lists_without_preceding_blankline
|
|
|
|
, Ext_shortcut_reference_links
|
|
|
|
]
|
|
|
|
|
2017-04-17 10:04:20 +02:00
|
|
|
-- | Extensions to be used with multimarkdown.
|
2017-01-14 13:06:27 +01:00
|
|
|
multimarkdownExtensions :: Extensions
|
|
|
|
multimarkdownExtensions = extensionsFromList
|
2017-01-14 10:29:12 +01:00
|
|
|
[ Ext_pipe_tables
|
|
|
|
, Ext_raw_html
|
|
|
|
, Ext_markdown_attribute
|
|
|
|
, Ext_mmd_link_attributes
|
|
|
|
-- , Ext_raw_tex
|
|
|
|
-- Note: MMD's raw TeX syntax requires raw TeX to be
|
|
|
|
-- enclosed in HTML comment
|
|
|
|
, Ext_tex_math_double_backslash
|
|
|
|
, Ext_intraword_underscores
|
|
|
|
, Ext_mmd_title_block
|
|
|
|
, Ext_footnotes
|
|
|
|
, Ext_definition_lists
|
|
|
|
, Ext_all_symbols_escapable
|
|
|
|
, Ext_implicit_header_references
|
2017-03-05 16:34:47 +01:00
|
|
|
, Ext_shortcut_reference_links
|
2017-01-14 10:29:12 +01:00
|
|
|
, Ext_auto_identifiers
|
|
|
|
, Ext_mmd_header_identifiers
|
|
|
|
, Ext_implicit_figures
|
|
|
|
-- Note: MMD's syntax for superscripts and subscripts
|
|
|
|
-- is a bit more permissive than pandoc's, allowing
|
|
|
|
-- e^2 and a~1 instead of e^2^ and a~1~, so even with
|
|
|
|
-- these options we don't have full support for MMD
|
|
|
|
-- superscripts and subscripts, but there's no reason
|
|
|
|
-- not to include these:
|
|
|
|
, Ext_superscript
|
|
|
|
, Ext_subscript
|
2017-05-04 16:36:35 +02:00
|
|
|
, Ext_backtick_code_blocks
|
2017-05-25 12:50:43 +02:00
|
|
|
, Ext_spaced_reference_links
|
2017-06-22 23:38:42 +02:00
|
|
|
-- So far only in dev version of mmd:
|
|
|
|
, Ext_raw_attribute
|
2017-01-14 10:29:12 +01:00
|
|
|
]
|
|
|
|
|
2017-04-17 10:04:20 +02:00
|
|
|
-- | Language extensions to be used with strict markdown.
|
2017-01-14 13:06:27 +01:00
|
|
|
strictExtensions :: Extensions
|
|
|
|
strictExtensions = extensionsFromList
|
2017-01-14 10:29:12 +01:00
|
|
|
[ Ext_raw_html
|
|
|
|
, Ext_shortcut_reference_links
|
2017-05-25 12:50:43 +02:00
|
|
|
, Ext_spaced_reference_links
|
2017-01-14 10:29:12 +01:00
|
|
|
]
|
|
|
|
|
2017-04-17 10:04:20 +02:00
|
|
|
-- | Default extensions from format-describing string.
|
|
|
|
getDefaultExtensions :: String -> Extensions
|
|
|
|
getDefaultExtensions "markdown_strict" = strictExtensions
|
|
|
|
getDefaultExtensions "markdown_phpextra" = phpMarkdownExtraExtensions
|
|
|
|
getDefaultExtensions "markdown_mmd" = multimarkdownExtensions
|
|
|
|
getDefaultExtensions "markdown_github" = githubMarkdownExtensions
|
|
|
|
getDefaultExtensions "markdown" = pandocExtensions
|
|
|
|
getDefaultExtensions "plain" = plainExtensions
|
|
|
|
getDefaultExtensions "org" = extensionsFromList
|
|
|
|
[Ext_citations,
|
|
|
|
Ext_auto_identifiers]
|
|
|
|
getDefaultExtensions "html" = extensionsFromList
|
|
|
|
[Ext_auto_identifiers,
|
|
|
|
Ext_native_divs,
|
|
|
|
Ext_native_spans]
|
|
|
|
getDefaultExtensions "html4" = getDefaultExtensions "html"
|
|
|
|
getDefaultExtensions "html5" = getDefaultExtensions "html"
|
|
|
|
getDefaultExtensions "epub" = extensionsFromList
|
|
|
|
[Ext_raw_html,
|
|
|
|
Ext_native_divs,
|
|
|
|
Ext_native_spans,
|
|
|
|
Ext_epub_html_exts]
|
|
|
|
getDefaultExtensions "epub2" = getDefaultExtensions "epub"
|
|
|
|
getDefaultExtensions "epub3" = getDefaultExtensions "epub"
|
|
|
|
getDefaultExtensions "latex" = extensionsFromList
|
|
|
|
[Ext_smart,
|
Rewrote LaTeX reader with proper tokenization.
This rewrite is primarily motivated by the need to
get macros working properly. A side benefit is that the
reader is significantly faster (27s -> 19s in one
benchmark, and there is a lot of room for further
optimization).
We now tokenize the input text, then parse the token stream.
Macros modify the token stream, so they should now be effective
in any context, including math. Thus, we no longer need the clunky
macro processing capacities of texmath.
A custom state LaTeXState is used instead of ParserState.
This, plus the tokenization, will require some rewriting
of the exported functions rawLaTeXInline, inlineCommand,
rawLaTeXBlock.
* Added Text.Pandoc.Readers.LaTeX.Types (new exported module).
Exports Macro, Tok, TokType, Line, Column. [API change]
* Text.Pandoc.Parsing: adjusted type of `insertIncludedFile`
so it can be used with token parser.
* Removed old texmath macro stuff from Parsing.
Use Macro from Text.Pandoc.Readers.LaTeX.Types instead.
* Removed texmath macro material from Markdown reader.
* Changed types for Text.Pandoc.Readers.LaTeX's
rawLaTeXInline and rawLaTeXBlock. (Both now return a String,
and they are polymorphic in state.)
* Added orgMacros field to OrgState. [API change]
* Removed readerApplyMacros from ReaderOptions.
Now we just check the `latex_macros` reader extension.
* Allow `\newcommand\foo{blah}` without braces.
Fixes #1390.
Fixes #2118.
Fixes #3236.
Fixes #3779.
Fixes #934.
Fixes #982.
2017-07-01 19:31:43 +02:00
|
|
|
Ext_latex_macros,
|
2017-04-17 10:04:20 +02:00
|
|
|
Ext_auto_identifiers]
|
|
|
|
getDefaultExtensions "context" = extensionsFromList
|
|
|
|
[Ext_smart,
|
|
|
|
Ext_auto_identifiers]
|
|
|
|
getDefaultExtensions "textile" = extensionsFromList
|
|
|
|
[Ext_old_dashes,
|
|
|
|
Ext_smart,
|
|
|
|
Ext_raw_html,
|
|
|
|
Ext_auto_identifiers]
|
|
|
|
getDefaultExtensions _ = extensionsFromList
|
|
|
|
[Ext_auto_identifiers]
|
|
|
|
|
|
|
|
-- | Parse a format-specifying string into a markup format and a function that
|
|
|
|
-- takes Extensions and enables and disables extensions as defined in the format
|
|
|
|
-- spec.
|
|
|
|
parseFormatSpec :: String
|
|
|
|
-> Either ParseError (String, Extensions -> Extensions)
|
|
|
|
parseFormatSpec = parse formatSpec ""
|
|
|
|
where formatSpec = do
|
|
|
|
name <- formatName
|
|
|
|
extMods <- many extMod
|
|
|
|
return (name, \x -> foldl (flip ($)) x extMods)
|
|
|
|
formatName = many1 $ noneOf "-+"
|
|
|
|
extMod = do
|
|
|
|
polarity <- oneOf "-+"
|
|
|
|
name <- many $ noneOf "-+"
|
|
|
|
ext <- case safeRead ("Ext_" ++ name) of
|
|
|
|
Just n -> return n
|
|
|
|
Nothing
|
|
|
|
| name == "lhs" -> return Ext_literate_haskell
|
|
|
|
| otherwise -> fail $ "Unknown extension: " ++ name
|
|
|
|
return $ case polarity of
|
|
|
|
'-' -> disableExtension ext
|
|
|
|
_ -> enableExtension ext
|