This is a fork from commercialhaskell/stack-templates.
Here is an example to create an executable project.
stack new my-exec https://raw.githubusercontent.com/nwtgck/stack-templates/master/executable.hsfiles
Here is an example to create a library project.
stack new my-lib https://raw.githubusercontent.com/nwtgck/stack-templates/master/library.hsfiles
There are plans to change the way Stack templates are done in the near future. Therefore, the project is not accepting new templates at this moment.
A repository for templates used by stack new
. See: http://haskellstack.org
Project templates are written in hsfiles format, using mustache. Each
file is specified with START_FILE
, like this:
{-# START_FILE {{name}}.cabal #-}
name: {{name}}
version: 0.1.0.0
...
Parameters to the template are written {{foo}}
. They are provided by
users via their ~/.stack/config.yaml
file, like this:
templates:
params:
author-email: chrisdone@gmail.com
author-name: Chris Done
copyright: 2018 Chris Done
github-username: chrisdone
category: Development
When the user runs stack new myproject yourtemplate
and they do not
have the parameters provided in, it will warn the user that such
parameters were missing, like this:
$ stack new foo new-template
Downloading template "new-template" to create project "foo" in foo/ ...
The following parameters were needed by the template but not provided: author-email, author-name
You can provide them in /home/chris/.stack/stack.yaml, like this:
templates:
params:
author-email: value
author-name: value
Or you can pass each one as parameters like this:
stack new foo new-template -p "author-email:value" -p "author-name:value"
The output of the template will yield a blank space where your parameter was. If you want to provide default values for your template parameters, use this Mustache syntax:
author: {{author-name}}{{^author-name}}Author name here{{/author-name}}
When contributing a new template, please remember to add a corresponding entry
to template-info.yaml
. Additional descriptive information for the template
may be provided, but is not required.
NOTE: The Yesod templates are generated from the yesod-scaffold repo. Please send pull requests for those templates to that repo instead.