@univerjs-pro/engine-formula 0.22.1 → 0.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/umd/index.js CHANGED
@@ -1 +1 @@
1
- (function(_0x4daaa2,_0x446c0f){const _0x27c37e=_0x3679,_0x114acb=_0x4daaa2();while(!![]){try{const _0x8c54cf=parseInt(_0x27c37e(0x1bf))/0x1*(-parseInt(_0x27c37e(0x10d))/0x2)+parseInt(_0x27c37e(0xfb))/0x3*(parseInt(_0x27c37e(0x1e4))/0x4)+-parseInt(_0x27c37e(0x11e))/0x5+-parseInt(_0x27c37e(0x1d1))/0x6+-parseInt(_0x27c37e(0x155))/0x7*(-parseInt(_0x27c37e(0x1a1))/0x8)+-parseInt(_0x27c37e(0x17a))/0x9+parseInt(_0x27c37e(0x1e9))/0xa*(parseInt(_0x27c37e(0x100))/0xb);if(_0x8c54cf===_0x446c0f)break;else _0x114acb['push'](_0x114acb['shift']());}catch(_0x429ec8){_0x114acb['push'](_0x114acb['shift']());}}}(_0x155e,0x586f6),function(_0x4728c9,_0x46bd56){const _0x5322cb=_0x3679;typeof exports==_0x5322cb(0x1eb)&&typeof module<'u'?_0x46bd56(exports,require(`@univerjs/engine-formula`),require(`@univerjs-pro/license`),require(`@univerjs/core`)):typeof define==_0x5322cb(0x129)&&define[_0x5322cb(0x101)]?define([_0x5322cb(0x177),_0x5322cb(0x1bc),'@univerjs-pro/license',_0x5322cb(0x1f4)],_0x46bd56):(_0x4728c9=typeof globalThis<'u'?globalThis:_0x4728c9||self,_0x46bd56(_0x4728c9['UniverProEngineFormula']={},_0x4728c9[_0x5322cb(0x14c)],_0x4728c9[_0x5322cb(0x154)],_0x4728c9[_0x5322cb(0x1c7)]));}(this,function(_0x4eb647,_0x5773e3,_0x3bb87b,_0x5e7a81){const _0x4c7e45=_0x3679;Object[_0x4c7e45(0x12d)](_0x4eb647,Symbol[_0x4c7e45(0x1af)],{'value':_0x4c7e45(0x10f)});function _0x22e753(_0x54f20f){'@babel/helpers - typeof';const _0x488f79=_0x4c7e45;return _0x22e753=typeof Symbol==_0x488f79(0x129)&&typeof Symbol['iterator']==_0x488f79(0x105)?function(_0x54ff57){return typeof _0x54ff57;}:function(_0x3ef2d9){const _0x24191a=_0x488f79;return _0x3ef2d9&&typeof Symbol==_0x24191a(0x129)&&_0x3ef2d9[_0x24191a(0x173)]===Symbol&&_0x3ef2d9!==Symbol[_0x24191a(0x10c)]?_0x24191a(0x105):typeof _0x3ef2d9;},_0x22e753(_0x54f20f);}function _0x4c1d89(_0x27ce23,_0x1a328d){const _0x1715bf=_0x4c7e45;if(_0x22e753(_0x27ce23)!=_0x1715bf(0x1eb)||!_0x27ce23)return _0x27ce23;var _0x4c098a=_0x27ce23[Symbol[_0x1715bf(0x144)]];if(_0x4c098a!==void 0x0){var _0x32b92a=_0x4c098a[_0x1715bf(0x134)](_0x27ce23,_0x1a328d||'default');if(_0x22e753(_0x32b92a)!=_0x1715bf(0x1eb))return _0x32b92a;throw TypeError('@@toPrimitive\x20must\x20return\x20a\x20primitive\x20value.');}return(_0x1a328d===_0x1715bf(0x12f)?String:Number)(_0x27ce23);}function _0x143909(_0x527324){const _0x508a0e=_0x4c7e45;var _0x468b37=_0x4c1d89(_0x527324,_0x508a0e(0x12f));return _0x22e753(_0x468b37)==_0x508a0e(0x105)?_0x468b37:_0x468b37+'';}function _0x5eaa43(_0x346183,_0x21e482,_0x42240a){const _0x19792e=_0x4c7e45;return(_0x21e482=_0x143909(_0x21e482))in _0x346183?Object[_0x19792e(0x12d)](_0x346183,_0x21e482,{'value':_0x42240a,'enumerable':!0x0,'configurable':!0x0,'writable':!0x0}):_0x346183[_0x21e482]=_0x42240a,_0x346183;}var _0x5cb4c6=class extends _0x5773e3[_0x4c7e45(0x19c)]{constructor(..._0x38f01b){const _0x1a02ea=_0x4c7e45;super(..._0x38f01b),_0x5eaa43(this,'_hasNewExcelFunction',!0x1),_0x5eaa43(this,_0x1a02ea(0x12b),new Set()),_0x5eaa43(this,_0x1a02ea(0x146),_0x1a02ea(0x1d6)),_0x5eaa43(this,_0x1a02ea(0x197),_0x1a02ea(0x1c8)),_0x5eaa43(this,'_currentUnitId','');}[_0x4c7e45(0x1d3)](){const _0x53ac24=_0x4c7e45;this['_xlpmPrefix']='_xlpm.',this[_0x53ac24(0x197)]='_xlfn.';}[_0x4c7e45(0x139)](){const _0x3832a4=_0x4c7e45;this[_0x3832a4(0x146)]='',this[_0x3832a4(0x197)]='';}[_0x4c7e45(0x1a8)](_0x58ff8b,_0x3c6012){const _0x14246d=_0x4c7e45;let _0xc0d90a=this['treeBuilder'](_0x58ff8b,!0x1);if(!_0xc0d90a||_0xc0d90a===_0x5773e3[_0x14246d(0x1da)]['VALUE']||Array[_0x14246d(0x169)](_0xc0d90a))return null;let _0x367aca=[];return this[_0x14246d(0x130)]=!0x1,this[_0x14246d(0x1a9)](_0xc0d90a,_0x367aca,_0x3c6012),this[_0x14246d(0x130)]?'='+_0x367aca['join'](''):null;}['_generateNewFunctionString'](_0x1753bc,_0x1005d5,_0x3330be){const _0x503243=_0x4c7e45;let _0x1f88ed=_0x1753bc[_0x503243(0xf4)](),_0x27d4f5=_0x1f88ed['trim'](),_0x534d0a=_0x27d4f5[_0x503243(0x1f9)](),_0x3c9ba1=this[_0x503243(0x126)](_0x534d0a),_0x4dbbab=_0x3330be(_0x3c9ba1),_0x29e6ae=0x0;_0x1f88ed===_0x5773e3[_0x503243(0x1d9)]?_0x29e6ae=0x3:_0x1f88ed===_0x5773e3[_0x503243(0x18b)]?_0x29e6ae=0x4:_0x1f88ed===_0x5773e3[_0x503243(0x170)]?_0x29e6ae=0x5:_0x5773e3[_0x503243(0x1ea)]['has'](_0x3c9ba1)?(_0x1005d5[_0x503243(0xfe)](''+this[_0x503243(0x197)]+_0x27d4f5),this['_hasNewExcelFunction']=!0x0):_0x534d0a===_0x5773e3[_0x503243(0x12c)]?(_0x1005d5['push'](''+this[_0x503243(0x197)]+_0x27d4f5),this[_0x503243(0x130)]=!0x0,_0x29e6ae=0x2):_0x534d0a===_0x5773e3[_0x503243(0x1bb)]?(_0x1005d5[_0x503243(0xfe)](''+this[_0x503243(0x197)]+_0x27d4f5),this[_0x503243(0x130)]=!0x0,_0x29e6ae=0x1):_0x534d0a===_0x5773e3[_0x503243(0x108)][_0x503243(0x13e)]?_0x29e6ae=0x8:_0x5773e3[_0x503243(0x116)][_0x503243(0x149)](_0x534d0a)?_0x29e6ae=0x7:_0x534d0a===_0x5773e3[_0x503243(0x132)][_0x503243(0x16b)]?(this[_0x503243(0x1f6)](_0x1753bc)&&(_0x29e6ae=0x9),_0x1005d5['push'](_0x1f88ed)):(_0x1005d5[_0x503243(0xfe)](_0x1f88ed),_0x29e6ae=0xa),_0x4dbbab?(_0x29e6ae!==0x2&&_0x29e6ae!==0x1&&(_0x29e6ae=0x6),_0x1005d5['push']('(')):_0x29e6ae===0x9&&_0x1005d5['push']('(');let _0x424eb6=_0x1753bc['getChildren'](),_0x4d183b=_0x424eb6[_0x503243(0x181)];if(_0x29e6ae===0x2){let _0x5191bb=_0x424eb6[0x0],_0x570560=0x0;_0x5191bb instanceof _0x5773e3[_0x503243(0x1ed)]&&_0x5191bb['getToken']()===_0x5773e3[_0x503243(0x170)]&&(_0x570560=0x1);for(let _0x59e397=_0x570560;_0x59e397<_0x4d183b-0x1;_0x59e397++){let _0x1b84dc=_0x424eb6[_0x59e397];if(_0x1b84dc instanceof _0x5773e3['LexerNode']){let _0x237e85=_0x1b84dc['getChildren']()[0x0];typeof _0x237e85=='string'&&(this[_0x503243(0x12b)]['has'](_0x237e85)&&console[_0x503243(0x191)](_0x503243(0x1c9)+_0x237e85+'\x22\x20is\x20duplicated.'),this[_0x503243(0x12b)][_0x503243(0x141)](_0x237e85),_0x1005d5['push'](''+this[_0x503243(0x146)]+_0x237e85),this[_0x503243(0x130)]=!0x0);}_0x1005d5[_0x503243(0xfe)](',');}this[_0x503243(0x1b0)](_0x424eb6[_0x4d183b-0x1],_0x1005d5,_0x3330be),_0x570560===0x1?(_0x1005d5[_0x503243(0xfe)](')'),_0x1005d5['push']('('),this[_0x503243(0x1a9)](_0x5191bb,_0x1005d5,_0x3330be),_0x1005d5[_0x503243(0xfe)](')')):_0x1005d5[_0x503243(0xfe)](')');return;}else{if(_0x29e6ae===0x1){for(let _0x40d111=0x0;_0x40d111<_0x4d183b-0x1;_0x40d111++){let _0x4589ee=_0x424eb6[_0x40d111];if(_0x4589ee instanceof _0x5773e3['LexerNode']&&_0x40d111%0x2==0x0){let _0x41c1db=_0x4589ee[_0x503243(0x112)]()[0x0];if(typeof _0x41c1db=='string'){this['_lambdaFunctionParameterSet'][_0x503243(0x149)](_0x41c1db)&&console[_0x503243(0x191)](_0x503243(0x1dc)+_0x41c1db+_0x503243(0x13b)),this[_0x503243(0x12b)]['add'](_0x41c1db),_0x1005d5[_0x503243(0xfe)](''+this[_0x503243(0x146)]+_0x41c1db),this[_0x503243(0x130)]=!0x0,_0x1005d5[_0x503243(0xfe)](',');continue;}}if(this[_0x503243(0x1b0)](_0x4589ee,_0x1005d5,_0x3330be),_0x4589ee instanceof _0x5773e3[_0x503243(0x1ed)]){let _0x2ab649=_0x424eb6[_0x40d111+0x1];_0x2ab649&&_0x2ab649 instanceof _0x5773e3[_0x503243(0x1ed)]&&_0x1005d5[_0x503243(0xfe)](',');}}this[_0x503243(0x1b0)](_0x424eb6[_0x4d183b-0x1],_0x1005d5,_0x3330be),_0x1005d5[_0x503243(0xfe)](')');return;}else{if(_0x29e6ae===0x8){let _0x14d80=_0x424eb6[0x0],_0x51ee15=_0x424eb6[0x1];this[_0x503243(0x1b0)](_0x14d80,_0x1005d5,_0x3330be),_0x1005d5[_0x503243(0xfe)](_0x1f88ed),this[_0x503243(0x1b0)](_0x51ee15,_0x1005d5,_0x3330be);return;}}}for(let _0x36a290=0x0;_0x36a290<_0x4d183b;_0x36a290++){let _0x1c383a=_0x424eb6[_0x36a290];if(this[_0x503243(0x1b0)](_0x1c383a,_0x1005d5,_0x3330be),_0x1c383a instanceof _0x5773e3[_0x503243(0x1ed)]){let _0x24b011=_0x424eb6[_0x36a290+0x1];_0x24b011&&_0x24b011 instanceof _0x5773e3[_0x503243(0x1ed)]&&_0x1005d5[_0x503243(0xfe)](',');}}_0x29e6ae===0x7&&_0x1005d5[_0x503243(0xfe)](_0x1f88ed),(_0x4dbbab||_0x29e6ae===0x9)&&_0x1005d5[_0x503243(0xfe)](')');}[_0x4c7e45(0x1b0)](_0x4e8bd4,_0x369688,_0x33d14f){const _0x4914ed=_0x4c7e45;_0x4e8bd4 instanceof _0x5773e3['LexerNode']?this[_0x4914ed(0x1a9)](_0x4e8bd4,_0x369688,_0x33d14f):this[_0x4914ed(0x12b)][_0x4914ed(0x149)](_0x4e8bd4)?(_0x369688[_0x4914ed(0xfe)](''+this[_0x4914ed(0x146)]+_0x4e8bd4),this[_0x4914ed(0x130)]=!0x0):_0x369688[_0x4914ed(0xfe)](_0x4e8bd4);}['_clearFunctionString'](_0x32a997){const _0x11bea4=_0x4c7e45;let _0x1af330=_0x32a997[_0x11bea4(0x15c)]();if(!_0x1af330)return _0x1af330;let _0x1fb5ce=_0x1af330[0x0];if((_0x1fb5ce===_0x5773e3[_0x11bea4(0x132)]['AT']||_0x1fb5ce===_0x5773e3[_0x11bea4(0x132)][_0x11bea4(0x16b)]||_0x1fb5ce===_0x5773e3[_0x11bea4(0x132)][_0x11bea4(0x18c)])&&(_0x1af330=_0x1af330[_0x11bea4(0x1e3)](0x1)),!_0x1af330)return _0x1af330;let _0x5400bd=_0x1af330[_0x1af330[_0x11bea4(0x181)]-0x1];return _0x5773e3[_0x11bea4(0x116)]['has'](_0x5400bd)&&(_0x1af330=_0x1af330[_0x11bea4(0x1e3)](0x0,-0x1)),_0x1af330;}[_0x4c7e45(0x1f6)](_0x14afc4){const _0x1986b4=_0x4c7e45;let _0x502dfd=_0x14afc4[_0x1986b4(0x112)]()[0x0];if(!_0x502dfd||!(_0x502dfd instanceof _0x5773e3[_0x1986b4(0x1ed)])||_0x14afc4['getChildren']()['length']>0x1)return!0x1;let _0x422844=_0x502dfd[_0x1986b4(0x112)](),_0x595a4f=_0x422844[_0x1986b4(0x181)];if(_0x595a4f===0x1)return!0x1;for(let _0x3eaf18=0x0;_0x3eaf18<_0x595a4f;_0x3eaf18++){let _0x14fe15=_0x422844[_0x3eaf18];if(!(_0x14fe15 instanceof _0x5773e3[_0x1986b4(0x1ed)])&&_0x5773e3['OPERATOR_TOKEN_SET'][_0x1986b4(0x149)](_0x14fe15))return!0x0;}return!0x1;}[_0x4c7e45(0x1a6)](_0x5c8684,_0x45520f,_0x22047a,_0x546cc0,_0x2e4f1c){const _0x51da5d=_0x4c7e45;let _0x2560da=this[_0x51da5d(0x113)](_0x5c8684,!0x1);if(!_0x2560da||_0x2560da===_0x5773e3['ErrorType']['VALUE']||Array[_0x51da5d(0x169)](_0x2560da))return null;this[_0x51da5d(0x139)](),this['_currentUnitId']=_0x45520f;let _0x3275d6=this[_0x51da5d(0x1a2)](_0x2560da,_0x22047a,_0x546cc0,_0x2e4f1c);return this[_0x51da5d(0x15b)]='',this[_0x51da5d(0x1d3)](),_0x3275d6;}['_generateExprTree'](_0x5d9330,_0x42425b,_0x4da8d4,_0x174b02){const _0x33d3cb=_0x4c7e45;let _0x111f14={'value':'','children':[],'startIndex':0x0},_0xf54a7=_0x5d9330;if(_0xf54a7 instanceof _0x5773e3[_0x33d3cb(0x1ed)]&&(_0xf54a7[_0x33d3cb(0xf4)]()===_0x5773e3['DEFAULT_TOKEN_TYPE_ROOT']||_0xf54a7[_0x33d3cb(0xf4)]()===_0x5773e3['DEFAULT_TOKEN_TYPE_PARAMETER'])&&_0xf54a7[_0x33d3cb(0x112)]()[_0x33d3cb(0x181)]===0x1&&(_0xf54a7=_0xf54a7[_0x33d3cb(0x112)]()[0x0]),!(_0xf54a7 instanceof _0x5773e3[_0x33d3cb(0x1ed)]))return this[_0x33d3cb(0x1ae)](_0xf54a7,_0x4da8d4,_0x174b02);let _0x74bb8a=_0xf54a7[_0x33d3cb(0x112)](),_0x5244fa=_0x74bb8a[_0x33d3cb(0x181)],_0x1e656e=[];this['_generateNewFunctionString'](_0xf54a7,_0x1e656e,_0x42425b),_0x111f14['value']=_0x1e656e['join'](''),_0x111f14[_0x33d3cb(0x1ad)]=_0xf54a7['getStartIndex']();let _0x2d2fde=this[_0x33d3cb(0x10b)](_0xf54a7);if(_0x2d2fde===0x2){let _0xd5a794=_0x74bb8a[0x0];if(_0xd5a794 instanceof _0x5773e3['LexerNode']){if(_0xd5a794[_0x33d3cb(0xf4)]()['trim']()!==_0x5773e3[_0x33d3cb(0x170)])return _0x111f14;this[_0x33d3cb(0x189)](_0xd5a794,_0x111f14,_0x42425b,_0x4da8d4,_0x174b02);}return _0x111f14;}else{if(_0x2d2fde===0x1){for(let _0x35cf26=0x0;_0x35cf26<_0x5244fa-0x1;_0x35cf26++){let _0x9d601e=_0x74bb8a[_0x35cf26];if(_0x9d601e instanceof _0x5773e3[_0x33d3cb(0x1ed)]&&_0x35cf26%0x2==0x1){let _0x7ce31c=_0x9d601e[_0x33d3cb(0x112)]();if(_0x7ce31c['length']===0x1&&!(_0x7ce31c[0x0]instanceof _0x5773e3[_0x33d3cb(0x1ed)]))continue;let _0x85fd9f=this['_generateExprTree'](_0x9d601e,_0x42425b,_0x4da8d4,_0x174b02);_0x85fd9f&&_0x111f14[_0x33d3cb(0x193)][_0x33d3cb(0xfe)](_0x85fd9f);}}return _0x111f14;}else{if(_0x2d2fde===0x8){let _0x1330e8=_0x74bb8a[0x0];if(_0x1330e8 instanceof _0x5773e3[_0x33d3cb(0x1ed)]){let _0x544b19=_0x1330e8['getChildren']()[0x0];_0x544b19 instanceof _0x5773e3['LexerNode']&&(_0x111f14[_0x33d3cb(0x1ad)]=_0x544b19[_0x33d3cb(0x1ba)]());}if(this[_0x33d3cb(0xf8)](_0xf54a7))return _0x111f14;}else{if(_0x2d2fde===0x7){let _0x1a633d=_0x74bb8a[0x0];if(_0x1a633d instanceof _0x5773e3[_0x33d3cb(0x1ed)]){let _0x306833=_0x1a633d[_0x33d3cb(0x112)]()[0x0];_0x306833 instanceof _0x5773e3[_0x33d3cb(0x1ed)]&&(_0x111f14[_0x33d3cb(0x1ad)]=_0x306833[_0x33d3cb(0x1ba)]());}}}}}return this[_0x33d3cb(0x1d7)](_0x74bb8a,_0x2d2fde,_0x111f14,_0x42425b,_0x4da8d4,_0x174b02),_0x111f14;}[_0x4c7e45(0x1d7)](_0x1a918,_0x297a7b,_0x4c6f74,_0x11d5e0,_0xcd5a7a,_0x2561c9){const _0x26bff6=_0x4c7e45;for(let _0x4bb28c=0x0;_0x4bb28c<_0x1a918[_0x26bff6(0x181)];_0x4bb28c++){let _0x3c1d75=_0x1a918[_0x4bb28c];if(!(_0x3c1d75 instanceof _0x5773e3[_0x26bff6(0x1ed)])){let _0x24b72c=this[_0x26bff6(0x1ae)](_0x3c1d75,_0xcd5a7a,_0x2561c9);_0x24b72c&&_0x4c6f74[_0x26bff6(0x193)]['push'](_0x24b72c);continue;}let _0x21d560=_0x3c1d75[_0x26bff6(0x112)]();if(_0x21d560[_0x26bff6(0x181)]===0x1&&!(_0x21d560[0x0]instanceof _0x5773e3[_0x26bff6(0x1ed)])){let _0x20a40a=_0x21d560[0x0];if(!_0xcd5a7a(this[_0x26bff6(0x15b)],_0x20a40a)&&!this['_getTableNameFromStructuredRef'](_0x20a40a,_0x2561c9)&&!(0x0,_0x5773e3[_0x26bff6(0xf6)])(_0x20a40a))continue;}if(_0x297a7b===0x8){let _0x2e5472=_0x21d560[0x0];if(_0x2e5472 instanceof _0x5773e3[_0x26bff6(0x1ed)]){if((0x0,_0x5773e3[_0x26bff6(0xf6)])(_0x2e5472['getToken']()['trim']()))continue;_0x3c1d75=_0x2e5472;}}let _0x47067d=this[_0x26bff6(0x1a2)](_0x3c1d75,_0x11d5e0,_0xcd5a7a,_0x2561c9);_0x47067d&&_0x4c6f74['children']['push'](_0x47067d);}}['_checkColonNodeForExprTree'](_0x5848a7){const _0x51ccba=_0x4c7e45;let _0x25a829=_0x5848a7[_0x51ccba(0x112)]();if(_0x25a829[_0x51ccba(0x181)]<0x2)return!0x1;let _0x3a78da=_0x25a829[0x0],_0xe045b3=_0x25a829[0x1];if(!(_0x3a78da instanceof _0x5773e3['LexerNode'])||!(_0xe045b3 instanceof _0x5773e3['LexerNode']))return!0x1;let _0x11d2aa=_0x3a78da[_0x51ccba(0x112)]()[0x0],_0x49c130=_0xe045b3[_0x51ccba(0x112)]()[0x0];if(!(_0x11d2aa instanceof _0x5773e3[_0x51ccba(0x1ed)])||!(_0x49c130 instanceof _0x5773e3[_0x51ccba(0x1ed)]))return!0x1;let _0x4c2ce3=_0x11d2aa['getToken']()['trim'](),_0x220919=_0x49c130[_0x51ccba(0xf4)]()['trim']();return!!(0x0,_0x5773e3[_0x51ccba(0xf6)])(''+_0x4c2ce3+_0x5773e3[_0x51ccba(0x108)][_0x51ccba(0x13e)]+_0x220919);}[_0x4c7e45(0x1ae)](_0x38ea23,_0x55e139,_0xe7f82c){const _0x308415=_0x4c7e45;let _0x29a1a4=_0x38ea23[_0x308415(0x15c)]();return _0x29a1a4[_0x308415(0x1c3)]('{')&&_0x29a1a4[_0x308415(0x17d)]('}')||_0x55e139(this['_currentUnitId'],_0x29a1a4)||this[_0x308415(0x166)](_0x29a1a4,_0xe7f82c)||(0x0,_0x5773e3['isReferenceString'])(_0x29a1a4)?{'value':_0x29a1a4,'children':[],'startIndex':-0x1}:null;}[_0x4c7e45(0x166)](_0x3bb782,_0x225085){const _0x57c08a=_0x4c7e45;let {tableName:_0x55398e}=(0x0,_0x5773e3[_0x57c08a(0x180)])(_0x3bb782);return _0x225085(this[_0x57c08a(0x15b)],_0x55398e)?_0x55398e:null;}[_0x4c7e45(0x189)](_0x49f6c2,_0x130478,_0x524957,_0x436794,_0x2e017f){const _0x34997e=_0x4c7e45;let _0x438f1f=_0x49f6c2[_0x34997e(0x112)]();for(let _0x26c3dd=0x0;_0x26c3dd<_0x438f1f[_0x34997e(0x181)];_0x26c3dd++){let _0x5519f8=_0x438f1f[_0x26c3dd];if(!(_0x5519f8 instanceof _0x5773e3[_0x34997e(0x1ed)]))continue;let _0xa837cc=_0x5519f8[_0x34997e(0x112)]();if(_0xa837cc[_0x34997e(0x181)]===0x1&&!(_0xa837cc[0x0]instanceof _0x5773e3['LexerNode']))continue;let _0x26af88=this[_0x34997e(0x1a2)](_0x5519f8,_0x524957,_0x436794,_0x2e017f);_0x26af88&&_0x130478[_0x34997e(0x193)][_0x34997e(0xfe)](_0x26af88);}}[_0x4c7e45(0x10b)](_0x3fe85e){const _0x356c0c=_0x4c7e45;let _0xe7ab8f=_0x3fe85e[_0x356c0c(0xf4)](),_0x1ec572=_0xe7ab8f[_0x356c0c(0x15c)]()['toUpperCase'](),_0x43eea9=0x0;return _0xe7ab8f===_0x5773e3[_0x356c0c(0x1d9)]?_0x43eea9=0x3:_0xe7ab8f===_0x5773e3[_0x356c0c(0x18b)]?_0x43eea9=0x4:_0xe7ab8f===_0x5773e3['DEFAULT_TOKEN_TYPE_LAMBDA_PARAMETER']?_0x43eea9=0x5:_0x1ec572===_0x5773e3[_0x356c0c(0x12c)]?_0x43eea9=0x2:_0x1ec572===_0x5773e3['DEFAULT_TOKEN_LET_FUNCTION_NAME']?_0x43eea9=0x1:_0x1ec572===_0x5773e3[_0x356c0c(0x108)][_0x356c0c(0x13e)]?_0x43eea9=0x8:_0x5773e3[_0x356c0c(0x116)][_0x356c0c(0x149)](_0x1ec572)?_0x43eea9=0x7:_0x1ec572===_0x5773e3[_0x356c0c(0x132)][_0x356c0c(0x16b)]?this[_0x356c0c(0x1f6)](_0x3fe85e)&&(_0x43eea9=0x9):_0x43eea9=0xa,_0x43eea9;}},_0x54c08c=_0x4c7e45(0x145),_0x514af2=_0x4c7e45(0x17c),_0x2271b4=class extends _0x5773e3['FormulaDependencyGenerator']{constructor(..._0x5e7dd1){const _0x1077e9=_0x4c7e45;super(..._0x5e7dd1),_0x5eaa43(this,_0x1077e9(0x195),new Map());}[_0x4c7e45(0xff)](){const _0x5e861a=_0x4c7e45;super[_0x5e861a(0xff)](),this['_dependencyTreeCache'][_0x5e861a(0x107)]();}async[_0x4c7e45(0x1cf)](_0x1dad26=!0x1){const _0x1e7e89=_0x4c7e45;this[_0x1e7e89(0x1a0)]();let _0x5e3b13=this[_0x1e7e89(0x178)][_0x1e7e89(0x11d)](),_0x54d262=this[_0x1e7e89(0x1cc)][_0x1e7e89(0x150)](),_0x359122=this[_0x1e7e89(0x178)][_0x1e7e89(0x1ce)]();_0x359122!=null&&Object[_0x1e7e89(0x11a)](_0x359122)[_0x1e7e89(0x1fb)](_0x57a6ac=>{const _0x223d75=_0x1e7e89;_0x57a6ac!=null&&Object[_0x223d75(0x11a)](_0x359122[_0x57a6ac])['forEach'](_0x4e3fa5=>{const _0xb5039f=_0x223d75;_0x4e3fa5!=null&&(this[_0xb5039f(0x17b)][_0xb5039f(0x1b8)](_0x57a6ac,_0x4e3fa5),this[_0xb5039f(0x17b)]['clearFeatureFormulaDependency'](_0x57a6ac,_0x4e3fa5),this[_0xb5039f(0x17b)][_0xb5039f(0x1ee)](_0x57a6ac,_0x4e3fa5));});});let _0x250011=this[_0x1e7e89(0x178)][_0x1e7e89(0x1e8)]();await this[_0x1e7e89(0x1de)](_0x5e3b13,_0x54d262,_0x250011),this['_dependencyManagerService']['openKdTree']();let _0xaee580=this[_0x1e7e89(0x147)](),_0x248900=this[_0x1e7e89(0x110)](_0xaee580);return this['_checkIsCycleDependency'](_0x248900)&&this[_0x1e7e89(0x1a7)][_0x1e7e89(0x1b2)](),_0x1dad26&&this[_0x1e7e89(0x1a7)]['setDependencyTreeModelData'](this['_getAllDependencyJson'](Array[_0x1e7e89(0x10a)](this[_0x1e7e89(0x195)][_0x1e7e89(0x168)]()))),this['_dependencyTreeCache']['clear'](),this['_dependencyRTreeCacheForAddressFunction']['clear'](),this[_0x1e7e89(0x17b)][_0x1e7e89(0x1bd)](),this[_0x1e7e89(0x1a7)][_0x1e7e89(0x143)](),Promise['resolve'](_0x248900);}[_0x4c7e45(0x1d0)](_0x54a9d6,_0x151ab3){const _0x7d09eb=_0x4c7e45;let _0x5a1d7a=[_0x54a9d6];for(;_0x5a1d7a['length']>0x0;){let _0x26a535=_0x5a1d7a[_0x5a1d7a['length']-0x1];if((_0x151ab3[_0x7d09eb(0x16e)](_0x26a535)||0x0)===0x0){_0x151ab3[_0x7d09eb(0x138)](_0x26a535,0x1);let _0x55eea7=this[_0x7d09eb(0x195)]['get'](_0x26a535);if(_0x55eea7==null){_0x151ab3[_0x7d09eb(0x138)](_0x26a535,0x2),_0x5a1d7a['pop']();continue;}let _0x20567b=this[_0x7d09eb(0x17b)][_0x7d09eb(0x136)](_0x55eea7[_0x7d09eb(0xf3)]());for(let _0x41bdfb of _0x20567b){let _0x297813=_0x151ab3[_0x7d09eb(0x16e)](_0x41bdfb)||0x0;if(_0x297813===0x1)return!0x0;_0x297813===0x0&&_0x5a1d7a[_0x7d09eb(0xfe)](_0x41bdfb);}}else _0x151ab3[_0x7d09eb(0x138)](_0x26a535,0x2),_0x5a1d7a['pop']();}return!0x1;}[_0x4c7e45(0x179)](_0x26747d){const _0x2459a4=_0x4c7e45;let _0x141f0c=new Map();for(let _0x3c4b72 of _0x26747d)if(!_0x141f0c['has'](_0x3c4b72['treeId'])&&this['_isCyclicUtilMap'](_0x3c4b72[_0x2459a4(0x19b)],_0x141f0c))return!0x0;return _0x141f0c[_0x2459a4(0x107)](),!0x1;}['_getFeatureFormulaTree'](_0x3e8452,_0x46fb09,_0x275ae6){const _0x350df0=_0x4c7e45;let {unitId:_0x7532d6,subUnitId:_0x4188fa,dependencyRanges:_0x3d1e3a,getDirtyData:_0x3e01d0}=_0x275ae6,_0x10fd1a=new _0x5773e3[(_0x350df0(0x1df))](_0x46fb09||(0x0,_0x5773e3[_0x350df0(0x1fa)])(this[_0x350df0(0x17b)]));_0x10fd1a[_0x350df0(0x1f8)]=_0x7532d6,_0x10fd1a[_0x350df0(0x135)]=_0x4188fa,_0x10fd1a[_0x350df0(0x121)]=_0x3d1e3a,_0x10fd1a[_0x350df0(0x1f1)]=_0x3e01d0;let _0x42738f=_0x3e01d0(this[_0x350df0(0x178)][_0x350df0(0x1f1)](),this[_0x350df0(0x1a7)][_0x350df0(0x1be)]());return _0x10fd1a['featureDirtyRanges']=this[_0x350df0(0x194)](_0x42738f[_0x350df0(0x1f0)]),_0x10fd1a[_0x350df0(0x15a)]=_0x3e8452,_0x10fd1a[_0x350df0(0x102)]=_0x5773e3[_0x350df0(0x1fc)][_0x350df0(0x1c0)],this[_0x350df0(0x17b)]['addFeatureFormulaDependency'](_0x7532d6,_0x4188fa,_0x3e8452,_0x10fd1a),this[_0x350df0(0x195)]['set'](_0x10fd1a[_0x350df0(0x19b)],_0x10fd1a),this[_0x350df0(0x17b)][_0x350df0(0x175)](_0x275ae6[_0x350df0(0x1f8)],_0x275ae6[_0x350df0(0x135)],_0x3e8452)&&(_0x10fd1a['isCache']=!0x0),_0x10fd1a;}[_0x4c7e45(0xf5)](_0x13205d,_0x561df7,_0x9a1fca){const _0x300b5c=_0x4c7e45;for(let _0x46b556 of _0x561df7){let _0xd58bfa=_0x13205d[_0x46b556];if(_0xd58bfa==null)continue;let _0x5ba8f4=Object[_0x300b5c(0x11a)](_0xd58bfa);for(let _0x494768 of _0x5ba8f4){let _0x475fb1=_0xd58bfa[_0x494768];if(_0x475fb1==null)continue;let {rowCount:_0x504b3d=0x1/0x0,columnCount:_0x10627c=0x1/0x0}=this[_0x300b5c(0x178)][_0x300b5c(0x187)](_0x46b556,_0x494768)||{},_0x1d3cd8=Object[_0x300b5c(0x11a)](_0x475fb1);for(let _0x23ae39 of _0x1d3cd8){var _0x2e7878;let _0x2da6ef=this['_dependencyManagerService'][_0x300b5c(0x1c5)](_0x23ae39),{f:_0x533f5e,ranges:_0x2d8461}=_0x475fb1[_0x23ae39],_0x1075e2=!0x1;_0x2da6ef&&(_0x1075e2=!0x0);let {firstRow:_0x250666,firstColumn:_0x78c44}=this[_0x300b5c(0xf7)](_0x2d8461),_0x4481db=this[_0x300b5c(0x17b)][_0x300b5c(0x119)](_0x46b556,_0x494768,_0x23ae39),_0xc458b8=new _0x5773e3[(_0x300b5c(0x1df))]((_0x2e7878=_0x4481db==null?void 0x0:_0x4481db['getValue'](0x0,0x0))==null?(0x0,_0x5773e3['generateRandomDependencyTreeId'])(this[_0x300b5c(0x17b)]):_0x2e7878);for(let _0x1f6309=0x0;_0x1f6309<_0x2d8461[_0x300b5c(0x181)];_0x1f6309++){let _0x2ebb0c=_0x2d8461[_0x1f6309],{startRow:_0x3bf371,startColumn:_0x517bd1}=_0x2ebb0c,{endRow:_0x1b5f78,endColumn:_0x58e333}=_0x2ebb0c;_0x1b5f78=Math[_0x300b5c(0x124)](_0x1b5f78,_0x504b3d-0x1),_0x58e333=Math[_0x300b5c(0x124)](_0x58e333,_0x10627c-0x1);for(let _0x5a0759=_0x3bf371;_0x5a0759<=_0x1b5f78;_0x5a0759++)for(let _0x66c738=_0x517bd1;_0x66c738<=_0x58e333;_0x66c738++){let _0x2c621f=_0x66c738-_0x78c44,_0x38e3b1=_0x5a0759-_0x250666;if(_0x2c621f===0x0&&_0x38e3b1===0x0){_0xc458b8['formula']=_0x533f5e,_0xc458b8[_0x300b5c(0x1f8)]=_0x46b556,_0xc458b8['subUnitId']=_0x494768,_0xc458b8[_0x300b5c(0x1ac)]=_0x23ae39,_0xc458b8[_0x300b5c(0x102)]=_0x5773e3[_0x300b5c(0x1fc)][_0x300b5c(0x103)],_0xc458b8[_0x300b5c(0x163)]=_0x1075e2,_0x9a1fca[_0x300b5c(0xfe)](_0xc458b8),this[_0x300b5c(0x195)][_0x300b5c(0x138)](_0xc458b8[_0x300b5c(0x19b)],_0xc458b8),this['_dependencyManagerService'][_0x300b5c(0xf9)](_0x46b556,_0x494768,_0x23ae39,_0xc458b8),this[_0x300b5c(0x17b)][_0x300b5c(0x171)](_0xc458b8);continue;}let _0x1f13d5=new _0x5773e3['FormulaDependencyTreeVirtual']();_0x1f13d5['treeId']=(_0x4481db==null?void 0x0:_0x4481db['getValue'](_0x2c621f,_0x38e3b1))||(0x0,_0x5773e3[_0x300b5c(0x1fa)])(this['_dependencyManagerService']),_0x1f13d5[_0x300b5c(0x118)]=_0xc458b8,_0x1f13d5[_0x300b5c(0x1f3)]=_0x2c621f,_0x1f13d5['refOffsetY']=_0x38e3b1,_0x1f13d5[_0x300b5c(0x163)]=_0x1075e2,_0x1f13d5[_0x300b5c(0x102)]=_0x5773e3[_0x300b5c(0x1fc)][_0x300b5c(0x103)],this[_0x300b5c(0x17b)][_0x300b5c(0xf9)](_0x46b556,_0x494768,_0x23ae39,_0x1f13d5),this[_0x300b5c(0x17b)]['addFormulaDependencyByDefinedName'](_0x1f13d5),_0x9a1fca[_0x300b5c(0xfe)](_0x1f13d5),this['_dependencyTreeCache']['set'](_0x1f13d5[_0x300b5c(0x19b)],_0x1f13d5);}}this['_dependencyManagerService'][_0x300b5c(0x137)](_0x23ae39);}}}}[_0x4c7e45(0x1e7)](_0xe7d2c0,_0x38b173,_0x596e99,_0x1219ae){const _0x25523a=_0x4c7e45;for(let _0x34fb72 of _0xe7d2c0){let _0x4e369f=_0x38b173[_0x34fb72];if(_0x4e369f==null)continue;let _0x448472=Object[_0x25523a(0x11a)](_0x4e369f);for(let _0x2c01a7 of _0x448472){let _0x6fa7d8=new _0x5e7a81['ObjectMatrix'](_0x4e369f[_0x2c01a7]||{}),_0x1354c3=new Map();_0x6fa7d8[_0x25523a(0x12e)]((_0x512190,_0x5a06b4,_0x1af3d9)=>{const _0x100c02=_0x25523a;if(_0x1af3d9==null)return!0x0;let {x:_0x4deac2=0x0,y:_0x17b982=0x0,si:_0x2b63ed}=_0x1af3d9;if(!(_0x4deac2===0x0&&_0x17b982===0x0&&_0x2b63ed!=null))return!0x0;let _0x25a0ca=this[_0x100c02(0x1a3)](_0x34fb72,_0x2c01a7,_0x512190,_0x5a06b4,_0x596e99,_0x1af3d9),_0x29aa2f=this[_0x100c02(0x17b)]['getFormulaDependency'](_0x34fb72,_0x2c01a7,_0x512190,_0x5a06b4);_0x29aa2f==null?(this[_0x100c02(0x17b)]['addFormulaDependency'](_0x34fb72,_0x2c01a7,_0x512190,_0x5a06b4,_0x25a0ca),this[_0x100c02(0x17b)][_0x100c02(0x171)](_0x25a0ca)):_0x25a0ca['treeId']=_0x29aa2f,_0x1354c3[_0x100c02(0x138)](_0x2b63ed,_0x25a0ca),_0x1219ae[_0x100c02(0xfe)](_0x25a0ca),this['_dependencyTreeCache']['set'](_0x25a0ca[_0x100c02(0x19b)],_0x25a0ca);}),_0x6fa7d8[_0x25523a(0x12e)]((_0x172f20,_0x464d3a,_0x3611cb)=>{const _0x4f28f1=_0x25523a;if(_0x3611cb==null)return!0x0;let {x:_0x560d11=0x0,y:_0x16304a=0x0,si:_0x18b331}=_0x3611cb;if(_0x560d11===0x0&&_0x16304a===0x0&&_0x18b331!=null)return!0x0;let _0x41fa26;if(_0x18b331&&_0x1354c3['has'](_0x18b331)){let _0x5bd848=_0x1354c3[_0x4f28f1(0x16e)](_0x18b331);_0x41fa26=this['_createVirtualFDtree'](_0x5bd848,_0x3611cb);}else _0x41fa26=this[_0x4f28f1(0x1a3)](_0x34fb72,_0x2c01a7,_0x172f20,_0x464d3a,_0x596e99,_0x3611cb);let _0xd7fbb8=this[_0x4f28f1(0x17b)][_0x4f28f1(0x1d5)](_0x34fb72,_0x2c01a7,_0x172f20,_0x464d3a);_0xd7fbb8==null?(this[_0x4f28f1(0x17b)][_0x4f28f1(0x1b5)](_0x34fb72,_0x2c01a7,_0x172f20,_0x464d3a,_0x41fa26),this[_0x4f28f1(0x17b)]['addFormulaDependencyByDefinedName'](_0x41fa26)):_0x41fa26[_0x4f28f1(0x19b)]=_0xd7fbb8,_0x1219ae[_0x4f28f1(0xfe)](_0x41fa26),this['_dependencyTreeCache'][_0x4f28f1(0x138)](_0x41fa26[_0x4f28f1(0x19b)],_0x41fa26);}),_0x1354c3[_0x25523a(0x107)]();}}}[_0x4c7e45(0x1a3)](_0x3dfe41,_0x3d5bb0,_0x390c64,_0x54413e,_0x7b3099,_0x323142){const _0x3d16b2=_0x4c7e45;let {f:_0x549c65,x:_0xfff75f=0x0,y:_0x1828c2=0x0}=_0x323142,_0x5f5a07=new _0x5773e3[(_0x3d16b2(0x1df))]((0x0,_0x5773e3['generateRandomDependencyTreeId'])(this[_0x3d16b2(0x17b)])),_0x3fa6f3=_0x7b3099[_0x3dfe41][_0x3d5bb0];return _0x5f5a07[_0x3d16b2(0x196)]=_0x549c65,_0x5f5a07[_0x3d16b2(0x1f8)]=_0x3dfe41,_0x5f5a07[_0x3d16b2(0x135)]=_0x3d5bb0,_0x5f5a07[_0x3d16b2(0x11b)]=_0x390c64,_0x5f5a07[_0x3d16b2(0x11f)]=_0x54413e,_0x5f5a07['rowCount']=_0x3fa6f3[_0x3d16b2(0x182)],_0x5f5a07[_0x3d16b2(0x13c)]=_0x3fa6f3[_0x3d16b2(0x13c)],_0x5f5a07;}[_0x4c7e45(0x147)](){const _0x4954bd=_0x4c7e45;let _0x524470=[],_0x1edbd5=new Set(),_0x1de164=this[_0x4954bd(0x178)][_0x4954bd(0x142)](),_0x3b7469=this[_0x4954bd(0x178)][_0x4954bd(0x14f)](),_0x32551c=this['_dependencyManagerService'][_0x4954bd(0x136)](_0x3b7469),_0x538aba=this['_dependencyRTreeCacheForAddressFunction'][_0x4954bd(0x16d)](_0x3b7469);for(let _0x3af8a2 of _0x538aba)_0x32551c[_0x4954bd(0x141)](_0x3af8a2);for(let [_0x13dd8f,_0xfdc049]of this[_0x4954bd(0x195)])(_0x1de164||_0xfdc049['isDirty']||_0xfdc049['dependencySheetName'](this[_0x4954bd(0x178)][_0x4954bd(0x123)]())||_0x32551c[_0x4954bd(0x149)](_0x13dd8f)&&!_0xfdc049[_0x4954bd(0x127)](this[_0x4954bd(0x178)][_0x4954bd(0x125)]()))&&!_0x1edbd5[_0x4954bd(0x149)](_0x13dd8f)&&(_0x524470['push'](_0xfdc049),_0x1edbd5[_0x4954bd(0x141)](_0x13dd8f));for(let [_0x750f79,_0x495bd9]of this[_0x4954bd(0x195)])_0x495bd9[_0x4954bd(0x120)]||(_0x495bd9[_0x4954bd(0x121)][_0x4954bd(0x181)]=0x0);return _0x524470;}[_0x4c7e45(0x19e)](_0x563e99){const _0x2f1afb=_0x4c7e45;return this[_0x2f1afb(0x195)]['get'](_0x563e99);}[_0x4c7e45(0x111)](_0x2d2e49){const _0x1f205a=_0x4c7e45;return(0x0,_0x5773e3['generateAstNode'])(_0x2d2e49['unitId'],_0x2d2e49[_0x1f205a(0x196)],this[_0x1f205a(0x1aa)],this[_0x1f205a(0x199)],this[_0x1f205a(0x178)]);}*[_0x4c7e45(0x1a4)](_0x270b84,_0x15defc){const _0x623256=_0x4c7e45;let _0x4b613d=_0x270b84,_0x3abaf3=new Set();for(;_0x4b613d[_0x623256(0x181)]>0x0;){let _0x441e0a=_0x4b613d['pop']();if(_0x3abaf3[_0x623256(0x107)](),_0x441e0a===void 0x0||_0x441e0a[_0x623256(0x1b7)]())continue;if(_0x441e0a[_0x623256(0x14e)]()){yield _0x441e0a,_0x441e0a['setSkip'](),_0x15defc[_0x623256(0x141)](_0x441e0a['treeId']);continue;}let _0x1d4d0f=this[_0x623256(0x17b)][_0x623256(0x136)](_0x441e0a[_0x623256(0xf3)](),_0x15defc),_0x32c173=this['_dependencyRTreeCacheForAddressFunction'][_0x623256(0x16d)](_0x441e0a['toRTreeItem'](),_0x15defc);for(let _0x5f078a of _0x32c173)_0x1d4d0f['add'](_0x5f078a);for(let _0x1fae66 of _0x1d4d0f){let _0x319d5f=this[_0x623256(0x195)][_0x623256(0x16e)](_0x1fae66);if(!_0x319d5f){console['error'](_0x623256(0x10e),_0x1fae66);continue;}_0x319d5f['isAdded']()||_0x441e0a['isSkip']()||_0x3abaf3[_0x623256(0x141)](_0x319d5f);}if(_0x1d4d0f[_0x623256(0x107)](),_0x3abaf3['size']===0x0)yield _0x441e0a,_0x441e0a['setSkip'](),_0x15defc[_0x623256(0x141)](_0x441e0a['treeId']);else{_0x441e0a[_0x623256(0x16a)](),_0x4b613d['push'](_0x441e0a);for(let _0x3f84a9 of _0x3abaf3)_0x4b613d[_0x623256(0xfe)](_0x3f84a9);}}_0x4b613d[_0x623256(0x181)]=0x0,_0x3abaf3['clear']();}['_calculateRunList'](_0x3969c0){const _0x1544c8=_0x4c7e45;let _0x23fe77=[],_0x2b4e0c=new Set();for(let _0x3a0bf5 of this['_traverse'](_0x3969c0,_0x2b4e0c))_0x23fe77[_0x1544c8(0xfe)](_0x3a0bf5);return _0x23fe77;}async['_getAllTreeList'](){const _0x25b91c=_0x4c7e45;return await this['_initializeGenerateTreeList'](),Array[_0x25b91c(0x10a)](this[_0x25b91c(0x195)][_0x25b91c(0x168)]());}[_0x4c7e45(0x109)](_0x408f6d){const _0x54a776=_0x4c7e45;return this[_0x54a776(0x17b)][_0x54a776(0x136)](_0x408f6d[_0x54a776(0xf3)]());}[_0x4c7e45(0x183)](_0x518b9b){const _0x197751=_0x4c7e45;let _0x4290c4=new Set(),_0x2f882b=_0x518b9b['rangeList'];for(let [_0x4ce40a,_0x27f681]of this['_dependencyTreeCache'])for(let _0x12aa92 of _0x2f882b){let _0x552570=_0x12aa92[_0x197751(0x1f8)],_0x4a9329=_0x12aa92[_0x197751(0x128)];if(_0x27f681['unitId']!==_0x552570||_0x27f681[_0x197751(0x135)]!==_0x4a9329)continue;let _0x2e5411=_0x12aa92[_0x197751(0x165)];if(_0x27f681[_0x197751(0x1ca)](_0x2e5411)){_0x4290c4[_0x197751(0x141)](_0x4ce40a);break;}}return _0x4290c4;}[_0x4c7e45(0x1c2)](){const _0xb857e1=_0x4c7e45;this[_0xb857e1(0x17b)][_0xb857e1(0x122)]();}[_0x4c7e45(0x198)](){const _0x1a9eac=_0x4c7e45;this[_0x1a9eac(0xfd)][_0x1a9eac(0x107)](),this[_0x1a9eac(0x195)][_0x1a9eac(0x107)](),this[_0x1a9eac(0x17b)][_0x1a9eac(0x1bd)]();}},_0x451a51=class extends _0x5773e3['CalculateFormulaService']{async['_apply'](_0x20c36d=!0x1){const _0x5d51f8=_0x4c7e45;_0x20c36d?this[_0x5d51f8(0x1a7)][_0x5d51f8(0x18f)](_0x5773e3[_0x5d51f8(0x1b1)][_0x5d51f8(0x1ef)]):this[_0x5d51f8(0x1a7)][_0x5d51f8(0x18f)](_0x5773e3[_0x5d51f8(0x1b1)][_0x5d51f8(0x1c1)]),this[_0x5d51f8(0x1e1)]['next'](this[_0x5d51f8(0x1a7)]['getRuntimeState']());let _0x58e6ca=await this[_0x5d51f8(0x174)][_0x5d51f8(0x1cf)](this['_isCalculateTreeModel']),_0x2cb244=this[_0x5d51f8(0x172)];_0x20c36d?(this['_runtimeService'][_0x5d51f8(0x18f)](_0x5773e3[_0x5d51f8(0x1b1)]['START_CALCULATION_ARRAY_FORMULA']),this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1b3)](_0x58e6ca['length'])):(this[_0x5d51f8(0x1a7)][_0x5d51f8(0x18f)](_0x5773e3[_0x5d51f8(0x1b1)][_0x5d51f8(0x15d)]),this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1db)](_0x58e6ca[_0x5d51f8(0x181)])),this[_0x5d51f8(0x1e1)]['next'](this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1cb)]());let _0x42deaa=[],_0x295412=this['_configService'][_0x5d51f8(0x18a)](_0x5773e3[_0x5d51f8(0x16f)]),_0x15b073=(_0x295412==null?void 0x0:_0x295412[_0x5d51f8(0x1f7)])||_0x5773e3[_0x5d51f8(0x117)],_0x32164c=0x0,_0x5e85d4=_0x58e6ca[_0x5d51f8(0x181)];for(;_0x58e6ca[_0x5d51f8(0x181)]>0x0;){let _0x48f4fb=_0x58e6ca['pop'](),_0xf1e73e=(0x0,_0x5773e3[_0x5d51f8(0x12a)])(_0x48f4fb[_0x5d51f8(0x1f8)],_0x48f4fb[_0x5d51f8(0x196)],this[_0x5d51f8(0x1aa)],this[_0x5d51f8(0x199)],this[_0x5d51f8(0x178)]),_0x2648f1={'node':_0xf1e73e,'refOffsetX':_0x48f4fb[_0x5d51f8(0x1f3)],'refOffsetY':_0x48f4fb['refOffsetY']},_0x42d8ad=_0x48f4fb[_0x5d51f8(0x1f1)];if(_0x32164c%_0x15b073===0x0&&(await new Promise(_0x2b05bc=>{const _0x15b883=_0x5d51f8;let _0x3248f2=(0x0,_0x5e7a81[_0x15b883(0x133)])(_0x2b05bc);_0x42deaa[_0x15b883(0xfe)](_0x3248f2);}),_0x20c36d?(this[_0x5d51f8(0x1a7)][_0x5d51f8(0x18f)](_0x5773e3['FormulaExecuteStageType'][_0x5d51f8(0x1e5)]),this['_runtimeService'][_0x5d51f8(0x1fe)](_0x32164c+0x1)):(this['_runtimeService']['setFormulaExecuteStage'](_0x5773e3['FormulaExecuteStageType'][_0x5d51f8(0x1fd)]),this['_runtimeService'][_0x5d51f8(0x190)](_0x32164c+0x1)),this[_0x5d51f8(0x1e1)][_0x5d51f8(0xfc)](this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1cb)]()),this[_0x5d51f8(0x1a7)][_0x5d51f8(0x18e)]()||_0x2648f1==null&&_0x42d8ad==null)){this[_0x5d51f8(0x1a7)]['setFormulaExecuteStage'](_0x5773e3[_0x5d51f8(0x1b1)]['IDLE']),this['_runtimeService'][_0x5d51f8(0x160)](),this['_executionCompleteListener$'][_0x5d51f8(0xfc)](this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1be)]());return;}this[_0x5d51f8(0x1a7)][_0x5d51f8(0x14a)](_0x48f4fb[_0x5d51f8(0x11b)],_0x48f4fb[_0x5d51f8(0x11f)],_0x48f4fb[_0x5d51f8(0x182)],_0x48f4fb[_0x5d51f8(0x13c)],_0x48f4fb[_0x5d51f8(0x135)],_0x48f4fb[_0x5d51f8(0x1f8)]);let _0x128343;if(_0x42d8ad!=null&&_0x48f4fb[_0x5d51f8(0x15a)]!=null){let {runtimeCellData:_0x18e5c5,dirtyRanges:_0x465874}=_0x42d8ad(this[_0x5d51f8(0x178)][_0x5d51f8(0x1f1)](),this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1be)]());this[_0x5d51f8(0x1a7)][_0x5d51f8(0x114)](_0x48f4fb['featureId'],_0x18e5c5),this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1e2)](_0x48f4fb[_0x5d51f8(0x15a)],_0x465874);}else _0x2648f1!=null&&(_0x128343=_0x2cb244[_0x5d51f8(0x176)](_0x2648f1['node'])?await _0x2cb244[_0x5d51f8(0x1e6)](_0x2648f1):_0x2cb244['execute'](_0x2648f1),_0x48f4fb['formulaId']==null?this[_0x5d51f8(0x1a7)]['setRuntimeData'](_0x128343):this[_0x5d51f8(0x1a7)]['setRuntimeOtherData'](_0x48f4fb[_0x5d51f8(0x1ac)],_0x48f4fb[_0x5d51f8(0x1f3)],_0x48f4fb['refOffsetY'],_0x128343));_0xf1e73e['resetCalculationState'](),_0x32164c++;}return _0x42deaa[_0x5d51f8(0x1fb)](_0x5be6b9=>_0x5be6b9()),_0x42deaa=[],_0x5e85d4>0x0?this[_0x5d51f8(0x1a7)][_0x5d51f8(0x13d)]():_0x20c36d||this[_0x5d51f8(0x1a7)]['markedAsNoFunctionsExecuted'](),this[_0x5d51f8(0x1a7)][_0x5d51f8(0x1be)]();}},_0xb05b84=class extends _0x5773e3['DependencyManagerBaseService']{constructor(..._0x2f1bf6){const _0x3910f7=_0x4c7e45;super(..._0x2f1bf6),_0x5eaa43(this,_0x3910f7(0x14d),new Map()),_0x5eaa43(this,_0x3910f7(0x19f),new _0x5e7a81['RTree'](!0x0));}[_0x4c7e45(0x186)](){const _0x41ebc6=_0x4c7e45;this[_0x41ebc6(0x159)][_0x41ebc6(0x107)](),this[_0x41ebc6(0x1dd)][_0x41ebc6(0x107)](),this[_0x41ebc6(0x153)][_0x41ebc6(0x107)](),this['_dependencyRTreeCache'][_0x41ebc6(0x107)](),this[_0x41ebc6(0x14d)]['clear'](),this[_0x41ebc6(0x158)](),this[_0x41ebc6(0x167)][_0x41ebc6(0x107)]();}[_0x4c7e45(0xf9)](_0x2d3ac8,_0x215346,_0x3fc7a5,_0x3c2829){const _0xcc7543=_0x4c7e45;this[_0xcc7543(0x159)][_0xcc7543(0x149)](_0x2d3ac8)||this[_0xcc7543(0x159)][_0xcc7543(0x138)](_0x2d3ac8,new Map());let _0x4d709c=this['_otherFormulaData'][_0xcc7543(0x16e)](_0x2d3ac8);_0x4d709c['has'](_0x215346)||_0x4d709c[_0xcc7543(0x138)](_0x215346,new Map());let _0xc9776f=_0x4d709c[_0xcc7543(0x16e)](_0x215346);_0xc9776f[_0xcc7543(0x149)](_0x3fc7a5)||_0xc9776f[_0xcc7543(0x138)](_0x3fc7a5,new _0x5e7a81[(_0xcc7543(0x164))]()),_0xc9776f[_0xcc7543(0x16e)](_0x3fc7a5)[_0xcc7543(0x1ab)](_0x3c2829['refOffsetX'],_0x3c2829[_0xcc7543(0x185)],_0x3c2829['treeId']);}['removeOtherFormulaDependency'](_0x5e01d8,_0x4a719c,_0x2efef0){const _0x4dcdcf=_0x4c7e45;let _0x253497=this[_0x4dcdcf(0x159)]['get'](_0x5e01d8);if(_0x253497&&_0x253497[_0x4dcdcf(0x149)](_0x4a719c)){let _0x5ab7e1=_0x253497[_0x4dcdcf(0x16e)](_0x4a719c);_0x2efef0[_0x4dcdcf(0x1fb)](_0x267e01=>{const _0x480a95=_0x4dcdcf;let _0x47d7c1=_0x5ab7e1['get'](_0x267e01);_0x47d7c1!=null&&(_0x47d7c1[_0x480a95(0x12e)]((_0x33d3c3,_0x29c4aa,_0x1aab2f)=>{const _0x41d401=_0x480a95;this[_0x41d401(0x1f5)](_0x1aab2f),this['_removeAllTreeMap'](_0x1aab2f);}),_0x5ab7e1['delete'](_0x267e01),this[_0x480a95(0x167)][_0x480a95(0xfa)](_0x267e01));}),_0x5ab7e1[_0x4dcdcf(0x11c)]===0x0&&_0x253497[_0x4dcdcf(0xfa)](_0x4a719c),_0x253497[_0x4dcdcf(0x11c)]===0x0&&this['_otherFormulaData'][_0x4dcdcf(0xfa)](_0x5e01d8);}}[_0x4c7e45(0x1b8)](_0x5f0d92,_0x10bb2e){const _0x46fa72=_0x4c7e45;let _0x9b4ed7=this['_otherFormulaData'][_0x46fa72(0x16e)](_0x5f0d92);if(_0x10bb2e&&_0x9b4ed7&&_0x9b4ed7[_0x46fa72(0x149)](_0x10bb2e)){let _0x5f3389=_0x9b4ed7['get'](_0x10bb2e);this[_0x46fa72(0x13f)](_0x5f0d92,_0x10bb2e);for(let _0x1da9e3 of _0x5f3389['keys']()){let _0x2c607d=_0x5f3389[_0x46fa72(0x16e)](_0x1da9e3);_0x2c607d!=null&&(_0x2c607d[_0x46fa72(0x12e)]((_0xa9cdd0,_0x590e3e,_0x1dcb88)=>{const _0x5c6c8d=_0x46fa72;this[_0x5c6c8d(0x14d)][_0x5c6c8d(0x16e)](_0x1dcb88)&&this[_0x5c6c8d(0x148)](_0x1dcb88);}),this[_0x46fa72(0x167)][_0x46fa72(0xfa)](_0x1da9e3));}_0x5f3389['clear']();}else{if(_0x9b4ed7){for(let _0xf608ee of _0x9b4ed7[_0x46fa72(0x11a)]()){let _0x291bad=_0x9b4ed7[_0x46fa72(0x16e)](_0xf608ee);this['_removeDependencyRTreeCacheById'](_0x5f0d92,_0xf608ee);for(let _0x4e4d26 of _0x291bad['keys']()){let _0x3d712e=_0x291bad[_0x46fa72(0x16e)](_0x4e4d26);_0x3d712e!=null&&(_0x3d712e['forValue']((_0x10c198,_0x46b174,_0xe611c8)=>{const _0x38e8df=_0x46fa72;this[_0x38e8df(0x14d)]['get'](_0xe611c8)&&this['_removeAllTreeMap'](_0xe611c8);}),this['_otherFormulaDataMainData'][_0x46fa72(0xfa)](_0x4e4d26));}}this[_0x46fa72(0x159)]['delete'](_0x5f0d92);}}}[_0x4c7e45(0x192)](_0x3b9c15,_0x1c7209,_0x1340a1,_0x1b1c45){const _0x5cfc74=_0x4c7e45;this[_0x5cfc74(0x1dd)]['has'](_0x3b9c15)||this[_0x5cfc74(0x1dd)]['set'](_0x3b9c15,new Map());let _0x1ca15c=this[_0x5cfc74(0x1dd)][_0x5cfc74(0x16e)](_0x3b9c15);_0x1ca15c[_0x5cfc74(0x149)](_0x1c7209)||_0x1ca15c[_0x5cfc74(0x138)](_0x1c7209,new Map()),_0x1ca15c[_0x5cfc74(0x16e)](_0x1c7209)[_0x5cfc74(0x138)](_0x1340a1,_0x1b1c45[_0x5cfc74(0x19b)]);}['removeFeatureFormulaDependency'](_0x33d3b3,_0x253be3,_0x2a8eac){const _0xd584c7=_0x4c7e45;let _0xb2be87=this[_0xd584c7(0x1dd)][_0xd584c7(0x16e)](_0x33d3b3);if(_0xb2be87&&_0xb2be87[_0xd584c7(0x149)](_0x253be3)){let _0x397f1b=_0xb2be87['get'](_0x253be3);_0x2a8eac[_0xd584c7(0x1fb)](_0x256467=>{const _0x4bdf5d=_0xd584c7;let _0x4cfc35=_0x397f1b[_0x4bdf5d(0x16e)](_0x256467);_0x4cfc35!=null&&(this[_0x4bdf5d(0x1f5)](_0x4cfc35),_0x397f1b['delete'](_0x256467),this[_0x4bdf5d(0x148)](_0x4cfc35));});}}['clearFeatureFormulaDependency'](_0x1caf9c,_0xb5035){const _0x415da6=_0x4c7e45;let _0x14bdf0=this[_0x415da6(0x1dd)]['get'](_0x1caf9c);if(_0xb5035&&_0x14bdf0&&_0x14bdf0[_0x415da6(0x149)](_0xb5035)){let _0x267e87=_0x14bdf0['get'](_0xb5035);this[_0x415da6(0x13f)](_0x1caf9c,_0xb5035),_0x267e87['forEach'](_0x477999=>{const _0x1eca63=_0x415da6;_0x477999!=null&&this[_0x1eca63(0x148)](_0x477999);}),_0x267e87[_0x415da6(0x107)]();}else _0x14bdf0&&(_0x14bdf0[_0x415da6(0x1fb)]((_0x1a91f5,_0x110640)=>{const _0x43ea72=_0x415da6;this[_0x43ea72(0x13f)](_0x1caf9c,_0x110640),_0x1a91f5['forEach'](_0x2652d3=>{_0x2652d3!=null&&this['_removeAllTreeMap'](_0x2652d3);});}),this[_0x415da6(0x1dd)]['delete'](_0x1caf9c));}[_0x4c7e45(0x1b5)](_0x158021,_0x3c8e85,_0x2d4dac,_0x36e651,_0x4d171b){const _0xc77020=_0x4c7e45;this[_0xc77020(0x153)][_0xc77020(0x149)](_0x158021)||this[_0xc77020(0x153)][_0xc77020(0x138)](_0x158021,new Map());let _0x45aec9=this[_0xc77020(0x153)][_0xc77020(0x16e)](_0x158021);_0x45aec9['has'](_0x3c8e85)||_0x45aec9[_0xc77020(0x138)](_0x3c8e85,new _0x5e7a81[(_0xc77020(0x164))]()),_0x45aec9[_0xc77020(0x16e)](_0x3c8e85)[_0xc77020(0x1ab)](_0x2d4dac,_0x36e651,_0x4d171b[_0xc77020(0x19b)]);}[_0x4c7e45(0x156)](_0xe35428,_0x1694c4,_0x20e3a2,_0x38ac5f){const _0x55b078=_0x4c7e45;let _0x26f455=this[_0x55b078(0x153)][_0x55b078(0x16e)](_0xe35428);if(_0x26f455&&_0x26f455[_0x55b078(0x149)](_0x1694c4)){let _0x44730e=_0x26f455['get'](_0x1694c4),_0x46d971=_0x44730e[_0x55b078(0x15f)](_0x20e3a2,_0x38ac5f);if(_0x46d971==null)return;this[_0x55b078(0x1f5)](_0x46d971),_0x44730e[_0x55b078(0x1d4)](_0x20e3a2,_0x38ac5f),this[_0x55b078(0x148)](_0x46d971);}}[_0x4c7e45(0x1ee)](_0x2d026b,_0x4a43b4){const _0x586669=_0x4c7e45;let _0x23abfb=this[_0x586669(0x153)][_0x586669(0x16e)](_0x2d026b);if(_0x4a43b4&&_0x23abfb&&_0x23abfb[_0x586669(0x149)](_0x4a43b4)){let _0x50c319=_0x23abfb[_0x586669(0x16e)](_0x4a43b4);this[_0x586669(0x13f)](_0x2d026b,_0x4a43b4),_0x50c319[_0x586669(0x12e)]((_0x575171,_0x5b45b4,_0x2222bd)=>{if(_0x2222bd==null)return!0x0;this['_removeAllTreeMap'](_0x2222bd);}),_0x50c319[_0x586669(0x186)]();}else _0x23abfb&&(_0x23abfb[_0x586669(0x1fb)]((_0x391c8e,_0x4392d0)=>{const _0x12ebdb=_0x586669;this[_0x12ebdb(0x13f)](_0x2d026b,_0x4392d0),_0x391c8e[_0x12ebdb(0x12e)]((_0x3808be,_0x5c55bc,_0x5b151a)=>{const _0x32146c=_0x12ebdb;if(_0x5b151a==null)return!0x0;this[_0x32146c(0x148)](_0x5b151a);});}),this[_0x586669(0x153)]['delete'](_0x2d026b));}[_0x4c7e45(0x1f5)](_0x3d0c70){const _0x55e50f=_0x4c7e45;if(_0x3d0c70==null)return;let _0x4b3d38=this[_0x55e50f(0x14d)][_0x55e50f(0x16e)](_0x3d0c70);if(_0x4b3d38){let _0x2b5046=[];for(let [_0x446261,_0xe2ac47]of _0x4b3d38)for(let [_0x26efae,_0x478cd7]of _0xe2ac47)_0x2b5046[_0x55e50f(0xfe)]({'unitId':_0x446261,'sheetId':_0x26efae,'range':_0x478cd7,'id':_0x3d0c70});this[_0x55e50f(0x19f)]['bulkRemove'](_0x2b5046);}}[_0x4c7e45(0x152)](_0x533e4b,_0x3232d2){const _0x52fdf5=_0x4c7e45;let _0x5983fd=this[_0x52fdf5(0x1ec)][_0x52fdf5(0x16e)](_0x533e4b);if(_0x5983fd){let _0x286278=_0x5983fd['get'](_0x3232d2);if(_0x286278){for(let _0x3af07d of _0x286278)this['_removeDependencyRTreeCache'](_0x3af07d),this['_removeAllTreeMap'](_0x3af07d);_0x286278[_0x52fdf5(0x107)]();}}}[_0x4c7e45(0x122)](){const _0x3fe664=_0x4c7e45;this['_dependencyRTreeCache'][_0x3fe664(0x122)]();}[_0x4c7e45(0x1bd)](){const _0x40451=_0x4c7e45;this[_0x40451(0x19f)][_0x40451(0x1bd)]();}['_removeAllTreeMap'](_0x55c24c){const _0x37b301=_0x4c7e45;_0x55c24c!=null&&this[_0x37b301(0x14d)][_0x37b301(0xfa)](_0x55c24c);}[_0x4c7e45(0x131)](_0x3f672e){const _0x4f900a=_0x4c7e45;let _0x47c6c8=_0x3f672e['rangeList'],_0x42f6d5=this['_allTreeMap'][_0x4f900a(0x16e)](_0x3f672e[_0x4f900a(0x19b)]);for(let _0x56b31f=0x0;_0x56b31f<_0x47c6c8[_0x4f900a(0x181)];_0x56b31f++){var _0x3eac4d,_0x21f477;let {unitId:_0x4620cd,sheetId:_0x5b53ab,range:_0xcf0424}=_0x47c6c8[_0x56b31f];_0x42f6d5||(_0x42f6d5=new Map(),this[_0x4f900a(0x14d)][_0x4f900a(0x138)](_0x3f672e['treeId'],_0x42f6d5)),_0x42f6d5['has'](_0x4620cd)||_0x42f6d5[_0x4f900a(0x138)](_0x4620cd,new Map());let _0x1d5a02=_0x42f6d5==null||(_0x3eac4d=_0x42f6d5[_0x4f900a(0x16e)](_0x4620cd))==null?void 0x0:_0x3eac4d[_0x4f900a(0x16e)](_0x5b53ab);_0x1d5a02&&(_0xcf0424={'startRow':Math[_0x4f900a(0x124)](_0xcf0424[_0x4f900a(0x184)],_0x1d5a02['startRow']),'startColumn':Math[_0x4f900a(0x124)](_0xcf0424[_0x4f900a(0x106)],_0x1d5a02[_0x4f900a(0x106)]),'endRow':Math['max'](_0xcf0424['endRow'],_0x1d5a02[_0x4f900a(0x140)]),'endColumn':Math['max'](_0xcf0424[_0x4f900a(0x161)],_0x1d5a02['endColumn'])}),(_0x21f477=_0x42f6d5['get'](_0x4620cd))==null||_0x21f477[_0x4f900a(0x138)](_0x5b53ab,_0xcf0424);}}};function _0x245c5f(_0x589def,_0x2d4721,_0x1ebf94,_0x34b757){const _0x2142ad=_0x4c7e45;var _0x67b047=arguments[_0x2142ad(0x181)],_0x35570d=_0x67b047<0x3?_0x2d4721:_0x34b757===null?_0x34b757=Object[_0x2142ad(0x1e0)](_0x2d4721,_0x1ebf94):_0x34b757,_0x343c0b;if(typeof Reflect==_0x2142ad(0x1eb)&&typeof Reflect[_0x2142ad(0x104)]=='function')_0x35570d=Reflect[_0x2142ad(0x104)](_0x589def,_0x2d4721,_0x1ebf94,_0x34b757);else{for(var _0x545845=_0x589def[_0x2142ad(0x181)]-0x1;_0x545845>=0x0;_0x545845--)(_0x343c0b=_0x589def[_0x545845])&&(_0x35570d=(_0x67b047<0x3?_0x343c0b(_0x35570d):_0x67b047>0x3?_0x343c0b(_0x2d4721,_0x1ebf94,_0x35570d):_0x343c0b(_0x2d4721,_0x1ebf94))||_0x35570d);}return _0x67b047>0x3&&_0x35570d&&Object[_0x2142ad(0x12d)](_0x2d4721,_0x1ebf94,_0x35570d),_0x35570d;}let _0x5d7a18=Number['parseInt'](0x6a042e58),_0x3e2b65=class extends _0x5773e3['UniverFormulaEnginePlugin']{[_0x4c7e45(0x18d)](){const _0x275319=_0x4c7e45;if(this[_0x275319(0x188)]()){var _0x22dd92;this['_injector'][_0x275319(0x141)]([_0x5773e3[_0x275319(0x19c)],{'useClass':_0x5cb4c6}]),(_0x22dd92=this[_0x275319(0x1d2)])!=null&&_0x22dd92['notExecuteFormula']||[[_0x5773e3[_0x275319(0x1b6)],{'useClass':_0x451a51}],[_0x5773e3[_0x275319(0x17e)],{'useClass':_0xb05b84}],[_0x5773e3[_0x275319(0x16c)],{'useClass':_0x2271b4}]][_0x275319(0x1fb)](_0xd54c28=>this['_injector'][_0x275319(0x141)](_0xd54c28));}else{var _0x5521e2;this['_injector'][_0x275319(0x141)]([_0x5773e3[_0x275319(0x19c)],{'useClass':_0x5773e3[_0x275319(0x19c)]}]),(_0x5521e2=this['_config'])!=null&&_0x5521e2[_0x275319(0x1c6)]||[[_0x5773e3[_0x275319(0x1b6)],{'useClass':_0x5773e3[_0x275319(0x13a)]}],[_0x5773e3[_0x275319(0x17e)],{'useClass':_0x5773e3[_0x275319(0x162)]}],[_0x5773e3['IFormulaDependencyGenerator'],{'useClass':_0x5773e3[_0x275319(0x17f)]}]][_0x275319(0x1fb)](_0x93783a=>this['_injector']['add'](_0x93783a));}}[_0x4c7e45(0x188)](){const _0x41bb5c=_0x4c7e45;var _0x2b37b8;let {ls:_0x139946,pbk:_0x36b3ec}=(_0x2b37b8=this[_0x41bb5c(0x1f2)][_0x41bb5c(0x18a)](_0x3bb87b[_0x41bb5c(0x1cd)]))==null?{}:_0x2b37b8;if(!_0x139946||!_0x36b3ec)return!0x1;let _0x39dba3=(0x0,_0x3bb87b[_0x41bb5c(0x151)])(_0x139946,_0x36b3ec),_0x280632=_0x39dba3[_0x41bb5c(0x19d)];return _0x39dba3[_0x41bb5c(0x15e)]&&(0x0,_0x3bb87b[_0x41bb5c(0x1c4)])(_0x280632,'sf',_0x5d7a18)?(0x0,_0x3bb87b[_0x41bb5c(0x1d8)])(_0x280632,!0x0,'a',!0x0,!0x1,!0x1):!0x1;}};_0x5eaa43(_0x3e2b65,_0x4c7e45(0x1b9),_0x54c08c),_0x5eaa43(_0x3e2b65,_0x4c7e45(0x115),_0x514af2),_0x3e2b65=_0x245c5f([(0x0,_0x5e7a81[_0x4c7e45(0x14b)])(_0x3bb87b[_0x4c7e45(0x1b4)])],_0x3e2b65),_0x4eb647[_0x4c7e45(0x19a)]=_0x5cb4c6,Object[_0x4c7e45(0x12d)](_0x4eb647,_0x4c7e45(0x157),{'enumerable':!0x0,'get':function(){return _0x3e2b65;}}),Object[_0x4c7e45(0x11a)](_0x5773e3)[_0x4c7e45(0x1fb)](function(_0x410d7b){const _0xea95ee=_0x4c7e45;_0x410d7b!=='default'&&!Object[_0xea95ee(0x10c)][_0xea95ee(0x1a5)][_0xea95ee(0x134)](_0x4eb647,_0x410d7b)&&Object['defineProperty'](_0x4eb647,_0x410d7b,{'enumerable':!0x0,'get':function(){return _0x5773e3[_0x410d7b];}});});}));function _0x3679(_0x1ec552,_0x5163d9){_0x1ec552=_0x1ec552-0xf3;const _0x155e32=_0x155e();let _0x3679cd=_0x155e32[_0x1ec552];return _0x3679cd;}function _0x155e(){const _0x2f5856=['startColumn','clear','matchToken','_getDependencyTreeParenIds','from','_getCurNodeTypeForExprTree','prototype','2qgHNeu','Dependency\x20tree\x20not\x20found\x20for\x20treeId:','Module','_calculateRunList','_getTreeNode','getChildren','treeBuilder','setRuntimeFeatureCellData','version','SUFFIX_TOKEN_SET','DEFAULT_INTERVAL_COUNT','refTree','getOtherFormulaDependency','keys','row','size','getFormulaData','764845gfNdre','column','isVirtual','rangeList','openKdTree','getDirtyNameMap','min','getExcludedRange','_clearFunctionString','isExcludeRange','sheetId','function','generateAstNode','_lambdaFunctionParameterSet','DEFAULT_TOKEN_LAMBDA_FUNCTION_NAME','defineProperty','forValue','string','_hasNewExcelFunction','_addAllTreeMap','prefixToken','requestImmediateMacroTask','call','subUnitId','searchDependency','addOtherFormulaDependencyMainData','set','_clearPrefix','CalculateFormulaService','\x22\x20is\x20duplicated.','columnCount','markedAsSuccessfullyExecuted','COLON','_removeDependencyRTreeCacheById','endRow','add','isForceCalculate','clearArrayObjectCache','toPrimitive','@univerjs-pro/engine-formula','_xlpmPrefix','_getUpdateTreeListAndMakeDependency','_removeAllTreeMap','has','setCurrent','DependentOn','UniverEngineFormula','_allTreeMap','isAdded','getDirtyRanges','getOtherFormulaData','getLicenseInfo','removeFormulaDependencyByDefinedName','_formulaData','UniverProLicense','413ffBdZU','removeFormulaDependency','UniverProFormulaEnginePlugin','_restDependencyTreeId','_otherFormulaData','featureId','_currentUnitId','trim','START_CALCULATION','valid','getValue','markedAsStopFunctionsExecuted','endColumn','DependencyManagerService','isCache','ObjectMatrix','range','_getTableNameFromStructuredRef','_otherFormulaDataMainData','values','isArray','setAdded','MINUS','IFormulaDependencyGenerator','bulkSearch','get','ENGINE_FORMULA_PLUGIN_CONFIG_KEY','DEFAULT_TOKEN_TYPE_LAMBDA_PARAMETER','addFormulaDependencyByDefinedName','_interpreter','constructor','_formulaDependencyGenerator','getFeatureFormulaDependency','checkAsyncNode','exports','_currentConfigService','_checkIsCycleDependency','5456430KaOxXQ','_dependencyManagerService','0.22.1','endsWith','IDependencyManagerService','FormulaDependencyGenerator','splitTableStructuredRef','length','rowCount','_getDependencyTreeChildrenIds','startRow','refOffsetY','reset','getSheetRowColumnCount','_initLicenseValid','_handleLambdaForExprTree','getConfig','DEFAULT_TOKEN_TYPE_PARAMETER','PLUS','_initializeWithOverride','isStopExecution','setFormulaExecuteStage','setCompletedFormulasCount','error','addFeatureFormulaDependency','children','_convertDirtyRangesToUnitRange','_dependencyTreeCache','formula','_xlfnPrefix','_endFormulaDependencyTreeModel','_astTreeBuilder','LexerTreeProBuilder','treeId','LexerTreeBuilder','message','_getTreeById','_dependencyRTreeCache','_updateRangeFlatten','48184iVYLOv','_generateExprTree','_createFDtree','_traverse','hasOwnProperty','getFormulaExprTree','_runtimeService','getNewFormulaWithPrefix','_generateNewFunctionString','_lexer','setValue','formulaId','startIndex','_handleTextNodeForExprTree','toStringTag','_handleNewFunctionChild','FormulaExecuteStageType','enableCycleDependency','setTotalArrayFormulasToCalculate','UniverLicensePlugin','addFormulaDependency','ICalculateFormulaService','isSkip','clearOtherFormulaDependency','packageName','getStartIndex','DEFAULT_TOKEN_LET_FUNCTION_NAME','@univerjs/engine-formula','closeKdTree','getAllRuntimeData','258287Dwerjc','FEATURE_FORMULA','START_DEPENDENCY','_startFormulaDependencyTreeModel','startsWith','isFeatureAuthorizedWithinTime','hasOtherFormulaDataMainData','notExecuteFormula','UniverCore','_xlfn.','Lambda\x20parameter\x20name\x20\x22','inRangeData','getRuntimeState','_otherFormulaManagerService','LS_CONFIG_KEY','getClearDependencyTreeCache','generate','_isCyclicUtilMap','3791472ksgsyr','_config','_resetPrefix','realDeleteValue','getFormulaDependency','_xlpm.','_handleChildrenForExprTree','getSheetFeatureLimit','DEFAULT_TOKEN_TYPE_ROOT','ErrorType','setTotalFormulasToCalculate','Let\x20variable\x20name\x20\x22','_featureFormulaData','_generateTreeList','FormulaDependencyTree','getOwnPropertyDescriptor','_executionInProgressListener$','setRuntimeFeatureRange','slice','4vNHpLQ','CURRENTLY_CALCULATING_ARRAY_FORMULA','executeAsync','_registerFormulas','getUnitData','10PgiPDk','NEW_EXCEL_FUNCTIONS','object','_definedNameMap','LexerNode','clearFormulaDependency','START_DEPENDENCY_ARRAY_FORMULA','dirtyRanges','getDirtyData','_configService','refOffsetX','@univerjs/core','_removeDependencyRTreeCache','_checkAddBracketForMinus','intervalCount','unitId','toUpperCase','generateRandomDependencyTreeId','forEach','FormulaDependencyTreeType','CURRENTLY_CALCULATING','setCompletedArrayFormulasCount','toRTreeItem','getToken','_registerOtherFormulas','isReferenceString','_getFirstCellOfRange','_checkColonNodeForExprTree','addOtherFormulaDependency','delete','2040069DNIhiE','next','_formulaDependencyTreeModel','push','dispose','10739168yFpqva','amd','type','OTHER_FORMULA','decorate','symbol'];_0x155e=function(){return _0x2f5856;};return _0x155e();}
1
+ (function(e,t){typeof exports==`object`&&typeof module<`u`?t(exports,require(`@univerjs-pro/license`),require(`@univerjs/core`),require(`@univerjs/engine-formula`)):typeof define==`function`&&define.amd?define([`exports`,`@univerjs-pro/license`,`@univerjs/core`,`@univerjs/engine-formula`],t):(e=typeof globalThis<`u`?globalThis:e||self,t(e.UniverProEngineFormula={},e.UniverProLicense,e.UniverCore,e.UniverEngineFormula))})(this,function(e,t,n,r){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var i=`@univerjs-pro/engine-formula`,a=`0.23.0`;function o(){return{totalFormulaNodes:0,totalSharedFormulaGroups:0,compressedSharedFormulaGroups:0,compressibleSharedFormulaGroups:0,expandedSharedFormulaGroups:0,totalVirtualFormulaNodesInCompressedGroups:0,totalVirtualFormulaNodesInCompressibleGroups:0,skippedExpandedDependencyRegistrationCount:0,sharedPatternCount:0,sharedSourceCoverageEntryCount:0,fallbackReasonCounts:{}}}function s(e,t={}){var n;let r=(n=t.minSharedGroupSize)==null?32:n,i=o(),a=c(e,i),s=[];return a.forEach(e=>{let t=l(e,r);if(s.push(t),i.totalSharedFormulaGroups++,t.mode===`candidate`){i.compressibleSharedFormulaGroups++,i.totalVirtualFormulaNodesInCompressibleGroups+=t.virtualFormulaCount;return}if(i.expandedSharedFormulaGroups++,t.fallbackReason){var n;i.fallbackReasonCounts[t.fallbackReason]=((n=i.fallbackReasonCounts[t.fallbackReason])==null?0:n)+1}}),{groups:s,metrics:i}}function c(e,t){let n=new Map;return Object.keys(e).forEach(r=>{let i=e[r];i!=null&&Object.keys(i).forEach(e=>{let a=i[e];a!=null&&Object.keys(a).forEach(i=>{let o=a[Number(i)];o!=null&&Object.keys(o).forEach(a=>{let s=o[Number(a)];if(s==null||(t.totalFormulaNodes++,s.si==null))return;let c=String(s.si),l=f(r,e,c),u=n.get(l);u==null&&(u={groupId:l,unitId:r,sheetId:e,si:c,members:[]},n.set(l,u)),u.members.push({row:Number(i),col:Number(a),item:s})})})})}),n}function l(e,t){let n=u(e.members),r=n.maxCol-n.minCol+1,i=n.maxRow-n.minRow+1,a={unitId:e.unitId,sheetId:e.sheetId,range:{startRow:n.minRow,endRow:n.maxRow,startColumn:n.minCol,endColumn:n.maxCol}},o=e.members.filter(e=>p(e.item)),s=o.length===1?{unitId:e.unitId,sheetId:e.sheetId,row:o[0].row,col:o[0].col}:void 0,c=d(e,a,o.length,t);return{groupId:e.groupId,unitId:e.unitId,sheetId:e.sheetId,si:e.si,anchor:s,fillRange:a,width:r,height:i,size:e.members.length,virtualFormulaCount:Math.max(0,e.members.length-1),mode:c==null?`candidate`:`expanded`,fallbackReason:c}}function u(e){let t=1/0,n=-1/0,r=1/0,i=-1/0;for(let a=0;a<e.length;a++){let o=e[a];t=Math.min(t,o.row),n=Math.max(n,o.row),r=Math.min(r,o.col),i=Math.max(i,o.col)}return{minRow:t,maxRow:n,minCol:r,maxCol:i}}function d(e,t,n,r){var i;if(n===0)return`missing-anchor-formula`;if(n>1)return`ambiguous-anchor-formula`;if(!m(e.members,t))return`non-rectangular-fill-range`;if(e.members.length<r)return`small-group`;let a=e.members.find(e=>p(e.item)),o=(i=a==null?void 0:a.item.f)==null?``:i;if(_(o))return`external-reference`;if(h(o))return`unsupported-dynamic-reference`;if(g(o))return`volatile-function`;if(v(o))return`array-formula`;if(y(o))return`spill-formula`}function f(e,t,n){return[e,t,n].join(`\0`)}function p(e){var t,n;return((t=e.x)==null?0:t)===0&&((n=e.y)==null?0:n)===0}function m(e,t){let n=t.range.endColumn-t.range.startColumn+1;if(n*(t.range.endRow-t.range.startRow+1)!==e.length)return!1;let r=new Set;for(let i=0;i<e.length;i++){let a=e[i],o=(a.row-t.range.startRow)*n+(a.col-t.range.startColumn);if(r.has(o))return!1;r.add(o)}return!0}function h(e){return b(e,[`INDIRECT`,`OFFSET`])}function g(e){return b(e,[`RAND`,`RANDBETWEEN`,`NOW`,`TODAY`])}function _(e){return/\[[^\]]+\]/.test(e)}function v(e){return/^\s*\{=.*\}\s*$/.test(e)}function y(e){return/#/.test(e)}function b(e,t){for(let n=0;n<t.length;n++)if(RegExp(`(^|[^A-Z0-9_.])${t[n]}\\s*\\(`,`i`).test(e))return!0;return!1}function x(e){"@babel/helpers - typeof";return x=typeof Symbol==`function`&&typeof Symbol.iterator==`symbol`?function(e){return typeof e}:function(e){return e&&typeof Symbol==`function`&&e.constructor===Symbol&&e!==Symbol.prototype?`symbol`:typeof e},x(e)}function S(e,t){if(x(e)!=`object`||!e)return e;var n=e[Symbol.toPrimitive];if(n!==void 0){var r=n.call(e,t||`default`);if(x(r)!=`object`)return r;throw TypeError(`@@toPrimitive must return a primitive value.`)}return(t===`string`?String:Number)(e)}function C(e){var t=S(e,`string`);return x(t)==`symbol`?t:t+``}function w(e,t,n){return(t=C(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}var T=class extends r.FormulaDependencyGenerator{constructor(...e){super(...e),w(this,`_featureFormulaDirtyDependencies`,[]),w(this,`_calculationTreeCache`,new Map),w(this,`_calculationNodeDataCache`,new Map),w(this,`_forcedRecalculationNodeIndices`,new Set),w(this,`_sharedFormulaCompressionMetrics`,o()),w(this,`_cacheDependencyTreeModelRangeList`,!1)}dispose(){super.dispose(),this._dependencyTreeCache.clear(),this._calculationTreeCache.clear(),this._calculationNodeDataCache=new Map,this._featureFormulaDirtyDependencies.length=0,this._forcedRecalculationNodeIndices.clear(),this._sharedFormulaCompressionMetrics=o()}clearCalculatedDirty(e){this._dependencyManagerService.clearCalculatedDirty(e)}clearCachedCalculationNodeData(){this._calculationNodeDataCache=new Map}clearCachedCalculationTree(){this._calculationTreeCache.clear()}getCachedCalculationNodeData(e){return this._calculationNodeDataCache.get(e)}getCalculationOrder(){return this._dependencyManagerService.getCalculationOrder({detectCycles:!0})}getSharedFormulaCompressionMetrics(){return this._sharedFormulaCompressionMetrics}hasDynamicDepsByIndex(e){return this._dependencyManagerService.hasDynamicDepsByIndex(e)}refreshDynamicDepsByIndex(e,t){return this._dependencyManagerService.refreshDynamicDepsByIndex(e,t)}hasUncalculatedDirtyPrecedentByIndex(e,t){return this._dependencyManagerService.hasUncalculatedDirtyPrecedentByIndex(e,t)}async getAllDependencyJson(){this._featureFormulaDirtyDependencies.length=0,this._updateRangeFlatten();let e=this._currentConfigService.getFormulaData(),t=s(e);this._sharedFormulaCompressionMetrics=t.metrics;let n=this._otherFormulaManagerService.getOtherFormulaData(),r=this._currentConfigService.getUnitData();this._cacheDependencyTreeModelRangeList=!0;try{return await this._generateTreeListPro(e,n,r,t),this._getAllDependencyJsonPro(this._calculationTreeCache)}finally{this._cacheDependencyTreeModelRangeList=!1,this._featureFormulaDirtyDependencies.length=0}}async generatePro(e=!1){this._featureFormulaDirtyDependencies.length=0,this._updateRangeFlatten();let t=this._currentConfigService.getFormulaData(),n=s(t);this._sharedFormulaCompressionMetrics=n.metrics;let r=this._otherFormulaManagerService.getOtherFormulaData(),i=this._currentConfigService.getClearDependencyTreeCache(),a=this._dependencyManagerService;i!=null&&Object.keys(i).forEach(e=>{e!=null&&Object.keys(i[e]).forEach(t=>{t!=null&&(a.clearOtherFormulaDependency(e,t),a.clearFeatureFormulaDependency(e,t),a.clearFormulaDependency(e,t),this._clearCalculationTreeCache(e,t))})});let o=this._currentConfigService.getUnitData();this._cacheDependencyTreeModelRangeList=e;try{await this._generateTreeListPro(t,r,o,n)}finally{this._cacheDependencyTreeModelRangeList=!1}await this._markDirtyDependenciesPro(),this._featureFormulaDirtyDependencies.length=0,this._runtimeService.clearArrayObjectCache();let c=a.getCalculationOrder({detectCycles:!0}),l=this._calculationTreeCache;return e&&this._runtimeService.setDependencyTreeModelData(this._getAllDependencyJsonPro(l)),{calculationOrderResult:c,dependencyTree:l}}async _generateTreeListPro(e,t,n,r){let i=Object.keys(e),a=Object.keys(t);this._registerFeatureFormulasPro(),await this._registerFormulasPro(i,e,n,r),await this._registerOtherFormulasPro(t,a)}_registerFeatureFormulasPro(){this._featureCalculationManagerService.getReferenceExecutorMap().forEach((e,t)=>{e.forEach((e,t)=>{e.forEach((e,t)=>{let n=this._dependencyManagerService.getFeatureFormulaDependency(e.unitId,e.subUnitId,t);this._getFeatureFormulaTreePro(t,n,e)})})})}_getFeatureFormulaTreePro(e,t,n){let{unitId:i,subUnitId:a,dependencyRanges:o,getDirtyData:s}=n,c=new r.FormulaDependencyTree(t||(0,r.generateRandomDependencyTreeId)(this._dependencyManagerService));c.unitId=i,c.subUnitId=a,c.rangeList=o,c.getDirtyData=s;let l=s(this._currentConfigService.getDirtyData(),this._runtimeService.getAllRuntimeData()),u=this._convertDirtyRangesToUnitRange(l.dirtyRanges);c.featureDirtyRanges=u,c.featureId=e,c.type=r.FormulaDependencyTreeType.FEATURE_FORMULA;let d=this._dependencyManagerService.getFeatureFormulaDependencyPro(n.unitId,n.subUnitId,e),f;return d===void 0&&(d=this._dependencyManagerService.addFeatureFormulaDependencyPro(i,a,e,c),f=d),u.length>0&&this._featureFormulaDirtyDependencies.push({node:this._dependencyManagerService.getFeatureFormulaDependencyNodePro(i,a,e),dirtyRanges:u}),this._cacheCalculationTree(d,c),this._releaseDependencyTree(c),f}async _registerOtherFormulasPro(e,t){for(let n of t){let t=e[n];if(t==null)continue;let i=Object.keys(t);for(let e of i){let i=t[e];if(i==null)continue;let{rowCount:a=1/0,columnCount:o=1/0}=this._currentConfigService.getSheetRowColumnCount(n,e)||{},s=Object.keys(i);for(let t of s){let s=this._dependencyManagerService.hasOtherFormulaDataMainData(t),{f:c,ranges:l}=i[t],u=!1;s&&(u=!0);let{firstRow:d,firstColumn:f}=this._getFirstCellOfRange(l),p=new r.FormulaDependencyTree((0,r.generateRandomDependencyTreeId)(this._dependencyManagerService));for(let i=0;i<l.length;i++){let s=l[i],{startRow:m,startColumn:h}=s,{endRow:g,endColumn:_}=s;g=Math.min(g,a-1),_=Math.min(_,o-1);for(let i=m;i<=g;i++)for(let a=h;a<=_;a++){let o=a-f,s=i-d,l=this._dependencyManagerService.getOtherFormulaDependencyPro(n,e,t,o,s);if(o===0&&s===0){p.formula=c,p.unitId=n,p.subUnitId=e,p.formulaId=t,p.type=r.FormulaDependencyTreeType.OTHER_FORMULA,p.isCache=u,p.node||await this._initialAstNodeAndRanges(p);let i=this._getFeatureFormulaDependencyNodes(p.rangeList);l===void 0?l=this._dependencyManagerService.addOtherFormulaDependencyPro(n,e,t,p,i):i.length>0&&(l=this._dependencyManagerService.addOtherFormulaDependencyPro(n,e,t,p,i,`merge`)),this._ensureTreeNodeForCalculation(p),this._cacheCalculationTree(l,p),this._syncForcedRecalculationNodeIndex(l,p);continue}let m=new r.FormulaDependencyTreeVirtual;m.treeId=(0,r.generateRandomDependencyTreeId)(this._dependencyManagerService),m.refTree=p,m.refOffsetX=o,m.refOffsetY=s,m.isCache=u,m.type=r.FormulaDependencyTreeType.OTHER_FORMULA;let h=this._getFeatureFormulaDependencyNodes(m.rangeList);l===void 0?l=this._dependencyManagerService.addOtherFormulaDependencyPro(n,e,t,m,h):h.length>0&&(l=this._dependencyManagerService.addOtherFormulaDependencyPro(n,e,t,m,h,`merge`)),this._cacheCalculationTree(l,m),this._syncForcedRecalculationNodeIndex(l,m),this._releaseDependencyTree(m)}}this._releaseDependencyTree(p)}}}}async _registerFormulasPro(e,t,n,i=s(t)){let a=this._createSharedFormulaGroupMap(i.groups),o=new Map,c=this._dependencyManagerService;for(let i of e){let e=t[i];if(e==null)continue;let s=Object.keys(e);for(let t of s){let s=new Map,l=[],u=e[t];if(u==null)continue;let d=Object.keys(u);for(let e of d){let r=Number.parseInt(e,10),d=u[r];if(d==null)continue;let f=Object.keys(d);for(let e of f){let u=Number.parseInt(e,10),f=d[u];if(f==null)continue;let{x:p=0,y:m=0,si:h}=f;if(!(p===0&&m===0&&h!=null))continue;let g=this._createFDtree(i,t,r,u,n,f),_=this._createSharedFormulaGroupId(i,t,h),v=a.get(_),y=(v==null?void 0:v.mode)===`candidate`?await this._analyzeSharedFormulaCompression(g,v):void 0,b=c.getFormulaDependencyPro(i,t,r,u);if((y==null?void 0:y.mode)===`compressed`)b=c.addFormulaDependencyNodeOnlyPro(i,t,r,u),o.set(_,y),l.push(y);else if((y==null?void 0:y.mode)===`expanded`&&(o.set(_,y),this._recordExpandedSharedFormulaGroupMetrics(y)),b===void 0){g.node||await this._initialAstNodeAndRanges(g);let e=this._getFeatureFormulaDependencyNodes(g.rangeList);b=c.addFormulaDependencyPro(i,t,r,u,g,e)}else{await this._ensureTreeInitializedForFeatureDependencies(g);let e=this._getFeatureFormulaDependencyNodes(g.rangeList);e.length>0&&(b=c.addFormulaDependencyPro(i,t,r,u,g,e,`merge`))}this._ensureTreeNodeForCalculation(g),s.set(h,g),this._cacheCalculationTree(b,g),this._syncForcedRecalculationNodeIndex(b,g)}}for(let e of d){let a=Number.parseInt(e,10),l=u[a];if(l==null)continue;let d=Object.keys(l);for(let e of d){let u=Number.parseInt(e,10),d=l[u];if(d==null)continue;let{x:f=0,y:p=0,si:m}=d;if(f===0&&p===0&&m!=null)continue;let h=c.getFormulaDependencyPro(i,t,a,u),g=m==null?void 0:this._createSharedFormulaGroupId(i,t,m),_=g==null?void 0:o.get(g);if((_==null?void 0:_.mode)===`compressed`&&m!=null&&s.has(m)){h=c.addFormulaDependencyNodeOnlyPro(i,t,a,u);let e=s.get(m),{x:n=0,y:r=0}=d;this._cacheCompressedVirtualCalculationTree(h,e,n,r),this._syncCompressedVirtualForcedRecalculationNodeIndex(h,e);continue}let v;if(m!=null&&s.has(m)){let e=s.get(m);v=this._createVirtualFDtree(e,d)}else v=this._createFDtree(i,t,a,u,n,d);if(h===void 0){!v.isVirtual&&!v.node&&await this._initialAstNodeAndRanges(v);let e=this._getFeatureFormulaDependencyNodes(v.rangeList);h=c.addFormulaDependencyPro(i,t,a,u,v,e)}else{await this._ensureTreeInitializedForFeatureDependencies(v);let e=this._getFeatureFormulaDependencyNodes(v.rangeList);e.length>0&&(h=c.addFormulaDependencyPro(i,t,a,u,v,e,`merge`))}this._cacheCalculationTree(h,v),this._syncForcedRecalculationNodeIndex(h,v),v instanceof r.FormulaDependencyTreeVirtual?this._releaseDependencyTree(v):m!=null&&s.has(m)||this._releaseDependencyTree(v)}}for(let e=0;e<l.length;e++){let t=l[e];t.patterns&&t.group.fillRange&&(c.registerCompressedSharedFormulaGroup({groupId:t.group.groupId,fillRange:t.group.fillRange,patterns:t.patterns}),this._recordCompressedSharedFormulaGroupMetrics(t))}s.forEach(e=>this._releaseDependencyTree(e)),s.clear()}}}_createSharedFormulaGroupMap(e){let t=new Map;for(let n=0;n<e.length;n++)t.set(e[n].groupId,e[n]);return t}_createSharedFormulaGroupId(e,t,n){return[e,t,String(n)].join(`\0`)}async _analyzeSharedFormulaCompression(e,t){if(t.fillRange==null)return{group:t,mode:`expanded`,fallbackReason:`non-rectangular-fill-range`};e.node||await this._initialAstNodeAndRanges(e);let n=this._getFeatureFormulaDependencyNodes(e.rangeList),r=this._getSharedFormulaUnsupportedReason(e,n.length);if(r)return{group:t,mode:`expanded`,fallbackReason:r};let i=this._convertSharedFormulaPatterns(e);return i==null||i.length===0?{group:t,mode:`expanded`,fallbackReason:`unsupported-range-pattern`}:this._hasSharedFormulaSelfOverlap(t.fillRange,i)?{group:t,mode:`expanded`,fallbackReason:`self-overlap`}:{group:t,mode:`compressed`,patterns:i}}_getSharedFormulaUnsupportedReason(e,t){if(e.addressFunctionNodes&&e.addressFunctionNodes.length>0)return`unsupported-dynamic-reference`;if(t>0||/\$/.test(e.formula))return`unsupported-range-pattern`}_convertSharedFormulaPatterns(e){let t=[],n=new Set,r=e.row,i=e.column;for(let a=0;a<e.rangeList.length;a++){let o=e.rangeList[a],s=this._normalizeSharedFormulaRange(o.range),c;c=s.startRow===s.endRow&&s.startColumn===s.endColumn?{kind:`cell`,unitId:o.unitId,sheetId:o.sheetId,rowDelta:s.startRow-r,colDelta:s.startColumn-i}:{kind:`range`,unitId:o.unitId,sheetId:o.sheetId,startRowDelta:s.startRow-r,startColDelta:s.startColumn-i,endRowDelta:s.endRow-r,endColDelta:s.endColumn-i};let l=JSON.stringify(c);n.has(l)||(n.add(l),t.push(c))}return t}_hasSharedFormulaSelfOverlap(e,t){for(let r=0;r<t.length;r++){let i=this._computeSharedFormulaSourceCoverage(e,t[r]);if(!(i.unitId!==e.unitId||i.sheetId!==e.sheetId)&&n.Rectangle.intersects(i.range,e.range))return!0}return!1}_computeSharedFormulaSourceCoverage(e,t){if(t.kind===`cell`)return{unitId:t.unitId,sheetId:t.sheetId,range:this._normalizeSharedFormulaRange({startRow:e.range.startRow+t.rowDelta,endRow:e.range.endRow+t.rowDelta,startColumn:e.range.startColumn+t.colDelta,endColumn:e.range.endColumn+t.colDelta})};let n=Math.min(t.startRowDelta,t.endRowDelta),r=Math.max(t.startRowDelta,t.endRowDelta),i=Math.min(t.startColDelta,t.endColDelta),a=Math.max(t.startColDelta,t.endColDelta);return{unitId:t.unitId,sheetId:t.sheetId,range:this._normalizeSharedFormulaRange({startRow:e.range.startRow+n,endRow:e.range.endRow+r,startColumn:e.range.startColumn+i,endColumn:e.range.endColumn+a})}}_normalizeSharedFormulaRange(e){return{startRow:Math.min(e.startRow,e.endRow),endRow:Math.max(e.startRow,e.endRow),startColumn:Math.min(e.startColumn,e.endColumn),endColumn:Math.max(e.startColumn,e.endColumn)}}_recordCompressedSharedFormulaGroupMetrics(e){e.mode!==`compressed`||e.patterns==null||(this._sharedFormulaCompressionMetrics.compressedSharedFormulaGroups++,this._sharedFormulaCompressionMetrics.totalVirtualFormulaNodesInCompressedGroups+=e.group.virtualFormulaCount,this._sharedFormulaCompressionMetrics.skippedExpandedDependencyRegistrationCount+=e.group.size*e.patterns.length,this._sharedFormulaCompressionMetrics.sharedPatternCount+=e.patterns.length,this._sharedFormulaCompressionMetrics.sharedSourceCoverageEntryCount+=e.patterns.length)}_recordExpandedSharedFormulaGroupMetrics(e){var t;e.mode!==`expanded`||e.fallbackReason==null||(this._sharedFormulaCompressionMetrics.expandedSharedFormulaGroups++,this._sharedFormulaCompressionMetrics.fallbackReasonCounts[e.fallbackReason]=((t=this._sharedFormulaCompressionMetrics.fallbackReasonCounts[e.fallbackReason])==null?0:t)+1)}async _markDirtyDependenciesPro(){let e=this._dependencyManagerService;if(this._currentConfigService.isForceCalculate()){e.markAllDirty();return}let t=this._currentConfigService.getDirtyRanges();t.length>0&&e.markRangesChanged(t,{includeFormulaCells:!0}),e.markDirtyFeatureCalculations(this._currentConfigService.getDirtyUnitFeatureMap()),e.markDirtyOtherFormulas(this._currentConfigService.getDirtyUnitOtherFormulaMap()),e.markDirtySheetNames(this._currentConfigService.getDirtyNameMap()),this._markForcedRecalculationNodesPro(e),await this._markDirtyDefinedNameDependenciesPro(e)}_markForcedRecalculationNodesPro(e){if(this._forcedRecalculationNodeIndices.size===0)return;let t=[];this._forcedRecalculationNodeIndices.forEach(e=>{t.push(e)}),e.markIndicesChanged(t)}async _markDirtyDefinedNameDependenciesPro(e){let t=this._currentConfigService.getDirtyDefinedNameMap();if(!this._hasDirtyDefinedNames(t))return;let n=[];for(let[e,t]of this._calculationTreeCache)t.formula&&t.formula.length>0&&this._includeDirtyDefinedNamePro(t.formula)&&n.push(e);n.length>0&&e.markIndicesChanged(n)}_cacheCalculationTree(e,t){let n={unitId:t.unitId,subUnitId:t.subUnitId,formula:t.formula,row:t.row,column:t.column,rowCount:t.rowCount,columnCount:t.columnCount,refOffsetX:t.refOffsetX,refOffsetY:t.refOffsetY,formulaId:t.formulaId,featureId:t.featureId,getDirtyData:t.getDirtyData,hasDynamicDeps:t.addressFunctionNodes.length>0,type:t.type};(t.addressFunctionNodes.length>0||this._cacheDependencyTreeModelRangeList)&&(n.rangeList=t.rangeList);let r=t.nodeData;(r==null?void 0:r.node)!=null&&this._calculationNodeDataCache.set(e,{node:r.node,refOffsetX:r.refOffsetX,refOffsetY:r.refOffsetY}),this._calculationTreeCache.set(e,n)}_cacheCompressedVirtualCalculationTree(e,t,n,r){this._calculationTreeCache.set(e,{unitId:t.unitId,subUnitId:t.subUnitId,formula:t.formula,row:t.row+r,column:t.column+n,rowCount:t.rowCount,columnCount:t.columnCount,refOffsetX:n,refOffsetY:r,formulaId:t.formulaId,featureId:t.featureId,getDirtyData:null,hasDynamicDeps:!1,type:t.type}),this._cacheDependencyTreeModelRangeList&&(this._calculationTreeCache.get(e).rangeList=this._getOffsetRangeList(t.rangeList,n,r)),t.node!=null&&this._calculationNodeDataCache.set(e,{node:t.node,refOffsetX:n,refOffsetY:r})}_getOffsetRangeList(e,t,n){return t===0&&n===0?e:e.map(e=>({unitId:e.unitId,sheetId:e.sheetId,range:{startRow:e.range.startRow+n,endRow:e.range.endRow+n,startColumn:e.range.startColumn+t,endColumn:e.range.endColumn+t}}))}_getAllDependencyJsonPro(e){let t=this._dependencyManagerService,n=[];for(let[a,o]of e){var r,i;let s=[],c=[];t.forEachPrecedentNodeByIndex(a,t=>{e.has(t)&&s.push(t)}),t.forEachDependentNodeByIndex(a,t=>{e.has(t)&&c.push(t)}),n.push({children:s,parents:c,treeId:a,formula:o.formula,row:o.row,column:o.column,unitId:o.unitId,subUnitId:o.subUnitId,refOffsetX:o.refOffsetX,refOffsetY:o.refOffsetY,rangeList:(r=o.rangeList)==null?[]:r,refTreeId:void 0,formulaId:o.formulaId,featureId:o.featureId,type:(i=o.type)==null?this._inferDependencyTreeTypePro(o):i})}return n}_inferDependencyTreeTypePro(e){return e.featureId==null?e.formulaId==null?r.FormulaDependencyTreeType.NORMAL_FORMULA:r.FormulaDependencyTreeType.OTHER_FORMULA:r.FormulaDependencyTreeType.FEATURE_FORMULA}_clearCalculationTreeCache(e,t){for(let[n,r]of this._calculationTreeCache)r.unitId===e&&r.subUnitId===t&&(this._calculationTreeCache.delete(n),this._calculationNodeDataCache.delete(n),this._forcedRecalculationNodeIndices.delete(n))}_releaseDependencyTree(e){if(e instanceof r.FormulaDependencyTreeVirtual){e.dispose();return}let t=e;t.dispose(),t.node=null}_hasDirtyDefinedNames(e){let t=Object.keys(e);for(let n=0;n<t.length;n++){let r=e[t[n]];if(r!=null&&Object.keys(r).length>0)return!0}return!1}_syncForcedRecalculationNodeIndex(e,t){if(!t.formula){this._forcedRecalculationNodeIndices.delete(e);return}let n=t.nodeData.node;n&&this._detectForcedRecalculationNodePro(n)?this._forcedRecalculationNodeIndices.add(e):this._forcedRecalculationNodeIndices.delete(e)}_syncCompressedVirtualForcedRecalculationNodeIndex(e,t){t.node&&this._detectForcedRecalculationNodePro(t.node)?this._forcedRecalculationNodeIndices.add(e):this._forcedRecalculationNodeIndices.delete(e)}_detectForcedRecalculationNodePro(e){if(e.isForcedCalculateFunction())return!0;let t=e.getChildren();for(let e=0;e<t.length;e++)if(this._detectForcedRecalculationNodePro(t[e]))return!0;return!1}_includeDirtyDefinedNamePro(e){let t=this._currentConfigService.getExecuteUnitId();if(t==null)return!1;let n=this._currentConfigService.getDirtyDefinedNameMap()[t];if(n==null)return!1;let r=Object.keys(n);for(let t=0;t<r.length;t++)if(e.indexOf(r[t])>-1)return!0;return!1}async _ensureTreeInitializedForFeatureDependencies(e){if(this._featureFormulaDirtyDependencies.length===0||e.isVirtual)return;let t=e;t.node||await this._initialAstNodeAndRanges(t)}_ensureTreeNodeForCalculation(e){if(e.node||this._lexer==null||this._astTreeBuilder==null)return;let{unitId:t,formula:n}=e;e.node=(0,r.generateAstNode)(t,n,this._lexer,this._astTreeBuilder,this._currentConfigService),e.addressFunctionNodes=this._getAddressFunctionNodeList(e.node)}_getFeatureFormulaDependencyNodes(e){if(this._featureFormulaDirtyDependencies.length===0||e.length===0)return[];let t=[];for(let n=0;n<this._featureFormulaDirtyDependencies.length;n++){let r=this._featureFormulaDirtyDependencies[n];this._rangesIntersectAny(e,r.dirtyRanges)&&t.push(r.node)}return t}_rangesIntersectAny(e,t){for(let r=0;r<e.length;r++){let i=e[r];for(let e=0;e<t.length;e++){let r=t[e];if(i.unitId===r.unitId&&i.sheetId===r.sheetId&&n.Rectangle.intersects(i.range,r.range))return!0}}return!1}async _initialAstNodeAndRanges(e){let{unitId:t,formula:n}=e,i=(0,r.generateAstNode)(t,n,this._lexer,this._astTreeBuilder,this._currentConfigService);e.node=i,e.addressFunctionNodes=this._getAddressFunctionNodeList(i),this._runtimeService.setCurrent(e.row,e.column,e.rowCount,e.columnCount,e.subUnitId,e.unitId);let a=await this._getRangeListByNode({node:i,refOffsetX:e.refOffsetX,refOffsetY:e.refOffsetY});e.pushRangeList(a)}_createFDtree(e,t,n,i,a,o){let{f:s}=o,c=new r.FormulaDependencyTree((0,r.generateRandomDependencyTreeId)(this._dependencyManagerService)),l=a[e][t];return c.formula=s,c.unitId=e,c.subUnitId=t,c.row=n,c.column=i,c.rowCount=l.rowCount,c.columnCount=l.columnCount,c}},E=class extends r.CalculateFormulaService{constructor(...e){super(...e),w(this,`_dynamicRuntimeRanges`,void 0)}async execute(e){this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.START),this._executionInProgressListener$.next(this._runtimeService.getRuntimeState()),this._currentConfigService.load(e),this._runtimeService.reset();let t=e.maxIteration||r.DEFAULT_CYCLE_REFERENCE_COUNT;this._isCalculateTreeModel=e.isCalculateTreeModel||!1,this._executeLock.acquire(`FORMULA_EXECUTION_LOCK`,async()=>{await this._executeStep(t),this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.CALCULATION_COMPLETED),this._executionInProgressListener$.next(this._runtimeService.getRuntimeState()),this._executionCompleteListener$.next(this._runtimeService.getAllRuntimeData()),r.CELL_INVERTED_INDEX_CACHE.clear(),this._runtimeService.reset()})}async _executeStep(e=r.DEFAULT_CYCLE_REFERENCE_COUNT){let t=await this._apply(!1,e);if(t==null)return;let{arrayFormulaRange:n}=t,{dirtyRanges:i,excludedCell:a}=this._getArrayFormulaDirtyRangeAndExcludedRange(n,{});return i==null||i.length===0?!0:(r.FORMULA_REF_TO_ARRAY_CACHE.clear(),this._currentConfigService.loadDirtyRangesAndExcludedCell(i,a),await this._apply(!0,e),!0)}async _apply(e=!1,t=r.DEFAULT_CYCLE_REFERENCE_COUNT){e?this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.START_DEPENDENCY_ARRAY_FORMULA):this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.START_DEPENDENCY),this._executionInProgressListener$.next(this._runtimeService.getRuntimeState());let n=this._configService.getConfig(r.ENGINE_FORMULA_PLUGIN_CONFIG_KEY),i=(n==null?void 0:n.intervalCount)||r.DEFAULT_INTERVAL_COUNT,a=this._formulaDependencyGenerator;try{let{calculationOrderResult:n,dependencyTree:o}=await a.generatePro(this._isCalculateTreeModel),s=this._getCalculationPlanTreeCount(n,o,t);n.hasCycle&&this._runtimeService.enableCycleDependency(),e?(this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.START_CALCULATION_ARRAY_FORMULA),this._runtimeService.setTotalArrayFormulasToCalculate(s)):(this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.START_CALCULATION),this._runtimeService.setTotalFormulasToCalculate(s)),this._executionInProgressListener$.next(this._runtimeService.getRuntimeState());let c=[],l=[],u=new Set,d=!1,f=0,p=0;for(this._runtimeService.setFormulaCycleIndex(0);;){let r=!1;if(await this._forEachCalculationPlanTree(n,o,t,async(t,n,o)=>{if(this._runtimeService.setFormulaCycleIndex(o==null?0:o),await this._waitForExecutionSlot(f,i,e,t,c))return d=!0,!1;await this._calculateDependencyTree(t,n,a)&&this._shouldRescheduleAfterDynamicChange(a,n,u)&&(r=!0),u.has(n)||(u.add(n),l.push(n)),f++}),n.calculationForest.length=0,d||!r)break;if(p++,p>8)throw Error(`Dynamic dependency did not stabilize`);n=a.getCalculationOrder(),n.hasCycle&&this._runtimeService.enableCycleDependency(),s=this._getCalculationPlanTreeCount(n,o,t),e?this._runtimeService.setTotalArrayFormulasToCalculate(s):this._runtimeService.setTotalFormulasToCalculate(s)}for(let e=0;e<c.length;e++)c[e]();return l.length>0&&a.clearCalculatedDirty(l),d?void 0:(s>0||l.length>0?this._runtimeService.markedAsSuccessfullyExecuted():e||this._runtimeService.markedAsNoFunctionsExecuted(),this._runtimeService.getAllRuntimeData())}finally{a.clearCachedCalculationNodeData(),a.clearCachedCalculationTree(),this._dynamicRuntimeRanges=void 0}}_shouldRescheduleAfterDynamicChange(e,t,n){let r=e;return typeof r.hasUncalculatedDirtyPrecedentByIndex==`function`?r.hasUncalculatedDirtyPrecedentByIndex(t,n):!0}async _forEachCalculationPlanTree(e,t,n,i){let a=Math.max(n,1);for(let n=0;n<e.calculationForest.length;n++){let o=e.calculationForest[n];for(let e=0;e<o.plan.length;e++){let n=o.plan[e];if(n.type===`node`){let e=t.get(n.nodeIndex);if(e!=null&&await i(e,n.nodeIndex)===!1)return;continue}if(n.type===`nodes`){for(let e=0;e<n.nodeIndices.length;e++){let r=n.nodeIndices[e],a=t.get(r);if(a!=null&&await i(a,r)===!1)return}n.nodeIndices.length=0;continue}for(let e=0;e<a;e++){e>0&&r.FORMULA_REF_TO_ARRAY_CACHE.clear();for(let r=0;r<n.nodeIndices.length;r++){let a=n.nodeIndices[r],o=t.get(a);if(o!=null&&await i(o,a,e)===!1)return}}}}}_getCalculationPlanTreeCount(e,t,n){let r=Math.max(n,1),i=0;for(let n=0;n<e.calculationForest.length;n++){let a=e.calculationForest[n];for(let e=0;e<a.plan.length;e++){let n=a.plan[e];if(n.type===`node`){t.has(n.nodeIndex)&&i++;continue}if(n.type===`nodes`){for(let e=0;e<n.nodeIndices.length;e++)t.has(n.nodeIndices[e])&&i++;continue}let o=0;for(let e=0;e<n.nodeIndices.length;e++)t.has(n.nodeIndices[e])&&o++;i+=o*r}}return i}_getDynamicResolver(){let e=this._dynamicRuntimeRanges;if(e==null)return;let t=e.map(e=>this._getRangeSignature(e)).sort().join(`|`);return()=>({signature:t,ranges:e,status:e.length>0?`resolved`:`unknown`})}_refreshDynamicDepsAfterCalculate(e,t,n,r){if(n.hasDynamicDeps===!1||!e.hasDynamicDepsByIndex(t))return!1;let i=this._collectAddressFunctionRuntimeRanges(r);if(i.length===0)return!1;this._dynamicRuntimeRanges=i;try{let n=this._getDynamicResolver();return n==null?!1:e.refreshDynamicDepsByIndex(t,n)}finally{this._dynamicRuntimeRanges=void 0}}_collectAddressFunctionRuntimeRanges(e){let t=[];return this._collectAddressFunctionRuntimeRangesInternal(e,t),t}_collectAddressFunctionRuntimeRangesInternal(e,t){if(e.isAddress()){let n=e.getValue();n!=null&&n.isReferenceObject()&&t.push(n.toUnitRange())}let n=e.getChildren();for(let e=0;e<n.length;e++)this._collectAddressFunctionRuntimeRangesInternal(n[e],t)}_getRangeSignature(e){return[e.unitId,e.sheetId,e.range.startRow,e.range.endRow,e.range.startColumn,e.range.endColumn].join(`:`)}async _waitForExecutionSlot(e,t,i,a,o){return e%t===0?(await new Promise(e=>{let t=(0,n.requestImmediateMacroTask)(e);o.push(t)}),i?(this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.CURRENTLY_CALCULATING_ARRAY_FORMULA),this._runtimeService.setCompletedArrayFormulasCount(e+1)):(this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.CURRENTLY_CALCULATING),this._runtimeService.setCompletedFormulasCount(e+1)),this._executionInProgressListener$.next(this._runtimeService.getRuntimeState()),this._runtimeService.isStopExecution()||a.formula==null&&a.getDirtyData==null?(this._runtimeService.setFormulaExecuteStage(r.FormulaExecuteStageType.IDLE),this._runtimeService.markedAsStopFunctionsExecuted(),this._executionCompleteListener$.next(this._runtimeService.getAllRuntimeData()),!0):!1):!1}async _calculateDependencyTree(e,t,n){let r=e.getDirtyData;if(this._runtimeService.setCurrent(e.row,e.column,e.rowCount,e.columnCount,e.subUnitId,e.unitId),r!=null&&e.featureId!=null){let t=e.featureId,{runtimeCellData:n,dirtyRanges:i}=r(this._currentConfigService.getDirtyData(),this._runtimeService.getAllRuntimeData());return this._runtimeService.setRuntimeFeatureCellData(t,n),this._runtimeService.setRuntimeFeatureRange(t,i),!1}let i=this._getCalculationNodeData(e,t,n),a=i.node,o;try{return o=this._interpreter.checkAsyncNode(i.node)?await this._interpreter.executeAsync(i):this._interpreter.execute(i),e.formulaId==null?this._runtimeService.setRuntimeData(o):this._runtimeService.setRuntimeOtherData(e.formulaId,e.refOffsetX,e.refOffsetY,o),this._refreshDynamicDepsAfterCalculate(n,t,e,a)}finally{a.resetCalculationState()}}_getCalculationNodeData(e,t,n){let i=n.getCachedCalculationNodeData(t);return(i==null?void 0:i.node)==null?{node:(0,r.generateAstNode)(e.unitId,e.formula,this._lexer,this._astTreeBuilder,this._currentConfigService),refOffsetX:e.refOffsetX,refOffsetY:e.refOffsetY}:i}},D=class{constructor(e,t){w(this,`maxRows`,void 0),w(this,`maxCols`,void 0),w(this,`sheetSize`,void 0),w(this,`_sheetKeyById`,new Map),w(this,`_sheetIdByKey`,[]),this.maxRows=e,this.maxCols=t,this.sheetSize=e*t}reset(){this._sheetKeyById.clear(),this._sheetIdByKey.length=0}encodeCell(e,t,n,r){return this.encodeSheet(e,t)*this.sheetSize+n*this.maxCols+r}decodeCell(e){let t=Math.floor(e/this.sheetSize),n=e-t*this.sheetSize,r=Math.floor(n/this.maxCols),i=n-r*this.maxCols,{unitId:a,sheetId:o}=this.decodeSheetKey(t);return{unitId:a,sheetId:o,row:r,col:i}}encodeSheet(e,t){let n=`${e}\0${t}`,r=this._sheetKeyById.get(n);if(r!==void 0)return r;let i=this._sheetIdByKey.length;return this._sheetKeyById.set(n,i),this._sheetIdByKey.push({unitId:e,sheetId:t}),i}decodeSheetKey(e){let t=this._sheetIdByKey[e];if(!t)throw Error(`Unknown sheet key: ${e}`);return t}encodeRow(e,t,n){return this.encodeSheet(e,t)*this.maxRows+n}encodeRowBySheetKey(e,t){return e*this.maxRows+t}decodeRowKey(e){let t=Math.floor(e/this.maxRows),n=e-t*this.maxRows;return{sheetKey:t,...this.decodeSheetKey(t),row:n}}encodeCol(e,t,n){return this.encodeSheet(e,t)*this.maxCols+n}encodeColBySheetKey(e,t){return e*this.maxCols+t}decodeColKey(e){let t=Math.floor(e/this.maxCols),n=e-t*this.maxCols;return{sheetKey:t,...this.decodeSheetKey(t),col:n}}};function O(e){if(typeof e!=`number`)throw TypeError(`CellFormula node id must be a numeric CellId`)}function k(e){let{startRow:t,endRow:n,startColumn:r,endColumn:i}=e.range;if(t<=n&&r<=i)return e;let a=t<n?t:n,o=t<n?n:t,s=r<i?r:i,c=r<i?i:r;return{...e,range:{...e.range,startRow:a,endRow:o,startColumn:s,endColumn:c}}}function A(e){return e.range.endRow-e.range.startRow+1}function j(e){return e.range.endColumn-e.range.startColumn+1}function M(e,t){return e.unitId===t.unitId&&e.sheetId===t.sheetId&&e.range.startRow<=t.row&&t.row<=e.range.endRow&&e.range.startColumn<=t.col&&t.col<=e.range.endColumn}function N(e){if(!e||e.length===0)return[];if(e.length===1)return[e[0]];let t=e.slice().sort((e,t)=>e-t),n=1;for(let e=1;e<t.length;e++)t[e]!==t[n-1]&&(t[n++]=t[e]);return t.length=n,t}function P(e,t,n){let r=e.get(t);r||(r=[],e.set(t,r)),r.push(n)}function F(e,t){let n=e.indexOf(t);if(n<0)return!1;let r=e.pop();return n<e.length&&(e[n]=r),!0}function I(e,t,n){let r=e.get(t);r&&(F(r,n),r.length===0&&e.delete(t))}function L(e,t){if(e===void 0)return t;if(typeof e==`number`)return e===t?e:[e,t];for(let n=0;n<e.length;n++)if(e[n]===t)return e;return e.push(t),e}function R(e,t){if(e===void 0)return;if(typeof e==`number`)return e===t?void 0:e;let n=e.indexOf(t);if(n<0)return e;if(e.length===1)return;if(e.length===2)return e[1-n];let r=e.pop();return n<e.length&&(e[n]=r),e}function z(e,t){if(e!==void 0){if(typeof e==`number`){t(e);return}for(let n=0;n<e.length;n++)t(e[n])}}function B(e,t,n){let r=L(e.get(t),n);e.set(t,r)}function V(e,t,n){let r=e.get(t);if(r===void 0)return;let i=R(r,n);i===void 0?e.delete(t):e.set(t,i)}function H(e,t){if(e.length>=t)return e;let n=Math.max(16,e.length);for(;n<t;)n*=2;let r=new Uint8Array(n);return r.set(e),r}function U(e,t){if(e.length>=t)return e;let n=Math.max(16,e.length);for(;n<t;)n*=2;let r=new Uint32Array(n);return r.set(e),r}function W(e){if(!e||e.length===0)return[];let t=new Set,n=[];for(let r=0;r<e.length;r++){let i=e[r],a=`${i.type}:${String(i.id)}`;t.has(a)||(t.add(a),n.push(i))}return n}function G(e){if(e.length<=1){let t=Array(e.length);for(let n=0;n<e.length;n++)t[n]=k(e[n]);return t}let t=Array(e.length);for(let n=0;n<e.length;n++)t[n]=k(e[n]);return q(K(t))}function K(e){let t=e.slice().sort((e,t)=>{let n=e.unitId.localeCompare(t.unitId);if(n!==0)return n;let r=e.sheetId.localeCompare(t.sheetId);return r===0?e.range.startRow===t.range.startRow?e.range.endRow===t.range.endRow?e.range.startColumn===t.range.startColumn?e.range.endColumn-t.range.endColumn:e.range.startColumn-t.range.startColumn:e.range.endRow-t.range.endRow:e.range.startRow-t.range.startRow:r}),n=[];for(let e of t){let t=n[n.length-1];t&&t.unitId===e.unitId&&t.sheetId===e.sheetId&&t.range.startRow===e.range.startRow&&t.range.endRow===e.range.endRow&&e.range.startColumn<=t.range.endColumn+1?e.range.endColumn>t.range.endColumn&&(t.range.endColumn=e.range.endColumn):n.push({...e,range:{...e.range}})}return n}function q(e){let t=e.slice().sort((e,t)=>{let n=e.unitId.localeCompare(t.unitId);if(n!==0)return n;let r=e.sheetId.localeCompare(t.sheetId);return r===0?e.range.startColumn===t.range.startColumn?e.range.endColumn===t.range.endColumn?e.range.startRow===t.range.startRow?e.range.endRow-t.range.endRow:e.range.startRow-t.range.startRow:e.range.endColumn-t.range.endColumn:e.range.startColumn-t.range.startColumn:r}),n=[];for(let e of t){let t=n[n.length-1];t&&t.unitId===e.unitId&&t.sheetId===e.sheetId&&t.range.startColumn===e.range.startColumn&&t.range.endColumn===e.range.endColumn&&e.range.startRow<=t.range.endRow+1?e.range.endRow>t.range.endRow&&(t.range.endRow=e.range.endRow):n.push({...e,range:{...e.range}})}return n}var J=class{constructor(e,t){this._codec=e,this._indexToNodeId=t,w(this,`_rowBuckets`,new Map),w(this,`_colBuckets`,new Map)}addFormulaCell(e,t){let n=this._codec.decodeCell(e);P(this._rowBuckets,this._codec.encodeRow(n.unitId,n.sheetId,n.row),t),P(this._colBuckets,this._codec.encodeCol(n.unitId,n.sheetId,n.col),t)}removeFormulaCell(e,t){let n=this._codec.decodeCell(e);I(this._rowBuckets,this._codec.encodeRow(n.unitId,n.sheetId,n.row),t),I(this._colBuckets,this._codec.encodeCol(n.unitId,n.sheetId,n.col),t)}forEachFormulaInRange(e,t){let n=k(e);return A(n)<=j(n)?this._scanRows(n,t):this._scanCols(n,t)}_scanRows(e,t){if(A(e)<=this._rowBuckets.size){for(let n=e.range.startRow;n<=e.range.endRow;n++)if(this._scanRowBucket(this._codec.encodeRow(e.unitId,e.sheetId,n),e,t)===!1)return!1;return!0}for(let[n]of this._rowBuckets){let r=this._codec.decodeRowKey(n);if(r.unitId===e.unitId&&r.sheetId===e.sheetId&&e.range.startRow<=r.row&&r.row<=e.range.endRow&&this._scanRowBucket(n,e,t)===!1)return!1}return!0}_scanCols(e,t){if(j(e)<=this._colBuckets.size){for(let n=e.range.startColumn;n<=e.range.endColumn;n++)if(this._scanColBucket(this._codec.encodeCol(e.unitId,e.sheetId,n),e,t)===!1)return!1;return!0}for(let[n]of this._colBuckets){let r=this._codec.decodeColKey(n);if(r.unitId===e.unitId&&r.sheetId===e.sheetId&&e.range.startColumn<=r.col&&r.col<=e.range.endColumn&&this._scanColBucket(n,e,t)===!1)return!1}return!0}_scanRowBucket(e,t,n){let r=this._rowBuckets.get(e);if(!r)return!0;for(let e=0;e<r.length;e++){let i=r[e],a=this._indexToNodeId[i],o=this._codec.decodeCell(a);if(o.unitId===t.unitId&&o.sheetId===t.sheetId&&t.range.startColumn<=o.col&&o.col<=t.range.endColumn&&n(i)===!1)return!1}return!0}_scanColBucket(e,t,n){let r=this._colBuckets.get(e);if(!r)return!0;for(let e=0;e<r.length;e++){let i=r[e],a=this._indexToNodeId[i],o=this._codec.decodeCell(a);if(o.unitId===t.unitId&&o.sheetId===t.sheetId&&t.range.startRow<=o.row&&o.row<=t.range.endRow&&n(i)===!1)return!1}return!0}},Y=class{constructor(e,t){this._codec=e,this._pointScanCellLimit=t,w(this,`_rowCells`,new Map),w(this,`_colCells`,new Map)}add(e){let t=this._codec.decodeCell(e);P(this._rowCells,this._codec.encodeRow(t.unitId,t.sheetId,t.row),e),P(this._colCells,this._codec.encodeCol(t.unitId,t.sheetId,t.col),e)}remove(e){let t=this._codec.decodeCell(e);I(this._rowCells,this._codec.encodeRow(t.unitId,t.sheetId,t.row),e),I(this._colCells,this._codec.encodeCol(t.unitId,t.sheetId,t.col),e)}forEachCellInRange(e,t){let n=k(e),r=A(n),i=j(n);if(this._isSmallArea(r,i)){for(let e=n.range.startRow;e<=n.range.endRow;e++)for(let r=n.range.startColumn;r<=n.range.endColumn;r++)t(this._codec.encodeCell(n.unitId,n.sheetId,e,r));return}Math.min(r,this._rowCells.size)<=Math.min(i,this._colCells.size)?this._scanRows(n,t):this._scanCols(n,t)}_isSmallArea(e,t){return e<=0||t<=0?!0:e>this._pointScanCellLimit?!1:e*t<=this._pointScanCellLimit}_scanRows(e,t){if(A(e)<=this._rowCells.size){for(let n=e.range.startRow;n<=e.range.endRow;n++)this._scanRowBucket(this._codec.encodeRow(e.unitId,e.sheetId,n),e,t);return}for(let[n]of this._rowCells){let r=this._codec.decodeRowKey(n);r.unitId===e.unitId&&r.sheetId===e.sheetId&&e.range.startRow<=r.row&&r.row<=e.range.endRow&&this._scanRowBucket(n,e,t)}}_scanCols(e,t){if(j(e)<=this._colCells.size){for(let n=e.range.startColumn;n<=e.range.endColumn;n++)this._scanColBucket(this._codec.encodeCol(e.unitId,e.sheetId,n),e,t);return}for(let[n]of this._colCells){let r=this._codec.decodeColKey(n);r.unitId===e.unitId&&r.sheetId===e.sheetId&&e.range.startColumn<=r.col&&r.col<=e.range.endColumn&&this._scanColBucket(n,e,t)}}_scanRowBucket(e,t,n){let r=this._rowCells.get(e);if(r)for(let e=0;e<r.length;e++){let i=r[e],a=this._codec.decodeCell(i);a.unitId===t.unitId&&a.sheetId===t.sheetId&&t.range.startColumn<=a.col&&a.col<=t.range.endColumn&&n(i)}}_scanColBucket(e,t,n){let r=this._colCells.get(e);if(r)for(let e=0;e<r.length;e++){let i=r[e],a=this._codec.decodeCell(i);a.unitId===t.unitId&&a.sheetId===t.sheetId&&t.range.startRow<=a.row&&a.row<=t.range.endRow&&n(i)}}},X=class{constructor(e,t,n){this._codec=e,this._maxIndexedSpan=n,w(this,`_wholeSheet`,new Map),w(this,`_wholeCol`,new Map),w(this,`_wholeRow`,new Map),w(this,`_rowBuckets`,new Map),w(this,`_colBuckets`,new Map),w(this,`_largeRangeIds`,[]),w(this,`_sheetArr`,void 0),w(this,`_startRowArr`,void 0),w(this,`_endRowArr`,void 0),w(this,`_startColArr`,void 0),w(this,`_endColArr`,void 0),w(this,`_nodeArr`,void 0),w(this,`_kindArr`,void 0),w(this,`_activeArr`,void 0),w(this,`_rangeSeenEpochArr`,void 0),w(this,`_rangeEpoch`,1),w(this,`_nextRangeId`,0),w(this,`_freeRangeIds`,[]),w(this,`_nodeToRangeIds`,new Map),w(this,`_nodeToWholeSheetKeys`,new Map),w(this,`_nodeToWholeColKeys`,new Map),w(this,`_nodeToWholeRowKeys`,new Map);let r=Math.max(16,t);this._sheetArr=new Uint32Array(r),this._startRowArr=new Uint32Array(r),this._endRowArr=new Uint32Array(r),this._startColArr=new Uint32Array(r),this._endColArr=new Uint32Array(r),this._nodeArr=new Uint32Array(r),this._kindArr=new Uint8Array(r),this._activeArr=new Uint8Array(r),this._rangeSeenEpochArr=new Uint32Array(r)}addRange(e,t){let n=k(t),r=this._codec.encodeSheet(n.unitId,n.sheetId),i=A(n),a=j(n),o=a===this._codec.maxCols,s=i===this._codec.maxRows;if(o&&s){B(this._wholeSheet,r,e),P(this._nodeToWholeSheetKeys,e,r);return}if(s){for(let t=n.range.startColumn;t<=n.range.endColumn;t++){let n=this._codec.encodeColBySheetKey(r,t);B(this._wholeCol,n,e),P(this._nodeToWholeColKeys,e,n)}return}if(o){for(let t=n.range.startRow;t<=n.range.endRow;t++){let n=this._codec.encodeRowBySheetKey(r,t);B(this._wholeRow,n,e),P(this._nodeToWholeRowKeys,e,n)}return}let c=Math.min(i,a),l=this._allocRangeId();if(this._setRangeMeta(l,e,n),c>this._maxIndexedSpan)this._kindArr[l]=3,this._largeRangeIds.push(l);else if(i<=a){this._kindArr[l]=1;for(let e=n.range.startRow;e<=n.range.endRow;e++)P(this._rowBuckets,this._codec.encodeRowBySheetKey(r,e),l)}else{this._kindArr[l]=2;for(let e=n.range.startColumn;e<=n.range.endColumn;e++)P(this._colBuckets,this._codec.encodeColBySheetKey(r,e),l)}P(this._nodeToRangeIds,e,l)}removeNode(e){let t=this._nodeToWholeSheetKeys.get(e);if(t){for(let n=0;n<t.length;n++)V(this._wholeSheet,t[n],e);this._nodeToWholeSheetKeys.delete(e)}let n=this._nodeToWholeColKeys.get(e);if(n){for(let t=0;t<n.length;t++)V(this._wholeCol,n[t],e);this._nodeToWholeColKeys.delete(e)}let r=this._nodeToWholeRowKeys.get(e);if(r){for(let t=0;t<r.length;t++)V(this._wholeRow,r[t],e);this._nodeToWholeRowKeys.delete(e)}let i=this._nodeToRangeIds.get(e);if(i){for(let e=0;e<i.length;e++)this._removeRangeId(i[e]);this._nodeToRangeIds.delete(e)}}forEachPoint(e,t,n,r,i){let a=this._codec.encodeSheet(e,t);z(this._wholeSheet.get(a),i),z(this._wholeCol.get(this._codec.encodeColBySheetKey(a,r)),i),z(this._wholeRow.get(this._codec.encodeRowBySheetKey(a,n)),i);let o=this._rowBuckets.get(this._codec.encodeRowBySheetKey(a,n));if(o)for(let e=0;e<o.length;e++){let t=o[e];this._activeArr[t]&&this._rangeContainsPoint(t,a,n,r)&&i(this._nodeArr[t])}let s=this._colBuckets.get(this._codec.encodeColBySheetKey(a,r));if(s)for(let e=0;e<s.length;e++){let t=s[e];this._activeArr[t]&&this._rangeContainsPoint(t,a,n,r)&&i(this._nodeArr[t])}for(let e=0;e<this._largeRangeIds.length;e++){let t=this._largeRangeIds[e];this._activeArr[t]&&this._rangeContainsPoint(t,a,n,r)&&i(this._nodeArr[t])}}forEachRangeIntersecting(e,t){this.forEachRangesIntersecting([e],t)}forEachRangesIntersecting(e,t){if(e.length===0)return;let n=Array(e.length);for(let t=0;t<e.length;t++)n[t]=k(e[t]);this._nextRangeEpoch();for(let e=0;e<n.length;e++){let r=n[e],i=this._codec.encodeSheet(r.unitId,r.sheetId);z(this._wholeSheet.get(i),t),this._scanWholeCols(r,i,t),this._scanWholeRows(r,i,t),this._scanRowIndexedRanges(r,i,t),this._scanColIndexedRanges(r,i,t);for(let e=0;e<this._largeRangeIds.length;e++){let n=this._largeRangeIds[e];this._activeArr[n]&&(this._wasRangeSeen(n)||this._rangeIntersectsInput(n,r,i)&&(this._markRangeSeen(n),t(this._nodeArr[n])))}}}_allocRangeId(){let e=this._freeRangeIds.pop();if(e!==void 0)return e;let t=this._nextRangeId++;return this._ensureRangeCapacity(t+1),t}_ensureRangeCapacity(e){this._sheetArr=U(this._sheetArr,e),this._startRowArr=U(this._startRowArr,e),this._endRowArr=U(this._endRowArr,e),this._startColArr=U(this._startColArr,e),this._endColArr=U(this._endColArr,e),this._nodeArr=U(this._nodeArr,e),this._kindArr=H(this._kindArr,e),this._activeArr=H(this._activeArr,e),this._rangeSeenEpochArr=U(this._rangeSeenEpochArr,e)}_setRangeMeta(e,t,n){this._sheetArr[e]=this._codec.encodeSheet(n.unitId,n.sheetId),this._startRowArr[e]=n.range.startRow,this._endRowArr[e]=n.range.endRow,this._startColArr[e]=n.range.startColumn,this._endColArr[e]=n.range.endColumn,this._nodeArr[e]=t,this._activeArr[e]=1}_removeRangeId(e){if(!this._activeArr[e])return;let t=this._kindArr[e],n=this._sheetArr[e];if(t===1)for(let t=this._startRowArr[e];t<=this._endRowArr[e];t++)I(this._rowBuckets,this._codec.encodeRowBySheetKey(n,t),e);else if(t===2)for(let t=this._startColArr[e];t<=this._endColArr[e];t++)I(this._colBuckets,this._codec.encodeColBySheetKey(n,t),e);else t===3&&F(this._largeRangeIds,e);this._activeArr[e]=0,this._kindArr[e]=0,this._freeRangeIds.push(e)}_nextRangeEpoch(){this._rangeEpoch++,this._rangeEpoch>=4294967295&&(this._rangeSeenEpochArr.fill(0),this._rangeEpoch=1)}_wasRangeSeen(e){return this._rangeSeenEpochArr[e]===this._rangeEpoch}_markRangeSeen(e){this._rangeSeenEpochArr[e]=this._rangeEpoch}_scanWholeCols(e,t,n){if(j(e)<=this._wholeCol.size){for(let r=e.range.startColumn;r<=e.range.endColumn;r++)z(this._wholeCol.get(this._codec.encodeColBySheetKey(t,r)),n);return}let r=this._codec.encodeColBySheetKey(t,e.range.startColumn),i=this._codec.encodeColBySheetKey(t,e.range.endColumn);for(let[e,t]of this._wholeCol)r<=e&&e<=i&&z(t,n)}_scanWholeRows(e,t,n){if(A(e)<=this._wholeRow.size){for(let r=e.range.startRow;r<=e.range.endRow;r++)z(this._wholeRow.get(this._codec.encodeRowBySheetKey(t,r)),n);return}let r=this._codec.encodeRowBySheetKey(t,e.range.startRow),i=this._codec.encodeRowBySheetKey(t,e.range.endRow);for(let[e,t]of this._wholeRow)r<=e&&e<=i&&z(t,n)}_scanRowIndexedRanges(e,t,n){if(A(e)<=this._rowBuckets.size){for(let r=e.range.startRow;r<=e.range.endRow;r++)this._scanRangeIdBucket(this._rowBuckets.get(this._codec.encodeRowBySheetKey(t,r)),e,t,n);return}let r=this._codec.encodeRowBySheetKey(t,e.range.startRow),i=this._codec.encodeRowBySheetKey(t,e.range.endRow);for(let[a,o]of this._rowBuckets)r<=a&&a<=i&&this._scanRangeIdBucket(o,e,t,n)}_scanColIndexedRanges(e,t,n){if(j(e)<=this._colBuckets.size){for(let r=e.range.startColumn;r<=e.range.endColumn;r++)this._scanRangeIdBucket(this._colBuckets.get(this._codec.encodeColBySheetKey(t,r)),e,t,n);return}let r=this._codec.encodeColBySheetKey(t,e.range.startColumn),i=this._codec.encodeColBySheetKey(t,e.range.endColumn);for(let[a,o]of this._colBuckets)r<=a&&a<=i&&this._scanRangeIdBucket(o,e,t,n)}_scanRangeIdBucket(e,t,n,r){if(e)for(let i=0;i<e.length;i++){let a=e[i];this._activeArr[a]&&(this._wasRangeSeen(a)||this._rangeIntersectsInput(a,t,n)&&(this._markRangeSeen(a),r(this._nodeArr[a])))}}_rangeContainsPoint(e,t,n,r){return this._sheetArr[e]===t&&this._startRowArr[e]<=n&&n<=this._endRowArr[e]&&this._startColArr[e]<=r&&r<=this._endColArr[e]}_rangeIntersectsInput(e,t,n){return this._sheetArr[e]===n&&this._startRowArr[e]<=t.range.endRow&&this._endRowArr[e]>=t.range.startRow&&this._startColArr[e]<=t.range.endColumn&&this._endColArr[e]>=t.range.startColumn}},Z=class{constructor(e){var t,n,r,i;w(this,`codec`,void 0),w(this,`_maxIndexedSpan`,void 0),w(this,`_pointScanCellLimit`,void 0),w(this,`_initialNodeCapacity`,void 0),w(this,`_initialRangeCapacity`,void 0),w(this,`directDeps`,void 0),w(this,`nodeDeps`,void 0),w(this,`rangeIndex`,void 0),w(this,`cellFormulaToIndex`,void 0),w(this,`otherFormulaToIndex`,void 0),w(this,`featureCalculationToIndex`,void 0),w(this,`indexToNodeId`,void 0),w(this,`dirty`,void 0),w(this,`inQueue`,void 0),w(this,`_indexToNodeType`,void 0),w(this,`_cellPrecedents`,void 0),w(this,`_rangePrecedents`,void 0),w(this,`_nodePrecedents`,void 0),w(this,`_dynamicDeps`,void 0),w(this,`_dynamicSignature`,void 0),w(this,`_runtimeDirectDeps`,void 0),w(this,`_runtimeNodeDeps`,void 0),w(this,`_runtimeRangeIndex`,void 0),w(this,`_runtimeCellPrecedents`,void 0),w(this,`_runtimeRangePrecedents`,void 0),w(this,`_runtimeNodePrecedents`,void 0),w(this,`_activeNode`,void 0),w(this,`_seenNodeEpoch`,void 0),w(this,`_visitNodeEpoch`,void 0),w(this,`_edgeSeenEpoch`,void 0),w(this,`_tarjanSeenEpoch`,void 0),w(this,`_tarjanIndexArr`,void 0),w(this,`_tarjanLowArr`,void 0),w(this,`_tarjanOnStack`,void 0),w(this,`_emitEpoch`,1),w(this,`_visitEpoch`,1),w(this,`_edgeEpoch`,1),w(this,`_tarjanEpoch`,1),w(this,`_propQueue`,[]),w(this,`_dirtyList`,[]),w(this,`_activeNodeCount`,0),w(this,`_dirtyNodeCount`,0),w(this,`_directPointIndex`,void 0),w(this,`_runtimeDirectPointIndex`,void 0),w(this,`_formulaCellIndex`,void 0),w(this,`_sharedFormulaGroups`,void 0),w(this,`_sharedFormulaGroupIndexById`,void 0),w(this,`_sharedFormulaMembershipByNode`,void 0),w(this,`_sharedFormulaSourceEntries`,void 0),w(this,`_sharedFormulaSourceRangeIndex`,void 0),this._maxIndexedSpan=(t=e.maxIndexedSpan)==null?4096:t,this._pointScanCellLimit=(n=e.pointScanCellLimit)==null?4096:n,this._initialNodeCapacity=Math.max(16,(r=e.initialNodeCapacity)==null?1024:r),this._initialRangeCapacity=Math.max(16,(i=e.initialRangeCapacity)==null?1024:i),this.codec=new D(e.maxRows,e.maxCols),this.reset()}reset(){this.codec.reset(),this.directDeps=new Map,this.nodeDeps=new Map,this.rangeIndex=new X(this.codec,this._initialRangeCapacity,this._maxIndexedSpan),this._runtimeDirectDeps=new Map,this._runtimeNodeDeps=new Map,this._runtimeRangeIndex=new X(this.codec,this._initialRangeCapacity,this._maxIndexedSpan),this.cellFormulaToIndex=new Map,this.otherFormulaToIndex=new Map,this.featureCalculationToIndex=new Map,this.indexToNodeId=[],this._indexToNodeType=new Uint8Array(this._initialNodeCapacity),this.dirty=new Uint8Array(this._initialNodeCapacity),this.inQueue=new Uint8Array(this._initialNodeCapacity),this._activeNode=new Uint8Array(this._initialNodeCapacity),this._cellPrecedents=[],this._rangePrecedents=[],this._nodePrecedents=[],this._dynamicDeps=[],this._dynamicSignature=[],this._runtimeCellPrecedents=[],this._runtimeRangePrecedents=[],this._runtimeNodePrecedents=[],this._seenNodeEpoch=new Uint32Array(this._initialNodeCapacity),this._visitNodeEpoch=new Uint32Array(this._initialNodeCapacity),this._edgeSeenEpoch=new Uint32Array(this._initialNodeCapacity),this._tarjanSeenEpoch=new Uint32Array(this._initialNodeCapacity),this._tarjanIndexArr=new Uint32Array(this._initialNodeCapacity),this._tarjanLowArr=new Uint32Array(this._initialNodeCapacity),this._tarjanOnStack=new Uint8Array(this._initialNodeCapacity),this._emitEpoch=1,this._visitEpoch=1,this._edgeEpoch=1,this._tarjanEpoch=1,this._propQueue.length=0,this._dirtyList.length=0,this._activeNodeCount=0,this._dirtyNodeCount=0,this._directPointIndex=new Y(this.codec,this._pointScanCellLimit),this._runtimeDirectPointIndex=new Y(this.codec,this._pointScanCellLimit),this._formulaCellIndex=new J(this.codec,this.indexToNodeId),this._sharedFormulaGroups=[],this._sharedFormulaGroupIndexById=new Map,this._sharedFormulaMembershipByNode=new Int32Array(this._initialNodeCapacity),this._sharedFormulaMembershipByNode.fill(-1),this._sharedFormulaSourceEntries=[],this._sharedFormulaSourceRangeIndex=new X(this.codec,this._initialRangeCapacity,this._maxIndexedSpan)}encodeCell(e,t,n,r){return this.codec.encodeCell(e,t,n,r)}decodeCell(e){return this.codec.decodeCell(e)}encodeFeatureCalculationId(e,t,n){return`${e}${t}${n}`}decodeFeatureCalculationId(e){let t=this._tryDecodeFeatureCalculationId(e);if(t===void 0)throw Error(`Invalid feature calculation id: ${String(e)}`);return t}encodeOtherFormulaId(e,t,n,r,i){return`${e}${t}${n}${r}${i}`}decodeOtherFormulaId(e){let t=this._tryDecodeOtherFormulaId(e);if(t===void 0)throw Error(`Invalid other formula id: ${String(e)}`);return t}setCellFormulaDeps(e,t,n){var r,i;return this._setCalcNodeDepsByType(1,e,t,(r=n==null?void 0:n.checkCycle)==null?!0:r,(i=n==null?void 0:n.markDirty)==null?!0:i,(n==null?void 0:n.mode)===`merge`)}setOtherFormulaDeps(e,t,n){var r,i;return this._setCalcNodeDepsByType(2,e,t,(r=n==null?void 0:n.checkCycle)==null?!0:r,(i=n==null?void 0:n.markDirty)==null?!0:i,(n==null?void 0:n.mode)===`merge`)}setFeatureCalculationDeps(e,t,n){var r,i;return this._setCalcNodeDepsByType(3,e,t,(r=n==null?void 0:n.checkCycle)==null?!0:r,(i=n==null?void 0:n.markDirty)==null?!0:i,(n==null?void 0:n.mode)===`merge`)}setCalcNodeDeps(e,t,n){var r,i;return this._setCalcNodeDepsByType(e.type,e.id,t,(r=n==null?void 0:n.checkCycle)==null?!0:r,(i=n==null?void 0:n.markDirty)==null?!0:i,(n==null?void 0:n.mode)===`merge`)}registerCompressedSharedFormulaGroup(e){this.unregisterCompressedSharedFormulaGroup(e.groupId);let t=this._sharedFormulaGroups.length,n=k(e.fillRange),r={...n,range:{...n.range}},i={groupId:e.groupId,fillRange:r,patterns:e.patterns.slice(),sourceEntryIds:[]};this._sharedFormulaGroups.push(i),this._sharedFormulaGroupIndexById.set(i.groupId,t),this._markCompressedSharedFormulaMembership(t,r);for(let e=0;e<i.patterns.length;e++){let n=this._getCompressedSharedSourceCoverage(r,i.patterns[e]),a=this._sharedFormulaSourceEntries.length;this._sharedFormulaSourceEntries.push({groupIndex:t,patternIndex:e,sourceCoverage:n,active:!0}),i.sourceEntryIds.push(a),this._sharedFormulaSourceRangeIndex.addRange(a,n)}}unregisterCompressedSharedFormulaGroup(e){let t=this._sharedFormulaGroupIndexById.get(e);if(t===void 0)return;let n=this._sharedFormulaGroups[t];this._sharedFormulaGroupIndexById.delete(e);for(let e=0;e<n.sourceEntryIds.length;e++){let t=n.sourceEntryIds[e],r=this._sharedFormulaSourceEntries[t];r&&(r.active=!1),this._sharedFormulaSourceRangeIndex.removeNode(t)}this._clearCompressedSharedFormulaMembership(t,n.fillRange)}clearCompressedSharedFormulaGroups(e,t){let n=[];for(let r=0;r<this._sharedFormulaGroups.length;r++){let i=this._sharedFormulaGroups[r];this._sharedFormulaGroupIndexById.has(i.groupId)&&(e!==void 0&&i.fillRange.unitId!==e||t!==void 0&&i.fillRange.sheetId!==t||n.push(i.groupId))}for(let e=0;e<n.length;e++)this.unregisterCompressedSharedFormulaGroup(n[e])}_setCalcNodeDepsByType(e,t,n,r,i,a){var o,s,c,l,u,d,f;let p=this._getOrCreateNodeIndexByType(e,t),m=this._activeNode[p]===1,h=m&&e===1&&!this._isEmptyCalcNodeDeps(n)&&this._sharedFormulaMembershipByNode[p]>=0,g=m&&(r||a),_=g?(o=(s=this._cellPrecedents[p])==null?void 0:s.slice())==null?[]:o:[],v=g?(c=(l=this._rangePrecedents[p])==null?void 0:l.slice())==null?[]:c:[],y=g?(u=(d=this._nodePrecedents[p])==null?void 0:d.slice())==null?[]:u:[];m&&this._removeNodeDepsOnly(p);let b=this._normalizeCalcNodeDeps(n),x=b.cells,S=b.ranges,C=b.nodes,w=this._resolveExplicitNodeDeps(C),T=(f=this._dynamicDeps[p])==null?[]:f,E=a?this._mergeDynamicDeps(T,b.dynamics):b.dynamics,D=a?this._mergeSortedUniqueNumbers(_,x):x,k=a?this._mergeRangeDeps(v,S):S,A=a?this._mergeSortedUniqueNumbers(y,w):w;return r&&this._wouldCreateCycleForNewDeps(p,D,k,A)?(m&&this._addNodeDepsOnly(p,_,v,y),{nodeIndex:p,hasCycle:!0}):(h&&this._unregisterCompressedSharedFormulaGroupByNode(p),!m&&e===1&&(O(t),this._formulaCellIndex.addFormulaCell(t,p)),m||this._activeNodeCount++,this._activeNode[p]=1,this._addNodeDepsOnly(p,D,k,A),this._setNodeDynamicDeps(p,E),i&&(this._markNodeIndexDirty(p,!0),this._propagateDirtyQueue()),{nodeIndex:p,hasCycle:!1})}setManyCalcNodeDeps(e,t){var n,r;let i=(n=t==null?void 0:t.markDirty)==null?!0:n,a=(r=t==null?void 0:t.checkCycle)==null?!0:r,o=(t==null?void 0:t.mode)===`merge`,s=Array(e.length),c=[];for(let t=0;t<e.length;t++){let n=e[t],r=this._setCalcNodeDepsByType(n.node.type,n.node.id,n.deps,a,!1,o);s[t]=r,r.hasCycle||c.push(r.nodeIndex)}return i&&c.length>0&&this._markCalcNodeIndicesChanged(c),s}setManyCellFormulaDeps(e,t){var n,r;let i=(n=t==null?void 0:t.markDirty)==null?!0:n,a=(r=t==null?void 0:t.checkCycle)==null?!0:r,o=(t==null?void 0:t.mode)===`merge`,s=Array(e.length),c=[];for(let t=0;t<e.length;t++){let n=e[t],r=this._setCalcNodeDepsByType(1,n.cell,n.deps,a,!1,o);s[t]=r,r.hasCycle||c.push(r.nodeIndex)}return i&&c.length>0&&this._markCalcNodeIndicesChanged(c),s}setManyOtherFormulaDeps(e,t){var n,r;let i=(n=t==null?void 0:t.markDirty)==null?!0:n,a=(r=t==null?void 0:t.checkCycle)==null?!0:r,o=(t==null?void 0:t.mode)===`merge`,s=Array(e.length),c=[];for(let t=0;t<e.length;t++){let n=e[t],r=this._setCalcNodeDepsByType(2,n.id,n.deps,a,!1,o);s[t]=r,r.hasCycle||c.push(r.nodeIndex)}return i&&c.length>0&&this._markCalcNodeIndicesChanged(c),s}setManyFeatureCalculationDeps(e,t){var n,r;let i=(n=t==null?void 0:t.markDirty)==null?!0:n,a=(r=t==null?void 0:t.checkCycle)==null?!0:r,o=(t==null?void 0:t.mode)===`merge`,s=Array(e.length),c=[];for(let t=0;t<e.length;t++){let n=e[t],r=this._setCalcNodeDepsByType(3,n.id,n.deps,a,!1,o);s[t]=r,r.hasCycle||c.push(r.nodeIndex)}return i&&c.length>0&&this._markCalcNodeIndicesChanged(c),s}removeCellFormula(e,t){this._removeCalcNodeByType(1,e,t)}removeOtherFormula(e,t){this._removeCalcNodeByType(2,e,t)}removeFeatureCalculation(e,t){this._removeCalcNodeByType(3,e,t)}removeCellFormulas(e,t){this._removeCalcNodeIds(1,e,t)}removeOtherFormulas(e,t){this._removeCalcNodeIds(2,e,t)}removeFeatureCalculations(e,t){this._removeCalcNodeIds(3,e,t)}removeCalcNodes(e,t){if(e.length===0)return;let n=[];for(let t=0;t<e.length;t++){let r=e[t],i=this._getNodeIndexByType(r.type,r.id);i!==void 0&&this._activeNode[i]&&n.push(i)}this._removeCalcNodeIndices(n,t)}clearCellFormulas(e,t,n){let r=[];for(let[n,i]of this.cellFormulaToIndex){if(!this._activeNode[i])continue;let a=this.codec.decodeCell(n);a.unitId===e&&(t!==void 0&&a.sheetId!==t||r.push(i))}this._removeCalcNodeIndices(r,n)}clearOtherFormulas(e,t,n,r,i,a){if(n!==void 0&&n.length===0)return;let o=[];for(let[a,s]of this.otherFormulaToIndex){if(!this._activeNode[s])continue;let c=this._tryDecodeOtherFormulaId(a);c!==void 0&&c.unitId===e&&(t!==void 0&&c.sheetId!==t||n!==void 0&&!this._includesFormulaId(n,c.formulaId)||r!==void 0&&c.refOffsetX!==r||r!==void 0&&i!==void 0&&c.refOffsetY!==i||o.push(s))}this._removeCalcNodeIndices(o,a)}_includesFormulaId(e,t){for(let n=0;n<e.length;n++)if(e[n]===t)return!0;return!1}clearFeatureCalculations(e,t,n){let r=[];for(let[n,i]of this.featureCalculationToIndex){if(!this._activeNode[i])continue;let a=this._tryDecodeFeatureCalculationId(n);a!==void 0&&a.unitId===e&&(t!==void 0&&a.sheetId!==t||r.push(i))}this._removeCalcNodeIndices(r,n)}_tryDecodeFeatureCalculationId(e){if(typeof e!=`string`)return;let t=e.indexOf(`\0`);if(t<=0)return;let n=e.indexOf(`\0`,t+1);if(!(n<=t+1)&&n!==e.length-1&&e.indexOf(`\0`,n+1)===-1)return{unitId:e.slice(0,t),sheetId:e.slice(t+1,n),formulaId:e.slice(n+1)}}_tryDecodeOtherFormulaId(e){if(typeof e!=`string`)return;let t=e.indexOf(`\0`);if(t<=0)return;let n=e.indexOf(`\0`,t+1);if(n<=t+1)return;let r=e.indexOf(`\0`,n+1);if(r<=n+1)return;let i=e.indexOf(`\0`,r+1);if(i<=r+1||i===e.length-1||e.indexOf(`\0`,i+1)!==-1)return;let a=Number(e.slice(r+1,i)),o=Number(e.slice(i+1));if(!(!Number.isFinite(a)||!Number.isFinite(o)))return{unitId:e.slice(0,t),sheetId:e.slice(t+1,n),formulaId:e.slice(n+1,r),refOffsetX:a,refOffsetY:o}}_removeCalcNodeIds(e,t,n){if(t.length===0)return;let r=[];for(let n=0;n<t.length;n++){let i=this._getNodeIndexByType(e,t[n]);i!==void 0&&this._activeNode[i]&&r.push(i)}this._removeCalcNodeIndices(r,n)}_removeCalcNodeIndices(e,t){if(e.length!==0){if(t!=null&&t.markDependentsDirty&&this._markCalcNodeIndicesChanged(e),t!=null&&t.detachDependents)for(let t=0;t<e.length;t++)this._detachDependentsFromNode(e[t]);for(let t=0;t<e.length;t++)this._removeCalcNodeByIndex(e[t])}}removeCalcNode(e,t){this._removeCalcNodeByType(e.type,e.id,t)}_removeCalcNodeByType(e,t,n){let r=this._getNodeIndexByType(e,t);r!==void 0&&this._activeNode[r]&&(n!=null&&n.markDependentsDirty&&(this._markNodeIndexDirty(r,!0),this._propagateDirtyQueue()),n!=null&&n.detachDependents&&this._detachDependentsFromNode(r),this._removeCalcNodeByIndex(r))}_removeCalcNodeByIndex(e){if(this._activeNode[e]){if(this._unregisterCompressedSharedFormulaGroupByNode(e),this._removeNodeDepsOnly(e),this._removeRuntimeDepsOnly(e),this._dynamicDeps[e]=void 0,this._dynamicSignature[e]=void 0,this._indexToNodeType[e]===1){let t=this.indexToNodeId[e];this._formulaCellIndex.removeFormulaCell(t,e)}this._activeNode[e]=0,this._activeNodeCount--,this.dirty[e]&&(this.dirty[e]=0,this._dirtyNodeCount--,this._compactDirtyList()),this.inQueue[e]=0}}markCellChanged(e){this.markCellsChanged([e])}markCellsChanged(e){this._nextEmitEpoch();for(let t of e)this._forEachDependentIndexByCellRaw(t,e=>{this._emitNodeOnceAndMarkDirty(e)});this._propagateDirtyQueue()}markRangeChanged(e,t){this.markRangesChanged([e],t)}markRangesChanged(e,t){if(e.length===0)return;let n=(t==null?void 0:t.coalesce)===!1?this._normalizeRangeDeps(e):G(e);this._nextEmitEpoch();for(let e=0;e<n.length;e++){let r=n[e];t!=null&&t.includeFormulaCells&&this._formulaCellIndex.forEachFormulaInRange(r,e=>{this._emitNodeOnceAndMarkDirty(e,!0)}),this._directPointIndex.forEachCellInRange(r,e=>{z(this.directDeps.get(e),e=>{this._emitNodeOnceAndMarkDirty(e)})}),this._runtimeDirectPointIndex.forEachCellInRange(r,e=>{z(this._runtimeDirectDeps.get(e),e=>{this._emitNodeOnceAndMarkDirty(e)})})}this._isEveryActiveNodeDirty()||this.rangeIndex.forEachRangesIntersecting(n,e=>{this._emitNodeOnceAndMarkDirty(e)}),this._isEveryActiveNodeDirty()||this._runtimeRangeIndex.forEachRangesIntersecting(n,e=>{this._emitNodeOnceAndMarkDirty(e)});for(let e=0;e<n.length&&!this._isEveryActiveNodeDirty();e++)this._forEachCompressedSharedDependentByRange(n[e],e=>{this._emitNodeOnceAndMarkDirty(e)});this._propagateDirtyQueue()}markCellFormulaChanged(e){this._markCalcNodeChangedByType(1,e)}markOtherFormulaChanged(e){this._markCalcNodeChangedByType(2,e)}markOtherFormulasChanged(e,t,n){if(!(n!==void 0&&n.length===0)){this._nextEmitEpoch();for(let[r,i]of this.otherFormulaToIndex){if(!this._activeNode[i])continue;let a=this._tryDecodeOtherFormulaId(r);a!==void 0&&a.unitId===e&&(t!==void 0&&a.sheetId!==t||n!==void 0&&!this._includesFormulaId(n,a.formulaId)||this._emitNodeOnceAndMarkDirty(i,!0))}this._propagateDirtyQueue()}}markFeatureCalculationChanged(e){this._markCalcNodeChangedByType(3,e)}markCalcNodeChanged(e){this._markCalcNodeChangedByType(e.type,e.id)}_markCalcNodeChangedByType(e,t){let n=this._getNodeIndexByType(e,t);n!==void 0&&this._activeNode[n]&&(this._markNodeIndexDirty(n,!0),this._propagateDirtyQueue())}markCalcNodesChanged(e){if(e.length!==0){this._nextEmitEpoch();for(let t=0;t<e.length;t++){let n=e[t],r=this._getNodeIndexByType(n.type,n.id);r!==void 0&&this._activeNode[r]&&this._emitNodeOnceAndMarkDirty(r,!0)}this._propagateDirtyQueue()}}markAllDirty(){this._nextEmitEpoch();for(let e=0;e<this.indexToNodeId.length;e++)this._activeNode[e]&&this._emitNodeOnceAndMarkDirty(e,!0);this._propagateDirtyQueue()}hasDynamicDeps(e){let t=this.getNodeIndex(e);if(t===void 0)return!1;let n=this._dynamicDeps[t];return n!==void 0&&n.length>0}refreshDynamicDeps(e,t){let n=this.getNodeIndex(e);if(n===void 0||!this._activeNode[n])return!1;let r=this._dynamicDeps[n];if(!r||r.length===0)return!1;let i={cells:[],ranges:[],nodes:[]},a=[];for(let n=0;n<r.length;n++){var o;let s=r[n],c=t(e,s),l=(o=c.status)==null?`resolved`:o;a.push(`${String(s.id)}:${l}:${c.signature}`),this._collectDynamicResolveResult(i,c)}i.cells=N(i.cells),i.ranges=this._normalizeRangeDeps(i.ranges),i.nodes=this._mergeSortedUniqueNumbers([],i.nodes);let s=a.join(`|`),c=this._dynamicSignature[n];return this._removeRuntimeDepsOnly(n),this._addRuntimeDepsOnly(n,i.cells,i.ranges,i.nodes),this._dynamicSignature[n]=s,s===c?!1:(this._markNodeIndexDirty(n,!0),this._propagateDirtyQueue(),!0)}prepareDynamicDependencies(e){let t=this._getDirtyNodeIndicesSnapshot(),n=!1;for(let r=0;r<t.length;r++){let i=t[r],a=this._dynamicDeps[i];!a||a.length===0||this.refreshDynamicDeps(this.getNodeRefByIndex(i),e)&&(n=!0)}return n}getCalculationOrder(e){let t=this._getDirtyNodeIndicesSnapshot();if(t.length===0)return{hasCycle:!1,calculationForest:[]};let n=this._buildDirtyCalculationGraph(t);return{hasCycle:n.hasCycle,calculationForest:n.calculationForest}}clearCalculatedDirty(e){let t=!1;for(let n=0;n<e.length;n++){let r=e[n];this.dirty[r]&&(this.dirty[r]=0,this._dirtyNodeCount--,t=!0)}t&&this._compactDirtyList()}_compactDirtyList(){let e=0;for(let t=0;t<this._dirtyList.length;t++){let n=this._dirtyList[t];this.dirty[n]&&this._activeNode[n]&&(this._dirtyList[e++]=n)}this._dirtyList.length=e}clearAllDirty(){for(let e=0;e<this._dirtyList.length;e++)this.dirty[this._dirtyList[e]]=0;this._dirtyList.length=0,this._dirtyNodeCount=0}getDirtyNodeIndices(){return this._getDirtyNodeIndicesSnapshot()}getDirtyNodes(){let e=this._getDirtyNodeIndicesSnapshot(),t=Array(e.length);for(let n=0;n<e.length;n++)t[n]=this.getNodeRefByIndex(e[n]);return t}forEachDependentByCell(e,t){this._nextEmitEpoch(),this._forEachDependentIndexByCellRaw(e,e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)})}forEachDependentByRange(e,t){this._nextEmitEpoch(),this._directPointIndex.forEachCellInRange(e,e=>{z(this.directDeps.get(e),e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)})}),this._runtimeDirectPointIndex.forEachCellInRange(e,e=>{z(this._runtimeDirectDeps.get(e),e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)})}),this.rangeIndex.forEachRangeIntersecting(e,e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)}),this._runtimeRangeIndex.forEachRangeIntersecting(e,e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)}),this._forEachCompressedSharedDependentByRange(e,e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)})}forEachDependentByNode(e,t){let n=this.getNodeIndex(e);n!==void 0&&(this._nextEmitEpoch(),this._forEachDependentOfNodeRaw(n,e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)}))}forEachDependentByIndex(e,t){this._activeNode[e]&&(this._nextEmitEpoch(),this._forEachDependentOfNodeRaw(e,e=>{this._activeNode[e]&&this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)}))}forEachPrecedentNode(e,t){let n=this.getNodeIndex(e);n!==void 0&&this._activeNode[n]&&(this._nextEmitEpoch(),this._forEachPrecedentNodeIndex(n,e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)}))}forEachPrecedentNodeByIndex(e,t){this._activeNode[e]&&(this._nextEmitEpoch(),this._forEachPrecedentNodeIndex(e,e=>{this._emitNodeOnce(e)&&t(this.getNodeRefByIndex(e),e)}))}hasUncalculatedDirtyPrecedentByIndex(e,t){if(!this._activeNode[e])return!1;let n=!1;return this._nextEmitEpoch(),this._forEachPrecedentNodeIndex(e,e=>{if(!n&&this.dirty[e]&&!t.has(e))return n=!0,!1}),n}wouldCreateCycle(e,t){let n=this._getOrCreateNodeIndex(e),r=this._normalizeCalcNodeDeps(t),i=r.cells,a=r.ranges,o=r.nodes,s=this._resolveExplicitNodeDeps(o);return this._wouldCreateCycleForNewDeps(n,i,a,s)}_normalizeCalcNodeDeps(e){let t=[],n=[],r=[];return this._collectStaticDeps(e,t,n,r),{cells:N(t),ranges:this._normalizeRangeDeps(n),nodes:W(r),dynamics:e.dynamics?e.dynamics.slice():[]}}_collectStaticDeps(e,t,n,r){if(e&&(e.cells&&t.push(...e.cells),e.ranges&&n.push(...e.ranges),e.nodes&&r.push(...e.nodes),e.dynamics))for(let i=0;i<e.dynamics.length;i++)this._collectStaticDeps(e.dynamics[i].paramDeps,t,n,r)}_mergeDynamicDeps(e,t){if(e.length===0)return t;if(t.length===0)return e;let n=e.slice();for(let e=0;e<t.length;e++){let r=t[e],i=!1;for(let e=0;e<n.length;e++)if(n[e].id===r.id){i=!0;break}i||n.push(r)}return n}_setNodeDynamicDeps(e,t){let n=this._dynamicDeps[e];n===void 0&&t.length===0||this._isSameDynamicDeps(n,t)||(this._removeRuntimeDepsOnly(e),this._dynamicSignature[e]=void 0,this._dynamicDeps[e]=t.length>0?t:void 0)}_isSameDynamicDeps(e,t){var n;if(((n=e==null?void 0:e.length)==null?0:n)!==t.length)return!1;if(!e)return t.length===0;for(let n=0;n<e.length;n++)if(e[n]!==t[n])return!1;return!0}_normalizeRangeDeps(e){if(!e||e.length===0)return[];let t=Array(e.length);for(let n=0;n<e.length;n++)t[n]=k(e[n]);return t}_mergeSortedUniqueNumbers(e,t){if(e.length===0)return t;if(t.length===0)return e;let n=[],r=0,i=0;for(;r<e.length&&i<t.length;){let a=e[r],o=t[i];a===o?(n.push(a),r++,i++):a<o?(n.push(a),r++):(n.push(o),i++)}for(;r<e.length;)n.push(e[r++]);for(;i<t.length;)n.push(t[i++]);return n}_mergeRangeDeps(e,t){if(e.length===0)return t;if(t.length===0)return e;let n=e.slice();for(let e=0;e<t.length;e++){let r=t[e];this._containsRange(n,r)||n.push(r)}return n}_containsRange(e,t){for(let n=0;n<e.length;n++)if(this._isSameRange(e[n],t))return!0;return!1}_isSameRange(e,t){return e.unitId===t.unitId&&e.sheetId===t.sheetId&&e.range.startRow===t.range.startRow&&e.range.endRow===t.range.endRow&&e.range.startColumn===t.range.startColumn&&e.range.endColumn===t.range.endColumn}canReachNode(e,t){let n=this.getNodeIndex(e),r=this.getNodeIndex(t);return n===void 0||r===void 0?!1:this._canReachNodeIndex(n,r)}hasCellFormula(e){let t=this.cellFormulaToIndex.get(e);return t!==void 0&&this._activeNode[t]===1}hasOtherFormula(e){let t=this.otherFormulaToIndex.get(e);return t!==void 0&&this._activeNode[t]===1}hasFeatureCalculation(e){let t=this.featureCalculationToIndex.get(e);return t!==void 0&&this._activeNode[t]===1}getNodeIndex(e){return this._getNodeIndexByType(e.type,e.id)}_getNodeIndexByType(e,t){switch(e){case 1:return O(t),this.cellFormulaToIndex.get(t);case 2:return this.otherFormulaToIndex.get(t);case 3:return this.featureCalculationToIndex.get(t);default:return}}getNodeRefByIndex(e){return{type:this._indexToNodeType[e],id:this.indexToNodeId[e]}}markCalcNodeIndicesChanged(e,t){this._markCalcNodeIndicesChanged(e,t)}_markCalcNodeIndicesChanged(e,t){if(e.length===0)return;this._nextEmitEpoch();let n=(t==null?void 0:t.onlySelf)!==!0;for(let t=0;t<e.length;t++){let r=e[t];this._activeNode[r]&&this._emitNodeOnceAndMarkDirty(r,n,n)}n&&this._propagateDirtyQueue()}_getOrCreateNodeIndex(e){return this._getOrCreateNodeIndexByType(e.type,e.id)}_getOrCreateNodeIndexByType(e,t){let n=this._getNodeIndexByType(e,t);if(n!==void 0)return n;let r=this.indexToNodeId.length;switch(this.indexToNodeId.push(t),this._ensureNodeCapacity(r+1),this._indexToNodeType[r]=e,e){case 1:O(t),this.cellFormulaToIndex.set(t,r);break;case 2:this.otherFormulaToIndex.set(t,r);break;case 3:this.featureCalculationToIndex.set(t,r);break;default:throw Error(`Unknown CalcNodeType: ${e}`)}return r}_ensureNodeCapacity(e){let t=this._sharedFormulaMembershipByNode.length;this._indexToNodeType=H(this._indexToNodeType,e),this.dirty=H(this.dirty,e),this.inQueue=H(this.inQueue,e),this._activeNode=H(this._activeNode,e),this._seenNodeEpoch=U(this._seenNodeEpoch,e),this._visitNodeEpoch=U(this._visitNodeEpoch,e),this._edgeSeenEpoch=U(this._edgeSeenEpoch,e),this._tarjanSeenEpoch=U(this._tarjanSeenEpoch,e),this._tarjanIndexArr=U(this._tarjanIndexArr,e),this._tarjanLowArr=U(this._tarjanLowArr,e),this._tarjanOnStack=H(this._tarjanOnStack,e),this._sharedFormulaMembershipByNode=this._growIntThirtyTwoArray(this._sharedFormulaMembershipByNode,e,-1),this._sharedFormulaMembershipByNode.length>t&&this._sharedFormulaMembershipByNode.fill(-1,t)}_growIntThirtyTwoArray(e,t,n){if(e.length>=t)return e;let r=Math.max(16,e.length);for(;r<t;)r*=2;let i=new Int32Array(r);return i.fill(n),i.set(e),i}_resolveExplicitNodeDeps(e){if(e.length===0)return[];let t=[];for(let n=0;n<e.length;n++){let r=e[n];if(r.type===2)throw Error(`OtherFormula cannot be used as a dependency`);let i=this._getOrCreateNodeIndex(r);t.push(i)}if(t.length<=1)return t;t.sort((e,t)=>e-t);let n=1;for(let e=1;e<t.length;e++)t[e]!==t[n-1]&&(t[n++]=t[e]);return t.length=n,t}_isEmptyCalcNodeDeps(e){return(e.cells==null||e.cells.length===0)&&(e.ranges==null||e.ranges.length===0)&&(e.nodes==null||e.nodes.length===0)&&(e.dynamics==null||e.dynamics.length===0)}_unregisterCompressedSharedFormulaGroupByNode(e){let t=this._sharedFormulaMembershipByNode[e];if(t<0)return;let n=this._sharedFormulaGroups[t];if(n==null||!this._sharedFormulaGroupIndexById.has(n.groupId)){this._sharedFormulaMembershipByNode[e]=-1;return}this.unregisterCompressedSharedFormulaGroup(n.groupId)}_markCompressedSharedFormulaMembership(e,t){for(let n=t.range.startRow;n<=t.range.endRow;n++)for(let r=t.range.startColumn;r<=t.range.endColumn;r++){let i=this.codec.encodeCell(t.unitId,t.sheetId,n,r),a=this.cellFormulaToIndex.get(i);a!==void 0&&this._activeNode[a]&&(this._sharedFormulaMembershipByNode[a]=e)}}_clearCompressedSharedFormulaMembership(e,t){for(let n=t.range.startRow;n<=t.range.endRow;n++)for(let r=t.range.startColumn;r<=t.range.endColumn;r++){let i=this.codec.encodeCell(t.unitId,t.sheetId,n,r),a=this.cellFormulaToIndex.get(i);a!==void 0&&this._sharedFormulaMembershipByNode[a]===e&&(this._sharedFormulaMembershipByNode[a]=-1)}}_getCompressedSharedSourceCoverage(e,t){if(t.kind===`cell`)return k({unitId:t.unitId,sheetId:t.sheetId,range:{startRow:e.range.startRow+t.rowDelta,endRow:e.range.endRow+t.rowDelta,startColumn:e.range.startColumn+t.colDelta,endColumn:e.range.endColumn+t.colDelta}});let n=Math.min(t.startRowDelta,t.endRowDelta),r=Math.max(t.startRowDelta,t.endRowDelta),i=Math.min(t.startColDelta,t.endColDelta),a=Math.max(t.startColDelta,t.endColDelta);return k({unitId:t.unitId,sheetId:t.sheetId,range:{startRow:e.range.startRow+n,endRow:e.range.endRow+r,startColumn:e.range.startColumn+i,endColumn:e.range.endColumn+a}})}_forEachCompressedSharedDependentByRange(e,t){let n=k(e);this._sharedFormulaSourceRangeIndex.forEachRangeIntersecting(n,e=>{let r=this._sharedFormulaSourceEntries[e];if(!(r!=null&&r.active))return;let i=this._sharedFormulaGroups[r.groupIndex],a=this._reverseMapCompressedSharedPattern(n,i.fillRange,i.patterns[r.patternIndex]);a!=null&&this._forEachActiveCellFormulaInRange(a,t)})}_forEachActiveCellFormulaInRange(e,t){for(let n=e.range.startRow;n<=e.range.endRow;n++)for(let r=e.range.startColumn;r<=e.range.endColumn;r++){let i=this.codec.encodeCell(e.unitId,e.sheetId,n,r),a=this.cellFormulaToIndex.get(i);a!==void 0&&this._activeNode[a]&&t(a)}}_reverseMapCompressedSharedPattern(e,t,n){let r=n.kind===`cell`?[e.range.startRow-n.rowDelta,e.range.endRow-n.rowDelta]:[e.range.startRow-Math.max(n.startRowDelta,n.endRowDelta),e.range.endRow-Math.min(n.startRowDelta,n.endRowDelta)],i=n.kind===`cell`?[e.range.startColumn-n.colDelta,e.range.endColumn-n.colDelta]:[e.range.startColumn-Math.max(n.startColDelta,n.endColDelta),e.range.endColumn-Math.min(n.startColDelta,n.endColDelta)];return this._intersectRanges(t,{unitId:t.unitId,sheetId:t.sheetId,range:{startRow:r[0],endRow:r[1],startColumn:i[0],endColumn:i[1]}})}_intersectRanges(e,t){if(e.unitId!==t.unitId||e.sheetId!==t.sheetId)return;let n=Math.max(e.range.startRow,t.range.startRow),r=Math.min(e.range.endRow,t.range.endRow),i=Math.max(e.range.startColumn,t.range.startColumn),a=Math.min(e.range.endColumn,t.range.endColumn);if(!(n>r||i>a))return{unitId:e.unitId,sheetId:e.sheetId,range:{startRow:n,endRow:r,startColumn:i,endColumn:a}}}_forEachCompressedSharedPrecedent(e,t){let n=this._sharedFormulaMembershipByNode[e];if(n<0)return!0;let r=this._sharedFormulaGroups[n];for(let e=0;e<r.patterns.length;e++)if(t(r.patterns[e])===!1)return!1;return!0}_getCompressedSharedPrecedentCell(e,t){let n=this.indexToNodeId[e],r=this.codec.decodeCell(n);return this.codec.encodeCell(t.unitId,t.sheetId,r.row+t.rowDelta,r.col+t.colDelta)}_getCompressedSharedPrecedentRange(e,t){let n=this.indexToNodeId[e],r=this.codec.decodeCell(n);return k({unitId:t.unitId,sheetId:t.sheetId,range:{startRow:r.row+t.startRowDelta,startColumn:r.col+t.startColDelta,endRow:r.row+t.endRowDelta,endColumn:r.col+t.endColDelta}})}_addNodeDepsOnly(e,t,n,r){for(let n=0;n<t.length;n++)this._addDirectEdge(t[n],e);this._cellPrecedents[e]=t.length>0?t:void 0,this._rangePrecedents[e]=n.length>0?n:void 0;for(let t=0;t<n.length;t++)this.rangeIndex.addRange(e,n[t]);this._nodePrecedents[e]=r.length>0?r:void 0;for(let t=0;t<r.length;t++)this._addExplicitNodeEdge(r[t],e)}_removeNodeDepsOnly(e){let t=this._cellPrecedents[e];if(t){for(let n=0;n<t.length;n++)this._removeDirectEdge(t[n],e);this._cellPrecedents[e]=void 0}this.rangeIndex.removeNode(e),this._rangePrecedents[e]=void 0;let n=this._nodePrecedents[e];if(n){for(let t=0;t<n.length;t++)this._removeExplicitNodeEdge(n[t],e);this._nodePrecedents[e]=void 0}}_collectDynamicResolveResult(e,t){t.traceCells&&e.cells.push(...t.traceCells),t.cells&&e.cells.push(...t.cells),t.ranges&&e.ranges.push(...t.ranges),t.nodes&&e.nodes.push(...this._resolveExplicitNodeDeps(W(t.nodes)))}_addRuntimeDepsOnly(e,t,n,r){for(let n=0;n<t.length;n++)this._addRuntimeDirectEdge(t[n],e);this._runtimeCellPrecedents[e]=t.length>0?t:void 0,this._runtimeRangePrecedents[e]=n.length>0?n:void 0;for(let t=0;t<n.length;t++)this._runtimeRangeIndex.addRange(e,n[t]);this._runtimeNodePrecedents[e]=r.length>0?r:void 0;for(let t=0;t<r.length;t++)this._addRuntimeExplicitNodeEdge(r[t],e)}_removeRuntimeDepsOnly(e){let t=this._runtimeCellPrecedents[e];if(t){for(let n=0;n<t.length;n++)this._removeRuntimeDirectEdge(t[n],e);this._runtimeCellPrecedents[e]=void 0}this._runtimeRangeIndex.removeNode(e),this._runtimeRangePrecedents[e]=void 0;let n=this._runtimeNodePrecedents[e];if(n){for(let t=0;t<n.length;t++)this._removeRuntimeExplicitNodeEdge(n[t],e);this._runtimeNodePrecedents[e]=void 0}}_detachDependentsFromNode(e){let t=this.nodeDeps.get(e),n=[];z(t,e=>{n.push(e)}),this.nodeDeps.delete(e);for(let t=0;t<n.length;t++)this._detachPrecedentFromDependent(n[t],e);let r=this._runtimeNodeDeps.get(e);if(r===void 0)return;let i=[];z(r,e=>{i.push(e)}),this._runtimeNodeDeps.delete(e);for(let t=0;t<i.length;t++)this._detachRuntimePrecedentFromDependent(i[t],e)}_detachPrecedentFromDependent(e,t){let n=this._nodePrecedents[e];if(n===void 0)return;let r=0,i=!1;for(let e=0;e<n.length;e++){let a=n[e];if(a===t){i=!0;continue}n[r++]=a}i&&(r===0?this._nodePrecedents[e]=void 0:n.length=r)}_detachRuntimePrecedentFromDependent(e,t){let n=this._runtimeNodePrecedents[e];if(n===void 0)return;let r=0,i=!1;for(let e=0;e<n.length;e++){let a=n[e];if(a===t){i=!0;continue}n[r++]=a}i&&(r===0?this._runtimeNodePrecedents[e]=void 0:n.length=r)}_addDirectEdge(e,t){let n=this.directDeps.get(e);n===void 0&&this._directPointIndex.add(e),this.directDeps.set(e,L(n,t))}_removeDirectEdge(e,t){let n=this.directDeps.get(e);if(n===void 0)return;let r=R(n,t);r===void 0?(this.directDeps.delete(e),this._directPointIndex.remove(e)):this.directDeps.set(e,r)}_addRuntimeDirectEdge(e,t){let n=this._runtimeDirectDeps.get(e);n===void 0&&this._runtimeDirectPointIndex.add(e),this._runtimeDirectDeps.set(e,L(n,t))}_removeRuntimeDirectEdge(e,t){let n=this._runtimeDirectDeps.get(e);if(n===void 0)return;let r=R(n,t);r===void 0?(this._runtimeDirectDeps.delete(e),this._runtimeDirectPointIndex.remove(e)):this._runtimeDirectDeps.set(e,r)}_addExplicitNodeEdge(e,t){B(this.nodeDeps,e,t)}_removeExplicitNodeEdge(e,t){V(this.nodeDeps,e,t)}_addRuntimeExplicitNodeEdge(e,t){B(this._runtimeNodeDeps,e,t)}_removeRuntimeExplicitNodeEdge(e,t){V(this._runtimeNodeDeps,e,t)}_forEachDependentIndexByCellRaw(e,t){z(this.directDeps.get(e),t),z(this._runtimeDirectDeps.get(e),t);let n=this.codec.decodeCell(e);this.rangeIndex.forEachPoint(n.unitId,n.sheetId,n.row,n.col,t),this._runtimeRangeIndex.forEachPoint(n.unitId,n.sheetId,n.row,n.col,t),this._forEachCompressedSharedDependentByRange({unitId:n.unitId,sheetId:n.sheetId,range:{startRow:n.row,endRow:n.row,startColumn:n.col,endColumn:n.col}},t)}_forEachDependentOfNodeRaw(e,t){if(this._indexToNodeType[e]===1){let n=this.indexToNodeId[e];this._forEachDependentIndexByCellRaw(n,t)}z(this.nodeDeps.get(e),t),z(this._runtimeNodeDeps.get(e),t)}_markNodeIndexDirty(e,t=!1,n=!0){if(!this._activeNode[e])return;let r=this.dirty[e]===1;r||(this.dirty[e]=1,this._dirtyList.push(e),this._dirtyNodeCount++),n&&(!r||t)&&!this.inQueue[e]&&(this.inQueue[e]=1,this._propQueue.push(e))}_isEveryActiveNodeDirty(){return this._activeNodeCount>0&&this._dirtyNodeCount>=this._activeNodeCount}_propagateDirtyQueue(){if(this._isEveryActiveNodeDirty()){for(let e=0;e<this._propQueue.length;e++)this.inQueue[this._propQueue[e]]=0;this._propQueue.length=0;return}let e=0;for(;e<this._propQueue.length;){let t=this._propQueue[e++];this.inQueue[t]=0,this._activeNode[t]&&this._forEachDependentOfNodeRaw(t,e=>{this._markNodeIndexDirty(e,!1)})}this._propQueue.length=0}_getDirtyNodeIndicesSnapshot(){let e=[];for(let t=0;t<this._dirtyList.length;t++){let n=this._dirtyList[t];this.dirty[n]&&this._activeNode[n]&&e.push(n)}return e}_forEachDependentOfNodeDeduped(e,t){this._nextEdgeEpoch(),this._forEachDependentOfNodeRaw(e,e=>{this._edgeSeenEpoch[e]!==this._edgeEpoch&&(this._edgeSeenEpoch[e]=this._edgeEpoch,t(e))})}_forEachPrecedentNodeIndex(e,t){let n=this._cellPrecedents[e];if(n)for(let e=0;e<n.length;e++){let r=n[e],i=this.cellFormulaToIndex.get(r);if(i!==void 0&&this._activeNode[i]&&t(i)===!1)return!1}let r=this._rangePrecedents[e];if(r)for(let e=0;e<r.length;e++){let n=!0;if(this._formulaCellIndex.forEachFormulaInRange(r[e],e=>{if(n&&this._activeNode[e]&&t(e)===!1)return n=!1,!1}),!n)return!1}if(!this._forEachCompressedSharedPrecedent(e,n=>{if(n.kind===`cell`){let r=this._getCompressedSharedPrecedentCell(e,n),i=this.cellFormulaToIndex.get(r);return i!==void 0&&this._activeNode[i]&&t(i)===!1?!1:void 0}let r=!0;return this._formulaCellIndex.forEachFormulaInRange(this._getCompressedSharedPrecedentRange(e,n),e=>{if(r&&this._activeNode[e]&&t(e)===!1)return r=!1,!1}),r}))return!1;let i=this._nodePrecedents[e];if(i)for(let e=0;e<i.length;e++){let n=i[e];if(this._activeNode[n]&&t(n)===!1)return!1}let a=this._runtimeCellPrecedents[e];if(a)for(let e=0;e<a.length;e++){let n=a[e],r=this.cellFormulaToIndex.get(n);if(r!==void 0&&this._activeNode[r]&&t(r)===!1)return!1}let o=this._runtimeRangePrecedents[e];if(o)for(let e=0;e<o.length;e++){let n=!0;if(this._formulaCellIndex.forEachFormulaInRange(o[e],e=>{if(n&&this._activeNode[e]&&t(e)===!1)return n=!1,!1}),!n)return!1}let s=this._runtimeNodePrecedents[e];if(s)for(let e=0;e<s.length;e++){let n=s[e];if(this._activeNode[n]&&t(n)===!1)return!1}return!0}_wouldCreateCycleForNewDeps(e,t,n,r){for(let n=0;n<t.length;n++){let r=t[n],i=this.cellFormulaToIndex.get(r);if(i!==void 0&&this._activeNode[i]&&(i===e||this._canReachNodeIndex(e,i)))return!0}if(this._indexToNodeType[e]===1){let t=this.indexToNodeId[e],r=this.codec.decodeCell(t);for(let e=0;e<n.length;e++)if(M(n[e],r))return!0}for(let t=0;t<n.length;t++){let r=n[t],i=!1;if(this._formulaCellIndex.forEachFormulaInRange(r,t=>{if(!i&&this._activeNode[t]){if(t===e){i=!0;return}this._canReachNodeIndex(e,t)&&(i=!0)}}),i)return!0}for(let t=0;t<r.length;t++){let n=r[t];if(n===e||this._canReachNodeIndex(e,n))return!0}return!1}_canReachNodeIndex(e,t){if(e===t)return!0;this._nextVisitEpoch();let n=[e];for(;n.length>0;){let e=n.pop(),r=!1;if(this._forEachDependentOfNodeRaw(e,e=>{if(!r&&this._visitNodeEpoch[e]!==this._visitEpoch){if(this._visitNodeEpoch[e]=this._visitEpoch,e===t){r=!0;return}n.push(e)}}),r)return!0}return!1}_buildDirtyCalculationGraph(e){let t=this._tryBuildAcyclicDirtyCalculationGraph(e);return t===void 0?this._buildDirtyCalculationGraphWithScc(e):t}_tryBuildAcyclicDirtyCalculationGraph(e){let t=e.length;this._nextTarjanEpoch();for(let n=0;n<t;n++){let t=e[n];this._tarjanSeenEpoch[t]=this._tarjanEpoch,this._tarjanIndexArr[t]=n+1}let n=new Uint32Array(t),r=new Int32Array(t),i=new Int32Array(t),a=new Uint8Array(t),o=new Uint8Array(t),s=new Uint8Array(t),c=[],l=[],u=new Map,d=[],f=[],p=[],m=[],h=new X(this.codec,this._initialRangeCapacity,this._maxIndexedSpan);for(let e=0;e<t;e++)i[e]=e,r[e]=-1;for(let g=0;g<t;g++){let t=e[g];this._nextEdgeEpoch(),this._addAcyclicExactPrecedentEdges(t,g,n,r,c,l,i,a,o,s),this._addAcyclicRangePrecedentGroups(t,g,n,u,d,f,p,m,h,i,a,o,s)}let g=new Int32Array(t),_=0,v=0;for(let e=0;e<t;e++)n[e]===0&&(g[v++]=e);let y=new Int32Array(t),b=[],x=-1,S=0,C=!1;for(;_<v;){let t=g[_++],a=e[t];S++,this._appendAcyclicCalculationNode(b,y,i,o,s,t,a,x),C=C||s[t]===1,o[t]===0&&x===-1&&(x=b.length-1);for(let e=r[t];e!==-1;e=l[e]){let t=c[e];n[t]--,n[t]===0&&(g[v++]=t)}if(this._indexToNodeType[a]===1){let e=this.indexToNodeId[a],t=this.codec.decodeCell(e);h.forEachPoint(t.unitId,t.sheetId,t.row,t.col,e=>{if(f[e]<=0||(f[e]--,f[e]!==0))return;let t=p[e];for(let e=0;e<t.length;e++){let r=t[e];n[r]--,n[r]===0&&(g[v++]=r)}})}}if(S===t)return{calculationForest:b,hasCycle:C}}_addAcyclicExactPrecedentEdges(e,t,n,r,i,a,o,s,c,l){let u=e=>{if(e===void 0||!this._activeNode[e]||!this.dirty[e]||this._edgeSeenEpoch[e]===this._edgeEpoch)return;this._edgeSeenEpoch[e]=this._edgeEpoch;let u=this._getCurrentDirtyOrdinal(e);if(!(u<0)){if(c[u]=1,c[t]=1,u===t){l[t]=1;return}a.push(r[u]),i.push(t),r[u]=i.length-1,n[t]++,this._unionCalculationForestComponents(o,s,u,t)}},d=this._cellPrecedents[e];if(d)for(let e=0;e<d.length;e++)u(this.cellFormulaToIndex.get(d[e]));let f=this._nodePrecedents[e];if(f)for(let e=0;e<f.length;e++)u(f[e]);let p=this._runtimeCellPrecedents[e];if(p)for(let e=0;e<p.length;e++)u(this.cellFormulaToIndex.get(p[e]));let m=this._runtimeNodePrecedents[e];if(m)for(let e=0;e<m.length;e++)u(m[e]);this._forEachCompressedSharedPrecedent(e,t=>{t.kind===`cell`&&u(this.cellFormulaToIndex.get(this._getCompressedSharedPrecedentCell(e,t)))})}_addAcyclicRangePrecedentGroups(e,t,n,r,i,a,o,s,c,l,u,d,f){let p=[],m=m=>{let h=this._getOrCreateAcyclicRangeGroup(m,r,i,a,o,s,c,l,u,d);if(a[h]===0)return;for(let e=0;e<p.length;e++)if(p[e]===h)return;p.push(h),o[h].push(t),n[t]++,d[t]=1;let g=s[h];g>=0&&this._unionCalculationForestComponents(l,u,g,t),this._indexToNodeType[e]===1&&M(m,this.codec.decodeCell(this.indexToNodeId[e]))&&(f[t]=1)},h=this._rangePrecedents[e];if(h)for(let e=0;e<h.length;e++)m(h[e]);let g=this._runtimeRangePrecedents[e];if(g)for(let e=0;e<g.length;e++)m(g[e]);this._forEachCompressedSharedPrecedent(e,t=>{t.kind===`range`&&m(this._getCompressedSharedPrecedentRange(e,t))})}_getOrCreateAcyclicRangeGroup(e,t,n,r,i,a,o,s,c,l){let u=k(e),d=[u.unitId,u.sheetId,u.range.startRow,u.range.endRow,u.range.startColumn,u.range.endColumn].join(`:`),f=t.get(d);if(f!==void 0)return f;let p=n.length,m=0,h=-1;return t.set(d,p),n.push(u),i.push([]),o.addRange(p,u),this._formulaCellIndex.forEachFormulaInRange(u,e=>{if(!this._activeNode[e]||!this.dirty[e])return;let t=this._getCurrentDirtyOrdinal(e);if(!(t<0)){if(m++,l[t]=1,h===-1){h=t;return}this._unionCalculationForestComponents(s,c,h,t)}}),r.push(m),a.push(h),p}_appendAcyclicCalculationNode(e,t,n,r,i,a,o,s){let c=r[a]===0,l=this._findCalculationForestRoot(n,a),u=(c?s+1:t[l])-1;if(u===-1&&(u=e.length,c||(t[l]=u+1),e.push({hasCycle:!1,plan:[]})),i[a]===1){e[u].plan.push({type:`cycle`,nodeIndices:[o]}),e[u].hasCycle=!0;return}this._appendCalculationNodePlanItem(e[u].plan,o)}_getCurrentDirtyOrdinal(e){return this._tarjanSeenEpoch[e]===this._tarjanEpoch?this._tarjanIndexArr[e]-1:-1}_buildDirtyCalculationGraphWithScc(e){let t=this._findDirtySccs(e),n=t.componentStarts.length,r=new Int32Array(this.indexToNodeId.length),i=new Int32Array(this.indexToNodeId.length);r.fill(-1),i.fill(-1);for(let t=0;t<e.length;t++)i[e[t]]=t;let a=new Int32Array(n);a.fill(2**53-1);for(let e=0;e<n;e++){let n=2**53-1,o=t.componentStarts[e],s=this._getDirtySccEnd(t,e);for(let a=o;a<s;a++){let o=t.componentNodes[a];r[o]=e;let s=i[o];s>=0&&s<n&&(n=s)}a[e]=n}let o=new Int32Array(n);o.fill(-1);let s=[],c=[],l=new Int32Array(n),u=new Uint8Array(n),d=new Uint8Array(n),f=new Uint32Array(n),p=1,m=new Uint32Array(n);for(let e=0;e<n;e++)l[e]=e;for(let e=0;e<n;e++){p===4294967295&&(f.fill(0),p=1);let n=t.componentStarts[e],i=this._getDirtySccEnd(t,e);for(let a=n;a<i;a++){let n=t.componentNodes[a];this._forEachDependentOfNodeDeduped(n,t=>{if(!this._activeNode[t]||!this.dirty[t])return;let n=r[t];n<0||n===e||f[n]!==p&&(f[n]=p,c.push(o[e]),s.push(n),o[e]=s.length-1,m[n]++,d[e]=1,d[n]=1,this._unionCalculationForestComponents(l,u,e,n))})}p++}let h=this._toposortComponents(o,s,c,m,a),g=this._buildCalculationForest(t,h,l,d);t.componentNodes.length=0,t.componentStarts.length=0,s.length=0,c.length=0,h.length=0;let _=!1;for(let e=0;e<g.length;e++)if(g[e].hasCycle){_=!0;break}return{calculationForest:g,hasCycle:_}}_toposortComponents(e,t,n,r,i){let a=new Uint32Array(r),o=[];for(let e=0;e<a.length;e++)a[e]===0&&this._insertComponentByRank(o,0,e,i);let s=[],c=0;for(;c<o.length;){let r=o[c++];s.push(r);for(let s=e[r];s!==-1;s=n[s]){let e=t[s];a[e]--,a[e]===0&&this._insertComponentByRank(o,c,e,i)}}return s}_insertComponentByRank(e,t,n,r){let i=e.length,a=r[n];for(;i>t&&r[e[i-1]]>a;)i--;e.splice(i,0,n)}_buildCalculationForest(e,t,n,r){let i=new Int32Array(e.componentStarts.length);i.fill(-1);let a=[],o=-1;for(let s=0;s<t.length;s++){let c=t[s],l=this._findCalculationForestRoot(n,c),u=r[c]===0,d=u?o:i[l];d===-1&&(d=a.length,u?o=d:i[l]=d,a.push({hasCycle:!1,plan:[]}));let f=a[d],p=this._createCalculationPlanItem(e,c);if(p.type===`node`){this._appendCalculationNodePlanItem(f.plan,p.nodeIndex);continue}f.plan.push(p),p.type===`cycle`&&(f.hasCycle=!0)}return a}_appendCalculationNodePlanItem(e,t){let n=e[e.length-1];if((n==null?void 0:n.type)===`nodes`&&n.nodeIndices.length<8192){n.nodeIndices.push(t);return}e.push({type:`nodes`,nodeIndices:[t]})}_findCalculationForestRoot(e,t){let n=t;for(;e[n]!==n;)n=e[n];for(;e[t]!==t;){let r=e[t];e[t]=n,t=r}return n}_unionCalculationForestComponents(e,t,n,r){let i=this._findCalculationForestRoot(e,n),a=this._findCalculationForestRoot(e,r);if(i!==a){if(t[i]<t[a]){let e=i;i=a,a=e}e[a]=i,t[i]===t[a]&&t[i]++}}_createCalculationPlanItem(e,t){let n=e.componentStarts[t],r=this._getDirtySccEnd(e,t);if(r-n===1&&!this._hasSelfLoop(e.componentNodes[n]))return{type:`node`,nodeIndex:e.componentNodes[n]};let i=e.componentNodes.slice(n,r);return i.sort((e,t)=>e-t),{type:`cycle`,nodeIndices:i}}_getDirtySccEnd(e,t){return t+1<e.componentStarts.length?e.componentStarts[t+1]:e.componentNodes.length}_findDirtySccs(e){this._nextTarjanEpoch();let t=1,n=[],r=[],i=[],a=e=>{if(this._tarjanSeenEpoch[e]=this._tarjanEpoch,this._tarjanIndexArr[e]=t,this._tarjanLowArr[e]=t,t++,n.push(e),this._tarjanOnStack[e]=1,this._forEachDependentOfNodeDeduped(e,t=>{this._activeNode[t]&&this.dirty[t]&&(this._tarjanSeenEpoch[t]===this._tarjanEpoch?this._tarjanOnStack[t]&&(this._tarjanLowArr[e]=Math.min(this._tarjanLowArr[e],this._tarjanIndexArr[t])):(a(t),this._tarjanLowArr[e]=Math.min(this._tarjanLowArr[e],this._tarjanLowArr[t])))}),this._tarjanLowArr[e]===this._tarjanIndexArr[e])for(i.push(r.length);;){let t=n.pop();if(this._tarjanOnStack[t]=0,r.push(t),t===e)break}};for(let t=0;t<e.length;t++){let n=e[t];this._activeNode[n]&&this.dirty[n]&&this._tarjanSeenEpoch[n]!==this._tarjanEpoch&&a(n)}return{componentNodes:r,componentStarts:i}}_hasSelfLoop(e){let t=!1;return this._forEachDependentOfNodeDeduped(e,n=>{n===e&&(t=!0)}),t}_nextEmitEpoch(){this._emitEpoch++,this._emitEpoch>=4294967295&&(this._seenNodeEpoch.fill(0),this._emitEpoch=1)}_emitNodeOnce(e){return this._seenNodeEpoch[e]===this._emitEpoch?!1:(this._seenNodeEpoch[e]=this._emitEpoch,!0)}_emitNodeOnceAndMarkDirty(e,t=!1,n=!0){this._emitNodeOnce(e)&&this._markNodeIndexDirty(e,t,n)}_nextVisitEpoch(){this._visitEpoch++,this._visitEpoch>=4294967295&&(this._visitNodeEpoch.fill(0),this._visitEpoch=1)}_nextEdgeEpoch(){this._edgeEpoch++,this._edgeEpoch>=4294967295&&(this._edgeSeenEpoch.fill(0),this._edgeEpoch=1)}_nextTarjanEpoch(){this._tarjanEpoch++,this._tarjanEpoch>=4294967295&&(this._tarjanSeenEpoch.fill(0),this._tarjanEpoch=1)}},Q=class extends r.DependencyManagerBaseService{constructor(...e){super(...e),w(this,`_dependencyEngineCache`,new Z({maxRows:1048576,maxCols:16384}))}reset(){this._dependencyEngineCache.reset()}_getCellIdsAndRanges(e){let t=[],n=[];for(let r=0;r<e.rangeList.length;r++){let{unitId:i,sheetId:a,range:o}=e.rangeList[r];if(o.startRow===o.endRow&&o.startColumn===o.endColumn){let e=this._dependencyEngineCache.encodeCell(i,a,o.startRow,o.startColumn);t.push(e)}else n.push({unitId:i,sheetId:a,range:o})}return{cellIds:t,ranges:n}}_getDynamicDeps(e,t,n,r){if(!(!e.addressFunctionNodes||e.addressFunctionNodes.length===0))return[{id:`address-functions`,paramDeps:{cells:t,ranges:n,nodes:r}}]}addOtherFormulaDependencyPro(e,t,n,r,i,a=`replace`){let{cellIds:o,ranges:s}=this._getCellIdsAndRanges(r),c=this._getDynamicDeps(r,o,s,i),l=r.refOffsetX||0,u=r.refOffsetY||0,d=this._dependencyEngineCache.encodeOtherFormulaId(e,t,n,l,u);return this._dependencyEngineCache.setOtherFormulaDeps(d,{cells:o,ranges:s,nodes:i,dynamics:c},{checkCycle:!1,markDirty:!1,mode:a}).nodeIndex}removeOtherFormulaDependency(e,t,n){this._dependencyEngineCache.clearOtherFormulas(e,t,n,void 0,void 0,{markDependentsDirty:!0})}clearOtherFormulaDependency(e,t){t?this._dependencyEngineCache.clearOtherFormulas(e,t,void 0,void 0,void 0,{markDependentsDirty:!0}):this._dependencyEngineCache.clearOtherFormulas(e,void 0,void 0,void 0,void 0,{markDependentsDirty:!0})}getOtherFormulaDependencyPro(e,t,n,r,i){let a=this._dependencyEngineCache.encodeOtherFormulaId(e,t,n,r,i);if(this._dependencyEngineCache.hasOtherFormula(a))return this._dependencyEngineCache.getNodeIndex({type:2,id:a})}addFeatureFormulaDependencyPro(e,t,n,r){let{cellIds:i,ranges:a}=this._getCellIdsAndRanges(r),o=this._dependencyEngineCache.encodeFeatureCalculationId(e,t,n);return this._dependencyEngineCache.setFeatureCalculationDeps(o,{cells:i,ranges:a},{checkCycle:!1,markDirty:!1}).nodeIndex}removeFeatureFormulaDependency(e,t,n){let r=n.map(n=>this._dependencyEngineCache.encodeFeatureCalculationId(e,t,n));this._dependencyEngineCache.removeFeatureCalculations(r,{markDependentsDirty:!0,detachDependents:!0})}clearFeatureFormulaDependency(e,t){t?this._dependencyEngineCache.clearFeatureCalculations(e,t,{markDependentsDirty:!0,detachDependents:!0}):this._dependencyEngineCache.clearFeatureCalculations(e,void 0,{markDependentsDirty:!0,detachDependents:!0})}getFeatureFormulaDependencyPro(e,t,n){let r=this._dependencyEngineCache.encodeFeatureCalculationId(e,t,n);if(this._dependencyEngineCache.hasFeatureCalculation(r))return this._dependencyEngineCache.getNodeIndex({type:3,id:r})}getFeatureFormulaDependencyNodePro(e,t,n){return{type:3,id:this._dependencyEngineCache.encodeFeatureCalculationId(e,t,n)}}addFormulaDependencyPro(e,t,n,r,i,a,o=`replace`){let s=this._dependencyEngineCache.encodeCell(e,t,n,r),{cellIds:c,ranges:l}=this._getCellIdsAndRanges(i),u=this._getDynamicDeps(i,c,l,a);return this._dependencyEngineCache.setCellFormulaDeps(s,{cells:c,ranges:l,nodes:a,dynamics:u},{checkCycle:!1,markDirty:!1,mode:o}).nodeIndex}addFormulaDependencyNodeOnlyPro(e,t,n,r){let i=this._dependencyEngineCache.encodeCell(e,t,n,r);return this._dependencyEngineCache.setCellFormulaDeps(i,{},{checkCycle:!1,markDirty:!1}).nodeIndex}registerCompressedSharedFormulaGroup(e){this._dependencyEngineCache.registerCompressedSharedFormulaGroup(e)}clearCompressedSharedFormulaGroups(e,t){this._dependencyEngineCache.clearCompressedSharedFormulaGroups(e,t)}removeFormulaDependency(e,t,n,r){let i=this._dependencyEngineCache.encodeCell(e,t,n,r);this._dependencyEngineCache.removeCellFormula(i,{markDependentsDirty:!0})}clearFormulaDependency(e,t){this._dependencyEngineCache.clearCompressedSharedFormulaGroups(e,t),t?this._dependencyEngineCache.clearCellFormulas(e,t,{markDependentsDirty:!0}):this._dependencyEngineCache.clearCellFormulas(e,void 0,{markDependentsDirty:!0})}getFormulaDependencyPro(e,t,n,r){let i=this._dependencyEngineCache.encodeCell(e,t,n,r);if(this._dependencyEngineCache.hasCellFormula(i))return this._dependencyEngineCache.getNodeIndex({type:1,id:i})}markIndicesChanged(e,t){this._dependencyEngineCache.markCalcNodeIndicesChanged(e,t)}markRangesChanged(e,t){this._dependencyEngineCache.markRangesChanged(e,t)}markDirtyFeatureCalculations(e){let t=[];Object.keys(e).forEach(n=>{let r=e[n];r!=null&&Object.keys(r).forEach(e=>{let i=r[e];i!=null&&Object.keys(i).forEach(r=>{t.push(this.getFeatureFormulaDependencyNodePro(n,e,r))})})}),this._dependencyEngineCache.markCalcNodesChanged(t)}markDirtyOtherFormulas(e){Object.keys(e).forEach(t=>{let n=e[t];n!=null&&Object.keys(n).forEach(e=>{let r=n[e];r!=null&&this._dependencyEngineCache.markOtherFormulasChanged(t,e,Object.keys(r))})})}markDirtySheetNames(e){let t=[];Object.keys(e).forEach(n=>{let r=e[n];r!=null&&Object.keys(r).forEach(e=>{t.push({unitId:n,sheetId:e,range:{startRow:0,endRow:1048575,startColumn:0,endColumn:16383}})})}),this._dependencyEngineCache.markRangesChanged(t,{includeFormulaCells:!1})}markAllDirty(){this._dependencyEngineCache.markAllDirty()}clearCalculatedDirty(e){this._dependencyEngineCache.clearCalculatedDirty(e)}hasDynamicDeps(e){return this._dependencyEngineCache.hasDynamicDeps(e)}hasDynamicDepsByIndex(e){return this._dependencyEngineCache.hasDynamicDeps(this._dependencyEngineCache.getNodeRefByIndex(e))}refreshDynamicDeps(e,t){return this._dependencyEngineCache.refreshDynamicDeps(e,t)}refreshDynamicDepsByIndex(e,t){return this._dependencyEngineCache.refreshDynamicDeps(this._dependencyEngineCache.getNodeRefByIndex(e),t)}hasUncalculatedDirtyPrecedentByIndex(e,t){return this._dependencyEngineCache.hasUncalculatedDirtyPrecedentByIndex(e,t)}forEachPrecedentNodeByIndex(e,t){this._dependencyEngineCache.forEachPrecedentNodeByIndex(e,(e,n)=>{t(n)})}forEachDependentNodeByIndex(e,t){this._dependencyEngineCache.forEachDependentByIndex(e,(e,n)=>{t(n)})}prepareDynamicDependencies(e){return this._dependencyEngineCache.prepareDynamicDependencies(e)}getCalculationOrder(e){return this._dependencyEngineCache.getCalculationOrder(e)}};function ee(e,t,n,r){var i=arguments.length,a=i<3?t:r===null?r=Object.getOwnPropertyDescriptor(t,n):r,o;if(typeof Reflect==`object`&&typeof Reflect.decorate==`function`)a=Reflect.decorate(e,t,n,r);else for(var s=e.length-1;s>=0;s--)(o=e[s])&&(a=(i<3?o(a):i>3?o(t,n,a):o(t,n))||a);return i>3&&a&&Object.defineProperty(t,n,a),a}let $=class extends r.UniverFormulaEnginePlugin{_initializeWithOverride(){var e;this._injector.add([r.LexerTreeBuilder,{useClass:r.LexerTreeBuilder}]),(e=this._config)!=null&&e.notExecuteFormula||[[r.ICalculateFormulaService,{useClass:E}],[r.IDependencyManagerService,{useClass:Q}],[r.IFormulaDependencyGenerator,{useClass:T}]].forEach(e=>this._injector.add(e))}};w($,`packageName`,i),w($,`version`,a),$=ee([(0,n.DependentOn)(t.UniverLicensePlugin)],$),Object.defineProperty(e,`UniverProFormulaEnginePlugin`,{enumerable:!0,get:function(){return $}}),Object.keys(r).forEach(function(t){t!==`default`&&!Object.prototype.hasOwnProperty.call(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:function(){return r[t]}})})});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@univerjs-pro/engine-formula",
3
- "version": "0.22.1",
3
+ "version": "0.23.0",
4
4
  "private": false,
5
5
  "description": "Performance-enhanced formula engine plugin for Univer Pro.",
6
6
  "author": "DreamNum Co., Ltd. <developer@univer.ai>",
@@ -58,14 +58,14 @@
58
58
  "lib"
59
59
  ],
60
60
  "dependencies": {
61
- "@univerjs/core": "0.22.1",
62
- "@univerjs-pro/license": "0.22.1",
63
- "@univerjs/engine-formula": "0.22.1"
61
+ "@univerjs-pro/license": "0.23.0",
62
+ "@univerjs/core": "0.23.0",
63
+ "@univerjs/engine-formula": "0.23.0"
64
64
  },
65
65
  "devDependencies": {
66
66
  "typescript": "^6.0.3",
67
67
  "vitest": "^4.1.4",
68
- "@univerjs-infra/shared": "0.22.1"
68
+ "@univerjs-infra/shared": "0.23.0"
69
69
  },
70
70
  "scripts": {
71
71
  "test": "vitest run",
@@ -1,25 +0,0 @@
1
- import type { Nullable } from '@univerjs/core';
2
- import type { IDefinedNamesServiceParam, IExprTreeNode, IFunctionNames, ISuperTable } from '@univerjs/engine-formula';
3
- import { LexerTreeBuilder } from '@univerjs/engine-formula';
4
- export declare class LexerTreeProBuilder extends LexerTreeBuilder {
5
- private _hasNewExcelFunction;
6
- private _lambdaFunctionParameterSet;
7
- private _xlpmPrefix;
8
- private _xlfnPrefix;
9
- private _resetPrefix;
10
- private _clearPrefix;
11
- getNewFormulaWithPrefix(formulaString: string, hasFunction: (functionToken: IFunctionNames) => boolean): string | null;
12
- private _generateNewFunctionString;
13
- private _handleNewFunctionChild;
14
- private _clearFunctionString;
15
- private _checkAddBracketForMinus;
16
- private _currentUnitId;
17
- getFormulaExprTree(formulaString: string, unitId: string, hasFunction: (functionToken: IFunctionNames) => boolean, getDefinedNameName: (unitId: string, name: string) => Nullable<IDefinedNamesServiceParam>, getTable: (unitId: string, tableName: string) => Nullable<ISuperTable>): IExprTreeNode | null;
18
- private _generateExprTree;
19
- private _handleChildrenForExprTree;
20
- private _checkColonNodeForExprTree;
21
- private _handleTextNodeForExprTree;
22
- private _getTableNameFromStructuredRef;
23
- private _handleLambdaForExprTree;
24
- private _getCurNodeTypeForExprTree;
25
- }