style: Change include sorter to yield one line at a time

The include sorter class normally yields one string per line and
relies on the caller to merge lines into a block of text separated by
newlines. However, there are cases when this isn't true. This makes
diffing using Python's difflib hard. This changeset updates the
include sorter to never do this and always yield one line at a time.

Signed-off-by: Andreas Sandberg <andreas.sandberg@arm.com>
Reviewed-by: Curtis Dunham <curtis.dunham@arm.com>
Reviewed-by: Steve Reinhardt <steve.reinhardt@amd.com>

--HG--
extra : rebase_source : 154c9c7e1ebdd77e09fe5f28d0cfddc9e6c6b1eb
This commit is contained in:
Andreas Sandberg 2016-03-30 15:30:05 +01:00
parent 7277defc31
commit 062b6c4c9d

View file

@ -204,17 +204,15 @@ class SortIncludes(object):
return sorted(set(includes)) return sorted(set(includes))
def dump_includes(self): def dump_includes(self):
blocks = [] includes = []
# Create a list of blocks in the prescribed include
# order. Each entry in the list is a multi-line string with
# multiple includes.
for types in self.block_order: for types in self.block_order:
block = "\n".join(self.dump_blocks(types)) block = self.dump_blocks(types)
if block: if includes and block:
blocks.append(block) includes.append("")
includes += block
self.reset() self.reset()
return "\n\n".join(blocks) return includes
def __call__(self, lines, filename, language): def __call__(self, lines, filename, language):
self.reset() self.reset()
@ -263,7 +261,8 @@ class SortIncludes(object):
# Output pending includes, a new line between, and the # Output pending includes, a new line between, and the
# current l. # current l.
yield self.dump_includes() for include in self.dump_includes():
yield include
yield '' yield ''
yield line yield line
else: else:
@ -272,9 +271,8 @@ class SortIncludes(object):
# We've reached EOF, so dump any pending includes # We've reached EOF, so dump any pending includes
if processing_includes: if processing_includes:
yield self.dump_includes() for include in self.dump_includes():
yield include
# default language types to try to apply our sorting rules to # default language types to try to apply our sorting rules to
default_languages = frozenset(('C', 'C++', 'isa', 'python', 'scons', 'swig')) default_languages = frozenset(('C', 'C++', 'isa', 'python', 'scons', 'swig'))