diff options
| author | davve@dtek.chalmers.se <David Waern> | 2007-03-25 00:46:48 +0000 | 
|---|---|---|
| committer | davve@dtek.chalmers.se <David Waern> | 2007-03-25 00:46:48 +0000 | 
| commit | 6f55aa8b181d1cfcfb415a87733e530809332573 (patch) | |
| tree | 4a9118ef06555ec818c1711ab61eb994758e481e /src/Haddock | |
| parent | a7077e5f38d08888459acb33e276e29ce733f206 (diff) | |
Start work on Haddock API
Diffstat (limited to 'src/Haddock')
| -rw-r--r-- | src/Haddock/Exception.hs | 14 | ||||
| -rw-r--r-- | src/Haddock/InterfaceFile.hs | 50 | 
2 files changed, 64 insertions, 0 deletions
| diff --git a/src/Haddock/Exception.hs b/src/Haddock/Exception.hs new file mode 100644 index 00000000..73ec2c5d --- /dev/null +++ b/src/Haddock/Exception.hs @@ -0,0 +1,14 @@ +module Haddock.Exception ( +  HaddockException, +  throwE +)where + +import Data.Typeable +import Control.Exception + +data HaddockException = HaddockException String deriving Typeable +throwE str = throwDyn (HaddockException str) + +instance Show HaddockException where +  show (HaddockException str) = str +   diff --git a/src/Haddock/InterfaceFile.hs b/src/Haddock/InterfaceFile.hs new file mode 100644 index 00000000..becd40df --- /dev/null +++ b/src/Haddock/InterfaceFile.hs @@ -0,0 +1,50 @@ +module Haddock.InterfaceFile ( +  InterfaceFile(..), +  writeInterfaceFile, +  readInterfaceFile +) where + +import HaddockTypes +import Haddock.Exception + +import Binary +import System.IO +import Data.Word +import qualified Data.Map as Map +import Control.Monad + +data InterfaceFile = InterfaceFile { +  ifDocEnv :: DocEnv +}  + +instance Binary InterfaceFile where +  put_ bh (InterfaceFile docEnv) = put_ bh (Map.toList docEnv) +  get bh = do +    envList <- get bh +    return (InterfaceFile (Map.fromList envList)) + +packageFileMagic = 0xDA303001 :: Word32 +packageFileVersion = 0 :: Word16 + +writeInterfaceFile :: FilePath -> InterfaceFile -> IO () +writeInterfaceFile filename iface = do  +  h <- openBinaryFile filename WriteMode +  bh <- openBinIO h +  ud <- newWriteState +  bh <- return $ setUserData bh ud +  put_ bh packageFileMagic +  put_ bh packageFileVersion +  put_ bh iface +  hClose h +     +readInterfaceFile :: FilePath -> IO InterfaceFile +readInterfaceFile filename = do +  h <- openBinaryFile filename ReadMode +  bh <- openBinIO h +  ud <- newReadState undefined +  bh <- return (setUserData bh ud) +  magic <- get bh +  when (magic /= packageFileMagic) $ throwE $ +    "Magic number mismatch: couldn't load interface file: " ++ filename +  (version :: Word16) <- get bh +  get bh | 
