mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-25 01:26:51 +00:00
IU stuff + shuffling things from BV::dispatch to LyXText::dispatch
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@8427 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
df974a3904
commit
4bcfc43c29
@ -324,26 +324,6 @@ void BufferView::gotoLabel(string const & label)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void BufferView::replaceWord(string const & replacestring)
|
|
||||||
{
|
|
||||||
if (!available())
|
|
||||||
return;
|
|
||||||
|
|
||||||
LyXText * t = getLyXText();
|
|
||||||
|
|
||||||
t->replaceSelectionWithString(replacestring);
|
|
||||||
t->setSelectionRange(replacestring.length());
|
|
||||||
|
|
||||||
// Go back so that replacement string is also spellchecked
|
|
||||||
for (string::size_type i = 0; i < replacestring.length() + 1; ++i)
|
|
||||||
t->cursorLeft(cursor(), this);
|
|
||||||
|
|
||||||
// FIXME: should be done through LFUN
|
|
||||||
buffer()->markDirty();
|
|
||||||
update();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void BufferView::hideCursor()
|
void BufferView::hideCursor()
|
||||||
{
|
{
|
||||||
screen().hideCursor();
|
screen().hideCursor();
|
||||||
@ -455,7 +435,7 @@ void BufferView::putSelectionAt(PosIterator const & cur,
|
|||||||
cursor().updatePos();
|
cursor().updatePos();
|
||||||
|
|
||||||
if (length) {
|
if (length) {
|
||||||
text->setSelectionRange(length);
|
text->setSelectionRange(cursor(), length);
|
||||||
cursor().setSelection();
|
cursor().setSelection();
|
||||||
if (backwards)
|
if (backwards)
|
||||||
swap(cursor().cursor_, cursor().anchor_);
|
swap(cursor().cursor_, cursor().anchor_);
|
||||||
|
@ -117,8 +117,6 @@ public:
|
|||||||
/// return the parent language of the given inset
|
/// return the parent language of the given inset
|
||||||
Language const * getParentLanguage(InsetOld * inset) const;
|
Language const * getParentLanguage(InsetOld * inset) const;
|
||||||
|
|
||||||
/// replace the currently selected word
|
|
||||||
void replaceWord(std::string const & replacestring);
|
|
||||||
/// simple replacing. Use the font of the first selected character
|
/// simple replacing. Use the font of the first selected character
|
||||||
void replaceSelectionWithString(std::string const & str);
|
void replaceSelectionWithString(std::string const & str);
|
||||||
|
|
||||||
|
@ -65,8 +65,6 @@
|
|||||||
|
|
||||||
#include <boost/bind.hpp>
|
#include <boost/bind.hpp>
|
||||||
|
|
||||||
using bv_funcs::currentState;
|
|
||||||
|
|
||||||
using lyx::pos_type;
|
using lyx::pos_type;
|
||||||
|
|
||||||
using lyx::support::AddPath;
|
using lyx::support::AddPath;
|
||||||
@ -975,7 +973,6 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & cmd)
|
|||||||
<< " button[" << cmd.button() << ']'
|
<< " button[" << cmd.button() << ']'
|
||||||
<< endl;
|
<< endl;
|
||||||
|
|
||||||
LyXTextClass const & tclass = buffer_->params().getLyXTextClass();
|
|
||||||
LCursor & cur = bv_->cursor();
|
LCursor & cur = bv_->cursor();
|
||||||
|
|
||||||
switch (cmd.action) {
|
switch (cmd.action) {
|
||||||
@ -1015,7 +1012,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_FONT_STATE:
|
case LFUN_FONT_STATE:
|
||||||
owner_->getLyXFunc().setMessage(currentState(bv_));
|
cur.message(cur.currentState());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_INSERT_LABEL: {
|
case LFUN_INSERT_LABEL: {
|
||||||
@ -1049,31 +1046,13 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & cmd)
|
|||||||
|
|
||||||
if (!label.empty())
|
if (!label.empty())
|
||||||
bv_->gotoLabel(label);
|
bv_->gotoLabel(label);
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case LFUN_PARAGRAPH_APPLY:
|
case LFUN_PARAGRAPH_APPLY:
|
||||||
setParagraphParams(*bv_, cmd.argument);
|
setParagraphParams(*bv_, cmd.argument);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_THESAURUS_ENTRY: {
|
|
||||||
string arg = cmd.argument;
|
|
||||||
|
|
||||||
if (arg.empty()) {
|
|
||||||
arg = cur.selectionAsString(false);
|
|
||||||
// FIXME
|
|
||||||
if (arg.size() > 100 || arg.empty()) {
|
|
||||||
// Get word or selection
|
|
||||||
bv_->getLyXText()->selectWordWhenUnderCursor(lyx::WHOLE_WORD);
|
|
||||||
arg = cur.selectionAsString(false);
|
|
||||||
// FIXME: where is getLyXText()->unselect(bv_) ?
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bv_->owner()->getDialogs().show("thesaurus", arg);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case LFUN_TRACK_CHANGES:
|
case LFUN_TRACK_CHANGES:
|
||||||
trackChanges();
|
trackChanges();
|
||||||
break;
|
break;
|
||||||
@ -1083,31 +1062,19 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_ACCEPT_ALL_CHANGES: {
|
case LFUN_ACCEPT_ALL_CHANGES: {
|
||||||
bv_->text()->setCursor(0, 0);
|
bv_->cursor().reset();
|
||||||
#warning FIXME changes
|
#warning FIXME changes
|
||||||
while (lyx::find::findNextChange(bv_))
|
while (lyx::find::findNextChange(bv_))
|
||||||
bv_->getLyXText()->acceptChange();
|
bv_->getLyXText()->acceptChange(bv_->cursor());
|
||||||
update();
|
update();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case LFUN_REJECT_ALL_CHANGES: {
|
case LFUN_REJECT_ALL_CHANGES: {
|
||||||
bv_->text()->setCursor(0, 0);
|
bv_->cursor().reset();
|
||||||
#warning FIXME changes
|
#warning FIXME changes
|
||||||
while (lyx::find::findNextChange(bv_))
|
while (lyx::find::findNextChange(bv_))
|
||||||
bv_->getLyXText()->rejectChange();
|
bv_->getLyXText()->rejectChange(bv_->cursor());
|
||||||
update();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case LFUN_ACCEPT_CHANGE: {
|
|
||||||
bv_->getLyXText()->acceptChange();
|
|
||||||
update();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case LFUN_REJECT_CHANGE: {
|
|
||||||
bv_->getLyXText()->rejectChange();
|
|
||||||
update();
|
update();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
* text.C:
|
* text.C:
|
||||||
* text2.C:
|
* text2.C:
|
||||||
* text3.C: add LCursor & parameter to most cursor movement functions
|
* text3.C: add LCursor & parameter to most cursor movement functions
|
||||||
|
remove usage of LyXText::cursorRow() and cursorPar()
|
||||||
|
|
||||||
* cursor.[Ch]: add textRow() needed members
|
* cursor.[Ch]: add textRow() needed members
|
||||||
|
|
||||||
|
@ -11,9 +11,10 @@
|
|||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include "support/std_sstream.h"
|
|
||||||
#include "Spacing.h"
|
#include "Spacing.h"
|
||||||
|
|
||||||
|
#include "support/std_sstream.h"
|
||||||
|
|
||||||
using std::ios;
|
using std::ios;
|
||||||
using std::istringstream;
|
using std::istringstream;
|
||||||
using std::ostream;
|
using std::ostream;
|
||||||
|
@ -145,118 +145,10 @@ bool string2font(string const & data, LyXFont & font, bool & toggle)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool changeDepthAllowed(BufferView * bv, LyXText * text, DEPTH_CHANGE type)
|
bool changeDepthAllowed(LCursor & cur, LyXText * text, DEPTH_CHANGE type)
|
||||||
{
|
{
|
||||||
return bv->available() && text && text->changeDepthAllowed(type);
|
return cur.bv().available() && text && text->changeDepthAllowed(cur, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void changeDepth(BufferView * bv, LyXText * text, DEPTH_CHANGE type)
|
|
||||||
{
|
|
||||||
if (bv->available() && text)
|
|
||||||
text->changeDepth(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Returns the current font and depth as a message.
|
|
||||||
string const currentState(BufferView * bv)
|
|
||||||
{
|
|
||||||
ostringstream state;
|
|
||||||
|
|
||||||
if (!bv->available())
|
|
||||||
return string();
|
|
||||||
|
|
||||||
if (bv->cursor().inMathed()) {
|
|
||||||
bv->cursor().info(state);
|
|
||||||
return state.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
LyXText * text = bv->getLyXText();
|
|
||||||
Buffer * buffer = bv->buffer();
|
|
||||||
CursorSlice const & c = text->cursor();
|
|
||||||
|
|
||||||
bool const show_change = buffer->params().tracking_changes
|
|
||||||
&& text->cursor().pos() != text->cursorPar()->size()
|
|
||||||
&& text->cursorPar()->lookupChange(c.pos()) != Change::UNCHANGED;
|
|
||||||
|
|
||||||
if (show_change) {
|
|
||||||
Change change = text->cursorPar()->lookupChangeFull(c.pos());
|
|
||||||
Author const & a = bv->buffer()->params().authors().get(change.author);
|
|
||||||
state << _("Change: ") << a.name();
|
|
||||||
if (!a.email().empty())
|
|
||||||
state << " (" << a.email() << ")";
|
|
||||||
if (change.changetime)
|
|
||||||
state << _(" at ") << ctime(&change.changetime);
|
|
||||||
state << " : ";
|
|
||||||
}
|
|
||||||
|
|
||||||
// I think we should only show changes from the default
|
|
||||||
// font. (Asger)
|
|
||||||
LyXFont font = text->real_current_font;
|
|
||||||
font.reduce(buffer->params().getLyXTextClass().defaultfont());
|
|
||||||
|
|
||||||
// avoid _(...) re-entrance problem
|
|
||||||
string const s = font.stateText(&buffer->params());
|
|
||||||
state << bformat(_("Font: %1$s"), s);
|
|
||||||
|
|
||||||
// state << bformat(_("Font: %1$s"), font.stateText(&buffer->params));
|
|
||||||
|
|
||||||
// The paragraph depth
|
|
||||||
int depth = text->getDepth();
|
|
||||||
if (depth > 0)
|
|
||||||
state << bformat(_(", Depth: %1$s"), tostr(depth));
|
|
||||||
|
|
||||||
// The paragraph spacing, but only if different from
|
|
||||||
// buffer spacing.
|
|
||||||
if (!text->cursorPar()->params().spacing().isDefault()) {
|
|
||||||
Spacing::Space cur_space =
|
|
||||||
text->cursorPar()->params().spacing().getSpace();
|
|
||||||
state << _(", Spacing: ");
|
|
||||||
|
|
||||||
switch (cur_space) {
|
|
||||||
case Spacing::Single:
|
|
||||||
state << _("Single");
|
|
||||||
break;
|
|
||||||
case Spacing::Onehalf:
|
|
||||||
state << _("OneHalf");
|
|
||||||
break;
|
|
||||||
case Spacing::Double:
|
|
||||||
state << _("Double");
|
|
||||||
break;
|
|
||||||
case Spacing::Other:
|
|
||||||
state << _("Other (")
|
|
||||||
<< text->cursorPar()->params().spacing().getValue()
|
|
||||||
<< ')';
|
|
||||||
break;
|
|
||||||
case Spacing::Default:
|
|
||||||
// should never happen, do nothing
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#ifdef DEVEL_VERSION
|
|
||||||
ParagraphList::iterator pit = text->cursorPar();
|
|
||||||
state << _(", Paragraph: ") << pit->id();
|
|
||||||
state << _(", Position: ") << text->cursor().pos();
|
|
||||||
RowList::iterator rit = pit->getRow(text->cursor().pos());
|
|
||||||
state << bformat(_(", Row b:%1$d e:%2$d"), rit->pos(), rit->endpos());
|
|
||||||
state << _(", Inset: ");
|
|
||||||
InsetOld * inset = pit->inInset();
|
|
||||||
if (inset)
|
|
||||||
state << inset << " owner: " << inset->owner();
|
|
||||||
else
|
|
||||||
state << -1;
|
|
||||||
#endif
|
|
||||||
return state.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// deletes a selection during an insertion
|
|
||||||
void replaceSelection(LyXText * text)
|
|
||||||
{
|
|
||||||
if (text->bv()->cursor().selection()) {
|
|
||||||
text->cutSelection(true, false);
|
|
||||||
text->bv()->update();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace bv_funcs
|
} // namespace bv_funcs
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
|
|
||||||
class BufferView;
|
class BufferView;
|
||||||
|
class LCursor;
|
||||||
class LyXFont;
|
class LyXFont;
|
||||||
class LyXText;
|
class LyXText;
|
||||||
class PosIterator;
|
class PosIterator;
|
||||||
@ -45,17 +46,8 @@ enum DEPTH_CHANGE {
|
|||||||
DEC_DEPTH
|
DEC_DEPTH
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Increase or decrease the nesting depth of the selected paragraph(s)
|
|
||||||
void changeDepth(BufferView *, LyXText *, DEPTH_CHANGE);
|
|
||||||
|
|
||||||
/// Returns whether something would be changed by changeDepth
|
/// Returns whether something would be changed by changeDepth
|
||||||
bool changeDepthAllowed(BufferView *, LyXText *, DEPTH_CHANGE);
|
bool changeDepthAllowed(LCursor & cur, LyXText * text, DEPTH_CHANGE);
|
||||||
|
|
||||||
/// Returns the current font and depth as a message.
|
|
||||||
std::string const currentState(BufferView *);
|
|
||||||
/// replace selection with insertion
|
|
||||||
void replaceSelection(LyXText * lt);
|
|
||||||
|
|
||||||
|
|
||||||
}; // namespace bv_funcs
|
}; // namespace bv_funcs
|
||||||
|
|
||||||
|
50
src/cursor.C
50
src/cursor.C
@ -35,6 +35,8 @@
|
|||||||
#include "mathed/math_support.h"
|
#include "mathed/math_support.h"
|
||||||
|
|
||||||
#include "support/limited_stack.h"
|
#include "support/limited_stack.h"
|
||||||
|
#include "support/std_sstream.h"
|
||||||
|
|
||||||
#include "frontends/LyXView.h"
|
#include "frontends/LyXView.h"
|
||||||
|
|
||||||
#include <boost/assert.hpp>
|
#include <boost/assert.hpp>
|
||||||
@ -255,7 +257,7 @@ void LCursor::getDim(int & asc, int & des) const
|
|||||||
asc = 10;
|
asc = 10;
|
||||||
des = 10;
|
des = 10;
|
||||||
} else {
|
} else {
|
||||||
Row const & row = *text()->cursorRow();
|
Row const & row = textRow();
|
||||||
asc = row.baseline();
|
asc = row.baseline();
|
||||||
des = row.height() - asc;
|
des = row.height() - asc;
|
||||||
}
|
}
|
||||||
@ -568,7 +570,7 @@ MathArray & LCursor::cell()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LCursor::info(std::ostream & os)
|
void LCursor::info(std::ostream & os) const
|
||||||
{
|
{
|
||||||
for (int i = 1, n = depth(); i < n; ++i) {
|
for (int i = 1, n = depth(); i < n; ++i) {
|
||||||
cursor_[i].inset()->infoize(os);
|
cursor_[i].inset()->infoize(os);
|
||||||
@ -1031,7 +1033,7 @@ void LCursor::insert(InsetBase * inset)
|
|||||||
if (inMathed())
|
if (inMathed())
|
||||||
insert(MathAtom(inset));
|
insert(MathAtom(inset));
|
||||||
else
|
else
|
||||||
text()->insertInset(inset);
|
text()->insertInset(*this, inset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1829,8 +1831,7 @@ InsetBase * LCursor::nextInset()
|
|||||||
return 0;
|
return 0;
|
||||||
if (inMathed())
|
if (inMathed())
|
||||||
return nextAtom().nucleus();
|
return nextAtom().nucleus();
|
||||||
Paragraph & par = paragraph();
|
return paragraph().isInset(pos()) ? paragraph().getInset(pos()) : 0;
|
||||||
return par.isInset(pos()) ? par.getInset(pos()) : 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1840,8 +1841,17 @@ InsetBase * LCursor::prevInset()
|
|||||||
return 0;
|
return 0;
|
||||||
if (inMathed())
|
if (inMathed())
|
||||||
return prevAtom().nucleus();
|
return prevAtom().nucleus();
|
||||||
Paragraph & par = paragraph();
|
return paragraph().isInset(pos() - 1) ? paragraph().getInset(pos() - 1) : 0;
|
||||||
return par.isInset(pos() - 1) ? par.getInset(pos() - 1) : 0;
|
}
|
||||||
|
|
||||||
|
|
||||||
|
InsetBase const * LCursor::prevInset() const
|
||||||
|
{
|
||||||
|
if (pos() == 0)
|
||||||
|
return 0;
|
||||||
|
if (inMathed())
|
||||||
|
return prevAtom().nucleus();
|
||||||
|
return paragraph().isInset(pos() - 1) ? paragraph().getInset(pos() - 1) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1892,3 +1902,29 @@ string LCursor::selectionAsString(bool label) const
|
|||||||
#warning an mathed?
|
#warning an mathed?
|
||||||
return string();
|
return string();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
string LCursor::currentState()
|
||||||
|
{
|
||||||
|
if (inMathed()) {
|
||||||
|
std::ostringstream os;
|
||||||
|
info(os);
|
||||||
|
return os.str();
|
||||||
|
}
|
||||||
|
return text()->currentState(*this);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// only used by the spellchecker
|
||||||
|
void LCursor::replaceWord(string const & replacestring)
|
||||||
|
{
|
||||||
|
LyXText * t = text();
|
||||||
|
|
||||||
|
t->replaceSelectionWithString(*this, replacestring);
|
||||||
|
t->setSelectionRange(*this, replacestring.length());
|
||||||
|
|
||||||
|
// Go back so that replacement string is also spellchecked
|
||||||
|
for (string::size_type i = 0; i < replacestring.length() + 1; ++i)
|
||||||
|
t->cursorLeft(*this, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -146,6 +146,8 @@ public:
|
|||||||
std::string selectionAsString(bool label) const;
|
std::string selectionAsString(bool label) const;
|
||||||
///
|
///
|
||||||
void paste(std::string const & data);
|
void paste(std::string const & data);
|
||||||
|
///
|
||||||
|
std::string currentState();
|
||||||
|
|
||||||
//
|
//
|
||||||
// access to the 'current' cursor slice
|
// access to the 'current' cursor slice
|
||||||
@ -189,6 +191,8 @@ public:
|
|||||||
InsetBase * nextInset();
|
InsetBase * nextInset();
|
||||||
/// the inset just in front of the cursor
|
/// the inset just in front of the cursor
|
||||||
InsetBase * prevInset();
|
InsetBase * prevInset();
|
||||||
|
/// the inset just in front of the cursor
|
||||||
|
InsetBase const * prevInset() const;
|
||||||
|
|
||||||
//
|
//
|
||||||
// math-specific part
|
// math-specific part
|
||||||
@ -276,11 +280,13 @@ public:
|
|||||||
/// access to owning BufferView
|
/// access to owning BufferView
|
||||||
BufferView & bv() const;
|
BufferView & bv() const;
|
||||||
/// get some interesting description of current position
|
/// get some interesting description of current position
|
||||||
void info(std::ostream & os);
|
void info(std::ostream & os) const;
|
||||||
/// are we in math mode (2), text mode (1) or unsure (0)?
|
/// are we in math mode (2), text mode (1) or unsure (0)?
|
||||||
int currentMode();
|
int currentMode();
|
||||||
/// reset cursor
|
/// reset cursor
|
||||||
void reset();
|
void reset();
|
||||||
|
/// for spellchecking
|
||||||
|
void replaceWord(std::string const & replacestring);
|
||||||
|
|
||||||
/// output
|
/// output
|
||||||
friend std::ostream & operator<<(std::ostream & os, LCursor const & cur);
|
friend std::ostream & operator<<(std::ostream & os, LCursor const & cur);
|
||||||
|
@ -154,7 +154,7 @@ InsetBase * createInset(BufferView * bv, FuncRequest const & cmd)
|
|||||||
// Try and generate a valid index entry.
|
// Try and generate a valid index entry.
|
||||||
InsetCommandParams icp("index");
|
InsetCommandParams icp("index");
|
||||||
string const contents = cmd.argument.empty() ?
|
string const contents = cmd.argument.empty() ?
|
||||||
bv->getLyXText()->getStringToIndex() :
|
bv->getLyXText()->getStringToIndex(bv->cursor()) :
|
||||||
cmd.argument;
|
cmd.argument;
|
||||||
icp.setContents(contents);
|
icp.setContents(contents);
|
||||||
|
|
||||||
|
@ -13,17 +13,18 @@
|
|||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include "ControlCommandBuffer.h"
|
#include "ControlCommandBuffer.h"
|
||||||
#include "bufferview_funcs.h"
|
|
||||||
|
#include "BufferView.h"
|
||||||
|
#include "cursor.h"
|
||||||
#include "lyxfunc.h"
|
#include "lyxfunc.h"
|
||||||
#include "LyXAction.h"
|
#include "LyXAction.h"
|
||||||
#include "funcrequest.h"
|
#include "funcrequest.h"
|
||||||
|
|
||||||
#include "frontends/LyXView.h"
|
#include "frontends/LyXView.h"
|
||||||
|
|
||||||
#include "support/lyxalgo.h"
|
#include "support/lyxalgo.h"
|
||||||
#include "support/lstrings.h"
|
#include "support/lstrings.h"
|
||||||
|
|
||||||
using bv_funcs::currentState;
|
|
||||||
|
|
||||||
using lyx::support::prefixIs;
|
using lyx::support::prefixIs;
|
||||||
|
|
||||||
using std::back_inserter;
|
using std::back_inserter;
|
||||||
@ -66,9 +67,9 @@ string const ControlCommandBuffer::historyUp()
|
|||||||
string const ControlCommandBuffer::historyDown()
|
string const ControlCommandBuffer::historyDown()
|
||||||
{
|
{
|
||||||
if (history_pos_ == history_.end())
|
if (history_pos_ == history_.end())
|
||||||
return "";
|
return string();
|
||||||
if (history_pos_ + 1 == history_.end())
|
if (history_pos_ + 1 == history_.end())
|
||||||
return "";
|
return string();
|
||||||
|
|
||||||
return *(++history_pos_);
|
return *(++history_pos_);
|
||||||
}
|
}
|
||||||
@ -76,7 +77,7 @@ string const ControlCommandBuffer::historyDown()
|
|||||||
|
|
||||||
string const ControlCommandBuffer::getCurrentState() const
|
string const ControlCommandBuffer::getCurrentState() const
|
||||||
{
|
{
|
||||||
return currentState(lv_.view().get());
|
return lv_.view()->cursor().currentState();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -98,9 +99,9 @@ ControlCommandBuffer::completions(string const & prefix, string & new_prefix)
|
|||||||
return vector<string>();
|
return vector<string>();
|
||||||
}
|
}
|
||||||
|
|
||||||
// find maximal avaliable prefix
|
// find maximal available prefix
|
||||||
string const tmp = comp[0];
|
string const tmp = comp[0];
|
||||||
string test(prefix);
|
string test = prefix;
|
||||||
if (tmp.length() > test.length())
|
if (tmp.length() > test.length())
|
||||||
test += tmp[test.length()];
|
test += tmp[test.length()];
|
||||||
while (test.length() < tmp.length()) {
|
while (test.length() < tmp.length()) {
|
||||||
|
@ -16,12 +16,11 @@
|
|||||||
#include "buffer.h"
|
#include "buffer.h"
|
||||||
#include "bufferparams.h"
|
#include "bufferparams.h"
|
||||||
#include "BufferView.h"
|
#include "BufferView.h"
|
||||||
#include "bufferview_funcs.h"
|
#include "cursor.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "gettext.h"
|
#include "gettext.h"
|
||||||
#include "language.h"
|
#include "language.h"
|
||||||
#include "lyxrc.h"
|
#include "lyxrc.h"
|
||||||
|
|
||||||
#include "PosIterator.h"
|
#include "PosIterator.h"
|
||||||
#include "paragraph.h"
|
#include "paragraph.h"
|
||||||
|
|
||||||
@ -235,17 +234,17 @@ void ControlSpellchecker::check()
|
|||||||
|
|
||||||
lyxerr[Debug::GUI] << "Found word \"" << word_.word() << "\"" << endl;
|
lyxerr[Debug::GUI] << "Found word \"" << word_.word() << "\"" << endl;
|
||||||
|
|
||||||
if (!word_.word().empty()) {
|
if (word_.word().empty()) {
|
||||||
int const size = word_.word().size();
|
|
||||||
advance(cur, -size);
|
|
||||||
bufferview()->putSelectionAt(cur, size, false);
|
|
||||||
advance(cur, size);
|
|
||||||
} else {
|
|
||||||
showSummary();
|
showSummary();
|
||||||
endSession();
|
endSession();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int const size = word_.word().size();
|
||||||
|
advance(cur, -size);
|
||||||
|
bufferview()->putSelectionAt(cur, size, false);
|
||||||
|
advance(cur, size);
|
||||||
|
|
||||||
// set suggestions
|
// set suggestions
|
||||||
if (res != SpellBase::OK && res != SpellBase::IGNORE) {
|
if (res != SpellBase::OK && res != SpellBase::IGNORE) {
|
||||||
lyxerr[Debug::GUI] << "Found a word needing checking." << endl;
|
lyxerr[Debug::GUI] << "Found a word needing checking." << endl;
|
||||||
@ -292,7 +291,9 @@ void ControlSpellchecker::showSummary()
|
|||||||
|
|
||||||
void ControlSpellchecker::replace(string const & replacement)
|
void ControlSpellchecker::replace(string const & replacement)
|
||||||
{
|
{
|
||||||
bufferview()->replaceWord(replacement);
|
bufferview()->cursor().replaceWord(replacement);
|
||||||
|
bufferview()->buffer()->markDirty();
|
||||||
|
bufferview()->update();
|
||||||
// fix up the count
|
// fix up the count
|
||||||
--count_;
|
--count_;
|
||||||
check();
|
check();
|
||||||
|
@ -348,15 +348,14 @@ InsetCollapsable::priv_dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
return lfunMouseRelease(cur, cmd);
|
return lfunMouseRelease(cur, cmd);
|
||||||
|
|
||||||
case LFUN_INSET_TOGGLE:
|
case LFUN_INSET_TOGGLE:
|
||||||
if (inset.text_.toggleInset())
|
if (inset.text_.toggleInset(cur))
|
||||||
return DispatchResult(true, true);
|
return DispatchResult(true, true);
|
||||||
if (status_ == Open) {
|
if (status_ == Open) {
|
||||||
setStatus(Inlined);
|
setStatus(Inlined);
|
||||||
return DispatchResult(true, true);
|
return DispatchResult(true, true);
|
||||||
} else {
|
}
|
||||||
setStatus(Collapsed);
|
setStatus(Collapsed);
|
||||||
return DispatchResult(false, FINISHED_RIGHT);
|
return DispatchResult(false, FINISHED_RIGHT);
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return inset.dispatch(cur, cmd);
|
return inset.dispatch(cur, cmd);
|
||||||
|
@ -52,8 +52,6 @@
|
|||||||
|
|
||||||
#include <boost/bind.hpp>
|
#include <boost/bind.hpp>
|
||||||
|
|
||||||
using bv_funcs::replaceSelection;
|
|
||||||
|
|
||||||
using lyx::pos_type;
|
using lyx::pos_type;
|
||||||
|
|
||||||
using lyx::graphics::PreviewLoader;
|
using lyx::graphics::PreviewLoader;
|
||||||
@ -279,7 +277,7 @@ void InsetText::sanitizeEmptyText(BufferView & bv)
|
|||||||
&& bv.getParentLanguage(this) != text_.current_font.language()) {
|
&& bv.getParentLanguage(this) != text_.current_font.language()) {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setLanguage(bv.getParentLanguage(this));
|
font.setLanguage(bv.getParentLanguage(this));
|
||||||
text_.setFont(font, false);
|
text_.setFont(bv.cursor(), font, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -329,7 +327,7 @@ DispatchResult InsetText::priv_dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
paragraphs().size() == 1) {
|
paragraphs().size() == 1) {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setLanguage(cur.bv().getParentLanguage(this));
|
font.setLanguage(cur.bv().getParentLanguage(this));
|
||||||
text_.setFont(font, false);
|
text_.setFont(cur, font, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
//lyxerr << "InsetText::priv_dispatch (end)" << endl;
|
//lyxerr << "InsetText::priv_dispatch (end)" << endl;
|
||||||
|
@ -361,9 +361,9 @@ void InsertAsciiFile(BufferView * bv, string const & f, bool asParagraph)
|
|||||||
if (bv->text() == bv->getLyXText())
|
if (bv->text() == bv->getLyXText())
|
||||||
bv->cursor().clearSelection();
|
bv->cursor().clearSelection();
|
||||||
if (asParagraph)
|
if (asParagraph)
|
||||||
bv->getLyXText()->insertStringAsParagraphs(tmpstr);
|
bv->getLyXText()->insertStringAsParagraphs(bv->cursor(), tmpstr);
|
||||||
else
|
else
|
||||||
bv->getLyXText()->insertStringAsLines(tmpstr);
|
bv->getLyXText()->insertStringAsLines(bv->cursor(), tmpstr);
|
||||||
bv->update();
|
bv->update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -388,8 +388,8 @@ int replace(BufferView * bv, string const & searchstr,
|
|||||||
|
|
||||||
LyXText * text = bv->getLyXText();
|
LyXText * text = bv->getLyXText();
|
||||||
|
|
||||||
text->replaceSelectionWithString(replacestr);
|
text->replaceSelectionWithString(bv->cursor(), replacestr);
|
||||||
text->setSelectionRange(replacestr.length());
|
text->setSelectionRange(bv->cursor(), replacestr.length());
|
||||||
bv->cursor().current() = fw ? bv->cursor().selEnd() : bv->cursor().selBegin();
|
bv->cursor().current() = fw ? bv->cursor().selEnd() : bv->cursor().selBegin();
|
||||||
bv->buffer()->markDirty();
|
bv->buffer()->markDirty();
|
||||||
find(bv, searchstr, cs, mw, fw);
|
find(bv, searchstr, cs, mw, fw);
|
||||||
|
113
src/lyxfunc.C
113
src/lyxfunc.C
@ -82,8 +82,6 @@
|
|||||||
#include "support/std_sstream.h"
|
#include "support/std_sstream.h"
|
||||||
#include "support/os.h"
|
#include "support/os.h"
|
||||||
|
|
||||||
using bv_funcs::changeDepth;
|
|
||||||
using bv_funcs::currentState;
|
|
||||||
using bv_funcs::DEC_DEPTH;
|
using bv_funcs::DEC_DEPTH;
|
||||||
using bv_funcs::freefont2string;
|
using bv_funcs::freefont2string;
|
||||||
using bv_funcs::INC_DEPTH;
|
using bv_funcs::INC_DEPTH;
|
||||||
@ -257,19 +255,19 @@ void LyXFunc::processKeySym(LyXKeySymPtr keysym, key_modifier::state state)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
FuncStatus LyXFunc::getStatus(FuncRequest const & cmd) const
|
||||||
{
|
{
|
||||||
FuncStatus flag;
|
FuncStatus flag;
|
||||||
Buffer * buf = owner->buffer();
|
Buffer * buf = owner->buffer();
|
||||||
LCursor & cur = view()->cursor();
|
LCursor & cur = view()->cursor();
|
||||||
|
|
||||||
if (ev.action == LFUN_NOACTION) {
|
if (cmd.action == LFUN_NOACTION) {
|
||||||
setStatusMessage(N_("Nothing to do"));
|
setStatusMessage(N_("Nothing to do"));
|
||||||
flag.disabled(true);
|
flag.disabled(true);
|
||||||
return flag;
|
return flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (ev.action) {
|
switch (cmd.action) {
|
||||||
case LFUN_UNKNOWN_ACTION:
|
case LFUN_UNKNOWN_ACTION:
|
||||||
#ifndef HAVE_LIBAIKSAURUS
|
#ifndef HAVE_LIBAIKSAURUS
|
||||||
case LFUN_THESAURUS_ENTRY:
|
case LFUN_THESAURUS_ENTRY:
|
||||||
@ -278,7 +276,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
flag.disabled(true);
|
flag.disabled(true);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
flag |= lyx_gui::getStatus(ev);
|
flag |= lyx_gui::getStatus(cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flag.unknown()) {
|
if (flag.unknown()) {
|
||||||
@ -290,13 +288,13 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
setStatusMessage(N_("Command disabled"));
|
setStatusMessage(N_("Command disabled"));
|
||||||
|
|
||||||
// Check whether we need a buffer
|
// Check whether we need a buffer
|
||||||
if (!lyxaction.funcHasFlag(ev.action, LyXAction::NoBuffer)) {
|
if (!lyxaction.funcHasFlag(cmd.action, LyXAction::NoBuffer)) {
|
||||||
// Yes we need a buffer, do we have one?
|
// Yes we need a buffer, do we have one?
|
||||||
if (buf) {
|
if (buf) {
|
||||||
// yes
|
// yes
|
||||||
// Can we use a readonly buffer?
|
// Can we use a readonly buffer?
|
||||||
if (buf->isReadonly() &&
|
if (buf->isReadonly() &&
|
||||||
!lyxaction.funcHasFlag(ev.action,
|
!lyxaction.funcHasFlag(cmd.action,
|
||||||
LyXAction::ReadOnly)) {
|
LyXAction::ReadOnly)) {
|
||||||
// no
|
// no
|
||||||
setStatusMessage(N_("Document is read-only"));
|
setStatusMessage(N_("Document is read-only"));
|
||||||
@ -317,10 +315,10 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
// I would really like to avoid having this switch and rather try to
|
// I would really like to avoid having this switch and rather try to
|
||||||
// encode this in the function itself.
|
// encode this in the function itself.
|
||||||
bool disable = false;
|
bool disable = false;
|
||||||
switch (ev.action) {
|
switch (cmd.action) {
|
||||||
case LFUN_EXPORT:
|
case LFUN_EXPORT:
|
||||||
disable = ev.argument != "custom"
|
disable = cmd.argument != "custom"
|
||||||
&& !Exporter::IsExportable(*buf, ev.argument);
|
&& !Exporter::IsExportable(*buf, cmd.argument);
|
||||||
break;
|
break;
|
||||||
case LFUN_UNDO:
|
case LFUN_UNDO:
|
||||||
disable = buf->undostack().empty();
|
disable = buf->undostack().empty();
|
||||||
@ -349,11 +347,11 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_DEPTH_MIN:
|
case LFUN_DEPTH_MIN:
|
||||||
disable = !changeDepthAllowed(view(), view()->getLyXText(), DEC_DEPTH);
|
disable = !changeDepthAllowed(cur, view()->getLyXText(), DEC_DEPTH);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_DEPTH_PLUS:
|
case LFUN_DEPTH_PLUS:
|
||||||
disable = !changeDepthAllowed(view(), view()->getLyXText(), INC_DEPTH);
|
disable = !changeDepthAllowed(cur, view()->getLyXText(), INC_DEPTH);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_LAYOUT:
|
case LFUN_LAYOUT:
|
||||||
@ -377,15 +375,15 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
disable = true;
|
disable = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (ev.argument.empty()) {
|
if (cmd.argument.empty()) {
|
||||||
flag.clear();
|
flag.clear();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!contains("tcb", ev.argument[0])) {
|
if (!contains("tcb", cmd.argument[0])) {
|
||||||
disable = true;
|
disable = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
flag.setOnOff(ev.argument[0] == align);
|
flag.setOnOff(cmd.argument[0] == align);
|
||||||
} else {
|
} else {
|
||||||
disable = true;
|
disable = true;
|
||||||
|
|
||||||
@ -394,15 +392,15 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
disable = true;
|
disable = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (ev.argument.empty()) {
|
if (cmd.argument.empty()) {
|
||||||
flag.clear();
|
flag.clear();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!contains("lcr", ev.argument[0])) {
|
if (!contains("lcr", cmd.argument[0])) {
|
||||||
disable = true;
|
disable = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
flag.setOnOff(ev.argument[0] == align);
|
flag.setOnOff(cmd.argument[0] == align);
|
||||||
|
|
||||||
disable = !mathcursor::halign();
|
disable = !mathcursor::halign();
|
||||||
break;
|
break;
|
||||||
@ -413,7 +411,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
//ret.disabled(true);
|
//ret.disabled(true);
|
||||||
InsetTabular * tab = cur.innerInsetTabular();
|
InsetTabular * tab = cur.innerInsetTabular();
|
||||||
if (tab) {
|
if (tab) {
|
||||||
ret = tab->getStatus(ev.argument);
|
ret = tab->getStatus(cmd.argument);
|
||||||
flag |= ret;
|
flag |= ret;
|
||||||
disable = false;
|
disable = false;
|
||||||
} else {
|
} else {
|
||||||
@ -422,7 +420,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
} else {
|
} else {
|
||||||
static InsetTabular inset(*buf, 1, 1);
|
static InsetTabular inset(*buf, 1, 1);
|
||||||
disable = true;
|
disable = true;
|
||||||
FuncStatus ret = inset.getStatus(ev.argument);
|
FuncStatus ret = inset.getStatus(cmd.argument);
|
||||||
if (ret.onoff(true) || ret.onoff(false))
|
if (ret.onoff(true) || ret.onoff(false))
|
||||||
flag.setOnOff(false);
|
flag.setOnOff(false);
|
||||||
}
|
}
|
||||||
@ -447,7 +445,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
break;
|
break;
|
||||||
case LFUN_BOOKMARK_GOTO:
|
case LFUN_BOOKMARK_GOTO:
|
||||||
disable = !view()->
|
disable = !view()->
|
||||||
isSavedPosition(strToUnsignedInt(ev.argument));
|
isSavedPosition(strToUnsignedInt(cmd.argument));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_MERGE_CHANGES:
|
case LFUN_MERGE_CHANGES:
|
||||||
@ -474,25 +472,25 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
InsetOld::Code code = inset->lyxCode();
|
InsetOld::Code code = inset->lyxCode();
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case InsetOld::TABULAR_CODE:
|
case InsetOld::TABULAR_CODE:
|
||||||
disable = ev.argument != "tabular";
|
disable = cmd.argument != "tabular";
|
||||||
break;
|
break;
|
||||||
case InsetOld::ERT_CODE:
|
case InsetOld::ERT_CODE:
|
||||||
disable = ev.argument != "ert";
|
disable = cmd.argument != "ert";
|
||||||
break;
|
break;
|
||||||
case InsetOld::FLOAT_CODE:
|
case InsetOld::FLOAT_CODE:
|
||||||
disable = ev.argument != "float";
|
disable = cmd.argument != "float";
|
||||||
break;
|
break;
|
||||||
case InsetOld::WRAP_CODE:
|
case InsetOld::WRAP_CODE:
|
||||||
disable = ev.argument != "wrap";
|
disable = cmd.argument != "wrap";
|
||||||
break;
|
break;
|
||||||
case InsetOld::NOTE_CODE:
|
case InsetOld::NOTE_CODE:
|
||||||
disable = ev.argument != "note";
|
disable = cmd.argument != "note";
|
||||||
break;
|
break;
|
||||||
case InsetOld::BRANCH_CODE:
|
case InsetOld::BRANCH_CODE:
|
||||||
disable = ev.argument != "branch";
|
disable = cmd.argument != "branch";
|
||||||
break;
|
break;
|
||||||
case InsetOld::BOX_CODE:
|
case InsetOld::BOX_CODE:
|
||||||
disable = ev.argument != "box";
|
disable = cmd.argument != "box";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -502,7 +500,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
|
|
||||||
case LFUN_MATH_MUTATE:
|
case LFUN_MATH_MUTATE:
|
||||||
if (cur.inMathed())
|
if (cur.inMathed())
|
||||||
//flag.setOnOff(mathcursor::formula()->hullType() == ev.argument);
|
//flag.setOnOff(mathcursor::formula()->hullType() == cmd.argument);
|
||||||
flag.setOnOff(false);
|
flag.setOnOff(false);
|
||||||
else
|
else
|
||||||
disable = true;
|
disable = true;
|
||||||
@ -519,7 +517,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_DIALOG_SHOW: {
|
case LFUN_DIALOG_SHOW: {
|
||||||
string const name = ev.getArg(0);
|
string const name = cmd.getArg(0);
|
||||||
if (!buf) {
|
if (!buf) {
|
||||||
disable = !(name == "aboutlyx" ||
|
disable = !(name == "aboutlyx" ||
|
||||||
name == "file" ||
|
name == "file" ||
|
||||||
@ -549,43 +547,43 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
|
|
||||||
// the functions which insert insets
|
// the functions which insert insets
|
||||||
InsetOld::Code code = InsetOld::NO_CODE;
|
InsetOld::Code code = InsetOld::NO_CODE;
|
||||||
switch (ev.action) {
|
switch (cmd.action) {
|
||||||
case LFUN_DIALOG_SHOW_NEW_INSET:
|
case LFUN_DIALOG_SHOW_NEW_INSET:
|
||||||
if (ev.argument == "bibitem")
|
if (cmd.argument == "bibitem")
|
||||||
code = InsetOld::BIBITEM_CODE;
|
code = InsetOld::BIBITEM_CODE;
|
||||||
else if (ev.argument == "bibtex")
|
else if (cmd.argument == "bibtex")
|
||||||
code = InsetOld::BIBTEX_CODE;
|
code = InsetOld::BIBTEX_CODE;
|
||||||
else if (ev.argument == "box")
|
else if (cmd.argument == "box")
|
||||||
code = InsetOld::BOX_CODE;
|
code = InsetOld::BOX_CODE;
|
||||||
else if (ev.argument == "branch")
|
else if (cmd.argument == "branch")
|
||||||
code = InsetOld::BRANCH_CODE;
|
code = InsetOld::BRANCH_CODE;
|
||||||
else if (ev.argument == "citation")
|
else if (cmd.argument == "citation")
|
||||||
code = InsetOld::CITE_CODE;
|
code = InsetOld::CITE_CODE;
|
||||||
else if (ev.argument == "ert")
|
else if (cmd.argument == "ert")
|
||||||
code = InsetOld::ERT_CODE;
|
code = InsetOld::ERT_CODE;
|
||||||
else if (ev.argument == "external")
|
else if (cmd.argument == "external")
|
||||||
code = InsetOld::EXTERNAL_CODE;
|
code = InsetOld::EXTERNAL_CODE;
|
||||||
else if (ev.argument == "float")
|
else if (cmd.argument == "float")
|
||||||
code = InsetOld::FLOAT_CODE;
|
code = InsetOld::FLOAT_CODE;
|
||||||
else if (ev.argument == "graphics")
|
else if (cmd.argument == "graphics")
|
||||||
code = InsetOld::GRAPHICS_CODE;
|
code = InsetOld::GRAPHICS_CODE;
|
||||||
else if (ev.argument == "include")
|
else if (cmd.argument == "include")
|
||||||
code = InsetOld::INCLUDE_CODE;
|
code = InsetOld::INCLUDE_CODE;
|
||||||
else if (ev.argument == "index")
|
else if (cmd.argument == "index")
|
||||||
code = InsetOld::INDEX_CODE;
|
code = InsetOld::INDEX_CODE;
|
||||||
else if (ev.argument == "label")
|
else if (cmd.argument == "label")
|
||||||
code = InsetOld::LABEL_CODE;
|
code = InsetOld::LABEL_CODE;
|
||||||
else if (ev.argument == "note")
|
else if (cmd.argument == "note")
|
||||||
code = InsetOld::NOTE_CODE;
|
code = InsetOld::NOTE_CODE;
|
||||||
else if (ev.argument == "ref")
|
else if (cmd.argument == "ref")
|
||||||
code = InsetOld::REF_CODE;
|
code = InsetOld::REF_CODE;
|
||||||
else if (ev.argument == "toc")
|
else if (cmd.argument == "toc")
|
||||||
code = InsetOld::TOC_CODE;
|
code = InsetOld::TOC_CODE;
|
||||||
else if (ev.argument == "url")
|
else if (cmd.argument == "url")
|
||||||
code = InsetOld::URL_CODE;
|
code = InsetOld::URL_CODE;
|
||||||
else if (ev.argument == "vspace")
|
else if (cmd.argument == "vspace")
|
||||||
code = InsetOld::VSPACE_CODE;
|
code = InsetOld::VSPACE_CODE;
|
||||||
else if (ev.argument == "wrap")
|
else if (cmd.argument == "wrap")
|
||||||
code = InsetOld::WRAP_CODE;
|
code = InsetOld::WRAP_CODE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -700,7 +698,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
flag.disabled(true);
|
flag.disabled(true);
|
||||||
|
|
||||||
// A few general toggles
|
// A few general toggles
|
||||||
switch (ev.action) {
|
switch (cmd.action) {
|
||||||
case LFUN_TOOLTIPS_TOGGLE:
|
case LFUN_TOOLTIPS_TOGGLE:
|
||||||
flag.setOnOff(owner->getDialogs().tooltipsEnabled());
|
flag.setOnOff(owner->getDialogs().tooltipsEnabled());
|
||||||
break;
|
break;
|
||||||
@ -715,7 +713,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
case LFUN_SWITCHBUFFER:
|
case LFUN_SWITCHBUFFER:
|
||||||
// toggle on the current buffer, but do not toggle off
|
// toggle on the current buffer, but do not toggle off
|
||||||
// the other ones (is that a good idea?)
|
// the other ones (is that a good idea?)
|
||||||
if (ev.argument == buf->fileName())
|
if (cmd.argument == buf->fileName())
|
||||||
flag.setOnOff(true);
|
flag.setOnOff(true);
|
||||||
break;
|
break;
|
||||||
case LFUN_TRACK_CHANGES:
|
case LFUN_TRACK_CHANGES:
|
||||||
@ -729,7 +727,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
// the font related toggles
|
// the font related toggles
|
||||||
if (cur.inTexted()) {
|
if (cur.inTexted()) {
|
||||||
LyXFont const & font = cur.text()->real_current_font;
|
LyXFont const & font = cur.text()->real_current_font;
|
||||||
switch (ev.action) {
|
switch (cmd.action) {
|
||||||
case LFUN_EMPH:
|
case LFUN_EMPH:
|
||||||
flag.setOnOff(font.emph() == LyXFont::ON);
|
flag.setOnOff(font.emph() == LyXFont::ON);
|
||||||
break;
|
break;
|
||||||
@ -753,7 +751,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
string tc = mathcursor::getLastCode();
|
string tc = mathcursor::getLastCode();
|
||||||
switch (ev.action) {
|
switch (cmd.action) {
|
||||||
case LFUN_BOLD:
|
case LFUN_BOLD:
|
||||||
flag.setOnOff(tc == "mathbf");
|
flag.setOnOff(tc == "mathbf");
|
||||||
break;
|
break;
|
||||||
@ -783,10 +781,11 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & ev) const
|
|||||||
|
|
||||||
// this one is difficult to get right. As a half-baked
|
// this one is difficult to get right. As a half-baked
|
||||||
// solution, we consider only the first action of the sequence
|
// solution, we consider only the first action of the sequence
|
||||||
if (ev.action == LFUN_SEQUENCE) {
|
if (cmd.action == LFUN_SEQUENCE) {
|
||||||
// argument contains ';'-terminated commands
|
// argument contains ';'-terminated commands
|
||||||
#warning LyXAction arguments not handled here.
|
#warning LyXAction arguments not handled here.
|
||||||
flag = getStatus(FuncRequest(lyxaction.lookupFunc(token(ev.argument, ';', 0))));
|
flag = getStatus(FuncRequest(
|
||||||
|
lyxaction.lookupFunc(token(cmd.argument, ';', 0))));
|
||||||
}
|
}
|
||||||
|
|
||||||
return flag;
|
return flag;
|
||||||
@ -1750,7 +1749,7 @@ string const LyXFunc::view_status_message()
|
|||||||
if (!view()->available())
|
if (!view()->available())
|
||||||
return _("Welcome to LyX!");
|
return _("Welcome to LyX!");
|
||||||
|
|
||||||
return currentState(view());
|
return view()->cursor().currentState();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -79,22 +79,19 @@ public:
|
|||||||
ParagraphList::iterator end,
|
ParagraphList::iterator end,
|
||||||
std::string const & layout);
|
std::string const & layout);
|
||||||
///
|
///
|
||||||
void setLayout(std::string const & layout);
|
void setLayout(LCursor & cur, std::string const & layout);
|
||||||
|
|
||||||
/// Increase or decrease the nesting depth of the selected paragraph(s)
|
/// Increase or decrease the nesting depth of the selected paragraph(s)
|
||||||
void changeDepth(bv_funcs::DEPTH_CHANGE type);
|
void changeDepth(LCursor & cur, bv_funcs::DEPTH_CHANGE type);
|
||||||
|
|
||||||
/// Returns whether something would be changed by changeDepth
|
/// Returns whether something would be changed by changeDepth
|
||||||
bool changeDepthAllowed(bv_funcs::DEPTH_CHANGE type);
|
bool changeDepthAllowed(LCursor & cur, bv_funcs::DEPTH_CHANGE type);
|
||||||
|
|
||||||
/// get the depth at current cursor position
|
/// get the depth at current cursor position
|
||||||
int getDepth() const;
|
int getDepth() const;
|
||||||
|
|
||||||
/** set font over selection and make a total rebreak of those
|
/// Set font over selection paragraphs and rebreak.
|
||||||
paragraphs.
|
void setFont(LCursor & cur, LyXFont const &, bool toggleall = false);
|
||||||
toggleall defaults to false.
|
|
||||||
*/
|
|
||||||
void setFont(LyXFont const &, bool toggleall = false);
|
|
||||||
|
|
||||||
/// rebreaks all paragaphs between the given pars.
|
/// rebreaks all paragaphs between the given pars.
|
||||||
void redoParagraphs(ParagraphList::iterator begin,
|
void redoParagraphs(ParagraphList::iterator begin,
|
||||||
@ -102,18 +99,18 @@ public:
|
|||||||
/// rebreaks the given par
|
/// rebreaks the given par
|
||||||
void redoParagraph(ParagraphList::iterator pit);
|
void redoParagraph(ParagraphList::iterator pit);
|
||||||
/// rebreaks the cursor par
|
/// rebreaks the cursor par
|
||||||
void redoParagraph();
|
void redoParagraph(LCursor & cur);
|
||||||
|
|
||||||
///
|
///
|
||||||
void toggleFree(LyXFont const &, bool toggleall = false);
|
void toggleFree(LCursor & cur, LyXFont const &, bool toggleall = false);
|
||||||
|
|
||||||
///
|
///
|
||||||
std::string getStringToIndex();
|
std::string getStringToIndex(LCursor & cur);
|
||||||
|
|
||||||
/// insert a character at cursor position
|
/// insert a character at cursor position
|
||||||
void insertChar(char c);
|
void insertChar(LCursor & cur, char c);
|
||||||
/// insert an inset at cursor position
|
/// insert an inset at cursor position
|
||||||
void insertInset(InsetBase * inset);
|
void insertInset(LCursor & cur, InsetBase * inset);
|
||||||
|
|
||||||
/// a full rebreak of the whole text
|
/// a full rebreak of the whole text
|
||||||
void fullRebreak();
|
void fullRebreak();
|
||||||
@ -137,10 +134,10 @@ public:
|
|||||||
ParagraphList::iterator getPar(lyx::paroffset_type par) const;
|
ParagraphList::iterator getPar(lyx::paroffset_type par) const;
|
||||||
///
|
///
|
||||||
int parOffset(ParagraphList::iterator pit) const;
|
int parOffset(ParagraphList::iterator pit) const;
|
||||||
/// convenience
|
/// # FIXME: should not be used
|
||||||
ParagraphList::iterator cursorPar() const;
|
ParagraphList::iterator cursorPar() const;
|
||||||
///
|
// Returns the current font and depth as a message.
|
||||||
RowList::iterator cursorRow() const;
|
std::string LyXText::currentState(LCursor & cur);
|
||||||
|
|
||||||
/** returns an iterator pointing to the row near the specified
|
/** returns an iterator pointing to the row near the specified
|
||||||
* y-coordinate (relative to the whole text). y is set to the
|
* y-coordinate (relative to the whole text). y is set to the
|
||||||
@ -162,12 +159,12 @@ public:
|
|||||||
*/
|
*/
|
||||||
void getWord(CursorSlice & from, CursorSlice & to, lyx::word_location const);
|
void getWord(CursorSlice & from, CursorSlice & to, lyx::word_location const);
|
||||||
/// just selects the word the cursor is in
|
/// just selects the word the cursor is in
|
||||||
void selectWord(lyx::word_location loc);
|
void selectWord(LCursor & cur, lyx::word_location loc);
|
||||||
|
|
||||||
/// accept selected change
|
/// accept selected change
|
||||||
void acceptChange();
|
void acceptChange(LCursor & cur);
|
||||||
/// reject selected change
|
/// reject selected change
|
||||||
void rejectChange();
|
void rejectChange(LCursor & cur);
|
||||||
|
|
||||||
/// returns true if par was empty and was removed
|
/// returns true if par was empty and was removed
|
||||||
bool setCursor(lyx::paroffset_type par, lyx::pos_type pos,
|
bool setCursor(lyx::paroffset_type par, lyx::pos_type pos,
|
||||||
@ -224,7 +221,7 @@ public:
|
|||||||
///
|
///
|
||||||
void backspace(LCursor & cur);
|
void backspace(LCursor & cur);
|
||||||
///
|
///
|
||||||
bool selectWordWhenUnderCursor(lyx::word_location);
|
bool selectWordWhenUnderCursor(LCursor & cur, lyx::word_location);
|
||||||
///
|
///
|
||||||
enum TextCase {
|
enum TextCase {
|
||||||
///
|
///
|
||||||
@ -235,16 +232,16 @@ public:
|
|||||||
text_uppercase = 2
|
text_uppercase = 2
|
||||||
};
|
};
|
||||||
/// Change the case of the word at cursor position.
|
/// Change the case of the word at cursor position.
|
||||||
void changeCase(TextCase action);
|
void changeCase(LCursor & cur, TextCase action);
|
||||||
|
|
||||||
/// returns success
|
/// returns success
|
||||||
bool toggleInset();
|
bool toggleInset(LCursor & cur);
|
||||||
///
|
///
|
||||||
void cutSelection(bool doclear = true, bool realcut = true);
|
void cutSelection(bool doclear = true, bool realcut = true);
|
||||||
///
|
///
|
||||||
void copySelection();
|
void copySelection();
|
||||||
///
|
///
|
||||||
void pasteSelection(size_t sel_index = 0);
|
void pasteSelection(LCursor & cur, size_t sel_index = 0);
|
||||||
|
|
||||||
/** the DTP switches for paragraphs. LyX will store the top settings
|
/** the DTP switches for paragraphs. LyX will store the top settings
|
||||||
always in the first physical paragraph, the bottom settings in the
|
always in the first physical paragraph, the bottom settings in the
|
||||||
@ -263,16 +260,16 @@ public:
|
|||||||
* Sets the selection from the current cursor position to length
|
* Sets the selection from the current cursor position to length
|
||||||
* characters to the right. No safety checks.
|
* characters to the right. No safety checks.
|
||||||
*/
|
*/
|
||||||
void setSelectionRange(lyx::pos_type length);
|
void setSelectionRange(LCursor & cur, lyx::pos_type length);
|
||||||
/** simple replacing. The font of the first selected character
|
/// simply replace using the font of the first selected character
|
||||||
is used
|
void replaceSelectionWithString(LCursor & cur, std::string const & str);
|
||||||
*/
|
/// replace selection helper
|
||||||
void replaceSelectionWithString(std::string const & str);
|
void replaceSelection(LCursor & cur);
|
||||||
|
|
||||||
/// needed to insert the selection
|
/// needed to insert the selection
|
||||||
void insertStringAsLines(std::string const & str);
|
void insertStringAsLines(LCursor & cur, std::string const & str);
|
||||||
/// needed to insert the selection
|
/// needed to insert the selection
|
||||||
void insertStringAsParagraphs(std::string const & str);
|
void insertStringAsParagraphs(LCursor & cur, std::string const & str);
|
||||||
|
|
||||||
/// Find next inset of some specified type.
|
/// Find next inset of some specified type.
|
||||||
bool gotoNextInset(std::vector<InsetOld_code> const & codes,
|
bool gotoNextInset(std::vector<InsetOld_code> const & codes,
|
||||||
|
249
src/text.C
249
src/text.C
@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
#include "lyxtext.h"
|
#include "lyxtext.h"
|
||||||
|
|
||||||
|
#include "author.h"
|
||||||
#include "buffer.h"
|
#include "buffer.h"
|
||||||
#include "bufferparams.h"
|
#include "bufferparams.h"
|
||||||
#include "BufferView.h"
|
#include "BufferView.h"
|
||||||
@ -50,10 +51,13 @@
|
|||||||
|
|
||||||
#include "support/lstrings.h"
|
#include "support/lstrings.h"
|
||||||
#include "support/textutils.h"
|
#include "support/textutils.h"
|
||||||
|
#include "support/tostr.h"
|
||||||
|
#include "support/std_sstream.h"
|
||||||
|
|
||||||
using lyx::pos_type;
|
using lyx::pos_type;
|
||||||
using lyx::word_location;
|
using lyx::word_location;
|
||||||
|
|
||||||
|
using lyx::support::bformat;
|
||||||
using lyx::support::contains;
|
using lyx::support::contains;
|
||||||
using lyx::support::lowercase;
|
using lyx::support::lowercase;
|
||||||
using lyx::support::uppercase;
|
using lyx::support::uppercase;
|
||||||
@ -834,25 +838,26 @@ void LyXText::breakParagraph(LCursor & cur, char keep_layout)
|
|||||||
|
|
||||||
|
|
||||||
// convenience function
|
// convenience function
|
||||||
void LyXText::redoParagraph()
|
void LyXText::redoParagraph(LCursor & cur)
|
||||||
{
|
{
|
||||||
bv()->cursor().clearSelection();
|
cur.clearSelection();
|
||||||
redoParagraph(cursorPar());
|
redoParagraph(getPar(cur.par()));
|
||||||
setCursorIntern(cursor().par(), cursor().pos());
|
setCursorIntern(cur.par(), cur.pos());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// insert a character, moves all the following breaks in the
|
// insert a character, moves all the following breaks in the
|
||||||
// same Paragraph one to the right and make a rebreak
|
// same Paragraph one to the right and make a rebreak
|
||||||
void LyXText::insertChar(char c)
|
void LyXText::insertChar(LCursor & cur, char c)
|
||||||
{
|
{
|
||||||
recordUndo(bv()->cursor(), Undo::INSERT);
|
recordUndo(cur, Undo::INSERT);
|
||||||
|
|
||||||
// When the free-spacing option is set for the current layout,
|
Paragraph & par = cur.paragraph();
|
||||||
// disable the double-space checking
|
// try to remove this
|
||||||
|
ParagraphList::iterator pit = getPar(cur.par());
|
||||||
|
|
||||||
bool const freeSpacing = cursorPar()->layout()->free_spacing ||
|
bool const freeSpacing = par.layout()->free_spacing ||
|
||||||
cursorPar()->isFreeSpacing();
|
par.isFreeSpacing();
|
||||||
|
|
||||||
if (lyxrc.auto_number) {
|
if (lyxrc.auto_number) {
|
||||||
static string const number_operators = "+-/*";
|
static string const number_operators = "+-/*";
|
||||||
@ -862,36 +867,28 @@ void LyXText::insertChar(char c)
|
|||||||
if (current_font.number() == LyXFont::ON) {
|
if (current_font.number() == LyXFont::ON) {
|
||||||
if (!IsDigit(c) && !contains(number_operators, c) &&
|
if (!IsDigit(c) && !contains(number_operators, c) &&
|
||||||
!(contains(number_seperators, c) &&
|
!(contains(number_seperators, c) &&
|
||||||
cursor().pos() >= 1 &&
|
cur.pos() != 0 &&
|
||||||
cursor().pos() < cursorPar()->size() &&
|
cur.pos() != cur.lastpos() &&
|
||||||
getFont(cursorPar(), cursor().pos()).number() == LyXFont::ON &&
|
getFont(pit, cur.pos()).number() == LyXFont::ON &&
|
||||||
getFont(cursorPar(), cursor().pos() - 1).number() == LyXFont::ON)
|
getFont(pit, cur.pos() - 1).number() == LyXFont::ON)
|
||||||
)
|
)
|
||||||
number(); // Set current_font.number to OFF
|
number(); // Set current_font.number to OFF
|
||||||
} else if (IsDigit(c) &&
|
} else if (IsDigit(c) &&
|
||||||
real_current_font.isVisibleRightToLeft()) {
|
real_current_font.isVisibleRightToLeft()) {
|
||||||
number(); // Set current_font.number to ON
|
number(); // Set current_font.number to ON
|
||||||
|
|
||||||
if (cursor().pos() > 0) {
|
if (cur.pos() != 0) {
|
||||||
char const c = cursorPar()->getChar(cursor().pos() - 1);
|
char const c = par.getChar(cur.pos() - 1);
|
||||||
if (contains(number_unary_operators, c) &&
|
if (contains(number_unary_operators, c) &&
|
||||||
(cursor().pos() == 1 ||
|
(cur.pos() == 1
|
||||||
cursorPar()->isSeparator(cursor().pos() - 2) ||
|
|| par.isSeparator(cur.pos() - 2)
|
||||||
cursorPar()->isNewline(cursor().pos() - 2))
|
|| par.isNewline(cur.pos() - 2))
|
||||||
) {
|
) {
|
||||||
setCharFont(
|
setCharFont(pit, cur.pos() - 1, current_font);
|
||||||
cursorPar(),
|
} else if (contains(number_seperators, c)
|
||||||
cursor().pos() - 1,
|
&& cur.pos() >= 2
|
||||||
current_font);
|
&& getFont(pit, cur.pos() - 2).number() == LyXFont::ON) {
|
||||||
} else if (contains(number_seperators, c) &&
|
setCharFont(pit, cur.pos() - 1, current_font);
|
||||||
cursor().pos() >= 2 &&
|
|
||||||
getFont(
|
|
||||||
cursorPar(),
|
|
||||||
cursor().pos() - 2).number() == LyXFont::ON) {
|
|
||||||
setCharFont(
|
|
||||||
cursorPar(),
|
|
||||||
cursor().pos() - 1,
|
|
||||||
current_font);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -913,36 +910,41 @@ void LyXText::insertChar(char c)
|
|||||||
LyXFont realtmpfont = real_current_font;
|
LyXFont realtmpfont = real_current_font;
|
||||||
LyXFont rawtmpfont = current_font;
|
LyXFont rawtmpfont = current_font;
|
||||||
|
|
||||||
|
// When the free-spacing option is set for the current layout,
|
||||||
|
// disable the double-space checking
|
||||||
if (!freeSpacing && IsLineSeparatorChar(c)) {
|
if (!freeSpacing && IsLineSeparatorChar(c)) {
|
||||||
if ((cursor().pos() > 0
|
if (cur.pos() == 0) {
|
||||||
&& cursorPar()->isLineSeparator(cursor().pos() - 1))
|
|
||||||
|| (cursor().pos() > 0
|
|
||||||
&& cursorPar()->isNewline(cursor().pos() - 1))
|
|
||||||
|| (cursor().pos() == 0)) {
|
|
||||||
static bool sent_space_message = false;
|
static bool sent_space_message = false;
|
||||||
if (!sent_space_message) {
|
if (!sent_space_message) {
|
||||||
if (cursor().pos() == 0)
|
cur.message(_("You cannot insert a space at the "
|
||||||
bv()->owner()->message(_("You cannot insert a space at the beginning of a paragraph. Please read the Tutorial."));
|
"beginning of a paragraph. Please read the Tutorial."));
|
||||||
else
|
sent_space_message = true;
|
||||||
bv()->owner()->message(_("You cannot type two spaces this way. Please read the Tutorial."));
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
BOOST_ASSERT(cur.pos() > 0);
|
||||||
|
if (par.isLineSeparator(cur.pos() - 1)
|
||||||
|
|| par.isNewline(cur.pos() - 1)) {
|
||||||
|
static bool sent_space_message = false;
|
||||||
|
if (!sent_space_message) {
|
||||||
|
cur.message(_("You cannot type two spaces this way. "
|
||||||
|
"Please read the Tutorial."));
|
||||||
sent_space_message = true;
|
sent_space_message = true;
|
||||||
}
|
}
|
||||||
charInserted();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Here case LyXText::InsertInset already inserted the character
|
// Here case LyXText::InsertInset already inserted the character
|
||||||
if (c != Paragraph::META_INSET)
|
if (c != Paragraph::META_INSET)
|
||||||
cursorPar()->insertChar(cursor().pos(), c);
|
par.insertChar(cur.pos(), c);
|
||||||
|
|
||||||
setCharFont(cursorPar(), cursor().pos(), rawtmpfont);
|
setCharFont(pit, cur.pos(), rawtmpfont);
|
||||||
|
|
||||||
current_font = rawtmpfont;
|
current_font = rawtmpfont;
|
||||||
real_current_font = realtmpfont;
|
real_current_font = realtmpfont;
|
||||||
redoParagraph(cursorPar());
|
redoParagraph(cur);
|
||||||
setCursor(cursor().par(), cursor().pos() + 1, false, cursor().boundary());
|
setCursor(cur.par(), cur.pos() + 1, false, cur.boundary());
|
||||||
|
|
||||||
charInserted();
|
charInserted();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1117,42 +1119,41 @@ void LyXText::cursorLeftOneWord(LCursor & cur)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::selectWord(word_location loc)
|
void LyXText::selectWord(LCursor & cur, word_location loc)
|
||||||
{
|
{
|
||||||
CursorSlice from = cursor();
|
CursorSlice from = cur.current();
|
||||||
CursorSlice to = cursor();
|
CursorSlice to = cur.current();
|
||||||
getWord(from, to, loc);
|
getWord(from, to, loc);
|
||||||
if (cursor() != from)
|
if (cur.current() != from)
|
||||||
setCursor(from.par(), from.pos());
|
setCursor(from.par(), from.pos());
|
||||||
if (to == from)
|
if (to == from)
|
||||||
return;
|
return;
|
||||||
bv()->cursor().resetAnchor();
|
cur.resetAnchor();
|
||||||
setCursor(to.par(), to.pos());
|
setCursor(to.par(), to.pos());
|
||||||
bv()->cursor().setSelection();
|
cur.setSelection();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Select the word currently under the cursor when no
|
// Select the word currently under the cursor when no
|
||||||
// selection is currently set
|
// selection is currently set
|
||||||
bool LyXText::selectWordWhenUnderCursor(word_location loc)
|
bool LyXText::selectWordWhenUnderCursor(LCursor & cur, word_location loc)
|
||||||
{
|
{
|
||||||
if (bv()->cursor().selection())
|
if (cur.selection())
|
||||||
return false;
|
return false;
|
||||||
selectWord(loc);
|
selectWord(cur, loc);
|
||||||
return bv()->cursor().selection();
|
return cur.selection();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::acceptChange()
|
void LyXText::acceptChange(LCursor & cur)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
if (!cur.selection() && cur.lastpos() != 0)
|
||||||
if (!cur.selection() && cursorPar()->size())
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (cur.selBegin().par() == cur.par()) {
|
|
||||||
CursorSlice const & startc = cur.selBegin();
|
CursorSlice const & startc = cur.selBegin();
|
||||||
CursorSlice const & endc = cur.selEnd();
|
CursorSlice const & endc = cur.selEnd();
|
||||||
recordUndo(cur, Undo::INSERT, cur.anchor().par());
|
if (startc.par() == endc.par()) {
|
||||||
|
recordUndoSelection(cur, Undo::INSERT);
|
||||||
getPar(startc)->acceptChange(startc.pos(), endc.pos());
|
getPar(startc)->acceptChange(startc.pos(), endc.pos());
|
||||||
finishUndo();
|
finishUndo();
|
||||||
cur.clearSelection();
|
cur.clearSelection();
|
||||||
@ -1163,16 +1164,15 @@ void LyXText::acceptChange()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::rejectChange()
|
void LyXText::rejectChange(LCursor & cur)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
if (!cur.selection() && cur.lastpos() != 0)
|
||||||
if (!cur.selection() && cursorPar()->size())
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (cur.selBegin().par() == cur.selEnd().par()) {
|
|
||||||
CursorSlice const & startc = cur.selBegin();
|
CursorSlice const & startc = cur.selBegin();
|
||||||
CursorSlice const & endc = cur.selEnd();
|
CursorSlice const & endc = cur.selEnd();
|
||||||
recordUndo(cur, Undo::INSERT, cur.anchor().par());
|
if (startc.par() == endc.par()) {
|
||||||
|
recordUndoSelection(cur, Undo::INSERT);
|
||||||
getPar(startc)->rejectChange(startc.pos(), endc.pos());
|
getPar(startc)->rejectChange(startc.pos(), endc.pos());
|
||||||
finishUndo();
|
finishUndo();
|
||||||
cur.clearSelection();
|
cur.clearSelection();
|
||||||
@ -1233,9 +1233,8 @@ void LyXText::deleteLineForward(LCursor & cur)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::changeCase(LyXText::TextCase action)
|
void LyXText::changeCase(LCursor & cur, LyXText::TextCase action)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
|
||||||
CursorSlice from;
|
CursorSlice from;
|
||||||
CursorSlice to;
|
CursorSlice to;
|
||||||
|
|
||||||
@ -1248,7 +1247,7 @@ void LyXText::changeCase(LyXText::TextCase action)
|
|||||||
setCursor(to.par(), to.pos() + 1);
|
setCursor(to.par(), to.pos() + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
recordUndo(cur, Undo::ATOMIC, cur.anchor().par());
|
recordUndoSelection(cur);
|
||||||
|
|
||||||
pos_type pos = from.pos();
|
pos_type pos = from.pos();
|
||||||
int par = from.par();
|
int par = from.par();
|
||||||
@ -1298,23 +1297,21 @@ void LyXText::Delete(LCursor & cur)
|
|||||||
|
|
||||||
void LyXText::backspace(LCursor & cur)
|
void LyXText::backspace(LCursor & cur)
|
||||||
{
|
{
|
||||||
// Get the font that is used to calculate the baselineskip
|
|
||||||
ParagraphList::iterator pit = cursorPar();
|
|
||||||
pos_type lastpos = pit->size();
|
|
||||||
|
|
||||||
if (cur.pos() == 0) {
|
if (cur.pos() == 0) {
|
||||||
// The cursor is at the beginning of a paragraph, so
|
// The cursor is at the beginning of a paragraph, so
|
||||||
// the the backspace will collapse two paragraphs into
|
// the the backspace will collapse two paragraphs into
|
||||||
// one.
|
// one.
|
||||||
|
|
||||||
// but it's not allowed unless it's new
|
// but it's not allowed unless it's new
|
||||||
if (pit->isChangeEdited(0, pit->size()))
|
Paragraph & par = cur.paragraph();
|
||||||
|
if (par.isChangeEdited(0, par.size()))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// we may paste some paragraphs
|
// we may paste some paragraphs
|
||||||
|
|
||||||
// is it an empty paragraph?
|
// is it an empty paragraph?
|
||||||
if (lastpos == 0 || (lastpos == 1 && pit->isSeparator(0))) {
|
pos_type lastpos = cur.lastpos();
|
||||||
|
if (lastpos == 0 || (lastpos == 1 && par.isSeparator(0))) {
|
||||||
// This is an empty paragraph and we delete it just
|
// This is an empty paragraph and we delete it just
|
||||||
// by moving the cursor one step
|
// by moving the cursor one step
|
||||||
// left and let the DeleteEmptyParagraphMechanism
|
// left and let the DeleteEmptyParagraphMechanism
|
||||||
@ -1323,7 +1320,7 @@ void LyXText::backspace(LCursor & cur)
|
|||||||
if (cur.par() != 0) {
|
if (cur.par() != 0) {
|
||||||
cursorLeft(cur, true);
|
cursorLeft(cur, true);
|
||||||
// the layout things can change the height of a row !
|
// the layout things can change the height of a row !
|
||||||
redoParagraph();
|
redoParagraph(cur);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1331,7 +1328,7 @@ void LyXText::backspace(LCursor & cur)
|
|||||||
if (cur.par() != 0)
|
if (cur.par() != 0)
|
||||||
recordUndo(cur, Undo::DELETE, cur.par() - 1);
|
recordUndo(cur, Undo::DELETE, cur.par() - 1);
|
||||||
|
|
||||||
ParagraphList::iterator tmppit = cursorPar();
|
ParagraphList::iterator tmppit = getPar(cur.par());
|
||||||
// We used to do cursorLeftIntern() here, but it is
|
// We used to do cursorLeftIntern() here, but it is
|
||||||
// not a good idea since it triggers the auto-delete
|
// not a good idea since it triggers the auto-delete
|
||||||
// mechanism. So we do a cursorLeftIntern()-lite,
|
// mechanism. So we do a cursorLeftIntern()-lite,
|
||||||
@ -1350,7 +1347,7 @@ void LyXText::backspace(LCursor & cur)
|
|||||||
Buffer & buf = *bv()->buffer();
|
Buffer & buf = *bv()->buffer();
|
||||||
BufferParams const & bufparams = buf.params();
|
BufferParams const & bufparams = buf.params();
|
||||||
LyXTextClass const & tclass = bufparams.getLyXTextClass();
|
LyXTextClass const & tclass = bufparams.getLyXTextClass();
|
||||||
ParagraphList::iterator const cpit = cursorPar();
|
ParagraphList::iterator const cpit = getPar(cur.par());
|
||||||
|
|
||||||
if (cpit != tmppit
|
if (cpit != tmppit
|
||||||
&& (cpit->layout() == tmppit->layout()
|
&& (cpit->layout() == tmppit->layout()
|
||||||
@ -1381,7 +1378,7 @@ void LyXText::backspace(LCursor & cur)
|
|||||||
if (cur.pos() == cur.lastpos())
|
if (cur.pos() == cur.lastpos())
|
||||||
setCurrentFont();
|
setCurrentFont();
|
||||||
|
|
||||||
redoParagraph();
|
redoParagraph(cur);
|
||||||
setCursor(cur.par(), cur.pos(), false, cur.boundary());
|
setCursor(cur.par(), cur.pos(), false, cur.boundary());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1394,12 +1391,6 @@ ParagraphList::iterator LyXText::cursorPar() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
RowList::iterator LyXText::cursorRow() const
|
|
||||||
{
|
|
||||||
return cursorPar()->getRow(cursor().pos());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
ParagraphList::iterator LyXText::getPar(CursorSlice const & cur) const
|
ParagraphList::iterator LyXText::getPar(CursorSlice const & cur) const
|
||||||
{
|
{
|
||||||
return getPar(cur.par());
|
return getPar(cur.par());
|
||||||
@ -1861,3 +1852,89 @@ CursorSlice const & LyXText::cursor() const
|
|||||||
}
|
}
|
||||||
return bv()->cursor().current();
|
return bv()->cursor().current();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void LyXText::replaceSelection(LCursor & cur)
|
||||||
|
{
|
||||||
|
if (cur.selection()) {
|
||||||
|
cutSelection(true, false);
|
||||||
|
bv()->update();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Returns the current font and depth as a message.
|
||||||
|
string LyXText::currentState(LCursor & cur)
|
||||||
|
{
|
||||||
|
Buffer * buffer = bv()->buffer();
|
||||||
|
Paragraph const & par = cur.paragraph();
|
||||||
|
std::ostringstream os;
|
||||||
|
|
||||||
|
bool const show_change = buffer->params().tracking_changes
|
||||||
|
&& cur.pos() != cur.lastpos()
|
||||||
|
&& par.lookupChange(cur.pos()) != Change::UNCHANGED;
|
||||||
|
|
||||||
|
if (show_change) {
|
||||||
|
Change change = par.lookupChangeFull(cur.pos());
|
||||||
|
Author const & a = buffer->params().authors().get(change.author);
|
||||||
|
os << _("Change: ") << a.name();
|
||||||
|
if (!a.email().empty())
|
||||||
|
os << " (" << a.email() << ")";
|
||||||
|
if (change.changetime)
|
||||||
|
os << _(" at ") << ctime(&change.changetime);
|
||||||
|
os << " : ";
|
||||||
|
}
|
||||||
|
|
||||||
|
// I think we should only show changes from the default
|
||||||
|
// font. (Asger)
|
||||||
|
LyXFont font = real_current_font;
|
||||||
|
font.reduce(buffer->params().getLyXTextClass().defaultfont());
|
||||||
|
|
||||||
|
// avoid _(...) re-entrance problem
|
||||||
|
string const s = font.stateText(&buffer->params());
|
||||||
|
os << bformat(_("Font: %1$s"), s);
|
||||||
|
|
||||||
|
// os << bformat(_("Font: %1$s"), font.stateText(&buffer->params));
|
||||||
|
|
||||||
|
// The paragraph depth
|
||||||
|
int depth = getDepth();
|
||||||
|
if (depth > 0)
|
||||||
|
os << bformat(_(", Depth: %1$s"), tostr(depth));
|
||||||
|
|
||||||
|
// The paragraph spacing, but only if different from
|
||||||
|
// buffer spacing.
|
||||||
|
Spacing const & spacing = par.params().spacing();
|
||||||
|
if (!spacing.isDefault()) {
|
||||||
|
os << _(", Spacing: ");
|
||||||
|
switch (spacing.getSpace()) {
|
||||||
|
case Spacing::Single:
|
||||||
|
os << _("Single");
|
||||||
|
break;
|
||||||
|
case Spacing::Onehalf:
|
||||||
|
os << _("OneHalf");
|
||||||
|
break;
|
||||||
|
case Spacing::Double:
|
||||||
|
os << _("Double");
|
||||||
|
break;
|
||||||
|
case Spacing::Other:
|
||||||
|
os << _("Other (") << spacing.getValue() << ')';
|
||||||
|
break;
|
||||||
|
case Spacing::Default:
|
||||||
|
// should never happen, do nothing
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#ifdef DEVEL_VERSION
|
||||||
|
os << _(", Paragraph: ") << par.id();
|
||||||
|
os << _(", Position: ") << cur.pos();
|
||||||
|
Row & row = cur.textRow();
|
||||||
|
os << bformat(_(", Row b:%1$d e:%2$d"), row.pos(), row.endpos());
|
||||||
|
os << _(", Inset: ");
|
||||||
|
InsetOld * inset = par.inInset();
|
||||||
|
if (inset)
|
||||||
|
os << inset << " owner: " << inset->owner();
|
||||||
|
else
|
||||||
|
os << -1;
|
||||||
|
#endif
|
||||||
|
return os.str();
|
||||||
|
}
|
||||||
|
140
src/text2.C
140
src/text2.C
@ -279,7 +279,7 @@ LyXText::setLayout(ParagraphList::iterator start,
|
|||||||
|
|
||||||
|
|
||||||
// set layout over selection and make a total rebreak of those paragraphs
|
// set layout over selection and make a total rebreak of those paragraphs
|
||||||
void LyXText::setLayout(string const & layout)
|
void LyXText::setLayout(LCursor & cur, string const & layout)
|
||||||
{
|
{
|
||||||
// special handling of new environment insets
|
// special handling of new environment insets
|
||||||
BufferParams const & params = bv()->buffer()->params();
|
BufferParams const & params = bv()->buffer()->params();
|
||||||
@ -291,18 +291,15 @@ void LyXText::setLayout(string const & layout)
|
|||||||
bv()->owner()->dispatch(FuncRequest(LFUN_ENDSEL));
|
bv()->owner()->dispatch(FuncRequest(LFUN_ENDSEL));
|
||||||
bv()->owner()->dispatch(FuncRequest(LFUN_CUT));
|
bv()->owner()->dispatch(FuncRequest(LFUN_CUT));
|
||||||
InsetBase * inset = new InsetEnvironment(params, layout);
|
InsetBase * inset = new InsetEnvironment(params, layout);
|
||||||
insertInset(inset);
|
insertInset(cur, inset);
|
||||||
//inset->edit(bv());
|
//inset->edit(bv());
|
||||||
//bv()->owner()->dispatch(FuncRequest(LFUN_PASTE));
|
//bv()->owner()->dispatch(FuncRequest(LFUN_PASTE));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ParagraphList::iterator start =
|
ParagraphList::iterator start = getPar(cur.selBegin().par());
|
||||||
getPar(bv()->cursor().selBegin().par());
|
ParagraphList::iterator end = boost::next(getPar(cur.selEnd().par()));
|
||||||
ParagraphList::iterator end =
|
|
||||||
boost::next(getPar(bv()->cursor().selEnd().par()));
|
|
||||||
ParagraphList::iterator endpit = setLayout(start, end, layout);
|
ParagraphList::iterator endpit = setLayout(start, end, layout);
|
||||||
|
|
||||||
redoParagraphs(start, endpit);
|
redoParagraphs(start, endpit);
|
||||||
updateCounters();
|
updateCounters();
|
||||||
}
|
}
|
||||||
@ -311,16 +308,16 @@ void LyXText::setLayout(string const & layout)
|
|||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
|
||||||
void getSelectionSpan(LyXText & text,
|
void getSelectionSpan(LCursor & cur, LyXText & text,
|
||||||
ParagraphList::iterator & beg,
|
ParagraphList::iterator & beg,
|
||||||
ParagraphList::iterator & end)
|
ParagraphList::iterator & end)
|
||||||
{
|
{
|
||||||
if (!text.bv()->cursor().selection()) {
|
if (!cur.selection()) {
|
||||||
beg = text.cursorPar();
|
beg = text.getPar(cur.par());
|
||||||
end = boost::next(beg);
|
end = boost::next(beg);
|
||||||
} else {
|
} else {
|
||||||
beg = text.getPar(text.bv()->cursor().selBegin());
|
beg = text.getPar(cur.selBegin());
|
||||||
end = boost::next(text.getPar(text.bv()->cursor().selEnd()));
|
end = boost::next(text.getPar(cur.selEnd()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -343,10 +340,10 @@ bool changeDepthAllowed(bv_funcs::DEPTH_CHANGE type,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool LyXText::changeDepthAllowed(bv_funcs::DEPTH_CHANGE type)
|
bool LyXText::changeDepthAllowed(LCursor & cur, bv_funcs::DEPTH_CHANGE type)
|
||||||
{
|
{
|
||||||
ParagraphList::iterator beg, end;
|
ParagraphList::iterator beg, end;
|
||||||
getSelectionSpan(*this, beg, end);
|
getSelectionSpan(cur, *this, beg, end);
|
||||||
int max_depth = 0;
|
int max_depth = 0;
|
||||||
if (beg != paragraphs().begin())
|
if (beg != paragraphs().begin())
|
||||||
max_depth = boost::prior(beg)->getMaxDepthAfter();
|
max_depth = boost::prior(beg)->getMaxDepthAfter();
|
||||||
@ -360,12 +357,11 @@ bool LyXText::changeDepthAllowed(bv_funcs::DEPTH_CHANGE type)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::changeDepth(bv_funcs::DEPTH_CHANGE type)
|
void LyXText::changeDepth(LCursor & cur, bv_funcs::DEPTH_CHANGE type)
|
||||||
{
|
{
|
||||||
ParagraphList::iterator beg, end;
|
ParagraphList::iterator beg, end;
|
||||||
getSelectionSpan(*this, beg, end);
|
getSelectionSpan(cur, *this, beg, end);
|
||||||
|
recordUndoSelection(cur);
|
||||||
recUndo(parOffset(beg), parOffset(end) - 1);
|
|
||||||
|
|
||||||
int max_depth = 0;
|
int max_depth = 0;
|
||||||
if (beg != paragraphs().begin())
|
if (beg != paragraphs().begin())
|
||||||
@ -388,17 +384,17 @@ void LyXText::changeDepth(bv_funcs::DEPTH_CHANGE type)
|
|||||||
|
|
||||||
|
|
||||||
// set font over selection and make a total rebreak of those paragraphs
|
// set font over selection and make a total rebreak of those paragraphs
|
||||||
void LyXText::setFont(LyXFont const & font, bool toggleall)
|
void LyXText::setFont(LCursor & cur, LyXFont const & font, bool toggleall)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
|
||||||
// if there is no selection just set the current_font
|
// if there is no selection just set the current_font
|
||||||
if (!cur.selection()) {
|
if (!cur.selection()) {
|
||||||
// Determine basis font
|
// Determine basis font
|
||||||
LyXFont layoutfont;
|
LyXFont layoutfont;
|
||||||
if (cursor().pos() < cursorPar()->beginOfBody())
|
ParagraphList::iterator pit = getPar(cur.par());
|
||||||
layoutfont = getLabelFont(cursorPar());
|
if (cur.pos() < pit->beginOfBody())
|
||||||
|
layoutfont = getLabelFont(pit);
|
||||||
else
|
else
|
||||||
layoutfont = getLayoutFont(cursorPar());
|
layoutfont = getLayoutFont(pit);
|
||||||
|
|
||||||
// Update current font
|
// Update current font
|
||||||
real_current_font.update(font,
|
real_current_font.update(font,
|
||||||
@ -415,7 +411,7 @@ void LyXText::setFont(LyXFont const & font, bool toggleall)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ok we have a selection.
|
// ok we have a selection.
|
||||||
recUndo(cur.selBegin().par(), cur.selEnd().par());
|
recordUndoSelection(cur);
|
||||||
freezeUndo();
|
freezeUndo();
|
||||||
|
|
||||||
ParagraphList::iterator beg = getPar(cur.selBegin().par());
|
ParagraphList::iterator beg = getPar(cur.selBegin().par());
|
||||||
@ -468,12 +464,12 @@ void LyXText::cursorBottom(LCursor & cur)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::toggleFree(LyXFont const & font, bool toggleall)
|
void LyXText::toggleFree(LCursor & cur, LyXFont const & font, bool toggleall)
|
||||||
{
|
{
|
||||||
// If the mask is completely neutral, tell user
|
// If the mask is completely neutral, tell user
|
||||||
if (font == LyXFont(LyXFont::ALL_IGNORE)) {
|
if (font == LyXFont(LyXFont::ALL_IGNORE)) {
|
||||||
// Could only happen with user style
|
// Could only happen with user style
|
||||||
bv()->owner()->message(_("No font change defined. "
|
cur.message(_("No font change defined. "
|
||||||
"Use Character under the Layout menu to define font change."));
|
"Use Character under the Layout menu to define font change."));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -481,45 +477,44 @@ void LyXText::toggleFree(LyXFont const & font, bool toggleall)
|
|||||||
// Try implicit word selection
|
// Try implicit word selection
|
||||||
// If there is a change in the language the implicit word selection
|
// If there is a change in the language the implicit word selection
|
||||||
// is disabled.
|
// is disabled.
|
||||||
CursorSlice resetCursor = cursor();
|
CursorSlice resetCursor = cur.current();
|
||||||
bool implicitSelection =
|
bool implicitSelection =
|
||||||
font.language() == ignore_language
|
font.language() == ignore_language
|
||||||
&& font.number() == LyXFont::IGNORE
|
&& font.number() == LyXFont::IGNORE
|
||||||
&& selectWordWhenUnderCursor(lyx::WHOLE_WORD_STRICT);
|
&& selectWordWhenUnderCursor(cur, lyx::WHOLE_WORD_STRICT);
|
||||||
|
|
||||||
// Set font
|
// Set font
|
||||||
setFont(font, toggleall);
|
setFont(cur, font, toggleall);
|
||||||
|
|
||||||
// Implicit selections are cleared afterwards
|
// Implicit selections are cleared afterwards
|
||||||
// and cursor is set to the original position.
|
// and cursor is set to the original position.
|
||||||
if (implicitSelection) {
|
if (implicitSelection) {
|
||||||
bv()->cursor().clearSelection();
|
cur.clearSelection();
|
||||||
cursor() = resetCursor;
|
cur.current() = resetCursor;
|
||||||
bv()->cursor().resetAnchor();
|
cur.resetAnchor();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
string LyXText::getStringToIndex()
|
string LyXText::getStringToIndex(LCursor & cur)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
|
||||||
// Try implicit word selection
|
// Try implicit word selection
|
||||||
// If there is a change in the language the implicit word selection
|
// If there is a change in the language the implicit word selection
|
||||||
// is disabled.
|
// is disabled.
|
||||||
CursorSlice const reset_cursor = cursor();
|
CursorSlice const reset_cursor = cur.current();
|
||||||
bool const implicitSelection =
|
bool const implicitSelection =
|
||||||
selectWordWhenUnderCursor(lyx::PREVIOUS_WORD);
|
selectWordWhenUnderCursor(cur, lyx::PREVIOUS_WORD);
|
||||||
|
|
||||||
string idxstring;
|
string idxstring;
|
||||||
if (!cur.selection())
|
if (!cur.selection())
|
||||||
bv()->owner()->message(_("Nothing to index!"));
|
cur.message(_("Nothing to index!"));
|
||||||
else if (cur.selBegin().par() != cur.selEnd().par())
|
else if (cur.selBegin().par() != cur.selEnd().par())
|
||||||
bv()->owner()->message(_("Cannot index more than one paragraph!"));
|
cur.message(_("Cannot index more than one paragraph!"));
|
||||||
else
|
else
|
||||||
idxstring = cur.selectionAsString(false);
|
idxstring = cur.selectionAsString(false);
|
||||||
|
|
||||||
// Reset cursors to their original position.
|
// Reset cursors to their original position.
|
||||||
cursor() = reset_cursor;
|
cur.current() = reset_cursor;
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
|
|
||||||
// Clear the implicit selection.
|
// Clear the implicit selection.
|
||||||
@ -859,24 +854,20 @@ void LyXText::updateCounters()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::insertInset(InsetBase * inset)
|
void LyXText::insertInset(LCursor & cur, InsetBase * inset)
|
||||||
{
|
{
|
||||||
if (!cursorPar()->insetAllowed(inset->lyxCode()))
|
recordUndo(cur);
|
||||||
return;
|
|
||||||
|
|
||||||
recUndo(cursor().par());
|
|
||||||
freezeUndo();
|
freezeUndo();
|
||||||
cursorPar()->insertInset(cursor().pos(), inset);
|
cur.paragraph().insertInset(cur.pos(), inset);
|
||||||
// Just to rebreak and refresh correctly.
|
// Just to rebreak and refresh correctly.
|
||||||
// The character will not be inserted a second time
|
// The character will not be inserted a second time
|
||||||
insertChar(Paragraph::META_INSET);
|
insertChar(cur, Paragraph::META_INSET);
|
||||||
// If we enter a highly editable inset the cursor should be before
|
// If we enter a highly editable inset the cursor should be before
|
||||||
// the inset. After an undo LyX tries to call inset->edit(...)
|
// the inset. After an undo LyX tries to call inset->edit(...)
|
||||||
// and fails if the cursor is behind the inset and getInset
|
// and fails if the cursor is behind the inset and getInset
|
||||||
// does not return the inset!
|
// does not return the inset!
|
||||||
if (isHighlyEditableInset(inset))
|
if (isHighlyEditableInset(inset))
|
||||||
cursorLeft(bv()->cursor(), true);
|
cursorLeft(cur, true);
|
||||||
|
|
||||||
unFreezeUndo();
|
unFreezeUndo();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -902,10 +893,10 @@ void LyXText::cutSelection(bool doclear, bool realcut)
|
|||||||
// and cur.selEnd()
|
// and cur.selEnd()
|
||||||
|
|
||||||
// make sure that the depth behind the selection are restored, too
|
// make sure that the depth behind the selection are restored, too
|
||||||
|
recordUndoSelection(cur);
|
||||||
ParagraphList::iterator begpit = getPar(cur.selBegin().par());
|
ParagraphList::iterator begpit = getPar(cur.selBegin().par());
|
||||||
ParagraphList::iterator endpit = getPar(cur.selEnd().par());
|
ParagraphList::iterator endpit = getPar(cur.selEnd().par());
|
||||||
ParagraphList::iterator undopit = undoSpan(endpit);
|
ParagraphList::iterator undopit = undoSpan(endpit);
|
||||||
recUndo(cur.selBegin().par(), parOffset(undopit) - 1);
|
|
||||||
|
|
||||||
int endpos = cur.selEnd().pos();
|
int endpos = cur.selEnd().pos();
|
||||||
|
|
||||||
@ -930,8 +921,8 @@ void LyXText::cutSelection(bool doclear, bool realcut)
|
|||||||
// cutSelection can invalidate the cursor so we need to set
|
// cutSelection can invalidate the cursor so we need to set
|
||||||
// it anew. (Lgb)
|
// it anew. (Lgb)
|
||||||
// we prefer the end for when tracking changes
|
// we prefer the end for when tracking changes
|
||||||
cursor().pos(endpos);
|
cur.pos() = endpos;
|
||||||
cursor().par(parOffset(endpit));
|
cur.par() = parOffset(endpit);
|
||||||
|
|
||||||
// need a valid cursor. (Lgb)
|
// need a valid cursor. (Lgb)
|
||||||
cur.clearSelection();
|
cur.clearSelection();
|
||||||
@ -967,14 +958,13 @@ void LyXText::copySelection()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::pasteSelection(size_t sel_index)
|
void LyXText::pasteSelection(LCursor & cur, size_t sel_index)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
|
||||||
// this does not make sense, if there is nothing to paste
|
// this does not make sense, if there is nothing to paste
|
||||||
if (!CutAndPaste::checkPastePossible())
|
if (!CutAndPaste::checkPastePossible())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
recUndo(cursor().par());
|
recordUndo(cur);
|
||||||
|
|
||||||
ParagraphList::iterator endpit;
|
ParagraphList::iterator endpit;
|
||||||
PitPosPair ppp;
|
PitPosPair ppp;
|
||||||
@ -1000,12 +990,10 @@ void LyXText::pasteSelection(size_t sel_index)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LyXText::setSelectionRange(lyx::pos_type length)
|
void LyXText::setSelectionRange(LCursor & cur, lyx::pos_type length)
|
||||||
{
|
{
|
||||||
if (!length)
|
if (!length)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
LCursor & cur = bv()->cursor();
|
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
while (length--)
|
while (length--)
|
||||||
cursorRight(cur, true);
|
cursorRight(cur, true);
|
||||||
@ -1014,10 +1002,9 @@ void LyXText::setSelectionRange(lyx::pos_type length)
|
|||||||
|
|
||||||
|
|
||||||
// simple replacing. The font of the first selected character is used
|
// simple replacing. The font of the first selected character is used
|
||||||
void LyXText::replaceSelectionWithString(string const & str)
|
void LyXText::replaceSelectionWithString(LCursor & cur, string const & str)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
recordUndo(cur);
|
||||||
recUndo(cur.par());
|
|
||||||
freezeUndo();
|
freezeUndo();
|
||||||
|
|
||||||
// Get font setting before we cut
|
// Get font setting before we cut
|
||||||
@ -1042,34 +1029,32 @@ void LyXText::replaceSelectionWithString(string const & str)
|
|||||||
|
|
||||||
|
|
||||||
// needed to insert the selection
|
// needed to insert the selection
|
||||||
void LyXText::insertStringAsLines(string const & str)
|
void LyXText::insertStringAsLines(LCursor & cur, string const & str)
|
||||||
{
|
{
|
||||||
LCursor & cur = bv()->cursor();
|
ParagraphList::iterator pit = getPar(cur.par());
|
||||||
ParagraphList::iterator pit = cursorPar();
|
ParagraphList::iterator endpit = boost::next(pit);
|
||||||
pos_type pos = cursor().pos();
|
pos_type pos = cursor().pos();
|
||||||
ParagraphList::iterator endpit = boost::next(cursorPar());
|
recordUndo(cur);
|
||||||
recordUndo(cur, Undo::ATOMIC);
|
|
||||||
|
|
||||||
// only to be sure, should not be neccessary
|
// only to be sure, should not be neccessary
|
||||||
cur.clearSelection();
|
cur.clearSelection();
|
||||||
bv()->buffer()->insertStringAsLines(pit, pos, current_font, str);
|
bv()->buffer()->insertStringAsLines(pit, pos, current_font, str);
|
||||||
|
|
||||||
redoParagraphs(cursorPar(), endpit);
|
redoParagraphs(getPar(cur.par()), endpit);
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
setCursor(parOffset(pit), pos);
|
setCursor(cur.par(), pos);
|
||||||
cur.setSelection();
|
cur.setSelection();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// turn double CR to single CR, others are converted into one
|
// turn double CR to single CR, others are converted into one
|
||||||
// blank. Then insertStringAsLines is called
|
// blank. Then insertStringAsLines is called
|
||||||
void LyXText::insertStringAsParagraphs(string const & str)
|
void LyXText::insertStringAsParagraphs(LCursor & cur, string const & str)
|
||||||
{
|
{
|
||||||
string linestr(str);
|
string linestr = str;
|
||||||
bool newline_inserted = false;
|
bool newline_inserted = false;
|
||||||
string::size_type const siz = linestr.length();
|
|
||||||
|
|
||||||
for (string::size_type i = 0; i < siz; ++i) {
|
for (string::size_type i = 0, siz = linestr.size(); i < siz; ++i) {
|
||||||
if (linestr[i] == '\n') {
|
if (linestr[i] == '\n') {
|
||||||
if (newline_inserted) {
|
if (newline_inserted) {
|
||||||
// we know that \r will be ignored by
|
// we know that \r will be ignored by
|
||||||
@ -1085,7 +1070,7 @@ void LyXText::insertStringAsParagraphs(string const & str)
|
|||||||
newline_inserted = false;
|
newline_inserted = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
insertStringAsLines(linestr);
|
insertStringAsLines(cur, linestr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1197,6 +1182,7 @@ void LyXText::setCurrentFont()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// x is an absolute screen coord
|
// x is an absolute screen coord
|
||||||
// returns the column near the specified x-coordinate of the row
|
// returns the column near the specified x-coordinate of the row
|
||||||
// x is set to the real beginning of this column
|
// x is set to the real beginning of this column
|
||||||
@ -1479,7 +1465,7 @@ bool LyXText::cursorRight(LCursor & cur, bool internal)
|
|||||||
|
|
||||||
void LyXText::cursorUp(LCursor & cur, bool selecting)
|
void LyXText::cursorUp(LCursor & cur, bool selecting)
|
||||||
{
|
{
|
||||||
Row const & row = *cursorRow();
|
Row const & row = cur.textRow();
|
||||||
int x = cur.x_target();
|
int x = cur.x_target();
|
||||||
int y = cursorY(cur.current()) - row.baseline() - 1;
|
int y = cursorY(cur.current()) - row.baseline() - 1;
|
||||||
setCursorFromCoordinates(x, y);
|
setCursorFromCoordinates(x, y);
|
||||||
@ -1702,17 +1688,17 @@ bool LyXText::isInInset() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool LyXText::toggleInset()
|
bool LyXText::toggleInset(LCursor & cur)
|
||||||
{
|
{
|
||||||
InsetBase * inset = bv()->cursor().nextInset();
|
InsetBase * inset = cur.nextInset();
|
||||||
// is there an editable inset at cursor position?
|
// is there an editable inset at cursor position?
|
||||||
if (!isEditableInset(inset))
|
if (!isEditableInset(inset))
|
||||||
return false;
|
return false;
|
||||||
//bv()->owner()->message(inset->editMessage());
|
cur.message(inset->editMessage());
|
||||||
|
|
||||||
// do we want to keep this?? (JMarc)
|
// do we want to keep this?? (JMarc)
|
||||||
if (!isHighlyEditableInset(inset))
|
if (!isHighlyEditableInset(inset))
|
||||||
recUndo(cursor().par());
|
recordUndo(cur);
|
||||||
|
|
||||||
if (inset->isOpen())
|
if (inset->isOpen())
|
||||||
inset->close();
|
inset->close();
|
||||||
|
209
src/text3.C
209
src/text3.C
@ -57,9 +57,6 @@
|
|||||||
|
|
||||||
#include <clocale>
|
#include <clocale>
|
||||||
|
|
||||||
|
|
||||||
using bv_funcs::replaceSelection;
|
|
||||||
|
|
||||||
using lyx::pos_type;
|
using lyx::pos_type;
|
||||||
|
|
||||||
using lyx::support::isStrUnsignedInt;
|
using lyx::support::isStrUnsignedInt;
|
||||||
@ -88,28 +85,26 @@ namespace {
|
|||||||
bool toggleall = false;
|
bool toggleall = false;
|
||||||
|
|
||||||
|
|
||||||
void toggleAndShow(BufferView * bv, LyXText * text,
|
void toggleAndShow(LCursor & cur, LyXText * text,
|
||||||
LyXFont const & font, bool toggleall = true)
|
LyXFont const & font, bool toggleall = true)
|
||||||
{
|
{
|
||||||
if (!bv->available())
|
if (!cur.bv().available())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
text->toggleFree(font, toggleall);
|
text->toggleFree(cur, font, toggleall);
|
||||||
bv->update();
|
|
||||||
|
|
||||||
if (font.language() != ignore_language ||
|
if (font.language() != ignore_language ||
|
||||||
font.number() != LyXFont::IGNORE) {
|
font.number() != LyXFont::IGNORE) {
|
||||||
CursorSlice & cur = text->cursor();
|
Paragraph & par = cur.paragraph();
|
||||||
Paragraph & par = *text->cursorPar();
|
text->bidi.computeTables(par, *cur.bv().buffer(), cur.textRow());
|
||||||
text->bidi.computeTables(par, *bv->buffer(),
|
|
||||||
*par.getRow(cur.pos()));
|
|
||||||
if (cur.boundary() !=
|
if (cur.boundary() !=
|
||||||
text->bidi.isBoundary(*bv->buffer(), par,
|
text->bidi.isBoundary(*cur.bv().buffer(), par,
|
||||||
cur.pos(),
|
cur.pos(),
|
||||||
text->real_current_font))
|
text->real_current_font))
|
||||||
text->setCursor(cur.par(), cur.pos(),
|
text->setCursor(cur.par(), cur.pos(),
|
||||||
false, !cur.boundary());
|
false, !cur.boundary());
|
||||||
}
|
}
|
||||||
|
cur.bv().update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -271,10 +266,10 @@ void LyXText::gotoInset(vector<InsetOld_code> const & codes, bool same_content)
|
|||||||
cur.pos() = 0;
|
cur.pos() = 0;
|
||||||
if (!gotoNextInset(codes, contents)) {
|
if (!gotoNextInset(codes, contents)) {
|
||||||
cursor() = tmp;
|
cursor() = tmp;
|
||||||
cur.bv().owner()->message(_("No more insets"));
|
cur.message(_("No more insets"));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
cur.bv().owner()->message(_("No more insets"));
|
cur.message(_("No more insets"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cur.bv().update();
|
cur.bv().update();
|
||||||
@ -330,30 +325,31 @@ void LyXText::cursorNext(LCursor & cur)
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
void specialChar(LyXText * text, BufferView * bv, InsetSpecialChar::Kind kind)
|
void specialChar(LCursor & cur, LyXText * text, BufferView * bv,
|
||||||
|
InsetSpecialChar::Kind kind)
|
||||||
{
|
{
|
||||||
bv->update();
|
bv->update();
|
||||||
replaceSelection(text);
|
text->replaceSelection(cur);
|
||||||
text->insertInset(new InsetSpecialChar(kind));
|
cur.insert(new InsetSpecialChar(kind));
|
||||||
bv->update();
|
bv->update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void doInsertInset(LyXText * text, BufferView * bv, FuncRequest const & cmd,
|
void doInsertInset(LCursor & cur, LyXText * text, BufferView * bv,
|
||||||
bool edit, bool pastesel)
|
FuncRequest const & cmd, bool edit, bool pastesel)
|
||||||
{
|
{
|
||||||
InsetBase * inset = createInset(bv, cmd);
|
InsetBase * inset = createInset(bv, cmd);
|
||||||
if (!inset)
|
if (!inset)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
bool gotsel = false;
|
bool gotsel = false;
|
||||||
if (bv->cursor().selection()) {
|
if (cur.selection()) {
|
||||||
bv->owner()->dispatch(FuncRequest(LFUN_CUT));
|
bv->owner()->dispatch(FuncRequest(LFUN_CUT));
|
||||||
gotsel = true;
|
gotsel = true;
|
||||||
}
|
}
|
||||||
text->insertInset(inset);
|
text->insertInset(cur, inset);
|
||||||
if (edit)
|
if (edit)
|
||||||
inset->edit(bv->cursor(), true);
|
inset->edit(cur, true);
|
||||||
if (gotsel && pastesel)
|
if (gotsel && pastesel)
|
||||||
bv->owner()->dispatch(FuncRequest(LFUN_PASTE));
|
bv->owner()->dispatch(FuncRequest(LFUN_PASTE));
|
||||||
}
|
}
|
||||||
@ -365,7 +361,7 @@ void LyXText::number()
|
|||||||
{
|
{
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setNumber(LyXFont::TOGGLE);
|
font.setNumber(LyXFont::TOGGLE);
|
||||||
toggleAndShow(bv(), this, font);
|
toggleAndShow(bv()->cursor(), this, font);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -385,8 +381,8 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
switch (cmd.action) {
|
switch (cmd.action) {
|
||||||
|
|
||||||
case LFUN_APPENDIX: {
|
case LFUN_APPENDIX: {
|
||||||
ParagraphList::iterator pit = cursorPar();
|
Paragraph & par = cur.paragraph();
|
||||||
bool start = !pit->params().startOfAppendix();
|
bool start = !par.params().startOfAppendix();
|
||||||
|
|
||||||
// ensure that we have only one start_of_appendix in this document
|
// ensure that we have only one start_of_appendix in this document
|
||||||
ParagraphList::iterator tmp = paragraphs().begin();
|
ParagraphList::iterator tmp = paragraphs().begin();
|
||||||
@ -401,12 +397,12 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
recUndo(parOffset(pit));
|
recordUndo(cur);
|
||||||
pit->params().startOfAppendix(start);
|
par.params().startOfAppendix(start);
|
||||||
|
|
||||||
// we can set the refreshing parameters now
|
// we can set the refreshing parameters now
|
||||||
updateCounters();
|
updateCounters();
|
||||||
redoParagraph(cursorPar());
|
redoParagraph(cur);
|
||||||
bv->update();
|
bv->update();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -560,7 +556,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_WORDSEL: {
|
case LFUN_WORDSEL: {
|
||||||
selectWord(lyx::WHOLE_WORD);
|
selectWord(cur, lyx::WHOLE_WORD);
|
||||||
finishChange(cur, true);
|
finishChange(cur, true);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -630,9 +626,9 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
|
|
||||||
case LFUN_BREAKLINE: {
|
case LFUN_BREAKLINE: {
|
||||||
// Not allowed by LaTeX (labels or empty par)
|
// Not allowed by LaTeX (labels or empty par)
|
||||||
if (cursor().pos() > cursorPar()->beginOfBody()) {
|
if (cur.pos() > cur.paragraph().beginOfBody()) {
|
||||||
replaceSelection(this);
|
replaceSelection(cur);
|
||||||
insertInset(new InsetNewline);
|
cur.insert(new InsetNewline);
|
||||||
moveCursor(cur, false);
|
moveCursor(cur, false);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -697,7 +693,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_BREAKPARAGRAPH:
|
case LFUN_BREAKPARAGRAPH:
|
||||||
replaceSelection(this);
|
replaceSelection(cur);
|
||||||
breakParagraph(cur, 0);
|
breakParagraph(cur, 0);
|
||||||
bv->update();
|
bv->update();
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
@ -706,7 +702,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_BREAKPARAGRAPHKEEPLAYOUT:
|
case LFUN_BREAKPARAGRAPHKEEPLAYOUT:
|
||||||
replaceSelection(this);
|
replaceSelection(cur);
|
||||||
breakParagraph(cur, 1);
|
breakParagraph(cur, 1);
|
||||||
bv->update();
|
bv->update();
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
@ -719,7 +715,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
// indentation and add a "defskip" at the top.
|
// indentation and add a "defskip" at the top.
|
||||||
// Otherwise, do the same as LFUN_BREAKPARAGRAPH.
|
// Otherwise, do the same as LFUN_BREAKPARAGRAPH.
|
||||||
#warning look here
|
#warning look here
|
||||||
replaceSelection(this);
|
replaceSelection(cur);
|
||||||
if (cur.pos() == 0) {
|
if (cur.pos() == 0) {
|
||||||
ParagraphParameters & params = cur.paragraph().params();
|
ParagraphParameters & params = cur.paragraph().params();
|
||||||
setParagraph(
|
setParagraph(
|
||||||
@ -772,7 +768,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
}
|
}
|
||||||
if (cur_spacing != new_spacing || cur_value != new_value) {
|
if (cur_spacing != new_spacing || cur_value != new_value) {
|
||||||
par.params().spacing(Spacing(new_spacing, new_value));
|
par.params().spacing(Spacing(new_spacing, new_value));
|
||||||
redoParagraph();
|
redoParagraph(cur);
|
||||||
bv->update();
|
bv->update();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -791,7 +787,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_INSET_INSERT: {
|
case LFUN_INSET_INSERT: {
|
||||||
InsetBase * inset = createInset(bv, cmd);
|
InsetBase * inset = createInset(bv, cmd);
|
||||||
if (inset)
|
if (inset)
|
||||||
insertInset(inset);
|
insertInset(cur, inset);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -802,69 +798,69 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
|
|
||||||
case LFUN_INSET_TOGGLE:
|
case LFUN_INSET_TOGGLE:
|
||||||
cur.clearSelection();
|
cur.clearSelection();
|
||||||
if (!toggleInset())
|
if (!toggleInset(cur))
|
||||||
return DispatchResult(false);
|
return DispatchResult(false);
|
||||||
bv->update();
|
bv->update();
|
||||||
bv->switchKeyMap();
|
bv->switchKeyMap();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_SPACE_INSERT:
|
case LFUN_SPACE_INSERT:
|
||||||
if (cursorPar()->layout()->free_spacing)
|
if (cur.paragraph().layout()->free_spacing)
|
||||||
insertChar(' ');
|
insertChar(cur, ' ');
|
||||||
else
|
else
|
||||||
doInsertInset(this, bv, cmd, false, false);
|
doInsertInset(cur, this, bv, cmd, false, false);
|
||||||
moveCursor(cur, false);
|
moveCursor(cur, false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_HYPHENATION:
|
case LFUN_HYPHENATION:
|
||||||
specialChar(this, bv, InsetSpecialChar::HYPHENATION);
|
specialChar(cur, this, bv, InsetSpecialChar::HYPHENATION);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_LIGATURE_BREAK:
|
case LFUN_LIGATURE_BREAK:
|
||||||
specialChar(this, bv, InsetSpecialChar::LIGATURE_BREAK);
|
specialChar(cur, this, bv, InsetSpecialChar::LIGATURE_BREAK);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_LDOTS:
|
case LFUN_LDOTS:
|
||||||
specialChar(this, bv, InsetSpecialChar::LDOTS);
|
specialChar(cur, this, bv, InsetSpecialChar::LDOTS);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_END_OF_SENTENCE:
|
case LFUN_END_OF_SENTENCE:
|
||||||
specialChar(this, bv, InsetSpecialChar::END_OF_SENTENCE);
|
specialChar(cur, this, bv, InsetSpecialChar::END_OF_SENTENCE);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_MENU_SEPARATOR:
|
case LFUN_MENU_SEPARATOR:
|
||||||
specialChar(this, bv, InsetSpecialChar::MENU_SEPARATOR);
|
specialChar(cur, this, bv, InsetSpecialChar::MENU_SEPARATOR);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_UPCASE_WORD:
|
case LFUN_UPCASE_WORD:
|
||||||
changeCase(LyXText::text_uppercase);
|
changeCase(cur, LyXText::text_uppercase);
|
||||||
bv->update();
|
bv->update();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_LOWCASE_WORD:
|
case LFUN_LOWCASE_WORD:
|
||||||
changeCase(LyXText::text_lowercase);
|
changeCase(cur, LyXText::text_lowercase);
|
||||||
bv->update();
|
bv->update();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_CAPITALIZE_WORD:
|
case LFUN_CAPITALIZE_WORD:
|
||||||
changeCase(LyXText::text_capitalization);
|
changeCase(cur, LyXText::text_capitalization);
|
||||||
bv->update();
|
bv->update();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_TRANSPOSE_CHARS:
|
case LFUN_TRANSPOSE_CHARS:
|
||||||
recUndo(cursor().par());
|
recordUndo(cur);
|
||||||
redoParagraph();
|
redoParagraph(cur);
|
||||||
bv->update();
|
bv->update();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_PASTE:
|
case LFUN_PASTE:
|
||||||
cur.message(_("Paste"));
|
cur.message(_("Paste"));
|
||||||
replaceSelection(this);
|
replaceSelection(cur);
|
||||||
#warning FIXME Check if the arg is in the domain of available selections.
|
#warning FIXME Check if the arg is in the domain of available selections.
|
||||||
if (isStrUnsignedInt(cmd.argument))
|
if (isStrUnsignedInt(cmd.argument))
|
||||||
pasteSelection(strToUnsignedInt(cmd.argument));
|
pasteSelection(cur, strToUnsignedInt(cmd.argument));
|
||||||
else
|
else
|
||||||
pasteSelection(0);
|
pasteSelection(cur, 0);
|
||||||
cur.clearSelection(); // bug 393
|
cur.clearSelection(); // bug 393
|
||||||
bv->update();
|
bv->update();
|
||||||
bv->switchKeyMap();
|
bv->switchKeyMap();
|
||||||
@ -928,7 +924,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_GETLAYOUT:
|
case LFUN_GETLAYOUT:
|
||||||
cur.message(cursorPar()->layout()->name());
|
cur.message(cur.paragraph().layout()->name());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_LAYOUT: {
|
case LFUN_LAYOUT: {
|
||||||
@ -982,7 +978,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
|
|
||||||
if (change_layout) {
|
if (change_layout) {
|
||||||
current_layout = layout;
|
current_layout = layout;
|
||||||
setLayout(layout);
|
setLayout(cur, layout);
|
||||||
bv->owner()->setLayout(layout);
|
bv->owner()->setLayout(layout);
|
||||||
bv->update();
|
bv->update();
|
||||||
bv->switchKeyMap();
|
bv->switchKeyMap();
|
||||||
@ -995,9 +991,9 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
string const clip = bv->getClipboard();
|
string const clip = bv->getClipboard();
|
||||||
if (!clip.empty()) {
|
if (!clip.empty()) {
|
||||||
if (cmd.argument == "paragraph")
|
if (cmd.argument == "paragraph")
|
||||||
insertStringAsParagraphs(clip);
|
insertStringAsParagraphs(cur, clip);
|
||||||
else
|
else
|
||||||
insertStringAsLines(clip);
|
insertStringAsLines(cur, clip);
|
||||||
bv->update();
|
bv->update();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -1020,30 +1016,30 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case LFUN_QUOTE: {
|
case LFUN_QUOTE: {
|
||||||
replaceSelection(this);
|
replaceSelection(cur);
|
||||||
ParagraphList::iterator pit = cursorPar();
|
Paragraph & par = cur.paragraph();
|
||||||
lyx::pos_type pos = cursor().pos();
|
lyx::pos_type pos = cur.pos();
|
||||||
char c;
|
char c;
|
||||||
if (!pos)
|
if (pos == 0)
|
||||||
c = ' ';
|
c = ' ';
|
||||||
else if (pit->isInset(pos - 1) && pit->getInset(pos - 1)->isSpace())
|
else if (cur.prevInset() && cur.prevInset()->isSpace())
|
||||||
c = ' ';
|
c = ' ';
|
||||||
else
|
else
|
||||||
c = pit->getChar(pos - 1);
|
c = par.getChar(pos - 1);
|
||||||
|
|
||||||
LyXLayout_ptr const & style = pit->layout();
|
LyXLayout_ptr const & style = par.layout();
|
||||||
|
|
||||||
BufferParams const & bufparams = bv->buffer()->params();
|
BufferParams const & bufparams = bv->buffer()->params();
|
||||||
if (style->pass_thru ||
|
if (style->pass_thru ||
|
||||||
pit->getFontSettings(bufparams,pos).language()->lang() == "hebrew")
|
par.getFontSettings(bufparams, pos).language()->lang() == "hebrew")
|
||||||
insertInset(new InsetQuotes(c, bufparams));
|
cur.insert(new InsetQuotes(c, bufparams));
|
||||||
else
|
else
|
||||||
bv->owner()->dispatch(FuncRequest(LFUN_SELFINSERT, "\""));
|
bv->owner()->dispatch(FuncRequest(LFUN_SELFINSERT, "\""));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case LFUN_DATE_INSERT: {
|
case LFUN_DATE_INSERT: {
|
||||||
replaceSelection(this);
|
replaceSelection(cur);
|
||||||
time_t now_time_t = time(NULL);
|
time_t now_time_t = time(NULL);
|
||||||
struct tm * now_tm = localtime(&now_time_t);
|
struct tm * now_tm = localtime(&now_time_t);
|
||||||
setlocale(LC_TIME, "");
|
setlocale(LC_TIME, "");
|
||||||
@ -1057,7 +1053,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
::strftime(datetmp, 32, arg.c_str(), now_tm);
|
::strftime(datetmp, 32, arg.c_str(), now_tm);
|
||||||
|
|
||||||
for (int i = 0; i < datetmp_len; i++)
|
for (int i = 0; i < datetmp_len; i++)
|
||||||
insertChar(datetmp[i]);
|
insertChar(cur, datetmp[i]);
|
||||||
|
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
moveCursor(cur, false);
|
moveCursor(cur, false);
|
||||||
@ -1078,7 +1074,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_MOUSE_DOUBLE:
|
case LFUN_MOUSE_DOUBLE:
|
||||||
if (cmd.button() == mouse_button::button1) {
|
if (cmd.button() == mouse_button::button1) {
|
||||||
selection_possible = true;
|
selection_possible = true;
|
||||||
selectWord(lyx::WHOLE_WORD_STRICT);
|
selectWord(cur, lyx::WHOLE_WORD_STRICT);
|
||||||
bv->haveSelection(cur.selection());
|
bv->haveSelection(cur.selection());
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -1095,14 +1091,14 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
"Dispatch: no selection possible\n";
|
"Dispatch: no selection possible\n";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
RowList::iterator cursorrow = cursorRow();
|
CursorSlice old = cur.current();
|
||||||
|
|
||||||
#warning
|
#warning
|
||||||
setCursorFromCoordinates(cmd.x, cmd.y);
|
setCursorFromCoordinates(cmd.x, cmd.y);
|
||||||
|
|
||||||
// This is to allow jumping over large insets
|
// This is to allow jumping over large insets
|
||||||
// FIXME: shouldn't be top-text-specific
|
// FIXME: shouldn't be top-text-specific
|
||||||
if (cursorrow == cursorRow() && !in_inset_) {
|
if (!in_inset_ && cur.current() == old) {
|
||||||
if (cmd.y - bv->top_y() >= bv->workHeight())
|
if (cmd.y - bv->top_y() >= bv->workHeight())
|
||||||
cursorDown(cur, true);
|
cursorDown(cur, true);
|
||||||
else if (cmd.y - bv->top_y() < 0)
|
else if (cmd.y - bv->top_y() < 0)
|
||||||
@ -1280,12 +1276,12 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_ENVIRONMENT_INSERT:
|
case LFUN_ENVIRONMENT_INSERT:
|
||||||
// Open the inset, and move the current selection
|
// Open the inset, and move the current selection
|
||||||
// inside it.
|
// inside it.
|
||||||
doInsertInset(this, bv, cmd, true, true);
|
doInsertInset(cur, this, bv, cmd, true, true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_INDEX_INSERT:
|
case LFUN_INDEX_INSERT:
|
||||||
// Just open the inset
|
// Just open the inset
|
||||||
doInsertInset(this, bv, cmd, true, false);
|
doInsertInset(cur, this, bv, cmd, true, false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_INDEX_PRINT:
|
case LFUN_INDEX_PRINT:
|
||||||
@ -1294,16 +1290,16 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_INSERT_LINE:
|
case LFUN_INSERT_LINE:
|
||||||
case LFUN_INSERT_PAGEBREAK:
|
case LFUN_INSERT_PAGEBREAK:
|
||||||
// do nothing fancy
|
// do nothing fancy
|
||||||
doInsertInset(this, bv, cmd, false, false);
|
doInsertInset(cur, this, bv, cmd, false, false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_DEPTH_MIN:
|
case LFUN_DEPTH_MIN:
|
||||||
bv_funcs::changeDepth(bv, this, bv_funcs::DEC_DEPTH);
|
changeDepth(cur, bv_funcs::DEC_DEPTH);
|
||||||
bv->update();
|
bv->update();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_DEPTH_PLUS:
|
case LFUN_DEPTH_PLUS:
|
||||||
bv_funcs::changeDepth(bv, this, bv_funcs::INC_DEPTH);
|
changeDepth(cur, bv_funcs::INC_DEPTH);
|
||||||
bv->update();
|
bv->update();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1343,7 +1339,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_EMPH: {
|
case LFUN_EMPH: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setEmph(LyXFont::TOGGLE);
|
font.setEmph(LyXFont::TOGGLE);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1351,7 +1347,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_BOLD: {
|
case LFUN_BOLD: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setSeries(LyXFont::BOLD_SERIES);
|
font.setSeries(LyXFont::BOLD_SERIES);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1359,7 +1355,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_NOUN: {
|
case LFUN_NOUN: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setNoun(LyXFont::TOGGLE);
|
font.setNoun(LyXFont::TOGGLE);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1367,7 +1363,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_CODE: {
|
case LFUN_CODE: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setFamily(LyXFont::TYPEWRITER_FAMILY); // no good
|
font.setFamily(LyXFont::TYPEWRITER_FAMILY); // no good
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1375,7 +1371,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_SANS: {
|
case LFUN_SANS: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setFamily(LyXFont::SANS_FAMILY);
|
font.setFamily(LyXFont::SANS_FAMILY);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1383,14 +1379,14 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_ROMAN: {
|
case LFUN_ROMAN: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setFamily(LyXFont::ROMAN_FAMILY);
|
font.setFamily(LyXFont::ROMAN_FAMILY);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case LFUN_DEFAULT: {
|
case LFUN_DEFAULT: {
|
||||||
LyXFont font(LyXFont::ALL_INHERIT, ignore_language);
|
LyXFont font(LyXFont::ALL_INHERIT, ignore_language);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1398,7 +1394,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_UNDERLINE: {
|
case LFUN_UNDERLINE: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setUnderbar(LyXFont::TOGGLE);
|
font.setUnderbar(LyXFont::TOGGLE);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1406,7 +1402,7 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
case LFUN_FONT_SIZE: {
|
case LFUN_FONT_SIZE: {
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setLyXSize(cmd.argument);
|
font.setLyXSize(cmd.argument);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1417,16 +1413,16 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
LyXFont font(LyXFont::ALL_IGNORE);
|
LyXFont font(LyXFont::ALL_IGNORE);
|
||||||
font.setLanguage(lang);
|
font.setLanguage(lang);
|
||||||
toggleAndShow(bv, this, font);
|
toggleAndShow(cur, this, font);
|
||||||
bv->switchKeyMap();
|
bv->switchKeyMap();
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case LFUN_FREEFONT_APPLY:
|
case LFUN_FREEFONT_APPLY:
|
||||||
toggleAndShow(bv, this, freefont, toggleall);
|
toggleAndShow(cur, this, freefont, toggleall);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
bv->owner()->message(_("Character set"));
|
cur.message(_("Character set"));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// Set the freefont using the contents of \param data dispatched from
|
// Set the freefont using the contents of \param data dispatched from
|
||||||
@ -1437,9 +1433,9 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
if (bv_funcs::string2font(cmd.argument, font, toggle)) {
|
if (bv_funcs::string2font(cmd.argument, font, toggle)) {
|
||||||
freefont = font;
|
freefont = font;
|
||||||
toggleall = toggle;
|
toggleall = toggle;
|
||||||
toggleAndShow(bv, this, freefont, toggleall);
|
toggleAndShow(cur, this, freefont, toggleall);
|
||||||
bv->owner()->view_state_changed();
|
bv->owner()->view_state_changed();
|
||||||
bv->owner()->message(_("Character set"));
|
cur.message(_("Character set"));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1535,9 +1531,9 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
breakParagraph(cur);
|
breakParagraph(cur);
|
||||||
}
|
}
|
||||||
|
|
||||||
setLayout(tclass.defaultLayoutName());
|
setLayout(cur, tclass.defaultLayoutName());
|
||||||
setParagraph(Spacing(), LYX_ALIGN_LAYOUT, string(), 0);
|
setParagraph(Spacing(), LYX_ALIGN_LAYOUT, string(), 0);
|
||||||
insertInset(new InsetFloatList(cmd.argument));
|
cur.insert(new InsetFloatList(cmd.argument));
|
||||||
unFreezeUndo();
|
unFreezeUndo();
|
||||||
} else {
|
} else {
|
||||||
lyxerr << "Non-existent float type: "
|
lyxerr << "Non-existent float type: "
|
||||||
@ -1546,6 +1542,33 @@ DispatchResult LyXText::dispatch(LCursor & cur, FuncRequest const & cmd)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case LFUN_ACCEPT_CHANGE: {
|
||||||
|
acceptChange(cur);
|
||||||
|
bv->update();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case LFUN_REJECT_CHANGE: {
|
||||||
|
rejectChange(cur);
|
||||||
|
bv->update();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case LFUN_THESAURUS_ENTRY: {
|
||||||
|
string arg = cmd.argument;
|
||||||
|
if (arg.empty()) {
|
||||||
|
arg = cur.selectionAsString(false);
|
||||||
|
// FIXME
|
||||||
|
if (arg.size() > 100 || arg.empty()) {
|
||||||
|
// Get word or selection
|
||||||
|
selectWordWhenUnderCursor(cur, lyx::WHOLE_WORD);
|
||||||
|
arg = cur.selectionAsString(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
bv->owner()->getDialogs().show("thesaurus", arg);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return DispatchResult(false);
|
return DispatchResult(false);
|
||||||
}
|
}
|
||||||
|
@ -12,11 +12,16 @@
|
|||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include "trans_mgr.h"
|
#include "trans_mgr.h"
|
||||||
#include "trans.h"
|
|
||||||
#include "lyxtext.h"
|
#include "BufferView.h"
|
||||||
|
#include "cursor.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "insets/insetlatexaccent.h"
|
|
||||||
#include "lyxrc.h"
|
#include "lyxrc.h"
|
||||||
|
#include "lyxtext.h"
|
||||||
|
#include "trans.h"
|
||||||
|
|
||||||
|
#include "insets/insetlatexaccent.h"
|
||||||
|
|
||||||
#include "support/lstrings.h"
|
#include "support/lstrings.h"
|
||||||
|
|
||||||
using lyx::support::split;
|
using lyx::support::split;
|
||||||
@ -260,11 +265,8 @@ void TransManager::TranslateAndInsert(char c, LyXText * text)
|
|||||||
|
|
||||||
void TransManager::insertVerbatim(string const & str, LyXText * text)
|
void TransManager::insertVerbatim(string const & str, LyXText * text)
|
||||||
{
|
{
|
||||||
string::size_type const l = str.length();
|
for (string::size_type i = 0, n = str.size(); i < n; ++i)
|
||||||
|
text->insertChar(text->bv()->cursor(), str[i]);
|
||||||
for (string::size_type i = 0; i < l; ++i) {
|
|
||||||
text->insertChar(str[i]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -282,15 +284,13 @@ void TransManager::insert(string const & str, LyXText * text)
|
|||||||
// Could not find an encoding
|
// Could not find an encoding
|
||||||
InsetLatexAccent ins(str);
|
InsetLatexAccent ins(str);
|
||||||
if (ins.canDisplay()) {
|
if (ins.canDisplay()) {
|
||||||
text->insertInset(
|
text->bv()->cursor().insert(new InsetLatexAccent(ins));
|
||||||
new InsetLatexAccent(ins));
|
|
||||||
} else {
|
} else {
|
||||||
insertVerbatim(str, text);
|
insertVerbatim(str, text);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
string tmp;
|
string const tmp(1, static_cast<char>(enc.second));
|
||||||
tmp += static_cast<char>(enc.second);
|
|
||||||
insertVerbatim(tmp, text);
|
insertVerbatim(tmp, text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
10
src/undo.C
10
src/undo.C
@ -186,7 +186,9 @@ bool performUndoOrRedo(BufferView & bv, Undo const & undo)
|
|||||||
text->updateCounters();
|
text->updateCounters();
|
||||||
|
|
||||||
// rebreak the entire lyxtext
|
// rebreak the entire lyxtext
|
||||||
buf.text().fullRebreak();
|
#warning needed?
|
||||||
|
text->redoParagraphs(buf.paragraphs().begin(), buf.paragraphs().end());
|
||||||
|
bv.cursor().resetAnchor();
|
||||||
|
|
||||||
ParIterator pit2 = num2pit(buf, undo.text);
|
ParIterator pit2 = num2pit(buf, undo.text);
|
||||||
advance(pit2, undo.cursor_par);
|
advance(pit2, undo.cursor_par);
|
||||||
@ -290,6 +292,12 @@ void recordUndo(LCursor & cur, Undo::undo_kind kind)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void recordUndoSelection(LCursor & cur, Undo::undo_kind kind)
|
||||||
|
{
|
||||||
|
recordUndo(kind, cur, cur.selBegin().par(), cur.selEnd().par());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void recordUndo(LCursor & cur, Undo::undo_kind kind, paroffset_type from)
|
void recordUndo(LCursor & cur, Undo::undo_kind kind, paroffset_type from)
|
||||||
{
|
{
|
||||||
recordUndo(kind, cur, cur.par(), from);
|
recordUndo(kind, cur, cur.par(), from);
|
||||||
|
@ -102,6 +102,8 @@ void recordUndo(LCursor & cur, Undo::undo_kind kind, lyx::paroffset_type from);
|
|||||||
|
|
||||||
/// convienience: prepare undo for the single paragraph containing the cursor
|
/// convienience: prepare undo for the single paragraph containing the cursor
|
||||||
void recordUndo(LCursor & cur, Undo::undo_kind kind = Undo::ATOMIC);
|
void recordUndo(LCursor & cur, Undo::undo_kind kind = Undo::ATOMIC);
|
||||||
|
/// convienience: prepare undo for the selected paragraphs
|
||||||
|
void recordUndoSelection(LCursor & cur, Undo::undo_kind kind = Undo::ATOMIC);
|
||||||
|
|
||||||
/// convienience: prepare undo for the single paragraph containing the cursor
|
/// convienience: prepare undo for the single paragraph containing the cursor
|
||||||
void recordUndoFullDocument(LCursor & cur);
|
void recordUndoFullDocument(LCursor & cur);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user