Commit 5c705d47 authored by Boris Kocherov's avatar Boris Kocherov

make changeOffset working for string arguments in formula by execute changeOffsetElem

added support of changOffsetElem. changeOffsetElem could be specified in
function definition.
in Russian:
добавлена поддержка changeOffsetElem определяемый в определении функции.
parent eabda5e7
...@@ -5542,8 +5542,50 @@ parserFormula.prototype.setFormula = function(formula) { ...@@ -5542,8 +5542,50 @@ parserFormula.prototype.setFormula = function(formula) {
/* Для обратной сборки функции иногда необходимо поменять ссылки на ячейки */ /* Для обратной сборки функции иногда необходимо поменять ссылки на ячейки */
parserFormula.prototype.changeOffset = function (offset, canResize) {//offset = AscCommonExcel.CRangeOffset parserFormula.prototype.changeOffset = function (offset, canResize) {//offset = AscCommonExcel.CRangeOffset
var elemArr = [], currentElement = null, arg,
disable_changeOffset_run = false,
argumentsCount;
for (var i = 0; i < this.outStack.length; i++) { for (var i = 0; i < this.outStack.length; i++) {
this.changeOffsetElem(this.outStack[i], this.outStack, i, offset, canResize); currentElement = this.outStack[i];
this.changeOffsetElem(currentElement, this.outStack, i, offset, canResize);
if (disable_changeOffset_run) {
continue;
}
if (currentElement.name == "(") {
continue;
}
if(currentElement.type === cElementType.specialFunctionStart){
continue;
}
if(currentElement.type === cElementType.specialFunctionEnd){
continue;
}
if("number" === typeof(currentElement)){
continue;
}
if (currentElement.type === cElementType.operator || currentElement.type === cElementType.func) {
argumentsCount = "number" === typeof(this.outStack[i - 1]) ? this.outStack[i - 1] : currentElement.argumentsCurrent;
if (elemArr.length < argumentsCount) {
disable_changeOffset_run = true;
continue;
} else {
if (currentElement && currentElement.changeOffsetElem) {
arg = [];
for (var ind = 0; ind < argumentsCount; ind++) {
arg.unshift(elemArr.pop());
}
currentElement.changeOffsetElem(arg, offset);
}
// calculation not work on changeOffset stage
elemArr.push(new cEmpty());
}
} else if (currentElement.type === cElementType.name || currentElement.type === cElementType.name3D) {
elemArr.push(currentElement.Calculate(null, null));
} else if (currentElement.type === cElementType.table) {
elemArr.push(currentElement.toRef(null));
} else {
elemArr.push(currentElement);
}
} }
return this; return this;
}; };
......
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