a
    f=_p                   @   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+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSdTdUdVdWdXdYdZd[d\d]d^d_d`dadbdcdddedfdgdhdidjdkdldmdndodpdqdrdsdtdudvdwdxdydzd{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Z,d1d2d3d4d5d6d7d8d9d:	Z-e.g d;Z/e0e1e0e1e0e1fZ2e1e0e1e0e1e0fZ3d<d= Z4dd>d?Z5dd@dAZ6ddBdCZ7ddDdEZ8ddFdGZ9ddHdIZ:G dJdK dKe;Z<G dLdM dMe=Z>G dNdO dOe?Z@dZAd
ZBdZCdPZDdQZEdZFeGdRdS\ZHZIZJZKZLZMdTdU ZNdVdW ZOdXdY ZPdZd[ ZQd\d] ZRd^d_ ZSd`da ZTdbdc ZUddde ZVeeNe!eWiZXeeNe!eNiZYeeVe!eNiZZeAeXeej[dfdgfeBeXeej\dfdhfeCeXeej]didjfeDeXeej^didkfeEeXeeOdldmfeFeZe!ej[dndofeHeYeePdpdqfeIeYeeQdpdrfeJeYeeRdpdsfeKeYeeSdpdtfeLeYeeTdpdufeMeYeeUdpdvfiZ_dwdx dydhdzfd{dx dydgdzfd|dx d}dzd~fdZ`dZadZbdZcdpZddddZedddZfdddZgdddZhdddZidd ZjdddZkddd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                ?   CELLZSHAREDZ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)r7   r6   r   r   r$   r4   r%   r5   ,)@r7   r%   r%   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r6   r7   r6   r&   r%   r$   r$   r4   	   r&   r$   r4   r&   r%      r5   r5   r5   r$   r%   r;   r%   r;   r$   r$   r7   r7   r7   r7   r7   r7   r7   r7   r4   r7   r7   r7   r7   r7   r7   r7   )@r7   r5   r5   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r6   r7   r6      r5   r$   r$   r4   r:   r:   r$   r4   r<   r%   r;   r;   r;   r;   r4   r%   r;   r%   r;   r4   r4   r7   r7   r7   r7   r7   r7   r7   r7   r4   r7   r7   r7   r7   r7   r7   r7   )@r7   r5   r5   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r6   r7   r6   r<   r5   r$   r$   r4   r:   r:   r4   r%   r<   r%   r;   r;   r;   r;   r4   r%   r;   r%   r;   r4   r4   r7   r7   r7   r7   r7   r7   r7   r7   r7   r7   r7   r7   r7   r7   r7   r7   )@r7   r5   r5   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r6   r7   r6   r7   r7   r$   r$   r4   r:   r:   r4   r%   r,   r%   r;   r;   r;   r;   r4   r%   r;   r%   r;   r4   r4   r7   r7   r7   r7   r7   r7   r7   r7   r7            r>   r?   r7   r7   )@r7   r5   r5   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r6   r6   r6   r7   r7   r$   r$   r4   r:   r:   r4   r%   r5   r5   r:   r;   r;   r;   r4   r5   r:   r5   r:   r4   r4   r7   r7   r7   r7   r7   r7   r7   r7   r7   r;   r;   r<   r;   r<   r7   r7   )   r?      (   r3   2   F   P   )@ZUnk00ZExpZTblZAddZSubZMulZDivZPowerZConcatZLTZLEZEQZGEZGTZNEZIsectListZRangeZUplusZUminusZPercentZParenZMissArgZStrZExtendedZAttrZSheetZEndSheetZErrZBoolZIntZNumZArrayZFuncZFuncVarNameZRefZAreaZMemAreaZMemErrZMemNoMemZMemFuncZRefErrZAreaErrZRefNZAreaNZMemAreaNZ	MemNoMemN rH   rH   rH   rH   rH   rH   rH   ZFuncCEZNameXZRef3dZArea3dZRefErr3dZ	AreaErr3drH   rH   )ZCOUNTr   rA   r%   r   VR)ZIFr$   r4   r%   r4   rI   VRR)ZISNAr   r   r$   r   rI   rI   )ZISERRORr   r   r$   r   rI   rI   )ZSUMr   rA   r%   r   rI   rJ   )ZAVERAGEr   rA   r%   r   rI   rJ   )ZMINr   rA   r%   r   rI   rJ   )MAXr   rA   r%   r   rI   rJ   )ZROWr   r   r%   r   rI   rJ   )ZCOLUMNr   r   r%   r   rI   rJ   )ZNAr   r   r$   r   rI   rH   )ZNPVr$   rA   r%   r$   rI   VR)ZSTDEVr   rA   r%   r   rI   rJ   )ZDOLLARr   r$   r%   r   rI   rI   )ZFIXEDr$   r4   r%   r4   rI   VVV)ZSINr   r   r$   r   rI   rI   )ZCOSr   r   r$   r   rI   rI   )ZTANr   r   r$   r   rI   rI   )ZATANr   r   r$   r   rI   rI   )ZPIr   r   r$   r   rI   rH   )ZSQRTr   r   r$   r   rI   rI   )ZEXPr   r   r$   r   rI   rI   )ZLNr   r   r$   r   rI   rI   )ZLOG10r   r   r$   r   rI   rI   )ZABSr   r   r$   r   rI   rI   )ZINTr   r   r$   r   rI   rI   )ZSIGNr   r   r$   r   rI   rI   )ZROUNDr$   r$   r$   r$   rI   VV)ZLOOKUPr$   r4   r%   r$   rI   rM   )ZINDEXr$   r%      r%   rJ   ZRVVV)ZREPTr$   r$   r$   r$   rI   rO   )ZMIDr4   r4   r$   r4   rI   rN   )ZLENr   r   r$   r   rI   rI   )ZVALUEr   r   r$   r   rI   rI   )TRUEr   r   r$   r   rI   rH   )FALSEr   r   r$   r   rI   rH   )ZANDr   rA   r%   r   rI   rJ   )ORr   rA   r%   r   rI   rJ   )ZNOTr   r   r$   r   rI   rI   )ZMODr$   r$   r$   r$   rI   rO   )ZDCOUNTr4   r4   r$   r4   rI   RRR)ZDSUMr4   r4   r$   r4   rI   rT   )ZDAVERAGEr4   r4   r$   r4   rI   rT   )ZDMINr4   r4   r$   r4   rI   rT   )ZDMAXr4   r4   r$   r4   rI   rT   )ZDSTDEVr4   r4   r$   r4   rI   rT   )ZVARr   rA   r%   r   rI   rJ   )ZDVARr4   r4   r$   r4   rI   rT   )ZTEXTr$   r$   r$   r$   rI   rO   )ZLINESTr   r%   r%   r%   ARRVV)ZTRENDr   r%   r%   r%   rU   RRRV)ZLOGESTr   r%   r%   r%   rU   rV   )ZGROWTHr   r%   r%   r%   rU   rW   )ZPVr4   r5   r%   r5   rI   VVVVV)ZFVr4   r5   r%   r5   rI   rX   )ZNPERr4   r5   r%   r5   rI   rX   )ZPMTr4   r5   r%   r5   rI   rX   )ZRATEr4      r%   rY   rI   VVVVVV)ZMIRRr4   r4   r$   r4   rI   ZRVV)ZIRRr   r$   r%   r$   rI   RV)ZRANDr   r   
   r   rI   rH   )ZMATCHr$   r4   r%   r4   rI   rK   )ZDATEr4   r4   r$   r4   rI   rN   )ZTIMEr4   r4   r$   r4   rI   rN   )ZDAYr   r   r$   r   rI   rI   )ZMONTHr   r   r$   r   rI   rI   )ZYEARr   r   r$   r   rI   rI   )ZWEEKDAYr   r$   r%   r$   rI   rO   )ZHOURr   r   r$   r   rI   rI   )ZMINUTEr   r   r$   r   rI   rI   )ZSECONDr   r   r$   r   rI   rI   )ZNOWr   r   r\   r   rI   rH   )ZAREASr   r   r$   r   rI   rJ   )ZROWSr   r   r$   r   rI   rJ   )COLUMNSr   r   r$   r   rI   rJ   )ZOFFSETr4   r5   r%   r5   rJ   ZRVVVV)ZSEARCHr$   r4   r%   r4   rI   rN   )Z	TRANSPOSEr   r   r$   r   rU   rU   )ZTYPEr   r   r$   r   rI   rI   )Z	SERIESSUMr%   r%   r$   r%   rI   ZVVVA)ZATAN2r$   r$   r$   r$   rI   rO   )ZASINr   r   r$   r   rI   rI   )ZACOSr   r   r$   r   rI   rI   )ZCHOOSEr$   rA   r%   r$   rI   rM   )ZHLOOKUPr4   r%   r%   r%   rI   VRRV)ZVLOOKUPr4   r%   r%   r%   rI   r^   )ZISREFr   r   r$   r   rI   rJ   )ZLOGr   r$   r%   r$   rI   rO   )ZCHARr   r   r$   r   rI   rI   )ZLOWERr   r   r$   r   rI   rI   )ZUPPERr   r   r$   r   rI   rI   )ZPROPERr   r   r$   r   rI   rI   )ZLEFTr   r$   r%   r$   rI   rO   )ZRIGHTr   r$   r%   r$   rI   rO   )ZEXACTr$   r$   r$   r$   rI   rO   )ZTRIMr   r   r$   r   rI   rI   )ZREPLACEr%   r%   r$   r%   rI   VVVV)Z
SUBSTITUTEr4   r%   r%   r%   rI   r_   )ZCODEr   r   r$   r   rI   rI   )ZFINDr$   r4   r%   r4   rI   rN   )r*   r   r$   rP   r$   rI   rM   )ZISERRr   r   r$   r   rI   rI   )ZISTEXTr   r   r$   r   rI   rI   )ZISNUMBERr   r   r$   r   rI   rI   )ZISBLANKr   r   r$   r   rI   rI   )Tr   r   r$   r   rI   rJ   )Nr   r   r$   r   rI   rJ   )Z	DATEVALUEr   r   r$   r   rI   rI   )Z	TIMEVALUEr   r   r$   r   rI   rI   )ZSLNr4   r4   r$   r4   rI   rN   )ZSYDr%   r%   r$   r%   rI   r_   )ZDDBr%   r5   r%   r5   rI   rX   )ZINDIRECTr   r$   rP   r$   rJ   rO   )ZCLEANr   r   r$   r   rI   rI   )ZMDETERMr   r   r$   r   rI   rU   )ZMINVERSEr   r   r$   r   rU   rU   )ZMMULTr$   r$   r$   r$   rU   AA)ZIPMTr%   rY   r%   rY   rI   rZ   )ZPPMTr%   rY   r%   rY   rI   rZ   )ZCOUNTAr   rA   r%   r   rI   rJ   )ZPRODUCTr   rA   r%   r   rI   rJ   )ZFACTr   r   r$   r   rI   rI   )ZDPRODUCTr4   r4   r$   r4   rI   rT   )Z	ISNONTEXTr   r   r$   r   rI   rI   )ZSTDEVPr   rA   r%   r   rI   rJ   )ZVARPr   rA   r%   r   rI   rJ   )ZDSTDEVPr4   r4   r$   r4   rI   rT   )ZDVARPr4   r4   r$   r4   rI   rT   )ZTRUNCr   r$   r%   r$   rI   rO   )Z	ISLOGICALr   r   r$   r   rI   rI   )ZDCOUNTAr4   r4   r$   r4   rI   rT   )ZUSDOLLARr   r$   r%   r$   rI   rO   )ZFINDBr$   r4   r%   r4   rI   rN   )ZSEARCHBr$   r4   r%   r4   rI   rN   )ZREPLACEBr%   r%   r$   r%   rI   r_   )ZLEFTBr   r$   r%   r$   rI   rO   )ZRIGHTBr   r$   r%   r$   rI   rO   )ZMIDBr4   r4   r$   r4   rI   rN   )ZLENBr   r   r$   r   rI   rI   )ZROUNDUPr$   r$   r$   r$   rI   rO   )Z	ROUNDDOWNr$   r$   r$   r$   rI   rO   )ZASCr   r   r$   r   rI   rI   )ZDBCSr   r   r$   r   rI   rI   )ZRANKr$   r4   r%   r4   rI   ZVRV)ZADDRESSr$   r5   r%   r5   rI   rX   )ZDAYS360r$   r4   r%   r4   rI   rN   )ZTODAYr   r   r\   r   rI   rH   )ZVDBr5   r;   r%   r;   rI   ZVVVVVVV)ZMEDIANr   rA   r%   r   rI   rJ   )Z
SUMPRODUCTr   rA   r%   r   rI   rU   )ZSINHr   r   r$   r   rI   rI   )ZCOSHr   r   r$   r   rI   rI   )ZTANHr   r   r$   r   rI   rI   )ZASINHr   r   r$   r   rI   rI   )ZACOSHr   r   r$   r   rI   rI   )ZATANHr   r   r$   r   rI   rI   )ZDGETr4   r4   r$   r4   rI   rT   )INFOr   r   r$   r   rI   rI   )ZDBr%   r5   r%   r5   rI   rX   )Z	FREQUENCYr$   r$   r$   r$   rU   ZRR)z
ERROR.TYPEr   r   r$   r   rI   rI   )ZAVEDEVr   rA   r%   r   rI   rJ   )ZBETADISTr4   r5   r%   r   rI   rI   )ZGAMMALNr   r   r$   r   rI   rI   )ZBETAINVr4   r5   r%   r   rI   rI   )Z	BINOMDISTr%   r%   r$   r%   rI   r_   )ZCHIDISTr$   r$   r$   r$   rI   rO   )ZCHIINVr$   r$   r$   r$   rI   rO   )ZCOMBINr$   r$   r$   r$   rI   rO   )Z
CONFIDENCEr4   r4   r$   r4   rI   rN   )Z	CRITBINOMr4   r4   r$   r4   rI   rN   )ZEVENr   r   r$   r   rI   rI   )Z	EXPONDISTr4   r4   r$   r4   rI   rN   )ZFDISTr4   r4   r$   r4   rI   rN   )ZFINVr4   r4   r$   r4   rI   rN   )ZFISHERr   r   r$   r   rI   rI   )Z	FISHERINVr   r   r$   r   rI   rI   )ZFLOORr$   r$   r$   r$   rI   rO   )Z	GAMMADISTr%   r%   r$   r%   rI   r_   )ZGAMMAINVr4   r4   r$   r4   rI   rN   )ZCEILINGr$   r$   r$   r$   rI   rO   )ZHYPGEOMDISTr%   r%   r$   r%   rI   r_   )ZLOGNORMDISTr4   r4   r$   r4   rI   rN   )ZLOGINVr4   r4   r$   r4   rI   rN   )ZNEGBINOMDISTr4   r4   r$   r4   rI   rN   )ZNORMDISTr%   r%   r$   r%   rI   r_   )Z	NORMSDISTr   r   r$   r   rI   rI   )ZNORMINVr4   r4   r$   r4   rI   rN   )ZNORMSINVr   r   r$   r   rI   rI   )ZSTANDARDIZEr4   r4   r$   r4   rI   rN   )ZODDr   r   r$   r   rI   rI   )ZPERMUTr$   r$   r$   r$   rI   rO   )ZPOISSONr4   r4   r$   r4   rI   rN   )ZTDISTr4   r4   r$   r4   rI   rN   )ZWEIBULLr%   r%   r$   r%   rI   r_   )ZSUMXMY2r$   r$   r$   r$   rI   rb   )ZSUMX2MY2r$   r$   r$   r$   rI   rb   )ZSUMX2PY2r$   r$   r$   r$   rI   rb   )ZCHITESTr$   r$   r$   r$   rI   rb   )ZCORRELr$   r$   r$   r$   rI   rb   )ZCOVARr$   r$   r$   r$   rI   rb   )ZFORECASTr4   r4   r$   r4   rI   ZVAA)ZFTESTr$   r$   r$   r$   rI   rb   )Z	INTERCEPTr$   r$   r$   r$   rI   rb   )ZPEARSONr$   r$   r$   r$   rI   rb   )ZRSQr$   r$   r$   r$   rI   rb   )ZSTEYXr$   r$   r$   r$   rI   rb   )ZSLOPEr$   r$   r$   r$   rI   rb   )ZTTESTr%   r%   r$   r%   rI   ZAAVV)ZPROBr4   r%   r%   r4   rI   ZAAV)ZDEVSQr   rA   r%   r   rI   rJ   )ZGEOMEANr   rA   r%   r   rI   rJ   )ZHARMEANr   rA   r%   r   rI   rJ   )ZSUMSQr   rA   r%   r   rI   rJ   )ZKURTr   rA   r%   r   rI   rJ   )ZSKEWr   rA   r%   r   rI   rJ   )ZZTESTr$   r4   r%   r$   rI   r[   )ZLARGEr$   r$   r$   r$   rI   r[   )ZSMALLr$   r$   r$   r$   rI   r[   )ZQUARTILEr$   r$   r$   r$   rI   r[   )Z
PERCENTILEr$   r$   r$   r$   rI   r[   )ZPERCENTRANKr$   r4   r%   r$   rI   r[   )ZMODEr   rA   r%   r   rI   rU   )ZTRIMMEANr$   r$   r$   r$   rI   r[   )ZTINVr$   r$   r$   r$   rI   rO   )ZCONCATENATEr   rA   r%   r   rI   rI   )ZPOWERr$   r$   r$   r$   rI   rO   )ZRADIANSr   r   r$   r   rI   rI   )ZDEGREESr   r   r$   r   rI   rI   )ZSUBTOTALr$   rA   r%   r$   rI   rM   )ZSUMIFr$   r4   r%   r4   rI   ZRVR)ZCOUNTIFr$   r$   r$   r$   rI   r[   )Z
COUNTBLANKr   r   r$   r   rI   rJ   )ZISPMTr%   r%   r$   r%   rI   r_   )ZDATEDIFr4   r4   r$   r4   rI   rN   )Z
DATESTRINGr   r   r$   r   rI   rI   )ZNUMBERSTRINGr$   r$   r$   r$   rI   rO   )ZROMANr   r$   r%   r$   rI   rO   )ZGETPIVOTDATAr$   r$   r$   r$   rI   r[   )Z	HYPERLINKr   r$   r%   r$   rI   rO   )ZPHONETICr   r   r$   r   rI   rI   )ZAVERAGEAr   rA   r%   r   rI   rJ   )ZMAXAr   rA   r%   r   rI   rJ   )ZMINAr   rA   r%   r   rI   rJ   )ZSTDEVPAr   rA   r%   r   rI   rJ   )ZVARPAr   rA   r%   r   rI   rJ   )ZSTDEVAr   rA   r%   r   rI   rJ   )ZVARAr   rA   r%   r   rI   rJ   )ZBAHTTEXTr   r   r$   r   rI   rI   )ZTHAIDAYOFWEEKr   r   r$   r   rI   rI   )Z	THAIDIGITr   r   r$   r   rI   rI   )ZTHAIMONTHOFYEARr   r   r$   r   rI   rI   )ZTHAINUMSOUNDr   r   r$   r   rI   rI   )ZTHAINUMSTRINGr   r   r$   r   rI   rI   )ZTHAISTRINGLENGTHr   r   r$   r   rI   rI   )ZISTHAIDIGITr   r   r$   r   rI   rI   )ZROUNDBAHTDOWNr   r   r$   r   rI   rI   )ZROUNDBAHTUPr   r   r$   r   rI   rI   )ZTHAIYEARr   r   r$   r   rI   rI   )ZRTDr$   r5   r%   r   rI   rI   (  r   r   r$   r4   r%   r5   rY   r;   r&   r:   r\   r<   rP         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VolatileZIfZChooseZSkipZSumZAssignZSpaceZSpaceVolatile)	r   r   r$   r%   r&   r'   r(   r   r   )r;   r&   r\   r<   rl   rm   ry   c                 C   s   t dd t| |j|jD S )Nc                 s   s   | ]\}}}|||V  qd S N ).0funcZnumaZnumbr   r   +lib/python3.9/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   re            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   re   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<HHBBrY   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 n0 ty>   td|t| j f | jd Y dS 0 |\}}}|| jkr|rntd||f | jd |d  kr|ksn J 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rR|  krR|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_inxZ_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    



&

r!  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  )r"  r  )r  r  r  r  )r  raw_extshtxr  r  r  r  r  r   r   r   r   get_externsheet_local_range_b57  s*    
 

r$  c                   @   s   e Zd ZdS )FormulaErrorN)__name__
__module____qualname__r   r   r   r   r%    s   r%  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)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   getr*  r+  r-  )r.  Z	kind_textr   r   r   __repr__l  s    zOperand.__repr__)NNr   r)  )
r&  r'  r(  __doc__r+  r   r*  r-  r/  r1  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   rY   rP   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 )Nr3  zRef3D(coords=%r)zRef3D(coords=%r, relflags=%r))r4  r   )r.  r   r   r   r1    s
    
zRef3D.__repr__N)r&  r'  r(  r2  r/  r1  r   r   r   r   r#   r  s   0	r#   rY   r;   r:   r,   c                 C   s   | S r   r   xr   r   r   nop  s    r7  c                 C   s   | | S r   r   r6  yr   r   r   _opr_pow      r:  c                 C   s   | |k S r   r   r8  r   r   r   _opr_lt  r;  r<  c                 C   s   | |kS r   r   r8  r   r   r   _opr_le  r;  r=  c                 C   s   | |kS r   r   r8  r   r   r   _opr_eq  r;  r>  c                 C   s   | |kS r   r   r8  r   r   r   _opr_ge  r;  r?  c                 C   s   | |kS r   r   r8  r   r   r   _opr_gt  r;  r@  c                 C   s   | |kS r   r   r8  r   r   r   _opr_ne  r;  rA  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)Znumsr   r   r   num2strg  s    
rE  rA   +-rB   r   /rC   ^r@   &r\   <z<==z>=>z<>c                 C   s   |  S r   r   r5  r   r   r   <lambda>  r;  rN  rD   rH   c                 C   s   | S r   r   r5  r   r   r   rN    r;  c                 C   s   | d S )Ng      Y@r   r5  r   r   r   rN    r;  r   %)rf   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 rdn 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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}!| |!_|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 ur|jd urt|jdksJ t|jdksJ tt|jd |jd }"t|"g|!_n|jt  kr^|jkrn nt|!_|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 n|d kr|r6td!|| jd t|dksHJ | }| }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v rv|jttfv rvt|!_|jtks |jtkr&t|!_|jd urv|jd urvt|jdksRJ t|jdksfJ |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rdt}!n8|jt  kr|jkrn nf|jd ur|jd urt|jdksJ t|jdksJ tt|jd |jd }"t|"g|!_n|jt  kr|jkrn nt|!_|jd ur|jd urt|jdks<J t|jdksPJ 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sJ 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	sRJ |d: }d;|j } tt d t+| |d:< nd6}|
rtd<|(|*||)f | jd nd=|  k	rd>k	rn n|d?k 	sJ td@ndA|  k	rdk
rn n|dA }+g dB|+ },tt,t t g|+ }-t(dCdD|+  ||
d |
d |,  \}.|+dk
rXt-|.}.t.|.}'n8|+dk
rlt.|.}'n$|+dk
rdE|. }'nd0t/|.  d0 }'|t|-|.t"|' ntdF| |dk
rtdG| |
|7 }
q|dk
r|| nb|dkrdt0|dHk },t(dCdI|,  ||
d |
d |,  d }/t1*|/d }0|0sXtdJ|/ | jd || n|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+| }!||! nP|dkrdt0|dHk },t(dPdI|,  ||
d |
d |,  \}2}/t3|2dQ\}4}2t3|/dR\}5}/|rxtdS|/|2|5|4f | jd t1*|/d }0|0stdT|/ | jd || qH|0d d \}1}6}7|rtdU|1|6|7f | jd |6|2  kr|7ksn J t||2ksJ t||2ksJ t2dVdM ||2 d  D }3dN|1|3f } ttd t+| }!|/dkrH||2  }8|8jt t,fvr|rF|8jtkrFtdW| jd n|8jdXvr|rF|8jd urFtdY| jd n|2dkr|8jst,d |!_|!_nJ|2 d t0|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 t0|8j  }:|:jt!krt d |!_|!_n|:j|:j |!_|!_||2 d = ||! 	nh|dkr.t(d\||
d |
d  d d };|r$td]|; | jd | j4|; }<|<j5sJt6| |<|;||d  |<j7sb|<j8sb|<j9r|rz|<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rtB||
d ||}!|r`t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rtC||
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}"|r|t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 },|rHtdf|, | jd n,|dgkr4||| n|dhkrL||| n|d=kr|dkrtB||
d ||}!t(d\||
d |
d  d }NtD| |N|\}A}Bn`tB||
d ||}!t(di||
d |
d  \}O}P}Q|rtdj|O|P|Q| jd tE| |O|P|Q|\}A}B|!\}=}>}?}@|?p|@}R|p |R}|A|Bd |=|=d |>|>d f}"||Ad:k O }|r`t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|!_||! nf|d>kr|dkr<tC||
d ||\}D}Et(d\||
d |
d  d }NtD| |N|\}A}BndtC||
d ||\}D}Et(di||
d |
d  \}O}P}Q|rt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|p|R}|A|Bd |F|Jd |G|Kd f}"|rtdd|"| jd ttd }!|RrZdd|H|L|I|Mf}Ct|"|C }St|!_tF| |Sddk|!_nt|"}St|!_tG| |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|r^tdo|U|N|;|Tf | jd |;|kr|r|tdp| jd d }T}|Ts|dkrtD| |N|\}A}Bn:|Udkrdq\}A}Bn&| jH|N }V|Vd6krdr\}A}Bnds\}A}B|Ts|Ad:k rdt|;|Uf } ttd t"| }!n| j4|; }<|<j5s2t6| |<|;||d  |<j7sJ|<j8sJ|<j9r|rb|<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 |!_|r
tdwtA|!j| jd ||! n4|tIv r,d}|| n|rDtdx| | jd d}|dkrZtdy|
|7 }
q|  }|rtJ| jdz||  || t|dkrtd{| jd t| jd ||_<t|dkrd |_Kn
|d |_K||_;||_9||_Ld|_5d S )|Nr   z1::: evaluate_name_formula %r %r %d %d %r level=%dr  r   Zfoutz-Excessive indirect references in NAME formulac                 S   s8  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y   |	|
 Y d S 0 |j
