Auto merge of #50119 - kennytm:rollup, r=kennytm
Rollup of 7 pull requests Successful merges: - #50031 (Clarified E0015 message.) - #50058 (Added build disk usage information) - #50081 (Update stdsimd submodule) - #50083 (wasm: Increase default stack size to 1MB) - #50104 (Disable auto-detection of libxml2 when compiling llvm.) - #50114 (Fix bad merge in #49991) - #50117 (must explicitly request file name when using with_file_name.) Failed merges:
This commit is contained in:
commit
05dc5e7d95
12 changed files with 50 additions and 11 deletions
|
@ -136,6 +136,8 @@ file. If you still have a `config.mk` file in your directory - from
|
||||||
### Building
|
### Building
|
||||||
[building]: #building
|
[building]: #building
|
||||||
|
|
||||||
|
A default configuration shall use around 3.5 GB of disk space, whereas building a debug configuration may require more than 30 GB.
|
||||||
|
|
||||||
Dependencies
|
Dependencies
|
||||||
- [build dependencies](README.md#building-from-source)
|
- [build dependencies](README.md#building-from-source)
|
||||||
- `gdb` 6.2.0 minimum, 7.1 or later recommended for test builds
|
- `gdb` 6.2.0 minimum, 7.1 or later recommended for test builds
|
||||||
|
|
|
@ -149,6 +149,7 @@ impl Step for Llvm {
|
||||||
.define("WITH_POLLY", "OFF")
|
.define("WITH_POLLY", "OFF")
|
||||||
.define("LLVM_ENABLE_TERMINFO", "OFF")
|
.define("LLVM_ENABLE_TERMINFO", "OFF")
|
||||||
.define("LLVM_ENABLE_LIBEDIT", "OFF")
|
.define("LLVM_ENABLE_LIBEDIT", "OFF")
|
||||||
|
.define("LLVM_ENABLE_LIBXML2", "OFF")
|
||||||
.define("LLVM_PARALLEL_COMPILE_JOBS", builder.jobs().to_string())
|
.define("LLVM_PARALLEL_COMPILE_JOBS", builder.jobs().to_string())
|
||||||
.define("LLVM_TARGET_ARCH", target.split('-').next().unwrap())
|
.define("LLVM_TARGET_ARCH", target.split('-').next().unwrap())
|
||||||
.define("LLVM_DEFAULT_TARGET_TRIPLE", target);
|
.define("LLVM_DEFAULT_TARGET_TRIPLE", target);
|
||||||
|
|
|
@ -930,7 +930,7 @@ impl<'a, 'b: 'a, 'tcx: 'b> IsolatedEncoder<'a, 'b, 'tcx> {
|
||||||
} else if let hir::ImplItemKind::Method(ref sig, _) = ast_item.node {
|
} else if let hir::ImplItemKind::Method(ref sig, _) = ast_item.node {
|
||||||
let generics = self.tcx.generics_of(def_id);
|
let generics = self.tcx.generics_of(def_id);
|
||||||
let types = generics.parent_types as usize + generics.types.len();
|
let types = generics.parent_types as usize + generics.types.len();
|
||||||
let needs_inline = types > 0 || tcx.trans_fn_attrs(def_id).requests_inline() &&
|
let needs_inline = (types > 0 || tcx.trans_fn_attrs(def_id).requests_inline()) &&
|
||||||
!self.metadata_output_only();
|
!self.metadata_output_only();
|
||||||
let is_const_fn = sig.constness == hir::Constness::Const;
|
let is_const_fn = sig.constness == hir::Constness::Const;
|
||||||
let always_encode_mir = self.tcx.sess.opts.debugging_opts.always_encode_mir;
|
let always_encode_mir = self.tcx.sess.opts.debugging_opts.always_encode_mir;
|
||||||
|
|
|
@ -964,7 +964,7 @@ This does not pose a problem by itself because they can't be accessed directly."
|
||||||
let (msg, note) = if let UnstableFeatures::Disallow =
|
let (msg, note) = if let UnstableFeatures::Disallow =
|
||||||
self.tcx.sess.opts.unstable_features {
|
self.tcx.sess.opts.unstable_features {
|
||||||
(format!("calls in {}s are limited to \
|
(format!("calls in {}s are limited to \
|
||||||
struct and enum constructors",
|
tuple structs and tuple variants",
|
||||||
self.mode),
|
self.mode),
|
||||||
Some("a limited form of compile-time function \
|
Some("a limited form of compile-time function \
|
||||||
evaluation is available on a nightly \
|
evaluation is available on a nightly \
|
||||||
|
@ -972,7 +972,7 @@ This does not pose a problem by itself because they can't be accessed directly."
|
||||||
} else {
|
} else {
|
||||||
(format!("calls in {}s are limited \
|
(format!("calls in {}s are limited \
|
||||||
to constant functions, \
|
to constant functions, \
|
||||||
struct and enum constructors",
|
tuple structs and tuple variants",
|
||||||
self.mode),
|
self.mode),
|
||||||
None)
|
None)
|
||||||
};
|
};
|
||||||
|
|
|
@ -960,6 +960,7 @@ impl Linker for WasmLd {
|
||||||
|
|
||||||
fn finalize(&mut self) -> Command {
|
fn finalize(&mut self) -> Command {
|
||||||
self.cmd.arg("--threads");
|
self.cmd.arg("--threads");
|
||||||
|
self.cmd.arg("-z").arg("stack-size=1048576");
|
||||||
|
|
||||||
// FIXME we probably shouldn't pass this but instead pass an explicit
|
// FIXME we probably shouldn't pass this but instead pass an explicit
|
||||||
// whitelist of symbols we'll allow to be undefined. Unfortunately
|
// whitelist of symbols we'll allow to be undefined. Unfortunately
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit effdcd0132d17b6c4badc67b4b6d3fdf749a2d22
|
Subproject commit 1ea18a5cb431e24aa838b652ac305acc5e394d6b
|
|
@ -11,7 +11,7 @@
|
||||||
fn xyz() -> u8 { 42 }
|
fn xyz() -> u8 { 42 }
|
||||||
|
|
||||||
const NUM: u8 = xyz();
|
const NUM: u8 = xyz();
|
||||||
//~^ ERROR calls in constants are limited to constant functions, struct and enum constructors
|
//~^ ERROR calls in constants are limited to constant functions, tuple structs and tuple variants
|
||||||
//~| ERROR constant evaluation error
|
//~| ERROR constant evaluation error
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
|
|
@ -7,6 +7,9 @@
|
||||||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
// option. This file may not be copied, modified, or distributed
|
// option. This file may not be copied, modified, or distributed
|
||||||
// except according to those terms.
|
// except according to those terms.
|
||||||
|
|
||||||
|
// ignore-tidy-linelength
|
||||||
|
|
||||||
#![feature(const_fn)]
|
#![feature(const_fn)]
|
||||||
|
|
||||||
const bad : u32 = {
|
const bad : u32 = {
|
||||||
|
@ -20,7 +23,7 @@ const bad_two : u32 = {
|
||||||
{
|
{
|
||||||
invalid();
|
invalid();
|
||||||
//~^ ERROR: blocks in constants are limited to items and tail expressions
|
//~^ ERROR: blocks in constants are limited to items and tail expressions
|
||||||
//~^^ ERROR: calls in constants are limited to constant functions, struct and enum
|
//~^^ ERROR: calls in constants are limited to constant functions, tuple structs and tuple variants
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -44,7 +47,7 @@ static bad_five : u32 = {
|
||||||
{
|
{
|
||||||
invalid();
|
invalid();
|
||||||
//~^ ERROR: blocks in statics are limited to items and tail expressions
|
//~^ ERROR: blocks in statics are limited to items and tail expressions
|
||||||
//~^^ ERROR: calls in statics are limited to constant functions, struct and enum
|
//~^^ ERROR: calls in statics are limited to constant functions, tuple structs and tuple variants
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -68,7 +71,7 @@ static mut bad_eight : u32 = {
|
||||||
{
|
{
|
||||||
invalid();
|
invalid();
|
||||||
//~^ ERROR: blocks in statics are limited to items and tail expressions
|
//~^ ERROR: blocks in statics are limited to items and tail expressions
|
||||||
//~^^ ERROR: calls in statics are limited to constant functions, struct and enum
|
//~^^ ERROR: calls in statics are limited to constant functions, tuple structs and tuple variants
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -4,7 +4,7 @@ error[E0016]: blocks in constant functions are limited to items and tail express
|
||||||
LL | let mut sum = 0;
|
LL | let mut sum = 0;
|
||||||
| ^
|
| ^
|
||||||
|
|
||||||
error[E0015]: calls in constant functions are limited to constant functions, struct and enum constructors
|
error[E0015]: calls in constant functions are limited to constant functions, tuple structs and tuple variants
|
||||||
--> $DIR/const-fn-error.rs:18:14
|
--> $DIR/const-fn-error.rs:18:14
|
||||||
|
|
|
|
||||||
LL | for i in 0..x {
|
LL | for i in 0..x {
|
||||||
|
|
21
src/test/ui/mir_check_nonconst.rs
Normal file
21
src/test/ui/mir_check_nonconst.rs
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
// Copyright 2017 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.
|
||||||
|
|
||||||
|
#![allow(dead_code)]
|
||||||
|
|
||||||
|
struct Foo { a: u8 }
|
||||||
|
fn bar() -> Foo {
|
||||||
|
Foo { a: 5 }
|
||||||
|
}
|
||||||
|
|
||||||
|
static foo: Foo = bar();
|
||||||
|
//~^ ERROR calls in statics are limited to constant functions, tuple structs and tuple variants
|
||||||
|
|
||||||
|
fn main() {}
|
9
src/test/ui/mir_check_nonconst.stderr
Normal file
9
src/test/ui/mir_check_nonconst.stderr
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
error[E0015]: calls in statics are limited to constant functions, tuple structs and tuple variants
|
||||||
|
--> $DIR/mir_check_nonconst.rs:18:19
|
||||||
|
|
|
||||||
|
LL | static foo: Foo = bar();
|
||||||
|
| ^^^^^
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0015`.
|
|
@ -2880,8 +2880,10 @@ impl<'test> TestCx<'test> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let expected_output_path = self.expected_output_path(kind);
|
let expected_output = self.expected_output_path(kind);
|
||||||
let output_file = self.output_base_name().with_file_name(&expected_output_path);
|
// #50113: output is abspath; only want filename component.
|
||||||
|
let expected_output = expected_output.file_name().expect("output path requires file name");
|
||||||
|
let output_file = self.output_base_name().with_file_name(&expected_output);
|
||||||
match File::create(&output_file).and_then(|mut f| f.write_all(actual.as_bytes())) {
|
match File::create(&output_file).and_then(|mut f| f.write_all(actual.as_bytes())) {
|
||||||
Ok(()) => {}
|
Ok(()) => {}
|
||||||
Err(e) => self.fatal(&format!(
|
Err(e) => self.fatal(&format!(
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue