mirror of
https://github.com/davidhalter/jedi.git
synced 2025-12-07 22:44:27 +08:00
Get renames working for module imports
This commit is contained in:
@@ -1,3 +1,5 @@
|
|||||||
|
from os.path import dirname, basename, join
|
||||||
|
import re
|
||||||
import difflib
|
import difflib
|
||||||
|
|
||||||
from parso import split_lines
|
from parso import split_lines
|
||||||
@@ -54,36 +56,44 @@ class Refactoring(object):
|
|||||||
|
|
||||||
Returns ``Iterable[Tuple[str, str]]``.
|
Returns ``Iterable[Tuple[str, str]]``.
|
||||||
"""
|
"""
|
||||||
return self._renames
|
return sorted(self._renames)
|
||||||
|
|
||||||
def get_diff(self):
|
def get_diff(self):
|
||||||
return ''.join(f.get_diff() for f in self.get_changed_files())
|
text = ''
|
||||||
|
for from_, to in self.get_renames():
|
||||||
|
text += 'rename from %s\nrename to %s\n' % (from_, to)
|
||||||
|
|
||||||
|
return text + ''.join(f.get_diff() for f in self.get_changed_files())
|
||||||
|
|
||||||
def apply(self):
|
def apply(self):
|
||||||
for old, new in self._renames:
|
for old, new in self.get_renames():
|
||||||
rename(old, new)
|
rename(old, new)
|
||||||
|
|
||||||
for f in self.get_changed_files():
|
for f in self.get_changed_files():
|
||||||
f.apply()
|
f.apply()
|
||||||
|
|
||||||
|
|
||||||
def _rename_path(path, new_name):
|
def _calculate_rename(path, new_name):
|
||||||
pass
|
name = basename(path)
|
||||||
|
dir_ = dirname(path)
|
||||||
|
if name in ('__init__.py', '__init__.pyi'):
|
||||||
|
parent_dir = dirname(dir_)
|
||||||
|
return dir_, join(parent_dir, new_name, name)
|
||||||
|
ending = re.search(r'\.pyi?$', name).group(0)
|
||||||
|
return path, join(dir_, new_name + ending)
|
||||||
|
|
||||||
|
|
||||||
def rename(grammar, definitions, new_name):
|
def rename(grammar, definitions, new_name):
|
||||||
file_renames = []
|
file_renames = set()
|
||||||
file_tree_name_map = {}
|
file_tree_name_map = {}
|
||||||
|
|
||||||
for d in definitions:
|
for d in definitions:
|
||||||
if d.type == 'module':
|
tree_name = d._name.tree_name
|
||||||
file_renames.append(
|
if d.type == 'module' and tree_name is None:
|
||||||
(d.module_path, _rename_path(d.module_path, new_name))
|
file_renames.add(_calculate_rename(d.module_path, new_name))
|
||||||
)
|
|
||||||
else:
|
else:
|
||||||
# This private access is ok in a way. It's not public to
|
# This private access is ok in a way. It's not public to
|
||||||
# protect Jedi users from seeing it.
|
# protect Jedi users from seeing it.
|
||||||
tree_name = d._name.tree_name
|
|
||||||
if tree_name is not None:
|
if tree_name is not None:
|
||||||
fmap = file_tree_name_map.setdefault(d.module_path, {})
|
fmap = file_tree_name_map.setdefault(d.module_path, {})
|
||||||
fmap[tree_name] = tree_name.prefix + new_name
|
fmap[tree_name] = tree_name.prefix + new_name
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ class RefactoringCase(object):
|
|||||||
return f_name.replace('.py', '')
|
return f_name.replace('.py', '')
|
||||||
|
|
||||||
def calculate_diff(self):
|
def calculate_diff(self):
|
||||||
project = jedi.Project(os.path.join(test_dir, 'completion'))
|
project = jedi.Project(os.path.join(test_dir, 'refactor'))
|
||||||
script = jedi.Script(self._code, path=self._path, project=project)
|
script = jedi.Script(self._code, path=self._path, project=project)
|
||||||
refactor_func = getattr(script, self.refactor_type)
|
refactor_func = getattr(script, self.refactor_type)
|
||||||
refactor_object = refactor_func(self._line_nr, self._index, *self._args)
|
refactor_object = refactor_func(self._line_nr, self._index, *self._args)
|
||||||
|
|||||||
1
test/refactor/import_tree/mod.py
Normal file
1
test/refactor/import_tree/mod.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
foobar = 3
|
||||||
@@ -43,44 +43,35 @@ def y():
|
|||||||
some_var = 3
|
some_var = 3
|
||||||
some_var
|
some_var
|
||||||
# ----- import
|
# ----- import
|
||||||
from import_tree.mod1 import foobarbaz
|
from import_tree.mod import foobar
|
||||||
#? 0 renamed
|
#? 0 renamed
|
||||||
foobarbaz
|
foobar
|
||||||
# +++++
|
# +++++
|
||||||
--- /home/dave/source/jedi/test/completion/import_tree/mod1.py
|
--- /home/dave/source/jedi/test/refactor/import_tree/mod.py
|
||||||
+++ /home/dave/source/jedi/test/completion/import_tree/mod1.py
|
+++ /home/dave/source/jedi/test/refactor/import_tree/mod.py
|
||||||
@@ -1,5 +1,5 @@
|
@@ -1,2 +1,2 @@
|
||||||
a = 1
|
-foobar = 3
|
||||||
from import_tree.random import a as c
|
+renamed = 3
|
||||||
|
|
||||||
-foobarbaz = 3.0
|
|
||||||
+renamed = 3.0
|
|
||||||
--- /home/dave/source/jedi/test/refactor/rename.py
|
--- /home/dave/source/jedi/test/refactor/rename.py
|
||||||
+++ /home/dave/source/jedi/test/refactor/rename.py
|
+++ /home/dave/source/jedi/test/refactor/rename.py
|
||||||
@@ -1,4 +1,4 @@
|
@@ -1,4 +1,4 @@
|
||||||
-from import_tree.mod1 import foobarbaz
|
-from import_tree.mod import foobar
|
||||||
+from import_tree.mod1 import renamed
|
+from import_tree.mod import renamed
|
||||||
#? 0 renamed
|
#? 0 renamed
|
||||||
-foobarbaz
|
-foobar
|
||||||
+renamed
|
+renamed
|
||||||
# ----- module
|
# ----- module
|
||||||
from import_tree import mod1
|
from import_tree import mod
|
||||||
#? 0 renamedm
|
#? 0 renamedm
|
||||||
mod1
|
mod
|
||||||
# +++++
|
# +++++
|
||||||
--- /home/dave/source/jedi/test/completion/import_tree/mod1.py
|
rename from /home/dave/source/jedi/test/refactor/import_tree/mod.py
|
||||||
+++ /home/dave/source/jedi/test/completion/import_tree/renamedm.py
|
rename to /home/dave/source/jedi/test/refactor/import_tree/renamedm.py
|
||||||
@@ -1,5 +1,5 @@
|
|
||||||
a = 1
|
|
||||||
from import_tree.random import a as c
|
|
||||||
|
|
||||||
-foobarbaz = 3.0
|
|
||||||
+renamed = 3.0
|
|
||||||
--- /home/dave/source/jedi/test/refactor/rename.py
|
--- /home/dave/source/jedi/test/refactor/rename.py
|
||||||
+++ /home/dave/source/jedi/test/refactor/rename.py
|
+++ /home/dave/source/jedi/test/refactor/rename.py
|
||||||
@@ -1,4 +1,4 @@
|
@@ -1,4 +1,4 @@
|
||||||
-from import_tree import mod1
|
-from import_tree import mod
|
||||||
+from import_tree import renamedm
|
+from import_tree import renamedm
|
||||||
#? 0 renamedm
|
#? 0 renamedm
|
||||||
-mod1
|
-mod
|
||||||
+renamedm
|
+renamedm
|
||||||
|
|||||||
Reference in New Issue
Block a user