Bug reports and feature requests are more than welcome, but please consider the following tips so we can respond to your feedback more effectively.
Before reporting a bug here, please determine whether the issue lies with the navigation SDK itself or with another Mapbox product:
- For general questions and troubleshooting help, please contact the Mapbox support team.
- Report problems with the map’s contents or routing problems, especially problems specific to a particular route or region, using the Mapbox Feedback tool.
- Report problems in guidance instructions in the OSRM Text Instructions repository (for Directions API profiles powered by OSRM) or the Valhalla repository (for profiles powered by Valhalla).
When reporting a bug in the navigation SDK itself, please indicate:
- The version of MapboxNavigation or MapboxCoreNavigation you installed
- The version of CocoaPods, Carthage, or Swift Package Manager that you used to install the package
- The version of Xcode you used to build the package
- The iOS version and device model on which you experienced the issue
- Any relevant settings in
NavigationRouteOptions
orNavigationMatchOptions
- Any relevant language settings
To contribute code changes to this project, use either Carthage or Swift Package Manager to set up a development environment. Carthage and the Xcode project in this repository are important for making sure dependent projects can use Carthage and for checking your work in the included Example or Example-CarPlay application. Swift Package Manager only builds MapboxCoreNavigation.
To build this SDK, you need Xcode 11.4.1 and Carthage v0.35:
-
Go to your Mapbox account dashboard and create an access token that has the
DOWNLOADS:READ
scope. PLEASE NOTE: This is not the same as your production Mapbox API token. Make sure to keep it private and do not insert it into any Info.plist file. Create a file named.netrc
in your home directory if it doesn’t already exist, then add the following lines to the end of the file:machine api.mapbox.com login mapbox password PRIVATE_MAPBOX_API_TOKEN
where PRIVATE_MAPBOX_API_TOKEN is your Mapbox API token with the
DOWNLOADS:READ
scope. -
(Optional) Clear your Carthage caches:
rm -rf ~/Library/Caches/carthage/ ~/Library/Caches/org.carthage.CarthageKit/binaries/{MapboxAccounts,MapboxCommon-ios,MapboxNavigationNative,mapbox-ios-sdk-dynamic}
-
Run
./scripts/wcarthage.sh bootstrap --platform iOS --cache-builds --use-netrc
. (wcarthage.sh is a temporary workaround for a linker error in Xcode 12.) -
Once the Carthage build finishes, open
MapboxNavigation.xcodeproj
in Xcode and build the MapboxNavigation scheme. Switch to the Example or Example-CarPlay scheme to see the SDK in action.
In Xcode, go to Source Control ‣ Clone, enter https://github.com/mapbox/mapbox-navigation-ios.git
, and click Clone.
Alternatively, on the command line:
git clone https://github.com/mapbox/mapbox-navigation-ios.git
cd mapbox-navigation-ios/
open Package.swift
The resulting package only includes MapboxCoreNavigation and MapboxCoreNavigationTests. It does not include MapboxNavigation, MapboxNavigationTests, or the example applications, so make sure to build and test the SDK in the Xcode workspace before opening a pull request.
To add any type, constant, or member to the SDK’s public interface:
- Name the symbol according to Swift design guidelines and Cocoa naming conventions.
- In rare cases where a symbol needs to bridge to Objective-C to interoperate with the Objective-C runtime, use
@objc(…)
to specify an Objective-C-specific name that conforms to Objective-C naming conventions. Use theMB
class prefix to avoid conflicts with client code. - Provide full documentation comments. We use jazzy to produce the documentation found on the website for this SDK. Many developers also rely on Xcode’s Quick Help feature, which supports a subset of Markdown.
- (Optional.) Add the type or constant’s name to the relevant category in the
custom_categories
section of the jazzy configuration file. This is required for classes and protocols and also recommended for any other type that is strongly associated with a particular class or protocol. If you leave out this step, the symbol will appear in an “Other” section in the generated HTML documentation’s table of contents.
Image assets are designed in a PaintCode document managed in the navigation-ui-resources repository. After changes to that repository are merged, export the PaintCode drawings as Swift source code and add or replace files in the MapboxNavigation folder.
To add or update text that the user may see in the navigation SDK:
- Use the
NSLocalizedString(_:tableName:bundle:value:comment:)
method:NSLocalizedString("UNIQUE_IDENTIFIER", bundle: .mapboxNavigation, value: "What English speakers see", comment: "Where this text appears or how it is used")
- (Optional.) If you need to embed some text in a string, use
NSLocalizedString(_:tableName:bundle:value:comment:)
withString.localizedStringWithFormat(_:_:)
instead ofString(format:)
:String.localizedStringWithFormat(NSLocalizedString("UNIQUE_IDENTIFIER", bundle: .mapboxNavigation, value: "What English speakers see with %@ for each embedded string", comment: "Format string for a string with an embedded string; 1 = the first embedded string"), embeddedString)
- (Optional.) When dealing with a number followed by a pluralized word, do not split the string. Instead, use a format string and make
val
ambiguous, like%d file(s)
. Then pluralize for English in the appropriate .stringsdict file. See MapboxNavigation/Resources/en.lproj/Localizable.stringsdict for an example. Localizers should do likewise for their languages. - Run
scripts/extract_localizable.sh
to add the new text to the .strings files. - Open a pull request with your changes. Once the pull request is merged, Transifex will pick up the changes within a few hours.
The Mapbox Navigation SDK for iOS features several translations contributed through Transifex. If your language already has a translation, feel free to complete or proofread it. Otherwise, please request your language so you can start translating. Note that we’re primarily interested in languages that iOS supports as system languages.
While you’re there, please consider also translating the following related projects:
- Mapbox Maps SDK for iOS, which is responsible for the map view and minor UI elements such as the compass (instructions)
- OSRM Text Instructions, which some Mapbox Directions API profiles use to generate textual and verbal turn instructions (instructions)
- Valhalla Phrases, which some Mapbox Directions API profiles use to generate textual and verbal turn instructions (instructions)
- Mapbox Navigation SDK for Android, the analogous library for Android applications (instructions)
Once you’ve finished translating the iOS navigation SDK into a new language in Transifex, open an issue in this repository asking to pull in your localization. Or do it yourself and open a pull request with the results:
- (First time only.) Download the
tx
command line tool and configure your .transifexrc. - In MapboxNavigation.xcodeproj, open the project editor. Using the project editor’s sidebar or tab bar dropdown, go to the “MapboxNavigation” project. Under the Localizations section of the Info tab, click the + button to add your language to the project.
- In the sheet that appears, select all the files, then click Finish.
The .strings files should still be in the original English – that’s expected. Now you can pull your translations into this repository:
- Run
tx pull -a
to fetch translations from Transifex. You can restrict the operation to just the new language usingtx pull -l xyz
, where xyz is the language code. - To facilitate diffing and merging, convert any added .strings files from UTF-16 encoding to UTF-8 encoding. You can convert the file encoding using Xcode’s File inspector or by running
scripts/convert_string_files.sh
. - For each of the localizable files in the project, open the file, then, in the File inspector, check the box for your new localization.
- Add a Unit Test Case Class file to the MapboxCoreNavigationTests group in MapboxNavigation.xcodeproj. It will be located in Tests/MapboxCoreNavigationTests/.
- If a unit test requires a fixture, add a file to Tests/MapboxCoreNavigationTests/Fixtures/. Import
TestHelper
and callFixture.stringFromFileNamed(name:)
orFixture.JSONFromFileNamed(name:)
.
- Add a file to the MapboxNavigationTests group in MapboxNavigation.xcodeproj. It will be located in Tests/MapboxNavigationTests/.
- Import
SnappyShrimp
and subclassSnapshotTest
, or importFBSnapshotTestCase
and subclassFBSnapshotTestCase
. - Add the expected screenshot image to Tests/MapboxNavigationTests/ReferenceImages/MapboxNavigationTests.TestSuiteName with a file name like
[email protected]
that indicates the test case name, device, iOS version, and resolution. Make sure the screenshot was taken on an iOS version and device that is consistent with the existing reference images. - Call
verify(_:)
.
Go to Product ‣ Test in Xcode. Snapshot tests will only pass if you select iPhone 8 Plus as the target device.
Pull requests are appreciated. If your PR includes any changes that would impact developers or end users, please mention those changes in the “main” section of CHANGELOG.md, noting the PR number. Examples of noteworthy changes include new features, fixes for user-visible bugs, and renamed or deleted public symbols.
Before we can merge your PR, it must pass automated continuous integration checks in each of the supported environments, as well as a check to ensure that code coverage has not decreased significantly.