JFIFC   %# , #&')*)-0-(0%()(C   (((((((((((((((((((((((((((((((((((((((((((((((((((" ,.Fh Ch@ 10D``DBB h4 @dX bD iD ІI$TBB'$"`I)Eb`(m9@0hb&!1114  b` Dh "lTH)TAiN  A" hf%n£!aY4hcC"5J2#Tզ@ #(a`QI+JHB8h@!!!hSMNhC4$11SB!`&2Dc(p*`"XE b!IJ&0C41 b `hL0JHLi1L -XX`ݚb% )*Cp& ! $40)!b䜢hC@D 6JJቨ4B!`b `0@ b`&ё^IÆ LO7dX h@)A "I`6H !L'@ DQ B!Bj4  L@ @hb&%$ D LQ~7ҜtZ&pӘ b `&)F؆` 7DBB&qI:LVF2B1 5iL4$ mj4 @ @ b`0b iS` 14V1l˦I7 @` L&ȒB[lC!FlIY +@!"!%$  HX J00CبDE18! L r2ϳ>Tس:=8Ӓb  & !`) "0$EMSIAL6D$B`&BBX&1C CT4h! @@4 0Yf |,tCE\T}nn` b$1AN&$ &IS`0118` 4  9_^8B14yꞿ3wlK 7 &@ 0@ @ `Ȓ b( +$2DR:]Z3cqcAȴNb11@#@18b`!upyt|z8lZ+]}3:zKcwA9SUU5AJ   2LUp*HR+EUEvF2qIW8)-JYDUQ  b `16!B& n$I9y~yntpX"QE,m[&C44 b ``@  BQ0&:Qud J7*"S-5(J7U@`  b1n.2/| ZrJY]3~ڕyצ1Ͳʬ3}[9NΨWVun}Tc~g6g=Mq6}GKsx b``L!nu"6ڬQ}_4 4IMtSҫ(610 b`],k4r:\_GOn骻q[,C*ͳԖzhUݐ9w L01 L& hQm(4d]nNiF wfG&ܱx*uθIbBʤSnܢaFj(@`8箄Ꝿ&IltgxgɻM%Mږ{z)]vSqUټ& b`0CT 8&`% '** -L/(4$cךRjp.h @1b!  0n7ʮB Kt}UF˞tr\7Jϖ~%Ҹ[!hUqp!&7Č1] *O4צN.Ǽt0!J%S101CC&1 Lh b bey ?fW7Ƨ,ʒ2t}֚m[PzvvF@ʀ  hb @%(#!!bBâM4BF=x Pցdd'YS̷ͬ 118h`bSv\>}Ux/ޝ7UI5h,pܞ^[U9=&v8@I!(XjaS,S3]av(KWP4j` -#ݒ7Jն&W"1t!^0 ! &X2y=yomNz.zVwfKݚж26ϗMa5L0C]q$8EQTl;yj]\U:znT62U f%uLb!  o7Q/{jyϣCJgS[oޮOO>_W6O~oC,2T`44\3zc(B A\cuݛU4컗AK2B6vǷ\n9WXQ,y:Bz` `4 @C&r_'RdxyNu <SQUM+#S⎬7v㦩K]Jy:KX5b`!!)*d 1RYn+έӚKUJX7U3˟EA}lŪe6@@  b b4x2\>|z^WvB{3^S׺Np^kέ㜅VզhW6rw{xz=)@h+ !daYZC.~mQniڲ7|0Qgj_J}l;8Po)Ά>4 @dtsNqОgͷ>ǻ \T`ыfNf7(pu9|]͙c{#(h1 @ @}6yn;*SHI*Bj"9̻&{y]4գ7>Wf~םZ0niMRsTH/NL` @ `/9ywVY-tkZJ~sGCz|z[cV-KX+csSTWu6kK2"2QiM b6y֝^]k׍ʻK=U**MVK2R.ZE9}v6{i1m]jZҌRUJ)De%dR*K~eS>-у$eͮsuκh%lGNl8#~:n5Yߎqf?L'@ @ojȲ*d.ܴn3q$ngլNKbS%{ߓ\qM(zOk=R͕zX_~=hE'J]\YA&]ƣLk4>5tdUFm8ʋ+7T+K-%3oU]kRKV=cNjkCiGY)s󝧂뫟CX=na\^ RgOA5F|-P_ew9jWM;暜Q}rUh;p_>|+ng<%̙uӧ>phss.SE67FH[W+8sc<=3Z_FJ^Mz('.Rǖ=<}<=hr7Z6v"pV-:jS٩}vf2UeYN\K JN*|y.!~O{ k#;1rt݃:>8sVL]*gs*-dY*Wdnb b&@?=1Ms*|ZW3VY.+ӋcSZg EWfgvZNDeSBWʋ$ӟLu?CԎvܚ/\hُR]zu3&UWZRvj^l[֢3u[ةZ2=Ox]wԥΛbyu͝p뚫3UsaVX;I>7~xgpa;_կM5yĔ1dD׳<K}*D&P&@18{N]n)E=Mg_811YGE) "J cMQ]e3>_Q=:f]IzTQS US-izΛ$Iv3Q]]JM$[VT *N5-eBHJO<侴euRVzseOv--m(JƬi`jKڹW+n}1Z^.sLyq9}4/sw@ZH!]M&y،l-nq沯Ets'mi9E: Q"Z 5ֽC^mkV[ʝ>]3n2,#\B `T(U6-N,gF~&[bB^w*<=UÎ+mBePW:IPڪ7䫲anm J0 Pg=iQpڎz\~-kRqXl9]O.w}Ku&kSuHS $BRee:̢r fnYmSE9Hr3PQuVE 6AM "vty|yU.Y!nm4kqB.N4UdF鶫,qLں[e ⒅kYknpwBϓU>^Ѳ+214E8,:"=YվٛG\N{UǭJ1؆( -Rd [ۏͣ1f^6%fF$sB̠YUӲs]0 &\Z\_dL)f{!f7}6_w5SYŵUUYe]=73uԌybv#3]ё+fXx?ί'jĪZ'KZCOmVg ٚ5![omjbїxue ؒuU̔g5ziW:7':]Uˎ:ur;ês솅Dq#$BGVQ}cWQd.ŋZ5yrhgg^1ʎxGo|u?=%[V63fH41ӿFBwwnlӯǵ*vp$FJdi::qӏ^|{sF5skb+b;+ɳǽy9mIAJ1ɚz9j]<+htU!lNZ`tafcʍ4⁳G/LJ|TZ5%TͲBLSd-.ط%ؓ5ˡæRdĉV bc@$::v֋oV\fwtr~.V:2.8n.YX͎hk1.Jvտ}ڸm볧-%\s^Lݾ}fƥ<;9 o-^,/B9T,ųXҬ o,4 hxiӛfR-zlFfR&oSG/G=fl"#o %$4W٫#1e;Y(62+W4:lt#:;1[G3YfzseN8dًI8Oy@ԉ``&!#8Hs3_OFRثRulvth;Ì:dl @TqVR* ˣnsuX4%y:f2h]KƣVi%:f'w?LkU?,iÑIg]B%6aUiUg&>zuƧM_5^^Z役:stNg\Y+6ٞEֹgZγV5vkD-d=y55(&: F%`Ȏ-@ 9}l|dNPGDWmp%܍=mbZFlӺ23jqъuپY|| FxiP+$'*싶M+oEșPBf x8O;)3:!319t5!K kϥ:o 鞖3;=QY٣ܘ0JCM`I5f|֭sb)[b6xe8Ne!Bq2c8&(Nv񺭁TmdB6AI"^OOA(D#4o,i󶞼 ^ϯɽEz{κչ  J2# J0lewn~̚!)N(џLbU9:x}qҲ6m~/LmҘ>F蛖޿q]V FbRF|qV]ب5ltO՜&e\u5N\&\تP ʕ^dKN}!F'3ԌIT-!Ќ\%||&zcy].:yٿ,n㨍vL1I"5I4ЇJ+y_4t[Aݦ>f:i2\2eP۱kqED1g۟NxǫOMJ4uH\EūB ]I!["IHl>GW t0peEN]2_g:nm#7S{qR7.ŲAVL,qhJ A$n,iօ7>]0g3MiKkK^#PJ8@LjVD,kU yz̪|NKυI@.v}5wy}~cLIWw!o )E(JT1RjґW{!#4}g(CD%bJ+WKO+ &3doFtr걤Zabb!ͫ7%ѯךU-Ăj*ÿУTҷ=|<=X[q6*iC"(d'"$- yyTnh-|z]fSn'dZ1Ky} />u_3\8 Nz8~GLP;iHvL@`SM"1`8x`q/mAI}E9qOןơ^r2U`JP,cBkW!$I)d+bܩir+уXJ-)~tc>&ĂVB-K_?z$. h0R)F@9"ʑe>\z\;5P:M9u9ɮsaOz{qҬsq6ȦN@gm ;\$8' #R#%M_28ІU[j,#"˟P=++| g!4n^䪶 i5P$ϮYCc`Wr^010#Њr3$H ۀ29# ?ӯ ,q=ی;G0O,, 4A@83s3o !<5-׼ 1?430D$a ;8cO4 ̲9G&o4 1ͫ?8<3w>9? 6 8E Ǡ~ߙs,< ,/1\O8<:Հn:,ӽDb.4'8+Jr<<9]+rˑ0 <8"CP/ < s c?2<O;x7}000 Á(N5M0ϯFo<Q!w0 # L4Ҏ +1`=LѨAuM 8 @h  Ϊg0[8d_o|n00 8 whhtS/-ŸsC8 0 07o8$ڍ"ʘq{ T2ѱa0sFsrљu[ ?Nz2"8fɒ{Oc1+3vzM|"D:I}KYaLω` 0 G+(+f?)ŖR+}0q@{1'7#:w4VO0 $βէFS4LBer JeN*/ =A1=$l\Ӯ@j.檄kz%eqe^PU콹4x=3` X?Rʺn.Z׍x)y"ř?21l6oW5O䐘eނ͠@{B2y^%kZ*ogxBVW`h9mh]zXX,нP,ۍ44&}=fJ4E6~JC 06}+n'Ui1᠗$ClLE՝)[T@Ub̶&R3[gXPB =J(B41|xs}Px蒲@[5"J۲syo#$;X#L z\,;tEfwҸ,=ěeӽ'O (7=u~*"x(Q$I0Nm5ͬz hEb0?%0+l2ͻXl RH#rA/TmXb̪?>޻|P:}f}Sb*QnW4{5\@9I{;MWjMxs1;1dY~>r[WRlW2 UսKzrIv6G'1gglOrm"(zLfo`Tx0fbhmNW= [c3 $'4jy32`$^vԩWW|[|{TFg4CPaڝ {X6]0[Ö4W`'LqϊJ.,3U[1[v Q!!FuZe$ eQw?ieg]TL-N @X-nqBٸGV'd H- 47O3y=Q ,swwF%"wXMhO{5! p:;K(o;1O6`.9I~hŶͱ]Yqưpmaƾk^'y; S!",`8t侑5qGZw)Ayw/<^?Oz1tӪ($S]n91#T2yJφ |R|3sJ(]U+G{a&Pd>i6ClR|2Ռ7Cgخurڛgs.3uo=p,!5bh-?KM)UzUk81ְ` ZIy6 qJN-ե5ymχ7cl,iX .CR oz⯫y/R褻kPp20%˄c`6HapC[q7C(Dz0DG ϴu{m[˯Ac" i;?vGms$יg,h?(sc}^?Z׼s8&IGhDm?Kosy[r)| Cq{د}4} /{ePE4]s։* -?ۉ붻]:+m'Wum}njj(l*J }mKVT~ 5o|YYLPK,"jC*6i<}}mg*ޏ<2cs|㐓bI/v}Hvw gM$YQm<}}}}ڡ, 5`na%mv}]}UhQۼu,0<2}5uSU[-3lMUQ }d[a-9qLԻƥŻIu<<}g}mD#͓[}3qԗq[\^|+ (ŵP }qqe5=߷ (Bt597=#a*8^ȁ 2y`Åqi}<887w]Գ=xQD\}Dr)XI 1ϻ( cK<u6YqJ|4tu<o0[$-| 4&'=M}R&ʨLs.Uij M\_҂B!wh,o3g]o4Q7u ?o.\o(iˣ&CpLTz7ʙqoyv1 ԄajAĕ]ȘYB1/&aжiv1$J]I1ڂ#y ہ+-AiVmmRYY̺}S*_އ #׭qrBv YR̿XB=kqYH8Dvq%=j1 PUjץ0,#>!Tף,8Ns|i,:$BWpہ0NNʼTrJkY?4@K_oYa @1沩(SgaA4Q6HwF!J`7pVhָe"֬jO>$,JdLTf9BV;(L\ h7 6: /[)+R1.?`2UM|r*Mѫ/-?H@l!M*"% d͖<HbģHo몯H^nTG[-9#%9I"9MԾtd%yhGN Z`˿LJܘ1 3Zޥ0ږ[z hfɎ$X览N7a./m ՖG]8_:)]`9xw(F.&n$6NJ?[^F GYdn΄΋9>z nf`~@lֽL&".qj'1q8hWݎ's@;B ;fdBy|q=S$`RD>]F ig ^%"MHt4SIK+fe Tnf/޳tdy%[1!Jdx'@^PMoxMS{TPfB|^*}'sUC-JA!AFx(i؟.C` \nx<졆|nxYPd(n`/fL#2t>#DũE^?кq OmNkoȚ6Y?7*&-BA0QRj`鋘LϡL61O{˗&T܊TΛ7 q5tfԯ09mKxt\6j0"4x/\ҙ UL}%jXƄ QYgк87d]G#aPJHrCN\xKg 3]Jy1`\` Ә![MͅX\ΖABn %̃rd@fL*tf]>]x*G~|ˀ`1|>;;_`GEqIؔ嚜 o3TrUsqǣĭ`FC1No}~`?52%f o5P  B楩I<$̙G.4v|ͬa,U+)7v1yP&_6WcBa1g$љWx5G!TxHRbL>}UȈ26KNV_OAk-eT~0 ""3›O1Pg(>L<^F,hF㘘ټËlauVGW5$Švչ6b.3N?/4Ow!~& <~0"1rvb Qf0U5Ax=Fo3S1z9f|1/&E(q3dq1&F #(Ua<DM@Af.gI똏fnD$;2?05(B A) >0Kp|~ED6EFZFv癩>Pڥ0 ӛf. Tk3mGVc0Qf;,ƥT`B"ߖ7*s iN*3("U FbqBbZ - ma_\X5 3.(drb;R`@58q@T&bfj\|{Tӹ$4AهB9itbĪہ̮D{ud\%jc5Ɍw,Le"m̠\xꙮkC ʔLD鷕x*D1(~?P& f&3Y1[c`J LzARspa\|t(TWJlKT"z 3 +ɨ80&]>Mg;0Ll&Ll61Z { MRSn(-=:fP& 8]!ryI'U,ynX\ n?sB9$̈́ u6`6/Y3Sd%1)w< 54QO8nYSMd&@k&<[DkcQ>&\ [%N:VA g08AyG淟R4qډswD:AOyDm<*\Mg3zA0c"țDɄf. ,jH#U6;U}1M 83y|kcBk889?Lچpd4L\W 2g&SLue~2-2!¦"Ӗ]:)&m;4bA?0k8d?)}AkV,&E(hڅ۸2S5Aq0F"UbYө䉗JF:6ry.6CMw> b&'5M{P|]T}8_3P,X Bc{A(7g9кӅr(55HDRiS~I:M_Ǐ  ZÕZ-k54ZV3Mg2/̹ڢiYԊD͐c]#6чu>Lv"pAFaJh]Q,MFfܢ&)>@CG(X%ߒhF(m.U?i.q.مw2c('kXIcbZkXD&#lGu g\)KlP#B`P[y}sR(UpAn%MW>fqԳM/|5FOm?ٷbx*ٚ-X9BP16ճ0ԲPP^cuyLF*e Ù­ -Ar8ybf&l$>!WQHQ.TIL ,?y"zmճ65Vq|L_"Sgϸ 72Ϸ#5Rܾb{["R>#9&e0Nf|6s5 ]?3:`"Γm@'gfLyybXq #=7VsE2%ĠG,y,n~"T~ _eXt^Q70ٝA7%ÑAf%3Vr(ij7@{_a_}od橶bdgGGɈlw˜' u.fYRh96i[9!>2p@*1&ELf`B~TM3F᱂\N`J AAH |e0sPJ|1>'L1L t nLQ cqsLUIQu4^a )u; о`vNbJP!1&Œ,.Rݳe(Gb}ޠ06mŒ`Q5ܙ#[`hP 6 cu 36`־& :3>SmxuxNMFdԐ9$G 4;++!>L(bdGRG pgʟ)3cܻ ~e3Hdiѷ)"T??ŋU"aENbw .SP@@_&l*1<8arcj/POܰ!48v ˊ|w3PrՄmCju594"~Q:LA[&-ϊc:f#YQ)="T{ajW><>D8[ǃz ExF6IOb"/"e֜965 &x&c̍h ~X9|K`01gm; 0md<Ӏ*3 >%]%Ӷ>4\AC85LY|@(vu{]:d5c::VzjzF]g.1dM3]bQn* "'6Vӯ28 e? Lu3IcaZ|T؉fm5:gyd9Rq:nǗ0:6ZvsB`G˘Lh8Oèf^Jk깠kMԸ~"nCop&. mS̹p{3b\ML;1|op܍l~_~&7<+\4g a+2 k_ߙ[ S7"ĚU@ѬGP&=7]=(!>cdːa,:~\r?i>ij28̵=<vm<)pc `1CهX õ{0t91 _`'cQf(\ehP" #YA>Q>yzS7Jy 1X Bp8s,v|G";_1+ks7#LZpڐ ?81|+fB\OB8<aMf*ȃϻo~5yֻ$ïb91LA1{xU5") E`+byg<\_lZ3aE c`;O0f,KNDd0XHN3tW3 OlHCaoUܒ&"Pه[2 FZW0'KWOt/ A δ 㹇E5L,JJ6DmZcdtRf w'1h_bc|ith\h/{XWfg`r#v=s<\ĻlkRkaٚţO:[鿿ogʡ<|h1TqNau3.,Y`c! Di3qۙaVh~ˆE<4бWf A{g2rL>8ljocMCAMO ';Q|Tv8&h5nqW IUdO\9P6y<fG&OT|8А&-22fp\tl~4zllCq] L9wB tiX\Fܠo~h?y/~AP*~ OãR(q` SfKN gfE]4hɈ6c Bkܮ3p=; DBAg0? =ˁS|Kt2ci4F3gJpee˪*~qwՐۏa4b1}S55 Cs EbE˸Q#4yCv{L^%XЈN6 ǭª&H*qsWv+gFuAƢy)MfhB2@PC '%}k"Lϑ9"z]BUΝ5@9&5';\>%H;u tۄ8V`zo3{@>'_l6dG+f:;A]BM;@D87"u@r2}t[ ¥4ll&>r!\O6&}n0!=`8'pftؾ=k1Yf(|uOrZn4(cuQɞ /L - T؊ۅ<ZEb*~&vߐ%+Fa*YSFM7/n&d5&i\>0@c"h#h n` `8 >=Ȍ(u`RǑ46`4{&R(H``7 abo"`ݻ5,('7j =5f\ '``g1|L˜"Vi[3HbT1g>`|č米?5_r~IjY 2p=kX0L4jLP-!Pr/gQm37}魻N}Ri`C4ŋ6,]R=ӷL#)(eF'%i&0L| 2UOULjliIP|b:}Bd_]vjvSCWe5$Q0>6!1A "0Q2@a#PqBR$%3?l/;?(g=T3iMm#D =>J~¿h,%_\rB>Q_qSMi3*:t(h{TR|aYR[oϧESFZ5`ܿ07a_8")&])5cbzԯF7KGz(JHP(F3X>?T6ʄJJޞJ dͰp&a)x]R~7NɘY18hHRĝL|2~#갢Sn<ً1ѓr]ٴq'>[\LoQ`צeBTf[ٌxmcgr`_ؾ!ݐ660-EQ  Ɂg@SC^&\z'Q8B= a?)?P:U?N@*>4}BrgX:;\N7jМ QK&ZNܯT6a6oa㸍練0d8E+`rVuhhhD3q=x멯oݙQfg<x?ӦÉV2?=`͟H$DXt`?TEeS'5g !{Aw~O2k'%8?6 1bmxls48>Hx55T[|G"0~{L`KPT4oU1c6|OF. >"De? FasQ^ʬrMne@3`d4tDDn8?2VC+VxHLeV748M* qU?M7& r g.Ѵ'o&\̀]` MqF*D,hA14l"\"@&T.f<r.2)&}0i#Qdƃ&nD3L@|@r"&#ɍs Eړ:cHfvd"G*fA\YB@S\X Fngt&,Yr*E!CDf mbiwd49Аc2uPr%&PCLlw\EP?1BSO(7#(☎B V0h@0SQrfn!kv?uw5LT!E "+2%}eAv`@Wc͒30+26Tc>fn<RT(9ֱO+n&W˦?UDZJAdQ`ZBAq0e*`"㈊Ld0X36fR@, #aJ?a 00GQ B% jfe WώE7iF ӏ(2}1:&e3A:%E]DPT A(DF=YTUm%d EPy<@ k mF^ft *Gs\DmšmAK列N2?gI8.0#%0 Fb. .f(FqV&P:vhtCwb-& ˇ#Lώ&#E!Rp'Og( xXX%,[V`Y LX!65mG],|Y*> i )4wdDs\f44M5Al|J8 f 3ןfyeSl"3]1X̸O+s"saWqR)yTccLCP, ;qh 4}y!IɴEv{9T2EXٚlG&@&W,j 3ǽ@j&zG&bLTno'cƘ<OLx=?(ؙȵʴRZ/R<֝Mq, nTյ$Yk] e`.u'V-w!h cOc4Y61&Rǁ1)4bG ,Cs 3'B@+1bg[Q4‰'˽&, o'"T5=`UvOj?BrC 8C XP ɤ:kȌMԻ1&ogG[@@aQp34_B QP_ hVbb C:c-h.!A ω 81J[ل'&)(ۣ,'X)\A 8D=Bo]7[{1QCP3&#Ez/gܻc~]q`QRf,eT ͤL=5#MC:.1\PT-8w Gan|c"%Y0LMٛ&L rsSd8u+W/Rè@E\\٦զ}1zQ,b~;"k6)F:YWc2TLnjb6ۓ9.><~1,NEn '74o_(*lD+u wӜٕDƼ@G3(e&lQзd@l. ȪjÓlUٔHn!:l"fL9v5hIu ǍL-o7:7EK.crmը௙ u3c]XGȘS2}#XZ?dO)f!ɐAbfG8T3OfpiNrfX)4cN2"F4!ʕL֠]ZŇLɷ%~e3܄E؈a/D>zzc=5V>L[i'b 'C>R#I( eR@9修euaFt`ŊSN]#bqk 3 j75lU*n}jOMWfUT0nf"!%zːc&gڥJ*i؜BV n|@7:0}bf\7M@9@gPМ`i 4j&p1m5?Qfk!ְcd luR>L'м̄&*}?툊怇J 0MfM) NՎs;)rlT=" (?9ɅZul@;%R&}: ^yVԛ# g-@@PRLg94^C>`&\.G7gйUL1 *: QDsAjqDl2-4u7Eox`܌c˼/*'fd*9㱆 D ;da:K2gbeh4{FҡgL |v3 }P ?tz`Ț&&o"{preLB$5fl L6وAn &3za)ϑŴ(ϩɄMQ\ޣ 3>=v~n ԐVPTWLĹnt̛3W=ØuqyYؿp}:O?g'ŷY(vf ,gQ9AL^?1!+n$֢&*`հ3$Ծ &5)\\@:&0E!iS3y7/URA<~"1e0YFNioIB;?Lpl=1V1w0`Nd`$C#O-ϙp!vkZ˹.fn|NɁOBdԽ(݇_-l3i0FԢ7+fLe9*D h;Ob`F1<"ڑح(E`Owֻc(VUlY{slc5UGESowѹ oy0Q{v剷 lsI6 FƖ8cimJIΓ 7TQsQ9F $h1"U/]Ps2+7s73YO|U|ΠS vcB=Tǘ>aۧjN3(côRƣ){Z;_@\P#؜gK=2͸1-qs:"1+*~`Ρ r"6b&mη$j 6>aTPŚ#1`R FD֔My$fI`ʻC3. >aӱ*1%g'i1lJfxjPðvېnk_%8 Q)RY4SLoɧ>lhđ&*&"ϑWj 8f_Xv3#B:;116&@caS0?`1sR37-b!q7Fa+4cE;S&Z3t;rq34)jQAJ!}c]@>`E3w]ҳ/8pÌe\I›, "1!cjTfb[if_i~ߨ4=ndY(L5cGQ ̣!5l=S2w,π-Fk6&wľ͆,UCJgP9cswbPݍ&ǰq0o*`C ȕ cF+/@B˩5fU #62‰(h۩2b`m4xm1V/lZo}VjiT/n 05w2Ʃ7b`<> 5٠%z"wv.n,LYWjfJ3wBm(w@\D|)d=Yqs?=f} s}&W4&Ĵ Cj}34s\m 0 &, &Lm3 % LTʶ.<x>FTLP"u-8 x (@QJy̨ʂT7?1}?n (6u^#>eh@Nnf*I<)aaԛ{}֊c]f{ UGT;,ͦʠyӌr1#nZE标80a+`DT\˘O(ٔa7`N[#6H#[YIU>'͙(M:.e/ONfRk޿> aٿ`G?~!^a£SP)cPD"l& 6ȇ)1t&zn|0dAc#'Calumb 4 ֩L=fݸ2oy.2I$\@=%?.$γc.U' &6yhc4~DžYz<fc@X~è81]K n DRk Ž &QbƣP pэZ:ljX3ʕ?ݎѲ(G` (z(PԅB~`kS6xM,bmwQ_ 6rMp{CdСG՝K cmؓG'ӲTnTM4k#Q{1O\GeN(QbsDO{h:Kihc'\?3(PBgmA)g 9aTq%#8N0m^T\cXQ%…^(/au9羳:o=3 =n-~Q~މs>0f' dΟ?n:cW=vKCiREd]|E9=(faݹ[9d* 8۳ݣeJ0}BKtLdIPGcGTıa+6M/" e'af[:^ 03~z?7*TqG Px{e`Q+yh'*94omJ(1W/Ɠ^+LJӓNJy-_$^kS h&fn!fusB'j9pV!8 0(蹦*9U4Xgc{ZUVӧw=Wf8TXңe\we7D ;>@SZ;VjgqHjP9 z#"bȯpcv)(et+w4gQ ,{ Ži$5EX:m/\ntXG\Frv~,Ԩp5! cL%O*Lx yŦqdGh 7cnSz L mgZl0G\dSݼ.UiVm FVcNH9dעlUe^,.I&Q&] mѝL/賀A5aS4s|CQqpoIH;|e_ -!Rb}/2tu #r@Uy6Tܻ0Phu]Ļٹ_@lrLдt#T1OS76~uwliΧ[L}LLiM9!7_O? IuZuNv,/!P25䷴CrwhcVI *U5ϢDiYLtaUvp}:'{?]fmst' LzMVrMMʮ0uFS naW7Ԃe Fk;B>Ƕ5D7w2&dK~ُƂڴ,;2Z{CX S5Mh?-$JfID£&x,-q#DQO2tj@GI @!Sv.2JvY*d &V`~#=27Z,TrdBCdFW K Tz;x5qTæʙ`;*kHQ&\JyݳKBt fL :|zt^c;`3 +ɀ-V;t)>au?7Xw`GRwAWHSnNeII*pU)ai0i8i9ͧPѥfcXUV6zy4Hg]NJ<-=֪xbS3fYOC. Py֩+kYZylg 9j:D3d\އoipwa6@nbq#\A}#R5Bl p2U]& %QΓ~3TLG]BbIU MӒcl*T&t9c=eC'~:;6x5@M4 [BnդM0I>򫅨VOt525j=wS1 0b L{mkEUm O *c T̸AiD? N;Ӛ`s^ǀ檓N|sPL:6HI?Eޙ'sf2M}'TjhhwL)? 煨 J Nu'䎉 ԅB4NU|)Tm<8B0k{2`i &KCe~Mޚx!%OA!Wk|!;T$S%L;kiTxG ײ4AL&ТJ.#4hmGhZ$4LtUeˡK*r{:s^D\TwPnQ[t\5ee=UG7˞je0GC,T8|P}(lsjhvwdOWgUtr;\DM)eEOHM >Rxs|BM:M}6aFbD eQ1[߽?P 9ke6N|hyD:9jpj6?ڎ-Kz*sDKay %^цAoyK)4nj]ˮ78uXjz5"汲!QQI=75iͳu}Ձ;V*}!TKC8nys]0etPmaS`CT*Tvb:ױ9*g<L0ʧU|!&eaL'϶DM$g53ZLk)#-S'wDcwE{0G;Ii#6?CrnC +Ϟp$puC=2oY4t 4FC9/Q:~'ET\t?T󯺰u8{C3B+'^XdamZZM<:}imް׎D+rKanUi*e"ςZs2潤CsS]sNRζqFHh4asۍaxJG9 ̕"ks7u)ѽLOE>>.suU?&hTUy}T!@& ?%̣| K]yoU#p#ZUDdNl9!R hNNg0[[o&O@p/ݯC3ȦRf+9إM)džA:J7@ˌqOK y]^3cNDѠqkXX~Z*AW,&קk*qglamFtqJ-'B|m>hwk!6!S)yBcW NmUZUIˈ.Ϫj܌~vFG$Ba;fVm:k x]^GN 1t /Tۓ@h+¼rW2gOݗ.Jxl"y%MzE1[uy,s-p,MTo8xʯ k $1Y:ȉ&̨;ÃVߧi dˠ "9BOȧ訸; i]c-{p ԉZ°1gif2nv2ZCW5[Pup|i ԜRʨX}I4w@Mny'K):\全9O%KxA Fn_٪*&i {%.*È*m &gR$Le" .$8OTT\*H:~F_ 5BF1ͱNrk Und*.|sޓ=Ld*6x2 v@)I/S5=%_ACFTثZ.xÒכxfd']%J܈#Ul4:({.|uꦵ'j{a~0r9#U4!apAd@ȣ190&hM_Ē)UUmsM%d 3o8ɵ=k:T*qLwu]h]chʓK9:_ө41{y.n|-@Wgl(:\D4cm:d Ow<_T8biS{d.ڃ(!UߴUMo7LԨ}mp:O: ^5*|MSK~`zSm\T ]& Mq+HTK YQR`s3΋ "'NߚܷunKv2/o㖍`vl&iA:VmE,9zg`̞>G^IwyTШzOM%4&@*O4; ˾*=}Bk?BaoA6 Csns M`Yy,"=S3{qn*'ڵrrՊ||LUHnJC) ve1/-ѣ@U[Uȵb*omx`n.Ӵ>*SLUZ *Ea6L\UR\w{g6Dhk[g)LdeW02BV5U6U,— cG `LOU8}~ K op|4q9(\~_=m7CdxH9eMl*ᕉ1Թa2D(܏TaBTUՄf EPC ?Obu'5Hk8G$y*cCrՅrM9Nyk>GTXdnoh4Xj;]9#YM­2ڲ3*joEARzeh@rküOWwZoU^69)'Xی;kߒcN ]< s'{lp Vi3R[ T`LE^ GS: P L}} (႘Ӫ}AlwEZzev#޳)Ȯq}C{bSֻ;IT}6s]:y)\ֻ{`L;%{zFKO}Uv-oHhQ2һK Y~LeڻPrDMwbby'rcTL$Z\2ǸT+*8Qt8]R)cAsdxDz6CDagXܩvk̦uQsdPqa|2ۏ`V w u6Fzho]m&wtX|>!<]Q1Z\ӡ݀ aȄ[qasUM>XrN ~LJ 0H}&ɨj=ʿı ^_> us{39+Z~%iv#03uO_תUeq| f}eR:,E ۗ.{`U\@ dgM04c6cj R3Xl@{n5X1-fࠉïNg~~wsDR:(rJ"\yŻ_o=ʼnZ*ѻ.4a*1uaouُ$I,)c[F@^ TGR&Mbnc\wMw*vVS6yL8džjvU ԅ@Mvy{D3=rYSkC@V@3QbP!q|Vڎ#Pf2{F2}!pT{M7T{F\L_0[5ZtTgi]97Y.ըfJf,s'D:6Yt}U4q-4cB>+ cmƲpvmh:ZGf32'k#o<'' _Bcd'CM#fp5k,;OV=G3Muj\eԕA-e1 ʬ4l9l)hÏUITk- y޻PŹ}ڸ50yQ'U2O@!T<SF6/H z7?XN3 BS)0-9s!SiTUw.HҚL~)\eT{Fly*.,Qp:gy. h-O`]}1ZPkP t:rXϧ^⏉8CM2c-&,y9MvXމCp8fmJuY,tHS]k:&x`!ۊ`r)lKS».R~~J9iuuވK{лO]W ?"Nh(uBJm췍܀sToKM.Cyho6{`CCvYpv9be0U??D *X~ӡ_4T'"ԤX㪥JjtđIu)w犏aT @{6X|Ml.rGf!V3+UȔ %Z|Ujze0ֹ^1OT>0 %2HX'vN+Ҝ!7'hp8+v.,R=Qѻjxѧ'dMH?HnX\=3AuĻ>^G_m 8\K@XAAk" +YsUt5vi?cLhI_5 <)JC /Ak\6,0;&)s h&q9SKU@^5_,ͱ$&nȷOݷڧ 7u^G89y m _,Rg/pjǘҫu0\?J]#\w"b=G%γX7l8a-[QU}r=B$h MUJLƦGS3@*\"B4E /VnͩNw,**Z[V.p9gpXgյ̧kc)ou7Bh 5U@FJ&,~t7)%37 S@sns)YMtn w4'xisWXa>o%kV}G'TU0vg J~lp*D$&vgkTwU%Yi^!b\xF+' ! 3\:G5iDWhGO*iЫwMwD|qvc*5C-aDjp^k V5 (7kKi7ywYoTʨ,B9rriL]60QR *`mVaY.e1R뾩Yn5c/k{xuﵤhCFjپ冤Vh zPab4^eRbgB 4]+_񓪜SC9[QG:Q`Y+Qw̬ v@ R,^,. 짖W _yDu๲-b>.$ )'}^'. {jWR9hb(6IVh ӬxI6Z1U Nm.ޣ4E@f>Ues-)*3 u=UJna 8:~K M-ܰm̧wd+I*imw Ri&Uh>VysnԳ>"2yNv%Pb:T.a5T=\S({*G^EhZ>G5هع өrU 4XC_Ul8 o5 Vو|uDasuDO%-0n5XgUpK+#2UiR6N 3G uBײa5u9gIN+*7O$H0Tn{qla_4O@RÅkXItEGqpyjihOͭ'>IUQu6,vg)Qc~ùh=Ή*}Wq ~ձ|UEYTqW.-y&Sxl_%in&v_y{oTG#%xy,E==ځ}C -oRHxuk L%昦A(qf|N7%Li-+ j#柕O4a_n!'(o9wK{ UOV絽:wbsAbUq5˟$r uL '*75n MB- /u:܈Xj&QNMyNH0TOUJ U0u[$o__ 9hqftY'J8; ?A2F2\dYtWh^ke*ƅp^j +|+Z>DmH B]Ty,#<=s ֛MٔZHsPF\8TiK˹NӅ:h(H\Jc&tJ}jnlo}CI!::<5\wBQK"3Qp51:eZ=Ät*# [)ܺ֙Jߴ?6hӒTkZ*zu|8GSktN|62f'3FOڵҝSH0ZKnj=ڰr֕!U|`1è?-ph >Jr: ~M`ۼwC%(Nn{ h ht]\0tL|~Knhø.q7D G  jANt#EO.`89跜1isCUkATiSkq#O^L@y2E x',(3 JpM9,Q蟲aC1L dWg{x|;vbkd杈uVaT׫knK ˭h,q&VEPf3RygbP2rjS]G>I"AG&$.ϧ$Yk/r{s4ւO c&5 h[(u!7x*5&89?>wu$2CR5F_[>u*=QΥiH=f.4l@-}#54@ ΉO0 l2?ҝ#0iO̩>. L ~X[`L_iAAx[XbuY8GЪT&gp9X٦:&yh 5%pRG%8&jS&LTXvjyn`{<5x4Â\9kچ4Laa^֜X.M4íf%;`G2~s ƛ;aRWm7 y"b0,hSmggԬ\>X:~kVGftRGyoᕼc|װezER4GUFPě.WX he< Z>NO85L5Uꖵx9amٻE$9 PH7~JmLtJӣZUS*FEauV.9+hȧze&73#^yg 4ˮh"7k {af ?ȉ[tZ<-XTʹ q,YXurr=L#iӺj~fL--jkRDwGkRѧUFe+w/E+ O_ XXQ|韆Dh Uw S=2 X[IRL1a.V"lxXZFWQZ] Ht9:uGV5U1oJ0Ktb:2~v:ջ6;Իv4O5 pfts\78S)fD+y놚A' (դ$2YC*9Tu*bXG \/<P hWejgiemmf<5@u 2Uud4i# dm;03 y/SA@L1-Uh0sGDse:CYV͵̭p;Rqꁹ->#Ś)wn(X!^UfL.ȧxx*7Cx,%?*|T Ҥ zͻFJM5?򫦣ˀp>{aЅyzMZbmn4 QʂZV; pKNTr@*bJgFDd7Soxuf>eb 9`\ZM;; 1.NCCs>KXiLW=G1g-q Ku[<|a'U9fF){DU*ݝg+HeJdazDiZu1P /GCD=ե{G%"oCJm*!B."J D>J"ᜅO8ےy͟{@~C R\rS=!0ѧK#yT!(tE"hF$y J.*X\1{ySjATZAy*7,I-p/ ȱkH^U 0<5?6g.7,'{]?!°檃!c/uLko#]"3թSi{8F)u6{QRrjh^e`mQ.k nBZ.Сu wcoVm4+ԫj}793 wz|,;3!'a\4+}X OC:V: v&ʐܚj2$ƫ 75Nmi"K}eLC |fD?LZ DHQ-YLA t2tj81br`yp٢d*9pNLɎmAeUUmFSk9D,Vm+vMN +߽hsC~jMu f^7%xSkO|K`&[%G 25 pH*:xOUP 2ElЎרּ`AzAne%By&O2N~JfsЧ*urJk*}"O>ES9,8;zhUs-$Z*\ ᒢw"3Nmi.D[*jUBրT8wM#Q‹]}HzK]rWf^v4:j[}\5ge7M; ʁN\f2|YaZLĪJ5y$E9 a);҅[kKwFs|tXO>"%od.wXi TV+Y= YI瓳w*.اR=5V u DHIMl&G޽s3~S XpZ,N3.+NCϢ6)TkUCK/y[~ɞhb*Y!֓:}\;OTЈUܟe?Hȷ3AS0 OHd8c^e/+zK]N*0}BDDfh ҷ7u0Ч!5i9gT}hUˋTeg)T?#x,h$xD4MHj]hBT M~ z7Jm':[96K ;o-Ӝa-)BfM'5W(;iWR4*Zs\YեUeGR9*g!y5DqNx}{MZS{IM7G$Ԟ8Vlߛ5V#JSPĿLp22X?mLx7fsM&%vJMߝVq3&"u+i<\$'^cg-@緸<x[:5 i>iЧa̔Ǵ) ei.:+U:cȦ֋DѪh>iL}8N}\ BVΑ$!s44^hwW>:xpY[gPp:*ױ||y[we4d4ٜ±sM9@Jz$cPee>nMSԂn\Lڊ/S57ky-s ADn 57}`.7-J^x)eArW,۫mVHUi,EKDTWf;ܘ@b< @ve`m';Xu:02޷{[PTe@$$4[jqGhy'g@QRx,> O&BgdӦ$U,)؆9 f(*f?־\ڔTMʡZ|0V0]:A5 ǻNjnaSΙi'h26Vo5I3dpH' 쎬*K^ZǫM!6e 2FɏU(Xch'-e`0SшżDesFt \52䫋*} >)o\Wm)0ŷyD41akUK'MVّs'!S\tE[F\&b2Lg iJ{p橐Y颖FSFDt 0N!>yPi) j0P (TELW%  OB{u<0oJ״Nf+#%a⒨Pm4¹M0aC۟А_wUUgaw, 4wE q g$BV;eӪҗi晢J*)t'876x`8uL1˄B$nOC^ Ѱ` ^5.)o/erlRۏtn3oBegTc̷{1ZdWg*WԈ FTo?!Ҭ]0px*,j2SCT+E0%9‡bwaSӼCrsm0sG<UҘB9ܴ6ho!&!UC/e[=*UamVEa`p۷zEIM֞+TtpX8yLaJQr]\OT0 peCDw-k{߂Ԇ* fn0حŶePi{h9L&؀ByVSlpJq98[19*!Uwӵf,R mv3 AY -%i)UTCa4dcc{ydZ8\UnU>O9?v7k!kw]!aiT{ƖP[K|]TYXxzsLT2=.e=Z\;v9 Oc]rW^ ΩR;PLIsX^*-k2Ui1%R@˪uWI]PڦRH'1>OӚCȏ /rQq,cSjwIғbpQ$[O9se; ӣ[ao^hP%Fj'?%/|*FnwWt=>LZ(妨TyVLNl>.ᕏ;CMZTAkcf]QQn傘3 ohdKO|rXJ]Iܴ 8Z+\Vl/a, ³bIWɐ\3GhEmrU|DuԢiRBmUtmrjԫW1H](˻q.s_{ɓ0u4Tj?OfA:a&_&\<=Pi0{5*Lx^4oq: xUuwM@I\Fқ1iz%Ps olUsbӏSM9AT/ʂq%RDStt鳆 ]} }ZdIaM"JaW`gtF3$Ð9x+̆Ɠ@ˉJp,6Qu>]Sh#Lp  UTS#7yP&zǗX9.VsG4LTmHnAE0HP̭knp6p*w901qE5Bvlvj3Q2\z8L!'9+F߳ly'CQwݪ'޺X;iOS\l v-Yn!uXhiϚb|d%bu'2x&ccyJ-aOjwU ;)9BJ*fLseP4fn/U-dG ƈlysR_=*¹5o$8jT#^J{x5CڲJ *MDD:SD+Sp W{U3s'䯜<x!59[7ИCEVRᓪ[ӢX3> 9o)/]/" M`qچqopS\hQwo,Ȫnm~JSdnNtHY57_|Sʬ{rΪH1$+ʛYCFaSi/rMw77NeuFF\uR 1QO-9!9ʧLn'5S: uTE&G&T%ZR9yu'HPiקCZC ȂE;6-_s-ks `Q)6!KZ\yM8-b 4fߺw,Zv؍&Gka WFBteb[Ҍ@sXb7`~(" qqOڌ{@sWw=[k XSsia^O-7:}REĽ%֋bMXGT N\wqf_lh ~zdW 35cNH^- m~^J%Li U*=h*99 dNי m'4 =^ . gU,})H-2=\qvQBiܲ-TNSk槌5jA`v] ƔSl\nƗD Dp˞cU:&Gsfc0ċ[2+[ leUstO0+Mw,M9җOY~Ik,|k UAg*ė.W,M  ]jaҜrȭNU= W$2FP8H,8L;J" M~92~RhoO"2P a0Y!b ơӉt*FNe[48Sʁ#00!„uN!B%JjNS` fm<[L X]u6=murq ) HCŒuV?wݴz*2tM*Tis=ѥ1HSܖDo(yOsH*o1O(CLӜ-v{ˍ̢skU:z+`G$O g/?Z5Maf^0o v̑™d1Ls I|,[%ZrWDJ*خ.>ISME6sT%V͍ UIU5c龠]nssa eisne9w'D 璥y!N;NkF\]uE"lY%1!;@Fn赘9jNV$"5:c)d+FY&gT~#%Vg+[ {<ˉ4JB6ۡe0 #67'i"sa$oz-vy8ndYRyT4 ?ֹ/oSV>U8e &2s޷-p,NAnV ՍCy2skþisx ϼSZ2o S\`<t9"I俁Nvd֟MJFن>*R Sj Zŧz@]Y^wPYZO9ALr~MYsT(Ѷe5. X~*8+-CSih]#H,*=֪n-R4PsGBTE=i'(Md2Sv:mҟ{@DCT`ys*d3*38JwB9'l/v* WpƥS~jwCvVzQEPlrofyFI5<&Qu٫S\Ot#j"'gJZfUzuTkK}+_^ jnq7wS:bGIW&O%yuBC( ؎!U(L vRӞQSgRK%We4ܮlQ'V3r` M,SN5`^ MpR'`*TJ\RXzTMVΪ-<{ȈJim뾉棄{f曊#\kǂJ%BoEwR匩;Uk|r@iV ''Z-'#0eIg;U'dNÇ!hPUFj])Nb&TOlL> V]᧽,8mVĹT8+XִHh:'2m uAµRT*WRz&419tKP8dUVXF7yhGvy/]R(aB eU"ntLl:k}a4Ʃ97~ =IWtF\NM+To$é7@T$ocZ eW]Nn5淘iXBo&HE{JJEك\i,>6uH) ND&} r^S_&*Gk訷wE,gz 7xEu "M*Y OIr*`yU5r^TAQP*+Xp 몴oBuѣOMU570莫z,嘒\5 _CA8g$3PcJ!90V"s`}|2M[f p9YUpYF\Z/ԫ{9J;UYCZ9v7gOk9ͤ*oI̪o:j}1u^L]MډT=}ٜh~r͒ʬUJu@2{MIw sn*,IW0vxO+HtUM:cD2s䍆hr4ө5\"~ix鰦SW!9R)ٷg&)T{LL*$#;lz|Ka{KQ{Y=Rxie}Bc n2X иsrVku1~j)\w! 8rꯦ3sHTa>IvF״r5wODi <&4 S[̑MBtԩb+:QȕBduqU ^o//lt+zL;,ް=NY"%E)FHx&rN 2U M-m2fJLBf LtswŎ ijUo;MÒ0zQĨ;;D^rr_(duty-}Ӓjb~ٽZfa uE2=9F>J/en|?p$Z69;ܿ5%O}Jgx9qpRz]a>jCi>ͪKG;+°&ꆫZQ@dUVdi)Akp{ ENо.l`)W) %hMb~ xvU٧~k E$^NlIth1NkɸTs6RՍD4*nžpN&DHPEc*7xE1D(vFS*Ԩ[żAAJO)>2d?OOvz6~jj2Y rw\RG{!ba-=OagQy"XSs#+v?6rN ouT5c4V7*'s)ﵤԞM9s0uIR$~0LFY}U;iGXU:#2:"DTd*dR{8\Ce \Z b~yަ~mGxћ] ufb}nG%@ BNNl#]5S+D禊Ri><>f\^zrMhh:(VR$ǂ'6jaVUDGUwltU;E7x-6E4Vtk#6SHjR.DgR}:&Ϣ;Ng%15n7\(maiញԞM@t7{ \;C^HB2kS97 fBe+5G2WխRi.{Qh=G0 ,‘vAN$:W35W7U#z쪔Lw__:d*] O%~Sp5^[bhlQs2/)z;5iBq.Ъ}Xݐ7؆7VT, Io8}GnTZ> hXpXv统2TF4hiS{-tX|S4ƆC%jЂ湠>J@@X;6 _4>US6YFY咎0Sja$O##$ /4W4\Nj)r@N e8l+Mkipo~d'5{ajw^9m&M♘3bknYN/x,FWv޺WeaSRc0%7uXLs[L%f|4!n)wFeTQֶe'G u(ӧ<ƪu3LjKIbZp 0oi>ebnT(!4 U*m8 K2Dv%:Xz6.rprn'z.h-JɍXی9> LZ%awj# m26l'DFK٢Uz4m> Ana ھ|+轌&g.i'[ ^Is# LjeW3B&Ys'ՍO N i-2GEA tR⃏vSpd+<G=CSi6*r]6V|%Xs)-M7`l] a&e;CkOC#AYiXk 89љ j NB;=.yTR,7{\rv(U#019?-$NS0=ػ{f::AkI 0|D61.:}3rM|D˺ǒrBU|"}DڜUZ+u3+w=C -Dvnlޙ*e$4ݪ4(lg,NY >8y.-mrjpvbvJC$*gCaC(Or2`Ach&.U{xf6X;a,Bu?X7$O8Uq>ʙ u`Ԯs .7. $stnvpgM<􅀾7{+}]֗d2uh_Vv%E&Lu32lXaMsT7o{IwlߖʂXSgx0Ϻ83PܜUkR~G J\iʣ"|s>AT3=>JȊtۉ [FϚ̔GM}(rA \sC]-eaj8Sk^-QB%5 fsu%]"NjRITxl9,}FcWg׃roŰ_.iuNU{&-N?못OF3F&i4UټMdHtU sȬ%}rjmQ%B*(PBjjZVHżOD:W8s{Wd2EUnL)%6Ub,Y==9'ɐtld\!P֖˓qL!hAdN nmV2= ִ 3 Vnג Dq#T{aꂵ BÚ3eSWxM祖תv 3d-B. Xa;CmXSaUa*yM I=Zݮns|FjDfs@?UfYP^mSLU;mpӲ %5?Ui!a9Z׺ R֑~G)X"ThwsR=Ld7K@]a:g%b(U^915 A'xm$|kZ^i } sN{r懚U reZd4 tZl(hOU0O"4Ҫwµ̔@s|Tҏ{: koV!3r&ZnU}Wd}u.qz#Q !4!s@~~UЧv}Ou#;_"֛ޑ桽Uܙ|kN¯sT #Ԉ]J%=vTe S&9f,Pky1Z r6$?6)%Fi=Rw& L1؆C'4.h0>h_dSB&sxjNܼhahC[5T\Cs|M'-|wfL/7UPjI?W4*HwQĵǝ:UZoHt41 } wB%ak4`v T4f9ʕa9}wBZ2V:$5EbL>tO>˧jkʕAQw?%<_3"LB=#Ȧ,{f]$;kxО\:Cs#=`?]NkHeyhi҃2VB r\i<7FIĺteZhRXU.ͱ)aMa=&ӱ^շ=ӏZJqZWx&TU4DTЪjMKWiWsD(ŚIUAȝ=L..cs/Ɨ݀g'e&:>9oX4.n;pcSt-DHF[7 VW\Z4^X& m h@JWS(_4{6%bnCÚzrXVRa{X*"X=1 d^2(ves̯֗&}j=א⪁.>U80IgHT]}6A٠Z e;ӕZE:O8TϮ;FliCϼZgW mrźOS-ہn碝]TyܧLWqƆ3h>j/ 'bg,=[LǠޛBz)D<5G0}j̀B{H>\JjQUhTTi~ .mQ]u<7;Oo3)w\-FJ g`ZoD)x)9#s.i$w^a9X߆oHj6v\:Ueg7LFp/n\6g}jRCi#ԕ x,3s(ViNf*Ҡ*E혒R%FkLֹn nR):]ҪDCQM-yJ!qCp#CITm[!ScZchvjv75O;WeN|әMIn'{jpdHdQ.YAavlz Wn:'8#>ΛUJ֍tySCfnW6T#)we@(-i@V_ ?6P7 | ķyftx {FJv,sbp? #.5 R/5%4Gf8wBKxMzmNצT.oߪkq M8OZ_)~OK?/~[R⭯_U?]OS<U[E7˹t*r }\= xk+Ѷd VNhZNIxfۂk- sc< jՇKG4h:Tzʺ]tD>aO5lMk/!T3ƎMD0uw5ID*uYXCr(3iSwy9pQ_JNFEnb&2u]>jKFlgihEcYלx.h=Pc]*uNWJH+{L9/9*X~j`溵7̥N:vs)4O3_ُ5]ի'+O%rQLsWeL9'"B| 4 jA @6y*[ʏ n+qWe)c\k9gaSAѸj` <̗@3UO<; N qDCG4uz5/ShQPTSOQL`J>HY:\VEd tVΪ DL(CvMkG=Sapzc C mV6&zKsMt8N})i§!P:sDv^V'kwZgMT}'3HJ7QnP" zJTY2O%Ul @ ,c:mZT fB##`ZuPŴQt0BR:Xw @,fQć8>< f"Y49&fgeU~5^]:e`7':u,S\Y[1ⷕ(5j? |G#.|gzefx8ukB?i|X:#A([:FY;1 j-ϒ,{-O'-P3£e'Q06-ZG%IkTꝘ[[S[w3fٵ)B jhh@#cJM*T䝢MJi~i |3& תcZ4().ˬ*iS>P4ʡ2<¤׹+| .m@AM2ܑ;2Pa -Lw.+0!krK[iڴd}L vТgEKMU vasyƂ:ibiu\C1qUjƊW8{IO ݖQµ=:/@:Eu'f#U DʬᄤrzØ_uW[!zUPQ2m%vχ[cZτB2[ݟig4l[MZ [Fgލ ˸Jϓ^#{?U$1RŗU+L E%4{QŞuV=h{E5 EBSD>aǪ:.ĶTve4vB湁j4RUèR:UxWh>^4k @<9JFD#/0 rThv@)Z<iDɘPB2nav=3z_U|0U.l6Mit}5yoT;2?D;63{;ٍX:Peʥ0Z֋O*0>;]Й__CtE>s`\@N*q2F6hJK ^\ײ59(kNcz*"sr~ Ɩ "Tq[>}"|!n? ^Z]2|jW^+FJ(^ժߺj|@~[Y nqG^_ .+?g:Q؃zwRvD3qP~mLj+UDi4ieg:ފ"ȡ =QԔ@lm0S"v#Ѩ]Tc G*g'?S5s,4 C pOuMaΌ;\c]6MNwBJզXNuЅu,{90@>6㩕O Q[aT ->K?(#jM+z}nޡNm-<|dJ)^2\uL'*:Ҏ)ky(wTtxX_ItOJ8*cʂu+N-{rPA6i $CBn`p2U,F\\^2sAŎu>aqշ8wxTj ԘVsYEvM[t(EQ71Qy-E^S02Oe}ۺ5k=l%3ۢk5脑Fa= qtQ&;HC~%wGl>Hf5*3n~'r#[S#p02ۊl{@'(!f:#gʔwBO0SXV[fRZ%> L;NSfZW~ZJq4pqO5Zl+ Zk:m#qʻJ9BsI1FX snXogU!JvA(ӞIB+w6=T:XG=y\; R(s1f<=2@Ts](/P 6l;P5rR,LYV״ N4[4tN:X29UUN.}E,7>V1f%We,óy^:'CD a9>IτriK HFYl-uԴǩ 6J' Mͣc!=[̑Aˎy,vy#vR$Ss^L(ex{>6TSo)nYڭvu <[ .K~uG[y4%Ti܋2VG S堟 MG{sx;Y+kD OԢ2)ۄxڏQ.UZg,1('8eVX`KNzme[gS3MWyPUKtWgϥJ~ 17T^`d 'xRbI(=:nrpmo/Wdjk 7ef՝S]|DmV4R O4V)T/K9B5hѩikgO5%Nxy]Xcc*K4E܁i"-/$7lȢ@Q(#]|zq,daQ]Zg&ʻƏNXmPzT Q\HBm>(*7_, niGTiyx#De@MdO܁sO"@UO n#YAVoS^oǺy=dmi=q;SLWhewO|dn7mi*$ !5vJ^OiVh> lfuLIkD\xZ#6Hٸiin B^:L8OĆtFѭMq23T+==Jcԩ[ﻗU|p^J޿L/ɡ2{xA{gf@EG0\>9a˪K:Y#FӔs+-kE>\â8rz#D̦Sr\6́Xwq H-czϨTi>Jn\*j%sTܱ}E>J!Jķgc4Rö=IOe\JOY *?YXe?Sm ŸQ#O8o uHBwOG;=p SE6ZV'Z7ڿ̫r[*frD5+:ֹ*6l:x'9O;yu ?VUJUjS1nV5۷wg?lj0NDѬ#pU=Gj٨FBZrMAuC4Ji$D\Ni}z-T65ZV2*2+a麩68QiVgQ>"sRk"AL&*Ew֤s@:V xF$3 lA. hԮѪk /SMJG)O3(z)_$S7JJvO%g\@lڻLN}oq޳z}~~TfSNKS8"&ssP`cIB\G23Nhx!E[ta ,~6ia֕ڮ`jğl=iPlt~OɅ)J gfkS䫙x~}'dZ ݵnPbwڬKNGW0Sƒp,5Kvb^@BgogvӓSmw5jZUxty*bicXV_SCZ^~kxOwz%ժa&qmG谴i vchS mJv> -Leτlے_iĠe:簎FY N~W1q2VWa^#I޷?'o=m]vdB#ll$aooX'=<^ݟ߳ǧ/Oُ,jL=[ڟ)TK/\Q=/M]9 'UN&閫g JۿمʋUTuW0拭nj~A>V>ϟT)%4jUnr@,q2LftB 2d45'SkA5:ըiG)P>^)nwU  >4r $ ٔYk {Y8 sd7.J؟5E ]z#P8z!fT _4l)ԣj+jVJNBJrMRRj:tg/#%%wTP*V$P੘jWsF[v*3Uqg5T2ghpp*t5 WFU].m60]9O%ӻ8&sXvW8eĪ6ʎoC4V AD%T' ȢP7.kPw6Wl ܲV({a䩙` gَ~y>K5_F}@'ŧ}Kyo-?]OG'/Ysf>c|eLϑ> !7~  q脲\isSu> 0_B}E.[9gD.)Á̎$KLiR۞qJd^hV'*o$2%`"S Vj:ݍQCdeqdV;5jX[oSs΍`_Gn7hG캎s 7FĈapwL6AiT3!xI˒kČh OǾ|SqfPs DӁb!kD<q4؉k>W"F7_tQ0Q i꣢ᖪG"@o!o|ܚ#5],"Lpea>zɥj|ef4֎gԍ(F']MOoK]d inmȐ &юMyq@Ore_P, wzY&NtOUjS(CC"ouF\ Ag?(>4V z"SG4LS fs觢>/V%ًXnN+ RkT!W͖Q1]>O F(XoKmi~JFl:l"u m-k:h4Ph`6yf 2uD-LDSIaez.ਚtYhAKg%9ׯD5ѦFڬwB pGX_e//o;4^}܂VKEMRM,~v5=JƉ)}V^t2sӮjeTL.`,5Bg4doa*l}Gg2-:Ӓ&T8ŭ*t)Nt\ch戹nNJ '0z-lوL}.tG⩹|&dBu OA [q=%bg5 2!S{s69Ǫi%FQM}` *a c<pz S l:eRC$jUkEk8^܎[FpCVWihϚi FO{5s_ZZr7K\~m01K/`6EW@ EHwq;zpS2PKt(憋aX'~QQ%S9&Fg%sA4ӈUrnPV'V˧E!s]vL6BqP T6YQmkd=3i{X@Я{=eTeBr0+~Ti> d>m9I^!-?4j1úQ"mKX[mvk6 Dw3g }"~p&h6WqfU!i1: ǩnp[t`ٟrhsn-AZ*:´R.k]uIXnZUk3P{k6C:,V-ӺQH:tҦA7waaXvqqT60 Tk~4#":S,jù~F]7KXnqs`&"KXJ)ucg/P(Cdz`z`/͞MT1~s]/@r *-xcF'w% 5kC1;E@_Z@p!YW.yT:>a,U">%aulp8jqyu$Th~9*ȯLwEڎ=#[B~c jsV25C5$I/FK9xXa_ C搏Y2YHk k񚅏yL!QbX ;)TɹZNPĹjZr̦3ؓwąs:N9@Bn9Ŭs.M=o ]e\h4+=U3P(N e"MFl:,ڀO9 =76QPB!Fzt^=G jiw=!s|=NK IvxRcVKꏪ*Ylkn#6Pe&9uVs{܏Dw ̂{.XOrtw%OxSۙ'w^{NcT67˞9,!zӛKb|SiXB32Ng5V/cɸ]5iZvv/l'Nw M㫑mџuW4Ѹ'H@TWkv7R<KLKxHXw5ָ"i .]ƦsO5Ru_5GT0{1憐-vl(*Ttb)0xpiNPwPThiC|s)=f765x'8O-\ A9ce4xf)aȻX*)9SCEsRI$a'`^ݽj*1GcrUmqZrbiT47gjxl#UVT0C8Ӣ5 Ou{9rٮ4r*6I樄Ջz#IYQR ҡz=C9h门=q9 KaVeMt$ꛃ5#!apo5*ln5nchx˸}+K .szeU?86!cs^C K|psnnm*2eȾ26xFkgT hAiU1vIyק*x%# c(SvB1)j+EFWyW{g/dvBW*Y^iվ[)eT*;aoGs.qxqm-nz.4o:?xZsEUs5nOS^hQ tO*i0N(cIy'c@ آS<W#SPMny#5}ymw~Y*Ns.q19Q b|"dJZ=Hl5(}AN=HGc̹(u9M%*LiRDs cJ@{]@Wg*T)CM3G9&ϦMᎰ993:Pv"Bu0Ak9d`Y iR1ڂ}Ȋ̔D;1⭈s/oUw@ڔ\eBF8UB'ZySk|O Kď }IO]cdm:-T"9&^?Tlq0JnAv)g+m3ncU7|>ypmpSS+JohmkG Y5=Z14x("bUJUh+]T6x-dHkd4%Z.r)Xu2S h)7UzSsog7vzmHTm,> `4zXc5; lxNȠ!"%ǒrUS Xr%,%?[ 2~}-Cռ붅Vs`94N~g۱,6Pj4l.)9aRR(Z@Ca|@U<{"v 182*x8;w~yKOXSd\GQ)6VjԼc\s1RF}sAUw2+X37ѫU5hOd| uR`-3/F7 | Zb*ꅃ,iQBpU W yUl ;lzNUoe%¦q0n2h'\A iq^=BaG v=9k@U:' (b\cR'l+VKU!BQɡVw ~+TӤ7sUDt' Qq4.\1cZp194v"'N֟%OsV6:䱔ǫNg0<,}cy^is`8qb0Ŕ!#%P\ ṖRQf[7㘔ݐdl!T 8u`PB}z/7ʄju9l5ͧV p!qƣ" A&faL$&ytB'eM!"}HQjJ%\٪D"!{dj)5ֺ+vPg-[SuA n6g$pޅvk!ȃ$ϬK6{ksY(QȊm^s;ޘXjK\Rܲ@`1M4)]HAI$=*WYRC+c~}Uz>u_lмz4=c'g_~T._ @!ڷa@"U<^z_~~/@*0G~iF\n_?K_Ex$ ZUY>緈w~X\~z+^6#7~z5z]M0dܭhOAՍ_櫽K/1A .JT^z'Hѷ~VЊGp\Ki>?Uz\"EJIRz1as~'Mz>3юo ryBw6?1 >"[NE_/KYCRJ~?/1;r߸&ehk1;r)*ܗа oWԌ}.\r=JE~RT}ULFW[lsbp&low._EJr+֥~ z?c0{.RV&*[^(Korn>w kftbʑ??g2J5^*TQ%z+ֽ.z GzxQzo_ 4a*fg8éf2#wT|Ns>m!GЊٷϪ*GV R>Wj쎫Uo7/>WtQ]4??rEܹr2C>RpޜD:Bݦfrs2J5ϭJ^%7j.nja$8QF; +fh #>cLEޅ6鸍a ?螧JeIHM+ٔj`b*tB`gHpZ <²MvE87ԇii7gңY8cb2d+Xß iGv} 53m@Cu~/YhXq;???bjU?NvVyG3N& mVsTJ2u>gѝNNs؈<,U1(*yNDU8NI\.j3 OF&my+oqڑݛ@|5;F6mmχգf=JYcxiP.+,E+vlWE:qU3<>*e.Gac/߻ .^ڥC͌?'藔T"yϜN2m֝Oah6W^"9!Ҫ{2y%L"c/@ s JqnqҪ8.Pi)J.eB%qiҖ2=lXoy!Jvmy4\?O?Lyf_&+i9gn!T ,]$ZXtw 4vN_RU<`q63TT*@ͭ2>=?賘YrKhGC yC;D"ݮ3\4Yt!kEt4D*Ǣmlf!H2ҾOmW3Lh7+;z=L:̱حFf}fplhHW(Rp=L`Oa2vوe(  >|eN9)%Snoq}״"=&]0*ovK;Lg̳rwmԽ[]]"hT[Sa|%{bDlıF!)vy/>6t32j#+LmZ=c&F.[9vR&p`U [x8579;s1Q)q803cb.7n|SfmyBHIv?0PusNjq8bQC/2Q<\7=sn[+5ۙrQ:tvE2}c=೩Z_/IkYQ0ޥ⧺tY,c5<J4jzjp0į< 6oLx,E\;\y0#U3Xf2:/?ybs"@W5 -BPȘ$;P)pep+-@E ۱h ]616_,*s0}MojDbKTP/RlN!8rNEXS }}u,u7^w/>#a-x0z DG&_hX`AaP+؋|G!gh;AWAn&sKPҍq*%q:ypzvs@Ydv b\S?8Gt,ra g#TBcؼkOc˯HrIGf#LLJd,N<gTBsWCA0ےqX_?y1|\3PZg?f9\yGtCL6q:',& -ܼ{pmy{\ARk<^Sľ(HK-qRg107R> IЋ^[+\שjHkIot@-⧴7V,*9 R\UyTVuaBbƿ1 dQ`v= @WX3RSٙAkXZ~IZ*4a.iC6T,wlJnGDKu.j+FRlg3r;.mSyx{WgQ*Yt{1op0/b3M>YMj:-ffA3 p#_qa!-kCSLxyByn#Ek~. ⏴ ֈ RnOyxM w͌0ΰ[ܭB%ׂ__B&x..lDJDZh[l +5F:x;K+ʲ\yW_@?ISo[i<ՀܤWvFe? جck-وj([ݿf06]I/]dUT&8/4/_3+2GRj*AM O9bur*),% o}L20~5L}(~xِ!8l܋ßxfʍbt5ůKK=ԼjnmdDϢT3ݧDmLΑlMu2W*0Dqc%a" iEi¸Ut0A/vcEyx@} *ΪQ^ﳬWsbdNC=EFf5xmoȔCWib(4ЧZ[փ0)FA+t>ʽyN1lƯ>0x8gAl+lA2FI=C(3G1S48?쳵 1!g-j7wnT,rlN u㙀#_ beĪ`e-?t;xoq^[7y*srnR13kOeG ەKsDG0TgIm&"*.|x]y{҅즾"&X :F Z;/ZVrusx/%zwV[{5^E0PTo]{]|LLM  חS  6(~g1*ҹpmE _SpZ{և-5 ¿ܯ; d9Έk$i TR&~ȣCL;1u ݹv`! \c~%{u}1^2͐5VƢKuMJ)PցcE bX_%3^<ŠeQniGyJW_ΊbcgCg'Ɇ8\UJpz,C/ ;ڊe*p}eԷ s̭l0*Rw (J2V7dSY,\^D,YcS^^cP@n@ l?(ljivþ[RTcm,x C qz^ h5)okѴL@lk^pi03sfR!W{ruE0޽P7WF*pFS' qa#kɰ }u'T 2rxѾV /5i7Ra"ԦkSn DS @ߺjNf >=̅vfeԍƱ(]g/i\Ӌz@}ӦXiP&N 3Gr7v-h;AA08Het;@TldM7Ѯ8Vhׇ"t-_.#e PglqAvR~IV|_JU)wmF"rU*B(ڷ v `j)?Kf:+R˗P*>ڞX & iӨyzAn?L*vʺq:g!ZbF+Jx9eLьF``R\',xҜ% k^ 4,j8L3r8(b(d̥]UgT/E.AX7X< L¹8z] >&Өyc/u?h5SD#x.+y`tvB4 %{,”fǥC} ܣG ԏo X$wgYeCPa)D!pP=H !P_(w:x״Vf%F_/(J> 0 X0Aw {17drn򍣱8N58or=C\eTs\F*.iZ/""NCƠ6b=Y fFp'_1Fa,~^ѹvL%NZ;Ҹj6^Y]NKQ9jZy .[;i euʸf0S߿IN{KCg\(-~ fA`9ka.`:]bRl~nMw^ n)*,/@rA^rGJ"SwXT&Qi?X9d\zeDzE@濾 ™)uɴ=_i\;]>k#~7,b75tStpyMn%OG3⢪y~hLcah3veÈnV꾦0/y}fwf h{`r{ΜRq&HMɸ?|i4(, saky4 =LX`10̂^|GBM;(3O,Mnd,C|)4VD3l@v!`(')il"++(cXcJۓ,z@ Mw!RَCh9J- ϓlP|[.lxD(XcP!Z A* -;G1*̳Es+̶yS=:"ʻLjoe(#b[ ϼn:Nx(cWeK^)=9v 阱YU{͙;R=it%İw1&˃L+e nkcɺ5W_{]X73E)cNO[?׬~y3]pP9v')@P܍+y:L}v_ R9iCغ1l&MP9 3.ؖO0ipo;u12ͣ-l4W4Dte_aX#>ޱQ!YW{JþiN7eȩ2 \P]XI\ y[Z#s{KmM)%<ܬumf:Fߙ7uh&(RPlr8͜)rۆe&<`Ru6cY@]piX`!RH֎ =P;n=\3" AH\5'M GP*pF"_Dv8ʑ 59w6Cv uc`N,eBݢlS>`-zSG0+US_`INk(O#[X5n58|T[2蘜)> Rl*FI>:]zinwOMu_-R՘8 LZ4S(̞|J^eC8ԶMj80 kb:#䍥t?x Mijz"y4)RKHŦ\T2X4#ڱ݄۳n,'vY"mx5 ;+(}k ˿lJpo#/(lUQp8S5NC/-76j%+Lps0iS i:<@h}UӞbĠ~߃aQ7#*v}}7GGGQ$X֥reۥuqC1ʧk/X7pJuVo3Ji%FפZ:VR 8Vdeu-o=k@-.E~D~9j 2ccT2+fR-*myqnLeTEn9˔,5b] N(Q 2ݞXmxNqf/-WT3,LQa|.:-Ws&1BJKUUQu/ Xqc̰ K(uf UkHL~ "YYƷaSa3jÒn3908#_X4@5α}pt; q *m\AZ8r2ƫEهR> pza=75{Ģ2W*:@Z KoX%k~􉉧P@5RI 6UET_vN{7dfk_!N9%PY7ۤu!PSTBUroA%-H"2XVGIsIQP|п rB5.p}`!riC&n tKzL˘DF55+;O러DYElA -grl= 91Q+.%JSS2ӯՌ/^1!􂥀ٞ+hc^Ng>pdu9:M37+5g,EEkAy*lFQnZ~C}!WpwU7*k f6fQQjȝ扺:ڟȧ l kmAp@fC#ˡLqs/$;uu; ^S7+M:Cдۊ ;&ic.CgMU}'\!{%z5X:55\CQTW8fk>0  w,yB9<v1{ܪb6ǴW\thP c|z |6|qqgM9V:B ?FT9ה(7G N8 iw rx! jϡ(ݙxX2ʶcK5}i=u5Cs+Eqhj׈EU_)!_mK xb珙@r̍l2{9C,T(r\rCb\S'J[';K#؊!*UŠ jcuD5)ia*c̷muoAd`@k Kb1קoN`DR¸ , zb%骻AϤtλ4Q,|acEyuYֹ-|A9/iV^jTF/LOvpOc9C=?빉Pfrzw Ɋ<Z.˗>ފfM;Fh3V% P',-+a] KgDZZVq9D+f=f RK|7 1eQGwt9T'i˓ԏ ^O9Qt0 Jĕkkc:>[~q Dh<=&`{dJΠ BxWPt%T~{i(vnPF 5KC"H2\Wi'ٹ|8P 3 ĸ1$t} P3g.%{n{ -*k$OA<@k^{VF rŴo=wίhT 2v)itsrK)0RQ&̩[tg\k YmZ "gdIPљiӣ=}fgl8l}c.ǘ4*`fj\/ъAg̤pO35B_2G7QsʨhRၥI{푱at\{h![LJhcu>D׵L@3([|Fq<ĺq4#L^jA8}9#ѷA% 1K_V`菊j`JsZ, n5|DX t.}%ٜK^ p7+2TPjffn&b..`HԏJ6kI*hVSe+j>ePɖW (prCo8W"8"eXΐYMaˮE5\0QX#q1A/!~ϛ"BfAyc]!N ^ٍve(YA3CvьMҔ\4 i8HNPeLk^1,a. =!'V2r^XK֫`!*AǼ!u# -:@׹ Z_׏JE%1S-naNefdK;ezd 4')6;Wr˅)Sw٨ w {JuxB/fL=Jd2ڰဿq*1ײj0lX:jMޥ59=a_~%x/`=vf]VWY`VHhkTy?ݽo +,D6Kޘ:Bڕ ‚S$93k7WU|fiD5|2ߔGRӻvw !2'<WEo{lK!hvz[e1}fo~¥3 _1S_蓏*mR:Vp8qvo@ 8CVK@;$ eBs̛\AC #K䎉fU>&p*X/tpD\"X Jd,2e h-W0ֹW0-!;%.D!uԱo Geѭӓ MRPe/*%̴u89Umt'U*avC]ʼn6}JB GKU+xtu_tE,Wԕ_N1Tq1T}?NOw0  WlPKtK!*]He|ͽGl)cMÓ")KŐzEas>*O:h4Bg+/ DhlٰykY̺f.HJAH9rDWq2tb6Se۪K*,gC@%U0tWȻAD|Gg˒0qbY VZ0:V]Z")}Y4ltNyqQM13D 9ZΦbG&nҠÉg\$p3&%UI}J8ޓ( N}ҙfIc26w@z+S2sc,?Xg^c$FIqUl {_&Tͷ̺z۪_އ+D1b^gCpA\m>]+1`R_T ;sa IZ|[9s1"n 5CJ(auqݭP:O4.s+=rgЎ2v< HPn/O8sbA|0<%8^FtA9԰Zw4*s,r8@ hpgBU+o7NEq @w ѾoNd\W2oa0sI"'Ml)S30f5o,nQLBk84:i)LxodPkg\ L/wK./t k}BV%7kC7eÇ$h! xGZ6 &z?+LcgrԩUӴLgC1sӦmdh:N'W~-LLsT|z%-X9h[|%%Ur)Q:l+͗|CQC qRx; tJ 4_Y͘|fep;@ KcL '|z852w& 0&QڽY(EI#7ˈ[K Կ|c?R4ωe3)G Y2q) ?XVx|L`QMavMҀ YQX%mpg3M`x J+oˊ-0_k?_n:1-# n*vjs/jxO[U :_R{C|S5IpV E[ tDxALZ22FAܹ§KPv,B FNVp?E}f$;L; K_\w۲sS>n:^W3DsMʲ/OB$Zt=|L"~Yrkl@BO p1R¾H0M ڨA+mħ荆qJPz8PJ@59" C QIT6yn.v#\φmmQj ^s/Ky#*"!6C |J&֘2%ӈeK%0y[x5ᙅK"!^b2Z2i˙˟ e)Eݯeqȥ5j,3]lVN2ƫ5bo11u)~gz~"r_I{( =sɃT{˼u~)9g%.XE)Lf |XI~R3/WI!=#)):J^.Zqܑ[@aGfiޏUYvNndE䧳LTTJ^qPY%'A8b㼩WM?1%V^.Q%{mpSC;#0$ƈWmTˑ5.ԡ7QU~R,\6R!:]A V @x=}fơLy#=pSW A&h>LQ,VY"u9[v)̣j2xf'a'Zy23#v} ݡs"l=m9(&%q*VT N%x[~&%~Sx%x X[^#ӹz̫S4dv:CGPy마NYНۀ.VVD`r }%z~ ahr1b ~GRSvJݵs2>t2q՗z9ˎ𣈬ll_(JzrӨ>!R2z03gY>Ъ]61.5Xeݩ(/ӈZΦK7q,Ctu3 hQn}2)eJTfp)Й+x#3_fMƷeU{%T;·B!$3bkhr{w+'94d]NAx=j S+* m9-`u8Ҿ%Er|D5 O̓){]0T8@<[F?5@r⯷]"-X!O \`b5Y6lZc`&rbanK?@FrE a[D6_M4 JLq3+yQy=">龡+'%G70j*eHs=X2Y]~ muYH}‹28^Sb8QT՟hL#x9Zxk~!¨|\6$p }%7tK' ̎YU3rzO6Jۙ3P ү@f YY޸] a2uC,hs ;,wcmcP}cNC A0[qK?(bYiy 8G8{xѴ+ߙ*@k6^N\cqEB0 ![4švKWvPR\b-WB}Eܶu<ǰO*O7ַ+fvؖ0 FkSb^ }n͋ףFN5dPNY(/-VT#oըfImn6Ʀd@B_ISў+:Ni]Z2^.`Kex?)J2uM%b yFXf%D g)k1!jwGO*usn7S2wI@ʢ1fs 2RJ6R 7)?Mbfzn'L"&E 1'z!R^FK!}Iӊ ]bZ@Jt$6^.v3+ PIJ)2FsYi+OUVMyDK_dǰˡq9Кa va-de`ģ|Z:=yo`Xw1緘δJqYr^4|t乱G,X)X,S \PGb_I`cv&H9%V `&6ʼ so꒩ 1CAo,))>,Ez-OA g0] aK֞GШ1yd[T6&؏q ,t`G_&s19Pg!'7 9 fwg3I.eDc>F)ΉLWY Y4xL &,m2weN!ĽgTh仪LqZMd&Xad\1243+q 0H)}QJE* Fk"G>m>ӓa!"{ѝ}i  pLXQ\< /o߿݈L 1 !y 6`dӻ2nX)^,ZU2F'2q}rTAaVUNжYje\=]fFYږ\/3$}.Yr.kCNh ;Z~k%-.;!Ny"}W&#y.s(=/wؘ>VO#jiЇ 6kTE ETu4,}AGXo/uܕ9+r8+ a!eM1$p0>"Pe F\g_5QQN;C [m3 ee_pg‡SZ|[?dfVl8-mJ{2G\־g'mSM;1M%ҹz' Omkn`/ӆ?D:ԡCyͺd -f/Qx_aZuJi.WlDR=/*EcnTL}!=WXoC|-v3u9k5"y&|X,\;8`<,GCkDܨ)v@XfEL-"\*s([߫}gC2E%:*3iPX9ݶf27ԗ6@4*c!ŘOɣa _s+8秆i<6|\(y_)a{,'78;[ O{\4.(BQ<!/oio.ml)2b!q d˿MbfT0j[he]hyD`/3w~I\^(&,ےÇ'C QLЩӿĻe<& `1/ PwQp=YY|ŝa1nZa~sh혠IkԻW YYu\J.uqa).A+sS)Z"7u.!ʤ y{Lyt˭}Z>k)2:21yu7K;83Ծrena4zz1s/G$̻Q#AX%te}"Ef51s3[T/j n6n*g5*+iNP.Q" ʳGf;Fgf6Z7*ӯM!y6d37K0JƠVvgkk kgK5\R]w2_s,}Ha5V(ԀYyS%_ MIB=XP,p'#l%QuSN}FTZ`A\p}s*TɆdٿYf<ޮekΆ$AϼQa)_R`~ܰ5gl0 0=_V(^@|Po3,s}HfWf}|Yf!~ l#"eHg蜲AkѦ98B2D+R et3p2IbSal˼04#7qljۼ@}%,m^rÔ5 ^&pkњFJ0@ -_/_#Gt=ߥ&*z&~Wa\תvj[3|g'̹,a73ƜC:u3b[q&P;3n٤~f4l#h0;eN$.\׭Ds_nI[L($S#jG1:e[[a :Mߍ9sKG1fJ"T/H?TJeB:lqIbgpWl>pd9VѿD 0FZ\8L_iOyuTՇٍ̽`c6#ӬxhT~s-Yؕq3n2J`M3*?b }#GeVyFof<.0˩YcÈ0[N"Id9뼭urK.˲[)A=Rs9Mq2#|ͿO7~ʂh1_mk#~o05 D6Q+_8h0TA8~!In߹+sWJt:mg}љ=xVfe{9N_Z0a!b2uO/CzMl+c*Xbά>@ĥ ÝJ+ҏ~p[s 5pY͉OɹQƊ 1fj|Ҍ bz<.;:Cp8<ǡQCmjqL ܱKG J/B+W2x3e uw5'ZY@;ObGAylz˸oG,_+MarV|E f\}e}B,tg>'򏥱{YC@;OCs&q(Yٹlʬ@]IONv2^j , ^tF%/JO-6F]JD!n5۔5̱ooS,_ghe;ןJN zX%t/֏T$+g/zCP5V xP/5wpVj㯩o512]-#\6u0BqWXegEom|EuS"J-Z&k/gLp2ZMYNs,F: r/w}6l[xunU6D62#]R-n+"bS۷SϠg៊4CJl_ Ŷ*=SV#|33"9pva7U&,-JjncG\5GflXruE 0[ \<^~YSe-qybX5/\?tI*o\X*efؿB[]#dOywNgR#Srňs%0?(, M3W_i|c]H;} PsSj$|ɣm+ y>ψSs(:z;j=G5yFTZ^ 0WxYL@PTIR3#oWaGy'b.\\cޅMS\0S1pŸ~?lLfX/?eMw ߂ozhu#g`z.,0ј NB 0f<0S~+@nj癖J'i+9en1:fjcё0Sƥ-L{Dys. vzJW̪Z2M2hG&68F,hseCGej]89V]X[2E~_> 2؜dr]B ۼx)܃Ŷ:ܲ ecĢi{\G<aIȕ/+q.q*N!O"V$1}Y7>VܚeGcuocBV0jwcmh,By16Uvv< 5BXLy)ĽVx' Fr0XwaN.20vgcQc4H>&ǙytKH/_2,]#-ݼ̉g)Ei71w4Gn)_ $J޻MGNf-SamڋE3NqU>鈀PƥF-i=EvVF9-U<7*~Ia-ku21O ڐs#Z5qc1B+9n1@=tӆqʩAyw,ZÍ`+os)"/%@ Jή%^L6/yA,iT&rSrwܥGgICבLOgfg&0E d4;Sg2@5fSAD:Wyn zX#y~U7f̸X1G\U{k7=$vCATDw7q1ü;1 T'RX0;S>^.' %pZ>aH:i*q?}=Q J.:J(OCܔf#I 0TKHY۩-e; ިL՗A7.We20tv:ٝ~g0*ߖZ1!LqiC.gb+70p`UjGh9G[ q:yr,d|Զ 㙞 ?=sq&Y=>O-n0JaADj~uMIk.vDsS&Еq閇0Ic^f)q^f9B\fu q 1+܉TvJ{&r`擴^U~s0Bf nTEEwԵ2;/~p:]~Rƻ"#:OKq^%s Tc{ʰ~띟SЇiv G9obvche\3;@-n=#_g̹Ri)}=ƍP_!uNn{[KW|JHXv1)fC]MGw ޠ]ǫ|1С\,xX]cu /9Q; v2qb^%Sat);3Me|Cr9*a`3^nwz.g̥qԮӡLG? LRcge8άܢVxR/y%<}Q==Z6c楛8L<@ k=c9 %)%Ǧ'3~ g>˧4coO9"s7ـvXwgt#ɡFJҳF0І2C9d¬wjAϏI2B.(+)Ybbnc+3G0X;ͣN"`]7ܞݝLЅ(>DžʶQ{NjS]S]B:4x%,U0:Ϣ>=KVF}陔X+ai3a7yvZ4 )ڃ[NDwO^~#ѣP2:Kc-k.Ȋ^k%2\˄szjLL1&qqʻ3dt;MADP+c{jh ^&Z^ +%{âh-bծe~#5[PFcB2-0%n2{LѼb,~aSqȫU6ī6ʋQϻO>'N% '1y}<¼L!bopsb\?hz4WzQb{ b'<]#kUQz9+-+Q! :1MOE\el_&wYMGImOV?812zƹ'ȷgg3LՓ` 5R"7틤.`NS%ʆ=9 wrzns9ۜ_[/iVcF-oXm0MR <>Dqǎ=Ftxϙ]5s^~gs4+7RmPV~jq (P+<1#0Q vD܎J`ZV{5I5h/9$sQ6(;kSdeivJQbssmi~c8Ks~==" L32cxr-LLgN`2Ѭ0)JDt}*d.Rs0q]%T-hJ tjLtOi nvo:6A/Z8Snڥ=xiޱ7,F 8gZICلmKY܍PܳWȈM!ꌚ/1q^;9h= SQ̒R,NW~T6޾ed1~]x: +]438=Ǡw cQTucqb2[zIk˰B.D37(wvy*3g/K9xeJ; zY{J[*.)^%~Ck8ZW%刱m3!0CX/LOĻ,>J}(J%Td~H}ѱCf/a'S vm GInw bs-ǟS!d۝RG>5Īnc!vaX xYUJu\o-;17K{x/ea}NJLf lN*4#| ]f_uwswĿ 3Vlpg΃!B4%,Of}7 Ny%ܓwR/ѯ^/5 jsң屪˞ۨ$+2f]RN/9~+PN*@sLĠ~Bʀʥ ݾƥYUoZ5,6TgUBW jU[۟H*Ú0 &.1p#ڠWAiB]~0}+db ]vEgh):͈I(`|?tcQXDLwgNɨzae>S718w h}Y3T W:?Ƭ{況}0lpao$t6C6}fW_9DIg^LgP S!h?skZ `{|5P{ m!g:"MLC= Y}q+SF22R(Ļōyo"&Ne|+-7a5 48ӿ_ގe GH˸+q`'Bgz6{~=XY 'tD=1OdN7AeTR'3^YdNDy&} z-S Д3{eG {"[.o;QxkT#fMf+g0|*KXās^Cܖ3~bm { ]=u8z)ܠh+1]]ݏGc(ؚ51@iLx0f\RseHɁ͞bX㈻"Z;$X(:89O;b/>}'髠> $-%TuY#MXbep pFpƝb")<^.eq ON\)}!3p {:VX Por=4Q؎=As X(^3<̪L,}ĵ% `勸<@z^2Ma(-lG׫X'BVu/XqT[IQ0&UNV#/f$kxzzkIe724yzo2Wa4@ vt c$hY9ε7%w% Aٞ`H8'()%u3.~4py;.Sxk՗fSobѤ̡ 萯 (gs˙YzC lp@daLYnk{f1vnK\YL:K) *K&,ρ~gmR/KdQ=WчCT\Ks238vp#Ib-c>P@a&h%Fos~"s"Am1L#,D𘾒`do&fqQA4I{ē$*@Uڍ8qK[-j z mtq+0flHg9pL )݄v`c>#<х}@p%ncџi"T1+u.+d^*P1n}y#SL9G_eu=݋1}aD>X6:[;YzOОIwl;AHxرQ-r ӇYi3Lt^20E3znsL0i[rvwNc}7\Tj|ٽ ǥ?2S!2ƙ]#fK^BO1,KJ}-W傰xJ1 秴/i 0Y-}3-(h-N_.W!ZU0UҎ(s,50u3(ryl k? ; {,AؤyW_>wij .k hNҜe8/ܞDvҷ/ C6 e1h/T2n!0_ޑj"*ܗ*-Tfx+`-7D.w*_Ϫߤ12ޥ9ͶOy 89yv &&q4b"wR%Lm_7U(2  2F̺AvT8ZT`)92ֶ̠w 7r].XPm79A3"~浘 }(<#['M X-̙U3Q^дP Sh9>m|])5JhTuIPY-& s49ΦLŲ yi/c%C}fZzz2_K=cu7Eyֽ1Ms;&,[UQl-o%T؆ ;J`'0pԾ:Jke{TJ;s`5(<] J ߈^wV%<{\ʧG \2|Jo%f(c~&r,W5Oiǘ`M Ûo%h !pA(`1 (CEch,_i5Lc8O*Q`M B 2BW(Uz$0&w˳` 8 k3EH\u1̫W FڎT蟑ƫ76Bf~4kq5ƿmX4jR`)rU&Kd5_hMlalLD&~pr$zj8g%z Me\eFFiӏFopz03]3ǥF %PJi/^s|"4Q.bb.1V1j1rCzЍ5g)}a'I1ݧ[L0 `T,};jf#; *uC*5`ORܑuҥ, 5X(s(1}Kg@QPSL/\Muxj%fbtnKჸktXQaW `)!_ 'e@%#6pfd,'w-"* uIpaMv*rf.9"eB5ǰu! _J+9^&FS̽4>/?J>Y|jjcY(pMosuj˴"<: }BzMO1ǯ2#؏} <z&Sy(VJ踄N%WWĪg!JMs9y#pplЕ¿4dǙm۴\Kc)xU@(F>C\xZjc2AcW-t3aќG.9EW 5 3bi2rܻTeeЗJXBU60"Kݱ`?/7>҈"1sZu{nb wipt{ʑ1Nc*Ѡ/rfE=b^950 ]Y* pq@}e${"QI4cw#~ص~7rfQeoDNefjԫ~!cN.fp_F%W9fs*gʢ@:Mn Ö9>!Zi_AwsQJ3̊Cz0Lquwc$ aԮ '%̹ ֮Q` XLjJ?;1)rzX_2^&&aRu#hwacΌD,%Ĭ-aB;-L Ś#E"d^gmeu"Ըe[M'0uVBb& (Oe|&ԮRW-~7%M,;8`:pJgH:8\ L5u Hu5ƒGJ+vk{RbQK{eCw@^(Ꙧ9D}e&ۇg9ɂ:!G0)f}.{C tq.4@0g zF0f;.C`Qn7:FRʲl ` ΄]Mb--2Hx"NyaUѬq3pwCi~!fsG63E{ť="[~AzNO5D 8*ݟ cKs=<Hi L_ڗ >`Z\ 90Q.C<AN8 4@rcw_lu,>{?M"򹒍x ͬJ2a3̵,Û,S"YmJQ+3SҽN`9ԋ1hz*i2fxf(&ebpT?V X>f/<]j1^#JFGBmn1`.U #k *?Pmx<gH7C ʷj26_#3D_KF8f#cҨ'hdI^TJb1 v&&Z͕ ip5;tPTXqslFi#9jg̨w&& d{N!sewk~_$ Ji#YrPUb;f"/Kc9i z5Z=<55ʢl @|,3*>铄,9L$! ϡkѿ]>5˛Hϣ~YjQ1T?uۊdڹ2^͗bc"S''dNMxA͹ _hP|qEcPlT jϰe!.-;yҭi ]r\Acۜ 5g&Suh>uc3}jvBb`.zi G702gP̪bY/=QLh0 d:KkY|3cI!\j+2,GXvc$!8^J:A^3:B5DrK<2=BPXJC8RрIoG'P eep]y _#9=C߬2F 6i J.g/Emr>:=(ff,tZ,C3ZoE)I@~4@fHĢOX8|DBɾrDe_X9 7! CC}>"TR@ Yߢ\KĪ7d73}bw>YFRS*(=sa}a8lje}XR`7M9/Ҩ_yd..k d֘ W^0,%J :_XY`C/A+Sp34#Bimeqś*醥0yk:53b* ǘ=Jv2GieR$\QS}c(ێ,`)ŸH<@nJV(.sA4u7٣B\oLs*THzWTR\3} Lښh|]hk,4*k>hNg EKzi~Ie@W@/Ó@`gcѴJL ~\lZmm[򩢧91;s;u(-re^]18"WA,oi%·lF+zv\T,J0I>JNJc9%WZ=22*ehZE=AUxQɿi}Y\E!$վT'DycmpVly3( FKt40bS<:* 535 ]~[:8=>2Lec^ԩY|76^)1u/ "WT*.UI% o3 rɛ9f~Rnl6̪-;N{6&-Q>%t59 =SD} =35aAy5*Bh+mX7q/.:S8 n[9oPw+טp)`]_3c7)'9әUܰWŌh!f&G"^L2ZhДMZD:y!:?4Z[{gK~9 v>O%7|K_XGYYLCO}X=e*!1AQaq 0@P?/TR ҿ}B.\ ./B.\r.\HAGqcYKH:8Z- ^ r˗/+.\peƢtr/~\aU@˗t(0Eȸ.C \(HL :?rѹr˗`˗\ yʉ 8?ĹqK?}<=1[3=P@:J333a!/_\r_K.__a6 uG=02/aHtFTRt*S:$r˗*ErTJ+ tW򨒥tN+RJRQb躃^eAX._*T}oYR W&[`UiQCfU|dNL#Ѓܹ}.\}_}/*J\qbqܸ *U[]ZS]@5T*TAper˃.?Q%tu ~@6&B1s_n\Yrˋ/(zBTI_en-q!c ҄_*T\/*TR}n\}n\Yrآ+miHrM%JTQ%u*.qt#lhtCۡab=0ƒK#$u\2չrοJ+/qa O)D8f՟~~%uRu.\} _CsGAp /u]rUꌾ K.\Zҥtj$a0^J`Dfaf#% ;ch[$]#|oM*!P%J/lJJ+e1_ٔʘrԯ}.\r\}*T+ + l|B涞 2#ԓ.5io_edͶYr˗JRq ˗._\QǢ e"G>BQ(*$p`˗.}C*;.\r\}jWa:nΠbi{x* +u/K -(,wF* ވLڮMsX[n\r.\rR'f/6XvkLJ< n㺪eOF A* M\a2X\uV+d4U!"`w2yFXZLPr .CGt%n;]*B `[ekIܴ(䟿撿rӹ0z;T0Q8HTAi,splXUo+L`Bj|ےpӎ^vAUTUr@ ݩxF- ҉6X`JVt*422tr˗_r J*_NB|gh6 fc ANs%$5& 2]FE\`awt$K.`=//]W{rXIPHͰ]/l h4גBlHƱ#߿ig~0)#Q^B}~/1~isX(ϘK? O)׼ǩœ| F":_*W0e9꧜ف!NsSUKB:0 !JoRv00B#< dSxKY/d`y Ц^‹c^/ e88)Ef!PӃ{0I9!npHW .,y贝0rǟ5r` P{ioPw8B4)ōj*k+LvS2riʆT =o3#Vf ;+ODA, B!n=Ņxq9MBϓ=cf%n7-o%[*ϙV Ru}@+E?\rѹUnTJDK1V9F$yQ! ՕbdaR8+V-)9KHHW>yuhw$%5˗._r.\W*\+}vEzd(l0(LZ>_T0A r|m,%Zd:Jk#s{|22%baizIf; R[*r9>0m5V򚔆C~f YuӮ 7 BhrԿ.\rɨof);`S# " X' 1.Xq ]S!qr#?SdHrX^ ̏:5QtuS&Gi/v/99IsXr?/B082Y_Әjg?Ws[O*j]460T/:=e4XX-yJIv쵨<̮r I<1K˿}wLx)P!osAոm;:QPJ)^׵6OD*& $NJ_E4^ ljRҹr$RPG"DzcUn W]JRU[J*7 q!k~JU7.ԫFv)ح@%괡_.;3yY7CՓ.J pS~KCβJݝ[ Bo_*TIRWST\z,<Ϳ;#i}=o+o"L*Y\ޞC-eeuIyW*j& cvsA-koG ZP&>.(14ODVwwwzV>+ @ ү?#P ZDHqV2ŔN!S-_C8xn$_w.\_wy`堨5SP=[]Uhߨ+%Iʺ!^d"-r׹R=Ve}t#TWM} Ǚj'kLPY1P1 #c{j0{B|l2s0e?Tf4ypwFoʵ 65D"_ '%. C@mcǍy~&mR{ 7J/H N_rr%J#/^zmm^4Lny%Q3''=8MAoklJFNפx-e˭+R[Ÿ.Uq 7.\"UmIP`̺֋UAZ&K8! |sr'ĻN**WG~0UxCoAMrR)Q 1ejleϭTZ\ L RԡV( %r7(򐥗FJk&ْ+l;nT "^6Al? QEB7i3NU z Jkk0ч㔙f}X=+E| =Cf⮾kC?5JӰnJM$q 77)RV9Db;g{3jø ^ M!{J&ST8b0|}n\KrkM ᙪg`N%fi)nX\Bh*~An?79^,雔? 2˵`f+ 5Pmu;[26aB[*z2,!MI2p9WBmc,tzWr˗/L[)+ZvsCڊٓ:EXJcjnݔCrw _L܌ؽH)ݧ=@;pU/%QvS98㜭q?wrSO8L]aY#;wѥKiK)c7)c@L"/[1JXP`h[y!EboeZqO{C#\_._/(4rRJ3ʸ"9b5De]l"I))?v2ª#bu+'E`⇵k{ݒ)ǿ`BW9\%V, ݕajk*O*WQ̹D׶:G{D|Lcx| |Z u;yϠQ)2❘V0Z%>' ¥={9 J^rl!,!߸2, JN-`!b`D[QYvcf`2`)q77gSjB6>!ݼk˗/r%]*k#rf7ӈ4$57,`B4#*e)G?,1̺"ިʇSk-tTݨX hEs%%==u<8c;y$Iڢ_O37`|& *u}HTj;?bielU<dHcC,sD$&651ah-`ERJjXh` 2_D}Zu> Ha# ʸƔ6?}ʘG$KKK< r,1 r^2 1â!:^qm̗zi~!ME{=OVHv2Y._}oQ2T66R^}H?~lEk9S }eƕ=O If¢0bXb7sv<.\zy"C5olLD\!6 Kr}o\r+øj&ʣbxZr66.0h#M`킣UNQ,9 7ZEZhri-,QU-_!b_r~LEN% Y8Vˢ\˗/w-eD dv>'iዀ6"C=/SP3Co?ք׾n6'{A*ntf.ܼfg[h4ݧ?n豎!}X4Z!)J7fdg3pc+}ށTN8M{d0n䲂csΧm>"[Sߊ.ϧw r˗._J7/tPiI_ ɦxc d5c0O5Jk$BVe!M[FwׄX1 bCzeӫ@څa pd瑗y.pT>Q9H˓u}ru/jW}.\˗/_[k r ÿc3d0EoUKh0֯f*|b:neоY ʚQMN#ZbJ||b#1!b#IYb8a&£0Uo!J^7zG+"+B1vP/Sʌ_JVRY~S+vy!TiBɸ|[2%Ɏ^ kJ;[C;pTX:ZWbam4ps}53c2g[xh0(bP+g>f~#j3m Y2BT1Wous<L4~Xu *~be˗/\"i&)㝻9_k'e3l-a8/ A._^,&wRHϘ+ z3b@LTz&^G{jig鸎ځM/o+3 ԳRrd4BM :nI++Њ+~(D,)\Gn<:e1w8~f7\2}La_bm5 U8#22OUM=хJ*A.U{\+-ێ5L?.L9mJ0TJw?WՍ]^UM^Xy{6(w," Ev ;QB|`X7 ֘|{JzW|2W.\r ev~ }?|:Vb<8}~*)q Rӽivj $2pTh @}e0w~=Ȥso!SyvCq~? ," v{':#&jr Q}3c6 6'j-MرSJR&tt<^RT>gץ -GDqKƭЪqUqy !pʏ"ݱk{Q5,?f~茗U]߃xbݯ!T U?uL7LI!n$ϯw/u@sɳFpb:(ٜ&v<-!Ji5]ahj|NpqG7īf-gzWXp.FX}TD嵍/\< lwA-R]ц7NX- i>%tB!rls%;.rRJ޵*_|U$WoJ])yM3cOi8BG &)t"J6K* ^pk$%+Px}Pp+ T&IQpς ئ$c+i v0Ơ.܌bW!Zq4y!YrC"b6VHJsv\?BG3v<6b ؀g!|0GXɹ&\  C?8drSl͓fGo$e)cZ5'ҩO M[RRw3ȳ+x7e8EsaqUeFEApJE$Ko }o$z*hsk|gs(J.f!E ὏ `,yC}J"ӤKxNA.=]мɦTӲv34=(+ T1k)L`XR* (+[_c3%UJ][%s+?ځ t(4MɬnMe=̻@a@Ƽt T's>F½ɞ?L.U}FE[%y8T NrDB QH @m$ +xȕZ3@f"3 &11T31&tX#ζ4d 5/C"i UKɖ/0P_{k _o,8y^1nx˲1f,u+VDt5߀)C@<:g`pBVicАѷ]ku._lwe[""mƛȝcpg[}(S`ԯn&N3ɃFgusf#0eqY 0 NnuƬ^Y9 P( lL@N Өy8M<8pJMn 036S4\9u-g CWkU˗._KЮ͙0mCE %ak+>M]1~bs,vCΎ dx=8LZ00ො^o |=تUDϴ^)7V\^Sұm (> bjŽ3 1k'#Y2'FNQP9P'?&zԩ_.=YkіU#s_H&L(szf3ty5`'Qs4$4ld|cU+w F1Qq3ev0KȌn y ZjF>X{ X5EuƠ/wHnͷK7%$U33U|f6cPaM{ƹn)7Vþ+/m`3N tݚs~ N`?*`rU'(Y.Ԥ1#،aYGm) X%,j*v~ێNQ{[W(!| Ǭ Co5W1Q3HsX<]AgT6?K*OOWm!23ow=NB/CR[%L_ aB˖K",Dl4oX}Ec{+NC_ <}#цH22ҊPB EW )X 1b X- XD p3v"adv%j ¹ca-Kޣl;Wg/ F/Y&Wj+8lßlq2N*YN0_7‚lՙ> ͋!&צ,[L R>Pq%I/P'ǤXc0I?셞*/aXA PŶ im>J4PdZŔpOP[,߄Y@+UeeIYbSukQ3`e#Cp4ªddcMU2VKa.Wc Ԧg]7Byxo>=h~6~|j#W%.15Uo_㾗/꿃SWt=_/10)tx ˥e?T ^~FE b ž'.lT<69հVDhoL4nk_-Id`66s^t+ )Z4i 5`[dޠ~Ț[jA1uNTSBhƫs1/&cSMiLpKxqV>+aRp!/?bA6ʬh [1gNDZg?_V5N4jpq;|E=WR F_'/g_1 Vo\Ꮏ&W7J '-UhTAC/"FemyBdMe®3p/Zb?Qn6a@$2Nl8#@9le#.!9pzPXIS +q*z4kjs?8.Rv0.Pa]438gI@8 mfh<4T$݈^/A(/mmyTXmeI{KfnԗUf%aܐ[-N*YK c'x녮gljbqw`wr *C[cpɗ7lӫy X0̉oR^U]2 k8[aOTk./ByBllNDǢ zr힇_ORkǘY,J;MQ*˗6S 4nɥbR0K];*y<b,WQ36 ]=t|v `ÃMxC Ac@J3{UԢStcU 9=gT9S 2I?C2]ciiBhFfnb[bml65rexLULY>8(j.l\1UZDsue ,MkEBƞU_%kbvqQ&j^,y82ZFh"-d N`0;lmr wREE0k`, b8:Z%ĻPklN;c+8e_[wc8ߗe;AsGvW඲_dG¿~12[ǨZudҥ}]+p؏@ 0j_cVgٙc:W}XF6W JSpߎ*[Tp*RKr܊%xnʐ,N3_b| D4 Xp C" \iż FypMd&Yj` q4t%*ʇp_`j9Xv-FQlee~ tlbCXZL)DҳErj-<8\N&9cx`51F\YcWGtn_5ÕL+JB;aB hdI|vJHgjbQDG9ya`pfzFԿt 5Zu,4Ŭ5z׹Ah!Bj)V4h$vn+%L2grI(Ҷcɗ& 9sPagI{@T)(xuZj'8 uݩ{@XBȮh9HX ^E k0,- `J?-R#1FU<{U'h4@ x@̢ͫ>(s {Q= Ѻ qIW`RgRPR эoe4GMQ«k:iݟ0A@!\mB/ٍEaEFy&]}7 fMxaBw/9_-ƗOy mf*gB'Nj#/rղ&e0`*#bz^K Ib}(ow rH y\RІfҲ0m KTFRx‡vfPw}60he Wn IJaE1Klp*6?K@ݷ4'Bt )DNOnvBrPxizI WEoq3_;edx旒3Yj^NVvޛ:Ra34鴅Ijͮ$M[WX{"7堂W;Ɓ`8X@+eBPbOk֪hKuhYWʦX[0X+u)\ؼ*˭AbRႋ78#~ H19r\jk_eheB[4LD9F(KYnuĽC燹Eu`m?ilpt_vT`L_ ewXAXq$ե>X*v=H ,HU5pXRW\]2SD#BXt)صr*3Gyc_/e]z^a_)A>)1MATi&*-ʋdٞ[< ׅѦ0 3^EIP21|\ Mבw2xܸm j~EcwKu8D \&<%.-2z4(F^ ^"ʽT@Rv!!m9~g;n-YQq+ U:ז&ZY#T;1KE3ZOoGیO,C~~;_^o4D'LJ%ƈ@C1EH_^C߃hN܁i}.b_P5DEKϙA8DYMiZ̪ruX@CIZzKds X.Ȳ1峼m1L-n YE(k+P\Ns` g5* whYfa}Rռ9,  o^m|,CTc4B*۫?@ qC^~+pbA1X[ "98z6w u ט[39:{wB<,_>ŦNx8}3F{oL}:φʳ)| .HA/*%)[Q^gWjZ(Ⳙd6^9dEٶx ?8Pq~nYH54n!7Z/,%O J:vZkl]=einRVJ%^V5I, f)I! [  Y.aC"cuF%+ڥUi4NDcsPG{9*YAv9p"` ~3)$L~tB֒kno0缩-Ear =t Ҹgh n g 2:*Urb#IG'r ,b_;JSP"#PET`5ⸯ)2,/cYc/L3h@P _r3z>5b]XXW֢ڣ`g#RF@Xp ԡanԘ!U@b--Ӧ̀A򈣹c0ѷ@p9WBAF!k)"Få۟rK.K$jŀvVJ#] n"3sD*̠74Ns) 蔭SWd$o <Կ vJn{1Er_Ob 2vCcp{V".yb_[`j0ૂ9fOӦ7h+ǔ{Lr dlu˵>l|&<1;Sa2`+54qBn|XmVë;QjsX @LSVDolJ5}a\=x͐x?.ގa.ʍ^fIR-E* gf`uD0B` ."Oz(K֭P#$雄R.+W>e7]-O-*PY)36\(\J:=(sr*"3p."rTw)6`F1r /Oirso=ATډ)wOhP_ aevPN`՛ٍXچÑ S^, i@j ;ucgDV ,3 Qp=Owq`,s$.42? G"vƍRryʖS]$DWQ0ȞA`Bn{z$Xza[Ь), L{q XE/3F2c ^'g_$շL(fjw nf)lD b#~e}U lgdm2W Eh\ybB[VD.KeoK(X ̝)/hb6Xskx_1Uu&4TbXUwtx&\Lr o9 jɄ"zk j2 4AAZr鵹!#'S08mM׉)ŵUǡ!)nO1-n\5(ܟTG>TZ\czTv 0@W1 @0mRvRtdJܼR@F2"54BA6(gLkBiNfRQݼ*0<,805 g>=2R/m/5Ev7;"79n 32 %5Щ3Qƻ ȿ "WյGU QSN-·.{ʞm.WjN'Ԍ,(ڰ`Q%,.@|B O[igOx,(cQs*8!A@!Z\"ɲd vvM(hM#$=Stϑ׷8cZvF#SOLِb!: U|P*VZb֡O+SK/cPx r {/"ٽc30a,KTBf{|Ӵ3Cee\[a0ivQ0PZl3\ҳFc Pg VJ.`Uyq=xu+46\h+ m{]xϰf@>#v㰖)^V.1I퀘 [XٖuZ)`&l{٪9kGA(Uut@]T+y_*\p=fZS*X~p܅m9m* u3oԷ+m!Ig7L_buRXj}Pϸ's7 b ObK#~b-(b\sLD, dҏtfR/;ui%^qb to!PggkXAScNC}ojHb1:fKF qN?.e? qPi|v" &bKq tf"0b]>#V.QpswMcz,@[~b~Q骸U&6 [!+/}azHe2f-K8q1N֪UNSe.,7pDh>z%w497a*Ulmh"sb k75{bP]Q'Ee5wO+uUDwfljE0[w!,чɘY+[؊A}/~]hj?eAgQ<35V' ;o/,lEe. Q6pY2 X 7*S;.+־ɚAՌO.YV\3^<#;(F奱O~Q򧐝vX׳*1v0# M)FhFfDfY~߷NGi'AKq 8Ɛl}V;B&񕯍"D(Ͳ|BEN އ/t$e[CvdCL MYmƎ.TWp =xүew@c%h̨UJ5@Ҧ)pneYJ0P-"aq`7oi,!bZ+q( y9Y̻q8R e8I46eY"[RsHhز4A…o^p^7ܢrg2ݟ\;.ị% l%B`QyG\F[[\% Ơ ^8DUzUl*D5'1EW y;p56b( :7v~(MmSVn`:VB+l"o-;̸ՋL:D, fw~rF#: ߴbΘ%&ILdJq \4m.qv*ٵcDW,3,ᭅFBh@f y7Vr1-qU@!yWn-ET%hY6S2ĭR(Kl.8n4 'l#ԸF.c>cVhj#( 9v>nS(ޮ+ L>B,6:Uj,LS^@fP֕ y,he*5dȇvQbr#SAu0Z{̿ĭLV(6/zeо%r8r4#-%Rsi̳<_/CY2 >ks28{K"\1l^Ɲ&b|i!X\H`j+,B >a* l׻.pJr@-¥Uo-SXR7[d3b5CXams2}43اDF2𜟨KwEƍ/Z1Nd2n'޻NTd|Mx)?fm][~ɗv% Hߒ Ar‡1iмX4X&ʓA~.Z.GI^v|BUɘ_4Kڲ,!A;( (`Sd+GuWtq rZSW5UCMRPXL1m8|@g8̡tlm,]ʪe.4M1}v2rITĭ9~PH߆qdhFܙ7M@yUanEE1lZZ0Pq@uK^W gWA1gx-S%n}Y" "3;'0h[Co-("@}b_mANvNo࿹_wCINvGL슕h?/v|~ S~?a-XҲ+?0TZFfN/E?r1Jⱏ*{ؽ1.U.0s*xw|ᘤ$~I&]C=K0]'ܴ 9}x2i4Xd<&Ƞ6)|d3c .&N{\UԶ6]V aшPA]&ͭZsSg򷃛2*M%^M&u 7bV@/rQMfDQÇV1q8"Emw+_{&$J+;@4gO̲ ˳߁>D/ &Z;GVV^m)|R5H&6=`~ѨnYdzR`M".Eb]R}EBoo`Z&Jx ߙfj5=E" | !Y3&p ι"$g;˪$D4,5M]HJ&X`6,FTE ]+CYV]7Y]a .lͱE 4#1b3 h],tby bpX%%su[f Qnh&Q|D \HoA;`4؇!7AnKa3guBpL(o}K'Wq F \PK$̬qIN},?07)-iܳq5 m2Y (#k|gXR'?#QBo Հ!m}@.˚Arr%-]Y<ȋz&L&{[ÿ2zLc : 3-:4/}iwPch#|Vh|ƹ5rGwmf:w2RL+QqnY4شuD Vv Wj1򺶧kAR+egb*ཏK÷7@4%1M]%T%VX@$l{fvsօ ^W9~V{%S$<"; #6_=΄w}RAbV*bGSR\c4;Lf%DqKswᘀKsMF;BGt뗣 2*qVfh6_lr+$GDwv_'<{)cy9qpV\Uj=ʙlRZA"Φs_;#Hbe&!%> Pԡ!4xҔ”_DTÚnT E]7W%"휆Tv.ͿE€8)e*]{FexĶedTƝFH[Lbv @tTC|Z\pJaAVjZ;cT*)n_!%ў26Θow&f,o `,Z8+ g S78n+$.L/"k}{ Jah*Q~q7|ef+ł1Ʉ2[$c,eAiZhU}$s,G/ TYj"AbweCB̓=ux]Cl&l|4ZrPX45ah  y5`=;9e 4A ئ`yk&XQc C5M0ԳA!o*!0e68GLb` –/(\U˥%b'f bVDI>*)|2C5q!/4=[LH6%i!abEVjU2D~X/UQz>Pܾs6*bes XF ኹJ>lb8鋯A:'"xS!MT%(WB {DAn7oy\GGZ!d}Bh %A*(QG{j:d n -,$f [Bqm)"Lh UP5X[. ~+ 3׮ oaߕhTL,E"c@U]h,נcKpro2t[&y3gzK}F^$mUj1}#wcU1˿1Ífo'VdzIH[tL)ipN9Z*dآiZeQxã'fgyO] jRq To(Xٖ`2)⩑1cx< ٘z0A H򙋖g*C_A,(7!@0@[0I&уTVtNnWN ٘,.'m_*un֠q-%j6f)R ^{K+UF6T/q>6QVeUq3-D%VW[weoUM7ž#f@UZ 5(/$ei+loqi Ւ֮i5J;a3VŸW*[ZUPH8&;$4%a|lq@&oD8@oo/.R.^,?WIBgeЗ< 򦒺NT=2c!ڲ@?XcK xaV]> Lb}SjI4q9LRan}(:Ȍdy1Q0)뙈c7yn*FQ[``mf5{ &hes3=j]RYwjR)4QT*WiVhSl9bʁXj! fkLJ0;wKnT,hyBk>heWK)7=<Wjp*9 eXj7r|aPzv5vq{tS<@*!E2P ^pA6QIGgYvHKxgf!nw+LDVdWzdw ֗=HK0W^ yYww P1߷UKGmoiYNe-=n9sEJxǖ`97'NG EU8ݙƕe C 1J-pDIh%Z x?'a97}O64@tLR|G&theԔ B("d&a.Hee.q~h [0>FV/x -mt@4Z)dEY[fc?2LSASM )6ALU#$sNPZx9qnŸ4#c 4@wt0_JؓU;18#[ SFVXcyNM;*)*̷KGvA "0Kҭ,J"xӏ(jaYŘ7+\ ɔLQa2ih ;TstTD丘 Gf@{Љ?r zVفQ9n_׆v)wڋXaS|۽],q|E0!:RS= Zd/89^+kb uDWl)v8 Af{4(Yyn̰䯍{ {Z6DkRQ@  C^&jD!6q~ _@zH|FZ ՗0Qq{I|"Pz-AC6L-D)4spq`b0^c Kv,(U|EAnp6xށ\.c ^#(1TeLO%bR >JS 0eAH6ʄiWQ4;eTw}xD7 3;'%s~Ҟhܫx};&2}יnnљP+, qe)O0C men6Zl çDRT2|nʎg~ s~`/QUa_{Nߘ3 ADD] 5w `N AV(Ķi5NۻBO'~mt1(\BPM7uF!md ,rlآ^WF'v52PZ܈~'0ZV6P3,K">6[?b/s;vr^QK ZU;xT^LKg,n4/Ҋ(I9 V wC֠*Zp #O5zn@[`)w*K5͙nBK0k9̍5ey.~>b zqZC|Oٖg[3h |3n|Jpnr>ʝ?+*7VPLMb[Qݍ2,e ^ 7:$Di-I:{ڢRS`ʭݞd?]U/ Y8G+}٪Ke ɮPGI"ɭ `4Ɇn8`wlH3% l=V]$0B#N_c/aDĠS4J3z`WeCEwTb9|o1E/bw"v=q7:i.CCheEŰ('sMr֮4"`d{ogԣj7b kR@b/u0(f&ں7ĺ3wQ4y%,4_I[MKS#' K;#;a(:ebJs~WCIxVa]O7o8 Id +/۰'`nMO1I\> 79{Nu7@IPttn,4qW@UZ" v@{>c)u|MȽWI [N"#V>"AKS!vfzK8Cؗɦ[xBRaa5ŹLs`˖!PÝQK'AwCݧs&j)[Y}ٖ2O1jA%:*eKP^}sƎ* + =Rh(}"!>l Zw>e#Er+,Os|^RF A/-=$g,ݡ~1l40Bd)m'Aߚ1J,.kL>E' c~o o0\d{_$טd'\N f@U@{$X 8{'5?hcn5чJ>e/D{6U;fW9XG}[!q13a@,6W3whdy!fQiw*XEx_XfM A`̢\Y,qzc,}{&vndv˫ۂTļbŃ._E˗J2~^b8e203E@EA@.Y'&_]i< qy|a8z#6HRŜc#4/xPJyy7`1t=UCkaϸZpfDpG?A2$h(A5v67 NUocEUy{m%Mȗg0^<%"Ҹķ0UhUe;ZqqF$n}s9J(tV(a9\;I 7p:1vkYFmf:+w)N٥v/V+Lʿ3ATo&>IH&f誶*\sY;k[Yг1"& `Y{pK|EWe;%V4Z*Tۇ1b/"pA AKja q͌.j9U1[BG8#,d- sZLpt`oiU> )&Y9!.,RwRYPXC"FXlxln9۩3Y< je,e+6"v]۸6V>p#q7M|Z& M'i4xѭExq1PѵʉQ6hN&OeӦA"hd0ea1 mҎZk %j=Wt RR? G"b*Km~hW1/e9|sNnOZy UQV8_ʃQ['y$1,A98`rUX~܍@A,AAsYVjߘ7.i\L˩+e"HBhQh*{֫{/Yj*SM!dQzc:0ˌ9`~^ 56e&HVaX*uor;M*, hYi̻*0^a#ܫDފN: 8!x+k Xc*8>S0{\ Zô6.XP. B`sCZ?(ca K0K 1:ZE[.1,^;&:x*2{%; robTohV+g>zCNbmeawU+K0b8|=g*d4=ĨTRG~bj*) oAi0\EK 6"Tþ"l 4- vN>LA*{%ADXPDwao0Y}r0GȏZfw?Mܰ.iw.( S& 9UPo.sٜKo/><$UFx%071>F6KHq Dz\pC厭w% .*%`x8nұ,݌tTBext.rE.1vS UdA z4\k*LA.h{?IGDt)4XnBlĺvg},UܼKn̽^tgLnxJ9^3l"$aȁ LM/h;ʦz+%l5 ۫( ӵ8 z[.1uW8^ZoKswXKLb/ q"D= xD\b^}VWYL+dV̦h /p/,BDwTzo{!՝o苓f#kf࠱>ABl](ɨ' CfjhYi5aB A/1q )E(o2?Ɗ`{>6"Vdlt֮*x:Q`6dіZĿDW3z]#`4q*O䕝:i@Pr4xw-^+\9yA̴Y9&܉t +U_XPhq J dœ[_:Lo|!գ)kO4/2z0?!wO8o [>(jbT7/GcdGEc Md75!v BF<1,!*"3LtJK%NzBu OYG1bH{Kpeo%o a ʼney06&Lp5 hP^cXU{?1qLeÊ#}0[͑XWT<#+%K\SH0_I$UMҷAt#5<߆t >J=%SG#A>Jt*#m/D0O ހ~п ,W_P#H`.%-ۿL _+%7/*dZgYA~N|,H+3ƩO7~na0aWZZӱ>.6w@ TVm }BGDx%)dV4&0 f,4Khulpb\ӱ 3*Q0iUO([FO;NIED BII0_r1%l%o1v"09.!pkj4XRXpѝ|+6prŘn] n^R# U<!#(8Hiem - [N`J.T҉S" ROhk %8 u >)geQx`.q,qZ"i/e0>UqNJ\x @+rհnahG7yB!(D(̳-X'4f9[6;YP̦t35<]*%[ɇ]@nOD6#Nҽ^0yE^oh0`e;&-@yd(tx)1p'`R^E-5{Ga[_-9TեxL+m8ipV\rXqxE.ձwNupܶ9ycu)فR9:ҨMވj1Yj*!u]$\-l /£y\1i撬=Ls>Qiw`fT0dШimiX&e8TUv"( Eȯ#cpN,z0n2ZwYZP*A oga`@ Q/i -@蝪FZDM©_0 :\ΦuM\ E6V8ք GB@l|ah+Ȱ*Q'lE^fop] sYsnarX" CR%8h 䔥neIp3F0?0 hyv!^fji4eNK[x8Gj f%af/?c/ZK mW?K9A]!fvq-{h4(Q @+ZG嗟v\*,fEl^&8q[LP"rlj4 XZ;B"US l>).&. \P{)pfx2>/¬r/xx/F%Q_L|?!Fc|U_ n](N|B#P86Y蛁#agAEA18A)QxJGr.0T3W*̣]땊)*W IV]w"]Y .VS.9yT(հe3[ķc wTQ!|Nڌ\ZKxE :'v"ۊkUE3F\ g'uk,Q{45JᎾp*4J7rCe./5.a–-OlNF#+Ǹ*Ih+4{ 1%zhS<˛--,[9=S1q12˷`Hsc0S\ U}Y>X.Q)(7+5)Jw3eRkAv`s[@8weg\@5 -L@ o /1pV{Vrhde &Z b{.uu(Ec 72ؖdHg&4S-Ūyfd܊hhrܸw !ouZюoU2;`ٕX+rJRZ=Մُh6\@vąMψ:C0qIP"X9 5~.YT#DS_4\ :|8"OEs; Z*ٰ(G6gBPKߐ|{FdP3JI^ OxfeMܮG@oQ?vnR (cH ؐXm@~@Ǡ¶!EL7=VPUwx `/~1ZsL+F^* (t$SDKXwQ!aPM zŗvpj%=!h8%2FfzEiYBzO &bt hUñ#\+*d/+?nPap!N@F.ɖ{ a(%Ǚ B\b&t}gii[lG&6h<D;~.LӔ|dQ,;X4^kQl̉@5sXv0\#c!(mjYJB<76ŵ1U|. ZKffx3HD9) Icc.#H1e) ֡ܬ$]|O!x3r6c.m&88Hܗ+Dj@о&{0EQJiT8E QM/&g[oFO.[(jX$w$ݰ9:XMҸ!n%U-A@ ƒ6@~ |1H06T^ҎKGh ʦx~ݡ(]Z-Vbfod0'ZWlsC*4)8ahP#I%D\m=4 +>VM'ZHUFKwy](BQk - .2ϔT axUvz.YWX9ʨsacnC@385)_#ꇡNB0]Aġ,=&40 `'qolø ~+ R-]Q*OG4)!⢓B`= JwSU}پ,Xbcn\Me7'VL)bōm!>,ߊ_TA99P)Uce\STF=KpA FB,Xk[.qfgҟqݸjj: >b2m& [;z,0a;b D?3xhX7bʗ%p4{;#._15߷.T;oQq"'kaP^HװE#]F]V=t[)l=%e 3qnz/4; Uh JtFĺS[fV*,XF3Z@Rk4!ayr?˨9.ha a Jހb7<_اH ,uQ2y ;֭C\wz!106,F{y!ώP7D*w+bzIrOܵqK}6dDLO %,Sz')a SK2+%Ĥ7 *%5AЇ k EP8hdR[8-5Ƃ#d:dإJ卛{:[s{O":(d+ R]d] %Up7(EGs]#dǁ%7B›Hdp/w_ kjnY N1򂶷xH׶0 ɿy.W^y px{>!֤mmzT.wuM©!r xw^ݒKUT.5V0Ʌ aq w%Fyfj 7mK Kt'3UL.5,ɿ~mbĜMͳNp=1+f5Chbw\LȆ%$RRM#..9R炇?E!Db(;ɛٹ+x~ѱ&f#׉IND40JD[|/ /N V5T>%4k&]YcnR\,2p+QcK2<nW,̡RȬI6ylu$ |DmfK)-МSeA_æi;?iq&Vjterxc]q,YP\K`'Ld"&l~N +9uCaRmލR&oFpTFW١Z`]۟$uen"e~MYu}@{PmB\:B5( SDgR..)soc`"fy)^P!P:f3%`^J1jwHQ@*a _snpl>eCT S+'{.V U(1PXl@2AZ-|9yiW #O %w3k6afjJ;cM0yJ>FlQAPVS-賠86ja@$Z7eKf:?!k * xB cs̽UJ%+d|M,@ 8{scmÈW-65 KufrԸ K"(!^y?FeW@`lf~zYSg[T3f7@nez]C.0@]r,vX*w2 fj+tUC1^x{Ǹb;OB qG,ޣDEzj-`&lwءy ?gAĴ Cp゠#l 7g1{XU0.m7;0U\.RβUU0 [[Fp\"9@QqAlLveL兘-a+X ~O$Kdǖ:n!WhL؈-֏ܻ/\qR͌ÌZ8}I-jƘ`eK07!% /UɚnT",o(p~P-г&.~cJ#"@&_, ̂°ަe FT 9L o2p 2P+d`hg{vo_1-~cO1TOw K,L栂ޕ&D@u.٬ƊU.}ȚV4dU[pJ|ҖU dX¨̧Yȷ-UhDvѳaR0Y%obQT^pGȈ-K(Jdv -` ûw+D^ NϕR!M_IWGRЂ{ M%jNkFR[;G3 PwZ +/aEu>E#dyVf xXov7$%)ڹG)0zj#AjY mxFū D.2#"vp/p6=s(ܮQ悆X`m7XJȇgq`Ӄmka ̶M)RB`[ &-%kTӪ10q6 0z+#+f#A|$o%C?؏TWLXx؎TY6|Ԫa0@HH0Td ZVeArQ|m"4 >me,5; +DB(lR[̯$ P )BCD\`Mwa97b(&3h[tԁeQx(\$b#Bs 095BEуnWS8)|D=tЕPKh]-MXP2f#Rp:V's0vx<&=uiو# mm  s7M16` KdV(`ef<^ҸL[\"]1ޠ|0<^UycG$9?bˈXrbjhx @RsWKޭ6ЃW,pWf|j KU;\Y^a! M(.Xc*86 er+U'F_<]=q\30C Ҍ9.,Bs 2R͌J4 ǵHÃFYPGÌ3^̗`z3n l I4m̃v7Ohdr5* E& 5`_Mie3%hɉp1Z(k@*E'^<+uɉ]pCL[Y%TlDUt ;V']kp0]& \D(:&iu瘿Hmy/%^& ei-V,))> Z?e[4!ݓb)" W{+eӕ5y2,w,W9zK/B{f­|6 F&p+z{P鵗Rl<3{z*Ux+qa|"ysBu@zYD,9^K5K}P-艔K>f躋y/#2Gdqn` ^ )Kaǔ) \WB-90 ys2[Lfc|H*̭@IK95!t'4L2EM!21 kj92 @L̕ͅv0ӄ11|UpQ79En`1,g'yx (K k!0ґ:ROҞ{Ѐ0md=jEdۮ1 B%j Utn]^cmԤL5,‹cl5Z muzZ wK7uX 1mBO+k0q6L7V` sNa=HC:a4BÁCݿeͿ)y-4F@ H9Y,ړ!|  ,ض\j`(Ja}NNQ t,@q]EBPF.ES-ҡFF4{1-GSIjfuQz|3#3j.Fc8z1hGst옩(.UU 3xc v%,&UxC +B6=ܾOd802›KnnAo}XgF͢cϽ/N?1R>-+u^ ȍxUnC`UQvCw;_pT-0|~ 85[r>V7Jm{>(Ÿ%DSfŨ~ Dq$@ ˂pG8eU&6 xcbC6Y%%%0p!mh+G@a-P2-=ڵ+Mvek,H!*gy3ʀ2r% 3^B6(wP= 4)G4TZEH3V<[A@#!@>)vxa'/cmJ(Pa8^c7}" ʯ+9[/P\@@#PV]QmObC)`ܡ'}PŏiQ'6;h4kY%̳1"![18eq`áYi.D>yFg.Z?aIu`}B_yeVA 7UKA9ؠΎuN.a! *iAM-*F LiĬvܵ~vm>NH`KeSFY3B*cN2F#sw˖䬹AeYZ R\KX{׬v$.k ʿ3Ef֦'W=0T_Kck^n-ZB0\RJ ReA%u5P ɫ ߃ kɹ_l m p,edgS{m{s ,hzki͡y-7͑ m+=)xSp{gG`XJcU9fhbL@4. ng\fgţl~&,&6E-n,&B LejQ Fy4TZ6_RR`t^5 4i棣}9鰘"O,f?LYA˜y]) ]+0gQBI FqU/]ыx0zL)%P3Ig̼.) 12W%\j~JٚK mZal٧a @jWC/71 L+eU,<L5dR,69ơ+Zn? rȌ.+)2CAR#;25< @;=1O67:Y"~5I%]8UċBk0ǥv&Wj8PXJ,68HY;U~SGJ~dꩤyEL֒T/yd ŰǴh18\Rf$Ӝ~V 4l֌*6é<}"u(c xavf ۹:%% %؏sf1#1!oZ_8\`T֮Xg&lC`ULP9MLFt}lk\@+Mʈ1x(K3b-&Ҕj6@`!QV.Xl4>Ax啇6URLD6r7KkԲM/u TDA/k6@Q5QY a*6Xg +nԠ">pK3Q.8qMl.*/G0O`jyߋF[W.<\Tqh8MHY#7]ŀi4"a;qG Nw;%F6FXSWuf1_ht+X9IzJNjS`H+meyb7 1^I_ Zns/ ;-2 Jlo.30.w=_5R(Wph袹L:/1_k6h-# &4@s?PF0R(s'"8NLq5TSHMʱV ᴄ Zv%8jxQ*E,(9EjhةH m7x'.L@lpZ`\Qa,Y,65k6g^ˤe`K>'.Vrfq LJ М6isV*}0Q;Eo)W̒jзm wJ-0%w?A tj7S$q^if.LF  Ma!0ۺOИtèXZ$)g v}m? *>e\Ee>3V>PU߂)v0]ַ0#L9WٌTBq[m_|{㢚Jȵ T[e 8VܬjR^ TF4 hdlcdp b[j^^%L7pzfQ>udAc~tPc3TA¯n{Q2q~ 9VK:T@aL/pL0,L:eo!* Jh.jR󽌤n@>%%%TA.23<Ŏ Vn?fHm1dSLüe^Ⱥ+p2(cظ4myaaZh^:CI䀛unr4$6֌;FXuBzc?3FǵyHr=6?*=Vd'## =1 JeB[oJ(Pji&ܥ[dFTyDP!:S:[Hp@t!?drߕJnʌÍ1=Qh'Q>VXj":ˇTXd@HfX Q7+!~:'J1Fd̞` )hӥ%* )fO  ,%j\-~Fzad3/KYEky'.˦4%\/.<U*4)enlX..>hip&Y@ɔ+TUƌqTńܭm xauyn8ͽ՚fƽRiO7cN <N\O*R\W剪6S^;p+G33FEb{YXU|ehG<" v(T¥1J]!w"81FjUN#-;́?U 2Ytw&#)` $I.@4\JhʔpVXN&Ռ!~ C MC}+
Linux 4gvps.4gvps.com 3.10.0-1127.18.2.vz7.163.46 #1 SMP Fri Nov 20 21:47:55 MSK 2020 x86_64
  SOFT : Apache PHP : 7.4.33
