about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2016-09-17 12:02:34 -0700
committerGitHub <noreply@github.com>2016-09-17 12:02:34 -0700
commit32571c05c82c3b0fcb5d38afe03542226ca25d2d (patch)
treefee712a977a46d4dfb10ad73032480bf3cdc67fe /src
parentfb62f4d544c954d355716dca8beb55726036721e (diff)
parentd104e5bfb70f7ee3fc3e7d30e6021ae804ce87e5 (diff)
downloadrust-32571c05c82c3b0fcb5d38afe03542226ca25d2d.tar.gz
rust-32571c05c82c3b0fcb5d38afe03542226ca25d2d.zip
Auto merge of #36508 - nagisa:llvm-backport, r=eddyb
Up the LLVM

Fixes #36474

The relevant patch to rust-llvm is at https://github.com/rust-lang/llvm/pull/51

r? @alexcrichton
Diffstat (limited to 'src')
m---------src/llvm0
-rw-r--r--src/rustllvm/llvm-auto-clean-trigger2
-rw-r--r--src/test/run-pass/issue-36474.rs40
3 files changed, 41 insertions, 1 deletions
diff --git a/src/llvm b/src/llvm
-Subproject 16b79d01fd6d942cf3c9120b92df56b13ec9266
+Subproject 7801978ec1f3637fcda1b564048ebc732bf586a
diff --git a/src/rustllvm/llvm-auto-clean-trigger b/src/rustllvm/llvm-auto-clean-trigger
index 1080070d21a..ea8d59290df 100644
--- a/src/rustllvm/llvm-auto-clean-trigger
+++ b/src/rustllvm/llvm-auto-clean-trigger
@@ -1,4 +1,4 @@
 # If this file is modified, then llvm will be forcibly cleaned and then rebuilt.
 # The actual contents of this file do not matter, but to trigger a change on the
 # build bots then the contents should be changed so git updates the mtime.
-2016-08-30
+2016-09-17
diff --git a/src/test/run-pass/issue-36474.rs b/src/test/run-pass/issue-36474.rs
new file mode 100644
index 00000000000..025244ca664
--- /dev/null
+++ b/src/test/run-pass/issue-36474.rs
@@ -0,0 +1,40 @@
+// Copyright 2016 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() {
+    remove_axis(&3, 0);
+}
+
+trait Dimension {
+    fn slice(&self) -> &[usize];
+}
+
+impl Dimension for () {
+    fn slice(&self) -> &[usize] { &[] }
+}
+
+impl Dimension for usize {
+    fn slice(&self) -> &[usize] {
+        unsafe {
+            ::std::slice::from_raw_parts(self, 1)
+        }
+    }
+}
+
+fn remove_axis(value: &usize, axis: usize) -> () {
+    let tup = ();
+    let mut it = tup.slice().iter();
+    for (i, _) in value.slice().iter().enumerate() {
+        if i == axis {
+            continue;
+        }
+        it.next();
+    }
+}