diff options
author | Ivan Dubrov <idubrov@guidewire.com> | 2015-07-08 12:49:17 -0700 |
---|---|---|
committer | Ivan Dubrov <idubrov@guidewire.com> | 2015-07-08 12:49:17 -0700 |
commit | a0446575db678bb699100e0f003c580b883c86ef (patch) | |
tree | 427d7d093ceebd434e23e646d9442fe59f7e9825 /dcevm/src | |
parent | 8d4957bb6185c425d7dfa87caa5d133824788023 (diff) | |
download | dcevm-a0446575db678bb699100e0f003c580b883c86ef.tar.gz dcevm-a0446575db678bb699100e0f003c580b883c86ef.zip |
Improving versions parsing in tests
Diffstat (limited to 'dcevm/src')
-rw-r--r-- | dcevm/src/main/java/com/github/dcevm/HotSwapTool.java | 18 |
1 files changed, 7 insertions, 11 deletions
diff --git a/dcevm/src/main/java/com/github/dcevm/HotSwapTool.java b/dcevm/src/main/java/com/github/dcevm/HotSwapTool.java index 43baa850..568124af 100644 --- a/dcevm/src/main/java/com/github/dcevm/HotSwapTool.java +++ b/dcevm/src/main/java/com/github/dcevm/HotSwapTool.java @@ -33,6 +33,8 @@ import java.net.URL; import java.util.HashMap; import java.util.Hashtable; import java.util.Map; +import java.util.regex.Matcher; +import java.util.regex.Pattern; /** * @author Thomas Wuerthinger @@ -47,7 +49,7 @@ public class HotSwapTool { * the following number is removed. This means that e.g. A___2 is treated as A anywhere in the source code. This is introduced * to make the IDE not complain about multiple defined classes. */ - public static final String IDENTIFIER = "___"; + public static final Pattern VERSION_PATTERN = Pattern.compile("___([0-9]+)"); private static final String CLASS_FILE_SUFFIX = ".class"; private static Map<Class<?>, Integer> currentVersion = new Hashtable<Class<?>, Integer>(); private static Redefiner redefiner; @@ -214,19 +216,13 @@ public class HotSwapTool { * Parse version of the class from the class name. Classes are named in the form of [Name]___[Version] */ private static int parseClassVersion(String simpleName) { - int index = simpleName.indexOf(IDENTIFIER); - if (index == -1) { - return 0; - } - return Integer.valueOf(simpleName.substring(index + IDENTIFIER.length(), simpleName.length())); + Matcher m = VERSION_PATTERN.matcher(simpleName); + return m.find() ? Integer.valueOf(m.group(1)) : 0; } private static String stripVersion(String className) { - int index = className.indexOf(IDENTIFIER); - if (index == -1) { - return className; - } - return className.substring(0, index); + Matcher m = VERSION_PATTERN.matcher(className); + return m.replaceAll(""); } public static void resetTimings() { |