[PATCH] D62570: Use LLVM's debug line parser in LLDB
Greg Clayton via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jul 16 18:04:17 PDT 2019
clayborg added a comment.
So in the actual line table parsing code it seems like we are creating a line table in LLVM format, complete with sequences and a bunch of LLVM data structures, and then copying the results over into LLDB and then throwing away the LLVM line table. It would be nicer to modify the LLVM line table code to be able to get a callback when a row was pushed (if it isn't already in that format) and expose that so clients, like LLDB, can just get a callback and only store the data structure we care about. This would allow us to share the llvm line table parsing code and re-use it in LLDB, but not require twice the memory and overhead. Symbolication tools could also take advantage of this by not storing any rows except the closest matching row.
================
Comment at: lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp:201
+ original_file))
+ continue;
+
----------------
I am worried about this continue stuff. If this fails, all of our file indexes will be off and nothing will make sense. We need the indexes in the support files to match those in the prologue.
================
Comment at: lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp:208
+ remapped_file))
+ continue;
+
----------------
Ditto
================
Comment at: lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp:211
+ module->RemapSourceFile(llvm::StringRef(original_file), remapped_file);
+ support_files.Append(FileSpec(remapped_file));
+ }
----------------
Is this FileSpec constructor going to do the right thing for all path types (windows, linux, etc)?
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D62570/new/
https://reviews.llvm.org/D62570
More information about the llvm-commits
mailing list