summaryrefslogtreecommitdiffstats
path: root/src/test/ui/consts/const_limit
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/ui/consts/const_limit
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/ui/consts/const_limit')
-rw-r--r--src/test/ui/consts/const_limit/const_eval_limit_not_reached.rs20
-rw-r--r--src/test/ui/consts/const_limit/const_eval_limit_overflow.rs15
-rw-r--r--src/test/ui/consts/const_limit/const_eval_limit_overflow.stderr10
-rw-r--r--src/test/ui/consts/const_limit/const_eval_limit_reached.rs17
-rw-r--r--src/test/ui/consts/const_limit/const_eval_limit_reached.stderr29
-rw-r--r--src/test/ui/consts/const_limit/feature-gate-const_eval_limit.rs14
-rw-r--r--src/test/ui/consts/const_limit/feature-gate-const_eval_limit.stderr12
7 files changed, 117 insertions, 0 deletions
diff --git a/src/test/ui/consts/const_limit/const_eval_limit_not_reached.rs b/src/test/ui/consts/const_limit/const_eval_limit_not_reached.rs
new file mode 100644
index 000000000..629d1f02a
--- /dev/null
+++ b/src/test/ui/consts/const_limit/const_eval_limit_not_reached.rs
@@ -0,0 +1,20 @@
+// check-pass
+
+#![feature(const_eval_limit)]
+
+// This needs to be higher than the number of loop iterations since each pass through the loop may
+// hit more than one terminator.
+#![const_eval_limit="4000"]
+
+const X: usize = {
+ let mut x = 0;
+ while x != 1000 {
+ x += 1;
+ }
+
+ x
+};
+
+fn main() {
+ assert_eq!(X, 1000);
+}
diff --git a/src/test/ui/consts/const_limit/const_eval_limit_overflow.rs b/src/test/ui/consts/const_limit/const_eval_limit_overflow.rs
new file mode 100644
index 000000000..1c49593cd
--- /dev/null
+++ b/src/test/ui/consts/const_limit/const_eval_limit_overflow.rs
@@ -0,0 +1,15 @@
+#![feature(const_eval_limit)]
+#![const_eval_limit="18_446_744_073_709_551_615"]
+//~^ ERROR `limit` must be a non-negative integer
+
+const CONSTANT: usize = limit();
+
+fn main() {
+ assert_eq!(CONSTANT, 1764);
+}
+
+const fn limit() -> usize {
+ let x = 42;
+
+ x * 42
+}
diff --git a/src/test/ui/consts/const_limit/const_eval_limit_overflow.stderr b/src/test/ui/consts/const_limit/const_eval_limit_overflow.stderr
new file mode 100644
index 000000000..7f5d5e6cd
--- /dev/null
+++ b/src/test/ui/consts/const_limit/const_eval_limit_overflow.stderr
@@ -0,0 +1,10 @@
+error: `limit` must be a non-negative integer
+ --> $DIR/const_eval_limit_overflow.rs:2:1
+ |
+LL | #![const_eval_limit="18_446_744_073_709_551_615"]
+ | ^^^^^^^^^^^^^^^^^^^^----------------------------^
+ | |
+ | not a valid integer
+
+error: aborting due to previous error
+
diff --git a/src/test/ui/consts/const_limit/const_eval_limit_reached.rs b/src/test/ui/consts/const_limit/const_eval_limit_reached.rs
new file mode 100644
index 000000000..773640b72
--- /dev/null
+++ b/src/test/ui/consts/const_limit/const_eval_limit_reached.rs
@@ -0,0 +1,17 @@
+#![feature(const_eval_limit)]
+#![const_eval_limit = "500"]
+
+const X: usize = {
+ let mut x = 0;
+ while x != 1000 {
+ //~^ ERROR any use of this value will cause an error
+ //~| WARN this was previously accepted by the compiler but is being phased out
+ x += 1;
+ }
+
+ x
+};
+
+fn main() {
+ assert_eq!(X, 1000);
+}
diff --git a/src/test/ui/consts/const_limit/const_eval_limit_reached.stderr b/src/test/ui/consts/const_limit/const_eval_limit_reached.stderr
new file mode 100644
index 000000000..e450f4aa3
--- /dev/null
+++ b/src/test/ui/consts/const_limit/const_eval_limit_reached.stderr
@@ -0,0 +1,29 @@
+error: any use of this value will cause an error
+ --> $DIR/const_eval_limit_reached.rs:6:11
+ |
+LL | const X: usize = {
+ | --------------
+LL | let mut x = 0;
+LL | while x != 1000 {
+ | ^^^^^^^^^ exceeded interpreter step limit (see `#[const_eval_limit]`)
+ |
+ = note: `#[deny(const_err)]` on by default
+ = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
+ = note: for more information, see issue #71800 <https://github.com/rust-lang/rust/issues/71800>
+
+error: aborting due to previous error
+
+Future incompatibility report: Future breakage diagnostic:
+error: any use of this value will cause an error
+ --> $DIR/const_eval_limit_reached.rs:6:11
+ |
+LL | const X: usize = {
+ | --------------
+LL | let mut x = 0;
+LL | while x != 1000 {
+ | ^^^^^^^^^ exceeded interpreter step limit (see `#[const_eval_limit]`)
+ |
+ = note: `#[deny(const_err)]` on by default
+ = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
+ = note: for more information, see issue #71800 <https://github.com/rust-lang/rust/issues/71800>
+
diff --git a/src/test/ui/consts/const_limit/feature-gate-const_eval_limit.rs b/src/test/ui/consts/const_limit/feature-gate-const_eval_limit.rs
new file mode 100644
index 000000000..61119d751
--- /dev/null
+++ b/src/test/ui/consts/const_limit/feature-gate-const_eval_limit.rs
@@ -0,0 +1,14 @@
+#![const_eval_limit="42"]
+//~^ ERROR the `#[const_eval_limit]` attribute is an experimental feature [E0658]
+
+const CONSTANT: usize = limit();
+
+fn main() {
+ assert_eq!(CONSTANT, 1764);
+}
+
+const fn limit() -> usize {
+ let x = 42;
+
+ x * 42
+}
diff --git a/src/test/ui/consts/const_limit/feature-gate-const_eval_limit.stderr b/src/test/ui/consts/const_limit/feature-gate-const_eval_limit.stderr
new file mode 100644
index 000000000..5bd29c7df
--- /dev/null
+++ b/src/test/ui/consts/const_limit/feature-gate-const_eval_limit.stderr
@@ -0,0 +1,12 @@
+error[E0658]: the `#[const_eval_limit]` attribute is an experimental feature
+ --> $DIR/feature-gate-const_eval_limit.rs:1:1
+ |
+LL | #![const_eval_limit="42"]
+ | ^^^^^^^^^^^^^^^^^^^^^^^^^
+ |
+ = note: see issue #67217 <https://github.com/rust-lang/rust/issues/67217> for more information
+ = help: add `#![feature(const_eval_limit)]` to the crate attributes to enable
+
+error: aborting due to previous error
+
+For more information about this error, try `rustc --explain E0658`.