X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=flower%2Finclude%2Fdirection.hh;h=50c41a4ab46f5b28b50135ffde9fced8639149e3;hb=d61cf3bbdb1c6670a127ba3baddf2f04d3e34fd3;hp=0572f786ce8ad62d2e31215ae96583f2ac19ec2f;hpb=7e72a1e50e94a7f9738d62599de79fe7745f600c;p=lilypond.git diff --git a/flower/include/direction.hh b/flower/include/direction.hh index 0572f786ce..50c41a4ab4 100644 --- a/flower/include/direction.hh +++ b/flower/include/direction.hh @@ -1,30 +1,51 @@ /* - direction.hh -- declare Direction + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 1997--2012 Han-Wen Nienhuys - (c) 1997--2004 Han-Wen Nienhuys -*/ + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . +*/ #ifndef DIRECTION_HH #define DIRECTION_HH -#include "axes.hh" +#include "axis.hh" -enum Direction +enum Direction { - UP=1, - DOWN=-1, - LEFT=-1, - RIGHT=1, - MIN=-1, - MAX=1, - CENTER=0, - SMALLER=-1, - BIGGER=1, + UP = 1, + DOWN = -1, + LEFT = -1, + RIGHT = 1, + MIN = -1, + MAX = 1, + CENTER = 0, + SMALLER = -1, + BIGGER = 1, START = -1, STOP = 1, + + /* + This is necessary to safely write loops, + since + + dir <= RIGHT + + is otherwise transformed into true unconditionally. + */ + DIRECTION_LIMIT = 2, + DIRECTION_NEG_LIMIT = -2, }; inline Direction @@ -41,10 +62,11 @@ operator - (Direction const d) // huh? inline Direction -flip (Direction *i) { +flip (Direction *i) +{ if (*i == (Direction)1) - *i = (Direction)-1; - else if (*i == (Direction)-1) + *i = (Direction) - 1; + else if (*i == (Direction) - 1) *i = (Direction)1; return *i; } @@ -52,8 +74,14 @@ flip (Direction *i) { /** if d > 0: the max operator if d < 0: the min operator - */ -template T minmax (Direction d, T, T); +*/ +template T minmax (Direction d, T a, T b) +{ + if (d == UP) + return max (a, b); + else + return min (a, b); +} // String direction_string (Direction, Axis);