-
Notifications
You must be signed in to change notification settings - Fork 18
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add a decoding algorithm for index maps #132
base: main
Are you sure you want to change the base?
Conversation
source-map.bs
Outdated
1. If |offsetColumn| is not a number, [=optionally report an error=]. | ||
1. If |previousOffset| is not null, | ||
1. If |previousLastMapping| is not null, | ||
1. If |offsetLine| is less than |previousLastMapping|'s [=decoded mapping/generatedLine=], [=optionally report an error=]. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should these range checks be "less than or equal to" to be strict inequality rather than allowing equality?
9570cc4
to
fd1bf64
Compare
Could you rebase? :) |
These aren't linked to so they don't need the tags
* Fix first line issue * Use extend again for new mappings
* Check the overlap of ranges {lastFirst, lastPrev} and the {first, last} of the current source map section instead of current more complicated steps. * The overlap check also ensures the order of the ranges, beyond the ordering of the offsets (which itself doesn't guarantee range order) * Some editorial changes for the check
Also set a default value so the algorithm continues
An implementation may do a generated->original lookup in an index map by first searching through the sections by their offset and looking in only the section where the position is within the range {offset, nextOffset}. This is only valid if all mappings in a given section are contained in that range, rather than going into the next section's range. Also simplifies the check by removing the firstPreviousMapping variable and its use. The algorithm checks that the (1) the offsets are ordered (in 8g) (2) the last mapping of the previous section is before the current offset (in 8h) (3) it doesn't check that the first mapping is after the current offset because that is true by construction
9505a3d
to
0d6ffb2
Compare
I rebased this and made some adjustments. It now checks that mapping ranges are always contained within the section offsets too, which I think is required for the assumptions made in implementations about mappings appearing in a unique bucket. That means mappings are ordered like this:
and so on. |
@jridgewell Just a friendly ping for a last pass on this, thanks! |
1. [=For each=] |mapping| of |decodedSection|'s [=decoded source map/mappings=]: | ||
1. Let |offsetMapping| be a new [=decoded mapping=]. | ||
1. Set |offsetMapping|'s [=decoded mapping/generatedLine=] to |mapping|'s [=decoded mapping/generatedLine=] + |offsetLine|. | ||
1. If |offsetMapping|'s [=decoded mapping/generatedLine=] is equal to 0, set |offsetMapping|'s [=decoded mapping/generatedColumn=] to |mapping|'s [=decoded mapping/generatedColumn=] + |offsetColumn|. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
1. If |offsetMapping|'s [=decoded mapping/generatedLine=] is equal to 0, set |offsetMapping|'s [=decoded mapping/generatedColumn=] to |mapping|'s [=decoded mapping/generatedColumn=] + |offsetColumn|. | |
1. If |decodedSection|'s [=decoded mapping/generatedLine=] is equal to 0, set |offsetMapping|'s [=decoded mapping/generatedColumn=] to |mapping|'s [=decoded mapping/generatedColumn=] + |offsetColumn|. |
We've just incremented offsetMapping.Line
with the offset.Line
, so this may be non-zero now even though we're still on the same line.
Rendered draft
This PR adds a decoding algorithm for index maps along the lines of the existing algorithms for normal source maps.
I'll leave a few comments for cases in the spec where it's not clear what we should do: