AW: [xsd-users] abstract type and its c++ equivalent

Klima Georg G.Klima at durst-online.at
Tue Apr 23 11:38:10 EDT 2013


Hi Boris,

Thank you for the fast response!

>> I'm having troubles understanding why an abstract schema type isn't 
>> mapped to an abstract / pure virtual / not instantiable class type in 
>> c++?
>
>It is not a good idea to add a pure virtual function (e.g., d-tor) to class that is otherwise non-polymorphic. That would result in code bloat. However, I don't see any harm in making all its c-tors >protected so that they are inaccessible from user code. I've added this item to the TODO list for the next release.
>
>
>> My motivation for this problem is that I'm implementing a visitor 
>> pattern and so can't implement pure virtual functions within classes 
>> of schema abstract types.
>
>I don't see why this is a problem. Just leave the "visiting" functions for abstract types as pure virtual?

Doing so, it didn't compile because of the new/instantiation in the clone function of the "abstract" base type.
But also it may have been caused by another fault of mine too, I forgot to set --polymorphic-type-all!!!

What brings me to another very strange problem:
Setting --polymorphic-type-all enables me what I want to do, implement an intrinsic visitor (accept methods "patched" into the generated code, by sort of aspect oriented programming - introduction).
But even with the clean unmodified/un-patched  code I do get an error:

XAlignDescriptorSimpleFrameSample.xml
terminate called after throwing an instance of 'xsd::cxx::tree::no_type_info<char>'
  what():  no type information available for a type

if I just do this:

#include <memory>   // std::auto_ptr
#include <iostream>
//#include <typeinfo>

#include "XAlignDescriptor.hxx"

int main(int argc, char **argv) {

	std::cout << argv[1] << std::endl;
	std::auto_ptr<DPrnCal::patternDescriptor_at> pd(DPrnCal::PatternDefinition(argv[1])); //<-- exception happens here
//	void* i = dynamic_cast<DPrnCal::xalignDescriptor_vt*>(pd.get());

	std::cout << "Done." << std::endl;
	return 0;
}

Removing the comment from the rtti code, that in effect (at least for this main method) does nothing:

#include <memory>   // std::auto_ptr
#include <iostream>
#include <typeinfo>

#include "XAlignDescriptor.hxx"

int main(int argc, char **argv) {

	std::cout << argv[1] << std::endl;
	std::auto_ptr<DPrnCal::patternDescriptor_at> pd(DPrnCal::PatternDefinition(argv[1]));
	void* i = dynamic_cast<DPrnCal::xalignDescriptor_vt*>(pd.get());

	std::cout << "Done." << std::endl;
	return 0;
}

It works with following output:

XAlignDescriptorSimpleFrameSample.xml
Done.

And the pointer i is valid if printed out!


The exception gets thrown in type-factory-map.txx line 401


And I don't understand this behaviour. The only thing I can think of is an initialisation problem concerning the RTTI and derived code!

If you need more info I could send you the schema + xml test files directly, including the xsd parameters used.......

Xsd version: 3.3.0
Xerces version: 3.1.1

Thanks
Georg




More information about the xsd-users mailing list