[llvm] Eliminate pointless copies (PR #95097)
    via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Tue Jun 11 03:54:21 PDT 2024
    
    
  
llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT-->
@llvm/pr-subscribers-llvm-support
Author: Braden Helmer (bradenhelmer)
<details>
<summary>Changes</summary>
Fixes #<!-- -->95090 #<!-- -->95091 #<!-- -->95092 
---
Full diff: https://github.com/llvm/llvm-project/pull/95097.diff
3 Files Affected:
- (modified) llvm/include/llvm/Object/ELFTypes.h (+2-2) 
- (modified) llvm/include/llvm/Passes/StandardInstrumentations.h (+3-3) 
- (modified) llvm/include/llvm/Support/Caching.h (+2-3) 
``````````diff
diff --git a/llvm/include/llvm/Object/ELFTypes.h b/llvm/include/llvm/Object/ELFTypes.h
index 4ab23e4ea81b1..a4f3ad6348c10 100644
--- a/llvm/include/llvm/Object/ELFTypes.h
+++ b/llvm/include/llvm/Object/ELFTypes.h
@@ -717,14 +717,14 @@ template <class ELFT> class Elf_Note_Iterator_Impl {
     advanceNhdr(NhdrPos, NoteSize);
     return *this;
   }
-  bool operator==(Elf_Note_Iterator_Impl Other) const {
+  bool operator==(const Elf_Note_Iterator_Impl &Other) const {
     if (!Nhdr && Other.Err)
       (void)(bool)(*Other.Err);
     if (!Other.Nhdr && Err)
       (void)(bool)(*Err);
     return Nhdr == Other.Nhdr;
   }
-  bool operator!=(Elf_Note_Iterator_Impl Other) const {
+  bool operator!=(const Elf_Note_Iterator_Impl &Other) const {
     return !(*this == Other);
   }
   Elf_Note_Impl<ELFT> operator*() const {
diff --git a/llvm/include/llvm/Passes/StandardInstrumentations.h b/llvm/include/llvm/Passes/StandardInstrumentations.h
index 84d1b541171bf..b3caa689c84b4 100644
--- a/llvm/include/llvm/Passes/StandardInstrumentations.h
+++ b/llvm/include/llvm/Passes/StandardInstrumentations.h
@@ -382,13 +382,13 @@ class EmptyData {
 template <typename T>
 class FuncDataT : public OrderedChangedData<BlockDataT<T>> {
 public:
-  FuncDataT(std::string S) : EntryBlockName(S) {}
+  FuncDataT(StringRef S) : EntryBlockName(S) {}
 
   // Return the name of the entry block
-  std::string getEntryBlockName() const { return EntryBlockName; }
+  StringRef getEntryBlockName() const { return EntryBlockName; }
 
 protected:
-  std::string EntryBlockName;
+  StringRef EntryBlockName;
 };
 
 // The data saved for comparing IRs.
diff --git a/llvm/include/llvm/Support/Caching.h b/llvm/include/llvm/Support/Caching.h
index 4fa57cc92e51f..cdf2bc2ecee19 100644
--- a/llvm/include/llvm/Support/Caching.h
+++ b/llvm/include/llvm/Support/Caching.h
@@ -27,11 +27,10 @@ class MemoryBuffer;
 /// that can be done by deriving from this class and overriding the destructor.
 class CachedFileStream {
 public:
-  CachedFileStream(std::unique_ptr<raw_pwrite_stream> OS,
-                   std::string OSPath = "")
+  CachedFileStream(std::unique_ptr<raw_pwrite_stream> OS, StringRef OSPath = "")
       : OS(std::move(OS)), ObjectPathName(OSPath) {}
   std::unique_ptr<raw_pwrite_stream> OS;
-  std::string ObjectPathName;
+  StringRef ObjectPathName;
   virtual ~CachedFileStream() = default;
 };
 
``````````
</details>
https://github.com/llvm/llvm-project/pull/95097
    
    
More information about the llvm-commits
mailing list