Skip to content

Commit 987c9a9

Browse files
committed
---
yaml --- r: 212223 b: refs/heads/tmp c: 3c0165d h: refs/heads/master i: 212221: 02c3fb1 212219: e0375ca 212215: 4a3c66e 212207: bef2628 212191: 4cc9514 212159: ccee55b 212095: f1faed5 211967: 1401657 v: v3
1 parent c8ca541 commit 987c9a9

File tree

24 files changed

+265
-261
lines changed

24 files changed

+265
-261
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -32,7 +32,7 @@ refs/heads/building: 126db549b038c84269a1e4fe46f051b2c15d6970
3232
refs/heads/beta: 62e70d35be3fe532c26a400b499c58a18f18dd3a
3333
refs/heads/windistfix: 7608dbad651f02e837ed05eef3d74a6662a6e928
3434
refs/tags/1.0.0-alpha: e42bd6d93a1d3433c486200587f8f9e12590a4d7
35-
refs/heads/tmp: f1dd27524ab4f2b201f2402d1edeeaf708a09a25
35+
refs/heads/tmp: 3c0165d59ffc3abe890a0e6512c60e8ab76a16d5
3636
refs/tags/1.0.0-alpha.2: 4c705f6bc559886632d3871b04f58aab093bfa2f
3737
refs/tags/homu-tmp: b77d60adb019bb5de05e884a99f3290ec4694137
3838
refs/heads/gate: 97c84447b65164731087ea82685580cc81424412

branches/tmp/configure

Lines changed: 10 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -1307,12 +1307,6 @@ CFG_LLVM_SRC_DIR=${CFG_SRC_DIR}src/llvm/
13071307
for t in $CFG_HOST
13081308
do
13091309
do_reconfigure=1
1310-
is_msvc=0
1311-
case "$t" in
1312-
(*-msvc)
1313-
is_msvc=1
1314-
;;
1315-
esac
13161310

13171311
if [ -z $CFG_LLVM_ROOT ]
13181312
then
@@ -1332,13 +1326,7 @@ do
13321326
LLVM_ASSERTION_OPTS="--disable-assertions"
13331327
else
13341328
LLVM_ASSERTION_OPTS="--enable-assertions"
1335-
1336-
# Apparently even if we request assertions be enabled for MSVC,
1337-
# LLVM's CMake build system ignore this and outputs in `Release`
1338-
# anyway.
1339-
if [ ${is_msvc} -eq 0 ]; then
1340-
LLVM_INST_DIR=${LLVM_INST_DIR}+Asserts
1341-
fi
1329+
LLVM_INST_DIR=${LLVM_INST_DIR}+Asserts
13421330
fi
13431331
else
13441332
msg "not reconfiguring LLVM, external LLVM root"
@@ -1368,7 +1356,14 @@ do
13681356
done
13691357
fi
13701358

1371-
if [ ${do_reconfigure} -ne 0 ] && [ ${is_msvc} -ne 0 ]
1359+
use_cmake=0
1360+
case "$t" in
1361+
(*-msvc)
1362+
use_cmake=1
1363+
;;
1364+
esac
1365+
1366+
if [ ${do_reconfigure} -ne 0 ] && [ ${use_cmake} -ne 0 ]
13721367
then
13731368
msg "configuring LLVM for $t with cmake"
13741369

@@ -1393,7 +1388,7 @@ do
13931388
need_ok "LLVM cmake configure failed"
13941389
fi
13951390

1396-
if [ ${do_reconfigure} -ne 0 ] && [ ${is_msvc} -eq 0 ]
1391+
if [ ${do_reconfigure} -ne 0 ] && [ ${use_cmake} -eq 0 ]
13971392
then
13981393
# LLVM's configure doesn't recognize the new Windows triples yet
13991394
gnu_t=$(to_gnu_triple $t)

branches/tmp/src/doc/index.md

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -25,7 +25,7 @@ series of small examples.
2525
If you need help with something, or just want to talk about Rust with others,
2626
there are a few places you can do that:
2727

