summary refs log tree commit diff stats
path: root/examples/htmltitle.nim
diff options
context:
space:
mode:
authorReimer Behrends <behrends@gmail.com>2015-12-15 13:33:38 +0100
committerReimer Behrends <behrends@gmail.com>2015-12-15 13:33:38 +0100
commitf664c576c2aab2b2d7f72693bff5a106eb6ef794 (patch)
tree0aaa71241b53117849f1454996ad35aae75ac71d /examples/htmltitle.nim
parent31ebb11d73f7ad58afc497f20d9723503b83ca75 (diff)
downloadNim-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 'examples/htmltitle.nim')
0 files changed, 0 insertions, 0 deletions