Fri, 31 May 2024 15:18:05 +0200
Code Style Checker, Name Ordering:
- Changed the import ordering such that '__x' is sorted before '_xx' before other module names (xxx). That is in line with isort.
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
1 | # -*- coding: utf-8 -*- |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
2 | |
10439
21c28b0f9e41
Updated copyright for 2024.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10046
diff
changeset
|
3 | # Copyright (c) 2021 - 2024 Detlev Offenbach <detlev@die-offenbachs.de> |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
4 | # |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
5 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
6 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
7 | Module implementing a class representing an import or import from node. |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
8 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
9 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
10 | # |
10046
35b27af462ef
Code Style Checker
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9653
diff
changeset
|
11 | # adapted from flake8-alphabetize v0.0.21 |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
12 | # |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
13 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
14 | import ast |
9473
3f23dbf37dbe
Resorted the import statements using isort.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9458
diff
changeset
|
15 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
16 | from functools import total_ordering |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
17 | |
10046
35b27af462ef
Code Style Checker
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9653
diff
changeset
|
18 | from eric7.SystemUtilities import SysUtilities |
35b27af462ef
Code Style Checker
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9653
diff
changeset
|
19 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
20 | from .ImportsEnums import GroupEnum, NodeTypeEnum |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
21 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
22 | |
9272
06ed98a19b79
Changed some exception names to comply with PEP-8.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9221
diff
changeset
|
23 | class ImportNodeError(Exception): |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
24 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
25 | Class representing an exception for an invalid import node. |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
26 | """ |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
27 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
28 | pass |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
29 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
30 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
31 | @total_ordering |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
32 | class ImportNode: |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
33 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
34 | Class representing an import or import from node. |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
35 | """ |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
36 | |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
37 | def __init__(self, appNames, astNode, checker, sortIgnoringStyle, sortFromFirst): |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
38 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
39 | Constructor |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
40 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
41 | @param appNames list of application package names |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
42 | @type list of str |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
43 | @param astNode reference to the ast node |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
44 | @type ast.AST |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
45 | @param checker reference to the checker object |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
46 | @type ImportsChecker |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
47 | @param sortIgnoringStyle flag indicating to sort ignoring the import style |
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
48 | @type bool |
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
49 | @param sortFromFirst flag indicating to sort from imports before straight ones |
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
50 | @type bool |
9272
06ed98a19b79
Changed some exception names to comply with PEP-8.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9221
diff
changeset
|
51 | @exception ImportNodeError raised to indicate an invalid node was |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
52 | given to this class |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
53 | """ |
8808
033fa34447d0
Finished implementing a checker for import statements (unnecessary alias, banned relative and banned modules).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
8802
diff
changeset
|
54 | if not isinstance(astNode, (ast.Import, ast.ImportFrom)): |
9278
36448ca469c2
Simplified some code iaw. recommendations of the extended style checker and reformatted the code with black.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9272
diff
changeset
|
55 | raise ImportNodeError("Node type {0} not recognized".format(type(astNode))) |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
56 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
57 | self.node = astNode |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
58 | self.error = None |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
59 | level = None |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
60 | group = None |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
61 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
62 | if isinstance(astNode, ast.Import): |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
63 | self.nodeType = NodeTypeEnum.IMPORT |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
64 | names = astNode.names |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
65 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
66 | self.moduleName = names[0].name |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
67 | self.asImport = bool(names[0].asname) |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
68 | level = 0 |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
69 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
70 | elif isinstance(astNode, ast.ImportFrom): |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
71 | module = astNode.module |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
72 | self.moduleName = "" if module is None else module |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
73 | self.nodeType = NodeTypeEnum.IMPORT_FROM |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
74 | |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
75 | names = [n.name for n in astNode.names] |
9479
b4dff37325de
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9478
diff
changeset
|
76 | expectedNames = checker.sorted( |
b4dff37325de
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9478
diff
changeset
|
77 | names, |
b4dff37325de
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9478
diff
changeset
|
78 | key=lambda k: checker.moduleKey(k, subImports=True), |
b4dff37325de
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9478
diff
changeset
|
79 | ) |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
80 | if names != expectedNames: |
10046
35b27af462ef
Code Style Checker
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9653
diff
changeset
|
81 | self.error = (self.node, "NO102", ", ".join(expectedNames)) |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
82 | level = astNode.level |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
83 | |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
84 | self.asImport = any(n.asname for n in astNode.names) |
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
85 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
86 | if self.moduleName == "__future__": |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
87 | group = GroupEnum.FUTURE |
10046
35b27af462ef
Code Style Checker
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9653
diff
changeset
|
88 | elif self.moduleName.split(".")[0] in SysUtilities.getStandardModules(): |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
89 | group = GroupEnum.STDLIB |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
90 | elif level > 0: |
9480
107aca8932ac
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9479
diff
changeset
|
91 | group = GroupEnum.LOCALPATH |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
92 | else: |
9480
107aca8932ac
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9479
diff
changeset
|
93 | group = GroupEnum.THIRDPARTY |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
94 | for name in appNames: |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
95 | if name == self.moduleName or self.moduleName.startswith( |
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
96 | "{0}.".format(name) |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
97 | ): |
9480
107aca8932ac
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9479
diff
changeset
|
98 | group = GroupEnum.FIRSTPARTY |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
99 | break |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
100 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
101 | if group == GroupEnum.STDLIB: |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
102 | self.sorter = ( |
9479
b4dff37325de
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9478
diff
changeset
|
103 | (group, -self.nodeType, checker.moduleKey(self.moduleName)) |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
104 | if sortFromFirst |
9479
b4dff37325de
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9478
diff
changeset
|
105 | else (group, self.nodeType, checker.moduleKey(self.moduleName)) |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
106 | ) |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
107 | else: |
10729
b9fdc104f98a
Code Style Checker, Name Ordering:
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10439
diff
changeset
|
108 | m = self.moduleName.replace("_", " ") |
b9fdc104f98a
Code Style Checker, Name Ordering:
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
10439
diff
changeset
|
109 | # sort '__' before '_' before other characters |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
110 | dotIndex = m.find(".") |
9480
107aca8932ac
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9479
diff
changeset
|
111 | topName = "." * level + (m if dotIndex == -1 else m[:dotIndex]) |
107aca8932ac
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9479
diff
changeset
|
112 | level = -level |
9478
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
113 | |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
114 | if sortIgnoringStyle: |
9478
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
115 | self.sorter = ( |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
116 | group, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
117 | level, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
118 | checker.moduleKey(topName), |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
119 | self.nodeType, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
120 | m, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
121 | ) |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
122 | elif sortFromFirst: |
9478
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
123 | self.sorter = ( |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
124 | group, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
125 | level, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
126 | -self.nodeType, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
127 | checker.moduleKey(topName), |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
128 | m, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
129 | ) |
9477
903ee653bf23
Changed the imports style checker to be in sync with some isort options.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9473
diff
changeset
|
130 | else: |
9478
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
131 | self.sorter = ( |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
132 | group, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
133 | level, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
134 | self.nodeType, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
135 | checker.moduleKey(topName), |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
136 | m, |
634062017057
Corrected the module sort order in the imports style checker.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9477
diff
changeset
|
137 | ) |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
138 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
139 | def __eq__(self, other): |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
140 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
141 | Special method implementing the equality operator. |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
142 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
143 | @param other reference to the object to compare |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
144 | @type ImportNode |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
145 | @return flag indicating equality |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
146 | @rtype bool |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
147 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
148 | return self.sorter == other.sorter |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
149 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
150 | def __lt__(self, other): |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
151 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
152 | Special method implementing the less than operator. |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
153 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
154 | @param other reference to the object to compare |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
155 | @type ImportNode |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
156 | @return flag indicating a less than situation |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
157 | @rtype bool |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
158 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
159 | return self.sorter < other.sorter |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
160 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
161 | def __str__(self): |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
162 | """ |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
163 | Special method to create a string representation of the instance. |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
164 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
165 | @return string representation of the instance |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
166 | @rtype str |
9272
06ed98a19b79
Changed some exception names to comply with PEP-8.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9221
diff
changeset
|
167 | @exception ImportNodeError raised to indicate an invalid node was |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
168 | given to this class |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
169 | """ |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
170 | if self.nodeType not in (NodeTypeEnum.IMPORT, NodeTypeEnum.IMPORT_FROM): |
9272
06ed98a19b79
Changed some exception names to comply with PEP-8.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9221
diff
changeset
|
171 | raise ImportNodeError( |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
172 | "The node type {0} is not recognized.".format(self.nodeType) |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
173 | ) |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
174 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
175 | if self.nodeType == NodeTypeEnum.IMPORT: |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
176 | return "import {0}".format(self.moduleName) |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
177 | elif self.nodeType == NodeTypeEnum.IMPORT_FROM: |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
178 | level = self.node.level |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
179 | levelStr = "" if level == 0 else "." * level |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
180 | names = [ |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
181 | n.name + ("" if n.asname is None else " as {0}".format(n.asname)) |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
182 | for n in self.node.names |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
183 | ] |
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
184 | return "from {0}{1} import {2}".format( |
9221
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
185 | levelStr, self.moduleName, ", ".join(names) |
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
186 | ) |
bf71ee032bb4
Reformatted the source code using the 'Black' utility.
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
9209
diff
changeset
|
187 | |
8802
129a973fc33e
Continued implementing a checker for import statements (import order).
Detlev Offenbach <detlev@die-offenbachs.de>
parents:
diff
changeset
|
188 | return None |