Commit ced81921 authored by Vadim Pisarevsky's avatar Vadim Pisarevsky

fixed several GCC warnings; fixed crash in kmeans test (because of…

fixed several GCC warnings; fixed crash in kmeans test (because of cv::swap(Mat&a, Mat&b)) (ticket #616)
parent b5f366fb
......@@ -2776,12 +2776,9 @@ public:
MatCommaInitializer_(Mat_<_Tp>* _m);
//! the operator that takes the next value and put it to the matrix
template<typename T2> MatCommaInitializer_<_Tp>& operator , (T2 v);
//! the conversion operator
//operator Mat_<_Tp>() const;
//! another form of conversion operator
Mat_<_Tp> operator *() const;
operator Mat_<_Tp>() const;
virtual void assignTo(Mat& m, int type=-1) const;
protected:
MatIterator_<_Tp> it;
};
......
......@@ -1938,12 +1938,6 @@ template<typename _Tp> inline MatCommaInitializer_<_Tp>::operator Mat_<_Tp>() co
return Mat_<_Tp>(*this->it.m);
}
template<typename _Tp> inline void
MatCommaInitializer_<_Tp>::assignTo(Mat& m, int type) const
{
Mat_<_Tp>(*this).assignTo(m, type);
}
template<typename _Tp, typename T2> static inline MatCommaInitializer_<_Tp>
operator << (const Mat_<_Tp>& m, T2 val)
{
......
......@@ -50,11 +50,26 @@ namespace cv {
void swap( Mat& a, Mat& b )
{
int *ap = (int*)&a, *bp = (int*)&b;
/*int *ap = (int*)&a, *bp = (int*)&b;
size_t i, n = sizeof(Mat)/sizeof(ap[0]);
for( i = 0; i < n; i++ )
std::swap(ap[i], bp[i]);
std::swap(ap[i], bp[i]);*/
std::swap(a.flags, b.flags);
std::swap(a.dims, b.dims);
std::swap(a.rows, b.rows);
std::swap(a.cols, b.cols);
std::swap(a.data, b.data);
std::swap(a.refcount, b.refcount);
std::swap(a.datastart, b.datastart);
std::swap(a.dataend, b.dataend);
std::swap(a.datalimit, b.datalimit);
std::swap(a.allocator, b.allocator);
std::swap(a.size.p, b.size.p);
std::swap(a.step.p, b.step.p);
std::swap(a.step.buf[0], b.step.buf[0]);
std::swap(a.step.buf[1], b.step.buf[1]);
if( a.step.p == b.step.buf )
{
......
......@@ -2325,7 +2325,7 @@ public:
virtual void train();
virtual bool supportMask() { matcher->supportMask(); }
virtual bool supportMask() { return matcher->supportMask(); }
virtual void read( const FileNode& fn );
virtual void write( FileStorage& fs ) const;
......
......@@ -45,7 +45,7 @@ CvTS test_system("ml");
const char* blacklist[] =
{
"kmeans", //ticket 616
//"kmeans", //ticket 616
"artrees", //ticket 460
"aboost", //ticket 474
0
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment