+2001-11-07 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
+
+ * buffer.C (saveParamsAsDefaults):
+ * lyx_cb.C (MenuLayoutSave): remove
+
+ * LyXAction.C (init):
+ * commandtags.h:
+ * lyxfunc.C (dispatch): remove LFUN_LAYOUT_SAVE_DEFAULT.
+
2001-11-06 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
* buffer.C (setPaperStuff): removed from here...
{ LFUN_LAYOUT_PASTE, "layout-paste",
N_("Paste paragraph environment type"), Noop },
{ LFUN_LAYOUT_PREAMBLE, "layout-preamble", "", ReadOnly },
- { LFUN_LAYOUT_SAVE_DEFAULT, "layout-save-default", "",
- ReadOnly },
{ LFUN_LAYOUT_TABULAR, "layout-tabular",
N_("Open the tabular layout"), Noop },
{ LFUN_HOME, "line-begin",
}
-bool Buffer::saveParamsAsDefaults() // const
-{
- string const fname = AddName(AddPath(user_lyxdir, "templates/"),
- "defaults.lyx");
- Buffer defaults = Buffer(fname);
-
- // Use the current buffer's parameters as default
- defaults.params = params;
-
- // add an empty paragraph. Is this enough?
- defaults.paragraph = new Paragraph;
-
- return defaults.writeFile(defaults.filename, false);
-}
-
-
/// Update window titles of all users
// Should work on a list
void Buffer::updateTitles() const
/// Destructor
~Buffer();
- /** Save the buffer's parameters as user default.
- This function saves a file \c user_lyxdir/templates/defaults.lyx
- which parameters are those of the current buffer. This file
- is used as a default template when creating a new
- file. Returns \c true on success.
- */
- bool saveParamsAsDefaults();
-
/** High-level interface to buffer functionality.
This function parses a command string and executes it
*/
LFUN_LAYOUT_PARAGRAPH,
LFUN_LAYOUT_DOCUMENT,
LFUN_LAYOUT_PREAMBLE,
- LFUN_LAYOUT_SAVE_DEFAULT,
LFUN_DROP_LAYOUTS_CHOICE,
LFUN_CODE,
LFUN_SANS,
+2001-11-07 Jean-Marc Lasgouttes <Jean-Marc.Lasgouttes@inria.fr>
+
+ * FormDocument.C (class_apply):
+ (paper_apply):
+ (language_apply):
+ (options_apply):
+ (bullets_apply): add a version of these methods taking a
+ BufferParams& parameters. The original versions are now wrappers
+ around these.
+ (saveParamsAsDefault): new function, moved from old
+ LFUN_LAYOUT_SAVE_DEFAULT code.
+
2001-11-03 John Levon <moz@compsoc.man.ac.uk>
* Makefile.am:
#include "debug.h"
#include "input_validators.h" // fl_unsigned_float_filter
#include "helper_funcs.h"
+#include "lyx_main.h" // for user_lyxdir
using Liason::setMinibuffer;
using SigC::slot;
}
+namespace {
+// should this go elsewhere? Maybe a ControllerDocument? (JMarc)
+/** Save the buffer's parameters as user default.
+ This function saves a file \c user_lyxdir/templates/defaults.lyx
+ which parameters are those of the current buffer. This file
+ is used as a default template when creating a new
+ file. Returns \c true on success.
+*/
+bool saveParamsAsDefault(BufferParams const ¶ms)
+{
+ if (!AskQuestion(_("Do you want to save the current settings"),
+ _("for document layout"),
+ _("as default for new documents?")))
+ return false;
+
+ string const fname = AddName(AddPath(user_lyxdir, "templates/"),
+ "defaults.lyx");
+ Buffer defaults = Buffer(fname);
+ defaults.params = params;
+
+ // add an empty paragraph. Is this enough?
+ defaults.paragraph = new Paragraph;
+
+ return defaults.writeFile(defaults.fileName(), false);
+}
+
+} //namespace
+
bool FormDocument::input( FL_OBJECT * ob, long data )
{
State cb = static_cast<State>( data );
}
if (ob == dialog_->button_save_defaults) {
- lv_->getLyXFunc()->dispatch(LFUN_LAYOUT_SAVE_DEFAULT);
+ BufferParams params;
+ class_apply(params);
+ paper_apply(params);
+ language_apply(params);
+ options_apply(params);
+ bullets_apply(params);
+ saveParamsAsDefault(params);
}
if (ob == dialog_->button_reset_defaults) {
void FormDocument::bullets_apply(BufferParams & params)
{
/* update the bullet settings */
- BufferParams & params_doc = lv_->buffer()->params;
+ BufferParams & buf_params = lv_->buffer()->params;
// a little bit of loop unrolling
- params.user_defined_bullets[0] = params_doc.temp_bullets[0];
- params.user_defined_bullets[1] = params_doc.temp_bullets[1];
- params.user_defined_bullets[2] = params_doc.temp_bullets[2];
- params.user_defined_bullets[3] = params_doc.temp_bullets[3];
+ params.user_defined_bullets[0] = buf_params.temp_bullets[0];
+ params.user_defined_bullets[1] = buf_params.temp_bullets[1];
+ params.user_defined_bullets[2] = buf_params.temp_bullets[2];
+ params.user_defined_bullets[3] = buf_params.temp_bullets[3];
}
}
-void MenuLayoutSave(BufferView * bv)
-{
- if (!bv->available())
- return;
-
- if (AskQuestion(_("Do you want to save the current settings"),
- _("for document layout"),
- _("as default for new documents?")))
- bv->buffer()->saveParamsAsDefaults();
-}
-
-
// This function runs "configure" and then rereads lyx.defaults to
// reconfigure the automatic settings.
void Reconfigure(BufferView * bv)
///
void MenuInsertLabel(BufferView * bv, string const & arg);
///
-void MenuLayoutSave(BufferView * bv);
-///
void Reconfigure(BufferView * bv);
#endif
owner->getDialogs()->showPreamble();
break;
- case LFUN_LAYOUT_SAVE_DEFAULT:
- MenuLayoutSave(owner->view());
- break;
-
case LFUN_DROP_LAYOUTS_CHOICE:
owner->getToolbar()->openLayoutList();
break;