This repository has been archived by the owner on Jun 23, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 59
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
filesystem: bug fix & code refactor (#148)
- Loading branch information
1 parent
9bd165b
commit f53c6cf
Showing
5 changed files
with
348 additions
and
323 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
// Copyright (c) 2011 The Chromium Authors. All rights reserved. | ||
// Use of this source code is governed by a BSD-style license that can be | ||
// found in the LICENSE file. | ||
|
||
#pragma once | ||
|
||
#include <string> | ||
|
||
namespace dsn { | ||
namespace utils { | ||
|
||
// This file declares safe, portable alternatives to the POSIX strerror() | ||
// function. strerror() is inherently unsafe in multi-threaded apps and should | ||
// never be used. Doing so can cause crashes. Additionally, the thread-safe | ||
// alternative strerror_r varies in semantics across platforms. Use these | ||
// functions instead. | ||
|
||
// Thread-safe strerror function with dependable semantics that never fails. | ||
// It will write the string form of error "err" to buffer buf of length len. | ||
// If there is an error calling the OS's strerror_r() function then a message to | ||
// that effect will be printed into buf, truncating if necessary. The final | ||
// result is always null-terminated. The value of errno is never changed. | ||
// | ||
// Use this instead of strerror_r(). | ||
void safe_strerror_r(int err, char *buf, size_t len); | ||
|
||
// Calls safe_strerror_r with a buffer of suitable size and returns the result | ||
// in a C++ string. | ||
// | ||
// Use this instead of strerror(). Note though that safe_strerror_r will be | ||
// more robust in the case of heap corruption errors, since it doesn't need to | ||
// allocate a string. | ||
std::string safe_strerror(int err); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,175 @@ | ||
// Copyright (c) 2012 The Chromium Authors. All rights reserved. | ||
// Use of this source code is governed by a BSD-style license that can be | ||
// found in the LICENSE file. | ||
|
||
// This file adds defines about the platform we're currently building on. | ||
// Operating System: | ||
// OS_WIN / OS_MACOSX / OS_LINUX / OS_POSIX (MACOSX or LINUX) / | ||
// OS_NACL (NACL_SFI or NACL_NONSFI) / OS_NACL_SFI / OS_NACL_NONSFI | ||
// Compiler: | ||
// COMPILER_MSVC / COMPILER_GCC | ||
// Processor: | ||
// ARCH_CPU_X86 / ARCH_CPU_X86_64 / ARCH_CPU_X86_FAMILY (X86 or X86_64) | ||
// ARCH_CPU_32_BITS / ARCH_CPU_64_BITS | ||
|
||
#pragma once | ||
|
||
// A set of macros to use for platform detection. | ||
#if defined(__native_client__) | ||
// __native_client__ must be first, so that other OS_ defines are not set. | ||
#define OS_NACL 1 | ||
// OS_NACL comes in two sandboxing technology flavors, SFI or Non-SFI. | ||
// PNaCl toolchain defines __native_client_nonsfi__ macro in Non-SFI build | ||
// mode, while it does not in SFI build mode. | ||
#if defined(__native_client_nonsfi__) | ||
#define OS_NACL_NONSFI | ||
#else | ||
#define OS_NACL_SFI | ||
#endif | ||
#elif defined(ANDROID) | ||
#define OS_ANDROID 1 | ||
#elif defined(__APPLE__) | ||
// only include TargetConditions after testing ANDROID as some android builds | ||
// on mac don't have this header available and it's not needed unless the target | ||
// is really mac/ios. | ||
#include <TargetConditionals.h> | ||
#define OS_MACOSX 1 | ||
#if defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE | ||
#define OS_IOS 1 | ||
#endif // defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE | ||
#elif defined(__linux__) | ||
#define OS_LINUX 1 | ||
// include a system header to pull in features.h for glibc/uclibc macros. | ||
#include <unistd.h> | ||
#if defined(__GLIBC__) && !defined(__UCLIBC__) | ||
// we really are using glibc, not uClibc pretending to be glibc | ||
#define LIBC_GLIBC 1 | ||
#endif | ||
#elif defined(_WIN32) | ||
#define OS_WIN 1 | ||
#define TOOLKIT_VIEWS 1 | ||
#elif defined(__FreeBSD__) | ||
#define OS_FREEBSD 1 | ||
#elif defined(__OpenBSD__) | ||
#define OS_OPENBSD 1 | ||
#elif defined(__sun) | ||
#define OS_SOLARIS 1 | ||
#elif defined(__QNXNTO__) | ||
#define OS_QNX 1 | ||
#else | ||
#error Please add support for your platform in butil/build_config.h | ||
#endif | ||
|
||
#if defined(USE_OPENSSL_CERTS) && defined(USE_NSS_CERTS) | ||
#error Cannot use both OpenSSL and NSS for certificates | ||
#endif | ||
|
||
// For access to standard BSD features, use OS_BSD instead of a | ||
// more specific macro. | ||
#if defined(OS_FREEBSD) || defined(OS_OPENBSD) | ||
#define OS_BSD 1 | ||
#endif | ||
|
||
// For access to standard POSIXish features, use OS_POSIX instead of a | ||
// more specific macro. | ||
#if defined(OS_MACOSX) || defined(OS_LINUX) || defined(OS_FREEBSD) || \ | ||
defined(OS_OPENBSD) || defined(OS_SOLARIS) || defined(OS_ANDROID) || \ | ||
defined(OS_NACL) || defined(OS_QNX) | ||
#define OS_POSIX 1 | ||
#endif | ||
|
||
// Use tcmalloc | ||
#if (defined(OS_WIN) || defined(OS_LINUX) || defined(OS_ANDROID)) && \ | ||
!defined(NO_TCMALLOC) | ||
#define USE_TCMALLOC 1 | ||
#endif | ||
|
||
// Compiler detection. | ||
#if defined(__GNUC__) | ||
#define COMPILER_GCC 1 | ||
#elif defined(_MSC_VER) | ||
#define COMPILER_MSVC 1 | ||
#else | ||
#error Please add support for your compiler in butil/build_config.h | ||
#endif | ||
|
||
// Processor architecture detection. For more info on what's defined, see: | ||
// http://msdn.microsoft.com/en-us/library/b0084kay.aspx | ||
// http://www.agner.org/optimize/calling_conventions.pdf | ||
// or with gcc, run: "echo | gcc -E -dM -" | ||
#if defined(_M_X64) || defined(__x86_64__) | ||
#define ARCH_CPU_X86_FAMILY 1 | ||
#define ARCH_CPU_X86_64 1 | ||
#define ARCH_CPU_64_BITS 1 | ||
#define ARCH_CPU_LITTLE_ENDIAN 1 | ||
#elif defined(_M_IX86) || defined(__i386__) | ||
#define ARCH_CPU_X86_FAMILY 1 | ||
#define ARCH_CPU_X86 1 | ||
#define ARCH_CPU_32_BITS 1 | ||
#define ARCH_CPU_LITTLE_ENDIAN 1 | ||
#elif defined(__ARMEL__) | ||
#define ARCH_CPU_ARM_FAMILY 1 | ||
#define ARCH_CPU_ARMEL 1 | ||
#define ARCH_CPU_32_BITS 1 | ||
#define ARCH_CPU_LITTLE_ENDIAN 1 | ||
#elif defined(__aarch64__) | ||
#define ARCH_CPU_ARM_FAMILY 1 | ||
#define ARCH_CPU_ARM64 1 | ||
#define ARCH_CPU_64_BITS 1 | ||
#define ARCH_CPU_LITTLE_ENDIAN 1 | ||
#elif defined(__pnacl__) | ||
#define ARCH_CPU_32_BITS 1 | ||
#define ARCH_CPU_LITTLE_ENDIAN 1 | ||
#elif defined(__MIPSEL__) | ||
#if defined(__LP64__) | ||
#define ARCH_CPU_MIPS64_FAMILY 1 | ||
#define ARCH_CPU_MIPS64EL 1 | ||
#define ARCH_CPU_64_BITS 1 | ||
#define ARCH_CPU_LITTLE_ENDIAN 1 | ||
#else | ||
#define ARCH_CPU_MIPS_FAMILY 1 | ||
#define ARCH_CPU_MIPSEL 1 | ||
#define ARCH_CPU_32_BITS 1 | ||
#define ARCH_CPU_LITTLE_ENDIAN 1 | ||
#endif | ||
#else | ||
#error Please add support for your architecture in butil/build_config.h | ||
#endif | ||
|
||
// Type detection for wchar_t. | ||
#if defined(OS_WIN) | ||
#define WCHAR_T_IS_UTF16 | ||
#elif defined(OS_POSIX) && defined(COMPILER_GCC) && \ | ||
defined(__WCHAR_MAX__) && \ | ||
(__WCHAR_MAX__ == 0x7fffffff || __WCHAR_MAX__ == 0xffffffff) | ||
#define WCHAR_T_IS_UTF32 | ||
#elif defined(OS_POSIX) && defined(COMPILER_GCC) && \ | ||
defined(__WCHAR_MAX__) && \ | ||
(__WCHAR_MAX__ == 0x7fff || __WCHAR_MAX__ == 0xffff) | ||
// On Posix, we'll detect short wchar_t, but projects aren't guaranteed to | ||
// compile in this mode (in particular, Chrome doesn't). This is intended for | ||
// other projects using base who manage their own dependencies and make sure | ||
// short wchar works for them. | ||
#define WCHAR_T_IS_UTF16 | ||
#else | ||
#error Please add support for your compiler in butil/build_config.h | ||
#endif | ||
|
||
#if defined(OS_ANDROID) | ||
// The compiler thinks std::string::const_iterator and "const char*" are | ||
// equivalent types. | ||
#define STD_STRING_ITERATOR_IS_CHAR_POINTER | ||
// The compiler thinks butil::string16::const_iterator and "char16*" are | ||
// equivalent types. | ||
#define BUTIL_STRING16_ITERATOR_IS_CHAR16_POINTER | ||
#endif | ||
|
||
#if defined(__GXX_EXPERIMENTAL_CXX0X__) || __cplusplus >= 201103L | ||
#define BUTIL_CXX11_ENABLED 1 | ||
#endif | ||
|
||
#if !defined(BUTIL_CXX11_ENABLED) | ||
#define nullptr NULL | ||
#endif | ||
|
||
#define HAVE_DLADDR |
Oops, something went wrong.