blob: d226c3c6eaa2154b7c5124d379dab53d2ef60f22 [file] [log] [blame]
/**
* 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.
*/
#ifndef avro_Schema_hh__
#define avro_Schema_hh__
#include "NodeImpl.hh"
/// \file
///
/// Schemas for representing all the avro types. The compound schema objects
/// allow composition from other schemas.
///
namespace avro {
class ValidSchema;
/// The root Schema object is a base class. Nobody constructs this class directly.
class Schema
{
public:
virtual ~Schema();
Type type() const {
return node_->type();
}
const NodePtr &root() const {
return node_;
}
NodePtr &root() {
return node_;
}
protected:
friend void compileJsonSchema(std::istream &is, ValidSchema &schema);
Schema();
explicit Schema(const NodePtr &node);
explicit Schema(Node *node);
NodePtr node_;
};
class NullSchema : public Schema
{
public:
NullSchema(): Schema(new NodePrimitive(AVRO_NULL)) {}
};
class BoolSchema : public Schema
{
public:
BoolSchema(): Schema(new NodePrimitive(AVRO_BOOL)) {}
};
class IntSchema : public Schema
{
public:
IntSchema(): Schema(new NodePrimitive(AVRO_INT)) {}
};
class LongSchema : public Schema
{
public:
LongSchema(): Schema(new NodePrimitive(AVRO_LONG)) {}
};
class FloatSchema : public Schema
{
public:
FloatSchema(): Schema(new NodePrimitive(AVRO_FLOAT)) {}
};
class DoubleSchema : public Schema
{
public:
DoubleSchema(): Schema(new NodePrimitive(AVRO_DOUBLE)) {}
};
class StringSchema : public Schema
{
public:
StringSchema(): Schema(new NodePrimitive(AVRO_STRING)) {}
};
class BytesSchema : public Schema
{
public:
BytesSchema(): Schema(new NodePrimitive(AVRO_BYTES)) {}
};
class RecordSchema : public Schema
{
public:
RecordSchema(const std::string &name);
void addField(const std::string &name, const Schema &fieldSchema);
};
class EnumSchema : public Schema
{
public:
EnumSchema(const std::string &name);
void addSymbol(const std::string &symbol);
};
class ArraySchema : public Schema
{
public:
ArraySchema(const Schema &itemsSchema);
};
class MapSchema : public Schema
{
public:
MapSchema(const Schema &valuesSchema);
};
class UnionSchema : public Schema
{
public:
UnionSchema();
void addType(const Schema &typeSchema);
};
class FixedSchema : public Schema
{
public:
FixedSchema(int size, const std::string &name);
};
} // namespace avro
#endif