PNG  IHDRQgAMA a cHRMz&u0`:pQ<bKGDgmIDATxwUﹻ& ^CX(J I@ "% (** BX +*i"]j(IH{~R)[~>h{}gy)I$Ij .I$I$ʊy@}x.: $I$Ii}VZPC)I$IF ^0ʐJ$I$Q^}{"r=OzI$gRZeC.IOvH eKX $IMpxsk.쒷/&r[޳<v| .I~)@$updYRa$I |M.e JaֶpSYR6j>h%IRز if&uJ)M$I vLi=H;7UJ,],X$I1AҒJ$ XY XzI@GNҥRT)E@;]K*Mw;#5_wOn~\ DC&$(A5 RRFkvIR}l!RytRl;~^ǷJj اy뷦BZJr&ӥ8Pjw~vnv X^(I;4R=P[3]J,]ȏ~:3?[ a&e)`e*P[4]T=Cq6R[ ~ޤrXR Հg(t_HZ-Hg M$ãmL5R uk*`%C-E6/%[t X.{8P9Z.vkXŐKjgKZHg(aK9ڦmKjѺm_ \#$5,)-  61eJ,5m| r'= &ڡd%-]J on Xm|{ RҞe $eڧY XYrԮ-a7RK6h>n$5AVڴi*ֆK)mѦtmr1p| q:흺,)Oi*ֺK)ܬ֦K-5r3>0ԔHjJئEZj,%re~/z%jVMڸmrt)3]J,T K֦OvԒgii*bKiNO~%PW0=dii2tJ9Jݕ{7"I P9JKTbu,%r"6RKU}Ij2HKZXJ,妝 XYrP ެ24c%i^IK|.H,%rb:XRl1X4Pe/`x&P8Pj28Mzsx2r\zRPz4J}yP[g=L) .Q[6RjWgp FIH*-`IMRaK9TXcq*I y[jE>cw%gLRԕiFCj-ďa`#e~I j,%r,)?[gp FI˨mnWX#>mʔ XA DZf9,nKҲzIZXJ,L#kiPz4JZF,I,`61%2s $,VOϚ2/UFJfy7K> X+6 STXIeJILzMfKm LRaK9%|4p9LwJI!`NsiazĔ)%- XMq>pk$-$Q2x#N ؎-QR}ᶦHZډ)J,l#i@yn3LN`;nڔ XuX5pF)m|^0(>BHF9(cզEerJI rg7 4I@z0\JIi䵙RR0s;$s6eJ,`n 䂦0a)S)A 1eJ,堌#635RIgpNHuTH_SԕqVe ` &S)>p;S$魁eKIuX`I4춒o}`m$1":PI<[v9^\pTJjriRŭ P{#{R2,`)e-`mgj~1ϣLKam7&U\j/3mJ,`F;M'䱀 .KR#)yhTq;pcK9(q!w?uRR,n.yw*UXj#\]ɱ(qv2=RqfB#iJmmL<]Y͙#$5 uTU7ӦXR+q,`I}qL'`6Kͷ6r,]0S$- [RKR3oiRE|nӦXR.(i:LDLTJjY%o:)6rxzҒqTJjh㞦I.$YR.ʼnGZ\ֿf:%55 I˼!6dKxm4E"mG_ s? .e*?LRfK9%q#uh$)i3ULRfK9yxm܌bj84$i1U^@Wbm4uJ,ҪA>_Ij?1v32[gLRD96oTaR׿N7%L2 NT,`)7&ƝL*꽙yp_$M2#AS,`)7$rkTA29_Iye"|/0t)$n XT2`YJ;6Jx".e<`$) PI$5V4]29SRI>~=@j]lp2`K9Jaai^" Ԋ29ORI%:XV5]JmN9]H;1UC39NI%Xe78t)a;Oi Ҙ>Xt"~G>_mn:%|~ޅ_+]$o)@ǀ{hgN;IK6G&rp)T2i୦KJuv*T=TOSV>(~D>dm,I*Ɛ:R#ۙNI%D>G.n$o;+#RR!.eU˽TRI28t)1LWϚ>IJa3oFbu&:tJ*(F7y0ZR ^p'Ii L24x| XRI%ۄ>S1]Jy[zL$adB7.eh4%%누>WETf+3IR:I3Xה)3אOۦSRO'ٺ)S}"qOr[B7ϙ.edG)^ETR"RtRݜh0}LFVӦDB^k_JDj\=LS(Iv─aTeZ%eUAM-0;~˃@i|l @S4y72>sX-vA}ϛBI!ݎߨWl*)3{'Y|iSlEڻ(5KtSI$Uv02,~ԩ~x;P4ցCrO%tyn425:KMlD ^4JRxSهF_}شJTS6uj+ﷸk$eZO%G*^V2u3EMj3k%)okI]dT)URKDS 7~m@TJR~荪fT"֛L \sM -0T KfJz+nإKr L&j()[E&I ߴ>e FW_kJR|!O:5/2跌3T-'|zX ryp0JS ~^F>-2< `*%ZFP)bSn"L :)+pʷf(pO3TMW$~>@~ū:TAIsV1}S2<%ޟM?@iT ,Eūoz%i~g|`wS(]oȤ8)$ ntu`өe`6yPl IzMI{ʣzʨ )IZ2= ld:5+請M$-ї;U>_gsY$ÁN5WzWfIZ)-yuXIfp~S*IZdt;t>KūKR|$#LcԀ+2\;kJ`]YǔM1B)UbG"IRߊ<xܾӔJ0Z='Y嵤 Leveg)$znV-º^3Ւof#0Tfk^Zs[*I꯳3{)ˬW4Ւ4 OdpbZRS|*I 55#"&-IvT&/윚Ye:i$ 9{LkuRe[I~_\ؠ%>GL$iY8 9ܕ"S`kS.IlC;Ҏ4x&>u_0JLr<J2(^$5L s=MgV ~,Iju> 7r2)^=G$1:3G< `J3~&IR% 6Tx/rIj3O< ʔ&#f_yXJiގNSz; Tx(i8%#4 ~AS+IjerIUrIj362v885+IjAhK__5X%nV%Iͳ-y|7XV2v4fzo_68"S/I-qbf; LkF)KSM$ Ms>K WNV}^`-큧32ŒVؙGdu,^^m%6~Nn&͓3ŒVZMsRpfEW%IwdǀLm[7W&bIRL@Q|)* i ImsIMmKmyV`i$G+R 0tV'!V)֏28vU7͒vHꦼtxꗞT ;S}7Mf+fIRHNZUkUx5SAJㄌ9MqμAIRi|j5)o*^'<$TwI1hEU^c_j?Е$%d`z cyf,XO IJnTgA UXRD }{H}^S,P5V2\Xx`pZ|Yk:$e ~ @nWL.j+ϝYb퇪bZ BVu)u/IJ_ 1[p.p60bC >|X91P:N\!5qUB}5a5ja `ubcVxYt1N0Zzl4]7­gKj]?4ϻ *[bg$)+À*x쳀ogO$~,5 زUS9 lq3+5mgw@np1sso Ӻ=|N6 /g(Wv7U;zωM=wk,0uTg_`_P`uz?2yI!b`kĸSo+Qx%!\οe|އԁKS-s6pu_(ֿ$i++T8=eY; צP+phxWQv*|p1. ά. XRkIQYP,drZ | B%wP|S5`~́@i޾ E;Չaw{o'Q?%iL{u D?N1BD!owPHReFZ* k_-~{E9b-~P`fE{AܶBJAFO wx6Rox5 K5=WwehS8 (JClJ~ p+Fi;ŗo+:bD#g(C"wA^ r.F8L;dzdIHUX݆ϞXg )IFqem%I4dj&ppT{'{HOx( Rk6^C٫O.)3:s(۳(Z?~ٻ89zmT"PLtw䥈5&b<8GZ-Y&K?e8,`I6e(֍xb83 `rzXj)F=l($Ij 2*(F?h(/9ik:I`m#p3MgLaKjc/U#n5S# m(^)=y=đx8ŬI[U]~SцA4p$-F i(R,7Cx;X=cI>{Km\ o(Tv2vx2qiiDJN,Ҏ!1f 5quBj1!8 rDFd(!WQl,gSkL1Bxg''՞^ǘ;pQ P(c_ IRujg(Wz bs#P­rz> k c&nB=q+ؔXn#r5)co*Ũ+G?7< |PQӣ'G`uOd>%Mctz# Ԫڞ&7CaQ~N'-P.W`Oedp03C!IZcIAMPUۀ5J<\u~+{9(FbbyAeBhOSܳ1 bÈT#ŠyDžs,`5}DC-`̞%r&ڙa87QWWp6e7 Rϫ/oY ꇅ Nܶըtc!LA T7V4Jsū I-0Pxz7QNF_iZgúWkG83 0eWr9 X]㾮݁#Jˢ C}0=3ݱtBi]_ &{{[/o[~ \q鯜00٩|cD3=4B_b RYb$óBRsf&lLX#M*C_L܄:gx)WΘsGSbuL rF$9';\4Ɍq'n[%p.Q`u hNb`eCQyQ|l_C>Lb꟟3hSb #xNxSs^ 88|Mz)}:](vbۢamŖ࿥ 0)Q7@0=?^k(*J}3ibkFn HjB׻NO z x}7p 0tfDX.lwgȔhԾŲ }6g E |LkLZteu+=q\Iv0쮑)QٵpH8/2?Σo>Jvppho~f>%bMM}\//":PTc(v9v!gոQ )UfVG+! 35{=x\2+ki,y$~A1iC6#)vC5^>+gǵ@1Hy٪7u;p psϰu/S <aʸGu'tD1ԝI<pg|6j'p:tպhX{o(7v],*}6a_ wXRk,O]Lܳ~Vo45rp"N5k;m{rZbΦ${#)`(Ŵg,;j%6j.pyYT?}-kBDc3qA`NWQū20/^AZW%NQ MI.X#P#,^Ebc&?XR tAV|Y.1!؅⨉ccww>ivl(JT~ u`ٵDm q)+Ri x/x8cyFO!/*!/&,7<.N,YDŽ&ܑQF1Bz)FPʛ?5d 6`kQձ λc؎%582Y&nD_$Je4>a?! ͨ|ȎWZSsv8 j(I&yj Jb5m?HWp=g}G3#|I,5v珿] H~R3@B[☉9Ox~oMy=J;xUVoj bUsl_35t-(ՃɼRB7U!qc+x4H_Qo֮$[GO<4`&č\GOc[.[*Af%mG/ ňM/r W/Nw~B1U3J?P&Y )`ѓZ1p]^l“W#)lWZilUQu`-m|xĐ,_ƪ|9i:_{*(3Gѧ}UoD+>m_?VPۅ15&}2|/pIOʵ> GZ9cmíتmnz)yߐbD >e}:) r|@R5qVSA10C%E_'^8cR7O;6[eKePGϦX7jb}OTGO^jn*媓7nGMC t,k31Rb (vyܴʭ!iTh8~ZYZp(qsRL ?b}cŨʊGO^!rPJO15MJ[c&~Z`"ѓޔH1C&^|Ш|rʼ,AwĴ?b5)tLU)F| &g٣O]oqSUjy(x<Ϳ3 .FSkoYg2 \_#wj{u'rQ>o;%n|F*O_L"e9umDds?.fuuQbIWz |4\0 sb;OvxOSs; G%T4gFRurj(֍ڑb uԖKDu1MK{1^ q; C=6\8FR艇!%\YÔU| 88m)֓NcLve C6z;o&X x59:q61Z(T7>C?gcļxѐ Z oo-08jہ x,`' ҔOcRlf~`jj".Nv+sM_]Zk g( UOPyεx%pUh2(@il0ݽQXxppx-NS( WO+轾 nFߢ3M<;z)FBZjciu/QoF 7R¥ ZFLF~#ȣߨ^<쩡ݛкvџ))ME>ώx4m#!-m!L;vv#~Y[đKmx9.[,UFS CVkZ +ߟrY٧IZd/ioi$%͝ب_ֶX3ܫhNU ZZgk=]=bbJS[wjU()*I =ώ:}-蹞lUj:1}MWm=̛ _ ¾,8{__m{_PVK^n3esw5ӫh#$-q=A̟> ,^I}P^J$qY~Q[ Xq9{#&T.^GVj__RKpn,b=`żY@^՝;z{paVKkQXj/)y TIc&F;FBG7wg ZZDG!x r_tƢ!}i/V=M/#nB8 XxЫ ^@CR<{䤭YCN)eKOSƟa $&g[i3.C6xrOc8TI;o hH6P&L{@q6[ Gzp^71j(l`J}]e6X☉#͕ ׈$AB1Vjh㭦IRsqFBjwQ_7Xk>y"N=MB0 ,C #o6MRc0|$)ف"1!ixY<B9mx `,tA>)5ػQ?jQ?cn>YZe Tisvh# GMމȇp:ԴVuږ8ɼH]C.5C!UV;F`mbBk LTMvPʍϤj?ԯ/Qr1NB`9s"s TYsz &9S%U԰> {<ؿSMxB|H\3@!U| k']$U+> |HHMLޢ?V9iD!-@x TIî%6Z*9X@HMW#?nN ,oe6?tQwڱ.]-y':mW0#!J82qFjH -`ѓ&M0u Uγmxϵ^-_\])@0Rt.8/?ٰCY]x}=sD3ojަЫNuS%U}ԤwHH>ڗjܷ_3gN q7[q2la*ArǓԖ+p8/RGM ]jacd(JhWko6ڎbj]i5Bj3+3!\j1UZLsLTv8HHmup<>gKMJj0@H%,W΃7R) ">c, xixј^ aܖ>H[i.UIHc U1=yW\=S*GR~)AF=`&2h`DzT󑓶J+?W+}C%P:|0H܆}-<;OC[~o.$~i}~HQ TvXΈr=b}$vizL4:ȰT|4~*!oXQR6Lk+#t/g lԁߖ[Jڶ_N$k*". xsxX7jRVbAAʯKҎU3)zSNN _'s?f)6X!%ssAkʱ>qƷb hg %n ~p1REGMHH=BJiy[<5 ǁJҖgKR*倳e~HUy)Ag,K)`Vw6bRR:qL#\rclK/$sh*$ 6덤 KԖc 3Z9=Ɣ=o>X Ώ"1 )a`SJJ6k(<c e{%kϊP+SL'TcMJWRm ŏ"w)qc ef꒵i?b7b('"2r%~HUS1\<(`1Wx9=8HY9m:X18bgD1u ~|H;K-Uep,, C1 RV.MR5άh,tWO8WC$ XRVsQS]3GJ|12 [vM :k#~tH30Rf-HYݺ-`I9%lIDTm\ S{]9gOڒMNCV\G*2JRŨ;Rҏ^ڽ̱mq1Eu?To3I)y^#jJw^Ńj^vvlB_⋌P4x>0$c>K†Aļ9s_VjTt0l#m>E-,,x,-W)سo&96RE XR.6bXw+)GAEvL)͞K4$p=Ũi_ѱOjb HY/+@θH9޼]Nԥ%n{ &zjT? Ty) s^ULlb,PiTf^<À] 62R^V7)S!nllS6~͝V}-=%* ʻ>G DnK<y&>LPy7'r=Hj 9V`[c"*^8HpcO8bnU`4JȪAƋ#1_\ XϘHPRgik(~G~0DAA_2p|J묭a2\NCr]M_0 ^T%e#vD^%xy-n}-E\3aS%yN!r_{ )sAw ڼp1pEAk~v<:`'ӭ^5 ArXOI驻T (dk)_\ PuA*BY]yB"l\ey hH*tbK)3 IKZ򹞋XjN n *n>k]X_d!ryBH ]*R 0(#'7 %es9??ښFC,ՁQPjARJ\Ρw K#jahgw;2$l*) %Xq5!U᢯6Re] |0[__64ch&_}iL8KEgҎ7 M/\`|.p,~`a=BR?xܐrQ8K XR2M8f ?`sgWS%" Ԉ 7R%$ N}?QL1|-эټwIZ%pvL3Hk>,ImgW7{E xPHx73RA @RS CC !\ȟ5IXR^ZxHл$Q[ŝ40 (>+ _C >BRt<,TrT {O/H+˟Pl6 I B)/VC<6a2~(XwV4gnXR ϱ5ǀHٻ?tw똤Eyxp{#WK qG%5],(0ӈH HZ])ג=K1j&G(FbM@)%I` XRg ʔ KZG(vP,<`[ Kn^ SJRsAʠ5xՅF`0&RbV tx:EaUE/{fi2;.IAwW8/tTxAGOoN?G}l L(n`Zv?pB8K_gI+ܗ #i?ޙ.) p$utc ~DžfՈEo3l/)I-U?aԅ^jxArA ΧX}DmZ@QLےbTXGd.^|xKHR{|ΕW_h] IJ`[G9{).y) 0X YA1]qp?p_k+J*Y@HI>^?gt.06Rn ,` ?);p pSF9ZXLBJPWjgQ|&)7! HjQt<| ؅W5 x W HIzYoVMGP Hjn`+\(dNW)F+IrS[|/a`K|ͻ0Hj{R,Q=\ (F}\WR)AgSG`IsnAR=|8$}G(vC$)s FBJ?]_u XRvύ6z ŨG[36-T9HzpW̞ú Xg큽=7CufzI$)ki^qk-) 0H*N` QZkk]/tnnsI^Gu't=7$ Z;{8^jB% IItRQS7[ϭ3 $_OQJ`7!]W"W,)Iy W AJA;KWG`IY{8k$I$^%9.^(`N|LJ%@$I}ֽp=FB*xN=gI?Q{٥4B)mw $Igc~dZ@G9K X?7)aK%݅K$IZ-`IpC U6$I\0>!9k} Xa IIS0H$I H ?1R.Чj:4~Rw@p$IrA*u}WjWFPJ$I➓/6#! LӾ+ X36x8J |+L;v$Io4301R20M I$-E}@,pS^ޟR[/s¹'0H$IKyfŸfVOπFT*a$I>He~VY/3R/)>d$I>28`Cjw,n@FU*9ttf$I~<;=/4RD~@ X-ѕzἱI$: ԍR a@b X{+Qxuq$IЛzo /~3\8ڒ4BN7$IҀj V]n18H$IYFBj3̵̚ja pp $Is/3R Ӻ-Yj+L;.0ŔI$Av? #!5"aʄj}UKmɽH$IjCYs?h$IDl843.v}m7UiI=&=0Lg0$I4: embe` eQbm0u? $IT!Sƍ'-sv)s#C0:XB2a w I$zbww{."pPzO =Ɔ\[ o($Iaw]`E).Kvi:L*#gР7[$IyGPI=@R 4yR~̮´cg I$I/<tPͽ hDgo 94Z^k盇΄8I56^W$I^0̜N?4*H`237}g+hxoq)SJ@p|` $I%>-hO0eO>\ԣNߌZD6R=K ~n($I$y3D>o4b#px2$yڪtzW~a $I~?x'BwwpH$IZݑnC㧄Pc_9sO gwJ=l1:mKB>Ab<4Lp$Ib o1ZQ@85b̍ S'F,Fe,^I$IjEdù{l4 8Ys_s Z8.x m"+{~?q,Z D!I$ϻ'|XhB)=…']M>5 rgotԎ 獽PH$IjIPhh)n#cÔqA'ug5qwU&rF|1E%I$%]!'3AFD/;Ck_`9 v!ٴtPV;x`'*bQa w I$Ix5 FC3D_~A_#O݆DvV?<qw+I$I{=Z8".#RIYyjǪ=fDl9%M,a8$I$Ywi[7ݍFe$s1ՋBVA?`]#!oz4zjLJo8$I$%@3jAa4(o ;p,,dya=F9ً[LSPH$IJYЉ+3> 5"39aZ<ñh!{TpBGkj}Sp $IlvF.F$I z< '\K*qq.f<2Y!S"-\I$IYwčjF$ w9 \ߪB.1v!Ʊ?+r:^!I$BϹB H"B;L'G[ 4U#5>੐)|#o0aڱ$I>}k&1`U#V?YsV x>{t1[I~D&(I$I/{H0fw"q"y%4 IXyE~M3 8XψL}qE$I[> nD?~sf ]o΁ cT6"?'_Ἣ $I>~.f|'!N?⟩0G KkXZE]ޡ;/&?k OۘH$IRۀwXӨ<7@PnS04aӶp.:@\IWQJ6sS%I$e5ڑv`3:x';wq_vpgHyXZ 3gЂ7{{EuԹn±}$I$8t;b|591nءQ"P6O5i }iR̈́%Q̄p!I䮢]O{H$IRϻ9s֧ a=`- aB\X0"+5"C1Hb?߮3x3&gşggl_hZ^,`5?ߎvĸ%̀M!OZC2#0x LJ0 Gw$I$I}<{Eb+y;iI,`ܚF:5ܛA8-O-|8K7s|#Z8a&><a&/VtbtLʌI$I$I$I$I$I$IRjDD%tEXtdate:create2022-05-31T04:40:26+00:00!Î%tEXtdate:modify2022-05-31T04:40:26+00:00|{2IENDB`Mini Shell

HOME


Mini Shell 1.0
DIR:/proc/self/root/usr/share/emacs/26.1/lisp/emacs-lisp/
Upload File :
Current File : //proc/self/root/usr/share/emacs/26.1/lisp/emacs-lisp/rx.elc
;ELC
;;; Compiled
;;; in Emacs version 26.1
;;; with all optimizations.

;;; This file uses dynamic docstrings, first added in Emacs 19.29.

;;; This file does not contain utf-8 non-ASCII characters,
;;; and so can be loaded in Emacs versions earlier than 23.

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;


#@642 Alist of sexp form regexp constituents.
Each element of the alist has the form (SYMBOL . DEFN).
SYMBOL is a valid constituent of sexp regular expressions.
If DEFN is a string, SYMBOL is translated into DEFN.
If DEFN is a symbol, use the definition of DEFN, recursively.
Otherwise, DEFN must be a list (FUNCTION MIN-ARGS MAX-ARGS PREDICATE).
FUNCTION is used to produce code for SYMBOL.  MIN-ARGS and MAX-ARGS
are the minimum and maximum number of arguments the function-form
sexp constituent SYMBOL may have in sexp regular expressions.
MAX-ARGS nil means no limit.  PREDICATE, if specified, means that
all arguments must satisfy PREDICATE.
(defvar rx-constituents '((and rx-and 1 nil) (seq . and) (: . and) (sequence . and) (or rx-or 1 nil) (| . or) (not-newline . ".") (nonl . not-newline) (anything rx-anything 0 nil) (any rx-any 1 nil rx-check-any) (any . ".") (in . any) (char . any) (not-char rx-not-char 1 nil rx-check-any) (not rx-not 1 1 rx-check-not) (repeat rx-repeat 2 nil) (= rx-= 2 nil) (>= rx->= 2 nil) (** rx-** 2 nil) (submatch rx-submatch 1 nil) (group . submatch) (submatch-n rx-submatch-n 2 nil) (group-n . submatch-n) (zero-or-more rx-kleene 1 nil) (one-or-more rx-kleene 1 nil) (zero-or-one rx-kleene 1 nil) (\? . zero-or-one) (\?\? . zero-or-one) (* . zero-or-more) (*\? . zero-or-more) (0+ . zero-or-more) (+ . one-or-more) (+\? . one-or-more) (1+ . one-or-more) (optional . zero-or-one) (opt . zero-or-one) (minimal-match rx-greedy 1 1) (maximal-match rx-greedy 1 1) (backref rx-backref 1 1 rx-check-backref) (line-start . "^") (bol . line-start) (line-end . "$") (eol . line-end) (string-start . "\\`") (bos . string-start) (bot . string-start) (string-end . "\\'") (eos . string-end) (eot . string-end) (buffer-start . "\\`") (buffer-end . "\\'") (point . "\\=") (word-start . "\\<") (bow . word-start) (word-end . "\\>") (eow . word-end) (word-boundary . "\\b") (not-word-boundary . "\\B") (symbol-start . "\\_<") (symbol-end . "\\_>") (syntax rx-syntax 1 1) (not-syntax rx-not-syntax 1 1) (category rx-category 1 1 rx-check-category) (eval rx-eval 1 1) (regexp rx-regexp 1 1 stringp) (regex . regexp) (digit . "[[:digit:]]") (numeric . digit) (num . digit) (control . "[[:cntrl:]]") (cntrl . control) (hex-digit . "[[:xdigit:]]") (hex . hex-digit) (xdigit . hex-digit) (blank . "[[:blank:]]") (graphic . "[[:graph:]]") (graph . graphic) (printing . "[[:print:]]") (print . printing) (alphanumeric . "[[:alnum:]]") (alnum . alphanumeric) (letter . "[[:alpha:]]") (alphabetic . letter) (alpha . letter) (ascii . "[[:ascii:]]") (nonascii . "[[:nonascii:]]") (lower . "[[:lower:]]") (lower-case . lower) (punctuation . "[[:punct:]]") (punct . punctuation) (space . "[[:space:]]") (whitespace . space) (white . space) (upper . "[[:upper:]]") (upper-case . upper) (word . "[[:word:]]") (wordchar . word) (not-wordchar . "\\W")) (#$ . 409))
#@265 Alist mapping Rx syntax symbols to syntax characters.
Each entry has the form (SYMBOL . CHAR), where SYMBOL is a valid
symbol in `(syntax SYMBOL)', and CHAR is the syntax character
corresponding to SYMBOL, as it would be used with \s or \S in
regular expressions.
(defconst rx-syntax '((whitespace . 45) (punctuation . 46) (word . 119) (symbol . 95) (open-parenthesis . 40) (close-parenthesis . 41) (expression-prefix . 39) (string-quote . 34) (paired-delimiter . 36) (escape . 92) (character-quote . 47) (comment-start . 60) (comment-end . 62) (string-delimiter . 124) (comment-delimiter . 33)) (#$ . 3279))
#@272 Alist mapping symbols to category characters.
Each entry has the form (SYMBOL . CHAR), where SYMBOL is a valid
symbol in `(category SYMBOL)', and CHAR is the category character
corresponding to SYMBOL, as it would be used with `\c' or `\C' in
regular expression strings.
(defconst rx-categories '((consonant . 48) (base-vowel . 49) (upper-diacritical-mark . 50) (lower-diacritical-mark . 51) (tone-mark . 52) (symbol . 53) (digit . 54) (vowel-modifying-diacritical-mark . 55) (vowel-sign . 56) (semivowel-lower . 57) (not-at-end-of-line . 60) (not-at-beginning-of-line . 62) (alpha-numeric-two-byte . 65) (chinese-two-byte . 67) (chinse-two-byte . 67) (greek-two-byte . 71) (japanese-hiragana-two-byte . 72) (indian-two-byte . 73) (japanese-katakana-two-byte . 75) (korean-hangul-two-byte . 78) (cyrillic-two-byte . 89) (combining-diacritic . 94) (ascii . 97) (arabic . 98) (chinese . 99) (ethiopic . 101) (greek . 103) (korean . 104) (indian . 105) (japanese . 106) (japanese-katakana . 107) (latin . 108) (lao . 111) (tibetan . 113) (japanese-roman . 114) (thai . 116) (vietnamese . 118) (hebrew . 119) (cyrillic . 121) (can-break . 124)) (#$ . 3895))
#@124 Non-nil means produce greedy regular expressions for `zero-or-one',
`zero-or-more', and `one-or-more'.  Dynamically bound.
(defvar rx-greedy-flag t (#$ . 5056))
#@292 Return parsing/code generation info for OP.
If OP is the space character ASCII 32, return info for the symbol `?'.
If OP is the character `?', return info for the symbol `??'.
See also `rx-constituents'.
If HEAD is non-nil, then OP is the head of a sexp, otherwise it's
a standalone symbol.
(defalias 'rx-info #[(op head) "\305\267\202
\306\202
\307\310\203O9\203O\n\236A\203(;\202*:\203	\211\n\236\n>A\236A\211\203K\203D\f;\202F\f:\204K\f)\202)\207" [op old-op rx-constituents head new-op #s(hash-table size 2 test eq rehash-size 1.5 rehash-threshold 0.8125 purecopy t data (32 6 63 11)) \? \?\? nil] 4 (#$ . 5224)])
#@49 Check FORM according to its car's parsing info.
(defalias 'rx-check #[(form) "<\204\n\306\307\"\210\310@\311\"GS	A@\312	8\313	8\2031\nW\2031\306\314@#\210\f\203B\n\fV\203B\306\315@\f#\210
??\205qA\316\211\205p@
!\204f\306\317@
#\210A\211\204S\316*-\207" [form rx nargs min-args max-args type-pred error "rx `%s' needs argument(s)" rx-info head 2 3 "rx form `%s' requires at least %d args" "rx form `%s' accepts at most %d args" nil "rx form `%s' requires args satisfying `%s'" sub-form --dolist-tail--] 5 (#$ . 5879)])
#@76 Put shy groups around REGEXP if seemingly necessary when GROUP
is non-nil.
(defalias 'rx-group-if #[(regexp group) "\302=\203\303	!\203K\304\202K\305=\2031\303\306\307	\"\203'	\310\211\224O\202(	!\203K\304\202K\311=\203<\304\202K\312=\204K\303	\312\"\203K\304\203T\313	\314Q\207	\207" [group regexp * rx-atomic-p nil : string-match "\\(?:[?*+]\\??\\|\\\\{[0-9]*,?[0-9]*\\\\}\\)\\'" 0 | t "\\(?:" "\\)"] 4 (#$ . 6443)])
#@74 Parse and produce code from FORM.
FORM is of the form `(and FORM1 ...)'.
(defalias 'rx-and #[(form) "\302!\210\303\304\305A\306#	\307>\205	\"\207" [form rx-parent rx-check rx-group-if mapconcat #[(x) "\301\302\"\207" [x rx-form :] 3] nil (* t)] 5 (#$ . 6891)])
#@62 Parse and produce code from FORM, which is `(or FORM1 ...)'.
(defalias 'rx-or #[(form) "\302!\210\303\304\305\306A\">\203\307\310A\311#\202\312A!	\313>\205#	\"\207" [form rx-parent rx-check rx-group-if nil mapcar stringp mapconcat #[(x) "\301\302\"\207" [x rx-form |] 3] "\\|" regexp-opt (: * t)] 5 (#$ . 7163)])
#@22 Match any character.
(defalias 'rx-anything #[(form) ":\203\n\301\302\"\210\303\304\305\306E!\207" [form error "rx `anything' syntax error: %s" rx-or or not-newline 10] 4 (#$ . 7492)])
#@93 Delete by side effect character CHAR from RANGES.
Only both edges of each range is checked.
(defalias 'rx-any-delete-from-range #[(char ranges) "\303	\n>\203\304	\n\"\202R	\n\236\211\2032	TA=\203*\n>	T\240\210\202R	T\240\210\202R\305	\n\"\211\203R	S@=\203M\n>	S\240\210\202R	S\241\210\n)\207" [m char ranges nil delq rassq] 3 (#$ . 7686)])
#@53 Condense by side effect ARGS as range for Rx `any'.
(defalias 'rx-any-condense-range #[(args) "\305\211\306\307\n\"\210\310\311\"\211\305\fA\211\203=\f@A@@SY\2037\f@\f@A@A]\241\210\fA\241\210\202\211\202*\312\313\314\315\"\"\316	!\244*\207" [l str args d tail nil mapc #[(e) ";\203	B\211\207\247\203\211B\nB\211\207\nB\211\207" [e str l] 2] sort car-less-than-car apply nconc mapcar #[(e) "@AU\203\f@C\207@TAU\203@AD\207C\207" [e] 2] delete-dups] 6 (#$ . 8052)])
#@41 Check string argument STR for Rx `any'.
(defalias 'rx-check-any-string #[(str) "\305\306\211\211\fG\305U\203\307\310!\210\311\312\f#\203X\305\224W\203-\313\f\305\224O\306\"\244\305\225\f\305\224H\fSH\n	W\203J\n	BC\244\202\n	U\203\nC\244\202\fGW\203i\313\f\306O\306\"\244,\207" [l c2 c1 i str 0 nil error "String arg for Rx `any' must not be empty" string-match ".-." append] 5 (#$ . 8563)])
#@29 Check arg ARG for Rx `any'.
(defalias 'rx-check-any #[(arg) "\250\203C\2079\2032\3021\303!0\202\210\304\211\203&\305\306	\"\204+\307\310\"\210	\311\312O)C\207\242\250\203A\243\250\203AC\207;\203J\313!\207\307\314!\207" [arg translation (error) rx-form nil string-match "\\`\\[\\[:[-a-z]+:\\]\\]\\'" error "Invalid char class `%s' in Rx `any'" 1 -1 rx-check-any-string "rx `any' requires string, character, char pair or char class args"] 4 (#$ . 8994)])
#@78 Parse and produce code from FORM, which is `(any ARG ...)'.
ARG is optional.
(defalias 'rx-any #[(form) "\305!\210\306\307\310\311\312A\"\"!\313\211\314	>\2037\314\315\314	\"B\316	>\204,\316	\236\203\336\317\316	\"\316C\244\202\336\314	\236\211\203l\n\315\n	\"B\316	>\203W\315\316	\"\316C\244\202\336\316	\236\211\203\336	\n\315\n	A\"B\241\210\202\336\320\314	\"\211\203\223\314\317\314	\"B\316	>\204\210\316	\236\203\336\317\316	\"\316C\244\202\336\316	>\203\243\316\315\316	\"B\202\336\316	\236\211\203\265\n\315\n	\"B\202\336	@\321=\204\304	@\242\321=\203\336	A\203\326	A@	@	AABB\202\335\317\321	\"\321C\244	A\204	@\247\203\322\323	@!!\211G\324U\204	@\321\232\203\f\325=\204\202\326\327\330	\313#\331Q+\207" [form args m s rx-parent rx-check rx-any-condense-range apply nconc mapcar rx-check-any nil 93 delq 45 rx-any-delete-from-range rassq 94 regexp-quote string 1 ! "[" mapconcat #[(e) "\247\203	\301!\207:\2034@TAU\203,@\302>\204,A\303>\204,\301@A\"\207\301@\304A#\207\207" [e string (93 45) (93 45) 45] 4] "]"] 7 (#$ . 9476)])
#@29 Check arg ARG for Rx `not'.
(defalias 'rx-check-not #[(arg) "9\203\301\302\3031\304!0\202\210\305\"\204/\306=\204/:\203*@\307>\204/\310\311\"\210\312\207" [arg string-match "\\`\\[\\[:[-a-z]+:\\]\\]\\'" (error) rx-form "" word-boundary (not any in syntax category) error "rx `not' syntax error: %s" t] 4 (#$ . 10587)])
#@57 Parse and produce code from FORM.  FORM is `(not ...)'.
(defalias 'rx-not #[(form) "\304!\210\305A@\306\"\307\310\311\n\"\203=\n\312\232\203\313\202z\nG\314U\2034\306=\2044\315\n\316\317O!\202z\320\n\316\307OP\202z\n\321H\322=\203N\323\n\324\307OP\202z\310\325\n\"\203b\n\321\316O\226\n\316\307OP\202z\310\326\n\"\203v\n\321\316O\227\n\316\307OP\202z\323\n\327Q*\207" [form case-fold-search result rx-parent rx-check rx-form ! nil string-match "\\`\\[^" "[^]" "[^^]" 4 regexp-quote 2 3 "[" 0 91 "[^" 1 "\\`\\\\[scbw]" "\\`\\\\[SCBW]" "]"] 4 (#$ . 10928)])
#@62 Parse and produce code from FORM.  FORM is `(not-char ...)'.
(defalias 'rx-not-char #[(form) "\301!\210\302\303\304ABD!\207" [form rx-check rx-not not in] 4 (#$ . 11509)])
#@67 Parse and produce code from FORM.  FORM is `(not-syntax SYNTAX)'.
(defalias 'rx-not-syntax #[(form) "\301!\210\302\303\304ABD!\207" [form rx-check rx-not not syntax] 4 (#$ . 11689)])
#@251 If FORM's length is greater than two, transform it to length two.
A form (HEAD REST ...) becomes (HEAD (and REST ...)).
If SKIP is non-nil, allow that number of items after the head, i.e.
`(= N REST ...)' becomes `(= N (and REST ...))' if SKIP is 1.
(defalias 'rx-trans-forms #[(form &optional skip) "\204\303T	\233\211G\304U\203	\202%\305	!	\233\306\nBC\241\210	))\207" [skip form tail 0 1 copy-sequence and] 4 (#$ . 11881)])
#@47 Parse and produce code from FORM `(= N ...)'.
(defalias 'rx-= #[(form) "\301!\210\302\303\"\211A@\250\203A@\304V\204\305\306!\210\307\310\311\3128\313\"A@#\207" [form rx-check rx-trans-forms 1 0 error "rx `=' requires positive integer first arg" format "%s\\{%d\\}" rx-form 2 *] 6 (#$ . 12325)])
#@48 Parse and produce code from FORM `(>= N ...)'.
(defalias 'rx->= #[(form) "\301!\210\302\303\"\211A@\250\203A@\304V\204\305\306!\210\307\310\311\3128\313\"A@#\207" [form rx-check rx-trans-forms 1 0 error "rx `>=' requires positive integer first arg" format "%s\\{%d,\\}" rx-form 2 *] 6 (#$ . 12637)])
#@50 Parse and produce code from FORM `(** N M ...)'.
(defalias 'rx-** #[(form) "\301!\210\302\303\304\305\"AB\306\"\207" [form rx-check rx-form repeat rx-trans-forms 2 *] 5 (#$ . 12953)])
#@97 Parse and produce code from FORM.
FORM is either `(repeat N FORM1)' or `(repeat N M FORMS...)'.
(defalias 'rx-repeat #[(form) "\301!\210G\302V\203\303\304\"\3048\204!@A@\305\233BBG\305U\203HA@\250\2037A@\306V\204;\307\310!\210\311\312\313\3048\314\"A@#\207\3048\250\203p\3048\306W\204pA@\250\203pA@\306W\204p\3048A@W\203t\307\315!\207\311\316\313\3058\314\"A@\3048$\207" [form rx-check 4 rx-trans-forms 2 3 0 error "rx `repeat' requires positive integer first arg" format "%s\\{%d\\}" rx-form * "rx `repeat' range error" "%s\\{%d,%d\\}"] 6 (#$ . 13145)])
#@62 Parse and produce code from FORM, which is `(submatch ...)'.
(defalias 'rx-submatch #[(form) "\301G\302U\203\303A@!\202\304\305A\306#\307Q\207" [form "\\(" 2 rx-form mapconcat #[(re) "\301\302\"\207" [re rx-form :] 3] nil "\\)"] 5 (#$ . 13740)])
#@66 Parse and produce code from FORM, which is `(submatch-n N ...)'.
(defalias 'rx-submatch-n #[(form) "A@\302\303	!\304G\305U\203\306\3078!\202\310\311AA\312#\313\260)\207" [form n "\\(?" number-to-string ":" 3 rx-form 2 mapconcat #[(re) "\301\302\"\207" [re rx-form :] 3] nil "\\)"] 7 (#$ . 14000)])
#@59 Parse and produce code from FORM, which is `(backref N)'.
(defalias 'rx-backref #[(form) "\301!\210\302\303A@\"\207" [form rx-check format "\\%d"] 3 (#$ . 14315)])
#@33 Check arg ARG for Rx `backref'.
(defalias 'rx-check-backref #[(arg) "\250\203\301Y\203\302X\206\303\304\"\207" [arg 1 9 error "rx `backref' requires numeric 1<=arg<=9: %s"] 3 (#$ . 14487)])
#@326 Parse and produce code from FORM.
FORM is `(OP FORM1)', where OP is one of the `zero-or-one',
`zero-or-more' etc.  operators.
If OP is one of `*', `+', `?', produce a greedy regexp.
If OP is one of `*?', `+?', `??', produce a non-greedy regexp.
If OP is anything else, produce a greedy regexp if `rx-greedy-flag'
is non-nil.
(defalias 'rx-kleene #[(form) "\305!\210\306!\211@\307>\203\310\202'@\311>\203\312\202'	\203&\310\202'\312@\313>\2032\314\202>@\315>\203=\316\202>\312\317\320A@\321\"\nQ\f\322>\205Q\f\"*\207" [form rx-greedy-flag op suffix rx-parent rx-check rx-trans-forms (* + 32) "" (*\? +\? 63) "?" (* *\? 0+ zero-or-more) "*" (+ +\? 1+ one-or-more) "+" rx-group-if rx-form * (t *)] 5 (#$ . 14694)])
#@988 Return non-nil if regexp string R is atomic.
An atomic regexp R is one such that a suffix operator
appended to R will apply to all of R.  For example, "a"
"[abc]" and "\(ab\|ab*c\)" are atomic and "ab",
"[ab]c", and "ab\|ab*c" are not atomic.

This function may return false negatives, but it will not
return false positives.  It is nevertheless useful in
situations where an efficiency shortcut can be taken only if a
regexp is atomic.  The function can be improved to detect
more cases of atomic regexps.  Presently, this function
detects the following categories of atomic regexp;

  a group or shy group:  \(...\)
  a character class:     [...]
  a single character:    a

On the other hand, false negatives will be returned for
regexps that are atomic but end in operators, such as
"a+".  I think these are rare.  Probably such cases could
be detected without much effort.  A guarantee of no false
negatives would require a theoretic specification of the set
of all atomic regexps.
(defalias 'rx-atomic-p #[(r &optional lax) "G\211\303X\2068	\304U\203\305H\306U\2028	\307U\203$\310\311\"\2028\n?\2058\310\312\"\2068\310\313\"\2068\314)\207" [r l lax 1 2 0 92 3 string-match "\\`\\(?:\\\\[cCsS_]\\|\\[[^^]\\]\\)" "\\`\\[^?]?\\(?:\\[:[a-z]+:]\\|[^]]\\)*\\]\\'" "\\`\\\\(\\(?:[^\\]\\|\\\\[^)]\\)*\\\\)\\'" nil] 4 (#$ . 15436)])
#@63 Parse and produce code from FORM, which is `(syntax SYMBOL)'.
(defalias 'rx-syntax #[(form) "\305!\210A@\211\n\236A\211\204:\306	!\203	\2021	9\2031\307	!\211G\310U\2030\f\311H)\204:\312\313	\"\210\314\315\"*\207" [form sym rx-syntax syntax name rx-check characterp symbol-name 1 0 error "Unknown rx syntax `%s'" format "\\s%c"] 4 (#$ . 16787)])
#@49 Check the argument FORM of a `(category FORM)'.
(defalias 'rx-check-category #[(form) "\250\204	\236A\204\302\303\"\210\304\207" [form rx-categories error "Unknown category `%s'" t] 3 (#$ . 17154)])
#@65 Parse and produce code from FORM, which is `(category SYMBOL)'.
(defalias 'rx-category #[(form) "\303!\210A@\250\203A@\202A@	\236A\304\305\n\")\207" [form rx-categories char rx-check format "\\c%c"] 3 (#$ . 17366)])
#@59 Parse and produce code from FORM, which is `(eval FORM)'.
(defalias 'rx-eval #[(form) "\302!\210\303\304A@!	\"\207" [form rx-parent rx-check rx-form eval] 3 (#$ . 17597)])
#@213 Parse and produce code from FORM.
If FORM is `(minimal-match FORM1)', non-greedy versions of `*',
`+', and `?' operators will be used in FORM1.  If FORM is
`(maximal-match FORM1)', greedy operators will be used.
(defalias 'rx-greedy #[(form) "\303!\210@\304=\305A@\n\")\207" [form rx-greedy-flag rx-parent rx-check maximal-match rx-form] 3 (#$ . 17778)])
#@63 Parse and produce code from FORM, which is `(regexp STRING)'.
(defalias 'rx-regexp #[(form) "\302!\210\303A@	\"\207" [form rx-parent rx-check rx-group-if] 3 (#$ . 18143)])
#@230 Parse and produce code for regular expression FORM.
FORM is a regular expression in sexp form.
RX-PARENT shows which type of expression calls and controls putting of
shy groups around the result and some more in other functions.
(defalias 'rx-form #[(form &optional rx-parent) ";\203\303\304!	\305=\205\306GW\205	\"\207\250\203$\304\307!!\2079\203H\310\311\"\211;\2037\n\202F\n\204B\312\313\"\202F\n@!)\207:\203d\310@\314\"\211:\204^\312\313@\"\210\n@!)\207\312\315\"\207" [form rx-parent info rx-group-if regexp-quote * 1 char-to-string rx-info nil error "Unknown rx form `%s'" head "rx syntax error at `%s'"] 5 (#$ . 18324)])
#@159 Parse and produce code for regular expression FORM.
FORM is a regular expression in sexp form.
NO-GROUP non-nil means don't put shy groups around the result.
(defalias 'rx-to-string #[(form &optional no-group) "\302\303!	?\"\207" [form no-group rx-group-if rx-form] 3 (#$ . 18989)])
#@8727 Translate regular expressions REGEXPS in sexp form to a regexp string.
REGEXPS is a non-empty sequence of forms of the sort listed below.

Note that `rx' is a Lisp macro; when used in a Lisp program being
compiled, the translation is performed by the compiler.
See `rx-to-string' for how to do such a translation at run-time.

The following are valid subforms of regular expressions in sexp
notation.

STRING
     matches string STRING literally.

CHAR
     matches character CHAR literally.

`not-newline', `nonl'
     matches any character except a newline.

`anything'
     matches any character

`(any SET ...)'
`(in SET ...)'
`(char SET ...)'
     matches any character in SET ....  SET may be a character or string.
     Ranges of characters can be specified as `A-Z' in strings.
     Ranges may also be specified as conses like `(?A . ?Z)'.

     SET may also be the name of a character class: `digit',
     `control', `hex-digit', `blank', `graph', `print', `alnum',
     `alpha', `ascii', `nonascii', `lower', `punct', `space', `upper',
     `word', or one of their synonyms.

`(not (any SET ...))'
     matches any character not in SET ...

`line-start', `bol'
     matches the empty string, but only at the beginning of a line
     in the text being matched

`line-end', `eol'
     is similar to `line-start' but matches only at the end of a line

`string-start', `bos', `bot'
     matches the empty string, but only at the beginning of the
     string being matched against.

`string-end', `eos', `eot'
     matches the empty string, but only at the end of the
     string being matched against.

`buffer-start'
     matches the empty string, but only at the beginning of the
     buffer being matched against.  Actually equivalent to `string-start'.

`buffer-end'
     matches the empty string, but only at the end of the
     buffer being matched against.  Actually equivalent to `string-end'.

`point'
     matches the empty string, but only at point.

`word-start', `bow'
     matches the empty string, but only at the beginning of a word.

`word-end', `eow'
     matches the empty string, but only at the end of a word.

`word-boundary'
     matches the empty string, but only at the beginning or end of a
     word.

`(not word-boundary)'
`not-word-boundary'
     matches the empty string, but not at the beginning or end of a
     word.

`symbol-start'
     matches the empty string, but only at the beginning of a symbol.

`symbol-end'
     matches the empty string, but only at the end of a symbol.

`digit', `numeric', `num'
     matches 0 through 9.

`control', `cntrl'
     matches ASCII control characters.

`hex-digit', `hex', `xdigit'
     matches 0 through 9, a through f and A through F.

`blank'
     matches horizontal whitespace, as defined by Annex C of the
     Unicode Technical Standard #18.  In particular, it matches
     spaces, tabs, and other characters whose Unicode
     `general-category' property indicates they are spacing
     separators.

`graphic', `graph'
     matches graphic characters--everything except whitespace, ASCII
     and non-ASCII control characters, surrogates, and codepoints
     unassigned by Unicode.

`printing', `print'
     matches whitespace and graphic characters.

`alphanumeric', `alnum'
     matches alphabetic characters and digits.  (For multibyte characters,
     it matches according to Unicode character properties.)

`letter', `alphabetic', `alpha'
     matches alphabetic characters.  (For multibyte characters,
     it matches according to Unicode character properties.)

`ascii'
     matches ASCII (unibyte) characters.

`nonascii'
     matches non-ASCII (multibyte) characters.

`lower', `lower-case'
     matches anything lower-case.

`upper', `upper-case'
     matches anything upper-case.

`punctuation', `punct'
     matches punctuation.  (But at present, for multibyte characters,
     it matches anything that has non-word syntax.)

`space', `whitespace', `white'
     matches anything that has whitespace syntax.

`word', `wordchar'
     matches anything that has word syntax.

`not-wordchar'
     matches anything that has non-word syntax.

`(syntax SYNTAX)'
     matches a character with syntax SYNTAX.  SYNTAX must be one
     of the following symbols, or a symbol corresponding to the syntax
     character, e.g. `\.' for `\s.'.

     `whitespace'		(\s- in string notation)
     `punctuation'		(\s.)
     `word'			(\sw)
     `symbol'			(\s_)
     `open-parenthesis'		(\s()
     `close-parenthesis'	(\s))
     `expression-prefix'	(\s')
     `string-quote'		(\s")
     `paired-delimiter'		(\s$)
     `escape'			(\s\)
     `character-quote'		(\s/)
     `comment-start'		(\s<)
     `comment-end'		(\s>)
     `string-delimiter'		(\s|)
     `comment-delimiter'	(\s!)

`(not (syntax SYNTAX))'
     matches a character that doesn't have syntax SYNTAX.

`(category CATEGORY)'
     matches a character with category CATEGORY.  CATEGORY must be
     either a character to use for C, or one of the following symbols.

     `consonant'			(\c0 in string notation)
     `base-vowel'			(\c1)
     `upper-diacritical-mark'		(\c2)
     `lower-diacritical-mark'		(\c3)
     `tone-mark'		        (\c4)
     `symbol'			        (\c5)
     `digit'			        (\c6)
     `vowel-modifying-diacritical-mark'	(\c7)
     `vowel-sign'			(\c8)
     `semivowel-lower'			(\c9)
     `not-at-end-of-line'		(\c<)
     `not-at-beginning-of-line'		(\c>)
     `alpha-numeric-two-byte'		(\cA)
     `chinese-two-byte'			(\cC)
     `greek-two-byte'			(\cG)
     `japanese-hiragana-two-byte'	(\cH)
     `indian-tow-byte'			(\cI)
     `japanese-katakana-two-byte'	(\cK)
     `korean-hangul-two-byte'		(\cN)
     `cyrillic-two-byte'		(\cY)
     `combining-diacritic'		(\c^)
     `ascii'				(\ca)
     `arabic'				(\cb)
     `chinese'				(\cc)
     `ethiopic'				(\ce)
     `greek'				(\cg)
     `korean'				(\ch)
     `indian'				(\ci)
     `japanese'				(\cj)
     `japanese-katakana'		(\ck)
     `latin'				(\cl)
     `lao'				(\co)
     `tibetan'				(\cq)
     `japanese-roman'			(\cr)
     `thai'				(\ct)
     `vietnamese'			(\cv)
     `hebrew'				(\cw)
     `cyrillic'				(\cy)
     `can-break'			(\c|)

`(not (category CATEGORY))'
     matches a character that doesn't have category CATEGORY.

`(and SEXP1 SEXP2 ...)'
`(: SEXP1 SEXP2 ...)'
`(seq SEXP1 SEXP2 ...)'
`(sequence SEXP1 SEXP2 ...)'
     matches what SEXP1 matches, followed by what SEXP2 matches, etc.

`(submatch SEXP1 SEXP2 ...)'
`(group SEXP1 SEXP2 ...)'
     like `and', but makes the match accessible with `match-end',
     `match-beginning', and `match-string'.

`(submatch-n N SEXP1 SEXP2 ...)'
`(group-n N SEXP1 SEXP2 ...)'
     like `group', but make it an explicitly-numbered group with
     group number N.

`(or SEXP1 SEXP2 ...)'
`(| SEXP1 SEXP2 ...)'
     matches anything that matches SEXP1 or SEXP2, etc.  If all
     args are strings, use `regexp-opt' to optimize the resulting
     regular expression.

`(minimal-match SEXP)'
     produce a non-greedy regexp for SEXP.  Normally, regexps matching
     zero or more occurrences of something are "greedy" in that they
     match as much as they can, as long as the overall regexp can
     still match.  A non-greedy regexp matches as little as possible.

`(maximal-match SEXP)'
     produce a greedy regexp for SEXP.  This is the default.

Below, `SEXP ...' represents a sequence of regexp forms, treated as if
enclosed in `(and ...)'.

`(zero-or-more SEXP ...)'
`(0+ SEXP ...)'
     matches zero or more occurrences of what SEXP ... matches.

`(* SEXP ...)'
     like `zero-or-more', but always produces a greedy regexp, independent
     of `rx-greedy-flag'.

`(*? SEXP ...)'
     like `zero-or-more', but always produces a non-greedy regexp,
     independent of `rx-greedy-flag'.

`(one-or-more SEXP ...)'
`(1+ SEXP ...)'
     matches one or more occurrences of SEXP ...

`(+ SEXP ...)'
     like `one-or-more', but always produces a greedy regexp.

`(+? SEXP ...)'
     like `one-or-more', but always produces a non-greedy regexp.

`(zero-or-one SEXP ...)'
`(optional SEXP ...)'
`(opt SEXP ...)'
     matches zero or one occurrences of A.

`(? SEXP ...)'
     like `zero-or-one', but always produces a greedy regexp.

`(?? SEXP ...)'
     like `zero-or-one', but always produces a non-greedy regexp.

`(repeat N SEXP)'
`(= N SEXP ...)'
     matches N occurrences.

`(>= N SEXP ...)'
     matches N or more occurrences.

`(repeat N M SEXP)'
`(** N M SEXP ...)'
     matches N to M occurrences.

`(backref N)'
     matches what was matched previously by submatch N.

`(eval FORM)'
     evaluate FORM and insert result.  If result is a string,
     `regexp-quote' it.

`(regexp REGEXP)'
     include REGEXP in string notation in the result.
(defalias 'rx '(macro . #[(&rest regexps) "\204\301\302!\207A\203\303\304B\305\"\207\303@\305\"\207" [regexps error "No regexp" rx-to-string and t] 3 (#$ . 19281)]))
#@903 Build a `pcase' pattern matching `rx' regexps.
The REGEXPS are interpreted as by `rx'.  The pattern matches if
the regular expression so constructed matches the object, as if
by `string-match'.

In addition to the usual `rx' constructs, REGEXPS can contain the
following constructs:

  (let VAR FORM...)  creates a new explicitly numbered submatch
                     that matches FORM and binds the match to
                     VAR.
  (backref VAR)      creates a backreference to the submatch
                     introduced by a previous (let VAR ...)
                     construct.

The VARs are associated with explicitly numbered submatches
starting from 1.  Multiple occurrences of the same VAR refer to
the same submatch.

If a case matches, the match data is modified as usual so you can
use it in the case body, but you still have to pass the correct
string as argument to `match-string'.
(defalias 'rx--pcase-macroexpander #[(&rest regexps) "\306\307\310\311BB\312\313\314\211\315\257	BB\316\317\nB\320\"\321\322\323DD\314\306\211
:\203H
@\324\325\fDEB\fT
A\211\202*\237.BB\207" [vars rx-constituents regexps regexp i #1=#:--cl-var-- nil let #[(form) "\304!\210A@\2119\204\305\306\307	\301E\"\210\310	\n\311\312$\206&\nG\313\n	C\"\314\315TAABB!*\207" [form var vars i rx-check signal wrong-type-argument symbol cl-position :test eq append rx-form submatch-n] 6] (1 nil) backref #[(form) "\303!\210\304\305A@\211\250\203	\202\306	\n\307\310$T)D!\207" [form var vars rx-check rx-backref backref cl-position :test eq] 8] 1 #[(var) "\250\203	\302!\207	>\203\303\207\304\305	#\207" [var vars rx-check-backref t error "rx `backref' variable must be one of %s: %s"] 4] rx-to-string seq :no-group and pred string-match app match-string var #2=#:--cl-var--] 7 (#$ . 28188)])
(byte-code "\300\301\302\303#\300\304\305\301#\306\304!\207" [define-symbol-prop rx--pcase-macroexpander edebug-form-spec nil rx pcase-macroexpander provide] 5)