Generate Variables From JSON: Difference between revisions
Jump to navigation
Jump to search
Verisimilar (talk | contribs) m (Removed line numbers for easier copy/paste, and redundant heading) |
|||
Line 1: | Line 1: | ||
When working with string properties, the {{func|varsFromStrProp}} function is an automated way to generate variables from the keys within a string property. For example, if you have the following string property: | When working with string properties, the {{func|varsFromStrProp}} function is an automated way to generate variables from the keys within a string property. For example, if you have the following string property: | ||
Line 11: | Line 9: | ||
There is no equivalent function for JSON objects. However, the following routine can be inserted into any macro to efficiently generate the variables in question. | There is no equivalent function for JSON objects. However, the following routine can be inserted into any macro to efficiently generate the variables in question. | ||
<source lang="mtmacro" | <hr> | ||
<source lang="mtmacro"> | |||
[h:varList=json.fields(testObj)] | [h:varList=json.fields(testObj)] | ||
Line 20: | Line 19: | ||
}] | }] | ||
</source> | </source> | ||
<hr> | |||
The variable {{code|testObj}} represents the JSON object that is fed into the routine. The variables generated will be available within the scope of the running macro (but not outside). | The variable {{code|testObj}} represents the JSON object that is fed into the routine. The variables generated will be available within the scope of the running macro (but not outside). | ||
[[Category:Cookbook]] | [[Category:Cookbook]] |
Revision as of 11:43, 16 April 2009
When working with string properties, the varsFromStrProp() function is an automated way to generate variables from the keys within a string property. For example, if you have the following string property:
[prop = "name=Axe; damage=1d12; proficiency=2;"]
You can use varsFromStrProp() to generate a variable for each key - in other words, using the function to generate a list of locally accessible variables name
, damage
, and proficiency
.
There is no equivalent function for JSON objects. However, the following routine can be inserted into any macro to efficiently generate the variables in question.
[h:varList=json.fields(testObj)]
[h,foreach(var,varList),CODE:
{
[value = json.get(testObj,var)]
[set(var,value)]
}]
The variable testObj
represents the JSON object that is fed into the routine. The variables generated will be available within the scope of the running macro (but not outside).