|
|
@ -43,20 +43,25 @@ def fix_from_imports(red): |
|
|
|
Case 2: from flask.ext import foo --> import flask_foo as foo |
|
|
|
Case 2: from flask.ext import foo --> import flask_foo as foo |
|
|
|
""" |
|
|
|
""" |
|
|
|
from_imports = red.find_all("FromImport") |
|
|
|
from_imports = red.find_all("FromImport") |
|
|
|
for x in range(len(from_imports)): |
|
|
|
for x, node in enumerate(from_imports): |
|
|
|
values = from_imports[x].value |
|
|
|
values = node.value |
|
|
|
if (values[0].value == 'flask') and (values[1].value == 'ext'): |
|
|
|
if (values[0].value == 'flask') and (values[1].value == 'ext'): |
|
|
|
# Case 1 |
|
|
|
# Case 1 |
|
|
|
if len(from_imports[x].value) == 3: |
|
|
|
if len(node.value) == 3: |
|
|
|
package = values[2].value |
|
|
|
package = values[2].value |
|
|
|
modules = from_imports[x].modules() |
|
|
|
modules = node.modules() |
|
|
|
|
|
|
|
if len(modules) > 1: |
|
|
|
r = "{}," * len(modules) |
|
|
|
r = "{}," * len(modules) |
|
|
|
from_imports[x].replace("from flask_%s import %s" |
|
|
|
node.replace("from flask_%s import %s" |
|
|
|
% (package, r.format(*modules)[:-1])) |
|
|
|
% (package, r.format(*modules)[:-1])) |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
name = node.names()[0] |
|
|
|
|
|
|
|
node.replace("from flask_%s import %s as %s" |
|
|
|
|
|
|
|
% (package, modules.pop(), name)) |
|
|
|
# Case 2 |
|
|
|
# Case 2 |
|
|
|
else: |
|
|
|
else: |
|
|
|
module = from_imports[x].modules()[0] |
|
|
|
module = node.modules()[0] |
|
|
|
from_imports[x].replace("import flask_%s as %s" |
|
|
|
node.replace("import flask_%s as %s" |
|
|
|
% (module, module)) |
|
|
|
% (module, module)) |
|
|
|
return red |
|
|
|
return red |
|
|
|
|
|
|
|
|
|
|
@ -70,13 +75,13 @@ def fix_standard_imports(red): |
|
|
|
original import statement. |
|
|
|
original import statement. |
|
|
|
""" |
|
|
|
""" |
|
|
|
imports = red.find_all("ImportNode") |
|
|
|
imports = red.find_all("ImportNode") |
|
|
|
for x in range(len(imports)): |
|
|
|
for x, node in enumerate(imports): |
|
|
|
values = imports[x].value |
|
|
|
|
|
|
|
try: |
|
|
|
try: |
|
|
|
if (values[x].value[0].value == 'flask' and |
|
|
|
if (node.value[0].value == 'flask' and |
|
|
|
values[x].value[1].value == 'ext'): |
|
|
|
node.value[1].value == 'ext'): |
|
|
|
package = values[x].value[2].value |
|
|
|
package = node.value[2].value |
|
|
|
imports[x].replace("import flask_%s" % package) |
|
|
|
name = node.names()[0] |
|
|
|
|
|
|
|
imports[x].replace("import flask_%s as %s" % (package, name)) |
|
|
|
except IndexError: |
|
|
|
except IndexError: |
|
|
|
pass |
|
|
|
pass |
|
|
|
|
|
|
|
|
|
|
@ -88,6 +93,8 @@ def fix(ast): |
|
|
|
return fix_imports(ast).dumps() |
|
|
|
return fix_imports(ast).dumps() |
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__": |
|
|
|
if __name__ == "__main__": |
|
|
|
|
|
|
|
if len(sys.argv) < 2: |
|
|
|
|
|
|
|
sys.exit("No filename was included, please try again.") |
|
|
|
input_file = sys.argv[1] |
|
|
|
input_file = sys.argv[1] |
|
|
|
ast = read_source(input_file) |
|
|
|
ast = read_source(input_file) |
|
|
|
ast = fix_imports(ast) |
|
|
|
ast = fix_imports(ast) |
|
|
|