CBMC
destructor.cpp
Go to the documentation of this file.
1 /*******************************************************************\
2 
3 Module: Destructor Calls
4 
5 Author: Daniel Kroening, kroening@kroening.com
6 
7 \*******************************************************************/
8 
11 
12 #include "destructor.h"
13 #include "goto_instruction_code.h"
14 
15 #include <util/namespace.h>
16 #include <util/pointer_expr.h>
17 
19  const namespacet &ns,
20  const typet &type)
21 {
22  if(type.id() == ID_struct_tag)
23  {
24  return get_destructor(ns, ns.follow_tag(to_struct_tag_type(type)));
25  }
26  else if(type.id()==ID_struct)
27  {
28  const exprt &methods=static_cast<const exprt&>(type.find(ID_methods));
29 
30  forall_operands(it, methods)
31  {
32  if(it->type().id()==ID_code)
33  {
34  const code_typet &code_type=to_code_type(it->type());
35 
36  if(code_type.return_type().id()==ID_destructor &&
37  code_type.parameters().size()==1)
38  {
39  const typet &arg_type=code_type.parameters().front().type();
40 
41  if(
42  arg_type.id() == ID_pointer &&
43  ns.follow(to_pointer_type(arg_type).base_type()) == type)
44  {
45  const symbol_exprt symbol_expr(it->get(ID_name), it->type());
46  return code_function_callt(symbol_expr);
47  }
48  }
49  }
50  }
51  }
52 
53  return static_cast<const code_function_callt &>(get_nil_irep());
54 }
goto_instruction_code.h
typet
The type of an expression, extends irept.
Definition: type.h:28
irept::find
const irept & find(const irep_idt &name) const
Definition: irep.cpp:106
get_destructor
code_function_callt get_destructor(const namespacet &ns, const typet &type)
Definition: destructor.cpp:18
exprt
Base class for all expressions.
Definition: expr.h:55
namespace_baset::follow_tag
const union_typet & follow_tag(const union_tag_typet &) const
Follow type tag of union type.
Definition: namespace.cpp:63
symbol_exprt
Expression to hold a symbol (variable)
Definition: std_expr.h:112
namespace.h
namespacet
A namespacet is essentially one or two symbol tables bound together, to allow for symbol lookups in t...
Definition: namespace.h:90
code_function_callt
goto_instruction_codet representation of a function call statement.
Definition: goto_instruction_code.h:271
to_code_type
const code_typet & to_code_type(const typet &type)
Cast a typet to a code_typet.
Definition: std_types.h:744
forall_operands
#define forall_operands(it, expr)
Definition: expr.h:20
pointer_expr.h
to_pointer_type
const pointer_typet & to_pointer_type(const typet &type)
Cast a typet to a pointer_typet.
Definition: pointer_expr.h:79
code_typet
Base type of functions.
Definition: std_types.h:538
irept::id
const irep_idt & id() const
Definition: irep.h:396
to_struct_tag_type
const struct_tag_typet & to_struct_tag_type(const typet &type)
Cast a typet to a struct_tag_typet.
Definition: std_types.h:474
code_typet::parameters
const parameterst & parameters() const
Definition: std_types.h:655
destructor.h
namespace_baset::follow
const typet & follow(const typet &) const
Resolve type symbol to the type it points to.
Definition: namespace.cpp:49
code_typet::return_type
const typet & return_type() const
Definition: std_types.h:645
get_nil_irep
const irept & get_nil_irep()
Definition: irep.cpp:20