From c95ccaf9672db82c04f21d97b4b52eef16bfe4f2 Mon Sep 17 00:00:00 2001 From: Tadej Novak Date: Sun, 5 May 2024 18:28:44 +0200 Subject: [PATCH 1/3] Make MapLibre QML module namespace independent of QtLocation --- examples/quick/main.qml | 4 +- src/location/macros.cmake | 4 +- src/location/plugins/CMakeLists.txt | 40 +++++++++---------- src/location/plugins/legacy/qml_module.cpp | 10 ++--- .../plugins/legacy/qml_registration.cpp | 20 +++++----- src/location/plugins/legacy/qmldir.in | 6 +-- src/location/plugins/qmldir.in | 6 +-- test/qml/qt5/tst_map.qml | 5 ++- test/qml/qt5/tst_style_parameters.qml | 9 +++-- test/qml/qt6/tst_map.qml | 5 ++- test/qml/qt6/tst_style_parameters.qml | 9 +++-- 11 files changed, 61 insertions(+), 57 deletions(-) diff --git a/examples/quick/main.qml b/examples/quick/main.qml index 09765ce..51ee792 100644 --- a/examples/quick/main.qml +++ b/examples/quick/main.qml @@ -1,4 +1,4 @@ -// Copyright (C) 2023 MapLibre contributors +// Copyright (C) 2024 MapLibre contributors // SPDX-License-Identifier: MIT @@ -7,7 +7,7 @@ import QtQuick.Window 6.5 import QtLocation 6.5 import QtPositioning 6.5 -import QtLocation.MapLibre 3.0 +import MapLibre 3.0 Window { id: window diff --git a/src/location/macros.cmake b/src/location/macros.cmake index 47f171b..aecdb29 100644 --- a/src/location/macros.cmake +++ b/src/location/macros.cmake @@ -15,12 +15,12 @@ function(qmaplibre_location_setup_plugins target) get_target_property(_ImportedLocationQml QMapLibre::PluginQml IMPORTED_LOCATION_${_Configuration}) get_filename_component(_ImportedLocationPathQml ${_ImportedLocationQml} DIRECTORY) get_filename_component(_ImportedLocationPathQml ${_ImportedLocationPathQml} DIRECTORY) - get_filename_component(_ImportedLocationPathQml ${_ImportedLocationPathQml} DIRECTORY) get_property(_targetName TARGET ${target} PROPERTY OUTPUT_NAME) if(NOT _targetName) set(_targetName ${target}) endif() + get_property(_targetDestination TARGET ${target} PROPERTY RUNTIME_OUTPUT_DIRECTORY) get_target_property(_targetTypeCore QMapLibre::Core TYPE) if(_targetTypeCore STREQUAL STATIC_LIBRARY) @@ -46,7 +46,7 @@ function(qmaplibre_location_setup_plugins target) if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin") file( COPY "${_ImportedLocationGeoServices}" - DESTINATION "${_targetName}.app/Contents/PlugIns/geoservices" + DESTINATION "${_targetDestination}/${_targetName}.app/Contents/PlugIns/geoservices" ) elseif(${CMAKE_SYSTEM_NAME} MATCHES "Windows") install( diff --git a/src/location/plugins/CMakeLists.txt b/src/location/plugins/CMakeLists.txt index eed36f8..fd84b20 100644 --- a/src/location/plugins/CMakeLists.txt +++ b/src/location/plugins/CMakeLists.txt @@ -99,28 +99,28 @@ if(COMMAND qt_add_qml_module) qt_add_qml_module( ${MLN_QT_QML_PLUGIN} STATIC - URI QtLocation.MapLibre + URI MapLibre VERSION ${PROJECT_VERSION} PLUGIN_TARGET ${MLN_QT_QML_PLUGIN} NO_PLUGIN_OPTIONAL NO_GENERATE_QMLDIR - CLASS_NAME QtLocationMapLibreQmlModule + CLASS_NAME MapLibreQmlModule RESOURCE_PREFIX "/" - OUTPUT_DIRECTORY "QtLocation/MapLibre" + OUTPUT_DIRECTORY "MapLibre" OUTPUT_TARGETS QmlPluginOutputTargets SOURCES ${Plugin_Sources} ) else() qt_add_qml_module( ${MLN_QT_QML_PLUGIN} - URI QtLocation.MapLibre + URI MapLibre VERSION ${PROJECT_VERSION} PLUGIN_TARGET ${MLN_QT_QML_PLUGIN} NO_PLUGIN_OPTIONAL NO_GENERATE_QMLDIR - CLASS_NAME QtLocationMapLibreQmlModule + CLASS_NAME MapLibreQmlModule RESOURCE_PREFIX "/" - OUTPUT_DIRECTORY "QtLocation/MapLibre" + OUTPUT_DIRECTORY "MapLibre" OUTPUT_TARGETS QmlPluginOutputTargets SOURCES ${Plugin_Sources} ) @@ -128,12 +128,12 @@ if(COMMAND qt_add_qml_module) set_target_properties( ${MLN_QT_QML_PLUGIN} PROPERTIES - LIBRARY_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre> - RUNTIME_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre> + LIBRARY_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/MapLibre> + RUNTIME_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/MapLibre> ) configure_file( "${CMAKE_CURRENT_SOURCE_DIR}/qmldir.in" - "${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre/qmldir" + "${CMAKE_CURRENT_BINARY_DIR}/MapLibre/qmldir" @ONLY ) else() @@ -168,12 +168,12 @@ else() ${MLN_QT_QML_PLUGIN} PROPERTIES AUTOMOC ON - LIBRARY_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre> - RUNTIME_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre> + LIBRARY_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/MapLibre> + RUNTIME_OUTPUT_DIRECTORY $<1:${CMAKE_CURRENT_BINARY_DIR}/MapLibre> ) configure_file( "${CMAKE_CURRENT_SOURCE_DIR}/legacy/qmldir.in" - "${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre/qmldir" + "${CMAKE_CURRENT_BINARY_DIR}/MapLibre/qmldir" @ONLY ) endif() @@ -212,21 +212,21 @@ install( install( TARGETS ${MLN_QT_QML_PLUGIN} ${QmlPluginOutputTargets} EXPORT ${MLN_QT_NAME}LocationPluginQmlTargets - ARCHIVE DESTINATION "qml/QtLocation/MapLibre" - LIBRARY DESTINATION "qml/QtLocation/MapLibre" - OBJECTS DESTINATION "qml/QtLocation/MapLibre" - RUNTIME DESTINATION "qml/QtLocation/MapLibre" + ARCHIVE DESTINATION "qml/MapLibre" + LIBRARY DESTINATION "qml/MapLibre" + OBJECTS DESTINATION "qml/MapLibre" + RUNTIME DESTINATION "qml/MapLibre" ) install( FILES - "${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre/qmldir" - DESTINATION "qml/QtLocation/MapLibre" + "${CMAKE_CURRENT_BINARY_DIR}/MapLibre/qmldir" + DESTINATION "qml/MapLibre" ) if(COMMAND qt_add_qml_module) install( FILES - "${CMAKE_CURRENT_BINARY_DIR}/QtLocation/MapLibre/${MLN_QT_QML_PLUGIN}.qmltypes" - DESTINATION "qml/QtLocation/MapLibre" + "${CMAKE_CURRENT_BINARY_DIR}/MapLibre/${MLN_QT_QML_PLUGIN}.qmltypes" + DESTINATION "qml/MapLibre" ) endif() diff --git a/src/location/plugins/legacy/qml_module.cpp b/src/location/plugins/legacy/qml_module.cpp index 91d60c9..dcc5b25 100644 --- a/src/location/plugins/legacy/qml_module.cpp +++ b/src/location/plugins/legacy/qml_module.cpp @@ -1,19 +1,19 @@ -// Copyright (C) 2023 MapLibre contributors +// Copyright (C) 2024 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause #include -extern void qml_register_types_QtLocation_MapLibre(); +extern void qml_register_types_MapLibre(); -class QtLocationMapLibreQmlModule : public QQmlEngineExtensionPlugin { +class MapLibreQmlModule : public QQmlEngineExtensionPlugin { Q_OBJECT Q_PLUGIN_METADATA(IID QQmlEngineExtensionInterface_iid) public: - QtLocationMapLibreQmlModule(QObject *parent = nullptr) + MapLibreQmlModule(QObject *parent = nullptr) : QQmlEngineExtensionPlugin(parent) { - volatile auto registration = &qml_register_types_QtLocation_MapLibre; + volatile auto registration = &qml_register_types_MapLibre; Q_UNUSED(registration) } }; diff --git a/src/location/plugins/legacy/qml_registration.cpp b/src/location/plugins/legacy/qml_registration.cpp index 28fceca..3a496a6 100644 --- a/src/location/plugins/legacy/qml_registration.cpp +++ b/src/location/plugins/legacy/qml_registration.cpp @@ -1,4 +1,4 @@ -// Copyright (C) 2023 MapLibre contributors +// Copyright (C) 2024 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause @@ -15,14 +15,14 @@ #else #define Q_QMLTYPE_EXPORT #endif -Q_QMLTYPE_EXPORT void qml_register_types_QtLocation_MapLibre() { - qmlRegisterTypesAndRevisions("QtLocation.MapLibre", 3); - qmlRegisterTypesAndRevisions("QtLocation.MapLibre", 3); - qmlRegisterTypesAndRevisions("QtLocation.MapLibre", 3); - qmlRegisterTypesAndRevisions("QtLocation.MapLibre", 3); - qmlRegisterTypesAndRevisions("QtLocation.MapLibre", 3); - qmlRegisterAnonymousType("QtLocation.MapLibre", 3); - qmlRegisterModule("QtLocation.MapLibre", 3, 0); +Q_QMLTYPE_EXPORT void qml_register_types_MapLibre() { + qmlRegisterTypesAndRevisions("MapLibre", 3); + qmlRegisterTypesAndRevisions("MapLibre", 3); + qmlRegisterTypesAndRevisions("MapLibre", 3); + qmlRegisterTypesAndRevisions("MapLibre", 3); + qmlRegisterTypesAndRevisions("MapLibre", 3); + qmlRegisterAnonymousType("MapLibre", 3); + qmlRegisterModule("MapLibre", 3, 0); } -static const QQmlModuleRegistration registration("QtLocation.MapLibre", 3, qml_register_types_QtLocation_MapLibre); +static const QQmlModuleRegistration registration("MapLibre", 3, qml_register_types_MapLibre); diff --git a/src/location/plugins/legacy/qmldir.in b/src/location/plugins/legacy/qmldir.in index 2e8d995..7f62275 100644 --- a/src/location/plugins/legacy/qmldir.in +++ b/src/location/plugins/legacy/qmldir.in @@ -1,5 +1,5 @@ -module QtLocation.MapLibre +module MapLibre linktarget @MLN_QT_QML_PLUGIN@ plugin @MLN_QT_QML_PLUGIN@ -classname QtLocationMapLibreQmlModule -prefer :/QtLocation/MapLibre/ +classname MapLibreQmlModule +prefer :/MapLibre/ diff --git a/src/location/plugins/qmldir.in b/src/location/plugins/qmldir.in index 1a4308a..954947e 100644 --- a/src/location/plugins/qmldir.in +++ b/src/location/plugins/qmldir.in @@ -1,6 +1,6 @@ -module QtLocation.MapLibre +module MapLibre linktarget QMapLibre::PluginQml plugin @MLN_QT_QML_PLUGIN@ -classname QtLocationMapLibreQmlModule +classname MapLibreQmlModule typeinfo @MLN_QT_QML_PLUGIN@.qmltypes -prefer :/QtLocation/MapLibre/ +prefer :/MapLibre/ diff --git a/test/qml/qt5/tst_map.qml b/test/qml/qt5/tst_map.qml index dba2542..6be44d7 100644 --- a/test/qml/qt5/tst_map.qml +++ b/test/qml/qt5/tst_map.qml @@ -1,12 +1,13 @@ -// Copyright (C) 2023 MapLibre contributors +// Copyright (C) 2024 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15 import QtLocation 5.15 -import QtLocation.MapLibre 3.0 import QtPositioning 5.15 +import MapLibre 3.0 + import QtTest 1.0 Rectangle { diff --git a/test/qml/qt5/tst_style_parameters.qml b/test/qml/qt5/tst_style_parameters.qml index d1a24fe..c113123 100644 --- a/test/qml/qt5/tst_style_parameters.qml +++ b/test/qml/qt5/tst_style_parameters.qml @@ -1,12 +1,13 @@ -// Copyright (C) 2023 MapLibre contributors +// Copyright (C) 2024 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15 import QtLocation 5.15 -import QtLocation.MapLibre 3.0 import QtPositioning 5.15 +import MapLibre 3.0 + import QtTest 1.0 Item { @@ -119,7 +120,7 @@ Item { let url = "https://s2maps-tiles.eu/wms?service=wms&bbox={bbox-epsg-3857}&format=image/png&service=WMS&version=1.1.1&request=GetMap&srs=EPSG:900913&width=256&height=256&layers=s2cloudless-2021_3857" let sourceParam = Qt.createQmlObject(` - import QtLocation.MapLibre 3.0 + import MapLibre 3.0 SourceParameter { styleId: "tileSource" @@ -134,7 +135,7 @@ Item { style.addParameter(sourceParam) let layerParam = Qt.createQmlObject(` - import QtLocation.MapLibre 3.0 + import MapLibre 3.0 LayerParameter { styleId: "tileLayer" diff --git a/test/qml/qt6/tst_map.qml b/test/qml/qt6/tst_map.qml index 1f94efe..17a5d0a 100644 --- a/test/qml/qt6/tst_map.qml +++ b/test/qml/qt6/tst_map.qml @@ -1,12 +1,13 @@ -// Copyright (C) 2023 MapLibre contributors +// Copyright (C) 2024 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15 import QtLocation 6.5 -import QtLocation.MapLibre 3.0 import QtPositioning 5.15 +import MapLibre 3.0 + import QtTest 1.0 Item { diff --git a/test/qml/qt6/tst_style_parameters.qml b/test/qml/qt6/tst_style_parameters.qml index 4dc7d8e..3fd96da 100644 --- a/test/qml/qt6/tst_style_parameters.qml +++ b/test/qml/qt6/tst_style_parameters.qml @@ -1,12 +1,13 @@ -// Copyright (C) 2023 MapLibre contributors +// Copyright (C) 2024 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15 import QtLocation 6.5 -import QtLocation.MapLibre 3.0 import QtPositioning 6.5 +import MapLibre 3.0 + import QtTest 1.0 Item { @@ -119,7 +120,7 @@ Item { let url = "https://s2maps-tiles.eu/wms?service=wms&bbox={bbox-epsg-3857}&format=image/png&service=WMS&version=1.1.1&request=GetMap&srs=EPSG:900913&width=256&height=256&layers=s2cloudless-2021_3857" let sourceParam = Qt.createQmlObject(` - import QtLocation.MapLibre 3.0 + import MapLibre 3.0 SourceParameter { styleId: "tileSource" @@ -134,7 +135,7 @@ Item { style.addParameter(sourceParam) let layerParam = Qt.createQmlObject(` - import QtLocation.MapLibre 3.0 + import MapLibre 3.0 LayerParameter { styleId: "tileLayer" From 194419e29242d073f745265dfe2abe3ba458fcf6 Mon Sep 17 00:00:00 2001 From: Bart Louwers Date: Sun, 5 May 2024 21:03:50 +0200 Subject: [PATCH 2/3] Revert copyright year change --- examples/quick/main.qml | 2 +- src/location/plugins/legacy/qml_module.cpp | 2 +- src/location/plugins/legacy/qml_registration.cpp | 2 +- test/qml/qt5/tst_map.qml | 3 ++- test/qml/qt5/tst_style_parameters.qml | 3 ++- test/qml/qt6/tst_map.qml | 3 ++- test/qml/qt6/tst_style_parameters.qml | 3 ++- 7 files changed, 11 insertions(+), 7 deletions(-) diff --git a/examples/quick/main.qml b/examples/quick/main.qml index 51ee792..25b5aca 100644 --- a/examples/quick/main.qml +++ b/examples/quick/main.qml @@ -1,4 +1,4 @@ -// Copyright (C) 2024 MapLibre contributors +// Copyright (C) 2023 MapLibre contributors // SPDX-License-Identifier: MIT diff --git a/src/location/plugins/legacy/qml_module.cpp b/src/location/plugins/legacy/qml_module.cpp index dcc5b25..a52a8b5 100644 --- a/src/location/plugins/legacy/qml_module.cpp +++ b/src/location/plugins/legacy/qml_module.cpp @@ -1,4 +1,4 @@ -// Copyright (C) 2024 MapLibre contributors +// Copyright (C) 2023 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause diff --git a/src/location/plugins/legacy/qml_registration.cpp b/src/location/plugins/legacy/qml_registration.cpp index 3a496a6..bdc26ea 100644 --- a/src/location/plugins/legacy/qml_registration.cpp +++ b/src/location/plugins/legacy/qml_registration.cpp @@ -1,4 +1,4 @@ -// Copyright (C) 2024 MapLibre contributors +// Copyright (C) 2023 MapLibre contributors // SPDX-License-Identifier: BSD-2-Clause diff --git a/test/qml/qt5/tst_map.qml b/test/qml/qt5/tst_map.qml index 6be44d7..ddf61c2 100644 --- a/test/qml/qt5/tst_map.qml +++ b/test/qml/qt5/tst_map.qml @@ -1,4 +1,5 @@ -// Copyright (C) 2024 MapLibre contributors +// Copyright (C) 2023 MapLibre contributors + // SPDX-License-Identifier: BSD-2-Clause diff --git a/test/qml/qt5/tst_style_parameters.qml b/test/qml/qt5/tst_style_parameters.qml index c113123..4d59f60 100644 --- a/test/qml/qt5/tst_style_parameters.qml +++ b/test/qml/qt5/tst_style_parameters.qml @@ -1,4 +1,5 @@ -// Copyright (C) 2024 MapLibre contributors +// Copyright (C) 2023 MapLibre contributors + // SPDX-License-Identifier: BSD-2-Clause diff --git a/test/qml/qt6/tst_map.qml b/test/qml/qt6/tst_map.qml index 17a5d0a..9f13d82 100644 --- a/test/qml/qt6/tst_map.qml +++ b/test/qml/qt6/tst_map.qml @@ -1,4 +1,5 @@ -// Copyright (C) 2024 MapLibre contributors +// Copyright (C) 2023 MapLibre contributors + // SPDX-License-Identifier: BSD-2-Clause diff --git a/test/qml/qt6/tst_style_parameters.qml b/test/qml/qt6/tst_style_parameters.qml index 3fd96da..e804e0b 100644 --- a/test/qml/qt6/tst_style_parameters.qml +++ b/test/qml/qt6/tst_style_parameters.qml @@ -1,4 +1,5 @@ -// Copyright (C) 2024 MapLibre contributors +// Copyright (C) 2023 MapLibre contributors + // SPDX-License-Identifier: BSD-2-Clause From 839e060e57182fbb1eac1adb1408df5a75d753ac Mon Sep 17 00:00:00 2001 From: Tadej Novak Date: Sun, 5 May 2024 21:58:54 +0200 Subject: [PATCH 3/3] fix --- src/location/macros.cmake | 5 ++++- test/qml/qt5/tst_map.qml | 1 - test/qml/qt5/tst_style_parameters.qml | 1 - test/qml/qt6/tst_map.qml | 1 - test/qml/qt6/tst_style_parameters.qml | 1 - 5 files changed, 4 insertions(+), 5 deletions(-) diff --git a/src/location/macros.cmake b/src/location/macros.cmake index aecdb29..51470cc 100644 --- a/src/location/macros.cmake +++ b/src/location/macros.cmake @@ -21,6 +21,9 @@ function(qmaplibre_location_setup_plugins target) set(_targetName ${target}) endif() get_property(_targetDestination TARGET ${target} PROPERTY RUNTIME_OUTPUT_DIRECTORY) + if(_targetDestination) + set(_targetDestination "${_targetDestination}/") + endif() get_target_property(_targetTypeCore QMapLibre::Core TYPE) if(_targetTypeCore STREQUAL STATIC_LIBRARY) @@ -46,7 +49,7 @@ function(qmaplibre_location_setup_plugins target) if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin") file( COPY "${_ImportedLocationGeoServices}" - DESTINATION "${_targetDestination}/${_targetName}.app/Contents/PlugIns/geoservices" + DESTINATION "${_targetDestination}${_targetName}.app/Contents/PlugIns/geoservices" ) elseif(${CMAKE_SYSTEM_NAME} MATCHES "Windows") install( diff --git a/test/qml/qt5/tst_map.qml b/test/qml/qt5/tst_map.qml index ddf61c2..7abb643 100644 --- a/test/qml/qt5/tst_map.qml +++ b/test/qml/qt5/tst_map.qml @@ -1,6 +1,5 @@ // Copyright (C) 2023 MapLibre contributors - // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15 diff --git a/test/qml/qt5/tst_style_parameters.qml b/test/qml/qt5/tst_style_parameters.qml index 4d59f60..2603550 100644 --- a/test/qml/qt5/tst_style_parameters.qml +++ b/test/qml/qt5/tst_style_parameters.qml @@ -1,6 +1,5 @@ // Copyright (C) 2023 MapLibre contributors - // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15 diff --git a/test/qml/qt6/tst_map.qml b/test/qml/qt6/tst_map.qml index 9f13d82..26a37d5 100644 --- a/test/qml/qt6/tst_map.qml +++ b/test/qml/qt6/tst_map.qml @@ -1,6 +1,5 @@ // Copyright (C) 2023 MapLibre contributors - // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15 diff --git a/test/qml/qt6/tst_style_parameters.qml b/test/qml/qt6/tst_style_parameters.qml index e804e0b..d4d9d30 100644 --- a/test/qml/qt6/tst_style_parameters.qml +++ b/test/qml/qt6/tst_style_parameters.qml @@ -1,6 +1,5 @@ // Copyright (C) 2023 MapLibre contributors - // SPDX-License-Identifier: BSD-2-Clause import QtQuick 2.15