U
    7hp                   @   sz  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 dd	d
dddddddddddddddddddddg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d0Zd1Z dZ!dZ"ddddd
dd	d2d3Z#d4Z$d1d!d!ddddddddddddddddddddd0d1d0d"d!d d d.d5d"d d.d"d!d6d/d/d/d d!d6d!d6d d d1d1d1d1d1d1d1d1d.d1d1d1d1d1d1d1g@Z%d1d/d/ddddddddddddddddddddd0d1d0d7d/d d d.d5d5d d.d7d!d6d6d6d6d.d!d6d!d6d.d.d1d1d1d1d1d1d1d1d.d1d1d1d1d1d1d1g@Z&d1d/d/ddddddddddddddddddddd0d1d0d7d/d d d.d5d5d.d!d7d!d6d6d6d6d.d!d6d!d6d.d.d1d1d1d1d1d1d1d1d1d1d1d1d1d1d1d1g@Z'd1d/d/ddddddddddddddddddddd0d1d0d1d1d d d.d5d5d.d!d8d!d6d6d6d6d.d!d6d!d6d.d.d1d1d1d1d1d1d1d1d1d9d:d;d:d;d1d1g@Z(d1d/d/ddddddddddddddddddddd0d0d0d1d1d d d.d5d5d.d!d/d/d5d6d6d6d.d/d5d/d5d.d.d1d1d1d1d1d1d1d1d1d6d6d7d6d7d1d1g@Z)e%e%e&e'e'e(e(e)d<Z*d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSdTdUdVdWdXdYdZd[d\d]d^d_d`dadbdcdddedfdgdhdidjdkdldmdmdmdmdmdmdmdmdndodpdqdrdsdmdmg@Z+dtdudvdwdxdydzd{d|d}d~ddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddd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'd(d)d*d+d,d-d.d/d0d1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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dvdwdxZ,dydzd{d|d}d~dddd	Z-e.d6d"dd7dddgZ/e0e1e0e1e0e1fZ2e1e0e1e0e1e0fZ3dd Z4dݐddZ5dސddZ6dߐddZ7dddZ8dddZ9dddZ:G dd de;Z<G dd de=Z>G dd de?Z@d.ZAd!ZBd/ZCdZDd6ZEd"ZFeGd5d8\ZHZIZJZKZLZMdd ZNdd ZOdd ZPdd ZQdd ZRdd ZSdd ZTdd ZUdd ZVeeNe!eWiZXeeNe!eNiZYeeVe!eNiZZeAeXeej[ddfeBeXeej\ddfeCeXeej]ddfeDeXeej^ddfeEeXeeOddfeFeZe!ej[ddfeHeYeePddfeIeYeeQddfeJeYeeRddfeKeYeeSddfeLeYeeTddfeMeYeeUddfiZ_dd dddmfdd dddmfdd ddmdfdÜZ`dZadZbd/ZcdZddddZedddZfdddZgddȐdɄZhddʐd˄Zidd ZjdddZkddΐdτZldd Zmddѐd҄ZnddӐdԄZodd Zpddd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                ?   CELLZSHAREDZARRAYzCOND-FMTzDATA-VALNAME)r   r$   r%   r&   r'   r(   )r   r$      r'      r(   #   9   :   ;   ,   -         oMSNG)r7   r6   r   r   r$   r4   r%   r5   ,	         r,            )   r?      (   r3   2   F   P   ZUnk00ZExpZTblAddSubZMulDivZPowerZConcatLTZLEZEQZGEGTZNEZIsectListRangeZUplusZUminusZPercentZParenZMissArgStrZExtendedZAttrZSheetZEndSheetZErrZBoolZIntNumZArrayZFuncZFuncVarNameZRefZAreaZMemAreaZMemErrZMemNoMemZMemFuncZRefErrZAreaErrZRefNZAreaNZMemAreaNZ	MemNoMemN ZFuncCEZNameXZRef3dZArea3dZRefErr3dZ	AreaErr3d)ZCOUNTr   rA   r%   r   VR)ZIFr$   r4   r%   r4   rQ   VRR)ZISNAr   r   r$   r   rQ   rQ   )ZISERRORr   r   r$   r   rQ   rQ   )ZSUMr   rA   r%   r   rQ   rR   )ZAVERAGEr   rA   r%   r   rQ   rR   )ZMINr   rA   r%   r   rQ   rR   )MAXr   rA   r%   r   rQ   rR   )ZROWr   r   r%   r   rQ   rR   )ZCOLUMNr   r   r%   r   rQ   rR   )ZNAr   r   r$   r   rQ   rP   )ZNPVr$   rA   r%   r$   rQ   VR)ZSTDEVr   rA   r%   r   rQ   rR   )ZDOLLARr   r$   r%   r   rQ   rQ   )ZFIXEDr$   r4   r%   r4   rQ   VVV)ZSINr   r   r$   r   rQ   rQ   )ZCOSr   r   r$   r   rQ   rQ   )ZTANr   r   r$   r   rQ   rQ   )ZATANr   r   r$   r   rQ   rQ   )ZPIr   r   r$   r   rQ   rP   )ZSQRTr   r   r$   r   rQ   rQ   )ZEXPr   r   r$   r   rQ   rQ   )LNr   r   r$   r   rQ   rQ   )ZLOG10r   r   r$   r   rQ   rQ   )ZABSr   r   r$   r   rQ   rQ   )INTr   r   r$   r   rQ   rQ   )ZSIGNr   r   r$   r   rQ   rQ   )ZROUNDr$   r$   r$   r$   rQ   VV)ZLOOKUPr$   r4   r%   r$   rQ   rU   )ZINDEXr$   r%      r%   rR   ZRVVV)ZREPTr$   r$   r$   r$   rQ   rY   )ZMIDr4   r4   r$   r4   rQ   rV   )ZLENr   r   r$   r   rQ   rQ   )ZVALUEr   r   r$   r   rQ   rQ   )TRUEr   r   r$   r   rQ   rP   )FALSEr   r   r$   r   rQ   rP   )ANDr   rA   r%   r   rQ   rR   )ORr   rA   r%   r   rQ   rR   )NOTr   r   r$   r   rQ   rQ   )ZMODr$   r$   r$   r$   rQ   rY   )ZDCOUNTr4   r4   r$   r4   rQ   RRR)ZDSUMr4   r4   r$   r4   rQ   r`   )ZDAVERAGEr4   r4   r$   r4   rQ   r`   )ZDMINr4   r4   r$   r4   rQ   r`   )ZDMAXr4   r4   r$   r4   rQ   r`   )ZDSTDEVr4   r4   r$   r4   rQ   r`   )ZVARr   rA   r%   r   rQ   rR   )ZDVARr4   r4   r$   r4   rQ   r`   )ZTEXTr$   r$   r$   r$   rQ   rY   )ZLINESTr   r%   r%   r%   ARRVV)ZTRENDr   r%   r%   r%   ra   RRRV)ZLOGESTr   r%   r%   r%   ra   rb   )ZGROWTHr   r%   r%   r%   ra   rc   )ZPVr4   r5   r%   r5   rQ   VVVVV)ZFVr4   r5   r%   r5   rQ   rd   )ZNPERr4   r5   r%   r5   rQ   rd   )ZPMTr4   r5   r%   r5   rQ   rd   )ZRATEr4      r%   re   rQ   VVVVVV)ZMIRRr4   r4   r$   r4   rQ   ZRVV)ZIRRr   r$   r%   r$   rQ   RV)ZRANDr   r   
   r   rQ   rP   )ZMATCHr$   r4   r%   r4   rQ   rS   )ZDATEr4   r4   r$   r4   rQ   rV   )ZTIMEr4   r4   r$   r4   rQ   rV   )ZDAYr   r   r$   r   rQ   rQ   )ZMONTHr   r   r$   r   rQ   rQ   )ZYEARr   r   r$   r   rQ   rQ   )ZWEEKDAYr   r$   r%   r$   rQ   rY   )ZHOURr   r   r$   r   rQ   rQ   )ZMINUTEr   r   r$   r   rQ   rQ   )ZSECONDr   r   r$   r   rQ   rQ   )ZNOWr   r   rh   r   rQ   rP   )ZAREASr   r   r$   r   rQ   rR   )ZROWSr   r   r$   r   rQ   rR   )COLUMNSr   r   r$   r   rQ   rR   )ZOFFSETr4   r5   r%   r5   rR   ZRVVVV)ZSEARCHr$   r4   r%   r4   rQ   rV   )Z	TRANSPOSEr   r   r$   r   ra   ra   )ZTYPEr   r   r$   r   rQ   rQ   )Z	SERIESSUMr%   r%   r$   r%   rQ   ZVVVA)ZATAN2r$   r$   r$   r$   rQ   rY   )ZASINr   r   r$   r   rQ   rQ   )ZACOSr   r   r$   r   rQ   rQ   )ZCHOOSEr$   rA   r%   r$   rQ   rU   )ZHLOOKUPr4   r%   r%   r%   rQ   VRRV)ZVLOOKUPr4   r%   r%   r%   rQ   rj   )ZISREFr   r   r$   r   rQ   rR   )ZLOGr   r$   r%   r$   rQ   rY   )ZCHARr   r   r$   r   rQ   rQ   )ZLOWERr   r   r$   r   rQ   rQ   )ZUPPERr   r   r$   r   rQ   rQ   )ZPROPERr   r   r$   r   rQ   rQ   )ZLEFTr   r$   r%   r$   rQ   rY   )ZRIGHTr   r$   r%   r$   rQ   rY   )ZEXACTr$   r$   r$   r$   rQ   rY   )ZTRIMr   r   r$   r   rQ   rQ   )ZREPLACEr%   r%   r$   r%   rQ   VVVV)Z
