controller-view split for TOC popup.

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@1863 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Angus Leeming 2001-03-30 19:24:28 +00:00
parent a6adf5d732
commit 071d35750a
17 changed files with 299 additions and 214 deletions

View File

@ -1,3 +1,8 @@
2001-03-30 Angus Leeming <a.leeming@ic.ac.uk>
* lyxfunc.C (Dispatch): prevent crash in LFUN_GOTO_PARAGRAPH when
the LyXParagraph * is 0.
2001-03-29 Juergen Vigna <jug@sad.it> 2001-03-29 Juergen Vigna <jug@sad.it>
* vspace.C: added support for %, c%, p%, l%. * vspace.C: added support for %, c%, p%, l%.

View File

@ -1,3 +1,10 @@
2001-03-30 Angus Leeming <a.leeming@ic.ac.uk>
* ControlToc.[Ch]: new files; a controller for the TOC popup.
* GUI.h:
* Makefile.am: associated changes with all of the above.
2001-03-30 Angus Leeming <a.leeming@ic.ac.uk> 2001-03-30 Angus Leeming <a.leeming@ic.ac.uk>
* ControlExternal.C: bug fixes. Can now apply changes to the inset * ControlExternal.C: bug fixes. Can now apply changes to the inset

View File

@ -0,0 +1,113 @@
/* This file is part of
* ======================================================
*
* LyX, The Document Processor
*
* Copyright 2001 The LyX Team.
*
* ======================================================
*
* \file ControlToc.C
* \author Angus Leeming <a.leeming@ic.ac.uk>
*/
#include <config.h>
#ifdef __GNUG__
#pragma implementation
#endif
#include "ControlToc.h"
#include "buffer.h"
#include "Dialogs.h"
#include "LyXView.h"
#include "lyxfunc.h"
#include "support/lstrings.h" // tostr
using std::vector;
using SigC::slot;
ControlToc::ControlToc(LyXView & lv, Dialogs & d)
: ControlCommand(lv, d, LFUN_TOC_INSERT)
{
d_.showTOC.connect(slot(this, &ControlToc::showInset));
d_.createTOC.connect(slot(this, &ControlToc::createInset));
}
void ControlToc::Goto(int const & id) const
{
string const tmp = tostr(id);
lv_.getLyXFunc()->Dispatch(LFUN_GOTO_PARAGRAPH, tmp);
}
vector<string> const ControlToc::getTypes() const
{
vector<string> types;
Buffer::Lists const tmp = lv_.view()->buffer()->getLists();
Buffer::Lists::const_iterator cit = tmp.begin();
Buffer::Lists::const_iterator end = tmp.end();
for (; cit != end; ++cit) {
types.push_back(cit->first.c_str());
}
return types;
}
Buffer::SingleList const ControlToc::getContents(string const & type) const
{
Buffer::SingleList contents;
Buffer::TocItem noContent(0, 0, string());
// This shouldn't be possible...
if (!lv_.view()->available()) {
noContent.str = _("*** No Document ***");
contents.push_back(noContent);
return contents;
}
Buffer::Lists tmp = lv_.view()->buffer()->getLists();
Buffer::Lists::iterator it = tmp.find(type);
if (it == tmp.end()) {
noContent.str = _("*** No Lists ***");
contents.push_back(noContent);
return contents;
}
return it->second;
}
namespace toc
{
string getType(string const & cmdName)
{
string type;
// It would be nice to have a map to extract this info.
// Does one already exist, Lars?
if (cmdName == "tableofcontents" )
type = "TOC";
else if (cmdName == "listofalgorithms" )
type = "algorithm";
else if (cmdName == "listoffigures" )
type = "figure";
else
type = "table";
return type;
}
} // namespace toc

View File

