Предположим, что у меня есть API, который имеет 2 метода, которые должны быть использованы в сочетании друг с другом:импульс shared_ptr интерфейс/объект
boost::shared_ptr<IAsset> getAsset(const std::string & id);
void update(const Asset & asset);
и у меня переменную-член boost::shared_ptr<Asset> asset
в другом классе. Если я:
asset = otherObject->getAsset("first_asset");
// do some stuff
otherObject->update(*asset);
я получаю ошибки:
\boost\include\boost/smart_ptr/shared_ptr.hpp(378): error C2440: '<function-style-cast>' : cannot convert from 'boost::shared_ptr<T>' to 'boost::shared_ptr<T>'
with
[
T=IAsset
]
and
[
T=Asset
]
No constructor could take the source type, or constructor overload resolution was ambiguous
src\TestMethod.cpp(35) : see reference to function template instantiation 'boost::shared_ptr<T> &boost::shared_ptr<T>::operator =<IAsset>(boost::shared_ptr<IAsset> &&)' being compiled
with
[
T=Asset
]
\boost\include\boost/smart_ptr/shared_ptr.hpp(378): error C2228: left of '.swap' must have class/struct/union
Здесь я должен отметить, что определение класса Asset
Распространяется IAsset
как в class Asset : virtual public IAsset {...}
Может кто-нибудь сказать мне правильный путь для этого, поскольку у меня нет доступа к базовому API?