https://gcc.gnu.org/bugzilla/show_bug.cgi?id=78595

Jonathan Wakely <redi at gcc dot gnu.org> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
           Keywords|                            |rejects-valid
   Target Milestone|---                         |8.0

--- Comment #10 from Jonathan Wakely <redi at gcc dot gnu.org> ---
A rejects-valid example that Tim Song provided in Bug 68869:

According to the standard ([map.modifiers]), 

template <class P> pair<iterator, bool> insert(P&& x);

is equivalent to return emplace(std::forward<P>(x)), provided that
std::is_constructible<value_type, P&&>::value is true.

The following code does not compile when insert() is used, but does compile
when emplace() is used. The same issue also affects multimap.

#include <map>
#include <utility>
#include <type_traits>
#include <memory>

struct S {
    operator std::pair<const int, int>() const && { return {}; }
};

static_assert(std::is_constructible<std::pair<const int, int>, S&&>::value,
"!!");
static_assert(std::is_constructible<std::pair<const std::unique_ptr<const int>,
int>, std::pair<std::unique_ptr<int>, int>&&>::value, "!!");

int main(){
    std::map<std::unique_ptr<const int>, int> m;
    std::map<int, int> m2;
    m.insert(std::make_pair(std::make_unique<int>(), 1));  // Error
    m2.insert(S());  // Error

    m.emplace(std::make_pair(std::make_unique<int>(), 1)); // OK
    m2.emplace(S()); // OK
}

Reply via email to