aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPatrick Walton <[email protected]>2011-03-28 13:10:10 -0700
committerPatrick Walton <[email protected]>2011-03-28 13:15:03 -0700
commitcc221c472a8f569a574240a27e113fca2ac0ae6b (patch)
tree723af2428637a240ca150d8aaf56823422ca421f /src
parentFix get_tydesc to alloca enough room for root; remove hack that was attemptin... (diff)
downloadrust-cc221c472a8f569a574240a27e113fca2ac0ae6b.tar.xz
rust-cc221c472a8f569a574240a27e113fca2ac0ae6b.zip
rustc: Don't include a trailing null when writing out metadata; it corrupts the EBML
Diffstat (limited to 'src')
-rw-r--r--src/comp/middle/metadata.rs9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/comp/middle/metadata.rs b/src/comp/middle/metadata.rs
index 44c62a47..ec29dae7 100644
--- a/src/comp/middle/metadata.rs
+++ b/src/comp/middle/metadata.rs
@@ -145,9 +145,9 @@ fn ty_fn_str(vec[ty.arg] args, @ty.t out, def_str ds) -> str {
}
-// Returns a Plain Old LLVM String.
+// Returns a Plain Old LLVM String, *without* the trailing zero byte.
fn C_postr(str s) -> ValueRef {
- ret llvm.LLVMConstString(_str.buf(s), _str.byte_len(s), False);
+ ret llvm.LLVMConstString(_str.buf(s), _str.byte_len(s) - 1u, False);
}
@@ -303,8 +303,9 @@ fn encode_tag_id(&ebml.writer ebml_w, &ast.def_id id) {
fn encode_tag_variant_info(@trans.crate_ctxt cx, &ebml.writer ebml_w,
ast.def_id did, vec[ast.variant] variants) {
for (ast.variant variant in variants) {
- ebml.start_tag(ebml_w, tag_items_variant);
+ ebml.start_tag(ebml_w, tag_items_item);
encode_def_id(ebml_w, variant.id);
+ encode_kind(ebml_w, 'v' as u8);
encode_tag_id(ebml_w, did);
encode_type(ebml_w, trans.node_ann_type(cx, variant.ann));
if (_vec.len[ast.variant_arg](variant.args) > 0u) {
@@ -356,7 +357,7 @@ fn encode_info_for_item(@trans.crate_ctxt cx, &ebml.writer ebml_w,
encode_type_params(ebml_w, tps);
ebml.end_tag(ebml_w);
- encode_tag_variant_info(cx, ebml_w, did, variants);
+ //encode_tag_variant_info(cx, ebml_w, did, variants);
}
case (ast.item_obj(?id, _, ?tps, ?did, ?ann)) {
ebml.start_tag(ebml_w, tag_items_item);