Skip to content

Commit d13f685

Browse files
committed
---
yaml --- r: 152211 b: refs/heads/try2 c: 1dc13e4 h: refs/heads/master i: 152209: 23bac7d 152207: 714c53d v: v3
1 parent f89d002 commit d13f685

File tree

4 files changed

+42
-50
lines changed

4 files changed

+42
-50
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ refs/heads/snap-stage3: 78a7676898d9f80ab540c6df5d4c9ce35bb50463
55
refs/heads/try: 519addf6277dbafccbb4159db4b710c37eaa2ec5
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b
8-
refs/heads/try2: b981add9ee56a2d6dc11aa48f01aac5d0dda9327
8+
refs/heads/try2: 1dc13e4ad4a140ae1ac4d84e13411c7406196926
99
refs/heads/dist-snap: ba4081a5a8573875fed17545846f6f6902c8ba8d
1010
refs/tags/release-0.2: c870d2dffb391e14efb05aa27898f1f6333a9596
1111
refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503

branches/try2/src/librustdoc/html/markdown.rs

Lines changed: 4 additions & 49 deletions
Original file line numberDiff line numberDiff line change
@@ -287,7 +287,10 @@ pub fn find_testable_code(doc: &str, tests: &mut ::test::Collector) {
287287
slice::raw::buf_as_slice((*lang).data,
288288
(*lang).size as uint, |lang| {
289289
let s = str::from_utf8(lang).unwrap();
290-
parse_lang_string(s)
290+
(s.contains("should_fail"),
291+
s.contains("no_run"),
292+
s.contains("ignore"),
293+
s.contains("notrust"))
291294
})
292295
};
293296
if notrust { return }
@@ -337,35 +340,6 @@ pub fn find_testable_code(doc: &str, tests: &mut ::test::Collector) {
337340
}
338341
}
339342

340-
fn parse_lang_string(string: &str) -> (bool,bool,bool,bool) {
341-
let mut seen_rust_tags = false;
342-
let mut seen_other_tags = false;
343-
let mut should_fail = false;
344-
let mut no_run = false;
345-
let mut ignore = false;
346-
let mut notrust = false;
347-
348-
let mut tokens = string.as_slice().split(|c: char|
349-
!(c == '_' || c == '-' || c.is_alphanumeric())
350-
);
351-
352-
for token in tokens {
353-
match token {
354-
"" => {},
355-
"should_fail" => { should_fail = true; seen_rust_tags = true; },
356-
"no_run" => { no_run = true; seen_rust_tags = true; },
357-
"ignore" => { ignore = true; seen_rust_tags = true; },
358-
"notrust" => { notrust = true; seen_rust_tags = true; },
359-
"rust" => { notrust = false; seen_rust_tags = true; },
360-
_ => { seen_other_tags = true }
361-
}
362-
}
363-
364-
let notrust = notrust || (seen_other_tags && !seen_rust_tags);
365-
366-
(should_fail, no_run, ignore, notrust)
367-
}
368-
369343
/// By default this markdown renderer generates anchors for each header in the
370344
/// rendered document. The anchor name is the contents of the header spearated
371345
/// by hyphens, and a task-local map is used to disambiguate among duplicate
@@ -393,22 +367,3 @@ impl<'a> fmt::Show for MarkdownWithToc<'a> {
393367
render(fmt, md.as_slice(), true)
394368
}
395369
}
396-
397-
#[cfg(test)]
398-
mod tests {
399-
use super::parse_lang_string;
400-
401-
#[test]
402-
fn test_parse_lang_string() {
403-
assert_eq!(parse_lang_string(""), (false,false,false,false))
404-
assert_eq!(parse_lang_string("rust"), (false,false,false,false))
405-
assert_eq!(parse_lang_string("sh"), (false,false,false,true))
406-
assert_eq!(parse_lang_string("notrust"), (false,false,false,true))
407-
assert_eq!(parse_lang_string("ignore"), (false,false,true,false))
408-
assert_eq!(parse_lang_string("should_fail"), (true,false,false,false))
409-
assert_eq!(parse_lang_string("no_run"), (false,true,false,false))
410-
assert_eq!(parse_lang_string("{.no_run .example}"), (false,true,false,false))
411-
assert_eq!(parse_lang_string("{.sh .should_fail}"), (true,false,false,false))
412-
assert_eq!(parse_lang_string("{.example .rust}"), (false,false,false,false))
413-
}
414-
}

branches/try2/src/libsyntax/ext/deriving/encodable.rs

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -175,6 +175,14 @@ fn encodable_substructure(cx: &mut ExtCtxt, trait_span: Span,
175175
stmts.push(cx.stmt_expr(call));
176176
}
177177

178+
// unit structs have no fields and need to return Ok()
179+
if stmts.is_empty() {
180+
let ret_ok = cx.expr(trait_span,
181+
ExprRet(Some(cx.expr_ok(trait_span,
182+
cx.expr_lit(trait_span, LitNil)))));
183+
stmts.push(cx.stmt_expr(ret_ok));
184+
}
185+
178186
let blk = cx.lambda_stmts_1(trait_span, stmts, blkarg);
179187
cx.expr_method_call(trait_span,
180188
encoder,
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
12+
extern crate serialize;
13+
14+
use serialize::{Encodable, Decodable};
15+
use serialize::json;
16+
17+
#[deriving(Encodable, Decodable, PartialEq, Show)]
18+
struct UnitLikeStruct;
19+
20+
pub fn main() {
21+
let obj = UnitLikeStruct;
22+
let json_str: String = json::Encoder::str_encode(&obj);
23+
24+
let json_object = json::from_str(json_str.as_slice());
25+
let mut decoder = json::Decoder::new(json_object.unwrap());
26+
let mut decoded_obj: UnitLikeStruct = Decodable::decode(&mut decoder).unwrap();
27+
28+
assert_eq!(obj, decoded_obj);
29+
}

0 commit comments

Comments
 (0)