mirror of
https://github.com/h2zero/esp-nimble-cpp.git
synced 2024-12-18 09:10:47 +01:00
4980e6a10a
* General code cleanup. * `NimBLEAdvertisementData` moved to it's own .h and .cpp files. * Added new method, `NimBLEAdvertising::setPreferredParams` that takes the min and max preferred connection parameters as an alternative for `setMinPreferred` and `setMaxPreferred`. * Added new method, `NimBLEAdvertising::setAdvertisingInterval` Sets the advertisement interval for min and max to the same value instead of calling `setMinInterval` and `setMaxInterval` separately if there is not value difference. * `NimBLEAdvertisementData` payload is now stored in `std::vector<uint8_t>` instead of `std::string`. * `NimBLEAdvertisementData::getPayload` now returns `std::vector<uint8_t>` instead of `std::string`. * `NimBLEAdvertisementData::addData` now takes either a `std::vector<uint8_t>` or `uint8_t* + length` instead of `std::string` or `char + length`. * `NimBLEAdvertisementData::setName` now takes an optional `bool` parameter to indicate if the name is complete or incomplete, default = complete. * `NimBLEAdvertising::start` No longer takes a callback pointer parameter, instead the new method `NimBLEAdvertising::setAdvertisingCompleteCallback` should be used. * `NimBLEAdvertising::setAdvertisementType` has been renamed to `NimBLEAdvertising::setConnectableMode` to better reflect it's function. * `NimBLEAdvertising::setScanResponse` has been renamed to `NimBLEAdvertising::enableScanResponse` to better reflect it's function. * Scan response is no longer enabled by default. * Added new method, `NimBLEAdvertising::setDiscoverableMode` to allow applications to control the discoverability of the advertiser. * Advertising the name and TX power of the device will no longer happen by default and should be set manually by the application. * Added overload for `NimBLEAdvertising::setManufacturerData` that takes a `const uint8_t*` and , size_t` paramter. * Added overload for `NimBLEAdvertising::setServiceData` that takes `const NimBLEUUID& uuid`, ` const uint8_t* data`, ` size_t length` as parameters. * Added overload for `NimBLEAdvertising::setServiceData` that takes `const NimBLEUUID& uuid`, `const std::vector<uint8_t>&` as parameters. * All `NimBLEAdvertisementData` functions that change data values now return `bool`, true = success. * All `NimBLEAdvertising` functions that change data values now return `bool`, true = success. * `NimBLEAdvertising::setMinPreferred` and `NimBLEAdvertising::setMaxPreferred` have been removed, use `NimBLEAdvertising::setPreferredParams` instead. * All advertising data is now stored in instances of `NimBLEAdvertisingData` and vectors removed from `NimBLEAdvertising`. * `NimBLEAdvertising::setAdvertisementData` and `NimBLEAdvertising::setScanResponseData` now return `bool`, true = success. * Added new method, `NimBLEAdvertisementData::removeData`, which takes a parameter `uint8_t type`, the data type to remove. * Added new method, `NimBLEAdvertisementData::toString`, which will print the data in hex. * Added new method, `NimBLEAdvertising::getAdvertisementData`, which returns a reference to the currently set advertisement data. * Added new method, `NimBLEAdvertising::getScanData`, which returns a reference to the currently set scan response data. * Added overloads for `NimBLEAdvertising::removeServiceUUID` and `NimBLEAdvertisementData::removeServiceUUID` to accept a `const char*` * Added new method, `NimBLEAdvertising::clearData`, which will clear the advertisement and scan response data.
75 lines
1.9 KiB
CMake
75 lines
1.9 KiB
CMake
# The following lines of boilerplate have to be in your project's
|
|
# CMakeLists in this exact order for cmake to work correctly
|
|
cmake_minimum_required(VERSION 3.5)
|
|
|
|
if(__COMPONENT_TARGETS MATCHES "___idf_esp-nimble-component")
|
|
list(APPEND ESP_NIMBLE_PRIV_REQUIRES
|
|
esp-nimble-component
|
|
)
|
|
elseif(__COMPONENT_TARGETS MATCHES "__idf_nimble")
|
|
list(APPEND ESP_NIMBLE_PRIV_REQUIRES
|
|
nimble
|
|
)
|
|
endif()
|
|
|
|
# Arduino install using IDF component manager
|
|
if(__COMPONENT_TARGETS MATCHES "___idf_espressif__arduino-esp32")
|
|
list(APPEND ESP_NIMBLE_PRIV_REQUIRES
|
|
arduino-esp32
|
|
)
|
|
# Manual installation of Arduino framework
|
|
elseif(__COMPONENT_TARGETS MATCHES "__idf_arduino")
|
|
list(APPEND ESP_NIMBLE_PRIV_REQUIRES
|
|
arduino
|
|
)
|
|
# PlatformIO
|
|
elseif(__COMPONENT_TARGETS MATCHES "___idf_framework-arduinoespressif32")
|
|
list(APPEND ESP_NIMBLE_PRIV_REQUIRES
|
|
framework-arduinoespressif32
|
|
)
|
|
endif()
|
|
|
|
idf_component_register(
|
|
REQUIRED_IDF_TARGETS
|
|
"esp32"
|
|
"esp32s3"
|
|
"esp32c2"
|
|
"esp32c3"
|
|
"esp32c6"
|
|
"esp32h2"
|
|
"esp32p4"
|
|
INCLUDE_DIRS
|
|
"src"
|
|
SRCS
|
|
"src/NimBLE2904.cpp"
|
|
"src/NimBLEAddress.cpp"
|
|
"src/NimBLEAdvertisedDevice.cpp"
|
|
"src/NimBLEAdvertisementData.cpp"
|
|
"src/NimBLEAdvertising.cpp"
|
|
"src/NimBLEAttValue.cpp"
|
|
"src/NimBLEBeacon.cpp"
|
|
"src/NimBLECharacteristic.cpp"
|
|
"src/NimBLEClient.cpp"
|
|
"src/NimBLEDescriptor.cpp"
|
|
"src/NimBLEDevice.cpp"
|
|
"src/NimBLEEddystoneTLM.cpp"
|
|
"src/NimBLEEddystoneURL.cpp"
|
|
"src/NimBLEExtAdvertising.cpp"
|
|
"src/NimBLEHIDDevice.cpp"
|
|
"src/NimBLERemoteCharacteristic.cpp"
|
|
"src/NimBLERemoteDescriptor.cpp"
|
|
"src/NimBLERemoteService.cpp"
|
|
"src/NimBLERemoteValueAttribute.cpp"
|
|
"src/NimBLEScan.cpp"
|
|
"src/NimBLEServer.cpp"
|
|
"src/NimBLEService.cpp"
|
|
"src/NimBLEUtils.cpp"
|
|
"src/NimBLEUUID.cpp"
|
|
REQUIRES
|
|
bt
|
|
nvs_flash
|
|
driver
|
|
PRIV_REQUIRES
|
|
${ESP_NIMBLE_PRIV_REQUIRES}
|
|
)
|
|
|