Rob Lahaye's "iconify dialogs with main window if so desired" patch.

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@2703 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Angus Leeming 2001-09-07 10:11:02 +00:00
parent 8adbe1580e
commit 5bc3841d41
14 changed files with 102 additions and 11 deletions

View File

@ -1,3 +1,8 @@
2001-09-07 Rob Lahaye <lahaye@users.sourceforge.net>
* lyxrc.[Ch]: added dialogs_iconify_with_main variable and associated
code.
2001-09-04 José Matos <jamatos@fep.up.pt> 2001-09-04 José Matos <jamatos@fep.up.pt>
* buffer.C * buffer.C
* buffer.h * buffer.h

View File

@ -1,3 +1,7 @@
2001-09-07 Rob Lahaye <lahaye@users.sourceforge.net>
* ControlButtons.[Ch]: added publicly accessible IconifyWithMain method.
2001-09-04 Angus Leeming <a.leeming@ic.ac.uk> 2001-09-04 Angus Leeming <a.leeming@ic.ac.uk>
* ControlCharacter.C: fix Michael's bug: In the "Character layout" * ControlCharacter.C: fix Michael's bug: In the "Character layout"

View File

@ -20,6 +20,7 @@
#include "ControlButtons.h" #include "ControlButtons.h"
#include "ButtonControllerBase.h" #include "ButtonControllerBase.h"
#include "ViewBase.h" #include "ViewBase.h"
#include "lyxrc.h"
ControlButtons::ControlButtons() ControlButtons::ControlButtons()
: is_closing_(false) : is_closing_(false)
@ -55,3 +56,9 @@ void ControlButtons::RestoreButton()
update(); update();
bc().restore(); bc().restore();
} }
bool ControlButtons::IconifyWithMain() const
{
return lyxrc.dialogs_iconify_with_main;
}

View File

@ -57,6 +57,8 @@ public:
void CancelButton(); void CancelButton();
/// ///
void RestoreButton(); void RestoreButton();
///
bool IconifyWithMain() const;
/** Allow the view to access the ButtonController. This method must be /** Allow the view to access the ButtonController. This method must be
instantiated in a daughter class that creates the actual instance instantiated in a daughter class that creates the actual instance

View File

@ -1,3 +1,19 @@
2001-09-07 Rob Lahaye <lahaye@users.sourceforge.net>
* FormBase.C (show): use controller_.IconifyWithMain() to control
the dialog's show policy
* FormBaseDeprecated.C (show): ditto, but use lyxrc variable directly.
* FormPreferences.C:
* forms/form_preferences.fd: add a check_dialogs_iconify_with_main
check button to the Look & Feel->Misc tab and code to modify the lyxrc
variable dialogs_iconify_with_main appropriately.
2001-09-07 Angus Leeming <a.leeming@ic.ac.uk>
* FormBase.h: clean-up comments. Remove mutable status of minw_, minh_.
2001-09-06 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr> 2001-09-06 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
* Toolbar_pimpl.C (updateLayoutList): do not display obsolete * Toolbar_pimpl.C (updateLayoutList): do not display obsolete

View File

@ -85,8 +85,9 @@ void FormBase::show()
fl_set_form_maxsize(form(), minw_, minh_); fl_set_form_maxsize(form(), minw_, minh_);
fl_show_form(form(), fl_show_form(form(),
FL_PLACE_MOUSE | FL_FREE_SIZE, 0, FL_PLACE_MOUSE | FL_FREE_SIZE,
title_.c_str()); (controller_.IconifyWithMain() ? FL_TRANSIENT : 0),
title_.c_str());
} }
} }

View File

@ -51,21 +51,19 @@ protected:
private: private:
/// Pointer to the actual instantiation of xform's form /// Pointer to the actual instantiation of xform's form
virtual FL_FORM * form() const = 0; virtual FL_FORM * form() const = 0;
/** Filter the inputs on callback from xforms /// Filter the inputs on callback from xforms
Return true if inputs are valid. */
virtual ButtonPolicy::SMInput input(FL_OBJECT *, long); virtual ButtonPolicy::SMInput input(FL_OBJECT *, long);
/** Redraw the form (on receipt of a Signal indicating, for example, /** Redraw the form (on receipt of a Signal indicating, for example,
that the xform colors have been re-mapped). */ that the xform colors have been re-mapped). */
virtual void redraw(); virtual void redraw();
/// Overcome a dumb xforms sizing bug /// The dialog's minimum allowable dimensions.
mutable int minw_; int minw_;
/// ///
mutable int minh_; int minh_;
/// Can the dialog be resized after it has been created? /// Can the dialog be resized after it has been created?
bool allow_resize_; bool allow_resize_;
/// dialog title, displayed by WM. /// dialog title, displayed by WM.
string title_; string title_;
}; };

