Skip to content

Commit a6807a8

Browse files
committed
---
yaml --- r: 14838 b: refs/heads/try c: ffa187d h: refs/heads/master v: v3
1 parent a2dbabc commit a6807a8

File tree

9 files changed

+208
-237
lines changed

9 files changed

+208
-237
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,5 +2,5 @@
22
refs/heads/master: 61b1875c16de39c166b0f4d54bba19f9c6777d1a
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: 4a81779abd786ff22d71434c6d9a5917ea4cdfff
5-
refs/heads/try: c6f2594319266c73f9b5a6c69dd482d6fda8dd12
5+
refs/heads/try: ffa187db252a7ee8765025f95d2cae18859258be
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105

branches/try/src/libcore/core.rc

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@ export uint, u8, u16, u32, u64;
3131
export float, f32, f64;
3232
export box, char, str, ptr, vec, bool;
3333
export either, option, result, iter;
34-
export libc, os, io, run, rand, sys, unsafe, logging, serialization;
34+
export libc, os, io, run, rand, sys, unsafe, logging;
3535
export comm, task, future;
3636
export extfmt;
3737
export tuple;
@@ -88,7 +88,6 @@ mod cmath;
8888
mod sys;
8989
mod unsafe;
9090
mod logging;
91-
mod serialization;
9291

9392
// Concurrency
9493
mod comm;

branches/try/src/libcore/serialization.rs

Lines changed: 0 additions & 116 deletions
This file was deleted.

branches/try/src/libcore/uint.rs

Lines changed: 0 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -192,14 +192,6 @@ fn compl(i: uint) -> uint {
192192
max_value ^ i
193193
}
194194

