From c54e70843f8f06aaba5988bc865157a5673f57b1 Mon Sep 17 00:00:00 2001 From: Jeff Lane Date: Fri, 11 Dec 2015 10:41:22 -0500 Subject: bin/memory_compare: Added regex matching to lshw class to fix bug where script fails on ARM64 systems --- bin/memory_compare | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) (limited to 'bin') diff --git a/bin/memory_compare b/bin/memory_compare index 12a14ec..ec307fe 100755 --- a/bin/memory_compare +++ b/bin/memory_compare @@ -24,6 +24,7 @@ import os import sys +import re from math import log, copysign from subprocess import check_output, PIPE @@ -36,10 +37,18 @@ class LshwJsonResult: memory_reported = 0 banks_reported = 0 + + # jlane LP:1525009 + # some systems ID as "memory" and some as "memory:X" + id_regex = re.compile('memory:?\d?') + # Discovered the case can change, my x86 systems used "System Memory" + # Failing ARM system used "System memory" + desc_regex = re.compile('System Memory', re.IGNORECASE) def addHardware(self, hardware): - if hardware['id'] == 'memory': - self.memory_reported += int(hardware.get('size', 0)) + if self.id_regex.match(hardware['id']): + if self.desc_regex.match(hardware.get('description',0)): + self.memory_reported += int(hardware.get('size', 0)) elif 'bank' in hardware['id']: self.banks_reported += int(hardware.get('size', 0)) -- cgit v1.2.3 From f1746d2da888dc26e0d242c369020adbec28bca7 Mon Sep 17 00:00:00 2001 From: Jeff Lane Date: Fri, 11 Dec 2015 17:41:50 -0500 Subject: After further review, refined the matching a bit so only one regex is needed --- bin/memory_compare | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) (limited to 'bin') diff --git a/bin/memory_compare b/bin/memory_compare index ec307fe..c145038 100755 --- a/bin/memory_compare +++ b/bin/memory_compare @@ -37,18 +37,15 @@ class LshwJsonResult: memory_reported = 0 banks_reported = 0 - + # jlane LP:1525009 - # some systems ID as "memory" and some as "memory:X" - id_regex = re.compile('memory:?\d?') # Discovered the case can change, my x86 systems used "System Memory" # Failing ARM system used "System memory" desc_regex = re.compile('System Memory', re.IGNORECASE) def addHardware(self, hardware): - if self.id_regex.match(hardware['id']): - if self.desc_regex.match(hardware.get('description',0)): - self.memory_reported += int(hardware.get('size', 0)) + if self.desc_regex.match(str(hardware.get('description',0))): + self.memory_reported += int(hardware.get('size', 0)) elif 'bank' in hardware['id']: self.banks_reported += int(hardware.get('size', 0)) -- cgit v1.2.3