blob: aac77129f068f987f43cccaf83eaff8e2918026a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
// 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 COMPONENTS_MUS_IDS_H_
#define COMPONENTS_MUS_IDS_H_
#include "components/mus/public/cpp/types.h"
#include "components/mus/public/cpp/util.h"
namespace view_manager {
// Connection id is used to indicate no connection. That is, no ViewTreeImpl
// ever gets this id.
const mojo::ConnectionSpecificId kInvalidConnectionId = 0;
// Adds a bit of type safety to view ids.
struct ViewId {
ViewId(mojo::ConnectionSpecificId connection_id,
mojo::ConnectionSpecificId view_id)
: connection_id(connection_id), view_id(view_id) {}
ViewId() : connection_id(0), view_id(0) {}
bool operator==(const ViewId& other) const {
return other.connection_id == connection_id && other.view_id == view_id;
}
bool operator!=(const ViewId& other) const { return !(*this == other); }
mojo::ConnectionSpecificId connection_id;
mojo::ConnectionSpecificId view_id;
};
inline ViewId ViewIdFromTransportId(mojo::Id id) {
return ViewId(mojo::HiWord(id), mojo::LoWord(id));
}
inline mojo::Id ViewIdToTransportId(const ViewId& id) {
return (id.connection_id << 16) | id.view_id;
}
// Returns a ViewId that is reserved to indicate no view. That is, no view will
// ever be created with this id.
inline ViewId InvalidViewId() {
return ViewId(kInvalidConnectionId, 0);
}
// Returns a root view id with a given index offset.
inline ViewId RootViewId(uint16_t index) {
return ViewId(kInvalidConnectionId, 2 + index);
}
} // namespace view_manager
#endif // COMPONENTS_MUS_IDS_H_
|