/usr/share/mysql-test/include/
38.135.39.45

 
[ NAME ] [ SIZE ] [ PERM ] [ DATE ] [ ACT ]
+FILE +DIR
Load_data.inc 0.169 KB -rw-r--r-- 2021-01-05 10:19 R E G D
add_anonymous_users.inc 0.183 KB -rw-r--r-- 2021-01-05 10:19 R E G D
allowed_ciphers.inc 0.399 KB -rw-r--r-- 2021-01-05 10:19 R E G D
analyze-sync_with_master.test 0.276 KB -rw-r--r-- 2021-01-05 10:19 R E G D
analyze-timeout.test 0.024 KB -rw-r--r-- 2021-01-05 10:19 R E G D
assert.inc 2.191 KB -rw-r--r-- 2021-01-05 10:19 R E G D
assert_binlog_events.inc 10.215 KB -rw-r--r-- 2021-01-05 10:19 R E G D
assert_command_output.inc 2.004 KB -rw-r--r-- 2021-01-05 10:19 R E G D
assert_grep.inc 4.104 KB -rw-r--r-- 2021-01-05 10:19 R E G D
begin_include_file.inc 3.21 KB -rw-r--r-- 2021-01-05 10:19 R E G D
big_test.inc 0.104 KB -rw-r--r-- 2021-01-05 10:19 R E G D
binlog_inject_error.inc 0.626 KB -rw-r--r-- 2021-01-05 10:19 R E G D
bug38347.inc 0.395 KB -rw-r--r-- 2021-01-05 10:19 R E G D
change_file_perms.inc 0.509 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check-testcase.test 2.83 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check-warnings.test 1.676 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_concurrent_insert.inc 2.657 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_events_off.inc 1.815 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_ftwrl_compatible.inc 3.64 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_ftwrl_incompatible.inc 3.804 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_ipv4_mapped.inc 0.667 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_ipv6.inc 0.583 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_key_reads.inc 0.244 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_key_req.inc 0.613 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_no_concurrent_insert.inc 2.066 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_no_row_lock.inc 1.759 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_openssl_version.inc 1.316 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_qep.inc 1.313 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_shared_row_lock.inc 1.39 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_slave_is_running.inc 0.636 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_slave_no_error.inc 0.64 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_slave_param.inc 1.006 KB -rw-r--r-- 2021-01-05 10:19 R E G D
check_var_limit.inc 0.385 KB -rw-r--r-- 2021-01-05 10:19 R E G D
cleanup_fake_relay_log.inc 0.653 KB -rw-r--r-- 2021-01-05 10:19 R E G D
commit.inc 21.188 KB -rw-r--r-- 2021-01-05 10:19 R E G D
common-tests.inc 115.903 KB -rw-r--r-- 2021-01-05 10:19 R E G D
concurrent.inc 25.077 KB -rw-r--r-- 2021-01-05 10:19 R E G D
connect2.inc 0.954 KB -rw-r--r-- 2021-01-05 10:19 R E G D
count_sessions.inc 0.373 KB -rw-r--r-- 2021-01-05 10:19 R E G D
create_table.inc 0.132 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_8bit.inc 2.849 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_ascii_order.inc 1.043 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_common.inc 2.816 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_czech.inc 0.427 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_datetime.inc 0.325 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_filesort.inc 0.368 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_filesort2.inc 0.982 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_german.inc 1.416 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_heap.inc 0.468 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_inet.inc 0.248 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_innodb_like.inc 0.649 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_like.inc 1.359 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_like_escape.inc 0.578 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_like_ignorable.inc 0.417 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_like_range_f1f2.inc 0.815 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_numconv.inc 44.652 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_pad_space.inc 0.13 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_regex.inc 1.029 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_unicode520.inc 7.126 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_unicode_latin.inc 10.234 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_utf8_table.inc 1.348 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ctype_utf8mb4.inc 59.489 KB -rw-r--r-- 2021-01-05 10:19 R E G D
daemon_example_bad_format.ini 0.21 KB -rw-r--r-- 2021-01-05 10:19 R E G D
daemon_example_bad_soname.ini 0.222 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ddl_i18n.check_events.inc 0.844 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ddl_i18n.check_sp.inc 1.478 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ddl_i18n.check_triggers.inc 1.548 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ddl_i18n.check_views.inc 0.531 KB -rw-r--r-- 2021-01-05 10:19 R E G D
deadlock.inc 3.591 KB -rw-r--r-- 2021-01-05 10:19 R E G D
default_client.cnf 0.358 KB -rw-r--r-- 2021-01-05 10:19 R E G D
default_my.cnf 1.571 KB -rw-r--r-- 2021-01-05 10:19 R E G D
default_mysqld.cnf 3.994 KB -rw-r--r-- 2021-01-05 10:19 R E G D
default_mysqld_autosize.cnf 2.807 KB -rw-r--r-- 2021-01-05 10:19 R E G D
default_ndbd.cnf 0.974 KB -rw-r--r-- 2021-01-05 10:19 R E G D
delete_anonymous_users.inc 0.202 KB -rw-r--r-- 2021-01-05 10:19 R E G D
diff_servers.inc 2.195 KB -rw-r--r-- 2021-01-05 10:19 R E G D
diff_tables.inc 6.648 KB -rw-r--r-- 2021-01-05 10:19 R E G D
end_include_file.inc 2.423 KB -rw-r--r-- 2021-01-05 10:19 R E G D
endspace.inc 0.33 KB -rw-r--r-- 2021-01-05 10:19 R E G D
escape_sql.inc 1.522 KB -rw-r--r-- 2021-01-05 10:19 R E G D
eval.inc 5.732 KB -rw-r--r-- 2021-01-05 10:19 R E G D
execute_with_statistics.inc 0.718 KB -rw-r--r-- 2021-01-05 10:19 R E G D
expect_qep.inc 1.157 KB -rw-r--r-- 2021-01-05 10:19 R E G D
explain.inc 11.167 KB -rw-r--r-- 2021-01-05 10:19 R E G D
explain_json.inc 10.148 KB -rw-r--r-- 2021-01-05 10:19 R E G D
explain_non_select.inc 29.639 KB -rw-r--r-- 2021-01-05 10:19 R E G D
explain_utils.inc 4.603 KB -rw-r--r-- 2021-01-05 10:19 R E G D
file_does_not_exist.inc 0.332 KB -rw-r--r-- 2021-01-05 10:19 R E G D
filter_file.inc 4.383 KB -rw-r--r-- 2021-01-05 10:19 R E G D
force_restart.inc 0.327 KB -rw-r--r-- 2021-01-05 10:19 R E G D
force_restart_if_skipped.inc 0.338 KB -rw-r--r-- 2021-01-05 10:19 R E G D
func_aes_block.inc 3.949 KB -rw-r--r-- 2021-01-05 10:19 R E G D
func_in.inc 17.894 KB -rw-r--r-- 2021-01-05 10:19 R E G D
function_defaults.inc 34.904 KB -rw-r--r-- 2021-01-05 10:19 R E G D
function_defaults_notembedded.inc 2.384 KB -rw-r--r-- 2021-01-05 10:19 R E G D
get_file_permissions.inc 0.268 KB -rw-r--r-- 2021-01-05 10:19 R E G D
get_ndb_epochs.inc 2.119 KB -rw-r--r-- 2021-01-05 10:19 R E G D
get_relay_log_pos.inc 2.766 KB -rw-r--r-- 2021-01-05 10:19 R E G D
gis_debug.inc 6.762 KB -rw-r--r-- 2021-01-05 10:19 R E G D
gis_generic.inc 12.982 KB -rw-r--r-- 2021-01-05 10:19 R E G D
gis_keys.inc 1.935 KB -rw-r--r-- 2021-01-05 10:19 R E G D
grant_cache.inc 7.473 KB -rw-r--r-- 2021-01-05 10:19 R E G D
greedy_search_drop_tables.inc 0.163 KB -rw-r--r-- 2021-01-05 10:19 R E G D
greedy_search_load_tables.inc 0.972 KB -rw-r--r-- 2021-01-05 10:19 R E G D
gtid_step_assert.inc 3.244 KB -rw-r--r-- 2021-01-05 10:19 R E G D
gtid_step_reset.inc 0.465 KB -rw-r--r-- 2021-01-05 10:19 R E G D
gtid_utils.inc 12.941 KB -rw-r--r-- 2021-01-05 10:19 R E G D
gtid_utils_end.inc 0.826 KB -rw-r--r-- 2021-01-05 10:19 R E G D
handler.inc 48.019 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_32bit.inc 0.418 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_64bit.inc 0.349 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_QC_Disabled.inc 0.134 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_archive.inc 0.176 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_archive_plugin.inc 0.403 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_big5.inc 0.104 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_checksum_off.inc 0.194 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_format_mixed.inc 0.151 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_format_mixed_or_row.inc 0.177 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_format_mixed_or_statement.inc 0.188 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_format_row.inc 0.149 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_format_row_or_statement.inc 0.188 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_format_statement.inc 0.155 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_binlog_rows_query.inc 0.313 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_blackhole.inc 0.169 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_blackhole_plugin.inc 0.417 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_case_insensitive_file_system.inc 0.131 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_case_sensitive_file_system.inc 0.129 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_compress.inc 0.106 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_cp1250_ch.inc 0.109 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_cp1251.inc 0.112 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_cp866.inc 0.11 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_cp932.inc 0.107 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_crypt.inc 0.101 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_csv.inc 0.17 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_daemon_example_plugin.inc 0.378 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_dbi_dbd-mysql.inc 3.096 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_debug.inc 0.11 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_debug_sync.inc 0.191 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_dynamic_loading.inc 0.216 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_engine_condition_pushdown.inc 0.166 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_eucjpms.inc 0.111 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_euckr.inc 0.105 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_example_plugin.inc 0.553 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_exampledb.inc 0.174 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_federated_plugin.inc 0.147 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_firstmatch.inc 0.151 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_gb2312.inc 0.108 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_gbk.inc 0.103 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_geometry.inc 0.107 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_gtid.inc 0.333 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_index_condition_pushdown.inc 0.165 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_innodb.inc 0.159 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_innodb_16k.inc 0.189 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_innodb_4k.inc 0.188 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_innodb_8k.inc 0.188 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ipv4_mapped.inc 0.282 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ipv6.inc 0.331 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_koi8r.inc 0.11 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_latin2_ch.inc 0.109 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_local_infile.inc 0.108 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_log_bin.inc 0.301 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_loosescan.inc 0.15 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_lowercase0.inc 0.113 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_lowercase1.inc 0.113 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_lowercase2.inc 0.113 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_materialization.inc 0.156 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_memcached_plugin.inc 0.067 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_mrr.inc 0.145 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_multi_ndb.inc 2.022 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_mysql_no_login_plugin.inc 0.658 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_mysql_upgrade.inc 0.131 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ndb.inc 0.644 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ndb_extra.inc 0.063 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ndbapi_examples.inc 0.145 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_nodebug.inc 0.112 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_not_innodb_plugin.inc 0.181 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_null_audit_plugin.inc 0.685 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_numa.inc 0.386 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_openssl.inc 0.136 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_openssl_support.inc 0.192 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_optimizer_trace.inc 0.249 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_outfile.inc 0.167 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_partition.inc 0.171 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_partition_open_file_limit.inc 0.146 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_perfschema.inc 1.32 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_plugin_auth.inc 0.184 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_plugin_interface.inc 0.183 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_plugin_server.inc 0.174 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_profiling.inc 0.109 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_query_cache.inc 0.112 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_semijoin.inc 0.149 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_semisync_plugin.inc 0.58 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_sha256_rsa_auth.inc 0.298 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_simple_parser.inc 0.646 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_sjis.inc 0.105 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ssl.inc 0.133 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ssl_communication.inc 0.133 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ssl_crypto_functs.inc 0.398 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_symlink.inc 0.382 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_tis620.inc 0.105 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ucs2.inc 0.104 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_udf.inc 0.615 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_ujis.inc 0.105 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_utf16.inc 0.106 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_utf32.inc 0.106 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_utf8.inc 0.108 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_utf8mb4.inc 0.114 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_util_nc.inc 0.908 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_valgrind.inc 0.178 KB -rw-r--r-- 2021-01-05 10:19 R E G D
have_validate_password_plugin.inc 0.687 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ib_logfile_size_check.inc 0.271 KB -rw-r--r-- 2021-01-05 10:19 R E G D
icp_tests.inc 25.44 KB -rw-r--r-- 2021-01-05 10:19 R E G D
implicit_commit_helper.inc 0.12 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge1.inc 22.551 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge2.inc 13.479 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_2sweeps.inc 1.526 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_delete.inc 6.422 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_insert-and-replace.inc 3.581 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_intersect_dml.inc 4.836 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_multi_col_setup.inc 1.252 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_ror.inc 11.341 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_ror_cpk.inc 5.119 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_single_col_setup.inc 1.2 KB -rw-r--r-- 2021-01-05 10:19 R E G D
index_merge_update.inc 4.544 KB -rw-r--r-- 2021-01-05 10:19 R E G D
innodb-index.inc 1.202 KB -rw-r--r-- 2021-01-05 10:19 R E G D
innodb-util.inc 3.146 KB -rw-r--r-- 2021-01-05 10:19 R E G D
innodb_pk_extension.inc 9.324 KB -rw-r--r-- 2021-01-05 10:19 R E G D
innodb_rollback_on_timeout.inc 0.909 KB -rw-r--r-- 2021-01-05 10:19 R E G D
innodb_trx_weight.inc 0.841 KB -rw-r--r-- 2021-01-05 10:19 R E G D
install_semisync.inc 1.024 KB -rw-r--r-- 2021-01-05 10:19 R E G D
io_thd_fault_injection.inc 0.584 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ipv6.inc 0.622 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ipv6_clients.inc 0.425 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ipv6_func.inc 1.376 KB -rw-r--r-- 2021-01-05 10:19 R E G D
is_embedded.inc 0.123 KB -rw-r--r-- 2021-01-05 10:19 R E G D
join_cache.inc 69.196 KB -rw-r--r-- 2021-01-05 10:19 R E G D
kill_query.inc 1.729 KB -rw-r--r-- 2021-01-05 10:19 R E G D
kill_query_and_diff_master_slave.inc 1.048 KB -rw-r--r-- 2021-01-05 10:19 R E G D
libdaemon_example.ini 0.225 KB -rw-r--r-- 2021-01-05 10:19 R E G D
linux.inc 0.097 KB -rw-r--r-- 2021-01-05 10:19 R E G D
linux_sys_vars.inc 0.59 KB -rw-r--r-- 2021-01-05 10:19 R E G D
load_sysvars.inc 0.432 KB -rw-r--r-- 2021-01-05 10:19 R E G D
loaddata_autocom.inc 0.876 KB -rw-r--r-- 2021-01-05 10:19 R E G D
master-slave.inc 1.433 KB -rw-r--r-- 2021-01-05 10:19 R E G D
memcache_config.inc 2.171 KB -rw-r--r-- 2021-01-05 10:19 R E G D
min_null_cond.inc 1.554 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mix1.inc 48.49 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mix2.inc 76.807 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mix2_ucs2.inc 11.522 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mrr_innodb_tests.inc 1.548 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mrr_tests.inc 16.037 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mtr_check.sql 4.805 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mtr_warnings.sql 12.009 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysql_have_debug.inc 0.956 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysql_upgrade_preparation.inc 0.759 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysqlbinlog_have_debug.inc 0.966 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysqlbinlog_raw_mode.inc 9.744 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysqld--help.inc 2.17 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysqldump.inc 2.019 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysqlhotcopy.inc 4.758 KB -rw-r--r-- 2021-01-05 10:19 R E G D
mysqltest-x.inc 0.04 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_backup.inc 0.396 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_backup_id.inc 0.908 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_backup_print.inc 0.448 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_default_cluster.inc 0.116 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_have_online_alter.inc 0.516 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_not_readonly.inc 0.903 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_restore_master.inc 0.598 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_restore_slave_eoption.inc 0.611 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_setup_slave.inc 0.849 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ndb_wait_connected.inc 0.459 KB -rw-r--r-- 2021-01-05 10:19 R E G D
no_protocol.inc 0.297 KB -rw-r--r-- 2021-01-05 10:19 R E G D
no_running_event_scheduler.inc 1.513 KB -rw-r--r-- 2021-01-05 10:19 R E G D
no_running_events.inc 1.724 KB -rw-r--r-- 2021-01-05 10:19 R E G D
no_valgrind_without_big.inc 0.347 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_as_root.inc 0.044 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_binlog_format_row.inc 0.09 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_blackhole.inc 0.169 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_crashrep.inc 0.58 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_embedded.inc 0.124 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_gtid_enabled.inc 0.305 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_master_info_table.inc 0.118 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_mts_slave_parallel_workers.inc 0.089 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_ndb.inc 0.179 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_ndb_default.inc 0.23 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_openssl.inc 0.104 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_parallel.inc 0.062 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_relay_log_info_table.inc 0.124 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_ssl.inc 0.096 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_threadpool.inc 0.196 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_valgrind.inc 0.115 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_var_link.inc 0.486 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_windows.inc 0.161 KB -rw-r--r-- 2021-01-05 10:19 R E G D
not_windows_embedded.inc 0.298 KB -rw-r--r-- 2021-01-05 10:19 R E G D
null_key.inc 9.639 KB -rw-r--r-- 2021-01-05 10:19 R E G D
one_thread_per_connection.inc 0.108 KB -rw-r--r-- 2021-01-05 10:19 R E G D
only_mts_slave_parallel_workers.inc 0.098 KB -rw-r--r-- 2021-01-05 10:19 R E G D
order_by.inc 76.021 KB -rw-r--r-- 2021-01-05 10:19 R E G D
parser_bug21114.inc 1.32 KB -rw-r--r-- 2021-01-05 10:19 R E G D
partition_date_range.inc 2.632 KB -rw-r--r-- 2021-01-05 10:19 R E G D
partition_default_functions.inc 3.663 KB -rw-r--r-- 2021-01-05 10:19 R E G D
plugin.defs 2.447 KB -rw-r--r-- 2021-01-05 10:19 R E G D
print_greedy_search_count.inc 0.558 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ps_conv.inc 47.799 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ps_create.inc 1.484 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ps_ddl_1.inc 0.457 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ps_modify.inc 10.237 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ps_modify1.inc 3.155 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ps_query.inc 24.487 KB -rw-r--r-- 2021-01-05 10:19 R E G D
ps_renew.inc 1.476 KB -rw-r--r-- 2021-01-05 10:19 R E G D
purge_first_log.inc 0.422 KB -rw-r--r-- 2021-01-05 10:19 R E G D
query_cache.inc 5.737 KB -rw-r--r-- 2021-01-05 10:19 R E G D
query_cache_sql_prepare.inc 14.112 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rand.inc 3.226 KB -rw-r--r-- 2021-01-05 10:19 R E G D
range.inc 64.177 KB -rw-r--r-- 2021-01-05 10:19 R E G D
read_file_to_var.inc 0.914 KB -rw-r--r-- 2021-01-05 10:19 R E G D
read_many_rows.inc 4.291 KB -rw-r--r-- 2021-01-05 10:19 R E G D
relocate_binlogs.inc 3.364 KB -rw-r--r-- 2021-01-05 10:19 R E G D
report-features.test 0.182 KB -rw-r--r-- 2021-01-05 10:19 R E G D
restart_mysqld.inc 1.023 KB -rw-r--r-- 2021-01-05 10:19 R E G D
restart_readonly_mysqld.inc 0.936 KB -rw-r--r-- 2021-01-05 10:19 R E G D
restart_slave_sql.inc 0.979 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rowid_order.inc 3.082 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_change_topology.inc 11.813 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_connect.inc 1.526 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_connection.inc 1.433 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_connection_master.inc 0.067 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_connection_master1.inc 0.068 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_connection_slave.inc 0.066 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_connection_slave1.inc 0.067 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_default_connections.inc 0.853 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_diff.inc 3.182 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_end.inc 3.104 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_events.inc 5.83 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_for_each_slave.inc 0.935 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_generate_sync_chain.inc 5.506 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_hash_scan_assertion.inc 0.339 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_init.inc 8.218 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_ip_mix.inc 0.754 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_ip_mix2.inc 0.754 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_ipv6.inc 0.646 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_loaddata_charset.inc 0.763 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_multi_engine.inc 0.712 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_multi_engine2.inc 2.56 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_multi_engine3.inc 2.206 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_reconnect.inc 3.646 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_reset.inc 2.051 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_restart_server.inc 1.326 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_row_img_general_loop.inc 1.182 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_row_img_parts_assertion.inc 3.015 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_row_img_parts_master_slave.inc 3.017 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_row_img_set.inc 1.51 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_set_gtid_mode.inc 2.223 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_start_server.inc 4.294 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_start_slaves.inc 0.823 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_stmt_seq.inc 7.633 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_stop_server.inc 2.221 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_stop_slaves.inc 0.762 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_sync.inc 4.159 KB -rw-r--r-- 2021-01-05 10:19 R E G D
rpl_udf.inc 5.657 KB -rw-r--r-- 2021-01-05 10:19 R E G D
running_event_scheduler.inc 1.759 KB -rw-r--r-- 2021-01-05 10:19 R E G D
safe_set_to_maybe_ro_var.inc 0.69 KB -rw-r--r-- 2021-01-05 10:19 R E G D
save_binlog_position.inc 0.714 KB -rw-r--r-- 2021-01-05 10:19 R E G D
save_io_thread_pos.inc 1.156 KB -rw-r--r-- 2021-01-05 10:19 R E G D
save_master_pos.inc 1.294 KB -rw-r--r-- 2021-01-05 10:19 R E G D
search_pattern.inc 1.754 KB -rw-r--r-- 2021-01-05 10:19 R E G D
search_pattern_in_file.inc 2.566 KB -rw-r--r-- 2021-01-05 10:19 R E G D
select.inc 189.263 KB -rw-r--r-- 2021-01-05 10:19 R E G D
set_binlog_format_mixed.sql 1.174 KB -rw-r--r-- 2021-01-05 10:19 R E G D
set_binlog_format_row.sql 1.17 KB -rw-r--r-- 2021-01-05 10:19 R E G D
set_binlog_format_statement.sql 1.182 KB -rw-r--r-- 2021-01-05 10:19 R E G D
setup_fake_relay_log.inc 3.88 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_all_binlogs.inc 1.639 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_all_relay_logs.inc 1.918 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_binary_logs.inc 0.089 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_binlog_events.inc 1.427 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_binlog_events2.inc 0.674 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_binlog_using_logname.inc 0.5 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_delayed_slave_state.inc 1.468 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_events.inc 2.93 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_master_logs.inc 0.104 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_master_status.inc 0.151 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_msg.inc 0.729 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_msg80.inc 4.46 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_relaylog_events.inc 0.375 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_rpl_debug_info.inc 4.301 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_slave_hosts.inc 0.189 KB -rw-r--r-- 2021-01-05 10:19 R E G D
show_slave_status.inc 3.782 KB -rw-r--r-- 2021-01-05 10:19 R E G D
shutdown_mysqld.inc 0.732 KB -rw-r--r-- 2021-01-05 10:19 R E G D
sp-vars.inc 3.291 KB -rw-r--r-- 2021-01-05 10:19 R E G D
start_mysqld.inc 0.418 KB -rw-r--r-- 2021-01-05 10:19 R E G D
start_slave.inc 0.74 KB -rw-r--r-- 2021-01-05 10:19 R E G D
start_slave_io.inc 0.772 KB -rw-r--r-- 2021-01-05 10:19 R E G D
start_slave_sql.inc 0.78 KB -rw-r--r-- 2021-01-05 10:19 R E G D
stop_dump_threads.inc 0.995 KB -rw-r--r-- 2021-01-05 10:19 R E G D
stop_slave.inc 2.321 KB -rw-r--r-- 2021-01-05 10:19 R E G D
stop_slave_io.inc 0.912 KB -rw-r--r-- 2021-01-05 10:19 R E G D
stop_slave_sql.inc 0.823 KB -rw-r--r-- 2021-01-05 10:19 R E G D
strict_autoinc.inc 0.604 KB -rw-r--r-- 2021-01-05 10:19 R E G D
subquery.inc 192.131 KB -rw-r--r-- 2021-01-05 10:19 R E G D
subquery_mat.inc 40.521 KB -rw-r--r-- 2021-01-05 10:19 R E G D
subquery_sj.inc 186.578 KB -rw-r--r-- 2021-01-05 10:19 R E G D
subquery_sj_innodb.inc 3.864 KB -rw-r--r-- 2021-01-05 10:19 R E G D
sync_slave_io.inc 1.393 KB -rw-r--r-- 2021-01-05 10:19 R E G D
sync_slave_io_with_master.inc 1.305 KB -rw-r--r-- 2021-01-05 10:19 R E G D
sync_slave_sql.inc 3.648 KB -rw-r--r-- 2021-01-05 10:19 R E G D
sync_slave_sql_with_io.inc 0.823 KB -rw-r--r-- 2021-01-05 10:19 R E G D
sync_slave_sql_with_master.inc 1.48 KB -rw-r--r-- 2021-01-05 10:19 R E G D
system_db_struct.inc 0.442 KB -rw-r--r-- 2021-01-05 10:19 R E G D
test_fieldsize.inc 0.707 KB -rw-r--r-- 2021-01-05 10:19 R E G D
test_outfile.inc 0.074 KB -rw-r--r-- 2021-01-05 10:19 R E G D
testdb_only.inc 1.387 KB -rw-r--r-- 2021-01-05 10:19 R E G D
tpcb.inc 4.365 KB -rw-r--r-- 2021-01-05 10:19 R E G D
tpcb_disk_data.inc 4.76 KB -rw-r--r-- 2021-01-05 10:19 R E G D
truncate_file.inc 0.308 KB -rw-r--r-- 2021-01-05 10:19 R E G D
uninstall_semisync.inc 0.767 KB -rw-r--r-- 2021-01-05 10:19 R E G D
unsafe_binlog.inc 6.78 KB -rw-r--r-- 2021-01-05 10:19 R E G D
uses_vardir.inc 0.376 KB -rw-r--r-- 2021-01-05 10:19 R E G D
varchar.inc 7.135 KB -rw-r--r-- 2021-01-05 10:19 R E G D
vardir_size_check.inc 0.556 KB -rw-r--r-- 2021-01-21 20:18 R E G D
view_alias.inc 1.053 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_condition.inc 1.334 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_condition_sp.inc 1.271 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_binlog_event.inc 0.797 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_ndb_committed_to_binlog.inc 1.871 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_query_to_fail.inc 0.357 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_query_to_succeed.inc 0.362 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_io_error.inc 3.827 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_io_to_start.inc 1.238 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_io_to_stop.inc 0.944 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_param.inc 5.613 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_sql_error.inc 3.26 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_sql_error_and_skip.inc 1.67 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_sql_to_start.inc 0.868 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_sql_to_stop.inc 0.984 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_to_start.inc 0.662 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_to_stop.inc 0.924 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_slave_to_sync_with_master.inc 0.564 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_for_status_var.inc 2.697 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_innodb_all_purged.inc 1.309 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_show_condition.inc 3.654 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_time_until_connected_again.inc 0.718 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_until_connected_again.inc 0.533 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_until_count_sessions.inc 4.118 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_until_disconnected.inc 0.373 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wait_until_rows_count.inc 0.399 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string.inc 1.279 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_8140.inc 2.065 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_8EA1.inc 2.065 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_8FA2C3.inc 2.204 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_A1A1.inc 2.065 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_chde.inc 3.256 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_euro.inc 1.808 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_l1.inc 0.485 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_l12.inc 0.194 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_l14.inc 1.275 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_l2.inc 0.305 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_l3.inc 0.485 KB -rw-r--r-- 2021-01-05 10:19 R E G D
weight_string_l4.inc 0.485 KB -rw-r--r-- 2021-01-05 10:19 R E G D
windows.inc 0.115 KB -rw-r--r-- 2021-01-05 10:19 R E G D
windows_sys_vars.inc 0.586 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wl6219-engine.test 3.252 KB -rw-r--r-- 2021-01-05 10:19 R E G D
wl6301.inc 2.415 KB -rw-r--r-- 2021-01-05 10:19 R E G D
world.inc 162.21 KB -rw-r--r-- 2021-01-05 10:19 R E G D
world_schema.inc 0.714 KB -rw-r--r-- 2021-01-05 10:19 R E G D
world_schema1.inc 0.536 KB -rw-r--r-- 2021-01-05 10:19 R E G D
write_result_to_file.inc 3.073 KB -rw-r--r-- 2021-01-05 10:19 R E G D
write_var_to_file.inc 1.773 KB -rw-r--r-- 2021-01-05 10:19 R E G D
REQUEST EXIT
################################################################################ # # # include/mix2.inc # # # # This is a derivate of t/innodb.test and has to be maintained by MySQL # # guys only. # # # # Please, DO NOT create a toplevel testcase mix2_innodb.test, because # # innodb.test does already these tests. # # # # Variables which have to be set before calling this script: # # $engine_type -- Storage engine to be tested # # $other_engine_type -- storage engine <> $engine_type # # $other_engine_type1 -- storage engine <> $engine_type # # storage engine <> $other_engine_type, if possible # # $other_non_trans_engine_type -- storage engine <> $engine_type # # $other_non_trans_engine_type must be a non # # transactional storage engine # # $other_non_live_chks_engine_type # # -- storage engine <> $engine_type, if possible # # storage engine must not support live checksum # # $other_live_chks_engine_type # # -- storage engine <> $engine_type, if possible # # storage engine must support live checksum # # General Note: The $other_*_engine_type variables must point to all # # time available storage engines # # 2006-08 MySQL 5.1 MyISAM and MEMORY only # # $test_transactions -- 0, skip transactional tests # # -- 1, do not skip transactional tests # # $test_foreign_keys -- 0, skip foreign key tests # # -- 1, do not skip foreign key tests # # $fulltext_query_unsupported -- 0, execute fulltext_query tests # # -- 1, skip fulltext query tests # # $no_autoinc_update -- 0, skip tests where it is expected that an update # # does not update the internal auto-increment value# # -- 1, do not skip these tests # # $no_spatial_key -- 0, skip tests where it is expected that keys on # # spatial data type are not allowed # # -- 1, do not skip these tests # # # # The comments/expectations refer to InnoDB. # # They might be not valid for other storage engines. # # # # # # Last update: # # 2006-08-15 ML - introduce several $variables # # - correct some storage engine assignments # # - minor improvements like correct wrong table after analyze # # - let checksum testcase meet all table variants with/without # # live checksum feature exiting and/or enabled # # 2006-07-26 ML create script by using t/innodb.test and introduce $variables # # # ################################################################################ # Set the SESSION DEFAULT STORAGE ENGINE to a value <> storage engine # to be tested. This must not affect any CREATE TABLE statement, where # the storage engine is assigned explicitely, eval SET SESSION DEFAULT_STORAGE_ENGINE = $other_engine_type; # # Small basic test with ignore # --disable_warnings drop table if exists t1,t2,t3,t4; drop database if exists mysqltest; --enable_warnings eval create table t1 (id int unsigned not null auto_increment, code tinyint unsigned not null, name char(20) not null, primary key (id), key (code), unique (name)) engine=$engine_type; insert into t1 (code, name) values (1, 'Tim'), (1, 'Monty'), (2, 'David'), (2, 'Erik'), (3, 'Sasha'), (3, 'Jeremy'), (4, 'Matt'); select id, code, name from t1 order by id; update ignore t1 set id = 8, name = 'Sinisa' where id < 3; select id, code, name from t1 order by id; update ignore t1 set id = id + 10, name = 'Ralph' where id < 4; select id, code, name from t1 order by id; drop table t1; # # A bit bigger test # The 'replace_column' statements are needed because the cardinality calculated # by innodb is not always the same between runs # eval CREATE TABLE t1 ( id int(11) NOT NULL auto_increment, parent_id int(11) DEFAULT '0' NOT NULL, level tinyint(4) DEFAULT '0' NOT NULL, PRIMARY KEY (id), KEY parent_id (parent_id), KEY level (level) ) engine=$engine_type; INSERT INTO t1 VALUES (1,0,0),(3,1,1),(4,1,1),(8,2,2),(9,2,2),(17,3,2),(22,4,2),(24,4,2),(28,5,2),(29,5,2),(30,5,2),(31,6,2),(32,6,2),(33,6,2),(203,7,2),(202,7,2),(20,3,2),(157,0,0),(193,5,2),(40,7,2),(2,1,1),(15,2,2),(6,1,1),(34,6,2),(35,6,2),(16,3,2),(7,1,1),(36,7,2),(18,3,2),(26,5,2),(27,5,2),(183,4,2),(38,7,2),(25,5,2),(37,7,2),(21,4,2),(19,3,2),(5,1,1),(179,5,2); update t1 set parent_id=parent_id+100; select * from t1 where parent_id=102; update t1 set id=id+1000; -- error ER_DUP_ENTRY,1022 update t1 set id=1024 where id=1009; select * from t1; update ignore t1 set id=id+1; # This will change all rows select * from t1; update ignore t1 set id=1023 where id=1010; select * from t1 where parent_id=102; --replace_column 9 # explain select level from t1 where level=1; --replace_column 9 # explain select level,id from t1 where level=1; --replace_column 9 # explain select level,id,parent_id from t1 where level=1; select level,id from t1 where level=1; select level,id,parent_id from t1 where level=1; optimize table t1; --replace_column 7 # show keys from t1; drop table t1; # # Test replace # eval CREATE TABLE t1 ( gesuchnr int(11) DEFAULT '0' NOT NULL, benutzer_id int(11) DEFAULT '0' NOT NULL, PRIMARY KEY (gesuchnr,benutzer_id) ) engine=$engine_type; replace into t1 (gesuchnr,benutzer_id) values (2,1); replace into t1 (gesuchnr,benutzer_id) values (1,1); replace into t1 (gesuchnr,benutzer_id) values (1,1); select * from t1; drop table t1; # # test delete using hidden_primary_key # eval create table t1 (a int) engine=$engine_type; insert into t1 values (1), (2); optimize table t1; delete from t1 where a = 1; select * from t1; check table t1; drop table t1; eval create table t1 (a int,b varchar(20)) engine=$engine_type; insert into t1 values (1,""), (2,"testing"); delete from t1 where a = 1; select * from t1; create index skr on t1 (a); insert into t1 values (3,""), (4,"testing"); analyze table t1; --replace_column 7 # show keys from t1; drop table t1; # Test of reading on secondary key with may be null eval create table t1 (a int,b varchar(20),key(a)) engine=$engine_type; insert into t1 values (1,""), (2,"testing"); select * from t1 where a = 1; drop table t1; if ($test_transactions) { # # Test rollback # eval create table t1 (n int not null primary key) engine=$engine_type; set autocommit=0; insert into t1 values (4); rollback; select n, "after rollback" from t1; insert into t1 values (4); commit; select n, "after commit" from t1; commit; insert into t1 values (5); -- error ER_DUP_ENTRY insert into t1 values (4); commit; select n, "after commit" from t1; set autocommit=1; insert into t1 values (6); -- error ER_DUP_ENTRY insert into t1 values (4); select n from t1; set autocommit=0; # # savepoints # begin; savepoint `my_savepoint`; insert into t1 values (7); savepoint `savept2`; insert into t1 values (3); select n from t1; savepoint savept3; rollback to savepoint savept2; --error 1305 rollback to savepoint savept3; rollback to savepoint savept2; release savepoint `my_savepoint`; select n from t1; -- error 1305 rollback to savepoint `my_savepoint`; --error 1305 rollback to savepoint savept2; insert into t1 values (8); savepoint sv; commit; savepoint sv; set autocommit=1; # nop rollback; drop table t1; # # Test for commit and FLUSH TABLES WITH READ LOCK # eval create table t1 (n int not null primary key) engine=$engine_type; start transaction; insert into t1 values (4); flush tables with read lock; # # Current code can't handle a read lock in middle of transaction #--error 1223; commit; unlock tables; commit; select * from t1; drop table t1; # # Testing transactions # eval create table t1 ( id int NOT NULL PRIMARY KEY, nom varchar(64)) engine=$engine_type; begin; insert into t1 values(1,'hamdouni'); select id as afterbegin_id,nom as afterbegin_nom from t1; rollback; select id as afterrollback_id,nom as afterrollback_nom from t1; set autocommit=0; insert into t1 values(2,'mysql'); select id as afterautocommit0_id,nom as afterautocommit0_nom from t1; rollback; select id as afterrollback_id,nom as afterrollback_nom from t1; set autocommit=1; drop table t1; # # Simple not autocommit test # eval CREATE TABLE t1 (id char(8) not null primary key, val int not null) engine=$engine_type; insert into t1 values ('pippo', 12); -- error ER_DUP_ENTRY insert into t1 values ('pippo', 12); # Gives error delete from t1; delete from t1 where id = 'pippo'; select * from t1; insert into t1 values ('pippo', 12); set autocommit=0; delete from t1; rollback; select * from t1; delete from t1; commit; select * from t1; drop table t1; # # Test of active transactions # eval create table t1 (a integer) engine=$engine_type; start transaction; rename table t1 to t2; eval create table t1 (b integer) engine=$engine_type; insert into t1 values (1); rollback; drop table t1; rename table t2 to t1; drop table t1; set autocommit=1; # # The following simple tests failed at some point # eval CREATE TABLE t1 (ID INTEGER NOT NULL PRIMARY KEY, NAME VARCHAR(64)) ENGINE=$engine_type; INSERT INTO t1 VALUES (1, 'Jochen'); select * from t1; drop table t1; eval CREATE TABLE t1 ( _userid VARCHAR(60) NOT NULL PRIMARY KEY) ENGINE=$engine_type; set autocommit=0; INSERT INTO t1 SET _userid='marc@anyware.co.uk'; COMMIT; SELECT * FROM t1; SELECT _userid FROM t1 WHERE _userid='marc@anyware.co.uk'; drop table t1; set autocommit=1; } # End of transactional tests # # Test when reading on part of unique key # eval CREATE TABLE t1 ( user_id int(10) DEFAULT '0' NOT NULL, name varchar(100), phone varchar(100), ref_email varchar(100) DEFAULT '' NOT NULL, detail varchar(200), PRIMARY KEY (user_id,ref_email) )engine=$engine_type; INSERT INTO t1 VALUES (10292,'sanjeev','29153373','sansh777@hotmail.com','xxx'),(10292,'shirish','2333604','shirish@yahoo.com','ddsds'),(10292,'sonali','323232','sonali@bolly.com','filmstar'); select * from t1 where user_id=10292; INSERT INTO t1 VALUES (10291,'sanjeev','29153373','sansh777@hotmail.com','xxx'),(10293,'shirish','2333604','shirish@yahoo.com','ddsds'); select * from t1 where user_id=10292; select * from t1 where user_id>=10292; select * from t1 where user_id>10292; select * from t1 where user_id<10292; drop table t1; # # Test that keys are created in right order # eval CREATE TABLE t1 (a int not null, b int not null,c int not null, key(a),primary key(a,b), unique(c),key(a),unique(b)) ENGINE = $engine_type; --replace_column 7 # show index from t1; drop table t1; # # Test of ALTER TABLE and innodb tables # eval create table t1 (col1 int not null, col2 char(4) not null, primary key(col1)) ENGINE = $other_engine_type; eval alter table t1 engine=$engine_type; insert into t1 values ('1','1'),('5','2'),('2','3'),('3','4'),('4','4'); select * from t1; update t1 set col2='7' where col1='4'; select * from t1; alter table t1 add co3 int not null; select * from t1; update t1 set col2='9' where col1='2'; select * from t1; drop table t1; # # INSERT INTO innodb tables # eval create table t1 (a int not null , b int, primary key (a)) engine = $engine_type; eval create table t2 (a int not null , b int, primary key (a)) engine = $other_engine_type; insert into t1 VALUES (1,3) , (2,3), (3,3); select * from t1; insert into t2 select * from t1; select * from t2; delete from t1 where b = 3; select * from t1; insert into t1 select * from t2; select * from t1; select * from t2; drop table t1,t2; # # Search on unique key # eval CREATE TABLE t1 ( id int(11) NOT NULL auto_increment, ggid varchar(32) binary DEFAULT '' NOT NULL, email varchar(64) DEFAULT '' NOT NULL, passwd varchar(32) binary DEFAULT '' NOT NULL, PRIMARY KEY (id), UNIQUE ggid (ggid) ) ENGINE=$engine_type; insert into t1 (ggid,passwd) values ('test1','xxx'); insert into t1 (ggid,passwd) values ('test2','yyy'); -- error ER_DUP_ENTRY insert into t1 (ggid,passwd) values ('test2','this will fail'); -- error ER_DUP_ENTRY insert into t1 (ggid,id) values ('this will fail',1); select * from t1 where ggid='test1'; select * from t1 where passwd='xxx'; select * from t1 where id=2; replace into t1 (ggid,id) values ('this will work',1); replace into t1 (ggid,passwd) values ('test2','this will work'); -- error ER_DUP_ENTRY update t1 set id=100,ggid='test2' where id=1; select * from t1; select * from t1 where id=1; select * from t1 where id=999; drop table t1; # # ORDER BY on not primary key # eval CREATE TABLE t1 ( user_name varchar(12), password text, subscribed char(1), user_id int(11) DEFAULT '0' NOT NULL, quota bigint(20), weight double, access_date date, access_time time, approved datetime, dummy_primary_key int(11) NOT NULL auto_increment, PRIMARY KEY (dummy_primary_key) ) ENGINE=$engine_type; INSERT INTO t1 VALUES ('user_0','somepassword','N',0,0,0,'2000-09-07','23:06:59','2000-09-07 23:06:59',1); INSERT INTO t1 VALUES ('user_1','somepassword','Y',1,1,1,'2000-09-07','23:06:59','2000-09-07 23:06:59',2); INSERT INTO t1 VALUES ('user_2','somepassword','N',2,2,1.4142135623731,'2000-09-07','23:06:59','2000-09-07 23:06:59',3); INSERT INTO t1 VALUES ('user_3','somepassword','Y',3,3,1.7320508075689,'2000-09-07','23:06:59','2000-09-07 23:06:59',4); INSERT INTO t1 VALUES ('user_4','somepassword','N',4,4,2,'2000-09-07','23:06:59','2000-09-07 23:06:59',5); select user_name, password , subscribed, user_id, quota, weight, access_date, access_time, approved, dummy_primary_key from t1 order by user_name; drop table t1; # # Testing of tables without primary keys # eval CREATE TABLE t1 ( id int(11) NOT NULL auto_increment, parent_id int(11) DEFAULT '0' NOT NULL, level tinyint(4) DEFAULT '0' NOT NULL, KEY (id), KEY parent_id (parent_id), KEY level (level) ) engine=$engine_type; INSERT INTO t1 VALUES (1,0,0),(3,1,1),(4,1,1),(8,2,2),(9,2,2),(17,3,2),(22,4,2),(24,4,2),(28,5,2),(29,5,2),(30,5,2),(31,6,2),(32,6,2),(33,6,2),(203,7,2),(202,7,2),(20,3,2),(157,0,0),(193,5,2),(40,7,2),(2,1,1),(15,2,2),(6,1,1),(34,6,2),(35,6,2),(16,3,2),(7,1,1),(36,7,2),(18,3,2),(26,5,2),(27,5,2),(183,4,2),(38,7,2),(25,5,2),(37,7,2),(21,4,2),(19,3,2),(5,1,1); INSERT INTO t1 values (179,5,2); update t1 set parent_id=parent_id+100; select * from t1 where parent_id=102; update t1 set id=id+1000; update t1 set id=1024 where id=1009; select * from t1; update ignore t1 set id=id+1; # This will change all rows select * from t1; update ignore t1 set id=1023 where id=1010; select * from t1 where parent_id=102; --replace_column 9 # explain select level from t1 where level=1; select level,id from t1 where level=1; select level,id,parent_id from t1 where level=1; select level,id from t1 where level=1 order by id; delete from t1 where level=1; select * from t1; drop table t1; # # Test of index only reads # eval CREATE TABLE t1 ( sca_code char(6) NOT NULL, cat_code char(6) NOT NULL, sca_desc varchar(50), lan_code char(2) NOT NULL, sca_pic varchar(100), sca_sdesc varchar(50), sca_sch_desc varchar(16), PRIMARY KEY (sca_code, cat_code, lan_code), INDEX sca_pic (sca_pic) ) engine = $engine_type ; INSERT INTO t1 ( sca_code, cat_code, sca_desc, lan_code, sca_pic, sca_sdesc, sca_sch_desc) VALUES ( 'PD', 'J', 'PENDANT', 'EN', NULL, NULL, 'PENDANT'),( 'RI', 'J', 'RING', 'EN', NULL, NULL, 'RING'),( 'QQ', 'N', 'RING', 'EN', 'not null', NULL, 'RING'); select count(*) from t1 where sca_code = 'PD'; select count(*) from t1 where sca_code <= 'PD'; select count(*) from t1 where sca_pic is null; alter table t1 drop index sca_pic, add index sca_pic (cat_code, sca_pic); select count(*) from t1 where sca_code='PD' and sca_pic is null; select count(*) from t1 where cat_code='E'; alter table t1 drop index sca_pic, add index (sca_pic, cat_code); select count(*) from t1 where sca_code='PD' and sca_pic is null; select count(*) from t1 where sca_pic >= 'n'; select sca_pic from t1 where sca_pic is null; update t1 set sca_pic="test" where sca_pic is null; delete from t1 where sca_code='pd'; drop table t1; # # Test of opening table twice and timestamps # set @a:=now(); eval CREATE TABLE t1 (a int not null, b timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, primary key (a)) engine=$engine_type; insert into t1 (a) values(1),(2),(3); select t1.a from t1 natural join t1 as t2 where t1.b >= @a order by t1.a; select a from t1 natural join t1 as t2 where b >= @a order by a; update t1 set a=5 where a=1; select a from t1; drop table t1; # # Test with variable length primary key # eval create table t1 (a varchar(100) not null, primary key(a), b int not null) engine=$engine_type; insert into t1 values("hello",1),("world",2); select * from t1 order by b desc; optimize table t1; --replace_column 7 # show keys from t1; drop table t1; # # Test of create index with NULL columns # eval create table t1 (i int, j int ) ENGINE=$engine_type; insert into t1 values (1,2); select * from t1 where i=1 and j=2; create index ax1 on t1 (i,j); select * from t1 where i=1 and j=2; drop table t1; # # Test min-max optimization # eval CREATE TABLE t1 ( a int3 unsigned NOT NULL, b int1 unsigned NOT NULL, UNIQUE (a, b) ) ENGINE = $engine_type; INSERT INTO t1 VALUES (1, 1); SELECT MIN(B),MAX(b) FROM t1 WHERE t1.a = 1; drop table t1; # # Test INSERT DELAYED # eval CREATE TABLE t1 (a int unsigned NOT NULL) engine=$engine_type; # Can't test this in 3.23 # INSERT DELAYED INTO t1 VALUES (1); INSERT INTO t1 VALUES (1); SELECT * FROM t1; DROP TABLE t1; # # Crash when using many tables (Test case by Jeremy D Zawodny) # eval create table t1 (a int primary key,b int, c int, d int, e int, f int, g int, h int, i int, j int, k int, l int, m int, n int, o int, p int, q int, r int, s int, t int, u int, v int, w int, x int, y int, z int, a1 int, a2 int, a3 int, a4 int, a5 int, a6 int, a7 int, a8 int, a9 int, b1 int, b2 int, b3 int, b4 int, b5 int, b6 int) engine = $engine_type; insert into t1 values (1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1); --replace_column 9 # explain select * from t1 where a > 0 and a < 50; drop table t1; # # Test lock tables # eval create table t1 (id int NOT NULL,id2 int NOT NULL,id3 int NOT NULL,dummy1 char(30),primary key (id,id2),index index_id3 (id3)) engine=$engine_type; insert into t1 values (0,0,0,'ABCDEFGHIJ'),(2,2,2,'BCDEFGHIJK'),(1,1,1,'CDEFGHIJKL'); LOCK TABLES t1 WRITE; --error ER_DUP_ENTRY insert into t1 values (99,1,2,'D'),(1,1,2,'D'); select id from t1; select id from t1; UNLOCK TABLES; DROP TABLE t1; eval create table t1 (id int NOT NULL,id2 int NOT NULL,id3 int NOT NULL,dummy1 char(30),primary key (id,id2),index index_id3 (id3)) engine=$engine_type; insert into t1 values (0,0,0,'ABCDEFGHIJ'),(2,2,2,'BCDEFGHIJK'),(1,1,1,'CDEFGHIJKL'); LOCK TABLES t1 WRITE; begin; --error ER_DUP_ENTRY insert into t1 values (99,1,2,'D'),(1,1,2,'D'); select id from t1; insert ignore into t1 values (100,1,2,'D'),(1,1,99,'D'); commit; select id,id3 from t1; UNLOCK TABLES; DROP TABLE t1; # # Test prefix key # eval create table t1 (a char(20), unique (a(5))) engine=$engine_type; drop table t1; eval create table t1 (a char(20), index (a(5))) engine=$engine_type; show create table t1; drop table t1; # # Test using temporary table and auto_increment # eval create temporary table t1 (a int not null auto_increment, primary key(a)) engine=$engine_type; insert into t1 values (NULL),(NULL),(NULL); delete from t1 where a=3; insert into t1 values (NULL); select * from t1; alter table t1 add b int; select * from t1; drop table t1; #Slashdot bug eval create table t1 ( id int auto_increment primary key, name varchar(32) not null, value text not null, uid int not null, unique key(name,uid) ) engine=$engine_type; insert into t1 values (1,'one','one value',101), (2,'two','two value',102),(3,'three','three value',103); set insert_id=5; replace into t1 (value,name,uid) values ('other value','two',102); delete from t1 where uid=102; set insert_id=5; replace into t1 (value,name,uid) values ('other value','two',102); set insert_id=6; replace into t1 (value,name,uid) values ('other value','two',102); select * from t1; drop table t1; # # Test DROP DATABASE # # ML: Test logics # Check that the creation of a table with engine = $engine_type does # in a certain database (already containing some tables using other # storage engines) not prevent the dropping of this database. create database mysqltest; eval create table mysqltest.t1 (a int not null) engine= $engine_type; insert into mysqltest.t1 values(1); eval create table mysqltest.t2 (a int not null) engine= $other_engine_type; insert into mysqltest.t2 values(1); eval create table mysqltest.t3 (a int not null) engine= $other_engine_type1; insert into mysqltest.t3 values(1); commit; drop database mysqltest; # Don't check error message --error 1049 show tables from mysqltest; # # Test truncate table with and without auto_commit # set autocommit=0; eval create table t1 (a int not null) engine= $engine_type; insert into t1 values(1),(2); truncate table t1; commit; truncate table t1; truncate table t1; select * from t1; insert into t1 values(1),(2); delete from t1; select * from t1; commit; drop table t1; set autocommit=1; eval create table t1 (a int not null) engine= $engine_type; insert into t1 values(1),(2); truncate table t1; insert into t1 values(1),(2); select * from t1; truncate table t1; insert into t1 values(1),(2); delete from t1; select * from t1; drop table t1; # # Test of how ORDER BY works when doing it on the whole table # eval create table t1 (a int not null, b int not null, c int not null, primary key (a),key(b)) engine=$engine_type; insert into t1 values (3,3,3),(1,1,1),(2,2,2),(4,4,4); --replace_column 9 # explain select * from t1 order by a; --replace_column 9 # explain select * from t1 order by b; --replace_column 9 # explain select * from t1 order by c; --replace_column 9 # explain select a from t1 order by a; --replace_column 9 # explain select b from t1 order by b; --replace_column 9 # explain select a,b from t1 order by b; --replace_column 9 # explain select a,b from t1; --replace_column 9 # explain select a,b,c from t1; drop table t1; # # Check describe # eval create table t1 (t int not null default 1, key (t)) engine=$engine_type; desc t1; drop table t1; # # Test of multi-table-delete # eval CREATE TABLE t1 ( number bigint(20) NOT NULL default '0', cname char(15) NOT NULL default '', carrier_id smallint(6) NOT NULL default '0', privacy tinyint(4) NOT NULL default '0', last_mod_date timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, last_mod_id smallint(6) NOT NULL default '0', last_app_date timestamp NOT NULL DEFAULT '0000-00-00 00:00:00', last_app_id smallint(6) default '-1', version smallint(6) NOT NULL default '0', assigned_scps int(11) default '0', status tinyint(4) default '0' ) ENGINE=$engine_type; INSERT INTO t1 VALUES (4077711111,'SeanWheeler',90,2,20020111112846,500,00000000000000,-1,2,3,1); INSERT INTO t1 VALUES (9197722223,'berry',90,3,20020111112809,500,20020102114532,501,4,10,0); INSERT INTO t1 VALUES (650,'San Francisco',0,0,20011227111336,342,00000000000000,-1,1,24,1); INSERT INTO t1 VALUES (302467,'Sue\'s Subshop',90,3,20020109113241,500,20020102115111,501,7,24,0); INSERT INTO t1 VALUES (6014911113,'SudzCarwash',520,1,20020102115234,500,20020102115259,501,33,32768,0); INSERT INTO t1 VALUES (333,'tubs',99,2,20020109113440,501,20020109113440,500,3,10,0); eval CREATE TABLE t2 ( number bigint(20) NOT NULL default '0', cname char(15) NOT NULL default '', carrier_id smallint(6) NOT NULL default '0', privacy tinyint(4) NOT NULL default '0', last_mod_date timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, last_mod_id smallint(6) NOT NULL default '0', last_app_date timestamp NOT NULL DEFAULT '0000-00-00 00:00:00', last_app_id smallint(6) default '-1', version smallint(6) NOT NULL default '0', assigned_scps int(11) default '0', status tinyint(4) default '0' ) ENGINE=$engine_type; INSERT INTO t2 VALUES (4077711111,'SeanWheeler',0,2,20020111112853,500,00000000000000,-1,2,3,1); INSERT INTO t2 VALUES (9197722223,'berry',90,3,20020111112818,500,20020102114532,501,4,10,0); INSERT INTO t2 VALUES (650,'San Francisco',90,0,20020109113158,342,00000000000000,-1,1,24,1); INSERT INTO t2 VALUES (333,'tubs',99,2,20020109113453,501,20020109113453,500,3,10,0); select * from t1; select * from t2; delete t1, t2 from t1 left join t2 on t1.number=t2.number where (t1.carrier_id=90 and t1.number=t2.number) or (t2.carrier_id=90 and t1.number=t2.number) or (t1.carrier_id=90 and t2.number is null); select * from t1; select * from t2; select * from t2; drop table t1,t2; # # A simple test with some isolation levels # TODO: Make this into a test using replication to really test how # this works. # eval create table t1 (id int unsigned not null auto_increment, code tinyint unsigned not null, name char(20) not null, primary key (id), key (code), unique (name)) engine=$engine_type; BEGIN; SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE; SELECT @@tx_isolation,@@global.tx_isolation; insert into t1 (code, name) values (1, 'Tim'), (1, 'Monty'), (2, 'David'); select id, code, name from t1 order by id; COMMIT; BEGIN; SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ; insert into t1 (code, name) values (2, 'Erik'), (3, 'Sasha'); select id, code, name from t1 order by id; COMMIT; BEGIN; SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED; insert into t1 (code, name) values (3, 'Jeremy'), (4, 'Matt'); select id, code, name from t1 order by id; COMMIT; DROP TABLE t1; # # Test of multi-table-update # eval create table t1 (n int(10), d int(10)) engine=$engine_type; eval create table t2 (n int(10), d int(10)) engine=$engine_type; insert into t1 values(1,1),(1,2); insert into t2 values(1,10),(2,20); UPDATE t1,t2 SET t1.d=t2.d,t2.d=30 WHERE t1.n=t2.n; select * from t1; select * from t2; drop table t1,t2; # # Testing of IFNULL # eval create table t1 (a int, b int) engine=$engine_type; insert into t1 values(20,null); select t2.b, ifnull(t2.b,"this is null") from t1 as t2 left join t1 as t3 on t2.b=t3.a; select t2.b, ifnull(t2.b,"this is null") from t1 as t2 left join t1 as t3 on t2.b=t3.a order by 1; insert into t1 values(10,null); select t2.b, ifnull(t2.b,"this is null") from t1 as t2 left join t1 as t3 on t2.b=t3.a order by 1; drop table t1; # # Test of read_through not existing const_table # eval create table t1 (a varchar(10) not null) engine = $other_engine_type; eval create table t2 (b varchar(10) not null unique) engine=$engine_type; select t1.a from t1,t2 where t1.a=t2.b; drop table t1,t2; eval create table t1 (a int not null, b int, primary key (a)) engine = $engine_type; eval create table t2 (a int not null, b int, primary key (a)) engine = $engine_type; insert into t1 values (10, 20); insert into t2 values (10, 20); update t1, t2 set t1.b = 150, t2.b = t1.b where t2.a = t1.a and t1.a = 10; drop table t1,t2; if ($test_foreign_keys) { # # Test of multi-table-delete with foreign key constraints # eval CREATE TABLE t1 (id INT NOT NULL, PRIMARY KEY (id)) ENGINE=$engine_type; eval CREATE TABLE t2 (id INT PRIMARY KEY, t1_id INT, INDEX par_ind (t1_id), FOREIGN KEY (t1_id) REFERENCES t1(id) ON DELETE CASCADE ) ENGINE=$engine_type; insert into t1 set id=1; insert into t2 set id=1, t1_id=1; delete t1,t2 from t1,t2 where t1.id=t2.t1_id; select * from t1; select * from t2; drop table t2,t1; eval CREATE TABLE t1(id INT NOT NULL, PRIMARY KEY (id)) ENGINE=$engine_type; eval CREATE TABLE t2(id INT PRIMARY KEY, t1_id INT, INDEX par_ind (t1_id) ) ENGINE=$engine_type; INSERT INTO t1 VALUES(1); INSERT INTO t2 VALUES(1, 1); SELECT * from t1; UPDATE t1,t2 SET t1.id=t1.id+1, t2.t1_id=t1.id+1; SELECT * from t1; UPDATE t1,t2 SET t1.id=t1.id+1 where t1.id!=t2.id; SELECT * from t1; DROP TABLE t1,t2; } if ($test_transactions) { # # Test of range_optimizer # set autocommit=0; eval CREATE TABLE t1 (id CHAR(15) NOT NULL, value CHAR(40) NOT NULL, PRIMARY KEY(id)) ENGINE=$engine_type; eval CREATE TABLE t2 (id CHAR(15) NOT NULL, value CHAR(40) NOT NULL, PRIMARY KEY(id)) ENGINE=$engine_type; eval CREATE TABLE t3 (id1 CHAR(15) NOT NULL, id2 CHAR(15) NOT NULL, PRIMARY KEY(id1, id2)) ENGINE=$engine_type; INSERT INTO t3 VALUES("my-test-1", "my-test-2"); COMMIT; INSERT INTO t1 VALUES("this-key", "will disappear"); INSERT INTO t2 VALUES("this-key", "will also disappear"); DELETE FROM t3 WHERE id1="my-test-1"; SELECT * FROM t1; SELECT * FROM t2; SELECT * FROM t3; ROLLBACK; SELECT * FROM t1; SELECT * FROM t2; SELECT * FROM t3; SELECT * FROM t3 WHERE id1="my-test-1" LOCK IN SHARE MODE; COMMIT; set autocommit=1; DROP TABLE t1,t2,t3; } # # Check update with conflicting key # eval CREATE TABLE t1 (a int not null primary key, b int not null, unique (b)) engine=$engine_type; INSERT INTO t1 values (1,1),(2,2),(3,3),(4,4),(5,5),(6,6),(7,7),(8,8),(9,9); # We need the a < 1000 test here to quard against the halloween problems UPDATE t1 set a=a+100 where b between 2 and 3 and a < 1000; SELECT * from t1; drop table t1; # # Test multi update with different join methods # eval CREATE TABLE t1 (a int not null primary key, b int not null, key (b)) engine=$engine_type; eval CREATE TABLE t2 (a int not null primary key, b int not null, key (b)) engine=$engine_type; INSERT INTO t1 values (1,1),(2,2),(3,3),(4,4),(5,5),(6,6),(7,7),(8,8),(9,9),(10,10),(11,11),(12,12); INSERT INTO t2 values (1,1),(2,2),(3,3),(4,4),(5,5),(6,6),(7,7),(8,8),(9,9); # Full join, without key update t1,t2 set t1.a=t1.a+100; select * from t1; # unique key update t1,t2 set t1.a=t1.a+100 where t1.a=101; select * from t1; # ref key update t1,t2 set t1.b=t1.b+10 where t1.b=2; select * from t1; # Range key (in t1) update t1,t2 set t1.b=t1.b+2,t2.b=t1.b+10 where t1.b between 3 and 5 and t1.a=t2.a+100; select * from t1; select * from t2; drop table t1,t2; eval CREATE TABLE t2 ( NEXT_T BIGINT NOT NULL PRIMARY KEY) ENGINE=$other_non_trans_engine_type; eval CREATE TABLE t1 ( B_ID INTEGER NOT NULL PRIMARY KEY) ENGINE=$engine_type; SET AUTOCOMMIT=0; INSERT INTO t1 ( B_ID ) VALUES ( 1 ); INSERT INTO t2 ( NEXT_T ) VALUES ( 1 ); ROLLBACK; SELECT * FROM t1; drop table t1,t2; eval create table t1 ( pk int primary key, parent int not null, child int not null, index (parent) ) engine = $engine_type; insert into t1 values (1,0,4), (2,1,3), (3,2,1), (4,1,2); select distinct parent,child from t1 order by parent; drop table t1; # # Test that MySQL priorities clustered indexes # eval create table t1 (a int not null auto_increment primary key, b int, c int, key(c)) engine=$engine_type; eval create table t2 (a int not null auto_increment primary key, b int) ENGINE = $other_engine_type; insert into t1 (b) values (null),(null),(null),(null),(null),(null),(null); insert into t2 (a) select b from t1; insert into t1 (b) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; insert into t2 (a) select b from t1; insert into t1 (a) select b from t2; select count(*) from t1; --replace_column 9 # explain select * from t1 where c between 1 and 2500; update t1 set c=a; --replace_column 9 # explain select * from t1 where c between 1 and 2500; drop table t1,t2; # # Test of UPDATE ... ORDER BY # eval create table t1 (id int primary key auto_increment, fk int, index index_fk (fk)) engine=$engine_type; insert into t1 (id) values (null),(null),(null),(null),(null); update t1 set fk=69 where fk is null order by id limit 1; SELECT * from t1; drop table t1; eval create table t1 (a int not null, b int not null, key (a)) engine=$engine_type; insert into t1 values (1,1),(1,2),(1,3),(3,1),(3,2),(3,3),(3,1),(3,2),(3,3),(2,1),(2,2),(2,3); SET @tmp=0; update t1 set b=(@tmp:=@tmp+1) order by a; update t1 set b=99 where a=1 order by b asc limit 1; update t1 set b=100 where a=1 order by b desc limit 2; update t1 set a=a+10+b where a=1 order by b; select * from t1 order by a,b; drop table t1; # # Test of multi-table-updates (bug #1980). # eval create table t1 ( c char(8) not null ) engine=$engine_type; insert into t1 values ('0'),('1'),('2'),('3'),('4'),('5'),('6'),('7'),('8'),('9'); insert into t1 values ('A'),('B'),('C'),('D'),('E'),('F'); alter table t1 add b char(8) not null; alter table t1 add a char(8) not null; alter table t1 add primary key (a,b,c); update t1 set a=c, b=c; eval create table t2 (c char(8) not null, b char(8) not null, a char(8) not null, primary key(a,b,c)) engine=$engine_type; insert into t2 select * from t1; delete t1,t2 from t2,t1 where t1.a<'B' and t2.b=t1.b; drop table t1,t2; # # test autoincrement with TRUNCATE # SET AUTOCOMMIT=1; eval create table t1 (a integer auto_increment primary key) engine=$engine_type; insert into t1 (a) values (NULL),(NULL); truncate table t1; insert into t1 (a) values (NULL),(NULL); SELECT * from t1; drop table t1; if ($test_foreign_keys) { # # Test dictionary handling with spaceand quoting # eval CREATE TABLE t1 (`id 1` INT NOT NULL, PRIMARY KEY (`id 1`)) ENGINE=$engine_type; eval CREATE TABLE t2 (id INT PRIMARY KEY, t1_id INT, INDEX par_ind (t1_id), FOREIGN KEY (`t1_id`) REFERENCES `t1`(`id 1`) ON DELETE CASCADE ) ENGINE=$engine_type; #show create table t2; drop table t2,t1; # # Test of multi updated and foreign keys # eval create table `t1` (`id` int( 11 ) not null ,primary key ( `id` )) engine = $engine_type; insert into `t1`values ( 1 ) ; eval create table `t2` (`id` int( 11 ) not null default '0',unique key `id` ( `id` ) ,constraint `t1_id_fk` foreign key ( `id` ) references `t1` (`id` )) engine = $engine_type; insert into `t2`values ( 1 ) ; eval create table `t3` (`id` int( 11 ) not null default '0',key `id` ( `id` ) ,constraint `t2_id_fk` foreign key ( `id` ) references `t2` (`id` )) engine = $engine_type; insert into `t3`values ( 1 ) ; --error 1451 delete t3,t2,t1 from t1,t2,t3 where t1.id =1 and t2.id = t1.id and t3.id = t2.id; --error 1451 update t1,t2,t3 set t3.id=5, t2.id=6, t1.id=7 where t1.id =1 and t2.id = t1.id and t3.id = t2.id; --error 1054 update t3 set t3.id=7 where t1.id =1 and t2.id = t1.id and t3.id = t2.id; drop table t3,t2,t1; # # test for recursion depth limit # eval create table t1( id int primary key, pid int, index(pid), foreign key(pid) references t1(id) on delete cascade) engine=$engine_type; insert into t1 values(0,0),(1,0),(2,1),(3,2),(4,3),(5,4),(6,5),(7,6), (8,7),(9,8),(10,9),(11,10),(12,11),(13,12),(14,13),(15,14); -- error 1451 delete from t1 where id=0; delete from t1 where id=15; delete from t1 where id=0; drop table t1; } # End of FOREIGN KEY tests # # Test timestamps # eval CREATE TABLE t1 (col1 int(1))ENGINE=$engine_type; eval CREATE TABLE t2 (col1 int(1),stamp TIMESTAMP,INDEX stamp_idx (stamp))ENGINE=$engine_type; insert into t1 values (1),(2),(3); # Note that timestamp 3 is wrong insert into t2 values (1, 20020204130000),(2, 20020204130000),(4,20020204310000 ),(5,20020204230000); SELECT col1 FROM t1 UNION SELECT col1 FROM t2 WHERE stamp < '20020204120000' GROUP BY col1; drop table t1,t2; # # Test by Francois MASUREL # eval CREATE TABLE t1 ( `id` int(10) unsigned NOT NULL auto_increment, `id_object` int(10) unsigned default '0', `id_version` int(10) unsigned NOT NULL default '1', `label` varchar(100) NOT NULL default '', `description` text, PRIMARY KEY (`id`), KEY `id_object` (`id_object`), KEY `id_version` (`id_version`) ) ENGINE=$engine_type; INSERT INTO t1 VALUES("6", "3382", "9", "Test", NULL), ("7", "102", "5", "Le Pekin (Test)", NULL),("584", "1794", "4", "Test de resto", NULL),("837", "1822", "6", "Test 3", NULL),("1119", "3524", "1", "Societe Test", NULL),("1122", "3525", "1", "Fournisseur Test", NULL); eval CREATE TABLE t2 ( `id` int(10) unsigned NOT NULL auto_increment, `id_version` int(10) unsigned NOT NULL default '1', PRIMARY KEY (`id`), KEY `id_version` (`id_version`) ) ENGINE=$engine_type; INSERT INTO t2 VALUES("3524", "1"),("3525", "1"),("1794", "4"),("102", "5"),("1822", "6"),("3382", "9"); SELECT t2.id, t1.`label` FROM t2 INNER JOIN (SELECT t1.id_object as id_object FROM t1 WHERE t1.`label` LIKE '%test%') AS lbl ON (t2.id = lbl.id_object) INNER JOIN t1 ON (t2.id = t1.id_object); drop table t1,t2; # Live checksum feature available + enabled eval create table t1 (a int, b varchar(200), c text not null) checksum=1 engine=$other_live_chks_engine_type; # Live checksum feature available + disabled eval create table t2 (a int, b varchar(200), c text not null) checksum=0 engine=$other_live_chks_engine_type; # # Live checksum feature not available + enabled eval create table t3 (a int, b varchar(200), c varchar(200) not null) checksum=1 engine=$other_non_live_chks_engine_type; # Live checksum feature not available + disabled eval create table t4 (a int, b varchar(200), c varchar(200) not null) checksum=0 engine=$other_non_live_chks_engine_type; # # Live checksum feature probably available + enabled eval create table t5 (a int, b varchar(200), c text not null) checksum=1 engine=$engine_type; # Live checksum feature probably available + disabled eval create table t6 (a int, b varchar(200), c text not null) checksum=0 engine=$engine_type; # insert t1 values (1, "aaa", "bbb"), (NULL, "", "ccccc"), (0, NULL, ""); insert t2 select * from t1; insert t3 select * from t1; insert t4 select * from t1; insert t5 select * from t1; insert t6 select * from t1; checksum table t1, t2, t3, t4, t5, t6, t7 quick; checksum table t1, t2, t3, t4, t5, t6, t7; checksum table t1, t2, t3, t4, t5, t6, t7 extended; # #show table status; drop table t1,t2,t3, t4, t5, t6; # # Test problem with refering to different fields in same table in UNION # (Bug#2552: UNION returns NULL instead of expected value (innoDB only tables)) # eval create table t1 (id int, name char(10) not null, name2 char(10) not null) engine=$engine_type; insert into t1 values(1,'first','fff'),(2,'second','sss'),(3,'third','ttt'); select trim(name2) from t1 union all select trim(name) from t1 union all select trim(id) from t1; drop table t1; # # Bug#2160: Extra error message for CREATE TABLE LIKE with InnoDB # eval create table t1 (a int) engine=$engine_type; create table t2 like t1; show create table t2; drop table t1,t2; if ($test_foreign_keys) { # # Test of automaticly created foreign keys # eval create table t1 (id int(11) not null, id2 int(11) not null, unique (id,id2)) engine=$engine_type; eval create table t2 (id int(11) not null, constraint t1_id_fk foreign key ( id ) references t1 (id)) engine = $engine_type; show create table t1; show create table t2; create index id on t2 (id); show create table t2; create index id2 on t2 (id); show create table t2; drop index id2 on t2; --error 1025,1025 drop index id on t2; show create table t2; drop table t2; eval create table t2 (id int(11) not null, id2 int(11) not null, constraint t1_id_fk foreign key (id,id2) references t1 (id,id2)) engine = $engine_type; show create table t2; create unique index id on t2 (id,id2); show create table t2; drop table t2; # Check foreign key columns created in different order than key columns eval create table t2 (id int(11) not null, id2 int(11) not null, unique (id,id2),constraint t1_id_fk foreign key (id2,id) references t1 (id,id2)) engine = $engine_type; show create table t2; drop table t2; eval create table t2 (id int(11) not null, id2 int(11) not null, unique (id,id2), constraint t1_id_fk foreign key (id) references t1 (id)) engine = $engine_type; show create table t2; drop table t2; eval create table t2 (id int(11) not null, id2 int(11) not null, unique (id,id2),constraint t1_id_fk foreign key (id2,id) references t1 (id,id2)) engine = $engine_type; show create table t2; drop table t2; eval create table t2 (id int(11) not null auto_increment, id2 int(11) not null, constraint t1_id_fk foreign key (id) references t1 (id), primary key (id), index (id,id2)) engine = $engine_type; show create table t2; drop table t2; eval create table t2 (id int(11) not null auto_increment, id2 int(11) not null, constraint t1_id_fk foreign key (id) references t1 (id)) engine= $engine_type; show create table t2; alter table t2 add index id_test (id), add index id_test2 (id,id2); show create table t2; drop table t2; # Test error handling # Clean up filename -- embedded server reports whole path without .frm, # regular server reports relative path with .frm (argh!) --replace_result \\ / $MYSQL_TEST_DIR . /var/master-data/ / t2.frm t2 --error 1005 eval create table t2 (id int(11) not null, id2 int(11) not null, constraint t1_id_fk foreign key (id2,id) references t1 (id)) engine = $engine_type; # bug#3749 eval create table t2 (a int auto_increment primary key, b int, index(b), foreign key (b) references t1(id), unique(b)) engine=$engine_type; show create table t2; drop table t2; eval create table t2 (a int auto_increment primary key, b int, foreign key (b) references t1(id), foreign key (b) references t1(id), unique(b)) engine=$engine_type; show create table t2; drop table t2, t1; } # End of FOREIGN KEY tests # # Let us test binlog_cache_use and binlog_cache_disk_use status vars. # Actually this test has nothing to do with innodb per se, it just requires # transactional table. # flush status; show status like "binlog_cache_use"; show status like "binlog_cache_disk_use"; eval create table t1 (a int) engine=$engine_type; # Now we are going to create transaction which is long enough so its # transaction binlog will be flushed to disk... let $1=2000; disable_query_log; begin; while ($1) { eval insert into t1 values( $1 ); dec $1; } commit; enable_query_log; show status like "binlog_cache_use"; show status like "binlog_cache_disk_use"; # Transaction which should not be flushed to disk and so should not # increase binlog_cache_disk_use. begin; delete from t1; commit; show status like "binlog_cache_use"; show status like "binlog_cache_disk_use"; drop table t1; # # Bug #6126: Duplicate columns in keys gives misleading error message # --error 1060 eval create table t1 (c char(10), index (c,c)) engine=$engine_type; --error 1060 eval create table t1 (c1 char(10), c2 char(10), index (c1,c2,c1)) engine=$engine_type; --error 1060 eval create table t1 (c1 char(10), c2 char(10), index (c1,c1,c2)) engine=$engine_type; --error 1060 eval create table t1 (c1 char(10), c2 char(10), index (c2,c1,c1)) engine=$engine_type; eval create table t1 (c1 char(10), c2 char(10)) engine=$engine_type; --error 1060 alter table t1 add key (c1,c1); --error 1060 alter table t1 add key (c2,c1,c1); --error 1060 alter table t1 add key (c1,c2,c1); --error 1060 alter table t1 add key (c1,c1,c2); drop table t1; # # Bug #4082: integer truncation # eval create table t1(a int(1) , b int(1)) engine=$engine_type; insert into t1 values ('1111', '3333'); select distinct concat(a, b) from t1; drop table t1; if ($fulltext_query_unsupported) { # # BUG#7709 test case - Boolean fulltext query against unsupported # engines does not fail # eval CREATE TABLE t1 ( a char(10) ) ENGINE=$engine_type; --error 1214 SELECT a FROM t1 WHERE MATCH (a) AGAINST ('test' IN BOOLEAN MODE); DROP TABLE t1; } if ($test_foreign_keys) { # # check null values #1 # --disable_warnings eval CREATE TABLE t1 (a_id tinyint(4) NOT NULL default '0', PRIMARY KEY (a_id)) ENGINE=$engine_type DEFAULT CHARSET=latin1; INSERT INTO t1 VALUES (1),(2),(3); eval CREATE TABLE t2 (b_id tinyint(4) NOT NULL default '0',b_a tinyint(4) NOT NULL default '0', PRIMARY KEY (b_id), KEY (b_a), CONSTRAINT fk_b_a FOREIGN KEY (b_a) REFERENCES t1 (a_id) ON DELETE CASCADE ON UPDATE NO ACTION) ENGINE=$engine_type DEFAULT CHARSET=latin1; --enable_warnings INSERT INTO t2 VALUES (1,1),(2,1),(3,1),(4,2),(5,2); SELECT * FROM (SELECT t1.*,GROUP_CONCAT(t2.b_id SEPARATOR ',') as b_list FROM (t1 LEFT JOIN (t2) on t1.a_id = t2.b_a) GROUP BY t1.a_id ) AS xyz; DROP TABLE t2; DROP TABLE t1; } # # Bug#11816 - Truncate table doesn't work with temporary innodb tables # This is not an innodb bug, but we test it using innodb. # eval create temporary table t1 (a int) engine=$engine_type; insert into t1 values (4711); truncate t1; insert into t1 values (42); select * from t1; drop table t1; # Show that it works with permanent tables too. eval create table t1 (a int) engine=$engine_type; insert into t1 values (4711); truncate t1; insert into t1 values (42); select * from t1; drop table t1; # # Bug #13025 Server crash during filesort # eval create table t1 (a int not null, b int not null, c blob not null, d int not null, e int, primary key (a,b,c(255),d)) engine=$engine_type; insert into t1 values (2,2,"b",2,2),(1,1,"a",1,1),(3,3,"ab",3,3); -- disable_query_log -- disable_result_log analyze table t1; -- enable_result_log -- enable_query_log select * from t1 order by a,b,c,d; explain select * from t1 order by a,b,c,d; drop table t1; # # BUG#11039,#13218 Wrong key length in min() # eval create table t1 (a char(1), b char(1), key(a, b)) engine=$engine_type; insert into t1 values ('8', '6'), ('4', '7'); select min(a) from t1; select min(b) from t1 where a='8'; drop table t1; # End of 4.1 tests # # range optimizer problem # eval create table t1 (x bigint unsigned not null primary key) engine=$engine_type; insert into t1(x) values (0xfffffffffffffff0),(0xfffffffffffffff1); select * from t1; select count(*) from t1 where x>0; select count(*) from t1 where x=0; select count(*) from t1 where x<0; select count(*) from t1 where x < -16; select count(*) from t1 where x = -16; explain select count(*) from t1 where x > -16; select count(*) from t1 where x > -16; select * from t1 where x > -16; select count(*) from t1 where x = 18446744073709551601; drop table t1; # Please do not remove the following skipped InnoDB specific tests. # They make the synchronization with innodb.test easier and give # an idea what to test on other storage engines. if (0) { # Test for testable InnoDB status variables. This test # uses previous ones(pages_created, rows_deleted, ...). show status like "Innodb_buffer_pool_pages_total"; show status like "Innodb_page_size"; show status like "Innodb_rows_deleted"; show status like "Innodb_rows_inserted"; show status like "Innodb_rows_updated"; # Test for row locks InnoDB status variables. show status like "Innodb_row_lock_waits"; show status like "Innodb_row_lock_current_waits"; show status like "Innodb_row_lock_time"; show status like "Innodb_row_lock_time_max"; show status like "Innodb_row_lock_time_avg"; # Test for innodb_sync_spin_loops variable show variables like "innodb_sync_spin_loops"; set global innodb_sync_spin_loops=1000; show variables like "innodb_sync_spin_loops"; set global innodb_sync_spin_loops=0; show variables like "innodb_sync_spin_loops"; set global innodb_sync_spin_loops=20; show variables like "innodb_sync_spin_loops"; # Test for innodb_thread_concurrency variable show variables like "innodb_thread_concurrency"; set global innodb_thread_concurrency=1001; show variables like "innodb_thread_concurrency"; set global innodb_thread_concurrency=0; show variables like "innodb_thread_concurrency"; set global innodb_thread_concurrency=16; show variables like "innodb_thread_concurrency"; # Test for innodb_concurrency_tickets variable show variables like "innodb_concurrency_tickets"; set global innodb_concurrency_tickets=1000; show variables like "innodb_concurrency_tickets"; set global innodb_concurrency_tickets=0; show variables like "innodb_concurrency_tickets"; set global innodb_concurrency_tickets=500; show variables like "innodb_concurrency_tickets"; # Test for innodb_thread_sleep_delay variable show variables like "innodb_thread_sleep_delay"; set global innodb_thread_sleep_delay=100000; show variables like "innodb_thread_sleep_delay"; set global innodb_thread_sleep_delay=0; show variables like "innodb_thread_sleep_delay"; set global innodb_thread_sleep_delay=10000; show variables like "innodb_thread_sleep_delay"; } # # Test varchar # let $default=`select @@default_storage_engine`; eval set default_storage_engine=$engine_type; source include/varchar.inc; # # Some errors/warnings on create # # Clean up filename -- embedded server reports whole path without .frm, # regular server reports relative path with .frm (argh!) --replace_result \\ / $MYSQL_TEST_DIR . /var/master-data/ / t1.frm t1 create table t1 (v varchar(65530), key(v)); drop table t1; create table t1 (v varchar(65536)); show create table t1; drop table t1; create table t1 (v varchar(65530) character set utf8); show create table t1; drop table t1; eval set default_storage_engine=$default; # InnoDB specific varchar tests eval create table t1 (v varchar(16384)) engine=$engine_type; drop table t1; # # BUG#11039 Wrong key length in min() # eval create table t1 (a char(1), b char(1), key(a, b)) engine=$engine_type; insert into t1 values ('8', '6'), ('4', '7'); select min(a) from t1; select min(b) from t1 where a='8'; drop table t1; # # Bug #11080 & #11005 Multi-row REPLACE fails on a duplicate key error # eval CREATE TABLE t1 ( `a` int(11) NOT NULL auto_increment, `b` int(11) default NULL,PRIMARY KEY (`a`),UNIQUE KEY `b` (`b`)) ENGINE=$engine_type; insert into t1 (b) values (1); replace into t1 (b) values (2), (1), (3); select * from t1; truncate table t1; insert into t1 (b) values (1); replace into t1 (b) values (2); replace into t1 (b) values (1); replace into t1 (b) values (3); select * from t1; drop table t1; eval create table t1 (rowid int not null auto_increment, val int not null,primary key (rowid), unique(val)) engine=$engine_type; replace into t1 (val) values ('1'),('2'); replace into t1 (val) values ('1'),('2'); --error ER_DUP_ENTRY insert into t1 (val) values ('1'),('2'); select * from t1; drop table t1; if ($no_autoinc_update) { # # Test that update does not change internal auto-increment value # eval create table t1 (a int not null auto_increment primary key, val int) engine=$engine_type; insert into t1 (val) values (1); update t1 set a=2 where a=1; # We should get the following error because InnoDB does not update the counter --error ER_DUP_ENTRY insert into t1 (val) values (1); select * from t1; drop table t1; } # # Bug#10465: DECIMAL, crash on DELETE (InnoDB only) # --disable_warnings eval CREATE TABLE t1 (GRADE DECIMAL(4) NOT NULL, PRIMARY KEY (GRADE)) ENGINE=$engine_type; --enable_warnings INSERT INTO t1 (GRADE) VALUES (151),(252),(343); SELECT GRADE FROM t1 WHERE GRADE > 160 AND GRADE < 300; SELECT GRADE FROM t1 WHERE GRADE= 151; DROP TABLE t1; # # Bug #12340 multitable delete deletes only one record # eval create table t1 (f1 varchar(10), f2 varchar(10), primary key (f1,f2)) engine=$engine_type; eval create table t2 (f3 varchar(10), f4 varchar(10), key (f4)) engine=$engine_type; insert into t2 values ('aa','cc'); insert into t1 values ('aa','bb'),('aa','cc'); delete t1 from t1,t2 where f1=f3 and f4='cc'; select * from t1; drop table t1,t2; if ($test_foreign_keys) { # # Test that the slow TRUNCATE implementation resets autoincrement columns # (bug #11946) # eval CREATE TABLE t1 ( id INTEGER NOT NULL AUTO_INCREMENT, PRIMARY KEY (id) ) ENGINE=$engine_type; eval CREATE TABLE t2 ( id INTEGER NOT NULL, FOREIGN KEY (id) REFERENCES t1 (id) ) ENGINE=$engine_type; INSERT INTO t1 (id) VALUES (NULL); SELECT * FROM t1; TRUNCATE t1; INSERT INTO t1 (id) VALUES (NULL); SELECT * FROM t1; # continued from above; test that doing a slow TRUNCATE on a table with 0 # rows resets autoincrement columns DELETE FROM t1; TRUNCATE t1; INSERT INTO t1 (id) VALUES (NULL); SELECT * FROM t1; DROP TABLE t2, t1; # Test that foreign keys in temporary tables are not accepted (bug #12084) eval CREATE TABLE t1 ( id INT PRIMARY KEY ) ENGINE=$engine_type; --error 1005,1005 eval CREATE TEMPORARY TABLE t2 ( id INT NOT NULL PRIMARY KEY, b INT, FOREIGN KEY (b) REFERENCES test.t1(id) ) ENGINE=$engine_type; DROP TABLE t1; } # End of FOREIGN KEY test # Please do not remove the following skipped InnoDB specific tests. # They make the synchronization with innodb.test easier and give # an idea what to test on other storage engines. if (0) { # # Test that index column max sizes are honored (bug #13315) # # prefix index eval create table t1 (col1 varchar(2000), index (col1(767))) character set = latin1 engine = $engine_type; # normal indexes eval create table t2 (col1 char(255), index (col1)) character set = latin1 engine = $engine_type; eval create table t3 (col1 binary(255), index (col1)) character set = latin1 engine = $engine_type; eval create table t4 (col1 varchar(767), index (col1)) character set = latin1 engine = $engine_type; eval create table t5 (col1 varchar(767) primary key) character set = latin1 engine = $engine_type; eval create table t6 (col1 varbinary(767) primary key) character set = latin1 engine = $engine_type; eval create table t7 (col1 text, index(col1(767))) character set = latin1 engine = $engine_type; eval create table t8 (col1 blob, index(col1(767))) character set = latin1 engine = $engine_type; # multi-column indexes are allowed to be longer eval create table t9 (col1 varchar(512), col2 varchar(512), index(col1, col2)) character set = latin1 engine = $engine_type; show create table t9; drop table t1, t2, t3, t4, t5, t6, t7, t8, t9; # these should have their index length trimmed eval create table t1 (col1 varchar(768), index(col1)) character set = latin1 engine = $engine_type; eval create table t2 (col1 varbinary(768), index(col1)) character set = latin1 engine = $engine_type; eval create table t3 (col1 text, index(col1(768))) character set = latin1 engine = $engine_type; eval create table t4 (col1 blob, index(col1(768))) character set = latin1 engine = $engine_type; show create table t1; drop table t1, t2, t3, t4; } # End of skipped test # Please do not remove the following skipped InnoDB specific tests. # They make the synchronization with innodb.test easier and give # an idea what to test on other storage engines. if (0) { # these should be refused --error 1071 eval create table t1 (col1 varchar(768) primary key) character set = latin1 engine = $engine_type; --error 1071 eval create table t2 (col1 varbinary(768) primary key) character set = latin1 engine = $engine_type; --error 1071 eval create table t3 (col1 text, primary key(col1(768))) character set = latin1 engine = $engine_type; --error 1071 eval create table t4 (col1 blob, primary key(col1(768))) character set = latin1 engine = $engine_type; } if ($test_foreign_keys) { # # Test improved foreign key error messages (bug #3443) # eval CREATE TABLE t1 ( id INT PRIMARY KEY ) ENGINE=$engine_type; eval CREATE TABLE t2 ( v INT, CONSTRAINT c1 FOREIGN KEY (v) REFERENCES t1(id) ) ENGINE=$engine_type; --error 1452 INSERT INTO t2 VALUES(2); INSERT INTO t1 VALUES(1); INSERT INTO t2 VALUES(1); --error 1451 DELETE FROM t1 WHERE id = 1; --error 1217 DROP TABLE t1; SET FOREIGN_KEY_CHECKS=0; DROP TABLE t1; SET FOREIGN_KEY_CHECKS=1; --error 1452 INSERT INTO t2 VALUES(3); DROP TABLE t2; } # End of FOREIGN tests if ($test_transactions) { # # Test that checksum table uses a consistent read Bug #12669 # connect (a,localhost,root,,); connect (b,localhost,root,,); connection a; eval create table t1(a int not null) engine=$engine_type DEFAULT CHARSET=latin1; insert into t1 values (1),(2); set autocommit=0; checksum table t1; connection b; insert into t1 values(3); connection a; # # Here checksum should not see insert # checksum table t1; connection a; commit; checksum table t1; commit; drop table t1; # # autocommit = 1 # connection a; eval create table t1(a int not null) engine=$engine_type DEFAULT CHARSET=latin1; insert into t1 values (1),(2); set autocommit=1; checksum table t1; connection b; set autocommit=1; insert into t1 values(3); connection a; # # Here checksum sees insert # checksum table t1; drop table t1; connection default; disconnect a; disconnect b; } # tests for bugs #9802 and #13778 if ($test_foreign_keys) { # test that FKs between invalid types are not accepted set foreign_key_checks=0; eval create table t2 (a int primary key, b int, foreign key (b) references t1(a)) engine = $engine_type; --replace_result $MYSQLTEST_VARDIR . master-data/ '' -- error 1005 eval create table t1(a char(10) primary key, b varchar(20)) engine = $engine_type; set foreign_key_checks=1; drop table t2; # test that FKs between different charsets are not accepted in CREATE even # when f_k_c is 0 set foreign_key_checks=0; eval create table t1(a varchar(10) primary key) engine = $engine_type DEFAULT CHARSET=latin1; --replace_result $MYSQLTEST_VARDIR . master-data/ '' -- error 1005 eval create table t2 (a varchar(10), foreign key (a) references t1(a)) engine = $engine_type DEFAULT CHARSET=utf8; set foreign_key_checks=1; drop table t1; # test that invalid datatype conversions with ALTER are not allowed set foreign_key_checks=0; eval create table t2 (a varchar(10), foreign key (a) references t1(a)) engine = $engine_type; eval create table t1(a varchar(10) primary key) engine = $engine_type; -- error 1025,1025 alter table t1 modify column a int; set foreign_key_checks=1; drop table t2,t1; # test that charset conversions with ALTER are allowed when f_k_c is 0 set foreign_key_checks=0; eval create table t2 (a varchar(10), foreign key (a) references t1(a)) engine = $engine_type DEFAULT CHARSET=latin1; eval create table t1(a varchar(10) primary key) engine = $engine_type DEFAULT CHARSET=latin1; alter table t1 convert to character set utf8; set foreign_key_checks=1; drop table t2,t1; # test that RENAME does not allow invalid charsets when f_k_c is 0 set foreign_key_checks=0; eval create table t2 (a varchar(10), foreign key (a) references t1(a)) engine = $engine_type DEFAULT CHARSET=latin1; eval create table t3(a varchar(10) primary key) engine = $engine_type DEFAULT CHARSET=utf8; --replace_result $MYSQLTEST_VARDIR . master-data/ '' -- error 1025 rename table t3 to t1; set foreign_key_checks=1; drop table t2,t3; # test that foreign key errors are reported correctly (Bug #15550) eval create table t1(a int primary key) row_format=redundant engine=$engine_type; eval create table t2(a int primary key,constraint foreign key(a)references t1(a)) row_format=compact engine=$engine_type; eval create table t3(a int primary key) row_format=compact engine=$engine_type; eval create table t4(a int primary key,constraint foreign key(a)references t3(a)) row_format=redundant engine=$engine_type; insert into t1 values(1); insert into t3 values(1); -- error 1452 insert into t2 values(2); -- error 1452 insert into t4 values(2); insert into t2 values(1); insert into t4 values(1); -- error 1451 update t1 set a=2; -- error 1452 update t2 set a=2; -- error 1451 update t3 set a=2; -- error 1452 update t4 set a=2; -- error 1451 truncate t1; -- error 1451 truncate t3; truncate t2; truncate t4; truncate t1; truncate t3; drop table t4,t3,t2,t1; } # End of FOREIGN KEY tests # Please do not remove the following skipped InnoDB specific tests. # They make the synchronization with innodb.test easier and give # an idea what to test on other storage engines. if (0) { # # Test that we can create a large (>1K) key # eval create table t1 (a varchar(255) character set utf8, b varchar(255) character set utf8, c varchar(255) character set utf8, d varchar(255) character set utf8, key (a,b,c,d)) engine=$engine_type; drop table t1; --error ER_TOO_LONG_KEY eval create table t1 (a varchar(255) character set utf8, b varchar(255) character set utf8, c varchar(255) character set utf8, d varchar(255) character set utf8, e varchar(255) character set utf8, key (a,b,c,d,e)) engine=$engine_type; # test the padding of BINARY types and collations (Bug #14189) eval create table t1 (s1 varbinary(2),primary key (s1)) engine=$engine_type; eval create table t2 (s1 binary(2),primary key (s1)) engine=$engine_type; eval create table t3 (s1 varchar(2) binary,primary key (s1)) engine=$engine_type; eval create table t4 (s1 char(2) binary,primary key (s1)) engine=$engine_type; insert into t1 values (0x41),(0x4120),(0x4100); -- error ER_DUP_ENTRY insert into t2 values (0x41),(0x4120),(0x4100); insert into t2 values (0x41),(0x4120); -- error ER_DUP_ENTRY insert into t3 values (0x41),(0x4120),(0x4100); insert into t3 values (0x41),(0x4100); -- error ER_DUP_ENTRY insert into t4 values (0x41),(0x4120),(0x4100); insert into t4 values (0x41),(0x4100); select hex(s1) from t1; select hex(s1) from t2; select hex(s1) from t3; select hex(s1) from t4; drop table t1,t2,t3,t4; } if ($test_foreign_keys) { eval create table t1 (a int primary key,s1 varbinary(3) not null unique) engine=$engine_type; eval create table t2 (s1 binary(2) not null, constraint c foreign key(s1) references t1(s1) on update cascade) engine=$engine_type; insert into t1 values(1,0x4100),(2,0x41),(3,0x4120),(4,0x42); -- error 1452 insert into t2 values(0x42); insert into t2 values(0x41); select hex(s1) from t2; update t1 set s1=0x123456 where a=2; select hex(s1) from t2; -- error 1451 update t1 set s1=0x12 where a=1; -- error 1451 update t1 set s1=0x12345678 where a=1; -- error 1451 update t1 set s1=0x123457 where a=1; update t1 set s1=0x1220 where a=1; select hex(s1) from t2; update t1 set s1=0x1200 where a=1; select hex(s1) from t2; update t1 set s1=0x4200 where a=1; select hex(s1) from t2; -- error 1451 delete from t1 where a=1; delete from t1 where a=2; update t2 set s1=0x4120; -- error 1451 delete from t1; delete from t1 where a!=3; select a,hex(s1) from t1; select hex(s1) from t2; drop table t2,t1; eval create table t1 (a int primary key,s1 varchar(2) binary not null unique) engine=$engine_type; eval create table t2 (s1 char(2) binary not null, constraint c foreign key(s1) references t1(s1) on update cascade) engine=$engine_type; insert into t1 values(1,0x4100),(2,0x41); insert into t2 values(0x41); select hex(s1) from t2; update t1 set s1=0x1234 where a=1; select hex(s1) from t2; update t1 set s1=0x12 where a=2; select hex(s1) from t2; delete from t1 where a=1; -- error 1451 delete from t1 where a=2; select a,hex(s1) from t1; select hex(s1) from t2; drop table t2,t1; } # End FOREIGN KEY tests if ($test_foreign_keys) { # Ensure that _ibfk_0 is not mistreated as a # generated foreign key identifier. (Bug #16387) eval CREATE TABLE t1(a INT, PRIMARY KEY(a)) ENGINE=$engine_type; eval CREATE TABLE t2(a INT) ENGINE=$engine_type; ALTER TABLE t2 ADD FOREIGN KEY (a) REFERENCES t1(a); ALTER TABLE t2 DROP FOREIGN KEY t2_ibfk_1; ALTER TABLE t2 ADD CONSTRAINT t2_ibfk_0 FOREIGN KEY (a) REFERENCES t1(a); ALTER TABLE t2 DROP FOREIGN KEY t2_ibfk_0; SHOW CREATE TABLE t2; DROP TABLE t2,t1; } # # Test case for bug #16229: MySQL/InnoDB uses full explicit table locks in trigger processing # connect (a,localhost,root,,); connect (b,localhost,root,,); connection a; eval create table t1(a int not null, b int, c int, d int, primary key(a)) engine=$engine_type; insert into t1(a) values (1),(2),(3); commit; connection b; set autocommit = 0; update t1 set b = 5 where a = 2; commit; connection a; delimiter |; create trigger t1t before insert on t1 for each row begin set NEW.b = NEW.a * 10 + 5, NEW.c = NEW.a / 10; end | delimiter ;| set autocommit = 0; connection a; insert into t1(a) values (10),(20),(30),(40),(50),(60),(70),(80),(90),(100), (11),(21),(31),(41),(51),(61),(71),(81),(91),(101), (12),(22),(32),(42),(52),(62),(72),(82),(92),(102), (13),(23),(33),(43),(53),(63),(73),(83),(93),(103), (14),(24),(34),(44),(54),(64),(74),(84),(94),(104); connection b; commit; connection a; commit; drop trigger t1t; drop table t1; disconnect a; disconnect b; # # Another trigger test # connect (a,localhost,root,,); connect (b,localhost,root,,); connection a; eval create table t1(a int not null, b int, c int, d int, primary key(a)) engine=$engine_type; eval create table t2(a int not null, b int, c int, d int, primary key(a)) engine=$engine_type; eval create table t3(a int not null, b int, c int, d int, primary key(a)) engine=$engine_type; eval create table t4(a int not null, b int, c int, d int, primary key(a)) engine=$engine_type; eval create table t5(a int not null, b int, c int, d int, primary key(a)) engine=$engine_type; insert into t1(a) values (1),(2),(3); insert into t2(a) values (1),(2),(3); insert into t3(a) values (1),(2),(3); insert into t4(a) values (1),(2),(3); insert into t3(a) values (5),(7),(8); insert into t4(a) values (5),(7),(8); insert into t5(a) values (1),(2),(3),(4),(5),(6),(7),(8),(9),(10),(11),(12); delimiter |; create trigger t1t before insert on t1 for each row begin INSERT INTO t2 SET a = NEW.a; end | create trigger t2t before insert on t2 for each row begin DELETE FROM t3 WHERE a = NEW.a; end | create trigger t3t before delete on t3 for each row begin UPDATE t4 SET b = b + 1 WHERE a = OLD.a; end | create trigger t4t before update on t4 for each row begin UPDATE t5 SET b = b + 1 where a = NEW.a; end | delimiter ;| commit; set autocommit = 0; update t1 set b = b + 5 where a = 1; update t2 set b = b + 5 where a = 1; update t3 set b = b + 5 where a = 1; update t4 set b = b + 5 where a = 1; insert into t5(a) values(20); commit; connection b; set autocommit = 0; insert into t1(a) values(7); insert into t2(a) values(8); delete from t2 where a = 3; update t4 set b = b + 1 where a = 3; commit; drop trigger t1t; drop trigger t2t; drop trigger t3t; drop trigger t4t; drop table t1, t2, t3, t4, t5; connection default; disconnect a; disconnect b; if ($test_foreign_keys) { # # Test that cascading updates leading to duplicate keys give the correct # error message (bug #9680) # eval CREATE TABLE t1 ( field1 varchar(8) NOT NULL DEFAULT '', field2 varchar(8) NOT NULL DEFAULT '', PRIMARY KEY (field1, field2) ) ENGINE=$engine_type; eval CREATE TABLE t2 ( field1 varchar(8) NOT NULL DEFAULT '' PRIMARY KEY, FOREIGN KEY (field1) REFERENCES t1 (field1) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=$engine_type; INSERT INTO t1 VALUES ('old', 'somevalu'); INSERT INTO t1 VALUES ('other', 'anyvalue'); INSERT INTO t2 VALUES ('old'); INSERT INTO t2 VALUES ('other'); --error ER_FOREIGN_DUPLICATE_KEY_WITH_CHILD_INFO UPDATE t1 SET field1 = 'other' WHERE field2 = 'somevalu'; DROP TABLE t2; DROP TABLE t1; # # Bug#18477 - MySQL/InnoDB Ignoring Foreign Keys in ALTER TABLE # eval create table t1 ( c1 bigint not null, c2 bigint not null, primary key (c1), unique key (c2) ) engine=$engine_type; # eval create table t2 ( c1 bigint not null, primary key (c1) ) engine=$engine_type; # alter table t1 add constraint c2_fk foreign key (c2) references t2(c1) on delete cascade; show create table t1; # alter table t1 drop foreign key c2_fk; show create table t1; # drop table t1, t2; } # End FOREIGN KEY test # # Bug #14360: problem with intervals # eval create table t1(a date) engine=$engine_type; eval create table t2(a date, key(a)) engine=$engine_type; insert into t1 values('2005-10-01'); insert into t2 values('2005-10-01'); select * from t1, t2 where t2.a between t1.a - interval 2 day and t1.a + interval 2 day; drop table t1, t2; eval create table t1 (id int not null, f_id int not null, f int not null, primary key(f_id, id)) engine=$engine_type; eval create table t2 (id int not null,s_id int not null,s varchar(200), primary key(id)) engine=$engine_type; INSERT INTO t1 VALUES (8, 1, 3); INSERT INTO t1 VALUES (1, 2, 1); INSERT INTO t2 VALUES (1, 0, ''); INSERT INTO t2 VALUES (8, 1, ''); commit; DELETE ml.* FROM t1 AS ml LEFT JOIN t2 AS mm ON (mm.id=ml.id) WHERE mm.id IS NULL; select ml.* from t1 as ml left join t2 as mm on (mm.id=ml.id) where mm.id is null lock in share mode; drop table t1,t2; # # Test case where X-locks on unused rows should be released in a # update (because READ COMMITTED isolation level) # connect (a,localhost,root,,); connect (b,localhost,root,,); connection a; eval create table t1(a int not null, b int, primary key(a)) engine=$engine_type; insert into t1 values(1,1),(2,2),(3,1),(4,2),(5,1),(6,2),(7,3); commit; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; update t1 set b = 5 where b = 1; connection b; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; # # X-lock to record (7,3) should be released in a update # select * from t1 where a = 7 and b = 3 for update; connection a; commit; connection b; commit; drop table t1; connection default; disconnect a; disconnect b; if ($test_transactions) { # # Test case where no locks should be released (because we are not # using READ COMMITTED isolation level) # connect (a,localhost,root,,); connect (b,localhost,root,,); connection a; eval create table t1(a int not null, b int, primary key(a)) engine=$engine_type; insert into t1 values(1,1),(2,2),(3,1),(4,2),(5,1),(6,2); commit; set autocommit = 0; select * from t1 lock in share mode; update t1 set b = 5 where b = 1; connection b; set autocommit = 0; # # S-lock to records (2,2),(4,2), and (6,2) should not be released in a update # --error 1205 select * from t1 where a = 2 and b = 2 for update; # # X-lock to record (1,1),(3,1),(5,1) should not be released in a update # --error 1205 connection a; commit; connection b; commit; connection default; disconnect a; disconnect b; drop table t1; # # Consistent read should be used in following selects # # 1) INSERT INTO ... SELECT # 2) UPDATE ... = ( SELECT ...) # 3) CREATE ... SELECT connect (a,localhost,root,,); connect (b,localhost,root,,); connection a; eval create table t1(a int not null, b int, primary key(a)) engine=$engine_type; insert into t1 values (1,2),(5,3),(4,2); eval create table t2(d int not null, e int, primary key(d)) engine=$engine_type; insert into t2 values (8,6),(12,1),(3,1); commit; set autocommit = 0; select * from t2 for update; connection b; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; insert into t1 select * from t2; update t1 set b = (select e from t2 where a = d); eval create table t3(d int not null, e int, primary key(d)) engine=$engine_type select * from t2; commit; connection a; commit; connection default; disconnect a; disconnect b; drop table t1, t2, t3; # # Consistent read should not be used if # # (a) isolation level is serializable OR # (b) select ... lock in share mode OR # (c) select ... for update # # in following queries: # # 1) INSERT INTO ... SELECT # 2) UPDATE ... = ( SELECT ...) # 3) CREATE ... SELECT connect (a,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (b,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (c,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (d,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (e,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (f,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (g,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (h,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (i,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connect (j,localhost,root,,); eval SET SESSION DEFAULT_STORAGE_ENGINE = $engine_type; connection a; create table t1(a int not null, b int, primary key(a)); insert into t1 values (1,2),(5,3),(4,2); create table t2(a int not null, b int, primary key(a)); insert into t2 values (8,6),(12,1),(3,1); create table t3(d int not null, b int, primary key(d)); insert into t3 values (8,6),(12,1),(3,1); create table t5(a int not null, b int, primary key(a)); insert into t5 values (1,2),(5,3),(4,2); create table t6(d int not null, e int, primary key(d)); insert into t6 values (8,6),(12,1),(3,1); create table t8(a int not null, b int, primary key(a)); insert into t8 values (1,2),(5,3),(4,2); create table t9(d int not null, e int, primary key(d)); insert into t9 values (8,6),(12,1),(3,1); commit; set autocommit = 0; select * from t2 for update; connection b; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE; --send insert into t1 select * from t2; connection c; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE; --send update t3 set b = (select b from t2 where a = d); connection d; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE; --send create table t4(a int not null, b int, primary key(a)) select * from t2; connection e; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; --send insert into t5 (select * from t2 lock in share mode); connection f; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; --send update t6 set e = (select b from t2 where a = d lock in share mode); connection g; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; --send create table t7(a int not null, b int, primary key(a)) select * from t2 lock in share mode; connection h; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; --send insert into t8 (select * from t2 for update); connection i; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; --send update t9 set e = (select b from t2 where a = d for update); connection j; set autocommit = 0; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; --send create table t10(a int not null, b int, primary key(a)) select * from t2 for update; connection b; --error 1205 reap; connection c; --error 1205 reap; connection d; --error 1205 reap; connection e; --error 1205 reap; connection f; --error 1205 reap; connection g; --error 1205 reap; connection h; --error 1205 reap; connection i; --error 1205 reap; connection j; --error 1205 reap; connection a; commit; connection default; disconnect a; disconnect b; disconnect c; disconnect d; disconnect e; disconnect f; disconnect g; disconnect h; disconnect i; disconnect j; drop table t1, t2, t3, t5, t6, t8, t9; } # End transactional tests if ($test_foreign_keys) { # bug 18934, "InnoDB crashes when table uses column names like DB_ROW_ID" --error 1005 eval CREATE TABLE t1 (DB_ROW_ID int) engine=$engine_type; # # Bug #17152: Wrong result with BINARY comparison on aliased column # eval CREATE TABLE t1 ( a BIGINT(20) NOT NULL, PRIMARY KEY (a) ) ENGINE=$engine_type DEFAULT CHARSET=UTF8; eval CREATE TABLE t2 ( a BIGINT(20) NOT NULL, b VARCHAR(128) NOT NULL, c TEXT NOT NULL, PRIMARY KEY (a,b), KEY idx_t2_b_c (b,c(200)), CONSTRAINT t_fk FOREIGN KEY (a) REFERENCES t1 (a) ON DELETE CASCADE ) ENGINE=$engine_type DEFAULT CHARSET=UTF8; INSERT INTO t1 VALUES (1); INSERT INTO t2 VALUES (1, 'bar', 'vbar'); INSERT INTO t2 VALUES (1, 'BAR2', 'VBAR'); INSERT INTO t2 VALUES (1, 'bar_bar', 'bibi'); INSERT INTO t2 VALUES (1, 'customer_over', '1'); SELECT * FROM t2 WHERE b = 'customer_over'; SELECT * FROM t2 WHERE BINARY b = 'customer_over'; SELECT DISTINCT p0.a FROM t2 p0 WHERE p0.b = 'customer_over'; /* Bang: Empty result set, above was expected: */ SELECT DISTINCT p0.a FROM t2 p0 WHERE BINARY p0.b = 'customer_over'; SELECT p0.a FROM t2 p0 WHERE BINARY p0.b = 'customer_over'; drop table t2, t1; } if ($no_spatial_key) { # # Bug #15680 (SPATIAL key in innodb) # --error ER_TABLE_CANT_HANDLE_SPKEYS eval create table t1 (g geometry not null, spatial gk(g)) engine=$engine_type; } # # Test optimize on table with open transaction # eval CREATE TABLE t1 ( a int ) ENGINE=$engine_type; BEGIN; INSERT INTO t1 VALUES (1); OPTIMIZE TABLE t1; DROP TABLE t1; ####################################################################### # # # This is derivate of t/innodb.test and has to be maintained by # # MySQL guys only. # # # # Please synchronize this file from time to time with t/innodb.test. # # Please, DO NOT create a toplevel testcase innodb-mix2.test, because # # innodb.test does already these tests. # # # #######################################################################