import sys
import re
class Region:
def __init__(self, name: str, used: int, total: int):
self.name = name
self.used = used
self.total = total
@property
def percentage(self) -> float:
return self.used/self.total*100
def __sub__(self, __o: object) -> object:
return Region(self.name, self.used - __o.used, self.total)
def __eq__(self, __o: object) -> bool:
return self.name == __o.name
def __str__(self):
return f'{self.name}: {self.used:+0d} / {self.total:d} B ({self.percentage:+0.2f}%)'
def get_regions(string: str) -> list:
regex = r"^\s+(\S+):\s+(\d+)\s(\S+)\s+(\d+)\s(\S+)\s+([\d.]+)%$"
UNIT_MULTIPLIER = {'B': 1, 'KB': 1024}
regions = []
for match in re.finditer(regex, string, re.MULTILINE):
regions.append(
Region(
match.group(1),
int(match.group(2)) * UNIT_MULTIPLIER[match.group(3)],
int(match.group(4)) * UNIT_MULTIPLIER[match.group(5)]))
return regions
if __name__ == '__main__':
if len(sys.argv) != 3:
print(f'Usage: {sys.argv[0]} <base_file> <diff_file>')
sys.exit(1)
with open(sys.argv[1], 'r') as base_file:
base_regions = get_regions(base_file.read())
with open(sys.argv[2], 'r') as diff_file:
diff_regions = get_regions(diff_file.read())
for region in base_regions:
if region in diff_regions:
print(diff_regions[diff_regions.index(region)] - region)