summaryrefslogtreecommitdiffstatshomepage
path: root/unix
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-01-20 19:42:39 +0200
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2014-01-20 20:37:01 +0200
commitfc35aa682847e9123064eeaf5955c06275b95a0d (patch)
tree0f7fd5b5b9e6d5f9ec997d46b2e9328108a91711 /unix
parentff3bdea49d10ea129fafb2e8be0cdaed172a036b (diff)
downloadmicropython-fc35aa682847e9123064eeaf5955c06275b95a0d.tar.gz
micropython-fc35aa682847e9123064eeaf5955c06275b95a0d.zip
unix socket: Add send() and recv() methods.
CPython _socket actually have only those and doesn't provide stream interface (higher-level CPython "socket" what adds this). +516 bytes x86.
Diffstat (limited to 'unix')
-rw-r--r--unix/socket.c38
1 files changed, 38 insertions, 0 deletions
diff --git a/unix/socket.c b/unix/socket.c
index 708cf7af52..7da6bb20d0 100644
--- a/unix/socket.c
+++ b/unix/socket.c
@@ -127,6 +127,42 @@ static mp_obj_t socket_accept(mp_obj_t self_in) {
}
static MP_DEFINE_CONST_FUN_OBJ_1(socket_accept_obj, socket_accept);
+static mp_obj_t socket_recv(uint n_args, const mp_obj_t *args) {
+ mp_obj_socket_t *self = args[0];
+ int sz = MP_OBJ_SMALL_INT_VALUE(args[1]);
+ int flags = 0;
+
+ if (n_args > 2) {
+ flags = MP_OBJ_SMALL_INT_VALUE(args[2]);
+ }
+
+ char *buf = m_new(char, sz + 1);
+ int out_sz = recv(self->fd, buf, sz, flags);
+ RAISE_ERRNO(out_sz, errno);
+
+ buf = m_realloc(buf, sz + 1, out_sz + 1);
+ buf[out_sz] = 0;
+ return MP_OBJ_NEW_QSTR(qstr_from_str_take(buf, out_sz + 1));
+}
+static MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(socket_recv_obj, 2, 3, socket_recv);
+
+static mp_obj_t socket_send(uint n_args, const mp_obj_t *args) {
+ mp_obj_socket_t *self = args[0];
+ int flags = 0;
+
+ if (n_args > 2) {
+ flags = MP_OBJ_SMALL_INT_VALUE(args[2]);
+ }
+
+ const char *buf = qstr_str(mp_obj_str_get(args[1]));
+ int sz = strlen(buf);
+ int out_sz = send(self->fd, buf, sz, flags);
+ RAISE_ERRNO(out_sz, errno);
+
+ return MP_OBJ_NEW_SMALL_INT(out_sz);
+}
+static MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(socket_send_obj, 2, 3, socket_send);
+
static mp_obj_t socket_make_new(mp_obj_t type_in, uint n_args, uint n_kw, const mp_obj_t *args) {
int family = AF_INET;
int type = SOCK_STREAM;
@@ -159,6 +195,8 @@ static const mp_method_t rawsocket_type_methods[] = {
{ "bind", &socket_bind_obj },
{ "listen", &socket_listen_obj },
{ "accept", &socket_accept_obj },
+ { "recv", &socket_recv_obj },
+ { "send", &socket_send_obj },
{ "close", &socket_close_obj },
#if MICROPY_SOCKET_EXTRA
{ "recv", &mp_stream_read_obj },