1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef COMPONENTS_VIEW_MANAGER_IDS_H_
6 #define COMPONENTS_VIEW_MANAGER_IDS_H_
8 #include "components/view_manager/public/cpp/types.h"
9 #include "components/view_manager/public/cpp/util.h"
11 namespace view_manager
{
13 // Connection id is used to indicate no connection. That is, no
14 // ViewManagerServiceImpl ever gets this id.
15 const mojo::ConnectionSpecificId kInvalidConnectionId
= 0;
17 // Adds a bit of type safety to view ids.
19 ViewId(mojo::ConnectionSpecificId connection_id
,
20 mojo::ConnectionSpecificId view_id
)
21 : connection_id(connection_id
), view_id(view_id
) {}
22 ViewId() : connection_id(0), view_id(0) {}
24 bool operator==(const ViewId
& other
) const {
25 return other
.connection_id
== connection_id
&&
26 other
.view_id
== view_id
;
29 bool operator!=(const ViewId
& other
) const {
30 return !(*this == other
);
33 mojo::ConnectionSpecificId connection_id
;
34 mojo::ConnectionSpecificId view_id
;
37 inline ViewId
ViewIdFromTransportId(mojo::Id id
) {
38 return ViewId(mojo::HiWord(id
), mojo::LoWord(id
));
41 inline mojo::Id
ViewIdToTransportId(const ViewId
& id
) {
42 return (id
.connection_id
<< 16) | id
.view_id
;
45 // Returns a ViewId that is reserved to indicate no view. That is, no view will
46 // ever be created with this id.
47 inline ViewId
InvalidViewId() {
48 return ViewId(kInvalidConnectionId
, 0);
51 // All cloned views use this id.
52 inline ViewId
ClonedViewId() {
53 return ViewId(kInvalidConnectionId
, 1);
56 // Returns a root view id with a given index offset.
57 inline ViewId
RootViewId(uint16_t index
) {
58 return ViewId(kInvalidConnectionId
, 2 + index
);
61 } // namespace view_manager
63 #endif // COMPONENTS_VIEW_MANAGER_IDS_H_