diff --git a/src/kernel_services/ast_data/property.ml b/src/kernel_services/ast_data/property.ml
index 4029b3829485231a6aee7a24913a591c026babe0..76dbce8cdaf50f200c46911f10bbcd187f9c26f9 100644
--- a/src/kernel_services/ast_data/property.ml
+++ b/src/kernel_services/ast_data/property.ml
@@ -76,7 +76,7 @@ type identified_complete = {
   ic_kf : kernel_function;
   ic_kinstr : kinstr;
   ic_active : Datatype.String.Set.t;
-  ic_bhvs : string list
+  ic_bhvs : Datatype.String.Set.t
 }
 
 type identified_disjoint = identified_complete
@@ -461,14 +461,16 @@ include Datatype.Make_with_collections
         | IPCodeAnnot {ica_ca} -> Cil_printer.pp_code_annotation fmt ica_ca
         | IPComplete {ic_active; ic_bhvs} ->
           Format.fprintf fmt "complete@ %a"
-            (Pretty_utils.pp_list ~sep:","
-               (fun fmt s ->  Format.fprintf fmt "@ %s" s))
+            (Pretty_utils.pp_iter ~sep:","
+               Datatype.String.Set.iter
+               (fun fmt s -> Format.fprintf fmt "@ %s" s))
             ic_bhvs;
           pp_active fmt ic_active
         | IPDisjoint {ic_active; ic_bhvs} ->
           Format.fprintf fmt "disjoint@ %a"
-            (Pretty_utils.pp_list ~sep:","
-               (fun fmt s ->  Format.fprintf fmt "@ %s" s))
+            (Pretty_utils.pp_iter ~sep:","
+               Datatype.String.Set.iter
+               (fun fmt s -> Format.fprintf fmt "@ %s" s))
             ic_bhvs;
           pp_active fmt ic_active
         | IPAllocation {ial_allocs=(f,a)} ->
@@ -511,11 +513,11 @@ include Datatype.Make_with_collections
           (* complete list is more likely to discriminate than active list. *)
           Hashtbl.hash
             (6, Kf.hash f, Kinstr.hash ki,
-             (y:string list), (x:Datatype.String.Set.t))
+             Datatype.String.Set.hash y, Datatype.String.Set.hash x)
         | IPDisjoint {ic_kf=f; ic_kinstr=ki; ic_bhvs=y; ic_active=x} ->
           Hashtbl.hash
             (7, Kf.hash f, Kinstr.hash ki,
-             (y: string list), (x:Datatype.String.Set.t))
+             Datatype.String.Set.hash y, Datatype.String.Set.hash x)
         | IPAssigns {ias_kf=f; ias_kinstr=ki; ias_bhv=b} ->
           Hashtbl.hash (8, Kf.hash f, Kinstr.hash ki, hash_bhv_loop b)
         | IPFrom {if_kf=kf; if_kinstr=ki; if_bhv=b; if_from=(t, _)} ->
@@ -572,7 +574,7 @@ include Datatype.Make_with_collections
           IPComplete {ic_kf=f2;ic_kinstr=ki2;ic_active=a2;ic_bhvs=x2}
         | IPDisjoint {ic_kf=f1;ic_kinstr=ki1;ic_active=a1;ic_bhvs=x1},
           IPDisjoint {ic_kf=f2;ic_kinstr=ki2;ic_active=a2;ic_bhvs=x2} ->
-          Kf.equal f1 f2 && Kinstr.equal ki1 ki2 && a1 = a2 && x1 = x2
+          Kf.equal f1 f2 && Kinstr.equal ki1 ki2 && a1 = a2 && Datatype.String.Set.equal x1 x2
         | IPAllocation {ial_kf=f1;ial_kinstr=ki1;ial_bhv=b1},
           IPAllocation {ial_kf=f2;ial_kinstr=ki2;ial_bhv=b2}
         | IPAssigns {ias_kf=f1;ias_kinstr=ki1;ias_bhv=b1},
@@ -641,7 +643,7 @@ include Datatype.Make_with_collections
           if n = 0 then
             let n = Kinstr.compare ki1 ki2 in
             if n = 0 then
-              let n = Extlib.compare_basic x1 x2 in
+              let n = Datatype.String.Set.compare x1 x2 in
               if n = 0 then
                 Datatype.String.Set.compare a1 a2
               else n
