aboutsummaryrefslogtreecommitdiffstats
path: root/api/direct_bt
diff options
context:
space:
mode:
authorSven Gothel <[email protected]>2021-09-18 18:36:22 +0200
committerSven Gothel <[email protected]>2021-09-18 18:36:22 +0200
commitbbaa9e5c5d2314440af042b1a515c982c8ca0f00 (patch)
treebfc0e3e3f53b1878f239b1669b8119977092b0cd /api/direct_bt
parent7b65703688949672815ad2deb43816e837329505 (diff)
Align Java/C++ findGatt[Service,Char](..) in BTDevice and BTGattService, remove obsolete entries in Java (w/ timeout parameter)
Diffstat (limited to 'api/direct_bt')
-rw-r--r--api/direct_bt/BTDevice.hpp31
-rw-r--r--api/direct_bt/BTGattService.hpp8
2 files changed, 32 insertions, 7 deletions
diff --git a/api/direct_bt/BTDevice.hpp b/api/direct_bt/BTDevice.hpp
index eecf0c1d..5a7a5f14 100644
--- a/api/direct_bt/BTDevice.hpp
+++ b/api/direct_bt/BTDevice.hpp
@@ -892,20 +892,37 @@ namespace direct_bt {
* </p>
* <p>
* If this method has been called for the first time or no services has been detected yet,
- * a list of GATTService will be discovered.
+ * a list of GATTService will be retrieved.
* <br>
- * In case no GATT connection has been established it will be created via connectGATT().
+ * A GATT connection will be created via connectGATT() if not established yet.
* </p>
*/
jau::darray<std::shared_ptr<BTGattService>> getGattServices() noexcept;
/**
- * Returns the matching GATTService for the given uuid.
- * <p>
- * Implementation calls getGattService().
- * </p>
+ * Find a BTGattService by its service_uuid.
+ *
+ * It will check objects for a connected device and caches them, using getGattService().
+ *
+ * It will not turn on discovery or connect to devices.
+ *
+ * @parameter service_uuid the jau::uuid_t of the desired BTGattService
+ * @return The matching service or null if not found
+ */
+ std::shared_ptr<BTGattService> findGattService(const jau::uuid_t& service_uuid) noexcept;
+
+ /**
+ * Find a BTGattChar by its service_uuid and char_uuid.
+ *
+ * It will check objects for a connected device and caches them, using getGattService().
+ *
+ * It will not turn on discovery or connect to devices.
+ *
+ * @parameter service_uuid the jau::uuid_t of the intermediate BTGattService
+ * @parameter char_uuid the jau::uuid_t of the desired BTGattChar, within the intermediate BTGattService.
+ * @return The matching characteristic or null if not found
*/
- std::shared_ptr<BTGattService> findGattService(const jau::uuid_t& uuid);
+ std::shared_ptr<BTGattChar> findGattChar(const jau::uuid_t& service_uuid, const jau::uuid_t& char_uuid) noexcept;
/** Returns the shared GenericAccess instance, retrieved by {@link #getGattService()} or nullptr if not available. */
std::shared_ptr<GattGenericAccessSvc> getGattGenericAccess();
diff --git a/api/direct_bt/BTGattService.hpp b/api/direct_bt/BTGattService.hpp
index 17dcef51..0c027813 100644
--- a/api/direct_bt/BTGattService.hpp
+++ b/api/direct_bt/BTGattService.hpp
@@ -115,6 +115,14 @@ namespace direct_bt {
std::shared_ptr<BTDevice> getDeviceUnchecked() const noexcept;
std::shared_ptr<BTDevice> getDeviceChecked() const;
+ /**
+ * Find a BTGattChar by its char_uuid.
+ *
+ * @parameter char_uuid the jau::uuid_t of the desired BTGattChar, within this BTGattService.
+ * @return The matching characteristic or null if not found
+ */
+ std::shared_ptr<BTGattChar> findGattChar(const jau::uuid_t& char_uuid) noexcept;
+
std::string toString() const noexcept override;
};