From f22e3c2d475f4579d9fdd0cd533c509a52a47ad1 Mon Sep 17 00:00:00 2001 From: Steven Koo Date: Wed, 6 Jan 2021 11:18:14 -0600 Subject: uhd: revert "Check property type at access..." This change reverts cb9329a681552e6ac6277d16e1627afcbb23e637. The type checking is causing some conversion issues on clang/macos. The type_index checking doesn't work correctly across shared libraries and should not be relied on to verify type, since it can vary from compiler to compiler. Signed-off-by: Steven Koo --- host/include/uhd/property_tree.hpp | 8 +------- host/include/uhd/property_tree.ipp | 6 ++---- host/lib/property_tree.cpp | 26 +------------------------- host/tests/property_test.cpp | 18 ------------------ 4 files changed, 4 insertions(+), 54 deletions(-) diff --git a/host/include/uhd/property_tree.hpp b/host/include/uhd/property_tree.hpp index b6acb791f..ebec6a9f8 100644 --- a/host/include/uhd/property_tree.hpp +++ b/host/include/uhd/property_tree.hpp @@ -13,7 +13,6 @@ #include #include #include -#include #include namespace uhd { @@ -253,15 +252,10 @@ private: //! Internal create property with wild-card type virtual void _create(const fs_path& path, - const std::shared_ptr& prop, - std::type_index prop_type) = 0; + const std::shared_ptr& prop) = 0; //! Internal access property with wild-card type virtual std::shared_ptr& _access(const fs_path& path) const = 0; - - //! Internal access property with wild-card type but with type verification - virtual std::shared_ptr& _access_with_type_check( - const fs_path& path, std::type_index expected_prop_type) const = 0; }; } // namespace uhd diff --git a/host/include/uhd/property_tree.ipp b/host/include/uhd/property_tree.ipp index 0fc871091..d0e127c5d 100644 --- a/host/include/uhd/property_tree.ipp +++ b/host/include/uhd/property_tree.ipp @@ -9,7 +9,6 @@ #pragma once #include -#include #include #include @@ -181,8 +180,7 @@ template property& property_tree::create(const fs_path& path, coerce_mode_t coerce_mode) { this->_create(path, - typename std::shared_ptr >(new property_impl(coerce_mode)), - std::type_index(typeid(T))); + typename std::shared_ptr >(new property_impl(coerce_mode))); return this->access(path); } @@ -190,7 +188,7 @@ template property& property_tree::access(const fs_path& path) { return *std::static_pointer_cast >( - this->_access_with_type_check(path, std::type_index(typeid(T)))); + this->_access(path)); } template diff --git a/host/lib/property_tree.cpp b/host/lib/property_tree.cpp index ba9670913..405c2ac6b 100644 --- a/host/lib/property_tree.cpp +++ b/host/lib/property_tree.cpp @@ -11,7 +11,6 @@ #include #include #include -#include using namespace uhd; @@ -158,8 +157,7 @@ public: } void _create(const fs_path& path_, - const std::shared_ptr& prop, - std::type_index prop_type) + const std::shared_ptr& prop) { const fs_path path = _root / path_; boost::mutex::scoped_lock lock(_guts->mutex); @@ -174,7 +172,6 @@ public: throw uhd::runtime_error( "Cannot create! Property already exists at: " + path); node->prop = prop; - node->prop_type_hash = prop_type.hash_code(); } std::shared_ptr& _access(const fs_path& path_) const @@ -193,26 +190,6 @@ public: return node->prop; } - std::shared_ptr& _access_with_type_check( - const fs_path& path_, std::type_index expected_prop_type) const - { - const fs_path path = _root / path_; - boost::mutex::scoped_lock lock(_guts->mutex); - - node_type* node = &_guts->root; - for (const std::string& name : path_tokenizer(path)) { - if (not node->has_key(name)) - throw_path_not_found(path); - node = &(*node)[name]; - } - if (node->prop.get() == NULL) - throw uhd::runtime_error("Cannot access! Property uninitialized at: " + path); - if (node->prop_type_hash != expected_prop_type.hash_code()) - throw uhd::runtime_error( - "Cannot access! Property types do not match at: " + path); - return node->prop; - } - private: void throw_path_not_found(const fs_path& path) const { @@ -223,7 +200,6 @@ private: struct node_type : uhd::dict { std::shared_ptr prop; - std::size_t prop_type_hash; }; // tree guts which may be referenced in a subtree diff --git a/host/tests/property_test.cpp b/host/tests/property_test.cpp index dbd39000f..9776dd91b 100644 --- a/host/tests/property_test.cpp +++ b/host/tests/property_test.cpp @@ -265,21 +265,3 @@ BOOST_AUTO_TEST_CASE(test_prop_operators) path4 = path4 / x; BOOST_CHECK_EQUAL(path4, "/root/2"); } - -BOOST_AUTO_TEST_CASE(test_mismatched_type_access) -{ - uhd::property_tree::sptr tree = uhd::property_tree::make(); - - // accesses of the correct type should succeed - tree->create("/intprop"); - tree->create("/doubleprop"); - tree->create("/stringprop"); - BOOST_CHECK_NO_THROW(tree->access("/intprop")); - BOOST_CHECK_NO_THROW(tree->access("/doubleprop")); - BOOST_CHECK_NO_THROW(tree->access("/stringprop")); - - // accesses of the incorrect type should throw an exception - BOOST_CHECK_THROW(tree->access("/doubleprop"), uhd::runtime_error); - BOOST_CHECK_THROW(tree->access("/stringprop"), uhd::runtime_error); - BOOST_CHECK_THROW(tree->access("/intprop"), uhd::runtime_error); -} -- cgit v1.2.3