@@ -824,13 +826,13 @@ let rec pretty_debug fmt = function
       Cil_types_debug.pp_kernel_function ic_kf
       Cil_types_debug.pp_kinstr ic_kinstr
       Datatype.String.Set.pretty ic_active
-      (Cil_types_debug.pp_list Cil_types_debug.pp_string) ic_bhvs
+      Datatype.String.Set.pretty ic_bhvs
   | IPDisjoint {ic_kf; ic_kinstr; ic_active; ic_bhvs} ->
     Format.fprintf fmt "IPDisjoint(%a,%a,%a,%a)"
       Cil_types_debug.pp_kernel_function ic_kf
       Cil_types_debug.pp_kinstr ic_kinstr
       Datatype.String.Set.pretty ic_active
-      (Cil_types_debug.pp_list Cil_types_debug.pp_string) ic_bhvs
+      Datatype.String.Set.pretty ic_bhvs
   | IPDecrease {id_kf; id_kinstr; id_ca; id_variant} ->
     Format.fprintf fmt "IPDecrease(%a,%a,%a,%a)"
       Cil_types_debug.pp_kernel_function id_kf
@@ -1023,9 +1025,11 @@ struct
         | AExtended(_,_,{ext_name}) -> ext_name
       in Format.asprintf "%s%s%a" (kf_prefix kf) name pp_code_annot_names ca
     | IPComplete {ic_kf=kf; ic_kinstr=ki; ic_active=a; ic_bhvs=lb} ->
+      let lb = Datatype.String.Set.elements lb in
       Format.asprintf  "%s%s%acomplete%a"
         (kf_prefix kf) (ki_prefix ki) active_prefix a pp_names lb
     | IPDisjoint {ic_kf=kf; ic_kinstr=ki; ic_active=a; ic_bhvs=lb} ->
+      let lb = Datatype.String.Set.elements lb in
       Format.asprintf  "%s%s%adisjoint%a"
         (kf_prefix kf) (ki_prefix ki) active_prefix a pp_names lb
     | IPDecrease {id_kf=kf; id_ca=None; id_variant=variant} ->
@@ -1235,8 +1239,10 @@ struct
       [K kf ; A "loop_allocates" ]
 
     | IPComplete {ic_kf=kf; ic_bhvs=cs} ->
+      let cs = Datatype.String.Set.elements cs in
       (K kf :: A "complete" :: List.map (fun a -> A a) cs)
     | IPDisjoint {ic_kf=kf; ic_bhvs=cs} ->
+      let cs = Datatype.String.Set.elements cs in
       (K kf :: A "disjoint" :: List.map (fun a -> A a) cs)
 
     | IPReachable {ir_kf=None} -> []
@@ -1449,6 +1455,7 @@ let ip_all_of_behavior kf st ~active b =
   @ List.map (ip_of_extended (e_loc_of_stmt kf st)) b.b_extended
 
 let ip_of_complete ic_kf ic_kinstr ~active ic_bhvs =
+  let ic_bhvs = Datatype.String.Set.of_list ic_bhvs in
   let ic_active = Datatype.String.Set.of_list active in
   IPComplete {ic_kf; ic_kinstr; ic_active; ic_bhvs}
 
@@ -1456,6 +1463,7 @@ let ip_complete_of_spec kf st ~active s =
   List.map (ip_of_complete kf st ~active) s.spec_complete_behaviors
 
 let ip_of_disjoint ic_kf ic_kinstr ~active ic_bhvs =
+  let ic_bhvs = Datatype.String.Set.of_list ic_bhvs in
   let ic_active = Datatype.String.Set.of_list active in
   IPDisjoint {ic_kf; ic_kinstr; ic_active; ic_bhvs}
 
diff --git a/src/kernel_services/ast_data/property.mli b/src/kernel_services/ast_data/property.mli
index 395250cf2e30de409e5fe3ae29b9477a97acaf05..ef1f193333d5fbb227ae616d02873e95aa24a814 100644
--- a/src/kernel_services/ast_data/property.mli
+++ b/src/kernel_services/ast_data/property.mli
@@ -100,7 +100,7 @@ type identified_complete = {
   ic_kf : kernel_function;
   ic_kinstr : kinstr;
   ic_active : Datatype.String.Set.t;
-  ic_bhvs : string list
+  ic_bhvs : Datatype.String.Set.t
 }
 (** Same as for {!identified_behavior}. *)
 
