From 36c4499d36a36ab3e1a68545e613bce61fb15f3c Mon Sep 17 00:00:00 2001 From: Paul Sokolovsky Date: Mon, 13 Jan 2014 19:20:46 +0200 Subject: [PATCH] Implement str() and repr() builtin functions. --- py/builtin.c | 16 ++++++++++++++++ py/builtin.h | 2 ++ py/misc.h | 2 ++ py/mpqstrraw.h | 2 ++ py/runtime.c | 2 ++ 5 files changed, 24 insertions(+) diff --git a/py/builtin.c b/py/builtin.c index a45b1463d9..bc10f29d7e 100644 --- a/py/builtin.c +++ b/py/builtin.c @@ -338,3 +338,19 @@ static mp_obj_t mp_builtin_sorted(mp_obj_t args, mp_map_t *kwargs) { return self; } MP_DEFINE_CONST_FUN_OBJ_KW(mp_builtin_sorted_obj, 1, mp_builtin_sorted); + +mp_obj_t mp_builtin_str(mp_obj_t o) { + vstr_t *vstr = vstr_new(); + mp_obj_print_helper(vstr_printf_wrapper, vstr, o, PRINT_STR); + return mp_obj_new_str(qstr_from_str_take(vstr->buf, vstr->alloc)); +} + +MP_DEFINE_CONST_FUN_OBJ_1(mp_builtin_str_obj, mp_builtin_str); + +mp_obj_t mp_builtin_repr(mp_obj_t o) { + vstr_t *vstr = vstr_new(); + mp_obj_print_helper(vstr_printf_wrapper, vstr, o, PRINT_REPR); + return mp_obj_new_str(qstr_from_str_take(vstr->buf, vstr->alloc)); +} + +MP_DEFINE_CONST_FUN_OBJ_1(mp_builtin_repr_obj, mp_builtin_repr); diff --git a/py/builtin.h b/py/builtin.h index 3401528a68..0716b952e5 100644 --- a/py/builtin.h +++ b/py/builtin.h @@ -23,3 +23,5 @@ MP_DECLARE_CONST_FUN_OBJ(mp_builtin_print_obj); MP_DECLARE_CONST_FUN_OBJ(mp_builtin_range_obj); MP_DECLARE_CONST_FUN_OBJ(mp_builtin_sorted_obj); MP_DECLARE_CONST_FUN_OBJ(mp_builtin_sum_obj); +MP_DECLARE_CONST_FUN_OBJ(mp_builtin_str_obj); +MP_DECLARE_CONST_FUN_OBJ(mp_builtin_repr_obj); diff --git a/py/misc.h b/py/misc.h index e985bc5253..8c2c85491d 100644 --- a/py/misc.h +++ b/py/misc.h @@ -81,6 +81,8 @@ void vstr_add_strn(vstr_t *vstr, const char *str, int len); //void vstr_add_le32(vstr_t *vstr, unsigned int v); void vstr_cut_tail(vstr_t *vstr, int len); void vstr_printf(vstr_t *vstr, const char *fmt, ...); +// TODO: do we need wrapper at all? +void vstr_printf_wrapper(void *env, const char *fmt, ...); #ifdef va_start void vstr_vprintf(vstr_t *vstr, const char *fmt, va_list ap); diff --git a/py/mpqstrraw.h b/py/mpqstrraw.h index c3cda84b4d..615c9da990 100644 --- a/py/mpqstrraw.h +++ b/py/mpqstrraw.h @@ -56,9 +56,11 @@ Q(ord) Q(pow) Q(print) Q(range) +Q(repr) Q(set) Q(sorted) Q(sum) +Q(str) Q(tuple) Q(type) Q(zip) diff --git a/py/runtime.c b/py/runtime.c index 3d8f0c9a7e..3f7595787b 100644 --- a/py/runtime.c +++ b/py/runtime.c @@ -136,6 +136,8 @@ void rt_init(void) { mp_map_add_qstr(&map_builtins, MP_QSTR_range, (mp_obj_t)&mp_builtin_range_obj); mp_map_add_qstr(&map_builtins, MP_QSTR_sorted, (mp_obj_t)&mp_builtin_sorted_obj); mp_map_add_qstr(&map_builtins, MP_QSTR_sum, (mp_obj_t)&mp_builtin_sum_obj); + mp_map_add_qstr(&map_builtins, MP_QSTR_str, (mp_obj_t)&mp_builtin_str_obj); + mp_map_add_qstr(&map_builtins, MP_QSTR_repr, (mp_obj_t)&mp_builtin_repr_obj); next_unique_code_id = 1; // 0 indicates "no code" unique_codes_alloc = 0;