U
    dp                   @   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SHAREDARRAYzCOND-FMTzDATA-VALNAME)r   r$   r%   r&   r'   r(   )r   r$      r'      r(   #   9   :   ;   ,   -         oMSNG)r8   r7   r   r   r$   r5   r%   r6   ,	         r-            )   r@      (   r4   2   F   P   ZUnk00ZExpZTblZAddZSubZMulZDivZPowerZConcatLTZLEZEQZGEGTZNEZIsectListZRangeZUplusZUminusZPercentZParenZMissArgZStrZExtendedZAttrZSheetZEndSheetZErrZBoolZIntZNum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   rB   r%   r   VR)ZIFr$   r5   r%   r5   rM   VRR)ZISNAr   r   r$   r   rM   rM   )ZISERRORr   r   r$   r   rM   rM   )ZSUMr   rB   r%   r   rM   rN   )ZAVERAGEr   rB   r%   r   rM   rN   )ZMINr   rB   r%   r   rM   rN   )MAXr   rB   r%   r   rM   rN   )ZROWr   r   r%   r   rM   rN   )ZCOLUMNr   r   r%   r   rM   rN   )ZNAr   r   r$   r   rM   rL   )ZNPVr$   rB   r%   r$   rM   VR)ZSTDEVr   rB   r%   r   rM   rN   )ZDOLLARr   r$   r%   r   rM   rM   )ZFIXEDr$   r5   r%   r5   rM   VVV)ZSINr   r   r$   r   rM   rM   )ZCOSr   r   r$   r   rM   rM   )ZTANr   r   r$   r   rM   rM   )ZATANr   r   r$   r   rM   rM   )PIr   r   r$   r   rM   rL   )ZSQRTr   r   r$   r   rM   rM   )ZEXPr   r   r$   r   rM   rM   )LNr   r   r$   r   rM   rM   )ZLOG10r   r   r$   r   rM   rM   )ZABSr   r   r$   r   rM   rM   )INTr   r   r$   r   rM   rM   )ZSIGNr   r   r$   r   rM   rM   )ZROUNDr$   r$   r$   r$   rM   VV)ZLOOKUPr$   r5   r%   r$   rM   rQ   )ZINDEXr$   r%      r%   rN   ZRVVV)ZREPTr$   r$   r$   r$   rM   rV   )ZMIDr5   r5   r$   r5   rM   rR   )ZLENr   r   r$   r   rM   rM   )ZVALUEr   r   r$   r   rM   rM   )TRUEr   r   r$   r   rM   rL   )FALSEr   r   r$   r   rM   rL   )ANDr   rB   r%   r   rM   rN   )ORr   rB   r%   r   rM   rN   )ZNOTr   r   r$   r   rM   rM   )ZMODr$   r$   r$   r$   rM   rV   )ZDCOUNTr5   r5   r$   r5   rM   RRR)ZDSUMr5   r5   r$   r5   rM   r\   )ZDAVERAGEr5   r5   r$   r5   rM   r\   )ZDMINr5   r5   r$   r5   rM   r\   )ZDMAXr5   r5   r$   r5   rM   r\   )ZDSTDEVr5   r5   r$   r5   rM   r\   )ZVARr   rB   r%   r   rM   rN   )ZDVARr5   r5   r$   r5   rM   r\   )ZTEXTr$   r$   r$   r$   rM   rV   )ZLINESTr   r%   r%   r%   ARRVV)ZTRENDr   r%   r%   r%   r]   RRRV)ZLOGESTr   r%   r%   r%   r]   r^   )ZGROWTHr   r%   r%   r%   r]   r_   )ZPVr5   r6   r%   r6   rM   VVVVV)ZFVr5   r6   r%   r6   rM   r`   )ZNPERr5   r6   r%   r6   rM   r`   )ZPMTr5   r6   r%   r6   rM   r`   )ZRATEr5      r%   ra   rM   VVVVVV)ZMIRRr5   r5   r$   r5   rM   ZRVV)ZIRRr   r$   r%   r$   rM   RV)ZRANDr   r   
   r   rM   rL   )MATCHr$   r5   r%   r5   rM   rO   )ZDATEr5   r5   r$   r5   rM   rR   )ZTIMEr5   r5   r$   r5   rM   rR   )ZDAYr   r   r$   r   rM   rM   )ZMONTHr   r   r$   r   rM   rM   )ZYEARr   r   r$   r   rM   rM   )ZWEEKDAYr   r$   r%   r$   rM   rV   )ZHOURr   r   r$   r   rM   rM   )ZMINUTEr   r   r$   r   rM   rM   )ZSECONDr   r   r$   r   rM   rM   )ZNOWr   r   rd   r   rM   rL   )ZAREASr   r   r$   r   rM   rN   )ZROWSr   r   r$   r   rM   rN   )COLUMNSr   r   r$   r   rM   rN   )ZOFFSETr5   r6   r%   r6   rN   ZRVVVV)ZSEARCHr$   r5   r%   r5   rM   rR   )Z	TRANSPOSEr   r   r$   r   r]   r]   )ZTYPEr   r   r$   r   rM   rM   )Z	SERIESSUMr%   r%   r$   r%   rM   ZVVVA)ZATAN2r$   r$   r$   r$   rM   rV   )ZASINr   r   r$   r   rM   rM   )ZACOSr   r   r$   r   rM   rM   )ZCHOOSEr$   rB   r%   r$   rM   rQ   )ZHLOOKUPr5   r%   r%   r%   rM   VRRV)ZVLOOKUPr5   r%   r%   r%   rM   rg   )ZISREFr   r   r$   r   rM   rN   )ZLOGr   r$   r%   r$   rM   rV   )ZCHARr   r   r$   r   rM   rM   )ZLOWERr   r   r$   r   rM   rM   )ZUPPERr   r   r$   r   rM   rM   )ZPROPERr   r   r$   r   rM   rM   )LEFTr   r$   r%   r$   rM   rV   )RIGHTr   r$   r%   r$   rM   rV   )ZEXACTr$   r$   r$   r$   rM   rV   )ZTRIMr   r   r$   r   rM   rM   )ZREPLACEr%   r%   r$   r%   rM   VVVV)Z
