Safe Haskell | None |
---|---|
Language | Haskell2010 |
Dhall lets you import external expressions located either in local files or hosted on network endpoints.
To import a local file as an expression, just insert the path to the file,
prepending a ./
if the path is relative to the current directory. For
example, if you create a file named id
with the following contents:
$ cat id λ(a : Type) → λ(x : a) → x
Then you can use the file directly within a dhall
program just by
referencing the file's path:
$ dhall ./id Bool True <Ctrl-D> Bool True
Imported expressions may contain imports of their own, too, which will continue to be resolved. However, Dhall will prevent cyclic imports. For example, if you had these two files:
$ cat foo ./bar
$ cat bar ./foo
... Dhall would throw the following exception if you tried to import foo
:
$ dhall ./foo ^D ↳ ./foo ↳ ./bar Cyclic import: ./foo
You can also import expressions hosted on network endpoints. Just use the URL
http://host[:port]/path
The compiler expects the downloaded expressions to be in the same format as local files, specifically UTF8-encoded source code text.
For example, if our id
expression were hosted at http://example.com/id
,
then we would embed the expression within our code using:
http://example.com/id
You can also import expressions stored within environment variables using
env:NAME
, where NAME
is the name of the environment variable. For
example:
$ export FOO=1 $ export BAR='"Hi"' $ export BAZ='λ(x : Bool) → x == False' $ dhall <<< "{ foo = env:FOO , bar = env:BAR , baz = env:BAZ }" { bar : Text, baz : ∀(x : Bool) → Bool, foo : Integer } { bar = "Hi", baz = λ(x : Bool) → x == False, foo = 1 }
If you wish to import the raw contents of an impoert as Text
then add
as Text
to the end of the import:
$ dhall <<< "http://example.com as Text" Text "<!doctype html>\n<html>\n<head>\n <title>Example Domain</title>\n\n <meta charset=\"utf-8\" />\n <meta http-equiv=\"Content-type\" content=\"text/html ; charset=utf-8\" />\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n <style type=\"text/css\">\n body {\n backgro und-color: #f0f0f2;\n margin: 0;\n padding: 0;\n font-famil y: \"Open Sans\", \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n \n }\n div {\n width: 600px;\n margin: 5em auto;\n paddi ng: 50px;\n background-color: #fff;\n border-radius: 1em;\n }\n a:link, a:visited {\n color: #38488f;\n text-decoration: none; \n }\n @media (max-width: 700px) {\n body {\n background -color: #fff;\n }\n div {\n width: auto;\n m argin: 0 auto;\n border-radius: 0;\n padding: 1em;\n }\n }\n </style> \n</head>\n\n<body>\n<div>\n <h1>Example Domain</ h1>\n <p>This domain is established to be used for illustrative examples in d ocuments. You may use this\n domain in examples without prior coordination or asking for permission.</p>\n <p><a href=\"http://www.iana.org/domains/exampl e\">More information...</a></p>\n</div>\n</body>\n</html>\n"
Synopsis
- exprFromImport :: Import -> StateT (Status IO) IO (Expr Src Import)
- exprToImport :: Import -> Expr Src X -> StateT (Status IO) IO ()
- load :: Expr Src Import -> IO (Expr Src X)
- loadWith :: MonadCatch m => Expr Src Import -> StateT (Status m) m (Expr Src X)
- hashExpression :: StandardVersion -> Expr s X -> Digest SHA256
- hashExpressionToCode :: StandardVersion -> Expr s X -> Text
- assertNoImports :: MonadIO io => Expr Src Import -> io (Expr Src X)
- data Status m
- emptyStatus :: FilePath -> Status IO
- stack :: Functor f => LensLike' f (Status m) (NonEmpty Import)
- cache :: Functor f => LensLike' f (Status m) (Map Import (NodeId, Expr Src X))
- manager :: Functor f => LensLike' f (Status m) (Maybe Dynamic)
- standardVersion :: Functor f => LensLike' f (Status m) StandardVersion
- normalizer :: Functor f => LensLike' f (Status m) (ReifiedNormalizer X)
- startingContext :: Functor f => LensLike' f (Status m) (Context (Expr Src X))
- resolver :: Functor f => LensLike' f (Status m) (Import -> StateT (Status m) m (Expr Src Import))
- cacher :: Functor f => LensLike' f (Status m) (Import -> Expr Src X -> StateT (Status m) m ())
- newtype Cycle = Cycle {}
- newtype ReferentiallyOpaque = ReferentiallyOpaque {}
- data Imported e = Imported {
- importStack :: NonEmpty Import
- nested :: e
- data ImportResolutionDisabled = ImportResolutionDisabled
- data PrettyHttpException = PrettyHttpException String Dynamic
- data MissingFile = MissingFile FilePath
- newtype MissingEnvironmentVariable = MissingEnvironmentVariable {}
- newtype MissingImports = MissingImports [SomeException]
Import
exprFromImport :: Import -> StateT (Status IO) IO (Expr Src Import) Source #
Parse an expression from a Import
containing a Dhall program
exprToImport :: Import -> Expr Src X -> StateT (Status IO) IO () Source #
Save an expression to the specified Import
Currently this only works for cached imports and ignores other types of imports, but could conceivably work for uncached imports in the future
The main reason for this more general type is for symmetry with
exprFromImport
and to support doing more clever things in the future,
like doing "the right thing" for uncached imports (i.e. exporting
environment variables or creating files)
hashExpression :: StandardVersion -> Expr s X -> Digest SHA256 Source #
Hash a fully resolved expression
hashExpressionToCode :: StandardVersion -> Expr s X -> Text Source #
Convenience utility to hash a fully resolved expression and return the
base-16 encoded hash with the sha256:
prefix
In other words, the output of this function can be pasted into Dhall source code to add an integrity check to an import
assertNoImports :: MonadIO io => Expr Src Import -> io (Expr Src X) Source #
Assert than an expression is import-free
emptyStatus :: FilePath -> Status IO Source #
Default starting Status
, importing relative to the given directory.
standardVersion :: Functor f => LensLike' f (Status m) StandardVersion Source #
normalizer :: Functor f => LensLike' f (Status m) (ReifiedNormalizer X) Source #
resolver :: Functor f => LensLike' f (Status m) (Import -> StateT (Status m) m (Expr Src Import)) Source #
cacher :: Functor f => LensLike' f (Status m) (Import -> Expr Src X -> StateT (Status m) m ()) Source #
An import failed because of a cycle in the import graph
Cycle | |
|
Instances
Show Cycle Source # | |
Exception Cycle Source # | |
Defined in Dhall.Import toException :: Cycle -> SomeException # fromException :: SomeException -> Maybe Cycle # displayException :: Cycle -> String # |
newtype ReferentiallyOpaque Source #
Dhall tries to ensure that all expressions hosted on network endpoints are weakly referentially transparent, meaning roughly that any two clients will compile the exact same result given the same URL.
To be precise, a strong interpretaton of referential transparency means that if you compiled a URL you could replace the expression hosted at that URL with the compiled result. Let's call this "static linking". Dhall (very intentionally) does not satisfy this stronger interpretation of referential transparency since "statically linking" an expression (i.e. permanently resolving all imports) means that the expression will no longer update if its dependencies change.
In general, either interpretation of referential transparency is not enforceable in a networked context since one can easily violate referential transparency with a custom DNS, but Dhall can still try to guard against common unintentional violations. To do this, Dhall enforces that a non-local import may not reference a local import.
Local imports are defined as:
- A file
- A URL with a host of
localhost
or127.0.0.1
All other imports are defined to be non-local
ReferentiallyOpaque | |
|
Instances
Show ReferentiallyOpaque Source # | |
Defined in Dhall.Import showsPrec :: Int -> ReferentiallyOpaque -> ShowS # show :: ReferentiallyOpaque -> String # showList :: [ReferentiallyOpaque] -> ShowS # | |
Exception ReferentiallyOpaque Source # | |
Defined in Dhall.Import |
Extend another exception with the current import stack
Imported | |
|
Instances
Show e => Show (Imported e) Source # | |
Exception e => Exception (Imported e) Source # | |
Defined in Dhall.Import toException :: Imported e -> SomeException # fromException :: SomeException -> Maybe (Imported e) # displayException :: Imported e -> String # |
data ImportResolutionDisabled Source #
A call to assertNoImports
failed because there was at least one import
Instances
Show ImportResolutionDisabled Source # | |
Defined in Dhall.Import showsPrec :: Int -> ImportResolutionDisabled -> ShowS # show :: ImportResolutionDisabled -> String # showList :: [ImportResolutionDisabled] -> ShowS # | |
Exception ImportResolutionDisabled Source # | |
data PrettyHttpException Source #
Wrapper around HttpException
s with a prettier Show
instance.
In order to keep the library API constant even when the with-http
Cabal
flag is disabled the pretty error message is pre-rendered and the real
HttpExcepion
is stored in a Dynamic
Instances
Show PrettyHttpException Source # | |
Defined in Dhall.Import.Types showsPrec :: Int -> PrettyHttpException -> ShowS # show :: PrettyHttpException -> String # showList :: [PrettyHttpException] -> ShowS # | |
Exception PrettyHttpException Source # | |
Defined in Dhall.Import.Types |
data MissingFile Source #
Exception thrown when an imported file is missing
Instances
Show MissingFile Source # | |
Defined in Dhall.Import showsPrec :: Int -> MissingFile -> ShowS # show :: MissingFile -> String # showList :: [MissingFile] -> ShowS # | |
Exception MissingFile Source # | |
Defined in Dhall.Import |
newtype MissingEnvironmentVariable Source #
Exception thrown when an environment variable is missing
Instances
Show MissingEnvironmentVariable Source # | |
Defined in Dhall.Import showsPrec :: Int -> MissingEnvironmentVariable -> ShowS # show :: MissingEnvironmentVariable -> String # showList :: [MissingEnvironmentVariable] -> ShowS # | |
Exception MissingEnvironmentVariable Source # | |
newtype MissingImports Source #
List of Exceptions we encounter while resolving Import Alternatives
Instances
Show MissingImports Source # | |
Defined in Dhall.Import showsPrec :: Int -> MissingImports -> ShowS # show :: MissingImports -> String # showList :: [MissingImports] -> ShowS # | |
Exception MissingImports Source # | |
Defined in Dhall.Import |