// 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 PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_
#define PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_
#include "base/memory/ref_counted.h"
#include "ppapi/c/pp_bool.h"
#include "ppapi/c/pp_completion_callback.h"
#include "ppapi/c/pp_stdint.h"
#include "ppapi/thunk/ppapi_thunk_export.h"
namespace ppapi {
class TrackedCallback;
namespace thunk {
class PPAPI_THUNK_EXPORT PPB_MessageLoop_API {
public:
virtual ~PPB_MessageLoop_API() {}
virtual int32_t AttachToCurrentThread() = 0;
virtual int32_t Run() = 0;
// Note: Most interfaces should use scoped_refptr<TrackedCallback>, in order
// to track callbacks and support things like blocking or optional callbacks.
// In this case, the callback is really just a way to pass a function pointer,
// and those options don't make sense.
virtual int32_t PostWork(PP_CompletionCallback callback,
int64_t delay_ms) = 0;
virtual int32_t PostQuit(PP_Bool should_destroy) = 0;
};
} // namespace thunk
} // namespace ppapi
#endif // PPAPI_THUNK_PPB_MESSAGE_LOOP_API_H_