Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rollup of PRs in the queue; Thursday #24232

Merged
merged 51 commits into from
Apr 9, 2015
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
da7529a
Split check_cast to a separate file
sanxiyn Apr 7, 2015
f4c2228
Check casts from float
sanxiyn Apr 7, 2015
d18b405
Check casts from fat pointer
sanxiyn Apr 7, 2015
df95719
Add Clone impls for extern "C" and unsafe fns
lilyball Apr 7, 2015
3344221
Fix a typo
omo Apr 7, 2015
9a51c63
rustup: let RUSTUP_PREFIX env override default prefix.
rillian Apr 7, 2015
5c3aa01
disabling a test that is failing on bitrig.
Apr 7, 2015
a329a61
alloc: impl fmt::Pointer for Rc, Arc and Box
richo Apr 7, 2015
e2ff188
Address review comments
sanxiyn Apr 8, 2015
59e62de
Add tests for #22289, #22370 and #22384
lgrz Apr 8, 2015
1e79870
Modify the ExprUseVisitor to walk each part of an AutoRef, and in
nikomatsakis Apr 8, 2015
45eb54c
configure: Remove obsolete --nightly flag
brson Apr 8, 2015
bc9f16c
configure: Remove obsolete --disable-verify option
brson Apr 8, 2015
ed8eebd
configure: Rename --enable-debug to --enable-debug-assertions
brson Apr 8, 2015
59e332b
configure: Disable debug assertions by default
brson Apr 8, 2015
2cdfd37
configure: Clarify help message for --enable-debug-assertions
brson Apr 8, 2015
8545d2c
configure: Disable LLVM asserts by default
brson Apr 8, 2015
1b34f0a
configure: Clarify --enable-debug-assertions status message
brson Apr 8, 2015
7cbf823
configure: Add --enable-debuginfo
brson Apr 8, 2015
0cb9379
Allow plugins to register LLVM passes
kmcallister Apr 8, 2015
1002155
Add --enable-debug to control multiple perf options
brson Apr 8, 2015
6436e34
Auto merge of #24144 - richo:ptr-formatter, r=alexcrichton
bors Apr 8, 2015
6d17c35
configure: Add --enable-debug-jemalloc
brson Apr 8, 2015
2a9e101
Remove `ignore-tidy-linelength` from tests that no longer need it
lgrz Apr 8, 2015
65e3f03
std: Destabilize the internals of panic!
alexcrichton Apr 8, 2015
6b32072
std: Stabilize Clone::clone_from
alexcrichton Apr 8, 2015
561fdec
std: Stabilize io::Error::from_raw_os_error
alexcrichton Apr 8, 2015
ec7c800
Remove pretty-expanded from failing tests
alexcrichton Apr 8, 2015
287a544
Auto merge of #24158 - sanxiyn:cast, r=nrc
bors Apr 9, 2015
a725426
Don't deoptimize llvm when --enable-debug
brson Apr 9, 2015
0a380a9
Implement io::Seek for io::BufReader<R> where R: io::Seek
lilyball Apr 7, 2015
1605205
Implement io::Seek for io::BufWriter<W> where W: io::Seek
lilyball Apr 8, 2015
0e5e669
Auto merge of #24168 - kballard:clone-for-extern-c-unsafe-fns, r=alex…
bors Apr 9, 2015
613cf9a
Debug impls for a few things in syntax::codemap
nrc Apr 9, 2015
341870a
Fix the span for `for` expressions
nrc Apr 9, 2015
ce76589
Rollup merge of #24171 - rillian:rustup, r=brson
Manishearth Apr 9, 2015
a00ab58
Rollup merge of #24175 - dhuseby:bitrig_fixing_tests_2, r=alexcrichton
Manishearth Apr 9, 2015
68100e4
Rollup merge of #24176 - kballard:bufreader-seek-impl, r=aturon
Manishearth Apr 9, 2015
3b87140
Rollup merge of #24191 - nikomatsakis:issue-20791, r=pnkfelix
Manishearth Apr 9, 2015
67fa4d3
Rollup merge of #24193 - lstat:needstest, r=alexcrichton
Manishearth Apr 9, 2015
2dffe78
Rollup merge of #24205 - brson:debug, r=alexcrichton
Manishearth Apr 9, 2015
4e466e7
Rollup merge of #24207 - kmcallister:llvm-plugin, r=brson
Manishearth Apr 9, 2015
5daee19
Rollup merge of #24212 - alexcrichton:destabilize-begin-unwind, r=huonw
Manishearth Apr 9, 2015
cdfbb11
Rollup merge of #24215 - alexcrichton:stabilize-clone-from, r=aturon
Manishearth Apr 9, 2015
1a6e100
Rollup merge of #24216 - alexcrichton:stabilize-from-raw-os-error, r=…
Manishearth Apr 9, 2015
b389207
Rollup merge of #24218 - lstat:remove-ignore-tidy, r=alexcrichton
Manishearth Apr 9, 2015
27ecaa2
Rollup merge of #24221 - nrc:debug-loc, r=sfackler
Manishearth Apr 9, 2015
ce825ab
Rollup merge of #24170 - omo:omo-typo-fix, r=steveklabnik
Manishearth Apr 9, 2015
ede25fe
Rollup merge of #24225 - nrc:for-span, r=pnkfelix
Manishearth Apr 9, 2015
53a609b
Rollup merge of #24217 - aturon:iterator-fixes, r=alexcrichton
Manishearth Apr 9, 2015
ea73179
fixup windows std_misc
Manishearth Apr 9, 2015
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
53 changes: 37 additions & 16 deletions configure
Original file line number Diff line number Diff line change
Expand Up @@ -523,30 +523,35 @@ fi
BOOL_OPTIONS=""
VAL_OPTIONS=""

