Commit e07e8b9d authored by Dmitry.Shahtanov's avatar Dmitry.Shahtanov Committed by Alexander.Trofimov

переделан парсинг массива

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@68473 954022d7-b5bf-4e40-9824-e11837661b57
parent 44f73ec2
...@@ -37,19 +37,19 @@ var c_oAscError = { ...@@ -37,19 +37,19 @@ var c_oAscError = {
UserCountExceed: -22, UserCountExceed: -22,
/* для формул */ /* для формул */
FrmlWrongCountParentheses: -30, FrmlWrongCountParentheses: -300,
FrmlWrongOperator: -31, FrmlWrongOperator: -301,
FrmlWrongMaxArgument: -32, FrmlWrongMaxArgument: -302,
FrmlWrongCountArgument: -33, FrmlWrongCountArgument: -303,
FrmlWrongFunctionName: -34, FrmlWrongFunctionName: -304,
FrmlAnotherParsingError: -35, FrmlAnotherParsingError: -305,
FrmlWrongArgumentRange: -36, FrmlWrongArgumentRange: -306,
FrmlOperandExpected: -37, FrmlOperandExpected: -307,
FrmlParenthesesCorrectCount: -38, FrmlParenthesesCorrectCount: -308,
FrmlWrongReferences: -39, FrmlWrongReferences: -309,
InvalidReferenceOrName: -40, InvalidReferenceOrName: -310,
LockCreateDefName: -41, LockCreateDefName: -311,
AutoFilterDataRangeError: -50, AutoFilterDataRangeError: -50,
......
...@@ -1176,7 +1176,6 @@ cRef.prototype.getValue = function () { ...@@ -1176,7 +1176,6 @@ cRef.prototype.getValue = function () {
} }
else if ( cellType === CellValueType.String ) { else if ( cellType === CellValueType.String ) {
res = new cString( this.range.getValueWithoutFormat() ); res = new cString( this.range.getValueWithoutFormat() );
// res = checkTypeCell( "" + this.range.getValueWithoutFormat() );
} }
else { else {
res = checkTypeCell( "" + this.range.getValueWithoutFormat() ); res = checkTypeCell( "" + this.range.getValueWithoutFormat() );
...@@ -4070,15 +4069,8 @@ parserFormula.prototype = { ...@@ -4070,15 +4069,8 @@ parserFormula.prototype = {
else if ( parserHelp.isComma.call( this, this.Formula, this.pCurrPos ) ) { else if ( parserHelp.isComma.call( this, this.Formula, this.pCurrPos ) ) {
wasLeftParentheses = false; wasLeftParentheses = false;
wasRigthParentheses = false; wasRigthParentheses = false;
/* if( this.operand_expected ){ var stackLength = this.elemArr.length, top_elem = null;
this.error.push(c_oAscError.ID.FrmlAnotherParsingError);
this.outStack = [];
this.elemArr = [];
return false;
} */
var wasLeftParentheses = false;
var stackLength = this.elemArr.length;
var top_elem = null;
if ( this.elemArr.length != 0 && this.elemArr[stackLength - 1].name == "(" && this.operand_expected ) { if ( this.elemArr.length != 0 && this.elemArr[stackLength - 1].name == "(" && this.operand_expected ) {
this.outStack.push( new cEmpty() ); this.outStack.push( new cEmpty() );
top_elem = this.elemArr[stackLength - 1]; top_elem = this.elemArr[stackLength - 1];
...@@ -4117,31 +4109,29 @@ parserFormula.prototype = { ...@@ -4117,31 +4109,29 @@ parserFormula.prototype = {
} }
/* Array */ /* Array */
else if ( parserHelp.isArray.call( this, this.Formula, this.pCurrPos, digitDelim ) ) { else if ( parserHelp.isLeftBrace.call(this, this.Formula, this.pCurrPos) ) {
wasLeftParentheses = false; wasLeftParentheses = false;
wasRigthParentheses = false; wasRigthParentheses = false;
var pH = new parserHelper(), tO = {pCurrPos: 0, Formula: this.operand_str, operand_str: ""};
var arr = new cArray(), operator = { isOperator: false, operatorName: ""}; var arr = new cArray(), operator = { isOperator: false, operatorName: ""};
while ( tO.pCurrPos < tO.Formula.length ) { while ( this.pCurrPos < this.Formula.length && !parserHelp.isRightBrace.call(this, this.Formula, this.pCurrPos) ) {
if ( parserHelp.isArraySeparator.call( this, this.Formula, this.pCurrPos, digitDelim ) ) {
if ( pH.isArraySeparator.call( tO, tO.Formula, tO.pCurrPos, digitDelim ) ) { if ( this.operand_str == (digitDelim ? arrayRowSeparator : arrayRowSeparatorDef) ) {
if ( tO.operand_str == (digitDelim ? arrayRowSeparator : arrayRowSeparatorDef) ) {
arr.addRow(); arr.addRow();
} }
} }
else if ( pH.isBoolean.call( tO, tO.Formula, tO.pCurrPos, local ) ) { else if ( parserHelp.isBoolean.call( this, this.Formula, this.pCurrPos, local ) ) {
arr.addElement( new cBool( tO.operand_str ) ); arr.addElement( new cBool( this.operand_str ) );
} }
else if ( pH.isString.call( tO, tO.Formula, tO.pCurrPos ) ) { else if ( parserHelp.isString.call( this, this.Formula, this.pCurrPos ) ) {
arr.addElement( new cString( tO.operand_str ) ); arr.addElement( new cString( this.operand_str ) );
} }
else if ( pH.isError.call( tO, tO.Formula, tO.pCurrPos ) ) { else if ( parserHelp.isError.call( this, this.Formula, this.pCurrPos ) ) {
arr.addElement( new cError( tO.operand_str ) ); arr.addElement( new cError( this.operand_str ) );
} }
else if ( pH.isNumber.call( tO, tO.Formula, tO.pCurrPos, digitDelim ) ) { else if ( parserHelp.isNumber.call( this, this.Formula, this.pCurrPos, digitDelim ) ) {
if ( operator.isOperator ) { if ( operator.isOperator ) {
if ( operator.operatorName == "+" || operator.operatorName == "-" ) { if ( operator.operatorName == "+" || operator.operatorName == "-" ) {
tO.operand_str = operator.operatorName + "" + tO.operand_str this.operand_str = operator.operatorName + "" + this.operand_str
} }
else { else {
this.outStack = []; this.outStack = [];
...@@ -4150,17 +4140,25 @@ parserFormula.prototype = { ...@@ -4150,17 +4140,25 @@ parserFormula.prototype = {
return false; return false;
} }
} }
arr.addElement( new cNumber( parseFloat( tO.operand_str ) ) ); arr.addElement( new cNumber( parseFloat( this.operand_str ) ) );
operator = { isOperator: false, operatorName: ""}; operator = { isOperator: false, operatorName: ""};
} }
else if ( pH.isOperator.call( tO, tO.Formula, tO.pCurrPos ) ) { else if ( parserHelp.isOperator.call( this, this.Formula, this.pCurrPos ) ) {
operator.isOperator = true; operator.isOperator = true;
operator.operatorName = tO.operand_str; operator.operatorName = this.operand_str;
} }
else{
this.outStack = [];
this.elemArr = [];
/*в массиве используется недопустимый параметр*/
this.error.push( c_oAscError.ID.FrmlAnotherParsingError );
return false;
}
} }
if ( !arr.isValidArray() ) { if ( !arr.isValidArray() ) {
this.outStack = []; this.outStack = [];
this.elemArr = []; this.elemArr = [];
/*размер массива не согласован*/
this.error.push( c_oAscError.ID.FrmlAnotherParsingError ); this.error.push( c_oAscError.ID.FrmlAnotherParsingError );
return false; return false;
} }
...@@ -4182,8 +4180,6 @@ parserFormula.prototype = { ...@@ -4182,8 +4180,6 @@ parserFormula.prototype = {
this.outStack = []; this.outStack = [];
this.elemArr = []; this.elemArr = [];
return false; return false;
// this.outStack = [new cError(cErrorType.unsupported_function)];
// return this.isParsed = true;
} }
/* Booleans */ /* Booleans */
...@@ -4268,6 +4264,7 @@ parserFormula.prototype = { ...@@ -4268,6 +4264,7 @@ parserFormula.prototype = {
found_operand = new cStrucTable( _tableTMP, this.wb, this.ws, this.ws.getCell( this.cellAddress ) ); found_operand = new cStrucTable( _tableTMP, this.wb, this.ws, this.ws.getCell( this.cellAddress ) );
if(found_operand.type==cElementType.error) { if(found_operand.type==cElementType.error) {
/*используется неверный именованный диапазон или таблица*/
this.error.push( c_oAscError.ID.FrmlAnotherParsingError ); this.error.push( c_oAscError.ID.FrmlAnotherParsingError );
this.outStack = []; this.outStack = [];
this.elemArr = []; this.elemArr = [];
...@@ -4341,10 +4338,6 @@ parserFormula.prototype = { ...@@ -4341,10 +4338,6 @@ parserFormula.prototype = {
found_operand = null found_operand = null
} }
else { else {
/*this.error.push( c_oAscError.ID.FrmlAnotherParsingError );
this.outStack = [];
this.elemArr = [];
return false;*/
if ( this.operand_str == null || this.operand_str == "'" ) { if ( this.operand_str == null || this.operand_str == "'" ) {
this.outStack.push( new cError( cErrorType.wrong_name ) ); this.outStack.push( new cError( cErrorType.wrong_name ) );
this.error.push( c_oAscError.ID.FrmlAnotherParsingError ); this.error.push( c_oAscError.ID.FrmlAnotherParsingError );
...@@ -4357,14 +4350,10 @@ parserFormula.prototype = { ...@@ -4357,14 +4350,10 @@ parserFormula.prototype = {
this.operand_expected = false; this.operand_expected = false;
if ( this.operand_str != null ) { if ( this.operand_str != null ) {
if ( this.operand_str == '"' ) { if ( this.operand_str == '"' ) {
//this.Formula = this.Formula.substr(0,this.pCurrPos) + '"' + this.Formula.substr(this.pCurrPos);
continue; continue;
} }
this.pCurrPos += this.operand_str.length; this.pCurrPos += this.operand_str.length;
} }
// break;
/*this.outStack = [new cError(cErrorType.wrong_name)];
return this.isParsed = false;*/
} }
if ( wasRigthParentheses ) { if ( wasRigthParentheses ) {
this.elemArr.push( new cMultOperator() ); this.elemArr.push( new cMultOperator() );
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment