input feta-autometric; input feta-macros; input feta-params; fet_beginfont("feta-braces", 16); mode_setup; staffsize#:=16pt#; save code; code := -1; def abc_encode_int (expr i) = if i > 0: abc_encode_int(i div 26)&char(65 + i mod 26) else: "A" fi enddef ; def draw_brace (expr height_sharp, width_sharp, slt_sharp) = save pendir, height, width, thin, thick, slt; save penangle; height# := height_sharp; width# := width_sharp; slt# := slt_sharp; fet_beginchar("brace number "&(decimal code), "brace"&abc_encode_int(code), "brace"&abc_encode_int (code)) set_char_box (0, width#, height#/2, height#/2); define_pixels (height, width, slt); thin = 2 slt; thick = .5 width; z2 = .5 [z1, z3]; y3l = y1 + height/2; x3 = x1 + width; y1 =0; x3 = - width / 2; pair pendir; pendir = unitvector(x3 - x1, y3l/6 - y1); penangle = angle pendir - 90; penpos3(thin, penangle); penpos2(thick, angle(z3 -z1) -90 ); penpos1(2/3 thin, penangle); penlabels(1,2,3); fill z2r .. simple_serif (z3r, z3l, 90) .. z2l .. simple_serif (z1l, z1r, 90) ..cycle; addto currentpicture also currentpicture yscaled -1; fet_endchar; enddef; save stafflinethickness; save increment; stafflinethickness := 0.5pt#; increment := 0.5pt#; y := 10pt#; for i := 0 step 1 until font_count: %% We can't store more than 64 (65?) height dimensions in a TFM %% file, so we make small files. for j := 0 step 1 until 63: % message "l: "&decimal l; % note: define_pixels (x) multiplies x by hppp, % must never get bigger than infinity y := min (y + increment, infinity/hppp - 1); % x should be about one staff space, taking brace to have % default height of 3 staffs, this yields height / 3 / 4 = 12 % but 15 looks better x := y / 15; increment := x / 10; stafflinethickness := min (0.5pt#, y/150); if i = font_count: draw_brace (y, x, stafflinethickness); fi endfor; endfor fet_endfont("feta-braces");