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))\n"
+ file << indent << "__attribute__((weak))\n"
<< indent << "::System::RunTime::GUID _guid = {\n"
<< indent << "\t{ ";
{
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"
-#if 0
- << indent << "\t_marshall, _unmarshall,\n"
-#endif
+// << 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"
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();
}
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();
}