@ -0,0 +1,50 @@
/* This file is part of
* ======================================================
*
* LyX, The Document Processor
*
* Copyright 2001 The LyX Team.
*
* ======================================================
*
* \file ControlToc.h
* \author Angus Leeming <a.leeming@ic.ac.uk>
*/
#ifndef CONTROLTOC_H
#define CONTROLTOC_H
#ifdef __GNUG__
#pragma interface
#endif
#include "ControlCommand.h"
#include "buffer.h" // Buffer::SingleList
/** A controller for TOC dialogs.
*/
class ControlToc : public ControlCommand
{
public:
///
ControlToc(LyXView &, Dialogs &);
/// Goto this paragraph id
void Goto(int const & id) const;
/// Returns a vector of list types in the document
std::vector<string> const getTypes() const;
/// Given a type, returns the contents
Buffer::SingleList const getContents(string const & type) const;
};
namespace toc
{
/** Given the cmdName of the TOC param, returns the type used
by ControlToc::getContents() */
string getType(string const & cmdName);
} // namespace toc
#endif // CONTROLTOC_H

View File

@ -294,6 +294,20 @@ public:
}; };
/** Specialization for Toc dialog
*/
class ControlToc;
template <class GUIview, class GUIbc>
class GUIToc :
public GUI<ControlToc, GUIview, OkCancelPolicy, GUIbc> {
public:
///
GUIToc(LyXView & lv, Dialogs & d)
: GUI<ControlToc, GUIview, OkCancelPolicy, GUIbc>(lv, d) {}
};
/** Specialization for TabularCreate dialog /** Specialization for TabularCreate dialog
*/ */
class ControlTabularCreate; class ControlTabularCreate;

View File

@ -65,6 +65,8 @@ libcontrollers_la_SOURCES=\
ControlSplash.h \ ControlSplash.h \
ControlTabularCreate.C \ ControlTabularCreate.C \
ControlTabularCreate.h \ ControlTabularCreate.h \
ControlToc.C \
ControlToc.h \
ControlUrl.C \ ControlUrl.C \
ControlUrl.h \ ControlUrl.h \
ControlVCLog.C \ ControlVCLog.C \

View File

@ -1,3 +1,12 @@
2001-03-30 Angus Leeming <a.leeming@ic.ac.uk>
* FormMathsPanel.C (c-tor): set button controller cancel label to close.
* FormToc.[Ch]:
* forms/form_toc.fd: implemented controller-view split.
* Dialogs.C: associated changes.
2001-03-30 Angus Leeming <a.leeming@ic.ac.uk> 2001-03-30 Angus Leeming <a.leeming@ic.ac.uk>
* FormCitation.C: * FormCitation.C:

View File

@ -38,6 +38,7 @@
#include "ControlSearch.h" #include "ControlSearch.h"
#include "ControlSplash.h" #include "ControlSplash.h"
#include "ControlTabularCreate.h" #include "ControlTabularCreate.h"
#include "ControlToc.h"
#include "ControlUrl.h" #include "ControlUrl.h"
#include "ControlVCLog.h" #include "ControlVCLog.h"
@ -63,6 +64,7 @@
#include "form_search.h" #include "form_search.h"
#include "form_splash.h" #include "form_splash.h"
#include "form_tabular_create.h" #include "form_tabular_create.h"
#include "form_toc.h"
#include "form_url.h" #include "form_url.h"
#include "FormBibitem.h" #include "FormBibitem.h"
@ -84,6 +86,7 @@
#include "FormSearch.h" #include "FormSearch.h"
#include "FormSplash.h" #include "FormSplash.h"
#include "FormTabularCreate.h" #include "FormTabularCreate.h"
#include "FormToc.h"
#include "FormUrl.h" #include "FormUrl.h"
#include "FormVCLog.h" #include "FormVCLog.h"
@ -92,7 +95,6 @@
#include "FormParagraph.h" #include "FormParagraph.h"
#include "FormPreferences.h" #include "FormPreferences.h"
#include "FormTabular.h" #include "FormTabular.h"
#include "FormToc.h"
// Signal enabling all visible popups to be redrawn if so desired. // Signal enabling all visible popups to be redrawn if so desired.
// E.g., when the GUI colours have been remapped. // E.g., when the GUI colours have been remapped.
@ -120,6 +122,7 @@ Dialogs::Dialogs(LyXView * lv)
add(new GUIRef<FormRef, xformsBC>(*lv, *this)); add(new GUIRef<FormRef, xformsBC>(*lv, *this));
add(new GUISearch<FormSearch, xformsBC>(*lv, *this)); add(new GUISearch<FormSearch, xformsBC>(*lv, *this));
add(new GUITabularCreate<FormTabularCreate, xformsBC>(*lv, *this)); add(new GUITabularCreate<FormTabularCreate, xformsBC>(*lv, *this));
add(new GUIToc<FormToc, xformsBC>(*lv, *this));
add(new GUIUrl<FormUrl, xformsBC>(*lv, *this)); add(new GUIUrl<FormUrl, xformsBC>(*lv, *this));
add(new GUIVCLog<FormVCLog, xformsBC>(*lv, *this)); add(new GUIVCLog<FormVCLog, xformsBC>(*lv, *this));
@ -128,7 +131,6 @@ Dialogs::Dialogs(LyXView * lv)
add(new FormParagraph(lv, this)); add(new FormParagraph(lv, this));
add(new FormPreferences(lv, this)); add(new FormPreferences(lv, this));
add(new FormTabular(lv, this)); add(new FormTabular(lv, this));
add(new FormToc(lv, this));
// reduce the number of connections needed in // reduce the number of connections needed in
// dialogs by a simple connection here. // dialogs by a simple connection here.