diff --git a/src/kernel_services/ast_printing/description.ml b/src/kernel_services/ast_printing/description.ml
index e9de181388eb05084d63e56edca560a46fbdd312..8ccda1048a0f5e2fdada76f9db31d63eee68125a 100644
--- a/src/kernel_services/ast_printing/description.ml
+++ b/src/kernel_services/ast_printing/description.ml
@@ -95,12 +95,17 @@ let pp_bhv fmt bhv =
   if not (Cil.is_default_behavior bhv) then
     Format.fprintf fmt " for '%s'" bhv.b_name
 
-let pp_bhvs fmt = function
-  | [] -> ()
-  | b::bs ->
-    Format.fprintf fmt " @[<hov 0>'%s'" b ;
-    List.iter (fun b -> Format.fprintf fmt ",@ '%s'" b) bs ;
-    Format.fprintf fmt "@]"
+let pp_bhvs fmt bhvs =
+  if Datatype.String.Set.is_empty bhvs then
+    ()
+  else
+    Pretty_utils.pp_iter
+      ~pre:" @[<hov 0>"
+      ~suf:"@]"
+      ~sep:",@ "
+      Datatype.String.Set.iter
+      (fun fmt s -> Format.fprintf fmt "'%s'" s)
+      fmt bhvs
 
 let pp_for fmt = function
   | [] -> ()
@@ -492,8 +497,10 @@ let rec ip_order = function
   | IPBehavior {ib_kf;ib_kinstr;ib_active;ib_bhv} ->
     [I 6;F ib_kf;K ib_kinstr;B ib_bhv; A ib_active]
   | IPComplete {ic_kf;ic_kinstr;ic_active;ic_bhvs} ->
+    let ic_bhvs = Datatype.String.Set.elements ic_bhvs in
     [I 7;F ic_kf;K ic_kinstr; A ic_active] @ for_order 0 ic_bhvs
   | IPDisjoint {ic_kf;ic_kinstr;ic_active;ic_bhvs} ->
+    let ic_bhvs = Datatype.String.Set.elements ic_bhvs in
     [I 8;F ic_kf;K ic_kinstr; A ic_active] @ for_order 0 ic_bhvs
   | IPPredicate {ip_kind;ip_kf;ip_kinstr} ->
     [I 9;F ip_kf;K ip_kinstr] @ kind_order ip_kind
diff --git a/src/plugins/wp/tests/wp/oracle/wp_behav.res.oracle b/src/plugins/wp/tests/wp/oracle/wp_behav.res.oracle
index 5d027100e9993d57ffab79a3eaf4675645c65204..1482e87b434d9c3b0567abedd3464113b9cda5b2 100644
--- a/src/plugins/wp/tests/wp/oracle/wp_behav.res.oracle
+++ b/src/plugins/wp/tests/wp/oracle/wp_behav.res.oracle
@@ -30,7 +30,7 @@ Prove: true.
   Function bhv
 ------------------------------------------------------------
 
-Goal Complete behaviors 'pos', 'neg':
+Goal Complete behaviors 'neg', 'pos':
 Assume { Type: is_sint32(n). (* Pre-condition *) Have: n != 0. }
 Prove: (0 < n) \/ (n < 0).
 
diff --git a/src/plugins/wp/tests/wp/oracle/wp_behavior.0.res.oracle b/src/plugins/wp/tests/wp/oracle/wp_behavior.0.res.oracle
index c28768d2976ffbf2d6c9b20e5988bcf6b50cb208..c377eb93bf7fa1a03983b67f6950c86b1e851748 100644
--- a/src/plugins/wp/tests/wp/oracle/wp_behavior.0.res.oracle
+++ b/src/plugins/wp/tests/wp/oracle/wp_behavior.0.res.oracle
@@ -6,7 +6,7 @@
   Function behaviors
 ------------------------------------------------------------
 
