esp32/modsocket: Allow getaddrinfo() to take up to 6 args.
Currently only the first 2 args are used, but this patch should at least make getaddrinfo() signature-compatible with CPython and other bare-metal ports that use the lwip bindings.
This commit is contained in:
parent
e600810f39
commit
cced43feb8
|
@ -520,9 +520,11 @@ STATIC mp_obj_t get_socket(size_t n_args, const mp_obj_t *args) {
|
||||||
}
|
}
|
||||||
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(get_socket_obj, 0, 3, get_socket);
|
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(get_socket_obj, 0, 3, get_socket);
|
||||||
|
|
||||||
STATIC mp_obj_t esp_socket_getaddrinfo(const mp_obj_t host, const mp_obj_t port) {
|
STATIC mp_obj_t esp_socket_getaddrinfo(size_t n_args, const mp_obj_t *args) {
|
||||||
|
// TODO support additional args beyond the first two
|
||||||
|
|
||||||
struct addrinfo *res = NULL;
|
struct addrinfo *res = NULL;
|
||||||
_socket_getaddrinfo2(host, port, &res);
|
_socket_getaddrinfo2(args[0], args[1], &res);
|
||||||
mp_obj_t ret_list = mp_obj_new_list(0, NULL);
|
mp_obj_t ret_list = mp_obj_new_list(0, NULL);
|
||||||
|
|
||||||
for (struct addrinfo *resi = res; resi; resi = resi->ai_next) {
|
for (struct addrinfo *resi = res; resi; resi = resi->ai_next) {
|
||||||
|
@ -552,7 +554,7 @@ STATIC mp_obj_t esp_socket_getaddrinfo(const mp_obj_t host, const mp_obj_t port)
|
||||||
if (res) lwip_freeaddrinfo(res);
|
if (res) lwip_freeaddrinfo(res);
|
||||||
return ret_list;
|
return ret_list;
|
||||||
}
|
}
|
||||||
STATIC MP_DEFINE_CONST_FUN_OBJ_2(esp_socket_getaddrinfo_obj, esp_socket_getaddrinfo);
|
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(esp_socket_getaddrinfo_obj, 2, 6, esp_socket_getaddrinfo);
|
||||||
|
|
||||||
STATIC mp_obj_t esp_socket_initialize() {
|
STATIC mp_obj_t esp_socket_initialize() {
|
||||||
static int initialized = 0;
|
static int initialized = 0;
|
||||||
|
|
Loading…
Reference in New Issue