summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSon Ho2022-02-23 19:10:58 +0100
committerSon Ho2022-02-23 19:10:58 +0100
commit11934689a41f1ad7645fb5f43347c6138db3ebf8 (patch)
tree6cbe8e8df2f2dd7397c4e9e4ace098088b9c80c9 /src
parentb712795d5b8aa1bf831a80b3a410c35946fcbce0 (diff)
Improve variable name generation
Diffstat (limited to '')
-rw-r--r--src/ExtractToFStar.ml18
1 files changed, 15 insertions, 3 deletions
diff --git a/src/ExtractToFStar.ml b/src/ExtractToFStar.ml
index 50a98093..02005f2b 100644
--- a/src/ExtractToFStar.ml
+++ b/src/ExtractToFStar.ml
@@ -306,9 +306,21 @@ let mk_formatter (ctx : trans_ctx) (variant_concatenate_type_name : bool) :
let def =
TypeDefId.Map.find adt_id ctx.type_context.type_defs
in
- let c = (get_type_name def.name).[0] in
- let c = StringUtils.lowercase_ascii c in
- String.make 1 c)
+ (* We do the following:
+ * - convert to snake_case
+ * - take the first letter of every "letter group"
+ * Ex.: "TypeVar" -> "type_var" -> "tv"
+ *)
+ let cl = get_type_name def.name in
+ let cl = StringUtils.to_snake_case cl in
+ let cl = String.split_on_char '_' cl in
+ let cl = List.filter (fun s -> String.length s > 0) cl in
+ assert (List.length cl > 0);
+ let cl = List.map (fun s -> s.[0]) cl in
+ StringUtils.string_of_chars cl
+ (* let c = (get_type_name def.name).[0] in
+ let c = StringUtils.lowercase_ascii c in
+ String.make 1 c *))
| TypeVar _ -> "x" (* lacking imagination here... *)
| Bool -> "b"
| Char -> "c"