diff options
author | Reimer Behrends <behrends@gmail.com> | 2015-12-15 13:33:38 +0100 |
---|---|---|
committer | Reimer Behrends <behrends@gmail.com> | 2015-12-15 13:33:38 +0100 |
commit | f664c576c2aab2b2d7f72693bff5a106eb6ef794 (patch) | |
tree | 0aaa71241b53117849f1454996ad35aae75ac71d /tests/array/tarray3.nim | |
parent | 31ebb11d73f7ad58afc497f20d9723503b83ca75 (diff) | |
download | Nim-f664c576c2aab2b2d7f72693bff5a106eb6ef794.tar.gz |
Fix code generation issues with TNimType.
This is an alternative attempt to fix issue #2841 in a way that does not rely on non-standard C compiler behavior. The underlying problem is that the typeinfo module includes system/hti.nim, but system/hti.nim is also included by system.nim. The result is that the compiler at any given point has two instances of TNimType with the same external name and will generate code either for one or both of them. Code generation for the second version is normally suppressed by using {.importc.}, but that results in a missing type declaration for modules that only use the second version. This happens for modules that import typeinfo, because the the second component of typeinfo.Any has type PNimType = ptr TNimType, which generates a "TNimType *" struct member. The previous solution was to have a typedef for TNimType in nimbase.h; however, this results in duplicate typedefs (specifically, but not only for the code generated for typeinfo.nim). Duplicate typedefs with the same type name are allowed in C++ and C11, but are explicitly forbidden in C89 and C99. Modern versions of gcc and clang accept them anyway, but this is not standard-compliant and may break for other C compilers or older versions of gcc and clang. This patch attempts to fix the issue by making the second component of typeinfo.Nim a pointer instead of a PNimType and casting back and forth as needed. Thus, the second version of TNimType occurs only within the code for typeinfo.nim, where it can be safely omitted.
Diffstat (limited to 'tests/array/tarray3.nim')
0 files changed, 0 insertions, 0 deletions