summaryrefslogtreecommitdiff
path: root/system/service/common/android/bluetooth/bluetooth_gatt_included_service.h
blob: b01153294e65136a171bd75139886c82b66f233f (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
56
57
58
59
60
61
62
63
64
65
66
67
//
//  Copyright 2016 Google, Inc.
//
//  Licensed under the Apache License, Version 2.0 (the "License");
//  you may not use this file except in compliance with the License.
//  You may obtain a copy of the License at:
//
//  http://www.apache.org/licenses/LICENSE-2.0
//
//  Unless required by applicable law or agreed to in writing, software
//  distributed under the License is distributed on an "AS IS" BASIS,
//  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
//  See the License for the specific language governing permissions and
//  limitations under the License.
//

#pragma once

#include "bluetooth/service.h"

#include <binder/Parcel.h>
#include <binder/Parcelable.h>

using android::Parcel;
using android::Parcelable;
using android::status_t;

using ::bluetooth::Uuid;

namespace android {
namespace bluetooth {

class BluetoothGattIncludedService : public Parcelable {
 public:
  BluetoothGattIncludedService() = default;
  BluetoothGattIncludedService(
      const ::bluetooth::Service& service)  // NOLINT(implicit)
      : handle_(service.handle()),
        uuid_(service.uuid()),
        primary_(service.primary()){};
  ~BluetoothGattIncludedService() = default;

  // Write |this| parcelable to the given |parcel|.  Keep in mind that
  // implementations of writeToParcel must be manually kept in sync
  // with readFromParcel and the Java equivalent versions of these methods.
  //
  // Returns android::OK on success and an appropriate error otherwise.
  status_t writeToParcel(Parcel* parcel) const override;

  // Read data from the given |parcel| into |this|.  After readFromParcel
  // completes, |this| should have equivalent state to the object that
  // wrote itself to the parcel.
  //
  // Returns android::OK on success and an appropriate error otherwise.
  status_t readFromParcel(const Parcel* parcel) override;

  uint16_t handle() const { return handle_; }
  bool primary() const { return primary_; }
  Uuid uuid() const { return uuid_; }

 protected:
  uint16_t handle_;
  Uuid uuid_;
  bool primary_;
};
}  // namespace bluetooth
}  // namespace android