Fix ambiguous overloads. Improve == test for sexprs. Remove redundant code

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-07-21 14:25:56 -07:00
parent 80d8fdbf48
commit b8315e5593
8 changed files with 125 additions and 58 deletions

View file

@ -22,8 +22,8 @@ public:
mpbq():m_k(0) {} mpbq():m_k(0) {}
mpbq(mpbq const & v):m_num(v.m_num), m_k(v.m_k) {} mpbq(mpbq const & v):m_num(v.m_num), m_k(v.m_k) {}
mpbq(mpbq && v); mpbq(mpbq && v);
mpbq(mpz const & v):m_num(v), m_k(0) {} explicit mpbq(mpz const & v):m_num(v), m_k(0) {}
mpbq(int n):m_num(n), m_k(0) {} explicit mpbq(int n):m_num(n), m_k(0) {}
mpbq(int n, unsigned k):m_num(n), m_k(k) { normalize(); } mpbq(int n, unsigned k):m_num(n), m_k(k) { normalize(); }
~mpbq() {} ~mpbq() {}
@ -133,28 +133,22 @@ public:
mpbq & operator*=(int a); mpbq & operator*=(int a);
friend mpbq operator+(mpbq a, mpbq const & b) { return a += b; } friend mpbq operator+(mpbq a, mpbq const & b) { return a += b; }
friend mpbq operator+(mpbq a, mpz const & b) { return a += b; } template<typename T>
friend mpbq operator+(mpbq a, unsigned b) { return a += b; } friend mpbq operator+(mpbq a, T const & b) { return a += mpbq(b); }
friend mpbq operator+(mpbq a, int b) { return a += b; } template<typename T>
friend mpbq operator+(mpz const & a, mpbq b) { return b += a; } friend mpbq operator+(T const & a, mpbq b) { return b += mpbq(a); }
friend mpbq operator+(unsigned a, mpbq b) { return b += a; }
friend mpbq operator+(int a, mpbq b) { return b += a; }
friend mpbq operator-(mpbq a, mpbq const & b) { return a -= b; } friend mpbq operator-(mpbq a, mpbq const & b) { return a -= b; }
friend mpbq operator-(mpbq a, mpz const & b) { return a -= b; } template<typename T>
friend mpbq operator-(mpbq a, unsigned b) { return a -= b; } friend mpbq operator-(mpbq a, T const & b) { return a -= mbpq(b); }
friend mpbq operator-(mpbq a, int b) { return a -= b; } template<typename T>
friend mpbq operator-(mpz const & a, mpbq b) { b.neg(); return b += a; } friend mpbq operator-(T const & a, mpbq b) { b.neg(); return b += mpbq(a); }
friend mpbq operator-(unsigned a, mpbq b) { b.neg(); return b += a; }
friend mpbq operator-(int a, mpbq b) { b.neg(); return b += a; }
friend mpbq operator*(mpbq a, mpbq const & b) { return a *= b; } friend mpbq operator*(mpbq a, mpbq const & b) { return a *= b; }
friend mpbq operator*(mpbq a, mpz const & b) { return a *= b; } template<typename T>
friend mpbq operator*(mpbq a, unsigned b) { return a *= b; } friend mpbq operator*(mpbq a, mpz const & b) { return a *= mpbq(b); }
friend mpbq operator*(mpbq a, int b) { return a *= b; } template<typename T>
friend mpbq operator*(mpz const & a, mpbq b) { return b *= a; } friend mpbq operator*(T const & a, mpbq b) { return b *= mpbq(a); }
friend mpbq operator*(unsigned a, mpbq b) { return b *= a; }
friend mpbq operator*(int a, mpbq b) { return b *= a; }
mpbq & operator++() { return operator+=(1); } mpbq & operator++() { return operator+=(1); }
mpbq operator++(int) { mpbq r(*this); ++(*this); return r; } mpbq operator++(int) { mpbq r(*this); ++(*this); return r; }

View file

