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

fix: Bug 26098 - Не производится расчет функции если аргумент ссылается на пустую ячейку

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@58882 954022d7-b5bf-4e40-9824-e11837661b57
parent 22a8e0a6
...@@ -633,6 +633,13 @@ Complex.prototype = { ...@@ -633,6 +633,13 @@ Complex.prototype = {
var pStr = {pStr:rStr}, f = {f:undefined}; var pStr = {pStr:rStr}, f = {f:undefined};
if ( rStr.length == 0 ) {
this.real = 0;
this.img = 0;
this.suffix = "i";
return this;
}
if ( this.isImagUnit( pStr.pStr[0] ) && rStr.length == 1 ) { if ( this.isImagUnit( pStr.pStr[0] ) && rStr.length == 1 ) {
this.real = 0; this.real = 0;
this.img = 1; this.img = 1;
...@@ -644,7 +651,7 @@ Complex.prototype = { ...@@ -644,7 +651,7 @@ Complex.prototype = {
return new cError( cErrorType.not_numeric ); return new cError( cErrorType.not_numeric );
} }
switch ( pStr.pStr[0]+"" ) { switch ( pStr.pStr[0] + "" ) {
case '-': // imag part follows case '-': // imag part follows
case '+': case '+':
{ {
...@@ -1010,12 +1017,16 @@ cBIN2DEC.prototype.Calculate = function ( arg ) { ...@@ -1010,12 +1017,16 @@ cBIN2DEC.prototype.Calculate = function ( arg ) {
arg0 = arg0.getElementRowCol( 0, 0 ); arg0 = arg0.getElementRowCol( 0, 0 );
} }
arg0 = arg0.tocNumber(); arg0 = arg0.tocString();
if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( validBINNumber( arg0 ) ) { if ( validBINNumber( arg0 ) ) {
var substr = arg0.toString(); var substr = arg0.toString();
if ( substr.length == 10 && substr.substring( 0, 1 ) == "1" ) { if ( substr.length == 10 && substr.substring( 0, 1 ) == "1" ) {
...@@ -1063,10 +1074,14 @@ cBIN2HEX.prototype.Calculate = function ( arg ) { ...@@ -1063,10 +1074,14 @@ cBIN2HEX.prototype.Calculate = function ( arg ) {
arg1 = arg1.getElementRowCol( 0, 0 ); arg1 = arg1.getElementRowCol( 0, 0 );
} }
arg0 = arg0.tocNumber(); arg0 = arg0.tocString();
if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.not_numeric ); if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.not_numeric );
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( !(arg1 instanceof cUndefined) ) { if ( !(arg1 instanceof cUndefined) ) {
arg1 = arg1.tocNumber(); arg1 = arg1.tocNumber();
if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
...@@ -1121,10 +1136,14 @@ cBIN2OCT.prototype.Calculate = function ( arg ) { ...@@ -1121,10 +1136,14 @@ cBIN2OCT.prototype.Calculate = function ( arg ) {
arg1 = arg1.getElementRowCol( 0, 0 ); arg1 = arg1.getElementRowCol( 0, 0 );
} }
arg0 = arg0.tocNumber(); arg0 = arg0.tocString();
if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.not_numeric ); if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.not_numeric );
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( !(arg1 instanceof cUndefined) ) { if ( !(arg1 instanceof cUndefined) ) {
arg1 = arg1.tocNumber(); arg1 = arg1.tocNumber();
if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
...@@ -1597,6 +1616,10 @@ cHEX2BIN.prototype.Calculate = function ( arg ) { ...@@ -1597,6 +1616,10 @@ cHEX2BIN.prototype.Calculate = function ( arg ) {
if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( !(arg1 instanceof cUndefined) ) { if ( !(arg1 instanceof cUndefined) ) {
arg1 = arg1.tocNumber(); arg1 = arg1.tocNumber();
if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
...@@ -1659,6 +1682,10 @@ cHEX2DEC.prototype.Calculate = function ( arg ) { ...@@ -1659,6 +1682,10 @@ cHEX2DEC.prototype.Calculate = function ( arg ) {
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( validHEXNumber( arg0 ) ) { if ( validHEXNumber( arg0 ) ) {
arg0 = parseInt( arg0, NumberBase.HEX ); arg0 = parseInt( arg0, NumberBase.HEX );
...@@ -1707,6 +1734,10 @@ cHEX2OCT.prototype.Calculate = function ( arg ) { ...@@ -1707,6 +1734,10 @@ cHEX2OCT.prototype.Calculate = function ( arg ) {
if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( !(arg1 instanceof cUndefined) ) { if ( !(arg1 instanceof cUndefined) ) {
arg1 = arg1.tocNumber(); arg1 = arg1.tocNumber();
if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
...@@ -2573,6 +2604,10 @@ cOCT2BIN.prototype.Calculate = function ( arg ) { ...@@ -2573,6 +2604,10 @@ cOCT2BIN.prototype.Calculate = function ( arg ) {
if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( !(arg1 instanceof cUndefined) ) { if ( !(arg1 instanceof cUndefined) ) {
arg1 = arg1.tocNumber(); arg1 = arg1.tocNumber();
if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
...@@ -2635,6 +2670,10 @@ cOCT2DEC.prototype.Calculate = function ( arg ) { ...@@ -2635,6 +2670,10 @@ cOCT2DEC.prototype.Calculate = function ( arg ) {
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( validOCTNumber( arg0 ) ) { if ( validOCTNumber( arg0 ) ) {
arg0 = parseInt( arg0, NumberBase.OCT ); arg0 = parseInt( arg0, NumberBase.OCT );
...@@ -2683,6 +2722,10 @@ cOCT2HEX.prototype.Calculate = function ( arg ) { ...@@ -2683,6 +2722,10 @@ cOCT2HEX.prototype.Calculate = function ( arg ) {
if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg0 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
arg0 = arg0.getValue(); arg0 = arg0.getValue();
if ( arg0.length == 0 ) {
arg0 = 0;
}
if ( !(arg1 instanceof cUndefined) ) { if ( !(arg1 instanceof cUndefined) ) {
arg1 = arg1.tocNumber(); arg1 = arg1.tocNumber();
if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type ); if ( arg1 instanceof cError ) return this.value = new cError( cErrorType.wrong_value_type );
......
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