source: josm/trunk/src/org/openstreetmap/josm/io/MultiFetchOverpassObjectReader.java@ 9352

Last change on this file since 9352 was 9325, checked in by simon04, 8 years ago

see #7670 fix #7647 - Fetching objects via Overpass API recurses down

Thus, there is no need for separately querying way nodes, or relation members.

File size: 1.4 KB
Line 
1// License: GPL. For details, see LICENSE file.
2package org.openstreetmap.josm.io;
3
4import org.openstreetmap.josm.data.osm.OsmPrimitiveType;
5import org.openstreetmap.josm.gui.preferences.server.OverpassServerPreference;
6import org.openstreetmap.josm.tools.Utils;
7
8import java.util.Set;
9
10/**
11 * Retrieves a set of {@link org.openstreetmap.josm.data.osm.OsmPrimitive}s from an Overpass API server.
12 *
13 * @since 9241
14 */
15class MultiFetchOverpassObjectReader extends MultiFetchServerObjectReader {
16
17 @Override
18 protected String buildRequestString(final OsmPrimitiveType type, Set<Long> idPackage) {
19 final Utils.Function<Long, Object> toOverpassExpression = new Utils.Function<Long, Object>() {
20 @Override
21 public Object apply(Long x) {
22 return type.getAPIName() + "(" + x + ");>;";
23 }
24 };
25 final String query = "(" + Utils.join("", Utils.transform(idPackage, toOverpassExpression)) + ");out meta;";
26 return "interpreter?data=" + Utils.encodeUrl(query);
27 }
28
29 @Override
30 protected String getBaseUrl() {
31 return OverpassServerPreference.getOverpassServer();
32 }
33
34 @Override
35 protected boolean recursesDown() {
36 // see https://wiki.openstreetmap.org/wiki/Overpass_API/Overpass_QL#Recurse_down_.28.3E.29 for documentation
37 // accomplished using >; in the query string above
38 return true;
39 }
40}
Note: See TracBrowser for help on using the repository browser.