/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ /* $Rev$ $Date$ */ #ifndef _XSDHELPER_H_ #define _XSDHELPER_H_ #include "commonj/sdo/export.h" #include "commonj/sdo/RefCountingObject.h" #include "commonj/sdo/DataFactory.h" #include "commonj/sdo/TypeDefinitions.h" namespace commonj { namespace sdo { /** * * XSDHelper provides the means of loading and saving XSD information * from/to the metadata (Types and properties) */ class XSDHelper : public RefCountingObject { public: /** define builds types/properties from file or stream * * define/defineFile * * Populates the data factory with Types and Properties from the schema * Loads from file, stream or char* buffer. * The return value is the URI of the root Type * */ SDO_API virtual const char* defineFile(const char* schemaFile) = 0; SDO_API virtual const char* defineFile(const SDOString& schemaFile) = 0; SDO_API virtual const char* define(std::istream& schema) = 0; SDO_API virtual const char* define(const char* schema) = 0; SDO_API virtual const char* define(const SDOString& schema) = 0; /** generate buildsXSD from types/properties * * generate/generateFile * * Saves the types/properties to an XSD stream or file * */ SDO_API virtual char* generate( const TypeList& types, const char* targetNamespaceURI = "", int indent = -1) = 0; SDO_API virtual char* generate( const TypeList& types, const SDOString& targetNamespaceURI = "", int indent = -1) = 0; SDO_API virtual void generate( const TypeList& types, std::ostream& outXsd, const char* targetNamespaceURI = "", int indent = -1) = 0; SDO_API virtual void generate( const TypeList& types, std::ostream& outXsd, const SDOString& targetNamespaceURI = "", int indent = -1) = 0; SDO_API virtual void generateFile( const TypeList& types, const char* fileName, const char* targetNamespaceURI = "", int indent = -1) = 0; SDO_API virtual void generateFile( const TypeList& types, const SDOString& fileName, const SDOString& targetNamespaceURI = "", int indent = -1) = 0; /***********************************/ /* Destructor */ /***********************************/ SDO_API virtual ~XSDHelper(); /** getDataFactory() * * Return the DataFactory */ SDO_API virtual DataFactoryPtr getDataFactory() = 0; /** getRootTypeURI * * Return the URI for the root Type */ SDO_API virtual const char* getRootTypeURI() = 0; /** getErrorCount gets number of parse errors * * Parser error count - the parse may have * succeeded or partially succeeded or failed. There * may be errors to report or handle. */ virtual unsigned int getErrorCount() const = 0; /** getErrorMessage gets the nth error message * * Each error has a message, usually giving the line and file * in which the parser error occurred. */ virtual const char* getErrorMessage(unsigned int errnum) const = 0; }; }//End - namespace sdo } // End - namespace commonj #endif //_XSDHELPER_H_