packaged_task
Section: 32.10.10.2 [futures.task.members] Status: C++11 Submitter: Alberto Ganesh Barbati Opened: 2011-02-09 Last modified: 2016-01-28
Priority: Not Prioritized
View other active issues in [futures.task.members].
View all other issues in [futures.task.members].
View all issues with C++11 status.
Discussion:
Related with LWG issue 1514.
The move constructor of packaged_task
does not specify how the stored task is constructed.
The obvious way is to move-construct it using the task stored in the argument. Moreover, the
constructor should be provided with a throws clause similar to one used for the other constructors,
as the move constructor of the stored task is not required to be nothrow.
As for the other constructors, the terms "stores a copy of f
" do not reflect the intent, which is
to allow f
to be moved when possible.
[2011-02-25: Alberto updates wording]
[2011-02-26 Reflector discussion]
Moved to Tentatively Ready after 5 votes.
Proposed resolution:
(wording written assuming LWG 1514 is also accepted)
Change 32.10.10.2 [futures.task.members] paragraph 3:
3 Effects: constructs a new
packaged_task
object with an associated asynchronous state andstores a copy ofinitializes the object's stored task withf
as the object's stored taskstd::forward<F>(f)
. The constructors that take anAllocator
argument use it to allocate memory needed to store the internal data structures.
Change 32.10.10.2 [futures.task.members] paragraph 5:
5 Effects: constructs a new
packaged_task
object and transfers ownership ofother
's associated asynchronous state to*this
, leavingother
with no associated asynchronous state. Moves the stored task fromother
to*this
.