Skip to content

Commit

Permalink
Cleaning up sorting of error messages.
Browse files Browse the repository at this point in the history
Closes #75.
  • Loading branch information
gvwilson committed Jul 15, 2016
1 parent aee474a commit 14cce03
Showing 1 changed file with 27 additions and 14 deletions.
41 changes: 27 additions & 14 deletions bin/util.py
Original file line number Diff line number Diff line change
Expand Up @@ -62,26 +62,39 @@ def check(self, condition, location, fmt, *args):
def add(self, location, fmt, *args):
"""Append error unilaterally."""

if isinstance(location, type(None)):
coords = ''
elif isinstance(location, str):
coords = '{0}: '.format(location)
elif isinstance(location, tuple):
filename, line_number = location
coords = '{0}:{1}: '.format(*location)
else:
assert False, 'Unknown location "{0}"/{1}'.format(location, type(location))

self.messages.append(coords + fmt.format(*args))
self.messages.append((location, fmt.format(*args)))


def report(self, stream=sys.stdout):
"""Report all messages."""
"""Report all messages in order."""

if not self.messages:
return
for m in sorted(self.messages):
print(m, file=stream)

def pretty(item):
location, message = item
if isinstance(location, type(None)):
return message
elif isinstance(location, str):
return location + ': ' + message
elif isinstance(location, tuple):
return '{0}:{1}: '.format(*location) + message
else:
assert False, 'Unknown item "{0}"'.format(item)

def key(item):
location, message = item
if isinstance(location, type(None)):
return ('', -1, message)
elif isinstance(location, str):
return (location, -1, message)
elif isinstance(location, tuple):
return (location[0], location[1], message)
else:
assert False, 'Unknown item "{0}"'.format(item)

for m in sorted(self.messages, key=key):
print(pretty(m), file=stream)


def read_markdown(parser, path):
Expand Down

0 comments on commit 14cce03

Please sign in to comment.