foreach (roll option): Difference between revisions

From RPTools Wiki
Jump to navigation Jump to search
(Updated topic to reasonable standard and to include JSONS, feel free to edit to clean up for me.)
m (→‎Usage: added default values for optional parameters)
Line 12: Line 12:
[FOREACH(var, list, output_separator, list_separator): body]
[FOREACH(var, list, output_separator, list_separator): body]
</source>
</source>
output_seperator default value is ""
list_seperator default value is ","


===Examples===
===Examples===

Revision as of 04:18, 12 November 2011

FOREACH Option

Introduced: Version 1.3.b46

Iterates over the contents of a string list in the format "item1, item2, item3" Can also be used with JSON arrays and JSON objects.

Usage

[FOREACH(var, list): body]
[FOREACH(var, list, output_separator): body]
[FOREACH(var, list, output_separator, list_separator): body]

output_seperator default value is "" list_seperator default value is ","

Examples

String List Example

[h: enemyList="Orcs, Goblins, Ogres, Trolls"]
[FOREACH(enemy, enemyList, "<br>"): "You really hate " + enemy]

JSON Array Example

[h: enemyList = json.append("","Orcs, Goblins, Ogres, Trolls")]
[FOREACH (enemy, enemyList): "You really hate " + enemy]

JSON Object Example

(Note that using foreach with a JSON object will result in only the keys being returned as vars).

[h: enemyList = json.set("","Orcs", "Bob, Dave", "Goblins", "Graham", "Ogres", "Philip, Emanual", "Trolls", "Ig, Og, Ug"]
[FOREACH (enemy, enemyList): "You really hate " + enemy]

All the above will output:

You really hate Orcs
You really hate Goblins
You really hate Ogres
You really hate Trolls

Using with [code():]

To use roll options with your FOREACH loop, you will need to use [code():] roll option.

[h: enemyList="Orcs; Goblins; Ogres; Trolls"]
[FOREACH(enemy, enemyList, " then ", ";"), CODE:
    {
    [r: enemy]
    }
]

output:

Orcs then Goblins then Ogres then Trolls


See Also

json.append, json.set, code_(roll_option)