% tipasym4.mf: TIPA phonetic symbols (4) non-IPA, old IPA symbols % Copyright 1996-2003 FUKUI Rei % % This program may be distributed and/or modified under the % conditions of the LaTeX Project Public License, either version 1.2 % of this license or (at your option) any later version. % The latest version of this license is in % http://www.latex-project.org/lppl.txt % and version 1.2 or later is part of all distributions of LaTeX % version 1999/12/01 or later. % % This program consists of all files listed in Manifest.txt. % % Version 1.2 2003/01/01 % % This font is based on: % Computer Modern font series by D. E. Knuth and % TSIPA by KOBAYASHI Hajime, FUKUI Rei and SHIRAKAWA Shun. % cmchar "Crossed B"; beginchar(oct"240",10u#+serif_fit#,asc_height#,0); italcorr .5x_height#*slant+min(.5curve#-u#,-.25u#); adjust_fit(serif_fit#,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(side_gap-.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(hair,0); pos7'(stem,0); z7'=z2; x8l=x7'l; bot y8=0; filldraw stroke z7'e--z8e; % point if serifs: sloped_serif.l(1,0',a,1/3,jut,serif_drop); fi % upper serif pickup if serifs: tiny.nib else: fine.nib fi; hbar(9,10,lft x0l-hround(1.8u+serif_fit),rt x0r+hround(side_gap), x_height+.5(h-x_height)); penlabels(0,1,2,3,4,5,6,7,8); endchar; cmchar "Crossed D"; beginchar(oct"241",10u#+serif_fit#,asc_height#,0); italcorr asc_height#*slant-serif_fit#+.5stem#-.5u#; adjust_fit(0,serif_fit#); d_stroke(true,true,0); pickup if serifs: tiny.nib else: fine.nib fi; hbar(8,9,lft x0l-hround 2.5u,rt x0r+hround(1.8u+serif_fit), x_height + .5(h-x_height)); penlabels(0,1,2,3,4,5,6,7); endchar; cmchar "Curly-tail D"; beginchar(oct"242",10u#+serif_fit#,asc_height#,desc_depth#); italcorr asc_height#*slant-serif_fit#+.5stem#-2.25u#; adjust_fit(0,serif_fit#+u#); d_stroke(true,false,.45bar_height); if serifs: pickup tiny.nib; else: pickup fine.nib; fi pos2'(stem,0); z2'=z2; numeric curlytail[]; curlytail1=if serifs: vair; else: vair; fi curlytail2=if serifs: hair; else: .8hair; fi curlytail3=if serifs: vair; else: vair; fi pos10(curlytail1,90); x10=.4[x2r,x11]; bot y10l=if serifs: -oo; else: -o; fi pos11(curlytail2,180); rt x11=w+.5u; y11=.3bar_height; pos12(curlytail3,280); x12=x2r+.5u; y12=2y11; pos13(hair,360); x13=.4w; y13=-.75desc_depth; filldraw stroke z2'e{down}..z10e..{up}z11e... {(-3,-1)}z12e...{(-1,-2)}z13e; % tail penlabels(0,1,2,3,4,5,6,7,8,9,10,11,12,13); endchar; cmchar "Hooktop right-tail D"; beginchar(oct"243",10u#+serif_fit#,asc_height#,desc_depth#); italcorr asc_height#*slant+.5u#; adjust_fit(0,serif_fit#+1.75u#); d_stroke(false,false,0); hooktop(0,9,10,11,stem,hround(w+1.5u),h,.9,.6,.5); if serifs: right_tail(2,12,13,14,stem,hround(w+1u),.88,.5,1/3); else: right_tail(2,12,13,14,stem,hround(w+1u),.833,.5,1/3); fi penlabels(0,1,2',3,4,5,6,7,9,10,11,12,13,14); endchar; cmchar "The letter g"; beginchar(oct"245",CT(9u#,10u#),x_height#,desc_depth#); italcorr x_height#*slant+.25u#; adjust_fit(0,0); numeric light_vair,light_curve,loop_top,loop_side; light_vair=Vround(.5[thin_join,vair]+vair_corr); light_curve=max(fine.breadth,hround(curve-3stem_corr)); loop_top=Vround .77[vair,fudged.stem]; loop_side=hround .64[vair,fudged.stem]; pickup fine.nib; pos1(light_vair,90); pos2(light_curve,180); pos3(light_vair,270); pos4(light_curve,360); pos11(loop_top,90); y11r=good.y(y11r+.15bar_height-y11); x1=x3=.5[x2,x4]; y2=y4=.5[y1,y3]; lft x2r=hround(1.75u-.5light_curve); rt x4r=hround(w-2.75u+.5light_curve); top y1r=h+oo; y3r=good.y(y3r+.27[top y11r,bot y1l]-y3); filldraw stroke pulled_arc.e(1,2) & pulled_arc.e(2,3); % left half of bowl filldraw stroke pulled_arc.e(3,4) & pulled_arc.e(4,1); % right half of bowl x0=superness[x1r,x4r]; y0=superness[y4r,y1r]; % NE point on the super bowl x8'=superness[x3r,x2r]; y8'=superness[y2r,y3r]; % SW point on the super bowl x8''=superness[x3,x2]; y8''=superness[y2,y3]; pos0(thin_join,angle(z0-z8')+90); pos8(thin_join,angle(z0-z8')-90); z8=.618[z8',z8'']; if serifs: pos5(vair,90); pos6(hair,0); pos7(.5[hair,flare],0); x5=.75[x0,x6]; top y5r=h+o; rt x6r=hround(w-.25u); y6+(.5[hair,flare])/2=.95[bar_height,h]+oo; filldraw stroke z0e..{right}z5e; bulb(5,6,7); % ear else: pos5(vair',100); top y5r=h+oo; rt x5l=hround(w-.25u); y5l:=good.y y5l; filldraw z0l{z5-z0}..z5l--z5r{left}..{curl 1}z0r--cycle; fi % ear pos10(loop_top,90); x10=x8+.75u; y10=y11; pos12(loop_side,0); pos13(light_vair,-90); pos14(loop_side,-180); pos10'(.5[thin_join,vair],-270); rt x12r=hround max(w-1.25u+.5loop_side,w-.5u); y12=y14=.5[y11,y13]; x11=x13=max(.5w,x10+eps); bot y13r=-d-oo-1; x14=w-x12; z10'l=z10l; filldraw stroke z8e{z8-z0}..z10e---z11e; % link filldraw stroke {{interim superness:=hein_super; super_arc.e(11,12)}} & super_arc.e(12,13) & super_arc.e(13,14) & super_arc.e(14,10'); % loop penlabels(0,1,2,3,4,5,6,7,8,10,11,12,13,14); labels(8',8''); endchar; cmchar "Left-hooktop Long I"; beginchar(oct"246",CT(6u#,6.66u#),x_height#,desc_depth#); italcorr x_height#*slant-2u#; adjust_fit(0,serif_fit#); pickup tiny.nib; pos3(stem,0); x2=x3; bot y3=-d; x0=.75u; lft x2l = hround(.5w+.5u-.5stem); hook_in(0,1,2); filldraw stroke z2e--z3e; dish_serif(3,2,a,1/3,jut,b,1/3,jut); penlabels(0,1,2,3); endchar; cmchar "Viby I"; beginchar(oct"247",CT(7.1u#,7.78u#),x_height#,desc_depth#); italcorr x_height#*slant-2u#; adjust_fit(if monospace:.5u#,.5u# else:0,-.5u# fi); pickup tiny.nib; x0=.75u; lft x2l = hround(.5w-.5stem); x3=x2; x5=w-.75u; hook_in(0,1,2); hook_out_bot(3,4,5); filldraw stroke z2e--z3e; penlabels(0,1,2,3,4,5); endchar; cmchar "Turned K"; beginchar(oct"251",CT(9.5u#,10u#),x_height#,desc_depth#); italcorr x_height#*slant; adjust_fit(serif_fit#,serif_fit#); pickup tiny.nib; numeric right_jut,stem[],alpha[]; stem1=max(tiny.breadth,hround(fudged.stem-stem_corr)); stem2=max(tiny.breadth,hround(fudged.stem-2stem_corr)); stem3=max(tiny.breadth,hround(fudged.hair if hefty:-\\4stem_corr fi)); stem4=max(tiny.breadth,hround(fudged.stem-3stem_corr)); if serifs: right_jut=.6jut; else: right_jut=.4tiny; fi pos1(stem1,0); pos2(stem2,0); top y1=x_height+d+min(oo,serif_drop); bot y2=0; lft x1l=lft x2l=hround(side_gap-.5stem1); top y3=x_height; rt x3r=hround(r-letter_fit-.7u-right_jut)+eps; bot y6=0; rt x6r=hround(r-letter_fit-.3u-right_jut)+eps; x4=x11=x1; y4=.7bar_height; y11=y3; alpha1=diag_ratio(1,.5(stem3-tiny),y3-y4,x3r-x4); alpha2=diag_ratio(1,.5(stem4-tiny),y11-y6,x6r-x1); penpos3(alpha1*(stem3-tiny),0); penpos4(whatever,-90); z5=.5[z5l,z5r]; penpos6(alpha2*(stem4-tiny),0); forsuffixes $=l,r: y3'$=x_height; y6'$=0; z4$=z3'$+whatever*(z3-z4); z5$=z6'$+whatever*(z11-z6)=whatever[z3,z4]; endfor z3'r=z3r+penoffset z3-z4 of currentpen+whatever*(z3-z4); % we have also z3'l=z3l+penoffset z4-z3 of currentpen+whatever*(z3-z4); z6'r=z6r+penoffset z11-z6 of currentpen+whatever*(z11-z6); z6'l=z6l+penoffset z6-z11 of currentpen+whatever*(z11-z6); fill z4r--diag_end(4r,3'r,1,.5,3'l,4l)--z4l--cycle; % upper diagonal fill z5l--diag_end(5l,6'l,.5,1,6'r,5r)--z5r--cycle; % lower diagonal pos0(stem1,0); pos0'(stem2,0); y0=y0'; x0=x1; x0'=x2; rt z0r=whatever[z3,z4]; filldraw stroke z1e..z0e--z0'e..z2e; % stem if serifs: numeric inner_jut; if rt x2r+jut+.5u+1<=lft x6l-jut: inner_jut=jut; else: rt x2r+inner_jut+.5u+1=lft x6l-inner_jut; fi sloped_serif.l(1,0,a,1/3,jut,serif_drop); % upper stem serif dish_serif(2,0',b,1/3,jut,c,1/3,inner_jut); % lower stem serif dish_serif(3,4,d,2/3,1.4jut,e,1/2,right_jut)(dark); % upper diagonal serif dish_serif(6,5,f,1/2,inner_jut,g,1/3,right_jut)(dark);fi % lower diagonal serif turn_picture_lower; penlabels(0,1,2,3,4,5,6,11); endchar; cmchar "Barred L"; beginchar(oct"252",7u#,asc_height#,0); italcorr asc_height#*slant-1u#; adjust_fit(0,0); pickup tiny.nib; pos1(stem',0); pos2(stem',0); if odd(w-stem'): change_width; fi lft x1l=hround(.5w-.5stem'); x1=x2; top y1=h; bot y2=0; filldraw stroke z1e--z2e; % stem if serifs: sloped_serif.l(1,2,a,1/3,jut,serif_drop); % upper serif dish_serif(2,1,b,1/3,jut,c,1/3,jut); fi % lower serif hbar(3,4,lft x1l - hround(2u),rt x2r + hround(2u), .82x_height+.5bar); penlabels(1,2); endchar; cmchar "Lambda"; beginchar(oct"253",CT(9.5u#,10u#),asc_height#,0); adjust_fit(0,0); pickup fine.nib; pos1(vair,90); lft x1=hround .1u; top y1r=h; x2=x1+2u; y2=.7[x_height,h]; x3=w-2u; bot y4=-oo; y3=max(.07h,y4+eps); z4-(.25u,0)=whatever[z2,z3]; numeric theta; theta=angle(z2-z3)-90; pos2(stem,theta); pos3(stem,theta); pos4(stem,0); filldraw circ_stroke z1e{right}...z2e---z3e ...{2(x4e-x3e),y4e-y3e}z4e; % long diagonal y5=.5[bar_height,x_height]; z5=whatever[z2,z3]; x6=1.5u; y6-.5stem=-oo; pos5(hair,theta-90); pos6(stem,angle(z5-z6)-90); filldraw circ_stroke z6e--z5e; % short diagonal penlabels(1,2,3,4,5,6); endchar; cmchar "Crossed lambda"; beginchar(oct"254",CT(9.5u#,10u#),asc_height#,0); adjust_fit(0,0); pickup fine.nib; pos1(vair,90); lft x1=hround .1u; top y1r=h; x2=x1+2u; y2=.7[x_height,h]; x3=w-2u; bot y4=-oo; y3=max(.07h,y4+eps); z4-(.25u,0)=whatever[z2,z3]; numeric theta; theta=angle(z2-z3)-90; pos2(stem,theta); pos3(stem,theta); pos4(stem,0); filldraw circ_stroke z1e{right}...z2e---z3e ...{2(x4e-x3e),y4e-y3e}z4e; % long diagonal y5=.5[bar_height,x_height]; z5=whatever[z2,z3]; x6=1.5u; y6-.5stem=-oo; pos5(hair,theta-90); pos6(stem,angle(z5-z6)-90); filldraw circ_stroke z6e--z5e; % short diagonal z7=whatever[z2,z3]; y7=1/3[y5,y2]; pos7(stem,theta+90); z8=z7+whatever*dir theta; x8=1.5u-.25stem; z9=z7+whatever*dir theta; x9-x7=x7-x8; pos8(.6[vair,stem],theta+90); pos9(.6[vair,stem],theta+90); filldraw stroke z8e--z9e; penlabels(1,2,3,4,5,6); endchar; cmchar "Old L-Yogh Ligature"; beginchar(oct"255",CT(9.5u#,10u#),asc_height#,desc_depth#); italcorr x_height#*slant-.5serif_fit#-u#; adjust_fit(serif_fit#+stem_shift#,.5serif_fit#); pickup fine.nib; pos1(if serifs: vair else: stem' fi,180); lft x1r=hround(side_gap-.5stem'); y1=.68x_height; pos2(.3[hair,stem],90); x2=.5w+u; top y2r=x_height+o; pos3(stem,0); x3=x7-.5u; y3=.4[bar_height,x_height]; pos5(.7[hair,curve],0); x5r=.7[x2,x3]; y5=.7bar_height; pos6(.8[hair,curve],30); x6=.5[x5l,x7r]; y6=.45[y5,y7]; pos7(curve,0); rt x7r=hround(w-.75u); y7=0; filldraw stroke z1e{up}...{right}z2e...{down}z3e...{down}z5e ...z6e...{down}z7e; % bowl if serifs: pickup tiny.nib; x8=x7; bot y8=-.16d; pos8(curve,0); pos9(vair,-90); pos10(hair,-180); pos10'(flare,-180); x9=.5[x8,x10r]; bot y9r=-d-oo; y10-.5flare=-.7d; z10r=z10'r; lft x10'r=hround 2u; numeric xx; (xx,y9r)=whatever[z9l,z8l]; x9r:=max(xx,.5[x10r,x9]); filldraw stroke z7e--z8e{down}...z9e{left}; bulb(9,10,10'); % arc and bulb else: pickup fine.nib; x8=x7; bot y8=-.16d; pos8(curve,0); pos9(vair,-90); x9=.5[x8,x10r]; bot y9r=-d-o; pos10(.7[vair,flare],-130); lft x10r=hround 2u; y10r=good.y -.7d; y10l:=good.y y10l; filldraw stroke z7e--z8e & super_arc.e(8,9) & term.e(9,10,left,.9,4); fi pickup tiny.nib; pos51(stem',0); pos52(stem',0); % l if odd(w-stem'): change_width; fi lft x51l=hround(side_gap-.5stem'); x51=x52; top y51=h; bot y52=0; filldraw stroke z51e--z52e; % stem if serifs: sloped_serif.l(51,52,e,1/3,jut,serif_drop); % upper serif dish_serif(52,51,f,1/3,jut,g,1/3,jut); fi % lower serif penlabels(1,2,3,4,5,6,7,8,9,10,12,13,51,52); endchar; cmchar "Curly-tail N"; beginchar(oct"256",10u#,x_height#,desc_depth#); italcorr .5[bar_height#,x_height#]*slant-serif_fit#+.5stem#-2u#; adjust_fit(serif_fit#+stem_shift#,serif_fit#-stem_shift#+u#); pickup tiny.nib; pos1(stem,0); pos2(stem,0); numeric shaved_stem; shaved_stem=hround(stem-2stem_corr); pos1'(shaved_stem,0); pos2'(shaved_stem,0); pos3(stem,0); lft x1l=hround(side_gap-.5stem); x1l=x1'l=x2l=x2'l; x3=w-x1; top y1=h+min(oo,serif_drop); bot y2=0; y1=y1'; y2=y2'; filldraw stroke z1'e--z2'e; % left stem raised_h_stroke(2,a,3,4); % arch and right stem if serifs: sloped_serif.l(1',2',b,1/3,jut,serif_drop); % upper left serif numeric inner_jut; pickup tiny.nib; if rt x2r+jut+.5u+1<=lft x4l-jut: inner_jut=jut; else: rt x2r+jut+.5u+1=lft x4l-inner_jut; fi dish_serif(2,1,c,1/3,jut,d,1/3,jut); fi % lower left serif if serifs: pickup tiny.nib; else: pickup fine.nib; fi pos4'(stem,0); z4'=z4; numeric curlytail[]; curlytail1=if serifs: vair; else: vair; fi curlytail2=if serifs: hair; else: .8hair; fi curlytail3=if serifs: vair; else: vair; fi pos10(curlytail1,90); x10=.4[x4r,x11]; bot y10l=if serifs: -oo; else: -o; fi pos11(curlytail2,180); rt x11=w+.5u; y11=.3bar_height; pos12(curlytail3,280); x12=x4r+.5u; y12=2y11; pos13(hair,360); x13=.45w; y13=-.75desc_depth; filldraw stroke z4'e{down} % stem ..z10e..{up}z11e...{(-3,-1)}z12e...{(-1,-2)}z13e; % tail penlabels(1,2,3,4,10,11,12,13); endchar; cmchar "Open O-E Ligature"; beginchar(oct"257",13u#,x_height#,0); italcorr .5[bar_height#,x_height#]*slant+.5min(curve#-1.5u#,0); adjust_fit(0,0); numeric left_curve,right_curve; if monospace: right_curve=left_curve=fudged.stem; else: left_curve=max(fine.breadth,hround(curve-2stem_corr)); right_curve=max(tiny.breadth,hround(curve-if serifs:6 else:8 fi\\stem_corr));fi pickup tiny.nib; pos11(right_curve,0); pos12(vair,90); pos13(mfudged.stem,180); y11=good.y bar_height; top y12r=h+vround 1.5oo; y10l=bot y11; rt x11r=hround min(w-.5u,w-u+.5right_curve); lft x13r=hround (.5(w)-.5mfudged.stem); x12=.55[x13,x11]; {{interim superness:=more_super; filldraw stroke super_arc.e(11,12)}}; % right bowl of e y13=.5[y12,y14]; bot y14r=-oo; x14=x12+.25u; if serifs: pos14(vair',270); pos15(mfudged.hair,360); y15=max(good.y(.5bar_height-.9),y14l+vair); x15r=x11r; (x,y14l)=whatever[z14r,z15]; x14l:=min(x,x14l+.5u); filldraw stroke pulled_arc.e(12,13) & pulled_super_arc.e(13,14)(.8superpull) ...{x15-x14,5(y15-y14)}z15e; % left bowl, arc, and terminal of e else: pos14(vair,270); filldraw stroke super_arc.e(12,13) & super_arc.e(13,14); % left bowl and arc of e pickup fine.nib; pos14'(vair,270); z14=z14'; pos15(.5[vair,flare],275); rt x15r=hround(w-.6u); y15r=good.y(y15r+1/3bar_height-y15); y15l:=good.y y15l; x15l:=good.x x15l; filldraw stroke term.e(14',15,right,1,4); fi % terminal y11'r=y10r=y10l+.6[thin_join,vair]; y11'l=y10l; x11'l=x11'r=x11; x10l=x10r=x13; fill stroke z10e--z11'e; % crossbar numeric BH; BH=if Times_Compat:.5613h else: bar_height fi; % Open O pickup fine.nib; pos2(vair',-90); pos4(vair',90); pos3(mfudged.stem,0); z3=z13; x2=x4=.5[.5u,x3]; bot y2r=vround(-1.5oo); top y4r=h+oo; if serifs: pos1(hair,-180); pos0(flare,-180); y1=max(h-BH-.5flare-2vair'-2,h-.9[BH,h]+.5flare); lft x1r=hround(.7u); bulb(2,1,0); % bulb pos5(hair,-180); lft x5r=hround(.5u); y5=min(h-good.y(.5BH-.9),y4l-vair'); filldraw stroke pulled_super_arc.e(2,3)(.7superpull) & pulled_super_arc.e(3,4)(.5superpull) ..tension .9 and 1..{x5-x4,5(y5-y4)}z5e; % arc and lower terminal else: pos1(4/7[vair',flare],-100); lft x1r=hround(.6u); bot y1r=h-vround .82[BH,top y4r]; filldraw stroke term.e(2,1,left,.8,4); % upper terminal pos5(.6[vair',flare],95); lft x5r=hround(.5u); y5r=good.y(h+y5r-1/3BH-y5); y5l:=good.y y5l; x5l:=good.x x5l; filldraw stroke pulled_super_arc.e(2,3)(.7superpull) & pulled_super_arc.e(3,4)(.5superpull) ..tension .9 and 1..z5e; fi % arc and lower terminal penlabels(1,2,3,4,10,11,12,13,14,15); endchar; cmchar "Omega"; beginchar(oct"260",CT(11u#,12u#),x_height#,0); % 2003/03/16 italcorr .5x_height#*slant; adjust_fit(0,0); pickup fine.nib; pos2(curve,-180); lft x2r=hround.5u; y2=y8=.45x_height; y4=y6=vround.6h; y1r=h+oo; x1=x5=.5w; pos1(vair,90); pos3(vair,-90); pos4(hair,0); pos5(vair,90); pos6(hair,180); pos7(vair,270); pos8(curve,360); bot y3r=bot y7r=-oo; top y5r=vround(.1[y4,h]+.5vair); x3=.5[x2,x4]; x7=.5[x6,x8]; rt x8r=hround(w-.5u); x5=.5[x4,x6]; rt x4r-lft x6r=min(stem,2hair)+2eps; if x4l