Commit fceda1c6 authored by William Stein's avatar William Stein

Made the output generated by Pyrex much more verbose with better context information.

For example:

  /* "/Volumes/HOME/s/devel/sage-1/sage/matrix/matrix_generic_sparse.pyx":581
    x = set(v.keys()).intersection(set(w.keys()))
    a = 0
    for k in x:             # <<<<<<<<<<<<<<
        a = a + v[k]*w[k]
    return a
 */
  __pyx_3 = PyObject_GetIter(__pyx_v_x); if (!__pyx_3) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 581; goto __pyx_L1;}
  for (;;) {
parent 5e8fb764
...@@ -19,6 +19,9 @@ class CCodeWriter: ...@@ -19,6 +19,9 @@ class CCodeWriter:
# in_try_finally boolean inside try of try...finally # in_try_finally boolean inside try of try...finally
# filename_table {string : int} for finding filename table indexes # filename_table {string : int} for finding filename table indexes
# filename_list [string] filenames in filename table order # filename_list [string] filenames in filename table order
# input_file_contents dict contents (=list of lines) of any file that was used as input
# to create this output C code. This is
# used to annotate the comments.
in_try_finally = 0 in_try_finally = 0
...@@ -31,6 +34,7 @@ class CCodeWriter: ...@@ -31,6 +34,7 @@ class CCodeWriter:
self.error_label = None self.error_label = None
self.filename_table = {} self.filename_table = {}
self.filename_list = [] self.filename_list = []
self.input_file_contents = {}
def putln(self, code = ""): def putln(self, code = ""):
if self.marker and self.bol: if self.marker and self.bol:
...@@ -74,9 +78,26 @@ class CCodeWriter: ...@@ -74,9 +78,26 @@ class CCodeWriter:
def indent(self): def indent(self):
self.f.write(" " * self.level) self.f.write(" " * self.level)
def file_contents(self, file):
try:
return self.input_file_contents[file]
except KeyError:
F = open(file).readlines()
self.input_file_contents[file] = F
return F
def mark_pos(self, pos): def mark_pos(self, pos):
file, line, col = pos file, line, col = pos
self.marker = '"%s":%s' % (file, line) contents = self.file_contents(file)
context = ''
for i in range(max(0,line-3), min(line+2, len(contents))):
s = contents[i]
if i+1 == line: # line numbers in pyrex start counting up from 1
s = s.rstrip() + ' # <<<<<<<<<<<<<< ' + '\n'
context += s
self.marker = '"%s":%s\n%s' % (file, line, context)
def init_labels(self): def init_labels(self):
self.label_counter = 0 self.label_counter = 0
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment