From c78b2a8dd8a2ce6c03f6c8cc4c5cc1be85404756 Mon Sep 17 00:00:00 2001 From: "Alon Zakai (kripken)" Date: Fri, 29 Nov 2019 14:50:04 -0800 Subject: [PATCH] Fix source maps issues on windows; followup to #9882 --- tests/test_other.py | 16 ++++++++-------- tools/wasm-sourcemap.py | 3 ++- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/tests/test_other.py b/tests/test_other.py index bfedacd16fe1e..671763e215af0 100644 --- a/tests/test_other.py +++ b/tests/test_other.py @@ -9723,17 +9723,17 @@ def test_lsan_leaks(self, ext): @parameterized({ 'c': ['c', [ r'in malloc.*a\.out\.wasm\+0x', - r'(?im)in f (|[/a-z\.]:).*/test_lsan_leaks\.c:6:21$', - r'(?im)in main (|[/a-z\.]:).*/test_lsan_leaks\.c:10:16$', - r'(?im)in main (|[/a-z\.]:).*/test_lsan_leaks\.c:12:3$', - r'(?im)in main (|[/a-z\.]:).*/test_lsan_leaks\.c:13:3$', + r'(?im)in f (|[/a-z\.\\]:).*test_lsan_leaks\.c:6:21$', + r'(?im)in main (|[/a-z\.\\]:).*test_lsan_leaks\.c:10:16$', + r'(?im)in main (|[/a-z\.\\]:).*test_lsan_leaks\.c:12:3$', + r'(?im)in main (|[/a-z\.\\]:).*test_lsan_leaks\.c:13:3$', ]], 'cpp': ['cpp', [ r'in operator new\[\]\(unsigned long\).*a\.out\.wasm\+0x', - r'(?im)in f\(\) (|[/a-z\.]:).*/test_lsan_leaks\.cpp:4:21$', - r'(?im)in main (|[/a-z\.]:).*/test_lsan_leaks\.cpp:8:16$', - r'(?im)in main (|[/a-z\.]:).*/test_lsan_leaks\.cpp:10:3$', - r'(?im)in main (|[/a-z\.]:).*/test_lsan_leaks\.cpp:11:3$', + r'(?im)in f\(\) (|[/a-z\.\\]:).*test_lsan_leaks\.cpp:4:21$', + r'(?im)in main (|[/a-z\.\\]:).*test_lsan_leaks\.cpp:8:16$', + r'(?im)in main (|[/a-z\.\\]:).*test_lsan_leaks\.cpp:10:3$', + r'(?im)in main (|[/a-z\.\\]:).*test_lsan_leaks\.cpp:11:3$', ]], }) @no_fastcomp('lsan not supported on fastcomp') diff --git a/tools/wasm-sourcemap.py b/tools/wasm-sourcemap.py index 6c1c9abfbfc23..8fcb82994a737 100755 --- a/tools/wasm-sourcemap.py +++ b/tools/wasm-sourcemap.py @@ -59,7 +59,6 @@ def resolve(self, name): if name in self.cache: return self.cache[name] - result = name.replace('\\', '/').replace('//', '/') for p in self.prefixes: if name.startswith(p['prefix']): if p['replacement'] is None: @@ -270,6 +269,8 @@ def build_sourcemap(entries, code_section_offset, prefixes, collect_sources, bas column = 1 address = entry['address'] + code_section_offset file_name = entry['file'] + # normalize between OSes + file_name = file_name.replace('\\', '/').replace('//', '/') # if prefixes were provided, we use that; otherwise, we emit a relative # path if prefixes.provided():