You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When studying a specification, it is helpful if the various portions have a natural ordering, such that each portion only depends upon the successful understanding (or implementation) of the preceding portions, and not on the implementation of any succeeding portions. Unfortunately, there is a dependency loop between the 'interpolation' and 'sections' portions of the specification. Specifically, the five tests 'Dotted Names - Basic Interpolation', 'Dotted Names - Triple Mustache Interpolation', 'Dotted Names - Ampersand Interpolation', 'Dotted Names - Initial Resolution' and 'Dotted Names - Context Precedence' of the 'interpolation' portion assume that the 'sections' portion has been implemented. These tests should be moved to the 'sections' portion. Modified versions of the first three can left in the 'interpolation' portion by making them more like the Dotted Names - Arbitrary Depth interpolation test.
Once the portions can be ordered, it would also be helpful to include information about that in the specification itself, by adding a key to the top level. Several possible names suggest themselves for this key; I will use 'depends_upon' but 'assumes', 'requires' or 'uses' would also be good names.
The 'interpolation' portion, being the base, would include this:
depends_upon: []
The 'comments' and 'sections' specs would include this:
depends_upon: ['interpolation']
The 'delimiters', 'inverted' and 'partials' portions would include this:
depends_upon: ['sections']
Finally, the '~lambdas' portion would include this:
depends_upon: ['inverted']
With this in place, a topological sort will produce an ordering. Note that each section defines a list of prerequisites, even though the current specs only demand one each; also note that although a topological sort can figure things out, you may want to include all prerequisites in the list, not just the immediate predecessor.
The text was updated successfully, but these errors were encountered:
I like the idea of turning the tests into a directed acyclic graph (DAG). Please feel welcome to create a pull request that does this for the current version of the spec.
When studying a specification, it is helpful if the various portions have a natural ordering, such that each portion only depends upon the successful understanding (or implementation) of the preceding portions, and not on the implementation of any succeeding portions. Unfortunately, there is a dependency loop between the 'interpolation' and 'sections' portions of the specification. Specifically, the five tests 'Dotted Names - Basic Interpolation', 'Dotted Names - Triple Mustache Interpolation', 'Dotted Names - Ampersand Interpolation', 'Dotted Names - Initial Resolution' and 'Dotted Names - Context Precedence' of the 'interpolation' portion assume that the 'sections' portion has been implemented. These tests should be moved to the 'sections' portion. Modified versions of the first three can left in the 'interpolation' portion by making them more like the Dotted Names - Arbitrary Depth interpolation test.
Once the portions can be ordered, it would also be helpful to include information about that in the specification itself, by adding a key to the top level. Several possible names suggest themselves for this key; I will use 'depends_upon' but 'assumes', 'requires' or 'uses' would also be good names.
The 'interpolation' portion, being the base, would include this:
The 'comments' and 'sections' specs would include this:
The 'delimiters', 'inverted' and 'partials' portions would include this:
Finally, the '~lambdas' portion would include this:
With this in place, a topological sort will produce an ordering. Note that each section defines a list of prerequisites, even though the current specs only demand one each; also note that although a topological sort can figure things out, you may want to include all prerequisites in the list, not just the immediate predecessor.
The text was updated successfully, but these errors were encountered: