X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=flower%2Finclude%2Frational.hh;h=ff149008058e7a77e235c104a3cafb274bc0b367;hb=8cab78caa0db1ba14f2e52e4c1ddbb541ea0e5cb;hp=361b075f7e5b2ed22aa650f723aa91640ca5a268;hpb=c659cb200486c2f908703696a1b2873e78c8160a;p=lilypond.git diff --git a/flower/include/rational.hh b/flower/include/rational.hh index 361b075f7e..ff14900805 100644 --- a/flower/include/rational.hh +++ b/flower/include/rational.hh @@ -3,19 +3,21 @@ source file of the Flower Library - (c) 1997--2004 Han-Wen Nienhuys + (c) 1997--2009 Han-Wen Nienhuys */ - #ifndef RATIONAL_HH #define RATIONAL_HH -#include "string.hh" +#include "flower-proto.hh" +#include "std-string.hh" +#include /** Rational numbers. Included is support for + and - infinity. - */ -class Rational { +*/ +class Rational +{ /** Sign of rational. -2, .. 2 @@ -23,62 +25,72 @@ 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 (); + U64 num_, den_; + void normalize (); void copy (Rational const &); public: void set_infinite (int sign); bool is_infinity () const; void invert (); - int num () const { return sign_ * num_; } - int den () const { return den_; } + I64 numerator () const { return sign_ * num_; } + I64 denominator () const { return den_; } + I64 num () const { return numerator (); } + I64 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) { + Rational (I64); + Rational (U64); + explicit Rational (I64, I64); + 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_; @@ -87,9 +99,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 (U64_MAX); #endif // RATIONAL_HH