summaryrefslogtreecommitdiff
path: root/py/objexcept.c
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-01-19 12:38:49 +0000
committerDamien George <damien.p.george@gmail.com>2014-01-19 12:38:49 +0000
commit136b149e417314e5ad46b3ee78b811df57e74f41 (patch)
tree203a941101aae04a8e20028c5301286da5ba87b4 /py/objexcept.c
parent49f6a99c65943c6b040e7237f7b86cbe184826c0 (diff)
py: Add full traceback to exception printing.
Diffstat (limited to 'py/objexcept.c')
-rw-r--r--py/objexcept.c38
1 files changed, 18 insertions, 20 deletions
diff --git a/py/objexcept.c b/py/objexcept.c
index 326d320d5..2e145ee35 100644
--- a/py/objexcept.c
+++ b/py/objexcept.c
@@ -17,9 +17,7 @@
// have args tuple (or otherwise have it as NULL).
typedef struct mp_obj_exception_t {
mp_obj_base_t base;
- qstr source_file;
- machine_uint_t source_line;
- qstr source_block;
+ mp_obj_t traceback; // a list object, holding (file,line,block) as numbers (not Python objects); a hack for now
qstr id;
qstr msg;
mp_obj_tuple_t args;
@@ -90,8 +88,7 @@ mp_obj_t mp_obj_new_exception_msg_varg(qstr id, const char *fmt, ...) {
// make exception object
mp_obj_exception_t *o = m_new_obj_var(mp_obj_exception_t, mp_obj_t*, 0);
o->base.type = &exception_type;
- o->source_file = 0;
- o->source_line = 0;
+ o->traceback = MP_OBJ_NULL;
o->id = id;
o->args.len = 0;
if (fmt == NULL) {
@@ -115,26 +112,27 @@ qstr mp_obj_exception_get_type(mp_obj_t self_in) {
return self->id;
}
-void mp_obj_exception_set_source_info(mp_obj_t self_in, qstr file, machine_uint_t line, qstr block) {
+void mp_obj_exception_add_traceback(mp_obj_t self_in, qstr file, machine_uint_t line, qstr block) {
assert(MP_OBJ_IS_TYPE(self_in, &exception_type));
mp_obj_exception_t *self = self_in;
- // TODO make a list of file/line pairs for the traceback
- // for now, just keep the first one
- if (file != 0 && self->source_file == 0) {
- self->source_file = file;
- }
- if (line != 0 && self->source_line == 0) {
- self->source_line = line;
- }
- if (block != 0 && self->source_block == 0) {
- self->source_block = block;
+ // for traceback, we are just using the list object for convenience, it's not really a list of Python objects
+ if (self->traceback == MP_OBJ_NULL) {
+ self->traceback = mp_obj_new_list(0, NULL);
}
+ mp_obj_list_append(self->traceback, (mp_obj_t)(machine_uint_t)file);
+ mp_obj_list_append(self->traceback, (mp_obj_t)(machine_uint_t)line);
+ mp_obj_list_append(self->traceback, (mp_obj_t)(machine_uint_t)block);
}
-void mp_obj_exception_get_source_info(mp_obj_t self_in, qstr *file, machine_uint_t *line, qstr *block) {
+void mp_obj_exception_get_traceback(mp_obj_t self_in, machine_uint_t *n, machine_uint_t **values) {
assert(MP_OBJ_IS_TYPE(self_in, &exception_type));
mp_obj_exception_t *self = self_in;
- *file = self->source_file;
- *line = self->source_line;
- *block = self->source_block;
+ if (self->traceback == MP_OBJ_NULL) {
+ *n = 0;
+ *values = NULL;
+ } else {
+ uint n2;
+ mp_obj_list_get(self->traceback, &n2, (mp_obj_t**)values);
+ *n = n2;
+ }
}