--- /dev/null
+/*
+ * 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()
+ );
+ }
+
+}