o
    ep                    @   s  d Z ddlmZ ddlZddlZddlmZ ddlm	Z	m
Z
mZmZmZmZ ddlT g dZdZd	Zd
ZdZdZdZdZdddddddZee ee ee e ee e ee e ee e eee e ee e ee e ee ee djZdZd
ZdZd	ZdZdZ dZ!dZ"dddddd d!d"d#Z#d$Z$g d%Z%g d&Z&g d'Z'g d(Z(g d)Z)e%e%e&e'e'e(e(e)d*Z*g d+Z+i dd,dd-d	d.dd/d
d0dd1d2d3d4d5dd6d7d8d9d:d;d<d=d>d?d@dAdBdCdDddEi dFdGdHdIdJdKdLdMdNdOdPdQdRdSdTdUdVdWdXdYdZd[d\d]d^d_d`dadbdcddddedfi dgdhdidjdkdldmdndodpdqdrdsdtdudvdwdxdydzd{d|d}d~ddddddddddi ddddddddddddddddddddddddddddddddddi ddddddddddddddddddddddddddÓddœddǓddɓdd˓i dd͓ddϓddѓddӓddՓddדddٓddۓddݓddߓddddddddddddddi ddddddddddddddddddd ddddddddd	d
dddddi ddddddddddddddddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1i d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSi dTdUdVdWdXdYdZd[d\d]d^d_d`dadbdcdddedfdgdhdidjdkdldmdndodpdqdrdsdtdui dvdwdxdydzd{d|d}d~dddddddddddddddddddddddddi ddddddddddddddddddddddddddddddddddi ddddddddddÓdĐdœdƐdǓdȐdɓdʐd˓d̐d͓dΐdϓdАdѓdҐdӓdԐdՓd֐dדdؐdٓdڐdۓi dܐdݓdސdߓddddddddddddddddddddddddddddddi ddd ddddddddd	d
dddddddddddddddddddddd d!d"d#d$d%Z,d&d'd(d)d*d+d,d-d.d/	Z-e.g d0Z/e0e1e0e1e0e1fZ2e1e0e1e0e1e0fZ3d1d2 Z4dd3d4Z5	dd5d6Z6dd7d8Z7dd9d:Z8dd;d<Z9	dd=d>Z:G d?d@ d@e;Z<G dAdB dBe=Z>G dCdD dDe?Z@dZAd
ZBdZCd2ZDd4ZEdZFeGd7dC\ZHZIZJZKZLZMdEdF ZNdGdH ZOdIdJ ZPdKdL ZQdMdN ZRdOdP ZSdQdR ZTdSdT ZUdUdV ZVeeNe!eWiZXeeNe!eNiZYeeVe!eNiZZeAeXeej[d`dWfeBeXeej\d`dXfeCeXeej]dsdYfeDeXeej^dsdZfeEeXeeOdd[feFeZe!ej[dLd\feHeYeePd9d]feIeYeeQd9d^feJeYeeRd9d_feKeYeeSd9d`feLeYeeTd9dafeMeYeeUd9dbfiZ_dcdd ddXdefdfdd ddWdefdgdd ddedhfdiZ`djZadjZbdZcd9ZdddkdlZe		ddmdnZfddodpZgddqdrZhddsdtZidudv ZjddwdxZkddydzZld{d| Zmdd}d~ZndddZodd ZpdddZqdd Zrdd Zsdd ZtdS (  z9
Module for parsing/evaluating Microsoft Excel formulas.
    )print_functionN)unpack   )
BaseObject	XLRDErrorerror_text_from_codehex_char_dumpunpack_string_update_posunpack_unicode_update_pos)*)oBOOLoERRoNUMoREFoRELoSTRGoUNKdecompile_formuladump_formulaevaluate_name_formula
okind_dictrangename3drangename3drelcellnamecellnameabscolnameFMLA_TYPE_CELLFMLA_TYPE_SHAREDFMLA_TYPE_ARRAYFMLA_TYPE_COND_FMTFMLA_TYPE_DATA_VALFMLA_TYPE_NAMEOperandRef3D                ?   CELLSHAREDARRAYzCOND-FMTzDATA-VALNAME)r   r$   r%   r&   r'   r(   )r   r$      r'      r(   #   9   :   ;   ,   -         r   r   r   r   r   r   r   oMSNG)r9   r8   r   r   r$   r6   r%   r7   ,)@r9   r%   r%   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r8   r9   r8   r&   r%   r$   r$   r6   	   r&   r$   r6   r&   r%      r7   r7   r7   r$   r%   r=   r%   r=   r$   r$   r9   r9   r9   r9   r9   r9   r9   r9   r6   r9   r9   r9   r9   r9   r9   r9   )@r9   r7   r7   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r8   r9   r8      r7   r$   r$   r6   r<   r<   r$   r6   r>   r%   r=   r=   r=   r=   r6   r%   r=   r%   r=   r6   r6   r9   r9   r9   r9   r9   r9   r9   r9   r6   r9   r9   r9   r9   r9   r9   r9   )@r9   r7   r7   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r8   r9   r8   r>   r7   r$   r$   r6   r<   r<   r6   r%   r>   r%   r=   r=   r=   r=   r6   r%   r=   r%   r=   r6   r6   r9   r9   r9   r9   r9   r9   r9   r9   r9   r9   r9   r9   r9   r9   r9   r9   )@r9   r7   r7   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r8   r9   r8   r9   r9   r$   r$   r6   r<   r<   r6   r%   r.   r%   r=   r=   r=   r=   r6   r%   r=   r%   r=   r6   r6   r9   r9   r9   r9   r9   r9   r9   r9   r9            r@   rA   r9   r9   )@r9   r7   r7   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r8   r8   r8   r9   r9   r$   r$   r6   r<   r<   r6   r%   r7   r7   r<   r=   r=   r=   r6   r7   r<   r7   r<   r6   r6   r9   r9   r9   r9   r9   r9   r9   r9   r9   r=   r=   r>   r=   r>   r9   r9   )   rA      (   r5   2   F   P   )@Unk00ExpTblAddSubMulDivPowerConcatLTLEEQGEGTNEIsectListRangeUplusUminusPercentParenMissArgStrExtendedAttrSheetEndSheetErrBoolIntNumArrayFuncFuncVarNameRefAreaMemAreaMemErrMemNoMemMemFuncRefErrAreaErrRefNAreaNMemAreaN	MemNoMemN rx   rx   rx   rx   rx   rx   rx   FuncCENameXRef3dArea3dRefErr3d	AreaErr3drx   rx   )COUNTr   rC   r%   r   VR)IFr$   r6   r%   r6   r   VRR)ISNAr   r   r$   r   r   r   )ISERRORr   r   r$   r   r   r   )SUMr   rC   r%   r   r   r   )AVERAGEr   rC   r%   r   r   r      )MINr   rC   r%   r   r   r   r=   )MAXr   rC   r%   r   r   r   )ROWr   r   r%   r   r   r   r<   )COLUMNr   r   r%   r   r   r   
   )NAr   r   r$   r   r   rx   r>   )NPVr$   rC   r%   r$   r   VR   )STDEVr   rC   r%   r   r   r      )DOLLARr   r$   r%   r   r   r      )FIXEDr$   r6   r%   r6   r   VVVr.   )SINr   r   r$   r   r   r   )COSr   r   r$   r   r   r   r/   )TANr   r   r$   r   r   r   r@   )ATANr   r   r$   r   r   r      )PIr   r   r$   r   r   rx   rB   )SQRTr   r   r$   r   r   r   rA   )EXPr   r   r$   r   r   r      )LNr   r   r$   r   r   r      )LOG10r   r   r$   r   r   r      )ABSr   r   r$   r   r   r   r?   )INTr   r   r$   r   r   r      )SIGNr   r   r$   r   r   r      )ROUNDr$   r$   r$   r$   r   VV   )LOOKUPr$   r6   r%   r$   r   r      )INDEXr$   r%   r   r%   r   RVVVrC   )REPTr$   r$   r$   r$   r   r      )MIDr6   r6   r$   r6   r   r   )LENr   r   r$   r   r   r   !   )VALUEr   r   r$   r   r   r   "   )TRUEr   r   r$   r   r   rx   r0   )FALSEr   r   r$   r   r   rx   $   )ANDr   rC   r%   r   r   r   %   )ORr   rC   r%   r   r   r   &   )NOTr   r   r$   r   r   r   '   )MODr$   r$   r$   r$   r   r   rD   )DCOUNTr6   r6   r$   r6   r   RRR)   )DSUMr6   r6   r$   r6   r   r   *   )DAVERAGEr6   r6   r$   r6   r   r   +   )DMINr6   r6   r$   r6   r   r   r4   )DMAXr6   r6   r$   r6   r   r   r5   )DSTDEVr6   r6   r$   r6   r   r   .   )VARr   rC   r%   r   r   r   /   )DVARr6   r6   r$   r6   r   r   0   )TEXTr$   r$   r$   r$   r   r   1   )LINESTr   r%   r%   r%   ARRVVrE   )TRENDr   r%   r%   r%   r   RRRV3   )LOGESTr   r%   r%   r%   r   r   4   )GROWTHr   r%   r%   r%   r   r   8   )PVr6   r7   r%   r7   r   VVVVVr1   )FVr6   r7   r%   r7   r   r   r2   )NPERr6   r7   r%   r7   r   r   r3   )PMTr6   r7   r%   r7   r   r   <   )RATEr6   r   r%   r   r   VVVVVV=   )MIRRr6   r6   r$   r6   r   RVV>   )IRRr   r$   r%   r$   r   RV)RANDr   r   r   r   r   rx   @   )MATCHr$   r6   r%   r6   r   r   A   )DATEr6   r6   r$   r6   r   r   B   )TIMEr6   r6   r$   r6   r   r   C   )DAYr   r   r$   r   r   r   D   )MONTHr   r   r$   r   r   r   E   )YEARr   r   r$   r   r   r   rF   )WEEKDAYr   r$   r%   r$   r   r   G   )HOURr   r   r$   r   r   r   H   )MINUTEr   r   r$   r   r   r   I   )SECONDr   r   r$   r   r   r   J   )NOWr   r   r   r   r   rx   K   )AREASr   r   r$   r   r   r   L   )ROWSr   r   r$   r   r   r   M   )COLUMNSr   r   r$   r   r   r   N   )OFFSETr6   r7   r%   r7   r   RVVVVR   )SEARCHr$   r6   r%   r6   r   r   S   )	TRANSPOSEr   r   r$   r   r   r   V   )TYPEr   r   r$   r   r   r   \   )	SERIESSUMr%   r%   r$   r%   r   VVVAa   )ATAN2r$   r$   r$   r$   r   r   b   )ASINr   r   r$   r   r   r   c   )ACOSr   r   r$   r   r   r   d   )CHOOSEr$   rC   r%   r$   r   r   e   )HLOOKUPr6   r%   r%   r%   r   VRRVf   )VLOOKUPr6   r%   r%   r%   r   r  i   )ISREFr   r   r$   r   r   r   m   )LOGr   r$   r%   r$   r   r   o   )CHARr   r   r$   r   r   r   p   )LOWERr   r   r$   r   r   r   q   )UPPERr   r   r$   r   r   r   r   )PROPERr   r   r$   r   r   r   s   )LEFTr   r$   r%   r$   r   r   t   )RIGHTr   r$   r%   r$   r   r   u   )EXACTr$   r$   r$   r$   r   r   v   )TRIMr   r   r$   r   r   r   w   )REPLACEr%   r%   r$   r%   r   VVVVx   )
