diff --git a/enabler/src/de/schildbach/pte/AbstractHafasProvider.java b/enabler/src/de/schildbach/pte/AbstractHafasProvider.java
index fc34092c..e4883a8e 100644
--- a/enabler/src/de/schildbach/pte/AbstractHafasProvider.java
+++ b/enabler/src/de/schildbach/pte/AbstractHafasProvider.java
@@ -2365,7 +2365,13 @@ public abstract class AbstractHafasProvider extends AbstractNetworkProvider
}
}
- private final static Pattern P_NEARBY_COARSE = Pattern.compile("
(.*?)
", Pattern.DOTALL);
+ protected void setHtmlNearbyStationsPattern(final Pattern htmlNearbyStationsPattern)
+ {
+ this.htmlNearbyStationsPattern = htmlNearbyStationsPattern;
+ }
+
+ private Pattern htmlNearbyStationsPattern = Pattern.compile("(.*?)
", Pattern.DOTALL);
+
private final static Pattern P_NEARBY_FINE_COORDS = Pattern
.compile("REQMapRoute0\\.Location0\\.X=(-?\\d+)&(?:amp;)?REQMapRoute0\\.Location0\\.Y=(-?\\d+)&");
private final static Pattern P_NEARBY_FINE_LOCATION = Pattern.compile("[\\?&;]input=(\\d+)&[^\"]*\">([^<]*)<");
@@ -2377,7 +2383,7 @@ public abstract class AbstractHafasProvider extends AbstractNetworkProvider
final CharSequence page = ParserUtils.scrape(uri);
String oldZebra = null;
- final Matcher mCoarse = P_NEARBY_COARSE.matcher(page);
+ final Matcher mCoarse = htmlNearbyStationsPattern.matcher(page);
while (mCoarse.find())
{
diff --git a/enabler/src/de/schildbach/pte/NsProvider.java b/enabler/src/de/schildbach/pte/NsProvider.java
index bf6ee61b..49341122 100644
--- a/enabler/src/de/schildbach/pte/NsProvider.java
+++ b/enabler/src/de/schildbach/pte/NsProvider.java
@@ -19,12 +19,12 @@ package de.schildbach.pte;
import java.io.IOException;
import java.util.Collection;
+import java.util.regex.Pattern;
import de.schildbach.pte.dto.Location;
import de.schildbach.pte.dto.LocationType;
import de.schildbach.pte.dto.NearbyStationsResult;
import de.schildbach.pte.dto.Product;
-import de.schildbach.pte.dto.QueryDeparturesResult;
/**
* @author Andreas Schildbach
@@ -34,9 +34,14 @@ public class NsProvider extends AbstractHafasProvider
public static final NetworkId NETWORK_ID = NetworkId.NS;
private static final String API_BASE = "http://hafas.bene-system.com/bin/";
+ private static final Pattern HTML_NEARBY_STATIONS_PATTERN = Pattern.compile("(.*?)
", Pattern.DOTALL);
+
public NsProvider()
{
super(API_BASE + "stboard.exe/nn", API_BASE + "ajax-getstop.exe/nny", API_BASE + "query.exe/nn", 10);
+
+ setHtmlNearbyStationsPattern(HTML_NEARBY_STATIONS_PATTERN);
+ setStationBoardHasLocation(true);
}
public NetworkId id()
@@ -47,7 +52,7 @@ public class NsProvider extends AbstractHafasProvider
public boolean hasCapabilities(final Capability... capabilities)
{
for (final Capability capability : capabilities)
- if (capability == Capability.SUGGEST_LOCATIONS || capability == Capability.TRIPS)
+ if (capability == Capability.DEPARTURES || capability == Capability.SUGGEST_LOCATIONS || capability == Capability.TRIPS)
return true;
return false;
@@ -66,8 +71,16 @@ public class NsProvider extends AbstractHafasProvider
return 'R';
if (value == 16)
return 'S';
+ if (value == 32)
+ return 'B';
if (value == 64)
return 'F';
+ if (value == 128)
+ return 'U';
+ if (value == 256)
+ return 'T';
+ if (value == 512)
+ return 'P';
throw new IllegalArgumentException("cannot handle: " + value);
}
@@ -91,15 +104,19 @@ public class NsProvider extends AbstractHafasProvider
}
else if (product == Product.SUBWAY)
{
- // productBits.setCharAt(8, '1');
+ productBits.setCharAt(7, '1');
}
else if (product == Product.TRAM)
{
- // productBits.setCharAt(7, '1');
+ productBits.setCharAt(8, '1');
}
- else if (product == Product.BUS || product == Product.ON_DEMAND)
+ else if (product == Product.BUS)
{
- // productBits.setCharAt(5, '1');
+ productBits.setCharAt(5, '1');
+ }
+ else if (product == Product.ON_DEMAND)
+ {
+ productBits.setCharAt(9, '1');
}
else if (product == Product.FERRY)
{
@@ -123,6 +140,7 @@ public class NsProvider extends AbstractHafasProvider
uri.append("?near=Anzeigen");
uri.append("&distance=").append(maxDistance != 0 ? maxDistance / 1000 : 50);
uri.append("&input=").append(normalizeStationId(location.id));
+ uri.append("&L=profi");
return htmlNearbyStations(uri.toString());
}
@@ -132,12 +150,6 @@ public class NsProvider extends AbstractHafasProvider
}
}
- @Override
- public QueryDeparturesResult queryDepartures(final String stationId, final int maxDepartures, final boolean equivs) throws IOException
- {
- throw new UnsupportedOperationException();
- }
-
@Override
public Collection defaultProducts()
{
@@ -151,6 +163,10 @@ public class NsProvider extends AbstractHafasProvider
if (ucType.equals("SPR"))
return 'R';
+ if (ucType.equals("E")) // Budapest, Ungarn
+ return 'R';
+ if (ucType.equals("N")) // Avignon
+ return 'R';
final char t = super.normalizeType(type);
if (t != 0)
diff --git a/enabler/test/de/schildbach/pte/live/NsProviderLiveTest.java b/enabler/test/de/schildbach/pte/live/NsProviderLiveTest.java
index 1f3c9b75..ac471bea 100644
--- a/enabler/test/de/schildbach/pte/live/NsProviderLiveTest.java
+++ b/enabler/test/de/schildbach/pte/live/NsProviderLiveTest.java
@@ -46,7 +46,7 @@ public class NsProviderLiveTest extends AbstractProviderLiveTest
@Test
public void nearbyStations() throws Exception
{
- final NearbyStationsResult result = provider.queryNearbyStations(new Location(LocationType.STATION, "8400058"), 0, 0);
+ final NearbyStationsResult result = provider.queryNearbyStations(new Location(LocationType.STATION, "8800004"), 0, 0);
print(result);
}
@@ -62,7 +62,7 @@ public class NsProviderLiveTest extends AbstractProviderLiveTest
@Test
public void queryDepartures() throws Exception
{
- final QueryDeparturesResult result = provider.queryDepartures("8400058", 0, false);
+ final QueryDeparturesResult result = provider.queryDepartures("8800004", 0, false);
print(result);
}
@@ -99,13 +99,4 @@ public class NsProviderLiveTest extends AbstractProviderLiveTest
print(result);
}
-
- @Test
- public void longTrip() throws Exception
- {
- final QueryTripsResult result = queryTrips(new Location(LocationType.STATION, "100024"), null, new Location(LocationType.STATION, "103624"),
- new Date(), true, null, WalkSpeed.FAST, Accessibility.NEUTRAL);
-
- print(result);
- }
}