195-
fn serialize<S: serialization::serializer>(s: S, v: uint) {
196-
s.emit_uint(v);
197-
}
198-
199-
fn deserialize<D: serialization::deserializer>(d: D) -> uint {
200-
d.read_uint()
201-
}
202-
203195
#[cfg(test)]
204196
mod tests {
205197

branches/try/src/libstd/ebml.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -293,7 +293,7 @@ enum ebml_serializer_tag {
293293
es_label // Used only when debugging
294294
}
295295

296-
impl serializer of core::serialization::serializer for ebml::writer {
296+
impl serializer of serialization::serializer for ebml::writer {
297297
fn emit_nil() {}
298298

299299
// used internally to emit things like the vector length and so on
@@ -371,7 +371,7 @@ fn ebml_deserializer(d: ebml::doc) -> ebml_deserializer {
371371
{mutable parent: d, mutable pos: d.start}
372372
}
373373

374-
impl deserializer of core::serialization::deserializer for ebml_deserializer {
374+
impl deserializer of serialization::deserializer for ebml_deserializer {
375375
fn _check_label(lbl: str) {
376376
if self.pos < self.parent.end {
377377
let {tag: r_tag, doc: r_doc} =
Lines changed: 118 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,122 @@
1-
#[doc = "Support code for serialization.
2-
3-
Deprecated in favor of core::serialization."];
1+
#[doc = "Support code for serialization."];
42

53
use core;
6-
import list::list;
7-
import ebml::writer;
84

9-
import core::serialization::{serializer,deserializer};
5+
/*
6+
Core serialization interfaces.
7+
*/
8+
9+
iface serializer {
10+
// Primitive types:
11+
fn emit_nil();
12+
fn emit_uint(v: uint);
13+
fn emit_u64(v: u64);
14+
fn emit_u32(v: u32);
15+
fn emit_u16(v: u16);
16+
fn emit_u8(v: u8);
17+
fn emit_int(v: int);
18+
fn emit_i64(v: i64);
19+
fn emit_i32(v: i32);
20+
fn emit_i16(v: i16);
21+
fn emit_i8(v: i8);
22+
fn emit_bool(v: bool);
23+
fn emit_float(v: float);
24+
fn emit_f64(v: f64);
25+
fn emit_f32(v: f32);
26+
fn emit_str(v: str);
27+
28+
// Compound types:
29+
fn emit_enum(name: str, f: fn());
30+
fn emit_enum_variant(v_name: str, v_id: uint, sz: uint, f: fn());
31+
fn emit_enum_variant_arg(idx: uint, f: fn());
32+
fn emit_vec(len: uint, f: fn());
33+
fn emit_vec_elt(idx: uint, f: fn());
34+
fn emit_box(f: fn());
35+
fn emit_uniq(f: fn());
36+
fn emit_rec(f: fn());
37+
fn emit_rec_field(f_name: str, f_idx: uint, f: fn());
38+
fn emit_tup(sz: uint, f: fn());
39+
fn emit_tup_elt(idx: uint, f: fn());
40+
}
41+
42+
iface deserializer {
43+
// Primitive types:
44+
fn read_nil() -> ();
45+
46+
fn read_uint() -> uint;
47+
fn read_u64() -> u64;
48+
fn read_u32() -> u32;
49+
fn read_u16() -> u16;
50+
fn read_u8() -> u8;
51+
52+
fn read_int() -> int;
53+
fn read_i64() -> i64;
54+
fn read_i32() -> i32;
55+
fn read_i16() -> i16;
56+
fn read_i8() -> i8;
57+
58+
59+
fn read_bool() -> bool;
60+
61+
fn read_str() -> str;
62+
63+
fn read_f64() -> f64;
64+
fn read_f32() -> f32;
65+
fn read_float() -> float;
66+
67+
// Compound types:
68+
fn read_enum<T:copy>(name: str, f: fn() -> T) -> T;
69+
fn read_enum_variant<T:copy>(f: fn(uint) -> T) -> T;
70+
fn read_enum_variant_arg<T:copy>(idx: uint, f: fn() -> T) -> T;
71+
fn read_vec<T:copy>(f: fn(uint) -> T) -> T;
72+
fn read_vec_elt<T:copy>(idx: uint, f: fn() -> T) -> T;
73+
fn read_box<T:copy>(f: fn() -> T) -> T;
74+
fn read_uniq<T:copy>(f: fn() -> T) -> T;
75+
fn read_rec<T:copy>(f: fn() -> T) -> T;
76+
fn read_rec_field<T:copy>(f_name: str, f_idx: uint, f: fn() -> T) -> T;
77+
fn read_tup<T:copy>(sz: uint, f: fn() -> T) -> T;
78+
fn read_tup_elt<T:copy>(idx: uint, f: fn() -> T) -> T;
79+
}
80+
81+
// ___________________________________________________________________________
82+
// Helper routines
83+
//
84+
// In some cases, these should eventually be coded as traits.
85+
86+
fn emit_from_vec<S: serializer, T>(s: S, v: [T], f: fn(T)) {
87+
s.emit_vec(vec::len(v)) {||
88+
vec::iteri(v) {|i,e|
89+
s.emit_vec_elt(i) {||
90+
f(e)
91+
}
92+
}
93+
}
94+
}
95+
96+
fn read_to_vec<D: deserializer, T>(d: D, f: fn() -> T) -> [T] {
97+
d.read_vec {|len|
98+
vec::from_fn(len) {|i|
99+
d.read_vec_elt(i) {|| f() }
100+
}
101+
}
102+
}
103+
104+
impl serializer_helpers<S: serializer> for S {
105+
fn emit_from_vec<T>(v: [T], f: fn(T)) {
106+
emit_from_vec(self, v, f)
107+
}
108+
}
109+
110+
impl deserializer_helpers<D: deserializer> for D {
111+
fn read_to_vec<T>(f: fn() -> T) -> [T] {
112+
read_to_vec(self, f)
113+
}
114+
}
115+
116+
fn serialize_uint<S: serializer>(s: S, v: uint) {
117+
s.emit_uint(v);
118+
}
10119

11-
export serializer;
12-
export deserializer;
120+
fn deserialize_uint<D: deserializer>(d: D) -> uint {
121+
d.read_uint()
122+
}

branches/try/src/rustc/metadata/astencode.rs

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -9,10 +9,10 @@ import std::ebml::writer;
99
import std::ebml::serializer;
1010
import std::ebml::deserializer;
1111
import std::map::hashmap;
12-
import serialization::serializer;
13-
import serialization::deserializer;
14-
import serialization::serializer_helpers;
15-
import serialization::deserializer_helpers;
12+
import std::serialization::serializer;
13+
import std::serialization::deserializer;
14+
import std::serialization::serializer_helpers;
15+
import std::serialization::deserializer_helpers;
1616
import std::smallintmap::map;
1717
import middle::trans::common::maps;
1818
import middle::{ty, typeck, last_use, ast_map};
@@ -295,13 +295,13 @@ impl of tr for span {
295295
}
296296
}
297297

298-
impl serializer_helpers<S: serialization::serializer> for S {
298+
impl serializer_helpers<S: serializer> for S {
299299
fn emit_def_id(did: ast::def_id) {
300300
astencode_gen::serialize_syntax_ast_def_id(self, did)
301301
}
302302
}
303303

304-
impl deserializer_helpers<D: serialization::deserializer> for D {
304+
impl deserializer_helpers<D: deserializer> for D {
305305
fn read_def_id(xcx: extended_decode_ctxt) -> ast::def_id {
306306
let did = astencode_gen::deserialize_syntax_ast_def_id(self);
307307
did.tr(xcx)

0 commit comments

Comments
 (0)