summary refs log tree commit diff
path: root/src
AgeCommit message (Collapse)AuthorLines
2018-01-01Prepare the 1.23.0 stable releaseAlex Crichton-1/+1
* Update the release channel to `stable` * Update the Cargo submodule to the latest tip for 1.23.0
2017-12-23Auto merge of #46912 - pnkfelix:backport-46211-to-beta, r=kennytmbors-0/+4
Backport to beta: disable jemalloc on executables for ios targets Back port of #46211
2017-12-23Auto merge of #46905 - pnkfelix:backport-46112-fix-to-beta, r=michaelwoeristerbors-11/+88
Backport 46112 fix to beta Its probably easiest to focus on the diff rather than the commit series. If you prefer I could squash them, but I figured preserving the cherry-picking will make it easier to relate what has happened here to what happens on the `master` branch. Note: This is a backport of *just* #46838. It does not include #46708 (which we may end up wanting to revert). Fix #46112
2017-12-23Auto merge of #46886 - durka:doc-search-backports, r=GuillaumeGomezbors-263/+329
[beta] Doc search backports This is a backport of #46081, #46175, #46433, and #46672. They all merged cleanly but I haven't tried a build; let's see what Travis says. These PRs fix pretty annoying issues with doc search and so I think it's important they don't slip to stable, but these PRs have *NOT* been `beta-accepted` yet. cc @steveklabnik @GuillaumeGomez can you tag the docs team to talk about beta-acceptance?
2017-12-22re-add tests from fixed regressionsAriel Ben-Yehuda-0/+71
This should make sure that they stay fixed.
2017-12-21Revert "Auto merge of #45225 - eddyb:trans-abi, r=arielb1"Ariel Ben-Yehuda-4965/+5603
This reverts commit f50fd075c2555d8511ccee8a7fe7aee3f2c45e14, reversing changes made to 5041b3bb3d953a14f32b15d1e41341c629acae12.
2017-12-21Revert "rustc: don't unpack newtypes of scalar-pairs with mismatched alignment."Ariel Ben-Yehuda-14/+1
This reverts commit db9d4b1fad7d4914d6184a6744faf1525f0692f2.
2017-12-21Revert "rustc_trans: don't apply noalias on returned references."Ariel Ben-Yehuda-25/+1
This reverts commit 9b2878c15cf9758dc5915e2d54709030bd12109e.
2017-12-21Revert "rustc_trans: don't write discriminants for uninhabited variants"Ariel Ben-Yehuda-42/+7
This reverts commit 4e28c6174b3fa2ec2031f913d35090392373ae70.
2017-12-21explanatory note for the workaroundMathieu Poumeyrol-0/+3
2017-12-21disable jemalloc on exectuable for ios targetsMathieu Poumeyrol-0/+1
2017-12-21reverted tests to cope with "regression" back to printing leading `core::`Felix S. Klock II-4/+4
The reason we see `core::` even after visiting the `std` crate first is the special case code that looks like this: ```rust Entry::Occupied(mut entry) => { // If `child` is defined in crate `cnum`, ensure // that it is mapped to a parent in `cnum`. if child.krate == cnum && entry.get().krate != cnum { entry.insert(parent); } } ``` This causes items to be associated with the crates they were originally defined in, even if we had encountered them during the traversal of an earlier crate. (Having said that, I am not clear on why this same logic does not apply when both #46708 and #46838 have been applied. But at this point, I am just happy to have a plausible explanation for why we see `core::foo::bar` in the output for these tests, and want to focus on getting this fix for #46112 backported to beta.)
2017-12-20Fix type filter in rustdoc jsGuillaume Gomez-4/+4
2017-12-20Fix deduplication of itemsGuillaume Gomez-3/+10
2017-12-20Fix global searchGuillaume Gomez-227/+227
2017-12-20Strongly improve search pathGuillaume Gomez-10/+37
2017-12-20Fix path search in docsGuillaume Gomez-82/+114
2017-12-20Regression test for issue #46112.Felix S. Klock II-0/+47
2017-12-20Followup for #46112.Felix S. Klock II-15/+45
Sorting by crate-num should ensure that we favor `std::foo::bar` over `any_other_crate::foo::bar`. Interestingly, *this* change had a much larger impact on our internal test suite than PR #46708 (which was my original fix to #46112). ---- (This is cherry-pick of aa030dd3deb438c688c85c32eb75d009378c5f12 to beta.)
2017-12-14Download the crosstool from GitHub instead of crosstool-ng.orgkennytm-4/+5
Temporary workaround since crosstool-ng.org was down. Consider mirroring the release tarball as a more permanent solution.
2017-12-14rustbuild: Fix a typo with the Cargo bookAlex Crichton-1/+1
The usage of `Path::new` prevented out-of-tree builds (like the bots do) from working by accident! Closes #46195
2017-12-07Bump beta to .2.Ralph Giles-1/+1
2017-12-07rustc_trans: don't write discriminants for uninhabited variantsSimon Sapin-7/+42
Fixes #46519. Patch as suggested by eddyb: https://github.com/rust-lang/rust/issues/46519#issuecomment-349443519
2017-12-05rustc_trans: don't apply noalias on returned references.Eduard-Mihai Burtescu-1/+25
2017-12-05rustc: don't unpack newtypes of scalar-pairs with mismatched alignment.Eduard-Mihai Burtescu-1/+14
2017-11-25Auto merge of #46145 - nrc:beta-rls, r=alexcrichtonbors-117/+162
[beta] Update rustfmt and rls r? @alexcrichton
2017-11-24Update rustfmt and rlsNick Cameron-117/+162
2017-11-21rustbuild: Allow using unstable rustdoc features on betaAlex Crichton-1/+2
I believe this was forgotten from #45191 but hopefully is a simple fix!
2017-11-20[beta] Prepare the 1.23.0 beta releaseAlex Crichton-5/+5
* Update the release channel config * Update the bootstrap compiler to the dev stable build * Update the cargo submodule to its master branch
2017-11-20Auto merge of #46110 - steveklabnik:update-books, r=steveklabnikbors-1/+1
Update books for next release Since I was out last week I didn't get this done as early as usual, I don't know if beta has branched already or not.
2017-11-20Auto merge of #45645 - fhartwig:39550, r=QuietMisdreavusbors-13/+14
Make rustdoc not include self-by-value methods from Deref target Fixes #39550
2017-11-20Update books for next releasesteveklabnik-1/+1
Also includes a fix in std::ops
2017-11-20Auto merge of #45998 - ollie27:doc_book_css, r=steveklabnikbors-16/+11
Fix broken CSS for book redirect pages rust.css has to be next to the font files so we shouldn't copy it for only the book redirect pages, instead just use the version that is already there. This also removes the duplicate code creating version_info.html. Fixes: #45974
2017-11-20Auto merge of #45905 - alexcrichton:add-wasm-target, r=aturonbors-440/+3636
std: Add a new wasm32-unknown-unknown target This commit adds a new target to the compiler: wasm32-unknown-unknown. This target is a reimagining of what it looks like to generate WebAssembly code from Rust. Instead of using Emscripten which can bring with it a weighty runtime this instead is a target which uses only the LLVM backend for WebAssembly and a "custom linker" for now which will hopefully one day be direct calls to lld. Notable features of this target include: * There is zero runtime footprint. The target assumes nothing exists other than the wasm32 instruction set. * There is zero toolchain footprint beyond adding the target. No custom linker is needed, rustc contains everything. * Very small wasm modules can be generated directly from Rust code using this target. * Most of the standard library is stubbed out to return an error, but anything related to allocation works (aka `HashMap`, `Vec`, etc). * Naturally, any `#[no_std]` crate should be 100% compatible with this new target. This target is currently somewhat janky due to how linking works. The "linking" is currently unconditional whole program LTO (aka LLVM is being used as a linker). Naturally that means compiling programs is pretty slow! Eventually though this target should have a linker. This target is also intended to be quite experimental. I'm hoping that this can act as a catalyst for further experimentation in Rust with WebAssembly. Breaking changes are very likely to land to this target, so it's not recommended to rely on it in any critical capacity yet. We'll let you know when it's "production ready". ### Building yourself First you'll need to configure the build of LLVM and enable this target ``` $ ./configure --target=wasm32-unknown-unknown --set llvm.experimental-targets=WebAssembly ``` Next you'll want to remove any previously compiled LLVM as it needs to be rebuilt with WebAssembly support. You can do that with: ``` $ rm -rf build ``` And then you're good to go! A `./x.py build` should give you a rustc with the appropriate libstd target. ### Test support Currently testing-wise this target is looking pretty good but isn't complete. I've got almost the entire `run-pass` test suite working with this target (lots of tests ignored, but many passing as well). The `core` test suite is [still getting LLVM bugs fixed](https://reviews.llvm.org/D39866) to get that working and will take some time. Relatively simple programs all seem to work though! In general I've only tested this with a local fork that makes use of LLVM 5 rather than our current LLVM 4 on master. The LLVM 4 WebAssembly backend AFAIK isn't broken per se but is likely missing bug fixes available on LLVM 5. I'm hoping though that we can decouple the LLVM 5 upgrade and adding this wasm target! ### But the modules generated are huge! It's worth nothing that you may not immediately see the "smallest possible wasm module" for the input you feed to rustc. For various reasons it's very difficult to get rid of the final "bloat" in vanilla rustc (again, a real linker should fix all this). For now what you'll have to do is: cargo install --git https://github.com/alexcrichton/wasm-gc wasm-gc foo.wasm bar.wasm And then `bar.wasm` should be the smallest we can get it! --- In any case for now I'd love feedback on this, particularly on the various integration points if you've got better ideas of how to approach them!
2017-11-20Auto merge of #45819 - Havvy:cell, r=aturonbors-13/+38
Add RefCell<T>::replace_with I also moved the `Panic` sections to before examples in the other two functions also under this feature gate, and changed the variable names in `replace` to be more readable. r? @rust-libs
2017-11-19std: Add a new wasm32-unknown-unknown targetAlex Crichton-440/+3636
This commit adds a new target to the compiler: wasm32-unknown-unknown. This target is a reimagining of what it looks like to generate WebAssembly code from Rust. Instead of using Emscripten which can bring with it a weighty runtime this instead is a target which uses only the LLVM backend for WebAssembly and a "custom linker" for now which will hopefully one day be direct calls to lld. Notable features of this target include: * There is zero runtime footprint. The target assumes nothing exists other than the wasm32 instruction set. * There is zero toolchain footprint beyond adding the target. No custom linker is needed, rustc contains everything. * Very small wasm modules can be generated directly from Rust code using this target. * Most of the standard library is stubbed out to return an error, but anything related to allocation works (aka `HashMap`, `Vec`, etc). * Naturally, any `#[no_std]` crate should be 100% compatible with this new target. This target is currently somewhat janky due to how linking works. The "linking" is currently unconditional whole program LTO (aka LLVM is being used as a linker). Naturally that means compiling programs is pretty slow! Eventually though this target should have a linker. This target is also intended to be quite experimental. I'm hoping that this can act as a catalyst for further experimentation in Rust with WebAssembly. Breaking changes are very likely to land to this target, so it's not recommended to rely on it in any critical capacity yet. We'll let you know when it's "production ready". --- Currently testing-wise this target is looking pretty good but isn't complete. I've got almost the entire `run-pass` test suite working with this target (lots of tests ignored, but many passing as well). The `core` test suite is still getting LLVM bugs fixed to get that working and will take some time. Relatively simple programs all seem to work though! --- It's worth nothing that you may not immediately see the "smallest possible wasm module" for the input you feed to rustc. For various reasons it's very difficult to get rid of the final "bloat" in vanilla rustc (again, a real linker should fix all this). For now what you'll have to do is: cargo install --git https://github.com/alexcrichton/wasm-gc wasm-gc foo.wasm bar.wasm And then `bar.wasm` should be the smallest we can get it! --- In any case for now I'd love feedback on this, particularly on the various integration points if you've got better ideas of how to approach them!
2017-11-20Auto merge of #46068 - wesleywiser:incr_duplicate_read_stats, r=michaelwoeristerbors-0/+18
[incremental] Collect stats about duplicated edge reads from queries Part of #45873
2017-11-20Make rustdoc not include self-by-value methods from Deref targetFlorian Hartwig-13/+14
2017-11-19Auto merge of #45225 - eddyb:trans-abi, r=arielb1bors-5603/+4965
Refactor type memory layouts and ABIs, to be more general and easier to optimize. To combat combinatorial explosion, type layouts are now described through 3 orthogonal properties: * `Variants` describes the plurality of sum types (where applicable) * `Single` is for one inhabited/active variant, including all C `struct`s and `union`s * `Tagged` has its variants discriminated by an integer tag, including C `enum`s * `NicheFilling` uses otherwise-invalid values ("niches") for all but one of its inhabited variants * `FieldPlacement` describes the number and memory offsets of fields (if any) * `Union` has all its fields at offset `0` * `Array` has offsets that are a multiple of its `stride`; guarantees all fields have one type * `Arbitrary` records all the field offsets, which can be out-of-order * `Abi` describes how values of the type should be passed around, including for FFI * `Uninhabited` corresponds to no values, associated with unreachable control-flow * `Scalar` is ABI-identical to its only integer/floating-point/pointer "scalar component" * `ScalarPair` has two "scalar components", but only applies to the Rust ABI * `Vector` is for SIMD vectors, typically `#[repr(simd)]` `struct`s in Rust * `Aggregate` has arbitrary contents, including all non-transparent C `struct`s and `union`s Size optimizations implemented so far: * ignoring uninhabited variants (i.e. containing uninhabited fields), e.g.: * `Option<!>` is 0 bytes * `Result<T, !>` has the same size as `T` * using arbitrary niches, not just `0`, to represent a data-less variant, e.g.: * `Option<bool>`, `Option<Option<bool>>`, `Option<Ordering>` are all 1 byte * `Option<char>` is 4 bytes * using a range of niches to represent *multiple* data-less variants, e.g.: * `enum E { A(bool), B, C, D }` is 1 byte Code generation now takes advantage of `Scalar` and `ScalarPair` to, in more cases, pass around scalar components as immediates instead of indirectly, through pointers into temporary memory, while avoiding LLVM's "first-class aggregates", and there's more untapped potential here. Closes #44426, fixes #5977, fixes #14540, fixes #43278.
2017-11-19Revert "tests: Update run-make/issue-25581 to reflect how fat pointers are ↵Eduard-Mihai Burtescu-4/+9
passed." This reverts commit b12dcdef4fae5e3856e6911fd6cfbeedadcf3821.
2017-11-19rustc_trans: remove primitive_align optimization.Eduard-Mihai Burtescu-55/+14
2017-11-19Remove some trailing whitespace.Michael Woerister-1/+1
2017-11-19Fix tidy line-length issue.Michael Woerister-1/+2
2017-11-19rustc_trans: work around i686-pc-windows-msvc byval align LLVM bug.Eduard-Mihai Burtescu-4/+6
2017-11-19Auto merge of #46074 - scottmcm:unspecialize-nth, r=blussbors-26/+6
Undo the Sized specialization from Iterator::nth I just added this as part of https://github.com/rust-lang/rust/pull/45595, but I'm now afraid there's a specialization issue with it, since I tried to add [another similar specialization](https://github.com/rust-lang/rust/compare/master...scottmcm:faster-iter-by-ref?expand=1#diff-1398f322bc563592215b583e9b0ba936R2390), and ended up getting really disturbing test failures like ``` thread 'iter::test_by_ref_folds' panicked at 'assertion failed: `(left == right)` left: `15`, right: `15`', src\libcore\../libcore/tests\iter.rs:1720:4 ``` So since this wasn't the most critical part of the change and a new beta is branching within a week, I think putting this part back to what it was before is the best option.
2017-11-19cargotest: temporarily use eddyb/servo to include servo/servo#19285.Eduard-Mihai Burtescu-2/+2
2017-11-19Don't glob-import overlapping variant names in ↵Eduard-Mihai Burtescu-11/+9
test/codegen/match-optimizes-away.rs.
2017-11-19Auto merge of #46064 - Keruspe:master, r=sfacklerbors-11/+11
update openssl{,-sys} to fix build with libressl 2.6.x
2017-11-19Auto merge of #46048 - cramertj:update-libc-2, r=alexcrichtonbors-0/+0
Update libc to include Fuchsia changes This is an update of libc to include the updated Fuchsia "open" flags added in https://github.com/rust-lang/libc/pull/849. cc @smklein r? @alexcrichton
2017-11-19rustc_trans: (hack) use preferred alignment for atomic loads/stores.Eduard-Mihai Burtescu-2/+7