X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;ds=sidebyside;f=core%2Fsrc%2Fcom%2Fgoogle%2Fzxing%2Fclient%2Fresult%2FResultParser.java;h=bdcc4d09b748de6c1347d505083ef1867e25a51b;hb=10276c1fd6c1871565ad6d6c87f0249f1c0b7e5c;hp=a3d6fc2740410e38dfd422a8d6bc74691caee46a;hpb=3c01cd7615e6a3e03728e31a5e208dd632ebc0f3;p=zxing.git diff --git a/core/src/com/google/zxing/client/result/ResultParser.java b/core/src/com/google/zxing/client/result/ResultParser.java index a3d6fc27..bdcc4d09 100644 --- a/core/src/com/google/zxing/client/result/ResultParser.java +++ b/core/src/com/google/zxing/client/result/ResultParser.java @@ -30,7 +30,7 @@ import java.util.Vector; *

Thanks to Jeff Griffin for proposing rewrite of these classes that relies less * on exception-based mechanisms during parsing.

* - * @author srowen@google.com (Sean Owen) + * @author Sean Owen */ public abstract class ResultParser { @@ -45,8 +45,6 @@ public abstract class ResultParser { return result; } else if ((result = EmailDoCoMoResultParser.parse(theResult)) != null) { return result; - } else if ((result = EmailAddressResultParser.parse(theResult)) != null) { - return result; } else if ((result = AddressBookAUResultParser.parse(theResult)) != null) { return result; } else if ((result = VCardResultParser.parse(theResult)) != null) { @@ -55,12 +53,20 @@ public abstract class ResultParser { return result; } else if ((result = VEventResultParser.parse(theResult)) != null) { return result; + } else if ((result = EmailAddressResultParser.parse(theResult)) != null) { + return result; + } else if ((result = SMTPResultParser.parse(theResult)) != null) { + return result; } else if ((result = TelResultParser.parse(theResult)) != null) { return result; } else if ((result = SMSMMSResultParser.parse(theResult)) != null) { return result; + } else if ((result = SMSTOMMSTOResultParser.parse(theResult)) != null) { + return result; } else if ((result = GeoResultParser.parse(theResult)) != null) { return result; + } else if ((result = WifiResultParser.parse(theResult)) != null) { + return result; } else if ((result = URLTOResultParser.parse(theResult)) != null) { return result; } else if ((result = URIResultParser.parse(theResult)) != null) { @@ -70,6 +76,8 @@ public abstract class ResultParser { return result; } else if ((result = ProductResultParser.parse(theResult)) != null) { return result; + } else if ((result = ExpandedProductResultParser.parse(theResult)) != null) { + return result; } return new TextParsedResult(theResult.getText(), null); } @@ -90,6 +98,10 @@ public abstract class ResultParser { } } + protected static String[] maybeWrap(String value) { + return value == null ? null : new String[] { value }; + } + protected static String unescapeBackslash(String escaped) { if (escaped != null) { int backslash = escaped.indexOf((int) '\\'); @@ -113,7 +125,7 @@ public abstract class ResultParser { return escaped; } - static String urlDecode(String escaped) { + private static String urlDecode(String escaped) { // No we can't use java.net.URLDecoder here. JavaME doesn't have it. if (escaped == null) { @@ -204,6 +216,24 @@ public abstract class ResultParser { return true; } + protected static boolean isSubstringOfDigits(String value, int offset, int length) { + if (value == null) { + return false; + } + int stringLength = value.length(); + int max = offset + length; + if (stringLength < max) { + return false; + } + for (int i = offset; i < max; i++) { + char c = value.charAt(i); + if (c < '0' || c > '9') { + return false; + } + } + return true; + } + static Hashtable parseNameValuePairs(String uri) { int paramStart = uri.indexOf('?'); if (paramStart < 0) { @@ -228,11 +258,8 @@ public abstract class ResultParser { String value = uri.substring(separator + 1, paramEnd); value = urlDecode(value); result.put(key, value); - } else { - // key, no value - String key = uri.substring(paramStart, paramEnd); - result.put(key, null); } + // Can't put key, null into a hashtable } static String[] matchPrefixedField(String prefix, String rawText, char endChar, boolean trim) {