r263785 - Make LookupResult movable again.

David Blaikie via cfe-commits cfe-commits at lists.llvm.org
Fri Mar 18 09:18:50 PDT 2016


Also might be marginally tidier if Paths was a unique_ptr, then you
wouldn't have to explicitly null it out.

I think this is still a pretty subtle thing to allow move or copy support
for & perhaps best avoided, or split into the query parameters and the
result if we're going to support it.

For example - what happens to the original object under move assignment if
Diagnose is true? Presumably we should diagnose rather than silently
suppress, but that seems like a pretty surprising side effect of move
assigning into an object. (perhaps no more than the result of moving into a
unique_ptr that is non-null and having its object's dtor run)

On Fri, Mar 18, 2016 at 6:31 AM, Benjamin Kramer via cfe-commits <
cfe-commits at lists.llvm.org> wrote:

> Author: d0k
> Date: Fri Mar 18 08:31:00 2016
> New Revision: 263785
>
> URL: http://llvm.org/viewvc/llvm-project?rev=263785&view=rev
> Log:
> Make LookupResult movable again.
>
> We lost copy semantics in r263730, because it only worked for a few very
> specific cases. Move semantics don't have this issue. Sadly the
> implementation is a bit messy but I don't know how to clean it up
> without losing support for msvc 2013 :/
>
> Modified:
>     cfe/trunk/include/clang/Sema/Lookup.h
>
> Modified: cfe/trunk/include/clang/Sema/Lookup.h
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Sema/Lookup.h?rev=263785&r1=263784&r2=263785&view=diff
>
> ==============================================================================
> --- cfe/trunk/include/clang/Sema/Lookup.h (original)
> +++ cfe/trunk/include/clang/Sema/Lookup.h Fri Mar 18 08:31:00 2016
> @@ -190,6 +190,44 @@ public:
>    LookupResult(const LookupResult &) = delete;
>    LookupResult &operator=(const LookupResult &) = delete;
>
> +  LookupResult(LookupResult &&Other)
> +      : ResultKind(std::move(Other.ResultKind)),
> +        Ambiguity(std::move(Other.Ambiguity)),
> Decls(std::move(Other.Decls)),
> +        Paths(std::move(Other.Paths)),
> +        NamingClass(std::move(Other.NamingClass)),
> +        BaseObjectType(std::move(Other.BaseObjectType)),
> +        SemaPtr(std::move(Other.SemaPtr)),
> NameInfo(std::move(Other.NameInfo)),
> +        NameContextRange(std::move(Other.NameContextRange)),
> +        LookupKind(std::move(Other.LookupKind)),
> IDNS(std::move(Other.IDNS)),
> +        Redecl(std::move(Other.Redecl)),
> HideTags(std::move(Other.HideTags)),
> +        Diagnose(std::move(Other.Diagnose)),
> +        AllowHidden(std::move(Other.AllowHidden)),
> +        Shadowed(std::move(Other.Shadowed)) {
> +    Other.Paths = nullptr;
> +    Other.Diagnose = false;
> +  }
> +  LookupResult &operator=(LookupResult &&Other) {
> +    ResultKind = std::move(Other.ResultKind);
> +    Ambiguity = std::move(Other.Ambiguity);
> +    Decls = std::move(Other.Decls);
> +    Paths = std::move(Other.Paths);
> +    NamingClass = std::move(Other.NamingClass);
> +    BaseObjectType = std::move(Other.BaseObjectType);
> +    SemaPtr = std::move(Other.SemaPtr);
> +    NameInfo = std::move(Other.NameInfo);
> +    NameContextRange = std::move(Other.NameContextRange);
> +    LookupKind = std::move(Other.LookupKind);
> +    IDNS = std::move(Other.IDNS);
> +    Redecl = std::move(Other.Redecl);
> +    HideTags = std::move(Other.HideTags);
> +    Diagnose = std::move(Other.Diagnose);
> +    AllowHidden = std::move(Other.AllowHidden);
> +    Shadowed = std::move(Other.Shadowed);
> +    Other.Paths = nullptr;
> +    Other.Diagnose = false;
> +    return *this;
> +  }
> +
>    ~LookupResult() {
>      if (Diagnose) diagnose();
>      if (Paths) deletePaths(Paths);
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20160318/d8dd2ac3/attachment-0001.html>


More information about the cfe-commits mailing list