Use a proper ignore_result() to fix a ftruncate warn_unused_result warning with GCC 4.8.

BUG=492
R=mark@chromium.org

Review URL: https://breakpad.appspot.com/944003

git-svn-id: http://google-breakpad.googlecode.com/svn/trunk@1266 4c0a9323-5329-0410-9bdc-e9ce6186880e
This commit is contained in:
thestig@chromium.org 2013-12-18 19:52:36 +00:00
parent 15873e0016
commit 74f640a92e
2 changed files with 19 additions and 1 deletions

View File

@ -86,6 +86,7 @@
#include <utility> #include <utility>
#include <vector> #include <vector>
#include "common/basictypes.h"
#include "common/linux/linux_libc_support.h" #include "common/linux/linux_libc_support.h"
#include "common/memory.h" #include "common/memory.h"
#include "client/linux/log/log.h" #include "client/linux/log/log.h"
@ -574,7 +575,7 @@ bool ExceptionHandler::WriteMinidump() {
// Reposition the FD to its beginning and resize it to get rid of the // Reposition the FD to its beginning and resize it to get rid of the
// previous minidump info. // previous minidump info.
lseek(minidump_descriptor_.fd(), 0, SEEK_SET); lseek(minidump_descriptor_.fd(), 0, SEEK_SET);
static_cast<void>(ftruncate(minidump_descriptor_.fd(), 0)); ignore_result(ftruncate(minidump_descriptor_.fd(), 0));
} }
// Allow this process to be dumped. // Allow this process to be dumped.

View File

@ -38,4 +38,21 @@
void operator=(const TypeName&) void operator=(const TypeName&)
#endif // DISALLOW_COPY_AND_ASSIGN #endif // DISALLOW_COPY_AND_ASSIGN
namespace google_breakpad {
// Used to explicitly mark the return value of a function as unused. If you are
// really sure you don't want to do anything with the return value of a function
// that has been marked with __attribute__((warn_unused_result)), wrap it with
// this. Example:
//
// scoped_ptr<MyType> my_var = ...;
// if (TakeOwnership(my_var.get()) == SUCCESS)
// ignore_result(my_var.release());
//
template<typename T>
inline void ignore_result(const T&) {
}
} // namespace google_breakpad
#endif // COMMON_BASICTYPES_H_ #endif // COMMON_BASICTYPES_H_