Class OrderByExpressionImpl
java.lang.Object
org.apache.olingo.odata2.core.uri.expression.OrderByExpressionImpl
- All Implemented Interfaces:
CommonExpression,OrderByExpression,Visitable
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionaccept(ExpressionVisitor visitor) MethodVisitable.accept(ExpressionVisitor)is called when traversing the expression tree.voidaddOrder(OrderExpression orderNode) getKind()intReturns the URI literal which lead to the creation of this expression.setEdmType(EdmType edmType) Set the edmType of this expression node
-
Constructor Details
-
OrderByExpressionImpl
-
-
Method Details
-
getExpressionString
- Specified by:
getExpressionStringin interfaceOrderByExpression- Returns:
- Returns the $filter expression string used to build the expression tree
-
getOrders
- Specified by:
getOrdersin interfaceOrderByExpression- Returns:
- Returns a ordered list of order expressions contained in the $orderby expression string
For example: The orderby expression build from "$orderby=name asc, age desc" would contain to order expression.
-
getOrdersCount
public int getOrdersCount()- Specified by:
getOrdersCountin interfaceOrderByExpression- Returns:
- Returns the count of order expressions contained in the $orderby expression string
-
addOrder
-
getKind
- Specified by:
getKindin interfaceCommonExpression- Returns:
- Kind of this expression
- See Also:
-
getEdmType
- Specified by:
getEdmTypein interfaceCommonExpression- Returns:
- The return type of the value represented with
this expression. For example the
CommonExpression.getEdmType()method for an expression representing the "concat" method will return always "Edm.String".
This type information is set while parsing the $filter or $orderby expressions and used to do a first validation of the expression. For calculating operators like "add, sub, mul" this type information is purely based on input and output types of the operator as defined in the OData specification. So for $filter=2 add 7 the
CommonExpression.getEdmType()method of the binary expression will return Edm.Byte and not Edm.Int16 because the parser performs no real addition.
However, the application may change this type while evaluating the expression tree.
-
setEdmType
Description copied from interface:CommonExpressionSet the edmType of this expression node- Specified by:
setEdmTypein interfaceCommonExpression- Parameters:
edmType- Type to be set- Returns:
- A self reference for method chaining"
-
getUriLiteral
Description copied from interface:CommonExpressionReturns the URI literal which lead to the creation of this expression.- Specified by:
getUriLiteralin interfaceCommonExpression- Returns:
- URI literal
-
accept
public Object accept(ExpressionVisitor visitor) throws ExceptionVisitExpression, ODataApplicationException Description copied from interface:VisitableMethodVisitable.accept(ExpressionVisitor)is called when traversing the expression tree. This method is invoked on each expression used as node in an expression tree. The implementations should behave as follows:- Call accept on all sub nodes and store the returned Objects
- Call the appropriate method on the
ExpressionVisitorinstance and provide the stored objects to that instance- Return the object which should be passed to the processing algorithm of the parent expression node
- Specified by:
acceptin interfaceVisitable- Parameters:
visitor- Object ( implementingExpressionVisitor) whose methods are called during traversing a expression node of the expression tree.- Returns:
- Object which should be passed to the processing algorithm of the parent expression node
- Throws:
ExceptionVisitExpression- Exception occurred the OData library while traversing the treeODataApplicationException- Exception thrown by the application who implemented the visitor
-