X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/77bbf3027c4240a2e833209a3a3f186589da8577..f021bb7ffaa82cc31dcfe9ccc8d1c34fd1940102:/include/xbt/functional.hpp diff --git a/include/xbt/functional.hpp b/include/xbt/functional.hpp index 64c3caac9d..8b73dabeaf 100644 --- a/include/xbt/functional.hpp +++ b/include/xbt/functional.hpp @@ -171,7 +171,7 @@ private: public: Task() { /* Nothing to do */} - Task(std::nullptr_t) { /* Nothing to do */} + explicit Task(std::nullptr_t) { /* Nothing to do */} ~Task() { this->clear(); @@ -184,7 +184,8 @@ public: if (that.vtable_ && that.vtable_->move) that.vtable_->move(buffer_, that.buffer_); else - std::memcpy(&buffer_, &that.buffer_, sizeof(buffer_)); + std::memcpy(static_cast(&buffer_), static_cast(&that.buffer_), sizeof(buffer_)); + vtable_ = that.vtable_; that.vtable_ = nullptr; } @@ -194,7 +195,7 @@ public: if (that.vtable_ && that.vtable_->move) that.vtable_->move(buffer_, that.buffer_); else - std::memcpy(&buffer_, &that.buffer_, sizeof(buffer_)); + std::memcpy(static_cast(&buffer_), static_cast(&that.buffer_), sizeof(buffer_)); vtable_ = that.vtable_; that.vtable_ = nullptr; return *this; @@ -255,12 +256,7 @@ private: } public: - - template - Task(F code) - { - this->init(std::move(code)); - } + template explicit Task(F code) { this->init(std::move(code)); } operator bool() const { return vtable_ != nullptr; } bool operator!() const { return vtable_ == nullptr; } @@ -297,7 +293,7 @@ auto makeTask(F code, Args... args) -> Task< decltype(code(std::move(args)...))() > { TaskImpl task(std::move(code), std::make_tuple(std::move(args)...)); - return std::move(task); + return Task(std::move(task)); } }