about summary refs log tree commit diff
diff options
context:
space:
mode:
authorCorey Farwell <coreyf@rwell.org>2017-02-09 19:43:24 -0500
committerGitHub <noreply@github.com>2017-02-09 19:43:24 -0500
commitaf1ddb9ec583df5dfda727df45de332f65e79521 (patch)
tree1f1bc6b405a633e9ae8e78a32bad5c7d714c4f10
parentae5d8fc929d73f0eb6d5a37e44f1c8405b7a13c1 (diff)
parentec4a3cc3710eba9b31e003771994e9b13c47c318 (diff)
downloadrust-af1ddb9ec583df5dfda727df45de332f65e79521.tar.gz
rust-af1ddb9ec583df5dfda727df45de332f65e79521.zip
Rollup merge of #39700 - msopena:master, r=est31
Adding compile fail test for const_indexing feature

First attempt at contributing to rust. Picked up an easy feature to test.

Issue #39059
r? @est31
-rw-r--r--src/test/compile-fail/feature-gate-const-indexing.rs17
-rw-r--r--src/tools/tidy/src/features.rs2
2 files changed, 18 insertions, 1 deletions
diff --git a/src/test/compile-fail/feature-gate-const-indexing.rs b/src/test/compile-fail/feature-gate-const-indexing.rs
new file mode 100644
index 00000000000..0d61878cd80
--- /dev/null
+++ b/src/test/compile-fail/feature-gate-const-indexing.rs
@@ -0,0 +1,17 @@
+// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+
+fn main() {
+    const ARR: [i32; 6] = [42, 43, 44, 45, 46, 47];
+    const IDX: usize = 3;
+    const VAL: i32 = ARR[IDX];
+    const BLUB: [i32; (ARR[0] - 41) as usize] = [5]; //~ ERROR constant evaluation error
+}
diff --git a/src/tools/tidy/src/features.rs b/src/tools/tidy/src/features.rs
index 2c3e57c8332..707d5da50bf 100644
--- a/src/tools/tidy/src/features.rs
+++ b/src/tools/tidy/src/features.rs
@@ -167,7 +167,7 @@ pub fn check(path: &Path, bad: &mut bool) {
     // FIXME get this whitelist empty.
     let whitelist = vec![
         "abi_ptx", "simd", "static_recursion",
-        "cfg_target_has_atomic", "staged_api", "const_indexing",
+        "cfg_target_has_atomic", "staged_api",
         "unboxed_closures", "stmt_expr_attributes",
         "cfg_target_thread_local", "unwind_attributes",
         "inclusive_range_syntax"