CongruenceClosure.SSet
Set of subterms which are present in the current data structure.
type t = TSet.t
val hash : t -> int
val empty : TSet.t
val show_set : TSet.t -> string
Adds all subterms of t to the SSet and the LookupMap
We try to find the dereferenced term between the already existing terms, in order to remember the information about the exp.
Sometimes it's important to keep the dereferenced term, even if it's not technically possible to dereference it from a point of view of the C types. We still need the dereferenced term for the correctness of some algorithms, and the resulting expression will never be used, so it doesn't need to be a C expression that makes sense.