module Hydra.Sources.Tier1.Constants where
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