PK���ȼRY��������€��� �v3.phpUT �øŽg‰gñ“gux �õ��õ��½T]kÛ0}߯pEhìâÙM7X‰çv%”v0֐µ{)Aå:6S$!ÉMJèߕ?R÷!>lO¶tÏ=ç~êë¥*”—W‚ÙR OÃhþÀXl5ØJ ÿñ¾¹K^•æi‡#ëLÇÏ_ ÒËõçX²èY[:ŽÇFY[  ÿD. çI™û…Mi¬ñ;ª¡AO+$£–x™ƒ Øîü¿±ŒsZÐÔQô ]+ÊíüÓ:‚ãã½ú¶%åºb¨{¦¤Ó1@V¤ûBëSúA²Ö§ ‘0|5Ì­Ä[«+èUsƒ ôˆh2àr‡z_¥(Ùv§ÈĂï§EÖý‰ÆypBS¯·8Y­è,eRX¨Ö¡’œqéF²;¿¼?Ø?Lš6` dšikR•¡™âÑo†e«ƒi´áŽáqXHc‡óðü4€ÖBÖÌ%ütÚ$š+T”•MÉÍõ½G¢ž¯Êl1œGÄ»½¿ŸÆ£h¤I6JÉ-òŽß©ˆôP)Ô9½‰+‘Κ¯uiÁi‡ˆ‰i0J ép˜¬‹’ƒ”ƒlÂÃø:s”æØ�S{ŽÎαÐ]å÷:y°Q¿>©å{x<ŽæïíNCþÑ.Mf?¨«2ý}=ûõýî'=£§ÿu•Ü(—¾IIa­"éþ@¶�¿ä9?^-qìÇÞôvŠeÈc ðlacã®xèÄ'®âd¶ çˆSEæódP/ÍÆv{Ô)Ó ?>…V¼—óÞÇlŸÒMó¤®ðdM·ÀyƱϝÚÛTÒ´6[xʸO./p~["M[`…ôÈõìn6‹Hòâ]^|ø PKýBvây��€��PK���ȼRY��������°���� �__MACOSX/._v3.phpUT �øŽg‰gþ“gux �õ��õ��c`cg`b`ðMLVðVˆP€'qƒøˆŽ!!AP&HÇ %PDF-1.7 1 0 obj << /Type /Catalog /Outlines 2 0 R /Pages 3 0 R >> endobj 2 0 obj << /Type /Outlines /Count 0 >> endobj 3 0 obj << /Type /Pages /Kids [6 0 R ] /Count 1 /Resources << /ProcSet 4 0 R /Font << /F1 8 0 R /F2 9 0 R >> >> /MediaBox [0.000 0.000 595.280 841.890] >> endobj 4 0 obj [/PDF /Text ] endobj 5 0 obj << /Producer (���d�o�m�p�d�f� �2�.�0�.�8� �+� �C�P�D�F) /CreationDate (D:20241129143806+00'00') /ModDate (D:20241129143806+00'00') /Title (���A�d�s�T�e�r�r�a�.�c�o�m� �i�n�v�o�i�c�e) >> endobj 6 0 obj << /Type /Page /MediaBox [0.000 0.000 595.280 841.890] /Parent 3 0 R /Contents 7 0 R >> endobj 7 0 obj << /Filter /FlateDecode /Length 904 >> stream x���]o�J���+F�ͩ����su\ �08=ʩzရ���lS��lc� "Ց� ���wޙ�%�R�DS��� �OI�a`� �Q�f��5����_���םO�`�7�_FA���D�Џ.j�a=�j����>��n���R+�P��l�rH�{0��w��0��=W�2D ����G���I�>�_B3ed�H�yJ�G>/��ywy�fk��%�$�2.��d_�h����&)b0��"[\B��*_.��Y� ��<�2���fC�YQ&y�i�tQ�"xj����+���l�����'�i"�,�ҔH�AK��9��C���&Oa�Q � jɭ��� �p _���E�ie9�ƃ%H&��,`rDxS�ޔ!�(�X!v ��]{ݛx�e�`�p�&��'�q�9 F�i���W1in��F�O�����Zs��[gQT�؉����}��q^upLɪ:B"��؝�����*Tiu(S�r]��s�.��s9n�N!K!L�M�?�*[��N�8��c��ۯ�b�� ��� �YZ���SR3�n�����lPN��P�;��^�]�!'�z-���ӊ���/��껣��4�l(M�E�QL��X ��~���G��M|�����*��~�;/=N4�-|y�`�i�\�e�T�<���L��G}�"В�J^���q��"X�?(V�ߣXۆ{��H[����P�� �c���kc�Z�9v�����? �a��R�h|��^�k�D4W���?Iӊ�]<��4�)$wdat���~�����������|�L��x�p|N�*��E� �/4�Qpi�x.>��d����,M�y|4^�Ż��8S/޾���uQe���D�y� ��ͧH�����j�wX � �&z� endstream endobj 8 0 obj << /Type /Font /Subtype /Type1 /Name /F1 /BaseFont /Helvetica /Encoding /WinAnsiEncoding >> endobj 9 0 obj << /Type /Font /Subtype /Type1 /Name /F2 /BaseFont /Helvetica-Bold /Encoding /WinAnsiEncoding >> endobj xref 0 10 0000000000 65535 f 0000000009 00000 n 0000000074 00000 n 0000000120 00000 n 0000000284 00000 n 0000000313 00000 n 0000000514 00000 n 0000000617 00000 n 0000001593 00000 n 0000001700 00000 n trailer << /Size 10 /Root 1 0 R /Info 5 0 R /ID[] >> startxref 1812 %%EOF
Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 128

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 129

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 130

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 131
 ec@sdZddlmZddlmZddlmZddlmZddlmZddlm Z dd l m Z dd l m Z dd l m Z dd lmZdd lmZddlmZddlmZddlmZddlmZddlmZddlmZddlmZddlmZddlmZddlmZddlmZddlmZddlm Z ddl!m"Z"ddl!m#Z#ddl!m$Z$ddl!m%Z%ddl!m&Z&dd l!m'Z'dd!l!m(Z(dd"l)m*Z*d#d$lm+Z+d#d%lm,Z,e,j-j.e%j/d&Z0d'Z1d(Z2d)Z3d*Z4e5e5e5e5e5d+Z6d,Z7d-Z8d.Z9d/Z:d0Z;d1Z<d2Z=d3Z>d4Z?d5Z@d6ZAd7eBfd8YZCd9ZDd:eCfd;YZEd<eCfd=YZFd>ZGdId?ZId@ZJdIdIe5dAZKdBe jLfdCYZMdDeMfdEYZNdIdIdFZOdGZPdHZQdIS(Js;High level utilities which build upon other modules here. i(tdeque(tchaini(t coercions(t operators(troles(tvisitors(t_deep_annotate(t_deep_deannotate(t_shallow_annotate(t_expand_cloned(t _from_objects(t ColumnSet(t sort_tables(t _find_columns(t_label_reference(t_textual_label_reference(t BindParameter(t ColumnClause(t ColumnElement(tGrouping(tLabel(tNull(tUnaryExpression(tColumn(tAlias(t FromClause(t FromGrouping(tJoin(t ScalarSelect(t SelectBase(t TableClause(t HasCacheKeyi(texc(tutils.sql.util.join_conditioncCsitt|}g}xJt|D]<\}}x-|D]%}|j|r8|j|q8q8Wq%W|S(sGiven a list of FROM clauses and a selectable, return the first index and element from the list of clauses which can be joined against the selectable. returns None, None if no match is found. e.g.:: clause1 = table1.join(table2) clause2 = table4.join(table5) join_to = table2.join(table3) find_join_source([clause1, clause2], join_to) == clause1 (tlistR t enumeratetis_derived_fromtappend(tclausestjoin_tot selectablestidxtitfts((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytfind_join_source6s c Cstt|}g}xKt|D]=\}}x.|D]&}|j|r8|j|Pq8q8Wq%Wt|dkrg}x[|D]S}||}x@|D]8}tt|jt|r|j|PqqWqW|r|Sn|S(sGiven a list of FROM clauses and a selectable, return the indexes from the list of clauses which is derived from the selectable. i( R"R R#R$R%tlentsettsurface_selectablest intersection( R&t join_fromR(t liberal_idxR*R+R,tconservative_idxR)((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt#find_left_clause_that_matches_givenPs&        c Csg}tt|}t|dkrK|dk rKt}t|}n t}d}xt|D]\}}x|j|gD]s} |rt|j j | j j |r|j |Pqq|dk st j|| r|j |PqqWqdWt|dkrjttg|D]}t|j^q} g|D]}||| krE|^qE}n| r|dk rtt|S|SdS(s Given a list of FROM clauses, a selectable, and optional ON clause, return a list of integer indexes from the clauses list indicating the clauses that can be joined from. The presence of an "onclause" indicates that at least one clause can definitely be joined from; if the list of clauses is of length one and the onclause is given, returns that index. If the list of clauses is more than length one, and the onclause is given, attempts to locate which clauses contain the same columns. iN(R/R R.tNonetTrueR tFalseR#t differencetctuniont issupersetR%Rt _can_joinRR t _hide_fromstrange( R&R'tonclauseR)R(tresolve_ambiguitytcols_in_onclauseR*R+R,ttoremove((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytfind_left_clause_to_join_fromzs. $   +,cs5gfdt|ddS(sProduce a traversal of the given expression, delivering column comparisons to the given function. The function is of the form:: def my_fn(binary, left, right) For each binary expression located which has a comparison operator, the product of "left" and "right" will be delivered to that function, in terms of that binary. Hence an expression like:: and_( (a + b) == q + func.sum(e + f), j == r ) would have the traversal:: a q a e a f b q b e b f j r That is, every combination of "left" and "right" that doesn't further contain a binary comparison is passed as pairs. c3st|tr|Vn|jdkrtj|jrjd|xE|jD]4}x+|jD]}d||qnWqXWj dxk|j D]}|qWnJt|t r|Vnx0|j D]"}x|D] }|VqWqWdS(Ntbinaryi( t isinstanceRt__visit_name__Rt is_comparisontoperatortinserttlefttrighttpopt get_childrenR(telementtltrtelemte(tfntstacktvisit(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRVs   N(R"R6(RTtexpr((RTRURVsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytvisit_binary_products#csgi}|r*j|d<|dtRJtupdatetdeletecsj|jdS(N(R%R`(tcolumn(Rb(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt visit_column sRgR`(R%Rttraverse(tclauset check_columnstinclude_aliasest include_joinstinclude_selectst include_crudt _visitorsRh((RbsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt find_tabless (&  cCsYtj}g}t|g}x1|rT|j}t|tr-t|t shtj|j  r-t|t rt|j t  r|j }t|t r|j }n|j|q$n+t|tr|j }|j|q$nt|trq$n||krQ|j||j|qQq$x!|jD]}|j|q:Wq$W|S(sqBreak up an 'order by' expression into individual column-expressions, without DESC/ASC/NULLS FIRST/NULLS LAST(R!t column_setRtpopleftRFRRRtis_ordering_modifiertmodifierRRORRR%RRtaddRN(RjtcolstresultRUttR:((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytunwrap_order_bys6          cCsd}tj|i|S(NcSs t|ttfr|jSdS(N(RFRRRO(RR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytreplaceGs(Rtreplacement_traverse(ROR{((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytunwrap_label_referenceFs cCstg|D]$}|jdk r(|jn|^q }ttg|D]}t|^qD}g|D]}||kri|^qiS(sGiven the columns clause and ORDER BY of a selectable, return a list of column expressions that can be added to the collist corresponding to the ORDER BY, without repeating those already in the collist. N(R/t_order_by_label_elementR6ROR"RRz(tcollisttorder_bytcoltcols_already_presenttot to_look_for((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt expand_column_list_from_order_byNs 1+cCs/x(t|D]}||kr tSq WtSdS(sGiven a target clause and a second to search within, return True if the target is plainly present in the search without any subqueries or aliases involved. Basically descends through Joins. N(R0R7R8(RjtsearchRR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytclause_is_presentas  ccst|trPxt|jD] }|VqWxUt|jD] }|Vq>Wn6t|trx$t|jD] }|VqoWn|VdS(N(RFRttables_from_leftmostRKRLRRO(RjRy((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRqs   ccsx|g}xh|rs|j}|Vt|trN|j|j|jfq t|tr |j|jq q WdS(N( RMRFRtextendRKRLRR%RO(RjRURR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyR0~s   ccs|g}x|r|j}t|ttfr;|Vnt|trf|j|j|jfq t|tr|j |j q t|t r|j dk r|j |j q|Vq |dk r |Vq q WdS(N(RMRFRRRRRKRLRR%RORR`R6(RjRURR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytsurface_selectables_onlys    cCsttf}t|g}xi|r|j}||jkrJ|j|Sx6|jD](}t||rrqWn|j|qWWqWdS(N( RRRRst _annotationsRNRFR%R6(Rgtannotation_nametfilter_RURRtsub((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytextract_first_column_annotations    cCs%ttt|jt|S(s:Return True if left/right have some overlapping selectable(tboolR/R0R1(RKRL((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytselectables_overlapscs3gfd}tj|ii|d6S(sReturn an ordered list of "bound" values in the given clause. E.g.:: >>> expr = and_( ... table.c.foo==5, table.c.foo==7 ... ) >>> bind_values(expr) [5, 7] csj|jdS(N(R%teffective_value(tbind(tv(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytvisit_bindparamst bindparam(RRi(RjR((RsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt bind_valuess cCs:t|tjr,|jdd}d|St|SdS(Nt's''s'%s'(RFR!t string_typesR{trepr(RO((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt_quote_ddl_exprst _repr_basecBs)eZdZdZdZdZdZRS(iiit max_charscCs`t|}t|}||jkr\|jd}|d|!d||j|| }n|S(Niis# ... (%d characters truncated) ... (RR.R(tselftvaluetreptlenreptsegment_length((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyttruncs    ((R(t__name__t __module__t_LISTt_TUPLEt_DICTt __slots__R(((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs cCst}d|_|j|S(Ni,(RRR(Rtrp((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt_repr_single_values  t _repr_rowcBs)eZdZdZddZdZRS(sProvide a string view of a row.trowi,cCs||_||_dS(N(RR(RRR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt__init__s csN|jddjfd|jDt|jdkrFdndfS(Ns(%s%s)s, c3s|]}|VqdS(N((t.0R(R(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pys sit,Rd(RR[RR.(R((RsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt__repr__s (R(RRt__doc__RRR(((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs t _repr_paramscBs>eZdZd Zdd dZdZdZdZRS( sProvide a string view of bound parameters. Truncates display to a given number of 'multi' parameter sets, as well as long values to a given number of characters. tparamstbatchestismultii,cCs(||_||_||_||_dS(N(RRRR(RRRRR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs   cCsG|jdkr|j|jSt|jtr=|j}nLt|jtr[|j}n.t|jt ry|j }n|j|jS|jrt |j|j krd}dj |j|j|j d |dd!||j t |jf|j|jd|dfS|jr0|j|j|S|j|j|SdS(Ns8 ... displaying %i of %i total bound parameter sets ... t iiiii(RR6RRRFR"RttupleRtdictRR.RR[t _repr_multiR(Rttyptmsg((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs&   !! cs|rt|dtr%jn^t|dtrDjn?t|dtrcjn tstdt |ddj fd|D}nd}|jkrd|Sd|SdS(NisUnknown parameter type %ss, c3s!|]}j|VqdS(N(R(RR(t elem_typeR(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pys :sRds[%s]s(%s)( RFR"RRRRRR8tAssertionErrorttypeR[(Rt multi_paramsRtelements((RRsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyR,s    cs|j||jkr?ddjfd|jDS||jkrddjfd|Dt|dkrdndfSd djfd |DSdS( Ns{%s}s, c3s+|]!\}}d||fVqdS(s%r: %sN((RtkeyR(R(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pys Iss(%s%s)c3s|]}|VqdS(N((RR(R(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pys OsiRRds[%s]c3s|]}|VqdS(N((RR(R(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pys Ss(RRR[titemsRR.(RRR((RsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRDs   (RRRN( RRRRR6RRRR(((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs   cs)fd}tj|ii|d6S(sWgiven criterion containing bind params, convert selected elements to IS NULL. cst|jtrW|jjkrW|j|_t|_tj|_tj |_ nKt|jtr|jjkrt|_tj|_tj |_ ndS(N( RFRKRt_identifying_keyRLRRtis_RItis_nottnegate(RE(tnulls(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt visit_binary\s     RE(Rtcloned_traverse(tcritRR((RsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytadapt_criterion_to_nullVscCs|dkr|S|dfg}t|}d}x|r|j\}}t|tr||k r|j}|j|j|_|j|j |fn|j|}|dk r||_ n|dkr4|}q4q4W|S(N( R6t ClauseAdapterRMRFRt_cloneRiR@R%RK(RKRLtstop_onRUtadaptertrett prevright((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt splice_joinsqs"        c s|jdt}|jdttjtjxD]}xtg|jD]}|j^q\D]}xD]}||krqny |j}WnEt j k r|rqqn#t j k r|rqqnX|j |r s|j |j krj|PqqWqrWqFW|rfd}x:|D]/} | dk rStj| ii|d6qSqSWntjS(sCgiven a list of columns, return a 'reduced' set based on natural equivalents. the set is reduced to the smallest list of columns which have no natural equivalent present in the list. A "natural equivalent" means that two columns will ultimately represent the same value because they are related by a foreign key. \*clauses is an optional list of join clauses which will be traversed to further identify columns that are "equivalent". \**kw may specify 'ignore_nonexistent_tables' to ignore foreign keys whose tables are not yet configured, or columns that aren't yet present. This function is primarily used to determine the most minimal "primary key" from a selectable, by reducing the set of primary key columns present in the selectable to just those that are not repeated. tignore_nonexistent_tablest only_synonymscs|jtjkrtjtgjD]}|j^q+}|j|kr|j |krxVt D]E}|j |j rq s|j |jj krqj |PqqqqWqndS(N(RIRteqR!RrRR9t proxy_setRKRLtreversedtshares_lineagetnameRv(RER:Rw(tcolumnstomitR(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs. REN(RMR8R!tordered_column_setRrRRt foreign_keysRgR tNoReferencedColumnErrortNoReferencedTableErrorRRRvR6RRiR R9( RR&tkwRRR:tfktfk_colRRj((RRRsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytreduce_columnss:  ,      $csfrrtjdndfd}gtj|ii|d6S(s9traverse an expression and locate binary criterion pairs.sSCan only specify one of 'consider_as_foreign_keys' or 'consider_as_referenced_keys'cSs |j|S(N(tcompare(tatb((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytcol_isscs" r|jtjk rdSt|jt sCt|jt rGdSr|jkr|j|js|jkrj|j|jfq|jkr|j|js|jkrj|j|jfqn0r|jkrC|j|js'|jkrCj|j|jfq|jkr|j|jsv|jkrj|j|jfqnt|jtrt|jtr|jj |jrj|j|jfq|jj |jrj|j|jfqndS(N( RIRRRFRKRRLR%Rt references(RE(t any_operatorRtconsider_as_foreign_keystconsider_as_referenced_keystpairs(sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs:RE(R t ArgumentErrorRRi(t expressionRRRR((RRRRRsF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytcriterion_as_pairss   'RcBsSeZdZdddeeddZejdZej dedZ RS(s5Clones and modifies clauses based on column correspondence. E.g.:: table1 = Table('sometable', metadata, Column('col1', Integer), Column('col2', Integer) ) table2 = Table('someothertable', metadata, Column('col1', Integer), Column('col2', Integer) ) condition = table1.c.col1 == table2.c.col1 make an alias of table1:: s = table1.alias('foo') calling ``ClauseAdapter(s).traverse(condition)`` converts condition to read:: s.c.col1 == table2.c.col1 cCsci|gd6|d6|_||_||_||_tj|pDi|_||_||_dS(NRtanonymize_labels( t__traverse_options__t selectablet include_fnt exclude_fnR!t column_dictt equivalentstadapt_on_namestadapt_from_selectables(RRRRRRRR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyR.s       cCs|jj|d|}|dkr||jkr||krxO|j|D]=}|j|d|d|j|g}|dk rM|SqMWn|jr|dkr|jjj|j }n|S(Ntrequire_embeddedt_seen( Rtcorresponding_columnR6Rt_corresponding_columnR;Rtexported_columnstgetR(RRRRtnewcoltequiv((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRCs '  ssqlalchemy.sql.functionscCstjj}t|trt||j r|jj|r~|jrwx+|jD]}|j|rSPqSqSWdSn|jSt|t rt|j t r|SdSn't|t sdS| r|jrdSd|jkr|jd}n|jrB||jkrBx7|jD]%}|jj|tdk rPqqWdSn|jr_|j| r_dS|jr{|j|r{dS|j|tSdS(Nt adapt_column(R!t preloadedt sql_functionsRFRtFunctionElementRR$RR6RRORRt_is_singleton_constantRRR:RR8RRRR7(RRt_include_singleton_constantst functionstadp((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyR{Ws<   N( RRRR6R8RR!t EMPTY_SETRtpreload_moduleR{(((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs  t ColumnAdapterc BseZdZd ed d eeed dZdefdYZdZ dZ e Z e j ZdZdZdZd ZRS( sExtends ClauseAdapter with extra utility functions. Key aspects of ColumnAdapter include: * Expressions that are adapted are stored in a persistent .columns collection; so that an expression E adapted into an expression E1, will return the same object E1 when adapted a second time. This is important in particular for things like Label objects that are anonymized, so that the ColumnAdapter can be used to present a consistent "adapted" view of things. * Exclusion of items from the persistent collection based on include/exclude rules, but also independent of hash identity. This because "annotated" items all have the same hash identity as their parent. * "wrapping" capability is added, so that the replacement of an expression E can proceed through a series of adapters. This differs from the visitor's "chaining" feature in that the resulting object is passed through all replacing functions unconditionally, rather than stopping at the first one that returns non-None. * An adapt_required option, used by eager loading to indicate that We don't trust a result row column that is not translated. This is to prevent a column from being interpreted as that of the child row in a self-referential scenario, see inheritance/test_basic.py->EagerTargetingTest.test_adapt_stringency c Cstj|||d|d|d|d|d| tj|j|_|jsX|jrs|j||j|_n||_ ||_ d|_ dS(NRRRRR( RRR!tWeakPopulateDictt _locate_colRRRt_IncludeExcludeMappingtadapt_requiredtallow_label_resolveR6t_wrap( RRRRRRRRRR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs   RcBseZdZdZRS(cCs||_||_dS(N(tparentR(RRR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs cCsl|jjr|jj| s=|jjra|jj|ra|jjrZ|jjj|S|Sn|j|S(N(RRRRR(RR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt __getitem__s  (RRRR(((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs cCsw|jj|j}|jj|j||_tj|j|_|j sX|j rs|j ||j|_n|S(N( t __class__t__new__t__dict__ReRR!R RRRRR(RRtac((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytwraps cCs |j|S(N(R(Rtobj((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRiscCs9|j|}||kr5|j|tdkr5dS|S(N(RRR7R6(RRR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pytadapt_check_presents $cCs|jrKxQ|jD]+}|j|dt}|dk rPqqW|}ntj||}|jr|jj|}|dk r|}qn|j r||krdS|j |_ |S(NR( t _is_immutabletvisitor_iteratorR{R7R6RRiRRRRt_allow_label_resolve(RRtvisR:tc2((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyRs       cCs|jj}|d=|S(NR(Rtcopy(Rtd((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt __getstate__scCs)|jj|tj|j|_dS(N(RReR!R RR(Rtstate((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt __setstate__sN(RRRR6R8R7RtobjectRRRit adapt_clauseRtcopy_and_processt adapt_listRRR#R%(((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyR s$     ! cCstjtj|d|d|S(sConvert the given value to an "offset or limit" clause. This handles incoming integers and converts to an expression; if an expression is already given, it is passed through. Rttype_(RtexpectRtLimitOffsetRole(RORR*((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt_offset_or_limit_clause$scCs=|dkrdSt|dr5|j}tj|S|SdS(sdReturn the offset or limit clause as a simple integer if possible, else return the clause. t_limit_offset_valueN(R6thasattrR.R!tasint(RjR((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt)_offset_or_limit_clause_asint_if_possible0s    cCs-|dk r|dk rt|}|dkr9d}n|dkrR||}n|dkrgd}n t|}t||}n|dkr|dk rt|}nv|dk r#|dkr#t|}|dkrd}n|dkr||}n|dkrd}q#t|}n||fS(s0Compute LIMIT/OFFSET in terms of slice start/endiN(R6R1R-(t limit_clauset offset_clausetstarttstop((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt _make_slice>s0               N(RRt collectionsRt itertoolsRRdRRRRt annotationRRRtbaseR R R tddlR RR RRRRRRRRRtschemaRRRRRRRRRt traversalsRR R!t langhelperstpublic_factoryt_join_conditiontjoin_conditionR-R5RDRXR8RqRzR}RRRR0RRRRRR&RRRRRR6RRRtReplacingExternalTraversalRR R-R1R6(((sF/opt/alt/python27/lib64/python2.7/site-packages/sqlalchemy/sql/util.pyt s   * 4 A $ /         X   M ;