libSBML C# API  libSBML 5.8.0 C# API
 All Classes Namespaces Files Functions Variables Properties Pages
libsbmlcs.SBMLValidator Class Reference
Inheritance diagram for libsbmlcs.SBMLValidator:
[legend]

Detailed Description

Base class for SBML validators.

This class of objects is defined by libSBML only and has no direct equivalent in terms of SBML components. This class is not prescribed by the SBML specifications, although it is used to implement features defined in SBML.

LibSBML implements facilities for verifying that a given SBML document is valid according to the SBML specifications; it also exposes the validation interface so that user programs and SBML Level 3 package authors may use the facilities to implement new validators. There are two main interfaces to libSBML's validation facilities, based on the classes Validator and SBMLValidator.

The Validator class is the basis of the system for validating an SBML document against the validation rules defined in the SBML specifications. The scheme used by Validator relies is compact and uses the visitor programming pattern, but it relies on C/C++ features and is not directly accessible from language bindings. SBMLValidator offers a framework for straightforward class-based extensibility, so that user code can subclass SBMLValidator to implement new validation systems, different validators can be introduced or turned off at run-time, and interfaces can be provided in the libSBML language bindings. SBMLValidator can call Validator functionality internally (as is the case in the current implementation of SBMLInternalValidator) or use entirely different implementation approaches, as necessary.

Users of libSBML may already be familiar with the facilities encompassed by the validation system, in the form of the consistency-checking methods defined on SBMLDocument. The methods SBMLDocument::setConsistencyChecks(), SBMLDocument::checkConsistency(), SBMLDocument::checkInternalConsistency() and other method of that sort are in fact implemented via SBMLValidator, specifically as methods on the class SBMLInternalValidator.

Authors may use SBMLValidator as the base class for their own validator extensions to libSBML. The class SBMLInternalValidator may serve as a code example for how to implement such things.

Public Member Functions

void clearFailures ()
 Clears this validator's list of failures. More...
 
SBMLValidator clone ()
 Creates and returns a deep copy of this SBMLValidator. More...
 
virtual void Dispose ()
 
SBMLDocument getDocument ()
 Returns the current SBML document in use by this validator. More...
 
SBMLErrorLog getErrorLog ()
 Returns the list of errors or warnings logged during parsing, consistency checking, or attempted translation of this model. More...
 
SBMLError getFailure (long n)
 Returns the failure object at index n in this validator's list of failures logged during the last run. More...
 
Model getModel ()
 Returns the Model object stored in the SBMLDocument. More...
 
long getNumFailures ()
 Returns the number of failures encountered in the last validation run. More...
 
void logFailure (SBMLError err)
 Adds the given failure to this list of Validators failures. More...
 
 SBMLValidator ()
 Creates a new SBMLValidator. More...
 
 SBMLValidator (SBMLValidator orig)
 Copy constructor; creates a copy of an SBMLValidator object. More...
 
int setDocument (SBMLDocument doc)
 Sets the current SBML document to the given SBMLDocument object. More...
 
delegate IntPtr SwigDelegateSBMLValidator_0 ()
 
delegate IntPtr SwigDelegateSBMLValidator_1 ()
 
delegate IntPtr SwigDelegateSBMLValidator_2 ()
 
delegate int SwigDelegateSBMLValidator_3 (IntPtr doc)
 
delegate uint SwigDelegateSBMLValidator_4 ()
 
delegate void SwigDelegateSBMLValidator_5 ()
 
long validate ()
 Runs this validator on the current SBML document. More...
 
long validate (SBMLDocument d)
 Validates the given SBMLDocument object. More...
 
long validate (string filename)
 Validates the SBML document located at the given filename. More...
 

Protected Attributes

bool swigCMemOwn
 

Constructor & Destructor Documentation

libsbmlcs.SBMLValidator.SBMLValidator ( )

Creates a new SBMLValidator.

libsbmlcs.SBMLValidator.SBMLValidator ( SBMLValidator  orig)

Copy constructor; creates a copy of an SBMLValidator object.

Parameters
origthe object to copy.
Exceptions
SBMLConstructorExceptionThrown if the argument orig is null.

Member Function Documentation

void libsbmlcs.SBMLValidator.clearFailures ( )

Clears this validator's list of failures.

If you are validating multiple SBML documents with the same validator, call this method after you have processed the list of failures from the last validation run and before validating the next document.

