Update the test case to handle a few more (degenerate) cases and remove
authorReid Spencer <rspencer@reidspencer.com>
Mon, 25 Apr 2005 21:08:34 +0000 (21:08 +0000)
committerReid Spencer <rspencer@reidspencer.com>
Mon, 25 Apr 2005 21:08:34 +0000 (21:08 +0000)
the restriction that it is an XFAIL because it now passes.

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

test/Transforms/SimplifyLibCalls/2005-04-24-strcat.ll

index 7c78dd12dc9eade82e2033e5bb01c5781cf1c52d..a0e7a6c10ee6e518903a998acc210fc8402758cb 100644 (file)
@@ -1,9 +1,11 @@
 ; Test that the StrCatOptimizer works correctly
-; RUN: llvm-as < %s | opt -simplify-libcalls | llvm-dis | grep strlen
-; XFAIL: *
+; RUN: llvm-as < %s | opt -simplify-libcalls | llvm-dis | grep -v 'call.*strcat'
 
 declare sbyte* %strcat(sbyte*,sbyte*)
+declare int %puts(sbyte*)
 %hello = constant [6 x sbyte] c"hello\00"
+%null = constant [1 x sbyte] c"\00"
+%null_hello = constant [7 x sbyte] c"\00hello\00"
 
 implementation   ; Functions:
 
@@ -12,6 +14,11 @@ int %main () {
   %arg1 = getelementptr [1024 x sbyte]* %target, int 0, int 0
   store sbyte 0, sbyte* %arg1
   %arg2 = getelementptr [6 x sbyte]* %hello, int 0, int 0
-  %rslt = call sbyte* %strcat(sbyte* %arg1, sbyte* %arg2)
+  %rslt1 = call sbyte* %strcat(sbyte* %arg1, sbyte* %arg2)
+  %arg3 = getelementptr [1 x sbyte]* %null, int 0, int 0
+  %rslt2 = call sbyte* %strcat(sbyte* %rslt1, sbyte* %arg3)
+  %arg4 = getelementptr [7 x sbyte]* %null_hello, int 0, int 0
+  %rslt3 = call sbyte* %strcat(sbyte* %rslt2, sbyte* %arg4)
+  call int %puts(sbyte* %rslt3)
   ret int 0
 }