Merge pull request #2560 from osmandapp/obf-merge
WIP: Address index merge: process namesake cities
This commit is contained in:
commit
73530b80fa
4 changed files with 40 additions and 29 deletions
|
@ -123,6 +123,7 @@ public class BinaryInspector {
|
|||
double latbottom = -85;
|
||||
double lonleft = -180;
|
||||
double lonright = 180;
|
||||
String lang = null;
|
||||
int zoom = -1;
|
||||
|
||||
public boolean isVaddress() {
|
||||
|
@ -186,6 +187,8 @@ public class BinaryInspector {
|
|||
}
|
||||
} else if (params[i].equals("-vtransport")) {
|
||||
vtransport = true;
|
||||
} else if (params[i].startsWith("-lang=")) {
|
||||
lang = params[i].substring("-lang=".length());
|
||||
} else if (params[i].startsWith("-zoom=")) {
|
||||
zoom = Integer.parseInt(params[i].substring("-zoom=".length()));
|
||||
} else if (params[i].startsWith("-bbox=")) {
|
||||
|
@ -609,18 +612,11 @@ public class BinaryInspector {
|
|||
"Villages section",
|
||||
"Postcodes section",
|
||||
};
|
||||
int[] cityType = new int[] {
|
||||
BinaryMapAddressReaderAdapter.CITY_TOWN_TYPE,
|
||||
BinaryMapAddressReaderAdapter.VILLAGES_TYPE,
|
||||
BinaryMapAddressReaderAdapter.POSTCODES_TYPE
|
||||
};
|
||||
String lang = "en";
|
||||
|
||||
for (int j = 0; j < cityType.length; j++) {
|
||||
int type = cityType[j];
|
||||
for (int j = 0; j < BinaryMapAddressReaderAdapter.CITY_TYPES.length; j++) {
|
||||
int type = BinaryMapAddressReaderAdapter.CITY_TYPES[j];
|
||||
final List<City> cities = index.getCities(region, null, type);
|
||||
|
||||
print(MessageFormat.format("\t{0}, {1,number,#} group(s)", new Object[]{cityType_String[j], cities.size()}));
|
||||
print(MessageFormat.format("\t{0}, {1,number,#} group(s)", cityType_String[j], cities.size()));
|
||||
if (BinaryMapAddressReaderAdapter.CITY_TOWN_TYPE == type) {
|
||||
if (!verbose.vstreetgroups && !verbose.vcities) {
|
||||
println("");
|
||||
|
@ -635,10 +631,11 @@ public class BinaryInspector {
|
|||
for (City c : cities) {
|
||||
int size = index.preloadStreets(c, null);
|
||||
List<Street> streets = new ArrayList<Street>(c.getStreets());
|
||||
print(MessageFormat.format("\t\t''{0}'' [{1,number,#}], {2,number,#} street(s) size {3,number,#} bytes",
|
||||
new Object[]{c.getName(lang), c.getId(), streets.size(), size}));
|
||||
if(!verbose.vstreets)
|
||||
{
|
||||
String cityDescription = (j == BinaryMapAddressReaderAdapter.POSTCODES_TYPE ?
|
||||
MessageFormat.format("\t\t''{0}'' {1,number,#} street(s) size {2,number,#} bytes", c.getName(verbose.lang), streets.size(), size) :
|
||||
MessageFormat.format("\t\t''{0}'' [{1,number,#}], {2,number,#} street(s) size {3,number,#} bytes", c.getName(verbose.lang), c.getId(), streets.size(), size));
|
||||
print(cityDescription);
|
||||
if (!verbose.vstreets) {
|
||||
println("");
|
||||
continue;
|
||||
}
|
||||
|
@ -654,20 +651,19 @@ public class BinaryInspector {
|
|||
final List<Street> intersections = t.getIntersectedStreets();
|
||||
|
||||
println(MessageFormat.format("\t\t\t''{0}'' [{1,number,#}], {2,number,#} building(s), {3,number,#} intersections(s)",
|
||||
new Object[]{t.getName(lang), t.getId(), buildings.size(), intersections.size()}));
|
||||
|
||||
new Object[]{t.getName(verbose.lang), t.getId(), buildings.size(), intersections.size()}));
|
||||
if (buildings != null && !buildings.isEmpty() && verbose.vbuildings) {
|
||||
println("\t\t\t\tBuildings:");
|
||||
for (Building b : buildings) {
|
||||
println(MessageFormat.format("\t\t\t\t{0} [{1,number,#}]",
|
||||
new Object[]{b.getName(lang), b.getId()}));
|
||||
new Object[]{b.getName(verbose.lang), b.getId()}));
|
||||
}
|
||||
}
|
||||
|
||||
if (intersections != null && !intersections.isEmpty() && verbose.vintersections) {
|
||||
print("\t\t\t\tIntersects with:");
|
||||
for (Street s : intersections) {
|
||||
println("\t\t\t\t\t" + s.getName(lang));
|
||||
println("\t\t\t\t\t" + s.getName(verbose.lang));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -593,7 +593,12 @@ public class BinaryMapIndexReader {
|
|||
}
|
||||
|
||||
public int preloadStreets(City c, SearchRequest<Street> resultMatcher) throws IOException {
|
||||
AddressRegion reg = checkAddressIndex(c.getFileOffset());
|
||||
AddressRegion reg;
|
||||
try {
|
||||
reg = checkAddressIndex(c.getFileOffset());
|
||||
} catch (IllegalArgumentException e) {
|
||||
throw new IOException(e.getMessage() + " while reading " + c + " (id: " + c.getId() + ")");
|
||||
}
|
||||
codedIS.seek(c.getFileOffset());
|
||||
int size = codedIS.readRawVarint32();
|
||||
int old = codedIS.pushLimit(size);
|
||||
|
@ -1737,9 +1742,6 @@ public class BinaryMapIndexReader {
|
|||
|
||||
|
||||
public static class MapIndex extends BinaryIndexPart {
|
||||
public String getPartName() { return "Map"; }
|
||||
public int getFieldNumber() { return OsmandOdb.OsmAndStructure.MAPINDEX_FIELD_NUMBER; }
|
||||
|
||||
List<MapRoot> roots = new ArrayList<MapRoot>();
|
||||
|
||||
Map<String, Map<String, Integer>> encodingRules = new HashMap<String, Map<String, Integer>>();
|
||||
|
|
|
@ -58,6 +58,13 @@ public class City extends MapObject {
|
|||
return new City(postcode, POSTCODE_INTERNAL_ID--);
|
||||
}
|
||||
|
||||
public City(City city) {
|
||||
this.type = city.type;
|
||||
this.listOfStreets = new ArrayList<>(city.listOfStreets);
|
||||
this.postcode = city.postcode;
|
||||
this.closestCity = city.closestCity;
|
||||
}
|
||||
|
||||
public City(CityType type) {
|
||||
if (type == null) {
|
||||
throw new NullPointerException();
|
||||
|
|
|
@ -23,6 +23,7 @@ public abstract class MapObject implements Comparable<MapObject> {
|
|||
protected LatLon location = null;
|
||||
protected int fileOffset = 0;
|
||||
protected Long id = null;
|
||||
public static final Comparator<MapObject> comparator = new MapObjectComparator();
|
||||
|
||||
public void setId(Long id) {
|
||||
this.id = id;
|
||||
|
@ -207,6 +208,11 @@ public abstract class MapObject implements Comparable<MapObject> {
|
|||
public static class MapObjectComparator implements Comparator<MapObject> {
|
||||
private final String l;
|
||||
Collator collator = OsmAndCollator.primaryCollator();
|
||||
|
||||
public MapObjectComparator() {
|
||||
this.l = null;
|
||||
}
|
||||
|
||||
public MapObjectComparator(String lang) {
|
||||
this.l = lang;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue