mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-27 08:56:07 +00:00

Replace `&__rhs` with `_VSTD::addressof(__rhs)` to guard against ADL hijacking of `operator&` in `operator=`. Thanks to @CaseyCarter for bringing it to our attention. Similar issues with hijacking `operator&` still exist, they will be addressed separately. Reviewed By: #libc, Quuxplusone, ldionne Differential Revision: https://reviews.llvm.org/D110852
40 lines
1.2 KiB
C++
40 lines
1.2 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef SUPPORT_OPERATOR_HIJACKER_H
|
|
#define SUPPORT_OPERATOR_HIJACKER_H
|
|
|
|
#include <cstddef>
|
|
#include <functional>
|
|
|
|
#include "test_macros.h"
|
|
|
|
/// Helper struct to test ADL-hijacking in containers.
|
|
///
|
|
/// The class has some additional operations to be usable in all containers.
|
|
struct operator_hijacker {
|
|
bool operator<(const operator_hijacker&) const { return true; }
|
|
bool operator==(const operator_hijacker&) const { return true; }
|
|
|
|
template <typename T>
|
|
friend void operator&(T&&) = delete;
|
|
template <class T, class U>
|
|
friend void operator,(T&&, U&&) = delete;
|
|
template <class T, class U>
|
|
friend void operator&&(T&&, U&&) = delete;
|
|
template <class T, class U>
|
|
friend void operator||(T&&, U&&) = delete;
|
|
};
|
|
|
|
template <>
|
|
struct std::hash<operator_hijacker> {
|
|
size_t operator()(const operator_hijacker&) const { return 0; }
|
|
};
|
|
|
|
#endif // SUPPORT_OPERATOR_HIJACKER_H
|