Merge branch 'master' into sf-osrm-routed
This commit is contained in:
commit
2016d468bb
@ -42,12 +42,15 @@ Checks: >
|
|||||||
-llvm-twine-local,
|
-llvm-twine-local,
|
||||||
misc-*,
|
misc-*,
|
||||||
-misc-argument-comment,
|
-misc-argument-comment,
|
||||||
|
-misc-const-correctness,
|
||||||
-misc-non-private-member-variables-in-classes,
|
-misc-non-private-member-variables-in-classes,
|
||||||
-misc-unconventional-assign-operator,
|
-misc-unconventional-assign-operator,
|
||||||
-misc-no-recursion,
|
-misc-no-recursion,
|
||||||
-misc-misplaced-const,
|
-misc-misplaced-const,
|
||||||
-misc-definitions-in-headers,
|
-misc-definitions-in-headers,
|
||||||
-misc-unused-parameters,
|
-misc-unused-parameters,
|
||||||
|
modernize-concat-nested-namespaces,
|
||||||
|
modernize-use-using,
|
||||||
performance-*,
|
performance-*,
|
||||||
-performance-noexcept-move-constructor,
|
-performance-noexcept-move-constructor,
|
||||||
-performance-no-int-to-ptr,
|
-performance-no-int-to-ptr,
|
||||||
|
315
.github/workflows/osrm-backend.yml
vendored
315
.github/workflows/osrm-backend.yml
vendored
@ -20,7 +20,7 @@ env:
|
|||||||
ENABLE_NODE_BINDINGS: "ON"
|
ENABLE_NODE_BINDINGS: "ON"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
windows:
|
windows-release-node:
|
||||||
needs: format-taginfo-docs
|
needs: format-taginfo-docs
|
||||||
runs-on: windows-2022
|
runs-on: windows-2022
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
@ -29,7 +29,7 @@ jobs:
|
|||||||
ENABLE_APPLE_SILICON: "OFF"
|
ENABLE_APPLE_SILICON: "OFF"
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- run: pip install conan==1.53.0
|
- run: pip install "conan<2.0.0"
|
||||||
- run: conan --version
|
- run: conan --version
|
||||||
- run: cmake --version
|
- run: cmake --version
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
@ -73,13 +73,13 @@ jobs:
|
|||||||
format-taginfo-docs:
|
format-taginfo-docs:
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v3
|
||||||
- name: Use Node.js
|
- name: Use Node.js
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: 12
|
node-version: 16
|
||||||
- name: Enable Node.js cache
|
- name: Enable Node.js cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v3
|
||||||
with:
|
with:
|
||||||
path: ~/.npm
|
path: ~/.npm
|
||||||
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
|
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
|
||||||
@ -95,6 +95,7 @@ jobs:
|
|||||||
./scripts/format.sh && ./scripts/error_on_dirty.sh
|
./scripts/format.sh && ./scripts/error_on_dirty.sh
|
||||||
node ./scripts/validate_changelog.js
|
node ./scripts/validate_changelog.js
|
||||||
npm run docs && ./scripts/error_on_dirty.sh
|
npm run docs && ./scripts/error_on_dirty.sh
|
||||||
|
npm audit --production
|
||||||
|
|
||||||
routed-js:
|
routed-js:
|
||||||
runs-on: ubuntu-22.04
|
runs-on: ubuntu-22.04
|
||||||
@ -127,7 +128,7 @@ jobs:
|
|||||||
- name: Check out the repo
|
- name: Check out the repo
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
- name: Enable osm.pbf cache
|
- name: Enable osm.pbf cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v3
|
||||||
with:
|
with:
|
||||||
path: berlin-latest.osm.pbf
|
path: berlin-latest.osm.pbf
|
||||||
key: v1-berlin-osm-pbf
|
key: v1-berlin-osm-pbf
|
||||||
@ -169,7 +170,7 @@ jobs:
|
|||||||
include:
|
include:
|
||||||
- name: gcc-9-debug-cov
|
- name: gcc-9-debug-cov
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Debug
|
BUILD_TYPE: Debug
|
||||||
@ -180,7 +181,7 @@ jobs:
|
|||||||
|
|
||||||
- name: gcc-9-debug-asan-ubsan
|
- name: gcc-9-debug-asan-ubsan
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Debug
|
BUILD_TYPE: Debug
|
||||||
@ -194,7 +195,7 @@ jobs:
|
|||||||
|
|
||||||
- name: clang-6.0-debug
|
- name: clang-6.0-debug
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Debug
|
BUILD_TYPE: Debug
|
||||||
@ -202,20 +203,20 @@ jobs:
|
|||||||
CXXCOMPILER: clang++-6.0
|
CXXCOMPILER: clang++-6.0
|
||||||
CUCUMBER_TIMEOUT: 60000
|
CUCUMBER_TIMEOUT: 60000
|
||||||
|
|
||||||
- name: clang-11.0-debug-clang-tidy
|
- name: clang-15.0-debug-clang-tidy
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-22.04
|
runs-on: ubuntu-22.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Debug
|
BUILD_TYPE: Debug
|
||||||
CCOMPILER: clang-14
|
CCOMPILER: clang-15
|
||||||
CXXCOMPILER: clang++-14
|
CXXCOMPILER: clang++-15
|
||||||
CUCUMBER_TIMEOUT: 60000
|
CUCUMBER_TIMEOUT: 60000
|
||||||
ENABLE_CLANG_TIDY: ON
|
ENABLE_CLANG_TIDY: ON
|
||||||
|
|
||||||
- name: conan-linux-debug-asan-ubsan
|
- name: conan-linux-debug-asan-ubsan
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -226,7 +227,7 @@ jobs:
|
|||||||
|
|
||||||
- name: conan-linux-release
|
- name: conan-linux-release
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 14
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -234,9 +235,20 @@ jobs:
|
|||||||
CXXCOMPILER: clang++-6.0
|
CXXCOMPILER: clang++-6.0
|
||||||
ENABLE_CONAN: ON
|
ENABLE_CONAN: ON
|
||||||
|
|
||||||
|
- name: gcc-12-release
|
||||||
|
continue-on-error: false
|
||||||
|
node: 16
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
BUILD_TOOLS: ON
|
||||||
|
BUILD_TYPE: Release
|
||||||
|
CCOMPILER: gcc-12
|
||||||
|
CXXCOMPILER: g++-12
|
||||||
|
ENABLE_BENCHMARKS: ON
|
||||||
|
CXXFLAGS: '-Wno-array-bounds -Wno-uninitialized'
|
||||||
|
|
||||||
- name: gcc-11-release
|
- name: gcc-11-release
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -246,7 +258,7 @@ jobs:
|
|||||||
|
|
||||||
- name: gcc-10-release
|
- name: gcc-10-release
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -255,7 +267,7 @@ jobs:
|
|||||||
|
|
||||||
- name: gcc-9-release
|
- name: gcc-9-release
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -265,7 +277,7 @@ jobs:
|
|||||||
|
|
||||||
- name: gcc-9-conan-release-i686
|
- name: gcc-9-conan-release-i686
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -278,7 +290,7 @@ jobs:
|
|||||||
|
|
||||||
- name: gcc-8-release
|
- name: gcc-8-release
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 16
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TOOLS: ON
|
BUILD_TOOLS: ON
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
@ -286,82 +298,10 @@ jobs:
|
|||||||
CXXCOMPILER: g++-8
|
CXXCOMPILER: g++-8
|
||||||
CXXFLAGS: -Wno-cast-function-type
|
CXXFLAGS: -Wno-cast-function-type
|
||||||
|
|
||||||
- name: gcc-7-release
|
- name: conan-linux-release-node
|
||||||
continue-on-error: false
|
|
||||||
node: 12
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TOOLS: ON
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: gcc-7
|
|
||||||
CXXCOMPILER: g++-7
|
|
||||||
|
|
||||||
- name: conan-macos-x64-release-node-12
|
|
||||||
build_node_package: true
|
build_node_package: true
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 18
|
||||||
runs-on: macos-11
|
|
||||||
BUILD_TOOLS: ON
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang
|
|
||||||
CXXCOMPILER: clang++
|
|
||||||
CUCUMBER_TIMEOUT: 60000
|
|
||||||
ENABLE_ASSERTIONS: ON
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
|
|
||||||
- name: conan-macos-x64-release-node-14
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 14
|
|
||||||
runs-on: macos-11
|
|
||||||
BUILD_TOOLS: ON
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang
|
|
||||||
CXXCOMPILER: clang++
|
|
||||||
CUCUMBER_TIMEOUT: 60000
|
|
||||||
ENABLE_ASSERTIONS: ON
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
|
|
||||||
- name: conan-macos-x64-release-node-16
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 16
|
|
||||||
runs-on: macos-11
|
|
||||||
BUILD_TOOLS: ON
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang
|
|
||||||
CXXCOMPILER: clang++
|
|
||||||
CUCUMBER_TIMEOUT: 60000
|
|
||||||
ENABLE_ASSERTIONS: ON
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
|
|
||||||
- name: conan-macos-arm64-release-node-16
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 16
|
|
||||||
runs-on: macos-11
|
|
||||||
BUILD_TOOLS: ON
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang
|
|
||||||
CXXCOMPILER: clang++
|
|
||||||
CUCUMBER_TIMEOUT: 60000
|
|
||||||
ENABLE_ASSERTIONS: ON
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
ENABLE_APPLE_SILICON: ON
|
|
||||||
|
|
||||||
- name: gcc-7-release-shared
|
|
||||||
continue-on-error: false
|
|
||||||
node: 12
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TOOLS: ON
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
BUILD_SHARED_LIBS: ON
|
|
||||||
CCOMPILER: gcc-7
|
|
||||||
CXXCOMPILER: g++-7
|
|
||||||
|
|
||||||
- name: node-12-conan-linux-release
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 12
|
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
CCOMPILER: clang-6.0
|
CCOMPILER: clang-6.0
|
||||||
@ -369,10 +309,10 @@ jobs:
|
|||||||
ENABLE_CONAN: ON
|
ENABLE_CONAN: ON
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
NODE_PACKAGE_TESTS_ONLY: ON
|
||||||
|
|
||||||
- name: node-12-conan-linux-debug
|
- name: conan-linux-debug-node
|
||||||
build_node_package: true
|
build_node_package: true
|
||||||
continue-on-error: false
|
continue-on-error: false
|
||||||
node: 12
|
node: 18
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
BUILD_TYPE: Debug
|
BUILD_TYPE: Debug
|
||||||
CCOMPILER: clang-6.0
|
CCOMPILER: clang-6.0
|
||||||
@ -380,55 +320,10 @@ jobs:
|
|||||||
ENABLE_CONAN: ON
|
ENABLE_CONAN: ON
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
NODE_PACKAGE_TESTS_ONLY: ON
|
||||||
|
|
||||||
- name: node-14-conan-linux-release
|
- name: conan-macos-x64-release-node
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 14
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
- name: node-14-conan-linux-debug
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 14
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Debug
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
|
|
||||||
- name: node-16-conan-linux-release
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 16
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
- name: node-16-conan-linux-debug
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: false
|
|
||||||
node: 16
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Debug
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
- name: conan-macos-x64-release-node-latest
|
|
||||||
build_node_package: true
|
build_node_package: true
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
node: latest
|
node: 18
|
||||||
runs-on: macos-11
|
runs-on: macos-11
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
CCOMPILER: clang
|
CCOMPILER: clang
|
||||||
@ -437,10 +332,10 @@ jobs:
|
|||||||
ENABLE_ASSERTIONS: ON
|
ENABLE_ASSERTIONS: ON
|
||||||
ENABLE_CONAN: ON
|
ENABLE_CONAN: ON
|
||||||
|
|
||||||
- name: conan-macos-arm64-release-node-latest
|
- name: conan-macos-arm64-release-node
|
||||||
build_node_package: true
|
build_node_package: true
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
node: latest
|
node: 18
|
||||||
runs-on: macos-11
|
runs-on: macos-11
|
||||||
BUILD_TYPE: Release
|
BUILD_TYPE: Release
|
||||||
CCOMPILER: clang
|
CCOMPILER: clang
|
||||||
@ -450,75 +345,6 @@ jobs:
|
|||||||
ENABLE_CONAN: ON
|
ENABLE_CONAN: ON
|
||||||
ENABLE_APPLE_SILICON: ON
|
ENABLE_APPLE_SILICON: ON
|
||||||
|
|
||||||
- name: node-latest-conan-linux-release
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: true
|
|
||||||
node: latest
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
- name: node-latest-conan-linux-debug
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: true
|
|
||||||
node: latest
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Debug
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
- name: conan-macos-x64-release-node-lts
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: true
|
|
||||||
node: "lts/*"
|
|
||||||
runs-on: macos-11
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang
|
|
||||||
CXXCOMPILER: clang++
|
|
||||||
CUCUMBER_TIMEOUT: 60000
|
|
||||||
ENABLE_ASSERTIONS: ON
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
|
|
||||||
- name: conan-macos-arm64-release-node-lts
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: true
|
|
||||||
node: "lts/*"
|
|
||||||
runs-on: macos-11
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang
|
|
||||||
CXXCOMPILER: clang++
|
|
||||||
CUCUMBER_TIMEOUT: 60000
|
|
||||||
ENABLE_ASSERTIONS: ON
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
ENABLE_APPLE_SILICON: ON
|
|
||||||
|
|
||||||
- name: node-lts-conan-linux-release
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: true
|
|
||||||
node: "lts/*"
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Release
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
- name: node-lts-conan-linux-debug
|
|
||||||
build_node_package: true
|
|
||||||
continue-on-error: true
|
|
||||||
node: "lts/*"
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
BUILD_TYPE: Debug
|
|
||||||
CCOMPILER: clang-6.0
|
|
||||||
CXXCOMPILER: clang++-6.0
|
|
||||||
ENABLE_CONAN: ON
|
|
||||||
NODE_PACKAGE_TESTS_ONLY: ON
|
|
||||||
|
|
||||||
name: ${{ matrix.name}}
|
name: ${{ matrix.name}}
|
||||||
continue-on-error: ${{ matrix.continue-on-error }}
|
continue-on-error: ${{ matrix.continue-on-error }}
|
||||||
runs-on: ${{ matrix.runs-on }}
|
runs-on: ${{ matrix.runs-on }}
|
||||||
@ -542,40 +368,40 @@ jobs:
|
|||||||
OSRM_CONNECTION_RETRIES: ${{ matrix.OSRM_CONNECTION_RETRIES }}
|
OSRM_CONNECTION_RETRIES: ${{ matrix.OSRM_CONNECTION_RETRIES }}
|
||||||
OSRM_CONNECTION_EXP_BACKOFF_COEF: ${{ matrix.OSRM_CONNECTION_EXP_BACKOFF_COEF }}
|
OSRM_CONNECTION_EXP_BACKOFF_COEF: ${{ matrix.OSRM_CONNECTION_EXP_BACKOFF_COEF }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Use Node.js
|
- name: Use Node.js
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: ${{ matrix.node }}
|
node-version: ${{ matrix.node }}
|
||||||
- name: Enable Node.js cache
|
- name: Enable Node.js cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v3
|
||||||
with:
|
with:
|
||||||
path: ~/.npm
|
path: ~/.npm
|
||||||
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
|
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
|
||||||
restore-keys: |
|
restore-keys: |
|
||||||
${{ runner.os }}-node-
|
${{ runner.os }}-node-
|
||||||
- name: Enable compiler cache
|
- name: Enable compiler cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v3
|
||||||
with:
|
with:
|
||||||
path: ~/.ccache
|
path: ~/.ccache
|
||||||
key: ccache-${{ matrix.name }}-${{ github.sha }}
|
key: ccache-${{ matrix.name }}-${{ github.sha }}
|
||||||
restore-keys: |
|
restore-keys: |
|
||||||
ccache-${{ matrix.name }}-
|
ccache-${{ matrix.name }}-
|
||||||
- name: Enable Conan cache
|
- name: Enable Conan cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v3
|
||||||
with:
|
with:
|
||||||
path: ~/.conan
|
path: ~/.conan
|
||||||
key: v6-conan-${{ matrix.name }}-${{ github.sha }}
|
key: v6-conan-${{ matrix.name }}-${{ github.sha }}
|
||||||
restore-keys: |
|
restore-keys: |
|
||||||
v6-conan-${{ matrix.name }}-
|
v6-conan-${{ matrix.name }}-
|
||||||
- name: Enable test cache
|
- name: Enable test cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v3
|
||||||
with:
|
with:
|
||||||
path: ${{github.workspace}}/test/cache
|
path: ${{github.workspace}}/test/cache
|
||||||
key: v3-test-${{ matrix.name }}-${{ github.sha }}
|
key: v4-test-${{ matrix.name }}-${{ github.sha }}
|
||||||
restore-keys: |
|
restore-keys: |
|
||||||
v3-test-${{ matrix.name }}-
|
v4-test-${{ matrix.name }}-
|
||||||
|
|
||||||
- name: Prepare environment
|
- name: Prepare environment
|
||||||
run: |
|
run: |
|
||||||
@ -597,7 +423,13 @@ jobs:
|
|||||||
|
|
||||||
- name: Install dev dependencies
|
- name: Install dev dependencies
|
||||||
run: |
|
run: |
|
||||||
python3 -m pip install conan==1.53.0
|
python3 -m pip install "conan<2.0.0"
|
||||||
|
|
||||||
|
# workaround for issue that GitHub Actions seems to not adding it to PATH after https://github.com/actions/runner-images/pull/6499
|
||||||
|
# and that's why CI cannot find conan executable installed above
|
||||||
|
if [[ "${RUNNER_OS}" == "macOS" ]]; then
|
||||||
|
echo "/Library/Frameworks/Python.framework/Versions/Current/bin" >> $GITHUB_PATH
|
||||||
|
fi
|
||||||
|
|
||||||
# ccache
|
# ccache
|
||||||
if [[ "${RUNNER_OS}" == "Linux" ]]; then
|
if [[ "${RUNNER_OS}" == "Linux" ]]; then
|
||||||
@ -609,6 +441,12 @@ jobs:
|
|||||||
# clang
|
# clang
|
||||||
if [[ "${CCOMPILER}" == "clang-6.0" ]]; then
|
if [[ "${CCOMPILER}" == "clang-6.0" ]]; then
|
||||||
sudo apt-get update -y && sudo apt-get install clang++-6
|
sudo apt-get update -y && sudo apt-get install clang++-6
|
||||||
|
elif [[ "${CCOMPILER}" == "clang-15" ]]; then
|
||||||
|
wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | sudo apt-key add -
|
||||||
|
sudo apt-get update -y && sudo apt-get install software-properties-common
|
||||||
|
sudo add-apt-repository 'deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-15 main'
|
||||||
|
sudo apt-get update -y && sudo apt-get install clang++-15 clang-tidy-15
|
||||||
|
sudo update-alternatives --install /usr/bin/clang-tidy clang-tidy /usr/bin/clang-tidy-15 100000
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Linux dev packages
|
# Linux dev packages
|
||||||
@ -637,7 +475,6 @@ jobs:
|
|||||||
tar zxvf onetbb.tgz
|
tar zxvf onetbb.tgz
|
||||||
sudo cp -a oneapi-tbb-${TBB_VERSION}/lib/. /usr/local/lib/
|
sudo cp -a oneapi-tbb-${TBB_VERSION}/lib/. /usr/local/lib/
|
||||||
sudo cp -a oneapi-tbb-${TBB_VERSION}/include/. /usr/local/include/
|
sudo cp -a oneapi-tbb-${TBB_VERSION}/include/. /usr/local/include/
|
||||||
|
|
||||||
- name: Prepare build
|
- name: Prepare build
|
||||||
run: |
|
run: |
|
||||||
mkdir ${OSRM_BUILD_DIR}
|
mkdir ${OSRM_BUILD_DIR}
|
||||||
@ -729,10 +566,38 @@ jobs:
|
|||||||
./src/benchmarks/packedvector-bench
|
./src/benchmarks/packedvector-bench
|
||||||
./src/benchmarks/rtree-bench ../test/data/monaco.osrm.ramIndex ../test/data/monaco.osrm.fileIndex ../test/data/monaco.osrm.nbg_nodes
|
./src/benchmarks/rtree-bench ../test/data/monaco.osrm.ramIndex ../test/data/monaco.osrm.fileIndex ../test/data/monaco.osrm.nbg_nodes
|
||||||
popd
|
popd
|
||||||
- name: Run Node package tests only
|
|
||||||
|
- name: Use Node 16
|
||||||
|
if: ${{ matrix.NODE_PACKAGE_TESTS_ONLY == 'ON' && matrix.ENABLE_APPLE_SILICON != 'ON' }}
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
- name: Run Node package tests on Node 16
|
||||||
if: ${{ matrix.NODE_PACKAGE_TESTS_ONLY == 'ON' && matrix.ENABLE_APPLE_SILICON != 'ON' }}
|
if: ${{ matrix.NODE_PACKAGE_TESTS_ONLY == 'ON' && matrix.ENABLE_APPLE_SILICON != 'ON' }}
|
||||||
run: |
|
run: |
|
||||||
|
node --version
|
||||||
npm run nodejs-tests
|
npm run nodejs-tests
|
||||||
|
- name: Use Node 18
|
||||||
|
if: ${{ matrix.NODE_PACKAGE_TESTS_ONLY == 'ON' && matrix.ENABLE_APPLE_SILICON != 'ON' }}
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 18
|
||||||
|
- name: Run Node package tests on Node 18
|
||||||
|
if: ${{ matrix.NODE_PACKAGE_TESTS_ONLY == 'ON' && matrix.ENABLE_APPLE_SILICON != 'ON' }}
|
||||||
|
run: |
|
||||||
|
node --version
|
||||||
|
npm run nodejs-tests
|
||||||
|
- name: Use Node latest
|
||||||
|
if: ${{ matrix.NODE_PACKAGE_TESTS_ONLY == 'ON' && matrix.ENABLE_APPLE_SILICON != 'ON' }}
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: latest
|
||||||
|
- name: Run Node package tests on Node-latest
|
||||||
|
if: ${{ matrix.NODE_PACKAGE_TESTS_ONLY == 'ON' && matrix.ENABLE_APPLE_SILICON != 'ON' }}
|
||||||
|
run: |
|
||||||
|
node --version
|
||||||
|
npm run nodejs-tests
|
||||||
|
|
||||||
- name: Upload test logs
|
- name: Upload test logs
|
||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
if: failure()
|
if: failure()
|
||||||
@ -783,6 +648,6 @@ jobs:
|
|||||||
|
|
||||||
ci-complete:
|
ci-complete:
|
||||||
runs-on: ubuntu-22.04
|
runs-on: ubuntu-22.04
|
||||||
needs: [build-test-publish, docker-image, routed-js, windows]
|
needs: [build-test-publish, docker-image, routed-js, windows-release-node]
|
||||||
steps:
|
steps:
|
||||||
- run: echo "CI complete"
|
- run: echo "CI complete"
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -105,3 +105,4 @@ debug.lua
|
|||||||
|
|
||||||
# node-osrm artifacts
|
# node-osrm artifacts
|
||||||
lib/binding
|
lib/binding
|
||||||
|
|
||||||
|
30
CHANGELOG.md
30
CHANGELOG.md
@ -1,9 +1,39 @@
|
|||||||
# Unreleased
|
# Unreleased
|
||||||
- Changes from 5.27.1
|
- Changes from 5.27.1
|
||||||
|
- Features
|
||||||
|
- ADDED: Add support for a default_radius flag. [#6575](https://github.com/Project-OSRM/osrm-backend/pull/6575)
|
||||||
|
- ADDED: Add support for disabling feature datasets. [#6666](https://github.com/Project-OSRM/osrm-backend/pull/6666)
|
||||||
|
- Build:
|
||||||
|
- ADDED: Add CI job which builds OSRM with gcc 12. [#6455](https://github.com/Project-OSRM/osrm-backend/pull/6455)
|
||||||
|
- CHANGED: Upgrade to clang-tidy 15. [#6439](https://github.com/Project-OSRM/osrm-backend/pull/6439)
|
||||||
|
- CHANGED: Update actions/cache to v3. [#6420](https://github.com/Project-OSRM/osrm-backend/pull/6420)
|
||||||
|
- REMOVED: Drop support of Node 12 & 14. [#6431](https://github.com/Project-OSRM/osrm-backend/pull/6431)
|
||||||
|
- ADDED: Add 'load directly' mode to default Cucumber test suite. [#6663](https://github.com/Project-OSRM/osrm-backend/pull/6663)
|
||||||
|
- NodeJS:
|
||||||
|
- CHANGED: Use node-api instead of NAN. [#6452](https://github.com/Project-OSRM/osrm-backend/pull/6452)
|
||||||
- Misc:
|
- Misc:
|
||||||
|
- FIXED: Fix an error in a RouteParameters AnnotationsType operator overload. [#6646](https://github.com/Project-OSRM/osrm-backend/pull/6646)
|
||||||
|
- ADDED: Add support for "unlimited" to be passed as a value for the default-radius and max-matching-radius flags. [#6599](https://github.com/Project-OSRM/osrm-backend/pull/6599)
|
||||||
|
- CHANGED: Allow -1.0 as unlimited for default_radius value. [#6599](https://github.com/Project-OSRM/osrm-backend/pull/6599)
|
||||||
|
- CHANGED: keep libosrm* in the docker image for downstream linking [#6602](https://github.com/Project-OSRM/osrm-backend/pull/6602)
|
||||||
|
- CHANGED: Move vector in CSVFilesParser instead copying it. [#6470](https://github.com/Project-OSRM/osrm-backend/pull/6470)
|
||||||
|
- REMOVED: Get rid of unused functions in util/json_util.hpp. [#6446](https://github.com/Project-OSRM/osrm-backend/pull/6446)
|
||||||
|
- FIXED: Apply workaround for Conan installation issue on CI. [#6442](https://github.com/Project-OSRM/osrm-backend/pull/6442)
|
||||||
|
- FIXED: Fix `npm audit` warnings in NPM package. [#6437](https://github.com/Project-OSRM/osrm-backend/pull/6437)
|
||||||
- FIXED: Handle snapping parameter for all plugins in NodeJs bindings, but not for Route only. [#6417](https://github.com/Project-OSRM/osrm-backend/pull/6417)
|
- FIXED: Handle snapping parameter for all plugins in NodeJs bindings, but not for Route only. [#6417](https://github.com/Project-OSRM/osrm-backend/pull/6417)
|
||||||
- FIXED: Fix annotations=true handling in NodeJS bindings & libosrm. [#6415](https://github.com/Project-OSRM/osrm-backend/pull/6415/)
|
- FIXED: Fix annotations=true handling in NodeJS bindings & libosrm. [#6415](https://github.com/Project-OSRM/osrm-backend/pull/6415/)
|
||||||
- FIXED: Fix bindings compilation issue on the latest Node. Update NAN to 2.17.0. [#6416](https://github.com/Project-OSRM/osrm-backend/pull/6416)
|
- FIXED: Fix bindings compilation issue on the latest Node. Update NAN to 2.17.0. [#6416](https://github.com/Project-OSRM/osrm-backend/pull/6416)
|
||||||
|
- CHANGED: Make edge metrics strongly typed [#6420](https://github.com/Project-OSRM/osrm-backend/pull/6420)
|
||||||
|
- FIXED: Typo in file name src/util/timed_historgram.cpp -> src/util/timed_histogram.cpp [#6428](https://github.com/Project-OSRM/osrm-backend/issues/6428)
|
||||||
|
- CHANGED: Replace boost::string_ref with std::string_view [#6433](https://github.com/Project-OSRM/osrm-backend/pull/6433)
|
||||||
|
- ADDED: Print tracebacks for Lua runtime errors [#6564](https://github.com/Project-OSRM/osrm-backend/pull/6564)
|
||||||
|
- FIXED: Added a variable to preprocessor guard in file osrm-backend/include/util/range_table.hpp to solve build error. [#6596](https://github.com/Project-OSRM/osrm-backend/pull/6596)
|
||||||
|
- FIXED: Ensure required file check in osrm-routed is correctly enforced. [#6655](https://github.com/Project-OSRM/osrm-backend/pull/6655)
|
||||||
|
- FIXED: Correct HTTP docs to reflect summary output dependency on steps parameter. [#6655](https://github.com/Project-OSRM/osrm-backend/pull/6655)
|
||||||
|
- Profiles:
|
||||||
|
- FIXED: Bicycle and foot profiles now don't route on proposed ways [#6615](https://github.com/Project-OSRM/osrm-backend/pull/6615)
|
||||||
|
- Routing:
|
||||||
|
- FIXED: Fix adding traffic signal penalties during compression [#6419](https://github.com/Project-OSRM/osrm-backend/pull/6419)
|
||||||
# 5.27.1
|
# 5.27.1
|
||||||
- Changes from 5.27.0
|
- Changes from 5.27.0
|
||||||
- Misc:
|
- Misc:
|
||||||
|
185
CMakeLists.txt
185
CMakeLists.txt
@ -1,8 +1,8 @@
|
|||||||
cmake_minimum_required(VERSION 3.2)
|
cmake_minimum_required(VERSION 3.18)
|
||||||
|
|
||||||
set(CMAKE_CXX_STANDARD 17)
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED TRUE)
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
set(CMAKE_CXX_EXTENSIONS OFF)
|
||||||
|
|
||||||
if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR AND NOT MSVC_IDE)
|
if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR AND NOT MSVC_IDE)
|
||||||
message(FATAL_ERROR "In-source builds are not allowed.
|
message(FATAL_ERROR "In-source builds are not allowed.
|
||||||
@ -33,7 +33,6 @@ option(ENABLE_COVERAGE "Build with coverage instrumentalisation" OFF)
|
|||||||
option(ENABLE_SANITIZER "Use memory sanitizer for Debug build" OFF)
|
option(ENABLE_SANITIZER "Use memory sanitizer for Debug build" OFF)
|
||||||
option(ENABLE_LTO "Use LTO if available" OFF)
|
option(ENABLE_LTO "Use LTO if available" OFF)
|
||||||
option(ENABLE_FUZZING "Fuzz testing using LLVM's libFuzzer" OFF)
|
option(ENABLE_FUZZING "Fuzz testing using LLVM's libFuzzer" OFF)
|
||||||
option(ENABLE_GOLD_LINKER "Use GNU gold linker if available" ON)
|
|
||||||
option(ENABLE_NODE_BINDINGS "Build NodeJs bindings" OFF)
|
option(ENABLE_NODE_BINDINGS "Build NodeJs bindings" OFF)
|
||||||
option(ENABLE_CLANG_TIDY "Enables clang-tidy checks" OFF)
|
option(ENABLE_CLANG_TIDY "Enables clang-tidy checks" OFF)
|
||||||
|
|
||||||
@ -113,29 +112,12 @@ include(CheckCXXCompilerFlag)
|
|||||||
include(FindPackageHandleStandardArgs)
|
include(FindPackageHandleStandardArgs)
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
|
|
||||||
set(bitness 32)
|
|
||||||
if(CMAKE_SIZEOF_VOID_P EQUAL 8)
|
if(CMAKE_SIZEOF_VOID_P EQUAL 8)
|
||||||
set(bitness 64)
|
|
||||||
message(STATUS "Building on a 64 bit system")
|
message(STATUS "Building on a 64 bit system")
|
||||||
else()
|
else()
|
||||||
message(STATUS "Building on a 32 bit system")
|
message(STATUS "Building on a 32 bit system")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WIN32 AND MSVC_VERSION LESS 1900)
|
|
||||||
message(FATAL_ERROR "Building with Microsoft compiler needs Latest Visual Studio 2015 (Community or better)")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Strictly require GCC>=5.0 and Clang>=3.4 - GCC 4.8 is already too old for C++14.
|
|
||||||
if(CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
|
||||||
if(CMAKE_CXX_COMPILER_VERSION VERSION_LESS 5.0)
|
|
||||||
message(FATAL_ERROR "GCC>=5.0 required. In case you are on Ubuntu upgrade via ppa:ubuntu-toolchain-r/test")
|
|
||||||
endif()
|
|
||||||
elseif(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|
||||||
if(CMAKE_CXX_COMPILER_VERSION VERSION_LESS 3.4)
|
|
||||||
message(FATAL_ERROR "Clang>=3.4 required. In case you are on Ubuntu upgrade via http://apt.llvm.org")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR}/include/)
|
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR}/include/)
|
||||||
include_directories(BEFORE ${CMAKE_CURRENT_SOURCE_DIR}/include/)
|
include_directories(BEFORE ${CMAKE_CURRENT_SOURCE_DIR}/include/)
|
||||||
include_directories(SYSTEM ${CMAKE_CURRENT_SOURCE_DIR}/third_party/sol2-3.3.0/include)
|
include_directories(SYSTEM ${CMAKE_CURRENT_SOURCE_DIR}/third_party/sol2-3.3.0/include)
|
||||||
@ -190,26 +172,6 @@ add_library(osrm_customize src/osrm/customizer.cpp $<TARGET_OBJECTS:CUSTOMIZER>
|
|||||||
add_library(osrm_update $<TARGET_OBJECTS:UPDATER> $<TARGET_OBJECTS:MICROTAR> $<TARGET_OBJECTS:UTIL>)
|
add_library(osrm_update $<TARGET_OBJECTS:UPDATER> $<TARGET_OBJECTS:MICROTAR> $<TARGET_OBJECTS:UTIL>)
|
||||||
add_library(osrm_store $<TARGET_OBJECTS:STORAGE> $<TARGET_OBJECTS:MICROTAR> $<TARGET_OBJECTS:UTIL>)
|
add_library(osrm_store $<TARGET_OBJECTS:STORAGE> $<TARGET_OBJECTS:MICROTAR> $<TARGET_OBJECTS:UTIL>)
|
||||||
|
|
||||||
if(ENABLE_GOLD_LINKER)
|
|
||||||
execute_process(COMMAND ${CMAKE_C_COMPILER} -fuse-ld=gold -Wl,--version ERROR_QUIET OUTPUT_VARIABLE LD_VERSION)
|
|
||||||
if("${LD_VERSION}" MATCHES "GNU gold")
|
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fuse-ld=gold -Wl,--disable-new-dtags")
|
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -fuse-ld=gold -Wl,--disable-new-dtags")
|
|
||||||
set(OSRM_LDFLAGS "${OSRM_LDFLAGS} -fuse-ld=gold -Wl,--disable-new-dtags")
|
|
||||||
message(STATUS "Using GNU gold as linker.")
|
|
||||||
|
|
||||||
# Issue 2785: check gold binutils version and don't use gc-sections for versions prior 2.25
|
|
||||||
string(REGEX REPLACE ".*\\(GNU Binutils[^\\)0-9]+([0-9]+\\.[0-9]+)[^\\)]*\\).*" "\\1" GOLD_BINUTILS_VERSION "${LD_VERSION}")
|
|
||||||
if ("${GOLD_BINUTILS_VERSION}" VERSION_LESS "2.26")
|
|
||||||
message(STATUS "Disabling gc-sections on gold binutils < 2.26, see: https://sourceware.org/bugzilla/show_bug.cgi?id=17639")
|
|
||||||
set(LD_AVOID_GC_SECTIONS TRUE)
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
message(WARNING "GNU gold linker isn't available.")
|
|
||||||
set(ENABLE_GOLD_LINKER OFF)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Explicitly set the build type to Release if no other type is specified
|
# Explicitly set the build type to Release if no other type is specified
|
||||||
# on the command line. Without this, cmake defaults to an unoptimized,
|
# on the command line. Without this, cmake defaults to an unoptimized,
|
||||||
# non-debug build, which almost nobody wants.
|
# non-debug build, which almost nobody wants.
|
||||||
@ -247,74 +209,17 @@ if(CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
|||||||
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Og -ggdb")
|
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Og -ggdb")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(ENABLE_LTO AND (CMAKE_BUILD_TYPE MATCHES Release OR CMAKE_BUILD_TYPE MATCHES MinRelSize OR CMAKE_BUILD_TYPE MATCHES RelWithDebInfo))
|
||||||
if(CMAKE_BUILD_TYPE MATCHES Release OR CMAKE_BUILD_TYPE MATCHES MinRelSize OR CMAKE_BUILD_TYPE MATCHES RelWithDebInfo)
|
include(CheckIPOSupported)
|
||||||
message(STATUS "Configuring release mode optimizations")
|
check_ipo_supported(RESULT LTO_SUPPORTED OUTPUT error)
|
||||||
# Check if LTO is available
|
if(LTO_SUPPORTED)
|
||||||
check_cxx_compiler_flag("-Wl,-flto" LTO_AVAILABLE)
|
message(STATUS "IPO / LTO enabled")
|
||||||
|
set(CMAKE_INTERPROCEDURAL_OPTIMIZATION TRUE)
|
||||||
if(ENABLE_LTO AND LTO_AVAILABLE)
|
else()
|
||||||
set(OLD_CXX_FLAGS ${CMAKE_CXX_FLAGS})
|
message(WARNING "IPO / LTO not supported: <${error}>")
|
||||||
# GCC in addition allows parallelizing LTO
|
|
||||||
if(CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
|
||||||
include(ProcessorCount)
|
|
||||||
ProcessorCount(NPROC)
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -flto=${NPROC}")
|
|
||||||
else()
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -flto")
|
|
||||||
endif()
|
|
||||||
set(CHECK_LTO_SRC "int main(){return 0;}")
|
|
||||||
check_cxx_source_compiles("${CHECK_LTO_SRC}" LTO_WORKS)
|
|
||||||
if(LTO_WORKS)
|
|
||||||
message(STATUS "LTO working")
|
|
||||||
set(OSRM_CXXFLAGS "${OSRM_CXXFLAGS} -flto")
|
|
||||||
set(OSRM_LDFLAGS "${OSRM_LDFLAGS} -flto")
|
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -flto")
|
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -flto")
|
|
||||||
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -flto")
|
|
||||||
else()
|
|
||||||
message(STATUS "LTO broken")
|
|
||||||
set(CMAKE_CXX_FLAGS "${OLD_CXX_FLAGS}")
|
|
||||||
set(ENABLE_LTO Off)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Since gcc 4.9 the LTO format is non-standart ('slim'), so we need to use the build-in tools
|
|
||||||
if(CMAKE_CXX_COMPILER_ID MATCHES "GNU" AND NOT MINGW)
|
|
||||||
find_program(GCC_AR gcc-ar)
|
|
||||||
find_program(GCC_RANLIB gcc-ranlib)
|
|
||||||
if ("${GCC_AR}" STREQUAL "GCC_AR-NOTFOUND" OR "${GCC_RANLIB}" STREQUAL "GCC_RANLIB-NOTFOUND")
|
|
||||||
message(WARNING "GCC specific binutils not found. In case of linker issues export env vars: AR=gcc-ar, NM=gcc-nm, RANLIB=gcc-ranlib")
|
|
||||||
else()
|
|
||||||
message(STATUS "Using GCC specific binutils for LTO:")
|
|
||||||
message(STATUS " ${GCC_AR}")
|
|
||||||
message(STATUS " ${GCC_RANLIB}")
|
|
||||||
set(CMAKE_AR ${GCC_AR})
|
|
||||||
set(CMAKE_RANLIB ${GCC_RANLIB})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Same for clang LTO requires their own toolchain
|
|
||||||
if(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|
||||||
find_program(LLVM_AR llvm-ar)
|
|
||||||
find_program(LLVM_RANLIB llvm-ranlib)
|
|
||||||
if ("${LLVM_AR}" STREQUAL "LLVM_AR-NOTFOUND" OR "${LLVM_RANLIB}" STREQUAL "LLVM_RANLIB-NOTFOUND")
|
|
||||||
message(WARNING "LLVM specific binutils not found.")
|
|
||||||
else()
|
|
||||||
message(STATUS "Using LLVM specific binutils for LTO:")
|
|
||||||
message(STATUS " ${LLVM_AR}")
|
|
||||||
message(STATUS " ${LLVM_RANLIB}")
|
|
||||||
set(CMAKE_AR ${LLVM_AR})
|
|
||||||
set(CMAKE_RANLIB ${LLVM_RANLIB})
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# TODO: this was added for Mason, we are not sure if it is true after migration to Conan
|
|
||||||
if(UNIX AND NOT APPLE AND ENABLE_CONAN AND (LTO_WORKS OR ENABLE_GOLD_LINKER))
|
|
||||||
message(WARNING "ENABLE_CONAN and ENABLE_LTO/ENABLE_GOLD_LINKER may not work on all linux systems currently")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(MAYBE_COVERAGE_LIBRARIES "")
|
set(MAYBE_COVERAGE_LIBRARIES "")
|
||||||
if (ENABLE_COVERAGE)
|
if (ENABLE_COVERAGE)
|
||||||
if (NOT CMAKE_BUILD_TYPE MATCHES "Debug")
|
if (NOT CMAKE_BUILD_TYPE MATCHES "Debug")
|
||||||
@ -352,14 +257,6 @@ elseif(CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
|||||||
add_dependency_defines(-DWIN32)
|
add_dependency_defines(-DWIN32)
|
||||||
set(OPTIONAL_SOCKET_LIBS ws2_32 wsock32)
|
set(OPTIONAL_SOCKET_LIBS ws2_32 wsock32)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# -fpermissive is required for parallel_do Intel TBB internal issue with GCC < 5
|
|
||||||
# https://github.com/Project-OSRM/osrm-backend/pull/3603#issuecomment-277688589
|
|
||||||
if(CMAKE_CXX_COMPILER_VERSION VERSION_LESS 5.0)
|
|
||||||
message(STATUS "Adding -fpermissive for GCC version < 5 bug (https://gcc.gnu.org/bugzilla/show_bug.cgi?id=51048). See #3603.")
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fpermissive")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
elseif(CMAKE_CXX_COMPILER_ID MATCHES "Intel")
|
elseif(CMAKE_CXX_COMPILER_ID MATCHES "Intel")
|
||||||
# using Intel C++
|
# using Intel C++
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -static-intel -wd10237 -Wall -ipo -fPIC")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -static-intel -wd10237 -Wall -ipo -fPIC")
|
||||||
@ -377,50 +274,11 @@ elseif(CMAKE_CXX_COMPILER_ID MATCHES "MSVC")
|
|||||||
target_link_libraries(osrm-extract wsock32 ws2_32)
|
target_link_libraries(osrm-extract wsock32 ws2_32)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Configuring linker
|
|
||||||
execute_process(COMMAND ${CMAKE_CXX_COMPILER} "-Wl,--version" ERROR_QUIET OUTPUT_VARIABLE LINKER_VERSION)
|
|
||||||
# For ld.gold and ld.bfs (the GNU linkers) we optimize hard
|
|
||||||
if("${LINKER_VERSION}" MATCHES "GNU gold" OR "${LINKER_VERSION}" MATCHES "GNU ld")
|
|
||||||
message(STATUS "Setting linker optimizations")
|
|
||||||
if(NOT (CMAKE_CXX_COMPILER_ID MATCHES "MSVC" OR "${LD_AVOID_GC_SECTIONS}"))
|
|
||||||
# Tell compiler to put every function in separate section, linker can then match sections and functions
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ffunction-sections -fdata-sections")
|
|
||||||
# Tell linker to do dead code and data eminination during link time discarding sections
|
|
||||||
set(LINKER_FLAGS "${LINKER_FLAGS} -Wl,--gc-sections")
|
|
||||||
endif()
|
|
||||||
# Default linker optimization flags
|
|
||||||
set(LINKER_FLAGS "${LINKER_FLAGS} -Wl,-O1 -Wl,--hash-style=gnu -Wl,--sort-common")
|
|
||||||
|
|
||||||
else()
|
|
||||||
message(STATUS "Using unknown linker, not setting linker optimizations")
|
|
||||||
endif ()
|
|
||||||
set(OSRM_LDFLAGS "${OSRM_LDFLAGS} ${LINKER_FLAGS}")
|
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${LINKER_FLAGS}")
|
|
||||||
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} ${LINKER_FLAGS}")
|
|
||||||
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} ${LINKER_FLAGS}")
|
|
||||||
|
|
||||||
# Activate C++1y
|
|
||||||
if(NOT CMAKE_CXX_COMPILER_ID MATCHES "MSVC")
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++17")
|
|
||||||
set(OSRM_CXXFLAGS "${OSRM_CXXFLAGS} -std=c++17")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Configuring other platform dependencies
|
|
||||||
if(APPLE)
|
|
||||||
execute_process(COMMAND xcrun --sdk macosx --show-sdk-path OUTPUT_VARIABLE CMAKE_OSX_SYSROOT OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
||||||
exec_program(uname ARGS -v OUTPUT_VARIABLE DARWIN_VERSION)
|
|
||||||
string(REGEX MATCH "[0-9]+" DARWIN_VERSION ${DARWIN_VERSION})
|
|
||||||
if(OSXLIBSTD)
|
|
||||||
message(STATUS "linking against ${OSXLIBSTD}")
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -stdlib=${OSXLIBSTD}")
|
|
||||||
elseif(DARWIN_VERSION GREATER 12)
|
|
||||||
message(STATUS "linking against libc++")
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -stdlib=libc++")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
set(MAYBE_RT_LIBRARY -lrt)
|
find_library(RT_LIB rt)
|
||||||
|
if (RT_LIB)
|
||||||
|
set(MAYBE_RT_LIBRARY -lrt)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
find_package(Threads REQUIRED)
|
find_package(Threads REQUIRED)
|
||||||
@ -432,11 +290,6 @@ include_directories(SYSTEM ${RAPIDJSON_INCLUDE_DIR})
|
|||||||
set(MICROTAR_INCLUDE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/third_party/microtar/src")
|
set(MICROTAR_INCLUDE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/third_party/microtar/src")
|
||||||
include_directories(SYSTEM ${MICROTAR_INCLUDE_DIR})
|
include_directories(SYSTEM ${MICROTAR_INCLUDE_DIR})
|
||||||
|
|
||||||
set(MBXGEOM_INCLUDE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/third_party/geometry.hpp-0.9.2/include")
|
|
||||||
include_directories(SYSTEM ${MBXGEOM_INCLUDE_DIR})
|
|
||||||
set(CHEAPRULER_INCLUDE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/third_party/cheap-ruler-cpp-2778eb8/include")
|
|
||||||
include_directories(SYSTEM ${CHEAPRULER_INCLUDE_DIR})
|
|
||||||
|
|
||||||
add_library(MICROTAR OBJECT "${CMAKE_CURRENT_SOURCE_DIR}/third_party/microtar/src/microtar.c")
|
add_library(MICROTAR OBJECT "${CMAKE_CURRENT_SOURCE_DIR}/third_party/microtar/src/microtar.c")
|
||||||
set_property(TARGET MICROTAR PROPERTY POSITION_INDEPENDENT_CODE ON)
|
set_property(TARGET MICROTAR PROPERTY POSITION_INDEPENDENT_CODE ON)
|
||||||
target_no_warning(MICROTAR unused-variable)
|
target_no_warning(MICROTAR unused-variable)
|
||||||
@ -550,12 +403,7 @@ if(ENABLE_CONAN)
|
|||||||
# expat and bzip2 are used from conan rather than the system
|
# expat and bzip2 are used from conan rather than the system
|
||||||
include_directories(SYSTEM ${CMAKE_CURRENT_SOURCE_DIR}/third_party/libosmium/include)
|
include_directories(SYSTEM ${CMAKE_CURRENT_SOURCE_DIR}/third_party/libosmium/include)
|
||||||
else()
|
else()
|
||||||
if (BUILD_ROUTED)
|
find_package(Boost 1.70 REQUIRED COMPONENTS ${BOOST_COMPONENTS})
|
||||||
# osrm-routed requires newer boost:asio
|
|
||||||
find_package(Boost 1.70 REQUIRED COMPONENTS ${BOOST_COMPONENTS})
|
|
||||||
else()
|
|
||||||
find_package(Boost 1.60 REQUIRED COMPONENTS ${BOOST_COMPONENTS})
|
|
||||||
endif()
|
|
||||||
add_dependency_includes(${Boost_INCLUDE_DIRS})
|
add_dependency_includes(${Boost_INCLUDE_DIRS})
|
||||||
|
|
||||||
find_package(TBB REQUIRED)
|
find_package(TBB REQUIRED)
|
||||||
@ -602,7 +450,6 @@ if(ENABLE_CCACHE AND (CMAKE_CXX_COMPILER_ID MATCHES "Clang" OR CMAKE_CXX_COMPILE
|
|||||||
message(STATUS "Using ccache to speed up incremental builds")
|
message(STATUS "Using ccache to speed up incremental builds")
|
||||||
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache)
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache)
|
||||||
set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ccache)
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ccache)
|
||||||
set(ENV{CCACHE_CPP2} "true")
|
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
14
README.md
14
README.md
@ -1,10 +1,9 @@
|
|||||||
## Open Source Routing Machine
|
## Open Source Routing Machine
|
||||||
|
|
||||||
| Linux / macOS / Windows | Code Coverage |
|
|
||||||
| ----------------------- | ------------- |
|
|
||||||
| [data:image/s3,"s3://crabby-images/000eb/000ebe04b3b032388b7abdc327a1e503570e5c40" alt="osrm-backend CI"](https://github.com/Project-OSRM/osrm-backend/actions/workflows/osrm-backend.yml) | [data:image/s3,"s3://crabby-images/305cd/305cde59bc2d9b7190b448ceb110a2614561694a" alt="Codecov"](https://codecov.io/gh/Project-OSRM/osrm-backend) |
|
|
||||||
|
|
||||||
High performance routing engine written in C++14 designed to run on OpenStreetMap data.
|
[data:image/s3,"s3://crabby-images/000eb/000ebe04b3b032388b7abdc327a1e503570e5c40" alt="osrm-backend CI"](https://github.com/Project-OSRM/osrm-backend/actions/workflows/osrm-backend.yml) [data:image/s3,"s3://crabby-images/305cd/305cde59bc2d9b7190b448ceb110a2614561694a" alt="Codecov"](https://codecov.io/gh/Project-OSRM/osrm-backend) [data:image/s3,"s3://crabby-images/c2278/c227856b96cebcf36e40ed5ee1ad38a6405d580a" alt="Discord"](https://discord.gg/es9CdcCXcb)
|
||||||
|
|
||||||
|
High performance routing engine written in C++ designed to run on OpenStreetMap data.
|
||||||
|
|
||||||
The following services are available via HTTP API, C++ library interface and NodeJs wrapper:
|
The following services are available via HTTP API, C++ library interface and NodeJs wrapper:
|
||||||
- Nearest - Snaps coordinates to the street network and returns the nearest matches
|
- Nearest - Snaps coordinates to the street network and returns the nearest matches
|
||||||
@ -33,6 +32,7 @@ Related [Project-OSRM](https://github.com/Project-OSRM) repositories:
|
|||||||
|
|
||||||
## Contact
|
## Contact
|
||||||
|
|
||||||
|
- Discord: [join](https://discord.gg/es9CdcCXcb)
|
||||||
- IRC: `irc.oftc.net`, channel: `#osrm` ([Webchat](https://webchat.oftc.net))
|
- IRC: `irc.oftc.net`, channel: `#osrm` ([Webchat](https://webchat.oftc.net))
|
||||||
- Mailinglist: `https://lists.openstreetmap.org/listinfo/osrm-talk`
|
- Mailinglist: `https://lists.openstreetmap.org/listinfo/osrm-talk`
|
||||||
|
|
||||||
@ -58,12 +58,12 @@ Download OpenStreetMap extracts for example from [Geofabrik](http://download.geo
|
|||||||
|
|
||||||
Pre-process the extract with the car profile and start a routing engine HTTP server on port 5000
|
Pre-process the extract with the car profile and start a routing engine HTTP server on port 5000
|
||||||
|
|
||||||
docker run -t -v "${PWD}:/data" ghcr.io/project-osrm/osrm-backend osrm-extract -p /opt/car.lua /data/berlin-latest.osm.pbf
|
docker run -t -v "${PWD}:/data" ghcr.io/project-osrm/osrm-backend osrm-extract -p /opt/car.lua /data/berlin-latest.osm.pbf || echo "osrm-extract failed"
|
||||||
|
|
||||||
The flag `-v "${PWD}:/data"` creates the directory `/data` inside the docker container and makes the current working directory `"${PWD}"` available there. The file `/data/berlin-latest.osm.pbf` inside the container is referring to `"${PWD}/berlin-latest.osm.pbf"` on the host.
|
The flag `-v "${PWD}:/data"` creates the directory `/data` inside the docker container and makes the current working directory `"${PWD}"` available there. The file `/data/berlin-latest.osm.pbf` inside the container is referring to `"${PWD}/berlin-latest.osm.pbf"` on the host.
|
||||||
|
|
||||||
docker run -t -v "${PWD}:/data" ghcr.io/project-osrm/osrm-backend osrm-partition /data/berlin-latest.osrm
|
docker run -t -v "${PWD}:/data" ghcr.io/project-osrm/osrm-backend osrm-partition /data/berlin-latest.osrm || echo "osrm-partition failed"
|
||||||
docker run -t -v "${PWD}:/data" ghcr.io/project-osrm/osrm-backend osrm-customize /data/berlin-latest.osrm
|
docker run -t -v "${PWD}:/data" ghcr.io/project-osrm/osrm-backend osrm-customize /data/berlin-latest.osrm || echo "osrm-customize failed"
|
||||||
|
|
||||||
Note there is no `berlin-latest.osrm` file, but multiple `berlin-latest.osrm.*` files, i.e. `berlin-latest.osrm` is not file path, but "base" path referring to set of files and there is an option to omit this `.osrm` suffix completely(e.g. `osrm-partition /data/berlin-latest`).
|
Note there is no `berlin-latest.osrm` file, but multiple `berlin-latest.osrm.*` files, i.e. `berlin-latest.osrm` is not file path, but "base" path referring to set of files and there is an option to omit this `.osrm` suffix completely(e.g. `osrm-partition /data/berlin-latest`).
|
||||||
|
|
||||||
|
@ -1,75 +0,0 @@
|
|||||||
{
|
|
||||||
"AWSTemplateFormatVersion": "2010-09-09",
|
|
||||||
"Description": "user for publishing to s3://mapbox-node-binary/osrm",
|
|
||||||
"Resources": {
|
|
||||||
"User": {
|
|
||||||
"Type": "AWS::IAM::User",
|
|
||||||
"Properties": {
|
|
||||||
"Policies": [
|
|
||||||
{
|
|
||||||
"PolicyName": "list",
|
|
||||||
"PolicyDocument": {
|
|
||||||
"Statement": [
|
|
||||||
{
|
|
||||||
"Action": [
|
|
||||||
"s3:ListBucket"
|
|
||||||
],
|
|
||||||
"Effect": "Allow",
|
|
||||||
"Resource": "arn:aws:s3:::mapbox-node-binary",
|
|
||||||
"Condition": {
|
|
||||||
"StringLike": {
|
|
||||||
"s3:prefix": [
|
|
||||||
"osrm/*"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"PolicyName": "publish",
|
|
||||||
"PolicyDocument": {
|
|
||||||
"Statement": [
|
|
||||||
{
|
|
||||||
"Action": [
|
|
||||||
"s3:DeleteObject",
|
|
||||||
"s3:GetObject",
|
|
||||||
"s3:GetObjectAcl",
|
|
||||||
"s3:PutObject",
|
|
||||||
"s3:PutObjectAcl"
|
|
||||||
],
|
|
||||||
"Effect": "Allow",
|
|
||||||
"Resource": "arn:aws:s3:::mapbox-node-binary/osrm/*"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"AccessKey": {
|
|
||||||
"Type": "AWS::IAM::AccessKey",
|
|
||||||
"Properties": {
|
|
||||||
"UserName": {
|
|
||||||
"Ref": "User"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"Outputs": {
|
|
||||||
"AccessKeyId": {
|
|
||||||
"Value": {
|
|
||||||
"Ref": "AccessKey"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"SecretAccessKey": {
|
|
||||||
"Value": {
|
|
||||||
"Fn::GetAtt": [
|
|
||||||
"AccessKey",
|
|
||||||
"SecretAccessKey"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,59 +0,0 @@
|
|||||||
var cf = require('@mapbox/cloudfriend');
|
|
||||||
var package_json = require('../package.json')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
AWSTemplateFormatVersion: '2010-09-09',
|
|
||||||
Description: 'user for publishing to s3://mapbox-node-binary/' + package_json.name,
|
|
||||||
Resources: {
|
|
||||||
User: {
|
|
||||||
Type: 'AWS::IAM::User',
|
|
||||||
Properties: {
|
|
||||||
Policies: [
|
|
||||||
{
|
|
||||||
PolicyName: 'list',
|
|
||||||
PolicyDocument: {
|
|
||||||
Statement: [
|
|
||||||
{
|
|
||||||
Action: ['s3:ListBucket'],
|
|
||||||
Effect: 'Allow',
|
|
||||||
Resource: 'arn:aws:s3:::mapbox-node-binary',
|
|
||||||
Condition : {
|
|
||||||
StringLike : {
|
|
||||||
"s3:prefix": [ package_json.name + "/*"]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
PolicyName: 'publish',
|
|
||||||
PolicyDocument: {
|
|
||||||
Statement: [
|
|
||||||
{
|
|
||||||
Action: ['s3:DeleteObject', 's3:GetObject', 's3:GetObjectAcl', 's3:PutObject', 's3:PutObjectAcl'],
|
|
||||||
Effect: 'Allow',
|
|
||||||
Resource: 'arn:aws:s3:::mapbox-node-binary/' + package_json.name + '/*'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
AccessKey: {
|
|
||||||
Type: 'AWS::IAM::AccessKey',
|
|
||||||
Properties: {
|
|
||||||
UserName: cf.ref('User')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
Outputs: {
|
|
||||||
AccessKeyId: {
|
|
||||||
Value: cf.ref('AccessKey')
|
|
||||||
},
|
|
||||||
SecretAccessKey: {
|
|
||||||
Value: cf.getAtt('AccessKey', 'SecretAccessKey')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
@ -1,29 +0,0 @@
|
|||||||
# - Check whether the CXX compiler supports a given flag.
|
|
||||||
# CHECK_CXX_COMPILER_FLAG(<flag> <var>)
|
|
||||||
# <flag> - the compiler flag
|
|
||||||
# <var> - variable to store the result
|
|
||||||
# This internally calls the check_cxx_source_compiles macro. See help
|
|
||||||
# for CheckCXXSourceCompiles for a listing of variables that can
|
|
||||||
# modify the build.
|
|
||||||
|
|
||||||
# Copyright (c) 2006, Alexander Neundorf, <neundorf@kde.org>
|
|
||||||
#
|
|
||||||
# Redistribution and use is allowed according to the terms of the BSD license.
|
|
||||||
# For details see the accompanying COPYING-CMAKE-SCRIPTS file.
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE(CheckCXXSourceCompiles)
|
|
||||||
|
|
||||||
MACRO (CHECK_CXX_COMPILER_FLAG _FLAG _RESULT)
|
|
||||||
SET(SAFE_CMAKE_REQUIRED_DEFINITIONS "${CMAKE_REQUIRED_DEFINITIONS}")
|
|
||||||
SET(CMAKE_REQUIRED_DEFINITIONS "${_FLAG}")
|
|
||||||
CHECK_CXX_SOURCE_COMPILES("int main() { return 0;}" ${_RESULT}
|
|
||||||
# Some compilers do not fail with a bad flag
|
|
||||||
FAIL_REGEX "unrecognized .*option" # GNU
|
|
||||||
FAIL_REGEX "ignoring unknown option" # MSVC
|
|
||||||
FAIL_REGEX "[Uu]nknown option" # HP
|
|
||||||
FAIL_REGEX "[Ww]arning: [Oo]ption" # SunPro
|
|
||||||
FAIL_REGEX "command option .* is not recognized" # XL
|
|
||||||
)
|
|
||||||
SET (CMAKE_REQUIRED_DEFINITIONS "${SAFE_CMAKE_REQUIRED_DEFINITIONS}")
|
|
||||||
ENDMACRO (CHECK_CXX_COMPILER_FLAG)
|
|
@ -36,7 +36,10 @@
|
|||||||
# This is because, the lua location is not standardized and may exist in
|
# This is because, the lua location is not standardized and may exist in
|
||||||
# locations other than lua/
|
# locations other than lua/
|
||||||
|
|
||||||
include(FindPkgConfig)
|
if(NOT PKG_CONFIG_FOUND)
|
||||||
|
include(CMakeFindDependencyMacro)
|
||||||
|
find_dependency(PkgConfig)
|
||||||
|
endif()
|
||||||
|
|
||||||
unset(_lua_include_subdirs)
|
unset(_lua_include_subdirs)
|
||||||
unset(_lua_library_names)
|
unset(_lua_library_names)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# https://github.com/sbellus/json-cmake/blob/9913da8800b95322d393894d3525d634568f305e/JSONParser.cmake
|
# https://github.com/sbellus/json-cmake/blob/9913da8800b95322d393894d3525d634568f305e/JSONParser.cmake
|
||||||
# MIT Licensed - https://github.com/sbellus/json-cmake/blob/master/LICENSE
|
# MIT Licensed - https://github.com/sbellus/json-cmake/blob/master/LICENSE
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.1)
|
cmake_minimum_required(VERSION 3.18)
|
||||||
|
|
||||||
if (DEFINED JSonParserGuard)
|
if (DEFINED JSonParserGuard)
|
||||||
return()
|
return()
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
default: '--strict --tags ~@stress --tags ~@todo --tags ~@mld-only --require features/support --require features/step_definitions',
|
default: '--strict --tags ~@stress --tags ~@todo --tags ~@mld --require features/support --require features/step_definitions',
|
||||||
verify: '--strict --tags ~@stress --tags ~@todo --tags ~@mld-only -f progress --require features/support --require features/step_definitions',
|
ch: '--strict --tags ~@stress --tags ~@todo --tags ~@mld -f progress --require features/support --require features/step_definitions',
|
||||||
todo: '--strict --tags @todo --require features/support --require features/step_definitions',
|
todo: '--strict --tags @todo --require features/support --require features/step_definitions',
|
||||||
all: '--strict --require features/support --require features/step_definitions',
|
all: '--strict --require features/support --require features/step_definitions',
|
||||||
mld: '--strict --tags ~@stress --tags ~@todo --tags ~@ch --require features/support --require features/step_definitions -f progress',
|
mld: '--strict --tags ~@stress --tags ~@todo --tags ~@ch --require features/support --require features/step_definitions -f progress',
|
||||||
|
@ -5,7 +5,7 @@ RUN mkdir -p /src && mkdir -p /opt
|
|||||||
|
|
||||||
RUN apt-get update && \
|
RUN apt-get update && \
|
||||||
apt-get -y --no-install-recommends install ca-certificates cmake make git gcc g++ libbz2-dev libxml2-dev wget \
|
apt-get -y --no-install-recommends install ca-certificates cmake make git gcc g++ libbz2-dev libxml2-dev wget \
|
||||||
libzip-dev libboost1.74-all-dev lua5.4 liblua5.4-dev -o APT::Install-Suggests=0 -o APT::Install-Recommends=0
|
libzip-dev libboost1.74-all-dev lua5.4 liblua5.4-dev pkg-config -o APT::Install-Suggests=0 -o APT::Install-Recommends=0
|
||||||
|
|
||||||
RUN NPROC=${BUILD_CONCURRENCY:-$(nproc)} && \
|
RUN NPROC=${BUILD_CONCURRENCY:-$(nproc)} && \
|
||||||
ldconfig /usr/local/lib && \
|
ldconfig /usr/local/lib && \
|
||||||
@ -37,7 +37,7 @@ RUN NPROC=${BUILD_CONCURRENCY:-$(nproc)} && \
|
|||||||
cd ../profiles && \
|
cd ../profiles && \
|
||||||
cp -r * /opt && \
|
cp -r * /opt && \
|
||||||
strip /usr/local/bin/* && \
|
strip /usr/local/bin/* && \
|
||||||
rm -rf /src /usr/local/lib/libosrm*
|
rm -rf /src
|
||||||
|
|
||||||
|
|
||||||
# Multistage build to reduce image size - https://docs.docker.com/engine/userguide/eng-image/multistage-build/#use-multi-stage-builds
|
# Multistage build to reduce image size - https://docs.docker.com/engine/userguide/eng-image/multistage-build/#use-multi-stage-builds
|
||||||
|
@ -32,9 +32,9 @@ For outputting data into our file (debug.geojson), we simply need to call the ma
|
|||||||
### Possible Scopeguard Location
|
### Possible Scopeguard Location
|
||||||
Think of the scopeguard as you would do of any reference. If you wan't to access to logging during a call, the guard object must be alive and valid.
|
Think of the scopeguard as you would do of any reference. If you wan't to access to logging during a call, the guard object must be alive and valid.
|
||||||
|
|
||||||
As an example: a good location to create the a scopeguard to log decisions in the edge-based-graph-factory would be right before we run it ([here](https://github.com/Project-OSRM/osrm-backend/blob/a933b5d94943bf3edaf42c84a614a99650d23cba/src/extractor/extractor.cpp#L497)). If you put `util::ScopedGeojsonLoggerGuard<util::NodeIdVectorToLineString> geojson_guard( "debug.geojson", node_coordinate_vector);` at that location, you can then print `util::ScopedGeojsonLoggerGuard<util::NodeIdVectorToLineString>::Write(list_of_node_ids);` anywhere within the `edge-based-graph-factory`.
|
As an example: a good location to create a scopeguard to log decisions in the edge-based-graph-factory would be right before we run it ([here](https://github.com/Project-OSRM/osrm-backend/blob/a933b5d94943bf3edaf42c84a614a99650d23cba/src/extractor/extractor.cpp#L497)). If you put `util::ScopedGeojsonLoggerGuard<util::NodeIdVectorToLineString> geojson_guard( "debug.geojson", node_coordinate_vector);` at that location, you can then print `util::ScopedGeojsonLoggerGuard<util::NodeIdVectorToLineString>::Write(list_of_node_ids);` anywhere within the `edge-based-graph-factory`.
|
||||||
|
|
||||||
This location would enable call for all guidance related pre-processing which is called in the edge-based-graph-factory.
|
This location would enable calls for all guidance related pre-processing which is called in the edge-based-graph-factory.
|
||||||
Logging any turn-handler decisions, for example, would now be possible.
|
Logging any turn-handler decisions, for example, would now be possible.
|
||||||
|
|
||||||
## Limitations
|
## Limitations
|
||||||
|
41
docs/http.md
41
docs/http.md
@ -88,10 +88,11 @@ Every response object has a `code` property containing one of the strings below
|
|||||||
| `InvalidService` | Service name is invalid. |
|
| `InvalidService` | Service name is invalid. |
|
||||||
| `InvalidVersion` | Version is not found. |
|
| `InvalidVersion` | Version is not found. |
|
||||||
| `InvalidOptions` | Options are invalid. |
|
| `InvalidOptions` | Options are invalid. |
|
||||||
| `InvalidQuery` | The query string is syntactically malformed. |
|
| `InvalidQuery` | The query string is syntactically malformed. |
|
||||||
| `InvalidValue` | The successfully parsed query parameters are invalid. |
|
| `InvalidValue` | The successfully parsed query parameters are invalid. |
|
||||||
| `NoSegment` | One of the supplied input coordinates could not snap to the street segment. |
|
| `NoSegment` | One of the supplied input coordinates could not snap to the street segment. |
|
||||||
| `TooBig` | The request size violates one of the service-specific request size restrictions. |
|
| `TooBig` | The request size violates one of the service-specific request size restrictions. |
|
||||||
|
| `DisabledDataset` | The request tried to access a disabled dataset. |
|
||||||
|
|
||||||
- `message` is a **optional** human-readable error message. All other status types are service-dependent.
|
- `message` is a **optional** human-readable error message. All other status types are service-dependent.
|
||||||
- In case of an error the HTTP status code will be `400`. Otherwise, the HTTP status code will be `200` and `code` will be `Ok`.
|
- In case of an error the HTTP status code will be `400`. Otherwise, the HTTP status code will be `200` and `code` will be `Ok`.
|
||||||
@ -130,7 +131,7 @@ In addition to the [general options](#general-options) the following options are
|
|||||||
|number |`integer >= 1` (default `1`) |Number of nearest segments that should be returned. |
|
|number |`integer >= 1` (default `1`) |Number of nearest segments that should be returned. |
|
||||||
|
|
||||||
As `waypoints` is a single thing, returned by that service, using it with the option `skip_waypoints` set to `true` is quite useless, but still
|
As `waypoints` is a single thing, returned by that service, using it with the option `skip_waypoints` set to `true` is quite useless, but still
|
||||||
possible. In that case, only the `code` field will be returned.
|
possible. In that case, only the `code` field will be returned.
|
||||||
|
|
||||||
**Response**
|
**Response**
|
||||||
|
|
||||||
@ -648,12 +649,12 @@ Represents a route between two waypoints.
|
|||||||
- `distance`: The distance traveled by this route leg, in `float` meters.
|
- `distance`: The distance traveled by this route leg, in `float` meters.
|
||||||
- `duration`: The estimated travel time, in `float` number of seconds.
|
- `duration`: The estimated travel time, in `float` number of seconds.
|
||||||
- `weight`: The calculated weight of the route leg.
|
- `weight`: The calculated weight of the route leg.
|
||||||
- `summary`: Summary of the route taken as `string`. Depends on the `summary` parameter:
|
- `summary`: Summary of the route taken as `string`. Depends on the `steps` parameter:
|
||||||
|
|
||||||
| summary | |
|
| steps | |
|
||||||
|--------------|-----------------------------------------------------------------------|
|
|-------|-----------------------------------------------------------------------|
|
||||||
| true | Names of the two major roads used. Can be empty if the route is too short.|
|
| true | Names of the two major roads used. Can be empty if the route is too short.|
|
||||||
| false | empty `string` |
|
| false | empty `string` |
|
||||||
|
|
||||||
- `steps`: Depends on the `steps` parameter.
|
- `steps`: Depends on the `steps` parameter.
|
||||||
|
|
||||||
@ -953,11 +954,11 @@ The object is used to describe the waypoint on a route.
|
|||||||
|
|
||||||
## Flatbuffers format
|
## Flatbuffers format
|
||||||
|
|
||||||
The default response format is `json`, but OSRM supports binary [`flatbuffers`](https://google.github.io/flatbuffers/) format, which
|
The default response format is `json`, but OSRM supports binary [`flatbuffers`](https://google.github.io/flatbuffers/) format, which
|
||||||
is much faster in serialization/deserialization, comparing to `json`.
|
is much faster in serialization/deserialization, comparing to `json`.
|
||||||
|
|
||||||
The format itself is described in message descriptors, located at `include/engine/api/flatbuffers` directory. Those descriptors could
|
The format itself is described in message descriptors, located at `include/engine/api/flatbuffers` directory. Those descriptors could
|
||||||
be compiled to provide protocol parsers in Go/Javascript/Typescript/Java/Dart/C#/Python/Lobster/Lua/Rust/PHP/Kotlin. Precompiled
|
be compiled to provide protocol parsers in Go/Javascript/Typescript/Java/Dart/C#/Python/Lobster/Lua/Rust/PHP/Kotlin. Precompiled
|
||||||
protocol parser for C++ is supplied with OSRM.
|
protocol parser for C++ is supplied with OSRM.
|
||||||
|
|
||||||
`Flatbuffers` format provides exactly the same data, as `json` format with a slightly different layout, which was optimized to minimize
|
`Flatbuffers` format provides exactly the same data, as `json` format with a slightly different layout, which was optimized to minimize
|
||||||
@ -971,7 +972,7 @@ Root object is the only object, available from a 'raw' `flatbuffers` buffer. It
|
|||||||
|
|
||||||
**Properties**
|
**Properties**
|
||||||
|
|
||||||
- `error`: `bool` Marks response as erroneous. An erroneous response should include the `code` fieldset, all the other fields may not be present.
|
- `error`: `bool` Marks response as erroneous. An erroneous response should include the `code` fieldset, all the other fields may not be present.
|
||||||
- `code`: `Error` Error description object, only present, when `error` is `true`
|
- `code`: `Error` Error description object, only present, when `error` is `true`
|
||||||
- `waypoints`: `[Waypoint]` Array of `Waypoint` objects. Should present for every service call, unless `skip_waypoints` is set to `true`. Table service will put `sources` array here.
|
- `waypoints`: `[Waypoint]` Array of `Waypoint` objects. Should present for every service call, unless `skip_waypoints` is set to `true`. Table service will put `sources` array here.
|
||||||
- `routes`: `[RouteObject]` Array of `RouteObject` objects. May be empty or absent. Should present for Route/Trip/Match services call.
|
- `routes`: `[RouteObject]` Array of `RouteObject` objects. May be empty or absent. Should present for Route/Trip/Match services call.
|
||||||
@ -983,21 +984,21 @@ Contains error information.
|
|||||||
|
|
||||||
**Properties**
|
**Properties**
|
||||||
|
|
||||||
- `code`: `string` Error code
|
- `code`: `string` Error code
|
||||||
- `message`: `string` Detailed error message
|
- `message`: `string` Detailed error message
|
||||||
|
|
||||||
### Waypoint object
|
### Waypoint object
|
||||||
|
|
||||||
Almost the same as `json` Waypoint object. The following properties differ:
|
Almost the same as `json` Waypoint object. The following properties differ:
|
||||||
|
|
||||||
- `location`: `Position` Same as `json` location field, but different format.
|
- `location`: `Position` Same as `json` location field, but different format.
|
||||||
- `nodes`: `Uint64Pair` Same as `json` nodes field, but different format.
|
- `nodes`: `Uint64Pair` Same as `json` nodes field, but different format.
|
||||||
|
|
||||||
### RouteObject object
|
### RouteObject object
|
||||||
|
|
||||||
Almost the same as `json` Route object. The following properties differ:
|
Almost the same as `json` Route object. The following properties differ:
|
||||||
|
|
||||||
- `polyline`: `string` Same as `json` geometry.polyline or geometry.polyline6 fields. One field for both formats.
|
- `polyline`: `string` Same as `json` geometry.polyline or geometry.polyline6 fields. One field for both formats.
|
||||||
- `coordinates`: `[Position]` Same as `json` geometry.coordinates field, but different format.
|
- `coordinates`: `[Position]` Same as `json` geometry.coordinates field, but different format.
|
||||||
- `legs`: `[Leg]` Array of `Leg` objects.
|
- `legs`: `[Leg]` Array of `Leg` objects.
|
||||||
|
|
||||||
@ -1012,7 +1013,7 @@ Almost the same as `json` Leg object. The following properties differ:
|
|||||||
|
|
||||||
Almost the same as `json` Step object. The following properties differ:
|
Almost the same as `json` Step object. The following properties differ:
|
||||||
|
|
||||||
- `polyline`: `string` Same as `json` geometry.polyline or geometry.polyline6 fields. One field for both formats.
|
- `polyline`: `string` Same as `json` geometry.polyline or geometry.polyline6 fields. One field for both formats.
|
||||||
- `coordinates`: `[Position]` Same as `json` geometry.coordinates field, but different format.
|
- `coordinates`: `[Position]` Same as `json` geometry.coordinates field, but different format.
|
||||||
- `maneuver`: `StepManeuver` Same as `json` maneuver field, but different format.
|
- `maneuver`: `StepManeuver` Same as `json` maneuver field, but different format.
|
||||||
|
|
||||||
@ -1035,7 +1036,7 @@ Almost the same as `json` Step object. The following properties differ:
|
|||||||
| `ExitRoundabout` | Describes a maneuver exiting a roundabout (usually preceded by a `roundabout` instruction) |
|
| `ExitRoundabout` | Describes a maneuver exiting a roundabout (usually preceded by a `roundabout` instruction) |
|
||||||
| `ExitRotary` | Describes the maneuver exiting a rotary (large named roundabout) |
|
| `ExitRotary` | Describes the maneuver exiting a rotary (large named roundabout) |
|
||||||
|
|
||||||
- `driving_side`: `bool` Ttrue stands for the left side driving.
|
- `driving_side`: `bool` Ttrue stands for the left side driving.
|
||||||
- `intersections`: `[Intersection]` Same as `json` intersections field, but different format.
|
- `intersections`: `[Intersection]` Same as `json` intersections field, but different format.
|
||||||
|
|
||||||
### Intersection object
|
### Intersection object
|
||||||
@ -1049,7 +1050,7 @@ Almost the same as `json` Intersection object. The following properties differ:
|
|||||||
|
|
||||||
Almost the same as `json` Lane object. The following properties differ:
|
Almost the same as `json` Lane object. The following properties differ:
|
||||||
|
|
||||||
- `indications`: `Turn` Array of `Turn` enum values.
|
- `indications`: `Turn` Array of `Turn` enum values.
|
||||||
|
|
||||||
| `value` | Description |
|
| `value` | Description |
|
||||||
|------------------------|---------------------------------------------------------------------------------------------------------------------------|
|
|------------------------|---------------------------------------------------------------------------------------------------------------------------|
|
||||||
@ -1089,16 +1090,16 @@ Almost the same as `json` StepManeuver object. The following properties differ:
|
|||||||
| `ExitRoundabout` | Describes a maneuver exiting a roundabout (usually preceded by a `roundabout` instruction) |
|
| `ExitRoundabout` | Describes a maneuver exiting a roundabout (usually preceded by a `roundabout` instruction) |
|
||||||
| `ExitRotary` | Describes the maneuver exiting a rotary (large named roundabout) |
|
| `ExitRotary` | Describes the maneuver exiting a rotary (large named roundabout) |
|
||||||
|
|
||||||
- `modifier`: `Turn` Maneuver turn (enum)
|
- `modifier`: `Turn` Maneuver turn (enum)
|
||||||
|
|
||||||
### Annotation object
|
### Annotation object
|
||||||
|
|
||||||
Exactly the same as `json` annotation object.
|
Exactly the same as `json` annotation object.
|
||||||
|
|
||||||
|
|
||||||
### Position object
|
### Position object
|
||||||
|
|
||||||
A point on Earth.
|
A point on Earth.
|
||||||
|
|
||||||
***Properties***
|
***Properties***
|
||||||
- `longitute`: `float` Point's longitude
|
- `longitute`: `float` Point's longitude
|
||||||
|
@ -31,6 +31,7 @@ var osrm = new OSRM('network.osrm');
|
|||||||
Old behaviour: Path to a file on disk to store the memory using mmap. Current behaviour: setting this value is the same as setting `mmap_memory: true`.
|
Old behaviour: Path to a file on disk to store the memory using mmap. Current behaviour: setting this value is the same as setting `mmap_memory: true`.
|
||||||
- `options.mmap_memory` **[Boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)?** Map on-disk files to virtual memory addresses (mmap), rather than loading into RAM.
|
- `options.mmap_memory` **[Boolean](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Boolean)?** Map on-disk files to virtual memory addresses (mmap), rather than loading into RAM.
|
||||||
- `options.path` **[String](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)?** The path to the `.osrm` files. This is mutually exclusive with setting {options.shared_memory} to true.
|
- `options.path` **[String](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/String)?** The path to the `.osrm` files. This is mutually exclusive with setting {options.shared_memory} to true.
|
||||||
|
- `options.disable_feature_dataset` **[Array](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array)?** Disables a feature dataset from being loaded into memory if not needed. Options: `ROUTE_STEPS`, `ROUTE_GEOMETRY`.
|
||||||
- `options.max_locations_trip` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. locations supported in trip query (default: unlimited).
|
- `options.max_locations_trip` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. locations supported in trip query (default: unlimited).
|
||||||
- `options.max_locations_viaroute` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. locations supported in viaroute query (default: unlimited).
|
- `options.max_locations_viaroute` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. locations supported in viaroute query (default: unlimited).
|
||||||
- `options.max_locations_distance_table` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. locations supported in distance table query (default: unlimited).
|
- `options.max_locations_distance_table` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. locations supported in distance table query (default: unlimited).
|
||||||
@ -38,6 +39,7 @@ var osrm = new OSRM('network.osrm');
|
|||||||
- `options.max_radius_map_matching` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. radius size supported in map matching query (default: 5).
|
- `options.max_radius_map_matching` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. radius size supported in map matching query (default: 5).
|
||||||
- `options.max_results_nearest` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. results supported in nearest query (default: unlimited).
|
- `options.max_results_nearest` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. results supported in nearest query (default: unlimited).
|
||||||
- `options.max_alternatives` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. number of alternatives supported in alternative routes query (default: 3).
|
- `options.max_alternatives` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Max. number of alternatives supported in alternative routes query (default: 3).
|
||||||
|
- `options.default_radius` **[Number](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Number)?** Default radius for queries (default: unlimited).
|
||||||
|
|
||||||
### route
|
### route
|
||||||
|
|
||||||
@ -248,7 +250,7 @@ osrm.match(options, function(err, response) {
|
|||||||
|
|
||||||
Returns **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** containing `tracepoints` and `matchings`.
|
Returns **[Object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object)** containing `tracepoints` and `matchings`.
|
||||||
**`tracepoints`** Array of [`Ẁaypoint`](#waypoint) objects representing all points of the trace in order.
|
**`tracepoints`** Array of [`Ẁaypoint`](#waypoint) objects representing all points of the trace in order.
|
||||||
If the trace point was ommited by map matching because it is an outlier, the entry will be null.
|
If the trace point was omitted by map matching because it is an outlier, the entry will be null.
|
||||||
Each `Waypoint` object has the following additional properties,
|
Each `Waypoint` object has the following additional properties,
|
||||||
1) `matchings_index`: Index to the
|
1) `matchings_index`: Index to the
|
||||||
[`Route`](#route) object in matchings the sub-trace was matched to,
|
[`Route`](#route) object in matchings the sub-trace was matched to,
|
||||||
|
@ -113,7 +113,7 @@ excludable | Sequence of Sets | Determines which class
|
|||||||
classes | Sequence | Determines the allowed classes that can be referenced using `{forward,backward}_classes` on the way in the `process_way` function.
|
classes | Sequence | Determines the allowed classes that can be referenced using `{forward,backward}_classes` on the way in the `process_way` function.
|
||||||
restrictions | Sequence | Determines which turn restrictions will be used for this profile.
|
restrictions | Sequence | Determines which turn restrictions will be used for this profile.
|
||||||
suffix_list | Set | List of name suffixes needed for determining if "Highway 101 NW" the same road as "Highway 101 ES".
|
suffix_list | Set | List of name suffixes needed for determining if "Highway 101 NW" the same road as "Highway 101 ES".
|
||||||
relation_types | Sequence | Determines wich relations should be cached for processing in this profile. It contains relations types
|
relation_types | Sequence | Determines which relations should be cached for processing in this profile. It contains relations types
|
||||||
|
|
||||||
### process_node(profile, node, result, relations)
|
### process_node(profile, node, result, relations)
|
||||||
Process an OSM node to determine whether this node is a barrier or can be passed and whether passing it incurs a delay.
|
Process an OSM node to determine whether this node is a barrier or can be passed and whether passing it incurs a delay.
|
||||||
@ -349,7 +349,7 @@ The input data must an ASCII file with rows of integers. e.g.:
|
|||||||
|
|
||||||
In your `segment_function` you can then access the raster source and use `raster:query()` to query to find the nearest data point, or `raster:interpolate()` to interpolate a value based on nearby data points.
|
In your `segment_function` you can then access the raster source and use `raster:query()` to query to find the nearest data point, or `raster:interpolate()` to interpolate a value based on nearby data points.
|
||||||
|
|
||||||
You must check whether the result is valid before use it.
|
You must check whether the result is valid before using it.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
@ -300,7 +300,7 @@ And the relations
|
|||||||
The setting looks perfectly fine at first glance. However, it is not well defined.
|
The setting looks perfectly fine at first glance. However, it is not well defined.
|
||||||
The forbidden right turn could be either a superfluous addition, forbidding the turn `cb` to `be`, or actually refer to the turn `ab` to `bd` to say that a turn is forbidden here.
|
The forbidden right turn could be either a superfluous addition, forbidding the turn `cb` to `be`, or actually refer to the turn `ab` to `bd` to say that a turn is forbidden here.
|
||||||
|
|
||||||
To model turn-restrictions correctly and unique, we need to split segments that contribute to the restriction into the smallest possible parts.
|
To model turn-restrictions correctly and uniquely, we need to split segments that contribute to the restriction into the smallest possible parts.
|
||||||
E.g. the above scenario could correctly be expressed as:
|
E.g. the above scenario could correctly be expressed as:
|
||||||
|
|
||||||
```
|
```
|
||||||
@ -360,7 +360,7 @@ When I route I should get
|
|||||||
|
|
||||||
And the test reports `turn right` for the route `a->e`, where before it said `slight right`.
|
And the test reports `turn right` for the route `a->e`, where before it said `slight right`.
|
||||||
|
|
||||||
If you changed the turn angles, obviously you can expect changes in the distinction between `slight right` and `right`.
|
If you change the turn angles, obviously you can expect changes in the distinction between `slight right` and `right`.
|
||||||
In such a case it is, of course, reasonable to change the expected route to report `right` instead of `slight right`. You should consider inspecting the actual turn angles at `b` to see if you feel that change is justified.
|
In such a case it is, of course, reasonable to change the expected route to report `right` instead of `slight right`. You should consider inspecting the actual turn angles at `b` to see if you feel that change is justified.
|
||||||
|
|
||||||
However, you should never adjust the test itself.
|
However, you should never adjust the test itself.
|
||||||
@ -390,9 +390,9 @@ In this case we would see a very slight turn angle. If your change now reports d
|
|||||||
|
|
||||||
### Consider Post-Processing Impacts
|
### Consider Post-Processing Impacts
|
||||||
|
|
||||||
Some changes you might see could look completely unrelated. To understand the impact of your changes, you can make use of the debugging utilities you can finde in `util/debug.hpp` (and potentially other related headers).
|
Some changes you might see could look completely unrelated. To understand the impact of your changes, you can make use of the debugging utilities you can find in `util/debug.hpp` (and potentially other related headers).
|
||||||
|
|
||||||
If your test is inspecting a series of turns (remember, a turn not necessarily equals an instruction), you could see interaction with post-processing.
|
If your test is inspecting a series of turns (remember, a turn does not necessarily equals an instruction), you could see interaction with post-processing.
|
||||||
To see the unprocessed turns, you should print the steps at the end of step assembly (`assembleSteps` in `engine/guidance/assemble_steps.hpp`).
|
To see the unprocessed turns, you should print the steps at the end of step assembly (`assembleSteps` in `engine/guidance/assemble_steps.hpp`).
|
||||||
|
|
||||||
If you see unexpected changes, you can consider adding the `locations` field to your test to study what location a turn is reported at.
|
If you see unexpected changes, you can consider adding the `locations` field to your test to study what location a turn is reported at.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
cmake_minimum_required(VERSION 2.8.8)
|
cmake_minimum_required(VERSION 3.18)
|
||||||
|
|
||||||
if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR AND NOT MSVC_IDE)
|
if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR AND NOT MSVC_IDE)
|
||||||
message(FATAL_ERROR "In-source builds are not allowed.
|
message(FATAL_ERROR "In-source builds are not allowed.
|
||||||
@ -12,20 +12,18 @@ endif()
|
|||||||
|
|
||||||
project(osrm-example C CXX)
|
project(osrm-example C CXX)
|
||||||
|
|
||||||
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
set(CMAKE_CXX_EXTENSIONS OFF)
|
||||||
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
||||||
|
|
||||||
set(bitness 32)
|
|
||||||
if(CMAKE_SIZEOF_VOID_P EQUAL 8)
|
if(CMAKE_SIZEOF_VOID_P EQUAL 8)
|
||||||
set(bitness 64)
|
|
||||||
message(STATUS "Building on a 64 bit system")
|
message(STATUS "Building on a 64 bit system")
|
||||||
else()
|
else()
|
||||||
message(STATUS "Building on a 32 bit system")
|
message(STATUS "Building on a 32 bit system")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WIN32 AND MSVC_VERSION LESS 1900)
|
|
||||||
message(FATAL_ERROR "Building with Microsoft compiler needs Latest Visual Studio 2015 (Community or better)")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
link_directories(${LibOSRM_LIBRARY_DIRS})
|
link_directories(${LibOSRM_LIBRARY_DIRS})
|
||||||
add_executable(osrm-example example.cpp)
|
add_executable(osrm-example example.cpp)
|
||||||
|
|
||||||
|
@ -78,6 +78,15 @@ Feature: Bike - Accessability of different way types
|
|||||||
| construction | yes | | |
|
| construction | yes | | |
|
||||||
| construction | | yes | |
|
| construction | | yes | |
|
||||||
|
|
||||||
|
@proposed
|
||||||
|
Scenario: Bike - Don't allow routing on ways still being proposed
|
||||||
|
Then routability should be
|
||||||
|
| highway | foot | bicycle | proposed | bothw |
|
||||||
|
| primary | | | | x |
|
||||||
|
| proposed | | | | |
|
||||||
|
| proposed | yes | | yes | |
|
||||||
|
| proposed | | yes | yes | |
|
||||||
|
|
||||||
@roundabout
|
@roundabout
|
||||||
Scenario: Bike - Don't push bikes against oneway flow on roundabouts
|
Scenario: Bike - Don't push bikes against oneway flow on roundabouts
|
||||||
Then routability should be
|
Then routability should be
|
||||||
|
@ -66,15 +66,50 @@ Feature: Car - Handle traffic lights
|
|||||||
| k | traffic_signals | backward |
|
| k | traffic_signals | backward |
|
||||||
|
|
||||||
When I route I should get
|
When I route I should get
|
||||||
| from | to | time | # |
|
| from | to | time | weight | # |
|
||||||
| 1 | 2 | 11.1s | no turn with no traffic light |
|
| 1 | 2 | 11.1s | 11.1 | no turn with no traffic light |
|
||||||
| 2 | 1 | 11.1s | no turn with no traffic light |
|
| 2 | 1 | 11.1s | 11.1 | no turn with no traffic light |
|
||||||
| 3 | 4 | 13.1s | no turn with traffic light |
|
| 3 | 4 | 13.1s | 13.1 | no turn with traffic light |
|
||||||
| 4 | 3 | 13.1s | no turn with traffic light |
|
| 4 | 3 | 13.1s | 13.1 | no turn with traffic light |
|
||||||
| 5 | 6 | 13.1s | no turn with traffic light |
|
| 5 | 6 | 13.1s | 13.1 | no turn with traffic light |
|
||||||
| 6 | 5 | 11.1s | no turn with no traffic light |
|
| 6 | 5 | 11.1s | 11.1 | no turn with no traffic light |
|
||||||
| 7 | 8 | 11.1s | no turn with no traffic light |
|
| 7 | 8 | 11.1s | 11.1 | no turn with no traffic light |
|
||||||
| 8 | 7 | 13.1s | no turn with traffic light |
|
| 8 | 7 | 13.1s | 13.1 | no turn with traffic light |
|
||||||
|
|
||||||
|
|
||||||
|
Scenario: Car - Traffic signal direction with distance weight
|
||||||
|
Given the profile file "car" initialized with
|
||||||
|
"""
|
||||||
|
profile.properties.weight_name = 'distance'
|
||||||
|
profile.properties.traffic_light_penalty = 100000
|
||||||
|
"""
|
||||||
|
|
||||||
|
Given the node map
|
||||||
|
"""
|
||||||
|
a---b---c
|
||||||
|
1 2
|
||||||
|
| |
|
||||||
|
| |
|
||||||
|
| |
|
||||||
|
| |
|
||||||
|
| |
|
||||||
|
d-------f
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
And the ways
|
||||||
|
| nodes | highway |
|
||||||
|
| abc | primary |
|
||||||
|
| adfc | primary |
|
||||||
|
|
||||||
|
And the nodes
|
||||||
|
| node | highway |
|
||||||
|
| b | traffic_signals |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| from | to | time | distances | weight | # |
|
||||||
|
| 1 | 2 | 100033.2s | 599.9m,0m | 599.8 | goes via the expensive traffic signal |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Scenario: Car - Encounters a traffic light
|
Scenario: Car - Encounters a traffic light
|
||||||
|
@ -36,3 +36,9 @@ Feature: Foot - Accessability of different way types
|
|||||||
| highway | leisure | forw |
|
| highway | leisure | forw |
|
||||||
| (nil) | track | x |
|
| (nil) | track | x |
|
||||||
|
|
||||||
|
Scenario: Foot - Proposed ways
|
||||||
|
Then routability should be
|
||||||
|
| highway | foot | proposed | forw |
|
||||||
|
| footway | | | x |
|
||||||
|
| proposed | | | |
|
||||||
|
| proposed | yes | yes | |
|
||||||
|
@ -68,8 +68,9 @@ class OSRMDirectLoader extends OSRMBaseLoader {
|
|||||||
super(scope);
|
super(scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
load (inputFile, callback) {
|
load (ctx, callback) {
|
||||||
this.inputFile = inputFile;
|
this.inputFile = ctx.inputFile;
|
||||||
|
this.loaderArgs = ctx.loaderArgs;
|
||||||
this.shutdown(() => {
|
this.shutdown(() => {
|
||||||
this.launch(callback);
|
this.launch(callback);
|
||||||
});
|
});
|
||||||
@ -78,7 +79,7 @@ class OSRMDirectLoader extends OSRMBaseLoader {
|
|||||||
osrmUp (callback) {
|
osrmUp (callback) {
|
||||||
if (this.osrmIsRunning()) return callback(new Error("osrm-routed already running!"));
|
if (this.osrmIsRunning()) return callback(new Error("osrm-routed already running!"));
|
||||||
|
|
||||||
const command_arguments = util.format('%s -p %d -i %s -a %s', this.inputFile, this.scope.OSRM_PORT, this.scope.OSRM_IP, this.scope.ROUTING_ALGORITHM);
|
const command_arguments = util.format('%s -p %d -i %s -a %s %s', this.inputFile, this.scope.OSRM_PORT, this.scope.OSRM_IP, this.scope.ROUTING_ALGORITHM, this.loaderArgs);
|
||||||
this.child = this.scope.runBin('osrm-routed', command_arguments, this.scope.environment, (err) => {
|
this.child = this.scope.runBin('osrm-routed', command_arguments, this.scope.environment, (err) => {
|
||||||
if (err && err.signal !== 'SIGINT') {
|
if (err && err.signal !== 'SIGINT') {
|
||||||
this.child = null;
|
this.child = null;
|
||||||
@ -101,8 +102,9 @@ class OSRMmmapLoader extends OSRMBaseLoader {
|
|||||||
super(scope);
|
super(scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
load (inputFile, callback) {
|
load (ctx, callback) {
|
||||||
this.inputFile = inputFile;
|
this.inputFile = ctx.inputFile;
|
||||||
|
this.loaderArgs = ctx.loaderArgs;
|
||||||
this.shutdown(() => {
|
this.shutdown(() => {
|
||||||
this.launch(callback);
|
this.launch(callback);
|
||||||
});
|
});
|
||||||
@ -111,7 +113,7 @@ class OSRMmmapLoader extends OSRMBaseLoader {
|
|||||||
osrmUp (callback) {
|
osrmUp (callback) {
|
||||||
if (this.osrmIsRunning()) return callback(new Error("osrm-routed already running!"));
|
if (this.osrmIsRunning()) return callback(new Error("osrm-routed already running!"));
|
||||||
|
|
||||||
const command_arguments = util.format('%s -p %d -i %s -a %s --mmap', this.inputFile, this.scope.OSRM_PORT, this.scope.OSRM_IP, this.scope.ROUTING_ALGORITHM);
|
const command_arguments = util.format('%s -p %d -i %s -a %s --mmap %s', this.inputFile, this.scope.OSRM_PORT, this.scope.OSRM_IP, this.scope.ROUTING_ALGORITHM, this.loaderArgs);
|
||||||
this.child = this.scope.runBin('osrm-routed', command_arguments, this.scope.environment, (err) => {
|
this.child = this.scope.runBin('osrm-routed', command_arguments, this.scope.environment, (err) => {
|
||||||
if (err && err.signal !== 'SIGINT') {
|
if (err && err.signal !== 'SIGINT') {
|
||||||
this.child = null;
|
this.child = null;
|
||||||
@ -134,8 +136,9 @@ class OSRMDatastoreLoader extends OSRMBaseLoader {
|
|||||||
super(scope);
|
super(scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
load (inputFile, callback) {
|
load (ctx, callback) {
|
||||||
this.inputFile = inputFile;
|
this.inputFile = ctx.inputFile;
|
||||||
|
this.loaderArgs = ctx.loaderArgs;
|
||||||
|
|
||||||
this.loadData((err) => {
|
this.loadData((err) => {
|
||||||
if (err) return callback(err);
|
if (err) return callback(err);
|
||||||
@ -148,7 +151,7 @@ class OSRMDatastoreLoader extends OSRMBaseLoader {
|
|||||||
}
|
}
|
||||||
|
|
||||||
loadData (callback) {
|
loadData (callback) {
|
||||||
const command_arguments = util.format('--dataset-name=%s %s', this.scope.DATASET_NAME, this.inputFile);
|
const command_arguments = util.format('--dataset-name=%s %s %s', this.scope.DATASET_NAME, this.inputFile, this.loaderArgs);
|
||||||
this.scope.runBin('osrm-datastore', command_arguments, this.scope.environment, (err) => {
|
this.scope.runBin('osrm-datastore', command_arguments, this.scope.environment, (err) => {
|
||||||
if (err) return callback(new Error('*** osrm-datastore exited with ' + err.code + ': ' + err));
|
if (err) return callback(new Error('*** osrm-datastore exited with ' + err.code + ': ' + err));
|
||||||
callback();
|
callback();
|
||||||
|
141
features/options/data/disabled_dataset.feature
Normal file
141
features/options/data/disabled_dataset.feature
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
@routing @disable-feature-dataset
|
||||||
|
Feature: disable-feature-dataset command line options
|
||||||
|
Background:
|
||||||
|
Given the profile "testbot"
|
||||||
|
And the node map
|
||||||
|
"""
|
||||||
|
0
|
||||||
|
a b c
|
||||||
|
"""
|
||||||
|
And the ways
|
||||||
|
| nodes |
|
||||||
|
| ab |
|
||||||
|
| bc |
|
||||||
|
|
||||||
|
Scenario: disable-feature-dataset - geometry disabled error
|
||||||
|
Given the data load extra arguments "--disable-feature-dataset ROUTE_GEOMETRY"
|
||||||
|
|
||||||
|
# The default values
|
||||||
|
And the query options
|
||||||
|
| overview | simplified |
|
||||||
|
| annotations | false |
|
||||||
|
| steps | false |
|
||||||
|
| skip_waypoints | false |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| from | to | code |
|
||||||
|
| a | c | DisabledDataset |
|
||||||
|
|
||||||
|
When I plan a trip I should get
|
||||||
|
| waypoints | code |
|
||||||
|
| a,b,c | DisabledDataset |
|
||||||
|
|
||||||
|
When I match I should get
|
||||||
|
| trace | code |
|
||||||
|
| abc | DisabledDataset |
|
||||||
|
|
||||||
|
Scenario: disable-feature-dataset - geometry disabled error table
|
||||||
|
Given the data load extra arguments "--disable-feature-dataset ROUTE_GEOMETRY"
|
||||||
|
|
||||||
|
When I request nearest I should get
|
||||||
|
| in | code |
|
||||||
|
| 0 | DisabledDataset |
|
||||||
|
|
||||||
|
When I request a travel time matrix with these waypoints I should get the response code
|
||||||
|
| waypoints | code |
|
||||||
|
| a,b,c | DisabledDataset |
|
||||||
|
|
||||||
|
|
||||||
|
Scenario: disable-feature-dataset - geometry disabled success
|
||||||
|
Given the data load extra arguments "--disable-feature-dataset ROUTE_GEOMETRY"
|
||||||
|
|
||||||
|
# No geometry values returned
|
||||||
|
And the query options
|
||||||
|
| overview | false |
|
||||||
|
| annotations | false |
|
||||||
|
| steps | false |
|
||||||
|
| skip_waypoints | true |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| from | to | code |
|
||||||
|
| a | c | Ok |
|
||||||
|
|
||||||
|
When I plan a trip I should get
|
||||||
|
| waypoints | code |
|
||||||
|
| a,b,c | Ok |
|
||||||
|
|
||||||
|
When I match I should get
|
||||||
|
| trace | code |
|
||||||
|
| abc | Ok |
|
||||||
|
|
||||||
|
Scenario: disable-feature-dataset - geometry disabled error table
|
||||||
|
Given the data load extra arguments "--disable-feature-dataset ROUTE_GEOMETRY"
|
||||||
|
|
||||||
|
And the query options
|
||||||
|
| skip_waypoints | true |
|
||||||
|
|
||||||
|
# You would never do this, but just to prove the point.
|
||||||
|
When I request nearest I should get
|
||||||
|
| in | code |
|
||||||
|
| 0 | Ok |
|
||||||
|
|
||||||
|
When I request a travel time matrix with these waypoints I should get the response code
|
||||||
|
| waypoints | code |
|
||||||
|
| a,b,c | Ok |
|
||||||
|
|
||||||
|
|
||||||
|
Scenario: disable-feature-dataset - steps disabled error
|
||||||
|
Given the data load extra arguments "--disable-feature-dataset ROUTE_STEPS"
|
||||||
|
|
||||||
|
# Default + annotations, steps
|
||||||
|
And the query options
|
||||||
|
| overview | simplified |
|
||||||
|
| annotations | true |
|
||||||
|
| steps | true |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| from | to | code |
|
||||||
|
| a | c | DisabledDataset |
|
||||||
|
|
||||||
|
When I plan a trip I should get
|
||||||
|
| waypoints | code |
|
||||||
|
| a,b,c | DisabledDataset |
|
||||||
|
|
||||||
|
When I match I should get
|
||||||
|
| trace | code |
|
||||||
|
| abc | DisabledDataset |
|
||||||
|
|
||||||
|
|
||||||
|
Scenario: disable-feature-dataset - geometry disabled error table
|
||||||
|
Given the data load extra arguments "--disable-feature-dataset ROUTE_STEPS"
|
||||||
|
|
||||||
|
When I request nearest I should get
|
||||||
|
| in | code |
|
||||||
|
| 0 | Ok |
|
||||||
|
|
||||||
|
When I request a travel time matrix with these waypoints I should get the response code
|
||||||
|
| waypoints | code |
|
||||||
|
| a,b,c | Ok |
|
||||||
|
|
||||||
|
|
||||||
|
Scenario: disable-feature-dataset - steps disabled success
|
||||||
|
Given the data load extra arguments "--disable-feature-dataset ROUTE_STEPS"
|
||||||
|
|
||||||
|
# Default + steps
|
||||||
|
And the query options
|
||||||
|
| overview | simplified |
|
||||||
|
| annotations | true |
|
||||||
|
| steps | false |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| from | to | code |
|
||||||
|
| a | c | Ok |
|
||||||
|
|
||||||
|
When I plan a trip I should get
|
||||||
|
| waypoints | code |
|
||||||
|
| a,b,c | Ok |
|
||||||
|
|
||||||
|
When I match I should get
|
||||||
|
| trace | code |
|
||||||
|
| abc | Ok |
|
||||||
|
|
@ -23,6 +23,7 @@ Feature: osrm-routed command line options: help
|
|||||||
And stdout should contain "--max-trip-size"
|
And stdout should contain "--max-trip-size"
|
||||||
And stdout should contain "--max-table-size"
|
And stdout should contain "--max-table-size"
|
||||||
And stdout should contain "--max-matching-size"
|
And stdout should contain "--max-matching-size"
|
||||||
|
And stdout should contain "--default-radius"
|
||||||
And it should exit successfully
|
And it should exit successfully
|
||||||
|
|
||||||
@skip_on_routed_js
|
@skip_on_routed_js
|
||||||
@ -44,6 +45,7 @@ Feature: osrm-routed command line options: help
|
|||||||
And stdout should contain "--max-trip-size"
|
And stdout should contain "--max-trip-size"
|
||||||
And stdout should contain "--max-table-size"
|
And stdout should contain "--max-table-size"
|
||||||
And stdout should contain "--max-matching-size"
|
And stdout should contain "--max-matching-size"
|
||||||
|
And stdout should contain "--default-radius"
|
||||||
And it should exit successfully
|
And it should exit successfully
|
||||||
|
|
||||||
|
|
||||||
@ -66,4 +68,5 @@ Feature: osrm-routed command line options: help
|
|||||||
And stdout should contain "--max-table-size"
|
And stdout should contain "--max-table-size"
|
||||||
And stdout should contain "--max-table-size"
|
And stdout should contain "--max-table-size"
|
||||||
And stdout should contain "--max-matching-size"
|
And stdout should contain "--max-matching-size"
|
||||||
|
And stdout should contain "--default-radius"
|
||||||
And it should exit successfully
|
And it should exit successfully
|
||||||
|
@ -33,6 +33,11 @@ module.exports = function () {
|
|||||||
callback();
|
callback();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.Given(/^the data load extra arguments "(.*?)"$/, (args, callback) => {
|
||||||
|
this.loaderArgs = this.expandOptions(args);
|
||||||
|
callback();
|
||||||
|
});
|
||||||
|
|
||||||
this.Given(/^a grid size of ([0-9.]+) meters$/, (meters, callback) => {
|
this.Given(/^a grid size of ([0-9.]+) meters$/, (meters, callback) => {
|
||||||
this.setGridSize(meters);
|
this.setGridSize(meters);
|
||||||
callback();
|
callback();
|
||||||
|
@ -5,6 +5,7 @@ var FBResult = require('../support/fbresult_generated').osrm.engine.api.fbresult
|
|||||||
|
|
||||||
module.exports = function () {
|
module.exports = function () {
|
||||||
const durationsRegex = new RegExp(/^I request a travel time matrix I should get$/);
|
const durationsRegex = new RegExp(/^I request a travel time matrix I should get$/);
|
||||||
|
const durationsCodeOnlyRegex = new RegExp(/^I request a travel time matrix with these waypoints I should get the response code$/);
|
||||||
const distancesRegex = new RegExp(/^I request a travel distance matrix I should get$/);
|
const distancesRegex = new RegExp(/^I request a travel distance matrix I should get$/);
|
||||||
const estimatesRegex = new RegExp(/^I request a travel time matrix I should get estimates for$/);
|
const estimatesRegex = new RegExp(/^I request a travel time matrix I should get estimates for$/);
|
||||||
const durationsRegexFb = new RegExp(/^I request a travel time matrix with flatbuffers I should get$/);
|
const durationsRegexFb = new RegExp(/^I request a travel time matrix with flatbuffers I should get$/);
|
||||||
@ -17,6 +18,7 @@ module.exports = function () {
|
|||||||
const FORMAT_FB = 'flatbuffers';
|
const FORMAT_FB = 'flatbuffers';
|
||||||
|
|
||||||
this.When(durationsRegex, function(table, callback) {tableParse.call(this, table, DURATIONS_NO_ROUTE, 'durations', FORMAT_JSON, callback);}.bind(this));
|
this.When(durationsRegex, function(table, callback) {tableParse.call(this, table, DURATIONS_NO_ROUTE, 'durations', FORMAT_JSON, callback);}.bind(this));
|
||||||
|
this.When(durationsCodeOnlyRegex, function(table, callback) {tableCodeOnlyParse.call(this, table, 'durations', FORMAT_JSON, callback);}.bind(this));
|
||||||
this.When(distancesRegex, function(table, callback) {tableParse.call(this, table, DISTANCES_NO_ROUTE, 'distances', FORMAT_JSON, callback);}.bind(this));
|
this.When(distancesRegex, function(table, callback) {tableParse.call(this, table, DISTANCES_NO_ROUTE, 'distances', FORMAT_JSON, callback);}.bind(this));
|
||||||
this.When(estimatesRegex, function(table, callback) {tableParse.call(this, table, DISTANCES_NO_ROUTE, 'fallback_speed_cells', FORMAT_JSON, callback);}.bind(this));
|
this.When(estimatesRegex, function(table, callback) {tableParse.call(this, table, DISTANCES_NO_ROUTE, 'fallback_speed_cells', FORMAT_JSON, callback);}.bind(this));
|
||||||
this.When(durationsRegexFb, function(table, callback) {tableParse.call(this, table, DURATIONS_NO_ROUTE, 'durations', FORMAT_FB, callback);}.bind(this));
|
this.When(durationsRegexFb, function(table, callback) {tableParse.call(this, table, DURATIONS_NO_ROUTE, 'durations', FORMAT_FB, callback);}.bind(this));
|
||||||
@ -27,6 +29,64 @@ const durationsParse = function(v) { return isNaN(parseInt(v)); };
|
|||||||
const distancesParse = function(v) { return isNaN(parseFloat(v)); };
|
const distancesParse = function(v) { return isNaN(parseFloat(v)); };
|
||||||
const estimatesParse = function(v) { return isNaN(parseFloat(v)); };
|
const estimatesParse = function(v) { return isNaN(parseFloat(v)); };
|
||||||
|
|
||||||
|
function tableCodeOnlyParse(table, annotation, format, callback) {
|
||||||
|
|
||||||
|
const params = this.queryParams;
|
||||||
|
params.annotations = ['durations','fallback_speed_cells'].indexOf(annotation) !== -1 ? 'duration' : 'distance';
|
||||||
|
params.output = format;
|
||||||
|
|
||||||
|
var got;
|
||||||
|
|
||||||
|
this.reprocessAndLoadData((e) => {
|
||||||
|
if (e) return callback(e);
|
||||||
|
var testRow = (row, ri, cb) => {
|
||||||
|
var afterRequest = (err, res) => {
|
||||||
|
if (err) return cb(err);
|
||||||
|
|
||||||
|
for (var k in row) {
|
||||||
|
var match = k.match(/param:(.*)/);
|
||||||
|
if (match) {
|
||||||
|
if (row[k] === '(nil)') {
|
||||||
|
params[match[1]] = null;
|
||||||
|
} else if (row[k]) {
|
||||||
|
params[match[1]] = [row[k]];
|
||||||
|
}
|
||||||
|
got[k] = row[k];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var json;
|
||||||
|
got.code = 'unknown';
|
||||||
|
if (res.body.length) {
|
||||||
|
json = JSON.parse(res.body);
|
||||||
|
got.code = json.code;
|
||||||
|
}
|
||||||
|
|
||||||
|
cb(null, got);
|
||||||
|
};
|
||||||
|
|
||||||
|
var params = this.queryParams,
|
||||||
|
waypoints = [];
|
||||||
|
if (row.waypoints) {
|
||||||
|
row.waypoints.split(',').forEach((n) => {
|
||||||
|
var node = this.findNodeByName(n);
|
||||||
|
if (!node) throw new Error(util.format('*** unknown waypoint node "%s"', n.trim()));
|
||||||
|
waypoints.push({ coord: node, type: 'loc' });
|
||||||
|
|
||||||
|
});
|
||||||
|
got = { waypoints: row.waypoints };
|
||||||
|
|
||||||
|
this.requestTable(waypoints, params, afterRequest);
|
||||||
|
} else {
|
||||||
|
throw new Error('*** no waypoints');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
this.processRowsAndDiff(table, testRow, callback);
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
function tableParse(table, noRoute, annotation, format, callback) {
|
function tableParse(table, noRoute, annotation, format, callback) {
|
||||||
|
|
||||||
const parse = annotation == 'distances' ? distancesParse : (annotation == 'durations' ? durationsParse : estimatesParse);
|
const parse = annotation == 'distances' ? distancesParse : (annotation == 'durations' ? durationsParse : estimatesParse);
|
||||||
@ -62,9 +122,6 @@ function tableParse(table, noRoute, annotation, format, callback) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var actual = [];
|
|
||||||
actual.push(table.headers);
|
|
||||||
|
|
||||||
this.reprocessAndLoadData((e) => {
|
this.reprocessAndLoadData((e) => {
|
||||||
if (e) return callback(e);
|
if (e) return callback(e);
|
||||||
// compute matrix
|
// compute matrix
|
||||||
|
@ -12,35 +12,43 @@ module.exports = function () {
|
|||||||
var inNode = this.findNodeByName(row.in);
|
var inNode = this.findNodeByName(row.in);
|
||||||
if (!inNode) throw new Error(util.format('*** unknown in-node "%s"', row.in));
|
if (!inNode) throw new Error(util.format('*** unknown in-node "%s"', row.in));
|
||||||
|
|
||||||
var outNode = this.findNodeByName(row.out);
|
|
||||||
if (!outNode) throw new Error(util.format('*** unknown out-node "%s"', row.out));
|
|
||||||
|
|
||||||
this.requestNearest(inNode, this.queryParams, (err, response) => {
|
this.requestNearest(inNode, this.queryParams, (err, response) => {
|
||||||
if (err) return cb(err);
|
if (err) return cb(err);
|
||||||
var coord;
|
var coord;
|
||||||
var headers = new Set(table.raw()[0]);
|
var headers = new Set(table.raw()[0]);
|
||||||
|
|
||||||
if (response.statusCode === 200 && response.body.length) {
|
var got = { in: row.in};
|
||||||
|
|
||||||
|
if (response.body.length) {
|
||||||
var json = JSON.parse(response.body);
|
var json = JSON.parse(response.body);
|
||||||
|
got.code = json.code;
|
||||||
|
|
||||||
coord = json.waypoints[0].location;
|
if (response.statusCode === 200) {
|
||||||
|
|
||||||
var got = { in: row.in, out: row.out };
|
if (headers.has('data_version')) {
|
||||||
|
got.data_version = json.data_version || '';
|
||||||
if (headers.has('data_version')) {
|
|
||||||
got.data_version = json.data_version || '';
|
|
||||||
}
|
|
||||||
|
|
||||||
Object.keys(row).forEach((key) => {
|
|
||||||
if (key === 'out') {
|
|
||||||
if (this.FuzzyMatch.matchLocation(coord, outNode)) {
|
|
||||||
got[key] = row[key];
|
|
||||||
} else {
|
|
||||||
row[key] = util.format('%s [%d,%d]', row[key], outNode.lat, outNode.lon);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
|
if (json.waypoints && json.waypoints.length && row.out) {
|
||||||
|
coord = json.waypoints[0].location;
|
||||||
|
|
||||||
|
got.out = row.out;
|
||||||
|
|
||||||
|
var outNode = this.findNodeByName(row.out);
|
||||||
|
if (!outNode) throw new Error(util.format('*** unknown out-node "%s"', row.out));
|
||||||
|
|
||||||
|
Object.keys(row).forEach((key) => {
|
||||||
|
if (key === 'out') {
|
||||||
|
if (this.FuzzyMatch.matchLocation(coord, outNode)) {
|
||||||
|
got[key] = row[key];
|
||||||
|
} else {
|
||||||
|
row[key] = util.format('%s [%d,%d]', row[key], outNode.lat, outNode.lon);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
cb(null, got);
|
cb(null, got);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -91,7 +91,7 @@ module.exports = function () {
|
|||||||
|
|
||||||
var encodedResult = '';
|
var encodedResult = '';
|
||||||
|
|
||||||
if (json.trips) row.trips.split(',').forEach((sub, si) => {
|
if (json.trips && row.trips) row.trips.split(',').forEach((sub, si) => {
|
||||||
if (si >= subTrips.length) {
|
if (si >= subTrips.length) {
|
||||||
ok = false;
|
ok = false;
|
||||||
} else {
|
} else {
|
||||||
@ -134,7 +134,6 @@ module.exports = function () {
|
|||||||
} else {
|
} else {
|
||||||
var params = this.queryParams,
|
var params = this.queryParams,
|
||||||
waypoints = [];
|
waypoints = [];
|
||||||
params['steps'] = 'true';
|
|
||||||
if (row.from && row.to) {
|
if (row.from && row.to) {
|
||||||
var fromNode = this.findNodeByName(row.from);
|
var fromNode = this.findNodeByName(row.from);
|
||||||
if (!fromNode) throw new Error(util.format('*** unknown from-node "%s"', row.from));
|
if (!fromNode) throw new Error(util.format('*** unknown from-node "%s"', row.from));
|
||||||
|
@ -280,10 +280,11 @@ module.exports = function () {
|
|||||||
};
|
};
|
||||||
|
|
||||||
this.reprocessAndLoadData = (callback) => {
|
this.reprocessAndLoadData = (callback) => {
|
||||||
|
let p = {loaderArgs: this.loaderArgs, inputFile: this.processedCacheFile};
|
||||||
let queue = d3.queue(1);
|
let queue = d3.queue(1);
|
||||||
queue.defer(this.writeAndLinkOSM.bind(this));
|
queue.defer(this.writeAndLinkOSM.bind(this));
|
||||||
queue.defer(this.extractContractPartitionAndCustomize.bind(this));
|
queue.defer(this.extractContractPartitionAndCustomize.bind(this));
|
||||||
queue.defer(this.osrmLoader.load.bind(this.osrmLoader), this.processedCacheFile);
|
queue.defer(this.osrmLoader.load.bind(this.osrmLoader), p);
|
||||||
queue.awaitAll(callback);
|
queue.awaitAll(callback);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -29,7 +29,8 @@ module.exports = function () {
|
|||||||
this.DEFAULT_ENVIRONMENT = process.env;
|
this.DEFAULT_ENVIRONMENT = process.env;
|
||||||
this.DEFAULT_PROFILE = 'bicycle';
|
this.DEFAULT_PROFILE = 'bicycle';
|
||||||
this.DEFAULT_INPUT_FORMAT = 'osm';
|
this.DEFAULT_INPUT_FORMAT = 'osm';
|
||||||
this.DEFAULT_LOAD_METHOD = process.argv[process.argv.indexOf('-m') +1].match('mmap') ? 'mmap' : 'datastore';
|
let loadMethod = process.argv[process.argv.indexOf('-m') +1];
|
||||||
|
this.DEFAULT_LOAD_METHOD = loadMethod.match('mmap') ? 'mmap' : loadMethod.match('directly') ? 'directly' : 'datastore';
|
||||||
this.DEFAULT_ORIGIN = [1,1];
|
this.DEFAULT_ORIGIN = [1,1];
|
||||||
this.OSM_USER = 'osrm';
|
this.OSM_USER = 'osrm';
|
||||||
this.OSM_UID = 1;
|
this.OSM_UID = 1;
|
||||||
@ -44,7 +45,7 @@ module.exports = function () {
|
|||||||
this.OSRM_IP = process.env.OSRM_IP || '127.0.0.1';
|
this.OSRM_IP = process.env.OSRM_IP || '127.0.0.1';
|
||||||
this.OSRM_CONNECTION_RETRIES = process.env.OSRM_CONNECTION_RETRIES && parseInt(process.env.OSRM_CONNECTION_RETRIES) || 100;
|
this.OSRM_CONNECTION_RETRIES = process.env.OSRM_CONNECTION_RETRIES && parseInt(process.env.OSRM_CONNECTION_RETRIES) || 100;
|
||||||
this.OSRM_CONNECTION_EXP_BACKOFF_COEF = process.env.OSRM_CONNECTION_EXP_BACKOFF_COEF && parseFloat(process.env.OSRM_CONNECTION_EXP_BACKOFF_COEF) || 1.0;
|
this.OSRM_CONNECTION_EXP_BACKOFF_COEF = process.env.OSRM_CONNECTION_EXP_BACKOFF_COEF && parseFloat(process.env.OSRM_CONNECTION_EXP_BACKOFF_COEF) || 1.0;
|
||||||
|
|
||||||
this.HOST = `http://${this.OSRM_IP}:${this.OSRM_PORT}`;
|
this.HOST = `http://${this.OSRM_IP}:${this.OSRM_PORT}`;
|
||||||
|
|
||||||
this.OSRM_PROFILE = process.env.OSRM_PROFILE;
|
this.OSRM_PROFILE = process.env.OSRM_PROFILE;
|
||||||
|
@ -37,6 +37,7 @@ module.exports = function () {
|
|||||||
this.contractArgs = '';
|
this.contractArgs = '';
|
||||||
this.partitionArgs = '';
|
this.partitionArgs = '';
|
||||||
this.customizeArgs = '';
|
this.customizeArgs = '';
|
||||||
|
this.loaderArgs = '';
|
||||||
this.environment = Object.assign(this.DEFAULT_ENVIRONMENT);
|
this.environment = Object.assign(this.DEFAULT_ENVIRONMENT);
|
||||||
this.resetOSM();
|
this.resetOSM();
|
||||||
|
|
||||||
|
@ -101,7 +101,8 @@ module.exports = function () {
|
|||||||
|
|
||||||
this.requestTrip = (waypoints, userParams, callback) => {
|
this.requestTrip = (waypoints, userParams, callback) => {
|
||||||
var defaults = {
|
var defaults = {
|
||||||
output: 'json'
|
output: 'json',
|
||||||
|
steps: 'true'
|
||||||
},
|
},
|
||||||
params = this.overwriteParams(defaults, userParams);
|
params = this.overwriteParams(defaults, userParams);
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ Feature: Alternative route
|
|||||||
| 7 | 8 | ca,ab,bd,dc,ca,ca | |
|
| 7 | 8 | ca,ab,bd,dc,ca,ca | |
|
||||||
|
|
||||||
|
|
||||||
@mld-only
|
@mld
|
||||||
Scenario: Alternative loop paths on a single node with an asymmetric circle
|
Scenario: Alternative loop paths on a single node with an asymmetric circle
|
||||||
# The test checks only MLD implementation, alternatives results are unpredictable for CH on windows (#4691, #4693)
|
# The test checks only MLD implementation, alternatives results are unpredictable for CH on windows (#4691, #4693)
|
||||||
Given a grid size of 10 meters
|
Given a grid size of 10 meters
|
||||||
|
@ -115,4 +115,4 @@ Feature: Annotations
|
|||||||
|
|
||||||
When I route I should get
|
When I route I should get
|
||||||
| from | to | route | a:speed | a:distance | a:duration | a:nodes |
|
| from | to | route | a:speed | a:distance | a:duration | a:nodes |
|
||||||
| a | c | abc,abc | 10:10 | 249.987618946:299.962882039 +- 1e-7 | 25:30 | 1:2:3 |
|
| a | c | abc,abc | 10:10 | 249.9876189:299.962882 +- 1e-7 | 25:30 | 1:2:3 |
|
@ -811,7 +811,7 @@ Feature: Basic Map Matching
|
|||||||
|
|
||||||
# These should have the same weights/duration in either direction
|
# These should have the same weights/duration in either direction
|
||||||
When I match I should get
|
When I match I should get
|
||||||
| trace | geometry | a:distance | a:duration | a:weight | duration |
|
| trace | geometry | a:distance | a:duration | a:weight | duration |
|
||||||
| 2345 | 1.00018,1,1.000314,1 | 14.914666491 | 1.4 | 1.4 | 1.4 |
|
| 2345 | 1.00018,1,1.000314,1 | 14.91466649 | 1.4 | 1.4 | 1.4 |
|
||||||
| 4321 | 1.00027,1,1.000135,1 | 15.025969972 | 1.5 | 1.5 | 1.5 |
|
| 4321 | 1.00027,1,1.000135,1 | 15.02596997 | 1.5 | 1.5 | 1.5 |
|
||||||
|
|
||||||
|
@ -570,7 +570,8 @@ Feature: Snapping at intersections
|
|||||||
| a,f,k | ac,cf,cf,fj,kj,kj | 132.8s | 132.8 |
|
| a,f,k | ac,cf,cf,fj,kj,kj | 132.8s | 132.8 |
|
||||||
| k,f | ik,fi,fi | 54.3s | 54.3 |
|
| k,f | ik,fi,fi | 54.3s | 54.3 |
|
||||||
| f,a | ef,ae,ae | 66.6s | 66.6 |
|
| f,a | ef,ae,ae | 66.6s | 66.6 |
|
||||||
| k,f,a | kj,fj,fj,ef,ae,ae | 141.399999999s +- 1e-7 | 141.399999999 +- 1e-7 |
|
| k,f,a | kj,fj,fj,ef,ae,ae | 141.4s +- 1e-7 | 141.4 +- 1e-7 |
|
||||||
|
|
||||||
|
|
||||||
When I request a travel time matrix I should get
|
When I request a travel time matrix I should get
|
||||||
| | a | f | k |
|
| | a | f | k |
|
||||||
@ -626,4 +627,4 @@ Feature: Snapping at intersections
|
|||||||
| a,f,k | ad,df,df,fj,kj,kj | 105.6s | 105.6 |
|
| a,f,k | ad,df,df,fj,kj,kj | 105.6s | 105.6 |
|
||||||
| k,f | ik,fi,fi | 54.3s | 54.3 |
|
| k,f | ik,fi,fi | 54.3s | 54.3 |
|
||||||
| f,a | ef,ae,ae | 66.6s | 66.6 |
|
| f,a | ef,ae,ae | 66.6s | 66.6 |
|
||||||
| k,f,a | ik,fi,fi,ef,ae,ae | 120.899999999s +- 1e-7 | 120.899999999 +- 1e-7 |
|
| k,f,a | ik,fi,fi,ef,ae,ae | 120.9s +- 1e-7 | 120.9 +- 1e-7 |
|
||||||
|
@ -52,11 +52,11 @@ Feature: Weight tests
|
|||||||
| abc |
|
| abc |
|
||||||
|
|
||||||
When I route I should get
|
When I route I should get
|
||||||
| waypoints | route | distances | weights | times | a:distance | a:duration | a:weight | a:speed |
|
| waypoints | route | distances | weights | times | a:distance | a:duration | a:weight | a:speed |
|
||||||
| s,t | abc,abc | 20m,0m | 2,0 | 2s,0s | 20.034626629 +- 1e-7 | 2 | 2 | 10 |
|
| s,t | abc,abc | 20m,0m | 2,0 | 2s,0s | 20.03462663 +- 1e-7 | 2 | 2 | 10 |
|
||||||
| t,s | abc,abc | 20m,0m | 2,0 | 2s,0s | 20.034626629 +- 1e-7 | 2 | 2 | 10 |
|
| t,s | abc,abc | 20m,0m | 2,0 | 2s,0s | 20.03462663 +- 1e-7 | 2 | 2 | 10 |
|
||||||
| s,e | abc,abc | 40m,0m | 3.9,0 | 3.9s,0s | 29.940636463:10.017313314 +- 1e-7 | 3:0.9 | 3:0.9 | 10:11.1 |
|
| s,e | abc,abc | 40m,0m | 3.9,0 | 3.9s,0s | 29.94063646:10.01731331 +- 1e-7 | 3:0.9 | 3:0.9 | 10:11.1 |
|
||||||
| e,s | abc,abc | 40m,0m | 3.9,0 | 3.9s,0s | 10.017313314:29.940636463 +- 1e-7 | 0.9:3 | 0.9:3 | 11.1:10 |
|
| e,s | abc,abc | 40m,0m | 3.9,0 | 3.9s,0s | 10.01731331:29.94063646 +- 1e-7 | 0.9:3 | 0.9:3 | 11.1:10 |
|
||||||
|
|
||||||
|
|
||||||
Scenario: Step weights -- way_function: fail if no weight or weight_per_meter property
|
Scenario: Step weights -- way_function: fail if no weight or weight_per_meter property
|
||||||
|
@ -7,9 +7,7 @@
|
|||||||
#include "contractor/graph_contractor_adaptors.hpp"
|
#include "contractor/graph_contractor_adaptors.hpp"
|
||||||
#include "contractor/query_graph.hpp"
|
#include "contractor/query_graph.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
using GraphAndFilter = std::tuple<QueryGraph, std::vector<std::vector<bool>>>;
|
using GraphAndFilter = std::tuple<QueryGraph, std::vector<std::vector<bool>>>;
|
||||||
@ -94,7 +92,6 @@ inline auto contractExcludableGraph(ContractorGraph contractor_graph_,
|
|||||||
return GraphAndFilter{QueryGraph{num_nodes, edge_container.edges},
|
return GraphAndFilter{QueryGraph{num_nodes, edge_container.edges},
|
||||||
edge_container.MakeEdgeFilters()};
|
edge_container.MakeEdgeFilters()};
|
||||||
}
|
}
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -14,9 +14,7 @@
|
|||||||
#include <numeric>
|
#include <numeric>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct ContractedEdgeContainer
|
struct ContractedEdgeContainer
|
||||||
@ -164,7 +162,6 @@ struct ContractedEdgeContainer
|
|||||||
std::vector<MergedFlags> flags;
|
std::vector<MergedFlags> flags;
|
||||||
std::vector<QueryEdge> edges;
|
std::vector<QueryEdge> edges;
|
||||||
};
|
};
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,9 +3,7 @@
|
|||||||
|
|
||||||
#include "contractor/query_graph.hpp"
|
#include "contractor/query_graph.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
@ -19,7 +17,6 @@ template <storage::Ownership Ownership> struct ContractedMetric
|
|||||||
|
|
||||||
using ContractedMetric = detail::ContractedMetric<storage::Ownership::Container>;
|
using ContractedMetric = detail::ContractedMetric<storage::Ownership::Container>;
|
||||||
using ContractedMetricView = detail::ContractedMetric<storage::Ownership::View>;
|
using ContractedMetricView = detail::ContractedMetric<storage::Ownership::View>;
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,9 +30,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
#include "contractor/contractor_config.hpp"
|
#include "contractor/contractor_config.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/// Base class of osrm-contract
|
/// Base class of osrm-contract
|
||||||
@ -49,7 +47,6 @@ class Contractor
|
|||||||
private:
|
private:
|
||||||
ContractorConfig config;
|
ContractorConfig config;
|
||||||
};
|
};
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // PROCESSING_CHAIN_HPP
|
#endif // PROCESSING_CHAIN_HPP
|
||||||
|
@ -35,9 +35,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct ContractorConfig final : storage::IOConfig
|
struct ContractorConfig final : storage::IOConfig
|
||||||
@ -71,7 +69,6 @@ struct ContractorConfig final : storage::IOConfig
|
|||||||
//(e.g. 0.8 contracts 80 percent of the hierarchy, leaving a core of 20%)
|
//(e.g. 0.8 contracts 80 percent of the hierarchy, leaving a core of 20%)
|
||||||
double core_factor = 1.0;
|
double core_factor = 1.0;
|
||||||
};
|
};
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // EXTRACTOR_OPTIONS_HPP
|
#endif // EXTRACTOR_OPTIONS_HPP
|
||||||
|
@ -4,20 +4,18 @@
|
|||||||
#include "util/dynamic_graph.hpp"
|
#include "util/dynamic_graph.hpp"
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct ContractorEdgeData
|
struct ContractorEdgeData
|
||||||
{
|
{
|
||||||
ContractorEdgeData()
|
ContractorEdgeData()
|
||||||
: weight(0), duration(0), distance(0), id(0), originalEdges(0), shortcut(0), forward(0),
|
: weight{0}, duration{0}, distance{0}, id(0), originalEdges(0), shortcut(0), forward(0),
|
||||||
backward(0)
|
backward(0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
ContractorEdgeData(EdgeWeight weight,
|
ContractorEdgeData(EdgeWeight weight,
|
||||||
EdgeWeight duration,
|
EdgeDuration duration,
|
||||||
EdgeDistance distance,
|
EdgeDistance distance,
|
||||||
unsigned original_edges,
|
unsigned original_edges,
|
||||||
unsigned id,
|
unsigned id,
|
||||||
@ -30,7 +28,7 @@ struct ContractorEdgeData
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
EdgeWeight weight;
|
EdgeWeight weight;
|
||||||
EdgeWeight duration;
|
EdgeDuration duration;
|
||||||
EdgeDistance distance;
|
EdgeDistance distance;
|
||||||
unsigned id;
|
unsigned id;
|
||||||
unsigned originalEdges : 29;
|
unsigned originalEdges : 29;
|
||||||
@ -42,7 +40,6 @@ struct ContractorEdgeData
|
|||||||
using ContractorGraph = util::DynamicGraph<ContractorEdgeData>;
|
using ContractorGraph = util::DynamicGraph<ContractorEdgeData>;
|
||||||
using ContractorEdge = ContractorGraph::InputEdge;
|
using ContractorEdge = ContractorGraph::InputEdge;
|
||||||
|
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CONTRACTOR_CONTRACTOR_GRAPH_HPP_
|
#endif // OSRM_CONTRACTOR_CONTRACTOR_GRAPH_HPP_
|
||||||
|
@ -5,9 +5,7 @@
|
|||||||
#include "util/typedefs.hpp"
|
#include "util/typedefs.hpp"
|
||||||
#include "util/xor_fast_hash_storage.hpp"
|
#include "util/xor_fast_hash_storage.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
struct ContractorHeapData
|
struct ContractorHeapData
|
||||||
{
|
{
|
||||||
@ -24,7 +22,6 @@ using ContractorHeap = util::QueryHeap<NodeID,
|
|||||||
ContractorHeapData,
|
ContractorHeapData,
|
||||||
util::XORFastHashStorage<NodeID, NodeID>>;
|
util::XORFastHashStorage<NodeID, NodeID>>;
|
||||||
|
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CONTRACTOR_CONTRACTOR_HEAP_HPP_
|
#endif // OSRM_CONTRACTOR_CONTRACTOR_HEAP_HPP_
|
||||||
|
@ -8,9 +8,7 @@
|
|||||||
|
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
void search(ContractorHeap &heap,
|
void search(ContractorHeap &heap,
|
||||||
@ -20,7 +18,6 @@ void search(ContractorHeap &heap,
|
|||||||
const EdgeWeight weight_limit,
|
const EdgeWeight weight_limit,
|
||||||
const NodeID forbidden_node);
|
const NodeID forbidden_node);
|
||||||
|
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CONTRACTOR_DIJKSTRA_HPP
|
#endif // OSRM_CONTRACTOR_DIJKSTRA_HPP
|
||||||
|
@ -9,9 +9,7 @@
|
|||||||
|
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class IteratorbasedCRC32
|
class IteratorbasedCRC32
|
||||||
@ -125,7 +123,6 @@ struct RangebasedCRC32
|
|||||||
private:
|
private:
|
||||||
IteratorbasedCRC32 crc32;
|
IteratorbasedCRC32 crc32;
|
||||||
};
|
};
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif /* ITERATOR_BASED_CRC32_H */
|
#endif /* ITERATOR_BASED_CRC32_H */
|
||||||
|
@ -5,11 +5,7 @@
|
|||||||
|
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor::files
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
|
||||||
namespace files
|
|
||||||
{
|
{
|
||||||
// reads .osrm.hsgr file
|
// reads .osrm.hsgr file
|
||||||
template <typename ContractedMetricT>
|
template <typename ContractedMetricT>
|
||||||
@ -52,8 +48,6 @@ inline void writeGraph(const boost::filesystem::path &path,
|
|||||||
serialization::write(writer, "/ch/metrics/" + pair.first, pair.second);
|
serialization::write(writer, "/ch/metrics/" + pair.first, pair.second);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // namespace files
|
} // namespace osrm::contractor::files
|
||||||
} // namespace contractor
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -8,9 +8,7 @@
|
|||||||
#include <tuple>
|
#include <tuple>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
std::vector<bool> contractGraph(ContractorGraph &graph,
|
std::vector<bool> contractGraph(ContractorGraph &graph,
|
||||||
@ -37,7 +35,6 @@ inline auto contractGraph(ContractorGraph &graph,
|
|||||||
graph, {}, std::move(node_is_contractable), std::move(node_weights), core_factor);
|
graph, {}, std::move(node_is_contractable), std::move(node_weights), core_factor);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CONTRACTOR_GRAPH_CONTRACTOR_HPP
|
#endif // OSRM_CONTRACTOR_GRAPH_CONTRACTOR_HPP
|
||||||
|
@ -10,9 +10,7 @@
|
|||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
// Make sure to move in the input edge list!
|
// Make sure to move in the input edge list!
|
||||||
@ -29,18 +27,20 @@ ContractorGraph toContractorGraph(NodeID number_of_nodes, InputEdgeContainer inp
|
|||||||
|
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
const unsigned int constexpr DAY_IN_DECI_SECONDS = 24 * 60 * 60 * 10;
|
const unsigned int constexpr DAY_IN_DECI_SECONDS = 24 * 60 * 60 * 10;
|
||||||
if (static_cast<unsigned int>(std::max(input_edge.data.weight, 1)) > DAY_IN_DECI_SECONDS)
|
if (from_alias<unsigned int>(std::max(input_edge.data.weight, EdgeWeight{1})) >
|
||||||
|
DAY_IN_DECI_SECONDS)
|
||||||
{
|
{
|
||||||
util::Log(logWARNING) << "Edge weight large -> "
|
util::Log(logWARNING) << "Edge weight large -> "
|
||||||
<< static_cast<unsigned int>(std::max(input_edge.data.weight, 1))
|
<< from_alias<unsigned int>(
|
||||||
|
std::max(input_edge.data.weight, EdgeWeight{1}))
|
||||||
<< " : " << static_cast<unsigned int>(input_edge.source) << " -> "
|
<< " : " << static_cast<unsigned int>(input_edge.source) << " -> "
|
||||||
<< static_cast<unsigned int>(input_edge.target);
|
<< static_cast<unsigned int>(input_edge.target);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
edges.emplace_back(input_edge.source,
|
edges.emplace_back(input_edge.source,
|
||||||
input_edge.target,
|
input_edge.target,
|
||||||
std::max(input_edge.data.weight, 1),
|
std::max(input_edge.data.weight, {1}),
|
||||||
input_edge.data.duration,
|
to_alias<EdgeDuration>(input_edge.data.duration),
|
||||||
input_edge.data.distance,
|
input_edge.data.distance,
|
||||||
1,
|
1,
|
||||||
input_edge.data.turn_id,
|
input_edge.data.turn_id,
|
||||||
@ -50,8 +50,8 @@ ContractorGraph toContractorGraph(NodeID number_of_nodes, InputEdgeContainer inp
|
|||||||
|
|
||||||
edges.emplace_back(input_edge.target,
|
edges.emplace_back(input_edge.target,
|
||||||
input_edge.source,
|
input_edge.source,
|
||||||
std::max(input_edge.data.weight, 1),
|
std::max(input_edge.data.weight, {1}),
|
||||||
input_edge.data.duration,
|
to_alias<EdgeDuration>(input_edge.data.duration),
|
||||||
input_edge.data.distance,
|
input_edge.data.distance,
|
||||||
1,
|
1,
|
||||||
input_edge.data.turn_id,
|
input_edge.data.turn_id,
|
||||||
@ -109,7 +109,7 @@ ContractorGraph toContractorGraph(NodeID number_of_nodes, InputEdgeContainer inp
|
|||||||
// merge edges (s,t) and (t,s) into bidirectional edge
|
// merge edges (s,t) and (t,s) into bidirectional edge
|
||||||
if (forward_edge.data.weight == reverse_edge.data.weight)
|
if (forward_edge.data.weight == reverse_edge.data.weight)
|
||||||
{
|
{
|
||||||
if ((int)forward_edge.data.weight != INVALID_EDGE_WEIGHT)
|
if (forward_edge.data.weight != INVALID_EDGE_WEIGHT)
|
||||||
{
|
{
|
||||||
forward_edge.data.backward = true;
|
forward_edge.data.backward = true;
|
||||||
edges[edge++] = forward_edge;
|
edges[edge++] = forward_edge;
|
||||||
@ -117,11 +117,11 @@ ContractorGraph toContractorGraph(NodeID number_of_nodes, InputEdgeContainer inp
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{ // insert seperate edges
|
{ // insert seperate edges
|
||||||
if (((int)forward_edge.data.weight) != INVALID_EDGE_WEIGHT)
|
if (forward_edge.data.weight != INVALID_EDGE_WEIGHT)
|
||||||
{
|
{
|
||||||
edges[edge++] = forward_edge;
|
edges[edge++] = forward_edge;
|
||||||
}
|
}
|
||||||
if ((int)reverse_edge.data.weight != INVALID_EDGE_WEIGHT)
|
if (reverse_edge.data.weight != INVALID_EDGE_WEIGHT)
|
||||||
{
|
{
|
||||||
edges[edge++] = reverse_edge;
|
edges[edge++] = reverse_edge;
|
||||||
}
|
}
|
||||||
@ -157,7 +157,7 @@ template <class Edge, typename GraphT> inline std::vector<Edge> toEdges(GraphT g
|
|||||||
new_edge.target = target;
|
new_edge.target = target;
|
||||||
BOOST_ASSERT_MSG(SPECIAL_NODEID != new_edge.target, "Target id invalid");
|
BOOST_ASSERT_MSG(SPECIAL_NODEID != new_edge.target, "Target id invalid");
|
||||||
new_edge.data.weight = data.weight;
|
new_edge.data.weight = data.weight;
|
||||||
new_edge.data.duration = data.duration;
|
new_edge.data.duration = from_alias<EdgeDuration::value_type>(data.duration);
|
||||||
new_edge.data.distance = data.distance;
|
new_edge.data.distance = data.distance;
|
||||||
new_edge.data.shortcut = data.shortcut;
|
new_edge.data.shortcut = data.shortcut;
|
||||||
new_edge.data.turn_id = data.id;
|
new_edge.data.turn_id = data.id;
|
||||||
@ -175,7 +175,6 @@ template <class Edge, typename GraphT> inline std::vector<Edge> toEdges(GraphT g
|
|||||||
return edges;
|
return edges;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CONTRACTOR_GRAPH_CONTRACTION_ADAPTORS_HPP_
|
#endif // OSRM_CONTRACTOR_GRAPH_CONTRACTION_ADAPTORS_HPP_
|
||||||
|
@ -5,9 +5,7 @@
|
|||||||
|
|
||||||
#include <tuple>
|
#include <tuple>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct QueryEdge
|
struct QueryEdge
|
||||||
@ -17,15 +15,15 @@ struct QueryEdge
|
|||||||
struct EdgeData
|
struct EdgeData
|
||||||
{
|
{
|
||||||
explicit EdgeData()
|
explicit EdgeData()
|
||||||
: turn_id(0), shortcut(false), weight(0), duration(0), forward(false), backward(false),
|
: turn_id(0), shortcut(false), weight{0}, duration(0), forward(false),
|
||||||
distance(0)
|
backward(false), distance{0}
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
EdgeData(const NodeID turn_id,
|
EdgeData(const NodeID turn_id,
|
||||||
const bool shortcut,
|
const bool shortcut,
|
||||||
const EdgeWeight weight,
|
const EdgeWeight weight,
|
||||||
const EdgeWeight duration,
|
const EdgeDuration duration,
|
||||||
const EdgeDistance distance,
|
const EdgeDistance distance,
|
||||||
const bool forward,
|
const bool forward,
|
||||||
const bool backward)
|
const bool backward)
|
||||||
@ -50,7 +48,7 @@ struct QueryEdge
|
|||||||
NodeID turn_id : 31;
|
NodeID turn_id : 31;
|
||||||
bool shortcut : 1;
|
bool shortcut : 1;
|
||||||
EdgeWeight weight;
|
EdgeWeight weight;
|
||||||
EdgeWeight duration : 30;
|
EdgeDuration::value_type duration : 30;
|
||||||
std::uint32_t forward : 1;
|
std::uint32_t forward : 1;
|
||||||
std::uint32_t backward : 1;
|
std::uint32_t backward : 1;
|
||||||
EdgeDistance distance;
|
EdgeDistance distance;
|
||||||
@ -77,7 +75,6 @@ struct QueryEdge
|
|||||||
data.distance == right.data.distance);
|
data.distance == right.data.distance);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // QUERYEDGE_HPP
|
#endif // QUERYEDGE_HPP
|
||||||
|
@ -6,9 +6,7 @@
|
|||||||
#include "util/static_graph.hpp"
|
#include "util/static_graph.hpp"
|
||||||
#include "util/typedefs.hpp"
|
#include "util/typedefs.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
{
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
@ -19,7 +17,6 @@ using QueryGraph = util::StaticGraph<typename QueryEdge::EdgeData, Ownership>;
|
|||||||
|
|
||||||
using QueryGraph = detail::QueryGraph<storage::Ownership::Container>;
|
using QueryGraph = detail::QueryGraph<storage::Ownership::Container>;
|
||||||
using QueryGraphView = detail::QueryGraph<storage::Ownership::View>;
|
using QueryGraphView = detail::QueryGraph<storage::Ownership::View>;
|
||||||
} // namespace contractor
|
} // namespace osrm::contractor
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // QUERYEDGE_HPP
|
#endif // QUERYEDGE_HPP
|
||||||
|
@ -8,11 +8,7 @@
|
|||||||
#include "storage/serialization.hpp"
|
#include "storage/serialization.hpp"
|
||||||
#include "storage/tar.hpp"
|
#include "storage/tar.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::contractor::serialization
|
||||||
{
|
|
||||||
namespace contractor
|
|
||||||
{
|
|
||||||
namespace serialization
|
|
||||||
{
|
{
|
||||||
|
|
||||||
template <storage::Ownership Ownership>
|
template <storage::Ownership Ownership>
|
||||||
@ -46,8 +42,6 @@ void read(storage::tar::FileReader &reader,
|
|||||||
metric.edge_filter[index]);
|
metric.edge_filter[index]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // namespace serialization
|
} // namespace osrm::contractor::serialization
|
||||||
} // namespace contractor
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -10,9 +10,7 @@
|
|||||||
|
|
||||||
#include <unordered_set>
|
#include <unordered_set>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::customizer
|
||||||
{
|
|
||||||
namespace customizer
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class CellCustomizer
|
class CellCustomizer
|
||||||
@ -61,7 +59,7 @@ class CellCustomizer
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
heap.Clear();
|
heap.Clear();
|
||||||
heap.Insert(source, 0, {false, 0, 0});
|
heap.Insert(source, {0}, {false, {0}, {0}});
|
||||||
|
|
||||||
// explore search space
|
// explore search space
|
||||||
while (!heap.Empty() && !destinations_set.empty())
|
while (!heap.Empty() && !destinations_set.empty())
|
||||||
@ -216,12 +214,11 @@ class CellCustomizer
|
|||||||
partition.GetCell(level - 1, to)))
|
partition.GetCell(level - 1, to)))
|
||||||
{
|
{
|
||||||
const EdgeWeight to_weight = weight + data.weight;
|
const EdgeWeight to_weight = weight + data.weight;
|
||||||
const EdgeDuration to_duration = duration + data.duration;
|
const EdgeDuration to_duration = duration + to_alias<EdgeDuration>(data.duration);
|
||||||
const EdgeDistance to_distance = distance + data.distance;
|
const EdgeDistance to_distance = distance + data.distance;
|
||||||
if (!heap.WasInserted(to))
|
if (!heap.WasInserted(to))
|
||||||
{
|
{
|
||||||
heap.Insert(
|
heap.Insert(to, to_weight, {false, to_duration, to_distance});
|
||||||
to, to_weight, {false, duration + data.duration, distance + data.distance});
|
|
||||||
}
|
}
|
||||||
else if (std::tie(to_weight, to_duration, to_distance) <
|
else if (std::tie(to_weight, to_duration, to_distance) <
|
||||||
std::tie(
|
std::tie(
|
||||||
@ -236,7 +233,6 @@ class CellCustomizer
|
|||||||
|
|
||||||
const partitioner::MultiLevelPartition &partition;
|
const partitioner::MultiLevelPartition &partition;
|
||||||
};
|
};
|
||||||
} // namespace customizer
|
} // namespace osrm::customizer
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CELLS_CUSTOMIZER_HPP
|
#endif // OSRM_CELLS_CUSTOMIZER_HPP
|
||||||
|
@ -7,9 +7,7 @@
|
|||||||
#include "util/typedefs.hpp"
|
#include "util/typedefs.hpp"
|
||||||
#include "util/vector_view.hpp"
|
#include "util/vector_view.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::customizer
|
||||||
{
|
|
||||||
namespace customizer
|
|
||||||
{
|
{
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
@ -26,7 +24,6 @@ template <storage::Ownership Ownership> struct CellMetricImpl
|
|||||||
|
|
||||||
using CellMetric = detail::CellMetricImpl<storage::Ownership::Container>;
|
using CellMetric = detail::CellMetricImpl<storage::Ownership::Container>;
|
||||||
using CellMetricView = detail::CellMetricImpl<storage::Ownership::View>;
|
using CellMetricView = detail::CellMetricImpl<storage::Ownership::View>;
|
||||||
} // namespace customizer
|
} // namespace osrm::customizer
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,9 +3,7 @@
|
|||||||
|
|
||||||
#include "customizer/customizer_config.hpp"
|
#include "customizer/customizer_config.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::customizer
|
||||||
{
|
|
||||||
namespace customizer
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class Customizer
|
class Customizer
|
||||||
@ -14,7 +12,6 @@ class Customizer
|
|||||||
int Run(const CustomizationConfig &config);
|
int Run(const CustomizationConfig &config);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace customizer
|
} // namespace osrm::customizer
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CUSTOMIZE_CUSTOMIZER_HPP
|
#endif // OSRM_CUSTOMIZE_CUSTOMIZER_HPP
|
||||||
|
@ -9,9 +9,7 @@
|
|||||||
#include "storage/io_config.hpp"
|
#include "storage/io_config.hpp"
|
||||||
#include "updater/updater_config.hpp"
|
#include "updater/updater_config.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::customizer
|
||||||
{
|
|
||||||
namespace customizer
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct CustomizationConfig final : storage::IOConfig
|
struct CustomizationConfig final : storage::IOConfig
|
||||||
@ -39,7 +37,6 @@ struct CustomizationConfig final : storage::IOConfig
|
|||||||
|
|
||||||
updater::UpdaterConfig updater_config;
|
updater::UpdaterConfig updater_config;
|
||||||
};
|
};
|
||||||
} // namespace customizer
|
} // namespace osrm::customizer
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_CUSTOMIZE_CUSTOMIZER_CONFIG_HPP
|
#endif // OSRM_CUSTOMIZE_CUSTOMIZER_CONFIG_HPP
|
||||||
|
@ -11,9 +11,7 @@
|
|||||||
|
|
||||||
#include <boost/filesystem/path.hpp>
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::customizer
|
||||||
{
|
|
||||||
namespace customizer
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct EdgeBasedGraphEdgeData
|
struct EdgeBasedGraphEdgeData
|
||||||
@ -97,7 +95,7 @@ class MultiLevelGraph : public partitioner::MultiLevelGraph<EdgeDataT, Ownership
|
|||||||
|
|
||||||
EdgeWeight GetNodeWeight(NodeID node) const { return node_weights[node]; }
|
EdgeWeight GetNodeWeight(NodeID node) const { return node_weights[node]; }
|
||||||
|
|
||||||
EdgeWeight GetNodeDuration(NodeID node) const { return node_durations[node]; }
|
EdgeDuration GetNodeDuration(NodeID node) const { return node_durations[node]; }
|
||||||
|
|
||||||
EdgeDistance GetNodeDistance(NodeID node) const { return node_distances[node]; }
|
EdgeDistance GetNodeDistance(NodeID node) const { return node_distances[node]; }
|
||||||
|
|
||||||
@ -126,7 +124,6 @@ using MultiLevelEdgeBasedGraph =
|
|||||||
MultiLevelGraph<EdgeBasedGraphEdgeData, storage::Ownership::Container>;
|
MultiLevelGraph<EdgeBasedGraphEdgeData, storage::Ownership::Container>;
|
||||||
using MultiLevelEdgeBasedGraphView =
|
using MultiLevelEdgeBasedGraphView =
|
||||||
MultiLevelGraph<EdgeBasedGraphEdgeData, storage::Ownership::View>;
|
MultiLevelGraph<EdgeBasedGraphEdgeData, storage::Ownership::View>;
|
||||||
} // namespace customizer
|
} // namespace osrm::customizer
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -9,11 +9,7 @@
|
|||||||
|
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::customizer::files
|
||||||
{
|
|
||||||
namespace customizer
|
|
||||||
{
|
|
||||||
namespace files
|
|
||||||
{
|
{
|
||||||
|
|
||||||
// reads .osrm.cell_metrics file
|
// reads .osrm.cell_metrics file
|
||||||
@ -106,8 +102,6 @@ inline void writeGraph(const boost::filesystem::path &path,
|
|||||||
writer.WriteFrom("/mld/connectivity_checksum", connectivity_checksum);
|
writer.WriteFrom("/mld/connectivity_checksum", connectivity_checksum);
|
||||||
serialization::write(writer, "/mld/multilevelgraph", graph);
|
serialization::write(writer, "/mld/multilevelgraph", graph);
|
||||||
}
|
}
|
||||||
} // namespace files
|
} // namespace osrm::customizer::files
|
||||||
} // namespace customizer
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -9,11 +9,7 @@
|
|||||||
#include "storage/shared_memory_ownership.hpp"
|
#include "storage/shared_memory_ownership.hpp"
|
||||||
#include "storage/tar.hpp"
|
#include "storage/tar.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::customizer::serialization
|
||||||
{
|
|
||||||
namespace customizer
|
|
||||||
{
|
|
||||||
namespace serialization
|
|
||||||
{
|
{
|
||||||
|
|
||||||
template <storage::Ownership Ownership>
|
template <storage::Ownership Ownership>
|
||||||
@ -65,8 +61,6 @@ inline void write(storage::tar::FileWriter &writer,
|
|||||||
storage::serialization::write(writer, name + "/is_backward_edge", graph.is_backward_edge);
|
storage::serialization::write(writer, name + "/is_backward_edge", graph.is_backward_edge);
|
||||||
storage::serialization::write(writer, name + "/node_to_edge_offset", graph.node_to_edge_offset);
|
storage::serialization::write(writer, name + "/node_to_edge_offset", graph.node_to_edge_offset);
|
||||||
}
|
}
|
||||||
} // namespace serialization
|
} // namespace osrm::customizer::serialization
|
||||||
} // namespace customizer
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,11 +3,7 @@
|
|||||||
|
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::routing_algorithms
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace routing_algorithms
|
|
||||||
{
|
{
|
||||||
|
|
||||||
// Contraction Hiearchy
|
// Contraction Hiearchy
|
||||||
@ -111,8 +107,6 @@ template <> struct HasGetTileTurns<mld::Algorithm> final : std::true_type
|
|||||||
template <> struct HasExcludeFlags<mld::Algorithm> final : std::true_type
|
template <> struct HasExcludeFlags<mld::Algorithm> final : std::true_type
|
||||||
{
|
{
|
||||||
};
|
};
|
||||||
} // namespace routing_algorithms
|
} // namespace osrm::engine::routing_algorithms
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -18,11 +18,7 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
static const constexpr char *INTERSECTION_DELIMITER = " / ";
|
static const constexpr char *INTERSECTION_DELIMITER = " / ";
|
||||||
@ -57,8 +53,8 @@ class BaseAPI
|
|||||||
{
|
{
|
||||||
// TODO: check forward/reverse
|
// TODO: check forward/reverse
|
||||||
const auto toName = [this](const auto &phantom) {
|
const auto toName = [this](const auto &phantom) {
|
||||||
return facade.GetNameForID(facade.GetNameIndex(phantom.forward_segment_id.id))
|
return std::string(
|
||||||
.to_string();
|
facade.GetNameForID(facade.GetNameIndex(phantom.forward_segment_id.id)));
|
||||||
};
|
};
|
||||||
const auto noEmpty = [](const auto &name) { return !name.empty(); };
|
const auto noEmpty = [](const auto &name) { return !name.empty(); };
|
||||||
|
|
||||||
@ -128,8 +124,8 @@ class BaseAPI
|
|||||||
static_cast<float>(static_cast<double>(util::toFloating(snapped_location.lat))));
|
static_cast<float>(static_cast<double>(util::toFloating(snapped_location.lat))));
|
||||||
|
|
||||||
const auto toName = [this](const auto &phantom) {
|
const auto toName = [this](const auto &phantom) {
|
||||||
return facade.GetNameForID(facade.GetNameIndex(phantom.forward_segment_id.id))
|
return std::string(
|
||||||
.to_string();
|
facade.GetNameForID(facade.GetNameIndex(phantom.forward_segment_id.id)));
|
||||||
};
|
};
|
||||||
const auto noEmpty = [](const auto &name) { return !name.empty(); };
|
const auto noEmpty = [](const auto &name) { return !name.empty(); };
|
||||||
|
|
||||||
@ -170,8 +166,6 @@ class BaseAPI
|
|||||||
const BaseParameters ¶meters;
|
const BaseParameters ¶meters;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -38,11 +38,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -124,8 +120,6 @@ struct BaseParameters
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // ROUTE_PARAMETERS_HPP
|
#endif // ROUTE_PARAMETERS_HPP
|
||||||
|
@ -8,16 +8,10 @@
|
|||||||
|
|
||||||
#include "util/json_container.hpp"
|
#include "util/json_container.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
using ResultT =
|
using ResultT =
|
||||||
mapbox::util::variant<util::json::Object, std::string, flatbuffers::FlatBufferBuilder>;
|
mapbox::util::variant<util::json::Object, std::string, flatbuffers::FlatBufferBuilder>;
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -6,10 +6,7 @@
|
|||||||
|
|
||||||
#include "flatbuffers/flatbuffers.h"
|
#include "flatbuffers/flatbuffers.h"
|
||||||
|
|
||||||
namespace osrm {
|
namespace osrm::engine::api::fbresult {
|
||||||
namespace engine {
|
|
||||||
namespace api {
|
|
||||||
namespace fbresult {
|
|
||||||
|
|
||||||
struct Position;
|
struct Position;
|
||||||
|
|
||||||
@ -219,7 +216,7 @@ FLATBUFFERS_MANUALLY_ALIGNED_STRUCT(8) Uint64Pair FLATBUFFERS_FINAL_CLASS {
|
|||||||
FLATBUFFERS_STRUCT_END(Uint64Pair, 16);
|
FLATBUFFERS_STRUCT_END(Uint64Pair, 16);
|
||||||
|
|
||||||
struct WaypointT : public flatbuffers::NativeTable {
|
struct WaypointT : public flatbuffers::NativeTable {
|
||||||
typedef Waypoint TableType;
|
using TableType = Waypoint;
|
||||||
std::string hint;
|
std::string hint;
|
||||||
float distance;
|
float distance;
|
||||||
std::string name;
|
std::string name;
|
||||||
@ -239,7 +236,7 @@ struct WaypointT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Waypoint FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Waypoint FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef WaypointT NativeTableType;
|
using NativeTableType = WaypointT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_HINT = 4,
|
VT_HINT = 4,
|
||||||
VT_DISTANCE = 6,
|
VT_DISTANCE = 6,
|
||||||
@ -393,14 +390,14 @@ inline flatbuffers::Offset<Waypoint> CreateWaypointDirect(
|
|||||||
flatbuffers::Offset<Waypoint> CreateWaypoint(flatbuffers::FlatBufferBuilder &_fbb, const WaypointT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Waypoint> CreateWaypoint(flatbuffers::FlatBufferBuilder &_fbb, const WaypointT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct MetadataT : public flatbuffers::NativeTable {
|
struct MetadataT : public flatbuffers::NativeTable {
|
||||||
typedef Metadata TableType;
|
using TableType = Metadata;
|
||||||
std::vector<std::string> datasource_names;
|
std::vector<std::string> datasource_names;
|
||||||
MetadataT() {
|
MetadataT() {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Metadata FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Metadata FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef MetadataT NativeTableType;
|
using NativeTableType = MetadataT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_DATASOURCE_NAMES = 4
|
VT_DATASOURCE_NAMES = 4
|
||||||
};
|
};
|
||||||
@ -457,7 +454,7 @@ inline flatbuffers::Offset<Metadata> CreateMetadataDirect(
|
|||||||
flatbuffers::Offset<Metadata> CreateMetadata(flatbuffers::FlatBufferBuilder &_fbb, const MetadataT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Metadata> CreateMetadata(flatbuffers::FlatBufferBuilder &_fbb, const MetadataT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct AnnotationT : public flatbuffers::NativeTable {
|
struct AnnotationT : public flatbuffers::NativeTable {
|
||||||
typedef Annotation TableType;
|
using TableType = Annotation;
|
||||||
std::vector<uint32_t> distance;
|
std::vector<uint32_t> distance;
|
||||||
std::vector<uint32_t> duration;
|
std::vector<uint32_t> duration;
|
||||||
std::vector<uint32_t> datasources;
|
std::vector<uint32_t> datasources;
|
||||||
@ -470,7 +467,7 @@ struct AnnotationT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Annotation FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Annotation FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef AnnotationT NativeTableType;
|
using NativeTableType = AnnotationT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_DISTANCE = 4,
|
VT_DISTANCE = 4,
|
||||||
VT_DURATION = 6,
|
VT_DURATION = 6,
|
||||||
@ -609,7 +606,7 @@ inline flatbuffers::Offset<Annotation> CreateAnnotationDirect(
|
|||||||
flatbuffers::Offset<Annotation> CreateAnnotation(flatbuffers::FlatBufferBuilder &_fbb, const AnnotationT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Annotation> CreateAnnotation(flatbuffers::FlatBufferBuilder &_fbb, const AnnotationT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct StepManeuverT : public flatbuffers::NativeTable {
|
struct StepManeuverT : public flatbuffers::NativeTable {
|
||||||
typedef StepManeuver TableType;
|
using TableType = StepManeuver;
|
||||||
std::unique_ptr<osrm::engine::api::fbresult::Position> location;
|
std::unique_ptr<osrm::engine::api::fbresult::Position> location;
|
||||||
uint16_t bearing_before;
|
uint16_t bearing_before;
|
||||||
uint16_t bearing_after;
|
uint16_t bearing_after;
|
||||||
@ -626,7 +623,7 @@ struct StepManeuverT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct StepManeuver FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct StepManeuver FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef StepManeuverT NativeTableType;
|
using NativeTableType = StepManeuverT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_LOCATION = 4,
|
VT_LOCATION = 4,
|
||||||
VT_BEARING_BEFORE = 6,
|
VT_BEARING_BEFORE = 6,
|
||||||
@ -722,7 +719,7 @@ inline flatbuffers::Offset<StepManeuver> CreateStepManeuver(
|
|||||||
flatbuffers::Offset<StepManeuver> CreateStepManeuver(flatbuffers::FlatBufferBuilder &_fbb, const StepManeuverT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<StepManeuver> CreateStepManeuver(flatbuffers::FlatBufferBuilder &_fbb, const StepManeuverT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct LaneT : public flatbuffers::NativeTable {
|
struct LaneT : public flatbuffers::NativeTable {
|
||||||
typedef Lane TableType;
|
using TableType = Lane;
|
||||||
std::vector<osrm::engine::api::fbresult::Turn> indications;
|
std::vector<osrm::engine::api::fbresult::Turn> indications;
|
||||||
bool valid;
|
bool valid;
|
||||||
LaneT()
|
LaneT()
|
||||||
@ -731,7 +728,7 @@ struct LaneT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Lane FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Lane FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef LaneT NativeTableType;
|
using NativeTableType = LaneT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_INDICATIONS = 4,
|
VT_INDICATIONS = 4,
|
||||||
VT_VALID = 6
|
VT_VALID = 6
|
||||||
@ -799,7 +796,7 @@ inline flatbuffers::Offset<Lane> CreateLaneDirect(
|
|||||||
flatbuffers::Offset<Lane> CreateLane(flatbuffers::FlatBufferBuilder &_fbb, const LaneT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Lane> CreateLane(flatbuffers::FlatBufferBuilder &_fbb, const LaneT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct IntersectionT : public flatbuffers::NativeTable {
|
struct IntersectionT : public flatbuffers::NativeTable {
|
||||||
typedef Intersection TableType;
|
using TableType = Intersection;
|
||||||
std::unique_ptr<osrm::engine::api::fbresult::Position> location;
|
std::unique_ptr<osrm::engine::api::fbresult::Position> location;
|
||||||
std::vector<int16_t> bearings;
|
std::vector<int16_t> bearings;
|
||||||
std::vector<std::string> classes;
|
std::vector<std::string> classes;
|
||||||
@ -814,7 +811,7 @@ struct IntersectionT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Intersection FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Intersection FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef IntersectionT NativeTableType;
|
using NativeTableType = IntersectionT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_LOCATION = 4,
|
VT_LOCATION = 4,
|
||||||
VT_BEARINGS = 6,
|
VT_BEARINGS = 6,
|
||||||
@ -950,7 +947,7 @@ inline flatbuffers::Offset<Intersection> CreateIntersectionDirect(
|
|||||||
flatbuffers::Offset<Intersection> CreateIntersection(flatbuffers::FlatBufferBuilder &_fbb, const IntersectionT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Intersection> CreateIntersection(flatbuffers::FlatBufferBuilder &_fbb, const IntersectionT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct StepT : public flatbuffers::NativeTable {
|
struct StepT : public flatbuffers::NativeTable {
|
||||||
typedef Step TableType;
|
using TableType = Step;
|
||||||
float distance;
|
float distance;
|
||||||
float duration;
|
float duration;
|
||||||
std::string polyline;
|
std::string polyline;
|
||||||
@ -976,7 +973,7 @@ struct StepT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Step FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Step FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef StepT NativeTableType;
|
using NativeTableType = StepT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_DISTANCE = 4,
|
VT_DISTANCE = 4,
|
||||||
VT_DURATION = 6,
|
VT_DURATION = 6,
|
||||||
@ -1234,7 +1231,7 @@ inline flatbuffers::Offset<Step> CreateStepDirect(
|
|||||||
flatbuffers::Offset<Step> CreateStep(flatbuffers::FlatBufferBuilder &_fbb, const StepT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Step> CreateStep(flatbuffers::FlatBufferBuilder &_fbb, const StepT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct LegT : public flatbuffers::NativeTable {
|
struct LegT : public flatbuffers::NativeTable {
|
||||||
typedef Leg TableType;
|
using TableType = Leg;
|
||||||
double distance;
|
double distance;
|
||||||
double duration;
|
double duration;
|
||||||
double weight;
|
double weight;
|
||||||
@ -1249,7 +1246,7 @@ struct LegT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Leg FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Leg FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef LegT NativeTableType;
|
using NativeTableType = LegT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_DISTANCE = 4,
|
VT_DISTANCE = 4,
|
||||||
VT_DURATION = 6,
|
VT_DURATION = 6,
|
||||||
@ -1369,7 +1366,7 @@ inline flatbuffers::Offset<Leg> CreateLegDirect(
|
|||||||
flatbuffers::Offset<Leg> CreateLeg(flatbuffers::FlatBufferBuilder &_fbb, const LegT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Leg> CreateLeg(flatbuffers::FlatBufferBuilder &_fbb, const LegT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct RouteObjectT : public flatbuffers::NativeTable {
|
struct RouteObjectT : public flatbuffers::NativeTable {
|
||||||
typedef RouteObject TableType;
|
using TableType = RouteObject;
|
||||||
float distance;
|
float distance;
|
||||||
float duration;
|
float duration;
|
||||||
float weight;
|
float weight;
|
||||||
@ -1387,7 +1384,7 @@ struct RouteObjectT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct RouteObject FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct RouteObject FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef RouteObjectT NativeTableType;
|
using NativeTableType = RouteObjectT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_DISTANCE = 4,
|
VT_DISTANCE = 4,
|
||||||
VT_DURATION = 6,
|
VT_DURATION = 6,
|
||||||
@ -1534,7 +1531,7 @@ inline flatbuffers::Offset<RouteObject> CreateRouteObjectDirect(
|
|||||||
flatbuffers::Offset<RouteObject> CreateRouteObject(flatbuffers::FlatBufferBuilder &_fbb, const RouteObjectT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<RouteObject> CreateRouteObject(flatbuffers::FlatBufferBuilder &_fbb, const RouteObjectT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct TableT : public flatbuffers::NativeTable {
|
struct TableT : public flatbuffers::NativeTable {
|
||||||
typedef Table TableType;
|
using TableType = Table;
|
||||||
std::vector<float> durations;
|
std::vector<float> durations;
|
||||||
uint16_t rows;
|
uint16_t rows;
|
||||||
uint16_t cols;
|
uint16_t cols;
|
||||||
@ -1548,7 +1545,7 @@ struct TableT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Table FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Table FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef TableT NativeTableType;
|
using NativeTableType = TableT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_DURATIONS = 4,
|
VT_DURATIONS = 4,
|
||||||
VT_ROWS = 6,
|
VT_ROWS = 6,
|
||||||
@ -1671,7 +1668,7 @@ inline flatbuffers::Offset<Table> CreateTableDirect(
|
|||||||
flatbuffers::Offset<Table> CreateTable(flatbuffers::FlatBufferBuilder &_fbb, const TableT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Table> CreateTable(flatbuffers::FlatBufferBuilder &_fbb, const TableT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct ErrorT : public flatbuffers::NativeTable {
|
struct ErrorT : public flatbuffers::NativeTable {
|
||||||
typedef Error TableType;
|
using TableType = Error;
|
||||||
std::string code;
|
std::string code;
|
||||||
std::string message;
|
std::string message;
|
||||||
ErrorT() {
|
ErrorT() {
|
||||||
@ -1679,7 +1676,7 @@ struct ErrorT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct Error FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct Error FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef ErrorT NativeTableType;
|
using NativeTableType = ErrorT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_CODE = 4,
|
VT_CODE = 4,
|
||||||
VT_MESSAGE = 6
|
VT_MESSAGE = 6
|
||||||
@ -1749,7 +1746,7 @@ inline flatbuffers::Offset<Error> CreateErrorDirect(
|
|||||||
flatbuffers::Offset<Error> CreateError(flatbuffers::FlatBufferBuilder &_fbb, const ErrorT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
flatbuffers::Offset<Error> CreateError(flatbuffers::FlatBufferBuilder &_fbb, const ErrorT *_o, const flatbuffers::rehasher_function_t *_rehasher = nullptr);
|
||||||
|
|
||||||
struct FBResultT : public flatbuffers::NativeTable {
|
struct FBResultT : public flatbuffers::NativeTable {
|
||||||
typedef FBResult TableType;
|
using TableType = FBResult;
|
||||||
bool error;
|
bool error;
|
||||||
std::unique_ptr<osrm::engine::api::fbresult::ErrorT> code;
|
std::unique_ptr<osrm::engine::api::fbresult::ErrorT> code;
|
||||||
std::string data_version;
|
std::string data_version;
|
||||||
@ -1762,7 +1759,7 @@ struct FBResultT : public flatbuffers::NativeTable {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct FBResult FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
struct FBResult FLATBUFFERS_FINAL_CLASS : private flatbuffers::Table {
|
||||||
typedef FBResultT NativeTableType;
|
using NativeTableType = FBResultT;
|
||||||
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
enum FlatBuffersVTableOffset FLATBUFFERS_VTABLE_UNDERLYING_TYPE {
|
||||||
VT_ERROR = 4,
|
VT_ERROR = 4,
|
||||||
VT_CODE = 6,
|
VT_CODE = 6,
|
||||||
@ -2431,9 +2428,6 @@ inline std::unique_ptr<osrm::engine::api::fbresult::FBResultT> UnPackSizePrefixe
|
|||||||
return std::unique_ptr<osrm::engine::api::fbresult::FBResultT>(GetSizePrefixedFBResult(buf)->UnPack(res));
|
return std::unique_ptr<osrm::engine::api::fbresult::FBResultT>(GetSizePrefixedFBResult(buf)->UnPack(res));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace fbresult
|
|
||||||
} // namespace api
|
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
} // namespace osrm
|
||||||
|
|
||||||
#endif // FLATBUFFERS_GENERATED_FBRESULT_OSRM_ENGINE_API_FBRESULT_H_
|
#endif // FLATBUFFERS_GENERATED_FBRESULT_OSRM_ENGINE_API_FBRESULT_H_
|
||||||
|
@ -19,16 +19,12 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct Hint;
|
struct Hint;
|
||||||
|
|
||||||
namespace api
|
namespace api::json
|
||||||
{
|
|
||||||
namespace json
|
|
||||||
{
|
{
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
@ -112,9 +108,7 @@ util::json::Object makeRouteLeg(guidance::RouteLeg leg, util::json::Array steps)
|
|||||||
util::json::Array makeRouteLegs(std::vector<guidance::RouteLeg> legs,
|
util::json::Array makeRouteLegs(std::vector<guidance::RouteLeg> legs,
|
||||||
std::vector<util::json::Value> step_geometries,
|
std::vector<util::json::Value> step_geometries,
|
||||||
std::vector<util::json::Object> annotations);
|
std::vector<util::json::Object> annotations);
|
||||||
} // namespace json
|
} // namespace api::json
|
||||||
} // namespace api
|
} // namespace osrm::engine
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // ENGINE_GUIDANCE_API_RESPONSE_GENERATOR_HPP_
|
#endif // ENGINE_GUIDANCE_API_RESPONSE_GENERATOR_HPP_
|
||||||
|
@ -12,11 +12,7 @@
|
|||||||
|
|
||||||
#include "util/integer_range.hpp"
|
#include "util/integer_range.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class MatchAPI final : public RouteAPI
|
class MatchAPI final : public RouteAPI
|
||||||
@ -253,8 +249,6 @@ class MatchAPI final : public RouteAPI
|
|||||||
const tidy::Result &tidy_result;
|
const tidy::Result &tidy_result;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -32,11 +32,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -98,8 +94,6 @@ struct MatchParameters : public RouteParameters
|
|||||||
(timestamps.empty() || timestamps.size() == coordinates.size());
|
(timestamps.empty() || timestamps.size() == coordinates.size());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -11,13 +11,7 @@
|
|||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
#include <boost/dynamic_bitset.hpp>
|
#include <boost/dynamic_bitset.hpp>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api::tidy
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
|
||||||
namespace tidy
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct Thresholds
|
struct Thresholds
|
||||||
@ -200,9 +194,6 @@ inline Result tidy(const MatchParameters ¶ms, Thresholds cfg = {15., 5})
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace tidy
|
} // namespace osrm::engine::api::tidy
|
||||||
} // namespace api
|
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -12,11 +12,7 @@
|
|||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class NearestAPI final : public BaseAPI
|
class NearestAPI final : public BaseAPI
|
||||||
@ -164,8 +160,6 @@ class NearestAPI final : public BaseAPI
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,11 +30,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
#include "engine/api/base_parameters.hpp"
|
#include "engine/api/base_parameters.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -52,8 +48,6 @@ struct NearestParameters : public BaseParameters
|
|||||||
|
|
||||||
bool IsValid() const { return BaseParameters::IsValid() && number_of_results >= 1; }
|
bool IsValid() const { return BaseParameters::IsValid() && number_of_results >= 1; }
|
||||||
};
|
};
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // ENGINE_API_NEAREST_PARAMETERS_HPP
|
#endif // ENGINE_API_NEAREST_PARAMETERS_HPP
|
||||||
|
@ -31,11 +31,7 @@
|
|||||||
#include <map>
|
#include <map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class RouteAPI : public BaseAPI
|
class RouteAPI : public BaseAPI
|
||||||
@ -1001,8 +997,6 @@ class RouteAPI : public BaseAPI
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -32,11 +32,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -206,13 +202,11 @@ inline RouteParameters::AnnotationsType operator|(RouteParameters::AnnotationsTy
|
|||||||
static_cast<std::underlying_type_t<RouteParameters::AnnotationsType>>(rhs));
|
static_cast<std::underlying_type_t<RouteParameters::AnnotationsType>>(rhs));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline RouteParameters::AnnotationsType operator|=(RouteParameters::AnnotationsType lhs,
|
inline RouteParameters::AnnotationsType &operator|=(RouteParameters::AnnotationsType &lhs,
|
||||||
RouteParameters::AnnotationsType rhs)
|
RouteParameters::AnnotationsType rhs)
|
||||||
{
|
{
|
||||||
return lhs = lhs | rhs;
|
return lhs = lhs | rhs;
|
||||||
}
|
}
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,11 +22,7 @@
|
|||||||
|
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class TableAPI final : public BaseAPI
|
class TableAPI final : public BaseAPI
|
||||||
@ -133,7 +129,8 @@ class TableAPI final : public BaseAPI
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool have_speed_cells =
|
bool have_speed_cells =
|
||||||
parameters.fallback_speed != INVALID_FALLBACK_SPEED && parameters.fallback_speed > 0;
|
parameters.fallback_speed != from_alias<double>(INVALID_FALLBACK_SPEED) &&
|
||||||
|
parameters.fallback_speed > 0;
|
||||||
flatbuffers::Offset<flatbuffers::Vector<uint32_t>> speed_cells;
|
flatbuffers::Offset<flatbuffers::Vector<uint32_t>> speed_cells;
|
||||||
if (have_speed_cells)
|
if (have_speed_cells)
|
||||||
{
|
{
|
||||||
@ -223,7 +220,8 @@ class TableAPI final : public BaseAPI
|
|||||||
MakeDistanceTable(tables.second, number_of_sources, number_of_destinations);
|
MakeDistanceTable(tables.second, number_of_sources, number_of_destinations);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parameters.fallback_speed != INVALID_FALLBACK_SPEED && parameters.fallback_speed > 0)
|
if (parameters.fallback_speed != from_alias<double>(INVALID_FALLBACK_SPEED) &&
|
||||||
|
parameters.fallback_speed > 0)
|
||||||
{
|
{
|
||||||
response.values["fallback_speed_cells"] = MakeEstimatesTable(fallback_speed_cells);
|
response.values["fallback_speed_cells"] = MakeEstimatesTable(fallback_speed_cells);
|
||||||
}
|
}
|
||||||
@ -272,17 +270,17 @@ class TableAPI final : public BaseAPI
|
|||||||
|
|
||||||
virtual flatbuffers::Offset<flatbuffers::Vector<float>>
|
virtual flatbuffers::Offset<flatbuffers::Vector<float>>
|
||||||
MakeDurationTable(flatbuffers::FlatBufferBuilder &builder,
|
MakeDurationTable(flatbuffers::FlatBufferBuilder &builder,
|
||||||
const std::vector<EdgeWeight> &values) const
|
const std::vector<EdgeDuration> &values) const
|
||||||
{
|
{
|
||||||
std::vector<float> distance_table;
|
std::vector<float> distance_table;
|
||||||
distance_table.resize(values.size());
|
distance_table.resize(values.size());
|
||||||
std::transform(
|
std::transform(
|
||||||
values.begin(), values.end(), distance_table.begin(), [](const EdgeWeight duration) {
|
values.begin(), values.end(), distance_table.begin(), [](const EdgeDuration duration) {
|
||||||
if (duration == MAXIMAL_EDGE_DURATION)
|
if (duration == MAXIMAL_EDGE_DURATION)
|
||||||
{
|
{
|
||||||
return 0.;
|
return 0.;
|
||||||
}
|
}
|
||||||
return duration / 10.;
|
return from_alias<double>(duration) / 10.;
|
||||||
});
|
});
|
||||||
return builder.CreateVector(distance_table);
|
return builder.CreateVector(distance_table);
|
||||||
}
|
}
|
||||||
@ -299,7 +297,7 @@ class TableAPI final : public BaseAPI
|
|||||||
{
|
{
|
||||||
return 0.;
|
return 0.;
|
||||||
}
|
}
|
||||||
return std::round(distance * 10) / 10.;
|
return std::round(from_alias<double>(distance) * 10) / 10.;
|
||||||
});
|
});
|
||||||
return builder.CreateVector(duration_table);
|
return builder.CreateVector(duration_table);
|
||||||
}
|
}
|
||||||
@ -347,7 +345,7 @@ class TableAPI final : public BaseAPI
|
|||||||
return json_waypoints;
|
return json_waypoints;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual util::json::Array MakeDurationTable(const std::vector<EdgeWeight> &values,
|
virtual util::json::Array MakeDurationTable(const std::vector<EdgeDuration> &values,
|
||||||
std::size_t number_of_rows,
|
std::size_t number_of_rows,
|
||||||
std::size_t number_of_columns) const
|
std::size_t number_of_columns) const
|
||||||
{
|
{
|
||||||
@ -361,13 +359,14 @@ class TableAPI final : public BaseAPI
|
|||||||
std::transform(row_begin_iterator,
|
std::transform(row_begin_iterator,
|
||||||
row_end_iterator,
|
row_end_iterator,
|
||||||
json_row.values.begin(),
|
json_row.values.begin(),
|
||||||
[](const EdgeWeight duration) {
|
[](const EdgeDuration duration) {
|
||||||
if (duration == MAXIMAL_EDGE_DURATION)
|
if (duration == MAXIMAL_EDGE_DURATION)
|
||||||
{
|
{
|
||||||
return util::json::Value(util::json::Null());
|
return util::json::Value(util::json::Null());
|
||||||
}
|
}
|
||||||
// division by 10 because the duration is in deciseconds (10s)
|
// division by 10 because the duration is in deciseconds (10s)
|
||||||
return util::json::Value(util::json::Number(duration / 10.));
|
return util::json::Value(
|
||||||
|
util::json::Number(from_alias<double>(duration) / 10.));
|
||||||
});
|
});
|
||||||
json_table.values.push_back(std::move(json_row));
|
json_table.values.push_back(std::move(json_row));
|
||||||
}
|
}
|
||||||
@ -394,8 +393,8 @@ class TableAPI final : public BaseAPI
|
|||||||
return util::json::Value(util::json::Null());
|
return util::json::Value(util::json::Null());
|
||||||
}
|
}
|
||||||
// round to single decimal place
|
// round to single decimal place
|
||||||
return util::json::Value(
|
return util::json::Value(util::json::Number(
|
||||||
util::json::Number(std::round(distance * 10) / 10.));
|
std::round(from_alias<double>(distance) * 10) / 10.));
|
||||||
});
|
});
|
||||||
json_table.values.push_back(std::move(json_row));
|
json_table.values.push_back(std::move(json_row));
|
||||||
}
|
}
|
||||||
@ -419,8 +418,6 @@ class TableAPI final : public BaseAPI
|
|||||||
const TableParameters ¶meters;
|
const TableParameters ¶meters;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -36,11 +36,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -59,7 +55,7 @@ struct TableParameters : public BaseParameters
|
|||||||
{
|
{
|
||||||
std::vector<std::size_t> sources;
|
std::vector<std::size_t> sources;
|
||||||
std::vector<std::size_t> destinations;
|
std::vector<std::size_t> destinations;
|
||||||
double fallback_speed = INVALID_FALLBACK_SPEED;
|
double fallback_speed = from_alias<double>(INVALID_FALLBACK_SPEED);
|
||||||
|
|
||||||
enum class FallbackCoordinateType
|
enum class FallbackCoordinateType
|
||||||
{
|
{
|
||||||
@ -166,8 +162,6 @@ inline TableParameters::AnnotationsType &operator|=(TableParameters::Annotations
|
|||||||
{
|
{
|
||||||
return lhs = lhs | rhs;
|
return lhs = lhs | rhs;
|
||||||
}
|
}
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // ENGINE_API_TABLE_PARAMETERS_HPP
|
#endif // ENGINE_API_TABLE_PARAMETERS_HPP
|
||||||
|
@ -30,11 +30,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -70,8 +66,6 @@ struct TileParameters final
|
|||||||
return valid_x && valid_y && valid_z;
|
return valid_x && valid_y && valid_z;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -10,11 +10,7 @@
|
|||||||
|
|
||||||
#include "util/integer_range.hpp"
|
#include "util/integer_range.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class TripAPI final : public RouteAPI
|
class TripAPI final : public RouteAPI
|
||||||
@ -180,8 +176,6 @@ class TripAPI final : public RouteAPI
|
|||||||
const TripParameters ¶meters;
|
const TripParameters ¶meters;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -33,11 +33,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
#include <boost/optional.hpp>
|
#include <boost/optional.hpp>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::api
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace api
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -76,8 +72,6 @@ struct TripParameters : public RouteParameters
|
|||||||
|
|
||||||
bool IsValid() const { return RouteParameters::IsValid(); }
|
bool IsValid() const { return RouteParameters::IsValid(); }
|
||||||
};
|
};
|
||||||
} // namespace api
|
} // namespace osrm::engine::api
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,9 +30,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
enum class Approach : std::uint8_t
|
enum class Approach : std::uint8_t
|
||||||
@ -41,6 +39,5 @@ enum class Approach : std::uint8_t
|
|||||||
UNRESTRICTED = 1
|
UNRESTRICTED = 1
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -28,9 +28,7 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
#ifndef OSRM_ENGINE_BEARING_HPP
|
#ifndef OSRM_ENGINE_BEARING_HPP
|
||||||
#define OSRM_ENGINE_BEARING_HPP
|
#define OSRM_ENGINE_BEARING_HPP
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
struct Bearing
|
struct Bearing
|
||||||
@ -46,7 +44,6 @@ inline bool operator==(const Bearing lhs, const Bearing rhs)
|
|||||||
return lhs.bearing == rhs.bearing && lhs.range == rhs.range;
|
return lhs.bearing == rhs.bearing && lhs.range == rhs.range;
|
||||||
}
|
}
|
||||||
inline bool operator!=(const Bearing lhs, const Bearing rhs) { return !(lhs == rhs); }
|
inline bool operator!=(const Bearing lhs, const Bearing rhs) { return !(lhs == rhs); }
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -17,9 +17,7 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
@ -149,7 +147,6 @@ class DataWatchdogImpl<AlgorithmT, datafacade::ContiguousInternalMemoryDataFacad
|
|||||||
// once a new dataset arrives.
|
// once a new dataset arrives.
|
||||||
template <typename AlgorithmT, template <typename A> class FacadeT>
|
template <typename AlgorithmT, template <typename A> class FacadeT>
|
||||||
using DataWatchdog = detail::DataWatchdogImpl<AlgorithmT, FacadeT<AlgorithmT>>;
|
using DataWatchdog = detail::DataWatchdogImpl<AlgorithmT, FacadeT<AlgorithmT>>;
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,15 +3,12 @@
|
|||||||
|
|
||||||
#include "engine/datafacade/contiguous_internalmem_datafacade.hpp"
|
#include "engine/datafacade/contiguous_internalmem_datafacade.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
using DataFacadeBase = datafacade::ContiguousInternalMemoryDataFacadeBase;
|
using DataFacadeBase = datafacade::ContiguousInternalMemoryDataFacadeBase;
|
||||||
template <typename AlgorithmT>
|
template <typename AlgorithmT>
|
||||||
using DataFacade = datafacade::ContiguousInternalMemoryDataFacade<AlgorithmT>;
|
using DataFacade = datafacade::ContiguousInternalMemoryDataFacade<AlgorithmT>;
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -12,11 +12,7 @@
|
|||||||
#include "util/filtered_graph.hpp"
|
#include "util/filtered_graph.hpp"
|
||||||
#include "util/integer_range.hpp"
|
#include "util/integer_range.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::datafacade
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace datafacade
|
|
||||||
{
|
{
|
||||||
|
|
||||||
// Namespace local aliases for algorithms
|
// Namespace local aliases for algorithms
|
||||||
@ -83,7 +79,7 @@ template <> class AlgorithmDataFacade<MLD>
|
|||||||
|
|
||||||
virtual EdgeWeight GetNodeWeight(const NodeID edge_based_node_id) const = 0;
|
virtual EdgeWeight GetNodeWeight(const NodeID edge_based_node_id) const = 0;
|
||||||
|
|
||||||
virtual EdgeWeight
|
virtual EdgeDuration
|
||||||
GetNodeDuration(const NodeID edge_based_node_id) const = 0; // TODO: to be removed
|
GetNodeDuration(const NodeID edge_based_node_id) const = 0; // TODO: to be removed
|
||||||
|
|
||||||
virtual EdgeDistance GetNodeDistance(const NodeID edge_based_node_id) const = 0;
|
virtual EdgeDistance GetNodeDistance(const NodeID edge_based_node_id) const = 0;
|
||||||
@ -109,8 +105,6 @@ template <> class AlgorithmDataFacade<MLD>
|
|||||||
virtual EdgeID FindEdge(const NodeID edge_based_node_from,
|
virtual EdgeID FindEdge(const NodeID edge_based_node_from,
|
||||||
const NodeID edge_based_node_to) const = 0;
|
const NodeID edge_based_node_to) const = 0;
|
||||||
};
|
};
|
||||||
} // namespace datafacade
|
} // namespace osrm::engine::datafacade
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,11 +3,7 @@
|
|||||||
|
|
||||||
#include "storage/shared_data_index.hpp"
|
#include "storage/shared_data_index.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::datafacade
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace datafacade
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class ContiguousBlockAllocator
|
class ContiguousBlockAllocator
|
||||||
@ -19,8 +15,6 @@ class ContiguousBlockAllocator
|
|||||||
virtual const storage::SharedDataIndex &GetIndex() = 0;
|
virtual const storage::SharedDataIndex &GetIndex() = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace datafacade
|
} // namespace osrm::engine::datafacade
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_ENGINE_DATAFACADE_CONTIGUOUS_BLOCK_ALLOCATOR_HPP_
|
#endif // OSRM_ENGINE_DATAFACADE_CONTIGUOUS_BLOCK_ALLOCATOR_HPP_
|
||||||
|
@ -28,13 +28,29 @@
|
|||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::datafacade
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace datafacade
|
|
||||||
{
|
{
|
||||||
|
|
||||||
|
static const std::string DATASET_TURN_DATA = "TurnData";
|
||||||
|
static const std::string DATASET_TURN_LANE_DATA = "NameLaneData";
|
||||||
|
static const std::string DATASET_NAME_DATA = "NameData";
|
||||||
|
static const std::string DATASET_INTERSECTION_BEARINGS = "IntersectionBearings";
|
||||||
|
static const std::string DATASET_ENTRY_CLASS = "EntryClass";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Macro is not ideal. But without it we either have to:
|
||||||
|
* a) Write this boiler-plate for every usage of an optional dataset.
|
||||||
|
* b) Convert to a function and add lots of polluting NOLINT(bugprone-unchecked-optional-access)
|
||||||
|
* comments. This macro keeps the API code readable.
|
||||||
|
*/
|
||||||
|
#define CHECK_DATASET_DISABLED(val, dataset) \
|
||||||
|
{ \
|
||||||
|
if (!(val)) \
|
||||||
|
{ \
|
||||||
|
throw osrm::util::DisabledDatasetException((dataset)); \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
template <typename AlgorithmT> class ContiguousInternalMemoryAlgorithmDataFacade;
|
template <typename AlgorithmT> class ContiguousInternalMemoryAlgorithmDataFacade;
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
@ -142,21 +158,18 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
extractor::Datasources *m_datasources;
|
extractor::Datasources *m_datasources;
|
||||||
|
|
||||||
std::uint32_t m_check_sum;
|
std::uint32_t m_check_sum;
|
||||||
StringView m_data_timestamp;
|
std::string_view m_data_timestamp;
|
||||||
util::vector_view<util::Coordinate> m_coordinate_list;
|
util::vector_view<util::Coordinate> m_coordinate_list;
|
||||||
extractor::PackedOSMIDsView m_osmnodeid_list;
|
extractor::PackedOSMIDsView m_osmnodeid_list;
|
||||||
util::vector_view<std::uint32_t> m_lane_description_offsets;
|
std::optional<util::vector_view<std::uint32_t>> m_lane_description_offsets;
|
||||||
util::vector_view<extractor::TurnLaneType::Mask> m_lane_description_masks;
|
std::optional<util::vector_view<extractor::TurnLaneType::Mask>> m_lane_description_masks;
|
||||||
util::vector_view<TurnPenalty> m_turn_weight_penalties;
|
util::vector_view<TurnPenalty> m_turn_weight_penalties;
|
||||||
util::vector_view<TurnPenalty> m_turn_duration_penalties;
|
util::vector_view<TurnPenalty> m_turn_duration_penalties;
|
||||||
extractor::SegmentDataView segment_data;
|
extractor::SegmentDataView segment_data;
|
||||||
extractor::EdgeBasedNodeDataView edge_based_node_data;
|
extractor::EdgeBasedNodeDataView edge_based_node_data;
|
||||||
guidance::TurnDataView turn_data;
|
std::optional<guidance::TurnDataView> turn_data;
|
||||||
|
|
||||||
util::vector_view<char> m_datasource_name_data;
|
std::optional<util::vector_view<util::guidance::LaneTupleIdPair>> m_lane_tuple_id_pairs;
|
||||||
util::vector_view<std::size_t> m_datasource_name_offsets;
|
|
||||||
util::vector_view<std::size_t> m_datasource_name_lengths;
|
|
||||||
util::vector_view<util::guidance::LaneTupleIdPair> m_lane_tupel_id_pairs;
|
|
||||||
|
|
||||||
util::vector_view<extractor::StorageManeuverOverride> m_maneuver_overrides;
|
util::vector_view<extractor::StorageManeuverOverride> m_maneuver_overrides;
|
||||||
util::vector_view<NodeID> m_maneuver_override_node_sequences;
|
util::vector_view<NodeID> m_maneuver_override_node_sequences;
|
||||||
@ -165,16 +178,24 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
std::unique_ptr<SharedGeospatialQuery> m_geospatial_query;
|
std::unique_ptr<SharedGeospatialQuery> m_geospatial_query;
|
||||||
boost::filesystem::path file_index_path;
|
boost::filesystem::path file_index_path;
|
||||||
|
|
||||||
extractor::IntersectionBearingsView intersection_bearings_view;
|
std::optional<extractor::IntersectionBearingsView> intersection_bearings_view;
|
||||||
|
|
||||||
extractor::NameTableView m_name_table;
|
std::optional<extractor::NameTableView> m_name_table;
|
||||||
// the look-up table for entry classes. An entry class lists the possibility of entry for all
|
// the look-up table for entry classes. An entry class lists the possibility of entry for all
|
||||||
// available turns. Such a class id is stored with every edge.
|
// available turns. Such a class id is stored with every edge.
|
||||||
util::vector_view<util::guidance::EntryClass> m_entry_class_table;
|
std::optional<util::vector_view<util::guidance::EntryClass>> m_entry_class_table;
|
||||||
|
|
||||||
// allocator that keeps the allocation data
|
// allocator that keeps the allocation data
|
||||||
std::shared_ptr<ContiguousBlockAllocator> allocator;
|
std::shared_ptr<ContiguousBlockAllocator> allocator;
|
||||||
|
|
||||||
|
bool isIndexed(const storage::SharedDataIndex &index, const std::string &name)
|
||||||
|
{
|
||||||
|
bool result = false;
|
||||||
|
index.List(name,
|
||||||
|
boost::make_function_output_iterator([&](const auto &) { result = true; }));
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
void InitializeInternalPointers(const storage::SharedDataIndex &index,
|
void InitializeInternalPointers(const storage::SharedDataIndex &index,
|
||||||
const std::string &metric_name,
|
const std::string &metric_name,
|
||||||
const std::size_t exclude_index)
|
const std::size_t exclude_index)
|
||||||
@ -187,7 +208,17 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
|
|
||||||
exclude_mask = m_profile_properties->excludable_classes[exclude_index];
|
exclude_mask = m_profile_properties->excludable_classes[exclude_index];
|
||||||
|
|
||||||
m_check_sum = *index.GetBlockPtr<std::uint32_t>("/common/connectivity_checksum");
|
// We no longer use "/common/connectivity_checksum", as osrm.edges is an optional dataset.
|
||||||
|
// Instead, we load the value from the MLD or CH graph, whichever is loaded.
|
||||||
|
if (isIndexed(index, "/mld/connectivity_checksum"))
|
||||||
|
{
|
||||||
|
m_check_sum = *index.GetBlockPtr<std::uint32_t>("/mld/connectivity_checksum");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
BOOST_ASSERT(isIndexed(index, "/ch/connectivity_checksum"));
|
||||||
|
m_check_sum = *index.GetBlockPtr<std::uint32_t>("/ch/connectivity_checksum");
|
||||||
|
}
|
||||||
|
|
||||||
m_data_timestamp = make_timestamp_view(index, "/common/timestamp");
|
m_data_timestamp = make_timestamp_view(index, "/common/timestamp");
|
||||||
|
|
||||||
@ -200,13 +231,23 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
|
|
||||||
edge_based_node_data = make_ebn_data_view(index, "/common/ebg_node_data");
|
edge_based_node_data = make_ebn_data_view(index, "/common/ebg_node_data");
|
||||||
|
|
||||||
turn_data = make_turn_data_view(index, "/common/turn_data");
|
if (isIndexed(index, "/common/turn_data"))
|
||||||
|
{
|
||||||
|
turn_data = make_turn_data_view(index, "/common/turn_data");
|
||||||
|
}
|
||||||
|
|
||||||
m_name_table = make_name_table_view(index, "/common/names");
|
if (isIndexed(index, "/common/names"))
|
||||||
|
{
|
||||||
|
m_name_table = make_name_table_view(index, "/common/names");
|
||||||
|
}
|
||||||
|
|
||||||
std::tie(m_lane_description_offsets, m_lane_description_masks) =
|
if (isIndexed(index, "/common/turn_lanes"))
|
||||||
make_turn_lane_description_views(index, "/common/turn_lanes");
|
{
|
||||||
m_lane_tupel_id_pairs = make_lane_data_view(index, "/common/turn_lanes");
|
std::tie(m_lane_description_offsets, m_lane_description_masks) =
|
||||||
|
make_turn_lane_description_views(index, "/common/turn_lanes");
|
||||||
|
|
||||||
|
m_lane_tuple_id_pairs = make_lane_data_view(index, "/common/turn_lanes");
|
||||||
|
}
|
||||||
|
|
||||||
m_turn_weight_penalties = make_turn_weight_view(index, "/common/turn_penalty");
|
m_turn_weight_penalties = make_turn_weight_view(index, "/common/turn_penalty");
|
||||||
m_turn_duration_penalties = make_turn_duration_view(index, "/common/turn_penalty");
|
m_turn_duration_penalties = make_turn_duration_view(index, "/common/turn_penalty");
|
||||||
@ -215,10 +256,12 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
|
|
||||||
m_datasources = index.GetBlockPtr<extractor::Datasources>("/common/data_sources_names");
|
m_datasources = index.GetBlockPtr<extractor::Datasources>("/common/data_sources_names");
|
||||||
|
|
||||||
intersection_bearings_view =
|
if (isIndexed(index, "/common/intersection_bearings"))
|
||||||
make_intersection_bearings_view(index, "/common/intersection_bearings");
|
{
|
||||||
|
intersection_bearings_view =
|
||||||
m_entry_class_table = make_entry_classes_view(index, "/common/entry_classes");
|
make_intersection_bearings_view(index, "/common/intersection_bearings");
|
||||||
|
m_entry_class_table = make_entry_classes_view(index, "/common/entry_classes");
|
||||||
|
}
|
||||||
|
|
||||||
std::tie(m_maneuver_overrides, m_maneuver_override_node_sequences) =
|
std::tie(m_maneuver_overrides, m_maneuver_override_node_sequences) =
|
||||||
make_maneuver_overrides_views(index, "/common/maneuver_overrides");
|
make_maneuver_overrides_views(index, "/common/maneuver_overrides");
|
||||||
@ -309,7 +352,8 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
osrm::guidance::TurnInstruction
|
osrm::guidance::TurnInstruction
|
||||||
GetTurnInstructionForEdgeID(const EdgeID edge_based_edge_id) const override final
|
GetTurnInstructionForEdgeID(const EdgeID edge_based_edge_id) const override final
|
||||||
{
|
{
|
||||||
return turn_data.GetTurnInstruction(edge_based_edge_id);
|
CHECK_DATASET_DISABLED(turn_data, DATASET_TURN_DATA);
|
||||||
|
return turn_data->GetTurnInstruction(edge_based_edge_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<RTreeLeaf> GetEdgesInBox(const util::Coordinate south_west,
|
std::vector<RTreeLeaf> GetEdgesInBox(const util::Coordinate south_west,
|
||||||
@ -408,32 +452,37 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
return edge_based_node_data.GetNameID(edge_based_node_id);
|
return edge_based_node_data.GetNameID(edge_based_node_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
StringView GetNameForID(const NameID id) const override final
|
std::string_view GetNameForID(const NameID id) const override final
|
||||||
{
|
{
|
||||||
return m_name_table.GetNameForID(id);
|
CHECK_DATASET_DISABLED(m_name_table, DATASET_NAME_DATA);
|
||||||
|
return m_name_table->GetNameForID(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
StringView GetRefForID(const NameID id) const override final
|
std::string_view GetRefForID(const NameID id) const override final
|
||||||
{
|
{
|
||||||
return m_name_table.GetRefForID(id);
|
CHECK_DATASET_DISABLED(m_name_table, DATASET_NAME_DATA);
|
||||||
|
return m_name_table->GetRefForID(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
StringView GetPronunciationForID(const NameID id) const override final
|
std::string_view GetPronunciationForID(const NameID id) const override final
|
||||||
{
|
{
|
||||||
return m_name_table.GetPronunciationForID(id);
|
CHECK_DATASET_DISABLED(m_name_table, DATASET_NAME_DATA);
|
||||||
|
return m_name_table->GetPronunciationForID(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
StringView GetDestinationsForID(const NameID id) const override final
|
std::string_view GetDestinationsForID(const NameID id) const override final
|
||||||
{
|
{
|
||||||
return m_name_table.GetDestinationsForID(id);
|
CHECK_DATASET_DISABLED(m_name_table, DATASET_NAME_DATA);
|
||||||
|
return m_name_table->GetDestinationsForID(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
StringView GetExitsForID(const NameID id) const override final
|
std::string_view GetExitsForID(const NameID id) const override final
|
||||||
{
|
{
|
||||||
return m_name_table.GetExitsForID(id);
|
CHECK_DATASET_DISABLED(m_name_table, DATASET_NAME_DATA);
|
||||||
|
return m_name_table->GetExitsForID(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
StringView GetDatasourceName(const DatasourceID id) const override final
|
std::string_view GetDatasourceName(const DatasourceID id) const override final
|
||||||
{
|
{
|
||||||
return m_datasources->GetSourceName(id);
|
return m_datasources->GetSourceName(id);
|
||||||
}
|
}
|
||||||
@ -463,46 +512,60 @@ class ContiguousInternalMemoryDataFacadeBase : public BaseDataFacade
|
|||||||
util::guidance::BearingClass
|
util::guidance::BearingClass
|
||||||
GetBearingClass(const NodeID node_based_node_id) const override final
|
GetBearingClass(const NodeID node_based_node_id) const override final
|
||||||
{
|
{
|
||||||
return intersection_bearings_view.GetBearingClass(node_based_node_id);
|
CHECK_DATASET_DISABLED(intersection_bearings_view, DATASET_INTERSECTION_BEARINGS);
|
||||||
|
return intersection_bearings_view->GetBearingClass(node_based_node_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
guidance::TurnBearing PreTurnBearing(const EdgeID edge_based_edge_id) const override final
|
guidance::TurnBearing PreTurnBearing(const EdgeID edge_based_edge_id) const override final
|
||||||
{
|
{
|
||||||
return turn_data.GetPreTurnBearing(edge_based_edge_id);
|
CHECK_DATASET_DISABLED(turn_data, DATASET_TURN_DATA);
|
||||||
|
return turn_data->GetPreTurnBearing(edge_based_edge_id);
|
||||||
}
|
}
|
||||||
guidance::TurnBearing PostTurnBearing(const EdgeID edge_based_edge_id) const override final
|
guidance::TurnBearing PostTurnBearing(const EdgeID edge_based_edge_id) const override final
|
||||||
{
|
{
|
||||||
return turn_data.GetPostTurnBearing(edge_based_edge_id);
|
CHECK_DATASET_DISABLED(turn_data, DATASET_TURN_DATA);
|
||||||
|
return turn_data->GetPostTurnBearing(edge_based_edge_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
util::guidance::EntryClass GetEntryClass(const EdgeID edge_based_edge_id) const override final
|
util::guidance::EntryClass GetEntryClass(const EdgeID edge_based_edge_id) const override final
|
||||||
{
|
{
|
||||||
auto entry_class_id = turn_data.GetEntryClassID(edge_based_edge_id);
|
CHECK_DATASET_DISABLED(m_entry_class_table, DATASET_ENTRY_CLASS);
|
||||||
return m_entry_class_table.at(entry_class_id);
|
CHECK_DATASET_DISABLED(turn_data, DATASET_TURN_DATA);
|
||||||
|
|
||||||
|
auto entry_class_id = turn_data->GetEntryClassID(edge_based_edge_id);
|
||||||
|
return m_entry_class_table->at(entry_class_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool HasLaneData(const EdgeID edge_based_edge_id) const override final
|
bool HasLaneData(const EdgeID edge_based_edge_id) const override final
|
||||||
{
|
{
|
||||||
return turn_data.HasLaneData(edge_based_edge_id);
|
CHECK_DATASET_DISABLED(turn_data, DATASET_TURN_DATA);
|
||||||
|
return turn_data->HasLaneData(edge_based_edge_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
util::guidance::LaneTupleIdPair
|
util::guidance::LaneTupleIdPair
|
||||||
GetLaneData(const EdgeID edge_based_edge_id) const override final
|
GetLaneData(const EdgeID edge_based_edge_id) const override final
|
||||||
{
|
{
|
||||||
|
CHECK_DATASET_DISABLED(turn_data, DATASET_TURN_DATA);
|
||||||
|
CHECK_DATASET_DISABLED(m_lane_tuple_id_pairs, DATASET_TURN_LANE_DATA);
|
||||||
|
|
||||||
BOOST_ASSERT(HasLaneData(edge_based_edge_id));
|
BOOST_ASSERT(HasLaneData(edge_based_edge_id));
|
||||||
return m_lane_tupel_id_pairs.at(turn_data.GetLaneDataID(edge_based_edge_id));
|
return m_lane_tuple_id_pairs->at(turn_data->GetLaneDataID(edge_based_edge_id));
|
||||||
}
|
}
|
||||||
|
|
||||||
extractor::TurnLaneDescription
|
extractor::TurnLaneDescription
|
||||||
GetTurnDescription(const LaneDescriptionID lane_description_id) const override final
|
GetTurnDescription(const LaneDescriptionID lane_description_id) const override final
|
||||||
{
|
{
|
||||||
|
CHECK_DATASET_DISABLED(m_lane_description_offsets, DATASET_TURN_LANE_DATA);
|
||||||
|
CHECK_DATASET_DISABLED(m_lane_description_masks, DATASET_TURN_LANE_DATA);
|
||||||
|
|
||||||
if (lane_description_id == INVALID_LANE_DESCRIPTIONID)
|
if (lane_description_id == INVALID_LANE_DESCRIPTIONID)
|
||||||
return {};
|
return {};
|
||||||
else
|
else
|
||||||
return extractor::TurnLaneDescription(
|
return extractor::TurnLaneDescription(
|
||||||
m_lane_description_masks.begin() + m_lane_description_offsets[lane_description_id],
|
m_lane_description_masks->begin() +
|
||||||
m_lane_description_masks.begin() +
|
m_lane_description_offsets->at(lane_description_id),
|
||||||
m_lane_description_offsets[lane_description_id + 1]);
|
m_lane_description_masks->begin() +
|
||||||
|
m_lane_description_offsets->at(lane_description_id + 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IsLeftHandDriving(const NodeID edge_based_node_id) const override final
|
bool IsLeftHandDriving(const NodeID edge_based_node_id) const override final
|
||||||
@ -693,8 +756,6 @@ class ContiguousInternalMemoryDataFacade<MLD> final
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace datafacade
|
} // namespace osrm::engine::datafacade
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // CONTIGUOUS_INTERNALMEM_DATAFACADE_HPP
|
#endif // CONTIGUOUS_INTERNALMEM_DATAFACADE_HPP
|
||||||
|
@ -26,7 +26,6 @@
|
|||||||
#include "util/integer_range.hpp"
|
#include "util/integer_range.hpp"
|
||||||
#include "util/packed_vector.hpp"
|
#include "util/packed_vector.hpp"
|
||||||
#include "util/string_util.hpp"
|
#include "util/string_util.hpp"
|
||||||
#include "util/string_view.hpp"
|
|
||||||
#include "util/typedefs.hpp"
|
#include "util/typedefs.hpp"
|
||||||
|
|
||||||
#include "osrm/coordinate.hpp"
|
#include "osrm/coordinate.hpp"
|
||||||
@ -37,17 +36,12 @@
|
|||||||
|
|
||||||
#include <engine/bearing.hpp>
|
#include <engine/bearing.hpp>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <string_view>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::datafacade
|
||||||
{
|
{
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace datafacade
|
|
||||||
{
|
|
||||||
|
|
||||||
using StringView = util::StringView;
|
|
||||||
|
|
||||||
class BaseDataFacade
|
class BaseDataFacade
|
||||||
{
|
{
|
||||||
@ -113,7 +107,7 @@ class BaseDataFacade
|
|||||||
GetUncompressedReverseDatasources(const PackedGeometryID id) const = 0;
|
GetUncompressedReverseDatasources(const PackedGeometryID id) const = 0;
|
||||||
|
|
||||||
// Gets the name of a datasource
|
// Gets the name of a datasource
|
||||||
virtual StringView GetDatasourceName(const DatasourceID id) const = 0;
|
virtual std::string_view GetDatasourceName(const DatasourceID id) const = 0;
|
||||||
|
|
||||||
virtual osrm::guidance::TurnInstruction
|
virtual osrm::guidance::TurnInstruction
|
||||||
GetTurnInstructionForEdgeID(const EdgeID edge_based_edge_id) const = 0;
|
GetTurnInstructionForEdgeID(const EdgeID edge_based_edge_id) const = 0;
|
||||||
@ -157,15 +151,15 @@ class BaseDataFacade
|
|||||||
|
|
||||||
virtual NameID GetNameIndex(const NodeID edge_based_node_id) const = 0;
|
virtual NameID GetNameIndex(const NodeID edge_based_node_id) const = 0;
|
||||||
|
|
||||||
virtual StringView GetNameForID(const NameID id) const = 0;
|
virtual std::string_view GetNameForID(const NameID id) const = 0;
|
||||||
|
|
||||||
virtual StringView GetRefForID(const NameID id) const = 0;
|
virtual std::string_view GetRefForID(const NameID id) const = 0;
|
||||||
|
|
||||||
virtual StringView GetPronunciationForID(const NameID id) const = 0;
|
virtual std::string_view GetPronunciationForID(const NameID id) const = 0;
|
||||||
|
|
||||||
virtual StringView GetDestinationsForID(const NameID id) const = 0;
|
virtual std::string_view GetDestinationsForID(const NameID id) const = 0;
|
||||||
|
|
||||||
virtual StringView GetExitsForID(const NameID id) const = 0;
|
virtual std::string_view GetExitsForID(const NameID id) const = 0;
|
||||||
|
|
||||||
virtual bool GetContinueStraightDefault() const = 0;
|
virtual bool GetContinueStraightDefault() const = 0;
|
||||||
|
|
||||||
@ -191,8 +185,6 @@ class BaseDataFacade
|
|||||||
virtual std::vector<extractor::ManeuverOverride>
|
virtual std::vector<extractor::ManeuverOverride>
|
||||||
GetOverridesThatStartAt(const NodeID edge_based_node_id) const = 0;
|
GetOverridesThatStartAt(const NodeID edge_based_node_id) const = 0;
|
||||||
};
|
};
|
||||||
} // namespace datafacade
|
} // namespace osrm::engine::datafacade
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // DATAFACADE_BASE_HPP
|
#endif // DATAFACADE_BASE_HPP
|
||||||
|
@ -12,11 +12,7 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::datafacade
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace datafacade
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -37,8 +33,6 @@ class MMapMemoryAllocator final : public ContiguousBlockAllocator
|
|||||||
std::string rtree_filename;
|
std::string rtree_filename;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace datafacade
|
} // namespace osrm::engine::datafacade
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_ENGINE_DATAFACADE_SHARED_MEMORY_ALLOCATOR_HPP_
|
#endif // OSRM_ENGINE_DATAFACADE_SHARED_MEMORY_ALLOCATOR_HPP_
|
||||||
|
@ -6,11 +6,7 @@
|
|||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::datafacade
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace datafacade
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -34,8 +30,6 @@ class ProcessMemoryAllocator final : public ContiguousBlockAllocator
|
|||||||
std::unique_ptr<char[]> internal_memory;
|
std::unique_ptr<char[]> internal_memory;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace datafacade
|
} // namespace osrm::engine::datafacade
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_ENGINE_DATAFACADE_PROCESS_MEMORY_ALLOCATOR_HPP_
|
#endif // OSRM_ENGINE_DATAFACADE_PROCESS_MEMORY_ALLOCATOR_HPP_
|
||||||
|
@ -8,11 +8,7 @@
|
|||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::datafacade
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace datafacade
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -35,8 +31,6 @@ class SharedMemoryAllocator final : public ContiguousBlockAllocator
|
|||||||
std::vector<std::unique_ptr<storage::SharedMemory>> memory_regions;
|
std::vector<std::unique_ptr<storage::SharedMemory>> memory_regions;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace datafacade
|
} // namespace osrm::engine::datafacade
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_ENGINE_DATAFACADE_SHARED_MEMORY_ALLOCATOR_HPP_
|
#endif // OSRM_ENGINE_DATAFACADE_SHARED_MEMORY_ALLOCATOR_HPP_
|
||||||
|
@ -16,9 +16,7 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
// This class selects the right facade for
|
// This class selects the right facade for
|
||||||
template <template <typename A> class FacadeT, typename AlgorithmT> class DataFacadeFactory
|
template <template <typename A> class FacadeT, typename AlgorithmT> class DataFacadeFactory
|
||||||
@ -152,7 +150,6 @@ template <template <typename A> class FacadeT, typename AlgorithmT> class DataFa
|
|||||||
std::unordered_map<std::string, extractor::ClassData> name_to_class;
|
std::unordered_map<std::string, extractor::ClassData> name_to_class;
|
||||||
const extractor::ProfileProperties *properties = nullptr;
|
const extractor::ProfileProperties *properties = nullptr;
|
||||||
};
|
};
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -8,9 +8,7 @@
|
|||||||
#include "engine/datafacade/process_memory_allocator.hpp"
|
#include "engine/datafacade/process_memory_allocator.hpp"
|
||||||
#include "engine/datafacade_factory.hpp"
|
#include "engine/datafacade_factory.hpp"
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
@ -103,7 +101,6 @@ template <typename AlgorithmT>
|
|||||||
using ImmutableProvider = detail::ImmutableProvider<AlgorithmT, DataFacade>;
|
using ImmutableProvider = detail::ImmutableProvider<AlgorithmT, DataFacade>;
|
||||||
template <typename AlgorithmT>
|
template <typename AlgorithmT>
|
||||||
using ExternalProvider = detail::ExternalProvider<AlgorithmT, DataFacade>;
|
using ExternalProvider = detail::ExternalProvider<AlgorithmT, DataFacade>;
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -6,9 +6,7 @@
|
|||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
@ -75,7 +73,6 @@ inline std::vector<util::Coordinate> douglasPeucker(const std::vector<util::Coor
|
|||||||
{
|
{
|
||||||
return douglasPeucker(begin(geometry), end(geometry), zoom_level);
|
return douglasPeucker(begin(geometry), end(geometry), zoom_level);
|
||||||
}
|
}
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif /* DOUGLAS_PEUCKER_HPP_ */
|
#endif /* DOUGLAS_PEUCKER_HPP_ */
|
||||||
|
@ -23,9 +23,7 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
class EngineInterface
|
class EngineInterface
|
||||||
@ -45,12 +43,16 @@ template <typename Algorithm> class Engine final : public EngineInterface
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
explicit Engine(const EngineConfig &config)
|
explicit Engine(const EngineConfig &config)
|
||||||
: route_plugin(config.max_locations_viaroute, config.max_alternatives), //
|
: route_plugin(config.max_locations_viaroute,
|
||||||
table_plugin(config.max_locations_distance_table), //
|
config.max_alternatives,
|
||||||
nearest_plugin(config.max_results_nearest), //
|
config.default_radius), //
|
||||||
trip_plugin(config.max_locations_trip), //
|
table_plugin(config.max_locations_distance_table, config.default_radius), //
|
||||||
match_plugin(config.max_locations_map_matching, config.max_radius_map_matching), //
|
nearest_plugin(config.max_results_nearest, config.default_radius), //
|
||||||
tile_plugin() //
|
trip_plugin(config.max_locations_trip, config.default_radius), //
|
||||||
|
match_plugin(config.max_locations_map_matching,
|
||||||
|
config.max_radius_map_matching,
|
||||||
|
config.default_radius), //
|
||||||
|
tile_plugin() //
|
||||||
|
|
||||||
{
|
{
|
||||||
if (config.use_shared_memory)
|
if (config.use_shared_memory)
|
||||||
@ -130,7 +132,6 @@ template <typename Algorithm> class Engine final : public EngineInterface
|
|||||||
const plugins::MatchPlugin match_plugin;
|
const plugins::MatchPlugin match_plugin;
|
||||||
const plugins::TilePlugin tile_plugin;
|
const plugins::TilePlugin tile_plugin;
|
||||||
};
|
};
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // OSRM_IMPL_HPP
|
#endif // OSRM_IMPL_HPP
|
||||||
|
@ -29,15 +29,14 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
#define ENGINE_CONFIG_HPP
|
#define ENGINE_CONFIG_HPP
|
||||||
|
|
||||||
#include "storage/storage_config.hpp"
|
#include "storage/storage_config.hpp"
|
||||||
|
#include "osrm/datasets.hpp"
|
||||||
|
|
||||||
#include <boost/filesystem/path.hpp>
|
#include <boost/filesystem/path.hpp>
|
||||||
|
|
||||||
|
#include <set>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -86,15 +85,16 @@ struct EngineConfig final
|
|||||||
int max_locations_map_matching = -1;
|
int max_locations_map_matching = -1;
|
||||||
double max_radius_map_matching = -1.0;
|
double max_radius_map_matching = -1.0;
|
||||||
int max_results_nearest = -1;
|
int max_results_nearest = -1;
|
||||||
|
boost::optional<double> default_radius = -1.0;
|
||||||
int max_alternatives = 3; // set an arbitrary upper bound; can be adjusted by user
|
int max_alternatives = 3; // set an arbitrary upper bound; can be adjusted by user
|
||||||
bool use_shared_memory = true;
|
bool use_shared_memory = true;
|
||||||
boost::filesystem::path memory_file;
|
boost::filesystem::path memory_file;
|
||||||
bool use_mmap = true;
|
bool use_mmap = true;
|
||||||
Algorithm algorithm = Algorithm::CH;
|
Algorithm algorithm = Algorithm::CH;
|
||||||
|
std::vector<storage::FeatureDataset> disable_feature_dataset;
|
||||||
std::string verbosity;
|
std::string verbosity;
|
||||||
std::string dataset_name;
|
std::string dataset_name;
|
||||||
};
|
};
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // SERVER_CONFIG_HPP
|
#endif // SERVER_CONFIG_HPP
|
||||||
|
@ -18,9 +18,7 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
{
|
||||||
|
|
||||||
inline std::pair<bool, bool> operator&&(const std::pair<bool, bool> &a,
|
inline std::pair<bool, bool> operator&&(const std::pair<bool, bool> &a,
|
||||||
@ -74,7 +72,7 @@ template <typename RTreeT, typename DataFacadeT> class GeospatialQuery
|
|||||||
[this, &max_distance, &max_results, input_coordinate](const std::size_t num_results,
|
[this, &max_distance, &max_results, input_coordinate](const std::size_t num_results,
|
||||||
const CandidateSegment &segment) {
|
const CandidateSegment &segment) {
|
||||||
return (max_results && num_results >= *max_results) ||
|
return (max_results && num_results >= *max_results) ||
|
||||||
(max_distance &&
|
(max_distance && max_distance != -1.0 &&
|
||||||
CheckSegmentDistance(input_coordinate, segment, *max_distance));
|
CheckSegmentDistance(input_coordinate, segment, *max_distance));
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -165,7 +163,8 @@ template <typename RTreeT, typename DataFacadeT> class GeospatialQuery
|
|||||||
auto distance = GetSegmentDistance(input_coordinate, segment);
|
auto distance = GetSegmentDistance(input_coordinate, segment);
|
||||||
auto further_than_big_component = distance > big_component_distance;
|
auto further_than_big_component = distance > big_component_distance;
|
||||||
auto no_more_candidates = has_big_component && further_than_big_component;
|
auto no_more_candidates = has_big_component && further_than_big_component;
|
||||||
auto too_far_away = max_distance && distance > *max_distance;
|
auto too_far_away =
|
||||||
|
max_distance && max_distance != -1.0 && distance > *max_distance;
|
||||||
|
|
||||||
// Time to terminate the search when:
|
// Time to terminate the search when:
|
||||||
// 1. We've found a node from a big component and the next candidate is further away
|
// 1. We've found a node from a big component and the next candidate is further away
|
||||||
@ -320,75 +319,84 @@ template <typename RTreeT, typename DataFacadeT> class GeospatialQuery
|
|||||||
|
|
||||||
const auto forward_weight_offset =
|
const auto forward_weight_offset =
|
||||||
// NOLINTNEXTLINE(bugprone-fold-init-type)
|
// NOLINTNEXTLINE(bugprone-fold-init-type)
|
||||||
std::accumulate(forward_weights.begin(),
|
alias_cast<EdgeWeight>(
|
||||||
forward_weights.begin() + data.fwd_segment_position,
|
std::accumulate(forward_weights.begin(),
|
||||||
EdgeWeight{0});
|
forward_weights.begin() + data.fwd_segment_position,
|
||||||
|
SegmentWeight{0}));
|
||||||
|
|
||||||
const auto forward_duration_offset =
|
const auto forward_duration_offset =
|
||||||
// NOLINTNEXTLINE(bugprone-fold-init-type)
|
// NOLINTNEXTLINE(bugprone-fold-init-type)
|
||||||
std::accumulate(forward_durations.begin(),
|
alias_cast<EdgeDuration>(
|
||||||
forward_durations.begin() + data.fwd_segment_position,
|
std::accumulate(forward_durations.begin(),
|
||||||
EdgeDuration{0});
|
forward_durations.begin() + data.fwd_segment_position,
|
||||||
|
SegmentDuration{0}));
|
||||||
|
|
||||||
EdgeDistance forward_distance_offset = 0;
|
EdgeDistance forward_distance_offset = {0};
|
||||||
// Sum up the distance from the start to the fwd_segment_position
|
// Sum up the distance from the start to the fwd_segment_position
|
||||||
for (auto current = forward_geometry.begin();
|
for (auto current = forward_geometry.begin();
|
||||||
current < forward_geometry.begin() + data.fwd_segment_position;
|
current < forward_geometry.begin() + data.fwd_segment_position;
|
||||||
++current)
|
++current)
|
||||||
{
|
{
|
||||||
forward_distance_offset += util::coordinate_calculation::greatCircleDistance(
|
forward_distance_offset +=
|
||||||
datafacade.GetCoordinateOfNode(*current),
|
to_alias<EdgeDistance>(util::coordinate_calculation::greatCircleDistance(
|
||||||
datafacade.GetCoordinateOfNode(*std::next(current)));
|
datafacade.GetCoordinateOfNode(*current),
|
||||||
|
datafacade.GetCoordinateOfNode(*std::next(current))));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_ASSERT(data.fwd_segment_position <
|
BOOST_ASSERT(data.fwd_segment_position <
|
||||||
std::distance(forward_durations.begin(), forward_durations.end()));
|
std::distance(forward_durations.begin(), forward_durations.end()));
|
||||||
|
|
||||||
EdgeWeight forward_weight = forward_weights[data.fwd_segment_position];
|
EdgeWeight forward_weight =
|
||||||
EdgeDuration forward_duration = forward_durations[data.fwd_segment_position];
|
alias_cast<EdgeWeight>(forward_weights[data.fwd_segment_position]);
|
||||||
EdgeDistance forward_distance = util::coordinate_calculation::greatCircleDistance(
|
EdgeDuration forward_duration =
|
||||||
datafacade.GetCoordinateOfNode(forward_geometry(data.fwd_segment_position)),
|
alias_cast<EdgeDuration>(forward_durations[data.fwd_segment_position]);
|
||||||
point_on_segment);
|
EdgeDistance forward_distance =
|
||||||
|
to_alias<EdgeDistance>(util::coordinate_calculation::greatCircleDistance(
|
||||||
|
datafacade.GetCoordinateOfNode(forward_geometry(data.fwd_segment_position)),
|
||||||
|
point_on_segment));
|
||||||
|
|
||||||
const auto reverse_weight_offset =
|
const auto reverse_weight_offset = alias_cast<EdgeWeight>(
|
||||||
std::accumulate(reverse_weights.begin(),
|
std::accumulate(reverse_weights.begin(),
|
||||||
reverse_weights.end() - data.fwd_segment_position - 1,
|
reverse_weights.end() - data.fwd_segment_position - 1,
|
||||||
EdgeWeight{0});
|
SegmentWeight{0}));
|
||||||
|
|
||||||
const auto reverse_duration_offset =
|
const auto reverse_duration_offset = alias_cast<EdgeDuration>(
|
||||||
std::accumulate(reverse_durations.begin(),
|
std::accumulate(reverse_durations.begin(),
|
||||||
reverse_durations.end() - data.fwd_segment_position - 1,
|
reverse_durations.end() - data.fwd_segment_position - 1,
|
||||||
EdgeDuration{0});
|
SegmentDuration{0}));
|
||||||
|
|
||||||
EdgeDistance reverse_distance_offset = 0;
|
EdgeDistance reverse_distance_offset = {0};
|
||||||
// Sum up the distance from just after the fwd_segment_position to the end
|
// Sum up the distance from just after the fwd_segment_position to the end
|
||||||
for (auto current = forward_geometry.begin() + data.fwd_segment_position + 1;
|
for (auto current = forward_geometry.begin() + data.fwd_segment_position + 1;
|
||||||
current != std::prev(forward_geometry.end());
|
current != std::prev(forward_geometry.end());
|
||||||
++current)
|
++current)
|
||||||
{
|
{
|
||||||
reverse_distance_offset += util::coordinate_calculation::greatCircleDistance(
|
reverse_distance_offset +=
|
||||||
datafacade.GetCoordinateOfNode(*current),
|
to_alias<EdgeDistance>(util::coordinate_calculation::greatCircleDistance(
|
||||||
datafacade.GetCoordinateOfNode(*std::next(current)));
|
datafacade.GetCoordinateOfNode(*current),
|
||||||
|
datafacade.GetCoordinateOfNode(*std::next(current))));
|
||||||
}
|
}
|
||||||
|
|
||||||
EdgeWeight reverse_weight =
|
EdgeWeight reverse_weight = alias_cast<EdgeWeight>(
|
||||||
reverse_weights[reverse_weights.size() - data.fwd_segment_position - 1];
|
reverse_weights[reverse_weights.size() - data.fwd_segment_position - 1]);
|
||||||
EdgeDuration reverse_duration =
|
EdgeDuration reverse_duration = alias_cast<EdgeDuration>(
|
||||||
reverse_durations[reverse_durations.size() - data.fwd_segment_position - 1];
|
reverse_durations[reverse_durations.size() - data.fwd_segment_position - 1]);
|
||||||
EdgeDistance reverse_distance = util::coordinate_calculation::greatCircleDistance(
|
EdgeDistance reverse_distance =
|
||||||
point_on_segment,
|
to_alias<EdgeDistance>(util::coordinate_calculation::greatCircleDistance(
|
||||||
datafacade.GetCoordinateOfNode(forward_geometry(data.fwd_segment_position + 1)));
|
point_on_segment,
|
||||||
|
datafacade.GetCoordinateOfNode(forward_geometry(data.fwd_segment_position + 1))));
|
||||||
|
|
||||||
ratio = std::min(1.0, std::max(0.0, ratio));
|
ratio = std::min(1.0, std::max(0.0, ratio));
|
||||||
if (data.forward_segment_id.id != SPECIAL_SEGMENTID)
|
if (data.forward_segment_id.id != SPECIAL_SEGMENTID)
|
||||||
{
|
{
|
||||||
forward_weight = static_cast<EdgeWeight>(forward_weight * ratio);
|
forward_weight = to_alias<EdgeWeight>(from_alias<double>(forward_weight) * ratio);
|
||||||
forward_duration = static_cast<EdgeDuration>(forward_duration * ratio);
|
forward_duration = to_alias<EdgeDuration>(from_alias<double>(forward_duration) * ratio);
|
||||||
}
|
}
|
||||||
if (data.reverse_segment_id.id != SPECIAL_SEGMENTID)
|
if (data.reverse_segment_id.id != SPECIAL_SEGMENTID)
|
||||||
{
|
{
|
||||||
reverse_weight -= static_cast<EdgeWeight>(reverse_weight * ratio);
|
reverse_weight -= to_alias<EdgeWeight>(from_alias<double>(reverse_weight) * ratio);
|
||||||
reverse_duration -= static_cast<EdgeDuration>(reverse_duration * ratio);
|
reverse_duration -=
|
||||||
|
to_alias<EdgeDuration>(from_alias<double>(reverse_duration) * ratio);
|
||||||
}
|
}
|
||||||
|
|
||||||
// check phantom node segments validity
|
// check phantom node segments validity
|
||||||
@ -574,7 +582,6 @@ template <typename RTreeT, typename DataFacadeT> class GeospatialQuery
|
|||||||
const CoordinateList &coordinates;
|
const CoordinateList &coordinates;
|
||||||
DataFacadeT &datafacade;
|
DataFacadeT &datafacade;
|
||||||
};
|
};
|
||||||
} // namespace engine
|
} // namespace osrm::engine
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -16,11 +16,7 @@
|
|||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::guidance
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace guidance
|
|
||||||
{
|
{
|
||||||
// Extracts the geometry for each segment and calculates the traveled distance
|
// Extracts the geometry for each segment and calculates the traveled distance
|
||||||
// Combines the geometry form the phantom node with the PathData
|
// Combines the geometry form the phantom node with the PathData
|
||||||
@ -95,8 +91,9 @@ inline LegGeometry assembleGeometry(const datafacade::BaseDataFacade &facade,
|
|||||||
// the duration_of_turn/weight_of_turn value, which is 0 for
|
// the duration_of_turn/weight_of_turn value, which is 0 for
|
||||||
// non-preceeding-turn segments, but contains the turn value
|
// non-preceeding-turn segments, but contains the turn value
|
||||||
// for segments before a turn.
|
// for segments before a turn.
|
||||||
(path_point.duration_until_turn - path_point.duration_of_turn) / 10.,
|
from_alias<double>(path_point.duration_until_turn - path_point.duration_of_turn) /
|
||||||
(path_point.weight_until_turn - path_point.weight_of_turn) /
|
10.,
|
||||||
|
from_alias<double>(path_point.weight_until_turn - path_point.weight_of_turn) /
|
||||||
facade.GetWeightMultiplier(),
|
facade.GetWeightMultiplier(),
|
||||||
path_point.datasource_id});
|
path_point.datasource_id});
|
||||||
geometry.locations.push_back(coordinate);
|
geometry.locations.push_back(coordinate);
|
||||||
@ -121,14 +118,15 @@ inline LegGeometry assembleGeometry(const datafacade::BaseDataFacade &facade,
|
|||||||
if (geometry.annotations.empty())
|
if (geometry.annotations.empty())
|
||||||
{
|
{
|
||||||
auto duration =
|
auto duration =
|
||||||
std::abs(
|
std::abs(from_alias<EdgeDuration::value_type>(
|
||||||
(reversed_target ? target_node.reverse_duration : target_node.forward_duration) -
|
(reversed_target ? target_node.reverse_duration : target_node.forward_duration) -
|
||||||
(reversed_source ? source_node.reverse_duration : source_node.forward_duration)) /
|
(reversed_source ? source_node.reverse_duration : source_node.forward_duration))) /
|
||||||
10.;
|
10.;
|
||||||
BOOST_ASSERT(duration >= 0);
|
BOOST_ASSERT(duration >= 0);
|
||||||
auto weight =
|
auto weight =
|
||||||
std::abs((reversed_target ? target_node.reverse_weight : target_node.forward_weight) -
|
std::abs(from_alias<EdgeWeight::value_type>(
|
||||||
(reversed_source ? source_node.reverse_weight : source_node.forward_weight)) /
|
(reversed_target ? target_node.reverse_weight : target_node.forward_weight) -
|
||||||
|
(reversed_source ? source_node.reverse_weight : source_node.forward_weight))) /
|
||||||
facade.GetWeightMultiplier();
|
facade.GetWeightMultiplier();
|
||||||
BOOST_ASSERT(weight >= 0);
|
BOOST_ASSERT(weight >= 0);
|
||||||
|
|
||||||
@ -142,8 +140,11 @@ inline LegGeometry assembleGeometry(const datafacade::BaseDataFacade &facade,
|
|||||||
{
|
{
|
||||||
geometry.annotations.emplace_back(LegGeometry::Annotation{
|
geometry.annotations.emplace_back(LegGeometry::Annotation{
|
||||||
current_distance,
|
current_distance,
|
||||||
(reversed_target ? target_node.reverse_duration : target_node.forward_duration) / 10.,
|
from_alias<double>(reversed_target ? target_node.reverse_duration
|
||||||
(reversed_target ? target_node.reverse_weight : target_node.forward_weight) /
|
: target_node.forward_duration) /
|
||||||
|
10.,
|
||||||
|
from_alias<double>(reversed_target ? target_node.reverse_weight
|
||||||
|
: target_node.forward_weight) /
|
||||||
facade.GetWeightMultiplier(),
|
facade.GetWeightMultiplier(),
|
||||||
forward_datasources(target_node.fwd_segment_position)});
|
forward_datasources(target_node.fwd_segment_position)});
|
||||||
}
|
}
|
||||||
@ -167,8 +168,6 @@ inline LegGeometry assembleGeometry(const datafacade::BaseDataFacade &facade,
|
|||||||
|
|
||||||
return geometry;
|
return geometry;
|
||||||
}
|
}
|
||||||
} // namespace guidance
|
} // namespace osrm::engine::guidance
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -23,18 +23,14 @@
|
|||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::guidance
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace guidance
|
|
||||||
{
|
{
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
const constexpr std::size_t MAX_USED_SEGMENTS = 2;
|
const constexpr std::size_t MAX_USED_SEGMENTS = 2;
|
||||||
struct NamedSegment
|
struct NamedSegment
|
||||||
{
|
{
|
||||||
EdgeWeight duration;
|
EdgeDuration duration;
|
||||||
std::uint32_t position;
|
std::uint32_t position;
|
||||||
std::uint32_t name_id;
|
std::uint32_t name_id;
|
||||||
};
|
};
|
||||||
@ -88,7 +84,7 @@ std::array<std::uint32_t, SegmentNumber> summarizeRoute(const datafacade::BaseDa
|
|||||||
target_traversed_in_reverse ? target_node.reverse_duration : target_node.forward_duration;
|
target_traversed_in_reverse ? target_node.reverse_duration : target_node.forward_duration;
|
||||||
const auto target_node_id = target_traversed_in_reverse ? target_node.reverse_segment_id.id
|
const auto target_node_id = target_traversed_in_reverse ? target_node.reverse_segment_id.id
|
||||||
: target_node.forward_segment_id.id;
|
: target_node.forward_segment_id.id;
|
||||||
if (target_duration > 1)
|
if (target_duration > EdgeDuration{1})
|
||||||
segments.push_back({target_duration, index++, facade.GetNameIndex(target_node_id)});
|
segments.push_back({target_duration, index++, facade.GetNameIndex(target_node_id)});
|
||||||
// this makes sure that the segment with the lowest position comes first
|
// this makes sure that the segment with the lowest position comes first
|
||||||
std::sort(
|
std::sort(
|
||||||
@ -145,11 +141,11 @@ inline std::string assembleSummary(const datafacade::BaseDataFacade &facade,
|
|||||||
const auto name_id_to_string = [&](const NameID name_id) {
|
const auto name_id_to_string = [&](const NameID name_id) {
|
||||||
const auto name = facade.GetNameForID(name_id);
|
const auto name = facade.GetNameForID(name_id);
|
||||||
if (!name.empty())
|
if (!name.empty())
|
||||||
return name.to_string();
|
return std::string(name);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const auto ref = facade.GetRefForID(name_id);
|
const auto ref = facade.GetRefForID(name_id);
|
||||||
return ref.to_string();
|
return std::string(ref);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -184,11 +180,11 @@ inline RouteLeg assembleLeg(const datafacade::BaseDataFacade &facade,
|
|||||||
|
|
||||||
auto duration = std::accumulate(
|
auto duration = std::accumulate(
|
||||||
route_data.begin(), route_data.end(), 0, [](const double sum, const PathData &data) {
|
route_data.begin(), route_data.end(), 0, [](const double sum, const PathData &data) {
|
||||||
return sum + data.duration_until_turn;
|
return sum + from_alias<double>(data.duration_until_turn);
|
||||||
});
|
});
|
||||||
auto weight = std::accumulate(
|
auto weight = std::accumulate(
|
||||||
route_data.begin(), route_data.end(), 0, [](const double sum, const PathData &data) {
|
route_data.begin(), route_data.end(), 0, [](const double sum, const PathData &data) {
|
||||||
return sum + data.weight_until_turn;
|
return sum + from_alias<double>(data.weight_until_turn);
|
||||||
});
|
});
|
||||||
|
|
||||||
// s
|
// s
|
||||||
@ -212,14 +208,14 @@ inline RouteLeg assembleLeg(const datafacade::BaseDataFacade &facade,
|
|||||||
// caputed by the phantom node. So we need to add the target duration here.
|
// caputed by the phantom node. So we need to add the target duration here.
|
||||||
// On local segments, the target duration is already part of the duration, however.
|
// On local segments, the target duration is already part of the duration, however.
|
||||||
|
|
||||||
duration = duration + target_duration;
|
duration = duration + from_alias<double>(target_duration);
|
||||||
weight = weight + target_weight;
|
weight = weight + from_alias<double>(target_weight);
|
||||||
if (route_data.empty())
|
if (route_data.empty())
|
||||||
{
|
{
|
||||||
weight -=
|
weight -= from_alias<double>(target_traversed_in_reverse ? source_node.reverse_weight
|
||||||
(target_traversed_in_reverse ? source_node.reverse_weight : source_node.forward_weight);
|
: source_node.forward_weight);
|
||||||
duration -= (target_traversed_in_reverse ? source_node.reverse_duration
|
duration -= from_alias<double>(target_traversed_in_reverse ? source_node.reverse_duration
|
||||||
: source_node.forward_duration);
|
: source_node.forward_duration);
|
||||||
// use rectified linear unit function to avoid negative duration values
|
// use rectified linear unit function to avoid negative duration values
|
||||||
// due to flooring errors in phantom snapping
|
// due to flooring errors in phantom snapping
|
||||||
duration = std::max(0, duration);
|
duration = std::max(0, duration);
|
||||||
@ -232,8 +228,6 @@ inline RouteLeg assembleLeg(const datafacade::BaseDataFacade &facade,
|
|||||||
{}};
|
{}};
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace guidance
|
} // namespace osrm::engine::guidance
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // ENGINE_GUIDANCE_SEGMENT_LIST_HPP_
|
#endif // ENGINE_GUIDANCE_SEGMENT_LIST_HPP_
|
||||||
|
@ -7,18 +7,12 @@
|
|||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::guidance
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace guidance
|
|
||||||
{
|
{
|
||||||
|
|
||||||
std::vector<util::Coordinate> assembleOverview(const std::vector<LegGeometry> &leg_geometries,
|
std::vector<util::Coordinate> assembleOverview(const std::vector<LegGeometry> &leg_geometries,
|
||||||
const bool use_simplification);
|
const bool use_simplification);
|
||||||
|
|
||||||
} // namespace guidance
|
} // namespace osrm::engine::guidance
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -6,17 +6,11 @@
|
|||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::guidance
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace guidance
|
|
||||||
{
|
{
|
||||||
|
|
||||||
Route assembleRoute(const std::vector<RouteLeg> &route_legs);
|
Route assembleRoute(const std::vector<RouteLeg> &route_legs);
|
||||||
|
|
||||||
} // namespace guidance
|
} // namespace osrm::engine::guidance
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -22,11 +22,7 @@
|
|||||||
#include <guidance/turn_bearing.hpp>
|
#include <guidance/turn_bearing.hpp>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace osrm
|
namespace osrm::engine::guidance
|
||||||
{
|
|
||||||
namespace engine
|
|
||||||
{
|
|
||||||
namespace guidance
|
|
||||||
{
|
{
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
@ -52,7 +48,7 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
const constexpr char *NO_ROTARY_NAME = "";
|
const constexpr char *NO_ROTARY_NAME = "";
|
||||||
const EdgeWeight source_weight =
|
const EdgeWeight source_weight =
|
||||||
source_traversed_in_reverse ? source_node.reverse_weight : source_node.forward_weight;
|
source_traversed_in_reverse ? source_node.reverse_weight : source_node.forward_weight;
|
||||||
const EdgeWeight source_duration =
|
const EdgeDuration source_duration =
|
||||||
source_traversed_in_reverse ? source_node.reverse_duration : source_node.forward_duration;
|
source_traversed_in_reverse ? source_node.reverse_duration : source_node.forward_duration;
|
||||||
const auto source_node_id = source_traversed_in_reverse ? source_node.reverse_segment_id.id
|
const auto source_node_id = source_traversed_in_reverse ? source_node.reverse_segment_id.id
|
||||||
: source_node.forward_segment_id.id;
|
: source_node.forward_segment_id.id;
|
||||||
@ -61,7 +57,7 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
const auto source_mode = facade.GetTravelMode(source_node_id);
|
const auto source_mode = facade.GetTravelMode(source_node_id);
|
||||||
auto source_classes = facade.GetClasses(facade.GetClassData(source_node_id));
|
auto source_classes = facade.GetClasses(facade.GetClassData(source_node_id));
|
||||||
|
|
||||||
const EdgeWeight target_duration =
|
const EdgeDuration target_duration =
|
||||||
target_traversed_in_reverse ? target_node.reverse_duration : target_node.forward_duration;
|
target_traversed_in_reverse ? target_node.reverse_duration : target_node.forward_duration;
|
||||||
const EdgeWeight target_weight =
|
const EdgeWeight target_weight =
|
||||||
target_traversed_in_reverse ? target_node.reverse_weight : target_node.forward_weight;
|
target_traversed_in_reverse ? target_node.reverse_weight : target_node.forward_weight;
|
||||||
@ -103,8 +99,8 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
// but a RouteStep is with regard to the segment after the turn.
|
// but a RouteStep is with regard to the segment after the turn.
|
||||||
// We need to skip the first segment because it is already covered by the
|
// We need to skip the first segment because it is already covered by the
|
||||||
// initial start of a route
|
// initial start of a route
|
||||||
EdgeWeight segment_duration = 0;
|
EdgeDuration segment_duration = {0};
|
||||||
EdgeWeight segment_weight = 0;
|
EdgeWeight segment_weight = {0};
|
||||||
|
|
||||||
// some name changes are not announced in our processing. For these, we have to keep the
|
// some name changes are not announced in our processing. For these, we have to keep the
|
||||||
// first name on the segment
|
// first name on the segment
|
||||||
@ -121,7 +117,7 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
: osrm::guidance::TurnInstruction::NO_TURN();
|
: osrm::guidance::TurnInstruction::NO_TURN();
|
||||||
if (turn_instruction.type != osrm::guidance::TurnType::NoTurn)
|
if (turn_instruction.type != osrm::guidance::TurnType::NoTurn)
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(segment_weight >= 0);
|
BOOST_ASSERT(segment_weight >= EdgeWeight{0});
|
||||||
const auto name = facade.GetNameForID(step_name_id);
|
const auto name = facade.GetNameForID(step_name_id);
|
||||||
const auto ref = facade.GetRefForID(step_name_id);
|
const auto ref = facade.GetRefForID(step_name_id);
|
||||||
const auto pronunciation = facade.GetPronunciationForID(step_name_id);
|
const auto pronunciation = facade.GetPronunciationForID(step_name_id);
|
||||||
@ -140,16 +136,16 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
steps.push_back(RouteStep{path_point.from_edge_based_node,
|
steps.push_back(RouteStep{path_point.from_edge_based_node,
|
||||||
step_name_id,
|
step_name_id,
|
||||||
is_segregated,
|
is_segregated,
|
||||||
name.to_string(),
|
std::string(name),
|
||||||
ref.to_string(),
|
std::string(ref),
|
||||||
pronunciation.to_string(),
|
std::string(pronunciation),
|
||||||
destinations.to_string(),
|
std::string(destinations),
|
||||||
exits.to_string(),
|
std::string(exits),
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
segment_duration / 10.,
|
from_alias<double>(segment_duration) / 10.,
|
||||||
distance,
|
distance,
|
||||||
segment_weight / weight_multiplier,
|
from_alias<double>(segment_weight) / weight_multiplier,
|
||||||
travel_mode,
|
travel_mode,
|
||||||
maneuver,
|
maneuver,
|
||||||
leg_geometry.FrontIndex(segment_index),
|
leg_geometry.FrontIndex(segment_index),
|
||||||
@ -228,29 +224,29 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
WaypointType::None,
|
WaypointType::None,
|
||||||
0};
|
0};
|
||||||
segment_index++;
|
segment_index++;
|
||||||
segment_duration = 0;
|
segment_duration = {0};
|
||||||
segment_weight = 0;
|
segment_weight = {0};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const auto distance = leg_geometry.segment_distances[segment_index];
|
const auto distance = leg_geometry.segment_distances[segment_index];
|
||||||
const EdgeWeight duration = segment_duration + target_duration;
|
const EdgeDuration duration = segment_duration + target_duration;
|
||||||
const EdgeWeight weight = segment_weight + target_weight;
|
const EdgeWeight weight = segment_weight + target_weight;
|
||||||
// intersections contain the classes of exiting road
|
// intersections contain the classes of exiting road
|
||||||
intersection.classes = facade.GetClasses(facade.GetClassData(target_node_id));
|
intersection.classes = facade.GetClasses(facade.GetClassData(target_node_id));
|
||||||
BOOST_ASSERT(duration >= 0);
|
BOOST_ASSERT(duration >= EdgeDuration{0});
|
||||||
steps.push_back(RouteStep{leg_data[leg_data.size() - 1].from_edge_based_node,
|
steps.push_back(RouteStep{leg_data[leg_data.size() - 1].from_edge_based_node,
|
||||||
step_name_id,
|
step_name_id,
|
||||||
is_segregated,
|
is_segregated,
|
||||||
facade.GetNameForID(step_name_id).to_string(),
|
std::string(facade.GetNameForID(step_name_id)),
|
||||||
facade.GetRefForID(step_name_id).to_string(),
|
std::string(facade.GetRefForID(step_name_id)),
|
||||||
facade.GetPronunciationForID(step_name_id).to_string(),
|
std::string(facade.GetPronunciationForID(step_name_id)),
|
||||||
facade.GetDestinationsForID(step_name_id).to_string(),
|
std::string(facade.GetDestinationsForID(step_name_id)),
|
||||||
facade.GetExitsForID(step_name_id).to_string(),
|
std::string(facade.GetExitsForID(step_name_id)),
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
duration / 10.,
|
from_alias<double>(duration) / 10.,
|
||||||
distance,
|
distance,
|
||||||
weight / weight_multiplier,
|
from_alias<double>(weight) / weight_multiplier,
|
||||||
target_mode,
|
target_mode,
|
||||||
maneuver,
|
maneuver,
|
||||||
leg_geometry.FrontIndex(segment_index),
|
leg_geometry.FrontIndex(segment_index),
|
||||||
@ -280,22 +276,23 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
|
|
||||||
// use rectified linear unit function to avoid negative duration values
|
// use rectified linear unit function to avoid negative duration values
|
||||||
// due to flooring errors in phantom snapping
|
// due to flooring errors in phantom snapping
|
||||||
BOOST_ASSERT(target_duration >= source_duration || weight == 0);
|
BOOST_ASSERT(target_duration >= source_duration || weight == EdgeWeight{0});
|
||||||
const EdgeWeight duration = std::max(0, target_duration - source_duration);
|
const EdgeDuration duration =
|
||||||
|
std::max<EdgeDuration>({0}, target_duration - source_duration);
|
||||||
|
|
||||||
steps.push_back(RouteStep{source_node_id,
|
steps.push_back(RouteStep{source_node_id,
|
||||||
source_name_id,
|
source_name_id,
|
||||||
is_segregated,
|
is_segregated,
|
||||||
facade.GetNameForID(source_name_id).to_string(),
|
std::string(facade.GetNameForID(source_name_id)),
|
||||||
facade.GetRefForID(source_name_id).to_string(),
|
std::string(facade.GetRefForID(source_name_id)),
|
||||||
facade.GetPronunciationForID(source_name_id).to_string(),
|
std::string(facade.GetPronunciationForID(source_name_id)),
|
||||||
facade.GetDestinationsForID(source_name_id).to_string(),
|
std::string(facade.GetDestinationsForID(source_name_id)),
|
||||||
facade.GetExitsForID(source_name_id).to_string(),
|
std::string(facade.GetExitsForID(source_name_id)),
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
duration / 10.,
|
from_alias<double>(duration) / 10.,
|
||||||
leg_geometry.segment_distances[segment_index],
|
leg_geometry.segment_distances[segment_index],
|
||||||
weight / weight_multiplier,
|
from_alias<double>(weight) / weight_multiplier,
|
||||||
source_mode,
|
source_mode,
|
||||||
maneuver,
|
maneuver,
|
||||||
leg_geometry.FrontIndex(segment_index),
|
leg_geometry.FrontIndex(segment_index),
|
||||||
@ -329,11 +326,11 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
steps.push_back(RouteStep{target_node_id,
|
steps.push_back(RouteStep{target_node_id,
|
||||||
target_name_id,
|
target_name_id,
|
||||||
facade.IsSegregated(target_node_id),
|
facade.IsSegregated(target_node_id),
|
||||||
facade.GetNameForID(target_name_id).to_string(),
|
std::string(facade.GetNameForID(target_name_id)),
|
||||||
facade.GetRefForID(target_name_id).to_string(),
|
std::string(facade.GetRefForID(target_name_id)),
|
||||||
facade.GetPronunciationForID(target_name_id).to_string(),
|
std::string(facade.GetPronunciationForID(target_name_id)),
|
||||||
facade.GetDestinationsForID(target_name_id).to_string(),
|
std::string(facade.GetDestinationsForID(target_name_id)),
|
||||||
facade.GetExitsForID(target_name_id).to_string(),
|
std::string(facade.GetExitsForID(target_name_id)),
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
NO_ROTARY_NAME,
|
NO_ROTARY_NAME,
|
||||||
ZERO_DURATION,
|
ZERO_DURATION,
|
||||||
@ -364,8 +361,6 @@ inline std::vector<RouteStep> assembleSteps(const datafacade::BaseDataFacade &fa
|
|||||||
return steps;
|
return steps;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace guidance
|
} // namespace osrm::engine::guidance
|
||||||
} // namespace engine
|
|
||||||
} // namespace osrm
|
|
||||||
|
|
||||||
#endif // ENGINE_GUIDANCE_SEGMENT_LIST_HPP_
|
#endif // ENGINE_GUIDANCE_SEGMENT_LIST_HPP_
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user