dods.dap.Server
Interface SubClause

All Superinterfaces:
Clause
All Known Implementing Classes:
BTFunctionClause, DereferenceClause, ValueClause

public interface SubClause
extends Clause

Represents a sub-clause of the selection portion of a constraint expression. A sub-clause is any part of a constraint that can be evaluated to a BaseType value. For instance, the constraint "var1>=function(var2,var3)" would have sub clauses "var1" and "function(var2,var3)". The latter would in turn have the sub-clauses "var2" and "var3".

A given instance of SubClause may change the value it returns when evaluated multiple times, but should not change the class of BaseType it returns. This allows function and operator clauses to do type-checking using the getValue() method. The parser supports several kinds of sub-clause. These are described in the ClauseFactory interface.

Author:
joew
See Also:
for more about the parsing of clauses., for an explanation of how Clauses are evaluated on data., ClauseFactory

Method Summary
 dods.dap.BaseType evaluate()
          Evaluates the clause, first calling evaluate() on any sub-clauses it contains.
 Clause getParent()
          Returns the Clause which contains this subclause.
 dods.dap.BaseType getValue()
          Returns a BaseType containing the current value of the sub-clause.
 void setParent(Clause parent)
          Sets the parent of this subclause.
 
Methods inherited from interface dods.dap.Server.Clause
getChildren, isConstant, isDefined
 

Method Detail

getParent

Clause getParent()
Returns the Clause which contains this subclause. The clause returned may be a TopLevelClause or another SubClause.


getValue

dods.dap.BaseType getValue()
Returns a BaseType containing the current value of the sub-clause. Sub-clauses that are not constant have an undefined value until the evaluate() method has been called. However, in such circumstances this method is still useful, as it indicates which class of BaseType the sub-clause will evaluate to. Implementations of this method should never return null.


evaluate

dods.dap.BaseType evaluate()
                           throws SDODSException
Evaluates the clause, first calling evaluate() on any sub-clauses it contains. Implementations of this method should flag the clause as "defined" if the evaluation is successful.

Throws:
SDODSException - Thrown if the evaluation fails for any reason.

setParent

void setParent(Clause parent)
Sets the parent of this subclause. Used during parsing.