1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
|
// file : xsd-frontend/transformations/schema-per-type.hxx
// copyright : Copyright (c) 2006-2014 Code Synthesis Tools CC
// license : GNU GPL v2 + exceptions; see accompanying LICENSE file
#ifndef XSD_FRONTEND_TRANSFORMATIONS_SCHEMA_PER_TYPE_HXX
#define XSD_FRONTEND_TRANSFORMATIONS_SCHEMA_PER_TYPE_HXX
#include <vector>
#include <xsd-frontend/types.hxx>
#include <xsd-frontend/semantic-graph/elements.hxx> // Path
#include <xsd-frontend/semantic-graph/schema.hxx>
namespace XSDFrontend
{
namespace Transformations
{
class SchemaPerTypeTranslator
{
public:
virtual
~SchemaPerTypeTranslator ();
// The following two functions should return empty string if
// there is no match.
//
virtual String
translate_type (String const& ns, String const& name) = 0;
virtual NarrowString
translate_schema (NarrowString const& abs_path) = 0;
};
// This transformation restructures the semantic graph to have
// each type definition in a seperate schema file.
//
class SchemaPerType
{
public:
struct Failed {};
// If a type of an element or attribute has a context entry
// with the by_value_key key and it is true, then the schema
// for this type is included "strongly".
//
SchemaPerType (SchemaPerTypeTranslator&,
bool fat_type_file,
char const* by_value_key = 0);
std::vector<SemanticGraph::Schema*>
transform (SemanticGraph::Schema&);
private:
bool fat_type_file_;
char const* by_value_key_;
SchemaPerTypeTranslator& trans_;
};
}
}
#endif // XSD_FRONTEND_TRANSFORMATIONS_SCHEMA_PER_TYPE_HXX
|