@ -29,21 +29,16 @@ public:
mpq & operator=(long int v) { mpq_set_si(m_val, v, 1); return *this; } mpq & operator=(long int v) { mpq_set_si(m_val, v, 1); return *this; }
mpq & operator=(unsigned int v) { return operator=(static_cast<unsigned long int>(v)); } mpq & operator=(unsigned int v) { return operator=(static_cast<unsigned long int>(v)); }
mpq & operator=(int v) { return operator=(static_cast<long int>(v)); } mpq & operator=(int v) { return operator=(static_cast<long int>(v)); }
mpq & operator=(double v) { mpq_set_d(m_val, v); return *this; }
mpq() { mpq_init(m_val); } mpq() { mpq_init(m_val); }
mpq(mpq const & v):mpq() { operator=(v); } mpq(mpq const & v):mpq() { operator=(v); }
mpq(mpz const & v):mpq() { operator=(v); }
mpq(mpq && s):mpq() { mpq_swap(m_val, s.m_val); } mpq(mpq && s):mpq() { mpq_swap(m_val, s.m_val); }
mpq(char const * v):mpq() { operator=(v); } template<typename T> explicit mpq(T const & v):mpq() { operator=(v); }
mpq(unsigned long int v):mpq() { operator=(v); }
mpq(long int v):mpq() { operator=(v); }
mpq(unsigned int v):mpq() { operator=(v); }
mpq(int v):mpq() { operator=(v); }
mpq(unsigned long int n, unsigned long int d):mpq() { mpq_set_ui(m_val, n, d); mpq_canonicalize(m_val); } mpq(unsigned long int n, unsigned long int d):mpq() { mpq_set_ui(m_val, n, d); mpq_canonicalize(m_val); }
mpq(long int n, long int d):mpq() { mpq_set_si(m_val, n, d); mpq_canonicalize(m_val); } mpq(long int n, long int d):mpq() { mpq_set_si(m_val, n, d); mpq_canonicalize(m_val); }
mpq(unsigned int n, unsigned int d):mpq() { mpq_set_ui(m_val, n, d); mpq_canonicalize(m_val); } mpq(unsigned int n, unsigned int d):mpq() { mpq_set_ui(m_val, n, d); mpq_canonicalize(m_val); }
mpq(int n, int d):mpq() { mpq_set_si(m_val, n, d); mpq_canonicalize(m_val); } mpq(int n, int d):mpq() { mpq_set_si(m_val, n, d); mpq_canonicalize(m_val); }
mpq(double v):mpq() { mpq_set_d(m_val, v); }
~mpq() { mpq_clear(m_val); } ~mpq() { mpq_clear(m_val); }
unsigned hash() const { return static_cast<unsigned>(mpz_get_si(mpq_numref(m_val))); } unsigned hash() const { return static_cast<unsigned>(mpz_get_si(mpq_numref(m_val))); }

View file

