define_pixels(block_rest_y, block_rest_x);
-def block_rest=
- pickup pencircle scaled blot_diameter;
-
- bot y1 = 0;
- top y2 = block_rest_y;
- y3 = y2;
- y4 = y1;
-
- rt x1 = block_rest_x;
- x2 = x1;
- lft x3 = 0;
- x4 = x3;
- save p;
- path p;
- p:=z1 -- z2 -- z3 -- z4 -- cycle;
-
- filldraw p;
-enddef;
+def block_rest =
+ draw_block ((0,0), (block_rest_x, block_rest_y));
+ enddef;
fet_beginchar( "whole rest", "0", "wholerest");
set_char_box(0, block_rest_x#,
superellipse((a,err_x),(-err_y,b),(-a,-err_x),(err_y,-b),super);
enddef;
+% stolen from feta-eindelijk, but still
+% FIXME: too high
+def draw_block (expr bottom_left, top_right) =
+ pickup pencircle scaled blot_diameter;
+
+ begingroup;
+ save x,y;
+ bot y1 = ypart bottom_left;
+ top y2 = ypart top_right;
+ y3 = y2;
+ y4 = y1;
+
+ rt x1 = xpart top_right;
+ x2 = x1;
+ lft x3 = xpart bottom_left;
+ x4 = x3;
+
+ filldraw z1--z2--z3--z4--cycle;
+ endgroup;
+ enddef;
+
def draw_brush(expr a,w,b,v) =
save x,y;
z1=a; z2=b;
fill z3r{z3r-z5l}..z4l..{z5r-z3l}z3l..z5r{z5r-z3l}..z6l..{z3r-z5l}z5l..cycle;
enddef;
+def draw_flare(expr pos,alpha,beta,line,flare) =
+ begingroup;
+ clearxy;
+ penpos1(line,180+beta+alpha);
+ z1r=pos;
+ penpos2(flare,180+beta+alpha);
+ z2=z3;
+ penpos3(flare,0+alpha);
+ z3l=z1r+(1/2+0.43)*flare*dir(alpha+beta);
+ z4=z2r-1/6flare*dir(alpha);
+ penlabels(1,2,3,4);
+ pickup pencircle;
+ save t; t=0.833;
+ fill z1r{dir(alpha)}..z3r{dir(180+alpha-beta)}..z2l{dir(alpha+180)}
+ ..z3l{dir(180+alpha+beta)}..tension t
+ ..z4{dir(180+alpha+beta)}..z1l{dir(alpha+180)}..cycle;
+ endgroup;
+ enddef;
+
def brush(expr a,w,b,v) =
begingroup;
draw_brush(a,w,b,v);
endgroup;
enddef;
-def draw_flare(expr pos,alpha,beta,line,flare) =
- begingroup;
- clearxy;
- penpos1(line,180+beta+alpha);
- z1r=pos;
- penpos2(flare,180+beta+alpha);
- z2=z3;
- penpos3(flare,0+alpha);
- z3l=z1r+(1/2+0.43)*flare*dir(alpha+beta);
- z4=z2r-1/6flare*dir(alpha);
- penlabels(1,2,3,4);
- pickup pencircle;
- save t; t=0.833;
- fill z1r{dir(alpha)}..z3r{dir(180+alpha-beta)}..z2l{dir(alpha+180)}
- ..z3l{dir(180+alpha+beta)}..tension t..z4{dir(180+alpha+beta)}..z1l{dir(alpha+180)}..cycle;
- endgroup;
- enddef;
-
def draw_six =
set_char_box(0, 2thick#+2thin#, 0, height#);
message "w:"&decimal w;
Moment
Mudela_note::duration_mom ()
{
-// ugh
-// return Duration_convert::dur2_mom (duration ());
assert (end_column_l_);
return end_column_l_->at_mom () - at_mom ();
}
if (dur.plet_b ())
str += String (" \\plet 1/1;");
+ /*
+ note of zero duration is nonsense,
+ but let's output anyway for convenient debugging
+ */
+ if (!duration_mom ())
+ return String ("\n% ") + str + "\n";
+
return str + " ";
}