[LIB-9] Separate chesshog-uci module
[chesshog.git] / chesshog-uci / src / main / java / org / hedgecode / chess / uci / AcceptorStub.java
diff --git a/chesshog-uci/src/main/java/org/hedgecode/chess/uci/AcceptorStub.java b/chesshog-uci/src/main/java/org/hedgecode/chess/uci/AcceptorStub.java
new file mode 100644 (file)
index 0000000..c667a7d
--- /dev/null
@@ -0,0 +1,161 @@
+/*
+ * Copyright (c) 2018. Developed by Hedgecode.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *   http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.hedgecode.chess.uci;
+
+import java.util.List;
+
+import org.hedgecode.chess.uci.annotation.CommandDirection;
+import org.hedgecode.chess.uci.command.OptionParams;
+import org.hedgecode.chess.uci.command.OptionType;
+
+/**
+ *
+ *
+ * @author Dmitry Samoshin aka gotty
+ */
+public class AcceptorStub implements Acceptor {
+
+    private static final String LOG_TO_FORMAT = ">> %s %s";
+    private static final String LOG_FROM_FORMAT = "<< %s %s";
+
+    private CommandExecutor commandExecutor;
+
+    AcceptorStub() {
+    }
+
+    public void init(CommandExecutor executor) {
+        commandExecutor = executor;
+    }
+
+    @Override
+    public void start() {
+        commandExecutor.exec(
+                UCIConstants.UCI, CommandDirection.TO_ENGINE, null
+        );
+        log(CommandDirection.TO_ENGINE, UCIConstants.UCI, null);
+    }
+
+    @Override
+    public void id(String params) {
+        log(CommandDirection.FROM_ENGINE, UCIConstants.ID, params);
+    }
+
+    @Override
+    public void uciOK(String params) {
+        log(CommandDirection.FROM_ENGINE, UCIConstants.UCI_OK, params);
+        commandExecutor.exec(
+                UCIConstants.IS_READY, CommandDirection.TO_ENGINE, null
+        );
+        log(CommandDirection.TO_ENGINE,  UCIConstants.IS_READY, null);
+    }
+
+    @Override
+    public void readyOK(String params) {
+        log(CommandDirection.FROM_ENGINE, UCIConstants.READY_OK, params);
+        commandExecutor.exec(
+                UCIConstants.QUIT, CommandDirection.TO_ENGINE, null
+        );
+        log(CommandDirection.TO_ENGINE, UCIConstants.QUIT, null);
+    }
+
+    @Override
+    public void setOption(String name) {
+        log(
+                CommandDirection.FROM_ENGINE,
+                UCIConstants.OPTION,
+                String.format(
+                        "%s %s %s %s",
+                        OptionParams.OPTION_NAME, name, OptionParams.OPTION_TYPE, OptionType.BUTTON.type()
+                )
+        );
+    }
+
+    @Override
+    public void setOption(String name, boolean def) {
+        log(
+                CommandDirection.FROM_ENGINE,
+                UCIConstants.OPTION,
+                String.format(
+                        "%s %s %s %s %s %b",
+                        OptionParams.OPTION_NAME, name, OptionParams.OPTION_TYPE, OptionType.CHECK.type(),
+                        OptionParams.OPTION_DEFAULT, def
+                )
+        );
+    }
+
+    @Override
+    public void setOption(String name, int def, int min, int max) {
+        log(
+                CommandDirection.FROM_ENGINE,
+                UCIConstants.OPTION,
+                String.format(
+                        "%s %s %s %s %s %d %s %d %s %d",
+                        OptionParams.OPTION_NAME, name, OptionParams.OPTION_TYPE, OptionType.SPIN.type(),
+                        OptionParams.OPTION_DEFAULT, def, OptionParams.OPTION_MIN, min, OptionParams.OPTION_MAX, max
+                )
+        );
+    }
+
+    @Override
+    public void setOption(String name, String def) {
+        log(
+                CommandDirection.FROM_ENGINE,
+                UCIConstants.OPTION,
+                String.format(
+                        "%s %s %s %s %s %s",
+                        OptionParams.OPTION_NAME, name, OptionParams.OPTION_TYPE, OptionType.STRING.type(),
+                        OptionParams.OPTION_DEFAULT, def == null ? "" : def
+                )
+        );
+    }
+
+    @Override
+    public void setOption(String name, String def, List<String> vars) {
+        StringBuilder varOptions = new StringBuilder();
+        for (String var : vars)
+            varOptions.append(
+                    String.format("%s %s ", OptionParams.OPTION_VAR, var == null ? "" : var)
+            );
+        log(
+                CommandDirection.FROM_ENGINE,
+                UCIConstants.OPTION,
+                String.format(
+                        "%s %s %s %s %s %s %s",
+                        OptionParams.OPTION_NAME, name, OptionParams.OPTION_TYPE, OptionType.COMBO.type(),
+                        OptionParams.OPTION_DEFAULT, def == null ? "" : def, varOptions.toString().trim()
+                )
+        );
+    }
+
+    @Override
+    public void terminate(String params) {
+        log(CommandDirection.FROM_ENGINE, UCIConstants.TERMINATE, params);
+    }
+
+    private void log(CommandDirection direction, String name, String params) {
+        System.out.println(
+                String.format(
+                        CommandDirection.TO_ENGINE.equals(direction)
+                                ? LOG_TO_FORMAT
+                                : LOG_FROM_FORMAT,
+                        name,
+                        params != null ? params : ""
+                ).trim()
+        );
+    }
+
+}