Skip to content

Commit 601b210

Browse files
committed
py/stream: Support additional arguments for stream_write1_method().
As suggested adding a stream_write_generic() function. Tested the different write timeouts with a RP2 using flow control. Tested support of the additional arguments of uart.write(). Signed-off-by: robert-hh <robert@hammelrath.com>
1 parent b37d132 commit 601b210

File tree

2 files changed

+10
-8
lines changed

2 files changed

+10
-8
lines changed

py/stream.c

Lines changed: 9 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -261,7 +261,7 @@ void mp_stream_write_adaptor(void *self, const char *buf, size_t len) {
261261
mp_stream_write(MP_OBJ_FROM_PTR(self), buf, len, MP_STREAM_RW_WRITE);
262262
}
263263

264-
static mp_obj_t stream_write_method(size_t n_args, const mp_obj_t *args) {
264+
static mp_obj_t stream_write_generic(size_t n_args, const mp_obj_t *args, byte flags) {
265265
mp_buffer_info_t bufinfo;
266266
mp_get_buffer_raise(args[1], &bufinfo, MP_BUFFER_READ);
267267
size_t max_len = (size_t)-1;
@@ -276,16 +276,18 @@ static mp_obj_t stream_write_method(size_t n_args, const mp_obj_t *args) {
276276
}
277277
}
278278
bufinfo.len -= off;
279-
return mp_stream_write(args[0], (byte *)bufinfo.buf + off, MIN(bufinfo.len, max_len), MP_STREAM_RW_WRITE);
279+
return mp_stream_write(args[0], (byte *)bufinfo.buf + off, MIN(bufinfo.len, max_len), flags);
280+
}
281+
282+
static mp_obj_t stream_write_method(size_t n_args, const mp_obj_t *args) {
283+
return stream_write_generic(n_args, args, MP_STREAM_RW_WRITE);
280284
}
281285
MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream_write_obj, 2, 4, stream_write_method);
282286

283-
static mp_obj_t stream_write1_method(mp_obj_t self_in, mp_obj_t arg) {
284-
mp_buffer_info_t bufinfo;
285-
mp_get_buffer_raise(arg, &bufinfo, MP_BUFFER_READ);
286-
return mp_stream_write(self_in, bufinfo.buf, bufinfo.len, MP_STREAM_RW_WRITE | MP_STREAM_RW_ONCE);
287+
static mp_obj_t stream_write1_method(size_t n_args, const mp_obj_t *args) {
288+
return stream_write_generic(n_args, args, MP_STREAM_RW_WRITE | MP_STREAM_RW_ONCE);
287289
}
288-
MP_DEFINE_CONST_FUN_OBJ_2(mp_stream_write1_obj, stream_write1_method);
290+
MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream_write1_obj, 2, 4, stream_write1_method);
289291

290292
static mp_obj_t stream_readinto_generic(size_t n_args, const mp_obj_t *args, byte flags) {
291293
mp_buffer_info_t bufinfo;

py/stream.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -83,7 +83,7 @@ MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream_readinto1_obj);
8383
MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream_unbuffered_readline_obj);
8484
MP_DECLARE_CONST_FUN_OBJ_1(mp_stream_unbuffered_readlines_obj);
8585
MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream_write_obj);
86-
MP_DECLARE_CONST_FUN_OBJ_2(mp_stream_write1_obj);
86+
MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream_write1_obj);
8787
MP_DECLARE_CONST_FUN_OBJ_1(mp_stream_close_obj);
8888
MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream___exit___obj);
8989
MP_DECLARE_CONST_FUN_OBJ_VAR_BETWEEN(mp_stream_seek_obj);

0 commit comments

Comments
 (0)