{-# LANGUAGE CPP #-}
{-# LANGUAGE NoRebindableSyntax #-}
{-# OPTIONS_GHC -fno-warn-missing-import-lists #-}
module Paths_haskell_src_exts_util (
    version,
    getBinDir, getLibDir, getDynLibDir, getDataDir, getLibexecDir,
    getDataFileName, getSysconfDir
  ) where

import qualified Control.Exception as Exception
import Data.Version (Version(..))
import System.Environment (getEnv)
import Prelude

#if defined(VERSION_base)

#if MIN_VERSION_base(4,0,0)
catchIO :: IO a -> (Exception.IOException -> IO a) -> IO a
#else
catchIO :: IO a -> (Exception.Exception -> IO a) -> IO a
#endif

#else
catchIO :: IO a -> (Exception.IOException -> IO a) -> IO a
#endif
catchIO = Exception.catch

version :: Version
version = Version [0,2,5] []
bindir, libdir, dynlibdir, datadir, libexecdir, sysconfdir :: FilePath

bindir     = "/usr/bin"
libdir     = "/usr/lib/ghc-8.6.5/haskell-src-exts-util-0.2.5"
dynlibdir  = "/usr/lib"
datadir    = "/usr/share/haskell-src-exts-util-0.2.5"
libexecdir = "/usr/libexec/haskell-src-exts-util-0.2.5"
sysconfdir = "/usr/etc"

getBinDir, getLibDir, getDynLibDir, getDataDir, getLibexecDir, getSysconfDir :: IO FilePath
getBinDir = catchIO (getEnv "haskell_src_exts_util_bindir") (\_ -> return bindir)
getLibDir = catchIO (getEnv "haskell_src_exts_util_libdir") (\_ -> return libdir)
getDynLibDir = catchIO (getEnv "haskell_src_exts_util_dynlibdir") (\_ -> return dynlibdir)
getDataDir = catchIO (getEnv "haskell_src_exts_util_datadir") (\_ -> return datadir)
getLibexecDir = catchIO (getEnv "haskell_src_exts_util_libexecdir") (\_ -> return libexecdir)
getSysconfDir = catchIO (getEnv "haskell_src_exts_util_sysconfdir") (\_ -> return sysconfdir)

getDataFileName :: FilePath -> IO FilePath
getDataFileName name = do
  dir <- getDataDir
  return (dir ++ "/" ++ name)