[llvm] [llvm][Support] fix convertToSnakeFromCamelCase (PR #68375)

Maksim Levental via llvm-commits llvm-commits at lists.llvm.org
Fri Oct 6 10:19:47 PDT 2023


================
@@ -96,18 +97,13 @@ std::string llvm::convertToSnakeFromCamelCase(StringRef input) {
   if (input.empty())
     return "";
 
-  std::string snakeCase;
-  snakeCase.reserve(input.size());
-  for (char c : input) {
-    if (!std::isupper(c)) {
-      snakeCase.push_back(c);
-      continue;
-    }
-
-    if (!snakeCase.empty() && snakeCase.back() != '_')
-      snakeCase.push_back('_');
-    snakeCase.push_back(llvm::toLower(c));
+  std::string snakeCase = input.str();
+  for (int i = 0; i < 10; ++i) {
----------------
makslevental wrote:

I mean I thought about doing a fixed-point type thing but `while` are strongly discouraged right?

https://github.com/llvm/llvm-project/pull/68375


More information about the llvm-commits mailing list