opt debug 0 "debug mode"
opt valgrind 0 "run tests with valgrind (memcheck by default)"
opt helgrind 0 "run tests with helgrind instead of memcheck"
opt valgrind-rpass 1 "run rpass-valgrind tests with valgrind"
opt docs 1 "build standard library documentation"
opt compiler-docs 0 "build compiler documentation"
opt optimize 1 "build optimized rust code"
opt optimize-cxx 1 "build optimized C++ code"
opt optimize-llvm 1 "build optimized LLVM"
opt optimize-tests 1 "build tests with optimizations"
opt libcpp 1 "build with llvm with libc++ instead of libstdc++ when using clang"
opt llvm-assertions 1 "build LLVM with assertions"
opt debug 1 "build with extra debug fun"
opt llvm-assertions 0 "build LLVM with assertions"
opt debug-assertions 0 "build with debugging assertions"
opt fast-make 0 "use .gitmodules as timestamp for submodule deps"
opt ccache 0 "invoke gcc/clang via ccache to reuse object files between builds"
opt local-rust 0 "use an installed rustc rather than downloading a snapshot"
opt llvm-static-stdcpp 0 "statically link to libstdc++ for LLVM"
opt rpath 0 "build rpaths into rustc itself"
opt nightly 0 "build nightly packages"
opt verify-install 1 "verify installed binaries work"
# This is used by the automation to produce single-target nightlies
opt dist-host-only 0 "only install bins for the host architecture"
opt inject-std-version 1 "inject the current compiler version of libstd into programs"
opt llvm-version-check 1 "don't check if the LLVM version is supported, build anyway"

# Optimization and debugging options. These may be overridden by the release channel, etc.
opt_nosave optimize 1 "build optimized rust code"
opt_nosave optimize-cxx 1 "build optimized C++ code"
opt_nosave optimize-llvm 1 "build optimized LLVM"
opt_nosave llvm-assertions 0 "build LLVM with assertions"
opt_nosave debug-assertions 0 "build with debugging assertions"
opt_nosave debuginfo 0 "build with debugger metadata"
opt_nosave debug-jemalloc 0 "build jemalloc with --enable-debug --enable-fill"

valopt localstatedir "/var/lib" "local state directory"
valopt sysconfdir "/etc" "install system configuration files"

Expand All @@ -556,6 +561,7 @@ valopt llvm-root "" "set LLVM root"
valopt jemalloc-root "" "set directory where libjemalloc_pic.a is located"
valopt build "${DEFAULT_BUILD}" "GNUs ./configure syntax LLVM build triple"
valopt android-cross-path "/opt/ndk_standalone" "Android NDK standalone path"
valopt release-channel "dev" "the name of the release channel to build"