View File

@ -21,6 +21,7 @@
#include "LyXView.h" #include "LyXView.h"
#include "support/LAssert.h" #include "support/LAssert.h"
#include "xformsBC.h" #include "xformsBC.h"
#include "lyxrc.h"
//#include "debug.h" //#include "debug.h"
using SigC::slot; using SigC::slot;
@ -112,9 +113,11 @@ void FormBaseDeprecated::show()
// calls to fl_set_form_minsize/maxsize apply only to the next // calls to fl_set_form_minsize/maxsize apply only to the next
// fl_show_form(), so connect() comes first. // fl_show_form(), so connect() comes first.
connect(); connect();
fl_show_form(form(), fl_show_form(form(),
FL_PLACE_MOUSE | FL_FREE_SIZE, 0, FL_PLACE_MOUSE | FL_FREE_SIZE,
title_.c_str()); (lyxrc.dialogs_iconify_with_main ? FL_TRANSIENT : 0),
title_.c_str());
} }
} }

View File

@ -1846,6 +1846,8 @@ void FormPreferences::LnFmisc::apply() const
lyxrc.new_ask_filename = fl_get_button(dialog_->check_ask_new_file); lyxrc.new_ask_filename = fl_get_button(dialog_->check_ask_new_file);
lyxrc.cursor_follows_scrollbar = lyxrc.cursor_follows_scrollbar =
fl_get_button(dialog_->check_cursor_follows_scrollbar); fl_get_button(dialog_->check_cursor_follows_scrollbar);
lyxrc.dialogs_iconify_with_main =
fl_get_button(dialog_->check_dialogs_iconify_with_main);
lyxrc.autosave = static_cast<unsigned int> lyxrc.autosave = static_cast<unsigned int>
(fl_get_counter_value(dialog_->counter_autosave)); (fl_get_counter_value(dialog_->counter_autosave));
lyxrc.wheel_jump = static_cast<unsigned int> lyxrc.wheel_jump = static_cast<unsigned int>
@ -1871,6 +1873,7 @@ void FormPreferences::LnFmisc::build()
setPreHandler(dialog_->counter_autosave); setPreHandler(dialog_->counter_autosave);
setPreHandler(dialog_->check_ask_new_file); setPreHandler(dialog_->check_ask_new_file);
setPreHandler(dialog_->check_cursor_follows_scrollbar); setPreHandler(dialog_->check_cursor_follows_scrollbar);
setPreHandler(dialog_->check_dialogs_iconify_with_main);
setPreHandler(dialog_->counter_wm_jump); setPreHandler(dialog_->counter_wm_jump);
} }
@ -1892,6 +1895,8 @@ FormPreferences::LnFmisc::feedback(FL_OBJECT const * const ob) const
str = lyxrc.getDescription(LyXRC::RC_NEW_ASK_FILENAME); str = lyxrc.getDescription(LyXRC::RC_NEW_ASK_FILENAME);
else if (ob == dialog_->check_cursor_follows_scrollbar) else if (ob == dialog_->check_cursor_follows_scrollbar)
str = lyxrc.getDescription(LyXRC::RC_CURSOR_FOLLOWS_SCROLLBAR); str = lyxrc.getDescription(LyXRC::RC_CURSOR_FOLLOWS_SCROLLBAR);
else if (ob == dialog_->check_dialogs_iconify_with_main)
str = lyxrc.getDescription(LyXRC::RC_DIALOGS_ICONIFY_WITH_MAIN);
else if (ob == dialog_->counter_autosave) else if (ob == dialog_->counter_autosave)
str = lyxrc.getDescription(LyXRC::RC_AUTOSAVE); str = lyxrc.getDescription(LyXRC::RC_AUTOSAVE);
else if (ob == dialog_->counter_wm_jump) else if (ob == dialog_->counter_wm_jump)
@ -1911,6 +1916,8 @@ void FormPreferences::LnFmisc::update()
fl_set_button(dialog_->check_ask_new_file, lyxrc.new_ask_filename); fl_set_button(dialog_->check_ask_new_file, lyxrc.new_ask_filename);
fl_set_button(dialog_->check_cursor_follows_scrollbar, fl_set_button(dialog_->check_cursor_follows_scrollbar,
lyxrc.cursor_follows_scrollbar); lyxrc.cursor_follows_scrollbar);
fl_set_button(dialog_->check_dialogs_iconify_with_main,
lyxrc.dialogs_iconify_with_main);
fl_set_counter_value(dialog_->counter_autosave, lyxrc.autosave); fl_set_counter_value(dialog_->counter_autosave, lyxrc.autosave);
fl_set_counter_value(dialog_->counter_wm_jump, lyxrc.wheel_jump); fl_set_counter_value(dialog_->counter_wm_jump, lyxrc.wheel_jump);
} }