SUBSTITUTEr6   r%   r%   r%   r   r6  y   )CODEr   r   r$   r   r   r   |   )FINDr$   r6   r%   r6   r   r   }   )r*   r   r$   r   r$   r   r   ~   )ISERRr   r   r$   r   r   r      )ISTEXTr   r   r$   r   r   r      )ISNUMBERr   r   r$   r   r   r      )ISBLANKr   r   r$   r   r   r      )Tr   r   r$   r   r   r      )Nr   r   r$   r   r   r      )	DATEVALUEr   r   r$   r   r   r      )	TIMEVALUEr   r   r$   r   r   r      )SLNr6   r6   r$   r6   r   r      )SYDr%   r%   r$   r%   r   r6     )DDBr%   r7   r%   r7   r   r      )INDIRECTr   r$   r   r$   r   r      )CLEANr   r   r$   r   r   r      )MDETERMr   r   r$   r   r   r      )MINVERSEr   r   r$   r   r   r      )MMULTr$   r$   r$   r$   r   AA   )IPMTr%   r   r%   r   r   r      )PPMTr%   r   r%   r   r   r      )COUNTAr   rC   r%   r   r   r      )PRODUCTr   rC   r%   r   r   r      )FACTr   r   r$   r   r   r      )DPRODUCTr6   r6   r$   r6   r   r      )	ISNONTEXTr   r   r$   r   r   r      )STDEVPr   rC   r%   r   r   r      )VARPr   rC   r%   r   r   r      )DSTDEVPr6   r6   r$   r6   r   r      )DVARPr6   r6   r$   r6   r   r      )TRUNCr   r$   r%   r$   r   r      )	ISLOGICALr   r   r$   r   r   r      )DCOUNTAr6   r6   r$   r6   r   r      )USDOLLARr   r$   r%   r$   r   r      )FINDBr$   r6   r%   r6   r   r      )SEARCHBr$   r6   r%   r6   r   r      )REPLACEBr%   r%   r$   r%   r   r6     )LEFTBr   r$   r%   r$   r   r      )RIGHTBr   r$   r%   r$   r   r      )MIDBr6   r6   r$   r6   r   r      )LENBr   r   r$   r   r   r      )ROUNDUPr$   r$   r$   r$   r   r      )	ROUNDDOWNr$   r$   r$   r$   r   r      )ASCr   r   r$   r   r   r      )DBCSr   r   r$   r   r   r      )RANKr$   r6   r%   r6   r   VRV   )ADDRESSr$   r7   r%   r7   r   r      )DAYS360r$   r6   r%   r6   r   r      )TODAYr   r   r   r   r   rx      )VDBr7   r=   r%   r=   r   VVVVVVV   )MEDIANr   rC   r%   r   r   r      )
SUMPRODUCTr   rC   r%   r   r   r      )SINHr   r   r$   r   r   r      )COSHr   r   r$   r   r   r      )TANHr   r   r$   r   r   r      )ASINHr   r   r$   r   r   r      )ACOSHr   r   r$   r   r   r      )ATANHr   r   r$   r   r   r      )DGETr6   r6   r$   r6   r   r      )INFOr   r   r$   r   r   r      )DBr%   r7   r%   r7   r   r      )	FREQUENCYr$   r$   r$   r$   r   RRi  )z
ERROR.TYPEr   r   r$   r   r   r   i  )AVEDEVr   rC   r%   r   r   r   i  )BETADISTr6   r7   r%   r   r   r   i  )GAMMALNr   r   r$   r   r   r   i  )BETAINVr6   r7   r%   r   r   r   i  )	BINOMDISTr%   r%   r$   r%   r   r6  i  )CHIDISTr$   r$   r$   r$   r   r   i  )CHIINVr$   r$   r$   r$   r   r   i  )COMBINr$   r$   r$   r$   r   r   i  )
CONFIDENCEr6   r6   r$   r6   r   r   i  )	CRITBINOMr6   r6   r$   r6   r   r   i  )EVENr   r   r$   r   r   r   i  )	EXPONDISTr6   r6   r$   r6   r   r   i  )FDISTr6   r6   r$   r6   r   r   i  )FINVr6   r6   r$   r6   r   r   i  )FISHERr   r   r$   r   r   r   i  )	FISHERINVr   r   r$   r   r   r   i  )FLOORr$   r$   r$   r$   r   r   i  )	GAMMADISTr%   r%   r$   r%   r   r6  i  )GAMMAINVr6   r6   r$   r6   r   r   i   )CEILINGr$   r$   r$   r$   r   r   i!  )HYPGEOMDISTr%   r%   r$   r%   r   r6  i"  )LOGNORMDISTr6   r6   r$   r6   r   r   i#  )LOGINVr6   r6   r$   r6   r   r   i$  )NEGBINOMDISTr6   r6   r$   r6   r   r   i%  )NORMDISTr%   r%   r$   r%   r   r6  i&  )	NORMSDISTr   r   r$   r   r   r   i'  )NORMINVr6   r6   r$   r6   r   r   i(  )NORMSINVr   r   r$   r   r   r   i)  )STANDARDIZEr6   r6   r$   r6   r   r   i*  )ODDr   r   r$   r   r   r   i+  )PERMUTr$   r$   r$   r$   r   r   i,  )POISSONr6   r6   r$   r6   r   r   i-  )TDISTr6   r6   r$   r6   r   r   i.  )WEIBULLr%   r%   r$   r%   r   r6  i/  )SUMXMY2r$   r$   r$   r$   r   r^  i0  )SUMX2MY2r$   r$   r$   r$   r   r^  i1  )SUMX2PY2r$   r$   r$   r$   r   r^  i2  )CHITESTr$   r$   r$   r$   r   r^  i3  )CORRELr$   r$   r$   r$   r   r^  i4  )COVARr$   r$   r$   r$   r   r^  i5  )FORECASTr6   r6   r$   r6   r   VAAi6  )FTESTr$   r$   r$   r$   r   r^  i7  )	INTERCEPTr$   r$   r$   r$   r   r^  i8  )PEARSONr$   r$   r$   r$   r   r^  i9  )RSQr$   r$   r$   r$   r   r^  i:  )STEYXr$   r$   r$   r$   r   r^  i;  )SLOPEr$   r$   r$   r$   r   r^  i<  )TTESTr%   r%   r$   r%   r   AAVVi=  )PROBr6   r%   r%   r6   r   AAVi>  )DEVSQr   rC   r%   r   r   r   i?  )GEOMEANr   rC   r%   r   r   r   i@  )HARMEANr   rC   r%   r   r   r   iA  )SUMSQr   rC   r%   r   r   r   iB  )KURTr   rC   r%   r   r   r   iC  )SKEWr   rC   r%   r   r   r   iD  )ZTESTr$   r6   r%   r$   r   r   iE  )LARGEr$   r$   r$   r$   r   r   iF  )SMALLr$   r$   r$   r$   r   r   iG  )QUARTILEr$   r$   r$   r$   r   r   iH  )
PERCENTILEr$   r$   r$   r$   r   r   iI  )PERCENTRANKr$   r6   r%   r$   r   r   iJ  )MODEr   rC   r%   r   r   r   iK  )TRIMMEANr$   r$   r$   r$   r   r   iL  )TINVr$   r$   r$   r$   r   r   iP  )CONCATENATEr   rC   r%   r   r   r   iQ  )POWERr$   r$   r$   r$   r   r   iV  )RADIANSr   r   r$   r   r   r   iW  )DEGREESr   r   r$   r   r   r   iX  )SUBTOTALr$   rC   r%   r$   r   r   iY  )SUMIFr$   r6   r%   r6   r   RVRiZ  )COUNTIFr$   r$   r$   r$   r   r   i[  )
COUNTBLANKr   r   r$   r   r   r   i^  )ISPMTr%   r%   r$   r%   r   r6  i_  )DATEDIFr6   r6   r$   r6   r   r   i`  )
DATESTRINGr   r   r$   r   r   r   ia  )NUMBERSTRINGr$   r$   r$   r$   r   r   ib  )ROMANr   r$   r%   r$   r   r   if  )GETPIVOTDATAr$   r$   r$   r$   r   r   ig  )	HYPERLINKr   r$   r%   r$   r   r   ih  )PHONETICr   r   r$   r   r   r   ii  )AVERAGEAr   rC   r%   r   r   r   ij  )MAXAr   rC   r%   r   r   r   ik  )MINAr   rC   r%   r   r   r   il  )STDEVPAr   rC   r%   r   r   r   im  )VARPAr   rC   r%   r   r   r   in  )STDEVAr   rC   r%   r   r   r   io  )VARAr   rC   r%   r   r   r   ip  )BAHTTEXTr   r   r$   r   r   r   iq  )THAIDAYOFWEEKr   r   r$   r   r   r   ir  )	THAIDIGITr   r   r$   r   r   r   is  )THAIMONTHOFYEARr   r   r$   r   r   r   it  )THAINUMSOUNDr   r   r$   r   r   r   iu  )THAINUMSTRINGr   r   r$   r   r   r   iv  )THAISTRINGLENGTHr   r   r$   r   r   r   )ISTHAIDIGITr   r   r$   r   r   r   )ROUNDBAHTDOWNr   r   r$   r   r   r   )ROUNDBAHTUPr   r   r$   r   r   r   )THAIYEARr   r   r$   r   r   r   )RTDr$   r7   r%   r   r   r   )iw  ix  iy  iz  i{  zSkip??VolatileIfChooseSkipSumAssignSpaceSpaceVolatile)	r   r   r$   r%   r&   r'   r(   r   r   )r=   r&   r   r>   r   r   r   c                 C   s   t dd t| |j|jD S )Nc                 s   s     | ]\}}}|||V  qd S N ).0funcnumanumbr(  r(  ?/var/www/html/venv/lib/python3.10/site-packages/xlrd/formula.py	<genexpr>  s
    
zdo_box_funcs.<locals>.<genexpr>)tuplezipcoords)	box_funcsboxaboxbr(  r(  r-  do_box_funcs  s   r5  c           	      C   sv   |d? d@ }|d? d@ }| }|d@ }|r)|r|dkr|d8 }|r(|dkr(|d8 }n|r/||8 }|r5||8 }||||fS )	Nr.   r   r            rB     r(  	rowvalcolvalreldeltabrowxbcolxrow_relcol_relrowxcolxr(  r(  r-  adjust_cell_addr_biff8  s   rD  c           	      C   sv   | d? d@ }| d? d@ }| d@ }|}|r)|r|dkr|d8 }|r(|dkr(|d8 }n|r/||8 }|r5||8 }||||fS )	Nr.   r   r   i?  i    i @  rB  r9  r(  r:  r(  r(  r-  adjust_cell_addr_biff_le7  s   rE  c                 C   s\   |dkrt d| ||d  \}}t|||||S t d| ||d  \}}t|||||S )NrG   <HHr%   z<HBr6   r   rD  rE  )dataposbvr=  r>  r?  r;  r<  r(  r(  r-  get_cell_addr  s   
rK  c                 C   s   |dkr't d| ||d  \}}}}	t|||||}
t||	|||}|
|fS t d| ||d  \}}}}	t|||||}
t||	|||}|
|fS )NrG   z<HHHHr&   z<HHBBr   rG  )rH  rI  rJ  r=  r>  r?  row1valrow2valcol1valcol2valres1res2r(  r(  r-  get_cell_range_addr  s   

rR  c           
      C   s  z| j | }W n ty   td|t| j f | jd Y dS w |\}}}|| jkrG|r7td||f | jd |d  krB|ksEJ  J dS || jkr[|rYtd||f | jd dS |d  kre|krvn n|rttd	||f | jd d
S |d  kr|krn n|rtd|f | jd dS t| j}d|  kr|  kr|k sn |rtd||f | jd td| | jd dS | j| }| j| }	d|  kr|	ksdS  dS ||	fS )Nz:!!! get_externsheet_local_range: refx=%d, not in range(%d)file)rU  z5/// get_externsheet_local_range(refx=%d) -> addins %ri  )rV  z7/// get_externsheet_local_range(refx=%d) -> external %rrX  z@/// get_externsheet_local_range(refx=%d) -> unspecified sheet %rr8   r8   i  z</// get_externsheet_local_range(refx=%d) -> deleted sheet(s)r9   r9   r   z./// get_externsheet_local_range(refx=%d) -> %r%--- first/last sheet not in range(%d))r\  r^  )_externsheet_info
IndexErrorprintlenlogfile_supbook_addins_inx_supbook_locals_inx_all_sheets_map)
bkrefxblahinforef_recordxref_first_sheetxref_last_sheetxnsheetsxlrd_sheetx1xlrd_sheetx2r(  r(  r-  get_externsheet_local_range  sR   



 

rq  c                 C   s   |dkr|rt d| | jd dS |dkr|dkrdS t| j}d|  kr/|  kr/|k sIn |rGt d|||f | jd t d| | jd d	S | j| }| j| }d|  kr^|ksad
S  d
S ||fS )Nr   z?/// get_externsheet_local_range_b57(raw_extshtx=%d) -> externalrS  rW  r8   rZ  z6/// get_externsheet_local_range_b57(%d, %d, %d) -> ???r[  )rr  r]  )ra  rc  rb  rf  )rg  raw_extshtxrl  rm  ri  rn  ro  rp  r(  r(  r-  get_externsheet_local_range_b57  s.   
 

rt  c                   @   s   e Zd ZdS )FormulaErrorN)__name__
__module____qualname__r(  r(  r(  r-  ru    s    ru  c                   @   s.   e Zd ZdZdZeZdZd	ddZdd Z	dS )
r"   a  
    Used in evaluating formulas.
    The following table describes the kinds and how their values
    are represented.

    .. raw:: html

        <table border="1" cellpadding="7">
        <tr>
        <th>Kind symbol</th>
        <th>Kind number</th>
        <th>Value representation</th>
        </tr>
        <tr>
        <td>oBOOL</td>
        <td align="center">3</td>
        <td>integer: 0 => False; 1 => True</td>
        </tr>
        <tr>
        <td>oERR</td>
        <td align="center">4</td>
        <td>None, or an int error code (same as XL_CELL_ERROR in the Cell class).
        </td>
        </tr>
        <tr>
        <td>oMSNG</td>
        <td align="center">5</td>
        <td>Used by Excel as a placeholder for a missing (not supplied) function
        argument. Should *not* appear as a final formula result. Value is None.</td>
        </tr>
        <tr>
        <td>oNUM</td>
        <td align="center">2</td>
        <td>A float. Note that there is no way of distinguishing dates.</td>
        </tr>
        <tr>
        <td>oREF</td>
        <td align="center">-1</td>
        <td>The value is either None or a non-empty list of
        absolute Ref3D instances.<br>
        </td>
        </tr>
        <tr>
        <td>oREL</td>
        <td align="center">-2</td>
        <td>The value is None or a non-empty list of
        fully or partially relative Ref3D instances.
        </td>
        </tr>
        <tr>
        <td>oSTRG</td>
        <td align="center">1</td>
        <td>A Unicode string.</td>
        </tr>
        <tr>
        <td>oUNK</td>
        <td align="center">0</td>
        <td>The kind is unknown or ambiguous. The value is None</td>
        </tr>
        </table>
    N?r   c                 C   s,   |d ur|| _ |d ur|| _|| _|| _d S r'  )kindvalueranktext)selfakindavaluearankatextr(  r(  r-  __init__b  s   
zOperand.__init__c                 C   s    t | jd}d|| j| jf S )Nz?Unknown kind?z#Operand(kind=%s, value=%r, text=%r))r   getrz  r{  r}  )r~  	kind_textr(  r(  r-  __repr__l  s   zOperand.__repr__)NNr   ry  )
rv  rw  rx  __doc__r{  r   rz  r}  r  r  r(  r(  r(  r-  r"     s    @

r"   c                   @   s    e Zd ZdZdd Zdd ZdS )r#   a  
    Represents an absolute or relative 3-dimensional reference to a box
    of one or more cells.

    The ``coords`` attribute is a tuple of the form::

      (shtxlo, shtxhi, rowxlo, rowxhi, colxlo, colxhi)

    where ``0 <= thingxlo <= thingx < thingxhi``.

    .. note::
      It is quite possible to have ``thingx > nthings``; for example
      ``Print_Titles`` could have ``colxhi == 256`` and/or ``rowxhi == 65536``
      irrespective of how many columns/rows are actually used in the worksheet.
      The caller will need to decide how to handle this situation.
      Keyword: :class:`IndexError` :-)

    The components of the coords attribute are also available as individual
    attributes: ``shtxlo``, ``shtxhi``, ``rowxlo``, ``rowxhi``, ``colxlo``, and
    ``colxhi``.

    The ``relflags`` attribute is a 6-tuple of flags which indicate whether
    the corresponding (sheet|row|col)(lo|hi) is relative (1) or absolute (0).

    .. note::
      There is necessarily no information available as to what cell(s)
      the reference could possibly be relative to. The caller must decide what
      if any use to make of ``oREL`` operands.

    .. note:
      A partially relative reference may well be a typo.
      For example, define name ``A1Z10`` as ``$a$1:$z10`` (missing ``$`` after
      ``z``) while the cursor is on cell ``Sheet3!A27``.

      The resulting :class:`Ref3D` instance will have
      ``coords = (2, 3, 0, -16, 0, 26)``
      and ``relflags = (0, 0, 0, 1, 0, 0).<br>

      So far, only one possibility of a sheet-relative component in
      a reference has been noticed: a 2D reference located in the
      "current sheet".

      This will appear as ``coords = (0, 1, ...)`` and
      ``relflags = (1, 1, ...)``.

    .. versionadded:: 0.6.0
    c                 C   sJ   |dd | _ |dd | _| jsd| _| j \| _| _| _| _| _| _d S )Nr   r   r   r   r   r   r   r   r   )r1  relflagsshtxloshtxhirowxlorowxhicolxlocolxhi)r~  atupler(  r(  r-  r    s   
zRef3D.__init__c                 C   s,   | j r| j dkrd| jf S d| j| j f S )Nr  zRef3D(coords=%r)zRef3D(coords=%r, relflags=%r))r  r1  )r~  r(  r(  r-  r    s
   
zRef3D.__repr__N)rv  rw  rx  r  r  r  r(  r(  r(  r-  r#   r  s    0	r#   c                 C      | S r'  r(  xr(  r(  r-  nop  s   r  c                 C   s   | | S r'  r(  r  yr(  r(  r-  _opr_pow      r  c                 C   s   | |k S r'  r(  r  r(  r(  r-  _opr_lt  r  r  c                 C   s   | |kS r'  r(  r  r(  r(  r-  _opr_le  r  r  c                 C   s   | |kS r'  r(  r  r(  r(  r-  _opr_eq  r  r  c                 C   s   | |kS r'  r(  r  r(  r(  r-  _opr_ge  r  r  c                 C   s   | |kS r'  r(  r  r(  r(  r-  _opr_gt  r  r  c                 C   s   | |kS r'  r(  r  r(  r(  r-  _opr_ne  r  r  c                 C   s"   t | }|dr|dd }|S )zN
    Attempt to emulate Excel's default conversion from number to string.
    z.0Nr9   )strendswith)numsr(  r(  r-  num2strg  s   
r  +-r   /^&<z<==z>=>z<>c                 C   s   |  S r'  r(  r  r(  r(  r-  <lambda>  s    r  rx   c                 C   r  r'  r(  r  r(  r(  r-  r    s    c                 C   s   | d S )Ng      Y@r(  r  r(  r(  r-  r    r  %)r   r@   rB   Z   c           W      C   s  |t krd}|j}|j}| j}d}|r,td||j||||f | jd t|d|| jd |tkr4t	dt
| }	d}
g }d}d}d}ttd }ttd }|j}dd }d	d
 }dd }|dkrb|g}d|
  krm|k r1n nt||
 }|d@ }|d@ d? }|r|d }n|}t| }|	| }|rtd|
|||||f | jd td|| jd |dkrd|||f }t||sZd|  krdkrn n||| n{d|  krdkrn n||| nh|dkr|rtd|| jd t|dksJ | }| }d}d}ddd |j|k  |jdd |j|k  |dd |j|k  |jdd |j|k  g} tt}!| |!_|jtksB|jtkrFt|!_n|jtksR|jtkrSn|jt  kra|jkrn n3|jd ur|jd urt|jdksyJ t|jdksJ tt|jd |jd }"t|"g|!_nZ|jt  kr|jkrn nIt|!_|jd ur|jd urt|jdksJ t|jdksJ tt|jd |jd }"|jd j}#|jd j}$|#|$krt|"|# g|!_n	 ||! |rtd|| jd nI|d kr|rtd!|| jd t|dksJ | }| }d"}d}ddd |j|k  |jdd |j|k  |dd |j|k  |jdd |j|k  g} ttd || }!|jtksc|jtkrgt|!_nK|jttfv r|jttfv rt|!_|jtks|jtkrt|!_|jd ur|jd urt|jdksJ t|jdksJ |j|j |!_n	 ||! |rtd#|| jd n|d$kr|rtd%|| jd t|dksJ | }| }d&}d}ddd |j|k  |jdd |j|k  |dd |j|k  |jdd |j|k  g} ttd || }!|jtks%|jtkr(t}!n|jt  kr6|jkrkn n3|jd urj|jd urjt|jdksNJ t|jdksXJ tt|jd |jd }"t|"g|!_nZ|jt  kry|jkrn nIt|!_|jd ur|jd urt|jdksJ t|jdksJ tt|jd |jd }"|jd j}#|jd j}$|#|$krt|"|# g|!_n	 ||! |rtd'|| jd ntd(|  krd)krn n||t | n^|d*krnW|d+kr|tt!d t"d nG|d,krL|d-krt#||
d | j$dd.\}%}&nt%||
d dd.\}%}&|&|
 }|r8td/||%f | jd d0|%&d0d1 d0 }'|tt'|%t"|' n|d2kr\|dksXJ td3|d4krt(d5||
d |
d6  \}(})t)*|(d7}*|(d6kr|)d d8 }n0|(d krd6}|rtd9|| jd t|dksJ |d: }d;|j } tt d t+| |d:< nd6}|rtd<|(|*||)f | jd nd=|  krd>krn n|d?k sJ td@dA|  krdkrDn nZ|dA }+g dB|+ },tt,t t g|+ }-t(dCdD|+  ||
d |
d |,  \}.|+dkrt-|.}.t.|.}'n|+dkr(t.|.}'n|+dkr2dE|. }'nd0t/|.  d0 }'|t|-|.t"|' ntdF| |dkrUtdG| |
|7 }
qb|dkre|| n|dkrdt0|dHk },t(dCdI|,  ||
d |
d |,  d }/t1*|/d }0|0stdJ|/ | jd || ny|0d d \}1}2|rtdK|/|1|2f | jd t||2ksJ |2rt2dLdM ||2 d  D }3dN|1|3f } ||2 d = n|1dO } ttd t+| }!||! n)|dkrddt0|dHk },t(dPdI|,  ||
d |
d |,  \}2}/t3|2dQ\}4}2t3|/dR\}5}/|r/tdS|/|2|5|4f | jd t1*|/d }0|0sGtdT|/ | jd || n|0d d \}1}6}7|r_tdU|1|6|7f | jd |6|2  krl|7ksoJ  J t||2ksxJ t||2ksJ t2dVdM ||2 d  D }3dN|1|3f } ttd t+| }!|/dkr||2  }8|8jt t,fvr|r|8jtkrtdW| jd n|8jdXvr|r|8jd urtdY| jd n|2dkr|8jst,d|!_|!_n%|2 d t0|8j }9||9 }:|:jt!krt d|!_|!_n	|:j|:j|!_|!_|rtdZ| jd n@|/d[krX||2  }8|8jt krXd|8j  kr5|2k rXn n!||2 t0|8j  }:|:jt!krOt d|!_|!_n	|:j|:j|!_|!_||2 d = ||! n|dkrt(d\||
d |
d  d d };|rtd]|; | jd | j4|; }<|<j5st6| |<|;||d  |<j7s|<j8s|<j9r|r|<j:| jd^d_d` ttd }!|p|<j7p|<j8p|<j9}|p|<j;}nt|<j<dksJ t=>|<j<d }!t"|!_|<j?d:kr|<j|!_nda| j@|<j? |<jf |!_|rtdbtA|!j| jd ||! n|d6krktB||
d ||}!|r$tdc|!| jd |!\}=}>}?}@d }A}Bd}|A|Bd |=|=d |>|>d f}"|rItdd|"| jd ttd }!|dkredd|?|?|@|@f}Cttt|"|C g}!||! n|dkrtC||
d ||\}D}E|rtdc|D|E| jd |D\}F}G}H}I|E\}J}K}L}Md }A}Bd}|A|Bd |F|Jd |G|Kd f}"|rtdd|"| jd ttd }!|dkrdd|H|L|I|Mf}Cttt|"|C g}!||! nD|d8kr||| n8|dek	rt(d\||
d |
d  d },|	r tdf|, | jd n|dgk	r||| n
|dhk	r||| n|d=k	r|dk	rEtB||
d ||}!t(d\||
d |
d  d }NtD| |N|\}A}Bn0tB||
d ||}!t(di||
d |
d  \}O}P}Q|	rktdj|O|P|Q| jd tE| |O|P|Q|\}A}B|!\}=}>}?}@|?	p|@}R|	p|R}|A|Bd |=|=d |>|>d f}"||Ad:k O }|	rtdd|"| jd ttd }!|R	rdd|?|?|@|@f}Ct|"|C }St|!_tF| |Sddk|!_nt|"}St|!_tG| |S|!_t"|!_|dk	r|Sg|!_||! n3|d>k
r|dk
rtC||
d ||\}D}Et(d\||
d |
d  d }NtD| |N|\}A}Bn2tC||
d ||\}D}Et(di||
d |
d  \}O}P}Q|
r:tdl|O|P|Q| jd tE| |O|P|Q|\}A}B||Ad:k O }|D\}F}G}H}I|E\}J}K}L}M|H
p`|I
p`|L
p`|M}R|
pe|R}|A|Bd |F|Jd |G|Kd f}"|
rtdd|"| jd ttd }!|R
rdd|H|L|I|Mf}Ct|"|C }St|!_tF| |Sddk|!_nt|"}St|!_tG| |S|!_t"|!_|dk
r|Sg|!_||! nX|d4krd}Tttd }!|dk
rt(dm||
d |
d  \}N};|;d8 };|N}Un,t(dn||
d |
dh  \}N};|;d8 };|N}U|Ndkr|Nd8 }Nn|Ndk r|N d }Nnd}T|r#tdo|U|N|;|Tf | jd |;|kr6|r2tdp| jd d }T}|Tsd|dkrGtD| |N|\}A}Bn|UdkrQdq\}A}Bn| jH|N }V|Vd6kr`dr\}A}Bnds\}A}B|Tsl|Ad:k rzdt|;|Uf } ttd t"| }!n| j4|; }<|<j5st6| |<|;||d  |<j7s|<j8s|<j9r|r|<j:| jdudvd` ttd }!|p|<j7p|<j8p|<j9}|p|<j;}nt|<j<dksJ t=>|<j<d }!t"|!_|<j?d:kr|<j|!_nda| j@|<j? |<jf |!_|rtdwtA|!j| jd ||! n|tIv r
d}|| n|rtdx| | jd d}|dkr!tdy|
|7 }
d|
  kr0|k spn |  }|rXtJ| jdz||  || t|dkrRtd{| jd t| jd ||_<t|dkrfd |_Kn|d |_K||_;||_9||_Ld|_5d S )|Nr   z1::: evaluate_name_formula %r %r %d %d %r level=%drS  r   foutz-Excessive indirect references in NAME formulac                 S   s4  t |dksJ | }| }t|  \}}}}}ddd |j|k  |jdd |j|k  |dd |j|k  |jdd |j|k  g}	t|d ||	}
