Merge remote-tracking branch 'origin/master'

This commit is contained in:
Weblate 2016-08-19 15:04:07 +02:00
commit ddbabe563b

View file

@ -35,13 +35,12 @@ public class BinaryMapRouteReaderAdapter {
protected static final Log LOG = PlatformUtil.getLog(BinaryMapRouteReaderAdapter.class); protected static final Log LOG = PlatformUtil.getLog(BinaryMapRouteReaderAdapter.class);
private static final int SHIFT_COORDINATES = 4; private static final int SHIFT_COORDINATES = 4;
private static class RouteTypeCondition { private static class RouteTypeCondition {
String condition = "";
OpeningHoursParser.OpeningHours hours = null;
float floatValue;
}
String condition = "";
OpeningHoursParser.OpeningHours hours = null;
float floatValue;
}
public static class RouteTypeRule { public static class RouteTypeRule {
private final static int ACCESS = 1; private final static int ACCESS = 1;
private final static int ONEWAY = 2; private final static int ONEWAY = 2;
@ -56,7 +55,7 @@ public class BinaryMapRouteReaderAdapter {
private int intValue; private int intValue;
private float floatValue; private float floatValue;
private int type; private int type;
private List<RouteTypeCondition> conditions = null; private List<RouteTypeCondition> conditions = null;
private int forward; private int forward;
public RouteTypeRule(String t, String v) { public RouteTypeRule(String t, String v) {
@ -75,61 +74,61 @@ public class BinaryMapRouteReaderAdapter {
throw e; throw e;
} }
} }
public int isForward() { public int isForward() {
return forward; return forward;
} }
public String getTag() { public String getTag() {
return t; return t;
} }
public String getValue(){ public String getValue(){
return v; return v;
} }
public boolean roundabout(){ public boolean roundabout(){
return type == ROUNDABOUT; return type == ROUNDABOUT;
} }
public int getType() { public int getType() {
return type; return type;
} }
public boolean conditional() { public boolean conditional() {
return conditions != null; return conditions != null;
} }
public int onewayDirection(){ public int onewayDirection(){
if(type == ONEWAY){ if(type == ONEWAY){
return intValue; return intValue;
} }
return 0; return 0;
} }
public float maxSpeed(){ public float maxSpeed(){
if(type == MAXSPEED){ if(type == MAXSPEED){
if(conditions != null) { if(conditions != null) {
Calendar i = Calendar.getInstance(); Calendar i = Calendar.getInstance();
i.setTimeInMillis(System.currentTimeMillis()); i.setTimeInMillis(System.currentTimeMillis());
for(RouteTypeCondition c : conditions) { for(RouteTypeCondition c : conditions) {
if(c.hours != null && c.hours.isOpenedForTime(i)) { if(c.hours != null && c.hours.isOpenedForTime(i)) {
return c.floatValue; return c.floatValue;
} }
} }
} }
return floatValue; return floatValue;
} }
return -1; return -1;
} }
public int lanes(){ public int lanes(){
if(type == LANES){ if(type == LANES){
return intValue; return intValue;
} }
return -1; return -1;
} }
public String highwayRoad(){ public String highwayRoad(){
if(type == HIGHWAY_TYPE){ if(type == HIGHWAY_TYPE){
return v; return v;
@ -159,23 +158,23 @@ public class BinaryMapRouteReaderAdapter {
type = HIGHWAY_TYPE; type = HIGHWAY_TYPE;
} else if(t.startsWith("access") && v != null){ } else if(t.startsWith("access") && v != null){
type = ACCESS; type = ACCESS;
} else if(t.equalsIgnoreCase("maxspeed:conditional") && v != null){ } else if(t.equalsIgnoreCase("maxspeed:conditional") && v != null){
conditions = new ArrayList<RouteTypeCondition>(); conditions = new ArrayList<RouteTypeCondition>();
String[] cts = v.split(";"); String[] cts = v.split(";");
for(String c : cts) { for(String c : cts) {
int ch = c.indexOf('@'); int ch = c.indexOf('@');
if (ch > 0) { if (ch > 0) {
RouteTypeCondition cond = new RouteTypeCondition(); RouteTypeCondition cond = new RouteTypeCondition();
cond.floatValue = RouteDataObject.parseSpeed(c.substring(0, ch), 0); cond.floatValue = RouteDataObject.parseSpeed(c.substring(0, ch), 0);
cond.condition = c.substring(ch + 1).trim(); cond.condition = c.substring(ch + 1).trim();
if (cond.condition.startsWith("(") && cond.condition.endsWith(")")) { if (cond.condition.startsWith("(") && cond.condition.endsWith(")")) {
cond.condition = cond.condition.substring(1, cond.condition.length() - 1).trim(); cond.condition = cond.condition.substring(1, cond.condition.length() - 1).trim();
} }
cond.hours = OpeningHoursParser.parseOpenedHours(cond.condition); cond.hours = OpeningHoursParser.parseOpenedHours(cond.condition);
conditions.add(cond); conditions.add(cond);
} }
} }
type = MAXSPEED; type = MAXSPEED;
} else if(t.equalsIgnoreCase("maxspeed") && v != null){ } else if(t.equalsIgnoreCase("maxspeed") && v != null){
type = MAXSPEED; type = MAXSPEED;
floatValue = RouteDataObject.parseSpeed(v, 0); floatValue = RouteDataObject.parseSpeed(v, 0);
@ -187,7 +186,7 @@ public class BinaryMapRouteReaderAdapter {
type = MAXSPEED; type = MAXSPEED;
forward = -1; forward = -1;
floatValue = RouteDataObject.parseSpeed(v, 0); floatValue = RouteDataObject.parseSpeed(v, 0);
} else if (t.equalsIgnoreCase("lanes") && v != null) { } else if (t.equalsIgnoreCase("lanes") && v != null) {
intValue = -1; intValue = -1;
int i = 0; int i = 0;
type = LANES; type = LANES;
@ -198,12 +197,9 @@ public class BinaryMapRouteReaderAdapter {
intValue = Integer.parseInt(v.substring(0, i)); intValue = Integer.parseInt(v.substring(0, i));
} }
} }
} }
} }
public static class RouteRegion extends BinaryIndexPart { public static class RouteRegion extends BinaryIndexPart {
public int regionsRead; public int regionsRead;
List<RouteSubregion> subregions = new ArrayList<RouteSubregion>(); List<RouteSubregion> subregions = new ArrayList<RouteSubregion>();