% This is DXILWEST.MF in text format, as of March 24, 1992 % % DC fonts Version 1.1 (prerelease of EC fonts) % % [ heavily borrowed from the Computer Modern Roman family of % fonts by D. E. Knuth ] % % Content: % % italic lowercase accented letters ("western part") % % oct"340" .. oct"377" % dcchar "Italic letter gravis a"; beginchar(oct"340",9u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; pos0(hair,0); pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(stem,0); x4=x0; y4+.5stem=vround .98x_height; x1=x3=.5[x0,x2]; lft x2r=hround(1.5u-.5curve); rt x4r=hround(w-2.5u+.5stem); top y1r=x_height+oo; bot y3r=-oo; y0=y2=.5[y1,y3]; filldraw stroke super_arc.e(0,1) & pulled_arc.e(1,2) & pulled_arc.e(2,3) & super_arc.e(3,0); % bowl x5=x4; x7=w; hook_out(5,6,7); % closing hook filldraw circ_stroke z4e--z5e; % stem math_fit(-.3x_height#*slant+.5curve#-u#,ic#); % the accent lowercase_gravis(0,0,8,9); penlabels(0,1,2,3,4,5,6,7,8,9); endchar; dcchar "Italic letter acute a"; beginchar(oct"341",9u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; pos0(hair,0); pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(stem,0); x4=x0; y4+.5stem=vround .98x_height; x1=x3=.5[x0,x2]; lft x2r=hround(1.5u-.5curve); rt x4r=hround(w-2.5u+.5stem); top y1r=x_height+oo; bot y3r=-oo; y0=y2=.5[y1,y3]; filldraw stroke super_arc.e(0,1) & pulled_arc.e(1,2) & pulled_arc.e(2,3) & super_arc.e(3,0); % bowl x5=x4; x7=w; hook_out(5,6,7); % closing hook filldraw circ_stroke z4e--z5e; % stem math_fit(-.3x_height#*slant+.5curve#-u#,ic#); % the accent lowercase_acute(-u,0,8,9); penlabels(0,1,2,3,4,5,6,7,8,9); endchar; dcchar "Italic letter circumflex a"; beginchar(oct"342",9u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; pos0(hair,0); pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(stem,0); x4=x0; y4+.5stem=vround .98x_height; x1=x3=.5[x0,x2]; lft x2r=hround(1.5u-.5curve); rt x4r=hround(w-2.5u+.5stem); top y1r=x_height+oo; bot y3r=-oo; y0=y2=.5[y1,y3]; filldraw stroke super_arc.e(0,1) & pulled_arc.e(1,2) & pulled_arc.e(2,3) & super_arc.e(3,0); % bowl x5=x4; x7=w; hook_out(5,6,7); % closing hook filldraw circ_stroke z4e--z5e; % stem math_fit(-.3x_height#*slant+.5curve#-u#,ic#); % the accent lowercase_hat(.5w,0,8,9,10,11,12); penlabels(0,1,2,3,4,5,6,7,8,9,10,11,12); endchar; dcchar "Italic letter tilde a"; beginchar(oct"343",9u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; pos0(hair,0); pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(stem,0); x4=x0; y4+.5stem=vround .98x_height; x1=x3=.5[x0,x2]; lft x2r=hround(1.5u-.5curve); rt x4r=hround(w-2.5u+.5stem); top y1r=x_height+oo; bot y3r=-oo; y0=y2=.5[y1,y3]; filldraw stroke super_arc.e(0,1) & pulled_arc.e(1,2) & pulled_arc.e(2,3) & super_arc.e(3,0); % bowl x5=x4; x7=w; hook_out(5,6,7); % closing hook filldraw circ_stroke z4e--z5e; % stem math_fit(-.3x_height#*slant+.5curve#-u#,ic#); % the accent lowercase_tilde(-.5u,-1/6acc_height,8,9,10,11,12); penlabels(0,1,2,3,4,5,6,7,8,9,10,11,12); endchar; % % % dcchar "Italic letter umlaut a"; beginchar(oct"344",9u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; pos0(hair,0); pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(stem,0); x4=x0; y4+.5stem=vround .98x_height; x1=x3=.5[x0,x2]; lft x2r=hround(1.5u-.5curve); rt x4r=hround(w-2.5u+.5stem); top y1r=x_height+oo; bot y3r=-oo; y0=y2=.5[y1,y3]; filldraw stroke super_arc.e(0,1) & pulled_arc.e(1,2) & pulled_arc.e(2,3) & super_arc.e(3,0); % bowl x5=x4; x7=w; hook_out(5,6,7); % closing hook filldraw circ_stroke z4e--z5e; % stem math_fit(-.3x_height#*slant+.5curve#-u#,ic#); % the accent lowercase_umlaut(0,0,8,9,10,11); penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar; dcchar "Italic letter circle a"; beginchar(oct"345",9u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; pos0(hair,0); pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(stem,0); x4=x0; y4+.5stem=vround .98x_height; x1=x3=.5[x0,x2]; lft x2r=hround(1.5u-.5curve); rt x4r=hround(w-2.5u+.5stem); top y1r=x_height+oo; bot y3r=-oo; y0=y2=.5[y1,y3]; filldraw stroke super_arc.e(0,1) & pulled_arc.e(1,2) & pulled_arc.e(2,3) & super_arc.e(3,0); % bowl x5=x4; x7=w; hook_out(5,6,7); % closing hook filldraw circ_stroke z4e--z5e; % stem math_fit(-.3x_height#*slant+.5curve#-u#,ic#); % the accent lowercase_circle(x1,(1/3[x_height,h]+apex_o),8,9,10,11); penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar; dcchar "Italic ligature ae"; beginchar(oct"346",13u#,x_height#,0); italcorr max(1/3x_height#*slant,x_height#*slant+.5(.2[hair#,stem#])-u#); adjust_fit(if monospace:-u#,-u# else: 0,0 fi); pickup fine.nib; forsuffixes $=hair,stem: shaved$:=mfudged$; save $; $=shaved$; endfor numeric heavy_hair; heavy_hair=hround .2[hair,stem]; numeric light_stem; light_stem=hround .75[hair,stem]; pos0(vair,-90); pos1(heavy_hair,0); pos2(vair,90); pos3(light_stem,180); pos4(vair,270); pos5(hair,320); x0=rt x3l; rt x1r=hround(w-1.5u+.5heavy_hair); x2=x4=.5(w+6u); lft x3r=hround(.5w-.5light_stem); x5r=good.x(w-.5u); x6=x5; y0=y3=y6=bar_height; y1=.5[y0,y2]; top y2r=h+oo; bot y4r=-oo; top y5l=vround(.5bar_height+.5); path p; p=z4{right}..z5..z6; filldraw stroke z0e{right}...z1e{up}...pulled_arc.e(2,3) & pulled_arc.e(3,4)...{direction 1 of p}z5e; % arc of e pos7(light_stem,0); pos8(light_stem,0); x7=x8=x3; y7+.5light_stem=h+oo; y8-.5light_stem=-oo; pos7'(vair,-225); pos11(curve,-180); z7'=z7; pos12(vair,-90); pos3'(hair,0); z3'=z3; lft x11r=hround(1.5u-.5curve); x12=.5[x11,x3]; y11=.3[y12,y7]; bot y12r=-oo; filldraw stroke z7'e{3(x11-x7),y11-y7}...pulled_arc.e(11,12) & pulled_arc.e(12,3'); % bowl of a filldraw z7l---z8l..z8r---z7r..cycle; % stem penlabels(0,1,2,3,4,5,6,7,8,11,12); endchar; dcchar "Italic letter cedilla c"; beginchar(oct"347",8u#,x_height#,0.875desc_depth#); italcorr if math_fitting:1/3x_height#*slant else:x_height#*slant-u# fi; adjust_fit(0,0); pickup fine.nib; pos0(flare,0); pos1(hair,0); pos2(vair,90); pos3(curve,180); pos4(vair,270); pos5(hair,320); x2=x4=.5(w+u); rt x1r=max(rt x2,hround(w-u))+eps; lft x3r=hround(1.5u-.5curve); x5r=good.x(w-eps); x6=x5; y1=.5[bar_height,h]; top y2r=h+oo; bulb(2,1,0); % bulb bot y4r=-oo; y3=.5[y2,y4]; top y5l=vround .5bar_height; y6=bar_height; path p; p=z4{right}..z5..z6; filldraw stroke pulled_arc.e(2,3) & pulled_arc.e(3,4)...{direction 1 of p}z5e; % arc math_fit(-.3x_height#*slant+.5curve#-u#,ic#); % the accent lowercase_cedilla(x4,0,7,8,9,10,11); penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar; dcchar "Italic letter gravis e"; beginchar(oct"350",8u#,x_height#+acc_height#,0); italcorr max(1/3x_height#*slant,x_height#*slant+.5(.2[hair#,stem#])-u#); adjust_fit(0,0); pickup fine.nib; numeric heavy_hair; heavy_hair=hround .2[hair,stem]; pos0(vair,-90); pos1(heavy_hair,0); pos2(vair,90); pos3(curve,180); pos4(vair,270); pos5(hair,320); x0=rt x3l; rt x1r=hround(w-1.5u+.5heavy_hair); x2=x4=.5(w+u); lft x3r=hround(1.5u-.5curve); x5r=good.x(w-eps); x6=x5; y0=y3=y6=bar_height; y1=.5[y0,y2]; top y2r=x_height+oo; bot y4r=-oo; top y5l=vround .5bar_height; path p; p=z4{right}..z5..z6; filldraw stroke z0e{right}...z1e{up}...pulled_arc.e(2,3) & pulled_arc.e(3,4)...{direction 1 of p}z5e; % arc %the accent lowercase_gravis(u,0,7,8); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(0,1,2,3,4,5,6,7,8); endchar; dcchar "Italic letter acute e"; beginchar(oct"351",8u#,x_height#+acc_height#,0); italcorr max(1/3x_height#*slant,x_height#*slant+.5(.2[hair#,stem#])-u#); adjust_fit(0,0); pickup fine.nib; numeric heavy_hair; heavy_hair=hround .2[hair,stem]; pos0(vair,-90); pos1(heavy_hair,0); pos2(vair,90); pos3(curve,180); pos4(vair,270); pos5(hair,320); x0=rt x3l; rt x1r=hround(w-1.5u+.5heavy_hair); x2=x4=.5(w+u); lft x3r=hround(1.5u-.5curve); x5r=good.x(w-eps); x6=x5; y0=y3=y6=bar_height; y1=.5[y0,y2]; top y2r=x_height+oo; bot y4r=-oo; top y5l=vround .5bar_height; path p; p=z4{right}..z5..z6; filldraw stroke z0e{right}...z1e{up}...pulled_arc.e(2,3) & pulled_arc.e(3,4)...{direction 1 of p}z5e; % arc %the accent lowercase_acute(if monospace:0 else: -u fi,0,7,8); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(0,1,2,3,4,5,6,7,8); endchar; dcchar "Italic letter circumflex e"; beginchar(oct"352",8u#,x_height#+acc_height#,0); italcorr max(1/3x_height#*slant,x_height#*slant+.5(.2[hair#,stem#])-u#); adjust_fit(0,0); pickup fine.nib; numeric heavy_hair; heavy_hair=hround .2[hair,stem]; pos0(vair,-90); pos1(heavy_hair,0); pos2(vair,90); pos3(curve,180); pos4(vair,270); pos5(hair,320); x0=rt x3l; rt x1r=hround(w-1.5u+.5heavy_hair); x2=x4=.5(w+u); lft x3r=hround(1.5u-.5curve); x5r=good.x(w-eps); x6=x5; y0=y3=y6=bar_height; y1=.5[y0,y2]; top y2r=x_height+oo; bot y4r=-oo; top y5l=vround .5bar_height; path p; p=z4{right}..z5..z6; filldraw stroke z0e{right}...z1e{up}...pulled_arc.e(2,3) & pulled_arc.e(3,4)...{direction 1 of p}z5e; % arc %the accent lowercase_hat(.5w,0,7,8,9,10,11); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar; dcchar "Italic letter umlaut e"; beginchar(oct"353",8u#,x_height#+acc_height#,0); italcorr max(1/3x_height#*slant,x_height#*slant+.5(.2[hair#,stem#])-u#); adjust_fit(0,0); pickup fine.nib; numeric heavy_hair; heavy_hair=hround .2[hair,stem]; pos0(vair,-90); pos1(heavy_hair,0); pos2(vair,90); pos3(curve,180); pos4(vair,270); pos5(hair,320); x0=rt x3l; rt x1r=hround(w-1.5u+.5heavy_hair); x2=x4=.5(w+u); lft x3r=hround(1.5u-.5curve); x5r=good.x(w-eps); x6=x5; y0=y3=y6=bar_height; y1=.5[y0,y2]; top y2r=x_height+oo; bot y4r=-oo; top y5l=vround .5bar_height; path p; p=z4{right}..z5..z6; filldraw stroke z0e{right}...z1e{up}...pulled_arc.e(2,3) & pulled_arc.e(3,4)...{direction 1 of p}z5e; % arc %the accent lowercase_umlaut(0,0,7,8,9,10); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(0,1,2,3,4,5,6,7,8,9,10); endchar; dcchar "Italic letter gravis i"; beginchar(oct"354",5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(if monospace:u#,u# else: 0,0 fi); pickup fine.nib; x0=0; x5=w; x2=.5w+.25u; x3=.5w-.25u; if classic_serif: hook_out(3,4,5)(skewed); % hooks top y2=x_height; pos2(stem,0); sloped_serif.l(2,3,a,1/3,jut,serif_drop); else: hook_in(0,1,2)(skewed); hook_out(3,4,5)(skewed); % hooks fi filldraw stroke z2e--z3e; % stem % the accent lowercase_gravis(if serifs: 0 else:.5u fi,0,6,7); penlabels(0,1,2,3,4,5,6,7); endchar; dcchar "Italic letter acute i"; beginchar(oct"355",5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(if monospace:u#,u# else: 0,0 fi); pickup fine.nib; x0=0; x5=w; x2=.5w+.25u; x3=.5w-.25u; if classic_serif: hook_out(3,4,5)(skewed); % hooks top y2=x_height; pos2(stem,0); sloped_serif.l(2,3,a,1/3,jut,serif_drop); else: hook_in(0,1,2)(skewed); hook_out(3,4,5)(skewed); % hooks fi filldraw stroke z2e--z3e; % stem % the accent lowercase_acute(0,0,6,7); penlabels(0,1,2,3,4,5,6,7); endchar; dcchar "Italic letter circumflex i"; beginchar(oct"356",5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(if monospace:u#,u# else: 0,0 fi); pickup fine.nib; x0=0; x5=w; x2=.5w+.25u; x3=.5w-.25u; if classic_serif: hook_out(3,4,5)(skewed); % hooks top y2=x_height; pos2(stem,0); sloped_serif.l(2,3,a,1/3,jut,serif_drop); else: hook_in(0,1,2)(skewed); hook_out(3,4,5)(skewed); % hooks fi filldraw stroke z2e--z3e; % stem % the accent lowercase_hat(.5[.x1r,x2l],0,6,7,8,9,10); penlabels(0,1,2,3,4,5,6,7,8,9,19); endchar; dcchar "Italic letter umlaut i"; beginchar(oct"357",5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(if monospace:u#,u# else: 0,0 fi); pickup fine.nib; x0=0; x5=w; x2=.5w+.25u; x3=.5w-.25u; if classic_serif: hook_out(3,4,5)(skewed); % hooks top y2=x_height; pos2(stem,0); sloped_serif.l(2,3,a,1/3,jut,serif_drop); else: hook_in(0,1,2)(skewed); hook_out(3,4,5)(skewed); % hooks fi filldraw stroke z2e--z3e; % stem % the accent lowercase_umlaut(0,0,6,7,8,9); penlabels(0,1,2,3,4,5,6,7,8,9); endchar; dcchar "The letter eth"; beginchar(oct"360",9u#,asc_height#,0); italcorr .7x_height#*slant + u ; adjust_fit(if monospace: .5u#,.5u# else: 0,0 fi); oh := vround x_height ; penpos1(vair,90); penpos3(vair',-90); penpos2(curve,180); penpos4(curve,0); penpos4'(hair,0) ; x2r=hround max(.5u,1.25u-.5curve); x4r=w-x2r; x1=x3=.5w; y1r=oh + vround 1.5oo; y3r=-oo; y2=y4=.5oh-vair_corr; y2l:=y4l:=.52oh; x4'l = x4l ; y4 = y4' ; penstroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) -- pulled_arc.e(4',1) & cycle; % bowl fill z4l .. {right}z4 -- z4r -- cycle ; % fill in a little gap! penpos5(.5[vair,hair],40) ; % x5 = 3u ; top y5r = h ; Breytt JP x5l = x2 ; top y5r = h ; x7r = x4r; y7 = .95[x4,x1]; penpos7(curve,0); penstroke z5e .. tension 1.1 and 0.9 .. z7e{down} .. z4e ; %penstroke z5e .. tension 1.1 and 0.9 .. z4e{down} ; path p ; p = z5 .. tension 1.1 and 0.9 .. z7{down} ; %z6 = ((0,.6[x_height,asc_height]) -- (w,.5[x_height,asc_height])) JP z6 = ((0,.7[x_height,asc_height]) -- (w,.6[x_height,asc_height])) intersectionpoint p ; penpos6'(.5[vair,hair],-60) ; penpos 6''(.5[vair,hair],-60) ; top y6''l = h ; z6'' = z6 + whatever*dir30; z6 = .5[z6',z6''] ; filldraw stroke z6'e -- z6''e ; penlabels(1,2,3,4,5,6,6',6''); endchar; %dcchar "The letter eth"; %beginchar(oct"360",9u#,asc_height#,0); %italcorr .7x_height#*slant; %adjust_fit(if monospace: .5u#,.5u# else: 0,0 fi); %penpos1(vair,90); penpos3(vair',-90); %penpos2(curve,180); penpos4(curve,0); %penpos5(0.7curve,70); %penpos6(0.7curve,0); %penpos4'(0.7curve,0); %z4=z4'; %x6r=x4r;y6=.2[y4,x_height]; %x5=x2; %y5r=h; %x2r=hround max(.5u,1.25u-.5curve); %x4r=w-x2r; x1=x3=.5w; y1r=x_height+vround 1.5oo; y3r=-oo; %y2=y4=.5x_height-vair_corr; y2l:=y4l:=.52x_height; %penstroke pulled_arc.e(1,2) & pulled_arc.e(2,3) % & pulled_arc.e(3,4) & pulled_arc.e(4,1) & cycle; % bowl %pickup fine.nib; %%filldraw stroke z4'e..z6e{up}..z5e; %penstroke pulled_arc.e(4,6); %penstroke pulled_arc.e(6,5); %z7=point 1.4 of path_.l; %z20=point 1.4 of path_.r; %z21=.5[z7,z20]; %%x7 :=xpart(point 1.65 of (z4'..z6{up}..z5)); %%y7 :=ypart(point 1.65 of (z4'..z6{up}..z5)); %%x11 :=xpart(point 1.8 of (z4'..z6{up}..z5)); %%y11 :=ypart(point 1.8 of (z4'..z6{up}..z5)); %numeric aaa; %aaa := (angle direction 1.4 of path_.l)-90; %%z8=z7-(1stem,1stem); %y8=.4[y21,x_height]; %z8=whatever[z21,z21+dir aaa]; %pos8(bar,aaa-90); %pos9(bar,aaa-90); %0.5[z8,z9]=z21; %filldraw stroke z8e--z9e; %if serifs: % pos10(vair,110); % z10r=whatever[z5l,z5r]; % y10=.6[x_height,y5]; % pos11(vair,110); % z11r=whatever[z5l,z5r]; % x11=x5; % filldraw stroke z10e--z11e; %% pos11(0.7curve,70); %% pos10(vair,110);% angle(z5r-z5l)-90); %% z10r=whatever[z5l,z5r]; %% y10=.5[x_height,y5]; %% arm(11,10,f,beak_darkness,0); %fi %penlabels(1,2,3,4,5,6,7,8,9,10,11); endchar; dcchar "Italic letter tilde n"; beginchar(oct"361",10u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; x0=0; x1=x2; pos2(stem,0); lft x2l=hround(2.5u-.5stem); y2-.5stem=-oo; if classic_serif: top y1=x_height; pos1(stem,0); sloped_serif.l(1,2,a,1/3,jut,serif_drop); else: hook_in(0,a,1); % opening hook fi filldraw circ_stroke z2e--z1e; % left stem x4+.5stem=hround(w-2.5u+.5stem); x5=x4-.25u; ital_arch(2,3,4); % arch x7=w; hook_out(5,6,7)(skewed); % closing hook filldraw stroke z4e{down}..{-u,-x_height}z5e; % right stem lowercase_tilde(0,-1/6acc_height,8,9,10,11,12); math_fit(-2/3x_height#*slant+.5hair#+.5u#,ic#); penlabels(0,a,1,2,3,4,5,6,7,8,9,10,11,12); endchar; dcchar "Italic letter gravis o"; beginchar(oct"362",9u#,x_height#+acc_height#,0); italcorr .7x_height#*slant+.5curve#-u# if math_fitting:-.5u# fi; adjust_fit(0,0); pickup fine.nib; pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(curve,360); x1=x3=.5w; lft x2r=hround(1.5u-.5curve); x4=w-x2; top y1r=x_height+oo; y2=y4=.5[y1,y3]; bot y3r=-oo; filldraw stroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) & pulled_arc.e(4,1); % bowl %the accent lowercase_gravis(u,0,5,6); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(1,2,3,4); endchar; dcchar "Italic letter acute o"; beginchar(oct"363",9u#,x_height#+acc_height#,0); italcorr .7x_height#*slant+.5curve#-u# if math_fitting:-.5u# fi; adjust_fit(0,0); pickup fine.nib; pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(curve,360); x1=x3=.5w; lft x2r=hround(1.5u-.5curve); x4=w-x2; top y1r=x_height+oo; y2=y4=.5[y1,y3]; bot y3r=-oo; filldraw stroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) & pulled_arc.e(4,1); % bowl %the accent lowercase_acute(0,0,5,6); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(1,2,3,4); endchar; dcchar "Italic letter circumflex o"; beginchar(oct"364",9u#,x_height#+acc_height#,0); italcorr .7x_height#*slant+.5curve#-u# if math_fitting:-.5u# fi; adjust_fit(0,0); pickup fine.nib; pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(curve,360); x1=x3=.5w; lft x2r=hround(1.5u-.5curve); x4=w-x2; top y1r=x_height+oo; y2=y4=.5[y1,y3]; bot y3r=-oo; filldraw stroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) & pulled_arc.e(4,1); % bowl %the accent lowercase_hat(x1,0,5,6,7,8,9); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(1,2,3,4,7,8,9); endchar; dcchar "Italic letter tilde o"; beginchar(oct"365",9u#,x_height#+acc_height#,0); italcorr .7x_height#*slant+.5curve#-u# if math_fitting:-.5u# fi; adjust_fit(0,0); pickup fine.nib; pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(curve,360); x1=x3=.5w; lft x2r=hround(1.5u-.5curve); x4=w-x2; top y1r=x_height+oo; y2=y4=.5[y1,y3]; bot y3r=-oo; filldraw stroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) & pulled_arc.e(4,1); % bowl %the accent lowercase_tilde(0,-1/6acc_height,5,6,7,8,9); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(1,2,3,4,7,8,9); endchar; dcchar "Italic letter umlaut o"; beginchar(oct"366",9u#,x_height#+acc_height#,0); italcorr .7x_height#*slant+.5curve#-u# if math_fitting:-.5u# fi; adjust_fit(0,0); pickup fine.nib; pos1(vair,90); pos2(curve,180); pos3(vair,270); pos4(curve,360); x1=x3=.5w; lft x2r=hround(1.5u-.5curve); x4=w-x2; top y1r=x_height+oo; y2=y4=.5[y1,y3]; bot y3r=-oo; filldraw stroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) & pulled_arc.e(4,1); % bowl %the accent lowercase_umlaut(0,0,5,6,7,8); math_fit(-.3x_height#*slant+.5curve#-u#,ic#); penlabels(1,2,3,4,7,8); endchar; dcchar "Italic ligature oe"; beginchar(oct"367",13u#,x_height#,0); italcorr max(1/3x_height#*slant,x_height#*slant+.5(.2[hair#,stem#])-u#); adjust_fit(if monospace:-u#,-u# else: 0,0 fi); pickup fine.nib; forsuffixes $=hair,stem: shaved$:=mfudged$; save $; $=shaved$; endfor numeric heavy_hair; heavy_hair=hround .2[hair,stem]; pos0(vair,-90); pos1(heavy_hair,0); pos2(vair,90); pos3(stem,180); pos4(vair,270); pos5(hair,320); x0=rt x3l; rt x1r=hround(w-1.5u+.5heavy_hair); x2=x4=.5(w+6u); lft x3r=hround(.5w-.5stem); x5r=good.x(w-.5u); x6=x5; y0=y3=y6=bar_height; y1=.5[y0,y2]; top y2r=h+oo; bot y4r=-oo; top y5l=vround(.5bar_height+.5); path p; p=z4{right}..z5..z6; filldraw stroke z0e{right}...z1e{up}...pulled_arc.e(2,3) & pulled_arc.e(3,4)...{direction 1 of p}z5e; % arc of e pos11(vair,90); pos12(curve,180); pos13(vair,270); pos14(stem,360); x11=x13=.5[x12,x14]; lft x12r=hround(1.5u-.5curve); x14=x3; top y11=h+oo; y12=y14=.5[y11,y13]; bot y13=-oo; filldraw stroke pulled_arc.e(11,12) & pulled_arc.e(12,13) & pulled_arc.e(13,14) & pulled_arc.e(14,11); % bowl penlabels(0,1,2,3,4,5,6); endchar; dcchar "Italic Scandinavian letter o/slash"; beginchar(oct"370",9u#,x_height#+.5desc_depth#,.5desc_depth#); italcorr h#*slant-u#+.5vair#; adjust_fit(0,0); pickup fine.nib; pos1(vair,90); pos2(fudged.stem,180); pos3(vair,270); pos4(fudged.stem,360); x1=x3=.5w; lft x2r=hround(1.5u-.5fudged.stem); x4=w-x2; top y1=x_height+oo; y2=y4=.5[y1,y3]; bot y3=-oo; filldraw stroke pulled_arc.e(1,2) & pulled_arc.e(2,3) & pulled_arc.e(3,4) & pulled_arc.e(4,1); % bowl x5=x4; x6=x2; y5=h; y6=-d; numeric theta; theta=angle(z5-z6)-90; pickup crisp.nib; pos5(vair,theta); pos6(vair,theta); filldraw stroke z5e--z6e; % diagonal penlabels(1,2,3,4,5,6); endchar; dcchar "Italic letter gravis u"; beginchar(oct"371",9.5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; interim superness:=more_super; if classic_serif: x0=0; x2=x3; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); pos2(stem,0); top y2=x_height; else: x0=0; x2=x3+.25u; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); hook_in(0,1,2)(skewed); % opening hook fi pos2'(stem,-180); z2'=z2; pos4(vair,-90); pos5(hair,0); x4=.5[x3,x5]; pos6(stem,0); rt x6r=hround(w-2.5u+.5stem); x5=x6=x7; x9=w; hook_out(7,8,9); % closing hook y3=.7[y4,y5]; bot y4r=-oo; y5=.57x_height; y6+.5stem=x_height; if classic_serif: filldraw stroke z2 ...super_arc.e(3,4)...{up}z5e; % left stem and arc else: filldraw stroke z2'e{-u,-x_height} ...super_arc.e(3,4)...{up}z5e; % left stem and arc fi filldraw circ_stroke z6e--z7e; % right stem if classic_serif: sloped_serif.l(2,3,a,1/3,jut,serif_drop); fi math_fit(-2/3x_height#*slant+.5hair#+.5u#,ic#); % the accent lowercase_gravis(0,0,10,11); penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar; dcchar "Italic letter acute u"; beginchar(oct"372",9.5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; interim superness:=more_super; if classic_serif: x0=0; x2=x3; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); pos2(stem,0); top y2=x_height; else: x0=0; x2=x3+.25u; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); hook_in(0,1,2)(skewed); % opening hook fi pos2'(stem,-180); z2'=z2; pos4(vair,-90); pos5(hair,0); x4=.5[x3,x5]; pos6(stem,0); rt x6r=hround(w-2.5u+.5stem); x5=x6=x7; x9=w; hook_out(7,8,9); % closing hook y3=.7[y4,y5]; bot y4r=-oo; y5=.57x_height; y6+.5stem=x_height; if classic_serif: filldraw stroke z2 ...super_arc.e(3,4)...{up}z5e; % left stem and arc else: filldraw stroke z2'e{-u,-x_height} ...super_arc.e(3,4)...{up}z5e; % left stem and arc fi filldraw circ_stroke z6e--z7e; % right stem if classic_serif: sloped_serif.l(2,3,a,1/3,jut,serif_drop); fi math_fit(-2/3x_height#*slant+.5hair#+.5u#,ic#); % the accent lowercase_acute(0,0,10,11); penlabels(0,1,2,3,4,5,6,7,8,9,10,11); endchar; dcchar "Italic letter circumflex u"; beginchar(oct"373",9.5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; interim superness:=more_super; if classic_serif: x0=0; x2=x3; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); pos2(stem,0); top y2=x_height; else: x0=0; x2=x3+.25u; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); hook_in(0,1,2)(skewed); % opening hook fi pos2'(stem,-180); z2'=z2; pos4(vair,-90); pos5(hair,0); x4=.5[x3,x5]; pos6(stem,0); rt x6r=hround(w-2.5u+.5stem); x5=x6=x7; x9=w; hook_out(7,8,9); % closing hook y3=.7[y4,y5]; bot y4r=-oo; y5=.57x_height; y6+.5stem=x_height; if classic_serif: filldraw stroke z2 ...super_arc.e(3,4)...{up}z5e; % left stem and arc else: filldraw stroke z2'e{-u,-x_height} ...super_arc.e(3,4)...{up}z5e; % left stem and arc fi filldraw circ_stroke z6e--z7e; % right stem if classic_serif: sloped_serif.l(2,3,a,1/3,jut,serif_drop); fi math_fit(-2/3x_height#*slant+.5hair#+.5u#,ic#); % the accent lowercase_hat(.5w,0,10,11,12,13,14); penlabels(0,1,2,3,4,5,6,7,8,9,10,11,12,13,14); endchar; dcchar "Italic letter umlaut u"; beginchar(oct"374",9.5u#,x_height#+acc_height#,0); italcorr 1/3x_height#*slant+.5hair#+.5u#; adjust_fit(0,0); pickup fine.nib; interim superness:=more_super; if classic_serif: x0=0; x2=x3; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); pos2(stem,0); top y2=x_height; else: x0=0; x2=x3+.25u; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); hook_in(0,1,2)(skewed); % opening hook fi pos2'(stem,-180); z2'=z2; pos4(vair,-90); pos5(hair,0); x4=.5[x3,x5]; pos6(stem,0); rt x6r=hround(w-2.5u+.5stem); x5=x6=x7; x9=w; hook_out(7,8,9); % closing hook y3=.7[y4,y5]; bot y4r=-oo; y5=.57x_height; y6+.5stem=x_height; if classic_serif: filldraw stroke z2 ...super_arc.e(3,4)...{up}z5e; % left stem and arc else: filldraw stroke z2'e{-u,-x_height} ...super_arc.e(3,4)...{up}z5e; % left stem and arc fi filldraw circ_stroke z6e--z7e; % right stem if classic_serif: sloped_serif.l(2,3,a,1/3,jut,serif_drop); fi math_fit(-2/3x_height#*slant+.5hair#+.5u#,ic#); % the accent lowercase_umlaut(0,0,10,11,12,13); penlabels(0,1,2,3,4,5,6,7,8,9,10,11,12,13); endchar; dcchar "Italic letter acute y"; beginchar(oct"375",8.5u#,x_height#+acc_height#,desc_depth#); italcorr x_height#*slant+.5stem#-u#; adjust_fit(0,0); pickup fine.nib; interim superness:=more_super; x0=0; x2=x3+.25u; pos3(stem,-180); lft x3r=hround(2.5u-.5stem); if classic_serif: pos2(stem,0); top y2=x_height; else: hook_in(0,1,2)(skewed); % opening hook fi pos2'(stem,-180); z2'=z2; pos4(vair,-90); pos5(hair,0); x4=.5[x3,x5]; pos6(stem,0); rt x6r=hround(w-1.5u+.5stem); pos7(stem,0); pos8(vair,-90); y3=.7[y4,y5]; bot y4r=-oo; y5=.57x_height; y6+.5stem=x_height; y7=0; bot y8r=-d-oo; x5=x6=x7; x8=.5w; pos9(hair,-180); pos10(flare,-180); y9=-.5d; lft x9r=hround(2.75u-.5flare); bulb(8,9,10); % bulb filldraw stroke z2'e{-u,-x_height} ...super_arc.e(3,4)...{up}z5e; % left stem and arc filldraw circ_stroke z6e---z7e...{left}z8e; % right stem and link if classic_serif: sloped_serif.l(2,3,a,1/3,jut,serif_drop); fi %the accent lowercase_acute(0,0,11,12); math_fit(-2/3x_height#*slant+.5hair#+.5u#,ic#-1/3x_height#*slant); penlabels(0,1,2,3,4,5,6,7,8,9,10,11,12); endchar; dcchar "Italic letter thorn"; beginchar(oct"376",9u#+serif_fit#,asc_height#,desc_depth#); italcorr .7x_height#*slant+.5curve# -u# if math_fitting: -.5u# fi; adjust_fit(0,0); pickup tiny.nib; pos1(stem',0); pos2(stem,0); pos0'(stem',0); pos0(stem,0); z0l=z0'l; x0'=x1; x0=x2; lft x1l=hround(2.5u-.5stem'); top y1=h; numeric edge; edge=rt x2r; pickup fine.nib; pos3(if hefty:thin_join else: hair fi,180); pos4(vair,90); pos5(curve,0); pos6(vair,-90); penpos7(x3l-x3r,-180); rt x3l=max(rt x3l-(lft x3r-tiny.lft x2l),1/3[rt x2,edge]); y3=1/8[bar_height,x_height]; x4l=w-.5(w-serif_fit)+.5u; top y4r=x_height+oo; rt x5r=hround min(w-1.35u+.5curve,w-.6u); y5=.5x_height; x6l=x4l-.2u; bot y6r=-oo; x7=x3; y7=min(y3,y6+y4-y3+.6vair); (x,y4r)=whatever[z3l,z4l]; x4r:=min(x,.5[x4,x5r]); (x',y6r)=whatever[z7l,z6l]; x6r:=min(x',.5[x6,x5r]); filldraw stroke z3e{up}...pulled_arc.e(4,5)&pulled_arc.e(5,6)...{up}z7e; % bowl y0=ypart(((edge,h)--(edge,0))intersectionpoint(z3l{up}...{right}z4l)); y2=ypart(((edge,h)--(edge,0))intersectionpoint(z6l{left}...{up}z7l)); pickup tiny.nib; filldraw stroke z1e--z0'e--z0e--z2e; % stem pickup crisp.nib; pos8(stem,0); pos7'(stem,0); z7'=z2; x8l=x7'l; bot y8=-d; filldraw stroke z7'e--z8e; % point if serifs: sloped_serif.l(1,0',a,1/3,jut,serif_drop); % upper serif dish_serif(8,1,c,1/3,jut,d,1/3,jut); % lower serif fi % upper serif penlabels(0,1,2,3,4,5,6,7,8); endchar; dcchar "Italic German letter es-zet (sharp s)"; beginchar(oct"377",4.5u#+max(1.5u#,stem#)+max(3.5u#,2flare#),asc_height#,desc_depth#); italcorr .9asc_height#*slant-u#; adjust_fit(if monospace: u# else: 0 fi,0); pickup fine.nib; z88=(.5w-2.75u,h); z89=(.5w-1.75u,-d); numeric theta; theta=angle(z88-z89); pos1(stem,0); pos2(vair,90); pos3(.5[hair,stem],180); pos4(stem,theta+90); pos5(stem,theta-90); pos6(.5[hair,stem],0); pos7(vair,-90); pos8(hair,-180); pos9(flare,-180); rt x1r=hround(w-1.5u); lft x8r=hround-.25u; x2=.5[x1,x4]; x7=.5[x8,x5]; y9-.5flare=vround -.85d; bot y7r=-d-oo; y1=.5[x_height,h]; top y2r=h+oo; y4=.25[x_height,h]; y5=.5[-d,y4]; z4=whatever[z88,z89]; z5=whatever[z88,z89]; x3=.8[x2+x4-x88,x88]; x6=.8[x7+x5-x89,x89]; y3=.8[y4,y2]; y6=.8[y5,y7]; bulb(7,8,9); % left bulb filldraw stroke z1e{up}...z2e{left}...z3e...{z89-z88}z4e; % upper arc filldraw z4r--z5l--z5r--z4l--cycle; % stem filldraw stroke z5e{z89-z88}...z6e...{left}z7e; % lower arc pos11(.1[hair,curve],-30); x11l=2/3[x12l,x1l]; y11=2/3[y1,y12]; pos12(.3[hair,curve],0); rt x12r=hround(w-3u); y12=.5h; pos13(.8[hair,curve],30); x13=.5[x12,x14]; y13=.5[y12,y14]; pos14(curve,0); rt x14r=hround(w-.5u); y14=.2h; pos15(vair,-90); x15=.5[x14,x16]; bot y15r=-oo; pos16(hair,-180); pos17(.6[hair,flare],-180); lft x16r=hround(rt x5r+.75u); y17-.5(.6[hair,flare])=.07h; filldraw stroke z1e{down}...z11e{1.5(x12e-x11e),y12e-y11e} ...{down}z12e...{2(x13-x12),y13-y12}z13e ...{down}z14e...{left}z15e; % stroke bulb(15,16,17); % inner bulb pickup crisp.nib; pos20(bar,90); pos21(bar,90); top y20r=top y21r=x_height; lft x20=lft x4r-.5stem-u; z21=whatever[z4,z5]; filldraw stroke z20e--z21e; % bar penlabels(1,2,3,4,5,6,7,8,9,11,12,13,14,15,16,17,20,21,88,89); endchar; endinput;