Simplify llvm::StringSwitch and improve incremental rebuild performance by 54% on dual Xeon 8168 machines.
Details
Diff Detail
- Repository
- rL LLVM
Event Timeline
| include/llvm/ADT/StringSwitch.h | ||
|---|---|---|
| 49 | This makes it impossible to return a move-only type by reference (although I suppose you can still do it by pointer). | |
| 73–75 | Until StringRef gets a known-size constructor I don't think we should do this, even if it's not kicking in in most cases. It's also serving another purpose right now, which is to make sure the argument strings are compile-time constants. I can see that it would generate tons of duplicate code this way, though. (StringRef has long been overdo for a constexpr known-size constructor anyway.) | |
| include/llvm/ADT/StringSwitch.h | ||
|---|---|---|
| 49 | Doug signed of on this in a separate and simpler review. | |
| 73–75 | strlen() is effectively constexpr (I just verified this in a test file). Unless there is something nontrivial I'm missing about StringRef that would prevent strlen() from being compile away, there should be no difference in code output. | |
| include/llvm/ADT/StringSwitch.h | ||
|---|---|---|
| 73–75 | Oh, I also tried adding a known size constructor to StringRef and that blew up spectacularly. Too much code likes to create large fixed size char arrays, fill in the first few bytes, and then call StringRef(array) and trust that strlen() finds the NUL byte. | |
| include/llvm/ADT/StringSwitch.h | ||
|---|---|---|
| 73–75 | There's a subclass of StringRef called StringLiteral that has a fixed size constructor. Can that be used here? | |
| include/llvm/ADT/StringSwitch.h | ||
|---|---|---|
| 73–75 | Neat-o. I spent hours yesterday trying to figure out if a mix of type traits and template magic could detect string literals inside of StringRef, but I didn't think of just subclassing StringRef and I forgot that __builtin_strlen() existed. That should work. | |
| include/llvm/ADT/StringSwitch.h | ||
|---|---|---|
| 73–75 | Oh, whoa, I didn't know that existed. Thanks, Craig! (Now to go use it in some places in Swift…) | |
Sorry for the STRING_SWITCH proposal/noise. I was working on that in parallel with the templated version fixes. Now that I'm comparing the code gen of the two, I'm impressed with the optimizer generating essentially the STRING_SWITCH code gen. I'll keep the macro version in my back pocket in case I find a scenario where the optimizer fails to optimize the templated version code gen.
| include/llvm/ADT/StringRef.h | ||
|---|---|---|
| 875 | I don't think this should be marked a hack. Sometimes people want to make StringRefs containing nul bytes. It's reasonable that it's explicit now, though. | |
I think this final diff addresses all concerns, including some amount of move-only type compatibility (it compiles, but I'm not sure the experience is pleasurable).
Jordan -- Chris recently gave me commit-after-approval access. Might you please approve this? Thanks!
I don't think this should be marked a hack. Sometimes people want to make StringRefs containing nul bytes. It's reasonable that it's explicit now, though.