Uh oh!
There was an error while loading. Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork 34k
Closed as not planned
Labels
buildThe build process and cross-buildThe build process and cross-buildextension-modulesC modules in the Modules dirC modules in the Modules dirinterpreter-core(Objects, Python, Grammar, and Parser dirs)(Objects, Python, Grammar, and Parser dirs)type-featureA feature request or enhancementA feature request or enhancement
Description
Feature or enhancement
Proposal:
Can we avoid the relative include? They tend to produce problems further down the road. Originally posted by @erlend-aasland in #120894 (comment)
There are few more examples:
$ git grep '#include .*\.\.\/' Include/internal/mimalloc/mimalloc/track.h:#include "../src/prim/windows/etw.h" Modules/_blake2/blake2b_impl.c:#include "../hashlib.h" Modules/_blake2/blake2s_impl.c:#include "../hashlib.h" Modules/_ctypes/callproc.c:#include "../_complex.h" // complex Modules/_hacl/internal/Hacl_Hash_MD5.h:#include "../Hacl_Hash_MD5.h" Modules/_hacl/internal/Hacl_Hash_SHA1.h:#include "../Hacl_Hash_SHA1.h" Modules/_hacl/internal/Hacl_Hash_SHA2.h:#include "../Hacl_Hash_SHA2.h" Modules/_hacl/internal/Hacl_Hash_SHA3.h:#include "../Hacl_Hash_SHA3.h" Modules/_ssl/cert.c:#include "../_ssl.h" Modules/_ssl/misc.c:#include "../_ssl.h" Modules/_testinternalcapi/set.c:#include "../_testcapi/util.h" // NULLABLE, RETURN_INT Objects/mimalloc/prim/osx/prim.c:#include "../unix/prim.c" Parser/lexer/lexer.c:#include "../tokenizer/helpers.h" Parser/tokenizer/file_tokenizer.c:#include "../lexer/state.h" Parser/tokenizer/file_tokenizer.c:#include "../lexer/lexer.h" Parser/tokenizer/file_tokenizer.c:#include "../lexer/buffer.h" Parser/tokenizer/helpers.c:#include "../lexer/state.h" Parser/tokenizer/helpers.h:#include "../lexer/state.h" Parser/tokenizer/readline_tokenizer.c:#include "../lexer/lexer.h" Parser/tokenizer/readline_tokenizer.c:#include "../lexer/state.h" Parser/tokenizer/readline_tokenizer.c:#include "../lexer/buffer.h" Parser/tokenizer/string_tokenizer.c:#include "../lexer/state.h" Parser/tokenizer/utf8_tokenizer.c:#include "../lexer/state.h" Python/Python-tokenize.c:#include "../Parser/lexer/state.h" Python/Python-tokenize.c:#include "../Parser/lexer/lexer.h" Python/Python-tokenize.c:#include "../Parser/tokenizer/tokenizer.h" Python/Python-tokenize.c:#include "../Parser/pegen.h" // _PyPegen_byte_offset_to_character_offset() Has this already been discussed elsewhere?
This is a minor feature, which does not need previous discussion elsewhere
Links to previous discussion of this feature:
No response
Metadata
Metadata
Assignees
Labels
buildThe build process and cross-buildThe build process and cross-buildextension-modulesC modules in the Modules dirC modules in the Modules dirinterpreter-core(Objects, Python, Grammar, and Parser dirs)(Objects, Python, Grammar, and Parser dirs)type-featureA feature request or enhancementA feature request or enhancement