{-# LANGUAGE NoImplicitPrelude #-} -- | Description : mostly reversible conversion between ipynb and lhs module IHaskell.Convert (convert) where import IHaskellPrelude import qualified Data.Text as T import qualified Data.Text.Lazy as LT import qualified Data.ByteString as BS import qualified Data.ByteString.Lazy as LBS import qualified Data.ByteString.Char8 as CBS import Control.Monad.Identity (Identity(Identity), unless, when) import IHaskell.Convert.Args (ConvertSpec(..), fromJustConvertSpec, toConvertSpec) import IHaskell.Convert.IpynbToLhs (ipynbToLhs) import IHaskell.Convert.LhsToIpynb (lhsToIpynb) import IHaskell.Flags (Argument) import System.Directory (doesFileExist) import Text.Printf (printf) -- | used by @IHaskell convert@ convert :: [Argument] -> IO () convert args = case fromJustConvertSpec (toConvertSpec args) of ConvertSpec { convertToIpynb = Identity toIpynb , convertInput = Identity inputFile , convertOutput = Identity outputFile , convertLhsStyle = Identity lhsStyle , convertOverwriteFiles = force } | toIpynb -> do unless force (failIfExists outputFile) lhsToIpynb lhsStyle inputFile outputFile | otherwise -> do unless force (failIfExists outputFile) ipynbToLhs lhsStyle inputFile outputFile -- | Call fail when the named file already exists. failIfExists :: FilePath -> IO () failIfExists file = do exists <- doesFileExist file when exists $ fail $ printf "File %s already exists. To force supply --force." file