CBMC
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
smt_commands.cpp
Go to the documentation of this file.
1// Author: Diffblue Ltd.
2
3#include "smt_commands.h"
4
5#include <util/range.h>
6
7#include <algorithm>
8
9// Define the irep_idts for commands.
10#define COMMAND_ID(the_id) \
11 const irep_idt ID_smt_##the_id##_command{"smt_" #the_id "_command"};
12#include "smt_commands.def"
13#undef COMMAND_ID
14
15bool smt_commandt::operator==(const smt_commandt &other) const
16{
17 return irept::operator==(other);
18}
19
20bool smt_commandt::operator!=(const smt_commandt &other) const
21{
22 return !(*this == other);
23}
24
27{
29 condition.get_sort() == smt_bool_sortt{},
30 "Only terms with boolean sorts can be asserted.");
31 set(ID_cond, upcast(std::move(condition)));
32}
33
35{
36 return downcast(find(ID_cond));
37}
38
43
45 smt_identifier_termt identifier,
46 std::vector<smt_sortt> parameter_sorts)
48{
50 std::transform(
51 std::make_move_iterator(parameter_sorts.begin()),
52 std::make_move_iterator(parameter_sorts.end()),
53 std::back_inserter(get_sub()),
55 return sort_storert::upcast(std::move(parameter_sort));
56 });
57}
58
64
66{
67 return identifier().get_sort();
68}
69
70std::vector<std::reference_wrapper<const smt_sortt>>
72{
73 return make_range(get_sub()).map([](const irept &parameter_sort) {
74 return std::cref(sort_storert::downcast(parameter_sort));
75 });
76}
77
81
83 irep_idt identifier,
84 std::vector<smt_identifier_termt> parameters,
85 smt_termt definition)
87{
88 set(
90 upcast(smt_identifier_termt{std::move(identifier), definition.get_sort()}));
91 std::transform(
92 std::make_move_iterator(parameters.begin()),
93 std::make_move_iterator(parameters.end()),
94 std::back_inserter(get_sub()),
96 return upcast(std::move(parameter));
97 });
98 set(ID_code, upcast(std::move(definition)));
99}
100
106
107std::vector<std::reference_wrapper<const smt_identifier_termt>>
109{
110 return make_range(get_sub()).map([](const irept &parameter) {
111 return std::cref(
112 static_cast<const smt_identifier_termt &>(downcast((parameter))));
113 });
114}
115
117{
118 return definition().get_sort();
119}
120
125
131
136
142
144{
145 return get_size_t(ID_value);
146}
147
153
155{
156 return get_size_t(ID_value);
157}
158
164
166{
167 return downcast(find(ID_value));
168}
169
175
177{
178 return downcast(find(ID_value));
179}
180
181template <typename visitort>
182void accept(const smt_commandt &command, const irep_idt &id, visitort &&visitor)
183{
184#define COMMAND_ID(the_id) \
185 if(id == ID_smt_##the_id##_command) \
186 return visitor.visit(static_cast<const smt_##the_id##_commandt &>(command));
187// The include below is marked as nolint because including the same file
188// multiple times is required as part of the x macro pattern.
189#include "smt_commands.def" // NOLINT(build/include)
190#undef COMMAND_ID
192}
193
198
200{
201 ::accept(*this, id(), std::move(visitor));
202}
203
212
215 : _identifier{function_definition.identifier()}
216{
217 const auto parameters = function_definition.parameters();
219 make_range(parameters)
220 .map([](const smt_termt &term) { return term.get_sort(); })
221 .collect<decltype(parameter_sorts)>();
222}
223
228
230 const std::vector<smt_termt> &arguments) const
231{
232 return _identifier.get_sort();
233}
234
236 const std::vector<smt_termt> &arguments) const
237{
238 INVARIANT(
239 parameter_sorts.size() == arguments.size(),
240 "Number of parameters and number of arguments must be the same.");
241 const auto parameter_sort_arguments =
242 make_range(parameter_sorts).zip(make_range(arguments));
244 {
245 INVARIANT(
247 parameter_sort_argument_pair.second.get_sort(),
248 "Sort of argument must have the same sort as the parameter.");
249 }
250}
ait supplies three of the four components needed: an abstract interpreter (in this case handling func...
Definition ai.h:562
dstringt has one field, an unsigned integer no which is an index into a static table of strings.
Definition dstring.h:38
There are a large number of kinds of tree structured or tree-like data in CPROVER.
Definition irep.h:364
bool operator==(const irept &other) const
Definition irep.cpp:133
std::size_t get_size_t(const irep_idt &name) const
Definition irep.cpp:67
const irept & find(const irep_idt &name) const
Definition irep.cpp:93
void set(const irep_idt &name, const irep_idt &value)
Definition irep.h:412
void set_size_t(const irep_idt &name, const std::size_t value)
Definition irep.cpp:82
subt & get_sub()
Definition irep.h:448
smt_assert_commandt(smt_termt condition)
const smt_termt & condition() const
std::vector< smt_sortt > parameter_sorts
irep_idt identifier() const
smt_command_functiont(const smt_declare_function_commandt &function_declaration)
smt_sortt return_sort(const std::vector< smt_termt > &arguments) const
smt_identifier_termt _identifier
void validate(const std::vector< smt_termt > &arguments) const
void accept(smt_command_const_downcast_visitort &) const
bool operator==(const smt_commandt &) const
bool operator!=(const smt_commandt &) const
const smt_identifier_termt & identifier() const
smt_declare_function_commandt(smt_identifier_termt identifier, std::vector< smt_sortt > parameter_sorts)
const smt_sortt & return_sort() const
std::vector< std::reference_wrapper< const smt_sortt > > parameter_sorts() const
const smt_termt & definition() const
const smt_identifier_termt & identifier() const
smt_define_function_commandt(irep_idt identifier, std::vector< smt_identifier_termt > parameters, smt_termt definition)
std::vector< std::reference_wrapper< const smt_identifier_termt > > parameters() const
const smt_sortt & return_sort() const
const smt_termt & descriptor() const
smt_get_value_commandt(smt_termt descriptor)
This constructor constructs the get-value command, such that it stores a single descriptor for which ...
Stores identifiers in unescaped and unquoted form.
Definition smt_terms.h:93
irep_idt identifier() const
Definition smt_terms.cpp:81
static const smt_logict & downcast(const irept &)
Definition smt_logics.h:59
static irept upcast(smt_logict logic)
Definition smt_logics.h:53
static const smt_optiont & downcast(const irept &)
Definition smt_options.h:59
static irept upcast(smt_optiont option)
Definition smt_options.h:53
size_t levels() const
smt_pop_commandt(std::size_t levels)
size_t levels() const
smt_push_commandt(std::size_t levels)
const smt_logict & logic() const
smt_set_logic_commandt(smt_logict logic)
smt_set_option_commandt(smt_optiont option)
const smt_optiont & option() const
static const smt_sortt & downcast(const irept &)
Definition smt_sorts.h:72
static irept upcast(smt_termt term)
Definition smt_terms.h:65
static const smt_termt & downcast(const irept &)
Definition smt_terms.h:71
const smt_sortt & get_sort() const
Definition smt_terms.cpp:36
Ranges: pair of begin and end iterators, which can be initialized from containers,...
ranget< iteratort > make_range(iteratort begin, iteratort end)
Definition range.h:522
void accept(const smt_commandt &command, const irep_idt &id, visitort &&visitor)
#define UNREACHABLE
This should be used to mark dead code.
Definition invariant.h:525
#define INVARIANT(CONDITION, REASON)
This macro uses the wrapper function 'invariant_violated_string'.
Definition invariant.h:423