diff --git a/CHANGELOG.md b/CHANGELOG.md index dc38807..b10f6d2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,10 @@ All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). +## Upcoming + +- Upgrades project to Swift 6 with swift-tools-version 6.0. + ## Version 0.7.0 - 2025-02-02 ### Added diff --git a/Package.resolved b/Package.resolved index b4b5457..009d4e4 100644 --- a/Package.resolved +++ b/Package.resolved @@ -1,13 +1,13 @@ { - "originHash" : "38dcbeee72b24bdfa4a2996241d74854484c6c169c780ccbb848c5b91e1f16ce", + "originHash" : "ba3eb8620cdf7e03ce1ee48a09f542740461a2d34a7b185836833a6dd904e309", "pins" : [ { "identity" : "maplibre-gl-native-distribution", "kind" : "remoteSourceControl", "location" : "https://github.com/maplibre/maplibre-gl-native-distribution.git", "state" : { - "revision" : "3615e3cc81b09b78b58b183660815b0f36107b3b", - "version" : "6.10.0" + "revision" : "f609802247705d95e852e4e277e597aa88230e2b", + "version" : "6.12.1" } }, { @@ -15,8 +15,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/stadiamaps/maplibre-swift-macros.git", "state" : { - "revision" : "9e27e62dff7fd727aebd0a7c8aa74e7635a5583e", - "version" : "0.0.5" + "revision" : "92a651a64bdedfea9b55ca365e0101a99a56cf85", + "version" : "0.0.6" } }, { @@ -24,8 +24,17 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/Kolos65/Mockable.git", "state" : { - "revision" : "e1b311b01c11415099341eee49769185e965ac4c", - "version" : "0.2.0" + "revision" : "203336d0ccb7ff03a8a03db54a4fa18fc2b0c771", + "version" : "0.3.0" + } + }, + { + "identity" : "swift-custom-dump", + "kind" : "remoteSourceControl", + "location" : "https://github.com/pointfreeco/swift-custom-dump", + "state" : { + "revision" : "82645ec760917961cfa08c9c0c7104a57a0fa4b1", + "version" : "1.3.3" } }, { @@ -33,8 +42,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/pointfreeco/swift-snapshot-testing", "state" : { - "revision" : "2e6a85b73fc14e27d7542165ae73b1a10516ca9a", - "version" : "1.17.7" + "revision" : "b2d4cb30735f4fbc3a01963a9c658336dd21e9ba", + "version" : "1.18.1" } }, { diff --git a/Package.swift b/Package.swift index 8b9ec7c..efe9d67 100644 --- a/Package.swift +++ b/Package.swift @@ -1,4 +1,4 @@ -// swift-tools-version: 5.10 +// swift-tools-version: 6.0 // The swift-tools-version declares the minimum version of Swift required to build this package. import CompilerPluginSupport @@ -21,11 +21,13 @@ let package = Package( ), ], dependencies: [ - .package(url: "https://github.com/maplibre/maplibre-gl-native-distribution.git", from: "6.10.0"), - .package(url: "https://github.com/stadiamaps/maplibre-swift-macros.git", from: "0.0.5"), + .package( + url: "https://github.com/maplibre/maplibre-gl-native-distribution.git", from: "6.12.1" + ), + .package(url: "https://github.com/stadiamaps/maplibre-swift-macros.git", from: "0.0.6"), // Testing - .package(url: "https://github.com/Kolos65/Mockable.git", from: "0.2.0"), - .package(url: "https://github.com/pointfreeco/swift-snapshot-testing", from: "1.17.7"), + .package(url: "https://github.com/Kolos65/Mockable.git", from: "0.3.0"), + .package(url: "https://github.com/pointfreeco/swift-snapshot-testing", from: "1.18.1"), ], targets: [ .target( @@ -38,7 +40,6 @@ let package = Package( ], swiftSettings: [ .define("MOCKING", .when(configuration: .debug)), - .enableExperimentalFeature("StrictConcurrency"), ] ), .target( @@ -47,18 +48,12 @@ let package = Package( .target(name: "InternalUtils"), .product(name: "MapLibre", package: "maplibre-gl-native-distribution"), .product(name: "MapLibreSwiftMacros", package: "maplibre-swift-macros"), - ], - swiftSettings: [ - .enableExperimentalFeature("StrictConcurrency"), ] ), .target( name: "InternalUtils", dependencies: [ .product(name: "MapLibre", package: "maplibre-gl-native-distribution"), - ], - swiftSettings: [ - .enableExperimentalFeature("StrictConcurrency"), ] ), diff --git a/Sources/MapLibreSwiftUI/MapViewCoordinator.swift b/Sources/MapLibreSwiftUI/MapViewCoordinator.swift index 0157bc0..603e4e7 100644 --- a/Sources/MapLibreSwiftUI/MapViewCoordinator.swift +++ b/Sources/MapLibreSwiftUI/MapViewCoordinator.swift @@ -2,7 +2,7 @@ import Foundation import MapLibre import MapLibreSwiftDSL -public class MapViewCoordinator: NSObject, MLNMapViewDelegate { +public class MapViewCoordinator: NSObject, @preconcurrency MLNMapViewDelegate { // This must be weak, the UIViewRepresentable owns the MLNMapView. weak var mapView: MLNMapView? var parent: MapView @@ -267,7 +267,7 @@ public class MapViewCoordinator: NSObject, MLNMapV } } - func addLayers(to mglStyle: MLNStyle) { + @MainActor func addLayers(to mglStyle: MLNStyle) { let firstSymbolLayer = mglStyle.layers.first { layer in layer is MLNSymbolStyleLayer } @@ -318,7 +318,7 @@ public class MapViewCoordinator: NSObject, MLNMapV // MARK: - MLNMapViewDelegate - public func mapView(_: MLNMapView, didFinishLoading mglStyle: MLNStyle) { + @MainActor public func mapView(_: MLNMapView, didFinishLoading mglStyle: MLNStyle) { addLayers(to: mglStyle) onStyleLoaded?(mglStyle) } @@ -373,17 +373,19 @@ public class MapViewCoordinator: NSObject, MLNMapV } /// The MapView's region has changed with a specific reason. - public func mapView(_ mapView: MLNMapView, regionDidChangeWith reason: MLNCameraChangeReason, animated _: Bool) { + @MainActor public func mapView( + _ mapView: MLNMapView, + regionDidChangeWith reason: MLNCameraChangeReason, + animated _: Bool + ) { // TODO: We could put this in regionIsChangingWith if we calculate significant change/debounce. - MainActor.assumeIsolated { - updateViewProxy(mapView: mapView, reason: reason) + updateViewProxy(mapView: mapView, reason: reason) - guard !suppressCameraUpdatePropagation else { - return - } - - updateParentCamera(mapView: mapView, reason: reason) + guard !suppressCameraUpdatePropagation else { + return } + + updateParentCamera(mapView: mapView, reason: reason) } // MARK: MapViewProxy diff --git a/Tests/MapLibreSwiftUITests/Examples/CameraPreviewTests.swift b/Tests/MapLibreSwiftUITests/Examples/CameraPreviewTests.swift index 5fff98a..fee80f3 100644 --- a/Tests/MapLibreSwiftUITests/Examples/CameraPreviewTests.swift +++ b/Tests/MapLibreSwiftUITests/Examples/CameraPreviewTests.swift @@ -2,6 +2,7 @@ import SnapshotTesting import XCTest @testable import MapLibreSwiftUI +@MainActor final class CameraPreviewTests: XCTestCase { func testCameraPreview() { assertView { diff --git a/Tests/MapLibreSwiftUITests/MapView/MapViewGestureTests.swift b/Tests/MapLibreSwiftUITests/MapView/MapViewGestureTests.swift index 83a9c79..219a7f5 100644 --- a/Tests/MapLibreSwiftUITests/MapView/MapViewGestureTests.swift +++ b/Tests/MapLibreSwiftUITests/MapView/MapViewGestureTests.swift @@ -3,10 +3,10 @@ import Mockable import XCTest @testable import MapLibreSwiftUI +@MainActor final class MapViewGestureTests: XCTestCase { let maplibreMapView = MLNMapView() - @MainActor let mapView = MapView(styleURL: URL(string: "https://maplibre.org")!) // MARK: Gesture View Modifiers