28-
The Rust IRC channels on [irc.mozilla.org](http://irc.mozilla.org/) are the
28+
The Rust IRC channels on [irc.mozilla.org](irc://irc.mozilla.org/) are the
2929
fastest way to get help.
3030
[`#rust`](http://chat.mibbit.com/?server=irc.mozilla.org&channel=%23rust) is
3131
the general discussion channel, and you'll find people willing to help you with
@@ -40,15 +40,15 @@ There's also
4040
[`#rust-internals`](http://chat.mibbit.com/?server=irc.mozilla.org&channel=%23rust-internals), which is for discussion of the development of Rust itself.
4141

4242
You can also get help on [Stack
43-
Overflow](http://stackoverflow.com/questions/tagged/rust). Searching for your
43+
Overflow](https://stackoverflow.com/questions/tagged/rust). Searching for your
4444
problem might reveal someone who has asked it before!
4545

46-
There is an active [subreddit](http://reddit.com/r/rust) with lots of
46+
There is an active [subreddit](https://reddit.com/r/rust) with lots of
4747
discussion and news about Rust.
4848

49-
There is also a [user forum](http://users.rust-lang.org), for all
50-
user-oriented discussion, and a [developer
51-
forum](http://internals.rust-lang.org/), where the development of Rust
49+
There is also a [user forum](https://users.rust-lang.org), for all
50+
user-oriented discussion, and a [developer
51+
forum](https://internals.rust-lang.org/), where the development of Rust
5252
itself is discussed.
5353

5454
# Specification
@@ -61,7 +61,7 @@ the language in as much detail as possible is in [the reference](reference.html)
6161
Rust is still a young language, so there isn't a ton of tooling yet, but the
6262
tools we have are really nice.
6363

64-
[Cargo](http://crates.io) is Rust's package manager, and its website contains
64+
[Cargo](https://crates.io) is Rust's package manager, and its website contains
6565
lots of good documentation.
6666

6767
[`rustdoc`](book/documentation.html) is used to generate documentation for Rust code.

branches/tmp/src/doc/trpl/for-loops.md

Lines changed: 0 additions & 42 deletions
Original file line numberDiff line numberDiff line change
@@ -41,45 +41,3 @@ so our loop will print `0` through `9`, not `10`.
4141
Rust does not have the “C-style” `for` loop on purpose. Manually controlling
4242
each element of the loop is complicated and error prone, even for experienced C
4343
developers.
44-
45-
# Enumerate
46-
47-
When you need to keep track of how many times you already looped, you can use the `.enumerate()` function.
48-
49-
## On ranges:
50-
51-
```rust
52-
for (i,j) in (5..10).enumerate() {
53-
println!("i = {} and j = {}", i, j);
54-
}
55-
```
56-
57-
Outputs:
58-
59-
```text
60-
i = 0 and j = 5
61-
i = 1 and j = 6
62-
i = 2 and j = 7
63-
i = 3 and j = 8
64-
i = 4 and j = 9
65-
```
66-
67-
Don't forget to add the parentheses around the range.
68-
69-
## On iterators:
70-
71-
```rust
72-
# let lines = "hello\nworld".lines();
73-
for (linenumber, line) in lines.enumerate() {
74-
println!("{}: {}", linenumber, line);
75-
}
76-
```
77-
78-
Outputs:
79-
80-
```text
81-
0: Content of line one
82-
1: Content of line two
83-
2: Content of line tree
84-
3: Content of line four
85-
```

branches/tmp/src/doc/trpl/references-and-borrowing.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -155,7 +155,7 @@ First, any borrow must last for a smaller scope than the owner. Second, you may
155155
have one or the other of these two kinds of borrows, but not both at the same
156156
time:
157157

158-
* one or more references (`&T`) to a resource.
158+
* 0 to N references (`&T`) to a resource.
159159
* exactly one mutable reference (`&mut T`)
160160

161161

branches/tmp/src/libcollections/linked_list.rs

Lines changed: 0 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -609,13 +609,7 @@ impl<T> LinkedList<T> {
609609
length: len - at
610610
};
611611

612-
// Swap split_node.next with list_head (which is None), nulling out split_node.next,
613-
// as it is the new tail.
614612
mem::swap(&mut split_node.resolve().unwrap().next, &mut splitted_list.list_head);
615-
// Null out list_head.prev. Note this `unwrap` won't fail because if at == len
616-
// we already branched out at the top of the fn to return the empty list.
617-
splitted_list.list_head.as_mut().unwrap().prev = Rawlink::none();
618-
// Fix the tail ptr
619613
self.list_tail = split_node;
620614
self.length = at;
621615

@@ -1081,26 +1075,6 @@ mod tests {
10811075
}
10821076
}
10831077

1084-
#[test]
1085-
fn test_26021() {
1086-
use std::iter::ExactSizeIterator;
1087-
// There was a bug in split_off that failed to null out the RHS's head's prev ptr.
1088-
// This caused the RHS's dtor to walk up into the LHS at drop and delete all of
1089-
// its nodes.
1090-
//
1091-
// https://github.com/rust-lang/rust/issues/26021
1092-
let mut v1 = LinkedList::new();
1093-
v1.push_front(1u8);
1094-
v1.push_front(1u8);
1095-
v1.push_front(1u8);
1096-
v1.push_front(1u8);
1097-
let _ = v1.split_off(3); // Dropping this now should not cause laundry consumption
1098-
assert_eq!(v1.len(), 3);
1099-
1100-
assert_eq!(v1.iter().len(), 3);
1101-
assert_eq!(v1.iter().collect::<Vec<_>>().len(), 3);
1102-
}
1103-
11041078
#[cfg(test)]
11051079
fn fuzz_test(sz: i32) {
11061080
let mut m: LinkedList<_> = LinkedList::new();

branches/tmp/src/liblibc/lib.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -6308,8 +6308,8 @@ pub mod funcs {
63086308
lpOverlapped: LPOVERLAPPED) -> BOOL;
63096309
pub fn WriteFile(hFile: HANDLE,
63106310
lpBuffer: LPVOID,
6311-
nNumberOfBytesToWrite: DWORD,
6312-
lpNumberOfBytesWritten: LPDWORD,
6311+
nNumberOfBytesToRead: DWORD,
6312+
lpNumberOfBytesRead: LPDWORD,
63136313
lpOverlapped: LPOVERLAPPED) -> BOOL;
63146314
pub fn SetFilePointerEx(hFile: HANDLE,
63156315
liDistanceToMove: LARGE_INTEGER,

branches/tmp/src/librustc/metadata/csearch.rs

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@
1313
use metadata::common::*;
1414
use metadata::cstore;
1515
use metadata::decoder;
16+
use middle::def;
1617
use middle::lang_items;
1718
use middle::ty;
1819

@@ -113,6 +114,12 @@ pub fn maybe_get_item_ast<'tcx>(tcx: &ty::ctxt<'tcx>, def: ast::DefId,
113114
decoder::maybe_get_item_ast(&*cdata, tcx, def.node, decode_inlined_item)
114115
}
115116

117+
pub fn get_enum_variant_defs(cstore: &cstore::CStore, enum_id: ast::DefId)
118+
-> Vec<(def::Def, ast::Name, ast::Visibility)> {
119+
let cdata = cstore.get_crate_data(enum_id.krate);
120+
decoder::get_enum_variant_defs(&*cstore.intr, &*cdata, enum_id.node)
121+
}
122+
116123
pub fn get_enum_variants<'tcx>(tcx: &ty::ctxt<'tcx>, def: ast::DefId)
117124
-> Vec<Rc<ty::VariantInfo<'tcx>>> {
118125
let cstore = &tcx.sess.cstore;

branches/tmp/src/librustc/metadata/decoder.rs

Lines changed: 43 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -268,6 +268,30 @@ fn item_trait_ref<'tcx>(doc: rbml::Doc, tcx: &ty::ctxt<'tcx>, cdata: Cmd)
268268
doc_trait_ref(tp, tcx, cdata)
269269
}
270270

271+
struct EnumVariantIds<'a> {
272+
iter: reader::TaggedDocsIterator<'a>,
273+
cdata: Cmd<'a>,
274+
}
275+
276+
impl<'a> Iterator for EnumVariantIds<'a> {
277+
type Item = ast::DefId;
278+
279+
fn next(&mut self) -> Option<ast::DefId> {
280+
self.iter.next().map(|p| translated_def_id(self.cdata, p))
281+
}
282+
283+
fn size_hint(&self) -> (usize, Option<usize>) {
284+
self.iter.size_hint()
285+
}
286+
}
287+
288+
fn enum_variant_ids<'a>(item: rbml::Doc<'a>, cdata: Cmd<'a>) -> EnumVariantIds<'a> {
289+
EnumVariantIds {
290+
iter: reader::tagged_docs(item, tag_items_data_item_variant),
291+
cdata: cdata,
292+
}
293+
}
294+
271295
fn item_path(item_doc: rbml::Doc) -> Vec<ast_map::PathElem> {
272296
let path_doc = reader::get_doc(item_doc, tag_path);
273297
reader::docs(path_doc).filter_map(|(tag, elt_doc)| {
@@ -706,14 +730,31 @@ pub fn maybe_get_item_ast<'tcx>(cdata: Cmd, tcx: &ty::ctxt<'tcx>, id: ast::NodeI
706730
}
707731
}
708732

733+
pub fn get_enum_variant_defs(intr: &IdentInterner,
734+
cdata: Cmd,
735+
id: ast::NodeId)
736+
-> Vec<(def::Def, ast::Name, ast::Visibility)> {
737+
let data = cdata.data();
738+
let items = reader::get_doc(rbml::Doc::new(data), tag_items);
739+
let item = find_item(id, items);
740+
enum_variant_ids(item, cdata).map(|did| {
741+
let item = find_item(did.node, items);
742+
let name = item_name(intr, item);
743+
let visibility = item_visibility(item);
744+
match item_to_def_like(cdata, item, did) {
745+
DlDef(def @ def::DefVariant(..)) => (def, name, visibility),
746+
_ => unreachable!()
747+
}
748+
}).collect()
749+
}
750+
709751
pub fn get_enum_variants<'tcx>(intr: Rc<IdentInterner>, cdata: Cmd, id: ast::NodeId,
710752
tcx: &ty::ctxt<'tcx>) -> Vec<Rc<ty::VariantInfo<'tcx>>> {
711753
let data = cdata.data();
712754
let items = reader::get_doc(rbml::Doc::new(data), tag_items);
713755
let item = find_item(id, items);
714756
let mut disr_val = 0;
715-
reader::tagged_docs(item, tag_items_data_item_variant).map(|p| {
716-
let did = translated_def_id(cdata, p);
757+
enum_variant_ids(item, cdata).map(|did| {
717758
let item = find_item(did.node, items);
718759
let ctor_ty = item_type(ast::DefId { krate: cdata.cnum, node: id},
719760
item, tcx, cdata);

branches/tmp/src/librustc/middle/subst.rs

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -448,6 +448,20 @@ impl<T> VecPerParamSpace<T> {
448448
self.self_limit)
449449
}
450450

451+
pub fn map_move<U, F>(self, mut pred: F) -> VecPerParamSpace<U> where
452+
F: FnMut(T) -> U,
453+
{
454+
let SeparateVecsPerParamSpace {
455+
types: t,
456+
selfs: s,
457+
fns: f
458+
} = self.split();
459+
460+
VecPerParamSpace::new(t.into_iter().map(|p| pred(p)).collect(),
461+
s.into_iter().map(|p| pred(p)).collect(),
462+
f.into_iter().map(|p| pred(p)).collect())
463+
}
464+
451465
pub fn split(self) -> SeparateVecsPerParamSpace<T> {
452466
let VecPerParamSpace { type_limit, self_limit, content } = self;
453467

branches/tmp/src/librustc/middle/traits/fulfill.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -329,7 +329,7 @@ fn process_predicate<'a,'tcx>(selcx: &mut SelectionContext<'a,'tcx>,
329329
false
330330
}
331331
Ok(Some(s)) => {
332-
new_obligations.append(&mut s.nested_obligations());
332+
s.map_move_nested(|p| new_obligations.push(p));
333333
true
334334
}
335335
Err(selection_err) => {

0 commit comments

Comments
 (0)