/***************************************************************************** * * This file is part of Mapnik (c++ mapping toolkit) * * Copyright (C) 2015 Artem Pavlenko * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * *****************************************************************************/ #ifndef GEOJSON_INDEX_FEATURESET_HPP #define GEOJSON_INDEX_FEATURESET_HPP #include "geojson_datasource.hpp" #include #include #if defined(MAPNIK_MEMORY_MAPPED_FILE) #pragma GCC diagnostic push #include #include #include #include #include #include #include #pragma GCC diagnostic pop #include #endif #include #include namespace { using keys_map = boost::bimap, boost::bimaps::set_of>; enum well_known_names { id = 1, type, features, geometry, coordinates, properties }; inline keys_map get_keys() { keys_map keys = boost::assign::list_of ("type", well_known_names::type) ("features", well_known_names::features) ("geometry", well_known_names::geometry) ("coordinates", well_known_names::coordinates) ("properties", well_known_names::properties) ("id", well_known_names::id) ; return keys; } } class geojson_index_featureset : public mapnik::Featureset { using value_type = std::pair; public: geojson_index_featureset(std::string const& filename, mapnik::filter_in_box const& filter); virtual ~geojson_index_featureset(); mapnik::feature_ptr next(); private: #if defined (MAPNIK_MEMORY_MAPPED_FILE) using file_source_type = boost::interprocess::ibufferstream; mapnik::mapped_region_ptr mapped_region_; #else using file_ptr = std::unique_ptr; file_ptr file_; #endif mapnik::value_integer feature_id_ = 1; mapnik::context_ptr ctx_; std::vector positions_; std::vector::iterator itr_; keys_map keys_ = get_keys(); }; #endif // GEOJSON_INDEX_FEATURESE_HPP