mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 18:54:02 +01:00
Add a new C++11 compatibility macro, LLVM_LVALUE_FUNCTION.
This expands to '&', and is intended to be used when an /optional/ rvalue override is available. Before: void foo() const { ... } After: void foo() const LLVM_LVALUE_FUNCTION { ... } void foo() && { ... } This is used to allow moving the contents of an Optional. llvm-svn: 168963
This commit is contained in:
parent
d3ba5ff018
commit
f630d777a3
@ -48,12 +48,17 @@ public:
|
||||
}
|
||||
|
||||
const T* getPointer() const { assert(hasVal); return &x; }
|
||||
const T& getValue() const { assert(hasVal); return x; }
|
||||
const T& getValue() const LLVM_LVALUE_FUNCTION { assert(hasVal); return x; }
|
||||
|
||||
operator bool() const { return hasVal; }
|
||||
bool hasValue() const { return hasVal; }
|
||||
const T* operator->() const { return getPointer(); }
|
||||
const T& operator*() const { assert(hasVal); return x; }
|
||||
const T& operator*() const LLVM_LVALUE_FUNCTION { assert(hasVal); return x; }
|
||||
|
||||
#if LLVM_USE_RVALUE_REFERENCES
|
||||
T&& getValue() && { assert(hasVal); return std::move(x); }
|
||||
T&& operator*() && { assert(hasVal); return std::move(x); }
|
||||
#endif
|
||||
};
|
||||
|
||||
template<typename T> struct simplify_type;
|
||||
|
@ -38,6 +38,16 @@
|
||||
#define llvm_move(value) (value)
|
||||
#endif
|
||||
|
||||
/// Expands to '&' if r-value references are supported.
|
||||
///
|
||||
/// This can be used to provide l-value/r-value overrides of member functions.
|
||||
/// The r-value override should be guarded by LLVM_USE_RVALUE_REFERENCES
|
||||
#if LLVM_USE_RVALUE_REFERENCES
|
||||
#define LLVM_LVALUE_FUNCTION &
|
||||
#else
|
||||
#define LLVM_LVALUE_FUNCTION
|
||||
#endif
|
||||
|
||||
/// LLVM_DELETED_FUNCTION - Expands to = delete if the compiler supports it.
|
||||
/// Use to mark functions as uncallable. Member functions with this should
|
||||
/// be declared private so that some behavior is kept in C++03 mode.
|
||||
|
Loading…
Reference in New Issue
Block a user