diff options
author | ajwong@chromium.org <ajwong@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-02-18 21:48:15 +0000 |
---|---|---|
committer | ajwong@chromium.org <ajwong@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-02-18 21:48:15 +0000 |
commit | 2ab9d4d9df442ff2cf4d622d6d37298284c06365 (patch) | |
tree | 2ea6c3c131e46c951ec4b48ac3a9841634f463b6 /base/callback_internal.h | |
parent | a6a62db1253843e10fb44d97f442946e37d2b90f (diff) | |
download | chromium_src-2ab9d4d9df442ff2cf4d622d6d37298284c06365.zip chromium_src-2ab9d4d9df442ff2cf4d622d6d37298284c06365.tar.gz chromium_src-2ab9d4d9df442ff2cf4d622d6d37298284c06365.tar.bz2 |
Revert "Callback: De-inline CallbackBase, and move to callback_helpers -> callback_internal.h"
This reverts commit r75443.
TBR=akalin
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@75445 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/callback_internal.h')
-rw-r--r-- | base/callback_internal.h | 86 |
1 files changed, 0 insertions, 86 deletions
diff --git a/base/callback_internal.h b/base/callback_internal.h deleted file mode 100644 index 4f1d3c3..0000000 --- a/base/callback_internal.h +++ /dev/null @@ -1,86 +0,0 @@ -// 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. - -// This file contains utility functions and classes that help the -// implementation, and management of the Callback objects. - -#ifndef BASE_CALLBACK_INTERNAL_H_ -#define BASE_CALLBACK_INTERNAL_H_ -#pragma once - -#include "base/ref_counted.h" - -namespace base { -namespace internal { - -// InvokerStorageBase is used to provide an opaque handle that the Callback -// class can use to represent a function object with bound arguments. It -// behaves as an existential type that is used by a corresponding -// DoInvoke function to perform the function execution. This allows -// us to shield the Callback class from the types of the bound argument via -// "type erasure." -class InvokerStorageBase : public RefCountedThreadSafe<InvokerStorageBase> { - protected: - friend class RefCountedThreadSafe<InvokerStorageBase>; - virtual ~InvokerStorageBase() {} -}; - -// This structure exists purely to pass the returned |invoker_storage_| from -// Bind() to Callback while avoiding an extra AddRef/Release() pair. -// -// To do this, the constructor of Callback<> must take a const-ref. The -// reference must be to a const object otherwise the compiler will emit a -// warning about taking a reference to a temporary. -// -// Unfortunately, this means that the internal |invoker_storage_| field must -// be made mutable. -template <typename T> -struct InvokerStorageHolder { - explicit InvokerStorageHolder(T* invoker_storage) - : invoker_storage_(invoker_storage) { - } - - mutable scoped_refptr<InvokerStorageBase> invoker_storage_; -}; - -template <typename T> -InvokerStorageHolder<T> MakeInvokerStorageHolder(T* o) { - return InvokerStorageHolder<T>(o); -} - -// Holds the Callback methods that don't require specialization to reduce -// template bloat. -class CallbackBase { - public: - // Returns true if Callback is null (doesn't refer to anything). - bool is_null() const; - - // Returns the Callback into an uninitalized state. - void Reset(); - - bool Equals(const CallbackBase& other) const; - - protected: - // In C++, it is safe to cast function pointers to function pointers of - // another type. It is not okay to use void*. We create a InvokeFuncStorage - // that that can store our function pointer, and then cast it back to - // the original type on usage. - typedef void(*InvokeFuncStorage)(void); - - CallbackBase(InvokeFuncStorage polymorphic_invoke, - scoped_refptr<InvokerStorageBase>* invoker_storage); - - // Force the destructor to be instaniated inside this translation unit so - // that our subclasses will not get inlined versions. Avoids more template - // bloat. - ~CallbackBase(); - - scoped_refptr<InvokerStorageBase> invoker_storage_; - InvokeFuncStorage polymorphic_invoke_; -}; - -} // namespace internal -} // namespace base - -#endif // BASE_CALLBACK_INTERNAL_H_ |