circular-dependencies: Avoid treating some .h/.cpp files as a unit
This avoids a bogus circular dependency error in the next commit: interfaces/chain -> interfaces/wallet -> wallet/wallet -> interfaces/chain Which is incorrect, because interfaces/chain.cpp depends only on the interfaces/wallet.h file, not the interfaces/wallet.cpp file, and it is wrong to treat these as a unit. Inside the interfaces directory, .h files contain abstract class definitions and .cpp files contain implementations of those classes, so you don't need to link against .cpp files if you're only using the abstract class definition in the .h file. An alternative fix might be to rename all the cpp files in the interfaces directory like: chain.cpp->chain_impl.cpp, node.cpp->node_impl.cpp. But just getting the linter to treat these files as independent dependencies seemed like it would allow keeping code organization straightforward and avoiding the need to rename things.
This commit is contained in:
parent
d02b34c8a8
commit
318f41fb2c
1 changed files with 9 additions and 0 deletions
|
@ -8,9 +8,18 @@ MAPPING = {
|
||||||
'core_write.cpp': 'core_io.cpp',
|
'core_write.cpp': 'core_io.cpp',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Directories with header-based modules, where the assumption that .cpp files
|
||||||
|
# define functions and variables declared in corresponding .h files is
|
||||||
|
# incorrect.
|
||||||
|
HEADER_MODULE_PATHS = [
|
||||||
|
'interfaces/'
|
||||||
|
]
|
||||||
|
|
||||||
def module_name(path):
|
def module_name(path):
|
||||||
if path in MAPPING:
|
if path in MAPPING:
|
||||||
path = MAPPING[path]
|
path = MAPPING[path]
|
||||||
|
if any(path.startswith(dirpath) for dirpath in HEADER_MODULE_PATHS):
|
||||||
|
return path
|
||||||
if path.endswith(".h"):
|
if path.endswith(".h"):
|
||||||
return path[:-2]
|
return path[:-2]
|
||||||
if path.endswith(".c"):
|
if path.endswith(".c"):
|
||||||
|
|
Loading…
Add table
Reference in a new issue