d u s|j
d u r|	|
 d S ||j
}||j
}|||}|tkr$|r dnd}||
_
|	|
 d S )Nr$   rH   ()r   r   )r  popbinop_rulesjoinr,  r-  r"   r*  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J | }|j}t|  \}}}}d|dd |j|k  |jdd |j|k  |g}	|d urp||}|t||||	 d S Nr   rH   rR  rS  )	r  rT  r+  
unop_rulesrV  r,  r-  rX  r"   )
opcoder^  rZ  r\  valr   r,  sym1sym2r`  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)r%  Zop_argZ	oname_argmsgr   r   r   not_in_name_formula7  s    z2evaluate_name_formula.<locals>.not_in_name_formularn   `   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   re   r,   
tIsect pre rE   rH   rR  rS  tIsect postr'   	tList prer9   
tList postr-   
tRange pre:tRange postr>   r@   r?   rg   rh   rD   Zlenlen   sz=%d strg=%r"""ri   tExtended token not implementedr=   <BHr%   ??Unknown??rY   tAttrSumr6   SUM(%s))   subop=%02xh subname=t%s sz=%d nc=%02xhrj   rk   rC   )tSheet & tEndsheet tokens not implementedrl   r   r   r$   r&   rK  BBHdrR   rQ   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   $  r;  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   @  r;  zIF testarg kind?)r   r   zIF testarg value?z$$$$$$ IF => constantr   <H   tgtnamex=%dz!!! tgtobj has problems!!!z-----------       --------)headerZfooter%s!%s    tName: setting text to     r:     %d bytes of cell ref formularP   rd   <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)MSTACK_ALARM_LEVELZraw_formulaZbasic_formula_lenbiff_versionr  namer  r   STACK_PANIC_LEVELr   szdictr"   r   r   rX  	BYTES_ORDonamesr%  r  rT  rV  r,  r-  r   r*  r+  r   tIsectFuncsr#   r   r4  tRangeFuncsr   r8   	LEAF_RANKr	   encodingr
   replacer   r   
tAttrNamesr0  	FUNC_RANKr   floatrB  r   int	func_defslistsepdivmodname_obj_listZ	evaluatedr   macroZbinaryany_errdumpany_relstackcopydeepcopyscope_sheet_namesreprr  r  r!  r$  r   r   _externsheet_type_b57error_opcodesZfprintfrb  any_external)Wr  Znobjnamexr  levelr   fmlalenr  r   sztabr  r  r  r  r  unk_opnd
error_opndspushrc  rj  rm  oprf  optypeopxonameszrl  r[  r\  r_  r,  r`  resr   ZrelfaZrelfbstrgnewposr-  subopncsubnameinxnbr*  r+  funcx
func_attrs	func_namenargsargtextpromptr  minargsmaxargsZtestargZresposZchosentgtnamextgtobjr   r   r   r   shx1shx2r4  r  r  rowx1colx1row_rel1col_rel1rowx2colx2row_rel2col_rel2r  r#  raw_shx1raw_shx2is_relref3ddodgyorigrefxextyr   r   r   r     s&   

 


	
  

	 
	  














(








*

*





"














 






 


























r   c	           X         s,  |t krd}ttttfv }	|}
 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|rJ 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~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}'|&|'_|"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 n4|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sb|#jtkrjt|'_nF|"jttfv r|#jttfv 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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 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sJ 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stJ |d> }#d?|#j }&tt d t)|&|d>< nd:}|rtd@|*|,||+f  jd ndA|  krdBkrn n|dCk sJ tdDndE|  krdkrn n|dE }-g dF|- }.tt*t t g|- }/tdGdH|-  |
|d |d |.  \}0|-dkrzt+|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 }1t/(|1d }2|2	szt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)|&}'||' 
n|dkrdt.|dLk }.tdTdM|.  |
|d |d |.  \}4}1t1|4dU\}6}4t1|1dV\}7}1|
rtdW|1|4|7|6f  jd |1dXk
rdY}2nt/(|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 J t||4ks8J t||4ksJJ t0d\dQ ||4 d  D }5dR|3|5f }&ttd t)|&}'||4 d = ||' 	n |dkrFt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|&}'||' nT|d:krt7|
|d ||	||}'|r|tda|' jd |'\}} }<}=|<p|=}>|>rt}?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rTt}?nt}?|rpt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rt7|
|d ||	||}'d}|r0tdb|' jd |'\}} }<}=|<pD|=}>|>rRt}?nt}?t8|| |<|=|||}&t|?d t|&}'||' n|dfkrNt9|
|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rt7|
|d ||	||}'td]|
|d |d  d }Lt= |L|\}M}Nndt7|
|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 }|rjtdb|J jd ttd }'|>rdd|<|<|=|=f}Kt?|J|K }Rt|'_t@ |R||||'_nt?|J}Rt|'_tA |R|'_t|'_d |'_B||' n|dBkr|dkr<t9|
|d ||	\}@}Atd]|
|d |d  d }Lt= |L|\}M}Nndt9|
|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rfd}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|rNtdl|T|L|:|Sf  jd |Ss|dkrpt= |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 }&nn|Ss|Md>k rdq|:|Tf }&nP j2|: };|;j3d>kr|;j4}&nd_ j5|;j3 |;j4f }&|rNtdrt6|'j jd t|?|Vt|&}'||' n4|tEv r~d}|| n|rtds|  jd d}|dkrtdt||7 }q|  }|r
tdu||  ||f  jd t|dkrt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   rQ  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$   rH   rR  rS  )r  rT  rU  rV  r,  r-  r"   rX  )rY  rZ  r[  r\  r]  r^  r   r,  r_  r`  ra  r   r   r   rc  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 rd  )r  rT  re  rV  r,  r-  rX  r"   )	rf  r^  rZ  r\  r   r,  rh  ri  r`  r   r   r   rj  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  rk  r  fmlatyper   r   unexpected_opcode  s    z,decompile_formula.<locals>.unexpected_opcodern   rn  r5   r(   z;Pos:%d Op:0x%02x opname:t%s Sz:%d opcode:%02xh optype:%02xhrp  r7   rq  rA   z<x2Hz<xHBzSHARED FMLA at rowx=%d colx=%dr4   re   r,   rr  r$   rs  rE   rH   rR  rS  rt  r'   ru  r9   rv  r-   rw  rx  ry  r>   r@   r?   rg   rh   rD   rz  r{  r|  r}  ri   r~  r=   r  r%   r  rY   r  r6   r  r  rj   rk   rC   r  rl   r  rK  r  r  r  r  rB   r  r  r  c                 s   s   | ]}|j V  qd S r   r  r  r   r   r   r   [  r;  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   {  r;  r  r  r  r  r  r  r:   r  rP   rd   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  )Fr  r   r!   r   r    r  r  r  r   r  r   r  r"   r   r   rX  r  r  r%  _TOKEN_NOT_ALLOWEDr   r  r   r   r  rT  rV  r,  r-  r   r*  r   r   r8   r	   r  r
   r  r   r  r0  r  r   r  rB  r   r  r  r  r  r  r  r  r  r  r  cellnamerelr  sumrangename2drelrm  r!  r$  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  rc  rj  r  r  rf  r  r  r  r  rl  Zfmtr   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  Zokindr  r  r  r  r  r  r  r  r  r  r   r4  r  r  r  r#  r  r  r  r  r  r  Zovaluerb  r   r  r   r   P  s   







	  
	 
	 













(








*

*



"












 





 
























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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sfJ |		 }|		 }|||  |rt d|	| jd nH|dkr8|rt d|	| jd t|	dksJ |		 }|		 }t|dksJ t|dksJ t
t|d |d }|| |rt d|	| jd n|dkr|rXt d|	| jd t|	dksjJ |		 }|		 }t|dksJ t|dksJ 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v 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   rQ  rE   rn   rn  r5   r(   ro  r   r$   r   r  r'   ru  z
tlist postr-   rw  ry  r,   rr  rt  r=   r  r%   r  rY   r  rh   rD   rz  r{  z**** Dud size; exiting ****rB   rK  r  z   FuncID=%dr  r   r   r  r4   r  z   namex=%dr:   r  rP   )r   r  rd   rj   r6   rk   z   refx=%d namex=%dr  z.End of formula. any_rel=%d any_err=%d stack=%rr  )r  r  r  r   r  rX  r  r  r   rT  r   r  r  r  r0  r
   r  r  r  r  r!  r  )4r  r   r  r  r   r  Zisnamer  r  r  r  r  r  r  rf  r  r  r  r  r   r   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  r  r  r  r  r  r  r   r   r   r   ^  s,   





"





&
*$











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]rJ   z%dr   r   )r   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]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    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  )r   r   r  r   r   r   r   "  s    r   c           	      C   s`   |s|st | ||S |r |d u s,|r0|d u 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'``ZABCDEFGHIJKLMNOPQRSTUVWXYZr=   rj   r   N)r  )r   ZalphabetZxdiv26Z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}|s4|r@|d u 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   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$   rY   )r   
sheetranger  )bookr  r   r   r   r   r   R  s
    r   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$   rY   r  )r   r4  sheetrangerelr  )	r  r  r   r   r  r   r4  shdescZrngdescr   r   r   r   ^  s    	 r   c                 C   s`   |dkr| | }nddddd |d| }d|v rHd|dd	 d S d
|v 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''rs  )r0  r  )shnamesZshxZshnamer   r   r   quotedsheetnameo  s    
r  c                 C   s8   |   }t||}||d kr4|dt||d  7 }|S )Nr   rx  )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|sLJ dS )Nr   r   rH   )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   )ur2  Z
__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  r0  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  r!  r$  	Exceptionr%  objectr"   r   r#   ZtAddZtSubZtMulZtDivZtPowerZtConcatrangeZtLTZtLEZtEQZtGEZtGTZtNEr7  r:  r<  r=  r>  r?  r@  rA  rE  r  Z_arith_argdictZ_cmp_argdictZ_strg_argdictaddsubmultruedivrU  re  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>   sP   







  
  &\A	    e      %	