The bool value in the old version served two purposes at once: it was used both to control the execution flow and to indicate the parsing result. As such, the return value of true meant "the needed key was found and the callback returned true when executed with the corresponding value" and the return value of false meant "either the needed key was not found or the callback returned false even though the key was present". This is too loaded semantically and is a false optimization (since the parsed url params need to be stored in a vector of pairs by the time of this call, early exit won't help much). |
||
---|---|---|
3party | ||
android | ||
base | ||
cmake | ||
coding | ||
data | ||
descriptions | ||
docs | ||
drape | ||
drape_frontend | ||
editor | ||
feature_list | ||
ge0 | ||
generator | ||
geometry | ||
indexer | ||
iphone | ||
kml | ||
local_ads | ||
map | ||
mapshot | ||
metrics | ||
openlr | ||
partners_api | ||
platform | ||
pyhelpers | ||
qt | ||
qt_tstfrm | ||
routing | ||
routing_common | ||
search | ||
shaders | ||
skin_generator | ||
software_renderer | ||
stats | ||
std | ||
storage | ||
testing | ||
tools | ||
topography_generator | ||
track_analyzing | ||
track_generator | ||
tracking | ||
traffic | ||
transit | ||
ugc | ||
web_api | ||
xcode | ||
.clang-format | ||
.gitattributes | ||
.gitignore | ||
.gitmodules | ||
build_version.hpp.in | ||
CMakeLists.txt | ||
configure.sh | ||
CONTRIBUTORS | ||
defines.hpp | ||
LICENSE | ||
NOTICE | ||
omim_config.h | ||
precompiled_headers.hpp | ||
private_default.h | ||
README.md |
MAPS.ME
MAPS.ME is an open source cross-platform offline maps application, built on top of crowd-sourced OpenStreetMap data. It was publicly released for iOS and Android.
Submodules
This repository contains submodules. Clone it with git clone --recursive
. If you forgot,
run git submodule update --init --recursive
.
Translations
If you want to improve app translations or add more search synonyms, please check our wiki.
Compilation
To compile the project, you would need to initialize private key files. Run
configure.sh
and press Enter to create empty files, good enough to build desktop
and Android debug packages.
For detailed installation instructions and Android/iOS building process, see INSTALL.md.
Building maps
To create one or many map files, first build the project, then use python module maps_generator.
Map styles
MAPS.ME uses its own binary format for map styles, drules_proto.bin
, which is compiled from
MapCSS using modified Kothic library.
Feature set in MWM files depends on a compiled style, so make sure to rebuild maps after
releasing a style.
For development, use MAPS.ME Designer app along with its generator tool: these allow for quick rebuilding of a style and symbols, and for producing a zoom-independent feature set in MWM files.
See STYLES.md for the format description, instructions on building a style and some links.
Development
You would need Qt 5 for development, most other libraries are included into the
repository: see 3party
directory. The team uses mostly XCode and Qt Creator,
though these are not mandatory. We have an established
c++ coding style and Objective-C coding style.
See CONTRIBUTING.md for the repository initialization process, the description of all the directories of this repository and other development-related information.
All contributors must sign a Contributor Agreement, so both our and their rights are protected.
Feedback
Please report bugs and suggestions to the issue tracker, or by mail to bugs@maps.me.
Authors and License
This source code is Copyright (C) 2020 My.com B.V. (Mail.Ru Group), published under Apache Public License 2.0, except third-party libraries. See NOTICE and data/copyright.html files for more information.