/**
- * \file text3.cpp
+ * \file Text3.cpp
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Asger Alstrup
- * \author Lars Gullik Bjønnes
+ * \author Lars Gullik Bjønnes
* \author Alfredo Braunstein
* \author Angus Leeming
* \author John Levon
- * \author André Pönitz
+ * \author André Pönitz
*
* Full author contact details are available in file CREDITS.
*/
#include "frontends/Clipboard.h"
#include "frontends/Selection.h"
+#include "frontends/Application.h"
+#include "frontends/LyXView.h"
+#include "frontends/WorkArea.h"
#include "insets/InsetCollapsable.h"
#include "insets/InsetCommand.h"
using cap::pasteClipboardText;
using cap::pasteClipboardGraphics;
using cap::replaceSelection;
+using cap::grabAndEraseSelection;
+using cap::selClearOrDel;
// globals...
static Font freefont(ignore_font, ignore_language);
istringstream is(selstr);
Lexer lex;
lex.setStream(is);
- formula->readQuiet(lex);
- if (formula->getType() == hullNone) {
+ if (!formula->readQuiet(lex)) {
// No valid formula, let's try with delims
is.str("$" + selstr + "$");
lex.setStream(is);
- formula->readQuiet(lex);
- if (formula->getType() == hullNone) {
+ if (!formula->readQuiet(lex)) {
// Still not valid, leave it as is
valid = false;
delete formula;
}
+void regexpDispatch(Cursor & cur, FuncRequest const & cmd)
+{
+ BOOST_ASSERT(cmd.action == LFUN_REGEXP_MODE);
+ if (cur.inRegexped()) {
+ cur.message(_("Already in regexp mode"));
+ return;
+ }
+ cur.recordUndo();
+ docstring const save_selection = grabAndEraseSelection(cur);
+ selClearOrDel(cur);
+ // replaceSelection(cur);
+
+ cur.insert(new InsetMathHull(hullRegexp));
+ cur.nextInset()->edit(cur, true);
+ cur.niceInsert(save_selection);
+
+ cur.message(_("Regexp editor mode"));
+}
+
+
static void specialChar(Cursor & cur, InsetSpecialChar::Kind kind)
{
cur.recordUndo();
if (edit)
inset->edit(cur, true);
// Now put this into inset
- static_cast<InsetCollapsable *>(inset)->text().insertStringAsParagraphs(cur, ds);
+ static_cast<InsetCollapsable *>(inset)->
+ text().insertStringAsParagraphs(cur, ds);
return true;
}
if (!gotsel || !pastesel)
return true;
- pasteFromStack(cur, cur.buffer().errorList("Paste"), 0);
- cur.buffer().errors("Paste");
+ pasteFromStack(cur, cur.buffer()->errorList("Paste"), 0);
+ cur.buffer()->errors("Paste");
cur.clearSelection(); // bug 393
cur.finishUndo();
InsetText * insetText = dynamic_cast<InsetText *>(inset);
static void outline(OutlineOp mode, Cursor & cur)
{
- Buffer & buf = cur.buffer();
+ Buffer & buf = *cur.buffer();
pit_type & pit = cur.pit();
ParagraphList & pars = buf.text().paragraphs();
ParagraphList::iterator bgn = pars.begin();
recUndo(cur, pit, pit + 1);
cur.finishUndo();
swap(pars_[pit], pars_[pit + 1]);
- updateLabels(cur.buffer());
+ cur.buffer()->updateLabels();
needsUpdate = true;
++cur.pit();
break;
recUndo(cur, pit - 1, pit);
cur.finishUndo();
swap(pars_[pit], pars_[pit - 1]);
- updateLabels(cur.buffer());
+ cur.buffer()->updateLabels();
--cur.pit();
needsUpdate = true;
break;
par.params().startOfAppendix(start);
// we can set the refreshing parameters now
- updateLabels(cur.buffer());
+ cur.buffer()->updateLabels();
break;
}
case LFUN_WORD_DELETE_FORWARD:
- if (cur.selection()) {
+ if (cur.selection())
cutSelection(cur, true, false);
- } else
+ else
deleteWordForward(cur);
finishChange(cur, false);
break;
case LFUN_WORD_DELETE_BACKWARD:
- if (cur.selection()) {
+ if (cur.selection())
cutSelection(cur, true, false);
- } else
+ else
deleteWordBackward(cur);
finishChange(cur, false);
break;
case LFUN_LINE_DELETE:
- if (cur.selection()) {
+ if (cur.selection())
cutSelection(cur, true, false);
- } else
+ else
tm.deleteLineForward(cur);
finishChange(cur, false);
break;
case LFUN_BUFFER_BEGIN:
case LFUN_BUFFER_BEGIN_SELECT:
needsUpdate |= cur.selHandle(cmd.action == LFUN_BUFFER_BEGIN_SELECT);
- if (cur.depth() == 1) {
+ if (cur.depth() == 1)
needsUpdate |= cursorTop(cur);
- } else {
+ else
cur.undispatched();
- }
cur.updateFlags(Update::FitCursor);
break;
case LFUN_BUFFER_END:
case LFUN_BUFFER_END_SELECT:
needsUpdate |= cur.selHandle(cmd.action == LFUN_BUFFER_END_SELECT);
- if (cur.depth() == 1) {
+ if (cur.depth() == 1)
needsUpdate |= cursorBottom(cur);
- } else {
+ else
cur.undispatched();
- }
cur.updateFlags(Update::FitCursor);
break;
// stop/start the selection
bool select = cmd.action == LFUN_DOWN_SELECT ||
cmd.action == LFUN_UP_SELECT;
- cur.selHandle(select);
// move cursor up/down
bool up = cmd.action == LFUN_UP_SELECT || cmd.action == LFUN_UP;
- bool const successful = cur.upDownInText(up, needsUpdate);
- if (successful) {
- // redraw if you leave mathed (for the decorations)
+ bool const atFirstOrLastRow = cur.atFirstOrLastRow(up);
+
+ if (!atFirstOrLastRow) {
+ needsUpdate |= cur.selHandle(select);
+ cur.selHandle(select);
+ cur.upDownInText(up, needsUpdate);
needsUpdate |= cur.beforeDispatchCursor().inMathed();
- } else
+ } else {
+ // if the cursor cannot be moved up or down do not remove
+ // the selection right now, but wait for the next dispatch.
+ if (select)
+ needsUpdate |= cur.selHandle(select);
+ cur.upDownInText(up, needsUpdate);
cur.undispatched();
+ }
break;
}
cur.posForward();
// Some insets are numbered, others are shown in the outline pane so
// let's update the labels and the toc backend.
- updateLabels(bv->buffer());
+ bv->buffer().updateLabels();
break;
case LFUN_TABULAR_INSERT:
doInsertInset(cur, this, cmd, true, true);
cur.posForward();
+ // If some text is moved into the inset, doInsertInset
+ // puts the cursor outside the inset. To insert the
+ // caption we put it back into the inset.
if (content)
cur.backwardPos();
// date metrics.
FuncRequest cmd_caption(LFUN_CAPTION_INSERT);
doInsertInset(cur, cur.text(), cmd_caption, true, false);
- updateLabels(bv->buffer());
+ bv->buffer().updateLabels();
cur.updateFlags(Update::Force);
// FIXME: When leaving the Float (or Wrap) inset we should
// delete any empty paragraph left above or below the
mathDispatch(cur, cmd, true);
break;
+ case LFUN_REGEXP_MODE:
+ regexpDispatch(cur, cmd);
+ break;
+
case LFUN_MATH_MODE:
if (cmd.argument() == "on")
// don't pass "on" as argument
break;
}
+ case LFUN_FONT_ITAL: {
+ Font font(ignore_font, ignore_language);
+ font.fontInfo().setShape(ITALIC_SHAPE);
+ toggleAndShow(cur, this, font);
+ break;
+ }
+
case LFUN_FONT_BOLD:
case LFUN_FONT_BOLDSYMBOL: {
Font font(ignore_font, ignore_language);
// Get word or selection
selectWordWhenUnderCursor(cur, WHOLE_WORD);
arg = cur.selectionAsString(false);
+ arg += " lang=" + from_ascii(cur.getFont().language()->lang());
}
}
bv->showDialog("thesaurus", to_utf8(arg));
case LFUN_OUTLINE_UP:
outline(OutlineUp, cur);
setCursor(cur, cur.pit(), 0);
- updateLabels(cur.buffer());
+ cur.buffer()->updateLabels();
needsUpdate = true;
break;
case LFUN_OUTLINE_DOWN:
outline(OutlineDown, cur);
setCursor(cur, cur.pit(), 0);
- updateLabels(cur.buffer());
+ cur.buffer()->updateLabels();
needsUpdate = true;
break;
case LFUN_OUTLINE_IN:
outline(OutlineIn, cur);
- updateLabels(cur.buffer());
+ cur.buffer()->updateLabels();
needsUpdate = true;
break;
case LFUN_OUTLINE_OUT:
outline(OutlineOut, cur);
- updateLabels(cur.buffer());
+ cur.buffer()->updateLabels();
needsUpdate = true;
break;
code = FLEX_CODE;
string s = cmd.getArg(0);
InsetLayout il =
- cur.buffer().params().documentClass().insetLayout(from_utf8(s));
- if (il.lyxtype() != "charstyle" &&
- il.lyxtype() != "custom" &&
- il.lyxtype() != "element" &&
- il.lyxtype ()!= "standard")
+ cur.buffer()->params().documentClass().insetLayout(from_utf8(s));
+ if (il.lyxtype() != InsetLayout::CHARSTYLE &&
+ il.lyxtype() != InsetLayout::CUSTOM &&
+ il.lyxtype() != InsetLayout::ELEMENT &&
+ il.lyxtype ()!= InsetLayout::STANDARD)
enable = false;
break;
}
break;
case LFUN_BRANCH_INSERT:
code = BRANCH_CODE;
- if (cur.buffer().masterBuffer()->params().branchlist().empty())
+ if (cur.buffer()->masterBuffer()->params().branchlist().empty())
enable = false;
break;
case LFUN_LABEL_INSERT:
flag.setOnOff(fontinfo.emph() == FONT_ON);
break;
+ case LFUN_FONT_ITAL:
+ flag.setOnOff(fontinfo.shape() == ITALIC_SHAPE);
+ break;
+
case LFUN_FONT_NOUN:
flag.setOnOff(fontinfo.noun() == FONT_ON);
break;
case LFUN_INSET_DISSOLVE:
if (!cmd.argument().empty()) {
- InsetLayout il = cur.inset().getLayout(cur.buffer().params());
+ InsetLayout const & il = cur.inset().getLayout(cur.buffer()->params());
+ InsetLayout::InsetLyXType const type =
+ translateLyXType(to_utf8(cmd.argument()));
enable = cur.inset().lyxCode() == FLEX_CODE
- && il.lyxtype() == to_utf8(cmd.argument());
+ && il.lyxtype() == type;
} else {
enable = !isMainText(cur.bv().buffer())
&& cur.inset().nargs() == 1;