Generate Variables From JSON: Difference between revisions

From RPTools Wiki
Jump to navigation Jump to search
m (Conversion script moved page Generate Variables From JSON to generate Variables From JSON: Converting page titles to lowercase)
m (Text replacement - "source>" to "syntaxhighlight>")
Line 3: Line 3:
<source lang="mtmacro" line>
<source lang="mtmacro" line>
[prop = "name=Axe; damage=1d12; proficiency=2;"]
[prop = "name=Axe; damage=1d12; proficiency=2;"]
</source>
</syntaxhighlight>


You can use {{func|varsFromStrProp}} to generate a variable for each key - in other words, using the function to generate a list of locally accessible variables {{code|name}}, {{code|damage}}, and {{code|proficiency}}.  
You can use {{func|varsFromStrProp}} to generate a variable for each key - in other words, using the function to generate a list of locally accessible variables {{code|name}}, {{code|damage}}, and {{code|proficiency}}.  
Line 18: Line 18:
     [set(var,value)]
     [set(var,value)]
}]
}]
</source>
</syntaxhighlight>
<hr>
<hr>



Revision as of 17:04, 14 March 2023

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:

<source lang="mtmacro" line> [prop = "name=Axe; damage=1d12; proficiency=2;"] </syntaxhighlight>

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.


<source lang="mtmacro"> [h:varList=json.fields(testObj)]

[h,foreach(var,varList),CODE: {

    [value = json.get(testObj,var)]
    [set(var,value)]

}] </syntaxhighlight>


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).