Index: mojo/ui/associates/resolved_hits.h |
diff --git a/mojo/ui/associates/resolved_hits.h b/mojo/ui/associates/resolved_hits.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..933ad09e80c6e3cace6d833384e89f90fbb38faa |
--- /dev/null |
+++ b/mojo/ui/associates/resolved_hits.h |
@@ -0,0 +1,65 @@ |
+// Copyright 2016 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 MOJO_UI_ASSOCIATES_RESOLVED_HIT_TEST_H_ |
+#define MOJO_UI_ASSOCIATES_RESOLVED_HIT_TEST_H_ |
+ |
+#include <iosfwd> |
+#include <memory> |
+#include <unordered_map> |
+ |
+#include "base/callback.h" |
+#include "base/macros.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "mojo/services/ui/views/interfaces/view_associates.mojom.h" |
+ |
+namespace mojo { |
+namespace ui { |
+ |
+using SceneTokenValueToViewTokenMap = |
+ std::unordered_map<uint32_t, mojo::ui::ViewTokenPtr>; |
+ |
+// A hit test result combined with a map explaining how scenes are mapped |
+// to views. |
+class ResolvedHits { |
+ public: |
+ ResolvedHits(mojo::gfx::composition::HitTestResultPtr result); |
+ ~ResolvedHits(); |
+ |
+ // The hit test result, not null unless |TakeResult| was called. |
+ const mojo::gfx::composition::HitTestResult* result() const { |
+ return result_.get(); |
+ } |
+ mojo::gfx::composition::HitTestResultPtr TakeResult() { |
+ return result_.Pass(); |
+ } |
+ |
+ // A map from scene token value to view token containing all scenes which |
+ // could be resolved. |
+ const SceneTokenValueToViewTokenMap& map() const { return map_; } |
+ |
+ // Adds a mapping for the specified scene token value to a view token. |
+ void AddMapping(uint32_t scene_token_value, |
+ mojo::ui::ViewTokenPtr view_token); |
+ |
+ private: |
+ mojo::gfx::composition::HitTestResultPtr result_; |
+ SceneTokenValueToViewTokenMap map_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ResolvedHits); |
+}; |
+ |
+// Provides a resolved description of the hit test results, or null if the |
+// hit test could not be performed at all. |
+// TODO(jeffbrown): Would prefer to use |std::unique_ptr| here but it doesn't |
+// play nice with base::Callback right now. |
+using ResolvedHitsCallback = base::Callback<void(scoped_ptr<ResolvedHits>)>; |
+ |
+std::ostream& operator<<(std::ostream& os, const mojo::ui::ResolvedHits& value); |
+std::ostream& operator<<(std::ostream& os, const mojo::ui::ResolvedHits* value); |
+ |
+} // namespace ui |
+} // namespace mojo |
+ |
+#endif // MOJO_UI_ASSOCIATES_RESOLVED_HIT_TEST_H_ |