PNG  IHDRX cHRMz&u0`:pQ<bKGD pHYsodtIME MeqIDATxw]Wug^Qd˶ 6`!N:!@xI~)%7%@Bh&`lnjVF29gΨ4E$|>cɚ{gk= %,a KX%,a KX%,a KX%,a KX%,a KX%,a KX%, b` ǟzeאfp]<!SJmɤY޲ڿ,%c ~ع9VH.!Ͳz&QynֺTkRR.BLHi٪:l;@(!MԴ=žI,:o&N'Kù\vRmJ雵֫AWic H@" !: Cé||]k-Ha oݜ:y F())u]aG7*JV@J415p=sZH!=!DRʯvɱh~V\}v/GKY$n]"X"}t@ xS76^[bw4dsce)2dU0 CkMa-U5tvLƀ~mlMwfGE/-]7XAƟ`׮g ewxwC4\[~7@O-Q( a*XGƒ{ ՟}$_y3tĐƤatgvێi|K=uVyrŲlLӪuܿzwk$m87k( `múcE)"@rK( z4$D; 2kW=Xb$V[Ru819קR~qloѱDyįݎ*mxw]y5e4K@ЃI0A D@"BDk_)N\8͜9dz"fK0zɿvM /.:2O{ Nb=M=7>??Zuo32 DLD@D| &+֎C #B8ַ`bOb $D#ͮҪtx]%`ES`Ru[=¾!@Od37LJ0!OIR4m]GZRJu$‡c=%~s@6SKy?CeIh:[vR@Lh | (BhAMy=݃  G"'wzn޺~8ԽSh ~T*A:xR[ܹ?X[uKL_=fDȊ؂p0}7=D$Ekq!/t.*2ʼnDbŞ}DijYaȲ(""6HA;:LzxQ‘(SQQ}*PL*fc\s `/d'QXW, e`#kPGZuŞuO{{wm[&NBTiiI0bukcA9<4@SӊH*؎4U/'2U5.(9JuDfrޱtycU%j(:RUbArLֺN)udA':uGQN"-"Is.*+k@ `Ojs@yU/ H:l;@yyTn}_yw!VkRJ4P)~y#)r,D =ě"Q]ci'%HI4ZL0"MJy 8A{ aN<8D"1#IJi >XjX֔#@>-{vN!8tRݻ^)N_╗FJEk]CT՟ YP:_|H1@ CBk]yKYp|og?*dGvzنzӴzjֺNkC~AbZƷ`.H)=!QͷVTT(| u78y֮}|[8-Vjp%2JPk[}ԉaH8Wpqhwr:vWª<}l77_~{s۴V+RCģ%WRZ\AqHifɤL36: #F:p]Bq/z{0CU6ݳEv_^k7'>sq*+kH%a`0ԣisqにtү04gVgW΂iJiS'3w.w}l6MC2uԯ|>JF5`fV5m`Y**Db1FKNttu]4ccsQNnex/87+}xaUW9y>ͯ骵G{䩓Գ3+vU}~jJ.NFRD7<aJDB1#ҳgSb,+CS?/ VG J?|?,2#M9}B)MiE+G`-wo߫V`fio(}S^4e~V4bHOYb"b#E)dda:'?}׮4繏`{7Z"uny-?ǹ;0MKx{:_pÚmFמ:F " .LFQLG)Q8qN q¯¯3wOvxDb\. BKD9_NN &L:4D{mm o^tֽ:q!ƥ}K+<"m78N< ywsard5+вz~mnG)=}lYݧNj'QJS{S :UYS-952?&O-:W}(!6Mk4+>A>j+i|<<|;ر^߉=HE|V#F)Emm#}/"y GII웻Jі94+v뾧xu~5C95~ūH>c@덉pʃ1/4-A2G%7>m;–Y,cyyaln" ?ƻ!ʪ<{~h~i y.zZB̃/,雋SiC/JFMmBH&&FAbϓO^tubbb_hZ{_QZ-sύodFgO(6]TJA˯#`۶ɟ( %$&+V'~hiYy>922 Wp74Zkq+Ovn錄c>8~GqܲcWꂎz@"1A.}T)uiW4="jJ2W7mU/N0gcqܗOO}?9/wìXžΏ0 >֩(V^Rh32!Hj5`;O28؇2#ݕf3 ?sJd8NJ@7O0 b־?lldщ̡&|9C.8RTWwxWy46ah嘦mh٤&l zCy!PY?: CJyв]dm4ǜҐR޻RլhX{FƯanшQI@x' ao(kUUuxW_Ñ줮[w8 FRJ(8˼)_mQ _!RJhm=!cVmm ?sFOnll6Qk}alY}; "baӌ~M0w,Ggw2W:G/k2%R,_=u`WU R.9T"v,<\Ik޽/2110Ӿxc0gyC&Ny޽JҢrV6N ``یeA16"J³+Rj*;BϜkZPJaÍ<Jyw:NP8/D$ 011z֊Ⱳ3ι֘k1V_"h!JPIΣ'ɜ* aEAd:ݺ>y<}Lp&PlRfTb1]o .2EW\ͮ]38؋rTJsǏP@芎sF\> P^+dYJLbJ C-xϐn> ι$nj,;Ǖa FU *择|h ~izť3ᤓ`K'-f tL7JK+vf2)V'-sFuB4i+m+@My=O҈0"|Yxoj,3]:cо3 $#uŘ%Y"y죯LebqtҢVzq¼X)~>4L׶m~[1_k?kxֺQ`\ |ٛY4Ѯr!)N9{56(iNq}O()Em]=F&u?$HypWUeB\k]JɩSع9 Zqg4ZĊo oMcjZBU]B\TUd34ݝ~:7ڶSUsB0Z3srx 7`:5xcx !qZA!;%͚7&P H<WL!džOb5kF)xor^aujƍ7 Ǡ8/p^(L>ὴ-B,{ۇWzֺ^k]3\EE@7>lYBȝR.oHnXO/}sB|.i@ɥDB4tcm,@ӣgdtJ!lH$_vN166L__'Z)y&kH;:,Y7=J 9cG) V\hjiE;gya~%ks_nC~Er er)muuMg2;֫R)Md) ,¶ 2-wr#F7<-BBn~_(o=KO㭇[Xv eN_SMgSҐ BS헃D%g_N:/pe -wkG*9yYSZS.9cREL !k}<4_Xs#FmҶ:7R$i,fi!~' # !6/S6y@kZkZcX)%5V4P]VGYq%H1!;e1MV<!ϐHO021Dp= HMs~~a)ަu7G^];git!Frl]H/L$=AeUvZE4P\.,xi {-~p?2b#amXAHq)MWǾI_r`S Hz&|{ +ʖ_= (YS(_g0a03M`I&'9vl?MM+m~}*xT۲(fY*V4x@29s{DaY"toGNTO+xCAO~4Ϳ;p`Ѫ:>Ҵ7K 3}+0 387x\)a"/E>qpWB=1 ¨"MP(\xp߫́A3+J] n[ʼnӼaTbZUWb={~2ooKױӰp(CS\S筐R*JغV&&"FA}J>G֐p1ٸbk7 ŘH$JoN <8s^yk_[;gy-;߉DV{c B yce% aJhDȶ 2IdйIB/^n0tNtџdcKj4϶v~- CBcgqx9= PJ) dMsjpYB] GD4RDWX +h{y`,3ꊕ$`zj*N^TP4L:Iz9~6s) Ga:?y*J~?OrMwP\](21sZUD ?ܟQ5Q%ggW6QdO+\@ ̪X'GxN @'4=ˋ+*VwN ne_|(/BDfj5(Dq<*tNt1х!MV.C0 32b#?n0pzj#!38}޴o1KovCJ`8ŗ_"]] rDUy޲@ Ȗ-;xџ'^Y`zEd?0„ DAL18IS]VGq\4o !swV7ˣι%4FѮ~}6)OgS[~Q vcYbL!wG3 7띸*E Pql8=jT\꘿I(z<[6OrR8ºC~ډ]=rNl[g|v TMTղb-o}OrP^Q]<98S¤!k)G(Vkwyqyr޽Nv`N/e p/~NAOk \I:G6]4+K;j$R:Mi #*[AȚT,ʰ,;N{HZTGMoּy) ]%dHء9Պ䠬|<45,\=[bƟ8QXeB3- &dҩ^{>/86bXmZ]]yޚN[(WAHL$YAgDKp=5GHjU&99v簪C0vygln*P)9^͞}lMuiH!̍#DoRBn9l@ xA/_v=ȺT{7Yt2N"4!YN`ae >Q<XMydEB`VU}u]嫇.%e^ánE87Mu\t`cP=AD/G)sI"@MP;)]%fH9'FNsj1pVhY&9=0pfuJ&gޤx+k:!r˭wkl03׼Ku C &ѓYt{.O.zҏ z}/tf_wEp2gvX)GN#I ݭ߽v/ .& и(ZF{e"=V!{zW`, ]+LGz"(UJp|j( #V4, 8B 0 9OkRrlɱl94)'VH9=9W|>PS['G(*I1==C<5"Pg+x'K5EMd؞Af8lG ?D FtoB[je?{k3zQ vZ;%Ɠ,]E>KZ+T/ EJxOZ1i #T<@ I}q9/t'zi(EMqw`mYkU6;[t4DPeckeM;H}_g pMww}k6#H㶏+b8雡Sxp)&C $@'b,fPߑt$RbJ'vznuS ~8='72_`{q纶|Q)Xk}cPz9p7O:'|G~8wx(a 0QCko|0ASD>Ip=4Q, d|F8RcU"/KM opKle M3#i0c%<7׿p&pZq[TR"BpqauIp$ 8~Ĩ!8Սx\ւdT>>Z40ks7 z2IQ}ItԀ<-%S⍤};zIb$I 5K}Q͙D8UguWE$Jh )cu4N tZl+[]M4k8֦Zeq֮M7uIqG 1==tLtR,ƜSrHYt&QP윯Lg' I,3@P'}'R˪e/%-Auv·ñ\> vDJzlӾNv5:|K/Jb6KI9)Zh*ZAi`?S {aiVDԲuy5W7pWeQJk֤#5&V<̺@/GH?^τZL|IJNvI:'P=Ϛt"¨=cud S Q.Ki0 !cJy;LJR;G{BJy޺[^8fK6)=yʊ+(k|&xQ2`L?Ȓ2@Mf 0C`6-%pKpm')c$׻K5[J*U[/#hH!6acB JA _|uMvDyk y)6OPYjœ50VT K}cǻP[ $:]4MEA.y)|B)cf-A?(e|lɉ#P9V)[9t.EiQPDѠ3ϴ;E:+Օ t ȥ~|_N2,ZJLt4! %ա]u {+=p.GhNcŞQI?Nd'yeh n7zi1DB)1S | S#ًZs2|Ɛy$F SxeX{7Vl.Src3E℃Q>b6G ўYCmtկ~=K0f(=LrAS GN'ɹ9<\!a`)֕y[uՍ[09` 9 +57ts6}b4{oqd+J5fa/,97J#6yν99mRWxJyѡyu_TJc`~W>l^q#Ts#2"nD1%fS)FU w{ܯ R{ ˎ󅃏џDsZSQS;LV;7 Od1&1n$ N /.q3~eNɪ]E#oM~}v֯FڦwyZ=<<>Xo稯lfMFV6p02|*=tV!c~]fa5Y^Q_WN|Vs 0ҘދU97OI'N2'8N֭fgg-}V%y]U4 峧p*91#9U kCac_AFңĪy뚇Y_AiuYyTTYЗ-(!JFLt›17uTozc. S;7A&&<ԋ5y;Ro+:' *eYJkWR[@F %SHWP 72k4 qLd'J "zB6{AC0ƁA6U.'F3:Ȅ(9ΜL;D]m8ڥ9}dU "v!;*13Rg^fJyShyy5auA?ɩGHRjo^]׽S)Fm\toy 4WQS@mE#%5ʈfFYDX ~D5Ϡ9tE9So_aU4?Ѽm%&c{n>.KW1Tlb}:j uGi(JgcYj0qn+>) %\!4{LaJso d||u//P_y7iRJ߬nHOy) l+@$($VFIQ9%EeKʈU. ia&FY̒mZ=)+qqoQn >L!qCiDB;Y<%} OgBxB!ØuG)WG9y(Ą{_yesuZmZZey'Wg#C~1Cev@0D $a@˲(.._GimA:uyw֬%;@!JkQVM_Ow:P.s\)ot- ˹"`B,e CRtaEUP<0'}r3[>?G8xU~Nqu;Wm8\RIkբ^5@k+5(By'L&'gBJ3ݶ!/㮻w҅ yqPWUg<e"Qy*167΃sJ\oz]T*UQ<\FԎ`HaNmڜ6DysCask8wP8y9``GJ9lF\G g's Nn͵MLN֪u$| /|7=]O)6s !ĴAKh]q_ap $HH'\1jB^s\|- W1:=6lJBqjY^LsPk""`]w)󭃈,(HC ?䔨Y$Sʣ{4Z+0NvQkhol6C.婧/u]FwiVjZka&%6\F*Ny#8O,22+|Db~d ~Çwc N:FuuCe&oZ(l;@ee-+Wn`44AMK➝2BRՈt7g*1gph9N) *"TF*R(#'88pm=}X]u[i7bEc|\~EMn}P瘊J)K.0i1M6=7'_\kaZ(Th{K*GJyytw"IO-PWJk)..axӝ47"89Cc7ĐBiZx 7m!fy|ϿF9CbȩV 9V-՛^pV̌ɄS#Bv4-@]Vxt-Z, &ֺ*diؠ2^VXbs֔Ìl.jQ]Y[47gj=幽ex)A0ip׳ W2[ᎇhuE^~q흙L} #-b۸oFJ_QP3r6jr+"nfzRJTUqoaۍ /$d8Mx'ݓ= OՃ| )$2mcM*cЙj}f };n YG w0Ia!1Q.oYfr]DyISaP}"dIӗթO67jqR ҊƐƈaɤGG|h;t]䗖oSv|iZqX)oalv;۩meEJ\!8=$4QU4Xo&VEĊ YS^E#d,yX_> ۘ-e\ "Wa6uLĜZi`aD9.% w~mB(02G[6y.773a7 /=o7D)$Z 66 $bY^\CuP. (x'"J60׿Y:Oi;F{w佩b+\Yi`TDWa~|VH)8q/=9!g߆2Y)?ND)%?Ǐ`k/sn:;O299yB=a[Ng 3˲N}vLNy;*?x?~L&=xyӴ~}q{qE*IQ^^ͧvü{Huu=R|>JyUlZV, B~/YF!Y\u_ݼF{_C)LD]m {H 0ihhadd nUkf3oٺCvE\)QJi+֥@tDJkB$1!Đr0XQ|q?d2) Ӣ_}qv-< FŊ߫%roppVBwü~JidY4:}L6M7f٬F "?71<2#?Jyy4뷢<_a7_=Q E=S1И/9{+93֮E{ǂw{))?maÆm(uLE#lïZ  ~d];+]h j?!|$F}*"4(v'8s<ŏUkm7^7no1w2ؗ}TrͿEk>p'8OB7d7R(A 9.*Mi^ͳ; eeUwS+C)uO@ =Sy]` }l8^ZzRXj[^iUɺ$tj))<sbDJfg=Pk_{xaKo1:-uyG0M ԃ\0Lvuy'ȱc2Ji AdyVgVh!{]/&}}ċJ#%d !+87<;qN޼Nفl|1N:8ya  8}k¾+-$4FiZYÔXk*I&'@iI99)HSh4+2G:tGhS^繿 Kتm0 вDk}֚+QT4;sC}rՅE,8CX-e~>G&'9xpW,%Fh,Ry56Y–hW-(v_,? ; qrBk4-V7HQ;ˇ^Gv1JVV%,ik;D_W!))+BoS4QsTM;gt+ndS-~:11Sgv!0qRVh!"Ȋ(̦Yl.]PQWgٳE'`%W1{ndΗBk|Ž7ʒR~,lnoa&:ü$ 3<a[CBݮwt"o\ePJ=Hz"_c^Z.#ˆ*x z̝grY]tdkP*:97YľXyBkD4N.C_[;F9`8& !AMO c `@BA& Ost\-\NX+Xp < !bj3C&QL+*&kAQ=04}cC!9~820G'PC9xa!w&bo_1 Sw"ܱ V )Yl3+ס2KoXOx]"`^WOy :3GO0g;%Yv㐫(R/r (s } u B &FeYZh0y> =2<Ϟc/ -u= c&׭,.0"g"7 6T!vl#sc>{u/Oh Bᾈ)۴74]x7 gMӒ"d]U)}" v4co[ ɡs 5Gg=XR14?5A}D "b{0$L .\4y{_fe:kVS\\O]c^W52LSBDM! C3Dhr̦RtArx4&agaN3Cf<Ԉp4~ B'"1@.b_/xQ} _߃҉/gٓ2Qkqp0շpZ2fԫYz< 4L.Cyυι1t@鎫Fe sYfsF}^ V}N<_`p)alٶ "(XEAVZ<)2},:Ir*#m_YӼ R%a||EƼIJ,,+f"96r/}0jE/)s)cjW#w'Sʯ5<66lj$a~3Kʛy 2:cZ:Yh))+a߭K::N,Q F'qB]={.]h85C9cr=}*rk?vwV렵ٸW Rs%}rNAkDv|uFLBkWY YkX מ|)1!$#3%y?pF<@<Rr0}: }\J [5FRxY<9"SQdE(Q*Qʻ)q1E0B_O24[U'],lOb ]~WjHޏTQ5Syu wq)xnw8~)c 쫬gٲߠ H% k5dƝk> kEj,0% b"vi2Wس_CuK)K{n|>t{P1򨾜j>'kEkƗBg*H%'_aY6Bn!TL&ɌOb{c`'d^{t\i^[uɐ[}q0lM˕G:‚4kb祔c^:?bpg… +37stH:0}en6x˟%/<]BL&* 5&fK9Mq)/iyqtA%kUe[ڛKN]Ě^,"`/ s[EQQm?|XJ߅92m]G.E΃ח U*Cn.j_)Tѧj̿30ڇ!A0=͜ar I3$C^-9#|pk!)?7.x9 @OO;WƝZBFU keZ75F6Tc6"ZȚs2y/1 ʵ:u4xa`C>6Rb/Yм)^=+~uRd`/|_8xbB0?Ft||Z\##|K 0>>zxv8۴吅q 8ĥ)"6>~\8:qM}#͚'ĉ#p\׶ l#bA?)|g g9|8jP(cr,BwV (WliVxxᡁ@0Okn;ɥh$_ckCgriv}>=wGzβ KkBɛ[˪ !J)h&k2%07δt}!d<9;I&0wV/ v 0<H}L&8ob%Hi|޶o&h1L|u֦y~󛱢8fٲUsւ)0oiFx2}X[zVYr_;N(w]_4B@OanC?gĦx>мgx>ΛToZoOMp>40>V Oy V9iq!4 LN,ˢu{jsz]|"R޻&'ƚ{53ўFu(<٪9:΋]B;)B>1::8;~)Yt|0(pw2N%&X,URBK)3\zz&}ax4;ǟ(tLNg{N|Ǽ\G#C9g$^\}p?556]/RP.90 k,U8/u776s ʪ_01چ|\N 0VV*3H鴃J7iI!wG_^ypl}r*jɤSR 5QN@ iZ#1ٰy;_\3\BQQ x:WJv츟ٯ$"@6 S#qe딇(/P( Dy~TOϻ<4:-+F`0||;Xl-"uw$Цi󼕝mKʩorz"mϺ$F:~E'ҐvD\y?Rr8_He@ e~O,T.(ފR*cY^m|cVR[8 JҡSm!ΆԨb)RHG{?MpqrmN>߶Y)\p,d#xۆWY*,l6]v0h15M˙MS8+EdI='LBJIH7_9{Caз*Lq,dt >+~ّeʏ?xԕ4bBAŚjﵫ!'\Ը$WNvKO}ӽmSşذqsOy?\[,d@'73'j%kOe`1.g2"e =YIzS2|zŐƄa\U,dP;jhhhaxǶ?КZ՚.q SE+XrbOu%\GتX(H,N^~]JyEZQKceTQ]VGYqnah;y$cQahT&QPZ*iZ8UQQM.qo/T\7X"u?Mttl2Xq(IoW{R^ ux*SYJ! 4S.Jy~ BROS[V|žKNɛP(L6V^|cR7i7nZW1Fd@ Ara{詑|(T*dN]Ko?s=@ |_EvF]׍kR)eBJc" MUUbY6`~V޴dJKß&~'d3i WWWWWW
Current Directory: /usr/share/emacs/24.3/lisp/emacs-lisp
Viewing File: /usr/share/emacs/24.3/lisp/emacs-lisp/rx.elc
;ELC ;;; Compiled by mockbuild@buildfarm01-new.corp.cloudlinux.com on Tue Nov 11 12:52:38 2025 ;;; from file /builddir/build/BUILD/emacs-24.3/lisp/emacs-lisp/rx.el ;;; in Emacs version 24.3.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")) (#$ . 557)) #@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)) (#$ . 3427)) #@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) (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)) (#$ . 4043)) #@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 (#$ . 5180)) #@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=\203 \306\202\307=\203\310\311\203U9\203U\n\236A \203.;\2020:\203 \211\n\236\n>A\236A\211\203Q \203J\f;\202L\f:\204Q\f)\202)\207" [op old-op rx-constituents head new-op 32 \? 63 \?\? nil] 4 (#$ . 5348)]) #@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\n W\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 (#$ . 5919)]) #@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 (#$ . 6483)]) #@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 (#$ . 6931)]) #@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 (#$ . 7203)]) #@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 (#$ . 7532)]) #@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 (#$ . 7726)]) #@53 Condense by side effect ARGS as range for Rx `any'. (defalias 'rx-any-condense-range #[(args) "\306\211\307\310\n\"\210\311\312\"\211\306\fA\211\203I\f\211@A) \211@@)SY\203C\f@\f\211@A) \211@A)]\241\210\f A\241\210\202 \211\202*\313\314\315\316\"\"\317 !\244*\207" [l str args d tail x 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 (#$ . 8092)]) #@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\f SH\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 (#$ . 8629)]) #@29 Check arg ARG for Rx `any'. (defalias 'rx-check-any #[(arg) "\250\203C\2079\203)\302\303\304\217\211\203\305\306 \"\204\"\307\310\"\210 \311\312O)C\207\242\250\2038\243\250\2038C\207;\203A\313!\207\307\314!\207" [arg translation nil (rx-form arg) ((error)) 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 (#$ . 9060)]) #@78 Parse and produce code from FORM, which is `(any ARG ...)'. ARG is optional. (defalias 'rx-any #[(form) "\306!\210\307\310\311\312\313A\"\"!\314\211\315 >\2037\315\316\315 \"B\317 >\204,\317 \236\203\343\320\317 \"\317C\244\202\343\315 \236\211\203k\n\316\n \"B\317 >\203W\316\317 \"\317C\244\202\343\317 \236\211\203\343 \n\316\n \"B\241\210\202\343\321\315 \"\211\203\222\315\320\315 \"B\317 >\204\207\317 \236\203\343\320\317 \"\317C\244\202\343\317 >\203\242\317\316\317 \"B\202\343\317 \236\211\203\264\n\316\n \"B\202\343 @\322=\204\303 @\242\322=\203\343 A\203\333 \211A@) @ \211AA)BB\202\342\320\322 \"\322C\244 A\204  @\247\203 \323\324 @!!\211G\325U\204  @\322\232\203  \326=\204  \202\327\330\331 \314#\332Q+\207" [form args m s x 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 (#$ . 9539)]) #@29 Check arg ARG for Rx `not'. (defalias 'rx-check-not #[(arg) "9\203\301\302\303\304\305\217\"\204&\306=\204&:\203!@\307>\204&\310\311\"\210\312\207" [arg string-match "\\`\\[\\[:[-a-z]+:\\]\\]\\'" nil (rx-form arg) ((error "")) word-boundary (not any in syntax category) error "rx `not' syntax error: %s" t] 5 (#$ . 10662)]) #@57 Parse and produce code from FORM. FORM is `(not ...)'. (defalias 'rx-not #[(form) "\305!\210\306\211A@)\307\"\310\311\312 \"\203@ \313\232\203!\314\202} G\315U\2037\f\307=\2047\316 \317\320O!\202}\321 \317\310OP\202} \322H\323=\203Q\324 \325\310OP\202}\311\326 \"\203e \322\317O\226 \317\310OP\202}\311\327 \"\203y \322\317O\227 \317\310OP\202}\324 \330Q*\207" [form x case-fold-search result rx-parent rx-check rx-form ! nil string-match "\\`\\[^" "[^]" "[^^]" 4 regexp-quote 2 3 "[" 0 91 "[^" 1 "\\`\\\\[scbw]" "\\`\\\\[SCBW]" "]"] 5 (#$ . 11003)]) #@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 (#$ . 11579)]) #@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 (#$ . 11759)]) #@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 (#$ . 11951)]) #@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 (#$ . 12395)]) #@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 (#$ . 12707)]) #@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 (#$ . 13023)]) #@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 (#$ . 13215)]) #@62 Parse and produce code from FORM, which is `(submatch ...)'. (defalias 'rx-submatch #[(form) "\302G\303U\203\304\211A@)!\202\305\306A\307#\310Q\207" [form x "\\(" 2 rx-form mapconcat #[(re) "\301\302\"\207" [re rx-form :] 3] nil "\\)"] 6 (#$ . 13810)]) #@66 Parse and produce code from FORM, which is `(submatch-n N ...)'. (defalias 'rx-submatch-n #[(form) "A@\303\304 !\305G\306U\203\307\3108!\202\"\311\312\211AA)\313#\314\260)\207" [form n x "\\(?" number-to-string ":" 3 rx-form 2 mapconcat #[(re) "\301\302\"\207" [re rx-form :] 3] nil "\\)"] 8 (#$ . 14078)]) #@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 (#$ . 14402)]) #@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 (#$ . 14574)]) #@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) "\306!\210\307!\211@\310>\203\311\202'@\312>\203\313\202' \203&\311\202'\313@\314>\2032\315\202>@\316>\203=\317\202>\313\320\321\211A@)\322\"\n Q \323>\205T \"*\207" [form rx-greedy-flag op suffix x rx-parent rx-check rx-trans-forms (* + 32) "" (*\? +\? 63) "?" (* *\? 0+ zero-or-more) "*" (+ +\? 1+ one-or-more) "+" rx-group-if rx-form * (t *)] 5 (#$ . 14781)]) #@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 (#$ . 15529)]) #@63 Parse and produce code from FORM, which is `(syntax SYMBOL)'. (defalias 'rx-syntax #[(form) "\306!\210\211A@)\211 \236A\211\204=\307\n!\203\n\2024\n9\2034\310\n!\211G\311U\2033 \312H)\f\204=\313\314\n\"\210\315\316\f\"*\207" [form x sym rx-syntax syntax name rx-check characterp symbol-name 1 0 error "Unknown rx syntax `%s'" format "\\s%c"] 4 (#$ . 16880)]) #@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 (#$ . 17260)]) #@65 Parse and produce code from FORM, which is `(category SYMBOL)'. (defalias 'rx-category #[(form) "\304!\210\211A@)\250\203\211A@)\202 \211A@)\n\236A\305\306 \")\207" [form x rx-categories char rx-check format "\\c%c"] 4 (#$ . 17472)]) #@59 Parse and produce code from FORM, which is `(eval FORM)'. (defalias 'rx-eval #[(form) "\303!\210\304\305\211A@)!\n\"\207" [form x rx-parent rx-check rx-form eval] 4 (#$ . 17723)]) #@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) "\304!\210@\305=\306\211A@) \")\207" [form rx-greedy-flag x rx-parent rx-check maximal-match rx-form] 4 (#$ . 17913)]) #@63 Parse and produce code from FORM, which is `(regexp STRING)'. (defalias 'rx-regexp #[(form) "\303!\210\304\211A@)\n\"\207" [form x rx-parent rx-check rx-group-if] 4 (#$ . 18285)]) #@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 (#$ . 18475)]) #@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 (#$ . 19140)]) #@8448 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 space and tab only. `graphic', `graph' matches graphic characters--everything except ASCII control chars, space, and DEL. `printing', `print' matches printing characters--everything except ASCII control chars and DEL. `alphanumeric', `alnum' matches letters and digits. (But at present, for multibyte characters, it matches anything that has word syntax.) `letter', `alphabetic', `alpha' matches letters. (But at present, for multibyte characters, it matches anything that has word syntax.) `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) `chinse-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 (#$ . 19432)])) (provide 'rx)