Added a parameter to control whether Constant::getStringValue() would chop
authorEvan Cheng <evan.cheng@apple.com>
Fri, 10 Mar 2006 23:52:03 +0000 (23:52 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Fri, 10 Mar 2006 23:52:03 +0000 (23:52 +0000)
off the result string at the first null terminator.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26704 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Constant.h
lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
lib/VMCore/Constants.cpp

index 13b4cb3fb8edd7a3c28535e9b567c6f96ebdc5c1..4411540ae520d6b1f0dcb550af6c94d14ac1588a 100644 (file)
@@ -93,8 +93,10 @@ public:
   
   /// getStringValue - Turn an LLVM constant pointer that eventually points to a
   /// global into a string value.  Return an empty string if we can't do it.
+  /// Parameter Chop determines if the result is chopped at the first null
+  /// terminator.
   ///
-   std::string getStringValue(unsigned Offset = 0);
+  std::string getStringValue(bool Chop = true, unsigned Offset = 0);
 };
 
 } // End llvm namespace
index 96694da971a071d482b2a64ea263cbd0b41cfcf7..f1afeb93e3d525cfab1c1d5ad00f39a2f9fd0b94 100644 (file)
@@ -1941,7 +1941,7 @@ void SelectionDAGLowering::visitMemIntrinsic(CallInst &I, unsigned Op) {
         if (G) {
           GlobalVariable *GV = dyn_cast<GlobalVariable>(G->getGlobal());
           if (GV) {
-            Str = GV->getStringValue();
+            Str = GV->getStringValue(false);
             if (!Str.empty()) {
               CopyFromStr = true;
               SrcOff += SrcDelta;
index 1beb5bc9b7cfacbc15b8c5d6824ad975282fa9aa..28ca2a416d9449dc7ef8d08382a67a8d5b530a3c 100644 (file)
@@ -1715,8 +1715,10 @@ void Constant::clearAllValueMaps() {
 
 /// getStringValue - Turn an LLVM constant pointer that eventually points to a
 /// global into a string value.  Return an empty string if we can't do it.
+/// Parameter Chop determines if the result is chopped at the first null
+/// terminator.
 ///
-std::string Constant::getStringValue(unsigned Offset) {
+std::string Constant::getStringValue(bool Chop, unsigned Offset) {
   if (GlobalVariable *GV = dyn_cast<GlobalVariable>(this)) {
     if (GV->hasInitializer() && isa<ConstantArray>(GV->getInitializer())) {
       ConstantArray *Init = cast<ConstantArray>(GV->getInitializer());
@@ -1727,9 +1729,11 @@ std::string Constant::getStringValue(unsigned Offset) {
           Result.erase(Result.begin(), Result.begin()+Offset);
 
           // Take off the null terminator, and any string fragments after it.
-          std::string::size_type NullPos = Result.find_first_of((char)0);
-          if (NullPos != std::string::npos)
-            Result.erase(Result.begin()+NullPos, Result.end());
+          if (Chop) {
+            std::string::size_type NullPos = Result.find_first_of((char)0);
+            if (NullPos != std::string::npos)
+              Result.erase(Result.begin()+NullPos, Result.end());
+          }
           return Result;
         }
       }