/**@brief Command response callback function for @ref sd_ble_gap_connect BLE command. * * Callback for decoding the output parameters and the command response return code. * * @param[in] p_buffer Pointer to begin of command response buffer. * @param[in] length Length of data in bytes. * * @return Decoded command response return code. */ static uint32_t gap_connect_rsp_dec(const uint8_t * p_buffer, uint16_t length) { uint32_t result_code = 0; const uint32_t err_code = ble_gap_connect_rsp_dec(p_buffer, length, &result_code); //@note: Should never fail. APP_ERROR_CHECK(err_code); return result_code; }
uint32_t sd_ble_gap_connect(adapter_t *adapter, ble_gap_addr_t const *const p_addr, ble_gap_scan_params_t const *const p_scan_params, ble_gap_conn_params_t const *const p_conn_params, uint8_t conn_cfg_tag) { encode_function_t encode_function = [&](uint8_t *buffer, uint32_t *length) -> uint32_t { return ble_gap_connect_req_enc(p_addr, p_scan_params, p_conn_params, conn_cfg_tag, buffer, length); }; decode_function_t decode_function = [&](uint8_t *buffer, uint32_t length, uint32_t *result) -> uint32_t { return ble_gap_connect_rsp_dec(buffer, length, result); }; return gap_encode_decode(adapter, encode_function, decode_function); }