Commit d1396084 authored by Qt Forward Merge Bot's avatar Qt Forward Merge Bot
Browse files

Merge remote-tracking branch 'origin/5.13' into dev

Change-Id: Iad2cfc593f6a9d3b554a2d4f7c16d6173071f7c8
Showing with 626 additions and 226 deletions
Qt 5.13 introduces many new features and improvements as well as bugfixes
over the 5.12.x series. For more details, refer to the online documentation
included in this distribution. The documentation is also available online:
https://doc.qt.io/qt-5/index.html
The Qt version 5.13 series is binary compatible with the 5.12.x series.
Applications compiled for 5.12 will continue to run with 5.13.
Some of the changes listed in this file include issue tracking numbers
corresponding to tasks in the Qt Bug Tracker:
https://bugreports.qt.io/
Each of these identifiers can be entered in the bug tracker to obtain more
information about a particular change.
****************************************************************************
* Qt 5.13.0 Changes *
****************************************************************************
QtBluetooth
-----------
- [QTBUG-58660] Added ability to connect to BLE devices on WinRT without
pairing.
- [QTBUG-69954] Fixed potential crash due to late callbacks on WinRT.
- Improved WinRT implementation signficantly. This incorporates a large
number of patches (each improving the stability and general robustness of
the code base). During the process the number of potential asserts was
reduced as well.
- Deprecated QBluetoothDeviceInfo::DataCompleteness related APIs.
- Replaced QBluetoothDeviceInfo::LanAccessDevice with QBluetoothDeviceInfo::NetworkDevice.
LanAccessDevice was deprecated.
- Implemented support for QBluetoothDeviceDiscoveryAgent::deviceUpdated() on Apple and WinRT
platforms.
- [QTBUG-71943] Implemented RSSI and manufacturer data discovery on WinRT.
- [QTBUG-74394] Fixed broken QLowEnergyController::disconnectFromDevice() on WinRT.
- Added a compile fix for g++ 8.
- [QTBUG-73717] Fixed warnings in QDeclarativeBluetoothDiscoveryModel.
QtNfc
-----
- QNearFieldManager:
* adapterStateChanged() now has a fully qualified parameter
QNearFieldManager::AdapterState. This can cause a problem if the
connection/method invocation was done with just AdapterState as the
parameter type, in which case these need to be changed to use
QNearFieldManager::AdapaterState instead.
......@@ -211,7 +211,7 @@ qtConfig(bluez) {
SOURCES += \
qbluetoothdevicediscoveryagent_winrt.cpp \
qbluetoothlocaldevice_p.cpp \
qbluetoothlocaldevice_winrt.cpp \
qbluetoothserver_winrt.cpp \
qbluetoothservicediscoveryagent_winrt.cpp \
qbluetoothserviceinfo_winrt.cpp \
......
......@@ -51,7 +51,7 @@ QBluetoothLocalDevice::QBluetoothLocalDevice(QObject *parent) :
QObject(parent),
d_ptr(new QBluetoothLocalDevicePrivate(this, QBluetoothAddress()))
{
#if !defined(QT_IOS_BLUETOOTH) && !defined(QT_WINRT_BLUETOOTH)
#if !defined(QT_IOS_BLUETOOTH)
printDummyWarning();
#endif
registerQBluetoothLocalDeviceMetaType();
......@@ -85,11 +85,7 @@ void QBluetoothLocalDevice::setHostMode(QBluetoothLocalDevice::HostMode mode)
QBluetoothLocalDevice::HostMode QBluetoothLocalDevice::hostMode() const
{
#ifdef QT_WINRT_BLUETOOTH
return HostConnectable;
#else
return HostPoweredOff;
#endif
}
QList<QBluetoothAddress> QBluetoothLocalDevice::connectedDevices() const
......@@ -116,11 +112,7 @@ QBluetoothLocalDevice::Pairing QBluetoothLocalDevice::pairingStatus(
const QBluetoothAddress &address) const
{
Q_UNUSED(address);
#ifdef QT_WINRT_BLUETOOTH
return Paired;
#else
return Unpaired;
#endif
}
void QBluetoothLocalDevice::pairingConfirmation(bool confirmation)
......
......@@ -84,6 +84,21 @@ QT_END_NAMESPACE
#include <QtCore/QPair>
#endif
#ifdef QT_WINRT_BLUETOOTH
#include <wrl.h>
namespace ABI {
namespace Windows {
namespace Devices {
namespace Bluetooth {
struct IBluetoothDeviceStatics;
struct IBluetoothLEDeviceStatics;
}
}
}
}
#endif
QT_BEGIN_NAMESPACE
extern void registerQBluetoothLocalDeviceMetaType();
......@@ -208,7 +223,22 @@ private:
void initializeAdapter();
void initializeAdapterBluez5();
};
#elif !defined(QT_OSX_BLUETOOTH) // winrt and dummy backend
#elif defined(QT_WINRT_BLUETOOTH)
class QBluetoothLocalDevicePrivate : public QObject
{
Q_DECLARE_PUBLIC(QBluetoothLocalDevice)
public:
QBluetoothLocalDevicePrivate(QBluetoothLocalDevice *q,
QBluetoothAddress = QBluetoothAddress());
bool isValid() const;
private:
QBluetoothLocalDevice *q_ptr;
Microsoft::WRL::ComPtr<ABI::Windows::Devices::Bluetooth::IBluetoothDeviceStatics> mStatics;
Microsoft::WRL::ComPtr<ABI::Windows::Devices::Bluetooth::IBluetoothLEDeviceStatics> mLEStatics;
};
#elif !defined(QT_OSX_BLUETOOTH) // dummy backend
class QBluetoothLocalDevicePrivate : public QObject
{
public:
......@@ -219,11 +249,7 @@ public:
bool isValid() const
{
#ifndef QT_WINRT_BLUETOOTH
return false;
#else
return true;
#endif
}
};
#endif
......
/****************************************************************************
**
** Copyright (C) 2019 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of the QtBluetooth module of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:LGPL$
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 3 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL3 included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 3 requirements
** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 2.0 or (at your option) the GNU General
** Public license version 3 or any later version approved by the KDE Free
** Qt Foundation. The licenses are as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-2.0.html and
** https://www.gnu.org/licenses/gpl-3.0.html.
**
** $QT_END_LICENSE$
**
****************************************************************************/
#include "qbluetoothlocaldevice.h"
#include "qbluetoothaddress.h"
#include "qbluetoothlocaldevice_p.h"
#ifdef CLASSIC_APP_BUILD
#define Q_OS_WINRT
#endif
#include <QtCore/qfunctions_winrt.h>
#include <robuffer.h>
#include <windows.devices.bluetooth.h>
#include <wrl.h>
using namespace ABI::Windows::Foundation;
using namespace ABI::Windows::Devices::Bluetooth;
using namespace ABI::Windows::Devices::Enumeration;
using namespace Microsoft::WRL;
using namespace Microsoft::WRL::Wrappers;
QT_BEGIN_NAMESPACE
template <class DeviceStatics, class OpResult, class Device, class Device2>
ComPtr<IDeviceInformationPairing> getPairingInfo(ComPtr<DeviceStatics> deviceStatics,
const QBluetoothAddress &address)
{
ComPtr<IAsyncOperation<OpResult *>> op;
if (!deviceStatics)
return nullptr;
HRESULT hr = deviceStatics->FromBluetoothAddressAsync(address.toUInt64(), &op);
RETURN_IF_FAILED("Could not obtain device from address", return nullptr);
ComPtr<Device> device;
hr = QWinRTFunctions::await(op, device.GetAddressOf(),
QWinRTFunctions::ProcessMainThreadEvents, 5000);
if (FAILED(hr) || !device) {
qErrnoWarning("Could not obtain device from address");
return nullptr;
}
ComPtr<Device2> device2;
hr = device.As(&device2);
RETURN_IF_FAILED("Could not cast device", return nullptr);
ComPtr<IDeviceInformation> deviceInfo;
hr = device2->get_DeviceInformation(&deviceInfo);
if (FAILED(hr) || !deviceInfo) {
qErrnoWarning("Could not obtain device information");
return nullptr;
}
ComPtr<IDeviceInformation2> deviceInfo2;
hr = deviceInfo.As(&deviceInfo2);
RETURN_IF_FAILED("Could not cast device information", return nullptr);
ComPtr<IDeviceInformationPairing> pairingInfo;
hr = deviceInfo2->get_Pairing(&pairingInfo);
RETURN_IF_FAILED("Could not obtain pairing information", return nullptr);
return pairingInfo;
}
QBluetoothLocalDevice::QBluetoothLocalDevice(QObject *parent) :
QObject(parent),
d_ptr(new QBluetoothLocalDevicePrivate(this, QBluetoothAddress()))
{
registerQBluetoothLocalDeviceMetaType();
}
QBluetoothLocalDevice::QBluetoothLocalDevice(const QBluetoothAddress &address, QObject *parent) :
QObject(parent),
d_ptr(new QBluetoothLocalDevicePrivate(this, address))
{
registerQBluetoothLocalDeviceMetaType();
}
QBluetoothLocalDevicePrivate::QBluetoothLocalDevicePrivate(QBluetoothLocalDevice *q, QBluetoothAddress)
: q_ptr(q)
{
GetActivationFactory(HString::MakeReference(RuntimeClass_Windows_Devices_Bluetooth_BluetoothLEDevice).Get(), &mLEStatics);
GetActivationFactory(HString::MakeReference(RuntimeClass_Windows_Devices_Bluetooth_BluetoothDevice).Get(), &mStatics);
}
bool QBluetoothLocalDevicePrivate::isValid() const
{
return (mStatics != nullptr && mLEStatics != nullptr);
}
void QBluetoothLocalDevice::requestPairing(const QBluetoothAddress &address, Pairing pairing)
{
Q_UNUSED(address);
Q_UNUSED(pairing);
QMetaObject::invokeMethod(this, "error", Qt::QueuedConnection,
Q_ARG(QBluetoothLocalDevice::Error,
QBluetoothLocalDevice::PairingError));
}
QBluetoothLocalDevice::Pairing QBluetoothLocalDevice::pairingStatus(
const QBluetoothAddress &address) const
{
if (!isValid() || address.isNull())
return QBluetoothLocalDevice::Unpaired;
ComPtr<IDeviceInformationPairing> pairingInfo = getPairingInfo<IBluetoothLEDeviceStatics,
BluetoothLEDevice, IBluetoothLEDevice, IBluetoothLEDevice2>(d_ptr->mLEStatics, address);
if (!pairingInfo)
pairingInfo = getPairingInfo<IBluetoothDeviceStatics, BluetoothDevice,
IBluetoothDevice, IBluetoothDevice2>(d_ptr->mStatics, address);
if (!pairingInfo)
return QBluetoothLocalDevice::Unpaired;
boolean isPaired;
HRESULT hr = pairingInfo->get_IsPaired(&isPaired);
RETURN_IF_FAILED("Could not obtain device pairing", return QBluetoothLocalDevice::Unpaired);
if (!isPaired)
return QBluetoothLocalDevice::Unpaired;
ComPtr<IDeviceInformationPairing2> pairingInfo2;
hr = pairingInfo.As(&pairingInfo2);
RETURN_IF_FAILED("Could not cast pairing info", return QBluetoothLocalDevice::Paired);
DevicePairingProtectionLevel protection = DevicePairingProtectionLevel_None;
hr = pairingInfo2->get_ProtectionLevel(&protection);
RETURN_IF_FAILED("Could not obtain pairing protection level", return QBluetoothLocalDevice::Paired);
if (protection == DevicePairingProtectionLevel_Encryption
|| protection == DevicePairingProtectionLevel_EncryptionAndAuthentication)
return QBluetoothLocalDevice::AuthorizedPaired;
return QBluetoothLocalDevice::Paired;
}
void QBluetoothLocalDevice::pairingConfirmation(bool confirmation)
{
Q_UNUSED(confirmation);
}
void QBluetoothLocalDevice::setHostMode(QBluetoothLocalDevice::HostMode mode)
{
Q_UNUSED(mode);
}
QBluetoothLocalDevice::HostMode QBluetoothLocalDevice::hostMode() const
{
return HostConnectable;
}
QList<QBluetoothAddress> QBluetoothLocalDevice::connectedDevices() const
{
return QList<QBluetoothAddress>();
}
void QBluetoothLocalDevice::powerOn()
{
}
QString QBluetoothLocalDevice::name() const
{
return QString();
}
QBluetoothAddress QBluetoothLocalDevice::address() const
{
return QBluetoothAddress();
}
QList<QBluetoothHostInfo> QBluetoothLocalDevice::allDevices()
{
QList<QBluetoothHostInfo> localDevices;
return localDevices;
}
QT_END_NAMESPACE
This diff is collapsed.
......@@ -60,8 +60,28 @@
#include "qlowenergycontroller.h"
#include "qlowenergycontrollerbase_p.h"
namespace ABI {
namespace Windows {
namespace Devices {
namespace Bluetooth {
namespace GenericAttributeProfile {
class GattDeviceServicesResult;
struct IGattCharacteristic;
struct IGattDeviceService;
struct IGattValueChangedEventArgs;
}
struct IBluetoothLEDevice;
}
}
namespace Foundation {
template <typename T> struct IAsyncOperation;
enum class AsyncStatus;
}
}
}
#include <wrl.h>
#include <windows.devices.bluetooth.h>
#include <functional>
......@@ -77,7 +97,6 @@ QLowEnergyControllerPrivate *createWinRTLowEnergyController();
class QLowEnergyControllerPrivateWinRTNew final : public QLowEnergyControllerPrivate
{
Q_OBJECT
public:
QLowEnergyControllerPrivateWinRTNew();
~QLowEnergyControllerPrivateWinRTNew() override;
......@@ -121,6 +140,10 @@ private slots:
void handleServiceHandlerError(const QString &error);
private:
void connectToPairedDevice();
void connectToUnpairedDevice();
bool mAbortPending = false;
Microsoft::WRL::ComPtr<ABI::Windows::Devices::Bluetooth::IBluetoothLEDevice> mDevice;
EventRegistrationToken mStatusChangedToken;
struct ValueChangedEntry {
......@@ -142,12 +165,17 @@ private:
void registerForValueChanges(const QBluetoothUuid &serviceUuid, const QBluetoothUuid &charUuid);
void unregisterFromValueChanges();
HRESULT onValueChange(ABI::Windows::Devices::Bluetooth::GenericAttributeProfile::IGattCharacteristic *characteristic,
ABI::Windows::Devices::Bluetooth::GenericAttributeProfile::IGattValueChangedEventArgs *args);
bool registerForStatusChanges();
void unregisterFromStatusChanges();
HRESULT onStatusChange(ABI::Windows::Devices::Bluetooth::IBluetoothLEDevice *dev, IInspectable *);
void obtainIncludedServices(QSharedPointer<QLowEnergyServicePrivate> servicePointer,
Microsoft::WRL::ComPtr<ABI::Windows::Devices::Bluetooth::GenericAttributeProfile::IGattDeviceService> nativeService);
HRESULT onServiceDiscoveryFinished(ABI::Windows::Foundation::IAsyncOperation<ABI::Windows::Devices::Bluetooth::GenericAttributeProfile::GattDeviceServicesResult *> *op,
ABI::Windows::Foundation::AsyncStatus status);
};
QT_END_NAMESPACE
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment