2 Copyright (c) 2006 Paolo Capriotti <p.capriotti@gmail.com>
3 (c) 2006 Maurizio Monge <maurizio.monge@kdemail.net>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
11 #include "engineinfo.h"
12 #include "xboardengine.h"
13 #include "gnushogiengine.h"
17 using namespace boost
;
19 void EngineDetails::load(Settings s
) {
22 type
= typeFromName(s
["type"].value
<QString
>());
24 s
["work-path"] >> workPath
;
27 void EngineDetails::save(Settings s
) {
30 s
["type"] = typeName(type
);
31 s
["work-path"] = workPath
;
34 void EngineInfo::playAsWhite() {
38 void EngineInfo::playAsBlack() {
42 void EngineInfo::playAs(int player
) {
43 if (m_token
[player
].valid()) {
44 m_ui
.removeEntity(m_token
[player
]);
45 m_token
[player
] = EntityToken();
48 m_token
[player
] = m_ui
.addPlayingEngine(player
, engine(player
));
52 // void EngineInfo::analyze() {
53 // if (m_token.valid()) {
54 // m_ui.removeAnalysingEngine(m_token);
55 // m_token = EntityToken();
58 // m_token = m_ui.addAnalysingEngine(engine());
61 EngineInfo::EngineInfo(const EngineDetails
& details
, UI
& ui
)
66 shared_ptr
<Engine
> EngineInfo::engine(int player
) {
67 shared_ptr
<Engine
> res
;
68 if (m_details
.type
== EngineDetails::XBoard
)
69 res
= shared_ptr
<Engine
>(new XBoardEngine(m_details
.path
, QStringList()));
70 else if (m_details
.type
== EngineDetails::GNUShogi
)
71 res
= shared_ptr
<Engine
>(new GNUShogiEngine(m_details
.path
, QStringList()));
73 kError() << "Unimplemented engine type" << EngineDetails::typeName(m_details
.type
);
74 return shared_ptr
<Engine
>();
78 res
->setWorkingPath(m_details
.workPath
);