fix(library/expr_lt): fix bug when using hash codes
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
b0322787ff
commit
8e56726116
1 changed files with 4 additions and 1 deletions
|
@ -12,7 +12,10 @@ bool is_lt(expr const & a, expr const & b, bool use_hash) {
|
||||||
if (!a && b) return true; // the null expression is the smallest one
|
if (!a && b) return true; // the null expression is the smallest one
|
||||||
if (a && !b) return false;
|
if (a && !b) return false;
|
||||||
if (a.kind() != b.kind()) return a.kind() < b.kind();
|
if (a.kind() != b.kind()) return a.kind() < b.kind();
|
||||||
if (use_hash && a.hash() < b.hash()) return true;
|
if (use_hash) {
|
||||||
|
if (a.hash() < b.hash()) return true;
|
||||||
|
if (a.hash() > b.hash()) return false;
|
||||||
|
}
|
||||||
if (a == b) return false;
|
if (a == b) return false;
|
||||||
if (is_var(a)) return var_idx(a) < var_idx(b);
|
if (is_var(a)) return var_idx(a) < var_idx(b);
|
||||||
switch (a.kind()) {
|
switch (a.kind()) {
|
||||||
|
|
Loading…
Reference in a new issue