3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-16 13:58:45 +00:00
z3/src/smt/uses_theory.cpp
Nikolaj Bjorner b19f94ae5b make include paths uniformly use path relative to src. #534
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
2017-07-31 13:24:11 -07:00

50 lines
906 B
C++

/*++
Copyright (c) 2006 Microsoft Corporation
Module Name:
uses_theory.cpp
Abstract:
<abstract>
Author:
Leonardo de Moura (leonardo) 2008-10-21.
Revision History:
--*/
#include "smt/uses_theory.h"
#include "ast/for_each_expr.h"
bool uses_theory(expr * n, family_id fid) {
expr_mark visited;
return uses_theory(n, fid, visited);
}
namespace uses_theory_ns {
struct found {};
struct proc {
family_id m_fid;
proc(family_id fid):m_fid(fid) {}
void operator()(var * n) {}
void operator()(app * n) { if (n->get_family_id() == m_fid) throw found(); }
void operator()(quantifier * n) {}
};
};
bool uses_theory(expr * n, family_id fid, expr_mark & visited) {
uses_theory_ns::proc p(fid);
try {
for_each_expr(p, visited, n);
}
catch (uses_theory_ns::found) {
return true;
}
return false;
}