-
-
Notifications
You must be signed in to change notification settings - Fork 30
Question: how come function references on the global scope are not closed #57
Comments
Thank you for your question. ....but, I'm not sure why it's so. I guess that it's as-is from the original package Maybe... it couldn't assume declarations in global scope make variables, because browsers may ignore declarations. var top = function() {}
top() // ERROR: 'top' is not a function
|
Interesting. I believe at least in |
Yes, Also, new |
is it only Doing some testing it looks like every single other case works as expected and throws this error: It's only |
@mysticatea what's the verdict here? Is there something to fix or no? |
@mysticatea is this something you want to address? |
eslint-scope/tests/references.js
Lines 211 to 263 in dbddf14
I'm working on trying to understand this codebase better.
But I can't understand why it works this way:
To me it seems clear that the reference that's created as part of the call should resolve directly to the function declaration, but it's not - it remains as an unresolved reference that's added to the global scope's
through
list.This would cause the
no-unused-vars
ESLint rule to error on the function declaration, were it not for this code in the linter.It looks like it works seemingly by chance? ESLint augments the global scope with more variables, and then forcefully resolves any
through
references against the global variableset
, which includes the function declaration as well as the augmented variables.Is anyone able to explain why this works this way?
Or a better question - when closing the global scope, why doesn't it attempt to resolve all
through
references against the variables defined in the global scope?The text was updated successfully, but these errors were encountered: