Files
cbindgen/tests/expectations/must-use.cpp
T
Emilio Cobos Álvarez b2e224354b Use placement new for constructing in tagged unions' helper methods.
Using operator= is not quite sound in presence of destructors and operator
overloading.

It's perfectly fine to assume that the left-hand-side of an operator= expression
is valid memory, however we're using uninitialized memory here, that may not be
the case.

Use placement new to properly construct tagged unions. I don't need this with
any urgency, but it's the right thing to do in presence of complex types, and
the current code seems a bomb waiting to explode :)
2019-05-10 18:15:39 +02:00

38 lines
620 B
C++

#define MUST_USE_FUNC __attribute__((warn_unused_result))
#define MUST_USE_STRUCT __attribute__((warn_unused))
#define MUST_USE_ENUM /* nothing */
#include <cstdarg>
#include <cstdint>
#include <cstdlib>
#include <new>
template<typename T>
struct MUST_USE_STRUCT MaybeOwnedPtr {
enum class MUST_USE_ENUM Tag : uint8_t {
Owned,
None,
};
struct Owned_Body {
T *_0;
};
Tag tag;
union {
Owned_Body owned;
};
};
template<typename T>
struct MUST_USE_STRUCT OwnedPtr {
T *ptr;
};
extern "C" {
MUST_USE_FUNC MaybeOwnedPtr<int32_t> maybe_consume(OwnedPtr<int32_t> input);
} // extern "C"