Details
- Reviewers
int3 - Group Reviewers
Restricted Project - Commits
- rGfc5d804ddbef: [lld-macho] Check platform and version when constructor ObjFile
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
Neat. Could you clean up the clang-tidy issues? Kind of hard to review the code with all that in the way.
Also, I think the method is getting large enough, it would be nice to factor out the arch/platform check into a separate method.
Finally, don't forget about the test :)
lld/MachO/InputFiles.cpp | ||
---|---|---|
351 | ultra nit: given that you're casting cmd->platform to a PlatformKind below, why not do it here too for uniformity? | |
364–368 | how about constructing another VersionTuple instance and compare that against platformInfo.minimum? that way you can also use VersionTuple::getAsString() below | |
509 | no need to repeat the type name on the same line | |
672 | seems kind of janky to pass in a function here just so we can prepend "dylib". I think it's clear enough that it's a dylib from the name (and if it's not, we should update toString so that all our error messages are uniform). Basically I think it would be cleaner to just pass in the InputFile * | |
lld/MachO/InputFiles.h | ||
179 | nice, I like the convenient casting. But I don't think there's a need to move this function into the header |
lld/test/MachO/incompat-version.s | ||
---|---|---|
1 ↗ | (On Diff #328387) | Can we merge this test into invalid/incompatible-arch.s? (and rename the file to incompatible-target or something). That test file is pretty small as-is and this test is covering very similar functionality. (In general we put tests that only check for error handling into invalid/.) |
updated diff:
- moved test into existing incompatible-arch.s
- added additional test case to cover the ObjFile path
- fixed other styling issues
lld/MachO/InputFiles.h | ||
---|---|---|
179 | It's a templated function, so you can't put it in the cpp file. If we put it in the cpp file, then it can only be a static local function. |
lld/MachO/InputFiles.h | ||
---|---|---|
179 | Oh, I didn't realize this was being used in ObjC.cpp | |
lld/test/MachO/invalid/incompatible-arch.s | ||
12–13 | doesn't seem like the -o %t/new.dylib is necessary given that we have -o /dev/null later | |
17 | nit: use hyphens for uniformity with things like CHECK-NEXT | |
20–23 | I'm guessing you created a bitcode file in order to specify the platform? You can actually specify it by compiling a regular assembly file via llvm-mc: llvm-mc -filetype=obj -triple=x86_64-apple-macos14.0 |
Updated test to specify the platform version with llvm-mc rather than going through the trouble of using a bitcode file
lld/test/MachO/invalid/incompatible-arch.s | ||
---|---|---|
20–23 | Good to know! |
lld/MachO/InputFiles.cpp | ||
---|---|---|
345 | oh I just noticed that you passed in the Configuration as a parameter. It's not necessary since config is a global singleton |
lld/MachO/InputFiles.cpp | ||
---|---|---|
345 | it was kind of intentional since I didn't like using a global variable in this context . |
nice, I like the convenient casting. But I don't think there's a need to move this function into the header