SUBSTITUTEr4   r%   r%   r%   rQ   rk   )ZCODEr   r   r$   r   rQ   rQ   )ZFINDr$   r4   r%   r4   rQ   rV   )r*   r   r$   rZ   r$   rQ   rU   )ZISERRr   r   r$   r   rQ   rQ   )ZISTEXTr   r   r$   r   rQ   rQ   )ZISNUMBERr   r   r$   r   rQ   rQ   )ZISBLANKr   r   r$   r   rQ   rQ   )Tr   r   r$   r   rQ   rR   )Nr   r   r$   r   rQ   rR   )Z	DATEVALUEr   r   r$   r   rQ   rQ   )Z	TIMEVALUEr   r   r$   r   rQ   rQ   )ZSLNr4   r4   r$   r4   rQ   rV   )ZSYDr%   r%   r$   r%   rQ   rk   )ZDDBr%   r5   r%   r5   rQ   rd   )ZINDIRECTr   r$   rZ   r$   rR   rY   )ZCLEANr   r   r$   r   rQ   rQ   )ZMDETERMr   r   r$   r   rQ   ra   )ZMINVERSEr   r   r$   r   ra   ra   )ZMMULTr$   r$   r$   r$   ra   AA)ZIPMTr%   re   r%   re   rQ   rf   )ZPPMTr%   re   r%   re   rQ   rf   )ZCOUNTAr   rA   r%   r   rQ   rR   )ZPRODUCTr   rA   r%   r   rQ   rR   )ZFACTr   r   r$   r   rQ   rQ   )ZDPRODUCTr4   r4   r$   r4   rQ   r`   )Z	ISNONTEXTr   r   r$   r   rQ   rQ   )ZSTDEVPr   rA   r%   r   rQ   rR   )ZVARPr   rA   r%   r   rQ   rR   )ZDSTDEVPr4   r4   r$   r4   rQ   r`   )ZDVARPr4   r4   r$   r4   rQ   r`   )ZTRUNCr   r$   r%   r$   rQ   rY   )Z	ISLOGICALr   r   r$   r   rQ   rQ   )ZDCOUNTAr4   r4   r$   r4   rQ   r`   )ZUSDOLLARr   r$   r%   r$   rQ   rY   )ZFINDBr$   r4   r%   r4   rQ   rV   )ZSEARCHBr$   r4   r%   r4   rQ   rV   )ZREPLACEBr%   r%   r$   r%   rQ   rk   )ZLEFTBr   r$   r%   r$   rQ   rY   )ZRIGHTBr   r$   r%   r$   rQ   rY   )ZMIDBr4   r4   r$   r4   rQ   rV   )ZLENBr   r   r$   r   rQ   rQ   )ZROUNDUPr$   r$   r$   r$   rQ   rY   )Z	ROUNDDOWNr$   r$   r$   r$   rQ   rY   )ZASCr   r   r$   r   rQ   rQ   )ZDBCSr   r   r$   r   rQ   rQ   )ZRANKr$   r4   r%   r4   rQ   ZVRV)ZADDRESSr$   r5   r%   r5   rQ   rd   )ZDAYS360r$   r4   r%   r4   rQ   rV   )ZTODAYr   r   rh   r   rQ   rP   )ZVDBr5   r;   r%   r;   rQ   ZVVVVVVV)ZMEDIANr   rA   r%   r   rQ   rR   )Z
SUMPRODUCTr   rA   r%   r   rQ   ra   )ZSINHr   r   r$   r   rQ   rQ   )ZCOSHr   r   r$   r   rQ   rQ   )ZTANHr   r   r$   r   rQ   rQ   )ZASINHr   r   r$   r   rQ   rQ   )ZACOSHr   r   r$   r   rQ   rQ   )ZATANHr   r   r$   r   rQ   rQ   )ZDGETr4   r4   r$   r4   rQ   r`   )INFOr   r   r$   r   rQ   rQ   )ZDBr%   r5   r%   r5   rQ   rd   )Z	FREQUENCYr$   r$   r$   r$   ra   ZRR)z
ERROR.TYPEr   r   r$   r   rQ   rQ   )ZAVEDEVr   rA   r%   r   rQ   rR   )ZBETADISTr4   r5   r%   r   rQ   rQ   )ZGAMMALNr   r   r$   r   rQ   rQ   )ZBETAINVr4   r5   r%   r   rQ   rQ   )Z	BINOMDISTr%   r%   r$   r%   rQ   rk   )ZCHIDISTr$   r$   r$   r$   rQ   rY   )ZCHIINVr$   r$   r$   r$   rQ   rY   )ZCOMBINr$   r$   r$   r$   rQ   rY   )Z
CONFIDENCEr4   r4   r$   r4   rQ   rV   )Z	CRITBINOMr4   r4   r$   r4   rQ   rV   )ZEVENr   r   r$   r   rQ   rQ   )Z	EXPONDISTr4   r4   r$   r4   rQ   rV   )ZFDISTr4   r4   r$   r4   rQ   rV   )ZFINVr4   r4   r$   r4   rQ   rV   )ZFISHERr   r   r$   r   rQ   rQ   )Z	FISHERINVr   r   r$   r   rQ   rQ   )ZFLOORr$   r$   r$   r$   rQ   rY   )Z	GAMMADISTr%   r%   r$   r%   rQ   rk   )ZGAMMAINVr4   r4   r$   r4   rQ   rV   )ZCEILINGr$   r$   r$   r$   rQ   rY   )ZHYPGEOMDISTr%   r%   r$   r%   rQ   rk   )ZLOGNORMDISTr4   r4   r$   r4   rQ   rV   )ZLOGINVr4   r4   r$   r4   rQ   rV   )ZNEGBINOMDISTr4   r4   r$   r4   rQ   rV   )ZNORMDISTr%   r%   r$   r%   rQ   rk   )Z	NORMSDISTr   r   r$   r   rQ   rQ   )ZNORMINVr4   r4   r$   r4   rQ   rV   )ZNORMSINVr   r   r$   r   rQ   rQ   )ZSTANDARDIZEr4   r4   r$   r4   rQ   rV   )ZODDr   r   r$   r   rQ   rQ   )ZPERMUTr$   r$   r$   r$   rQ   rY   )ZPOISSONr4   r4   r$   r4   rQ   rV   )ZTDISTr4   r4   r$   r4   rQ   rV   )ZWEIBULLr%   r%   r$   r%   rQ   rk   )ZSUMXMY2r$   r$   r$   r$   rQ   rn   )ZSUMX2MY2r$   r$   r$   r$   rQ   rn   )ZSUMX2PY2r$   r$   r$   r$   rQ   rn   )ZCHITESTr$   r$   r$   r$   rQ   rn   )ZCORRELr$   r$   r$   r$   rQ   rn   )ZCOVARr$   r$   r$   r$   rQ   rn   )ZFORECASTr4   r4   r$   r4   rQ   ZVAA)ZFTESTr$   r$   r$   r$   rQ   rn   )Z	INTERCEPTr$   r$   r$   r$   rQ   rn   )ZPEARSONr$   r$   r$   r$   rQ   rn   )ZRSQr$   r$   r$   r$   rQ   rn   )ZSTEYXr$   r$   r$   r$   rQ   rn   )ZSLOPEr$   r$   r$   r$   rQ   rn   )ZTTESTr%   r%   r$   r%   rQ   ZAAVV)ZPROBr4   r%   r%   r4   rQ   ZAAV)ZDEVSQr   rA   r%   r   rQ   rR   )ZGEOMEANr   rA   r%   r   rQ   rR   )ZHARMEANr   rA   r%   r   rQ   rR   )ZSUMSQr   rA   r%   r   rQ   rR   )ZKURTr   rA   r%   r   rQ   rR   )ZSKEWr   rA   r%   r   rQ   rR   )ZZTESTr$   r4   r%   r$   rQ   rg   )ZLARGEr$   r$   r$   r$   rQ   rg   )ZSMALLr$   r$   r$   r$   rQ   rg   )ZQUARTILEr$   r$   r$   r$   rQ   rg   )Z
PERCENTILEr$   r$   r$   r$   rQ   rg   )ZPERCENTRANKr$   r4   r%   r$   rQ   rg   )ZMODEr   rA   r%   r   rQ   ra   )ZTRIMMEANr$   r$   r$   r$   rQ   rg   )ZTINVr$   r$   r$   r$   rQ   rY   )ZCONCATENATEr   rA   r%   r   rQ   rQ   )ZPOWERr$   r$   r$   r$   rQ   rY   )ZRADIANSr   r   r$   r   rQ   rQ   )ZDEGREESr   r   r$   r   rQ   rQ   )ZSUBTOTALr$   rA   r%   r$   rQ   rU   )ZSUMIFr$   r4   r%   r4   rQ   ZRVR)ZCOUNTIFr$   r$   r$   r$   rQ   rg   )Z
COUNTBLANKr   r   r$   r   rQ   rR   )ZISPMTr%   r%   r$   r%   rQ   rk   )ZDATEDIFr4   r4   r$   r4   rQ   rV   )Z
DATESTRINGr   r   r$   r   rQ   rQ   )ZNUMBERSTRINGr$   r$   r$   r$   rQ   rY   )ZROMANr   r$   r%   r$   rQ   rY   )ZGETPIVOTDATAr$   r$   r$   r$   rQ   rg   )Z	HYPERLINKr   r$   r%   r$   rQ   rY   )ZPHONETICr   r   r$   r   rQ   rQ   )ZAVERAGEAr   rA   r%   r   rQ   rR   )ZMAXAr   rA   r%   r   rQ   rR   )ZMINAr   rA   r%   r   rQ   rR   )ZSTDEVPAr   rA   r%   r   rQ   rR   )ZVARPAr   rA   r%   r   rQ   rR   )ZSTDEVAr   rA   r%   r   rQ   rR   )ZVARAr   rA   r%   r   rQ   rR   )ZBAHTTEXTr   r   r$   r   rQ   rQ   )ZTHAIDAYOFWEEKr   r   r$   r   rQ   rQ   )Z	THAIDIGITr   r   r$   r   rQ   rQ   )ZTHAIMONTHOFYEARr   r   r$   r   rQ   rQ   )ZTHAINUMSOUNDr   r   r$   r   rQ   rQ   )ZTHAINUMSTRINGr   r   r$   r   rQ   rQ   )ZTHAISTRINGLENGTHr   r   r$   r   rQ   rQ   )ZISTHAIDIGITr   r   r$   r   rQ   rQ   )ZROUNDBAHTDOWNr   r   r$   r   rQ   rQ   )ZROUNDBAHTUPr   r   r$   r   rQ   rQ   )ZTHAIYEARr   r   r$   r   rQ   rQ   )ZRTDr$   r5   r%   r   rQ   rQ   (  r   r   r$   r4   r%   r5   re   r;   r&   r:   rh   r<   rZ         r,   r'   r-   r>      r@   r?            r=               rA      r(   !   "   r.   $   %   &   '   rB   )   *   +   r2   r3   .   /   0   1   rC   3   4   8   r/   r0   r1   <   =   >   r)   @   A   B   C   D   E   rD   G   H   I   J   K   L   M   N   R   S   V   \   a   b   c   d   e   f   i   m   o   p   q   r   s   t   u   v   w   x   y   |   }   ~                                                                                                                                                                                 i  i  i  i  i  i  i  i  i  i  i  i  i  i  i  i  i  i  i  i  i   i!  i"  i#  i$  i%  i&  i'  i(  i)  i*  i+  i,  i-  i.  i/  i0  i1  i2  i3  i4  i5  i6  i7  i8  i9  i:  i;  i<  i=  i>  i?  i@  iA  iB  iC  iD  iE  iF  iG  iH  iI  iJ  iK  iL  iP  iQ  iV  iW  iX  iY  iZ  i[  i^  i_  i`  ia  ib  if  ig  ih  ii  ij  ik  il  im  in  io  ip  iq  ir  is  it  iu  iv  iw  ix  iy  iz  i{  zSkip??ZVolatileIfZChooseZSkipZSumAssignZSpaceZSpaceVolatile)	r   r   r$   r%   r&   r'   r(   r   r   rh   rx   ry   r   c                 C   s   t dd t| |j|jD S )Nc                 s   s   | ]\}}}|||V  qd S N ).0funcZnumaZnumbr   r   F/var/www/formularioweb/env/lib/python3.8/site-packages/xlrd/formula.py	<genexpr>  s   zdo_box_funcs.<locals>.<genexpr>)tuplezipcoords)Z	box_funcsZboxaZboxbr   r   r   do_box_funcs  s    r   c           	      C   sv   |d? d@ }|d? d@ }| }|d@ }|rR|r<|dkr<|d8 }|rj|dkrj|d8 }n|r^||8 }|rj||8 }||||fS )	Nr,   r   rq            r      r   	rowvalcolvalreldeltabrowxbcolxrow_relcol_relrowxcolxr   r   r   adjust_cell_addr_biff8  s    
r
  c           	      C   sv   | d? d@ }| d? d@ }| d@ }|}|rR|r<|dkr<|d8 }|rj|dkrj|d8 }n|r^||8 }|rj||8 }||||fS )	Nr,   r   rq   i?  i    i @  r   r   r   r   r   r   r   adjust_cell_addr_biff_le7  s    
