nickdesaulniers added inline comments.

================
Comment at: llvm/lib/Transforms/IPO/ThinLTOBitcodeWriter.cpp:45
+  }
+  return true;
+}
----------------
samitolvanen wrote:
> nickdesaulniers wrote:
> > samitolvanen wrote:
> > > nickdesaulniers wrote:
> > > > Can llvm::any_of or llvm::none_of be used here?
> > > > llvm/ADT/STLExtras.h
> > > Maybe, but I don't see how they would make this function any cleaner. Did 
> > > you have something specific in mind?
> > Something like?
> > 
> > return any_of(Name, [](const char &C) { return isAlnum(C) || C == '_' || C 
> > == '.'; }
> > 
> > or maybe we need !none_of(...)? (not sure if characters of a string can be 
> > enumerated this way)
> Since we want to ensure all the characters in the string match the predicate, 
> I believe it would make sense to use `all_of()` instead.
> 
> However, I don't see the point of introducing additional complexity to such a 
> trivial function to shave off a couple of lines of code. While it might not 
> actually matter here, using `all_of()` also seems to generate ~5x as many 
> instructions to execute:
> 
> https://godbolt.org/z/Pndfxj6rM
> 
> If you feel like the current version is too long, I can drop one line by 
> changing the loop to use:
> ```
> if (!isAlnum(C) && C != '_' && C != '.')
>   return false;
> ```
> I initially wanted to keep the test identical to 
> `MCAsmInfo::isAcceptableChar()` to make it easier to see it actually matches, 
> but since it's no longer identical, I suppose that doesn't matter.
> 
> Thoughts?
> using all_of() also seems to generate ~5x as many instructions to execute:

Hard to argue with that.

Might be nice to add some test coverage of this code with an mscv target triple 
though.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D104058/new/

https://reviews.llvm.org/D104058

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to