module Happy.Backend.LALR where

import Happy.Paths
import Data.Char

lalrBackendDataDir :: IO String
lalrBackendDataDir :: IO String
lalrBackendDataDir = IO String
getDataDir

magicFilter :: Maybe String -> String -> String
magicFilter :: Maybe String -> String -> String
magicFilter Maybe String
magicName = case Maybe String
magicName of
    Maybe String
Nothing -> String -> String
forall a. a -> a
id
    Just String
name' -> let
        small_name :: String
small_name = String
name'
        big_name :: String
big_name = Char -> Char
toUpper (String -> Char
forall a. HasCallStack => [a] -> a
head String
name') Char -> String -> String
forall a. a -> [a] -> [a]
: String -> String
forall a. HasCallStack => [a] -> [a]
tail String
name'
        filter_output :: String -> String
filter_output (Char
'h':Char
'a':Char
'p':Char
'p':Char
'y':String
rest) = String
small_name String -> String -> String
forall a. [a] -> [a] -> [a]
++ String -> String
filter_output String
rest
        filter_output (Char
'H':Char
'a':Char
'p':Char
'p':Char
'y':String
rest) = String
big_name String -> String -> String
forall a. [a] -> [a] -> [a]
++ String -> String
filter_output String
rest
        filter_output (Char
c:String
cs) = Char
c Char -> String -> String
forall a. a -> [a] -> [a]
: String -> String
filter_output String
cs
        filter_output [] = []
      in String -> String
filter_output

importsToInject :: Bool -> String
importsToInject :: Bool -> String
importsToInject Bool
debug = [String] -> String
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
concat [String
"\n", String
import_prelude, String
import_array, String
import_bits, String
import_glaexts, String
debug_imports, String
applicative_imports]
    where
      debug_imports :: String
debug_imports  | Bool
debug     = String
import_debug
                     | Bool
otherwise = String
""
      applicative_imports :: String
applicative_imports        = String
import_applicative

      import_glaexts :: String
import_glaexts     = String
"import qualified GHC.Exts as Happy_GHC_Exts\n"
      _import_ghcstack :: String
_import_ghcstack   = String
"import qualified GHC.Stack as Happy_GHC_Stack\n"
      import_array :: String
import_array       = String
"import qualified Data.Array as Happy_Data_Array\n"
      import_bits :: String
import_bits        = String
"import qualified Data.Bits as Bits\n"
      import_debug :: String
import_debug       = String
"import qualified System.IO as Happy_System_IO\n" String -> String -> String
forall a. [a] -> [a] -> [a]
++
                           String
"import qualified System.IO.Unsafe as Happy_System_IO_Unsafe\n" String -> String -> String
forall a. [a] -> [a] -> [a]
++
                           String
"import qualified Debug.Trace as Happy_Debug_Trace\n"
      import_applicative :: String
import_applicative = String
"import Control.Applicative(Applicative(..))\n" String -> String -> String
forall a. [a] -> [a] -> [a]
++
                           String
"import Control.Monad (ap)\n"
      import_prelude :: String
import_prelude     = [String] -> String
unlines ([String] -> String) -> [String] -> String
forall a b. (a -> b) -> a -> b
$ (String -> String) -> [String] -> [String]
forall a b. (a -> b) -> [a] -> [b]
map (\ String
x -> [String] -> String
unwords [String
"import qualified", String
x, String
"as Happy_Prelude"]) ([String] -> [String]) -> [String] -> [String]
forall a b. (a -> b) -> a -> b
$
        [ String
"Data.Function"
        , String
"Data.Bool"
        , String
"Data.Function"
        , String
"Data.Maybe"
        , String
"Data.Int"
        , String
"Data.String"
        , String
"Data.List"
        , String
"Control.Monad"
        , String
"Text.Show"
        , String
"GHC.Num"
        , String
"GHC.Err"
        ]

langExtsToInject :: [String]
langExtsToInject :: [String]
langExtsToInject = [String
"MagicHash", String
"BangPatterns", String
"TypeSynonymInstances", String
"FlexibleInstances", String
"PatternGuards", String
"NoStrictData", String
"UnboxedTuples", String
"PartialTypeSignatures"]

defines :: Bool -> Bool -> String
defines :: Bool -> Bool -> String
defines Bool
debug Bool
coerce = [String] -> String
unlines [ String
"#define " String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
d String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
" 1" | String
d <- [String]
vars_to_define ]
  where
  vars_to_define :: [String]
vars_to_define = [[String]] -> [String]
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
concat
    [ [ String
"HAPPY_DEBUG"  | Bool
debug ]
    , [ String
"HAPPY_COERCE" | Bool
coerce ]
    ]