From baae74af57372896d612e54180b50010b915a37c Mon Sep 17 00:00:00 2001 From: fiddlosopher Date: Sun, 14 Mar 2010 23:23:26 +0000 Subject: [PATCH] Added --base-header-level option. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 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 --- README | 3 +++ man/man1/pandoc.1.md | 3 +++ src/pandoc.hs | 34 ++++++++++++++++++++++++++++------ 3 files changed, 34 insertions(+), 6 deletions(-) diff --git a/README b/README index 57fd2dea5..801fda040 100644 --- a/README +++ b/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 diff --git a/man/man1/pandoc.1.md b/man/man1/pandoc.1.md index 3e1005caa..647606404 100644 --- a/man/man1/pandoc.1.md +++ b/man/man1/pandoc.1.md @@ -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 diff --git a/src/pandoc.hs b/src/pandoc.hs index 5e2eec08a..952401d16 100644 --- a/src/pandoc.hs +++ b/src/pandoc.hs @@ -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