# Many of these are saved below during the "writing configuration" step
# (others are conditionally saved).
Expand All @@ -568,7 +574,6 @@ valopt_nosave local-rust-root "/usr/local" "set prefix for local rust binary"
valopt_nosave host "${CFG_BUILD}" "GNUs ./configure syntax LLVM host triples"
valopt_nosave target "${CFG_HOST}" "GNUs ./configure syntax LLVM target triples"
valopt_nosave mandir "${CFG_PREFIX}/share/man" "install man pages in PATH"
valopt_nosave release-channel "dev" "the name of the release channel to build"

# Temporarily support old triples until buildbots get updated
CFG_BUILD=$(to_llvm_triple $CFG_BUILD)
Expand Down Expand Up @@ -621,13 +626,24 @@ case "$CFG_RELEASE_CHANNEL" in
;;
esac

# Continue supporting the old --enable-nightly flag to transition the bots
# XXX Remove me
if [ ! -z "$CFG_ENABLE_NIGHTLY" ]
then
CFG_RELEASE_CHANNEL=nightly
# Adjust perf and debug options for debug mode
if [ -n "$CFG_ENABLE_DEBUG" ]; then
msg "debug mode enabled, setting performance options"
CFG_DISABLE_OPTIMIZE=1
CFG_DISABLE_OPTIMIZE_CXX=1
CFG_ENABLE_LLVM_ASSERTIONS=1
CFG_ENABLE_DEBUG_ASSERTIONS=1
CFG_ENABLE_DEBUG_JEMALLOC=1
fi
putvar CFG_RELEASE_CHANNEL

# OK, now write the debugging options
if [ -n "$CFG_DISABLE_OPTIMIZE" ]; then putvar CFG_DISABLE_OPTIMIZE; fi
if [ -n "$CFG_DISABLE_OPTIMIZE_CXX" ]; then putvar CFG_DISABLE_OPTIMIZE_CXX; fi
if [ -n "$CFG_DISABLE_OPTIMIZE_LLVM" ]; then putvar CFG_DISABLE_OPTIMIZE_LLVM; fi
if [ -n "$CFG_ENABLE_LLVM_ASSERTIONS" ]; then putvar CFG_ENABLE_LLVM_ASSERTIONS; fi
if [ -n "$CFG_ENABLE_DEBUG_ASSERTIONS" ]; then putvar CFG_ENABLE_DEBUG_ASSERTIONS; fi
if [ -n "$CFG_ENABLE_DEBUGINFO" ]; then putvar CFG_ENABLE_DEBUGINFO; fi
if [ -n "$CFG_ENABLE_DEBUG_JEMALLOC" ]; then putvar CFG_ENABLE_DEBUG_JEMALLOC; fi

# A magic value that allows the compiler to use unstable features
# during the bootstrap even when doing so would normally be an error
Expand Down Expand Up @@ -1180,7 +1196,7 @@ do
LLVM_DBG_OPTS="--enable-optimized"
LLVM_INST_DIR=$LLVM_BUILD_DIR/Release
fi
if [ ! -z "$CFG_DISABLE_LLVM_ASSERTIONS" ]
if [ -z "$CFG_ENABLE_LLVM_ASSERTIONS" ]
then
LLVM_ASSERTION_OPTS="--disable-assertions"
else
Expand Down Expand Up @@ -1434,6 +1450,11 @@ move_if_changed config.tmp config.mk
rm -f config.tmp
touch config.stamp

step_msg "complete"
if [ -z "$CFG_ENABLE_DEBUG" ]; then
step_msg "configured in release mode. for development consider --enable-debug"
else
step_msg "complete"
fi

msg "run \`make help\`"
msg
10 changes: 2 additions & 8 deletions mk/install.mk
Original file line number Diff line number Diff line change
Expand Up @@ -8,12 +8,6 @@
# option. This file may not be copied, modified, or distributed
# except according to those terms.

ifdef CFG_DISABLE_VERIFY_INSTALL
MAYBE_DISABLE_VERIFY=--disable-verify
else
MAYBE_DISABLE_VERIFY=
endif

