Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(895)

Unified Diff: remoting/host/it2me/it2me_confirmation_dialog_proxy.h

Issue 816903002: It2Me Confirmation Dialog (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address feedback, clean up implementation, add tests. Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: remoting/host/it2me/it2me_confirmation_dialog_proxy.h
diff --git a/remoting/host/it2me/it2me_confirmation_dialog_proxy.h b/remoting/host/it2me/it2me_confirmation_dialog_proxy.h
new file mode 100644
index 0000000000000000000000000000000000000000..c9f50e11f44ccfda62a91a43c78a29ca49752e9b
--- /dev/null
+++ b/remoting/host/it2me/it2me_confirmation_dialog_proxy.h
@@ -0,0 +1,49 @@
+// Copyright 2014 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 REMOTING_HOST_IT2ME_IT2ME_CONFIRMATION_DIALOG_PROXY_H_
+#define REMOTING_HOST_IT2ME_IT2ME_CONFIRMATION_DIALOG_PROXY_H_
+
+#include "base/callback.h"
+#include "base/memory/ref_counted.h"
+#include "base/memory/weak_ptr.h"
+#include "base/single_thread_task_runner.h"
+#include "base/threading/non_thread_safe.h"
+#include "remoting/host/it2me/it2me_confirmation_dialog.h"
+
+namespace remoting {
+
+// A helper class to use an It2MeConfirmationDialog from a non-UI thread.
+class It2MeConfirmationDialogProxy : public It2MeConfirmationDialog {
+ public:
+ // |ui_task_runner| must be the UI thread. It will be used to call into the
+ // wrapped dialog.
+ // |caller_task_runner| is the thread that will be used call into this object.
+ // It will also be used to execute any callbacks.
+ // |dialog| is the dialog being wrapped.
+ It2MeConfirmationDialogProxy(
+ scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner,
+ scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner,
Sergey Ulanov 2014/12/22 19:29:08 Maybe use ThreadTaskRunnerHandle::Get() instead of
dcaiafa 2015/01/05 19:39:27 Done.
+ scoped_ptr<It2MeConfirmationDialog> dialog);
+
+ ~It2MeConfirmationDialogProxy() override;
+
+ // It2MeConfirmationDialog implementation.
+ void Show(const It2MeConfirmationDialog::ResultCallback& callback) override;
+
+ private:
+ class Core;
+
+ void ReportResult(It2MeConfirmationDialog::Result result);
+
+ scoped_ptr<Core> core_;
+ It2MeConfirmationDialog::ResultCallback callback_;
+ base::WeakPtrFactory<It2MeConfirmationDialogProxy> weak_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(It2MeConfirmationDialogProxy);
+};
+
+} // namespace remoting
+
+#endif // REMOTING_HOST_IT2ME_IT2ME_CONFIRMATION_DIALOG_PROXY_H_

Powered by Google App Engine
This is Rietveld 408576698