diff --git a/fboss/thrift_cow/storage/CowStorage.h b/fboss/thrift_cow/storage/CowStorage.h index 998bda778a2a4..3d5fad4ac719c 100644 --- a/fboss/thrift_cow/storage/CowStorage.h +++ b/fboss/thrift_cow/storage/CowStorage.h @@ -67,11 +67,20 @@ class CowStorage : public Storage> { const { T out; auto op = thrift_cow::pvlambda([&](auto& node) { - auto val = node.toThrift(); - if constexpr (std::is_assignable_v) { - out = std::move(val); + if constexpr (!thrift_cow::is_cow_type_v) { + // Thrift object under HybridNode + if constexpr (std::is_assignable_v) { + out = std::move(node); + } else { + throw std::runtime_error("Type mismatch"); + } } else { - throw std::runtime_error("Type mismatch"); + auto val = node.toThrift(); + if constexpr (std::is_assignable_v) { + out = std::move(val); + } else { + throw std::runtime_error("Type mismatch"); + } } }); const auto& rootNode = *root_; @@ -130,14 +139,23 @@ class CowStorage : public Storage> { std::optional set_impl(PathIter begin, PathIter end, T&& value) { StorageImpl::modifyPath(&root_, begin, end); + using ValueT = typename folly::remove_cvref_t; auto op = thrift_cow::pvlambda([&](auto& node) { using NodeT = typename folly::remove_cvref_t; - using TType = typename NodeT::ThriftType; - using ValueT = typename folly::remove_cvref_t; - if constexpr (std::is_same_v) { - node.fromThrift(std::forward(value)); + if constexpr (!thrift_cow::is_cow_type_v) { + // Thrift object under HybridNode + if constexpr (std::is_same_v) { + node = std::forward(value); + } else { + throw std::runtime_error("set: type mismatch for passed in path"); + } } else { - throw std::runtime_error("set: type mismatch for passed in path"); + using TType = typename NodeT::ThriftType; + if constexpr (std::is_same_v) { + node.fromThrift(std::forward(value)); + } else { + throw std::runtime_error("set: type mismatch for passed in path"); + } } }); auto traverseResult = thrift_cow::RootPathVisitor::visit(