diff options
author | Damien George <damien.p.george@gmail.com> | 2014-06-03 10:46:36 +0100 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2014-06-03 10:46:36 +0100 |
commit | 07995e947967b7159cf88c48c2f09463015c1d45 (patch) | |
tree | 7affa52a8ac05faa07ec777a319015731a5abc73 /py/vm.c | |
parent | 509c7a7854f24c202832d8fb1369130bf8908261 (diff) | |
parent | 411732e93bcbeb529bc5f9722015b61c63eef3c5 (diff) | |
download | micropython-07995e947967b7159cf88c48c2f09463015c1d45.tar.gz micropython-07995e947967b7159cf88c48c2f09463015c1d45.zip |
Merge pull request #649 from pfalcon/multi-opt
Support multiple bytecode optimisation levels
Diffstat (limited to 'py/vm.c')
-rw-r--r-- | py/vm.c | 12 |
1 files changed, 8 insertions, 4 deletions
@@ -1042,12 +1042,16 @@ exception_handler: machine_uint_t code_info_size = code_info[0] | (code_info[1] << 8) | (code_info[2] << 16) | (code_info[3] << 24); qstr source_file = code_info[4] | (code_info[5] << 8) | (code_info[6] << 16) | (code_info[7] << 24); qstr block_name = code_info[8] | (code_info[9] << 8) | (code_info[10] << 16) | (code_info[11] << 24); - machine_uint_t source_line = 1; + machine_uint_t source_line = 0; machine_uint_t bc = code_state->ip - code_info - code_info_size; //printf("find %lu %d %d\n", bc, code_info[12], code_info[13]); - for (const byte* ci = code_info + 12; *ci && bc >= ((*ci) & 31); ci++) { - bc -= *ci & 31; - source_line += *ci >> 5; + const byte* ci = code_info + 12; + if (*ci) { + source_line = 1; + for (; *ci && bc >= ((*ci) & 31); ci++) { + bc -= *ci & 31; + source_line += *ci >> 5; + } } mp_obj_exception_add_traceback(nlr.ret_val, source_file, source_line, block_name); } |