z||j }||j }W n tye   |	|
 Y d S w |j
d u sp|j
d u rw|	|
 d S ||j
}||j
}|||}|tkr|rdnd}||
_
|	|
 d S )Nr$   rx   ()r   r   )rb  popbinop_rulesjoinr|  r}  r"   rz  KeyErrorappendr{  r   )opcdstkbopaopargdictresult_kindr*  r|  symotextresopbconvaconvbvalavalresultr(  r(  r-  do_binop  s>   	





z'evaluate_name_formula.<locals>.do_binopc           
   	   S   s   t |dksJ | }|j}t|  \}}}}d|dd |j|k  |jdd |j|k  |g}	|d ur8||}|t||||	 d S Nr   rx   r  r  )	rb  r  r{  
unop_rulesr  r|  r}  r  r"   )
opcoder  r  r  valr*  r|  sym1sym2r  r(  r(  r-  
do_unaryop'  s   z)evaluate_name_formula.<locals>.do_unaryopc                 S   s   d| |f }t |)Nz1ERROR *** Token 0x%02x (%s) found in NAME formula)ru  op_arg	oname_argmsgr(  r(  r-  not_in_name_formula7  s   z2evaluate_name_formula.<locals>.not_in_name_formular   `   r7   r(   9Pos:%d Op:0x%02x Name:t%s Sz:%d opcode:%02xh optype:%02xhStack =r9   9ERROR *** Unexpected token 0x%02x ("%s"); biff_version=%dr$   r6   r   r.   
tIsect pre rG   rx   r  r  tIsect postr'   	tList prer;   
tList postr/   
tRange pre:tRange postr@   rB   rA   r   r   rF   lenlen   sz=%d strg=%r"""r   tExtended token not implementedr?   <BHr%   ??Unknown??r   tAttrSumr8   SUM(%s))   subop=%02xh subname=t%s sz=%d nc=%02xhr   r   rE   )tSheet & tEndsheet tokens not implementedr   r   r   r$   r&   r  BBHdr   r   Unhandled opcode: 0x%02xSize not set for opcode 0x%02xrD    BH#*** formula/tFunc unknown FuncID:%d    FuncID=%d name=%s nargs=%dc                 s       | ]}|j V  qd S r'  r}  r)  argr(  r(  r-  r.  $      z(evaluate_name_formula.<locals>.<genexpr>%s(%s)()<BrB  r7  (   FuncID=%d nargs=%d macro=%d prompt=%d&*** formula/tFuncVar unknown FuncID:%d!    name: %r, min~max args: %d~%dc                 s   r  r'  r  r  r(  r(  r-  r.  @  r  zIF testarg kind?)r   r   zIF testarg value?z$$$$$$ IF => constantr  <H   tgtnamex=%dz!!! tgtobj has problems!!!z-----------       --------)headerfooter%s!%s    tName: setting text to     r<     %d bytes of cell ref formular   r   <hxxxxxxxxhhtRef3d)r1c1tArea3drF  <hxxxxxxxxH+   origrefx=%d refx=%d tgtnamex=%d dodgy=%dz!!!! Self-referential !!!!rW  rY  fr  $<<Name #%d in external(?) file #%d>>z!!! bad tgtobj !!!z------------------    tNameX: setting text toFORMULA: /// Not handled yet: t!Fatal: token size is not positivez8End of formula. level=%d any_rel=%d any_err=%d stack=%r
*** Stack has unprocessed args)MSTACK_ALARM_LEVELraw_formulabasic_formula_lenbiff_versionra  namerc  r   STACK_PANIC_LEVELr   szdictr"   r   r   r  	BYTES_ORDonamesru  rb  r  r  r|  r}  r   rz  r{  r5  tIsectFuncsr#   r   r  tRangeFuncsr   r:   	LEAF_RANKr	   encodingr
   replacer   r   
tAttrNamesr  	FUNC_RANKr   floatr  r   int	func_defslistsepdivmodname_obj_list	evaluatedr   macrobinaryany_errdumpany_relstackcopydeepcopyscope_sheet_namesreprrK  rR  rq  rt  r   r   _externsheet_type_b57error_opcodesfprintfr  any_external)Wrg  nobjnamexri  levelrH  fmlalenrJ  r=  sztabrI  r0  r/  r-  r9  unk_opnd
error_opndspushr  r  r  opr  optypeopxonameszr  r  r  r  r|  r  resr1  relfarelfbstrgnewposr}  subopncsubnameinxnbrz  r{  funcx
func_attrs	func_namenargsargtextpromptr+  minargsmaxargstestargresposchosentgtnamextgtobjrB  rC  r@  rA  shx1shx2r  rP  rQ  rowx1colx1row_rel1col_rel1rowx2colx2row_rel2col_rel2rh  rs  raw_shx1raw_shx2is_relref3ddodgyorigrefxextyr(  r(  r-  r     sX  

 

	  

	 
	  












(








*
*
 




"














 






 
























        

r   c	           X         s6  |t krd}ttttfv }	|}
 j}|r.td||||	|
|f  jd t|
d| jd |t	kr6t
dt| }d}g }d}d}ttd }ttd }|j}dd }d	d
 } fdd}|dkre|g}d|  krp|k 
r_n 	nt|
| }|d@ }|d@ d? }|r|d }n|}t| }|| }|rtd||||||f  jd td| jd |dkrd|||f }t|t|d@ r||| |so|dkr	|dkrd}nd}|dkr||kr|rJ t||
\}} d|| f }!|ttd t|! ttB @ s||| nVd|  krdkrn n||| nA|dkr|r.td| jd t|dks7J | }"| }#d}$d}%d d!d |#j|%k  |#jd"d |#j|%k  |$d!d |"j|%k  |"jd"d |"j|%k  g}&tt}'|&|'_|"jtks|#jtkrt|'_n3|"jtks|#jtkrn&|"jt  kr|#jkrn nn|"jt  kr|#jkrn nt|'_n	 ||' |rtd#| jd n|d$krc|rtd%| jd t|dksJ | }"| }#d&}$d}%d d!d |#j|%k  |#jd"d |#j|%k  |$d!d |"j|%k  |"jd"d |"j|%k  g}&ttd |%|&}'|"jtks*|#jtkr.t|'_n$|"jttfv rQ|#jttfv rQt|'_|#jtksM|"jtkrPt|'_n	 ||' |ratd'| jd n|d(kr|rstd)| jd t|dks|J | }"| }#d*}$d}%d d!d |#j|%k  |#jd"d |#j|%k  |$d!d |"j|%k  |"jd"d |"j|%k  g}&ttd |%|&}'|"jtks|#jtkrt}'n|"jt  kr|#jkrn nn	 ||' |rtd+| jd ntd,|  krd-krn n||t | n^|d.krnW|d/kr|tt!d td  nG|d0kra|d1kr0t"|
|d  j#dd2\}(})nt$|
|d dd2\}(})|)| }|rMtd3||(f  jd d4|(%d4d5 d4 }!|tt&d t|! n|d6krq|dksmJ td7|d8krtd9|
|d |d:  \}*}+t'(|*d;},|*d:kr|+d d< }n0|*d$krd:}|rtd=| jd t|dksJ |d> }#d?|#j }&tt d t)|&|d>< nd:}|rtd@|*|,||+f  jd ndA|  krdBkrn n|dCk sJ tdDdE|  krdkrYn nZ|dE }-g dF|- }.tt*t t g|- }/tdGdH|-  |
|d |d |.  \}0|-dkr3t+|0}0t,|0}!n|-dkr=t,|0}!n|-dkrGdI|0 }!nd4t-|0  d4 }!|t|/d t|! ntdJ| |dkrjtdK| ||7 }qe|dkrz|| n|dkrdt.|dLk }.tdGdM|.  |
|d |d |.  d }1t/(|1d }2|2stdN|1  jd || n|2d d \}3}4|rtdO|1|3|4f  jd t||4ksJ |4rt0dPdQ ||4 d  D }5dR|3|5f }&||4 d = n|3dS }&ttd t)|&}'||' nB|dkrdt.|dLk }.tdTdM|.  |
|d |d |.  \}4}1t1|4dU\}6}4t1|1dV\}7}1|rDtdW|1|4|7|6f  jd |1dXkrLdY}2nt/(|1d }2|2sdtdZ|1  jd || n|2d d \}3}8}9|r|td[|3|8|9f  jd |8|4  kr|9ksJ  J t||4ksJ t||4ksJ t0d\dQ ||4 d  D }5dR|3|5f }&ttd t)|&}'||4 d = ||' n|dkrtd]|
|d |d  d d }:|rtd^|:  jd  j2|: };|;j3d>kr|;j4}&nd_ j5|;j3 |;j4f }&|rtd`t6|& jd ttd t|&}'||' n*|d:krat7|
|d ||	||}'|r7tda|' jd |'\}} }<}=|<pA|=}>|>rHt}?nt}?t8|| |<|=|||}&t|?d t|&}'||' n|dkrt9|
|d ||	||\}@}A|rtda|@|A jd |@\}B}C}D}E|A\}F}G}H}I|B|Fd |C|Gd f}J|D|H|E|If}Kt:|Krt}?nt}?|rtdb|J|K jd t;|J|K|||}&t|?d t|&}'||' n|d<krt<|| nt|dckrtd]|
|d |d  d }.|rtdd|.  jd nR|dekr;t7|
|d ||	||}'d}|rtdb|' jd |'\}} }<}=|<p|=}>|>r"t}?nt}?t8|| |<|=|||}&t|?d t|&}'||' n|dfkrt9|
|d ||	||\}@}A|rYtda|@|A jd |@\}B}C}D}E|A\}F}G}H}I|B|Fd |C|Gd f}J|D|H|E|If}Kt:|Kr}t}?nt}?|rtdb|J|K jd t;|J|K|||}&t|?d t|&}'||' n|dAkrj|dkrt7|
|d ||	||}'td]|
|d |d  d }Lt= |L|\}M}Nn2t7|
|d ||	||}'tdg|
|d |d  \}O}P}Q|rtdh|O|P|Q jd t> |O|P|Q|\}M}N|'\}} }<}=|<p	|=}>|p|>}|M|Nd ||d | | d f}J||Md>k O }|r.tdb|J jd ttd }'|>rQdd|<|<|=|=f}Kt?|J|K }Rt|'_t@ |R||||'_nt?|J}Rt|'_tA |R|'_t|'_d |'_B||' n|dBk	r=|dkrt9|
|d ||	\}@}Atd]|
|d |d  d }Lt= |L|\}M}Nn2t9|
|d ||	\}@}Atdg|
|d |d  \}O}P}Q|rtdi|O|P|Q jd t> |O|P|Q|\}M}N||Md>k O }|@\}B}C}D}E|A\}F}G}H}I|Dp|Ep|Hp|I}>|p|>}|M|Nd |B|Fd |C|Gd f}J|	rtdb|J jd ttd }'|>	r'dd|D|H|E|If}Kt?|J|K }Rt|'_t@ |R||||'_nt?|J}Rt|'_tA |R|'_t|'_||' n	|d8k
r,d}Sttd }'|dk	rdtdj|
|d |d  \}L}:|:d8 }:|L}Tn,tdk|
|d |df  \}L}:|:d8 }:|L}T|Ldk	r|Ld8 }Ln|Ldk 	r|L d }Lnd}S|	rtdl|T|L|:|Sf  jd |S	s|dk	rt= |L|\}M}Nn|Tdk	rdm\}M}Nn jC|L }U|Ud:k	rdn\}M}Nndo\}M}Nt}?d }V|Mdpk	rt&}? jD|: }Vd4|V%d4d5 d4 }&n7|S	s|Md>k 	rdq|:|Tf }&n( j2|: };|;j3d>k
r|;j4}&nd_ j5|;j3 |;j4f }&|
r tdrt6|'j jd t|?|Vt|&}'||' n|tEv 
r8d}|| n|
rDtds|  jd d}|dk
rOtdt||7 }d|  k
r^|k ssn |  }|
rtdu||  ||f  jd t|dk
rtdv jd t jd t|dk
rd }W|WS |d j}W|WS )wNr   zR::: decompile_formula len=%d fmlatype=%r browx=%r bcolx=%r reldelta=%d %r level=%drS  r   r  z(Excessive indirect references in formulac                 S   s   t |dksJ | }| }t|  \}}}}}ddd |j|k  |jdd |j|k  |dd |j|k  |jdd |j|k  g}	t|d ||	}
||
 d S )Nr$   rx   r  r  )rb  r  r  r  r|  r}  r"   r  )r  r  r  r  r  r  r*  r|  r  r  r  r(  r(  r-  r  g  s   	z#decompile_formula.<locals>.do_binopc           	   	   S   sr   t |dksJ | }t|  \}}}}d|dd |j|k  |jdd |j|k  |g}|t|d || d S r  )rb  r  r  r  r|  r}  r  r"   )	r  r  r  r  r*  r|  r  r  r  r(  r(  r-  r  x  s   z%decompile_formula.<locals>.do_unaryopc                    s$   d| |t  f }t| jd d S )Nz?ERROR *** Unexpected token 0x%02x (%s) found in formula type %srS  )FMLA_TYPEDESCR_MAPra  rc  r  rg  fmlatyper(  r-  unexpected_opcode  s   z,decompile_formula.<locals>.unexpected_opcoder   r  r7   r(   z;Pos:%d Op:0x%02x opname:t%s Sz:%d opcode:%02xh optype:%02xhr  r9   r  rC   z<x2Hz<xHBzSHARED FMLA at rowx=%d colx=%dr6   r   r.   r  r$   r  rG   rx   r  r  r  r'   r  r;   r  r/   r  r  r  r@   rB   rA   r   r   rF   r  r  r  r  r   r  r?   r  r%   r  r   r  r8   r  r  r   r   rE   r  r   r  r  r  r  r  r  rD   r  r  r  c                 s   r  r'  r  r  r(  r(  r-  r.  [  r  z$decompile_formula.<locals>.<genexpr>r  r  r  rB  r7  r  r6  )
CALL_ADDINr   rC   r  r  c                 s   r  r'  r  r  r(  r(  r-  r.  {  r  r  r  r  r  r  r  r<   r  r   r   r  r  r
  rF  r  r  rW  rY  r  rV  r  r  r  r  z7End of formula. level=%d any_rel=%d any_err=%d stack=%rr  )Fr  r   r!   r   r    r  ra  rc  r   r  r   r  r"   r   r   r  r  r  ru  _TOKEN_NOT_ALLOWEDr   r  r   r   rb  r  r  r|  r}  r   rz  r   r   r:   r	   r   r
   r!  r   r"  r  r#  r   r$  r  r   r%  r&  r'  r(  r)  r3  r  r4  r5  rK  cellnamerelrR  sumrangename2drelr  rq  rt  r#   r   r   r{  r6  addin_func_namesr7  )Xrg  fmlar=  rq  r>  r?  ri  r<  r	  r=  rH  rJ  r>  rI  r0  r/  r-  r?  r@  rA  r  r  rr  rB  r  rC  rD  rE  rF  r  fmtrB  rC  r}  r  r  r  r|  r  rG  rJ  rK  rL  rM  rN  rO  rP  rz  r{  rQ  rR  rS  rT  rU  rV  r+  rW  rX  r\  r]  r@  rA  rj  okindrP  rQ  r`  ra  rb  rc  rd  re  rf  rg  r1  r  rh  r^  r_  rs  rh  ri  rk  rl  rm  rn  ovaluer  r(  rp  r-  r   P  s  






	  
	 
	 











(








*
*

 
"












 





 






















      D
r   c           4      C   s  |rt d||t|| jd t|d|| jd |dksJ t| }d}g }	d}
d}|	j}d|  kr7|k rNn nt|| }|d@ }|d@ d? }|rQ|d	 }n|}t| }|| }|rlt d
||||||f | jd |sd|  krydkrn ntd||d |d  \}}|rt d||f| jd nN|dkr|rt d|	| jd t|	dksJ |		 }|		 }|||  |rt d|	| jd n|dkr|rt d|	| jd t|	dksJ |		 }|		 }t|dksJ t|dksJ t
t|d |d }|| |rt d|	| jd n|dkr^|r!t d|	| jd t|	dks*J |		 }|		 }t|dks;J t|dksDJ t
t|d |d }|| |r]t d|	| jd n|dkrtd||d |d  \}}t|d}|dkr|d d }nd}|rt d||||f | jd nO|dkr|dkrt||d  }||d |d |  }|d }nt||d dd \}}|| }|rt d!||f | jd n|dkrt d"| jd d S ||7 }q,|dkrn>|dkr dt|d#k }td$d%|  ||d |d |  }|rt d&| | jd n|dkrbdt|d#k }td'd%|  ||d |d |  \}}t|d(\} }t|d)\}!}|r`t d*|||!| f | jd n|d+krtd,||d |d+  }"|rt d-|" | jd n|dkrt||d ||}#|rt d|#| jd n|dkrt||d ||}#|rt d|#| jd nx|d.krtd,||d |d+  d }|rt d/| | jd nV|d0krt||d |dd1}#d}
|rt d2|#| jd n8|d3krt||d |dd1}#d}
|rt d2|#| jd n|d4krtd,||d |d+  d }$t||d+ ||}#|r?t d|$|#| jd |#\}}}%}&|
pL|%pL|&}
t| |$|\}'}(||'d5k O }|'|(d ||d ||d f})|rtt d2|)| jd |dkr~||)g n|d6krtd,||d |d+  d }$t||d+ ||\}*}+|rt d|$|*|+| jd |*\},}-}.}/|+\}0}1}2}3|
p|.p|/p|2p|3}
t| |$|\}'}(||'d5k O }|'|(d |,|0d |-|1d f})|rt d2|)| jd |dkr||)g n9|dkrtd||d |d  \}$}"|rt d7|$|"f | jd n|tv r"d}n|r.t d8| | jd d}|dkr>t d"| jd d S ||7 }d|  krM|k s:n |rot d9|
  ||	f | jd t|	dkrqt d:| jd d S d S d S );Nr   rS  r   r  rG   r   r  r7   r(   r  r   r$   rF  r  r'   r  z
tlist postr/   r  r  r.   r  r  r?   r  r%   r  r   r  r   rF   r  r  z**** Dud size; exiting ****rD   r  r  z   FuncID=%dr  rB  r7  r  r6   r  z   namex=%dr<   r  r   )r=  r  r   r   r8   r   z   refx=%d namex=%dr  z.End of formula. any_rel=%d any_err=%d stack=%rr  )ra  rb  rc  r   r  r  r  r  r   r  r5  r  r  r"  r  r
   r%  r(  rK  rR  rq  r7  )4rg  rH  r=  rJ  r=  ri  isnamer>  rI  r0  r/  r-  rA  rB  r  rC  rD  rE  rF  rB  rC  r  r  r  rL  rM  rN  rJ  rK  rP  rQ  rT  rV  r+  r;  rG  rh  r@  rA  r^  r_  r1  rP  rQ  r`  ra  rb  rc  rd  re  rf  rg  r(  r(  r-  r   ^  sX  




 





&
* 










  r   c                 C   sT   |d u rd}|s|rd| d  S d| d  S |r | rd|  S dS d||  d d  S )	NTzR%dr   z$%dzR[%d]r   z%dr8  r(  )rB  rowxrelr>  r	  r(  r(  r-  
rownamerel  s   r  c                 C   sP   |d u rd}|s|rd| d  S dt |  S |r | rd|  S dS t ||  d S )NTzC%dr   $zC[%d]Cr9  r   )rC  colxrelr?  r	  r(  r(  r-  
colnamerel  s   r  c                 C   s   dt || d f S )z(Utility function: ``(5, 7)`` => ``'H6'``z%s%dr   r  )rB  rC  r(  r(  r-  r     s   r   c                 C   s,   |rd| d |d f S dt || d f S )z*Utility function: ``(5, 7)`` => ``'$H$6'``zR%dC%dr   z$%s$%dr  )rB  rC  r	  r(  r(  r-  r   "  s   r   c           	      C   s`   |s
|s
t | ||S |r|d u s|r|d u rd}t||||}t| |||}|r,|| S || S )NT)r   r  r  )	rB  rC  r~  r  r>  r?  r	  crr(  r(  r-  ru  (  s   ru  c                 C   s6   d}| dkr
||  S t | d\}}||d  ||  S )z6Utility function: ``7`` => ``'H'``, ``27`` => ``'AB'``ABCDEFGHIJKLMNOPQRSTUVWXYZr?   r   r   )r(  )rC  alphabetxdiv26xmod26r(  r(  r-  r   4  s
   r   c                 C   sP   |rdS || d kr||d krt | ||S dt | ||t |d |d |f S )z( ``(5, 20, 7, 10)`` => ``'$H$6:$J$20'`` Nr   %s:%s)r   )rlorhiclochir	  r(  r(  r-  rangename2d=  s
   $r  c              
   C   st   | \}}}}|\}	}
}}|	s|
r|d u rd}|s|r |d u r d}dt |||	||||t |d |d |
||||f S )NTr  r   )ru  )rlo_rhi_clo_chirlorel_rhirel_clorel_chirelr>  r?  r	  r  r  r  r  rlorelrhirelclorelchirelr(  r(  r-  rw  E  s   rw  c                 C   s2   |j }dt| g|dd R  t|dd  f S )z
    Utility function:
    ``Ref3D(1, 4, 5, 20, 7, 10)`` =>
    ``'Sheet2:Sheet3!$H$6:$J$20'``
    (assuming Excel's default sheetnames)
    r  Nr$   r   )r1  
sheetranger  )bookrk  r1  r(  r(  r-  r   R  s
   r   c           	      C   s\   |j }|j}t| |dd |dd }t|dd |dd |||}|s(|S d||f S )z
    Utility function:
    ``Ref3D(coords=(0, 1, -32, -22, -13, 13), relflags=(0, 0, 1, 1, 1, 1))``

    In R1C1 mode => ``'Sheet1!R[-32]C[-13]:R[-23]C[12]'``

    In A1 mode => depends on base cell ``(browx, bcolx)``
    Nr$   r   r  )r1  r  sheetrangerelrw  )	r  rk  r>  r?  r	  r1  r  shdescrngdescr(  r(  r-  r   ^  s   	 r   c                 C   s`   |dkr	| | }nddddd |d| }d|v r$d|dd	 d S d
|v r.d| d S |S )Nr   z?internal; any sheet?zinternal; deleted sheetzinternal; macro sheetz<<external>>)r8   r9   r^  rX  z
?error %d?'z''r  )r  r!  )shnamesshxshnamer(  r(  r-  quotedsheetnameo  s   
r  c                 C   s8   |   }t||}||d kr|dt||d  7 }|S )Nr   r  )sheet_namesr  )r  sloshir  r  r(  r(  r-  r    s
   
r  c                 C   sR   |\}}|\}}|s|st | ||S |d  kr|d kr%n J |r%|s'J dS )Nr   r   rx   )r  )r  srange	srangerelr  r  slorelshirelr(  r(  r-  r    s   *r  )NN)r   )r   r   )NNNr   r   r   )Nr   )NNr   )ur  
__future__r   r1  operatoroprstructr   biffhr   r   r   r   r	   r
   timemachine__all__r   r   r   r   r    r!   ALL_FMLA_TYPESro  r  rt  r   r   r:   r   r   r   r   r   r   r'  sztab0sztab1sztab2sztab3sztab4r  r  r&  r"  setr7  minmaxr  r  r5  rD  rE  rK  rR  rq  rt  	Exceptionru  objectr"   r/  r#   tAddtSubtMultDivtPowertConcatrangetLTtLEtEQtGEtGTtNEr  r  r  r  r  r  r  r  r  r$  _arith_argdict_cmp_argdict_strg_argdictaddsubmultruedivr  r  r  r#  r  r  r   r   r   r  r  r   r   ru  r   r  rw  r   r   r  r  r  r(  r(  r(  r-  <module>   sf   







	
 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                 	  
                                               !  "  #  $  %  &  '  (  )  *  +  ,  -  .  /  0  1  2  3  4  5  6  7  8  9  :  ;  <  =  >  ?  @  A  B  C  D  E  F  G  H  I  J  K  L  M  N  O  P  Q  R  S  T  U  V  W  X  Y  Z  [  \  ]  ^  _  `  a  b  c  d  e  f  g  h  i  j  k  l  m  n  o  p  q  r  s  t  u  v  w  x  y  z  {  |  }  ~               
  &\A	    e     %	