KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > caucho > db > sql > DoubleCmpExpr


1 /*
2  * Copyright (c) 1998-2006 Caucho Technology -- all rights reserved
3  *
4  * This file is part of Resin(R) Open Source
5  *
6  * Each copy or derived work must preserve the copyright notice and this
7  * notice unmodified.
8  *
9  * Resin Open Source is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * Resin Open Source is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
17  * of NON-INFRINGEMENT. See the GNU General Public License for more
18  * details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with Resin Open Source; if not, write to the
22  * Free SoftwareFoundation, Inc.
23  * 59 Temple Place, Suite 330
24  * Boston, MA 02111-1307 USA
25  *
26  * @author Scott Ferguson
27  */

28
29 package com.caucho.db.sql;
30
31 import com.caucho.log.Log;
32
33 import java.sql.SQLException JavaDoc;
34 import java.util.ArrayList JavaDoc;
35 import java.util.logging.Logger JavaDoc;
36
37 class DoubleCmpExpr extends Expr {
38   private static final Logger JavaDoc log = Log.open(DoubleCmpExpr.class);
39
40   private Expr _left;
41   private Expr _right;
42   private int _op;
43
44   DoubleCmpExpr(int op, Expr left, Expr right)
45   {
46     _left = left;
47     _right = right;
48     _op = op;
49   }
50
51   protected Expr bind(Query query)
52     throws SQLException JavaDoc
53   {
54     Expr newLeft = _left.bind(query);
55     Expr newRight = _right.bind(query);
56
57     if (_left == newLeft && _right == newRight)
58       return this;
59     else
60       return new CmpExpr(newLeft, newRight, _op);
61   }
62
63   /**
64    * Returns the type of the expression.
65    */

66   public Class JavaDoc getType()
67   {
68     return boolean.class;
69   }
70
71   /**
72    * Returns the cost based on the given FromList.
73    */

74   public long subCost(ArrayList JavaDoc<FromItem> fromList)
75   {
76     return _left.subCost(fromList) + _right.subCost(fromList);
77   }
78
79   /**
80    * Evaluates the expression as a boolean.
81    */

82   public int evalBoolean(QueryContext context)
83     throws SQLException JavaDoc
84   {
85     if (_left.isNull(context) || _right.isNull(context))
86       return UNKNOWN;
87     
88     switch (_op) {
89     case Parser.LT:
90       if (_left.evalDouble(context) < _right.evalDouble(context))
91     return TRUE;
92       else
93     return FALSE;
94     
95     case Parser.LE:
96       if (_left.evalDouble(context) <= _right.evalDouble(context))
97     return TRUE;
98       else
99     return FALSE;
100     
101     case Parser.GT:
102       if (_left.evalDouble(context) > _right.evalDouble(context))
103     return TRUE;
104       else
105     return FALSE;
106     
107     case Parser.GE:
108       if (_left.evalDouble(context) >= _right.evalDouble(context))
109     return TRUE;
110       else
111     return FALSE;
112     
113     case Parser.NE:
114       if (_left.evalDouble(context) != _right.evalDouble(context))
115     return TRUE;
116       else
117     return FALSE;
118     
119     case Parser.EQ:
120       if (_left.evalDouble(context) == _right.evalDouble(context))
121     return TRUE;
122       else
123     return FALSE;
124
125     default:
126       throw new SQLException JavaDoc("can't compare");
127     }
128   }
129
130   public String JavaDoc evalString(QueryContext context)
131     throws SQLException JavaDoc
132   {
133     throw new SQLException JavaDoc("can't convert string to boolean");
134   }
135
136   /**
137    * Evaluates aggregate functions during the group phase.
138    *
139    * @param state the current database tuple
140    */

141   public void evalGroup(QueryContext context)
142     throws SQLException JavaDoc
143   {
144     _left.evalGroup(context);
145     _right.evalGroup(context);
146   }
147
148   public String JavaDoc toString()
149   {
150     return "(" + _left + " = " + _right + ")";
151   }
152 }
153
Popular Tags