View File

@ -3,7 +3,7 @@
* *
* LyX, The Document Processor * LyX, The Document Processor
* *
* Copyright 2000 The LyX Team. * Copyright 2000-2001 The LyX Team.
* *
* ====================================================== * ======================================================
* *

View File

@ -1,13 +1,13 @@
// -*- C++ -*-
/* This file is part of /* This file is part of
* ====================================================== * ======================================================
* *
* LyX, The Document Processor * LyX, The Document Processor
* *
* Copyright 2000 The LyX Team. * Copyright 2000-2001 The LyX Team.
* *
* ====================================================== * ======================================================
* *
* \file FormCitation.h
* \author Angus Leeming <a.leeming@ic.ac.uk> * \author Angus Leeming <a.leeming@ic.ac.uk>
*/ */

View File

@ -55,7 +55,7 @@ using SigC::slot;
FormMathsPanel::FormMathsPanel(LyXView * lv, Dialogs * d) FormMathsPanel::FormMathsPanel(LyXView * lv, Dialogs * d)
: FormBaseBD(lv, d, _("Maths Panel")), : FormBaseBD(lv, d, _("Maths Panel")),
active_(0) active_(0), bc_("Close")
{ {
deco_.reset( new FormMathsDeco( lv, d, *this)); deco_.reset( new FormMathsDeco( lv, d, *this));
delim_.reset( new FormMathsDelim( lv, d, *this)); delim_.reset( new FormMathsDelim( lv, d, *this));
@ -263,7 +263,7 @@ void FormMathsPanel::mathDisplay() const
FormMathsSub::FormMathsSub(LyXView * lv, Dialogs * d, FormMathsPanel const & p, FormMathsSub::FormMathsSub(LyXView * lv, Dialogs * d, FormMathsPanel const & p,
string const & t) string const & t)
: FormBaseBD(lv, d, t), parent_(p) : FormBaseBD(lv, d, t), parent_(p), bc_("Close")
{} {}

View File

@ -1,81 +1,45 @@
// -*- C++ -*-
/* This file is part of /* This file is part of
* ====================================================== * ======================================================
* *
* LyX, The Document Processor * LyX, The Document Processor
* *
* Copyright 2000 The LyX Team. * Copyright 2000-2001 The LyX Team.
* *
* ====================================================== * ======================================================
*
* \file FormToc.C
* \author Angus Leeming, a.leeming@ic.ac.uk
*/ */
#include <config.h> #include <config.h>
#include <vector> #include <vector>
#include FORMS_H_LOCATION
#ifdef __GNUG__ #ifdef __GNUG__
#pragma implementation #pragma implementation
#endif #endif
#include "xformsBC.h"
#include "Dialogs.h" #include "ControlToc.h"
#include "FormToc.h" #include "FormToc.h"
#include "LyXView.h"
#include "form_toc.h" #include "form_toc.h"
#include "lyxtext.h" #include "helper_funcs.h" // getStringFromVector
#include "lyxfunc.h" #include "support/lstrings.h" // frontStrip, strip
#include "support/lstrings.h"
using std::vector;
using SigC::slot;
// The current code uses the apply() for handling the Update button and the
// type-of-table selection and cancel() for the close button. This is a little
// confusing to the button controller so I've made an IgnorantPolicy to cover
// this situation since the dialog doesn't care about buttons. ARRae 20001013
FormToc::FormToc(LyXView * lv, Dialogs * d)
: FormCommand(lv, d, _("Table of Contents")),
dialog_(0)
{
// let the dialog be shown
// These are permanent connections so we won't bother
// storing a copy because we won't be disconnecting.
d->showTOC.connect(slot(this, &FormToc::showInset));
d->createTOC.connect(slot(this, &FormToc::createInset));
}
FL_FORM * FormToc::form() const typedef FormCB<ControlToc, FormDB<FD_form_toc> > base_class;
{
if (dialog_.get())
return dialog_->form;
return 0;
}
FormToc::FormToc(ControlToc & c)
void FormToc::disconnect() : base_class(c, _("Table of Contents"))
{ {}
toclist.clear();
FormCommand::disconnect();
}
void FormToc::build() void FormToc::build()
{ {
dialog_.reset(build_toc()); dialog_.reset(build_toc());
#if 0 string const choice =
fl_addto_choice(dialog_->choice_toc_type, " " + getStringFromVector(controller().getTypes(), " | ") + " ";
_(" TOC | LOF | LOT | LOA ")); fl_addto_choice(dialog_->choice_toc_type, choice.c_str());
#else
Buffer::Lists const tmp = lv_->view()->buffer()->getLists();
Buffer::Lists::const_iterator cit = tmp.begin();
Buffer::Lists::const_iterator end = tmp.end();
for (; cit != end; ++cit) {
fl_addto_choice(dialog_->choice_toc_type, cit->first.c_str());
}
#endif
// Manage the cancel/close button // Manage the cancel/close button
bc().setCancel(dialog_->button_cancel); bc().setCancel(dialog_->button_cancel);
@ -85,122 +49,65 @@ void FormToc::build()
void FormToc::update() void FormToc::update()
{ {
#if 0 updateType();
Buffer::TocType type; updateContents();
if (params.getCmdName() == "tableofcontents" )
type = Buffer::TOC_TOC;
else if (params.getCmdName() == "listofalgorithms" )
type = Buffer::TOC_LOA;
else if (params.getCmdName() == "listoffigures" )
type = Buffer::TOC_LOF;
else
type = Buffer::TOC_LOT;
fl_set_choice( dialog_->choice_toc_type, type+1 );
#else
#warning Reimplement (Lgb)
#endif
updateToc();
} }
void FormToc::updateToc() ButtonPolicy::SMInput FormToc::input(FL_OBJECT *, long)
{ {
#if 0 updateContents();
if (!lv_->view()->available()) {
toclist.clear(); unsigned int const choice = fl_get_browser( dialog_->browser_toc );
fl_clear_browser( dialog_->browser_toc ); if (0 < choice && choice - 1 < toclist_.size()) {
fl_add_browser_line( dialog_->browser_toc, controller().Goto(toclist_[choice-1].par->id());
_("*** No Document ***"));
return;
} }
vector<vector<Buffer::TocItem> > tmp = return ButtonPolicy::SMI_VALID;
lv_->view()->buffer()->getTocList(); }
int type = fl_get_choice( dialog_->choice_toc_type ) - 1;
// Check if all elements are the same.
if (toclist.size() == tmp[type].size()) { void FormToc::updateType()
unsigned int i = 0; {
for (; i < toclist.size(); ++i) { string const type = toc::getType(controller().params().getCmdName());
if (toclist[i] != tmp[type][i])
fl_set_choice(dialog_->choice_toc_type, 1);
for (int i = 1;
i <= fl_get_choice_maxitems(dialog_->choice_toc_type); ++i) {
string const choice =
fl_get_choice_item_text(dialog_->choice_toc_type, i);
if (choice == type) {
fl_set_choice(dialog_->choice_toc_type, i);
break; break;
} }
if (i >= toclist.size()) return;
} }
}
// List has changed. Update browser
toclist = tmp[type];
static Buffer * buffer = 0; void FormToc::updateContents()
int topline = 0; {
int line = 0;
if (buffer == lv_->view()->buffer()) {
topline = fl_get_browser_topline( dialog_->browser_toc );
line = fl_get_browser( dialog_->browser_toc );
} else
buffer = lv_->view()->buffer();
fl_clear_browser( dialog_->browser_toc );
for (vector<Buffer::TocItem>::const_iterator it = toclist.begin();
it != toclist.end(); ++it)
fl_add_browser_line( dialog_->browser_toc,
(string(4 * (*it).depth, ' ')
+ (*it).str).c_str());
fl_set_browser_topline( dialog_->browser_toc, topline );
fl_select_browser_line( dialog_->browser_toc, line );
#else
#warning Fix Me! (Lgb)
if (!lv_->view()->available()) {
toclist.clear();
fl_clear_browser( dialog_->browser_toc );
fl_add_browser_line( dialog_->browser_toc,
_("*** No Document ***"));
return;
}
Buffer::Lists tmp = lv_->view()->buffer()->getLists();
string const type = string const type =
fl_get_choice_item_text(dialog_->choice_toc_type, frontStrip(strip(fl_get_choice_text(dialog_->choice_toc_type)));
fl_get_choice(dialog_->choice_toc_type));
Buffer::Lists::iterator it = tmp.find(type); Buffer::SingleList const contents = controller().getContents(type);
if (it != tmp.end()) {
// Check if all elements are the same. // Check if all elements are the same.
if (toclist == it->second) { if (toclist_ == contents) {
return;
}
} else if (it == tmp.end()) {
toclist.clear();
fl_clear_browser(dialog_->browser_toc);
fl_add_browser_line(dialog_->browser_toc,
_("*** No Lists ***"));
return; return;
} }
// List has changed. Update browser // List has changed. Update browser
toclist = it->second; toclist_ = contents;
static Buffer * buffer = 0; unsigned int const topline =
int topline = 0; fl_get_browser_topline(dialog_->browser_toc);
int line = 0; unsigned int const line = fl_get_browser(dialog_->browser_toc);
if (buffer == lv_->view()->buffer()) {
topline = fl_get_browser_topline(dialog_->browser_toc);
line = fl_get_browser( dialog_->browser_toc );
} else
buffer = lv_->view()->buffer();
fl_clear_browser(dialog_->browser_toc); fl_clear_browser( dialog_->browser_toc );
Buffer::SingleList::const_iterator cit = toclist.begin(); Buffer::SingleList::const_iterator cit = toclist_.begin();
Buffer::SingleList::const_iterator end = toclist.end(); Buffer::SingleList::const_iterator end = toclist_.end();
for (; cit != end; ++cit) { for (; cit != end; ++cit) {
string const line = string(4 * cit->depth, ' ') + cit->str; string const line = string(4 * cit->depth, ' ') + cit->str;
@ -209,19 +116,4 @@ void FormToc::updateToc()
fl_set_browser_topline(dialog_->browser_toc, topline); fl_set_browser_topline(dialog_->browser_toc, topline);
fl_select_browser_line(dialog_->browser_toc, line); fl_select_browser_line(dialog_->browser_toc, line);
#endif
}
bool FormToc::input(FL_OBJECT *, long)
{
updateToc();
unsigned int const choice = fl_get_browser( dialog_->browser_toc );
if (0 < choice && choice - 1 < toclist.size()) {
string const tmp = tostr(toclist[choice-1].par->id());
lv_->getLyXFunc()->Dispatch(LFUN_GOTO_PARAGRAPH, tmp);
}
return true;
} }

View File

@ -1,67 +1,56 @@
// -*- C++ -*-
/* This file is part of /* This file is part of
* ====================================================== * ======================================================
* *
* LyX, The Document Processor * LyX, The Document Processor
* *
* Copyright 2000 The LyX Team. * Copyright 2000-2001 The LyX Team.
* *
* ====================================================== * ======================================================
*
* \file FormToc.h
* \author Angus Leeming <a.leeming@ic.ac.uk>
*/ */
#ifndef FORMTOC_H #ifndef FORMTOC_H
#define FORMTOC_H #define FORMTOC_H
#include <boost/smart_ptr.hpp>
#ifdef __GNUG__ #ifdef __GNUG__
#pragma interface #pragma interface
#endif #endif
#include "FormInset.h" #include "FormBase.h"
#include "buffer.h" #include "buffer.h"
class ControlToc;
struct FD_form_toc; struct FD_form_toc;
/** This class provides an XForms implementation of the FormToc Dialog. /** This class provides an XForms implementation of the FormToc Dialog.
*/ */
class FormToc : public FormCommand { class FormToc : public FormCB<ControlToc, FormDB<FD_form_toc> > {
public: public:
/// ///
FormToc(LyXView *, Dialogs *); FormToc(ControlToc &);
private:
/// Pointer to the actual instantiation of the ButtonController.
virtual xformsBC & bc();
/// Disconnect signals. Also perform any necessary housekeeping.
virtual void disconnect();
private:
/// not needed
virtual void apply() {}
/// Build the dialog /// Build the dialog
virtual void build(); virtual void build();
/// bool indicates if a buffer switch took place
virtual void updateSlot(bool) { update(); }
/// Update dialog before showing it /// Update dialog before showing it
virtual void update(); virtual void update();
/// Filter the inputs on callback from xforms /// Filter the inputs on callback from xforms
virtual bool input( FL_OBJECT *, long); virtual ButtonPolicy::SMInput input(FL_OBJECT *, long);
/// Pointer to the actual instantiation of the xforms form
virtual FL_FORM * form() const;
/// ///
void updateToc(); void updateType();
/// ///
void updateContents();
/// Fdesign generated method
FD_form_toc * build_toc(); FD_form_toc * build_toc();
/// ///
Buffer::SingleList toclist; Buffer::SingleList toclist_;
/// Real GUI implementation.
boost::scoped_ptr<FD_form_toc> dialog_;
/// The ButtonController
ButtonController<OkCancelPolicy, xformsBC> bc_;
}; };
#endif // FORMTOC_H
inline
xformsBC & FormToc::bc()
{
return bc_;
}
#endif

View File

@ -27,7 +27,7 @@ FD_form_toc * FormToc::build_toc()
obj = fl_add_box(FL_UP_BOX, 0, 0, 420, 340, ""); obj = fl_add_box(FL_UP_BOX, 0, 0, 420, 340, "");
fdui->browser_toc = obj = fl_add_browser(FL_HOLD_BROWSER, 10, 10, 400, 280, ""); fdui->browser_toc = obj = fl_add_browser(FL_HOLD_BROWSER, 10, 10, 400, 280, "");
fl_set_object_gravity(obj, FL_NorthWest, FL_SouthEast); fl_set_object_gravity(obj, FL_NorthWest, FL_SouthEast);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0); fl_set_object_callback(obj, C_FormBaseInputCB, 0);
{ {
char const * const dummy = N_("Update|#U"); char const * const dummy = N_("Update|#U");
fdui->button_update = obj = fl_add_button(FL_NORMAL_BUTTON, 200, 300, 100, 30, idex(_(dummy))); fdui->button_update = obj = fl_add_button(FL_NORMAL_BUTTON, 200, 300, 100, 30, idex(_(dummy)));
@ -35,7 +35,7 @@ FD_form_toc * FormToc::build_toc()
} }
fl_set_object_lsize(obj, FL_NORMAL_SIZE); fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_gravity(obj, FL_SouthEast, FL_SouthEast); fl_set_object_gravity(obj, FL_SouthEast, FL_SouthEast);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0); fl_set_object_callback(obj, C_FormBaseInputCB, 0);
{ {
char const * const dummy = N_("Type|#T"); char const * const dummy = N_("Type|#T");
fdui->choice_toc_type = obj = fl_add_choice(FL_NORMAL_CHOICE, 60, 300, 130, 30, idex(_(dummy))); fdui->choice_toc_type = obj = fl_add_choice(FL_NORMAL_CHOICE, 60, 300, 130, 30, idex(_(dummy)));
@ -43,7 +43,7 @@ FD_form_toc * FormToc::build_toc()
} }
fl_set_object_boxtype(obj, FL_FRAME_BOX); fl_set_object_boxtype(obj, FL_FRAME_BOX);
fl_set_object_gravity(obj, FL_SouthEast, FL_SouthEast); fl_set_object_gravity(obj, FL_SouthEast, FL_SouthEast);
fl_set_object_callback(obj, C_FormBaseDeprecatedInputCB, 0); fl_set_object_callback(obj, C_FormBaseInputCB, 0);
{ {
char const * const dummy = N_("Close|^[^M"); char const * const dummy = N_("Close|^[^M");
fdui->button_cancel = obj = fl_add_button(FL_RETURN_BUTTON, 310, 300, 100, 30, idex(_(dummy))); fdui->button_cancel = obj = fl_add_button(FL_RETURN_BUTTON, 310, 300, 100, 30, idex(_(dummy)));
@ -51,7 +51,7 @@ FD_form_toc * FormToc::build_toc()
} }
fl_set_object_lsize(obj, FL_NORMAL_SIZE); fl_set_object_lsize(obj, FL_NORMAL_SIZE);
fl_set_object_gravity(obj, FL_SouthEast, FL_SouthEast); fl_set_object_gravity(obj, FL_SouthEast, FL_SouthEast);
fl_set_object_callback(obj, C_FormBaseDeprecatedCancelCB, 0); fl_set_object_callback(obj, C_FormBaseCancelCB, 0);
fl_end_form(); fl_end_form();
fdui->form->fdui = fdui; fdui->form->fdui = fdui;

View File

@ -5,8 +5,8 @@
#define FD_form_toc_h_ #define FD_form_toc_h_
/** Callbacks, globals and object handlers **/ /** Callbacks, globals and object handlers **/
extern "C" void C_FormBaseDeprecatedInputCB(FL_OBJECT *, long); extern "C" void C_FormBaseInputCB(FL_OBJECT *, long);
extern "C" void C_FormBaseDeprecatedCancelCB(FL_OBJECT *, long); extern "C" void C_FormBaseCancelCB(FL_OBJECT *, long);
/**** Forms and Objects ****/ /**** Forms and Objects ****/

View File

@ -45,7 +45,7 @@ shortcut:
resize: FL_RESIZE_ALL resize: FL_RESIZE_ALL
gravity: FL_NorthWest FL_SouthEast gravity: FL_NorthWest FL_SouthEast
name: browser_toc name: browser_toc
callback: C_FormBaseDeprecatedInputCB callback: C_FormBaseInputCB
argument: 0 argument: 0
-------------------- --------------------
@ -63,7 +63,7 @@ shortcut:
resize: FL_RESIZE_NONE resize: FL_RESIZE_NONE
gravity: FL_SouthEast FL_SouthEast gravity: FL_SouthEast FL_SouthEast
name: button_update name: button_update
callback: C_FormBaseDeprecatedInputCB callback: C_FormBaseInputCB
argument: 0 argument: 0
-------------------- --------------------
@ -81,7 +81,7 @@ shortcut:
resize: FL_RESIZE_NONE resize: FL_RESIZE_NONE
gravity: FL_SouthEast FL_SouthEast gravity: FL_SouthEast FL_SouthEast
name: choice_toc_type name: choice_toc_type
callback: C_FormBaseDeprecatedInputCB callback: C_FormBaseInputCB
argument: 0 argument: 0
-------------------- --------------------
@ -99,7 +99,7 @@ shortcut:
resize: FL_RESIZE_NONE resize: FL_RESIZE_NONE
gravity: FL_SouthEast FL_SouthEast gravity: FL_SouthEast FL_SouthEast
name: button_cancel name: button_cancel
callback: C_FormBaseDeprecatedCancelCB callback: C_FormBaseCancelCB
argument: 0 argument: 0
============================== ==============================

View File

@ -1227,6 +1227,8 @@ string const LyXFunc::Dispatch(int ac,
int id; int id;
istr >> id; istr >> id;
LyXParagraph * par = TEXT()->GetParFromID(id); LyXParagraph * par = TEXT()->GetParFromID(id);
if (par == 0)
break;
// Set the cursor // Set the cursor
TEXT()->SetCursor(owner->view(), par, 0); TEXT()->SetCursor(owner->view(), par, 0);