Skip to content

estraverse breaking on comments inside conditions#26

Open
evindor wants to merge 1 commit intoestools:masterfrom
evindor:master
Open

estraverse breaking on comments inside conditions#26
evindor wants to merge 1 commit intoestools:masterfrom
evindor:master

Conversation

@evindor
Copy link
Copy Markdown

@evindor evindor commented Apr 8, 2014

Example:

if (a &&
    // We need to check b beacuse of IE   <<< BOOM
    b > 0 && c) {
    // code
}

Trace:

/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/escodegen/node_modules/estraverse/estraverse.js:646
                    if (node.range[1] < comment.extendedRange[0]) {
                                  ^
TypeError: Cannot read property '1' of undefined
    at Controller.traverse.leave (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/escodegen/node_modules/estraverse/estraverse.js:646:35)
    at Controller.__execute (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/escodegen/node_modules/estraverse/estraverse.js:313:31)
    at Controller.traverse (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/escodegen/node_modules/estraverse/estraverse.js:379:28)
    at traverse (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/escodegen/node_modules/estraverse/estraverse.js:551:27)
    at Object.attachComments (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/escodegen/node_modules/estraverse/estraverse.js:640:9)
    at Stream.end (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/index.js:98:17)
    at _end (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/through/index.js:65:9)
    at Stream.stream.end (/Users/evindor/.nvm/v0.10.26/lib/node_modules/amd-to-closure/node_modules/through/index.js:74:5)
    at ReadStream.onend (_stream_readable.js:483:10)
    at ReadStream.g (events.js:180:16)

I've just hacked it around, i guess this issue needs more deep exploration.

@Constellation
Copy link
Copy Markdown
Member

Hm.
Do you add range option to esprima? attachComments need range option.

@evindor
Copy link
Copy Markdown
Author

evindor commented Apr 13, 2014

Yes, range option was turned on.

@RReverser
Copy link
Copy Markdown
Member

@evindor Looks like the issue is you are calling attachComments(...) after modifying AST, which means absolute positions it relies on are broken at moment of attachment.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants