开发者

why doesn't eclipse-python have magic refactor?

Eclipse is able to utilize compiled bytecode to enable "magic refactor" functionality--renaming methods, tracing up and down class hierarchies and tracing through meth开发者_StackOverflow中文版od calls.

What technical barriers exist that make this harder to do for languages like Python and Javascript?


Because of dynamic binding. Python is a dynamic language in a way that you can do almost everything with your variables. You can even access the globals-dict and introduce new variables composed of runtime values.

So an IDE can’t be sure which variables exist when. See this example:

#silly.py

import sys

if len(sys.argv) > 1:
    thisNowExists = True

#1

try:
    if thisNowExists:
        print("this existed before")
except NameError:
    print("this _now_ exists")
    thisNowExists = True

No human or IDE can know if thisNowExists is defined at the position #1, so if you want to rename the stupidly named thisNowExists below that point, it is undefined if we should rename the appearance before #1, too.

You would have to do advanced control flow analysis to take a good guess that thisNowExists is defined below the try/catch statement, but due to dynamic loading of the script (thisNowExists = 1; import silly) and sorts, it could even exist before import sys without arguments.

naming your variables differently and find/replace is your best option ;)


so it turns out that tracing of static information like methods and class hierarchies is perfectly possible in python. PyDev eclipse plugin does it. PyLint plugin attempts to do static analysis even on stuff like dynamic variables by assuming that nothing funky happens at runtime and does a pretty good job.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