Wywołanie niejawnie usuniętego konstruktora kopii w LLVM

Zgodnie z C ++ 11 reguły domyślnie generują 6 rzeczy (konstruktor domyślny, konstruktor kopiowania, konstruktor ruchu, przypisanie kopii, przypisanie ruchu i destruktor). Zgodnie z drugą zasadą, gdy zdefiniowana jest dowolna niestandardowa kopia, ruch lub destruktor, te operacje domyślne nie są generowane. Ale w moim kodzie, który następuje, tak nie jest. Ale ten kod nie kompiluje się z błędem

call to implicitly deleted copy constructor of 'Uni'

Kiedy piszę własny konstruktor kopii dla Uni, wszystko działa dobrze. (Jest to komentarz w kodzie, podane w celach informacyjnych)

Wszelkie myśli bardzo doceniane.

Na koniec używam tego na Macu, Xcode z kompilatorem LLVM.

Wielkie dzięki...

#include <iostream>

class A
{
public:
    A(int i) :num{i}
    {
        std::clog<< "ctor  A() num = " << num << "\n";

    }
    A( A const &aRef)
    :num{aRef.num}
    {
        std::clog << " copy ctor A( A const &aRef) num = " << num << "\n";
    }

    int value()
    {
        return num;
    }

private:
    int num;

};
class Uni
{

public:
    Uni(A* aptr) : up{aptr}
    {
        std::clog << " ctor Uni value = " << up.get()->value() << "\n";
    }
    /*Uni(Uni const &uRef)
    {
        std::clog << " copy ctor Uni copying obj pointed by unique_ptr\n";
        up.reset(uRef.up.get() ? new A{*uRef.up.get()} : nullptr);
    }*/
private:
    std::unique_ptr<A> up;

};

int main(int argc, const char * argv[])
{
    Uni one{new A{10}};
    Uni two{one}; //default copy ctor is implicitly deleted. why ?
}

questionAnswers(1)

yourAnswerToTheQuestion