% % lgocyrac.mf % %% Cyrillic font container with T2 encoding beta-support % % This file is future part of lxfonts package % Version 3.4 // Patchlevel=1 % (c) O.Lapko % % This package belongs to the public domain under conditions similar to % those of D. E. Knuth specified for the Computer Modern family of fonts. % In particular, only the authors are entitled to modify this file % and to save it under the same name. % % Content: % % Old Slav Accents and Signs % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % List of accents & signs % % thousands % titlo % paerok % kamora % dasia % psili % zvat % pneuac % pneugr % accte % palatal (round titlo) % tlo_c % tlo_d % tlo_o % tlo_g % tlo_r % % tma % legion % leodr % vran % koloda % tmatem % LHver_check(3,4); % like |version_check| in ec lhchar "Cyrillic sign thousands"; % ss uses SlavTeX form cyrchar(thousands,if serifs:8u# else:7u# fi,x_height#,desc_depth#); adjust_fit(0,0); if serifs: pickup tiny.nib; %pickup crisp.nib; numeric bulb_diam,mid_thickness,stem[]; stem1=fudged.hair if hefty:-4stem_corr fi; bulb_diam=.7[vair,flare]; mid_thickness=vround if serifs:1/4 else: 1/3 fi[vair,stem]; x0=w-u; y0=vround .5bar_height; pos0(vair,90); lft x2r=u; bot y2=-.5d if serifs:+.25bulb_diam fi; pos2(vair,180); pos3(bulb_diam,180); cyrbulb(0,2,3); numeric theta; theta=-135; pos4(vair,theta); pos4'(vair,theta); pos5(vair,theta); pos5'(vair,theta); path thous_p; thous_p=z0{left}...z2{down}; z1'=((.3[x2r,x0],-d)--(.3[x2r,x0],h)) intersectionpoint thous_p; z2'=((.75[x2r,x0],-d)--(.75[x2r,x0],h)) intersectionpoint thous_p; z4 =z1'+1.5u*dir(theta-90); z4'=z1'-1.5u*dir(theta-90); z5 =z2'+1.5u*dir(theta-90); z5'=z2'-1.5u*dir(theta-90); filldraw stroke z4e--z4'e; filldraw stroke z5e--z5'e; else: pickup fine.nib; numeric middle_weight,theta,stem[]; middle_weight=max(fine.breadth,.6[thin_join,vair]); stem1=1/3[max(fine.breadth,.6[thin_join,vair]),stem]; theta=angle(1/2(w-fine-max(u,.5u+.5stem1)-stem1),d); z0=(w/2,0); z1=z0+5u*dir(theta); z2=z0-5u*dir(theta); if y2<-d: y2:=-d; y1:=2y0-y2; fi pos1(stem1,theta-90); pos2(stem1,theta-90); filldraw stroke z1e--z2e; z3=z0+min(2u,.5(x0-x2))*dir(theta)+2u*dir(theta-90); z4=z0+min(2u,.5(x0-x2))*dir(theta)-2u*dir(theta-90); z5=z0-min(2u,.5(x0-x2))*dir(theta)+2u*dir(theta-90); z6=z0-min(2u,.5(x0-x2))*dir(theta)-2u*dir(theta-90); pos3(middle_weight,theta); pos4(middle_weight,theta); pos5(middle_weight,theta); pos6(middle_weight,theta); filldraw stroke z3e--z4e; filldraw stroke z5e--z6e; fi penlabels(0,1,1',2,2',3,4,4',5,5',6); endchar; lhchar "Cyrillic accent titlo"; cyrchar(titlo,8u#,x_height#+acc_height#,0); italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); x1=.5w; % low_titlo (1); _zero:=1; _one:=2; _two:=3; _three:=4; _four:=5; _five:=6; _six:=7; % pickup fine.nib; numeric stem[]; stem0=if serifs: .8[hair,stem] else: fudged.hair-4stem_corr fi; pos[_one](stem0,0); pos[_two](stem0,0); pos[_three](stem0,0); pos[_four](stem0,0); numeric middle_weight; middle_weight=if serifs: vair else: max(fine.breadth,.6[thin_join,vair]) fi; pos[_five](middle_weight,90); pos[_six](middle_weight,90); lft x[_one]l=lft x[_two]l=x[_zero]-hround(2.75u+.5stem0); rt x[_four]r=rt x[_three]r=x[_zero]+hround(2.75u+.5stem0); x[_five]=x[_one]r; x[_six]=x[_three]l; top y[_five]r=top y[_one]; bot y[_six]l=bot y[_four]; top y[_three]=h+o; bot y[_two]=if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5crisp else: vround 2/3[x_height+acc_height,x_height] fi; y[_one]=5/6[y[_two],y[_three]]; y[_four]=1/6[y[_two],y[_three]]; filldraw stroke z[_five]e--z[_six]e; % bar filldraw stroke z[_one]e--z[_two]e; filldraw stroke z[_three]e--z[_four]e; % stems %%% endchar; lhchar "Cyrillic accent paerok - vertical tilde"; cyrchar(paerok,5u#,asc_height#,0);%Apostrophe height italcorr asc_height#*slant+.5pdot_diam#-2u#;%Apostrophe adjust_fit(if monospace: u#,u# else: 0,0 fi); pickup if serifs: crisp.nib; if not monospace: if vair#>.8curve#: pickup rule.nib; autorounded; fi fi else: fine.nib; fi numeric stem[]; stem1=max(currentbreadth+eps,if serifs: .7 rule_thickness else:1/3[thin_join,vair] fi); stem2=max(currentbreadth+eps,if serifs:1.4 rule_thickness else:vair fi); theta:=30; x1=hround(.5w-1.25u if monospace: /expansion_factor fi)-eps; x3=hround(.5w+1.25u if monospace: /expansion_factor fi)+eps; bot y1r=good.y(asc_height-comma_depth-pdot_diam)-eps; top y3l=h+oo+eps; z2=1/2[z1,z3]; pos1(stem1,theta-90); pos3(stem1,theta-90); pos2(stem2,theta); filldraw stroke z1e{dir theta}..{dir(theta+90)}z2e..{dir theta}z3e; penlabels(1,2,3); endchar; lhchar "Cyrillic accent kamora"; cyrchar(kamora,9u#,x_height#+acc_height#,0); italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); %!!! lowercase_breve flipped x_center:=.5w; y_move:=0; _one:=1; _two:=2; _three:=3; % numeric stem[]; stem1=if serifs:vround (1/3[vair,stem]) else: .6[thin_join,vair] fi; stem2=stem1; pickup if serifs: crisp else: fine fi nib; pos[_one](stem1,180); pos[_three](stem1,0); top y[_two]r=h+oo+eps; x[_two]=x_center; %!!!v lft x[_one]r=hround(x[_two]-if serifs: 2 else: 1.5 fi u%narrower frown if monospace: /expansion_factor fi -0.5stem1); rt x[_three]r=hround(x[_two]+if serifs: 2 else: 1.5 fi u%narrower frown if monospace: /expansion_factor fi +0.5stem1); bot y[_one]=bot y[_three]= %!!! if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5crisp else: vround 2/3[x_height+acc_height,x_height] fi; if y[_two]r<(y[_one]+.5if serifs: crisp else: fine fi+eps): %!!! y[_two]r:=y[_one]+.5if serifs: crisp else: fine fi+eps; fi %!!! pos[_two](stem2,90); %!!! moved here after if filldraw stroke z[_one]e{((x[_one]r-x[_three]r),3acc_height)}... z[_two]e{right}...{((x[_one]r-x[_three]r),-3acc_height)}z[_three]e; % stroke % penlabels(1,2,3); endchar; lhchar "Cyrillic accent dasia pneumata"; cyrchar(dasia,9u#,min(asc_height#,2x_height#),0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); pickup if serifs: crisp else: fine fi nib; numeric bulb_diam,stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs:vround (1/4[vair,stem]) else: vair fi; if serifs: bulb_diam=max(currentbreadth+eps,min(flare,3u-vair-1-eps)); lft x0r=hround (.5w-1.25u if monospace: /expansion_factor fi -0.5stem1); bot y0=if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5crisp else: vround 2/3[x_height+acc_height,x_height] fi; pos0(stem1,180); x1=.5w; top y1r=h+o; pos1(stem2,90); y2=if hefty: y0 if monospace:+.5bulb_diam-.5currentbreadth fi else: min(bot y0+7/8bulb_diam,top y1r-currentbreadth-eps) fi; rt x2r=hround (.5w+2u if monospace: /expansion_factor fi); pos2(stem1,0); pos3(bulb_diam,0); cyrbulb(1,2,3); if y1r<(y2+.5currentbreadth+eps): y1r:=y2+.5currentbreadth+eps; fi filldraw stroke z0e{(3(x0-x2),acc_height)}...{right}z1e; else: % zvat!!!; x_center:=.5w-.5u; _one:=1; _two:=2; _three:=3; % theta:=45; z[_one]=(x_center-1.15u,.55[y[_three],h]); z[_two]=(x_center+1.15u,4/5[y[_three],h]); bot z[_three]r=(x_center+.65u, if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair) -.5 if serifs: crisp else: fine fi else: vround 2/3[x_height+acc_height,x_height] fi); pos[_one](stem1,theta+90); pos[_two](stem2,theta); pos[_three](stem1,theta-90); filldraw stroke z[_one]e{dir(theta+45)} ..{dir(theta-90)}z[_two]e..{dir(theta+180)}z[_three]e; % stroke fi endchar; lhchar "Cyrillic accent psili pneumata"; cyrchar(psili,9u#,min(asc_height#,2x_height#),0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); pickup if serifs: crisp else: fine fi nib; numeric bulb_diam,stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=vround if serifs:(1/4[vair,stem]) else: vair fi; if serifs: bulb_diam=max(currentbreadth+eps,min(flare,3u-vair-1-eps)); rt x0r=hround (.5w+1.25u if monospace: /expansion_factor fi +0.5stem1); bot y0=if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5crisp else: vround 2/3[x_height+acc_height,x_height] fi; pos0(stem1,0); x1=.5w; top y1r=h+o; pos1(stem2,90); y2=if hefty: y0 if monospace:+.5bulb_diam-.5currentbreadth fi else: min(bot y0+7/8bulb_diam,top y1r-currentbreadth-eps) fi; lft x2r=hround (.5w- 2u if monospace: /expansion_factor fi); pos2(stem1,180); pos3(bulb_diam,180); cyrbulb(1,2,3); if y1r<(y2+.5currentbreadth+eps): y1r:=y2+.5currentbreadth+eps; fi filldraw stroke z0e{(3(x0-x2),acc_height)}...{left}z1e; else: % zvat!!!; x_center:=.5w-.5u; _one:=1; _two:=2; _three:=3; % theta:=135; z[_one]=(x_center+1.15u,.55[y[_three],h]); z[_two]=(x_center-1.15u,4/5[y[_three],h]); bot z[_three]r=(x_center-.65u, if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair) -.5 if serifs: crisp else: fine fi else: vround 2/3[x_height+acc_height,x_height] fi); pos[_one](stem1,theta-90); pos[_two](stem2,theta); pos[_three](stem1,theta+90); filldraw stroke z[_one]e{dir(theta-45)} ..{dir(theta+90)}z[_two]e..{dir(theta-180)}z[_three]e; % stroke fi endchar; lhchar "Cyrillic zvatel'stvo accent"; cyrchar(zvat,9u#,min(asc_height#,2x_height#),0);%height enlarged italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); pickup if serifs: crisp else: fine fi nib; % zvat; x_center:=.5w-.5u; _one:=1; _two:=2; _three:=3; % numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs:vround (1/3[vair,stem]) else: vair fi; theta:=45; z[_one]=(x_center-u,.55[y[_three],h]); z[_two]=(x_center+u,4/5[y[_three],h]); bot z[_three]r=(x_center+.5u, if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair) -.5 if serifs: crisp else: fine fi else: vround 2/3[x_height+acc_height,x_height] fi); pos[_one](stem1,theta+90); pos[_two](stem2,theta); pos[_three](stem1,theta-90); filldraw stroke z[_one]e{dir(theta+45)} ..{dir(theta-90)}z[_two]e..{dir(theta+180)}z[_three]e; % stroke % penlabels(1,2,3); endchar; lhchar "Cyrillic accent pneuac - pneumata acute"; cyrchar(pneuac,9u#,min(asc_height#,2x_height#),0); italcorr asc_height#*slant+.5dot_size#-2u#; adjust_fit(0,0); old_u:=u; u:=.75u; % classic acute if serifs: pickup crisp.nib; x1+.5fudged.stem=hround(w-2u)+x_move; x2=2/3[x1,w+x_move-x1+(w+x_move-9u)]; y1+.5fudged.stem=h+eps; y2=max(2/3[x_height+acc_height,x_height],x_height+o+hair); numeric theta; theta=angle(z2-z1)+90; pos1(fudged.stem,theta); pos2(min(fudged.stem,hair),theta); filldraw circ_stroke z1e--z2e; % diagonal else: pickup fine.nib; pos1(fudged.stem,0); pos2(vair,0); rt x1r=hround(w-1.5u)+x_move; lft x2l=hround(.5[w+x_move-9u,w+x_move]-.25u-.5vair); top y1=h; bot y2=vround 2/3[x_height+acc_height,x_height]; filldraw stroke z1e--z2e; fi % diagonal u:=old_u; % zvat; x_center:=.5w-1.5u; _one:=3; _two:=4; _three:=5; % numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs:vround (1/3[vair,stem]) else: vair fi; theta:=45; z[_one]=(x_center-u,.55[y[_three],h]); z[_two]=(x_center+u,4/5[y[_three],h]); bot z[_three]r=(x_center+.5u, if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair) -.5 if serifs: crisp else: fine fi else: vround 2/3[x_height+acc_height,x_height] fi); pos[_one](stem1,theta+90); pos[_two](stem2,theta); pos[_three](stem1,theta-90); filldraw stroke z[_one]e{dir(theta+45)} ..{dir(theta-90)}z[_two]e..{dir(theta+180)}z[_three]e; % stroke % penlabels(1,2,3,4,5); endchar; lhchar "Cyrillic accent pneugr - pneumata grave"; cyrchar(pneugr,9u#,min(asc_height#,2x_height#),0); italcorr asc_height#*slant+.5dot_size#-2u#; adjust_fit(0,0); old_u:=u; u:=.75u; x_move:=if monospace:2u else: 2.5u fi; % classic gravis if serifs: pickup crisp.nib; x1-.5fudged.stem=hround 2u+(w-9u)+x_move; x2=2/3[x1,w+x_move-x1+(w+x_move-9u)]; y1+.5fudged.stem=h+eps; y2=max(2/3[x_height+acc_height,x_height],x_height+o+hair); numeric theta; theta=angle(z2-z1)+90; pos1(fudged.stem,theta); pos2(min(fudged.stem,hair),theta); filldraw circ_stroke z1e--z2e; % diagonal else: pickup fine.nib; pos1(fudged.stem,0); pos2(vair,0); lft x1l=hround 1.5u+(w-9u)+x_move; rt x2r=hround(.5[w+x_move-9u,w+x_move]+.25u+.5vair); top y1=h; bot y2=vround 2/3[x_height+acc_height,x_height]; filldraw stroke z1e--z2e; fi % diagonal u:=old_u; % zvat; x_center:=.5w-1.5u; _one:=3; _two:=4; _three:=5; % numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs:vround (1/3[vair,stem]) else: vair fi; theta:=45; z[_one]=(x_center-u,.55[y[_three],h]); z[_two]=(x_center+u,4/5[y[_three],h]); bot z[_three]r=(x_center+.5u, if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair) -.5 if serifs: crisp else: fine fi else: vround 2/3[x_height+acc_height,x_height] fi); pos[_one](stem1,theta+90); pos[_two](stem2,theta); pos[_three](stem1,theta-90); filldraw stroke z[_one]e{dir(theta+45)} ..{dir(theta-90)}z[_two]e..{dir(theta+180)}z[_three]e; % stroke % penlabels(1,2,3,4,5); endchar; lhchar "Cyrillic accent accte - accent te"; cyrchar(accte,8u#,x_height#+acc_height#,0); italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); h:=x_height; % low_te(0); _zero:=0; x0=.5w; _one:=1; _two:=2; _three:=3; _four:=4; _five:=5; % if serifs: pickup crisp.nib; else: pickup pencircle scaled min(.5fine,.15vair); fi numeric stem[]; stem1=if hefty: fudged.hair-2stem_corr else: .7[vair,stem] fi; stem2=if serifs: vair else: max(currentbreadth+eps,.6[thin_join,vair]) fi; stem3=min(stem1,if serifs: hair else: max(currentbreadth+eps,7/8[thin_join,vair]) fi); pos[_one](stem1,0); pos[_two](stem1,0); lft x[_one]l=lft x[_two]l=hround(x[_zero]-.5stem1); numeric mid_thickness; mid_thickness=vround if serifs:1/4 else: 1/3 fi[vair,stem]; bot y[_two]=bot y[_four]=bot y[_five]= vround max(h+o+max(tiny,.5mid_thickness),1/3[h,h+acc_height]+o-.5mid_thickness); top y[_one]=top y[_three]r=max(h+acc_height,bot y[_two]+1.5vair); filldraw stroke z[_one]e--z[_two]e; % stem pos[_three](stem2,90); pos[_four](stem3,0); pos[_five](stem3,180); x[_three]=x[_one]; rt x[_four]r=hround(x[_zero]+2.5u if monospace:/expansion_factor fi+.5vair); x[_four]-x[_three]=x[_three]-x[_five]; z[_four]'=beak_darkness[(x[_four]l,y[_three]l), .5[(x[_one]r,y[_three]l),z[_four]l] ]; z[_five]'=beak_darkness[(x[_five]l,y[_three]l), .5[(x[_one]l,y[_three]l),z[_five]l] ]; filldraw z[_four]r--z[_four]l{up}...z[_four]' ...{left}(x[_one]r,y[_three]l)--(x[_one]r,y[_three]l){left}...z[_five]' ...{down}z[_five]l--z[_five]r--- (x[_five]r,y[_three]r)---(x[_four]r,y[_three]r)---cycle; %%% endchar; lhchar "Cyrillic accent palatalization (round titlo)"; cyrchar(palatal,10u#,x_height#+acc_height#,0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); % low_palatal; x_center:=.5w-.25u; x_move:=0; y_move:=-o; _one:=1; _two:=2; _three:=3; _four:=4; % pickup fine.nib; numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs: .8[hair,stem] else: 1/3[vair,hair] fi; pos[_one](stem2,180); pos[_three](1/5[stem2,stem1],0); pos[_two](stem1,90); pos[_four](stem1,90); top y[_two]r=h+o; x[_two]=x_center; rt x[_one]l =hround(x[_two]-3.5u if monospace: /expansion_factor fi +.5stem2); lft x[_three]l=hround(x[_two]+3.5u if monospace: /expansion_factor fi -.5stem2); bot y[_one]=bot y[_three]= if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5fine else: vround 2/3[x_height+acc_height,x_height] fi; bot y[_four]l=x_height+o; x[_four]=w+eps; forsuffixes e=l,r: path p; p=z[_two]e{right}...{(x[_three]-x[_one]),-7acc_height}z[_three]e; z[_three]'e=point .8 of p; endfor filldraw stroke z[_one]e{(x[_three]-x[_one]),7acc_height}... z[_two]e{right}... {direction .8 of p}z[_three]'e...{right}z[_four]e; % stroke %%% penlabels(1,2,3,4); endchar; lhchar "Cyrillic accent titlo with letter c"; cyrchar(tlo_c,10u#,min(asc_height#,2x_height#),0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); full_h:=h; h:=x_height+acc_height; % low_palatal; x_center:=.5w-.25u; x_move:=0; y_move:=full_h-h; _one:=1; _two:=2; _three:=3; _four:=4; % pickup fine.nib; numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs: .8[hair,stem] else: 1/3[vair,hair] fi; pos[_one](stem2,180); pos[_three](1/5[stem2,stem1],0); pos[_two](stem1,90); pos[_four](stem1,90); top y[_two]r=h+o+y_move; x[_two]=x_center; rt x[_one]l =hround(x[_two]-3.5u if monospace: /expansion_factor fi +.5stem2); lft x[_three]l=hround(x[_two]+3.5u if monospace: /expansion_factor fi -.5stem2); bot y[_one]=bot y[_three]= if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5fine else: vround 2/3[x_height+acc_height,x_height] fi+y_move; bot y[_four]l=x_height+o+y_move; x[_four]=w+eps; forsuffixes e=l,r: path p; p=z[_two]e{right}...{(x[_three]-x[_one]),-7acc_height}z[_three]e; z[_three]'e=point .8 of p; endfor filldraw stroke z[_one]e{(x[_three]-x[_one]),7acc_height}... z[_two]e{right}... {direction .8 of p}z[_three]'e...{right}z[_four]e; % stroke %%% %tlo_c begingroup stem2:=1/3[hair,fudged.stem]; if not serifs: stem2:=max(fine.breadth,1/2[thin_join,vair]); stem1:=max(fine.breadth,thin_join); fi save curve; curve:=stem2; if not serifs: save vair,flare; vair:=stem1; flare:=1/3[stem1,stem2]; fi numeric hh,ll,rr; hh=min(acc_height,bot y[_two]l-x_height)-o-oo-eps; y_move:=x_height+oo; old_u:=u; u:=u*(acc_height/x_height); ll=hround(.5w-5.25u); rr=hround(.5w+3.25u); clearxy; % if serifs: pickup fine.nib; pos1(hair,0); pos2(vair,90); pos3(curve,180); pos4(vair',270); pos5(hair,360); rt x1r=rt x5r=hround(rr-u); lft x3r=hround(ll+u); x2=x4=.55[x3,x1]; top y2r=hh+oo+y_move; bot y4r=o+y_move; y3=.5[y2,y4]; bot y1=min(vround max(.65hh,.75hh-.5vair),bot y2l-eps)+y_move; y5=max(good.y (.95(hh-y1)+y_move),y4l+eps-y_move)+y_move; (x2l',y2l)=whatever[z2r,z1l]; x2l:=min(x2l',x2l+.5u); (x4l',y4l)=whatever[z4r,z5l]; x4l:=min(x4l',x4l+.5u); filldraw stroke z1e{x2-x1,10(y2-y1)} ...pulled_arc.e(2,3) & pulled_arc.e(3,4)...{up}z5e; % arc pos6(.3[fine.breadth,cap_hair],0); x6r=x1r; top y6=hh+oo+y_move; x1r-x1'=2cap_curve-fine; y1'=y1; path upper_arc; upper_arc=z1{x2-x1,10(y2-y1)}..z2{left}; numeric t; t=xpart(upper_arc intersectiontimes (z6l--z1')); filldraw z1r--z6r--z6l--subpath(t,0) of upper_arc--cycle; % barb else: pickup fine.nib; pos1(flare,80); pos2(vair,90); pos3(curve,180); pos4(vair,270); pos5(flare,275); rt x1r=hround(rr-1.1u); x2=x4=.55[x3,x1]; lft x3r=ll+hround max(u,2u-.5cap_curve); rt x5r=hround(rr-.9u); top y1r=vround .9hh+oo+y_move; top y2r=hh+oo+y_move; y3=.5hh+y_move; bot y4r=o+y_move+eps; bot y5r=vround .15[oo,hh]+y_move; y5l:=good.y y5l; x5l:=good.x x5l; filldraw stroke rterm.e(2,1,right,.9,4) & super_arc.e(2,3) & super_arc.e(3,4) & term.e(4,5,right,.8,4); fi % arc and terminals endgroup; penlabels(1,2,3,4); endchar; lhchar "Cyrillic accent titlo with letter d"; cyrchar(tlo_d,10u#,min(asc_height#,2x_height#),0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); full_h:=h; h:=x_height+acc_height; % low_palatal; x_center:=.5w-.25u; x_move:=0; y_move:=full_h-h;%!!! _one:=1; _two:=2; _three:=3; _four:=4; % pickup fine.nib; numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs: .8[hair,stem] else: 1/3[vair,hair] fi; pos[_one](stem2,180); pos[_three](1/5[stem2,stem1],0); pos[_two](stem1,90); pos[_four](stem1,90); top y[_two]r=h+o+y_move; x[_two]=x_center; rt x[_one]l =hround(x[_two]-3.5u if monospace: /expansion_factor fi +.5stem2); lft x[_three]l=hround(x[_two]+3.5u if monospace: /expansion_factor fi -.5stem2); bot y[_one]=bot y[_three]= if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5fine else: vround 2/3[x_height+acc_height,x_height] fi+y_move;%!!! bot y[_four]l=min(bot y[_one]-.5y_move,x_height+o+.5y_move)-eps; x[_four]=w+eps; forsuffixes e=l,r: path p; p=z[_two]e{right}...{(x[_three]-x[_one]),-7acc_height}z[_three]e; z[_three]'e=point .8 of p; endfor filldraw stroke z[_one]e{(x[_three]-x[_one]),7acc_height}... z[_two]e{right}... {direction .8 of p}z[_three]'e...{right}z[_four]e; % stroke %%% %tlo_d stem2:=1/3[hair,fudged.stem]; if not serifs: stem2:=max(fine.breadth,1/2[thin_join,vair]); stem1:=max(fine.breadth,thin_join); fi pos5(stem2,90); pos6(stem2,90); pos5'(stem1,90); pos7(stem1,-15); pos8(stem1,0); bot y5'l=bot y[_four]l; top y5r=top y6r=top y5'r; z8l=z[_three]'l; x8-x[_four]=x7-x8; bot y7=bot y[_four]l; rt x6=rt x[_four]+eps; lft x5=lft x7l-eps; x5'=.5[x5,x6]; filldraw stroke z7e..{dir75}z8e; filldraw z6r--z5r--z5l{up}...z5'l...{down}z6l--cycle; penlabels(1,2,3,4); endchar; lhchar "Cyrillic accent titlo with letter o"; cyrchar(tlo_o,10u#,min(asc_height#,2x_height#),0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); full_h:=h; h:=x_height+acc_height; % low_palatal; x_center:=.5w-.25u; x_move:=0; y_move:=full_h-h; _one:=1; _two:=2; _three:=3; _four:=4; % pickup fine.nib; numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs: .8[hair,stem] else: 1/3[vair,hair] fi; pos[_one](stem2,180); pos[_three](1/5[stem2,stem1],0); pos[_two](stem1,90); pos[_four](stem1,90); top y[_two]r=h+o+y_move; x[_two]=x_center; rt x[_one]l =hround(x[_two]-3.5u if monospace: /expansion_factor fi +.5stem2); lft x[_three]l=hround(x[_two]+3.5u if monospace: /expansion_factor fi -.5stem2); bot y[_one]=bot y[_three]= if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5fine else: vround 2/3[x_height+acc_height,x_height] fi+y_move; bot y[_four]l=x_height+o+y_move; x[_four]=w+eps; forsuffixes e=l,r: path p; p=z[_two]e{right}...{(x[_three]-x[_one]),-7acc_height}z[_three]e; z[_three]'e=point .8 of p; endfor filldraw stroke z[_one]e{(x[_three]-x[_one]),7acc_height}... z[_two]e{right}... {direction .8 of p}z[_three]'e...{right}z[_four]e; % stroke %%% %tlo_o begingroup stem2:=1/3[hair,fudged.stem]; if not serifs: stem2:=max(fine.breadth,1/2[thin_join,vair]); stem1:=max(fine.breadth,thin_join); fi save curve; curve:=stem2; if not serifs: save vair; vair:=stem1; fi numeric hh,ll,rr; hh=min(acc_height,bot y[_two]l-x_height)-o-oo-eps; y_move:=x_height+oo; old_u:=u; u:=u*(acc_height/x_height); ll=hround(.5w-4.5u); rr=hround(.5w+3u); clearxy; % penpos1(vair,90); penpos3(vair,-90); penpos2(curve,180); penpos4(curve,0); x2r=hround max(ll+.5u,ll+1.25u-.5curve); x4r=rr-(ll-x2r); x1=x3=.5[x2r,x4r]; y1r=hh+oo+y_move; y3r=o+y_move+eps; y2=y4=.5[o,hh]-.5vair_corr+y_move; y2l:=y4l:=.52[o,hh]+y_move; penstroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) & pulled_arc.e(4,1) & cycle; % bowl endgroup; penlabels(1,2,3,4); endchar; lhchar "Cyrillic accent titlo with letter g"; cyrchar(tlo_g,10u#,min(asc_height#,2x_height#),0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); full_h:=h; h:=x_height+acc_height; % low_palatal; x_center:=.5w-.25u; x_move:=0; y_move:=full_h-h; _one:=1; _two:=2; _three:=3; _four:=4; % pickup fine.nib; numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs: .8[hair,stem] else: 1/3[vair,hair] fi; pos[_one](stem2,180); pos[_three](1/5[stem2,stem1],0); pos[_two](stem1,90); pos[_four](stem1,90); top y[_two]r=h+o+y_move; x[_two]=x_center; rt x[_one]l =hround(x[_two]-3.5u if monospace: /expansion_factor fi +.5stem2); lft x[_three]l=hround(x[_two]+3.5u if monospace: /expansion_factor fi -.5stem2); bot y[_one]=bot y[_three]= if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5fine else: vround 2/3[x_height+acc_height,x_height] fi+y_move; bot y[_four]l=x_height+o+y_move; x[_four]=w+eps; forsuffixes e=l,r: path p; p=z[_two]e{right}...{(x[_three]-x[_one]),-7acc_height}z[_three]e; z[_three]'e=point .8 of p; endfor filldraw stroke z[_one]e{(x[_three]-x[_one]),7acc_height}... z[_two]e{right}... {direction .8 of p}z[_three]'e...{right}z[_four]e; % stroke %%% %tlo_g begingroup stem2:=1/3[hair,fudged.stem]; if not serifs: stem2:=max(fine.breadth,1/2[thin_join,vair]); stem1:=max(fine.breadth,thin_join); fi if not serifs: save vair,hair; vair:=stem1; hair:=stem1; fi numeric hh,ll,rr; hh=min(acc_height,bot y[_two]l-x_height)-o-oo-eps; y_move:=x_height+oo; old_u:=u; u:=u*(acc_height/x_height); ll=hround(.5w-4u); rr=hround(.5w+3u); clearxy; % pickup if serifs: tiny else: fine fi nib; pos1(stem2,0); pos2(stem2,0); lft x1l=lft x2l=hround (ll+2.5u-.5stem2); top y1=hh+y_move; bot y2=o+y_move+eps; filldraw stroke z1e--z2e; % stem pickup if serifs: crisp else: fine fi nib; pos3(vair,90); pos4(vair,0); top y3r=hh+y_move; x3=x1; rt x4r=hround(rr-.45u); y4=good.y(y3l-if serifs: .15 fi beak)-eps; arm(3,4,e,beak_darkness,.2beak_jut); % upper arm and beak if serifs: save slab; slab:=max(crisp.breadth,Vround(vair-2vair_corr)); % lower.slab nodish_serif(1,2,a,1/3,.2jut,b,1/3,.1jut); % upper serif slab:=vair; % lower.slab dish_serif(2,1,c,1/3,.2jut,d,1/3,.2jut); fi % lower serif endgroup; penlabels(1,2,3,4); endchar; lhchar "Cyrillic accent titlo with letter r"; cyrchar(tlo_r,10u#,min(asc_height#,2x_height#),0); % italcorr h#*slant+.5vair#-1.5u#; adjust_fit(0,0); full_h:=h; h:=x_height+acc_height; % low_palatal; x_center:=.5w-.25u; x_move:=0; y_move:=full_h-h; _one:=1; _two:=2; _three:=3; _four:=4; % pickup fine.nib; numeric stem[]; stem1=if serifs: vair else: max(currentbreadth+eps,1/3[thin_join,vair]) fi; stem2=if serifs: .8[hair,stem] else: 1/3[vair,hair] fi; pos[_one](stem2,180); pos[_three](1/5[stem2,stem1],0); pos[_two](stem1,90); pos[_four](stem1,90); top y[_two]r=h+o+y_move; x[_two]=x_center; rt x[_one]l =hround(x[_two]-3.5u if monospace: /expansion_factor fi +.5stem2); lft x[_three]l=hround(x[_two]+3.5u if monospace: /expansion_factor fi -.5stem2); bot y[_one]=bot y[_three]= if serifs: max(2/3[x_height+acc_height,x_height],x_height+o+hair)-.5fine else: vround 2/3[x_height+acc_height,x_height] fi+y_move; bot y[_four]l=x_height+o+y_move; x[_four]=w+eps; forsuffixes e=l,r: path p; p=z[_two]e{right}...{(x[_three]-x[_one]),-7acc_height}z[_three]e; z[_three]'e=point .8 of p; endfor filldraw stroke z[_one]e{(x[_three]-x[_one]),7acc_height}... z[_two]e{right}... {direction .8 of p}z[_three]'e...{right}z[_four]e; % stroke %%% %tlo_r begingroup stem2:=1/3[hair,fudged.stem]; if not serifs: stem2:=max(fine.breadth,1/2[thin_join,vair]); stem1:=max(fine.breadth,thin_join); fi save curve; curve:=stem2; if not serifs: save vair,hair; vair:=stem1; hair:=stem1; fi numeric hh,ll,rr,dd; hh=min(acc_height,bot y[_two]l-x_height)-o-oo-eps; dd:=d*(acc_height/x_height); y_move:=x_height+oo; old_u:=u; u:=u*(acc_height/x_height); ll=hround(.5w-4.75u); rr=hround(.5w+3.25u); clearxy; % pickup if serifs: tiny else: fine fi nib; pos2(stem2,0); pos3'(stem2,0); lft x2l=hround(ll+2.5u-.5stem2); bot y2=o+y_move+eps; y3'=min(hh+1.5oo+y_move-vair-eps,1/3[.55hh,hh]+y_move); rt x3'r=rt x2r; z3'=z3; filldraw stroke z2e--z3'e; %stem pickup fine.nib; pos3(stem2,180); pos4(vair,90); pos5(curve,0); pos6(vair,-90); pos7(if hefty: thin_join else: hair fi,-180); numeric edge; edge=rt x2r; x4l=rr-(.5(rr-ll)-.25serif_fit)+.5u; top y4r=hh+1.5oo+y_move; rt x5r=hround min(rr-1.35u+.5curve,rr-.6u); y5=.25[hh,oo]+y_move; x6l=x4l-.2u; bot y6r=max(.4[oo,hh],.45[oo,hh]-oo)+y_move; rt x7l=tiny.rt x2r; y7=min(y3,y6+y4-y3); (x,y4r)=whatever[z3l,z4l]; x4r:=min(x,.5[x5r,x4]); (x',y6r)=whatever[z7l,z6l]; x6r:=min(x',.5[x5r,x6]); filldraw stroke z3e{up}...{right}z4e&super_arc.e(4,5) &super_arc.e(5,6)&z6e{left}...{up}z7e; % bowl if serifs: save slab; slab:=max(crisp.breadth,Vround(vair-2vair_corr)); % lower.slab dish_serif(2,3',b,1/3,.2jut,c,1/3,.2jut); fi % lower serif endgroup; penlabels(1,2,3,4); endchar; % % Number symbols % lhchar"Cyrillic Tma number symbol"; cyrchar(tma,20u#,body_height#,max(paren_depth#,desc_depth#)); autorounded; adjust_fit(if monospace:-3u#,-3u# else: 0,0 fi); pickup rule.nib; if .5w <> good.x .5w: change_width; fi lft x6=hround u; x2=w-x6; top y8=h+o; bot y4=-d-o; circle_points; draw_circle; % circle penlabels(1,2,3,4,5,6,7,8); endchar; lhchar"Cyrillic Legion number symbol"; cyrchar(legion,20u#,body_height#,max(paren_depth#,desc_depth#)); autorounded; adjust_fit(if monospace:-3u#,-3u# else: 0,0 fi); pickup rule.nib; if .5w <> good.x .5w: change_width; fi lft x6=hround u; x2=w-x6; top y8=h+o; bot y4=-d-o; circle_points; %draw_circle; % circle pickup pencircle scaled .5rule_thickness; def temp (suffix $) = numeric t; t:=rule_thickness+eps; filldraw (x$-t,y$)...(x$,y$-t)...(x$+t,y$)...(x$,y$+t)...cycle; % roundish dot enddef; temp(1); temp(2); temp(3); temp(4); temp(5); temp(6); temp(7); temp(8); penlabels(1,2,3,4,5,6,7,8); endchar; lhchar"Cyrillic Leodr number symbol"; cyrchar(leodr,20u#,body_height#,max(paren_depth#,desc_depth#)); autorounded; adjust_fit(if monospace:-3u#,-3u# else: 0,0 fi); pickup rule.nib; if .5w <> good.x .5w: change_width; fi lft x6=hround u; x2=w-x6; top y8=h+o; bot y4=-d-o; circle_points; %draw_circle; % circle numeric theta; pickup pencircle scaled .5rule_thickness; def temp (suffix $,$$) = numeric t; t:=rule_thickness; filldraw (x$-t,y$)...(x$,y$-t)...(x$+t,y$)...(x$,y$+t)...cycle; % roundish dot z$'=z$+t*(unitvector((x$,y$)-(x$$,y$$))rotated 90); z$''=z$+2.5t*unitvector((x$,y$)-(x$$,y$$)); theta:=angle((x$,y$)-(x$$,y$$))-60; draw stroke z$'{(x$,y$)-(x$$,y$$)}...z$''; % comma tail enddef; temp(1,6); temp(2,7); temp(3,8); temp(4,1); temp(5,2); temp(6,3); temp(7,4); temp(8,5); penlabels(1,2,3,4,5,6,7,8); endchar; lhchar"Cyrillic Vran number symbol"; cyrchar(vran,20u#,body_height#,max(paren_depth#,desc_depth#)); autorounded; adjust_fit(if monospace:-3u#,-3u# else: 0,0 fi); pickup rule.nib; if .5w <> good.x .5w: change_width; fi lft x6=hround u; x2=w-x6; top y8=h+o; bot y4=-d-o; circle_points; %draw_circle; % circle pickup pencircle scaled .5rule_thickness; def temp (suffix $) = numeric t; t:=rule_thickness+1+eps; draw (x$,y$-t)...(x$,y$+t); draw (x$-t,y$)...(x$+t,y$); % plus sign enddef; temp(1); temp(2); temp(3); temp(4); temp(5); temp(6); temp(7); temp(8); penlabels(1,2,3,4,5,6,7,8); endchar; lhchar "Cyrillic koloda number symbol"; cyrchar(koloda,18u#,body_height#,max(paren_depth#,desc_depth#));% italcorr h#*slant+.5vair#-1.5u#; adjust_fit(if monospace:-3u#,-3u# else: 0,0 fi); %!!! lowercase_breve flipped x_center:=.5w; y_move:=0; _one:=1; _two:=2; _three:=3; % pickup pencircle scaled .5rule_thickness; pos[_one](vair,180); pos[_three](vair,0); top y[_two]r=h+oo; %!!! x[_two]=x_center; lft x[_one]r=hround (1.5u); rt x[_three]r=hround(w-1.5u); numeric mid_thickness; mid_thickness=max(currentbreadth+eps,vround 1/3[vair,stem]);%!!! bot y[_one]=bot y[_three]= %!!! vround max(x_height+o+tiny,1/3[x_height,h]+o-.5mid_thickness)-.5acc_height; if y[_two]r<(y[_one]+.5crisp+eps): %!!! y[_two]r:=y[_one]+.5crisp+eps; fi %!!! pos[_two](mid_thickness,90); %!!! moved here after if filldraw stroke (z[_one]e+(u,0))--z[_one]e{up}...z[_two]e{right} ...{down}z[_three]e--(z[_three]e+(-u,0)); % stroke %flip forsuffixes $ = [_one]l,[_one],[_one]r,[_two]l,[_two],[_two]r, [_three]l,[_three],[_three]r : y$:=h-d-y$; endfor; filldraw stroke (z[_three]e+(-u,0))--z[_three]e{down}...z[_two]e{left} ...{up}z[_one]e--(z[_one]e+(u,0)); % stroke penlabels(1,2,3); endchar; lhchar"Cyrillic Tma Tem number symbol"; cyrchar(tmatem,20u#,body_height#,max(paren_depth#,desc_depth#)); autorounded; adjust_fit(if monospace:-3u#,-3u# else: 0,0 fi); pickup rule.nib; if .5w <> good.x .5w: change_width; fi lft x6=hround u; x2=w-x6; top y8=h+o; bot y4=-d-o; circle_points; %draw_circle; % circle pickup pencircle scaled .5rule_thickness; def temp (suffix $) = numeric t; t:=rule_thickness+1+eps; draw (x$-t,y$)...(x$+t,y$); % minus sign enddef; temp(1); temp(2); temp(3); temp(4); temp(5); temp(6); temp(7); %temp(8); draw (x8-t,y8)...(x8+t,y8); draw (x8,y8-t)...(x8,y8+t);% plus sign penlabels(1,2,3,4,5,6,7,8); endchar; endinput; %end of file