X-Git-Url: http://git.buserror.net/cgi-bin/gitweb.cgi?p=polintos%2Fscott%2Fpriv.git;a=blobdiff_plain;f=idlcomp%2Flanguages%2Fc%2B%2B%2Fmain.cc;fp=idlcomp%2Flanguages%2Fc%2B%2B%2Fmain.cc;h=4368bca4d95bbddb9e56ced6a98dad3c490bfbcd;hp=ab4289c596e5c3dee5e3af14e35d0c00e6ef9d47;hb=39d6852ead7a839f9e15e21e517dfd7a795e5cdd;hpb=cc1bee96fd874ff2c85c765f81ec2f4ba4584b9d diff --git a/idlcomp/languages/c++/main.cc b/idlcomp/languages/c++/main.cc index ab4289c..4368bca 100644 --- a/idlcomp/languages/c++/main.cc +++ b/idlcomp/languages/c++/main.cc @@ -52,7 +52,7 @@ dirname(dir) 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"; @@ -640,12 +640,12 @@ void CPPFile::output(Struct *sym, int pass, void *arg2) output_nsdecl_begin(sym); output_nsdecl_children(sym); output_guid(sym->def.guid); - output_marshall(sym, trav_nsdecl); + output_marshall_pass(sym, trav_nsdecl); output_nsdecl_end(sym); } else { output_nsdecl_begin(sym); output_nsdecl_children(sym); - output_marshall(sym, trav_nsdecl); + output_marshall_pass(sym, trav_nsdecl); output_nsdecl_end(sym); } @@ -719,6 +719,8 @@ void CPPFile::output(Struct *sym, int pass, void *arg2) if (sym->is_virtual()) output_struct_ctor(sym, true); } + + output_marshall_pass(sym, trav_full); upscope(); file << indent << "};\n"; @@ -734,6 +736,10 @@ void CPPFile::output(Struct *sym, int pass, void *arg2) break; } + + case trav_marshall: + output_marshall(sym, static_cast(arg2)); + break; default: BUG(); @@ -842,6 +848,10 @@ void CPPFile::output(Interface *sym, int pass, void *arg2) } break; + + case trav_marshall: + output_marshall(sym, static_cast(arg2)); + break; default: BUG(); @@ -992,6 +1002,10 @@ void CPPFile::output(BitField *sym, int pass, void *arg2) break; } + case trav_marshall: + output_marshall(sym, static_cast(arg2)); + break; + default: BUG(); } @@ -1062,6 +1076,10 @@ void CPPFile::output(Enum *sym, int pass, void *arg2) output_pass(sym, trav_forward); break; + case trav_marshall: + output_marshall(sym, static_cast(arg2)); + break; + default: BUG(); } @@ -1099,6 +1117,10 @@ void CPPFile::output(BasicType *sym, int pass, void *arg2) output_pass(sym, trav_forward); break; + case trav_marshall: + output_marshall(sym, static_cast(arg2)); + break; + default: BUG(); }