Fix Option<String> pattern match double-dereference in C codegen
LuxString is typedef char* but the codegen treated it as a struct type, generating *(LuxString*)(field0) instead of (LuxString)(field0). This caused a heap-buffer-overflow on any Option<String> pattern match since it read the string contents as a memory address. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -5316,11 +5316,12 @@ impl CBackend {
|
|||||||
if Self::is_primitive_c_type(&actual_type) {
|
if Self::is_primitive_c_type(&actual_type) {
|
||||||
// For primitive types stored as boxed void*, dereference
|
// For primitive types stored as boxed void*, dereference
|
||||||
self.writeln(&format!("{} {} = *({}*)({});", actual_type, var_name, actual_type, c_expr));
|
self.writeln(&format!("{} {} = *({}*)({});", actual_type, var_name, actual_type, c_expr));
|
||||||
} else if !actual_type.ends_with('*') && actual_type != "void" {
|
} else if actual_type == "LuxString" || actual_type.ends_with('*') || actual_type == "void" {
|
||||||
|
// Pointer types (including LuxString which is typedef char*): simple cast
|
||||||
|
self.writeln(&format!("{} {} = ({})({});", actual_type, var_name, actual_type, c_expr));
|
||||||
|
} else {
|
||||||
// Struct types: cast to pointer and dereference
|
// Struct types: cast to pointer and dereference
|
||||||
self.writeln(&format!("{} {} = *({}*)({});", actual_type, var_name, actual_type, c_expr));
|
self.writeln(&format!("{} {} = *({}*)({});", actual_type, var_name, actual_type, c_expr));
|
||||||
} else {
|
|
||||||
self.writeln(&format!("{} {} = ({})({});", actual_type, var_name, actual_type, c_expr));
|
|
||||||
}
|
}
|
||||||
self.var_types.insert(var_name.clone(), actual_type);
|
self.var_types.insert(var_name.clone(), actual_type);
|
||||||
} else if actual_type.ends_with('*') && actual_type != "void*" {
|
} else if actual_type.ends_with('*') && actual_type != "void*" {
|
||||||
|
|||||||
Reference in New Issue
Block a user