install:
ifeq (root user, $(USER) $(patsubst %,user,$(SUDO_USER)))
# Build the dist as the original user
Expand All @@ -22,9 +16,9 @@ else
$(Q)$(MAKE) prepare_install
endif
ifeq ($(CFG_DISABLE_DOCS),)
$(Q)cd tmp/empty_dir && sh ../../tmp/dist/$(DOC_PKG_NAME)-$(CFG_BUILD)/install.sh --prefix="$(DESTDIR)$(CFG_PREFIX)" --libdir="$(DESTDIR)$(CFG_LIBDIR)" --mandir="$(DESTDIR)$(CFG_MANDIR)" "$(MAYBE_DISABLE_VERIFY)"
$(Q)cd tmp/empty_dir && sh ../../tmp/dist/$(DOC_PKG_NAME)-$(CFG_BUILD)/install.sh --prefix="$(DESTDIR)$(CFG_PREFIX)" --libdir="$(DESTDIR)$(CFG_LIBDIR)" --mandir="$(DESTDIR)$(CFG_MANDIR)"
endif
$(Q)cd tmp/empty_dir && sh ../../tmp/dist/$(PKG_NAME)-$(CFG_BUILD)/install.sh --prefix="$(DESTDIR)$(CFG_PREFIX)" --libdir="$(DESTDIR)$(CFG_LIBDIR)" --mandir="$(DESTDIR)$(CFG_MANDIR)" "$(MAYBE_DISABLE_VERIFY)"
$(Q)cd tmp/empty_dir && sh ../../tmp/dist/$(PKG_NAME)-$(CFG_BUILD)/install.sh --prefix="$(DESTDIR)$(CFG_PREFIX)" --libdir="$(DESTDIR)$(CFG_LIBDIR)" --mandir="$(DESTDIR)$(CFG_MANDIR)"
# Remove tmp files because it's a decent amount of disk space
$(Q)rm -R tmp/dist

Expand Down
13 changes: 9 additions & 4 deletions mk/main.mk
Original file line number Diff line number Diff line change
Expand Up @@ -126,11 +126,16 @@ endif

CFG_JEMALLOC_FLAGS += $(JEMALLOC_FLAGS)

ifdef CFG_DISABLE_DEBUG
CFG_RUSTC_FLAGS += --cfg ndebug
else
$(info cfg: enabling more debugging (CFG_ENABLE_DEBUG))
ifdef CFG_ENABLE_DEBUG_ASSERTIONS
$(info cfg: enabling debug assertions (CFG_ENABLE_DEBUG_ASSERTIONS))
CFG_RUSTC_FLAGS += --cfg debug -C debug-assertions=on
else
CFG_RUSTC_FLAGS += --cfg ndebug
endif

ifdef CFG_ENABLE_DEBUGINFO
$(info cfg: enabling debuginfo (CFG_ENABLE_DEBUGINFO))
CFG_RUSTC_FLAGS += -g
endif

ifdef SAVE_TEMPS
Expand Down
4 changes: 4 additions & 0 deletions mk/rt.mk
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,10 @@ else ifeq ($(findstring android, $(OSTYPE_$(1))), android)
JEMALLOC_ARGS_$(1) := --disable-tls
endif

ifdef CFG_ENABLE_DEBUG_JEMALLOC
JEMALLOC_ARGS_$(1) += --enable-debug --enable-fill
endif

