This implements the -needed-libs option functionality in Mach-O dumper.
Details
Diff Detail
- Repository
- rL LLVM
Event Timeline
To give more context, I'm planning on implementing this feature for COFF as well and then using llvm-readobj in D41272 to have a solution that works across all platforms.
I'm across the pond fo the rest of the year, sorry if communication is a little slow :)
tools/llvm-readobj/MachODumper.cpp | ||
---|---|---|
42–43 ↗ | (On Diff #127991) | this is Mach-O specific no? So it should be grouped with the others. |
687–692 ↗ | (On Diff #127991) | maybe this would be more readable if it used a switch, not sure if it's entirely feasible. |
695 ↗ | (On Diff #127991) | static_cast<> and auto *. |
701 ↗ | (On Diff #127991) | Why you need this stable sort? |
tools/llvm-readobj/MachODumper.cpp | ||
---|---|---|
42–43 ↗ | (On Diff #127991) | This should be implemented for all formats, see https://github.com/llvm-mirror/llvm/blob/master/tools/llvm-readobj/ObjDumper.h#L42. It's currently implemented for ELF, I'm trying to add an implementation for Mach-O (D41527) and COFF (D41529). |
701 ↗ | (On Diff #127991) | I have followed the ELF implementation which also uses stable sort, I'm not sure why it's used there. |
LGTM with one comment addressed. Thanks.
tools/llvm-readobj/MachODumper.cpp | ||
---|---|---|
701 ↗ | (On Diff #127991) | I'd rather not cargo cult this here unless we have a good reason to. We shouldn't need this call, should we? |
tools/llvm-readobj/MachODumper.cpp | ||
---|---|---|
701 ↗ | (On Diff #127991) | I think having a stable output order may be useful in some cases. Also if that's what we're already doing for ELF version, we should probably be consistent across all formats? |
tools/llvm-readobj/MachODumper.cpp | ||
---|---|---|
701 ↗ | (On Diff #127991) | I think we should have a stable order of these *regardless*. I'm nervous about adding a call to std::stable_sort() unless we have a good reason for it, because it might hide bugs elsewhere in the reader. |
tools/llvm-readobj/MachODumper.cpp | ||
---|---|---|
701 ↗ | (On Diff #127991) | Understood, the problem is that load_command() doesn't provide any guarantees about the ordering, the order should be the same as the order in which the commands were read from the file, but commands are also not guaranteed to be sorted and after briefly checking a few binaries they definitely aren't. So the way to guarantee ordering would be to sort LoadCommands in MachOObjectFile constructor when reading the file, is that what you're suggesting? |