-Goal Complete behaviors 'Y', 'X':
+Goal Complete behaviors 'X', 'Y':
 Assume {
   (* Pre-condition *)
   Have: P_R.
@@ -19,7 +19,7 @@ Prove: P_CX \/ P_CY.
 
 ------------------------------------------------------------
 
-Goal Disjoint behaviors 'Y', 'X':
+Goal Disjoint behaviors 'X', 'Y':
 Assume {
   (* Pre-condition *)
   Have: P_R.
diff --git a/src/plugins/wp/tests/wp/oracle/wp_behavior.1.res.oracle b/src/plugins/wp/tests/wp/oracle/wp_behavior.1.res.oracle
index e6e7eac38d3a52d4a34a9410eee8e1b1a7b2a27b..8d98a45587a8418840253e104b34f8591534e2d9 100644
--- a/src/plugins/wp/tests/wp/oracle/wp_behavior.1.res.oracle
+++ b/src/plugins/wp/tests/wp/oracle/wp_behavior.1.res.oracle
@@ -6,13 +6,13 @@
   Function behaviors
 ------------------------------------------------------------
 
-Goal Complete behaviors 'Y', 'X':
+Goal Complete behaviors 'X', 'Y':
 Assume { (* Pre-condition *) Have: P_R. }
 Prove: P_CX \/ P_CY.
 
 ------------------------------------------------------------
 
-Goal Disjoint behaviors 'Y', 'X':
+Goal Disjoint behaviors 'X', 'Y':
 Assume { (* Pre-condition *) Have: P_R. }
 Prove: (!P_CX) \/ (!P_CY).
 
diff --git a/src/plugins/wp/tests/wp/oracle_qualif/wp_behav.0.res.oracle b/src/plugins/wp/tests/wp/oracle_qualif/wp_behav.0.res.oracle
index 367808737638d33e42c15d3193b3e69cb7dde789..faa679c96697f66156e01511131f9dc0cf867911 100644
--- a/src/plugins/wp/tests/wp/oracle_qualif/wp_behav.0.res.oracle
+++ b/src/plugins/wp/tests/wp/oracle_qualif/wp_behav.0.res.oracle
@@ -22,7 +22,7 @@
 [wp] [Qed] Goal typed_min_disjoint_bx_by : Valid
 [wp] [Qed] Goal typed_min_bx_ensures_qed_ok : Valid
 [wp] [Qed] Goal typed_min_by_ensures_qed_ok : Valid
-[wp] [Alt-Ergo] Goal typed_bhv_complete_pos_neg : Valid
+[wp] [Alt-Ergo] Goal typed_bhv_complete_neg_pos : Valid
 [wp] [Qed] Goal typed_bhv_pos_ensures_qed_ok : Valid
 [wp] [Qed] Goal typed_bhv_neg_ensures_qed_ok : Valid
 [wp] [Qed] Goal typed_stmt_contract_requires_qed_ok : Valid
diff --git a/src/plugins/wp/tests/wp_gallery/oracle/frama_c_hashtbl_solved.res.oracle b/src/plugins/wp/tests/wp_gallery/oracle/frama_c_hashtbl_solved.res.oracle
index b4db2ed7bddb4b89ef0bb5252ec75a712daea063..2429963d412aaa3b426504d27c25d7c2fc60722a 100644
--- a/src/plugins/wp/tests/wp_gallery/oracle/frama_c_hashtbl_solved.res.oracle
+++ b/src/plugins/wp/tests/wp_gallery/oracle/frama_c_hashtbl_solved.res.oracle
@@ -7,8 +7,8 @@
 [rte] annotating function init
 [rte] annotating function mem_binding
 [rte] annotating function size
-[wp] Goal typed_eq_string_complete_not_eq_eq : trivial
-[wp] Goal typed_eq_string_disjoint_not_eq_eq : trivial
+[wp] Goal typed_eq_string_complete_eq_not_eq : trivial
+[wp] Goal typed_eq_string_disjoint_eq_not_eq : trivial
 [wp] Goal typed_eq_string_loop_invariant_preserved : not tried
 [wp] Goal typed_eq_string_loop_invariant_established : not tried
 [wp] Goal typed_eq_string_loop_invariant_2_preserved : not tried
@@ -111,8 +111,8 @@
 [wp] Goal typed_add_full_assigns_normal_part7 : not tried
 [wp] Goal typed_add_full_assigns_normal_part8 : not tried
 [wp] Goal typed_add_full_assigns_normal_part9 : not tried
-[wp] Goal typed_mem_binding_complete_not_found_found : not tried
-[wp] Goal typed_mem_binding_disjoint_not_found_found : not tried
+[wp] Goal typed_mem_binding_complete_found_not_found : not tried
+[wp] Goal typed_mem_binding_disjoint_found_not_found : not tried
 [wp] Goal typed_mem_binding_loop_invariant_preserved : not tried
 [wp] Goal typed_mem_binding_loop_invariant_established : not tried
 [wp] Goal typed_mem_binding_loop_invariant_2_preserved : not tried
diff --git a/src/plugins/wp/tests/wp_gallery/oracle_qualif/frama_c_hashtbl_solved.res.oracle b/src/plugins/wp/tests/wp_gallery/oracle_qualif/frama_c_hashtbl_solved.res.oracle
index aa0a56a75fb331b2a4da497baecf2d428424c801..b9066d9921a764ee6e240b742d1f8f5c6387d265 100644
--- a/src/plugins/wp/tests/wp_gallery/oracle_qualif/frama_c_hashtbl_solved.res.oracle
+++ b/src/plugins/wp/tests/wp_gallery/oracle_qualif/frama_c_hashtbl_solved.res.oracle
@@ -3,8 +3,8 @@
 [wp] Running WP plugin...
 [wp] Warning: Missing RTE guards
 [wp] 102 goals scheduled
-[wp] [Qed] Goal typed_eq_string_complete_not_eq_eq : Valid
-[wp] [Qed] Goal typed_eq_string_disjoint_not_eq_eq : Valid
+[wp] [Qed] Goal typed_eq_string_complete_eq_not_eq : Valid
+[wp] [Qed] Goal typed_eq_string_disjoint_eq_not_eq : Valid
 [wp] [Alt-Ergo] Goal typed_eq_string_loop_invariant_preserved : Valid
 [wp] [Qed] Goal typed_eq_string_loop_invariant_established : Valid
 [wp] [Alt-Ergo] Goal typed_eq_string_loop_invariant_2_preserved : Valid
@@ -79,8 +79,8 @@
 [wp] [Alt-Ergo] Goal typed_add_full_assigns_normal_part7 : Valid
 [wp] [Alt-Ergo] Goal typed_add_full_assigns_normal_part8 : Valid
 [wp] [Qed] Goal typed_add_full_assigns_normal_part9 : Valid
-[wp] [Alt-Ergo] Goal typed_mem_binding_complete_not_found_found : Valid
-[wp] [Alt-Ergo] Goal typed_mem_binding_disjoint_not_found_found : Valid
+[wp] [Alt-Ergo] Goal typed_mem_binding_complete_found_not_found : Valid
+[wp] [Alt-Ergo] Goal typed_mem_binding_disjoint_found_not_found : Valid
 [wp] [Alt-Ergo] Goal typed_mem_binding_loop_invariant_preserved : Valid
 [wp] [Alt-Ergo] Goal typed_mem_binding_loop_invariant_established : Valid
 [wp] [Alt-Ergo] Goal typed_mem_binding_loop_invariant_2_preserved : Valid
diff --git a/src/plugins/wp/wpPropId.ml b/src/plugins/wp/wpPropId.ml
index 22988574935a64368c3c240dcd1811f688623d81..441d8cbfb9a77ad409cac7eaec0ee71afb1318db 100644
--- a/src/plugins/wp/wpPropId.ml
+++ b/src/plugins/wp/wpPropId.ml
@@ -458,8 +458,11 @@ let get_propid = Names.get_prop_id_name
 let pp_propid fmt pid =
   Format.pp_print_string fmt (get_propid pid)
 
-let pp_names fmt l =  match l with [] -> () | _ ->
-  Format.fprintf fmt "_%a" (Wp_error.pp_string_list ~empty:"" ~sep:"_") l
+let pp_names fmt l =
+  let l = Datatype.String.Set.elements l in
+  match l with
+  | [] -> ()
+  | _ -> Format.fprintf fmt "_%a" (Wp_error.pp_string_list ~empty:"" ~sep:"_") l
 
 let ident_names names =
   List.filter (function "" -> true
@@ -670,7 +673,7 @@ let property_hints hs =
         List.iter (add_required hs) (il_name::il_pred.tp_statement.pred_name)
     | IPBehavior _ -> ()
     | IPComplete {ic_bhvs} | IPDisjoint {ic_bhvs} ->
-        List.iter (add_required hs) ic_bhvs
+        Datatype.String.Set.iter (add_required hs) ic_bhvs
     | IPPredicate {ip_pred} ->
         List.iter (add_hint hs) ip_pred.ip_content.tp_statement.pred_name
     | IPExtended {ie_ext={ext_name}} -> List.iter (add_hint hs) [ext_name]