// 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. #ifndef BASE_ALLOCATOR_ALLOCATOR_EXTENSION_H_ #define BASE_ALLOCATOR_ALLOCATOR_EXTENSION_H_ #include // for size_t #include "base/base_export.h" #include "build/build_config.h" namespace base { namespace allocator { typedef void (*ReleaseFreeMemoryFunction)(); typedef bool (*GetNumericPropertyFunction)(const char* name, size_t* value); // Request that the allocator release any free memory it knows about to the // system. BASE_EXPORT void ReleaseFreeMemory(); // Get the named property's |value|. Returns true if the property is known. // Returns false if the property is not a valid property name for the current // allocator implementation. // |name| or |value| cannot be NULL BASE_EXPORT bool GetNumericProperty(const char* name, size_t* value); // These settings allow specifying a callback used to implement the allocator // extension functions. These are optional, but if set they must only be set // once. These will typically called in an allocator-specific initialization // routine. // // No threading promises are made. The caller is responsible for making sure // these pointers are set before any other threads attempt to call the above // functions. BASE_EXPORT void SetReleaseFreeMemoryFunction( ReleaseFreeMemoryFunction release_free_memory_function); BASE_EXPORT void SetGetNumericPropertyFunction( GetNumericPropertyFunction get_numeric_property_function); } // namespace allocator } // namespace base #endif // BASE_ALLOCATOR_ALLOCATOR_EXTENSION_H_