Line data Source code
1 :
2 : /* Copyright (c) 2007-2011, Stefan Eilemann <eile@equalizergraphics.com>
3 : * 2010, Cedric Stalder <cedric.stalder@gmail.com>
4 : * 2010, Daniel Nachbaur <danielnachbaur@gmail.com>
5 : *
6 : * This library is free software; you can redistribute it and/or modify it under
7 : * the terms of the GNU Lesser General Public License version 2.1 as published
8 : * by the Free Software Foundation.
9 : *
10 : * This library is distributed in the hope that it will be useful, but WITHOUT
11 : * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 : * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
13 : * details.
14 : *
15 : * You should have received a copy of the GNU Lesser General Public License
16 : * along with this library; if not, write to the Free Software Foundation, Inc.,
17 : * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 : */
19 :
20 : #include "localServer.h"
21 :
22 : #include "server.h"
23 :
24 : #include "global.h"
25 : #include "loader.h"
26 :
27 : #include <co/node.h>
28 :
29 : #define CONFIG "server{ config{ appNode{ pipe { \
30 : window { viewport [ .25 .25 .5 .5 ] channel { name \"channel\" }}}} \
31 : compound { channel \"channel\" wall { }}}}"
32 :
33 : namespace eq
34 : {
35 : namespace server
36 : {
37 : namespace
38 : {
39 : class ServerThread : public lunchbox::Thread
40 : {
41 : public:
42 28 : ServerThread() {}
43 28 : virtual ~ServerThread() {}
44 :
45 24 : bool start( eq::server::ServerPtr server )
46 : {
47 24 : LBASSERT( !_server );
48 24 : _server = server;
49 24 : return Thread::start();
50 : }
51 :
52 48 : eq::server::ServerPtr getServer()
53 : {
54 48 : return _server;
55 : }
56 :
57 : protected:
58 :
59 24 : void run() final
60 : {
61 24 : _server->run();
62 24 : _server->close();
63 24 : _server->deleteConfigs();
64 :
65 24 : LBASSERTINFO( _server->getRefCount() == 1,
66 : "Server thread done, still referenced by " <<
67 : _server->getRefCount( ));
68 24 : _server = 0;
69 24 : eq::server::Global::clear();
70 24 : }
71 :
72 : private:
73 : eq::server::ServerPtr _server;
74 : };
75 :
76 28 : static ServerThread _serverThread;
77 : }
78 :
79 24 : bool startLocalServer( const std::string& config )
80 : {
81 24 : if( _serverThread.isRunning( ))
82 : {
83 0 : LBWARN << "Only one app-local per process server allowed" << std::endl;
84 0 : return false;
85 : }
86 :
87 24 : eq::server::Loader loader;
88 48 : eq::server::ServerPtr server;
89 :
90 24 : if( config.length() > 3 && config.find( ".eqc" ) == config.length() - 4 )
91 4 : server = loader.loadFile( config );
92 : else
93 : {
94 : #ifdef EQUALIZER_USE_HWSD
95 20 : server = new eq::server::Server; // configured upon Server::chooseConfig
96 : #else
97 : server = loader.parseServer( CONFIG );
98 : #endif
99 : }
100 :
101 24 : if( !server )
102 : {
103 0 : LBERROR << "Failed to load configuration" << std::endl;
104 0 : return false;
105 : }
106 :
107 24 : eq::server::Loader::addOutputCompounds( server );
108 24 : eq::server::Loader::addDestinationViews( server );
109 24 : eq::server::Loader::addDefaultObserver( server );
110 24 : eq::server::Loader::convertTo11( server );
111 24 : eq::server::Loader::convertTo12( server );
112 : // TODO: ref count is 2 since config holds ServerPtr
113 : // LBASSERTINFO( server->getRefCount() == 1, server );
114 :
115 24 : if( !server->listen( ))
116 : {
117 0 : LBERROR << "Failed to setup server listener" << std::endl;
118 0 : return false;
119 : }
120 :
121 24 : if( !_serverThread.start( server ))
122 : {
123 0 : LBERROR << "Failed to start server thread" << std::endl;
124 0 : return false;
125 : }
126 :
127 48 : return true;
128 : }
129 :
130 24 : co::ConnectionPtr connectLocalServer()
131 : {
132 24 : if( !_serverThread.getServer( ))
133 0 : return nullptr;
134 :
135 24 : co::ConnectionDescriptionPtr desc = new co::ConnectionDescription;
136 24 : desc->type = co::CONNECTIONTYPE_PIPE;
137 48 : co::ConnectionPtr connection = co::Connection::create( desc );
138 24 : if( !connection->connect( ))
139 : {
140 0 : LBERROR << "Failed to set up server connection" << std::endl;
141 0 : return nullptr;
142 : }
143 :
144 48 : co::ConnectionPtr sibling = connection->acceptSync();
145 :
146 24 : _serverThread.getServer()->addConnection( sibling );
147 :
148 48 : return connection;
149 : }
150 :
151 24 : void joinLocalServer()
152 : {
153 24 : _serverThread.join();
154 24 : }
155 :
156 : }
157 84 : }
|