From c214135586b69af4d23f5c7102da51471d2b137b Mon Sep 17 00:00:00 2001 From: dimfred Date: Sat, 7 Sep 2019 11:49:12 +0200 Subject: [PATCH] static space_type for abstract_object (optional) --- libraries/db/include/graphene/db/object.hpp | 5 +++++ libraries/plugins/es_objects/es_objects.cpp | 16 ++++++++-------- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/libraries/db/include/graphene/db/object.hpp b/libraries/db/include/graphene/db/object.hpp index b5a6724a2b..4c2d5580fb 100644 --- a/libraries/db/include/graphene/db/object.hpp +++ b/libraries/db/include/graphene/db/object.hpp @@ -101,6 +101,11 @@ namespace graphene { namespace db { } virtual variant to_variant()const { return variant( static_cast(*this), MAX_NESTING ); } virtual vector pack()const { return fc::raw::pack( static_cast(*this) ); } + + static constexpr uint16_t space_type() + { + return (uint16_t)DerivedClass::space_id << 8 | DerivedClass::type_id; + } }; typedef flat_map annotation_map; diff --git a/libraries/plugins/es_objects/es_objects.cpp b/libraries/plugins/es_objects/es_objects.cpp index c6023f9ba5..c9918d636e 100644 --- a/libraries/plugins/es_objects/es_objects.cpp +++ b/libraries/plugins/es_objects/es_objects.cpp @@ -151,7 +151,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s { switch( value.space_type() ) { - case( proposal_object::space_id << 8 | proposal_object::type_id ): + case( proposal_object::space_type() ): { if( _es_objects_proposals ) { auto obj = db.find_object(value); @@ -165,7 +165,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s } break; } - case( account_object::space_id << 8 | account_object::type_id ): + case( account_object::space_type() ): { if( _es_objects_accounts ) { auto obj = db.find_object(value); @@ -179,7 +179,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s } break; } - case( asset_object::space_id << 8 | asset_object::type_id ): + case( asset_object::space_type() ): { if( _es_objects_assets ) { auto obj = db.find_object(value); @@ -193,7 +193,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s } break; } - case( account_balance_object::space_id << 8 | account_balance_object::type_id ): + case( account_balance_object::space_type() ): { if( _es_objects_balances ) { auto obj = db.find_object(value); @@ -207,7 +207,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s } break; } - case( limit_order_object::space_id << 8 | limit_order_object::type_id ): + case( limit_order_object::space_type() ): { if( _es_objects_limit_orders ) { auto obj = db.find_object(value); @@ -221,7 +221,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s } break; } - case( asset_bitasset_data_object::space_id << 8 | asset_bitasset_data_object::type_id ): + case( asset_bitasset_data_object::space_type() ): { if( _es_objects_asset_bitasset ) { auto obj = db.find_object(value); @@ -235,7 +235,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s } break; } - case( voting_statistics_object::space_id << 8 | voting_statistics_object::type_id ): + case( voting_statistics_object::space_type() ): { if( _es_objects_voting_statistics ) { auto obj = db.find_object(value); @@ -250,7 +250,7 @@ bool es_objects_plugin_impl::index_database(const vector& ids, s } break; } - case( voteable_statistics_object::space_id << 8 | voteable_statistics_object::type_id ): + case( voteable_statistics_object::space_type() ): { if( _es_objects_voteable_statistics ) { auto obj = db.find_object(value);