]> git.lyx.org Git - lyx.git/blobdiff - src/lyx_gui.C
ws change
[lyx.git] / src / lyx_gui.C
index 80807e657f0fd55b708083908c7ae5f076e87dcc..aff0e0fe87819ed5beedd4473f3ab724f611dbba 100644 (file)
@@ -1,8 +1,8 @@
 /* This file is part of
  * ======================================================
- * 
+ *
  *           LyX, The Document Processor
- *      
+ *
  *         Copyright 1995 Matthias Ettrich
  *          Copyright 1995-2001 The LyX Team.
  *
@@ -16,8 +16,6 @@
 
 #include "lyx_gui.h"
 #include FORMS_H_LOCATION
-#include "figure_form.h"
-#include "print_form.h"
 #include "tex-strings.h"
 #include "lyx_main.h"
 #include "debug.h"
@@ -28,7 +26,6 @@
 #include "lyxserver.h"
 #include "lyxrc.h"
 #include "gettext.h"
-#include "lyx_gui_misc.h"
 #if FL_REVISION < 89 || (FL_REVISION == 89 && FL_FIXLEVEL < 5)
 #include "lyxlookup.h"
 #endif
@@ -47,9 +44,6 @@
 
 using std::endl;
 
-FD_form_sendto * fd_form_sendto;
-FD_form_figure * fd_form_figure;
-
 extern LyXServer * lyxserver;
 extern bool finished;  // flag, that we are quitting the program
 extern BufferList bufferlist;
@@ -78,22 +72,27 @@ FL_resource res[] =
 
 
 extern "C" {
-       
+
 static
 int LyX_XErrHandler(Display * display, XErrorEvent * xeev)
 {
+       if (xeev->error_code == BadWindow) {
+               // We don't abort on BadWindow
+               return 0;
+       }
+
        // emergency cleanup
        LyX::emergencyCleanup();
 
        // Get the reason for the crash.
        char etxt[513];
        XGetErrorText(display, xeev->error_code, etxt, 512);
-       lyxerr << etxt << endl;
+       lyxerr << etxt << " id: " << xeev->resourceid << endl;
        // By doing an abort we get a nice backtrace. (hopefully)
        lyx::abort();
        return 0; // Solaris CC wants us to return something
 }
-       
+
 }
 
 
@@ -104,18 +103,18 @@ LyXGUI::LyXGUI(LyX * owner, int * argc, char * argv[], bool GUI)
        if (!gui)
                return;
 
-       // 
+       //
        setDefaults();
-       
+
        static const int num_res = sizeof(res)/sizeof(FL_resource);
        fl_initialize(argc, argv, "LyX", cmdopt, num_res);
        // It appears that, in xforms >=0.89.5, fl_initialize()
        // calls setlocale() and ruins our LC_NUMERIC setting.
        locale_init();
-       fl_get_app_resources(res, num_res);
+       fl_get_app_resources(res, num_res);
 
        static const int geometryBitmask =
-               XParseGeometry( geometry,
+               XParseGeometry(geometry,
                                &xpos,
                                &ypos,
                                reinterpret_cast<unsigned int *>(&width),
@@ -133,10 +132,10 @@ LyXGUI::LyXGUI(LyX * owner, int * argc, char * argv[], bool GUI)
 
        // A width less than 590 pops up an awkward main window
        // The minimal values of width/height (590/400) are defined in
-       // src/lyx.C  
-        if (width < 590) width = 590;
+       // src/lyx.C
+       if (width < 590) width = 590;
        if (height < 400) height = 400;
-       
+
        // If width is not set by geometry, check it against monitor width
        if (!(geometryBitmask & 4)) {
                Screen * scr = ScreenOfDisplay(fl_get_display(), fl_screen);
@@ -169,8 +168,8 @@ LyXGUI::LyXGUI(LyX * owner, int * argc, char * argv[], bool GUI)
 // A destructor is always necessary  (asierra-970604)
 LyXGUI::~LyXGUI()
 {
-        // Lyxserver was created in this class so should be destroyed
-        // here.  asierra-970604
+       // Lyxserver was created in this class so should be destroyed
+       // here.  asierra-970604
        delete lyxserver;
        lyxserver = 0;
        delete lyxViews;
@@ -194,25 +193,25 @@ void LyXGUI::init()
 
        create_forms();
 
-       if (lyxrc.font_norm_menu.empty())
-               lyxrc.font_norm_menu = lyxrc.font_norm;
+       if (lyxrc.popup_font_encoding.empty())
+               lyxrc.popup_font_encoding = lyxrc.font_norm;
        // Set the font name for popups and menus
-        string boldfontname = lyxrc.menu_font_name 
-                              + "-*-*-*-?-*-*-*-*-"  
-                              + lyxrc.font_norm_menu;
+       string boldfontname = lyxrc.popup_bold_font
+                              + "-*-*-*-?-*-*-*-*-"
+                              + lyxrc.popup_font_encoding;
                // "?" means "scale that font"
-        string fontname = lyxrc.popup_font_name 
-                              + "-*-*-*-?-*-*-*-*-"  
-                              + lyxrc.font_norm_menu;
+       string fontname = lyxrc.popup_normal_font
+                              + "-*-*-*-?-*-*-*-*-"
+                              + lyxrc.popup_font_encoding;
 
        int bold = fl_set_font_name(FL_BOLD_STYLE, boldfontname.c_str());
        int normal = fl_set_font_name(FL_NORMAL_STYLE, fontname.c_str());
-        if (bold < 0)
-                lyxerr << "Could not set menu font to "
+       if (bold < 0)
+               lyxerr << "Could not set menu font to "
                       << boldfontname << endl;
 
-        if (normal < 0)
-                lyxerr << "Could not set popup font to "
+       if (normal < 0)
+               lyxerr << "Could not set popup font to "
                       << fontname << endl;
 
        if (bold < 0 && normal < 0) {
@@ -233,32 +232,22 @@ void LyXGUI::init()
        else if (normal < 0)
                fl_set_font_name(FL_NORMAL_STYLE, boldfontname.c_str());
 
-       // put here (after fl_initialize) to avoid segfault. Cannot be done
+       // put here (after fl_initialize) to avoid segfault. Cannot be done
        // in setDefaults() (Matthias 140496)
-       // Moved from ::LyXGUI to ::init to allow popup font customization 
+       // Moved from ::LyXGUI to ::init to allow popup font customization
        // (petr 120997).
-       fl_setpup_fontstyle(FL_NORMAL_STYLE);
-       fl_setpup_fontsize(FL_NORMAL_SIZE);
-       fl_setpup_color(FL_MCOL, FL_BLACK);
+       fl_setpup_fontstyle(FL_NORMAL_STYLE);
+       fl_setpup_fontsize(FL_NORMAL_SIZE);
+       fl_setpup_color(FL_MCOL, FL_BLACK);
        fl_set_goodies_font(FL_NORMAL_STYLE, FL_NORMAL_SIZE);
+#if FL_REVISION < 89
+       fl_set_oneliner_font(FL_NORMAL_STYLE, FL_NORMAL_SIZE);
+#else
+       fl_set_tooltip_font(FL_NORMAL_STYLE, FL_NORMAL_SIZE);
+#endif
 
-        // all lyxrc settings has to be done here as lyxrc has not yet
-        // been read when the GUI is created (Jug)
-
-       // the sendto form
-        if (!lyxrc.custom_export_command.empty())
-                fl_set_input(fd_form_sendto->input_cmd,
-                             lyxrc.custom_export_command.c_str());
-       if (lyxrc.custom_export_format == "lyx")
-               fl_set_button(fd_form_sendto->radio_ftype_lyx, 1);
-       else if (lyxrc.custom_export_format == "tex")
-               fl_set_button(fd_form_sendto->radio_ftype_latex, 1);
-       else if (lyxrc.custom_export_format == "dvi")
-               fl_set_button(fd_form_sendto->radio_ftype_dvi, 1);
-       else if (lyxrc.custom_export_format == "ps")
-               fl_set_button(fd_form_sendto->radio_ftype_ps, 1);
-        else if (lyxrc.custom_export_format == "ascii")
-                fl_set_button(fd_form_sendto->radio_ftype_ascii, 1);
+       // all lyxrc settings has to be done here as lyxrc has not yet
+       // been read when the GUI is created (Jug)
 
        // Update parameters.
        lyxViews->redraw();
@@ -266,8 +255,7 @@ void LyXGUI::init()
        // Initialize the views.
        lyxViews->init();
 
-       // in 0.12 the initialisation of the LyXServer must be done here
-       // 0.13 it should be moved again...
+       // this should be moved ...
        lyxserver = new LyXServer(lyxViews->getLyXFunc(), lyxrc.lyxpipes);
 }
 
@@ -280,25 +268,11 @@ void LyXGUI::create_forms()
 
        // From here down should be done by somebody else. (Lgb)
 
-       //
-       // Create forms
-       //
-
-       // the sendto form
-       fd_form_sendto = create_form_form_sendto();
-       fl_set_form_atclose(fd_form_sendto->form_sendto, CancelCloseBoxCB, 0);
-
-       // the figure form
-       fd_form_figure = create_form_form_figure();
-       fl_set_form_atclose(fd_form_figure->form_figure,
-                           CancelCloseBoxCB, 0);
-       fl_set_button(fd_form_figure->radio_postscript, 1);
-
        // This is probably as good a time as any to map the xform colours,
        // should a mapping exist.
        string const filename = AddName(user_lyxdir, "preferences.xform");
-       XformsColor::read( filename );
-       
+       XformsColor::read(filename);
+
        // Show the main & title form
        int main_placement = FL_PLACE_CENTER | FL_FREE_SIZE;
        // Did we get a valid position?