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/local/share/man/man3
Viewing File: /usr/local/share/man/man3/CDB_File.3pm
.\" Automatically generated by Pod::Man 4.11 (Pod::Simple 3.35) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is >0, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .nr rF 0 .if \n(.g .if rF .nr rF 1 .if (\n(rF:(\n(.g==0)) \{\ . if \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} . \} .\} .rr rF .\" ======================================================================== .\" .IX Title "CDB_File 3" .TH CDB_File 3 "2020-12-11" "perl v5.26.3" "User Contributed Perl Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "NAME" CDB_File \- Perl extension for access to cdb databases .SH "SYNOPSIS" .IX Header "SYNOPSIS" .Vb 2 \& use CDB_File; \& $c = tie(%h, \*(AqCDB_File\*(Aq, \*(Aqfile.cdb\*(Aq) or die "tie failed: $!\en"; \& \& # If accessing a utf8 stored CDB_File \& $c = tie(%h, \*(AqCDB_File\*(Aq, \*(Aqfile.cdb\*(Aq, utf8 => 1) or die "tie failed: $!\en"; \& \& $fh = $c\->handle; \& sysseek $fh, $c\->datapos, 0 or die ...; \& sysread $fh, $x, $c\->datalen; \& undef $c; \& untie %h; \& \& $t = CDB_File\->new(\*(Aqt.cdb\*(Aq, "t.$$") or die ...; \& $t\->insert(\*(Aqkey\*(Aq, \*(Aqvalue\*(Aq); \& $t\->finish; \& \& CDB_File::create %t, $file, "$file.$$"; .Ve .PP or .PP .Vb 2 \& use CDB_File \*(Aqcreate\*(Aq; \& create %t, $file, "$file.$$"; \& \& # If you want to store the data in utf8 mode. \& create %t, $file, "$file.$$", utf8 => 1; \&=head1 DESCRIPTION .Ve .PP \&\fBCDB_File\fR is a module which provides a Perl interface to Dan Bernstein's \fBcdb\fR package: .PP .Vb 2 \& cdb is a fast, reliable, lightweight package for creating and \& reading constant databases. .Ve .SS "Reading from a cdb" .IX Subsection "Reading from a cdb" After the \f(CW\*(C`tie\*(C'\fR shown above, accesses to \f(CW%h\fR will refer to the \fBcdb\fR file \f(CW\*(C`file.cdb\*(C'\fR, as described in \*(L"tie\*(R" in perlfunc. .PP Low level access to the database is provided by the three methods \&\f(CW\*(C`handle\*(C'\fR, \f(CW\*(C`datapos\*(C'\fR, and \f(CW\*(C`datalen\*(C'\fR. To use them, you must remember the \f(CW\*(C`CDB_File\*(C'\fR object returned by the \f(CW\*(C`tie\*(C'\fR call: \f(CW$c\fR in the example above. The \f(CW\*(C`datapos\*(C'\fR and \f(CW\*(C`datalen\*(C'\fR methods return the file offset position and length respectively of the most recently visited key (for example, via \f(CW\*(C`exists\*(C'\fR). .PP Beware that if you create an extra reference to the \f(CW\*(C`CDB_File\*(C'\fR object (like \f(CW$c\fR in the example above) you must destroy it (with \f(CW\*(C`undef\*(C'\fR) before calling \f(CW\*(C`untie\*(C'\fR on the hash. This ensures that the object's \&\f(CW\*(C`DESTROY\*(C'\fR method is called. Note that \f(CW\*(C`perl \-w\*(C'\fR will check this for you; see perltie for further details. .SS "Creating a cdb" .IX Subsection "Creating a cdb" A \fBcdb\fR file is created in three steps. First call \f(CW\*(C`new CDB_File ($final, $tmp)\*(C'\fR, where \f(CW$final\fR is the name of the database to be created, and \f(CW$tmp\fR is the name of a temporary file which can be atomically renamed to \f(CW$final\fR. Secondly, call the \f(CW\*(C`insert\*(C'\fR method once for each (\fIkey\fR, \fIvalue\fR) pair. Finally, call the \f(CW\*(C`finish\*(C'\fR method to complete the creation and renaming of the \fBcdb\fR file. .PP Alternatively, call the \f(CW\*(C`insert()\*(C'\fR method with multiple key/value pairs. This can be significantly faster because there is less crossing over the bridge from perl to C code. One simple way to do this is to pass in an entire hash, as in: \f(CW\*(C`$cdbmaker\->insert(%hash);\*(C'\fR. .PP A simpler interface to \fBcdb\fR file creation is provided by \&\f(CW\*(C`CDB_File::create %t, $final, $tmp\*(C'\fR. This creates a \fBcdb\fR file named \&\f(CW$final\fR containing the contents of \f(CW%t\fR. As before, \f(CW$tmp\fR must name a temporary file which can be atomically renamed to \f(CW$final\fR. \&\f(CW\*(C`CDB_File::create\*(C'\fR may be imported. .SS "\s-1UTF8\s0 support." .IX Subsection "UTF8 support." When CDB_File was created in 1997 (prior even to Perl 5.6), Perl SVs didn't really deal with \s-1UTF8.\s0 In order to properly store mixed bytes and utf8 data in the file, we would normally need to store a bit for each string which clarifies the encoding of the key / values. This would be useful since Perl hash keys are downgraded to bytes when possible so as to normalize the hash key access regardless of encoding. .PP The CDB_File format is used outside of Perl and so must maintain file format compatibility with those systems. As a result this module provides a utf8 mode which must be enabled at database generation and then later at read. Keys will always be stored as \s-1UTF8\s0 strings which is the opposite of how Perl stores the strings. This approach had to be taken to assure no data corruption happened due to accidentally downgraded SVs before they are stored or on retrieval. .PP You can enable utf8 mode by passing \f(CW\*(C`utf8 => 1\*(C'\fR to \fBnew\fR, \fBtie\fR, or \fBcreate\fR. All returned SVs while in this mode will be encoded in utf8. This feature is not available below 5.14 due to lack of Perl macro support. .PP \&\fB\s-1NOTE:\s0\fR read/write of databases not stored in utf8 mode will often be incompatible with any non-ascii data. .SH "EXAMPLES" .IX Header "EXAMPLES" These are all complete programs. .PP 1. Convert a Berkeley \s-1DB\s0 (B\-tree) database to \fBcdb\fR format. .PP .Vb 2 \& use CDB_File; \& use DB_File; \& \& tie %h, DB_File, $ARGV[0], O_RDONLY, undef, $DB_BTREE or \& die "$0: can\*(Aqt tie to $ARGV[0]: $!\en"; \& \& CDB_File::create %h, $ARGV[1], "$ARGV[1].$$" or \& die "$0: can\*(Aqt create cdb: $!\en"; .Ve .PP 2. Convert a flat file to \fBcdb\fR format. In this example, the flat file consists of one key per line, separated by a colon from the value. Blank lines and lines beginning with \fB#\fR are skipped. .PP .Vb 1 \& use CDB_File; \& \& $cdb = new CDB_File("data.cdb", "data.$$") or \& die "$0: new CDB_File failed: $!\en"; \& while (<>) { \& next if /^$/ or /^#/; \& chop; \& ($k, $v) = split /:/, $_, 2; \& if (defined $v) { \& $cdb\->insert($k, $v); \& } else { \& warn "bogus line: $_\en"; \& } \& } \& $cdb\->finish or die "$0: CDB_File finish failed: $!\en"; .Ve .PP 3. Perl version of \fBcdbdump\fR. .PP .Vb 1 \& use CDB_File; \& \& tie %data, \*(AqCDB_File\*(Aq, $ARGV[0] or \& die "$0: can\*(Aqt tie to $ARGV[0]: $!\en"; \& while (($k, $v) = each %data) { \& print \*(Aq+\*(Aq, length $k, \*(Aq,\*(Aq, length $v, ":$k\->$v\en"; \& } \& print "\en"; .Ve .PP 4. For really enormous data values, you can use \f(CW\*(C`handle\*(C'\fR, \f(CW\*(C`datapos\*(C'\fR, and \f(CW\*(C`datalen\*(C'\fR, in combination with \f(CW\*(C`sysseek\*(C'\fR and \f(CW\*(C`sysread\*(C'\fR, to avoid reading the values into memory. Here is the script \fIbun\-x.pl\fR, which can extract uncompressed files and directories from a \fBbun\fR file. .PP .Vb 1 \& use CDB_File; \& \& sub unnetstrings { \& my($netstrings) = @_; \& my @result; \& while ($netstrings =~ s/^([0\-9]+)://) { \& push @result, substr($netstrings, 0, $1, \*(Aq\*(Aq); \& $netstrings =~ s/^,//; \& } \& return @result; \& } \& \& my $chunk = 8192; \& \& sub extract { \& my($file, $t, $b) = @_; \& my $head = $$b{"H$file"}; \& my ($code, $type) = $head =~ m/^([0\-9]+)(.)/; \& if ($type eq "/") { \& mkdir $file, 0777; \& } elsif ($type eq "_") { \& my ($total, $now, $got, $x); \& open OUT, ">$file" or die "open for output: $!\en"; \& exists $$b{"D$code"} or die "corrupt bun file\en"; \& my $fh = $t\->handle; \& sysseek $fh, $t\->datapos, 0; \& $total = $t\->datalen; \& while ($total) { \& $now = ($total > $chunk) ? $chunk : $total; \& $got = sysread $fh, $x, $now; \& if (not $got) { die "read error\en"; } \& $total \-= $got; \& print OUT $x; \& } \& close OUT; \& } else { \& print STDERR "warning: skipping unknown file type\en"; \& } \& } \& \& die "usage\en" if @ARGV != 1; \& \& my (%b, $t); \& $t = tie %b, \*(AqCDB_File\*(Aq, $ARGV[0] or die "tie: $!\en"; \& map { extract $_, $t, \e%b } unnetstrings $b{""}; .Ve .PP 5. Although a \fBcdb\fR file is constant, you can simulate updating it in Perl. This is an expensive operation, as you have to create a new database, and copy into it everything that's unchanged from the old database. (As compensation, the update does not affect database readers. The old database is available for them, till the moment the new one is \f(CW\*(C`finish\*(C'\fRed.) .PP .Vb 1 \& use CDB_File; \& \& $file = \*(Aqdata.cdb\*(Aq; \& $new = new CDB_File($file, "$file.$$") or \& die "$0: new CDB_File failed: $!\en"; \& \& # Add the new values; remember which keys we\*(Aqve seen. \& while (<>) { \& chop; \& ($k, $v) = split; \& $new\->insert($k, $v); \& $seen{$k} = 1; \& } \& \& # Add any old values that haven\*(Aqt been replaced. \& tie %old, \*(AqCDB_File\*(Aq, $file or die "$0: can\*(Aqt tie to $file: $!\en"; \& while (($k, $v) = each %old) { \& $new\->insert($k, $v) unless $seen{$k}; \& } \& \& $new\->finish or die "$0: CDB_File finish failed: $!\en"; .Ve .SH "REPEATED KEYS" .IX Header "REPEATED KEYS" Most users can ignore this section. .PP A \fBcdb\fR file can contain repeated keys. If the \f(CW\*(C`insert\*(C'\fR method is called more than once with the same key during the creation of a \fBcdb\fR file, that key will be repeated. .PP Here's an example. .PP .Vb 4 \& $cdb = new CDB_File ("$file.cdb", "$file.$$") or die ...; \& $cdb\->insert(\*(Aqcat\*(Aq, \*(Aqgato\*(Aq); \& $cdb\->insert(\*(Aqcat\*(Aq, \*(Aqchat\*(Aq); \& $cdb\->finish; .Ve .PP Normally, any attempt to access a key retrieves the first value stored under that key. This code snippet always prints \fBgato\fR. .PP .Vb 2 \& $catref = tie %catalogue, CDB_File, "$file.cdb" or die ...; \& print "$catalogue{cat}"; .Ve .PP However, all the usual ways of iterating over a hash\-\-\-\f(CW\*(C`keys\*(C'\fR, \&\f(CW\*(C`values\*(C'\fR, and \f(CW\*(C`each\*(C'\fR\-\-\-do the Right Thing, even in the presence of repeated keys. This code snippet prints \fBcat cat gato chat\fR. .PP .Vb 1 \& print join(\*(Aq \*(Aq, keys %catalogue, values %catalogue); .Ve .PP And these two both print \fBcat:gato cat:chat\fR, although the second is more efficient. .PP .Vb 3 \& foreach $key (keys %catalogue) { \& print "$key:$catalogue{$key} "; \& } \& \& while (($key, $val) = each %catalogue) { \& print "$key:$val "; \& } .Ve .PP The \f(CW\*(C`multi_get\*(C'\fR method retrieves all the values associated with a key. It returns a reference to an array containing all the values. This code prints \fBgato chat\fR. .PP .Vb 1 \& print "@{$catref\->multi_get(\*(Aqcat\*(Aq)}"; .Ve .PP \&\f(CW\*(C`multi_get\*(C'\fR always returns an array reference. If the key was not found in the database, it will be a reference to an empty array. To test whether the key was found, you must test the array, and not the reference. .PP .Vb 3 \& $x = $catref\->multiget($key); \& warn "$key not found\en" unless $x; # WRONG; message never printed \& warn "$key not found\en" unless @$x; # Correct .Ve .PP The \f(CW\*(C`fetch_all\*(C'\fR method returns a hashref of all keys with the first value in the cdb. This is useful for quickly loading a cdb file where there is a 1:1 key mapping. In practice it proved to be about 400% faster then iterating a tied hash. .PP .Vb 2 \& # Slow \& my %copy = %tied_cdb; \& \& # Much Faster \& my $copy_hashref = $catref\->fetch_all(); .Ve .SH "RETURN VALUES" .IX Header "RETURN VALUES" The routines \f(CW\*(C`tie\*(C'\fR, \f(CW\*(C`new\*(C'\fR, and \f(CW\*(C`finish\*(C'\fR return \fBundef\fR if the attempted operation failed; \f(CW$!\fR contains the reason for failure. .SH "DIAGNOSTICS" .IX Header "DIAGNOSTICS" The following fatal errors may occur. (See \*(L"eval\*(R" in perlfunc if you want to trap them.) .IP "Modification of a CDB_File attempted" 4 .IX Item "Modification of a CDB_File attempted" You attempted to modify a hash tied to a \fBCDB_File\fR. .IP "\s-1CDB\s0 database too large" 4 .IX Item "CDB database too large" You attempted to create a \fBcdb\fR file larger than 4 gigabytes. .IP "[ Write to | Read of | Seek in ] CDB_File failed: <error string>" 4 .IX Item "[ Write to | Read of | Seek in ] CDB_File failed: <error string>" If \fBerror string\fR is \fBProtocol error\fR, you tried to \f(CW\*(C`use CDB_File\*(C'\fR to access something that isn't a \fBcdb\fR file. Otherwise a serious \s-1OS\s0 level problem occurred, for example, you have run out of disk space. .SH "PERFORMANCE" .IX Header "PERFORMANCE" Sometimes you need to get the most performance possible out of a library. Rumour has it that perl's \fBtie()\fR interface is slow. In order to get around that you can use CDB_File in an object oriented fashion, rather than via \fBtie()\fR. .PP .Vb 1 \& my $cdb = CDB_File\->TIEHASH(\*(Aq/path/to/cdbfile.cdb\*(Aq); \& \& if ($cdb\->EXISTS(\*(Aqkey\*(Aq)) { \& print "Key is: ", $cdb\->FETCH(\*(Aqkey\*(Aq), "\en"; \& } .Ve .PP For more information on the methods available on tied hashes see perltie. .SH "THE ALGORITHM" .IX Header "THE ALGORITHM" This algorithm is described at <http://cr.yp.to/cdb/cdb.txt> It is small enough that it is included inline in the event that the internet loses the page: .SS "A structure for constant databases" .IX Subsection "A structure for constant databases" Copyright (c) 1996 D. J. Bernstein, djb@pobox.com .PP A cdb is an associative array: it maps strings ('keys'') to strings ('data''). .PP A cdb contains 256 pointers to linearly probed open hash tables. The hash tables contain pointers to (key,data) pairs. A cdb is stored in a single file on disk: .PP .Vb 3 \& +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-+\-\-\-\-\-\-\-+\-\-\-\-\-+\-\-\-\-\-\-\-\-\-+ \& | p0 p1 ... p255 | records | hash0 | hash1 | ... | hash255 | \& +\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-\-\-+\-\-\-\-\-\-\-+\-\-\-\-\-\-\-+\-\-\-\-\-+\-\-\-\-\-\-\-\-\-+ .Ve .PP Each of the 256 initial pointers states a position and a length. The position is the starting byte position of the hash table. The length is the number of slots in the hash table. .PP Records are stored sequentially, without special alignment. A record states a key length, a data length, the key, and the data. .PP Each hash table slot states a hash value and a byte position. If the byte position is 0, the slot is empty. Otherwise, the slot points to a record whose key has that hash value. .PP Positions, lengths, and hash values are 32\-bit quantities, stored in little-endian form in 4 bytes. Thus a cdb must fit into 4 gigabytes. .PP A record is located as follows. Compute the hash value of the key in the record. The hash value modulo 256 is the number of a hash table. The hash value divided by 256, modulo the length of that table, is a slot number. Probe that slot, the next higher slot, and so on, until you find the record or run into an empty slot. .PP The cdb hash function is \f(CW\*(C`h = ((h << 5) + h) ^ c\*(C'\fR, with a starting hash of 5381. .SH "BUGS" .IX Header "BUGS" The \f(CW\*(C`create()\*(C'\fR interface could be done with \f(CW\*(C`TIEHASH\*(C'\fR. .SH "SEE ALSO" .IX Header "SEE ALSO" \&\fBcdb\fR\|(3) .SH "AUTHOR" .IX Header "AUTHOR" Tim Goodwin, <tjg@star.le.ac.uk>. \fBCDB_File\fR began on 1997\-01\-08. .PP Work provided through 2008 by Matt Sergeant, <matt@sergeant.org> .PP Now maintained by Todd Rinaldo, <toddr@cpan.org>