libSBML Python API  5.18.0
libsbml.SBMLValidator Class Reference
Inheritance diagram for libsbml.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

def __init__ (self, args)
 This method has multiple variants; they differ in the arguments they accept. More...
 
def clearFailures (self)
 Clears this validator's list of failures. More...
 
def clone (self)
 Creates and returns a deep copy of this SBMLValidator object. More...
 
def getDocument (self, args)
 Returns the current SBML document in use by this validator. More...
 
def getErrorLog (self)
 Returns the list of errors or warnings logged during parsing, consistency checking, or attempted translation of this model. More...
 
def getFailure (self, n)
 Returns the failure object at index n in this validator's list of failures logged during the last run. More...
 
def getModel (self, args)
 Returns the Model object stored in the SBMLDocument. More...
 
def getNumFailures (self)
 Returns the number of failures encountered in the last validation run. More...
 
def logFailure (self, err)
 Adds the given failure to this list of Validators failures. More...
 
def setDocument (self, doc)
 Sets the current SBML document to the given SBMLDocument object. More...
 
def validate (self, args)
 This method has multiple variants; they differ in the arguments they accept. More...
 

Constructor & Destructor Documentation

def libsbml.SBMLValidator.__init__ (   self,
  args 
)

This method has multiple variants; they differ in the arguments they accept.

__init__()   SBMLValidator
__init__(SBMLValidator orig)   SBMLValidator

Each variant is described separately below.


Method variant with the following signature:
SBMLValidator()

Creates a new SBMLValidator.


Method variant with the following signature:
SBMLValidator(SBMLValidator orig)

Copy constructor; creates a copy of an SBMLValidator object.

Parameters
origthe object to copy.

Member Function Documentation

def libsbml.SBMLValidator.clearFailures (   self)

Clears this validator's list of failures.

clearFailures()

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.

def libsbml.SBMLValidator.clone (   self)

Creates and returns a deep copy of this SBMLValidator object.

clone()   SBMLValidator
Returns
the (deep) copy of this SBMLValidator object.
def libsbml.SBMLValidator.getDocument (   self,
  args 
)

Returns the current SBML document in use by this validator.

getDocument()   SBMLDocument
Returns
the current SBML document.
See also
setDocument()
def libsbml.SBMLValidator.getErrorLog (   self)

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

getErrorLog()   SBMLErrorLog

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.
def libsbml.SBMLValidator.getFailure (   self,
  n 
)

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

getFailure(long  n)   SBMLError

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()
def libsbml.SBMLValidator.getModel (   self,
  args 
)

Returns the Model object stored in the SBMLDocument.

getModel()   Model

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 None if a model does not yet exist.

Returns
the Model contained in this validator's SBMLDocument object.
See also
SBMLDocument.setModel()
SBMLDocument.createModel()
def libsbml.SBMLValidator.getNumFailures (   self)

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

getNumFailures()   long

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.
def libsbml.SBMLValidator.logFailure (   self,
  err 
)

Adds the given failure to this list of Validators failures.

logFailure(SBMLError err)
Parameters
erran SBMLError object representing an error or warning.
def libsbml.SBMLValidator.setDocument (   self,
  doc 
)

Sets the current SBML document to the given SBMLDocument object.

setDocument(SBMLDocument doc)   int
Parameters
docthe document to use for this validation.
Returns
integer value indicating success/failure of the function. This particular function only does one thing irrespective of user input or object state, and thus will only return a single value:
See also
getDocument()
def libsbml.SBMLValidator.validate (   self,
  args 
)

This method has multiple variants; they differ in the arguments they accept.

validate()   long 
validate(SBMLDocument d)   long 
validate(string filename)   long

Each variant is described separately below.


Method variant with the following signature:
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().

Method variant with the following signature:
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.

Method variant with the following signature:
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().