From 1621968fc82f17708c1d5b6f5bd65ba2244269a3 Mon Sep 17 00:00:00 2001 From: Bruce Hill Date: Mon, 17 Jun 2024 17:31:50 -0400 Subject: Fix issue with bitfields --- structs.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'structs.c') diff --git a/structs.c b/structs.c index 5c00055f..51f69287 100644 --- a/structs.c +++ b/structs.c @@ -102,7 +102,10 @@ static CORD compile_hash_method(env_t *env, ast_t *ast) "uint32_t field_hashes[] = {"); for (arg_ast_t *field = def->fields; field; field = field->next) { type_t *field_type = get_arg_ast_type(env, field); - hash_func = CORD_all(hash_func, "\ngeneric_hash(&obj->", field->name, ", ", compile_type_info(env, field_type), "),"); + if (field_type->tag == BoolType) // Bools can be bit fields, so you can't use *obj->field there: + hash_func = CORD_all(hash_func, "\n(uint32_t)(obj->", field->name, "),"); + else + hash_func = CORD_all(hash_func, "\ngeneric_hash(&obj->", field->name, ", ", compile_type_info(env, field_type), "),"); } hash_func = CORD_all(hash_func, "};\n" "uint32_t hash;\n" -- cgit v1.2.3