LLCalcparser update
This commit is contained in:
@@ -1,9 +1,26 @@
|
||||
/*
|
||||
* LLCalc.cpp
|
||||
* SecondLife
|
||||
*
|
||||
* Created by Aimee Walton on 28/09/2008.
|
||||
* Copyright 2008 Aimee Walton.
|
||||
* Copyright 2008 Aimee Walton.
|
||||
* $LicenseInfo:firstyear=2008&license=viewerlgpl$
|
||||
* Second Life Viewer Source Code
|
||||
* Copyright (C) 2008, Linden Research, Inc.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation;
|
||||
* version 2.1 of the License only.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*
|
||||
* Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
|
||||
* $/LicenseInfo$
|
||||
*
|
||||
*/
|
||||
|
||||
@@ -11,59 +28,61 @@
|
||||
|
||||
#include "llcalc.h"
|
||||
|
||||
#include "llcalcparser.h"
|
||||
#include "llmath.h"
|
||||
|
||||
#include "llcalcparser.h"
|
||||
|
||||
// Variable names for use in the build floater
|
||||
const char* LLCalc::X_POS = "PX";
|
||||
const char* LLCalc::Y_POS = "PY";
|
||||
const char* LLCalc::Z_POS = "PZ";
|
||||
const char* LLCalc::X_SCALE = "SX";
|
||||
const char* LLCalc::Y_SCALE = "SY";
|
||||
const char* LLCalc::Z_SCALE = "SZ";
|
||||
const char* LLCalc::X_ROT = "RX";
|
||||
const char* LLCalc::Y_ROT = "RY";
|
||||
const char* LLCalc::Z_ROT = "RZ";
|
||||
const char* LLCalc::HOLLOW = "HLW";
|
||||
const char* LLCalc::CUT_BEGIN = "CB";
|
||||
const char* LLCalc::CUT_END = "CE";
|
||||
const char* LLCalc::PATH_BEGIN = "PB";
|
||||
const char* LLCalc::PATH_END = "PE";
|
||||
const char* LLCalc::TWIST_BEGIN = "TB";
|
||||
const char* LLCalc::TWIST_END = "TE";
|
||||
const char* LLCalc::X_SHEAR = "SHX";
|
||||
const char* LLCalc::Y_SHEAR = "SHY";
|
||||
const char* LLCalc::X_TAPER = "TPX";
|
||||
const char* LLCalc::Y_TAPER = "TPY";
|
||||
const char* LLCalc::RADIUS_OFFSET = "ROF";
|
||||
const char* LLCalc::REVOLUTIONS = "REV";
|
||||
const char* LLCalc::SKEW = "SKW";
|
||||
const char* LLCalc::X_HOLE = "HLX";
|
||||
const char* LLCalc::Y_HOLE = "HLY";
|
||||
const char* LLCalc::TEX_U_SCALE = "TSU";
|
||||
const char* LLCalc::TEX_V_SCALE = "TSV";
|
||||
const char* LLCalc::TEX_U_OFFSET = "TOU";
|
||||
const char* LLCalc::TEX_V_OFFSET = "TOV";
|
||||
const char* LLCalc::TEX_ROTATION = "TROT";
|
||||
const char* LLCalc::TEX_TRANSPARENCY = "TRNS";
|
||||
const char* LLCalc::TEX_GLOW = "GLOW";
|
||||
|
||||
// must be lower case for parser definition
|
||||
// case-insensitive for actual parsing
|
||||
const char* LLCalc::X_POS = "px";
|
||||
const char* LLCalc::Y_POS = "py";
|
||||
const char* LLCalc::Z_POS = "pz";
|
||||
const char* LLCalc::X_SCALE = "sx";
|
||||
const char* LLCalc::Y_SCALE = "sy";
|
||||
const char* LLCalc::Z_SCALE = "sz";
|
||||
const char* LLCalc::X_ROT = "rx";
|
||||
const char* LLCalc::Y_ROT = "ry";
|
||||
const char* LLCalc::Z_ROT = "rz";
|
||||
const char* LLCalc::HOLLOW = "hlw";
|
||||
const char* LLCalc::CUT_BEGIN = "cb";
|
||||
const char* LLCalc::CUT_END = "ce";
|
||||
const char* LLCalc::PATH_BEGIN = "pb";
|
||||
const char* LLCalc::PATH_END = "pe";
|
||||
const char* LLCalc::TWIST_BEGIN = "tb";
|
||||
const char* LLCalc::TWIST_END = "te";
|
||||
const char* LLCalc::X_SHEAR = "shx";
|
||||
const char* LLCalc::Y_SHEAR = "shy";
|
||||
const char* LLCalc::X_TAPER = "tpx";
|
||||
const char* LLCalc::Y_TAPER = "tpy";
|
||||
const char* LLCalc::RADIUS_OFFSET = "rof";
|
||||
const char* LLCalc::REVOLUTIONS = "rev";
|
||||
const char* LLCalc::SKEW = "skw";
|
||||
const char* LLCalc::X_HOLE = "hlx";
|
||||
const char* LLCalc::Y_HOLE = "hly";
|
||||
const char* LLCalc::TEX_U_SCALE = "tsu";
|
||||
const char* LLCalc::TEX_V_SCALE = "tsv";
|
||||
const char* LLCalc::TEX_U_OFFSET = "tou";
|
||||
const char* LLCalc::TEX_V_OFFSET = "tov";
|
||||
const char* LLCalc::TEX_ROTATION = "trot";
|
||||
const char* LLCalc::TEX_TRANSPARENCY = "trns";
|
||||
const char* LLCalc::TEX_GLOW = "glow";
|
||||
|
||||
LLCalc* LLCalc::sInstance = NULL;
|
||||
|
||||
//TODO: Make this a static global class
|
||||
LLCalc::LLCalc() : mLastErrorPos(0)
|
||||
{
|
||||
// Init table of constants
|
||||
mConstants["PI"] = F_PI;
|
||||
mConstants["TWO_PI"] = F_TWO_PI;
|
||||
mConstants["PI_BY_TWO"] = F_PI_BY_TWO;
|
||||
mConstants["SQRT_TWO_PI"] = F_SQRT_TWO_PI;
|
||||
mConstants["SQRT2"] = F_SQRT2;
|
||||
mConstants["SQRT3"] = F_SQRT3;
|
||||
mConstants["DEG_TO_RAD"] = DEG_TO_RAD;
|
||||
mConstants["RAD_TO_DEG"] = RAD_TO_DEG;
|
||||
mConstants["GRAVITY"] = GRAVITY;
|
||||
/*setVar("PI", F_PI);
|
||||
setVar("TWO_PI", F_TWO_PI);
|
||||
setVar("PI_BY_TWO", F_PI_BY_TWO);
|
||||
setVar("SQRT_TWO_PI", F_SQRT_TWO_PI);
|
||||
setVar("SQRT2", F_SQRT2);
|
||||
setVar("SQRT3", F_SQRT3);
|
||||
setVar("DEG_TO_RAD", DEG_TO_RAD);
|
||||
setVar("RAD_TO_DEG", RAD_TO_DEG);
|
||||
setVar("GRAVITY", GRAVITY);*/
|
||||
}
|
||||
|
||||
LLCalc::~LLCalc()
|
||||
@@ -80,7 +99,7 @@ void LLCalc::cleanUp()
|
||||
//static
|
||||
LLCalc* LLCalc::getInstance()
|
||||
{
|
||||
if (!sInstance) sInstance = new LLCalc();
|
||||
if (!sInstance) sInstance = new LLCalc();
|
||||
return sInstance;
|
||||
}
|
||||
|
||||
@@ -99,47 +118,35 @@ void LLCalc::clearAllVariables()
|
||||
mVariables.clear();
|
||||
}
|
||||
|
||||
/*
|
||||
void LLCalc::updateVariables(LLSD& vars)
|
||||
{
|
||||
LLSD::map_iterator cIt = vars.beginMap();
|
||||
for(; cIt != vars.endMap(); cIt++)
|
||||
{
|
||||
setVar(cIt->first, (F32)(LLSD::Real)cIt->second);
|
||||
}
|
||||
}
|
||||
*/
|
||||
|
||||
bool LLCalc::evalString(const std::string& expression, F32& result)
|
||||
{
|
||||
std::string expr_upper = expression;
|
||||
LLStringUtil::toUpper(expr_upper);
|
||||
|
||||
LLCalcParser calc(result, &mConstants, &mVariables);
|
||||
|
||||
mLastErrorPos = 0;
|
||||
std::string::iterator start = expr_upper.begin();
|
||||
parse_info<std::string::iterator> info;
|
||||
|
||||
try
|
||||
std::string::const_iterator itr = expression.begin();
|
||||
expression::grammar<F32,std::string::const_iterator> calc;
|
||||
calc.constant.add
|
||||
("pi", F_PI)
|
||||
("two_pi", F_TWO_PI)
|
||||
("pi_by_two", F_PI_BY_TWO)
|
||||
("sqrt_two_pi", F_SQRT_TWO_PI)
|
||||
("sqrt2", F_SQRT2)
|
||||
("sqrt3", F_SQRT3)
|
||||
("deg_to_rad", DEG_TO_RAD)
|
||||
("rad_to_deg", RAD_TO_DEG)
|
||||
("gravity", GRAVITY)
|
||||
;
|
||||
for(calc_map_t::const_iterator iter = mVariables.begin();
|
||||
iter != mVariables.end();
|
||||
++iter)
|
||||
{
|
||||
info = parse(start, expr_upper.end(), calc, space_p);
|
||||
lldebugs << "Math expression: " << expression << " = " << result << llendl;
|
||||
calc.constant.add(iter->first, iter->second);
|
||||
}
|
||||
catch(parser_error<std::string, std::string::iterator> &e)
|
||||
|
||||
if (!expression::parse<F32,std::string::const_iterator>(itr, expression.end(), calc, result) || itr != expression.end())
|
||||
{
|
||||
mLastErrorPos = e.where - expr_upper.begin();
|
||||
|
||||
llinfos << "Calc parser exception: " << e.descriptor << " at " << mLastErrorPos << " in expression: " << expression << llendl;
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!info.full)
|
||||
{
|
||||
mLastErrorPos = info.stop - expr_upper.begin();
|
||||
mLastErrorPos = itr - expression.begin();
|
||||
llinfos << "Unhandled syntax error at " << mLastErrorPos << " in expression: " << expression << llendl;
|
||||
return false;
|
||||
}
|
||||
|
||||
lldebugs << "Math expression: " << expression << " = " << result << llendl;
|
||||
return true;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user