| 12
 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
 |