// 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_