Merge pull request #6197 from geky/revert-pretty-bars

Revert "Added pretty bar printing for compile output"
pull/6119/merge
Cruz Monrreal 2018-02-26 14:35:49 -06:00 committed by GitHub
commit d49862bcfa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 10 additions and 83 deletions

View File

@ -528,24 +528,19 @@ def build_project(src_paths, build_path, target, toolchain_name,
memap_instance = getattr(toolchain, 'memap_instance', None) memap_instance = getattr(toolchain, 'memap_instance', None)
memap_table = '' memap_table = ''
if memap_instance: if memap_instance:
real_stats_depth = stats_depth if stats_depth is not None else 2 # Write output to stdout in text (pretty table) format
memap_table = memap_instance.generate_output('table', real_stats_depth) memap_table = memap_instance.generate_output('table', stats_depth)
if not silent: if not silent:
if not stats_depth: print(memap_table)
memap_bars = memap_instance.generate_output('bars',
real_stats_depth, None,
getattr(toolchain.target, 'device_name', None))
print(memap_bars)
else:
print(memap_table)
# Write output to file in JSON format # Write output to file in JSON format
map_out = join(build_path, name + "_map.json") map_out = join(build_path, name + "_map.json")
memap_instance.generate_output('json', real_stats_depth, map_out) memap_instance.generate_output('json', stats_depth, map_out)
# Write output to file in CSV format for the CI # Write output to file in CSV format for the CI
map_csv = join(build_path, name + "_map.csv") map_csv = join(build_path, name + "_map.csv")
memap_instance.generate_output('csv-ci', real_stats_depth, map_csv) memap_instance.generate_output('csv-ci', stats_depth, map_csv)
resources.detect_duplicates(toolchain) resources.detect_duplicates(toolchain)

View File

@ -118,7 +118,7 @@ if __name__ == '__main__':
"--stats-depth", "--stats-depth",
type=int, type=int,
dest="stats_depth", dest="stats_depth",
default=None, default=2,
help="Depth level for static memory report") help="Depth level for static memory report")
# Local run # Local run

View File

@ -10,11 +10,9 @@ from os.path import basename, dirname, join, relpath, commonprefix
import re import re
import csv import csv
import json import json
import math
from argparse import ArgumentParser from argparse import ArgumentParser
from copy import deepcopy from copy import deepcopy
from prettytable import PrettyTable from prettytable import PrettyTable
from tools.arm_pack_manager import Cache
from .utils import (argparse_filestring_type, argparse_lowercase_hyphen_type, from .utils import (argparse_filestring_type, argparse_lowercase_hyphen_type,
argparse_uppercase_type) argparse_uppercase_type)
@ -509,7 +507,7 @@ class MemapParser(object):
export_formats = ["json", "csv-ci", "table"] export_formats = ["json", "csv-ci", "table"]
def generate_output(self, export_format, depth, file_output=None, *args): def generate_output(self, export_format, depth, file_output=None):
""" Generates summary of memory map data """ Generates summary of memory map data
Positional arguments: Positional arguments:
@ -534,9 +532,8 @@ class MemapParser(object):
to_call = {'json': self.generate_json, to_call = {'json': self.generate_json,
'csv-ci': self.generate_csv, 'csv-ci': self.generate_csv,
'table': self.generate_table, 'table': self.generate_table}[export_format]
'bars': self.generate_bars}[export_format] output = to_call(file_desc)
output = to_call(file_desc, *args)
if file_desc is not stdout: if file_desc is not stdout:
file_desc.close() file_desc.close()
@ -620,71 +617,6 @@ class MemapParser(object):
return output return output
def generate_bars(self, file_desc, device_name=None):
""" Generates nice looking bars that represent the memory consumption
Returns: string containing nice looking bars
"""
# TODO add tty detection, and width detection probably
WIDTH = 72
try:
# NOTE this only works on linux
import sys, fcntl, termios, struct
height, width, _, _ = struct.unpack('HHHH',
fcntl.ioctl(sys.stdout.fileno(), termios.TIOCGWINSZ,
struct.pack('HHHH', 0, 0, 0, 0)))
WIDTH = min(width, WIDTH)
except Exception:
pass
text = self.subtotal['.text']
data = self.subtotal['.data']
bss = self.subtotal['.bss']
rom_used = self.mem_summary['total_flash']
ram_used = self.mem_summary['static_ram']
# No device_name = no cmsis-pack = we don't know the memory layout
if device_name is not None:
try:
cache = Cache(False, False)
cmsis_part = cache.index[device_name]
rom_avail = int(cmsis_part['memory']['IROM1']['size'], 0)
ram_avail = int(cmsis_part['memory']['IRAM1']['size'], 0)
except KeyError:
# If we don't have the expected regions, fall back to no device_name
device_name = None
PREFIXES = ['', 'K', 'M', 'G', 'T', 'P', 'E']
def unit(n, u='B', p=3):
if n == 0:
return '0' + u
scale = math.floor(math.log(n, 1024))
return '{1:.{0}g}{2}{3}'.format(p, n/(1024**scale), PREFIXES[int(scale)], u)
usage = "Text {} Data {} BSS {}".format(unit(text), unit(data), unit(bss))
avail = "ROM {} RAM {}".format(unit(rom_used), unit(ram_used))
output = ["{0} {1:>{2}}".format(usage, avail,
abs(WIDTH-len(usage)-1) if device_name is not None else 0)]
if device_name is not None:
for region, avail, uses in [
('ROM', rom_avail, [('|', text), ('|', data)]),
('RAM', ram_avail, [('|', bss), ('|', data)])]:
barwidth = WIDTH-17 - len(region)
used = sum(use for c, use in uses)
bars = [(c, (barwidth*use) // avail) for c, use in uses]
bars.append((' ', barwidth - sum(width for c, width in bars)))
bars = ''.join(c*width for c, width in bars)
output.append("{0} [{2:<{1}}] {3:>13}".format(
region, barwidth, bars,
"{}/{}".format(unit(used), unit(avail))))
return '\n'.join(output)
toolchains = ["ARM", "ARM_STD", "ARM_MICRO", "GCC_ARM", "GCC_CR", "IAR"] toolchains = ["ARM", "ARM_STD", "ARM_MICRO", "GCC_ARM", "GCC_CR", "IAR"]
def compute_report(self): def compute_report(self):