r  c                 C   s`   |dkr2t d| ||d  \}}t|||||S t d| ||d  \}}t|||||S d S )NrE   <HHr%   z<HBr4   r   r
  r  )dataposbvr  r  r  r  r  r   r   r   get_cell_addr  s        r  c                 C   s   |dkrNt d| ||d  \}}}}	t|||||}
t||	|||}|
|fS t d| ||d  \}}}}	t|||||}
t||	|||}|
|fS d S )NrE   z<HHHHr&   z<HHBBre   r  )r  r  r  r  r  r  Zrow1valZrow2valZcol1valZcol2valres1res2r   r   r   get_cell_range_addr  s*            r  c           
      C   s  z| j | }W n2 tk
r@   td|t| j f | jd Y dS X |\}}}|| jkr|rptd||f | jd |d  kr|ksn tdS || jkr|rtd||f | jd dS |d  kr|krn n|rtd	||f | jd d
S |d  kr|kr&n n|r"td|f | jd dS t| j}d|  krT|  krT|k sn |rtd||f | jd td| | jd dS | j| }| j| }	d|  kr|	ksn dS ||	fS )Nz:!!! get_externsheet_local_range: refx=%d, not in range(%d)file)r  z5/// get_externsheet_local_range(refx=%d) -> addins %ri  )r  z7/// get_externsheet_local_range(refx=%d) -> external %rr  z@/// get_externsheet_local_range(refx=%d) -> unspecified sheet %rr6   r6   i  z</// get_externsheet_local_range(refx=%d) -> deleted sheet(s)r7   r7   r   z./// get_externsheet_local_range(refx=%d) -> %r%--- first/last sheet not in range(%d))r  r   )	Z_externsheet_info
IndexErrorprintlenlogfileZ_supbook_addins_inxAssertionErrorZ_supbook_locals_inx_all_sheets_map)
bkrefxblahinfoZref_recordxref_first_sheetxref_last_sheetxnsheetsxlrd_sheetx1xlrd_sheetx2r   r   r   get_externsheet_local_range  sL    



&

r0  c                 C   s   |dkr"|rt d| | jd dS |dkr6|dkr6d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sn d
S ||fS )Nr   z?/// get_externsheet_local_range_b57(raw_extshtx=%d) -> externalr  r  r6   r  z6/// get_externsheet_local_range_b57(%d, %d, %d) -> ???r  )r1  r  )r"  r$  r#  r&  )r'  raw_extshtxr+  r,  r)  r-  r.  r/  r   r   r   get_externsheet_local_range_b57  s*    
 

r3  c                   @   s   e Zd ZdS )FormulaErrorN)__name__
__module____qualname__r   r   r   r   r4    s   r4  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 k	r|| _ |d k	r|| _|| _|| _d S r   )kindvalueranktext)selfZakindZavalueZarankZ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   getr9  r:  r<  )r=  Z	kind_textr   r   r   __repr__l  s    zOperand.__repr__)NNr   r8  )
r5  r6  r7  __doc__r:  r   r9  r<  r>  r@  r   r   r   r   r"     s   @

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   re   rZ   r   r   r   r   r   r   )r   relflagsZshtxloZshtxhiZrowxloZrowxhiZcolxloZcolxhi)r=  Zatupler   r   r   r>    s    
  zRef3D.__init__c                 C   s0   | j r| j dkrd| jf S d| j| j f S d S )NrB  zRef3D(coords=%r)zRef3D(coords=%r, relflags=%r))rC  r   )r=  r   r   r   r@    s
    
zRef3D.__repr__N)r5  r6  r7  rA  r>  r@  r   r   r   r   r#   r  s   0	re   c                 C   s   | S r   r   xr   r   r   nop  s    rF  c                 C   s   | | S r   r   rE  yr   r   r   _opr_pow      rI  c                 C   s   | |k S r   r   rG  r   r   r   _opr_lt  rJ  rK  c                 C   s   | |kS r   r   rG  r   r   r   _opr_le  rJ  rL  c                 C   s   | |kS r   r   rG  r   r   r   _opr_eq  rJ  rM  c                 C   s   | |kS r   r   rG  r   r   r   _opr_ge  rJ  rN  c                 C   s   | |kS r   r   rG  r   r   r   _opr_gt  rJ  rO  c                 C   s   | |kS r   r   rG  r   r   r   _opr_ne  rJ  rP  c                 C   s"   t | }|dr|dd }|S )zN
    Attempt to emulate Excel's default conversion from number to string.
    z.0Nr7   )strendswith)numsr   r   r   num2strg  s    
rU  rA   +-rB   r   /rC   ^r@   &<z<==z>=>z<>c                 C   s   |  S r   r   rD  r   r   r   <lambda>  rJ  r^  rD   c                 C   s   | S r   r   rD  r   r   r   r^    rJ  c                 C   s   | d S )Ng      Y@r   rD  r   r   r   r^    rJ  r   %)rr   r>   r@   Z   c           W      C   s  |t krd}|j}|j}| j}d}|rXtd||j||||f | jd t|d|| jd |tkrht	dt
| }	d}
g }d}d}d}ttd }ttd }|j}dd }d	d
 }dd }|dkr|g}d|
  kr|k rhn nt||
 }|d@ }|d@ d? }|r|d }n|}t| }|	| }|rXtd|
|||||f | jd td|| jd |dkrxd|||f }t||
sd|  krdkrn n||| 	nd|  krdkrn n||| n|dkr|rtd|| jd t|dkst| }| }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|!_nT|jtks|jtkrn8|jt  kr|jkrBn nf|jd k	r|jd k	rt|jdkstt|jdksttt|jd |jd }"t|"g|!_n|jt  kr^|jkrn nt|!_|jd k	r|jd k	rt|jdkstt|jdksttt|jd |jd }"|jd j}#|jd j}$|#|$krt|"|# g|!_n ||! |
rtd|| jd n|d kr|r6td!|| jd t|dksHt| }| }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tfkrv|jttfkrvt|!_|jtks |jtkr&t|!_|jd k	rv|jd k	rvt|jdksRtt|jdksft|j|j |!_n ||! |
rtd#|| jd n|d$kr|rtd%|| jd t|dkst| }| }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rdt}!n8|jt  kr|jkrn nf|jd k	r|jd k	rt|jdkstt|jdksttt |jd |jd }"t|"g|!_n|jt  kr|jkrn nt|!_|jd k	r|jd k	rt|jdks<tt|jdksPttt |jd |jd }"|jd j}#|jd j}$|#|$krt|"|# g|!_n ||! |
rtd'|| jd nd(|  krd)krn n||t!| n|d*krn|d+kr|tt"d t#d n|d,kr|d-krHt$||
d | j%dd.\}%}&nt&||
d dd.\}%}&|&|
 }|rtd/||%f | jd d0|%'d0d1 d0 }'|tt(|%t#|' n|d2kr|dksttd3n|d4k	rt)d5||
d |
d6  \}(})t*+|(d7}*|(d6k	r|)d d8 }n`|(d k	rxd6}|	r@td9|| jd t|dk	sRt|d: }d;|j } tt!d t,| |d:< nd6}|
rtd<|(|*||)f | jd nd=|  k	rd>k	rn n|d?k 	sttd@ndA|  k	rdk
rn n|dA }+ddddBg|+ },tt-t!t!g|+ }-t)dCdD|+  ||
d |
d |,  \}.|+dk
r\t.|.}.t/|.}'n8|+dk
rpt/|.}'n$|+dk
rdE|. }'nd0t0|.  d0 }'|t|-|.t#|' ntdF| |dk
rtdG| |
|7 }
q|dk
r|| nb|dkrdt1|dHk },t)dCdI|,  ||
d |
d |,  d }/t2+|/d }0|0s\tdJ|/ | jd || n|0d d \}1}2|rtdK|/|1|2f | jd t||2kst|2rt3dLdM ||2 d  D }3dN|1|3f } ||2 d = n|1dO } ttd t,| }!||! nP|dkrdt1|dHk },t)dPdI|,  ||
d |
d |,  \}2}/t4|2dQ\}4}2t4|/dR\}5}/|r|tdS|/|2|5|4f | jd t2+|/d }0|0stdT|/ | jd || qL|0d d \}1}6}7|rtdU|1|6|7f | jd |6|2  kr|7ksn tt||2kstt||2kstt3dVdM ||2 d  D }3dN|1|3f } ttd t,| }!|/dkrL||2  }8|8jt!t-fkr|rJ|8jtkrJtdW| jd n|8jdXkr|rJ|8jd k	rJtdY| jd n|2dkr|8jst-d |!_|!_nJ|2 d t1|8j }9||9 }:|:jt"kr$t!d |!_|!_n|:j|:j |!_|!_|rtdZ| jd n|/d[kr||2  }8|8jt!krd|8j  kr|2k rn nB||2 t1|8j  }:|:jt"krt!d |!_|!_n|:j|:j |!_|!_||2 d = ||! 	nh|dkr2t)d\||
d |
d  d d };|r(td]|; | jd | j5|; }<|<j6sNt7| |<|;||d  |<j8sf|<j9sf|<j:r|r~|<j;| jd^d_d` ttd }!|p|<j8p|<j9p|<j:}|p|<j<}n$t|<j=dkstt>?|<j=d }!t#|!_|<j@d:kr|<j|!_nda| jA|<j@ |<jf |!_|r&tdbtB|!j| jd ||! n|d6krtC||
d ||}!|rdtdc|!| jd |!\}=}>}?}@d }A}Bd}|A|Bd |=|=d |>|>d f}"|rtdd|"| jd ttd }!|dkrdd|?|?|@|@f}Cttt|"|C g}!||! nZ|dkrtD||
d ||\}D}E|r*t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}!||! n|d8kr||| np|dekr t)d\||
d |
d  d },|rLtdf|, | jd n,|dgkr8||| n|dhkrP||| n|d=kr|dkrtC||
d ||}!t)d\||
d |
d  d }NtE| |N|\}A}Bn`tC||
d ||}!t)di||
d |
d  \}O}P}Q|rtdj|O|P|Q| jd tF| |O|P|Q|\}A}B|!\}=}>}?}@|?p|@}R|p$|R}|A|Bd |=|=d |>|>d f}"||Ad:k O }|rdtdd|"| jd ttd }!|Rrdd|?|?|@|@f}Ct|"|C }St|!_tG| |Sddk|!_nt|"}St|!_tH| |S|!_t#|!_|dkr|Sg|!_||! nf|d>kr|dkr@tD||
d ||\}D}Et)d\||
d |
d  d }NtE| |N|\}A}BndtD||
d ||\}D}Et)di||
d |
d  \}O}P}Q|rtdl|O|P|Q| jd tF| |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|p|R}|A|Bd |F|Jd |G|Kd f}"|rtdd|"| jd ttd }!|Rr^dd|H|L|I|Mf}Ct|"|C }St|!_tG| |Sddk|!_nt|"}St|!_tH| |S|!_t#|!_|dkr|Sg|!_||! n|d4krd}Tttd }!|dkrt)dm||
d |
d  \}N};|;d8 };|N}UnXt)dn||
d |
dh  \}N};|;d8 };|N}U|Ndkr(|Nd8 }Nn|Ndk r>|N d }Nnd}T|rbtdo|U|N|;|Tf | jd |;|kr|rtdp| jd d }T}|Ts|dkrtE| |N|\}A}Bn:|Udkrdq\}A}Bn&| jI|N }V|Vd6krdr\}A}Bnds\}A}B|Ts|Ad:k rdt|;|Uf } ttd t#| }!n| j5|; }<|<j6s6t7| |<|;||d  |<j8sN|<j9sN|<j:r|rf|<j;| jdudvd` ttd }!|p|<j8p|<j9p|<j:}|p|<j<}n$t|<j=dkstt>?|<j=d }!t#|!_|<j@d:kr|<j|!_nda| jA|<j@ |<jf |!_|rtdwtB|!j| jd ||! n4|tJkr0d}|| n|rHtdx| | jd d}|dkr^tdy|
|7 }
q|  }|rtK| jdz||  || t|dkrtd{| jd t| jd ||_=t|dkrd |_Ln
|d |_L||_<||_:||_Md|_6d S )|Nr   z1::: evaluate_name_formula %r %r %d %d %r level=%dr  r   Zfoutz-Excessive indirect references in NAME formulac                 S   s:  t |dkst| }| }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	k
r   |
|
 Y d S X |jd ks|jd kr|
