return new CCodeConstant ("NULL");
} else if (type is ErrorType) {
return new CCodeConstant ("NULL");
+ } else if (type is CType) {
+ return new CCodeConstant (((CType) type).cdefault_value);
}
return null;
}
var array_type = (ArrayType) param.variable_type;
var array_length_type = int_type;
if (get_ccode_array_length_type (param) != null) {
- array_length_type = new CType (get_ccode_array_length_type (param));
+ array_length_type = new CType (get_ccode_array_length_type (param), "0");
}
for (int dim = 1; dim <= array_type.rank; dim++) {
var temp_array_length = get_temp_variable (array_length_type);
if (get_ccode_array_length_type (m) == null) {
temp_var = get_temp_variable (int_type, true, null, true);
} else {
- temp_var = get_temp_variable (new CType (get_ccode_array_length_type (m)), true, null, true);
+ temp_var = get_temp_variable (new CType (get_ccode_array_length_type (m), "0"), true, null, true);
}
var temp_ref = get_variable_cexpression (temp_var.name);
*/
public string ctype_name { get; set; }
- public CType (string ctype_name) {
+ /**
+ * The default value of the C type.
+ */
+ public string cdefault_value { get; set; }
+
+ public CType (string ctype_name, string cdefault_value) {
this.ctype_name = ctype_name;
+ this.cdefault_value = cdefault_value;
}
public override DataType copy () {
- return new CType (ctype_name);
+ return new CType (ctype_name, cdefault_value);
}
}
expr.value_type.value_owned = true;
set_cvalue (expr, to_string);
} else {
- var temp_var = get_temp_variable (new CType (is_flags ? "GFlagsValue*" : "GEnumValue*"), false, expr, false);
+ var temp_var = get_temp_variable (new CType (is_flags ? "GFlagsValue*" : "GEnumValue*", "NULL"), false, expr, false);
emit_temp_var (temp_var);
var class_ref = new CCodeFunctionCall (new CCodeIdentifier ("g_type_class_ref"));