osrm-text-instructions
WIP: This project is under heavy development and should not be integrated yet.
osrm-text-instructions transforms OSRM route responses into text instructions. It currently has only an implementation in JavaScript, with more to come.
Design goals
- Cross platform Use a data-driven approach that makes implementations in other programming environments easy to write
- Test suite Have a data-driven test suite with fixtures which can be used cross-platform
- Translation Allow for translations via Transifex
- Customization Users should be able to easily fork or monkey patch the results to adjust to their own likings
Javascript Usage
var osrmTextInstructions = require('osrm-text-instructions')('v5', 'en');
// make your request against the API
response.legs.forEach(function(leg) {
leg.steps.forEach(function(step) {
instruction = osrmTextInstructions.compile(step)
});
});
Development
Architecture
index.js
holds the main transformation logic in javascriptinstructions/
holds the translateable strings
Tests
Tests are data-driven integration tests for the english language.
To run them yourself for the JavaScript implementation:
npm install
npm test
Generate Fixtures
Fixtures can be programatically created and updated via scripts/generate_fixtures.js
. To update the instructions in the fixture files, run UPDATE=1 npm test
.
Translations
To add own translations:
- Create a new file in
instructions/
- Translate
- Add the new instructions file to
instructions.js
- Add the new instructions file to the
languages
array in test/instructions_test.js
- To manually look at the changes:
- Change the locale in
test/index_test.js
- Run
UPDATE=1 npm test
and look at the changes in git diff
- When done, revert via
git checkout test
- Make a PR