@ -22,11 +22,11 @@ class mpz {
mpz(__mpz_struct const * v) { mpz_init_set(m_val, v); } mpz(__mpz_struct const * v) { mpz_init_set(m_val, v); }
public: public:
mpz() { mpz_init(m_val); } mpz() { mpz_init(m_val); }
mpz(char const * v) { mpz_init_set_str(m_val, const_cast<char*>(v), 10); } explicit mpz(char const * v) { mpz_init_set_str(m_val, const_cast<char*>(v), 10); }
mpz(unsigned long int v) { mpz_init_set_ui(m_val, v); } explicit mpz(unsigned long int v) { mpz_init_set_ui(m_val, v); }
mpz(long int v) { mpz_init_set_si(m_val, v); } explicit mpz(long int v) { mpz_init_set_si(m_val, v); }
mpz(unsigned int v) { mpz_init_set_ui(m_val, v); } explicit mpz(unsigned int v) { mpz_init_set_ui(m_val, v); }
mpz(int v) { mpz_init_set_si(m_val, v); } explicit mpz(int v) { mpz_init_set_si(m_val, v); }
mpz(mpz const & s) { mpz_init_set(m_val, s.m_val); } mpz(mpz const & s) { mpz_init_set(m_val, s.m_val); }
mpz(mpz && s):mpz() { mpz_swap(m_val, s.m_val); } mpz(mpz && s):mpz() { mpz_swap(m_val, s.m_val); }
~mpz() { mpz_clear(m_val); } ~mpz() { mpz_clear(m_val); }

View file

@ -172,8 +172,8 @@ bool operator==(sexpr const & a, sexpr const & b) {
sexpr::kind kb = b.get_kind(); sexpr::kind kb = b.get_kind();
if (ka != kb) if (ka != kb)
return false; return false;
// if (a.hash() != b.hash()) if (a.hash() != b.hash())
// return false; return false;
switch (ka) { switch (ka) {
case sexpr::kind::NIL: return true; case sexpr::kind::NIL: return true;
case sexpr::kind::STRING: return to_string(a) == to_string(b); case sexpr::kind::STRING: return to_string(a) == to_string(b);
@ -224,4 +224,10 @@ std::ostream & operator<<(std::ostream & out, sexpr const & s) {
return out; return out;
} }
bool operator==(sexpr const & a, name const & b) { return is_name(a) && to_name(a) == b; }
bool operator==(sexpr const & a, mpz const & b) { return is_mpz(a) && to_mpz(a) == b; }
bool operator==(sexpr const & a, mpq const & b) { return is_mpq(a) && to_mpq(a) == b; }
} }
void pp(lean::sexpr const & n) { std::cout << n << "\n"; }

View file

@ -27,21 +27,18 @@ class sexpr {
public: public:
enum class kind { NIL, STRING, INT, DOUBLE, NAME, MPZ, MPQ, CONS }; enum class kind { NIL, STRING, INT, DOUBLE, NAME, MPZ, MPQ, CONS };
sexpr():m_ptr(nullptr) {} sexpr():m_ptr(nullptr) {}
sexpr(char const * v); explicit sexpr(char const * v);
sexpr(std::string const & v); explicit sexpr(std::string const & v);
sexpr(int v); explicit sexpr(int v);
sexpr(double v); explicit sexpr(double v);
sexpr(name const & v); explicit sexpr(name const & v);
sexpr(mpz const & v); explicit sexpr(mpz const & v);
sexpr(mpq const & v); explicit sexpr(mpq const & v);
sexpr(sexpr const & h, sexpr const & t); sexpr(sexpr const & h, sexpr const & t);
sexpr(char const * v, sexpr const & t):sexpr(sexpr(v), t) {} template<typename T>
sexpr(std::string const & v, sexpr const & t):sexpr(sexpr(v), t) {} sexpr(T const & h, sexpr const & t):sexpr(sexpr(h), t) {}
sexpr(int v, sexpr const & t):sexpr(sexpr(v), t) {} template<typename T1, typename T2>
sexpr(double v, sexpr const & t):sexpr(sexpr(v), t) {} sexpr(T1 const & h, T2 const & t):sexpr(sexpr(h), sexpr(t)) {}
sexpr(name const & v, sexpr const & t):sexpr(sexpr(v), t) {}
sexpr(mpz const & v, sexpr const & t):sexpr(sexpr(v), t) {}
sexpr(mpq const & v, sexpr const & t):sexpr(sexpr(v), t) {}
sexpr(sexpr const & s); sexpr(sexpr const & s);
sexpr(sexpr && s); sexpr(sexpr && s);
template<typename T> template<typename T>
@ -71,11 +68,8 @@ public:
sexpr & operator=(sexpr const & s); sexpr & operator=(sexpr const & s);
sexpr & operator=(sexpr&& s); sexpr & operator=(sexpr&& s);
sexpr & operator=(char const * v) { return operator=(sexpr(v)); } template<typename T>
sexpr & operator=(std::string const & v) { return operator=(sexpr(v)); } sexpr & operator=(T const & v) { return operator=(sexpr(v)); }
sexpr & operator=(int v) { return operator=(sexpr(v)); }
sexpr & operator=(mpz const & v) { return operator=(sexpr(v)); }
sexpr & operator=(mpq const & v) { return operator=(sexpr(v)); }
friend void swap(sexpr & a, sexpr & b) { std::swap(a.m_ptr, b.m_ptr); } friend void swap(sexpr & a, sexpr & b) { std::swap(a.m_ptr, b.m_ptr); }
@ -115,10 +109,13 @@ bool operator==(sexpr const & a, sexpr const & b);
inline bool operator==(sexpr const & a, int b) { return is_int(a) && to_int(a) == b; } inline bool operator==(sexpr const & a, int b) { return is_int(a) && to_int(a) == b; }
inline bool operator==(sexpr const & a, double b) { return is_double(a) && to_double(a) == b; } inline bool operator==(sexpr const & a, double b) { return is_double(a) && to_double(a) == b; }
inline bool operator==(sexpr const & a, std::string const & b) { return is_string(a) && to_string(a) == b; } inline bool operator==(sexpr const & a, std::string const & b) { return is_string(a) && to_string(a) == b; }
inline bool operator==(sexpr const & a, name const & b) { return is_name(a) && to_name(a) == b; } bool operator==(sexpr const & a, name const & b);
inline bool operator==(sexpr const & a, mpz const & b) { return is_mpz(a) && to_mpz(a) == b; } bool operator==(sexpr const & a, mpz const & b);
inline bool operator==(sexpr const & a, mpq const & b) { return is_mpq(a) && to_mpq(a) == b; } bool operator==(sexpr const & a, mpq const & b);
template<typename T> inline bool operator==(T const & a, sexpr const & b) { return b == a; }
inline bool operator!=(sexpr const & a, sexpr const & b) { return !(a == b); }
template<typename T> inline bool operator!=(sexpr const & a, T const & b) { return !(a == b); } template<typename T> inline bool operator!=(sexpr const & a, T const & b) { return !(a == b); }
template<typename T> inline bool operator!=(T const & a, sexpr const & b) { return !(a == b); }
bool operator<(sexpr const & a, sexpr const & b); bool operator<(sexpr const & a, sexpr const & b);
inline bool operator>(sexpr const & a, sexpr const & b) { return b < a; } inline bool operator>(sexpr const & a, sexpr const & b) { return b < a; }
inline bool operator<=(sexpr const & a, sexpr const & b) { return !(a > b); } inline bool operator<=(sexpr const & a, sexpr const & b) { return !(a > b); }

View file

@ -91,11 +91,48 @@ static void tst4() {
lean_assert(a == mpq(2,5)); lean_assert(a == mpq(2,5));
} }
static void tst5() {
mpq a;
a = 1;
lean_assert(a == mpq(1));
lean_assert(a <= 1);
lean_assert(a < 2);
lean_assert(a > 0);
lean_assert(a >= 0);
lean_assert(a >= 1);
lean_assert(!(a >= 2));
lean_assert(a == 1);
lean_assert(1 == a);
lean_assert(a != 2);
lean_assert(!(a == 3));
lean_assert(a < mpz(2));
lean_assert(a <= mpz(1));
lean_assert(a > 0);
lean_assert(a <= 1u);
lean_assert(a < 2u);
lean_assert(a > 0u);
lean_assert(a >= 1u);
lean_assert(a == 1u);
lean_assert(1u >= a);
lean_assert(2u > a);
a = "1/3";
lean_assert(a == mpq(1,3));
a = 2.0;
lean_assert(a == mpq(2));
a = mpz(10);
lean_assert(a == mpq(10));
lean_assert(a >= mpz(10));
lean_assert(mpz(10) <= a);
lean_assert(mpz(10) >= a);
lean_assert(mpz(10) == a);
}
int main() { int main() {
continue_on_violation(true); continue_on_violation(true);
tst1(); tst1();
tst2(); tst2();
tst3(); tst3();
tst4(); tst4();
tst5();
return has_violations() ? 1 : 0; return has_violations() ? 1 : 0;
} }

View file

@ -71,8 +71,46 @@ static void tst1() {
lean_assert(!contains(sexpr{10,20,-2,0,10}, [](sexpr e) { return to_int(e) < -10; })); lean_assert(!contains(sexpr{10,20,-2,0,10}, [](sexpr e) { return to_int(e) < -10; }));
} }
void tst2() {
sexpr a;
a = 2;
lean_assert(a == sexpr(2));
lean_assert(a == 2);
lean_assert(2 == a);
a = 0.125;
lean_assert(a == sexpr(0.125));
lean_assert(a == 0.125);
lean_assert(0.125 == a);
a = "foo";
lean_assert(a == sexpr("foo"));
lean_assert(a == "foo");
lean_assert("foo" == a);
lean_assert(a != "blah");
lean_assert(a != name("foo"));
lean_assert(std::string("foo") == a);
lean_assert(a == std::string("foo"));
a = name(name("foo"), 1);
lean_assert(a == sexpr(name(name("foo"), 1)));
lean_assert(a == name(name("foo"), 1));
lean_assert(name(name("foo"), 1) == a);
a = mpq(1,3);
lean_assert(a == sexpr(mpq(1,3)));
lean_assert(a == mpq(1,3));
lean_assert(mpq(1, 3) == a);
lean_assert(mpq(2, 3) != a);
a = power(mpz(2),100);
lean_assert(a == sexpr(power(mpz(2), 100)));
lean_assert(a == power(mpz(2), 100));
lean_assert(power(mpz(2), 100) == a);
lean_assert(mpq(power(mpz(2), 100)) != a);
lean_assert(sexpr(1, 2) != sexpr(2, 1));
lean_assert(sexpr(1, 2) != sexpr(1, sexpr(2, nil())));
lean_assert(sexpr(1, 2) == sexpr(1, sexpr(2)));
}
int main() { int main() {
continue_on_violation(true); continue_on_violation(true);
tst1(); tst1();
tst2();
return has_violations() ? 1 : 0; return has_violations() ? 1 : 0;
} }

View file

@ -21,8 +21,8 @@ class name {
name(imp * p); name(imp * p);
public: public:
name(); name();
name(char const * name); explicit name(char const * name);
name(unsigned k); explicit name(unsigned k);
name(name const & prefix, char const * name); name(name const & prefix, char const * name);
name(name const & prefix, unsigned k); name(name const & prefix, unsigned k);
name(name const & other); name(name const & other);