X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=flower%2Finclude%2Frational.hh;h=969d0121470db512f58f342046fd5293c735ad29;hb=84dfa31321b6f0c3224ed8c586b64ec97e88402f;hp=8ac80fb1246a0b507f6d842a1d3d230e2f8b24fc;hpb=91e7cbaa6e54e004365d28e0f10c9362a7f13320;p=lilypond.git diff --git a/flower/include/rational.hh b/flower/include/rational.hh index 8ac80fb124..969d012147 100644 --- a/flower/include/rational.hh +++ b/flower/include/rational.hh @@ -3,19 +3,20 @@ source file of the Flower Library - (c) 1997--2005 Han-Wen Nienhuys + (c) 1997--2007 Han-Wen Nienhuys */ - #ifndef RATIONAL_HH #define RATIONAL_HH -#include "string.hh" +#include "std-string.hh" +#include /** Rational numbers. Included is support for + and - infinity. - */ -class Rational { +*/ +class Rational +{ /** Sign of rational. -2, .. 2 @@ -23,10 +24,10 @@ class Rational { -2,2 is - and + infinity. -1,1 is negative and positive. 0 if *this is zero. - */ + */ int sign_; unsigned int num_, den_; - void normalise (); + void normalize (); void copy (Rational const &); public: @@ -35,52 +36,58 @@ public: void invert (); int numerator () const { return sign_ * num_; } int denominator () const { return den_; } - int num () const { return numerator(); } - int den () const { return denominator(); } + int num () const { return numerator (); } + int den () const { return denominator (); } Rational trunc_rat () const; Rational div_rat (Rational) const; Rational mod_rat (Rational) const; + Rational abs () const; void negate (); - // operator bool () const; int to_int () const; - operator double () const; + + operator double () const { return to_double (); } + double to_double () const; + Rational operator - () const; /** - Initialize to 0. - */ + Initialize to 0. + */ Rational (); Rational (int); - Rational (int, int); - Rational (double); - Rational (Rational const&r) { copy (r);} - Rational &operator = (Rational const &r) { + explicit Rational (int, int); + explicit Rational (double); + Rational (Rational const &r) { copy (r);} + Rational &operator = (Rational const &r) + { copy (r); return *this; } Rational &operator *= (Rational); - Rational &operator /= (Rational); + Rational &operator /= (Rational); Rational &operator += (Rational); Rational &operator -= (Rational); Rational &operator %= (Rational); - static int compare (Rational const&, Rational const&); + static int compare (Rational const &, Rational const &); int sign () const; - String to_string () const; + string to_string () const; }; -IMPLEMENT_ARITHMETIC_OPERATOR (Rational, / ); -IMPLEMENT_ARITHMETIC_OPERATOR (Rational, + ); -IMPLEMENT_ARITHMETIC_OPERATOR (Rational, * ); -IMPLEMENT_ARITHMETIC_OPERATOR (Rational, - ); -IMPLEMENT_ARITHMETIC_OPERATOR (Rational, % ); +#include "arithmetic-operator.hh" + +IMPLEMENT_ARITHMETIC_OPERATOR (Rational, /); +IMPLEMENT_ARITHMETIC_OPERATOR (Rational, +); +IMPLEMENT_ARITHMETIC_OPERATOR (Rational, *); +IMPLEMENT_ARITHMETIC_OPERATOR (Rational, -); +IMPLEMENT_ARITHMETIC_OPERATOR (Rational, %); -INSTANTIATE_COMPARE (Rational const&, Rational::compare); +INSTANTIATE_COMPARE (Rational const &, Rational::compare); -int compare (Rational const&,Rational const&); +int compare (Rational const &, Rational const &); int sign (Rational r); inline void -Rational::copy (Rational const&r) +Rational::copy (Rational const &r) { sign_ = r.sign_; num_ = r.num_; @@ -89,9 +96,9 @@ Rational::copy (Rational const&r) #if 0 ostream & -operator << (ostream &, Rational); +operator << (ostream &, Rational); #endif -const Rational infinity_rat = INT_MAX; +const Rational infinity_rat (INT_MAX); #endif // RATIONAL_HH