module Hydra.Sources.Tier1.Constants where

-- Standard Tier-1 imports
import           Prelude hiding ((++))
import qualified Data.List                 as L
import qualified Data.Map                  as M
import qualified Data.Set                  as S
import qualified Data.Maybe                as Y
import           Hydra.Dsl.Base            as Base
import qualified Hydra.Dsl.Core            as Core
import qualified Hydra.Dsl.Graph           as Graph
import qualified Hydra.Dsl.Lib.Equality    as Equality
import qualified Hydra.Dsl.Lib.Flows       as Flows
import qualified Hydra.Dsl.Lib.Io          as Io
import qualified Hydra.Dsl.Lib.Lists       as Lists
import qualified Hydra.Dsl.Lib.Literals    as Literals
import qualified Hydra.Dsl.Lib.Logic       as Logic
import qualified Hydra.Dsl.Lib.Maps        as Maps
import qualified Hydra.Dsl.Lib.Math        as Math
import qualified Hydra.Dsl.Lib.Optionals   as Optionals
import qualified Hydra.Dsl.Lib.Sets        as Sets
import           Hydra.Dsl.Lib.Strings     as Strings
import qualified Hydra.Dsl.Module          as Module
import qualified Hydra.Dsl.Terms           as Terms
import qualified Hydra.Dsl.Types           as Types
import           Hydra.Sources.Tier0.All


constantsDefinition :: String -> Datum a -> Definition a
constantsDefinition :: forall a. String -> Datum a -> Definition a
constantsDefinition = Module -> String -> Datum a -> Definition a
forall a. Module -> String -> Datum a -> Definition a
definitionInModule Module
hydraConstantsModule

hydraConstantsModule :: Module
hydraConstantsModule :: Module
hydraConstantsModule = Namespace
-> [Element] -> [Module] -> [Module] -> Maybe String -> Module
Module (String -> Namespace
Namespace String
"hydra/constants") [Element]
elements [] [Module]
tier0Modules (Maybe String -> Module) -> Maybe String -> Module
forall a b. (a -> b) -> a -> b
$
    String -> Maybe String
forall a. a -> Maybe a
Just (String
"A module for tier-0 constants.")
  where
   elements :: [Element]
elements = [
     Definition String -> Element
forall a. Definition a -> Element
el Definition String
ignoredVariableDef,
     Definition Name -> Element
forall a. Definition a -> Element
el Definition Name
placeholderNameDef,
     Definition Int -> Element
forall a. Definition a -> Element
el Definition Int
maxTraceDepthDef]

ignoredVariableDef :: Definition String
ignoredVariableDef :: Definition String
ignoredVariableDef = String -> Datum String -> Definition String
forall a. String -> Datum a -> Definition a
constantsDefinition String
"ignoredVariable" (Datum String -> Definition String)
-> Datum String -> Definition String
forall a b. (a -> b) -> a -> b
$
  String -> Datum String
string String
"_"

placeholderNameDef :: Definition Name
placeholderNameDef :: Definition Name
placeholderNameDef = String -> Datum Name -> Definition Name
forall a. String -> Datum a -> Definition a
constantsDefinition String
"placeholderName" (Datum Name -> Definition Name) -> Datum Name -> Definition Name
forall a b. (a -> b) -> a -> b
$
  String -> Datum Name -> Datum Name
forall a. String -> Datum a -> Datum a
doc String
"A placeholder name for row types as they are being constructed" (Datum Name -> Datum Name) -> Datum Name -> Datum Name
forall a b. (a -> b) -> a -> b
$
  Name -> Datum String -> Datum Name
forall a b. Name -> Datum a -> Datum b
wrap Name
_Name (Datum String -> Datum Name) -> Datum String -> Datum Name
forall a b. (a -> b) -> a -> b
$ String -> Datum String
string String
"Placeholder"

maxTraceDepthDef :: Definition Int
maxTraceDepthDef :: Definition Int
maxTraceDepthDef = String -> Datum Int -> Definition Int
forall a. String -> Datum a -> Definition a
constantsDefinition String
"maxTraceDepth" (Datum Int -> Definition Int) -> Datum Int -> Definition Int
forall a b. (a -> b) -> a -> b
$ Int -> Datum Int
int32 Int
50