moductypes: Swap address and descriptor args in constructor.
Now address comes first, and args related to struct type are groupped next. Besides clear groupping, should help catch errors eagerly (e.g. forgetting to pass address will error out). Also, improve args number checking/reporting overall.
This commit is contained in:
parent
07408cbd1f
commit
1679696612
|
@ -122,14 +122,11 @@ STATIC NORETURN void syntax_error(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
STATIC mp_obj_t uctypes_struct_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
|
STATIC mp_obj_t uctypes_struct_make_new(mp_obj_t type_in, mp_uint_t n_args, mp_uint_t n_kw, const mp_obj_t *args) {
|
||||||
(void)n_kw;
|
mp_arg_check_num(n_args, n_kw, 2, 3, false);
|
||||||
if (n_args < 2 || n_args > 3) {
|
|
||||||
syntax_error();
|
|
||||||
}
|
|
||||||
mp_obj_uctypes_struct_t *o = m_new_obj(mp_obj_uctypes_struct_t);
|
mp_obj_uctypes_struct_t *o = m_new_obj(mp_obj_uctypes_struct_t);
|
||||||
o->base.type = type_in;
|
o->base.type = type_in;
|
||||||
o->desc = args[0];
|
o->addr = (void*)mp_obj_get_int(args[0]);
|
||||||
o->addr = (void*)mp_obj_get_int(args[1]);
|
o->desc = args[1];
|
||||||
o->flags = LAYOUT_NATIVE;
|
o->flags = LAYOUT_NATIVE;
|
||||||
if (n_args == 3) {
|
if (n_args == 3) {
|
||||||
o->flags = mp_obj_get_int(args[2]);
|
o->flags = mp_obj_get_int(args[2]);
|
||||||
|
|
|
@ -7,7 +7,7 @@ desc = {
|
||||||
|
|
||||||
data = bytearray(b"01234567")
|
data = bytearray(b"01234567")
|
||||||
|
|
||||||
S = uctypes.struct(desc, uctypes.addressof(data), uctypes.LITTLE_ENDIAN)
|
S = uctypes.struct(uctypes.addressof(data), desc, uctypes.LITTLE_ENDIAN)
|
||||||
|
|
||||||
# Arrays of UINT8 are accessed as bytearrays
|
# Arrays of UINT8 are accessed as bytearrays
|
||||||
print(S.arr)
|
print(S.arr)
|
||||||
|
|
|
@ -22,7 +22,7 @@ desc = {
|
||||||
|
|
||||||
data = bytearray(b"01")
|
data = bytearray(b"01")
|
||||||
|
|
||||||
S = uctypes.struct(desc, uctypes.addressof(data), uctypes.LITTLE_ENDIAN)
|
S = uctypes.struct(uctypes.addressof(data), desc, uctypes.LITTLE_ENDIAN)
|
||||||
|
|
||||||
#print(S)
|
#print(S)
|
||||||
print(hex(S.s0))
|
print(hex(S.s0))
|
||||||
|
|
|
@ -31,7 +31,7 @@ desc = {
|
||||||
|
|
||||||
data = bytearray(b"01")
|
data = bytearray(b"01")
|
||||||
|
|
||||||
S = uctypes.struct(desc, uctypes.addressof(data), uctypes.NATIVE)
|
S = uctypes.struct(uctypes.addressof(data), desc, uctypes.NATIVE)
|
||||||
|
|
||||||
#print(S)
|
#print(S)
|
||||||
print(hex(S.s0))
|
print(hex(S.s0))
|
||||||
|
|
|
@ -16,7 +16,7 @@ bytes = b"01"
|
||||||
addr = uctypes.addressof(bytes)
|
addr = uctypes.addressof(bytes)
|
||||||
buf = addr.to_bytes(uctypes.sizeof(desc))
|
buf = addr.to_bytes(uctypes.sizeof(desc))
|
||||||
|
|
||||||
S = uctypes.struct(desc, uctypes.addressof(buf), uctypes.LITTLE_ENDIAN)
|
S = uctypes.struct(uctypes.addressof(buf), desc, uctypes.LITTLE_ENDIAN)
|
||||||
|
|
||||||
print(S.ptr[0])
|
print(S.ptr[0])
|
||||||
assert S.ptr[0] == ord("0")
|
assert S.ptr[0] == ord("0")
|
||||||
|
|
|
@ -17,7 +17,7 @@ bytes = b"01"
|
||||||
addr = uctypes.addressof(bytes)
|
addr = uctypes.addressof(bytes)
|
||||||
buf = addr.to_bytes(uctypes.sizeof(desc))
|
buf = addr.to_bytes(uctypes.sizeof(desc))
|
||||||
|
|
||||||
S = uctypes.struct(desc, uctypes.addressof(buf), uctypes.NATIVE)
|
S = uctypes.struct(uctypes.addressof(buf), desc, uctypes.NATIVE)
|
||||||
|
|
||||||
print(S.ptr[0])
|
print(S.ptr[0])
|
||||||
assert S.ptr[0] == ord("0")
|
assert S.ptr[0] == ord("0")
|
||||||
|
|
|
@ -10,7 +10,7 @@ desc = {
|
||||||
|
|
||||||
data = bytearray(b"01234567")
|
data = bytearray(b"01234567")
|
||||||
|
|
||||||
S = uctypes.struct(desc, uctypes.addressof(data), uctypes.LITTLE_ENDIAN)
|
S = uctypes.struct(uctypes.addressof(data), desc, uctypes.LITTLE_ENDIAN)
|
||||||
|
|
||||||
print(uctypes.sizeof(S.arr))
|
print(uctypes.sizeof(S.arr))
|
||||||
assert uctypes.sizeof(S.arr) == 2
|
assert uctypes.sizeof(S.arr) == 2
|
||||||
|
|
|
@ -32,7 +32,7 @@ S5 = {
|
||||||
|
|
||||||
assert uctypes.sizeof(S5) == 12
|
assert uctypes.sizeof(S5) == 12
|
||||||
|
|
||||||
s5 = uctypes.struct(S5, 0)
|
s5 = uctypes.struct(0, S5)
|
||||||
assert uctypes.sizeof(s5) == 12
|
assert uctypes.sizeof(s5) == 12
|
||||||
assert uctypes.sizeof(s5.sub) == 2
|
assert uctypes.sizeof(s5.sub) == 2
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue