summaryrefslogtreecommitdiff
path: root/src/Main.hs
blob: 984f2d74c2598c13cb722168329f62841e776f8f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
{-# LANGUAGE RecordWildCards #-}
module Main
    ( main
    ) where

import qualified Data.Text.Lazy.Builder as Text.Builder
import qualified Data.Text.Lazy.IO as Text.Lazy
import Graphics.Fountainhead (dumpFontFile)
import Options.Applicative
    ( ParserInfo(..)
    , (<**>)
    , argument
    , execParser
    , header
    , help
    , helper
    , info
    , long
    , fullDesc
    , metavar
    , optional
    , progDesc
    , short
    , str
    , strOption
    )

data Options = Options
    { tableName :: Maybe String
    , fontFile :: FilePath
    } deriving (Eq, Show)

operationOptions :: ParserInfo Options
operationOptions = info (options <**> helper)
    $ fullDesc
    <> progDesc "Dumping the contents of a TrueType Font file."
    <> header "fountainhead - font parser"
  where
    options = Options
        <$> tableNameArgument
        <*> argument str (metavar "FONTFILE")
    tableNameArgument = optional $ strOption
        $ long "table"
        <> short 't'
        <> metavar "tablename"
        <> help "Dump only the specified table. Otherwise dump all tables"

main :: IO ()
main = execParser operationOptions >>= handleArguments
  where
    handleArguments Options{..}
        = putStrLn ("Dumping File:" <> fontFile <> "\n\n")
        >> dumpFontFile fontFile tableName
        >>= either print (Text.Lazy.putStrLn . Text.Builder.toLazyText)