|  | // 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. | 
|  |  | 
|  | #ifndef BASE_I18N_ICU_UTIL_H_ | 
|  | #define BASE_I18N_ICU_UTIL_H_ | 
|  |  | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include "base/files/memory_mapped_file.h" | 
|  | #include "base/i18n/base_i18n_export.h" | 
|  | #include "build_config.h" | 
|  |  | 
|  | #define ICU_UTIL_DATA_FILE   0 | 
|  | #define ICU_UTIL_DATA_SHARED 1 | 
|  | #define ICU_UTIL_DATA_STATIC 2 | 
|  |  | 
|  | namespace base { | 
|  | namespace i18n { | 
|  |  | 
|  | #if !defined(OS_NACL) | 
|  | // Call this function to load ICU's data tables for the current process.  This | 
|  | // function should be called before ICU is used. | 
|  | BASE_I18N_EXPORT bool InitializeICU(); | 
|  |  | 
|  | #if ICU_UTIL_DATA_IMPL == ICU_UTIL_DATA_FILE | 
|  | #if defined(OS_ANDROID) | 
|  | // Returns the PlatformFile and Region that was initialized by InitializeICU(). | 
|  | // Use with InitializeICUWithFileDescriptor(). | 
|  | BASE_I18N_EXPORT PlatformFile GetIcuDataFileHandle( | 
|  | MemoryMappedFile::Region* out_region); | 
|  |  | 
|  | // Android uses a file descriptor passed by browser process to initialize ICU | 
|  | // in render processes. | 
|  | BASE_I18N_EXPORT bool InitializeICUWithFileDescriptor( | 
|  | PlatformFile data_fd, | 
|  | const MemoryMappedFile::Region& data_region); | 
|  | #endif | 
|  |  | 
|  | // Returns a void pointer to the memory mapped ICU data file. | 
|  | // | 
|  | // There are cases on Android where we would be unsafely reusing a file | 
|  | // descriptor within the same process when initializing two copies of ICU from | 
|  | // different binaries in the same address space. This returns an unowned | 
|  | // pointer to the memory mapped icu data file; consumers copies of base must | 
|  | // not outlive the copy of base that owns the memory mapped file. | 
|  | BASE_I18N_EXPORT const uint8_t* GetRawIcuMemory(); | 
|  |  | 
|  | // Initializes ICU memory | 
|  | // | 
|  | // This does nothing in component builds; this initialization should only be | 
|  | // done in cases where there could be two copies of base in a single process in | 
|  | // non-component builds. (The big example is standalone service libraries: the | 
|  | // Service Manager will have a copy of base linked in, and the majority of | 
|  | // service libraries will have base linked in but in non-component builds, | 
|  | // these will be separate copies of base.) | 
|  | BASE_I18N_EXPORT bool InitializeICUFromRawMemory(const uint8_t* raw_memory); | 
|  | #endif  // ICU_UTIL_DATA_IMPL == ICU_UTIL_DATA_FILE | 
|  | #endif  // !defined(OS_NACL) | 
|  |  | 
|  | // In a test binary, the call above might occur twice. | 
|  | BASE_I18N_EXPORT void AllowMultipleInitializeCallsForTesting(); | 
|  |  | 
|  | }  // namespace i18n | 
|  | }  // namespace base | 
|  |  | 
|  | #endif  // BASE_I18N_ICU_UTIL_H_ |