Objective Toolkit now includes a Lex (Flex)-based formula evaluation engine. By instantiating objects of the toolkit-defined class SRFormulaScanner, developers can easily add formula evaluation functionality to their applications.
The formula scanner:
Supports decimal and hexadecimal representations of numeric input.
Supports all common arithmetic, trigonometric, and bitwise logical functions.
Supports common string operations (e.g., LEFT, MID).
Tests for formula validity and error explanations.
Is usable in Unicode and single-byte character mode applications.
Parsing is driven by a Flex-generated, finite state, machine type, regular expression parser.
Use of the formula engine class is straightforward.
In any source file in which you wish to incorporate formula evaluation functionality, include the following toolkit-supplied header files, as follows:
#include <SRFormulaScanner.h> #include <errorcodes.h> |
Declare an instance of the formula engine class, as follows:
SRFormulaScanner scan; |
Set the formula, tell the formula engine to evaluate it, and extract the answer (or an error message), as follows:
scan.lex(_T("SUM(3,4,(6 * (4+SQRT(9))))")); if (scan.IsValid()) { _TCHAR *cb = NULL; scan.GetResult(&cb); //cb now points to the answer, formatted as a string if(cb) free(cb); //since the answer string is dynamically allocated //within the formula engine, you must free it to avoid a //memory leak } else { _TCHAR * errdesc = NULL; scan.GetErrDescription(&errdesc); //errdesc points to an error message string. //this string is not dynamically allocated, and //therefore does not have to be freed. } |
See the sample included with the product for an example of how the formula engine can be used.
Copyright © Rogue Wave Software, Inc. All Rights Reserved.
The Rogue Wave name and logo, and Stingray, are registered trademarks of Rogue Wave Software. All other trademarks are the property of their respective owners.
Provide feedback to Rogue Wave about its documentation.