View File

@ -402,6 +402,14 @@ FD_form_lnf_misc * FormPreferences::build_lnf_misc()
fl_set_object_lsize(obj, FL_NORMAL_SIZE); fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0); fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0);
fl_set_button(obj, 1); fl_set_button(obj, 1);
{
char const * const dummy = N_("Dialogs iconify with main window|#D");
fdui->check_dialogs_iconify_with_main = obj = fl_add_checkbutton(FL_PUSH_BUTTON, 15, 195, 30, 30, idex(_(dummy)));
fl_set_button_shortcut(obj, scex(_(dummy)), 1);
}
fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0);
fl_set_button(obj, 1);
fdui->counter_wm_jump = obj = fl_add_counter(FL_NORMAL_COUNTER, 320, 225, 115, 30, _("Wheel mouse jump")); fdui->counter_wm_jump = obj = fl_add_counter(FL_NORMAL_COUNTER, 320, 225, 115, 30, _("Wheel mouse jump"));
fl_set_object_lsize(obj, FL_NORMAL_SIZE); fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_lalign(obj, FL_ALIGN_LEFT); fl_set_object_lalign(obj, FL_ALIGN_LEFT);

View File

@ -115,6 +115,7 @@ struct FD_form_lnf_misc {
FL_OBJECT *check_display_shrtcuts; FL_OBJECT *check_display_shrtcuts;
FL_OBJECT *check_ask_new_file; FL_OBJECT *check_ask_new_file;
FL_OBJECT *check_cursor_follows_scrollbar; FL_OBJECT *check_cursor_follows_scrollbar;
FL_OBJECT *check_dialogs_iconify_with_main;
FL_OBJECT *counter_wm_jump; FL_OBJECT *counter_wm_jump;
FL_OBJECT *counter_autosave; FL_OBJECT *counter_autosave;
}; };

View File

@ -938,7 +938,7 @@ argument: 0
Name: form_lnf_misc Name: form_lnf_misc
Width: 450 Width: 450
Height: 350 Height: 350
Number of Objects: 9 Number of Objects: 10
-------------------- --------------------
class: FL_BOX class: FL_BOX
@ -1072,6 +1072,25 @@ callback: C_FormBaseDeprecatedInputCB
argument: 0 argument: 0
value: 1 value: 1
--------------------
class: FL_CHECKBUTTON
type: PUSH_BUTTON
box: 15 195 30 30
boxtype: FL_NO_BOX
colors: FL_COL1 FL_YELLOW
alignment: FL_ALIGN_CENTER
style: FL_NORMAL_STYLE
size: FL_NORMAL_SIZE
lcol: FL_BLACK
label: Dialogs iconify with main window|#D
shortcut:
resize: FL_RESIZE_ALL
gravity: FL_NoGravity FL_NoGravity
name: check_dialogs_iconify_with_main
callback: C_FormBaseDeprecatedInputCB
argument: 0
value: 1
-------------------- --------------------
class: FL_COUNTER class: FL_COUNTER
type: NORMAL_COUNTER type: NORMAL_COUNTER

View File

