OSDN Git Service

release-request-e04bb055-13fc-41a1-8a9f-7fb10894ec3d-for-git_oc-mr1-release-4189380...
[android-x86/hardware-interfaces.git] / broadcastradio / 1.1 / utils / Utils.h
1 /*
2  * Copyright (C) 2017 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 #ifndef ANDROID_HARDWARE_BROADCASTRADIO_V1_1_UTILS_H
17 #define ANDROID_HARDWARE_BROADCASTRADIO_V1_1_UTILS_H
18
19 #include <android/hardware/broadcastradio/1.1/types.h>
20 #include <chrono>
21 #include <queue>
22 #include <thread>
23
24 namespace android {
25 namespace hardware {
26 namespace broadcastradio {
27 namespace V1_1 {
28 namespace implementation {
29 namespace utils {
30
31 /**
32  * Checks, if {@code pointer} tunes to {@channel}.
33  *
34  * For example, having a channel {AMFM_FREQUENCY = 103.3}:
35  * - selector {AMFM_FREQUENCY = 103.3, HD_SUBCHANNEL = 0} can tune to this channel;
36  * - selector {AMFM_FREQUENCY = 103.3, HD_SUBCHANNEL = 1} can't.
37  *
38  * @param pointer selector we're trying to match against channel.
39  * @param channel existing channel.
40  */
41 bool tunesTo(const ProgramSelector& pointer, const ProgramSelector& channel);
42
43 ProgramType getType(const ProgramSelector& sel);
44 bool isAmFm(const ProgramType type);
45
46 bool hasId(const ProgramSelector& sel, const IdentifierType type);
47
48 /**
49  * Returns ID (either primary or secondary) for a given program selector.
50  *
51  * If the selector does not contain given type, returns 0 and emits a warning.
52  */
53 uint64_t getId(const ProgramSelector& sel, const IdentifierType type);
54
55 /**
56  * Returns ID (either primary or secondary) for a given program selector.
57  *
58  * If the selector does not contain given type, returns default value.
59  */
60 uint64_t getId(const ProgramSelector& sel, const IdentifierType type, uint64_t defval);
61
62 ProgramSelector make_selector(V1_0::Band band, uint32_t channel, uint32_t subChannel = 0);
63
64 bool getLegacyChannel(const ProgramSelector& sel, uint32_t& channelOut, uint32_t& subChannelOut);
65
66 bool isDigital(const ProgramSelector& sel);
67
68 }  // namespace utils
69 }  // namespace implementation
70 }  // namespace V1_1
71 }  // namespace broadcastradio
72 }  // namespace hardware
73 }  // namespace android
74
75 #endif  // ANDROID_HARDWARE_BROADCASTRADIO_V1_1_UTILS_H