SUBSTITUTEr5   r%   r%   r%   rM   rj   )ZCODEr   r   r$   r   rM   rM   )ZFINDr$   r5   r%   r5   rM   rR   )r*   r   r$   rW   r$   rM   rQ   )ZISERRr   r   r$   r   rM   rM   )ZISTEXTr   r   r$   r   rM   rM   )ZISNUMBERr   r   r$   r   rM   rM   )ZISBLANKr   r   r$   r   rM   rM   )Tr   r   r$   r   rM   rN   )Nr   r   r$   r   rM   rN   )Z	DATEVALUEr   r   r$   r   rM   rM   )Z	TIMEVALUEr   r   r$   r   rM   rM   )ZSLNr5   r5   r$   r5   rM   rR   )ZSYDr%   r%   r$   r%   rM   rj   )ZDDBr%   r6   r%   r6   rM   r`   )ZINDIRECTr   r$   rW   r$   rN   rV   )ZCLEANr   r   r$   r   rM   rM   )ZMDETERMr   r   r$   r   rM   r]   )ZMINVERSEr   r   r$   r   r]   r]   )ZMMULTr$   r$   r$   r$   r]   AA)ZIPMTr%   ra   r%   ra   rM   rb   )ZPPMTr%   ra   r%   ra   rM   rb   )ZCOUNTAr   rB   r%   r   rM   rN   )ZPRODUCTr   rB   r%   r   rM   rN   )ZFACTr   r   r$   r   rM   rM   )ZDPRODUCTr5   r5   r$   r5   rM   r\   )Z	ISNONTEXTr   r   r$   r   rM   rM   )ZSTDEVPr   rB   r%   r   rM   rN   )ZVARPr   rB   r%   r   rM   rN   )ZDSTDEVPr5   r5   r$   r5   rM   r\   )ZDVARPr5   r5   r$   r5   rM   r\   )ZTRUNCr   r$   r%   r$   rM   rV   )Z	ISLOGICALr   r   r$   r   rM   rM   )ZDCOUNTAr5   r5   r$   r5   rM   r\   )ZUSDOLLARr   r$   r%   r$   rM   rV   )ZFINDBr$   r5   r%   r5   rM   rR   )ZSEARCHBr$   r5   r%   r5   rM   rR   )ZREPLACEBr%   r%   r$   r%   rM   rj   )ZLEFTBr   r$   r%   r$   rM   rV   )ZRIGHTBr   r$   r%   r$   rM   rV   )ZMIDBr5   r5   r$   r5   rM   rR   )ZLENBr   r   r$   r   rM   rM   )ZROUNDUPr$   r$   r$   r$   rM   rV   )Z	ROUNDDOWNr$   r$   r$   r$   rM   rV   )ASCr   r   r$   r   rM   rM   )ZDBCSr   r   r$   r   rM   rM   )ZRANKr$   r5   r%   r5   rM   ZVRV)ZADDRESSr$   r6   r%   r6   rM   r`   )ZDAYS360r$   r5   r%   r5   rM   rR   )ZTODAYr   r   rd   r   rM   rL   )ZVDBr6   r<   r%   r<   rM   ZVVVVVVV)ZMEDIANr   rB   r%   r   rM   rN   )Z
SUMPRODUCTr   rB   r%   r   rM   r]   )ZSINHr   r   r$   r   rM   rM   )ZCOSHr   r   r$   r   rM   rM   )ZTANHr   r   r$   r   rM   rM   )ZASINHr   r   r$   r   rM   rM   )ZACOSHr   r   r$   r   rM   rM   )ZATANHr   r   r$   r   rM   rM   )ZDGETr5   r5   r$   r5   rM   r\   )INFOr   r   r$   r   rM   rM   )ZDBr%   r6   r%   r6   rM   r`   )Z	FREQUENCYr$   r$   r$   r$   r]   ZRR)z
ERROR.TYPEr   r   r$   r   rM   rM   )ZAVEDEVr   rB   r%   r   rM   rN   )ZBETADISTr5   r6   r%   r   rM   rM   )ZGAMMALNr   r   r$   r   rM   rM   )ZBETAINVr5   r6   r%   r   rM   rM   )Z	BINOMDISTr%   r%   r$   r%   rM   rj   )ZCHIDISTr$   r$   r$   r$   rM   rV   )ZCHIINVr$   r$   r$   r$   rM   rV   )ZCOMBINr$   r$   r$   r$   rM   rV   )Z
CONFIDENCEr5   r5   r$   r5   rM   rR   )Z	CRITBINOMr5   r5   r$   r5   rM   rR   )ZEVENr   r   r$   r   rM   rM   )Z	EXPONDISTr5   r5   r$   r5   rM   rR   )ZFDISTr5   r5   r$   r5   rM   rR   )ZFINVr5   r5   r$   r5   rM   rR   )ZFISHERr   r   r$   r   rM   rM   )Z	FISHERINVr   r   r$   r   rM   rM   )ZFLOORr$   r$   r$   r$   rM   rV   )Z	GAMMADISTr%   r%   r$   r%   rM   rj   )ZGAMMAINVr5   r5   r$   r5   rM   rR   )ZCEILINGr$   r$   r$   r$   rM   rV   )ZHYPGEOMDISTr%   r%   r$   r%   rM   rj   )ZLOGNORMDISTr5   r5   r$   r5   rM   rR   )ZLOGINVr5   r5   r$   r5   rM   rR   )ZNEGBINOMDISTr5   r5   r$   r5   rM   rR   )ZNORMDISTr%   r%   r$   r%   rM   rj   )Z	NORMSDISTr   r   r$   r   rM   rM   )ZNORMINVr5   r5   r$   r5   rM   rR   )ZNORMSINVr   r   r$   r   rM   rM   )ZSTANDARDIZEr5   r5   r$   r5   rM   rR   )ZODDr   r   r$   r   rM   rM   )ZPERMUTr$   r$   r$   r$   rM   rV   )ZPOISSONr5   r5   r$   r5   rM   rR   )ZTDISTr5   r5   r$   r5   rM   rR   )ZWEIBULLr%   r%   r$   r%   rM   rj   )ZSUMXMY2r$   r$   r$   r$   rM   rm   )ZSUMX2MY2r$   r$   r$   r$   rM   rm   )ZSUMX2PY2r$   r$   r$   r$   rM   rm   )ZCHITESTr$   r$   r$   r$   rM   rm   )ZCORRELr$   r$   r$   r$   rM   rm   )ZCOVARr$   r$   r$   r$   rM   rm   )ZFORECASTr5   r5   r$   r5   rM   ZVAA)ZFTESTr$   r$   r$   r$   rM   rm   )Z	INTERCEPTr$   r$   r$   r$   rM   rm   )ZPEARSONr$   r$   r$   r$   rM   rm   )ZRSQr$   r$   r$   r$   rM   rm   )ZSTEYXr$   r$   r$   r$   rM   rm   )ZSLOPEr$   r$   r$   r$   rM   rm   )ZTTESTr%   r%   r$   r%   rM   ZAAVV)ZPROBr5   r%   r%   r5   rM   ZAAV)ZDEVSQr   rB   r%   r   rM   rN   )ZGEOMEANr   rB   r%   r   rM   rN   )ZHARMEANr   rB   r%   r   rM   rN   )ZSUMSQr   rB   r%   r   rM   rN   )ZKURTr   rB   r%   r   rM   rN   )ZSKEWr   rB   r%   r   rM   rN   )ZZTESTr$   r5   r%   r$   rM   rc   )ZLARGEr$   r$   r$   r$   rM   rc   )ZSMALLr$   r$   r$   r$   rM   rc   )ZQUARTILEr$   r$   r$   r$   rM   rc   )Z
PERCENTILEr$   r$   r$   r$   rM   rc   )ZPERCENTRANKr$   r5   r%   r$   rM   rc   )ZMODEr   rB   r%   r   rM   r]   )ZTRIMMEANr$   r$   r$   r$   rM   rc   )ZTINVr$   r$   r$   r$   rM   rV   )ZCONCATENATEr   rB   r%   r   rM   rM   )ZPOWERr$   r$   r$   r$   rM   rV   )ZRADIANSr   r   r$   r   rM   rM   )ZDEGREESr   r   r$   r   rM   rM   )ZSUBTOTALr$   rB   r%   r$   rM   rQ   )ZSUMIFr$   r5   r%   r5   rM   ZRVR)ZCOUNTIFr$   r$   r$   r$   rM   rc   )Z
COUNTBLANKr   r   r$   r   rM   rN   )ZISPMTr%   r%   r$   r%   rM   rj   )ZDATEDIFr5   r5   r$   r5   rM   rR   )Z
DATESTRINGr   r   r$   r   rM   rM   )ZNUMBERSTRINGr$   r$   r$   r$   rM   rV   )ZROMANr   r$   r%   r$   rM   rV   )ZGETPIVOTDATAr$   r$   r$   r$   rM   rc   )Z	HYPERLINKr   r$   r%   r$   rM   rV   )ZPHONETICr   r   r$   r   rM   rM   )ZAVERAGEAr   rB   r%   r   rM   rN   )ZMAXAr   rB   r%   r   rM   rN   )ZMINAr   rB   r%   r   rM   rN   )ZSTDEVPAr   rB   r%   r   rM   rN   )ZVARPAr   rB   r%   r   rM   rN   )ZSTDEVAr   rB   r%   r   rM   rN   )ZVARAr   rB   r%   r   rM   rN   )ZBAHTTEXTr   r   r$   r   rM   rM   )ZTHAIDAYOFWEEKr   r   r$   r   rM   rM   )Z	THAIDIGITr   r   r$   r   rM   rM   )ZTHAIMONTHOFYEARr   r   r$   r   rM   rM   )ZTHAINUMSOUNDr   r   r$   r   rM   rM   )ZTHAINUMSTRINGr   r   r$   r   rM   rM   )ZTHAISTRINGLENGTHr   r   r$   r   rM   rM   )ZISTHAIDIGITr   r   r$   r   rM   rM   )ZROUNDBAHTDOWNr   r   r$   r   rM   rM   )ZROUNDBAHTUPr   r   r$   r   rM   rM   )ZTHAIYEARr   r   r$   r   rM   rM   )ZRTDr$   r6   r%   r   rM   rM   (  r   r   r$   r5   r%   r6   ra   r<   r&   r;   rd   r=   rW         r-   r'   r.   r?      rA   r@            r>               rB      r(   !   "   r/   $   %   &   '   rC   )   *   +   r3   r4   .   /   0   1   rD   3   4   8   r0   r1   r2   <   =   >   r)   @   A   B   C   D   E   rE   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   rd   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   0/tmp/pip-unpacked-wheel-zwq1az3t/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 )NrF   <HHr%   z<HBr5   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 )NrF   z<HHHHr&   z<HHBBra   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r7   r7   i  z</// get_externsheet_local_range(refx=%d) -> deleted sheet(s)r8   r8   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    



&

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  r7   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*    
 

r1  c                   @   s   e Zd ZdS )FormulaErrorN)__name__
__module____qualname__r   r   r   r   r2    s   r2  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   getr7  r8  r:  )r;  Z	kind_textr   r   r   __repr__l  s    zOperand.__repr__)NNr   r6  )
r3  r4  r5  __doc__r8  r   r7  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   ra   rW   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 )Nr@  zRef3D(coords=%r)zRef3D(coords=%r, relflags=%r))rA  r   )r;  r   r   r   r>    s
    
zRef3D.__repr__N)r3  r4  r5  r?  r<  r>  r   r   r   r   r#   r  s   0	ra   c                 C   s   | S r   r   xr   r   r   nop  s    rD  c                 C   s   | | S r   r   rC  yr   r   r   _opr_pow      rG  c                 C   s   | |k S r   r   rE  r   r   r   _opr_lt  rH  rI  c                 C   s   | |kS r   r   rE  r   r   r   _opr_le  rH  rJ  c                 C   s   | |kS r   r   rE  r   r   r   _opr_eq  rH  rK  c                 C   s   | |kS r   r   rE  r   r   r   _opr_ge  rH  rL  c                 C   s   | |kS r   r   rE  r   r   r   _opr_gt  rH  rM  c                 C   s   | |kS r   r   rE  r   r   r   _opr_ne  rH  rN  c                 C   s"   t | }|dr|dd }|S )zN
    Attempt to emulate Excel's default conversion from number to string.
    z.0Nr8   )strendswith)numsr   r   r   num2strg  s    
rS  rB   +-rC   r   /rD   ^rA   &<z<==z>=>z<>c                 C   s   |  S r   r   rB  r   r   r   <lambda>  rH  r\  rE   c                 C   s   | S r   r   rB  r   r   r   r\    rH  c                 C   s   | d S )Ng      Y@r   rB  r   r   r   r\    rH  r   %)rr   r?   rA   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$   rL   ()r   r   )r!  r#  popbinop_rulesjoinr9  r:  r"   r7  KeyErrorappendr8  r   )opcdstkbopaopargdictresult_kindr   r9  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   rL   r`  ra  )
r!  r#  rb  r8  
unop_rulesrd  r9  r:  rf  r"   )
opcoderl  rh  rj  valr   r9  sym1sym2rn  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)r2  Zop_argZ	oname_argmsgr   r   r   not_in_name_formula7  s    z2evaluate_name_formula.<locals>.not_in_name_formularz   `   r6   r(   9Pos:%d Op:0x%02x Name:t%s Sz:%d opcode:%02xh optype:%02xhStack =r8   9ERROR *** Unexpected token 0x%02x ("%s"); biff_version=%dr$   r5   rq   r-   
tIsect pre rF   rL   r`  ra  tIsect postr'   	tList prer:   
tList postr.   
tRange pre:tRange postr?   rA   r@   rs   rt   rE   Zlenlen   sz=%d strg=%r"""ru   tExtended token not implementedr>   <BHr%   ??Unknown??ra   tAttrSumr7   SUM(%s))   subop=%02xh subname=t%s sz=%d nc=%02xhrv   rw   rD   )tSheet & tEndsheet tokens not implementedrx   r&   rY  BBHdrY   rX   Unhandled opcode: 0x%02xSize not set for opcode 0x%02xrC    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 formularW   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   rf  	BYTES_ORDonamesr2  r!  r#  rb  rd  r9  r:  r   r7  r8  r   tIsectFuncsr#   r   rA  tRangeFuncsr   r9   	LEAF_RANKr	   encodingr
   replacer   r   
tAttrNamesr=  	FUNC_RANKr   floatrO  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  r.  r1  r   r   _externsheet_type_b57error_opcodesZfprintfrp  any_external)Wr%  Znobjnamexr'  levelr  fmlalenr  r  sztabr  r  r  r  r  unk_opnd
error_opndspushrq  rx  r{  oprt  optypeopxonameszrz  ri  rj  rm  r9  rn  resr   ZrelfaZrelfbstrgnewposr:  subopncsubnameinxnbr7  r8  funcx
func_attrs	func_namenargsargtextpromptr  minargsmaxargsZtestargZresposZchosentgtnamextgtobjr  r  r  r  shx1shx2rA  r  r  rowx1colx1row_rel1col_rel1rowx2colx2row_rel2col_rel2r&  r0  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   r_  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$   rL   r`  ra  )	r!  r#  rb  rc  rd  r9  r:  r"   rf  )rg  rh  ri  rj  rk  rl  r   r9  rm  rn  ro  r   r   r   rq  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 rr  )	r!  r#  rb  rs  rd  r9  r:  rf  r"   )	rt  rl  rh  rj  r   r9  rv  rw  rn  r   r   r   rx  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"  ry  r%  fmlatyper   r   unexpected_opcode  s    z,decompile_formula.<locals>.unexpected_opcoderz   r|  r6   r(   z;Pos:%d Op:0x%02x opname:t%s Sz:%d opcode:%02xh optype:%02xhr~  r8   r  rB   z<x2Hz<xHBzSHARED FMLA at rowx=%d colx=%dr5   rq   r-   r  r$   r  rF   rL   r`  ra  r  r'   r  r:   r  r.   r  r  r  r?   rA   r@   rs   rt   rE   r  r  r  r  ru   r  r>   r  r%   r  ra   r  r7   r  r  rv   rw   rD   r  rx   r&   rY  r  r  r  r  rC   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   rB   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  rW   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   rf  r  r  r2  _TOKEN_NOT_ALLOWEDr#  r   r  r   r   r!  rb  rd  r9  r:  r   r7  r   r   r9   r	   r  r
   r  r   r  r=  r  r   r  rO  r   r  r  r  r  r  r  r  r  r  r  cellnamerelr  sumrangename2drelr{  r.  r1  r#   r   r   r8  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  rq  rx  r  r  rt  r  r  r  r  rz  fmtr  r  r:  ri  rj  rm  r9  rn  r  r  r  r  r  r  r  r  r7  r8  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   rA  r&  r  r  r0  r  r  r  r  r  r	  Zovaluerp  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   r_  rF   rz   r|  r6   r(   r}  r   r$   r
  r  r'   r  z
tlist postr.   r  r  r-   r  r  r>   r  r%   r  ra   r  rt   rE   r  r  z**** Dud size; exiting ****rC   rY  r  z   FuncID=%dr  r   r   r  r5   r  z   namex=%dr;   r  rW   )r  r  rp   rv   r7   rw   z   refx=%d namex=%dr  z.End of formula. any_rel=%d any_err=%d stack=%rr  )r   r!  r"  r   r#  r  rf  r  r  r   rb  r   r  r  r  r=  r
   r  r  r  r  r.  r  )4r%  r  r  r  r  r'  Zisnamer  r  r  r  r  r  r  rt  r  r  r  r  r  r  ri  rj  rp  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]rN   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$   ra   )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$   ra   r  )r   rA  sheetrangerelr  )	r%  r  r  r  r  r   rA  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>>)r7   r8   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   rL   )r$  r#  )r%  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   )ur?  
__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   r9   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.  r1  	Exceptionr2  objectr"   r   r#   ZtAddZtSubZtMulZtDivZtPowerZtConcatrangeZtLTZtLEZtEQZtGEZtGTZtNErD  rG  rI  rJ  rK  rL  rM  rN  rS  r  Z_arith_argdictZ_cmp_argdictZ_strg_argdictaddsubmultruedivrc  rs  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              %

	