SBMLValidator libsbmlcs.SBMLValidator.clone ( )

Creates and returns a deep copy of this SBMLValidator.

Returns
a (deep) copy of this SBMLValidator.
virtual void libsbmlcs.SBMLValidator.Dispose ( )
virtual
SBMLDocument libsbmlcs.SBMLValidator.getDocument ( )

Returns the current SBML document in use by this validator.

Returns
the current SBML document
See Also
setDocument()
SBMLErrorLog libsbmlcs.SBMLValidator.getErrorLog ( )

Returns the list of errors or warnings logged during parsing, consistency checking, or attempted translation of this model.

Note that this refers to the SBMLDocument object's error log (i.e., the list returned by SBMLDocument::getErrorLog()). That list of errors and warnings is separate from the validation failures tracked by this validator (i.e., the list returned by getFailures()).

Returns
the SBMLErrorLog used for the SBMLDocument
SBMLError libsbmlcs.SBMLValidator.getFailure ( long  n)

Returns the failure object at index n in this validator's list of failures logged during the last run.

Callers should use getNumFailures() first, to find out the number of entries in this validator's list of failures.

Parameters
nan integer indicating the index of the object to return from the failures list; index values start at 0.
Returns
the failure at the given index number.
See Also
getNumFailures()
Model libsbmlcs.SBMLValidator.getModel ( )

Returns the Model object stored in the SBMLDocument.

It is important to note that this method does not create a Model instance. The model in the SBMLDocument must have been created at some prior time, for example using SBMLDocument::createModel() or SBMLDocument::setModel(). This method returns null if a model does not yet exist.

Returns
the Model contained in this validator's SBMLDocument object.
See Also
SBMLDocument::setModel()
SBMLDocument::createModel()
long libsbmlcs.SBMLValidator.getNumFailures ( )

Returns the number of failures encountered in the last validation run.

This method returns the number of failures logged by this validator. This number only reflects this validator's actions; the number may not be the same as the number of errors and warnings logged on the SBMLDocument object's error log (i.e., the object returned by SBMLDocument::getErrorLog()), because other parts of libSBML may log errors and warnings beyond those found by this validator.

Returns
the number of errors logged by this validator.
void libsbmlcs.SBMLValidator.logFailure ( SBMLError  err)

Adds the given failure to this list of Validators failures.

Parameters
erran SBMLError object representing an error or warning
int libsbmlcs.SBMLValidator.setDocument ( SBMLDocument  doc)

Sets the current SBML document to the given SBMLDocument object.

Parameters
docthe document to use for this validation
Returns
an integer value indicating the success/failure of the validation. The possible values returned by this function are
See Also
getDocument()
delegate IntPtr libsbmlcs.SBMLValidator.SwigDelegateSBMLValidator_0 ( )
delegate IntPtr libsbmlcs.SBMLValidator.SwigDelegateSBMLValidator_1 ( )
delegate IntPtr libsbmlcs.SBMLValidator.SwigDelegateSBMLValidator_2 ( )
delegate int libsbmlcs.SBMLValidator.SwigDelegateSBMLValidator_3 ( IntPtr  doc)
delegate uint libsbmlcs.SBMLValidator.SwigDelegateSBMLValidator_4 ( )
delegate void libsbmlcs.SBMLValidator.SwigDelegateSBMLValidator_5 ( )
long libsbmlcs.SBMLValidator.validate ( )

Runs this validator on the current SBML document.

Returns
an integer value indicating the success/failure of the validation. The possible values returned by this function are determined by the specific subclasses of this class.
long libsbmlcs.SBMLValidator.validate ( SBMLDocument  d)

Validates the given SBMLDocument object.

This is identical to calling setDocument() followed by validate().

Parameters
dthe SBML document to validate
Returns
the number of validation failures that occurred. The objects describing the actual failures can be retrieved using getFailures().
long libsbmlcs.SBMLValidator.validate ( string  filename)

Validates the SBML document located at the given filename.

This is a convenience method that saves callers the trouble of using SBMLReader to read the document first.

Parameters
filenamethe path to the file to be read and validated.
Returns
the number of validation failures that occurred. The objects describing the actual failures can be retrieved using getFailures().

Member Data Documentation

bool libsbmlcs.SBMLValidator.swigCMemOwn
protected