mirror of
https://github.com/janet-lang/janet
synced 2025-01-23 05:36:52 +00:00
Fix Issue #1512
This commit is contained in:
parent
07155ce657
commit
2b84fb14b4
@ -400,7 +400,7 @@ static JanetFFIStruct *build_struct_type(int32_t argc, const Janet *argv) {
|
|||||||
|
|
||||||
JanetFFIStruct *st = janet_abstract(&janet_struct_type,
|
JanetFFIStruct *st = janet_abstract(&janet_struct_type,
|
||||||
sizeof(JanetFFIStruct) + argc * sizeof(JanetFFIStructMember));
|
sizeof(JanetFFIStruct) + argc * sizeof(JanetFFIStructMember));
|
||||||
st->field_count = member_count;
|
st->field_count = 0;
|
||||||
st->size = 0;
|
st->size = 0;
|
||||||
st->align = 1;
|
st->align = 1;
|
||||||
if (argc == 0) {
|
if (argc == 0) {
|
||||||
@ -418,13 +418,13 @@ static JanetFFIStruct *build_struct_type(int32_t argc, const Janet *argv) {
|
|||||||
st->fields[i].type = decode_ffi_type(argv[j]);
|
st->fields[i].type = decode_ffi_type(argv[j]);
|
||||||
size_t el_size = type_size(st->fields[i].type);
|
size_t el_size = type_size(st->fields[i].type);
|
||||||
size_t el_align = type_align(st->fields[i].type);
|
size_t el_align = type_align(st->fields[i].type);
|
||||||
|
if (el_align <= 0) janet_panicf("bad field type %V", argv[j]);
|
||||||
if (all_packed || pack_one) {
|
if (all_packed || pack_one) {
|
||||||
if (st->size % el_align != 0) is_aligned = 0;
|
if (st->size % el_align != 0) is_aligned = 0;
|
||||||
st->fields[i].offset = st->size;
|
st->fields[i].offset = st->size;
|
||||||
st->size += (uint32_t) el_size;
|
st->size += (uint32_t) el_size;
|
||||||
} else {
|
} else {
|
||||||
if (el_align > st->align) st->align = (uint32_t) el_align;
|
if (el_align > st->align) st->align = (uint32_t) el_align;
|
||||||
if (el_align <= 0) el_align = 1;
|
|
||||||
st->fields[i].offset = (uint32_t)(((st->size + el_align - 1) / el_align) * el_align);
|
st->fields[i].offset = (uint32_t)(((st->size + el_align - 1) / el_align) * el_align);
|
||||||
st->size = (uint32_t)(el_size + st->fields[i].offset);
|
st->size = (uint32_t)(el_size + st->fields[i].offset);
|
||||||
}
|
}
|
||||||
@ -434,6 +434,7 @@ static JanetFFIStruct *build_struct_type(int32_t argc, const Janet *argv) {
|
|||||||
st->size += (st->align - 1);
|
st->size += (st->align - 1);
|
||||||
st->size /= st->align;
|
st->size /= st->align;
|
||||||
st->size *= st->align;
|
st->size *= st->align;
|
||||||
|
st->field_count = member_count;
|
||||||
return st;
|
return st;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,9 +53,6 @@
|
|||||||
"array struct size"))
|
"array struct size"))
|
||||||
|
|
||||||
(compwhen has-ffi
|
(compwhen has-ffi
|
||||||
(assert-no-error "bad struct issue #1512" (ffi/struct :void))
|
(assert-error "bad struct issue #1512" (ffi/struct :void)))
|
||||||
(def s (ffi/struct :void))
|
|
||||||
(assert (= 0 (ffi/size s)))
|
|
||||||
(assert (= 1 (ffi/align s))))
|
|
||||||
|
|
||||||
(end-suite)
|
(end-suite)
|
||||||
|
Loading…
Reference in New Issue
Block a user