Avoid upcasting uninitialized pointers
Fixes google/protobuf#693 msan flags this as being undefined behavior. I think it's triggering because the compiler has to insert a branch to avoid changing the pointer's value if it starts out NULL. I can't figure out if this is actually undefined behavior or not, but it definitely seems to be a gray area of the standard which is best avoided.
This commit is contained in:
parent
fe066bd514
commit
96c2dd5dfc
@ -224,14 +224,14 @@ inline StatusOr<T>& StatusOr<T>::operator=(const StatusOr<T>& other) {
|
|||||||
template<typename T>
|
template<typename T>
|
||||||
template<typename U>
|
template<typename U>
|
||||||
inline StatusOr<T>::StatusOr(const StatusOr<U>& other)
|
inline StatusOr<T>::StatusOr(const StatusOr<U>& other)
|
||||||
: status_(other.status_), value_(other.value_) {
|
: status_(other.status_), value_(other.status_.ok() ? other.value_ : NULL) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
template<typename U>
|
template<typename U>
|
||||||
inline StatusOr<T>& StatusOr<T>::operator=(const StatusOr<U>& other) {
|
inline StatusOr<T>& StatusOr<T>::operator=(const StatusOr<U>& other) {
|
||||||
status_ = other.status_;
|
status_ = other.status_;
|
||||||
value_ = other.value_;
|
if (status_.ok()) value_ = other.value_;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user