Contents of this readme
Since CLLocationManager
doesn’t support block based APIs sometimes it’s very annoying to setup a delegate and implement all delegate methods if you just want to fetch the current location once and that’s it.
OneShotLocationManager
is a class that solves that problem in Swift. Whenever you need to fetch the current device location you just need to create an instance of OneShotLocationManager
and call the method to fetch a location. It will request the necessary authorizations and return the current location. Very easy. It just works.
The infrastructure and best practices for distributing Swift libraries is currently being developed by the developer community during this beta period of the language and Xcode. In the meantime, you can simply download this repository as a ZIP file and drag the OneShotLocationManager.swift
file into your Xcode project.
Here's the simplest way to use OneShotLocationManager in Swift:
//in your view controller
var manager: OneShotLocationManager?
override func viewDidLoad() {
manager = OneShotLocationManager()
manager!.fetchWithCompletion {location, error in
// fetch location or an error
if let loc = location {
println(location)
} else if let err = error {
prinln(err.localizedDescription)
}
self.manager = nil
}
}
For a complete example app check out the included Xcode project in this repository.
Author: Marin Todorov
OneShotLocationManager is available under the MIT license. See the LICENSE file for more info.