1 // 2 // Copyright 2016 Google, Inc. 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 17 #pragma once 18 19 #include "android/bluetooth/bluetooth_gatt_included_service.h" 20 #include "bluetooth/service.h" 21 22 #include <binder/Parcel.h> 23 #include <binder/Parcelable.h> 24 25 using android::Parcel; 26 using android::Parcelable; 27 using android::status_t; 28 29 namespace android { 30 namespace bluetooth { 31 32 class BluetoothGattService : public Parcelable, public ::bluetooth::Service { 33 public: 34 BluetoothGattService() = default; BluetoothGattService(const::bluetooth::Service & service)35 BluetoothGattService(const ::bluetooth::Service& service) 36 : ::bluetooth::Service(service){}; // NOLINT(implicit) BluetoothGattService(const BluetoothGattIncludedService & includedService)37 BluetoothGattService( 38 const BluetoothGattIncludedService& includedService) // NOLINT(implicit) 39 : ::bluetooth::Service(includedService.handle(), 40 includedService.primary(), includedService.uuid(), 41 {}, {}){}; 42 ~BluetoothGattService() = default; 43 44 // Write |this| parcelable to the given |parcel|. Keep in mind that 45 // implementations of writeToParcel must be manually kept in sync 46 // with readFromParcel and the Java equivalent versions of these methods. 47 // 48 // Returns android::OK on success and an appropriate error otherwise. 49 status_t writeToParcel(Parcel* parcel) const override; 50 51 // Read data from the given |parcel| into |this|. After readFromParcel 52 // completes, |this| should have equivalent state to the object that 53 // wrote itself to the parcel. 54 // 55 // Returns android::OK on success and an appropriate error otherwise. 56 status_t readFromParcel(const Parcel* parcel) override; 57 }; 58 } // namespace bluetooth 59 } // namespace android 60