language-dockerfile alternatives and similar packages
Based on the "Development" category.
Alternatively, view language-dockerfile alternatives based on common mentions on social networks and blogs.
-
cabal-install-parsers
Scripts and instructions for using CI services (e.g. Travis CI or Appveyor) with multiple GHC configurations -
fourmolu
A fourk of ormolu that uses four space indentation and allows arbitrary configuration. Don't like it? PRs welcome!
InfluxDB - Purpose built for real-time analytics at any scale.
Do you think we are missing an alternative of language-dockerfile or a related project?
README
haskell-language-dockerfile
Dockerfile linter, parser, pretty-printer and embedded DSL, forked from hadolint.
Published on Hackage as language-dockerfile.
It extends hadolint with the pretty-printer and EDSL for writting Dockerfiles in Haskell.
- Parsing files
- Parsing strings
- Pretty-printing files
- Writing Dockerfiles in Haskell
- Using the QuasiQuoter
- Templating Dockerfiles in Haskell
- Using IO in the DSL
Parsing files
import Language.Dockerfile
main = do
ef <- parseFile "./Dockerfile"
print ef
Parsing strings
import Language.Dockerfile
main = do
c <- readFile "./Dockerfile"
print (parseString c)
Pretty-printing files
import Language.Dockerfile
main = do
Right d <- parseFile "./Dockerfile"
putStr (prettyPrint d)
Writing Dockerfiles in Haskell
{-# LANGUAGE OverloadedStrings #-}
import Language.Dockerfile
main = putStr $ toDockerfileStr $ do
from "node"
run "apt-get update"
runArgs ["apt-get", "install", "something"]
-- ...
Using the QuasiQuoter
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE QuasiQuotes #-}
import Language.Dockerfile
main = putStr $ toDockerfileStr $ do
from "node"
run "apt-get update"
[edockerfile|
RUN apt-get update
CMD node something.js
|]
-- ...
Templating Dockerfiles in Haskell
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE OverloadedStrings #-}
import Control.Monad
import Language.Dockerfile
tags = ["7.8", "7.10", "8"]
cabalSandboxBuild packageName = do
let cabalFile = packageName ++ ".cabal"
run "cabal sandbox init"
run "cabal update"
add cabalFile ("/app/" ++ cabalFile)
run "cabal install --only-dep -j"
add "." "/app/"
run "cabal build"
main =
forM_ tags $ \tag -> do
let df = toDockerfileStr $ do
from ("haskell" `tagged` tag)
cabalSandboxBuild "mypackage"
writeFile ("./examples/templating-" ++ tag ++ ".dockerfile") df
Using IO in the DSL
By default the DSL runs in the Identity
monad. By running in IO we can
support more features like file globbing:
{-# LANGUAGE OverloadedStrings #-}
import Language.Dockerfile
import qualified System.Directory as Directory
import qualified System.FilePath as FilePath
import qualified System.FilePath.Glob as Glob
main = do
str <- toDockerfileStrIO $ do
fs <- liftIO $ do
cwd <- Directory.getCurrentDirectory
fs <- Glob.glob "./test/*.hs"
return (map (FilePath.makeRelative cwd) fs)
from "ubuntu"
mapM_ (\f -> add f ("/app/" ++ FilePath.takeFileName f)) fs
putStr str
License
GPLv3
*Note that all licence references and agreements mentioned in the language-dockerfile README section above
are relevant to that project's source code only.