################################################################################
# jemalloc
################################################################################
Expand Down
2 changes: 1 addition & 1 deletion src/doc/trpl/associated-types.md
Original file line number Diff line number Diff line change
Expand Up @@ -198,5 +198,5 @@ let obj = Box::new(graph) as Box<Graph<N=Node, E=Edge>>;
```

The `N=Node` syntax allows us to provide a concrete type, `Node`, for the `N`
type parameter. Same with `E=Edge`. If we didn’t proide this constraint, we
type parameter. Same with `E=Edge`. If we didn’t provide this constraint, we
couldn’t be sure which `impl` to match this trait object to.
2 changes: 1 addition & 1 deletion src/etc/rustup.sh
Original file line number Diff line number Diff line change
Expand Up @@ -286,7 +286,7 @@ BOOL_OPTIONS=""
VAL_OPTIONS=""

flag uninstall "only uninstall from the installation prefix"
valopt prefix "" "set installation prefix"
valopt prefix "${RUSTUP_PREFIX}" "set installation prefix"
valopt date "" "use the YYYY-MM-DD nightly instead of the current nightly"
valopt channel "beta" "use the selected release channel [beta]"
flag save "save the downloaded nightlies to ~/.rustup"
Expand Down
7 changes: 7 additions & 0 deletions src/liballoc/arc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -668,6 +668,13 @@ impl<T: fmt::Debug> fmt::Debug for Arc<T> {
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T> fmt::Pointer for Arc<T> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fmt::Pointer::fmt(&*self._ptr, f)
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T: Default + Sync + Send> Default for Arc<T> {
#[stable(feature = "rust1", since = "1.0.0")]
Expand Down
10 changes: 10 additions & 0 deletions src/liballoc/boxed.rs
Original file line number Diff line number Diff line change
Expand Up @@ -275,6 +275,16 @@ impl<T: fmt::Debug + ?Sized> fmt::Debug for Box<T> {
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T> fmt::Pointer for Box<T> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
// It's not possible to extract the inner Uniq directly from the Box,
// instead we cast it to a *const which aliases the Unique
let ptr: *const T = &**self;
fmt::Pointer::fmt(&ptr, f)
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T: ?Sized> Deref for Box<T> {
type Target = T;
Expand Down
7 changes: 7 additions & 0 deletions src/liballoc/rc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -634,6 +634,13 @@ impl<T: fmt::Debug> fmt::Debug for Rc<T> {
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T> fmt::Pointer for Rc<T> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fmt::Pointer::fmt(&*self._ptr, f)
}
}

/// A weak version of `Rc<T>`.
///
/// Weak references do not count when determining if the inner value should be
Expand Down
24 changes: 22 additions & 2 deletions src/libcore/clone.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,7 @@ pub trait Clone : Sized {
/// but can be overridden to reuse the resources of `a` to avoid unnecessary
/// allocations.
#[inline(always)]
#[unstable(feature = "core",
reason = "this function is rarely used")]
#[stable(feature = "rust1", since = "1.0.0")]
fn clone_from(&mut self, source: &Self) {
*self = source.clone()
}
Expand Down Expand Up @@ -97,6 +96,27 @@ macro_rules! extern_fn_clone {
#[inline]
fn clone(&self) -> extern "Rust" fn($($A),*) -> ReturnType { *self }
}

#[unstable(feature = "core", reason = "brand new")]
impl<$($A,)* ReturnType> Clone for extern "C" fn($($A),*) -> ReturnType {
/// Return a copy of a function pointer
#[inline]
fn clone(&self) -> extern "C" fn($($A),*) -> ReturnType { *self }
}

#[unstable(feature = "core", reason = "brand new")]
impl<$($A,)* ReturnType> Clone for unsafe extern "Rust" fn($($A),*) -> ReturnType {
/// Return a copy of a function pointer
#[inline]
fn clone(&self) -> unsafe extern "Rust" fn($($A),*) -> ReturnType { *self }
}

#[unstable(feature = "core", reason = "brand new")]
impl<$($A,)* ReturnType> Clone for unsafe extern "C" fn($($A),*) -> ReturnType {
/// Return a copy of a function pointer
#[inline]
fn clone(&self) -> unsafe extern "C" fn($($A),*) -> ReturnType { *self }
}
)
}

Expand Down
8 changes: 8 additions & 0 deletions src/libcore/ptr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,7 @@ use mem;
use clone::Clone;
use intrinsics;
use ops::Deref;
use core::fmt;
use option::Option::{self, Some, None};
use marker::{PhantomData, Send, Sized, Sync};
use nonzero::NonZero;
Expand Down Expand Up @@ -570,3 +571,10 @@ impl<T:?Sized> Deref for Unique<T> {
unsafe { mem::transmute(&*self.pointer) }
}
}

#[stable(feature = "rust1", since = "1.0.0")]
impl<T> fmt::Pointer for Unique<T> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
fmt::Pointer::fmt(&*self.pointer, f)
}
}
14 changes: 13 additions & 1 deletion src/librustc/middle/check_const.rs
Original file line number Diff line number Diff line change
Expand Up @@ -662,7 +662,19 @@ impl<'a, 'tcx> euv::Delegate<'tcx> for CheckCrateVisitor<'a, 'tcx> {
cmt: mc::cmt<'tcx>,
_loan_region: ty::Region,
bk: ty::BorrowKind,
loan_cause: euv::LoanCause) {
loan_cause: euv::LoanCause)
{
// Kind of hacky, but we allow Unsafe coercions in constants.
// These occur when we convert a &T or *T to a *U, as well as
// when making a thin pointer (e.g., `*T`) into a fat pointer
// (e.g., `*Trait`).
match loan_cause {
euv::LoanCause::AutoUnsafe => {
return;
}
_ => { }
}

let mut cur = &cmt;
let mut is_interior = false;
loop {
Expand Down
Loading