summaryrefslogtreecommitdiffstats
path: root/src/test/run-make-fulldeps/compiler-lookup-paths
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/run-make-fulldeps/compiler-lookup-paths
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/run-make-fulldeps/compiler-lookup-paths')
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/Makefile38
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/a.rs1
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/b.rs2
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/c.rs2
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/d.rs4
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/e.rs2
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/e2.rs4
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/f.rs2
-rw-r--r--src/test/run-make-fulldeps/compiler-lookup-paths/native.c1
9 files changed, 56 insertions, 0 deletions
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/Makefile b/src/test/run-make-fulldeps/compiler-lookup-paths/Makefile
new file mode 100644
index 000000000..e22b937a0
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/Makefile
@@ -0,0 +1,38 @@
+-include ../tools.mk
+
+all: $(TMPDIR)/libnative.a
+ mkdir -p $(TMPDIR)/crate
+ mkdir -p $(TMPDIR)/native
+ mv $(TMPDIR)/libnative.a $(TMPDIR)/native
+ $(RUSTC) a.rs
+ mv $(TMPDIR)/liba.rlib $(TMPDIR)/crate
+ $(RUSTC) b.rs -L native=$(TMPDIR)/crate && exit 1 || exit 0
+ $(RUSTC) b.rs -L dependency=$(TMPDIR)/crate && exit 1 || exit 0
+ $(RUSTC) b.rs -L crate=$(TMPDIR)/crate
+ $(RUSTC) b.rs -L all=$(TMPDIR)/crate
+ $(RUSTC) c.rs -L native=$(TMPDIR)/crate && exit 1 || exit 0
+ $(RUSTC) c.rs -L crate=$(TMPDIR)/crate && exit 1 || exit 0
+ $(RUSTC) c.rs -L dependency=$(TMPDIR)/crate
+ $(RUSTC) c.rs -L all=$(TMPDIR)/crate
+ $(RUSTC) d.rs -L dependency=$(TMPDIR)/native && exit 1 || exit 0
+ $(RUSTC) d.rs -L crate=$(TMPDIR)/native && exit 1 || exit 0
+ $(RUSTC) d.rs -L native=$(TMPDIR)/native
+ $(RUSTC) d.rs -L all=$(TMPDIR)/native
+ # Deduplication tests:
+ # Same hash, no errors.
+ mkdir -p $(TMPDIR)/e1
+ mkdir -p $(TMPDIR)/e2
+ $(RUSTC) e.rs -o $(TMPDIR)/e1/libe.rlib
+ $(RUSTC) e.rs -o $(TMPDIR)/e2/libe.rlib
+ $(RUSTC) f.rs -L $(TMPDIR)/e1 -L $(TMPDIR)/e2
+ $(RUSTC) f.rs -L crate=$(TMPDIR)/e1 -L $(TMPDIR)/e2
+ $(RUSTC) f.rs -L crate=$(TMPDIR)/e1 -L crate=$(TMPDIR)/e2
+ # Different hash, errors.
+ $(RUSTC) e2.rs -o $(TMPDIR)/e2/libe.rlib
+ $(RUSTC) f.rs -L $(TMPDIR)/e1 -L $(TMPDIR)/e2 && exit 1 || exit 0
+ $(RUSTC) f.rs -L crate=$(TMPDIR)/e1 -L $(TMPDIR)/e2 && exit 1 || exit 0
+ $(RUSTC) f.rs -L crate=$(TMPDIR)/e1 -L crate=$(TMPDIR)/e2 && exit 1 || exit 0
+ # Native/dependency paths don't cause errors.
+ $(RUSTC) f.rs -L native=$(TMPDIR)/e1 -L $(TMPDIR)/e2
+ $(RUSTC) f.rs -L dependency=$(TMPDIR)/e1 -L $(TMPDIR)/e2
+ $(RUSTC) f.rs -L dependency=$(TMPDIR)/e1 -L crate=$(TMPDIR)/e2
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/a.rs b/src/test/run-make-fulldeps/compiler-lookup-paths/a.rs
new file mode 100644
index 000000000..83be6e807
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/a.rs
@@ -0,0 +1 @@
+#![crate_type = "lib"]
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/b.rs b/src/test/run-make-fulldeps/compiler-lookup-paths/b.rs
new file mode 100644
index 000000000..1be6cbc91
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/b.rs
@@ -0,0 +1,2 @@
+#![crate_type = "lib"]
+extern crate a;
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/c.rs b/src/test/run-make-fulldeps/compiler-lookup-paths/c.rs
new file mode 100644
index 000000000..4c7ce01b6
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/c.rs
@@ -0,0 +1,2 @@
+#![crate_type = "lib"]
+extern crate b;
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/d.rs b/src/test/run-make-fulldeps/compiler-lookup-paths/d.rs
new file mode 100644
index 000000000..6cd9916b6
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/d.rs
@@ -0,0 +1,4 @@
+#![crate_type = "rlib"]
+
+#[link(name = "native", kind = "static")]
+extern "C" {}
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/e.rs b/src/test/run-make-fulldeps/compiler-lookup-paths/e.rs
new file mode 100644
index 000000000..18eb60aca
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/e.rs
@@ -0,0 +1,2 @@
+#![crate_name = "e"]
+#![crate_type = "rlib"]
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/e2.rs b/src/test/run-make-fulldeps/compiler-lookup-paths/e2.rs
new file mode 100644
index 000000000..cbf08b98e
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/e2.rs
@@ -0,0 +1,4 @@
+#![crate_name = "e"]
+#![crate_type = "rlib"]
+
+pub fn f() {}
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/f.rs b/src/test/run-make-fulldeps/compiler-lookup-paths/f.rs
new file mode 100644
index 000000000..483deaaea
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/f.rs
@@ -0,0 +1,2 @@
+#![crate_type = "rlib"]
+extern crate e;
diff --git a/src/test/run-make-fulldeps/compiler-lookup-paths/native.c b/src/test/run-make-fulldeps/compiler-lookup-paths/native.c
new file mode 100644
index 000000000..d11c69f81
--- /dev/null
+++ b/src/test/run-make-fulldeps/compiler-lookup-paths/native.c
@@ -0,0 +1 @@
+// intentionally empty