1 /* This file is part of
2 * ======================================================
4 * LyX, The Document Processor
6 * Copyright 1995 Matthias Ettrich,
7 * Copyright 1995-2000 The LyX Team.
9 * ====================================================== */
17 #include FORMS_H_LOCATION
19 #include "layout_forms.h"
22 #include "insets/insetlabel.h"
23 #include "insets/figinset.h"
25 #include "minibuffer.h"
27 #include "bufferlist.h"
29 #include "lyx_gui_misc.h"
31 #include "lastfiles.h"
32 #include "bufferview_funcs.h"
33 #include "support/FileInfo.h"
34 #include "support/syscall.h"
35 #include "support/filetools.h"
36 #include "support/path.h"
42 using std::back_inserter;
46 using std::istream_iterator;
52 extern Combox * combo_language;
53 extern Combox * combo_language2;
54 extern BufferList bufferlist;
55 extern void show_symbols_form();
56 extern FD_form_title * fd_form_title;
57 extern FD_form_character * fd_form_character;
58 extern FD_form_preamble * fd_form_preamble;
59 extern FD_form_figure * fd_form_figure;
61 extern BufferView * current_view; // called too many times in this file...
63 extern void DeleteSimpleCutBuffer(); /* for the cleanup when exiting */
66 extern bool send_fax(string const & fname, string const & sendcmd);
69 extern void MenuSendto();
71 // this should be static, but I need it in buffer.C
72 bool quitting; // flag, that we are quitting the program
73 extern bool finished; // all cleanup done just let it run through now.
75 char ascii_type; /* for selection notify callbacks */
77 bool scrolling = false;
79 // This is used to make the dreaded font toggle problem hopefully go
80 // away. Definitely not the best solution, but I think it sorta works.
81 bool toggleall = true;
84 This is the inset locking stuff needed for mathed --------------------
86 an inset can simple call LockInset in it's edit call and *ONLY* in it's
88 Inset::Edit() can only be called by the main lyx module.
90 Then the inset may modify the menu's and/or iconbars.
92 Unlocking is either done by LyX or the inset itself with a UnlockInset-call
94 During the lock, all button and keyboard events will be modified
95 and send to the inset through the following inset-features. Note that
96 Inset::InsetUnlock will be called from inside UnlockInset. It is meant
97 to contain the code for restoring the menus and things like this.
100 virtual void InsetButtonPress(int x, int y, int button);
101 virtual void InsetButtonRelease(int x, int y, int button);
102 virtual void InsetKeyPress(XKeyEvent *ev);
103 virtual void InsetMotionNotify(int x, int y, int state);
104 virtual void InsetUnlock();
106 If a inset wishes any redraw and/or update it just has to call
108 It's is completly irrelevant, where the inset is. UpdateInset will
109 find it in any paragraph in any buffer.
110 Of course the_locking_inset and the insets in the current paragraph/buffer
111 are checked first, so no performance problem should occur.
113 Hope that's ok for the beginning, Alejandro,
114 sorry that I needed so much time,
119 //void UpdateInset(BufferView * bv, Inset * inset, bool mark_dirty = true);
121 /* these functions return 1 if an error occured,
123 // Now they work only for updatable insets. [Alejandro 080596]
124 //int LockInset(UpdatableInset * inset);
125 void ToggleLockedInsetCursor(int x, int y, int asc, int desc);
126 //void FitLockedInsetCursor(long x, long y, int asc, int desc);
127 //int UnlockInset(UpdatableInset * inset);
128 //void LockedInsetStoreUndo(Undo::undo_kind kind);
130 /* this is for asyncron updating. UpdateInsetUpdateList will be called
131 automatically from LyX. Just insert the Inset into the Updatelist */
132 //void UpdateInsetUpdateList();
133 //void PutInsetIntoInsetUpdateList(Inset * inset);
135 //InsetUpdateStruct * InsetUpdateList = 0;
139 -----------------------------------------------------------------------
143 void ShowMessage(Buffer const * buf,
146 string const & msg3, int delay)
149 buf->getUser()->owner()->getMiniBuffer()->Set(msg1, msg2,
152 lyxerr << msg1 << msg2 << msg3 << endl;
164 // should be moved to lyxfunc.C
165 bool MenuWrite(BufferView * bv, Buffer * buffer)
167 XFlush(fl_get_display());
168 if (!buffer->save()) {
169 string const fname = buffer->fileName();
170 string const s = MakeAbsPath(fname);
171 if (AskQuestion(_("Save failed. Rename and try again?"),
172 MakeDisplayPath(s, 50),
173 _("(If not, document is not saved.)"))) {
174 return MenuWriteAs(bv, buffer);
178 lastfiles->newFile(buffer->fileName());
184 // should be moved to BufferView.C
185 // Half of this func should be in LyXView, the rest in BufferView.
186 bool MenuWriteAs(BufferView * bv, Buffer * buffer)
188 // Why do we require BufferView::text to be able to write a
189 // document? I see no point in that. (Lgb)
190 //if (!bv->text) return;
192 string fname = buffer->fileName();
193 string oldname = fname;
197 fileDlg.SetButton(0, _("Documents"), lyxrc.document_path);
198 fileDlg.SetButton(1, _("Templates"), lyxrc.template_path);
200 if (!IsLyXFilename(fname))
203 fname = fileDlg.Select(_("Enter Filename to Save Document as"),
206 OnlyFilename(fname));
213 // Make sure the absolute filename ends with appropriate suffix
214 string s = MakeAbsPath(fname);
215 if (!IsLyXFilename(s))
218 // Same name as we have already?
219 if (!buffer->isUnnamed() && s == oldname) {
220 if (!AskQuestion(_("Same name as document already has:"),
221 MakeDisplayPath(s, 50),
224 // Falls through to name change and save
226 // No, but do we have another file with this name open?
227 else if (!buffer->isUnnamed() && bufferlist.exists(s)) {
228 if (AskQuestion(_("Another document with same name open!"),
229 MakeDisplayPath(s, 50),
230 _("Replace with current document?")))
232 bufferlist.close(bufferlist.getBuffer(s));
234 // Ok, change the name of the buffer, but don't save!
235 buffer->setFileName(s);
238 ShowMessage(buffer, _("Document renamed to '"),
239 MakeDisplayPath(s), _("', but not saved..."));
242 } // Check whether the file exists
244 FileInfo const myfile(s);
245 if (myfile.isOK() && !AskQuestion(_("Document already exists:"),
246 MakeDisplayPath(s, 50),
251 // Ok, change the name of the buffer
252 buffer->setFileName(s);
254 bool unnamed = buffer->isUnnamed();
255 buffer->setUnnamed(false);
257 // Small bug: If the save fails, we have irreversible changed the name
259 // Hope this is fixed this way! (Jug)
260 if (!MenuWrite(bv, buffer)) {
261 buffer->setFileName(oldname);
262 buffer->setUnnamed(unnamed);
263 ShowMessage(buffer, _("Document could not be saved!"),
264 _("Holding the old name."), MakeDisplayPath(oldname));
267 // now remove the oldname autosave file if existant!
268 removeAutosaveFile(oldname);
273 int MenuRunChktex(Buffer * buffer)
277 if (buffer->isSGML()) {
278 WriteAlert(_("Chktex does not work with SGML derived documents."));
281 ret = buffer->runChktex();
287 s = _("No warnings found.");
288 } else if (ret == 1) {
289 s = _("One warning found.");
290 t = _("Use 'Edit->Go to Error' to find it.");
293 s += _(" warnings found.");
294 t = _("Use 'Edit->Go to Error' to find them.");
296 WriteAlert(_("Chktex run successfully"), s, t);
298 WriteAlert(_("Error!"), _("It seems chktex does not work."));
305 void MenuFax(Buffer * buffer)
307 // Generate postscript file
308 if (!Exporter::Export(buffer, "ps", true))
312 string const ps = OnlyFilename(ChangeExtension(buffer->fileName(),
315 string path = OnlyPath (buffer->fileName());
316 if (lyxrc.use_tempdir || (IsDirWriteable(path) < 1)) {
317 path = buffer->tmppath;
320 if (!lyxrc.fax_program.empty()) {
321 string help2 = subst(lyxrc.fax_program, "$$FName", ps);
323 Systemcalls one(Systemcalls::System, help2);
325 send_fax(ps, lyxrc.fax_command);
332 lyxerr.debug() << "Running QuitLyX." << endl;
334 if (!bufferlist.QwriteAll())
337 lastfiles->writeFile(lyxrc.lastfiles);
339 // Set a flag that we do quitting from the program,
340 // so no refreshes are necessary.
343 // close buffers first
344 bufferlist.closeAll();
346 // do any other cleanup procedures now
347 lyxerr.debug() << "Deleting tmp dir " << system_tempdir << endl;
349 DestroyLyXTmpDir(system_tempdir);
356 void AutoSave(BufferView * bv)
357 // should probably be moved into BufferList (Lgb)
358 // Perfect target for a thread...
360 if (!bv->available())
363 if (bv->buffer()->isBakClean() || bv->buffer()->isReadonly()) {
364 // We don't save now, but we'll try again later
365 bv->owner()->resetAutosaveTimer();
369 bv->owner()->getMiniBuffer()->Set(_("Autosaving current document..."));
371 // create autosave filename
372 string fname = OnlyPath(bv->buffer()->fileName());
374 fname += OnlyFilename(bv->buffer()->fileName());
377 // tmp_ret will be located (usually) in /tmp
378 // will that be a problem?
379 pid_t const pid = fork(); // If you want to debug the autosave
380 // you should set pid to -1, and comment out the
382 if (pid == 0 || pid == -1) {
383 // pid = -1 signifies that lyx was unable
384 // to fork. But we will do the save
388 string const tmp_ret = lyx::tempName();
389 if (!tmp_ret.empty()) {
390 bv->buffer()->writeFile(tmp_ret, 1);
391 // assume successful write of tmp_ret
392 if (lyx::rename(tmp_ret, fname)) {
394 // most likely couldn't move between filesystems
395 // unless write of tmp_ret failed
396 // so remove tmp file (if it exists)
397 lyx::unlink(tmp_ret);
404 // failed to write/rename tmp_ret so try writing direct
405 if (!bv->buffer()->writeFile(fname, 1)) {
406 // It is dangerous to do this in the child,
407 // but safe in the parent, so...
409 bv->owner()->getMiniBuffer()->Set(_("Autosave Failed!"));
412 if (pid == 0) { // we are the child so...
417 bv->buffer()->markBakClean();
418 bv->owner()->resetAutosaveTimer();
423 // Copyright CHT Software Service GmbH
426 // create new file with template
429 Buffer * NewLyxFile(string const & filename)
431 // Split argument by :
433 string tmpname = split(filename, name, ':');
434 #ifdef __EMX__ // Fix me! lyx_cb.C may not be low level enough to allow this.
435 if (name.length() == 1
436 && isalpha(static_cast<unsigned char>(name[0]))
437 && (prefixIs(tmpname, "/") || prefixIs(tmpname, "\\"))) {
439 name += token(tmpname, ':', 0);
440 tmpname = split(tmpname, ':');
443 lyxerr.debug() << "Arg is " << filename
444 << "\nName is " << name
445 << "\nTemplate is " << tmpname << endl;
447 // find a free buffer
448 Buffer * tmpbuf = bufferlist.newFile(name, tmpname);
450 lastfiles->newFile(tmpbuf->fileName());
455 // Insert ascii file (if filename is empty, prompt for one)
456 void InsertAsciiFile(BufferView * bv, string const & f, bool asParagraph)
461 if (!bv->available()) return;
465 fname = fileDlg.Select(_("File to Insert"),
466 bv->owner()->buffer()->filepath,
469 if (fname.empty()) return;
474 if (!fi.readable()) {
475 WriteFSAlert(_("Error! Specified file is unreadable: "),
476 MakeDisplayPath(fname, 50));
480 ifstream ifs(fname.c_str());
482 WriteFSAlert(_("Error! Cannot open specified file: "),
483 MakeDisplayPath(fname, 50));
487 ifs.unsetf(ios::skipws);
488 istream_iterator<char> ii(ifs);
489 istream_iterator<char> end;
490 #if !defined(USE_INCLUDED_STRING) && !defined(STD_STRING_IS_GOOD)
491 // We use this until the compilers get better...
493 copy(ii, end, back_inserter(tmp));
494 string const tmpstr(tmp.begin(), tmp.end());
496 // This is what we want to use and what we will use once the
497 // compilers get good enough.
498 //string tmpstr(ii, end); // yet a reason for using std::string
499 // alternate approach to get the file into a string:
501 copy(ii, end, back_inserter(tmpstr));
506 // clear the selection
509 bv->text->InsertStringA(bv, tmpstr);
511 bv->text->InsertStringB(bv, tmpstr);
512 bv->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
516 void MenuInsertLabel(BufferView * bv, string const & arg)
522 result = askForText(_("Enter new label to insert:"));
524 label = frontStrip(strip(result.second));
527 if (!label.empty()) {
528 InsetCommandParams p( "label", label );
529 InsetLabel * inset = new InsetLabel( p );
530 bv->insertInset( inset );
536 // This is _only_ used in Toolbar_pimpl.C, move it there and get rid of
537 // current_view. (Lgb)
538 void LayoutsCB(int sel, void *, Combox *)
540 string const tmp = tostr(sel);
541 current_view->owner()->getLyXFunc()->Dispatch(LFUN_LAYOUTNO,
546 void MenuLayoutCharacter()
548 static int ow = -1, oh;
550 if (fd_form_character->form_character->visible) {
551 fl_raise_form(fd_form_character->form_character);
553 fl_show_form(fd_form_character->form_character,
554 FL_PLACE_MOUSE | FL_FREE_SIZE, FL_TRANSIENT,
555 _("Character Style"));
557 ow = fd_form_character->form_character->w;
558 oh = fd_form_character->form_character->h;
560 fl_set_form_minsize(fd_form_character->form_character, ow, oh);
565 bool UpdateLayoutPreamble(BufferView * bv)
568 if (!bv->available())
572 fl_set_input(fd_form_preamble->input_preamble,
573 bv->buffer()->params.preamble.c_str());
575 if (bv->buffer()->isReadonly()) {
576 fl_deactivate_object(fd_form_preamble->input_preamble);
577 fl_deactivate_object(fd_form_preamble->button_ok);
578 fl_deactivate_object(fd_form_preamble->button_apply);
579 fl_set_object_lcol(fd_form_preamble->button_ok, FL_INACTIVE);
580 fl_set_object_lcol(fd_form_preamble->button_apply, FL_INACTIVE);
582 fl_activate_object(fd_form_preamble->input_preamble);
583 fl_activate_object(fd_form_preamble->button_ok);
584 fl_activate_object(fd_form_preamble->button_apply);
585 fl_set_object_lcol(fd_form_preamble->button_ok, FL_BLACK);
586 fl_set_object_lcol(fd_form_preamble->button_apply, FL_BLACK);
588 } else if (fd_form_preamble->form_preamble->visible) {
589 fl_hide_form(fd_form_preamble->form_preamble);
595 void MenuLayoutPreamble()
597 static int ow = -1, oh;
599 if (UpdateLayoutPreamble(current_view)) {
600 if (fd_form_preamble->form_preamble->visible) {
601 fl_raise_form(fd_form_preamble->form_preamble);
603 fl_show_form(fd_form_preamble->form_preamble,
604 FL_PLACE_MOUSE | FL_FREE_SIZE,
606 _("LaTeX Preamble"));
608 ow = fd_form_preamble->form_preamble->w;
609 oh = fd_form_preamble->form_preamble->h;
611 fl_set_form_minsize(fd_form_preamble->form_preamble,
618 void MenuLayoutSave(BufferView * bv)
620 if (!bv->available())
623 if (AskQuestion(_("Do you want to save the current settings"),
624 _("for Character, Document, Paper and Quotes"),
625 _("as default for new documents?")))
626 bv->buffer()->saveParamsAsDefaults();
630 // This is both GUI and LyXFont dependent. Don't know where to put it. (Asger)
631 // Well, it's mostly GUI dependent, so I guess it will stay here. (Asger)
632 LyXFont const UserFreeFont(BufferParams const & params)
634 LyXFont font(LyXFont::ALL_IGNORE);
636 int pos = fl_get_choice(fd_form_character->choice_family);
638 case 1: font.setFamily(LyXFont::IGNORE_FAMILY); break;
639 case 2: font.setFamily(LyXFont::ROMAN_FAMILY); break;
640 case 3: font.setFamily(LyXFont::SANS_FAMILY); break;
641 case 4: font.setFamily(LyXFont::TYPEWRITER_FAMILY); break;
642 case 5: font.setFamily(LyXFont::INHERIT_FAMILY); break;
645 pos = fl_get_choice(fd_form_character->choice_series);
647 case 1: font.setSeries(LyXFont::IGNORE_SERIES); break;
648 case 2: font.setSeries(LyXFont::MEDIUM_SERIES); break;
649 case 3: font.setSeries(LyXFont::BOLD_SERIES); break;
650 case 4: font.setSeries(LyXFont::INHERIT_SERIES); break;
653 pos = fl_get_choice(fd_form_character->choice_shape);
655 case 1: font.setShape(LyXFont::IGNORE_SHAPE); break;
656 case 2: font.setShape(LyXFont::UP_SHAPE); break;
657 case 3: font.setShape(LyXFont::ITALIC_SHAPE); break;
658 case 4: font.setShape(LyXFont::SLANTED_SHAPE); break;
659 case 5: font.setShape(LyXFont::SMALLCAPS_SHAPE); break;
660 case 6: font.setShape(LyXFont::INHERIT_SHAPE); break;
663 pos = fl_get_choice(fd_form_character->choice_size);
665 case 1: font.setSize(LyXFont::IGNORE_SIZE); break;
666 case 2: font.setSize(LyXFont::SIZE_TINY); break;
667 case 3: font.setSize(LyXFont::SIZE_SCRIPT); break;
668 case 4: font.setSize(LyXFont::SIZE_FOOTNOTE); break;
669 case 5: font.setSize(LyXFont::SIZE_SMALL); break;
670 case 6: font.setSize(LyXFont::SIZE_NORMAL); break;
671 case 7: font.setSize(LyXFont::SIZE_LARGE); break;
672 case 8: font.setSize(LyXFont::SIZE_LARGER); break;
673 case 9: font.setSize(LyXFont::SIZE_LARGEST); break;
674 case 10: font.setSize(LyXFont::SIZE_HUGE); break;
675 case 11: font.setSize(LyXFont::SIZE_HUGER); break;
676 case 12: font.setSize(LyXFont::INCREASE_SIZE); break;
677 case 13: font.setSize(LyXFont::DECREASE_SIZE); break;
678 case 14: font.setSize(LyXFont::INHERIT_SIZE); break;
681 pos = fl_get_choice(fd_form_character->choice_bar);
683 case 1: font.setEmph(LyXFont::IGNORE);
684 font.setUnderbar(LyXFont::IGNORE);
685 font.setNoun(LyXFont::IGNORE);
686 font.setLatex(LyXFont::IGNORE);
688 case 2: font.setEmph(LyXFont::TOGGLE); break;
689 case 3: font.setUnderbar(LyXFont::TOGGLE); break;
690 case 4: font.setNoun(LyXFont::TOGGLE); break;
691 case 5: font.setLatex(LyXFont::TOGGLE); break;
692 case 6: font.setEmph(LyXFont::INHERIT);
693 font.setUnderbar(LyXFont::INHERIT);
694 font.setNoun(LyXFont::INHERIT);
695 font.setLatex(LyXFont::INHERIT);
699 pos = fl_get_choice(fd_form_character->choice_color);
701 case 1: font.setColor(LColor::ignore); break;
702 case 2: font.setColor(LColor::none); break;
703 case 3: font.setColor(LColor::black); break;
704 case 4: font.setColor(LColor::white); break;
705 case 5: font.setColor(LColor::red); break;
706 case 6: font.setColor(LColor::green); break;
707 case 7: font.setColor(LColor::blue); break;
708 case 8: font.setColor(LColor::cyan); break;
709 case 9: font.setColor(LColor::magenta); break;
710 case 10: font.setColor(LColor::yellow); break;
711 case 11: font.setColor(LColor::inherit); break;
714 int const choice = combo_language2->get();
716 font.setLanguage(ignore_language);
717 else if (choice == 2)
718 font.setLanguage(params.language);
720 font.setLanguage(languages.getLanguage(combo_language2->getline()));
726 /* callbacks for form form_title */
728 void TimerCB(FL_OBJECT *, long)
730 // only if the form still exists
731 if (lyxrc.show_banner
733 && fd_form_title->form_title) {
734 if (fd_form_title->form_title->visible) {
735 fl_hide_form(fd_form_title->form_title);
737 fl_free_form(fd_form_title->form_title);
738 fd_form_title->form_title = 0;
743 /* callbacks for form form_character */
746 void CharacterApplyCB(FL_OBJECT *, long)
748 // we set toggleall locally here, since it should be true for
749 // all other uses of ToggleAndShow() (JMarc)
750 toggleall = fl_get_button(fd_form_character->check_toggle_all);
751 ToggleAndShow(current_view, UserFreeFont(current_view->buffer()->params));
752 current_view->setState();
758 void CharacterCloseCB(FL_OBJECT *, long)
760 fl_hide_form(fd_form_character->form_character);
765 void CharacterOKCB(FL_OBJECT * ob, long data)
767 CharacterApplyCB(ob, data);
768 CharacterCloseCB(ob, data);
772 /* callbacks for form form_preamble */
775 void PreambleCancelCB(FL_OBJECT *, long)
777 fl_hide_form(fd_form_preamble->form_preamble);
782 void PreambleApplyCB(FL_OBJECT *, long)
784 if (!current_view->available())
787 current_view->buffer()->params.preamble =
788 fl_get_input(fd_form_preamble->input_preamble);
789 current_view->buffer()->markDirty();
790 current_view->owner()->getMiniBuffer()->Set(_("LaTeX preamble set"));
795 void PreambleOKCB(FL_OBJECT * ob, long data)
797 PreambleApplyCB(ob, data);
798 PreambleCancelCB(ob, data);
804 if (fd_form_figure->form_figure->visible) {
805 fl_raise_form(fd_form_figure->form_figure);
807 fl_show_form(fd_form_figure->form_figure,
808 FL_PLACE_MOUSE | FL_FREE_SIZE, FL_TRANSIENT,
814 /* callbacks for form form_figure */
816 void FigureApplyCB(FL_OBJECT *, long)
818 if (!current_view->available())
821 Buffer * buffer = current_view->buffer();
822 if (buffer->isReadonly()) // paranoia
825 current_view->owner()->getMiniBuffer()->Set(_("Inserting figure..."));
826 if (fl_get_button(fd_form_figure->radio_inline)) {
827 InsetFig * new_inset = new InsetFig(100, 20, *buffer);
828 current_view->insertInset(new_inset);
829 current_view->owner()->getMiniBuffer()->Set(_("Figure inserted"));
830 new_inset->Edit(current_view, 0, 0, 0);
834 current_view->hideCursor();
835 current_view->update(BufferView::SELECT|BufferView::FITCUR);
836 current_view->beforeChange();
838 current_view->text->SetCursorParUndo(current_view->buffer());
839 current_view->text->FreezeUndo();
841 current_view->text->BreakParagraph(current_view);
842 current_view->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
844 if (current_view->text->cursor.par()->Last()) {
845 current_view->text->CursorLeft(current_view);
847 current_view->text->BreakParagraph(current_view);
848 current_view->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
851 // The standard layout should always be numer 0;
852 current_view->text->SetLayout(current_view, 0);
855 if (current_view->text->cursor.par()->footnoteflag ==
856 LyXParagraph::NO_FOOTNOTE) {
859 SetParagraph(current_view, 0, 0,
861 VSpace (0.3 * buffer->params.spacing.getValue(),
864 buffer->params.spacing.getValue(),
866 LYX_ALIGN_CENTER, string(), 0);
869 current_view->text->SetParagraph(current_view, 0, 0,
871 VSpace(VSpace::NONE),
872 VSpace(VSpace::NONE),
879 current_view->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
881 Inset * new_inset = new InsetFig(100, 100, *buffer);
882 current_view->insertInset(new_inset);
883 new_inset->Edit(current_view, 0, 0, 0);
884 current_view->update(BufferView::SELECT|BufferView::FITCUR);
885 current_view->owner()->getMiniBuffer()->Set(_("Figure inserted"));
886 current_view->text->UnFreezeUndo();
887 current_view->setState();
891 extern "C" void FigureCancelCB(FL_OBJECT *, long)
893 fl_hide_form(fd_form_figure->form_figure);
897 extern "C" void FigureOKCB(FL_OBJECT * ob, long data)
899 FigureApplyCB(ob, data);
900 FigureCancelCB(ob, data);
904 // This function runs "configure" and then rereads lyx.defaults to
905 // reconfigure the automatic settings.
906 void Reconfigure(BufferView * bv)
908 bv->owner()->getMiniBuffer()->Set(_("Running configure..."));
910 // Run configure in user lyx directory
912 Systemcalls one(Systemcalls::System,
913 AddName(system_lyxdir, "configure"));
915 bv->owner()->getMiniBuffer()->Set(_("Reloading configuration..."));
916 lyxrc.read(LibFileSearch(string(), "lyxrc.defaults"));
917 WriteAlert(_("The system has been reconfigured."),
918 _("You need to restart LyX to make use of any"),
919 _("updated document class specifications."));