1 {*********************************************************}
3 { Zeos Database Objects }
4 { Variables classes and interfaces }
6 { Originally written by Sergey Seroukhov }
8 {*********************************************************}
10 {@********************************************************}
11 { Copyright (c) 1999-2012 Zeos Development Group }
13 { License Agreement: }
15 { This library is distributed in the hope that it will be }
16 { useful, but WITHOUT ANY WARRANTY; without even the }
17 { implied warranty of MERCHANTABILITY or FITNESS FOR }
18 { A PARTICULAR PURPOSE. See the GNU Lesser General }
19 { Public License for more details. }
21 { The source code of the ZEOS Libraries and packages are }
22 { distributed under the Library GNU General Public }
23 { License (see the file COPYING / COPYING.ZEOS) }
24 { with the following modification: }
25 { As a special exception, the copyright holders of this }
26 { library give you permission to link this library with }
27 { independent modules to produce an executable, }
28 { regardless of the license terms of these independent }
29 { modules, and to copy and distribute the resulting }
30 { executable under terms of your choice, provided that }
31 { you also meet, for each linked independent module, }
32 { the terms and conditions of the license of that module. }
33 { An independent module is a module which is not derived }
34 { from or based on this library. If you modify this }
35 { library, you may extend this exception to your version }
36 { of the library, but you are not obligated to do so. }
37 { If you do not wish to do so, delete this exception }
38 { statement from your version. }
41 { The project web site is located on: }
42 { http://zeos.firmos.at (FORUM) }
43 { http://sourceforge.net/p/zeoslib/tickets/ (BUGTRACKER)}
44 { svn://svn.code.sf.net/p/zeoslib/code-0/trunk (SVN) }
46 { http://www.sourceforge.net/projects/zeoslib. }
49 { Zeos Development Group. }
50 {********************************************************@}
59 SysUtils, ZFunctions, ZExpression, ZVariant;
65 {** Implements a EMPTY function. }
66 TZEmptyFunction = class (TZAbstractFunction)
68 function Execute(Stack: TZExecutionStack;
69 VariantManager: IZVariantManager): TZVariant; override;
72 {** Implements a MIN function. }
73 TZMinFunction = class (TZAbstractFunction)
75 function Execute(Stack: TZExecutionStack;
76 VariantManager: IZVariantManager): TZVariant; override;
79 {** Implements a MAX function. }
80 TZMaxFunction = class (TZAbstractFunction)
82 function Execute(Stack: TZExecutionStack;
83 VariantManager: IZVariantManager): TZVariant; override;
86 {** Implements a SUM function. }
87 TZSumFunction = class (TZAbstractFunction)
89 function Execute(Stack: TZExecutionStack;
90 VariantManager: IZVariantManager): TZVariant; override;
93 {** Implements a IIF function. }
94 TZIIFFunction = class (TZAbstractFunction)
96 function Execute(Stack: TZExecutionStack;
97 VariantManager: IZVariantManager): TZVariant; override;
100 {** Implements a CASEF function. }
101 TZCASEFFunction = class (TZAbstractFunction)
103 function Execute(Stack: TZExecutionStack;
104 VariantManager: IZVariantManager): TZVariant; override;
107 procedure AddOtherFunctions(Functions : TZFunctionsList);
117 Executes this function.
118 @param Stack the stack object.
119 @param VariantManager a reference to variant processor object.
120 @returns a function value.
122 function TZEmptyFunction.Execute(Stack: TZExecutionStack;
123 VariantManager: IZVariantManager): TZVariant;
127 CheckParamsCount(Stack, 1);
128 Value := Stack.GetParameter(1);
129 VariantManager.SetAsBoolean(Result, VariantManager.IsNull(Value));
135 Executes this function.
136 @param Stack the stack object.
137 @param VariantManager a reference to variant processor object.
138 @returns a function value.
140 function TZMinFunction.Execute(Stack: TZExecutionStack;
141 VariantManager: IZVariantManager): TZVariant;
143 I, ParamsCount: Integer;
146 ParamsCount := VariantManager.GetAsInteger(Stack.GetParameter(0));
147 if ParamsCount < 2 then
148 raise TZExpressionError.Create(SExpectedMoreParams);
150 Result := Stack.GetParameter(ParamsCount);
151 for I := 1 to ParamsCount - 1 do
153 Value := Stack.GetParameter(I);
154 if VariantManager.Compare(Result, Value) > 0 then
162 Executes this function.
163 @param Stack the stack object.
164 @param VariantManager a reference to variant processor object.
165 @returns a function value.
167 function TZMaxFunction.Execute(Stack: TZExecutionStack;
168 VariantManager: IZVariantManager): TZVariant;
170 I, ParamsCount: Integer;
173 ParamsCount := VariantManager.GetAsInteger(Stack.GetParameter(0));
174 if ParamsCount < 2 then
175 raise TZExpressionError.Create(SExpectedMoreParams);
177 Result := Stack.GetParameter(ParamsCount);
178 for I := 1 to ParamsCount - 1 do
180 Value := Stack.GetParameter(I);
181 if VariantManager.Compare(Result, Value) < 0 then
189 Executes this function.
190 @param Stack the stack object.
191 @param VariantManager a reference to variant processor object.
192 @returns a function value.
194 function TZSumFunction.Execute(Stack: TZExecutionStack;
195 VariantManager: IZVariantManager): TZVariant;
197 I, ParamsCount: Integer;
199 ParamsCount := VariantManager.GetAsInteger(Stack.GetParameter(0));
200 if ParamsCount < 2 then
201 raise TZExpressionError.Create(SExpectedMoreParams);
203 Result := Stack.GetParameter(ParamsCount);
204 for I := ParamsCount - 1 downto 1 do
205 Result := VariantManager.OpAdd(Result, Stack.GetParameter(I));
211 Executes this function.
212 @param Stack the stack object.
213 @param VariantManager a reference to variant processor object.
214 @returns a function value.
216 function TZIIFFunction.Execute(Stack: TZExecutionStack;
217 VariantManager: IZVariantManager): TZVariant;
219 CheckParamsCount(Stack, 3);
220 if VariantManager.GetAsBoolean(Stack.GetParameter(3)) then
221 Result := Stack.GetParameter(2)
223 Result := Stack.GetParameter(1);
229 Executes this function.
230 @param Stack the stack object.
231 @param VariantManager a reference to variant processor object.
232 @returns a function value.
234 function TZCASEFFunction.Execute(Stack: TZExecutionStack;
235 VariantManager: IZVariantManager): TZVariant;
237 ParamsCount, Index : Integer;
240 ParamsCount := VariantManager.GetAsInteger(Stack.GetParameter(0));
241 if ParamsCount < 2 then
242 raise TZExpressionError.Create(SExpectedMoreParams);
243 Index := VariantManager.GetAsInteger(Stack.GetParameter(ParamsCount));
244 if ParamsCount < (Index+2) then
245 raise TZExpressionError.Create(SExpectedMoreParams);
246 Result := Stack.GetParameter(ParamsCount-Index-1)
249 procedure AddOtherFunctions(Functions : TZFunctionsList);
251 Functions.Add(TZEmptyFunction.Create('EMPTY'));
252 Functions.Add(TZMinFunction.Create('MIN'));
253 Functions.Add(TZMaxFunction.Create('MAX'));
254 Functions.Add(TZSumFunction.Create('SUM'));
255 Functions.Add(TZIIFFunction.Create('IIF'));
256 Functions.Add(TZCASEFFunction.Create('CASEF'));