#include "bufferlist.h"
#include "BufferView.h"
#include "debug.h"
+#include "funcrequest.h"
#include "gettext.h"
+#include "LColor.h"
#include "lyx_main.h"
+#include "LyXAction.h"
#include "lyxfunc.h"
#include "lyxrc.h"
#include "lyxserver.h"
+#include "lyxsocket.h"
#include "graphics/LoaderQueue.h"
+#include "support/filetools.h"
#include "support/lyxlib.h"
#include "support/os.h"
-#include "support/filetools.h"
#include "support/path_defines.h"
#include "lyx_forms.h"
#include <fcntl.h>
using lyx::support::AddName;
-using lyx::support::os;
using lyx::support::user_lyxdir;
+namespace os = lyx::support::os;
+
#ifndef CXX_GLOBAL_CSTD
using std::exit;
#endif
using std::setw;
using std::ostringstream;
using std::vector;
+using std::string;
extern BufferList bufferlist;
// FIXME: wrong place !
LyXServer * lyxserver;
+LyXServerSocket * lyxsocket;
namespace {
}
// emergency cleanup
- LyX::emergencyCleanup();
+ LyX::cref().emergencyCleanup();
// Get the reason for the crash.
char etxt[513];
XSetErrorHandler(LyX_XErrHandler);
- lyxColorHandler.reset(new LyXColorHandler());
+ lyxColorHandler.reset(new LyXColorHandler);
using namespace lyx::graphics;
lyxerr[Debug::GUI] << "Creating view: " << width << 'x' << height
<< '+' << xpos << '+' << ypos << endl;
- XFormsView view(width, height);
+ boost::shared_ptr<XFormsView> view_ptr(new XFormsView(width, height));
+ LyX::ref().addLyXView(view_ptr);
+
+ XFormsView & view = *view_ptr.get();
view.show(xpos, ypos, "LyX");
view.init();
// FIXME: some code below needs moving
lyxserver = new LyXServer(&view.getLyXFunc(), lyxrc.lyxpipes);
+ lyxsocket = new LyXServerSocket(&view.getLyXFunc(),
+ os::slashify_path(os::getTmpDir() + "/lyxsocket"));
vector<string>::const_iterator cit = files.begin();
vector<string>::const_iterator end = files.end();
// handle the batch commands the user asked for
if (!batch.empty())
- view.getLyXFunc().dispatch(batch);
+ view.getLyXFunc().dispatch(lyxaction.lookupFunc(batch));
// enter the event loop
while (!finished) {
}
// FIXME: breaks emergencyCleanup
+ delete lyxsocket;
delete lyxserver;
}
return FuncStatus();
}
-string const hexname(EnumLColor col)
+string const hexname(LColor_color col)
{
unsigned int r, g, b;
bool const success = getRGBColor(col, r, g, b);
}
-void update_color(EnumLColor col)
+void update_color(LColor_color col)
{
+ lyxColorHandler->getGCForeground(col);
lyxColorHandler->updateColor(col);
}
comm->read_ready();
}
+extern "C"
+void C_datasocket_callback(int, void * data)
+{
+ LyXDataSocket * client = static_cast<LyXDataSocket *>(data);
+ client->server()->dataCallback(client);
+}
+
+extern "C"
+void C_serversocket_callback(int, void * data)
+{
+ LyXServerSocket * server = static_cast<LyXServerSocket *>(data);
+ server->serverCallback();
+}
+
}
void set_read_callback(int fd, LyXComm * comm)
fl_add_io_callback(fd, FL_READ, C_read_callback, comm);
}
-
void remove_read_callback(int fd)
{
fl_remove_io_callback(fd, FL_READ, C_read_callback);
}
+void set_datasocket_callback(LyXDataSocket * p)
+{
+ fl_add_io_callback(p->fd(), FL_READ, C_datasocket_callback, p);
+}
+
+void remove_datasocket_callback(LyXDataSocket * p)
+{
+ fl_remove_io_callback(p->fd(), FL_READ, C_datasocket_callback);
+}
+
+void set_serversocket_callback(LyXServerSocket * p)
+{
+ fl_add_io_callback(p->fd(), FL_READ, C_serversocket_callback, p);
+}
+
+void remove_serversocket_callback(LyXServerSocket * p)
+{
+ fl_remove_io_callback(p->fd(), FL_READ, C_serversocket_callback);
+}
string const roman_font_name()
{