У нас есть много нативных классов C++, которые отлично сериализуются с помощью boost::serialization.
Теперь мы хотим изменить некоторые из их полей-членов на property, чтобы мы могли использовать их в PropertyGrids. Когда мы изменили определение класса на ref class X, мы получили огромное количество следующих ошибок компиляции:
#1:
error C2893: Failed to specialize function template 'boost::archive::text_oarchive &boost::archive::detail::interface_oarchive<Archive>::operator <<(T &)' d:\someAddress\someFile.cpp 58
#2:
error C2784: 'std::basic_ostream<_Elem,_Traits> &std::operator <<(std::basic_ostream<_Elem,_Traits> &,const std::_Smanip<_Arg> &)' : could not deduce template argument for 'std::basic_ostream<_Elem,_Traits> &' from 'boost::archive::text_oarchive' d:\someAddress\someFile.cpp 58
У нас здесь много крошечных классов, поэтому написать обертку для каждого из них было бы мучением!
Вот пример класса, который мы использовали:
ref class gps_position2
{
public:
template<class Archive>
void serialize(Archive & ar, const unsigned int version)
{
ar & seconds;
}
public:
gps_position(){};
gps_position(float s)
{
this->seconds = s;
}
property float seconds;
};
А вот основной тестовый код:
int main()
{
std::ofstream ofs("out.txt");
gps_position2 g(24.567f);
// save data to archive
{
boost::archive::text_oarchive oa(ofs);
// write class instance to archive
oa << g;
}
// ................
return 0;
}
Возможно ли вообще использовать boost::serialization с управляемыми классами?
Изменить:
Если мы изменим код использования класса на это:
...
gps_position2^ g = gcnew gps_position2(24.567f);
...
то получаем только 1 ошибку:
error C2027: use of undefined type 'boost::STATIC_ASSERTION_FAILURE<x>' D:\path\to\Boost\boostw\boost\archive\detail\check.hpp 60
boost
в проектах C++ Cli. Особенноboost::serialization
. - person ali_bahoo   schedule 16.03.2011operator<<
иoperator>>
, взяв ссылки на управляемые классы, которые служат адаптерами для версий Boost. - person Tim Sylvester   schedule 29.03.2011