All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.barrybecker4.game.twoplayer.go.GtpKgsTesujisoftGoClient Maven / Gradle / Ivy

/** Copyright by Barry G. Becker, 2000-2011. Licensed under MIT License: http://www.opensource.org/licenses/MIT  */
package com.barrybecker4.game.twoplayer.go;

import com.barrybecker4.common.util.FileUtil;
import com.barrybecker4.game.common.GameContext;
import com.barrybecker4.game.twoplayer.go.server.GtpTesujisoftGoServer;
import org.igoweb.kgs.client.gtp.GtpClient;
import org.igoweb.kgs.client.gtp.Options;

import javax.swing.*;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.PrintStream;
import java.util.Properties;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 * Use this class to connect to KGS using lib/kgsGtp.jar and have my Tesujisoft go engine play on KGS.
 * kgsGtp is a java program that connects Go playing programs to the KGS Go server.
 * http://senseis.xmp.net/?KgsGtp
 * It uses GTP to communicate with your engine, giving commands like "play w cd5" and receives the engine's responses.
 *
 *  @author Barry Becker
 */
public class GtpKgsTesujisoftGoClient {

    private GtpKgsTesujisoftGoClient() {}

    public static void main(String[] args)  {

        try {
            String logFile = FileUtil.getHomeDir() + "/game/temp/" + "log.txt";

            File file = new File(logFile);
            PrintStream log = new PrintStream(new FileOutputStream(file));
            log.println("log=" + logFile);

            final GtpTesujisoftGoServer gtpTSGoServer = new GtpTesujisoftGoServer(System.in, System.out, log);

            Properties props = new Properties();
            FileInputStream inStream = new FileInputStream(FileUtil.getHomeDir()
                    + GameContext.GAME_ROOT + "twoplayer/go/resources/tesujiBot.properties");
            props.load(inStream);
            log.println("props=" + props.toString());
            inStream.close();

            log.println("step 0");
            SwingUtilities.invokeLater(new Runnable() {
                @Override
                public void run() {
                    try {
                        gtpTSGoServer.mainLoop();
                    } catch (IOException ex) {
                        Logger.getLogger(GtpKgsTesujisoftGoClient.class.getName()).log(Level.SEVERE, null, ex);
                    }
                }
            });

            Options kgsOptions = new Options(props, logFile);
            log.println("step 1");
            GtpClient gtpClient = new GtpClient(System.in, System.out, kgsOptions);

            log.println("step 2");
            gtpClient.go();
            log.println("step 3");

            log.close();
        }
        catch (Throwable t) {
            t.printStackTrace();
            System.exit(-1);
        }
    }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy