|
Parsnip
parsing library
|
Schema adapter component that allows use of schemas from option parsers. More...
#include <parsnip_schema.h>
Public Member Functions | |
| OptionSchema ()=default | |
| Validate a type schema: ensure the datatype is as expected. | |
| OptionSchema (const OptionSchema &)=default | |
| OptionSchema (OptionSchema &&)=default | |
| OptionSchema & | operator= (const OptionSchema &)=default |
| OptionSchema & | operator= (OptionSchema &&)=default |
| OptionSchema (const SchemaRef &option_schema) | |
| Construct a new option schema. | |
| virtual OptionSchema * | createCopy () const override |
| Create an identical, deep copy of the schema. | |
| virtual void | validate (const Parsnip::Data &entry) const override |
| Validate the option's schema by calling that scheme's validator. | |
| virtual bool | operator== (const SchemaBase &other) const override |
| Check if two schemas perform the same validation. | |
| virtual void | mergeSchemas (const SchemaBase &from) override |
| Merge elements into the current schema. | |
| virtual std::ostream & | dump (std::ostream &target, int indent, bool suppress_ident=false) const override |
| Render the schema in human-friendly text. | |
Public Member Functions inherited from Parsnip::SchemaBase | |
| bool | operator!= (const SchemaBase &other) const |
Additional Inherited Members | |
Protected Types inherited from Parsnip::SchemaBase | |
| using | StringType = Data::StringType |
| using | SchemaRegex = std::basic_regex< StringType::value_type > |
Protected Member Functions inherited from Parsnip::SchemaBase | |
| SchemaBase (const SchemaBase &)=default | |
| SchemaBase (SchemaBase &&)=default | |
| SchemaBase & | operator= (const SchemaBase &)=default |
| SchemaBase & | operator= (SchemaBase &&)=default |
| SchemaBase (const Parsnip::Data &schema_spec) | |
| Construct a schema from a JSON specification. | |
| void | checkType (Data::Type expected, const Parsnip::Data &entry) const |
| Check that Data item is an allowed type. | |
| bool | isValidlyNull (const Parsnip::Data &entry) const |
| Determine if the data is Null and if that is allowed. | |
| bool | isType (Data::Type expected, const Parsnip::Data &entry) const |
| Check if a data object is a particular type. | |
Protected Attributes inherited from Parsnip::SchemaBase | |
| bool | nullable = false |
If true, element may be null. | |
Schema adapter component that allows use of schemas from option parsers.
|
overridevirtual |
Create an identical, deep copy of the schema.
Caller is responsible for deleting it.
Implements Parsnip::SchemaBase.
|
overridevirtual |
Render the schema in human-friendly text.
| target | Where to write the schema. |
| indent | Amount of indent to use. |
| suppress_indent | Flag indicating indent was already performed. |
Implements Parsnip::SchemaBase.
|
overridevirtual |
Merge elements into the current schema.
Merge elements managed by this class.
| from | A schema for a valid command command line. |
| Various | exceptions. |
Reimplemented from Parsnip::SchemaBase.
|
overridevirtual |
Check if two schemas perform the same validation.
Compare two schemas to see if they determine validity in the same manner.
| other | The schema to compare to. |
Reimplemented from Parsnip::SchemaBase.
|
overridevirtual |
Validate the option's schema by calling that scheme's validator.
Implements Parsnip::SchemaBase.