summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDanial Klimkin <dklimkin@github.com>2017-04-10 22:16:34 +0200
committerDanial Klimkin <dklimkin@github.com>2017-04-10 22:16:34 +0200
commit545b1e364eec52a28ce823b0b8c598b163ebfd95 (patch)
tree6f42743317f16a3296417c4e69142b49e4878b04
parentb34910261c184a51f9de578b364d14e6d486567c (diff)
downloadAntennaPod-545b1e364eec52a28ce823b0b8c598b163ebfd95.zip
Additional date format and a hack for CEST
-rw-r--r--core/src/androidTest/java/de/danoeh/antennapod/core/tests/util/DateUtilsTest.java15
-rw-r--r--core/src/main/java/de/danoeh/antennapod/core/util/DateUtils.java40
2 files changed, 37 insertions, 18 deletions
diff --git a/core/src/androidTest/java/de/danoeh/antennapod/core/tests/util/DateUtilsTest.java b/core/src/androidTest/java/de/danoeh/antennapod/core/tests/util/DateUtilsTest.java
index 2727b1447..bdd114f46 100644
--- a/core/src/androidTest/java/de/danoeh/antennapod/core/tests/util/DateUtilsTest.java
+++ b/core/src/androidTest/java/de/danoeh/antennapod/core/tests/util/DateUtilsTest.java
@@ -101,4 +101,19 @@ public class DateUtilsTest extends AndroidTestCase {
assertEquals(expected, actual);
}
+ public void testParseDateWithNoTimezonePadding() throws Exception {
+ GregorianCalendar exp = new GregorianCalendar(2017, 1, 22, 22, 28, 00);
+ exp.setTimeZone(TimeZone.getTimeZone("UTC"));
+ Date expected = new Date(exp.getTimeInMillis() + 2);
+ Date actual = DateUtils.parse("2017-02-22T14:28:00.002-08:00");
+ assertEquals(expected, actual);
+ }
+
+ public void testParseDateWithForCest() throws Exception {
+ GregorianCalendar exp = new GregorianCalendar(2017, 0, 28, 23, 00, 00);
+ exp.setTimeZone(TimeZone.getTimeZone("UTC"));
+ Date expected = new Date(exp.getTimeInMillis());
+ Date actual = DateUtils.parse("Sun, 29 Jan 2017 00:00:00 CEST");
+ assertEquals(expected, actual);
+ }
}
diff --git a/core/src/main/java/de/danoeh/antennapod/core/util/DateUtils.java b/core/src/main/java/de/danoeh/antennapod/core/util/DateUtils.java
index 314062e52..c06921c95 100644
--- a/core/src/main/java/de/danoeh/antennapod/core/util/DateUtils.java
+++ b/core/src/main/java/de/danoeh/antennapod/core/util/DateUtils.java
@@ -16,41 +16,44 @@ import java.util.TimeZone;
* Parses several date formats.
*/
public class DateUtils {
-
- private static final String TAG = "DateUtils";
+
+ private static final String TAG = "DateUtils";
private static final TimeZone defaultTimezone = TimeZone.getTimeZone("GMT");
public static Date parse(final String input) {
- if(input == null) {
+ if (input == null) {
throw new IllegalArgumentException("Date must not be null");
}
String date = input.trim().replace('/', '-').replaceAll("( ){2,}+", " ");
+ // CEST is widely used but not in the "ISO 8601 Time zone" list. Let's hack around.
+ date = date.replaceAll("CEST$", "+01:00");
+
// if datetime is more precise than seconds, make sure the value is in ms
- if(date.contains(".")) {
+ if (date.contains(".")) {
int start = date.indexOf('.');
- int current = start+1;
- while(current < date.length() && Character.isDigit(date.charAt(current))) {
+ int current = start + 1;
+ while (current < date.length() && Character.isDigit(date.charAt(current))) {
current++;
}
// even more precise than microseconds: discard further decimal places
- if(current - start > 4) {
- if(current < date.length()-1) {
+ if (current - start > 4) {
+ if (current < date.length() - 1) {
date = date.substring(0, start + 4) + date.substring(current);
} else {
date = date.substring(0, start + 4);
}
- // less than 4 decimal places: pad to have a consistent format for the parser
- } else if(current - start < 4) {
- if(current < date.length()-1) {
- date = date.substring(0, current) + StringUtils.repeat("0", 4-(current-start)) + date.substring(current);
+ // less than 4 decimal places: pad to have a consistent format for the parser
+ } else if (current - start < 4) {
+ if (current < date.length() - 1) {
+ date = date.substring(0, current) + StringUtils.repeat("0", 4 - (current - start)) + date.substring(current);
} else {
- date = date.substring(0, current) + StringUtils.repeat("0", 4-(current-start));
+ date = date.substring(0, current) + StringUtils.repeat("0", 4 - (current - start));
}
}
}
- String[] patterns = {
+ final String[] patterns = {
"dd MMM yy HH:mm:ss Z",
"dd MMM yy HH:mm Z",
"EEE, dd MMM yyyy HH:mm:ss Z",
@@ -76,6 +79,7 @@ public class DateUtils {
"yyyy-MM-dd'T'HH:mm:ss.SSS",
"yyyy-MM-dd'T'HH:mm:ssZ",
"yyyy-MM-dd'T'HH:mm:ss'Z'",
+ "yyyy-MM-dd'T'HH:mm:ss.SSSZ",
"yyyy-MM-ddZ",
"yyyy-MM-dd"
};
@@ -85,7 +89,7 @@ public class DateUtils {
parser.setTimeZone(defaultTimezone);
ParsePosition pos = new ParsePosition(0);
- for(String pattern : patterns) {
+ for (String pattern : patterns) {
parser.applyPattern(pattern);
pos.setIndex(0);
try {
@@ -93,7 +97,7 @@ public class DateUtils {
if (result != null && pos.getIndex() == date.length()) {
return result;
}
- } catch(Exception e) {
+ } catch (Exception e) {
Log.e(TAG, Log.getStackTraceString(e));
}
}
@@ -143,7 +147,7 @@ public class DateUtils {
}
public static String formatAbbrev(final Context context, final Date date) {
- if(date == null) {
+ if (date == null) {
return "";
}
GregorianCalendar cal = new GregorianCalendar();
@@ -152,7 +156,7 @@ public class DateUtils {
cal.add(GregorianCalendar.DAY_OF_MONTH, 10);
boolean withinLastYear = date.after(cal.getTime());
int format = android.text.format.DateUtils.FORMAT_ABBREV_ALL;
- if(withinLastYear) {
+ if (withinLastYear) {
format |= android.text.format.DateUtils.FORMAT_NO_YEAR;
}
return android.text.format.DateUtils.formatDateTime(context, date.getTime(), format);