@ -65,6 +65,7 @@ keyword_item lyxrcTags[] = {
{ "\\date_insert_format", LyXRC::RC_DATE_INSERT_FORMAT }, { "\\date_insert_format", LyXRC::RC_DATE_INSERT_FORMAT },
{ "\\default_language", LyXRC::RC_DEFAULT_LANGUAGE }, { "\\default_language", LyXRC::RC_DEFAULT_LANGUAGE },
{ "\\default_papersize", LyXRC::RC_DEFAULT_PAPERSIZE }, { "\\default_papersize", LyXRC::RC_DEFAULT_PAPERSIZE },
{ "\\dialogs_iconify_with_main", LyXRC::RC_DIALOGS_ICONIFY_WITH_MAIN },
{ "\\display_shortcuts", LyXRC::RC_DISPLAY_SHORTCUTS }, { "\\display_shortcuts", LyXRC::RC_DISPLAY_SHORTCUTS },
{ "\\document_path", LyXRC::RC_DOCUMENTPATH }, { "\\document_path", LyXRC::RC_DOCUMENTPATH },
{ "\\escape_chars", LyXRC::RC_ESC_CHARS }, { "\\escape_chars", LyXRC::RC_ESC_CHARS },
@ -248,6 +249,7 @@ void LyXRC::setDefaults() {
date_insert_format = "%A, %e %B %Y"; date_insert_format = "%A, %e %B %Y";
show_banner = true; show_banner = true;
cursor_follows_scrollbar = false; cursor_follows_scrollbar = false;
dialogs_iconify_with_main = false;
label_init_length = 3; label_init_length = 3;
/// These variables are not stored on disk (perhaps they /// These variables are not stored on disk (perhaps they
@ -751,6 +753,11 @@ int LyXRC::read(string const & filename)
cursor_follows_scrollbar = lexrc.getBool(); cursor_follows_scrollbar = lexrc.getBool();
break; break;
case RC_DIALOGS_ICONIFY_WITH_MAIN:
if (lexrc.next())
dialogs_iconify_with_main = lexrc.getBool();
break;
case RC_ASCIIROFF_COMMAND: case RC_ASCIIROFF_COMMAND:
if (lexrc.next()) if (lexrc.next())
ascii_roff_command = lexrc.getString(); ascii_roff_command = lexrc.getString();
@ -1117,6 +1124,12 @@ void LyXRC::output(ostream & os) const
os << "\\cursor_follows_scrollbar " os << "\\cursor_follows_scrollbar "
<< tostr(cursor_follows_scrollbar) << "\n"; << tostr(cursor_follows_scrollbar) << "\n";
} }
case RC_DIALOGS_ICONIFY_WITH_MAIN:
if (dialogs_iconify_with_main
!= system_lyxrc.dialogs_iconify_with_main) {
os << "\\dialogs_iconify_with_main "
<< tostr(dialogs_iconify_with_main) << "\n";
}
case RC_SCREEN_FONT_ROMAN: case RC_SCREEN_FONT_ROMAN:
if (roman_font_name != system_lyxrc.roman_font_name) { if (roman_font_name != system_lyxrc.roman_font_name) {
os << "\\screen_font_roman \"" << roman_font_name os << "\\screen_font_roman \"" << roman_font_name
@ -1854,6 +1867,10 @@ string const LyXRC::getDescription(LyXRCTags tag)
str = N_("LyX normally doesn't update the cursor position if you move the scrollbar. Set to true if you'd prefer to always have the cursor on screen."); str = N_("LyX normally doesn't update the cursor position if you move the scrollbar. Set to true if you'd prefer to always have the cursor on screen.");
break; break;
case RC_DIALOGS_ICONIFY_WITH_MAIN:
str = N_("Iconify the dialogs when the main window is iconified. (Affects only dialogs shown after the change has been made.)");
break;
case RC_EXIT_CONFIRMATION: case RC_EXIT_CONFIRMATION:
str = N_("Sets whether LyX asks for a second confirmation to exit when you have changed documents. (LyX will still ask to save changed documents.)"); str = N_("Sets whether LyX asks for a second confirmation to exit when you have changed documents. (LyX will still ask to save changed documents.)");
break; break;

View File

@ -94,6 +94,7 @@ enum LyXRCTags {
RC_ESC_CHARS, RC_ESC_CHARS,
RC_CHKTEX_COMMAND, RC_CHKTEX_COMMAND,
RC_CURSOR_FOLLOWS_SCROLLBAR, RC_CURSOR_FOLLOWS_SCROLLBAR,
RC_DIALOGS_ICONIFY_WITH_MAIN,
RC_EXIT_CONFIRMATION, RC_EXIT_CONFIRMATION,
RC_DISPLAY_SHORTCUTS, RC_DISPLAY_SHORTCUTS,
RC_MAKE_BACKUP, RC_MAKE_BACKUP,
@ -336,6 +337,8 @@ enum LyXRCTags {
/// ///
bool cursor_follows_scrollbar; bool cursor_follows_scrollbar;
/// ///
bool dialogs_iconify_with_main;
///
int label_init_length; int label_init_length;
private: private:
/// Is a bind file already (or currently) read? /// Is a bind file already (or currently) read?