diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:30:19 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:30:19 +0000 |
commit | 5c1676dfe6d2f3c837a5e074117b45613fd29a72 (patch) | |
tree | cbffb45144febf451e54061db2b21395faf94bfe /tools/performance-log-resolve.py | |
parent | Initial commit. (diff) | |
download | gimp-5c1676dfe6d2f3c837a5e074117b45613fd29a72.tar.xz gimp-5c1676dfe6d2f3c837a5e074117b45613fd29a72.zip |
Adding upstream version 2.10.34.upstream/2.10.34upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tools/performance-log-resolve.py')
-rwxr-xr-x | tools/performance-log-resolve.py | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/tools/performance-log-resolve.py b/tools/performance-log-resolve.py new file mode 100755 index 0000000..272f0eb --- /dev/null +++ b/tools/performance-log-resolve.py @@ -0,0 +1,55 @@ +#!/usr/bin/env python3 + +""" +performance-log-resolve.py -- Resolve GIMP performance log backtrace symbols +Copyright (C) 2018 Ell + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 3 of the License, or +(at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program. If not, see <https://www.gnu.org/licenses/>. + + +Usage: performance-log-resolve.py < infile > outfile +""" + +from xml.etree import ElementTree +import sys + +empty_element = ElementTree.Element ("") + +# Read performance log from STDIN +log = ElementTree.fromstring (sys.stdin.buffer.read ()) + +address_map = log.find ("address-map") + +if address_map: + # Create address dictionary + addresses = {} + + for address in address_map.iterfind ("address"): + addresses[address.get ("value")] = list (address) + + # Resolve addresses in backtraces + for sample in (log.find ("samples") or empty_element).iterfind ("sample"): + for thread in sample.find ("backtrace") or (): + for frame in thread: + address = addresses.get (frame.get ("address")) + + if address: + frame.text = "\n" + frame.extend (address) + + # Remove address map + log.remove (address_map) + +# Write performance log to STDOUT +sys.stdout.buffer.write (ElementTree.tostring (log)) |