summaryrefslogtreecommitdiff
path: root/src/components/ble/ServiceDiscovery.h
diff options
context:
space:
mode:
authorJF002 <JF002@users.noreply.github.com>2020-10-30 14:16:04 +0100
committerGitHub <noreply@github.com>2020-10-30 14:16:04 +0100
commit0e97db1c30748d9893291a27504bb55723f58e7d (patch)
tree9b410aee92af82099619c56a4d25c9c6b7c99e68 /src/components/ble/ServiceDiscovery.h
parentcb9e8815d8bc6ce71fd8e97f3e3dae402658ce1f (diff)
parent29f8074fcb844cf9668a5bf071e9cffa47299c99 (diff)
Merge pull request #118 from JF002/improve-ble-connection
Improve ble connection
Diffstat (limited to 'src/components/ble/ServiceDiscovery.h')
-rw-r--r--src/components/ble/ServiceDiscovery.h24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/components/ble/ServiceDiscovery.h b/src/components/ble/ServiceDiscovery.h
new file mode 100644
index 00000000..c86fc4ec
--- /dev/null
+++ b/src/components/ble/ServiceDiscovery.h
@@ -0,0 +1,24 @@
+#pragma once
+
+#include <array>
+#include <functional>
+#include <memory>
+#include "BleClient.h"
+
+namespace Pinetime {
+ namespace Controllers {
+ class ServiceDiscovery {
+ public:
+ ServiceDiscovery(std::array<BleClient*, 2>&& bleClients);
+
+ void StartDiscovery(uint16_t connectionHandle);
+
+
+ private:
+ BleClient** clientIterator;
+ std::array<BleClient*, 2> clients;
+ void OnServiceDiscovered(uint16_t connectionHandle);
+ void DiscoverNextService(uint16_t connectionHandle);
+ };
+ }
+}