summaryrefslogtreecommitdiffstats
path: root/remoting/client/plugin/chromoting_instance.h
diff options
context:
space:
mode:
Diffstat (limited to 'remoting/client/plugin/chromoting_instance.h')
-rw-r--r--remoting/client/plugin/chromoting_instance.h84
1 files changed, 84 insertions, 0 deletions
diff --git a/remoting/client/plugin/chromoting_instance.h b/remoting/client/plugin/chromoting_instance.h
new file mode 100644
index 0000000..9fe10b6
--- /dev/null
+++ b/remoting/client/plugin/chromoting_instance.h
@@ -0,0 +1,84 @@
+// Copyright (c) 2010 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.
+
+// TODO(ajwong): We need to come up with a better description of the
+// responsibilities for each thread.
+
+#ifndef REMOTING_CLIENT_PLUGIN_CHROMOTING_INSTANCE_H_
+#define REMOTING_CLIENT_PLUGIN_CHROMOTING_INSTANCE_H_
+
+#include <string>
+
+#include "base/at_exit.h"
+#include "base/scoped_ptr.h"
+#include "remoting/client/client_context.h"
+#include "remoting/client/host_connection.h"
+#include "testing/gtest/include/gtest/gtest_prod.h"
+#include "third_party/ppapi/c/pp_event.h"
+#include "third_party/ppapi/c/pp_instance.h"
+#include "third_party/ppapi/c/pp_rect.h"
+#include "third_party/ppapi/c/pp_resource.h"
+#include "third_party/ppapi/cpp/instance.h"
+#include "third_party/ppapi/cpp/device_context_2d.h"
+#include "third_party/ppapi/cpp/var.h"
+
+class MessageLoop;
+
+namespace base {
+class Thread;
+} // namespace base
+
+namespace pp {
+class Module;
+} // namespace pp
+
+namespace remoting {
+
+class ChromotingClient;
+class ClientContext;
+class HostConnection;
+class InputHandler;
+class JingleThread;
+class PepperView;
+
+class ChromotingInstance : public pp::Instance {
+ public:
+ // The mimetype for which this plugin is registered.
+ static const char *kMimeType;
+
+ explicit ChromotingInstance(PP_Instance instance);
+ virtual ~ChromotingInstance();
+
+ virtual bool Init(uint32_t argc, const char* argn[], const char* argv[]);
+ virtual void Connect(const ClientConfig& config);
+ virtual bool HandleEvent(const PP_Event& event);
+ virtual pp::Var GetInstanceObject();
+ virtual void ViewChanged(const pp::Rect& position, const pp::Rect& clip);
+
+ virtual bool CurrentlyOnPluginThread() const;
+
+ private:
+ FRIEND_TEST(ChromotingInstanceTest, TestCaseSetup);
+
+ // Since we're an internal plugin, we can just grab the message loop during
+ // init to figure out which thread we're on. This should only be used to
+ // sanity check which thread we're executing on. Do not post task here!
+ // Instead, use PPB_Core:CallOnMainThread() in the pepper api.
+ //
+ // TODO(ajwong): Think if there is a better way to safeguard this.
+ MessageLoop* pepper_main_loop_dont_post_to_me_;
+
+ ClientContext context_;
+ scoped_ptr<HostConnection> host_connection_;
+ scoped_ptr<PepperView> view_;
+ scoped_ptr<InputHandler> input_handler_;
+ scoped_ptr<ChromotingClient> client_;
+ pp::Var instance_object_; // JavaScript interface to control this instance.
+
+ DISALLOW_COPY_AND_ASSIGN(ChromotingInstance);
+};
+
+} // namespace remoting
+
+#endif // REMOTING_CLIENT_PLUGIN_CHROMOTING_INSTANCE_H_