| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectdods.dap.Server.CEEvaluator
public class CEEvaluator
This class is used to parse and evaluate a constraint expression. When constructed it must be passed a valid DDS along with the expression. This DDS will be used as the environment (collection of variables and functions) during the parse and evaluation of the constraint expression.
A server (servlet, CGI, ...) must first instantiate the DDS (possibly reading it from a cache) and then create and instance of this class. Once created, the constraint may be parsed and then evaluated. The class supports sending data based on the results of CE evaluation. That is, the send() method of the class combines both the evaluation of the constraint and the output of data values so that the server can return data using a single method call.
Custom parsing The CEEvaluator parses constraint expressions into Clause objects using a ClauseFactory. Customized behavior during parsing can be achieved by passing a customized ClauseFactory into the CEEvaluator.
Support for server side functions Server side functions are supported via the FunctionLibrary class. Custom server side function support is achieved by using a customized ClauseFactory which in turn contains a customized FunctionLibrary.
More details are found in the documentation for the respective classes.
ServerDDS, 
ServerMethods, 
ClauseFactory, 
FunctionLibrary, 
Clause| Constructor Summary | |
|---|---|
| CEEvaluator(ServerDDS dds)Construct a new CEEvaluatorwithddsas the
        DDS object with which to resolve all variable and function names. | |
| CEEvaluator(ServerDDS dds,
            ClauseFactory clauseFactory)Construct a new CEEvaluatorwithddsas the
        DDS object with which to resolve all variable and function names, andclauseFactoryas a source of Clause objects . | |
| Method Summary | |
|---|---|
|  void | appendClause(Clause c)Add a clause to the constraint expression. | 
|  boolean | evalClauses(Object specialO)Evaluate all of the Clauses in the Clause vector. | 
|  Enumeration | getClauses()Get access to the list of clauses built by parsing the selection part of the constraint expression. | 
|  ServerDDS | getDDS()Return a reference to the CEEvaluator's DDS object. | 
|  void | markAll(boolean state)Mark all the variables in the DDS either as part of the current projection (when stateis true) or not
        (stateis false). | 
|  void | parseConstraint(String expression)Parse a constraint expression. | 
|  boolean | removeClause(Clause c)Remove a clause from the constraint expression. | 
|  void | send(String dataset,
     OutputStream sink,
     Object specialO)This function sends the variables described in the constrained DDS to the output described by sink. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
public CEEvaluator(ServerDDS dds)
CEEvaluator with dds as the
        DDS object with which to resolve all variable and function names.
dds - DDS object describing the dataset targeted by this
        constraint.
public CEEvaluator(ServerDDS dds,
                   ClauseFactory clauseFactory)
CEEvaluator with dds as the
        DDS object with which to resolve all variable and function names, and
        clauseFactory as a source of Clause objects .
clauseFactory - The factory which will be used by the parser to construct the clause
        tree. This allows servers to pass in a factory which creates
        custom clause objects.dds - DDS object describing the dataset targeted by this
        constraint. 
        author Joe Wielgosz (joew@cola.iges.org)| Method Detail | 
|---|
public ServerDDS getDDS()
public void parseConstraint(String expression)
                     throws ParseException,
                            dods.dap.DODSException,
                            dods.dap.NoSuchVariableException,
                            dods.dap.NoSuchFunctionException,
                            InvalidOperatorException,
                            InvalidParameterException,
                            SBHException,
                            WrongTypeException
The parser is located in dods.dap.parser.ExprParser.
expression - The constraint expression to parse.
ParseException
dods.dap.NoSuchVariableException
dods.dap.NoSuchFunctionException
InvalidOperatorException
InvalidParameterException
SBHException
dods.dap.DODSException
WrongTypeExceptionpublic void appendClause(Clause c)
c - The Clause to append.public boolean removeClause(Clause c)
c - The Clause to append.
public final Enumeration getClauses()
NB: This is not valid until the CE has been parsed!
public void send(String dataset,
                 OutputStream sink,
                 Object specialO)
          throws dods.dap.NoSuchVariableException,
                 SDODSException,
                 IOException
sink. This function calls
 parse_constraint(), BaseType::read(), and
 ServerIO::serialize().
dataset - The name of the dataset to send.sink - A pointer to the output buffer for the data.specialO - Not sure - special object?
dods.dap.NoSuchVariableException
SDODSException
IOExceptionparseConstraint(String), 
ServerMethods.serialize()
public boolean evalClauses(Object specialO)
                    throws dods.dap.NoSuchVariableException,
                           SDODSException,
                           IOException
specialO - That special Object that can be passed down 
 through the DDS.send() method.
dods.dap.NoSuchVariableException
SDODSException
IOException
public void markAll(boolean state)
             throws InvalidParameterException,
                    dods.dap.NoSuchVariableException,
                    SBHException
state is true) or not
        (state is false). This is a convenience function that
        provides a way to clear or set an entire dataset described by a DDS
        with respect to its projection.
state - true if the variables should all be projected, false is
        no variable should be projected.
InvalidParameterException
dods.dap.NoSuchVariableException
SBHException| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||