diff options
author | Boris Kolpackov <boris@codesynthesis.com> | 2014-01-17 12:49:09 +0200 |
---|---|---|
committer | Boris Kolpackov <boris@codesynthesis.com> | 2014-01-17 12:49:09 +0200 |
commit | 5ae3932141c79e9240a34465b2608385275f2db5 (patch) | |
tree | 810529e92a6c057988f1f89c175b7ce7c15bef1d /odb/context.cxx | |
parent | a680c33b7b15c4da6780b98a9fba6e4f09ba656f (diff) |
Handle query column exporting for composite value types
A composite value is represented in query_columns as a nested struct.
Even though the query_columns template instantiation is exported, VC++
for some reason doesn't appear to also export the nested structs. To
work around this, nested structs have to have the export macro in the
declaration. But that's not it: we also have to declare the nested
structs extern, just like the outer template instantiation itself.
Diffstat (limited to 'odb/context.cxx')
-rw-r--r-- | odb/context.cxx | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/odb/context.cxx b/odb/context.cxx index 352cb51..ef6ef9c 100644 --- a/odb/context.cxx +++ b/odb/context.cxx @@ -2345,14 +2345,14 @@ strlit (string const& str) } void context:: -inst_header (bool decl) +inst_header (bool decl, bool omit_exp) { if (decl && !ext.empty ()) os << ext << " "; os << "template struct"; - if (!exp.empty ()) + if (!omit_exp && !exp.empty ()) { // If we are generating an explicit instantiation directive rather // than the extern template declaration, then omit the export symbol |