[LIB-13] Rename some common classes
[chesshog-scanner.git] / src / main / java / org / hedgecode / chess / scanner / portal / AbstractSettingsScanner.java
index 0910047..8d0ccf4 100644 (file)
 
 package org.hedgecode.chess.scanner.portal;
 
-import org.hedgecode.chess.scanner.ChessHogScannerException;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
 import org.hedgecode.chess.scanner.Initiable;
+import org.hedgecode.chess.scanner.ScannerException;
 import org.hedgecode.chess.scanner.Settings;
 import org.hedgecode.chess.scanner.SettingsBuilder;
 import org.hedgecode.chess.scanner.regex.RegexBuilder;
 import org.hedgecode.chess.scanner.regex.RegexParams;
 import org.hedgecode.chess.scanner.spi.ServiceRegistry;
 
+import static org.hedgecode.chess.scanner.ScannerConstants.*;
 import static org.hedgecode.chess.scanner.regex.RegexBuilder.Type;
 
 /**
@@ -38,7 +42,7 @@ public abstract class AbstractSettingsScanner extends AbstractRequestScanner imp
     protected abstract String getResourceName();
 
     @Override
-    public void init() throws ChessHogScannerException {
+    public void init() throws ScannerException {
         SettingsBuilder settingsBuilder = ServiceRegistry.singleProvider(
                 SettingsBuilder.class
         );
@@ -102,6 +106,18 @@ public abstract class AbstractSettingsScanner extends AbstractRequestScanner imp
         );
     }
 
+    protected String regex(String source, String regex) {
+        Matcher matcher = Pattern.compile(regex, Pattern.MULTILINE).matcher(source);
+        if (matcher.find()) {
+            return matcher.groupCount() > 0 ? matcher.group(1) : matcher.group();
+        }
+        return null;
+    }
+
+    protected boolean isPgnFormat(String source) {
+        return regex(source, PGN_DETECT_REGEX) != null;
+    }
+
     private String assignUrlWithParams(String url, String params) {
         return params != null
                 ? url.concat(params)