2 ;; Test to make sure the thinlto-object-suffix-replace option is handled
4 ; RUN: rm -rf %t && mkdir %t && cd %t
6 ;; Generate bitcode file with summary, as well as a minimized bitcode without
7 ; the debug metadata for the thin link.
8 ; RUN: opt --thinlto-bc %s -thin-link-bitcode-file=1.thinlink.bc -o 1.o
10 ;; First perform the thin link on the normal bitcode file, and save the
12 ; RUN: %lld --thinlto-index-only -dylib 1.o -o 3
13 ; RUN: cp 1.o.thinlto.bc 1.o.thinlto.bc.orig
15 ;; Next perform the thin link on the minimized bitcode file, and compare dump
16 ;; of the resulting index to the above dump to ensure they are identical.
17 ; RUN: rm -f 1.o.thinlto.bc
18 ;; Make sure it isn't inadvertently using the regular bitcode file.
20 ; RUN: %lld --thinlto-index-only --thinlto-object-suffix-replace=".thinlink.bc;.o" \
21 ; RUN: -dylib 1.thinlink.bc -o 3
22 ; RUN: cmp 1.o.thinlto.bc.orig 1.o.thinlto.bc
24 ;; Ensure lld generates error if object suffix replace option does not have 'old;new' format
25 ; RUN: rm -f 1.o.thinlto.bc
26 ; RUN: not %lld --thinlto-index-only --thinlto-object-suffix-replace="abc:def" -dylib 1.thinlink.bc \
27 ; RUN: -o 3 2>&1 | FileCheck %s --check-prefix=ERR1
28 ; ERR1: --thinlto-object-suffix-replace= expects 'old;new' format, but got abc:def
30 ;; If filename does not end with old suffix, no suffix change should occur,
31 ;; so ".thinlto.bc" will simply be appended to the input file name.
32 ; RUN: rm -f 1.thinlink.bc.thinlto.bc
33 ; RUN: %lld --thinlto-index-only --thinlto-object-suffix-replace=".abc;.o" -dylib 1.thinlink.bc -o /dev/null
34 ; RUN: ls 1.thinlink.bc.thinlto.bc
36 target datalayout = "e-m:o-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
37 target triple = "x86_64-apple-darwin"
46 !1 = !{i32 2, !"Debug Info Version", i32 3}
47 !llvm.module.flags = !{!1}