summaryrefslogtreecommitdiff
path: root/src/hir/deserialise.cpp
diff options
context:
space:
mode:
authorJohn Hodge <tpg@mutabah.net>2016-12-03 08:35:33 +0800
committerJohn Hodge <tpg@mutabah.net>2016-12-03 08:35:33 +0800
commit3d4b0c406c11a2f98ea258e0762736fca119b76a (patch)
treef2d9a6e2af70e7821ea1ec3809559be704cf43ec /src/hir/deserialise.cpp
parent55bc4a9e019b1b5e51fec58030a30ea9146de45c (diff)
downloadmrust-3d4b0c406c11a2f98ea258e0762736fca119b76a.tar.gz
HIR/MIR - Vtable generation working well
Diffstat (limited to 'src/hir/deserialise.cpp')
-rw-r--r--src/hir/deserialise.cpp10
1 files changed, 3 insertions, 7 deletions
diff --git a/src/hir/deserialise.cpp b/src/hir/deserialise.cpp
index 3d84c9d6..2d16b230 100644
--- a/src/hir/deserialise.cpp
+++ b/src/hir/deserialise.cpp
@@ -539,12 +539,9 @@ namespace {
::HIR::TraitValueItem deserialise_traitvalueitem()
{
- auto tag = m_in.read_tag();
- auto idx = m_in.read_count();
- ::HIR::TraitValueItem rv;
- switch( tag )
+ switch( m_in.read_tag() )
{
- #define _(x, ...) case ::HIR::TraitValueItem::TAG_##x: DEBUG("- " #x); rv = ::HIR::TraitValueItem::make_##x( __VA_ARGS__ ); break;
+ #define _(x, ...) case ::HIR::TraitValueItem::TAG_##x: DEBUG("- " #x); return ::HIR::TraitValueItem::make_##x( __VA_ARGS__ ); break;
_(Constant, deserialise_constant() )
_(Static, deserialise_static() )
_(Function, deserialise_function() )
@@ -553,8 +550,6 @@ namespace {
DEBUG("Invalid TraitValueItem tag");
throw "";
}
- rv.vtable_ofs = idx;
- return rv;
}
::HIR::AssociatedType deserialise_associatedtype()
{
@@ -866,6 +861,7 @@ namespace {
rv.m_is_marker = m_in.read_bool();
rv.m_types = deserialise_strumap< ::HIR::AssociatedType>();
rv.m_values = deserialise_strumap< ::HIR::TraitValueItem>();
+ rv.m_value_indexes = deserialise_strumap< unsigned int>();
rv.m_type_indexes = deserialise_strumap< unsigned int>();
return rv;
}