#ifndef PPAPI_PROXY_PROXY_COMPLETION_CALLBACK_FACTORY_H_
#define PPAPI_PROXY_PROXY_COMPLETION_CALLBACK_FACTORY_H_
#include "base/logging.h"
#include "base/message_loop/message_loop.h"
#include "ppapi/cpp/completion_callback.h"
#include "ppapi/utility/completion_callback_factory.h"
namespace ppapi {
namespace proxy {
class ProxyNonThreadSafeThreadTraits {
public:
class RefCount {
public:
RefCount() : ref_(0) {
#ifndef NDEBUG
message_loop_ = base::MessageLoop::current();
#endif
}
~RefCount() {
#ifndef NDEBUG
DCHECK(message_loop_ == base::MessageLoop::current());
#endif
}
int32_t AddRef() {
#ifndef NDEBUG
DCHECK(message_loop_ == base::MessageLoop::current());
#endif
return ++ref_;
}
int32_t Release() {
#ifndef NDEBUG
DCHECK(message_loop_ == base::MessageLoop::current());
#endif
DCHECK(ref_ > 0);
return --ref_;
}
private:
int32_t ref_;
#ifndef NDEBUG
base::MessageLoop* message_loop_;
#endif
};
class Lock {
public:
Lock() {}
~Lock() {}
void Acquire() {}
void Release() {}
};
class AutoLock {
public:
explicit AutoLock(Lock&) {}
~AutoLock() {}
};
};
template<typename T>
class ProxyCompletionCallbackFactory
: public pp::CompletionCallbackFactory<T, ProxyNonThreadSafeThreadTraits> {
public:
ProxyCompletionCallbackFactory()
: pp::CompletionCallbackFactory<T, ProxyNonThreadSafeThreadTraits>() {}
ProxyCompletionCallbackFactory(T* t)
: pp::CompletionCallbackFactory<T, ProxyNonThreadSafeThreadTraits>(t) {}
};
}
}
#endif