Merge pull request #821 from litetex/cleanup-TimeAgoParser-java
Cleanup ``TimeAgoParser``
This commit is contained in:
commit
7c78c39230
1 changed files with 27 additions and 40 deletions
|
@ -7,7 +7,6 @@ import org.schabi.newpipe.extractor.utils.Parser;
|
||||||
import java.time.OffsetDateTime;
|
import java.time.OffsetDateTime;
|
||||||
import java.time.ZoneOffset;
|
import java.time.ZoneOffset;
|
||||||
import java.time.temporal.ChronoUnit;
|
import java.time.temporal.ChronoUnit;
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
@ -58,36 +57,27 @@ public class TimeAgoParser {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int timeAgoAmount;
|
return getResultFor(parseTimeAgoAmount(textualDate), parseChronoUnit(textualDate));
|
||||||
try {
|
|
||||||
timeAgoAmount = parseTimeAgoAmount(textualDate);
|
|
||||||
} catch (final NumberFormatException e) {
|
|
||||||
// If there is no valid number in the textual date,
|
|
||||||
// assume it is 1 (as in 'a second ago').
|
|
||||||
timeAgoAmount = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
final ChronoUnit chronoUnit = parseChronoUnit(textualDate);
|
|
||||||
return getResultFor(timeAgoAmount, chronoUnit);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private int parseTimeAgoAmount(final String textualDate) throws NumberFormatException {
|
private int parseTimeAgoAmount(final String textualDate) {
|
||||||
return Integer.parseInt(textualDate.replaceAll("\\D+", ""));
|
try {
|
||||||
|
return Integer.parseInt(textualDate.replaceAll("\\D+", ""));
|
||||||
|
} catch (final NumberFormatException ignored) {
|
||||||
|
// If there is no valid number in the textual date,
|
||||||
|
// assume it is 1 (as in 'a second ago').
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private ChronoUnit parseChronoUnit(final String textualDate) throws ParsingException {
|
private ChronoUnit parseChronoUnit(final String textualDate) throws ParsingException {
|
||||||
for (final Map.Entry<ChronoUnit, Collection<String>> entry
|
return patternsHolder.asMap().entrySet().stream()
|
||||||
: patternsHolder.asMap().entrySet()) {
|
.filter(e -> e.getValue().stream()
|
||||||
final ChronoUnit chronoUnit = entry.getKey();
|
.anyMatch(agoPhrase -> textualDateMatches(textualDate, agoPhrase)))
|
||||||
|
.map(Map.Entry::getKey)
|
||||||
for (final String agoPhrase : entry.getValue()) {
|
.findFirst()
|
||||||
if (textualDateMatches(textualDate, agoPhrase)) {
|
.orElseThrow(() ->
|
||||||
return chronoUnit;
|
new ParsingException("Unable to parse the date: " + textualDate));
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new ParsingException("Unable to parse the date: " + textualDate);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean textualDateMatches(final String textualDate, final String agoPhrase) {
|
private boolean textualDateMatches(final String textualDate, final String agoPhrase) {
|
||||||
|
@ -97,24 +87,21 @@ public class TimeAgoParser {
|
||||||
|
|
||||||
if (patternsHolder.wordSeparator().isEmpty()) {
|
if (patternsHolder.wordSeparator().isEmpty()) {
|
||||||
return textualDate.toLowerCase().contains(agoPhrase.toLowerCase());
|
return textualDate.toLowerCase().contains(agoPhrase.toLowerCase());
|
||||||
} else {
|
}
|
||||||
final String escapedPhrase = Pattern.quote(agoPhrase.toLowerCase());
|
|
||||||
final String escapedSeparator;
|
final String escapedPhrase = Pattern.quote(agoPhrase.toLowerCase());
|
||||||
if (patternsHolder.wordSeparator().equals(" ")) {
|
final String escapedSeparator = patternsHolder.wordSeparator().equals(" ")
|
||||||
// From JDK8 → \h - Treat horizontal spaces as a normal one
|
// From JDK8 → \h - Treat horizontal spaces as a normal one
|
||||||
// (non-breaking space, thin space, etc.)
|
// (non-breaking space, thin space, etc.)
|
||||||
escapedSeparator = "[ \\t\\xA0\\u1680\\u180e\\u2000-\\u200a\\u202f\\u205f\\u3000]";
|
? "[ \\t\\xA0\\u1680\\u180e\\u2000-\\u200a\\u202f\\u205f\\u3000]"
|
||||||
} else {
|
: Pattern.quote(patternsHolder.wordSeparator());
|
||||||
escapedSeparator = Pattern.quote(patternsHolder.wordSeparator());
|
|
||||||
}
|
|
||||||
|
|
||||||
// (^|separator)pattern($|separator)
|
// (^|separator)pattern($|separator)
|
||||||
// Check if the pattern is surrounded by separators or start/end of the string.
|
// Check if the pattern is surrounded by separators or start/end of the string.
|
||||||
final String pattern =
|
final String pattern =
|
||||||
"(^|" + escapedSeparator + ")" + escapedPhrase + "($|" + escapedSeparator + ")";
|
"(^|" + escapedSeparator + ")" + escapedPhrase + "($|" + escapedSeparator + ")";
|
||||||
|
|
||||||
return Parser.isMatch(pattern, textualDate.toLowerCase());
|
return Parser.isMatch(pattern, textualDate.toLowerCase());
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private DateWrapper getResultFor(final int timeAgoAmount, final ChronoUnit chronoUnit) {
|
private DateWrapper getResultFor(final int timeAgoAmount, final ChronoUnit chronoUnit) {
|
||||||
|
|
Loading…
Reference in a new issue