Added --base-header-level option.
Thanks to Jérémy Bobbio for the patch that formed the basis of this commit. Closes Debian #563416. git-svn-id: https://pandoc.googlecode.com/svn/trunk@1889 788f1e2b-df1e-0410-8736-df70ead52e1b
This commit is contained in:
parent
075f958c6a
commit
baae74af57
3 changed files with 34 additions and 6 deletions
3
README
3
README
|
@ -243,6 +243,9 @@ For further documentation, see the `pandoc(1)` man page.
|
|||
one) in the output document. This option has no effect with `man`,
|
||||
`docbook`, or `s5` output formats.
|
||||
|
||||
`--base-header-level` *level*
|
||||
: specifies the base level for headers (defaults to 1).
|
||||
|
||||
`--template=`*file*
|
||||
: uses *file* as a custom template for the generated document. Implies
|
||||
`-s`. See [Templates](#templates) below for a description
|
||||
|
|
|
@ -174,6 +174,9 @@ should pipe input and output through `iconv`:
|
|||
RTF) or an instruction to create one (LaTeX, reStructuredText).
|
||||
This option has no effect on man, DocBook, or S5 output.
|
||||
|
||||
\--base-header-level=*LEVEL*
|
||||
: Specify the base level for headers (defaults to 1).
|
||||
|
||||
\--template=*FILE*
|
||||
: Use *FILE* as a custom template for the generated document. Implies
|
||||
`-s`. See TEMPLATES below for a description of template syntax. If
|
||||
|
|
|
@ -42,7 +42,7 @@ import System.Exit ( exitWith, ExitCode (..) )
|
|||
import System.FilePath
|
||||
import System.Console.GetOpt
|
||||
import Data.Maybe ( fromMaybe )
|
||||
import Data.Char ( toLower )
|
||||
import Data.Char ( toLower, isDigit )
|
||||
import Data.List ( intercalate, isSuffixOf )
|
||||
import System.Directory ( getAppUserDataDirectory )
|
||||
import System.IO ( stdout, stderr )
|
||||
|
@ -59,7 +59,7 @@ import Text.CSL
|
|||
import Text.Pandoc.Biblio
|
||||
#endif
|
||||
import Control.Monad (when, unless, liftM)
|
||||
import Network.HTTP
|
||||
import Network.HTTP (simpleHTTP, mkRequest, getResponseBody, RequestMethod(..))
|
||||
import Network.URI (parseURI)
|
||||
import Data.ByteString.Lazy.UTF8 (toString)
|
||||
|
||||
|
@ -145,6 +145,7 @@ data Opt = Opt
|
|||
, optWriter :: String -- ^ Writer format
|
||||
, optParseRaw :: Bool -- ^ Parse unconvertable HTML and TeX
|
||||
, optTableOfContents :: Bool -- ^ Include table of contents
|
||||
, optHeaderShift :: Int -- ^ Headers base level
|
||||
, optTemplate :: String -- ^ Custom template
|
||||
, optVariables :: [(String,String)] -- ^ Template variables to set
|
||||
, optBefore :: [String] -- ^ Texts to include before body
|
||||
|
@ -184,6 +185,7 @@ defaultOpts = Opt
|
|||
, optWriter = "" -- null for default writer
|
||||
, optParseRaw = False
|
||||
, optTableOfContents = False
|
||||
, optHeaderShift = 1
|
||||
, optTemplate = ""
|
||||
, optVariables = []
|
||||
, optBefore = []
|
||||
|
@ -352,6 +354,17 @@ options =
|
|||
(\opt -> return opt { optTableOfContents = True }))
|
||||
"" -- "Include table of contents"
|
||||
|
||||
, Option "" ["base-header-level"]
|
||||
(ReqArg
|
||||
(\arg opt -> do
|
||||
if all isDigit arg && (read arg :: Int) >= 1
|
||||
then return opt { optHeaderShift = read arg - 1 }
|
||||
else do
|
||||
hPutStrLn stderr $ "base-header-level must be a number >= 1"
|
||||
exitWith $ ExitFailure 19)
|
||||
"LEVEL")
|
||||
"" -- "Headers base level"
|
||||
|
||||
, Option "" ["template"]
|
||||
(ReqArg
|
||||
(\arg opt -> do
|
||||
|
@ -559,6 +572,10 @@ defaultWriterName x =
|
|||
['.',y] | y `elem` ['1'..'9'] -> "man"
|
||||
_ -> "html"
|
||||
|
||||
shiftHeaderLevels :: Int -> Block -> Block
|
||||
shiftHeaderLevels shift (Header level inner) = Header (level + shift) inner
|
||||
shiftHeaderLevels _ x = x
|
||||
|
||||
main :: IO ()
|
||||
main = do
|
||||
|
||||
|
@ -595,6 +612,7 @@ main = do
|
|||
, optBefore = befores
|
||||
, optAfter = afters
|
||||
, optTableOfContents = toc
|
||||
, optHeaderShift = headerShift
|
||||
, optTemplate = template
|
||||
, optOutputFile = outputFile
|
||||
, optNumberSections = numberSections
|
||||
|
@ -748,14 +766,18 @@ main = do
|
|||
|
||||
doc <- fmap (reader startParserState . convertTabs . intercalate "\n") (readSources sources)
|
||||
|
||||
doc' <- do
|
||||
let doc' = if headerShift > 1
|
||||
then processWith (shiftHeaderLevels headerShift) doc
|
||||
else doc
|
||||
|
||||
doc'' <- do
|
||||
#ifdef _CITEPROC
|
||||
processBiblio cslFile refs doc
|
||||
processBiblio cslFile refs doc'
|
||||
#else
|
||||
return doc
|
||||
return doc'
|
||||
#endif
|
||||
|
||||
let writerOutput = writer writerOptions doc' ++ "\n"
|
||||
let writerOutput = writer writerOptions doc'' ++ "\n"
|
||||
|
||||
case writerName' of
|
||||
"odt" -> saveOpenDocumentAsODT datadir outputFile sourceDirRelative referenceODT writerOutput
|
||||
|
|
Loading…
Reference in a new issue