summaryrefslogtreecommitdiff
path: root/py/pfenv.h
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-04-08 01:29:53 +0100
committerDamien George <damien.p.george@gmail.com>2014-04-08 01:29:53 +0100
commita12a0f78b0462f9b5e8f3d4cb1b164656f44ad03 (patch)
tree1d828572cecd5fa90155050ec73a3a9afa52179c /py/pfenv.h
parent97543c5285b47c765e19d6ab7c08b36630e23c6a (diff)
py: Rename pfenv_print_int to pfenv_print_mp_int, and add back former.
stmhal relies on pfenv_* to implement its printf. Thus, it needs a pfenv_print_int which prints a proper 32-bit integer. With latest change to pfenv, this function became one that took mp_obj_t, and extracted the integer value from that object. To fix temporarily, pfenv_print_int has been renamed to pfenv_print_mp_int (to indicate it takes a mp_obj_t for the int), and pfenv_print_int has been added (which takes a normal C int). Currently, pfenv_print_int proxies to pfenv_print_mp_int, but this means it looses the MSB. Need to find a way to fix this, but the only way I can think of will duplicate lots of code.
Diffstat (limited to 'py/pfenv.h')
-rw-r--r--py/pfenv.h3
1 files changed, 2 insertions, 1 deletions
diff --git a/py/pfenv.h b/py/pfenv.h
index 32ecc159f..6240b47ac 100644
--- a/py/pfenv.h
+++ b/py/pfenv.h
@@ -18,7 +18,8 @@ typedef struct _pfenv_t {
void pfenv_vstr_add_strn(void *data, const char *str, unsigned int len);
int pfenv_print_strn(const pfenv_t *pfenv, const char *str, unsigned int len, int flags, char fill, int width);
-int pfenv_print_int(const pfenv_t *pfenv, mp_obj_t x, int sgn, int base, int base_char, int flags, char fill, int width);
+int pfenv_print_int(const pfenv_t *pfenv, int x, int sgn, int base, int base_char, int flags, char fill, int width);
+int pfenv_print_mp_int(const pfenv_t *pfenv, mp_obj_t x, int sgn, int base, int base_char, int flags, char fill, int width);
#if MICROPY_ENABLE_FLOAT
int pfenv_print_float(const pfenv_t *pfenv, mp_float_t f, char fmt, int flags, char fill, int width, int prec);
#endif