3 DECLARE_PTR_LIST(state_list
, struct sm_state
);
4 DECLARE_PTR_LIST(state_list_stack
, struct state_list
);
5 DECLARE_PTR_LIST(stree_stack
, struct AVL
);
9 struct state_list
*slist
;
11 DECLARE_ALLOCATOR(named_slist
);
12 DECLARE_PTR_LIST(named_stack
, struct named_slist
);
18 DECLARE_ALLOCATOR(named_stree
);
19 DECLARE_PTR_LIST(named_stree_stack
, struct named_stree
);
22 extern struct state_list_stack
*implied_pools
;
23 extern int __slist_id
;
25 char *show_sm(struct sm_state
*sm
);
26 void __print_slist(struct state_list
*slist
);
27 void __print_stree(struct AVL
*stree
);
28 void add_history(struct sm_state
*sm
);
29 int cmp_tracker(const struct sm_state
*a
, const struct sm_state
*b
);
30 char *alloc_sname(const char *str
);
32 void free_every_single_sm_state(void);
33 struct sm_state
*clone_sm(struct sm_state
*s
);
34 int is_merged(struct sm_state
*sm
);
35 int is_implied(struct sm_state
*sm
);
36 struct state_list
*clone_slist(struct state_list
*from_slist
);
37 struct state_list_stack
*clone_stack(struct state_list_stack
*from_stack
);
39 int slist_has_state(struct state_list
*slist
, struct smatch_state
*state
);
40 struct smatch_state
*merge_states(int owner
, const char *name
,
42 struct smatch_state
*state1
,
43 struct smatch_state
*state2
);
45 int too_many_possible(struct sm_state
*sm
);
46 struct sm_state
*merge_sm_states(struct sm_state
*one
, struct sm_state
*two
);
47 struct smatch_state
*get_state_slist(struct state_list
*slist
, int owner
, const char *name
,
49 struct smatch_state
*get_state_stree(struct AVL
*stree
, int owner
, const char *name
,
52 struct sm_state
*get_sm_state_slist(struct state_list
*slist
, int owner
, const char *name
,
54 struct sm_state
*get_sm_state_stree(struct AVL
*stree
, int owner
, const char *name
,
57 void overwrite_sm_state(struct state_list
**slist
, struct sm_state
*sm
);
58 void overwrite_sm_state_stree(struct AVL
**stree
, struct sm_state
*sm
);
59 void overwrite_sm_state_stack(struct state_list_stack
**stack
, struct sm_state
*sm
);
60 void overwrite_sm_state_stree_stack(struct stree_stack
**stack
, struct sm_state
*sm
);
61 struct sm_state
*set_state_slist(struct state_list
**slist
, int owner
, const char *name
,
62 struct symbol
*sym
, struct smatch_state
*state
);
63 struct sm_state
*set_state_stree(struct AVL
**stree
, int owner
, const char *name
,
64 struct symbol
*sym
, struct smatch_state
*state
);
66 void delete_state_slist(struct state_list
**slist
, int owner
, const char *name
,
68 void delete_state_stree(struct AVL
**stree
, int owner
, const char *name
,
71 void delete_state_stack(struct state_list_stack
**stack
, int owner
, const char *name
,
73 void delete_state_stree_stack(struct stree_stack
**stack
, int owner
, const char *name
,
76 void push_slist(struct state_list_stack
**list_stack
, struct state_list
*slist
);
77 void push_stree(struct stree_stack
**list_stack
, struct AVL
*stree
);
79 struct state_list
*pop_slist(struct state_list_stack
**list_stack
);
80 struct AVL
*pop_stree(struct stree_stack
**list_stack
);
82 void free_slist(struct state_list
**slist
);
83 void free_stree(struct AVL
**stree
);
84 void free_stack(struct state_list_stack
**stack
);
85 void free_stree_stack(struct stree_stack
**stack
);
86 void free_stack_and_slists(struct state_list_stack
**slist_stack
);
87 void free_stack_and_strees(struct stree_stack
**stree_stack
);
89 struct sm_state
*set_state_stack(struct state_list_stack
**stack
, int owner
, const char *name
,
90 struct symbol
*sym
, struct smatch_state
*state
);
91 struct sm_state
*set_state_stree_stack(struct stree_stack
**stack
, int owner
, const char *name
,
92 struct symbol
*sym
, struct smatch_state
*state
);
94 struct smatch_state
*get_state_stack(struct state_list_stack
*stack
, int owner
,
95 const char *name
, struct symbol
*sym
);
96 struct smatch_state
*get_state_stree_stack(struct stree_stack
*stack
, int owner
,
97 const char *name
, struct symbol
*sym
);
99 int out_of_memory(void);
100 int low_on_memory(void);
101 void merge_slist(struct state_list
**to
, struct state_list
*slist
);
102 void merge_stree(struct AVL
**to
, struct AVL
*stree
);
103 void filter_slist(struct state_list
**slist
, struct state_list
*filter
);
104 void filter_stree(struct AVL
**stree
, struct AVL
*filter
);
105 void and_slist_stack(struct state_list_stack
**slist_stack
);
106 void and_stree_stack(struct stree_stack
**stree_stack
);
108 void or_slist_stack(struct state_list_stack
**pre_conds
,
109 struct state_list
*cur_slist
,
110 struct state_list_stack
**slist_stack
);
111 void or_stree_stack(struct stree_stack
**pre_conds
,
112 struct AVL
*cur_stree
,
113 struct stree_stack
**stack
);
115 struct state_list
**get_slist_from_named_stack(struct named_stack
*stack
,
118 struct AVL
**get_named_stree(struct named_stree_stack
*stack
,
121 void overwrite_slist(struct state_list
*from
, struct state_list
**to
);
122 void overwrite_stree(struct AVL
*from
, struct AVL
**to
);
124 /* add stuff smatch_returns.c here */
126 void all_return_states_hook(void (*callback
)(struct state_list
*slist
));
127 void all_return_states_hook_stree(void (*callback
)(struct AVL
*slist
));
129 int get_slist_id(struct state_list
*slist
);
130 int get_stree_id(struct AVL
*slist
);
132 struct state_list
*stree_to_slist(struct AVL
*stree
);
133 struct AVL
*slist_to_stree(struct state_list
*stree
);