Skip to content

Latest commit

 

History

History
65 lines (41 loc) · 2.41 KB

ADVANCED.md

File metadata and controls

65 lines (41 loc) · 2.41 KB

Advanced usage

###Are there parameter naming restrictions?

Yes. Parameters can be any combination of unicode code points that forms a series of runes. But, parameters must not contain square brackets ([]), and must not include either a semicolon, comma, or an equals sign (;, , or =), and cannot begin with a colon (:).

Parameters can begin with numbers, unlike other frameworks/parsers which prohibit this.

As features emerge, further restrictions may apply. Any new feature that adds naming restrictions will try to stick to the ascii-range symbols. In general, try to keep your parameters alphanumeric, and you'll be fine.

###How do I make package paths?

Parameters can be specified as a list by separating values with a comma, like so.

wisk -p "project.package=com,example,sample"

By default, if a parameter is referenced and the parameter is a list, only the first element in the list will be used. So using "${{=project.package=}}" with the above parameters will only result in "com". However, placeholders can specify a separator used to join the list elements together, like so;

${{=project.package[.]=}}

In this case, the above will be replaced with "com.example.sample". This is useful for creating nested folder structures, or package names. See the Java examples in the "samples" folder for an implementation of this, using a single "project.package" parameter to create nested folder hierarchies and package declarations.

Note that if no separator is specified, the default OS path separator is used instead.

###Can I inject parameters into a block of boilerplate?

A "content placeholder" can be used to create a sequence of values, each using one value from the list of a single parameter. For instance;

${{=:project.properties=}}
${{value}}=TRUE
${{=;project.properties=}}

Would use each value in "project.properties" to generate a line. Given the input:

wisk -p "project.properties=foo,bar,baz,quux"

The following would be generated:

foo=TRUE
bar=TRUE
baz=TRUE
quux=TRUE

However, this "content placeholder" construct can be used recursively with the recurse reserved placeholder. This is primarily useful for things like Ruby module declarations. Given the below example;

${{=:project.module=}}
module ${{value}}
${{recurse}}
end
${{=;project.module=}}

With the parameter being;

wisk -p "project.module=My,Sample,Project"

The result is:

module My
module Sample
module Project
end
end
end