diff options
author | Son Ho | 2022-02-23 19:10:58 +0100 |
---|---|---|
committer | Son Ho | 2022-02-23 19:10:58 +0100 |
commit | 11934689a41f1ad7645fb5f43347c6138db3ebf8 (patch) | |
tree | 6cbe8e8df2f2dd7397c4e9e4ace098088b9c80c9 /src | |
parent | b712795d5b8aa1bf831a80b3a410c35946fcbce0 (diff) |
Improve variable name generation
Diffstat (limited to '')
-rw-r--r-- | src/ExtractToFStar.ml | 18 |
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" |