Improve the walk up test to prove that DustJS is doing dynamic scoping, not lexical scoping.
This commit is contained in:
parent
9adb88d132
commit
45facfed0d
33
js/test_cases/walk_up/README.md
Normal file
33
js/test_cases/walk_up/README.md
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
Through experimentation it seems that you can walk up to access higher levels in the context. Interestingly enough, it seems that walking up to a higher context does not unwind the context stack but instead seems to add the higher level context element to the bottom. For example:
|
||||||
|
|
||||||
|
```js
|
||||||
|
{
|
||||||
|
"foo": {
|
||||||
|
"f1": "f",
|
||||||
|
"f2": "ff"
|
||||||
|
},
|
||||||
|
"bar": {
|
||||||
|
"b1": "b",
|
||||||
|
"b2": "bb"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
if we walk down into bar and then into foo then our variable look ups appear to follow this pattern:
|
||||||
|
```
|
||||||
|
(attempts to read from the context in-order starting with the first line)
|
||||||
|
|
||||||
|
Starting access context:
|
||||||
|
{"foo":{"f1":"f","f2":"ff"},"bar":{"b1":"b","b2":"bb"}}
|
||||||
|
|
||||||
|
After walk "bar":
|
||||||
|
{"b1":"b","b2":"bb"}
|
||||||
|
{"foo":{"f1":"f","f2":"ff"},"bar":{"b1":"b","b2":"bb"}}
|
||||||
|
|
||||||
|
After walk "foo":
|
||||||
|
{"f1":"f","f2":"ff"}
|
||||||
|
{"b1":"b","b2":"bb"}
|
||||||
|
{"foo":{"f1":"f","f2":"ff"},"bar":{"b1":"b","b2":"bb"}}
|
||||||
|
```
|
||||||
|
|
||||||
|
This appears to be using dynamic scoping instead of lexical scoping. For example, in lexical scoping a read of "b1" would fail after that final walk because you're inside the "foo" context which does not have any "b1" in or above it, however, since this is using dynamic scoping its using the invocations to build a scope tree rather than their original position.
|
@ -6,6 +6,6 @@
|
|||||||
"people": [
|
"people": [
|
||||||
{"name": "Alice", "job": "Chief Swinger"},
|
{"name": "Alice", "job": "Chief Swinger"},
|
||||||
{"name": "Bob", "job": "Chief Swayer"},
|
{"name": "Bob", "job": "Chief Swayer"},
|
||||||
{"name": "Chris", "job": "Barista", "company": "GenericCoffee"}
|
{"name": "Chris", "job": "Barista", "company": "GenericCoffee", "email": "thecoffeeguy@generic.coffee"}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
Directory for {company}:{~n}
|
Directory for {company}:{~n}
|
||||||
{#people}
|
{#people}
|
||||||
{name}: {job} at {company} (email: {globals.email}){~n}
|
{name}: {job} at {company} (email: {globals.email}){~n}
|
||||||
|
Testing walking after entering a parent context {#globals}job: {job}, email: {email}, company: {company}{/globals}{~n}
|
||||||
{/people}
|
{/people}
|
||||||
|
@ -181,6 +181,7 @@ impl<'a> DustRenderer<'a> {
|
|||||||
fn walk_path<'a>(
|
fn walk_path<'a>(
|
||||||
context: &'a dyn ContextElement,
|
context: &'a dyn ContextElement,
|
||||||
path: &Vec<&str>,
|
path: &Vec<&str>,
|
||||||
|
breadcrumbs: Vec<&'a dyn ContextElement>,
|
||||||
) -> Result<&'a dyn ContextElement, RenderError<'a>> {
|
) -> Result<&'a dyn ContextElement, RenderError<'a>> {
|
||||||
let mut output = context;
|
let mut output = context;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user