|
 d S ||j}||j}|||}|tkr&|r"dnd}||
_|
|
 d S )Nr$   rP   ()r   r   )r#  r%  popbinop_rulesjoinr;  r<  r"   r9  KeyErrorappendr:  r   )opcdstkbopaopargdictresult_kindr   r;  symotextresopZbconvZaconvZbvalZavalresultr   r   r   do_binop  s<    	






z'evaluate_name_formula.<locals>.do_binopc           
   	   S   s   t |dkst| }|j}t|  \}}}}d|dd |j|k  |jdd |j|k  |g}	|d k	rp||}|t	||||	 d S Nr   rP   rb  rc  )
r#  r%  rd  r:  
unop_rulesrf  r;  r<  rh  r"   )
opcodern  rj  rl  valr   r;  sym1sym2rp  r   r   r   
do_unaryop'  s    z)evaluate_name_formula.<locals>.do_unaryopc                 S   s   d| |f }t |d S )Nz1ERROR *** Token 0x%02x (%s) found in NAME formula)r4  Zop_argZ	oname_argmsgr   r   r   not_in_name_formula7  s    z2evaluate_name_formula.<locals>.not_in_name_formularz   `   r5   r(   9Pos:%d Op:0x%02x Name:t%s Sz:%d opcode:%02xh optype:%02xhStack =r7   9ERROR *** Unexpected token 0x%02x ("%s"); biff_version=%dr$   r4   rq   r,   
tIsect pre rE   rP   rb  rc  tIsect postr'   	tList prer9   
tList postr-   
tRange pre:tRange postr>   r@   r?   rs   rt   rD   Zlenlen   sz=%d strg=%r"""ru   tExtended token not implementedr=   <BHr%   ??Unknown??re   tAttrSumr6   SUM(%s))   subop=%02xh subname=t%s sz=%d nc=%02xhrv   rw   rC   )tSheet & tEndsheet tokens not implementedrx   r&   r[  BBHdr\   r[   Unhandled opcode: 0x%02xSize not set for opcode 0x%02xrB    BH#*** formula/tFunc unknown FuncID:%d    FuncID=%d name=%s nargs=%dc                 s   s   | ]}|j V  qd S r   r<  r   argr   r   r   r   $  s     z(evaluate_name_formula.<locals>.<genexpr>%s(%s)()<Br   r   (   FuncID=%d nargs=%d macro=%d prompt=%d&*** formula/tFuncVar unknown FuncID:%d!    name: %r, min~max args: %d~%dc                 s   s   | ]}|j V  qd S r   r  r  r   r   r   r   @  s     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 formularZ   rp   <hxxxxxxxxhhtRef3d)r1c1tArea3dr  <hxxxxxxxxH+   origrefx=%d refx=%d tgtnamex=%d dodgy=%dz!!!! Self-referential !!!!r  r  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)NSTACK_ALARM_LEVELZraw_formulaZbasic_formula_lenbiff_versionr"  namer$  r   STACK_PANIC_LEVELr   szdictr"   r   r   rh  	BYTES_ORDonamesr4  r#  r%  rd  rf  r;  r<  r   r9  r:  r   tIsectFuncsr#   r   rC  tRangeFuncsr   r8   	LEAF_RANKr	   encodingr
   replacer   r   
tAttrNamesr?  	FUNC_RANKr   floatrQ  r   int	func_defslistsepdivmodname_obj_listZ	evaluatedr   macrobinaryany_errdumpany_relstackcopydeepcopyscope_sheet_namesreprr  r  r0  r3  r   r   _externsheet_type_b57error_opcodesZfprintfrr  any_external)Wr'  Znobjnamexr)  levelr  fmlalenr  r  sztabr  r  r  r  r  unk_opnd
error_opndspushrs  rz  r}  oprv  optypeopxonameszr|  rk  rl  ro  r;  rp  resr   ZrelfaZrelfbstrgnewposr<  subopncsubnameinxnbr9  r:  funcx
func_attrs	func_namenargsargtextpromptr  minargsmaxargsZtestargZresposZchosentgtnamextgtobjr  r	  r  r  shx1shx2rC  r  r  rowx1colx1row_rel1col_rel1rowx2colx2row_rel2col_rel2r(  r2  raw_shx1raw_shx2is_relref3ddodgyorigrefxextyr   r   r   r     sx   

 


 	
      
 
 	  
 	      
 



     
 



 



(








*

*





" 



  


  



 



     

 



     
 









 













   
c	           X         s0  |t krd}ttttfk}	|}
 j}|r\td||||	|
|f  jd t|
d| jd |t	krlt
dt| }d}g }d}d}ttd }ttd }|j}dd }d	d
 } fdd}|dkr|g}d|  kr|k rn nt|
| }|d@ }|d@ d? }|r|d }n|}t| }|| }|r^td||||||f  jd td| jd |dkr~d|||f }t|t|d@ r||| |s|dkr"|dkrd}nd}|dkr||kr|rtt||
\}} d|| f }!|ttd t|! ttB @ s||| nd|  kr:dkrLn n||| n|dkr|rltd| jd t|dks~t| }"| }#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rt|'_nd|"jtks||#jtkr2nJ|"jt  krN|#jkrTn nn(|"jt   krp|#jkr|n nt |'_n ||' |rtd#| jd n8|d$kr|rtd%| jd t|dkst| }"| }#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sb|#jtkrjt|'_nF|"jtt fkr|#jtt fkrt|'_|#jt ks|"jt krt |'_n ||' |rtd'| jd n|d(kr|rtd)| jd t|dkst| }"| }#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 nd,|  krd-krn n||t!| n|d.krn|d/kr:|tt"d td  n|d0kr|d1krjt#|
|d  j$dd2\}(})nt%|
|d dd2\}(})|)| }|rtd3||(f  jd d4|(&d4d5 d4 }!|tt'd t|! n|d6kr|dksttd7n|d8krtd9|
|d |d:  \}*}+t()|*d;},|*d:kr>|+d d< }n`|*d$krd:}|rbtd=| jd t|dkstt|d> }#d?|#j }&tt!d t*|&|d>< nd:}|rtd@|*|,||+f  jd ndA|  krdBkrn n|dCk sttdDndE|  krdkrn n|dE }-ddddFg|- }.tt+t!t!g|- }/tdGdH|-  |
|d |d |.  \}0|-dkr~t,|0}0t-|0}!n8|-dkrt-|0}!n$|-dkrdI|0 }!nd4t.|0  d4 }!|t|/d t|! ntdJ| |dkrtdK| ||7 }q|dk	r|| n|dk
rdt/|dLk }.tdGdM|.  |
|d |d |.  d }1t0)|1d }2|2	s~tdN|1  jd || n|2d d \}3}4|	rtdO|1|3|4f  jd t||4k	st|4	rt1dPdQ ||4 d  D }5dR|3|5f }&||4 d = n|3dS }&ttd t*|&}'||' 
n|dkrdt/|dLk }.tdTdM|.  |
|d |d |.  \}4}1t2|4dU\}6}4t2|1dV\}7}1|
rtdW|1|4|7|6f  jd |1dXk
rdY}2nt0)|1d }2|2
stdZ|1  jd || n|2d d \}3}8}9|rtd[|3|8|9f  jd |8|4  kr$|9ks*n tt||4ks<tt||4ksNtt1d\dQ ||4 d  D }5dR|3|5f }&ttd t*|&}'||4 d = ||' 	n |dkrJtd]|
|d |d  d d }:|rtd^|:  jd  j3|: };|;j4d>kr |;j5}&nd_ j6|;j4 |;j5f }&|r0td`t7|& jd ttd t|&}'||' nT|d:krt8|
|d ||	||}'|rtda|' jd |'\}} }<}=|<p|=}>|>rt }?nt}?t9|| |<|=|||}&t|?d t|&}'||' n|dkrt:|
|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rXt }?nt}?|rttdb|J|K jd t<|J|K|||}&t|?d t|&}'||' n |d<krt=|| n|dckrtd]|
|d |d  d }.|rtdd|.  jd n|dekrt8|
|d ||	||}'d}|r4tdb|' jd |'\}} }<}=|<pH|=}>|>rVt }?nt}?t9|| |<|=|||}&t|?d t|&}'||' n|dfkrRt:|
|d ||	||\}@}A|rt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}?|r(tdb|J|K jd t<|J|K|||}&t|?d t|&}'||' nL|dAkr|dkrt8|
|d ||	||}'td]|
|d |d  d }Lt> |L|\}M}Nndt8|
|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 }|rntdb|J jd ttd }'|>rdd|<|<|=|=f}Kt@|J|K }Rt |'_tA |R||||'_nt@|J}Rt|'_tB |R|'_t|'_d |'_C||' n|dBkr|dkr@t:|
|d ||	\}@}Atd]|
|d |d  d }Lt> |L|\}M}Nndt:|
|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 |'_tA |R||||'_nt@|J}Rt|'_tB |R|'_t|'_||' n|d8krjd}Sttd }'|dkrtdj|
|d |d  \}L}:|:d8 }:|L}TnXtdk|
|d |df  \}L}:|:d8 }:|L}T|Ldkr|Ld8 }Ln|Ldk r.|L d }Lnd}S|rRtdl|T|L|:|Sf  jd |Ss|dkrtt> |L|\}M}Nn:|Tdkrdm\}M}Nn& jD|L }U|Ud:krdn\}M}Nndo\}M}Nt}?d }V|Mdpkrt'}? jE|: }Vd4|V&d4d5 d4 }&nn|Ss|Md>k rdq|:|Tf }&nP j3|: };|;j4d>kr |;j5}&nd_ j6|;j4 |;j5f }&|rRtdrt7|'j jd t|?|Vt|&}'||' n4|tFkrd}|| n|rtds|  jd d}|dkrtdt||7 }q|  }|rtdu||  ||f  jd t|dkrtdv jd t jd t|dkr"d }Wn
|d j}W|WS )wNr   zR::: decompile_formula len=%d fmlatype=%r browx=%r bcolx=%r reldelta=%d %r level=%dr  r   ra  z(Excessive indirect references in formulac                 S   s   t |dkst| }| }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$   rP   rb  rc  )	r#  r%  rd  re  rf  r;  r<  r"   rh  )ri  rj  rk  rl  rm  rn  r   r;  ro  rp  rq  r   r   r   rs  g  s    	z#decompile_formula.<locals>.do_binopc           	   	   S   sr   t |dkst| }t|  \}}}}d|dd |j|k  |jdd |j|k  |g}|t|d || d S rt  )	r#  r%  rd  ru  rf  r;  r<  rh  r"   )	rv  rn  rj  rl  r   r;  rx  ry  rp  r   r   r   rz  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 %sr  )FMLA_TYPEDESCR_MAPr"  r$  r{  r'  fmlatyper   r   unexpected_opcode  s    z,decompile_formula.<locals>.unexpected_opcoderz   r~  r5   r(   z;Pos:%d Op:0x%02x opname:t%s Sz:%d opcode:%02xh optype:%02xhr  r7   r  rA   z<x2Hz<xHBzSHARED FMLA at rowx=%d colx=%dr4   rq   r,   r  r$   r  rE   rP   rb  rc  r  r'   r  r9   r  r-   r  r  r  r>   r@   r?   rs   rt   rD   r  r  r  r  ru   r  r=   r  r%   r  re   r  r6   r  r  rv   rw   rC   r  rx   r&   r[  r  r  r  r  rB   r  r  r  c                 s   s   | ]}|j V  qd S r   r  r  r   r   r   r   [  s     z$decompile_formula.<locals>.<genexpr>r  r  r  r   r   r  r   )Z
CALL_ADDINr   rA   r  r  c                 s   s   | ]}|j V  qd S r   r  r  r   r   r   r   {  s     r  r  r  r  r  r  r:   r  rZ   rp   r  r  r  r  r  r  r  r  r  r  r  r  r  r  z7End of formula. level=%d any_rel=%d any_err=%d stack=%rr  )Gr  r   r!   r   r    r  r"  r$  r   r  r   r  r"   r   r   rh  r  r  r4  _TOKEN_NOT_ALLOWEDr%  r   r  r   r   r#  rd  rf  r;  r<  r   r9  r   r   r8   r	   r  r
   r  r   r  r?  r  r   r  rQ  r   r  r  r  r  r  r  r  r  r  r  cellnamerelr  sumrangename2drelr}  r0  r3  r#   r   r   r:  r  Zaddin_func_namesr  )Xr'  Zfmlar  r  r  r  r)  r  r  r  r  r  r  r  r  r  r  r  r  r  rs  rz  r  r  rv  r  r  r  r  r|  fmtr  r	  r<  rk  rl  ro  r;  rp  r  r  r  r  r  r  r  r  r9  r:  r  r  r  r  r  r  r  r  r  r  r  r  r  r  Zokindr  r  r  r  r  r   r  r  r  r  r   rC  r(  r  r  r2  r  r  r  r	  r
  r  Zovaluerr  r   r  r   r   P  s   







 	   
 	  
 	  



     
 



 



(








*

*



" 

 

      
 

 
 

      
 

     

 


     
 






















c           4      C   s  |r.t d||t|| jd t|d|| jd |dks:tt| }d}g }	d}
d}|	j}d|  krn|k rn n,t|| }|d@ }|d@ d? }|r|d	 }n|}t| }|| }|rt d
||||||f | jd |sd|  krdkr4n n<t	d||d |d  \}}|rt d||f| jd n|dkr|rTt d|	| jd t|	dksft|	
 }|	
 }|||  |rt d|	| jd nH|dkr8|rt d|	| jd t|	dkst|	
 }|	
 }t|dkstt|dksttt|d |d }|| |rt d|	| jd n|dkr|rXt d|	| jd t|	dksjt|	
 }|	
 }t|dkstt|dksttt|d |d }|| |rt d|	| jd n|dkrFt	d||d |d  \}}t|d}|dkr |d d }nd}|rt d||||f | jd n|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 }qX|dkrn~|dkrXdt|d#k }t	d$d%|  ||d |d |  }|rzt d&| | jd n"|dkrdt|d#k }t	d'd%|  ||d |d |  \}}t|d(\} }t|d)\}!}|rzt d*|||!| f | jd n|d+krt	d,||d |d+  }"|rzt d-|" | jd n^|dkrRt||d ||}#|rzt d|#| jd n(|dkrt||d ||}#|rzt d|#| jd n|d.krt	d,||d |d+  d }|rzt d/| | jd n|d0krt||d |dd1}#d}
|rzt d2|#| jd nr|d3krDt||d |dd1}#d}
|rzt d2|#| jd n6|d4krt	d,||d |d+  d }$t||d+ ||}#|rt d|$|#| jd |#\}}}%}&|
p|%p|&}
t| |$|\}'}(||'d5k O }|'|(d ||d ||d f})|r t d2|)| jd |dkrz||)g nb|d6krt	d,||d |d+  d }$t||d+ ||\}*}+|rpt 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rz||)g nr|dkrNt	d||d |d  \}$}"|rzt d7|$|"f | jd n,|tkr^d}n|rvt d8| | jd d}|dkrt d"| jd d S ||7 }qX|rt d9|
  ||	f | jd t|	dkrt d:| jd d S );Nr   r  r   ra  rE   rz   r~  r5   r(   r  r   r$   r  r  r'   r  z
tlist postr-   r  r  r,   r  r  r=   r  r%   r  re   r  rt   rD   r  r  z**** Dud size; exiting ****rB   r[  r  z   FuncID=%dr  r   r   r  r4   r  z   namex=%dr:   r  rZ   )r  r  rp   rv   r6   rw   z   refx=%d namex=%dr  z.End of formula. any_rel=%d any_err=%d stack=%rr  )r"  r#  r$  r   r%  r  rh  r  r  r   rd  r   r  r  r  r?  r
   r  r  r  r  r0  r  )4r'  r  r  r  r  r)  Zisnamer  r  r  r  r  r  r  rv  r  r  r  r  r  r	  rk  rl  rr  r  r  r  r  r  r  r  r  r  r  r  r  r(  r  r  r  r  r   r  r  r  r  r  r   r  r  r  r  r   r   r   r   ^  s^   
 
  
  
  

 


 


& 
* 
 
 
 
 
 
 
  
 
  
 
 
 

c                 C   sT   |d k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]rR   z%dr   r   )r  rowxrelr  r  r   r   r   
rownamerel  s    r  c                 C   sP   |d k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]Cr   r   )r	  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  )r  r	  r   r   r   r     s    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  )r  r	  r  r   r   r   r   "  s    c           	      C   s`   |s|st | ||S |r |d ks,|r0|d kr0d}t||||}t| |||}|rX|| S || S )NT)r   r  r  )	r  r	  r  r  r  r  r  crr   r   r   r  (  s    r  c                 C   s:   d}| dkr||  S t | d\}}||d  ||  S dS )z6Utility function: ``7`` => ``'H'``, ``27`` => ``'AB'``ABCDEFGHIJKLMNOPQRSTUVWXYZr=   rv   r   N)r  )r	  alphabetZxdiv26Zxmod26r   r   r   r   4  s
    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 kr,d}|s4|r@|d kr@d}dt |||	||||t |d |d |
||||f S )NTr   r   )r  )Zrlo_rhi_clo_chiZrlorel_rhirel_clorel_chirelr  r  r  r!  r"  r#  r$  ZrlorelZrhirelZclorelZchirelr   r   r   r  E  s    r  c                 C   s0   |j }dt| f|dd  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$   re   )r   
sheetranger%  )bookr  r   r   r   r   r   R  s
    c           	      C   s\   |j }|j}t| |dd |dd }t|dd |dd |||}|sP|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$   re   r  )r   rC  sheetrangerelr  )	r'  r  r  r  r  r   rC  shdescZrngdescr   r   r   r   ^  s    	 c                 C   s`   |dkr| | }nddddd |d| }d|krHd|dd	 d S d
|kr\d| d S |S )Nr   z?internal; any sheet?zinternal; deleted sheetzinternal; macro sheetz<<external>>)r6   r7   r   r  z
?error %d?'z''r  )r?  r  )shnamesZshxZshnamer   r   r   quotedsheetnameo  s    
 r,  c                 C   s8   |   }t||}||d kr4|dt||d  7 }|S )Nr   r  )Zsheet_namesr,  )r'  sloshir+  r)  r   r   r   r&    s
    
r&  c                 C   sP   |\}}|\}}|s$|s$t | ||S |d  kr<|d krHn n|rH|sLtdS )Nr   r   rP   )r&  r%  )r'  ZsrangeZ	srangerelr-  r.  ZslorelZshirelr   r   r   r(    s    (r(  )NN)NN)NN)NN)r   )r   )r   r   )NNNr   r   r   )r   r   )Nr   )Nr   )r   )NNr   )r   )NNr   )NNr   )urA  
__future__r   r  operatorZoprstructr   Zbiffhr   r   r   r   r	   r
   Ztimemachine__all__r   r   r   r   r    r!   ZALL_FMLA_TYPESr  r?  r  r   r   r8   r   r   r   r   r   r   r  Zsztab0Zsztab1Zsztab2Zsztab3Zsztab4r  r  r  r  setr  minmaxr  r  r   r
  r  r  r  r0  r3  	Exceptionr4  objectr"   r   r#   ZtAddZtSubZtMulZtDivZtPowerZtConcatrangeZtLTZtLEZtEQZtGEZtGTZtNErF  rI  rK  rL  rM  rN  rO  rP  rU  r  Z_arith_argdictZ_cmp_argdictZ_strg_argdictaddsubmultruedivre  ru  r  r  r  r  r   r   r   r  r  r   r   r  r   r%  r  r   r   r,  r&  r(  r   r   r   r   <module>   s              







  
    &\A	                e              %

	
