diff --git a/editor/editor_config.cpp b/editor/editor_config.cpp index a1e6a77bdd2..0ec50742147 100644 --- a/editor/editor_config.cpp +++ b/editor/editor_config.cpp @@ -27,6 +27,7 @@ static unordered_map const kNamesToFMD = { // {"", feature::Metadata::FMD_TURN_LANES_FORWARD}, // {"", feature::Metadata::FMD_TURN_LANES_BACKWARD}, {"email", feature::Metadata::FMD_EMAIL}, + {"postcode", feature::Metadata::FMD_POSTCODE}, {"wikipedia", feature::Metadata::FMD_WIKIPEDIA}, // {"", feature::Metadata::FMD_MAXSPEED}, {"flats", feature::Metadata::FMD_FLATS}, @@ -133,6 +134,7 @@ bool EditorConfig::GetTypeDescription(vector classificatorTypes, { outDesc.m_address = isBuilding = true; outDesc.m_editableFields.push_back(feature::Metadata::FMD_BUILDING_LEVELS); + outDesc.m_editableFields.push_back(feature::Metadata::FMD_POSTCODE); classificatorTypes.erase(it); break; } diff --git a/editor/editor_tests/xml_feature_test.cpp b/editor/editor_tests/xml_feature_test.cpp index 1ae1360a37a..553a81034a2 100644 --- a/editor/editor_tests/xml_feature_test.cpp +++ b/editor/editor_tests/xml_feature_test.cpp @@ -61,7 +61,6 @@ UNIT_TEST(XMLFeature_Setters) feature.SetName("int_name", "Gorky Park"); feature.SetHouse("10"); - feature.SetPostcode("127001"); feature.SetTagValue("opening_hours", "Mo-Fr 08:15-17:30"); feature.SetTagValue("amenity", "atm"); @@ -75,7 +74,6 @@ UNIT_TEST(XMLFeature_Setters) - @@ -169,7 +167,6 @@ auto const kTestNode = R"( - @@ -189,7 +186,6 @@ UNIT_TEST(XMLFeature_FromXml) TEST(!feature.HasKey("FooBarBaz"), ()); TEST_EQUAL(feature.GetHouse(), "10", ()); - TEST_EQUAL(feature.GetPostcode(), "127001", ()); TEST_EQUAL(feature.GetCenter(), ms::LatLon(55.7978998, 37.4745280), ()); TEST_EQUAL(feature.GetName(), "Gorki Park", ()); TEST_EQUAL(feature.GetName("default"), "Gorki Park", ()); @@ -367,7 +363,6 @@ UNIT_TEST(XMLFeature_FromXMLAndBackToXML) - )"; diff --git a/editor/osm_editor.cpp b/editor/osm_editor.cpp index 4f5310e1e59..fb3b7726342 100644 --- a/editor/osm_editor.cpp +++ b/editor/osm_editor.cpp @@ -130,9 +130,6 @@ bool AreObjectsEqualButStreet(osm::EditableMapObject const & lhs, if (lhs.GetHouseNumber() != rhs.GetHouseNumber()) return false; - if (lhs.GetPostcode() != rhs.GetPostcode()) - return false; - if (lhs.GetCuisines() != rhs.GetCuisines()) return false; diff --git a/editor/xml_feature.cpp b/editor/xml_feature.cpp index ebcf9c8bec4..359d969ad80 100644 --- a/editor/xml_feature.cpp +++ b/editor/xml_feature.cpp @@ -27,7 +27,6 @@ constexpr char const * kUploadTimestamp = "upload_timestamp"; constexpr char const * kUploadStatus = "upload_status"; constexpr char const * kUploadError = "upload_error"; constexpr char const * kHouseNumber = "addr:housenumber"; -constexpr char const * kPostcode = "addr:postcode"; constexpr char const * kCuisine = "cuisine"; constexpr char const * kUnknownType = "unknown"; @@ -289,10 +288,6 @@ string XMLFeature::GetHouse() const { return GetTagValue(kHouseNumber); } void XMLFeature::SetHouse(string const & house) { SetTagValue(kHouseNumber, house); } -string XMLFeature::GetPostcode() const { return GetTagValue(kPostcode); } - -void XMLFeature::SetPostcode(string const & postcode) { SetTagValue(kPostcode, postcode); } - string XMLFeature::GetCuisine() const { return GetTagValue(kCuisine); } void XMLFeature::SetCuisine(string const & cuisine) { SetTagValue(kCuisine, cuisine); } @@ -430,10 +425,6 @@ void ApplyPatch(XMLFeature const & xml, osm::EditableMapObject & object) if (!house.empty()) object.SetHouseNumber(house); - auto const postcode = xml.GetPostcode(); - if (!postcode.empty()) - object.SetPostcode(postcode); - auto const cuisineStr = xml.GetCuisine(); if (!cuisineStr.empty()) { @@ -469,10 +460,6 @@ XMLFeature ToXML(osm::EditableMapObject const & object, bool serializeType) if (!house.empty()) toFeature.SetHouse(house); - auto const postcode = object.GetPostcode(); - if (!postcode.empty()) - toFeature.SetPostcode(postcode); - auto const cuisines = object.GetCuisines(); if (!cuisines.empty()) { @@ -552,10 +539,6 @@ bool FromXML(XMLFeature const & xml, osm::EditableMapObject & object) if (!house.empty()) object.SetHouseNumber(house); - auto const postcode = xml.GetPostcode(); - if (!postcode.empty()) - object.SetPostcode(postcode); - auto const cuisineStr = xml.GetCuisine(); if (!cuisineStr.empty()) { diff --git a/editor/xml_feature.hpp b/editor/xml_feature.hpp index 6f96bf9d96f..01793c8d89e 100644 --- a/editor/xml_feature.hpp +++ b/editor/xml_feature.hpp @@ -140,9 +140,6 @@ class XMLFeature std::string GetHouse() const; void SetHouse(std::string const & house); - std::string GetPostcode() const; - void SetPostcode(std::string const & postcode); - std::string GetCuisine() const; void SetCuisine(std::string const & cuisine); diff --git a/generator/CMakeLists.txt b/generator/CMakeLists.txt index 1e1818f295b..80969ccd151 100644 --- a/generator/CMakeLists.txt +++ b/generator/CMakeLists.txt @@ -17,6 +17,8 @@ set( boost_helpers.hpp borders.cpp borders.hpp + boundary_postcodes_enricher.cpp + boundary_postcodes_enricher.hpp brands_loader.cpp brands_loader.hpp camera_info_collector.cpp @@ -163,8 +165,6 @@ set( popular_places_section_builder.hpp postcode_points_builder.cpp postcode_points_builder.hpp - postcodes_section_builder.cpp - postcodes_section_builder.hpp processor_booking.hpp processor_coastline.cpp processor_coastline.hpp diff --git a/generator/boundary_postcodes_enricher.cpp b/generator/boundary_postcodes_enricher.cpp new file mode 100644 index 00000000000..63bd68aa0a2 --- /dev/null +++ b/generator/boundary_postcodes_enricher.cpp @@ -0,0 +1,57 @@ +#include "generator/boundary_postcodes_enricher.hpp" + +#include "indexer/ftypes_matcher.hpp" + +#include "platform/platform.hpp" + +#include "geometry/point2d.hpp" + +namespace generator +{ +BoundaryPostcodesEnricher::BoundaryPostcodesEnricher(std::string const & boundaryPostcodesFilename) +{ + // May be absent for tests because TestMwmBuilder cannot collect data from osm elements. + if (Platform::IsFileExistsByFullPath(boundaryPostcodesFilename)) + { + FileReader reader(boundaryPostcodesFilename); + ReaderSource src(reader); + + while (src.Size() > 0) + { + std::string postcode; + utils::ReadString(src, postcode); + std::vector geometry; + rw::ReadVectorOfPOD(src, geometry); + m_boundaryPostcodes.emplace_back(std::move(postcode), std::move(geometry)); + m_boundariesTree.Add(m_boundaryPostcodes.size() - 1, + m_boundaryPostcodes.back().second.GetRect()); + } + } +}; + +void BoundaryPostcodesEnricher::Enrich(feature::FeatureBuilder & fb) const +{ + if (!ftypes::IsAddressObjectChecker::Instance()(fb.GetTypes())) + return; + + auto const hasName = !fb.GetMultilangName().IsEmpty(); + + auto const hasHouseNumber = !fb.GetParams().house.Get().empty(); + + // We do not save postcodes for unnamed features without house number to reduce amount of data. + // For example with this filter we have +100Kb for Turkey_Marmara Region_Istanbul.mwm, without + // filter we have +3Mb because of huge amount of unnamed houses without number. + if (!hasName && !hasHouseNumber) + return; + + auto const center = fb.GetKeyPoint(); + m_boundariesTree.ForAnyInRect(m2::RectD(center, center), [&](size_t i) { + CHECK_LESS(i, m_boundaryPostcodes.size(), ()); + if (!m_boundaryPostcodes[i].second.Contains(center)) + return false; + + fb.GetMetadata().Set(feature::Metadata::FMD_POSTCODE, m_boundaryPostcodes[i].first); + return true; + }); +} +} // namespace generator diff --git a/generator/boundary_postcodes_enricher.hpp b/generator/boundary_postcodes_enricher.hpp new file mode 100644 index 00000000000..af6c4bf9379 --- /dev/null +++ b/generator/boundary_postcodes_enricher.hpp @@ -0,0 +1,25 @@ +#pragma once + +#include "generator/feature_builder.hpp" + +#include "geometry/region2d.hpp" +#include "geometry/tree4d.hpp" + +#include +#include +#include + +namespace generator +{ +class BoundaryPostcodesEnricher +{ +public: + explicit BoundaryPostcodesEnricher(std::string const & boundaryPostcodesFilename); + + void Enrich(feature::FeatureBuilder & fb) const; + +private: + std::vector> m_boundaryPostcodes; + m4::Tree m_boundariesTree; +}; +} // namespace generator diff --git a/generator/feature_sorter.cpp b/generator/feature_sorter.cpp index 8a6f238dc5e..704faf0931f 100644 --- a/generator/feature_sorter.cpp +++ b/generator/feature_sorter.cpp @@ -1,6 +1,7 @@ #include "generator/feature_sorter.hpp" #include "generator/borders.hpp" +#include "generator/boundary_postcodes_enricher.hpp" #include "generator/feature_builder.hpp" #include "generator/feature_generator.hpp" #include "generator/gen_mwm_info.hpp" @@ -54,10 +55,11 @@ class FeaturesCollector2 : public FeaturesCollector public: static uint32_t constexpr kInvalidFeatureId = std::numeric_limits::max(); - FeaturesCollector2(string const & filename, DataHeader const & header, - RegionData const & regionData, uint32_t versionDate) + FeaturesCollector2(string const & filename, string const & boundaryPostcodesFilename, + DataHeader const & header, RegionData const & regionData, uint32_t versionDate) : FeaturesCollector(filename + FEATURES_FILE_TAG) , m_filename(filename) + , m_boundaryPostcodesEnricher(boundaryPostcodesFilename) , m_header(header) , m_regionData(regionData) , m_versionDate(versionDate) @@ -241,7 +243,10 @@ class FeaturesCollector2 : public FeaturesCollector fb.GetAddressData().SerializeForMwmTmp(*m_addrFile); if (!fb.GetMetadata().Empty()) + { + m_boundaryPostcodesEnricher.Enrich(fb); m_metadataBuilder.Put(featureId, fb.GetMetadata()); + } if (fb.HasOsmIds()) m_osm2ft.AddIds(generator::MakeCompositeId(fb), featureId); @@ -299,6 +304,7 @@ class FeaturesCollector2 : public FeaturesCollector // Temporary files for sections. TmpFiles m_geoFile, m_trgFile; + generator::BoundaryPostcodesEnricher m_boundaryPostcodesEnricher; indexer::MetadataBuilder m_metadataBuilder; DataHeader m_header; @@ -353,7 +359,10 @@ bool GenerateFinalFeatures(feature::GenerateInfo const & info, string const & na // FeaturesCollector2 will create temporary file `dataFilePath + FEATURES_FILE_TAG`. // We cannot remove it in ~FeaturesCollector2(), we need to remove it in SCOPE_GUARD. SCOPE_GUARD(_, [&]() { Platform::RemoveFileIfExists(dataFilePath + FEATURES_FILE_TAG); }); - FeaturesCollector2 collector(dataFilePath, header, regionData, info.m_versionDate); + auto const boundaryPostcodesFilename = + info.GetIntermediateFileName(BOUNDARY_POSTCODE_TMP_FILENAME); + FeaturesCollector2 collector(dataFilePath, boundaryPostcodesFilename, header, regionData, + info.m_versionDate); for (auto const & point : midPoints.GetVector()) { diff --git a/generator/generator_tests_support/test_feature.cpp b/generator/generator_tests_support/test_feature.cpp index 999802e1d80..7b04eb557f6 100644 --- a/generator/generator_tests_support/test_feature.cpp +++ b/generator/generator_tests_support/test_feature.cpp @@ -138,7 +138,10 @@ void TestFeature::Serialize(FeatureBuilder & fb) const }); if (!m_postcode.empty()) + { fb.GetParams().AddPostcode(m_postcode); + fb.GetMetadata().Set(Metadata::FMD_POSTCODE, m_postcode); + } } // TestCountry ------------------------------------------------------------------------------------- diff --git a/generator/generator_tests_support/test_mwm_builder.cpp b/generator/generator_tests_support/test_mwm_builder.cpp index 7f00008fafd..7ec7a167fbd 100644 --- a/generator/generator_tests_support/test_mwm_builder.cpp +++ b/generator/generator_tests_support/test_mwm_builder.cpp @@ -7,7 +7,6 @@ #include "generator/feature_sorter.hpp" #include "generator/generator_tests_support/test_feature.hpp" #include "generator/postcode_points_builder.hpp" -#include "generator/postcodes_section_builder.hpp" #include "generator/search_index_builder.hpp" #include "indexer/city_boundary.hpp" @@ -150,11 +149,6 @@ void TestMwmBuilder::Finish() CHECK(indexer::BuildIndexFromDataFile(path, path), ("Can't build geometry index.")); - // We do not have boundaryPostcodesFilename because we do not have osm elements stage. - CHECK(BuildPostcodesSection(m_file.GetDirectory(), m_file.GetCountryName(), - "" /* boundaryPostcodesFilename */), - ("Can't build postcodes section.")); - CHECK(indexer::BuildSearchIndexFromDataFile(m_file.GetDirectory(), m_file.GetCountryName(), true /* forceRebuild */, 1 /* threadsCount */), ("Can't build search index.")); diff --git a/generator/generator_tool/generator_tool.cpp b/generator/generator_tool/generator_tool.cpp index d31acfe7d4f..4fcf99dda0a 100644 --- a/generator/generator_tool/generator_tool.cpp +++ b/generator/generator_tool/generator_tool.cpp @@ -19,7 +19,6 @@ #include "generator/platform_helpers.hpp" #include "generator/popular_places_section_builder.hpp" #include "generator/postcode_points_builder.hpp" -#include "generator/postcodes_section_builder.hpp" #include "generator/processor_factory.hpp" #include "generator/ratings_section_builder.hpp" #include "generator/raw_generator.hpp" @@ -368,11 +367,6 @@ MAIN_WITH_ERROR_HANDLING([](int argc, char ** argv) if (!feature::BuildOffsetsTable(dataFile)) continue; - auto const boundaryPostcodesFilename = - genInfo.GetIntermediateFileName(BOUNDARY_POSTCODE_TMP_FILENAME); - if (!BuildPostcodesSection(path, country, boundaryPostcodesFilename)) - LOG(LCRITICAL, ("Error generating postcodes section.")); - if (mapType == MapType::Country) { string const metalinesFilename = genInfo.GetIntermediateFileName(METALINES_FILENAME); diff --git a/generator/osm2meta.cpp b/generator/osm2meta.cpp index 12bc8ac1ef9..bc597b7dcb2 100644 --- a/generator/osm2meta.cpp +++ b/generator/osm2meta.cpp @@ -155,6 +155,8 @@ string MetadataTagProcessorImpl::ValidateAndFormat_email(string const & v) const return v; } +string MetadataTagProcessorImpl::ValidateAndFormat_postcode(string const & v) const { return v; } + string MetadataTagProcessorImpl::ValidateAndFormat_flats(string const & v) const { return v; diff --git a/generator/osm2meta.hpp b/generator/osm2meta.hpp index 050c9ee1cd9..7fd5ce0f8c1 100644 --- a/generator/osm2meta.hpp +++ b/generator/osm2meta.hpp @@ -19,6 +19,7 @@ struct MetadataTagProcessorImpl std::string ValidateAndFormat_turn_lanes_forward(std::string const & v) const; std::string ValidateAndFormat_turn_lanes_backward(std::string const & v) const; std::string ValidateAndFormat_email(std::string const & v) const; + std::string ValidateAndFormat_postcode(std::string const & v) const; std::string ValidateAndFormat_flats(std::string const & v) const; std::string ValidateAndFormat_internet(std::string v) const; std::string ValidateAndFormat_height(std::string const & v) const; @@ -76,6 +77,7 @@ class MetadataTagProcessor : private MetadataTagProcessorImpl case Metadata::FMD_TURN_LANES_FORWARD: valid = ValidateAndFormat_turn_lanes_forward(v); break; case Metadata::FMD_TURN_LANES_BACKWARD: valid = ValidateAndFormat_turn_lanes_backward(v); break; case Metadata::FMD_EMAIL: valid = ValidateAndFormat_email(v); break; + case Metadata::FMD_POSTCODE: valid = ValidateAndFormat_postcode(v); break; case Metadata::FMD_WIKIPEDIA: valid = ValidateAndFormat_wikipedia(v); break; case Metadata::FMD_FLATS: valid = ValidateAndFormat_flats(v); break; case Metadata::FMD_MIN_HEIGHT: // The same validator as for height. @@ -89,7 +91,6 @@ class MetadataTagProcessor : private MetadataTagProcessorImpl case Metadata::FMD_DURATION: valid = ValidateAndFormat_duration(v); break; // Used for old data compatibility only and should not be set: case Metadata::FMD_CUISINE: - case Metadata::FMD_POSTCODE: CHECK(false, (mdType, "used for compatibility, should not be set.")); // Metadata types we do not get from OSM. case Metadata::FMD_SPONSORED_ID: case Metadata::FMD_PRICE_RATE: diff --git a/generator/osm2type.cpp b/generator/osm2type.cpp index 76a5b3d5617..adb04c726d7 100644 --- a/generator/osm2type.cpp +++ b/generator/osm2type.cpp @@ -852,8 +852,6 @@ void GetNameAndType(OsmElement * p, FeatureBuilderParams & params, {"addr:postcode", "*", [¶ms](string & k, string & v) { params.AddPostcode(v); - k.clear(); - v.clear(); }}, {"population", "*", [¶ms](string & k, string & v) { diff --git a/generator/postcodes_section_builder.cpp b/generator/postcodes_section_builder.cpp deleted file mode 100644 index c81369e6a75..00000000000 --- a/generator/postcodes_section_builder.cpp +++ /dev/null @@ -1,120 +0,0 @@ -#include "generator/postcodes_section_builder.hpp" - -#include "generator/gen_mwm_info.hpp" - -#include "indexer/feature_algo.hpp" -#include "indexer/feature_processor.hpp" -#include "indexer/ftypes_matcher.hpp" -#include "indexer/postcodes.hpp" - -#include "platform/platform.hpp" - -#include "coding/files_container.hpp" -#include "coding/reader.hpp" - -#include "geometry/point2d.hpp" -#include "geometry/region2d.hpp" -#include "geometry/tree4d.hpp" - -#include "base/checked_cast.hpp" -#include "base/file_name_utils.hpp" - -#include -#include -#include - -#include "defines.hpp" - -namespace generator -{ -bool BuildPostcodesSection(std::string const & path, std::string const & country, - std::string const & boundaryPostcodesFilename) -{ - LOG(LINFO, ("Building the Postcodes section")); - - std::vector addrs; - { - auto const addrFile = base::JoinPath(path, country + DATA_FILE_EXTENSION + TEMP_ADDR_FILENAME); - FileReader reader(addrFile); - ReaderSource src(reader); - while (src.Size() > 0) - { - addrs.push_back({}); - addrs.back().DeserializeFromMwmTmp(src); - } - } - - auto const featuresCount = base::checked_cast(addrs.size()); - - std::vector> boundaryPostcodes; - m4::Tree boundariesTree; - - // May be empty for tests because TestMwmBuilder cannot collect data from osm elements. - if (!boundaryPostcodesFilename.empty()) - { - FileReader reader(boundaryPostcodesFilename); - ReaderSource src(reader); - - while (src.Size() > 0) - { - std::string postcode; - utils::ReadString(src, postcode); - std::vector geometry; - rw::ReadVectorOfPOD(src, geometry); - boundaryPostcodes.emplace_back(std::move(postcode), std::move(geometry)); - boundariesTree.Add(boundaryPostcodes.size() - 1, boundaryPostcodes.back().second.GetRect()); - } - } - - indexer::PostcodesBuilder builder; - size_t postcodesFromAddr = 0; - size_t postcodesFromBoundaries = 0; - auto const mwmFile = base::JoinPath(path, country + DATA_FILE_EXTENSION); - feature::ForEachFeature(mwmFile, [&](FeatureType & f, uint32_t featureId) { - CHECK_LESS(featureId, featuresCount, ()); - auto const postcode = addrs[featureId].Get(feature::AddressData::Type::Postcode); - if (!postcode.empty()) - { - ++postcodesFromAddr; - builder.Put(featureId, postcode); - return; - } - - if (!ftypes::IsAddressObjectChecker::Instance()(f)) - return; - - std::string name; - f.GetReadableName(name); - - auto const houseNumber = f.GetHouseNumber(); - - // We do not save postcodes for unnamed features without house number to reduce amount of data. - // For example with this filter we have +100Kb for Turkey_Marmara Region_Istanbul.mwm, without - // filter we have +3Mb because of huge amount of unnamed houses without number. - if (name.empty() && houseNumber.empty()) - return; - - auto const center = feature::GetCenter(f); - boundariesTree.ForAnyInRect(m2::RectD(center, center), [&](size_t i) { - CHECK_LESS(i, boundaryPostcodes.size(), ()); - if (!boundaryPostcodes[i].second.Contains(center)) - return false; - - ++postcodesFromBoundaries; - builder.Put(featureId, boundaryPostcodes[i].first); - return true; - }); - }); - - if (postcodesFromBoundaries == 0 && postcodesFromAddr == 0) - return true; - - LOG(LINFO, ("Adding", postcodesFromAddr, "postcodes from addr:postalcode and", - postcodesFromBoundaries, "postcodes from boundary=postal_code relation.")); - - FilesContainerW writeContainer(mwmFile, FileWriter::OP_WRITE_EXISTING); - auto writer = writeContainer.GetWriter(POSTCODES_FILE_TAG); - builder.Freeze(*writer); - return true; -} -} // namespace generator diff --git a/generator/postcodes_section_builder.hpp b/generator/postcodes_section_builder.hpp deleted file mode 100644 index 2537d7640bb..00000000000 --- a/generator/postcodes_section_builder.hpp +++ /dev/null @@ -1,9 +0,0 @@ -#pragma once - -#include - -namespace generator -{ -bool BuildPostcodesSection(std::string const & path, std::string const & country, - std::string const & boundaryPostcodesFilename); -} // namespace generator diff --git a/generator/search_index_builder.cpp b/generator/search_index_builder.cpp index b657b689650..fce6011dfbd 100644 --- a/generator/search_index_builder.cpp +++ b/generator/search_index_builder.cpp @@ -247,7 +247,7 @@ bool InsertPostcodes(FeatureType & f, function using namespace search; auto const & postBoxChecker = ftypes::IsPostBoxChecker::Instance(); - string const postcode = f.GetPostcode(); + string const postcode = f.GetMetadata().Get(feature::Metadata::FMD_POSTCODE); vector postcodes; if (!postcode.empty()) postcodes.push_back(postcode); diff --git a/indexer/editable_map_object.cpp b/indexer/editable_map_object.cpp index 6df6fdbe82e..24bd07b50f4 100644 --- a/indexer/editable_map_object.cpp +++ b/indexer/editable_map_object.cpp @@ -291,7 +291,10 @@ NamesDataSource EditableMapObject::GetNamesDataSource(StringUtf8Multilang const vector const & EditableMapObject::GetNearbyStreets() const { return m_nearbyStreets; } -string EditableMapObject::GetPostcode() const { return m_postcode; } +string EditableMapObject::GetPostcode() const +{ + return m_metadata.Get(feature::Metadata::FMD_POSTCODE); +} string EditableMapObject::GetWikipedia() const { @@ -460,7 +463,10 @@ bool EditableMapObject::UpdateMetadataValue(string const & key, string const & v return true; } -void EditableMapObject::SetPostcode(string const & postcode) { m_postcode = postcode; } +void EditableMapObject::SetPostcode(string const & postcode) +{ + m_metadata.Set(feature::Metadata::FMD_POSTCODE, postcode); +} void EditableMapObject::SetPhone(string const & phone) { diff --git a/indexer/feature.cpp b/indexer/feature.cpp index 04da6d92ddc..1abb3e71480 100644 --- a/indexer/feature.cpp +++ b/indexer/feature.cpp @@ -242,9 +242,6 @@ FeatureType::FeatureType(osm::MapObject const & emo) m_params.house.Set(house); m_parsed.m_common = true; - m_postcode = emo.GetPostcode(); - m_parsed.m_postcode = true; - m_metadata = emo.GetMetadata(); m_parsed.m_metadata = true; @@ -568,6 +565,18 @@ void FeatureType::ParseMetadata() m_metadata.DeserializeFromMwmTmp(src); } } + // December 19 - September 20 mwm compatibility + auto postcodesReader = m_loadInfo->GetPostcodesReader(); + if (postcodesReader) + { + auto postcodes = indexer::Postcodes::Load(*postcodesReader->GetPtr()); + CHECK(postcodes, ()); + string postcode; + auto const havePostcode = postcodes->Get(m_id.m_index, postcode); + CHECK(!havePostcode || !postcode.empty(), (havePostcode, postcode)); + if (havePostcode) + m_metadata.Set(feature::Metadata::FMD_POSTCODE, postcode); + } } catch (Reader::OpenException const &) { @@ -577,29 +586,6 @@ void FeatureType::ParseMetadata() m_parsed.m_metadata = true; } -void FeatureType::ParsePostcode() -{ - if (m_parsed.m_postcode) - return; - - auto postcodesReader = m_loadInfo->GetPostcodesReader(); - if (postcodesReader) - { - auto postcodes = indexer::Postcodes::Load(*postcodesReader->GetPtr()); - CHECK(postcodes, ()); - auto const havePostcode = postcodes->Get(m_id.m_index, m_postcode); - CHECK(!havePostcode || !m_postcode.empty(), (havePostcode, m_postcode)); - } - else - { - // Old data compatibility. - ParseMetadata(); - m_postcode = m_metadata.Get(feature::Metadata::FMD_POSTCODE); - } - - m_parsed.m_postcode = true; -} - StringUtf8Multilang const & FeatureType::GetNames() { ParseCommon(); @@ -817,12 +803,6 @@ string FeatureType::GetRoadNumber() return m_params.ref; } -string const & FeatureType::GetPostcode() -{ - ParsePostcode(); - return m_postcode; -} - feature::Metadata & FeatureType::GetMetadata() { ParseMetadata(); diff --git a/indexer/feature.hpp b/indexer/feature.hpp index b18a68f4ae6..78d14f6962f 100644 --- a/indexer/feature.hpp +++ b/indexer/feature.hpp @@ -157,8 +157,6 @@ class FeatureType uint64_t GetPopulation(); std::string GetRoadNumber(); - std::string const & GetPostcode(); - feature::Metadata & GetMetadata(); /// @name Statistic functions. @@ -197,12 +195,8 @@ class FeatureType bool m_points = false; bool m_triangles = false; bool m_metadata = false; - bool m_postcode = false; - void Reset() - { - m_types = m_common = m_header2 = m_points = m_triangles = m_metadata = m_postcode = false; - } + void Reset() { m_types = m_common = m_header2 = m_points = m_triangles = m_metadata = false; } }; struct Offsets @@ -224,7 +218,6 @@ class FeatureType void ParseCommon(); void ParseHeader2(); void ParseMetadata(); - void ParsePostcode(); void ParseGeometryAndTriangles(int scale); uint8_t m_header = 0; @@ -232,7 +225,6 @@ class FeatureType FeatureID m_id; FeatureParamsBase m_params; - std::string m_postcode; m2::PointD m_center; m2::RectD m_limitRect; diff --git a/indexer/feature_meta.cpp b/indexer/feature_meta.cpp index d6ead842e17..d88595bb256 100644 --- a/indexer/feature_meta.cpp +++ b/indexer/feature_meta.cpp @@ -83,6 +83,8 @@ bool Metadata::TypeFromString(string const & k, Metadata::EType & outType) outType = Metadata::FMD_TURN_LANES_BACKWARD; else if (k == "email" || k == "contact:email") outType = Metadata::FMD_EMAIL; + else if (k == "addr:postcode") + outType = Metadata::FMD_POSTCODE; else if (k == "wikipedia") outType = Metadata::FMD_WIKIPEDIA; else if (k == "addr:flats") diff --git a/indexer/feature_meta.hpp b/indexer/feature_meta.hpp index 25fe29ae0e2..8dfd1852cb8 100644 --- a/indexer/feature_meta.hpp +++ b/indexer/feature_meta.hpp @@ -125,7 +125,7 @@ class Metadata : public MetadataBase FMD_TURN_LANES_FORWARD = 12, FMD_TURN_LANES_BACKWARD = 13, FMD_EMAIL = 14, - FMD_POSTCODE = 15, // Used for old data compatibility only. Should be empty for new mwms. + FMD_POSTCODE = 15, FMD_WIKIPEDIA = 16, // FMD_MAXSPEED used to be 17 but now it is stored in a section of its own. FMD_FLATS = 18, diff --git a/indexer/indexer_tests/CMakeLists.txt b/indexer/indexer_tests/CMakeLists.txt index fe1e9ac3bdd..3ec58747e36 100644 --- a/indexer/indexer_tests/CMakeLists.txt +++ b/indexer/indexer_tests/CMakeLists.txt @@ -25,7 +25,6 @@ set( interval_index_test.cpp mwm_set_test.cpp postcodes_matcher_tests.cpp - postcodes_tests.cpp rank_table_test.cpp read_features_tests.cpp scale_index_reading_tests.cpp diff --git a/indexer/indexer_tests/postcodes_tests.cpp b/indexer/indexer_tests/postcodes_tests.cpp deleted file mode 100644 index 87f2dc2a8a1..00000000000 --- a/indexer/indexer_tests/postcodes_tests.cpp +++ /dev/null @@ -1,53 +0,0 @@ -#include "testing/testing.hpp" - -#include "indexer/postcodes.hpp" - -#include "coding/reader.hpp" -#include "coding/writer.hpp" - -#include -#include -#include - -using namespace indexer; -using namespace std; - -using Buffer = vector; - -UNIT_TEST(Postcodes_Smoke) -{ - map const features = { - {1, "127001"}, {5, "aa1 1aa"}, {10, "123"}, {20, "aaa 1111"}}; - - Buffer buffer; - { - PostcodesBuilder builder; - - for (auto const & feature : features) - builder.Put(feature.first, feature.second); - - MemWriter writer(buffer); - builder.Freeze(writer); - } - - { - MemReader reader(buffer.data(), buffer.size()); - auto postcodes = Postcodes::Load(reader); - TEST(postcodes.get(), ()); - - string actual; - for (uint32_t i = 0; i < 100; ++i) - { - auto const it = features.find(i); - if (it != features.end()) - { - TEST(postcodes->Get(i, actual), ()); - TEST_EQUAL(actual, it->second, ()); - } - else - { - TEST(!postcodes->Get(i, actual), ()); - } - } - } -} diff --git a/indexer/map_object.cpp b/indexer/map_object.cpp index 4530626be8c..c9c59f0d738 100644 --- a/indexer/map_object.cpp +++ b/indexer/map_object.cpp @@ -77,7 +77,6 @@ void MapObject::SetFromFeatureType(FeatureType & ft) m_metadata = ft.GetMetadata(); m_houseNumber = ft.GetHouseNumber(); m_roadNumber = ft.GetRoadNumber(); - m_postcode = ft.GetPostcode(); m_featureID = ft.GetID(); m_geomType = ft.GetGeomType(); if (m_geomType == feature::GeomType::Area) @@ -116,8 +115,6 @@ StringUtf8Multilang const & MapObject::GetNameMultilang() const string const & MapObject::GetHouseNumber() const { return m_houseNumber; } -string const & MapObject::GetPostcode() const { return m_postcode; } - string MapObject::GetLocalizedType() const { ASSERT(!m_types.Empty(), ()); diff --git a/indexer/map_object.hpp b/indexer/map_object.hpp index 5d1d0fd2849..7a7dc739065 100644 --- a/indexer/map_object.hpp +++ b/indexer/map_object.hpp @@ -69,7 +69,6 @@ class MapObject StringUtf8Multilang const & GetNameMultilang() const; std::string const & GetHouseNumber() const; - std::string const & GetPostcode() const; /// @name Metadata fields. //@{ @@ -127,7 +126,6 @@ class MapObject StringUtf8Multilang m_name; std::string m_houseNumber; std::string m_roadNumber; - std::string m_postcode; feature::TypesHolder m_types; feature::Metadata m_metadata; diff --git a/indexer/postcodes.cpp b/indexer/postcodes.cpp index a9e6d7fa41c..68b52cc1bdd 100644 --- a/indexer/postcodes.cpp +++ b/indexer/postcodes.cpp @@ -70,70 +70,4 @@ unique_ptr Postcodes::Load(Reader & reader) return postcodes; } - -// PostcodesBuilder ----------------------------------------------------------------------------- -void PostcodesBuilder::Put(uint32_t featureId, std::string const & postcode) -{ - uint32_t postcodeId = 0; - auto const it = m_postcodeToId.find(postcode); - if (it != m_postcodeToId.end()) - { - postcodeId = it->second; - CHECK_LESS_OR_EQUAL(postcodeId, m_postcodeToId.size(), ()); - CHECK_EQUAL(m_idToPostcode.count(postcodeId), 1, ()); - } - else - { - postcodeId = base::asserted_cast(m_postcodeToId.size()); - m_postcodeToId[postcode] = postcodeId; - CHECK(m_idToPostcode.emplace(postcodeId, postcode).second, ()); - CHECK_EQUAL(m_idToPostcode.size(), m_postcodeToId.size(), ()); - } - m_builder.Put(featureId, postcodeId); -} - -void PostcodesBuilder::Freeze(Writer & writer) const -{ - size_t startOffset = writer.Pos(); - CHECK(coding::IsAlign8(startOffset), ()); - - Postcodes::Header header; - header.Serialize(writer); - - uint64_t bytesWritten = writer.Pos(); - coding::WritePadding(writer, bytesWritten); - - header.m_stringsOffset = base::asserted_cast(writer.Pos() - startOffset); - { - coding::BlockedTextStorageWriter stringsWriter(writer, 1000 /* blockSize */); - for (size_t i = 0; i < m_idToPostcode.size(); ++i) - { - auto const it = m_idToPostcode.find(base::asserted_cast(i)); - CHECK(it != m_idToPostcode.end(), ()); - stringsWriter.Append(it->second); - } - // stringsWriter destructor writes strings section index right after strings. - } - - header.m_stringsSize = - base::asserted_cast(writer.Pos() - header.m_stringsOffset - startOffset); - bytesWritten = writer.Pos(); - coding::WritePadding(writer, bytesWritten); - - header.m_postcodesMapOffset = base::asserted_cast(writer.Pos() - startOffset); - - auto const writeBlockCallback = [](auto & w, auto begin, auto end) { - for (auto it = begin; it != end; ++it) - WriteVarUint(w, *it); - }; - m_builder.Freeze(writer, writeBlockCallback); - - header.m_postcodesMapSize = - base::asserted_cast(writer.Pos() - header.m_postcodesMapOffset - startOffset); - - auto const endOffset = writer.Pos(); - writer.Seek(startOffset); - header.Serialize(writer); - writer.Seek(endOffset); -} } // namespace indexer diff --git a/indexer/postcodes.hpp b/indexer/postcodes.hpp index b7694fa9d6a..5c078ceaf31 100644 --- a/indexer/postcodes.hpp +++ b/indexer/postcodes.hpp @@ -15,6 +15,7 @@ namespace indexer { +// December 2019 - September 2020 mwm compatibility class Postcodes { public: @@ -26,17 +27,6 @@ class Postcodes struct Header { - template - void Serialize(Sink & sink) const - { - CHECK_EQUAL(base::Underlying(m_version), base::Underlying(Version::V0), ()); - WriteToSink(sink, static_cast(m_version)); - WriteToSink(sink, m_stringsOffset); - WriteToSink(sink, m_stringsSize); - WriteToSink(sink, m_postcodesMapOffset); - WriteToSink(sink, m_postcodesMapSize); - } - void Read(Reader & reader); Version m_version = Version::Latest; @@ -62,16 +52,4 @@ class Postcodes std::unique_ptr m_mapSubreader; Version m_version = Version::Latest; }; - -class PostcodesBuilder -{ -public: - void Put(uint32_t featureId, std::string const & postcode); - void Freeze(Writer & writer) const; - -private: - std::unordered_map m_postcodeToId; - std::unordered_map m_idToPostcode; - MapUint32ToValueBuilder m_builder; -}; } // namespace indexer diff --git a/xcode/generator/generator.xcodeproj/project.pbxproj b/xcode/generator/generator.xcodeproj/project.pbxproj index 8e335ff321f..d708989c192 100644 --- a/xcode/generator/generator.xcodeproj/project.pbxproj +++ b/xcode/generator/generator.xcodeproj/project.pbxproj @@ -120,6 +120,8 @@ 40492BC92021DC53008E093A /* feature_helpers.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 40492BC42021DC53008E093A /* feature_helpers.cpp */; }; 40492BCA2021DC53008E093A /* feature_helpers.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 40492BC52021DC53008E093A /* feature_helpers.hpp */; }; 40492BCC2021DC53008E093A /* geometry_holder.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 40492BC72021DC53008E093A /* geometry_holder.hpp */; }; + 4067A69F2506588E00A99EAA /* boundary_postcodes_enricher.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 4067A69D2506588D00A99EAA /* boundary_postcodes_enricher.cpp */; }; + 4067A6A02506588E00A99EAA /* boundary_postcodes_enricher.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 4067A69E2506588E00A99EAA /* boundary_postcodes_enricher.hpp */; }; 407E8A122265FEE100C6E668 /* ratings_section_builder.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 407E8A102265FEE000C6E668 /* ratings_section_builder.hpp */; }; 407E8A132265FEE100C6E668 /* ratings_section_builder.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 407E8A112265FEE100C6E668 /* ratings_section_builder.cpp */; }; 4088CE2421AE995D00E2702A /* brands_loader.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 4088CE2221AE995D00E2702A /* brands_loader.hpp */; }; @@ -166,9 +168,7 @@ 56DAC3092398FA77000BC50D /* processor_coastline.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 56DAC2CE2398FA74000BC50D /* processor_coastline.hpp */; }; 56DAC30A2398FA77000BC50D /* filter_world.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 56DAC2CF2398FA74000BC50D /* filter_world.hpp */; }; 56DAC30B2398FA77000BC50D /* processor_booking.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 56DAC2D02398FA74000BC50D /* processor_booking.hpp */; }; - 56DAC30C2398FA77000BC50D /* postcodes_section_builder.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 56DAC2D12398FA74000BC50D /* postcodes_section_builder.cpp */; }; 56DAC30D2398FA77000BC50D /* collector_boundary_postcode.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 56DAC2D22398FA74000BC50D /* collector_boundary_postcode.hpp */; }; - 56DAC30E2398FA77000BC50D /* postcodes_section_builder.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 56DAC2D32398FA74000BC50D /* postcodes_section_builder.hpp */; }; 56DAC30F2398FA77000BC50D /* complex_loader.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 56DAC2D42398FA74000BC50D /* complex_loader.cpp */; }; 56DAC3102398FA77000BC50D /* filter_complex.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 56DAC2D52398FA74000BC50D /* filter_complex.hpp */; }; 56DAC3112398FA77000BC50D /* collector_boundary_postcode.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 56DAC2D62398FA74000BC50D /* collector_boundary_postcode.cpp */; }; @@ -446,6 +446,8 @@ 40492BC42021DC53008E093A /* feature_helpers.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = feature_helpers.cpp; sourceTree = ""; }; 40492BC52021DC53008E093A /* feature_helpers.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = feature_helpers.hpp; sourceTree = ""; }; 40492BC72021DC53008E093A /* geometry_holder.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = geometry_holder.hpp; sourceTree = ""; }; + 4067A69D2506588D00A99EAA /* boundary_postcodes_enricher.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = boundary_postcodes_enricher.cpp; sourceTree = ""; }; + 4067A69E2506588E00A99EAA /* boundary_postcodes_enricher.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = boundary_postcodes_enricher.hpp; sourceTree = ""; }; 407E8A102265FEE000C6E668 /* ratings_section_builder.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = ratings_section_builder.hpp; sourceTree = ""; }; 407E8A112265FEE100C6E668 /* ratings_section_builder.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ratings_section_builder.cpp; sourceTree = ""; }; 4088CE2221AE995D00E2702A /* brands_loader.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = brands_loader.hpp; sourceTree = ""; }; @@ -492,9 +494,7 @@ 56DAC2CE2398FA74000BC50D /* processor_coastline.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = processor_coastline.hpp; sourceTree = ""; }; 56DAC2CF2398FA74000BC50D /* filter_world.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = filter_world.hpp; sourceTree = ""; }; 56DAC2D02398FA74000BC50D /* processor_booking.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = processor_booking.hpp; sourceTree = ""; }; - 56DAC2D12398FA74000BC50D /* postcodes_section_builder.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = postcodes_section_builder.cpp; sourceTree = ""; }; 56DAC2D22398FA74000BC50D /* collector_boundary_postcode.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = collector_boundary_postcode.hpp; sourceTree = ""; }; - 56DAC2D32398FA74000BC50D /* postcodes_section_builder.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = postcodes_section_builder.hpp; sourceTree = ""; }; 56DAC2D42398FA74000BC50D /* complex_loader.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = complex_loader.cpp; sourceTree = ""; }; 56DAC2D52398FA74000BC50D /* filter_complex.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = filter_complex.hpp; sourceTree = ""; }; 56DAC2D62398FA74000BC50D /* collector_boundary_postcode.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = collector_boundary_postcode.cpp; sourceTree = ""; }; @@ -713,6 +713,8 @@ 6753401D1A3F2A1B00A0A8C3 /* generator */ = { isa = PBXGroup; children = ( + 4067A69D2506588D00A99EAA /* boundary_postcodes_enricher.cpp */, + 4067A69E2506588E00A99EAA /* boundary_postcodes_enricher.hpp */, 40C3B8A8244DF33500AB1669 /* cluster_finder.hpp */, 40C3B8A5244DF33500AB1669 /* final_processor_coastline.cpp */, 40C3B89F244DF33400AB1669 /* final_processor_coastline.hpp */, @@ -763,8 +765,6 @@ 56DAC3032398FA77000BC50D /* mini_roundabout_info.hpp */, 56DAC2ED2398FA76000BC50D /* mini_roundabout_transformer.cpp */, 56DAC2E22398FA75000BC50D /* mini_roundabout_transformer.hpp */, - 56DAC2D12398FA74000BC50D /* postcodes_section_builder.cpp */, - 56DAC2D32398FA74000BC50D /* postcodes_section_builder.hpp */, 56DAC2D02398FA74000BC50D /* processor_booking.hpp */, 56DAC3022398FA77000BC50D /* processor_coastline.cpp */, 56DAC2CE2398FA74000BC50D /* processor_coastline.hpp */, @@ -1154,7 +1154,6 @@ 3DFEBF821EF423FB00317D5C /* sponsored_object_storage.hpp in Headers */, 56FB438C2164F571002099B3 /* region.hpp in Headers */, 56DAC3392398FA77000BC50D /* raw_generator_writer.hpp in Headers */, - 56DAC30E2398FA77000BC50D /* postcodes_section_builder.hpp in Headers */, 56DAC3092398FA77000BC50D /* processor_coastline.hpp in Headers */, 56DAC3172398FA77000BC50D /* filter_roads.hpp in Headers */, 6753406D1A3F2A7400A0A8C3 /* feature_generator.hpp in Headers */, @@ -1217,6 +1216,7 @@ 56DAC33E2398FA77000BC50D /* mini_roundabout_info.hpp in Headers */, 3989E321230300CD00D63F84 /* affiliation.hpp in Headers */, 40C3B8AC244DF33500AB1669 /* final_processor_coastline.hpp in Headers */, + 4067A6A02506588E00A99EAA /* boundary_postcodes_enricher.hpp in Headers */, 3989E360230302CB00D63F84 /* geo_objects_maintainer.hpp in Headers */, 56DAC3042398FA77000BC50D /* processor_country.hpp in Headers */, 397057C522CB5850001A55CA /* translation.hpp in Headers */, @@ -1350,6 +1350,7 @@ 670E7BB31EF9812B00A8E9ED /* metalines_builder.cpp in Sources */, 56DAC3162398FA77000BC50D /* cross_mwm_osm_ways_collector.cpp in Sources */, 3D51BC581D5E512500F1FA8D /* srtm_parser.cpp in Sources */, + 4067A69F2506588E00A99EAA /* boundary_postcodes_enricher.cpp in Sources */, 675340871A3F2A7400A0A8C3 /* unpack_mwm.cpp in Sources */, 40C3B8B4244DF33500AB1669 /* final_processor_utils.cpp in Sources */, 670B84BC1A8CDB0000CE4492 /* osm_source.cpp in Sources */, @@ -1399,7 +1400,6 @@ E9502E331D34012200CAB86B /* booking_scoring.cpp in Sources */, 56DAC32B2398FA77000BC50D /* raw_generator.cpp in Sources */, 40492BC92021DC53008E093A /* feature_helpers.cpp in Sources */, - 56DAC30C2398FA77000BC50D /* postcodes_section_builder.cpp in Sources */, 670E7BB91EF9812B00A8E9ED /* ugc_db.cpp in Sources */, 4032E72F225D151D00D33617 /* filter_planet.cpp in Sources */, 56DAC3112398FA77000BC50D /* collector_boundary_postcode.cpp in Sources */, diff --git a/xcode/indexer/indexer.xcodeproj/project.pbxproj b/xcode/indexer/indexer.xcodeproj/project.pbxproj index fa1527b3eaa..2f48e80fd32 100644 --- a/xcode/indexer/indexer.xcodeproj/project.pbxproj +++ b/xcode/indexer/indexer.xcodeproj/project.pbxproj @@ -78,7 +78,6 @@ 4099F64A1FC7142A002A7B05 /* fake_feature_ids.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 4099F6481FC7142A002A7B05 /* fake_feature_ids.hpp */; }; 409EE3E3237E9AA700EA31A4 /* postcodes.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 409EE3E1237E9AA700EA31A4 /* postcodes.hpp */; }; 409EE3E4237E9AA700EA31A4 /* postcodes.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 409EE3E2237E9AA700EA31A4 /* postcodes.cpp */; }; - 40BC58CA237EACDF006B2C4E /* postcodes_tests.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 40BC58C9237EACDF006B2C4E /* postcodes_tests.cpp */; }; 40C3C091205BF9F400CED188 /* bounds.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 40C3C090205BF9F400CED188 /* bounds.hpp */; }; 40D62CEF23F2E8BE009A20F5 /* dat_section_header.hpp in Headers */ = {isa = PBXBuildFile; fileRef = 40D62CEE23F2E8BE009A20F5 /* dat_section_header.hpp */; }; 40DB152D23F2AC9400E49602 /* meta_idx.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 40DB152B23F2AC9400E49602 /* meta_idx.cpp */; }; @@ -312,7 +311,6 @@ 4099F6481FC7142A002A7B05 /* fake_feature_ids.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = fake_feature_ids.hpp; sourceTree = ""; }; 409EE3E1237E9AA700EA31A4 /* postcodes.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = postcodes.hpp; sourceTree = ""; }; 409EE3E2237E9AA700EA31A4 /* postcodes.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = postcodes.cpp; sourceTree = ""; }; - 40BC58C9237EACDF006B2C4E /* postcodes_tests.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = postcodes_tests.cpp; sourceTree = ""; }; 40C3C090205BF9F400CED188 /* bounds.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = bounds.hpp; sourceTree = ""; }; 40D62CEE23F2E8BE009A20F5 /* dat_section_header.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = dat_section_header.hpp; sourceTree = ""; }; 40DB152B23F2AC9400E49602 /* meta_idx.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = meta_idx.cpp; sourceTree = ""; }; @@ -586,7 +584,6 @@ isa = PBXGroup; children = ( 4067554B242BB04800EB8F8B /* read_features_tests.cpp */, - 40BC58C9237EACDF006B2C4E /* postcodes_tests.cpp */, 391C0C8522BD255E003DC252 /* feature_to_osm_tests.cpp */, 406970A121AEF2F10024DDB2 /* brands_tests.cpp */, 40C3C090205BF9F400CED188 /* bounds.hpp */, @@ -1046,7 +1043,6 @@ 6753410D1A3F540F00A0A8C3 /* drawing_rules.cpp in Sources */, 675341301A3F540F00A0A8C3 /* data_source.cpp in Sources */, 34664CF61D49FEC1003D7096 /* centers_table.cpp in Sources */, - 40BC58CA237EACDF006B2C4E /* postcodes_tests.cpp in Sources */, 3D12E3D72111B4BE0015A9A9 /* caching_rank_table_loader.cpp in Sources */, 6753414D1A3F540F00A0A8C3 /* types_mapping.cpp in Sources */, 34583BC71C88552100F94664 /* cuisines.cpp in Sources */,