//
// This software is copyright (c) 2006 Scott Wood <scott@buserror.net>.
//
-// Permission is hereby granted, free of charge, to any person obtaining a copy of
-// this software and associated documentation files (the "Software"), to deal with
-// the Software without restriction, including without limitation the rights to
-// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
-// of the Software, and to permit persons to whom the Software is furnished to do
-// so, subject to the following condition:
+// This software is provided 'as-is', without any express or implied warranty.
+// In no event will the authors or contributors be held liable for any damages
+// arising from the use of this software.
//
-// The above copyright notice and this permission notice shall be
-// included in all copies or substantial portions of the Software.
-//
-// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
-// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-// CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS WITH THE
-// SOFTWARE.
+// Permission is hereby granted to everyone, free of charge, to use, copy,
+// modify, prepare derivative works of, publish, distribute, perform,
+// sublicense, and/or sell copies of the Software, provided that the above
+// copyright notice and disclaimer of warranty be included in all copies or
+// substantial portions of this software.
// FIXME: escape C++ reserved words
throw UserError();
}
- file << "// " << *ns->get_fq_name()->flatten(".")
+ file << "// " << *ns->get_fq_name()->flatten()
<< "\n// This is a C++ language binding generated by idlc.\n"
<< "// Do not modify this file directly.\n\n";
cpp_output_name(file, t);
if (array)
- file << ">";
+ file << ", ::System::RunTime::ORBMM>";
file << ' ';
}
}
if (is_array(t))
- file << '>';
+ file << ", ::System::RunTime::ORBMM>";
file << ' ';
}
const unsigned char *guid = reinterpret_cast<const unsigned char *>(guid64);
char guidhex[7];
- file << indent << "static const __attribute__((unused)) union {\n"
- << indent << "\tunsigned char c[16];\n"
- << indent << "\tunsigned long l[];\n"
- << indent << "} _guid = {\n"
+ file << indent << "__attribute__((weak))\n"
+ << indent << "::System::RunTime::GUID _guid = {\n"
<< indent << "\t{ ";
for (int i = 0; i < 16; i++) {
do_extra_newline = true;
}
-void CPPFile::output_nsdecl(NameSpace *ns, nsdecl_callback cb)
+void CPPFile::output_nsdecl_begin(NameSpace *ns)
{
// If indent level is not zero, this is a nested struct or interface.
if (indent.indent_level == 0)
file << indent << "namespace " << **ns->name << "_ns {\n";
downscope();
+}
- if (cb)
- cb(this, ns);
-
+void CPPFile::output_nsdecl_children(NameSpace *ns)
+{
for (NameSpace::const_iterator i = ns->begin(); i != ns->end(); ++i) {
Symbol *sym = (*i).second;
output_pass(sym, trav_forward);
output_pass(sym, trav_nsdecl);
}
-
+}
+
+void CPPFile::output_nsdecl_end(NameSpace *ns)
+{
upscope();
file << indent << "}\n";
ns_out(ns);
}
+void CPPFile::output_nsdecl(NameSpace *ns)
+{
+ output_nsdecl_begin(ns);
+ output_nsdecl_children(ns);
+ output_nsdecl_end(ns);
+}
+
void CPPFile::output_aliases_and_types(NameSpace *ns)
{
for (NameSpace::const_iterator i = ns->begin(); i != ns->end(); ++i) {
}
}
-void CPPFile::output_vstruct_ns(CPPFile *cpp, NameSpace *sym)
-{
- Struct *str = dynamic_cast<Struct *>(sym);
- assert(str);
- assert(str->is_virtual());
-
- cpp->output_guid(str->def.guid);
-}
-
void CPPFile::output_vstruct_info(Struct *sym)
{
all_ns_in(sym, true, "VINFO_");
- file << indent << "static const __attribute__((unused)) "
- "unsigned long *const _guids[] = {\n";
+ file << indent << "__attribute__((weak)) "
+ "unsigned long * _guids[] = {\n";
stack<StructRef> supers;
sym->chainlen = 0;
}
file << indent << "};\n\n"
- << indent << "static const __attribute__((unused)) "
+ << indent << "__attribute__((weak)) "
"::System::RunTime::VStructInfo _info = {\n"
- << indent << "\t_guids, " << sym->chainlen << '\n'
+ << indent << "\t_guids, " << sym->chainlen << ",\n"
+// << indent << "\t_marshall, _unmarshall,\n"
<< indent << "};\n";
if (super)
file << '\n'
- << indent << "static " << name << " *downcast(::System::VStruct *base)\n"
+ << indent << "static __attribute__((weak)) " << name << " *downcast(::System::VStruct *base)\n"
<< indent << "{\n"
<< indent << "\tif (!base)\n"
<< indent << "\t\treturn NULL;\n\n"
switch (pass) {
case trav_nsdecl:
if (sym->is_virtual()) {
- output_nsdecl(sym, output_vstruct_ns);
+ output_nsdecl_begin(sym);
+ output_nsdecl_children(sym);
+ output_guid(sym->def.guid);
+ output_marshall_pass(sym, trav_nsdecl);
+ output_nsdecl_end(sym);
} else {
- output_nsdecl(sym);
+ output_nsdecl_begin(sym);
+ output_nsdecl_children(sym);
+ output_marshall_pass(sym, trav_nsdecl);
+ output_nsdecl_end(sym);
}
break;
if (sym->is_virtual())
output_struct_ctor(sym, true);
}
+
+ output_marshall_pass(sym, trav_full);
upscope();
file << indent << "};\n";
break;
}
+
+ case trav_marshall:
+ output_marshall(sym, static_cast<Datum *>(arg2));
+ break;
default:
BUG();
}
}
-void CPPFile::output_iface_ns(CPPFile *file, NameSpace *sym)
-{
- Interface *i = dynamic_cast<Interface *>(sym);
- assert(i);
-
- file->output_guid(i->def.guid);
-}
-
void CPPFile::output(Interface *sym, int pass, void *arg2)
{
switch (pass) {
case trav_nsdecl:
- output_nsdecl(sym, output_iface_ns);
+ output_nsdecl_begin(sym);
+ output_nsdecl_children(sym);
+
+ output_guid(sym->def.guid);
+ output_ifaceinfo(sym);
+
+ output_nsdecl_end(sym);
break;
case trav_forward: {
}
break;
+
+ case trav_marshall:
+ output_marshall(sym, static_cast<Datum *>(arg2));
+ break;
default:
BUG();
break;
}
+ case trav_marshall:
+ output_marshall(sym, static_cast<Datum *>(arg2));
+ break;
+
default:
BUG();
}
output_pass(sym, trav_forward);
break;
+ case trav_marshall:
+ output_marshall(sym, static_cast<Datum *>(arg2));
+ break;
+
default:
BUG();
}
output_pass(sym, trav_forward);
break;
+ case trav_marshall:
+ output_marshall(sym, static_cast<Datum *>(arg2));
+ break;
+
default:
BUG();
}