#include "support/lstrings.h"
#include "support/LAssert.h"
+#include "support/limited_stack.h"
#include "debug.h"
#include "frontends/Painter.h"
#include "math_cursor.h"
// matheds own cut buffer
-string theCutBuffer;
+limited_stack<string> theCutBuffer;
MathCursor::MathCursor(InsetFormulaBase * formula, bool front)
{
dump("selCopy");
if (selection_) {
- theCutBuffer = grabSelection();
+ theCutBuffer.push(grabSelection());
selection_ = false;
} else {
- theCutBuffer.erase();
+ //theCutBuffer.erase();
}
}
void MathCursor::selCut()
{
dump("selCut");
- theCutBuffer = grabAndEraseSelection();
+ theCutBuffer.push(grabAndEraseSelection());
}
}
-void MathCursor::selPaste()
+void MathCursor::selPaste(int n)
{
dump("selPaste");
selClearOrDel();
- paste(theCutBuffer);
+ if (n < theCutBuffer.size())
+ paste(theCutBuffer[n]);
//grabSelection();
selection_ = false;
}
return pos() != size();
}
- if (c == '#') {
- insert(c);
- return true;
- }
-
- if (c == '{' || c == '}') {
- niceInsert(createMathInset(string(1, c)));
- return true;
- }
-
- if (c == '$') {
- insert(createMathInset("$"));
+ if (c == '{' || c == '}' || c == '#' || c == '&' || c == '$') {
+ createMathInset(string(1, c));
return true;
}
MathInset::mode_type asMode(MathInset::mode_type oldmode, string const & str)
{
+ lyxerr << "handling mode: '" << str << "'\n";
if (str == "mathmode")
return MathInset::MATH_MODE;
if (str == "textmode" || str == "forcetext")
grid.asHullInset()->numbered(cellrow, numbered);
//dump();
+ //lyxerr << " flags: " << flags << "\n";
+ //lyxerr << " mode: " << mode << "\n";
//lyxerr << "grid: " << grid << endl;
while (good()) {
#ifdef FILEDEBUG
lyxerr << "t: " << t << " flags: " << flags << "\n";
+ lyxerr << "mode: " << mode << "\n";
cell->dump();
lyxerr << "\n";
#endif
if (flags & FLAG_ITEM) {
- skipSpaces();
- flags &= ~FLAG_ITEM;
- if (t.cat() == catBegin) {
+ if (t.cat() == catBegin) {
// skip the brace and collect everything to the next matching
// closing brace
- flags |= FLAG_BRACE_LAST;
- continue;
+ parse1(grid, FLAG_BRACE_LAST, mode, numbered);
+ return;
}
// handle only this single token, leave the loop if done
- flags |= FLAG_LEAVE;
+ flags = FLAG_LEAVE;
}
// is a version for display attached?
skipSpaces();
MathArray ar2;
- if (nextToken().cat() == catBegin) {
+ if (nextToken().cat() == catBegin)
parse(ar2, FLAG_ITEM, MathInset::MATH_MODE);
- }
cell->push_back(MathAtom(new MathMacroTemplate(name, nargs, ar1, ar2)));
}
MathAtom at = createMathInset(t.cs());
MathInset::mode_type m = mode;
//if (m == MathInset::UNDECIDED_MODE)
+ lyxerr << "default creation: m1: " << m << "\n";
if (at->currentMode() != MathInset::UNDECIDED_MODE)
m = at->currentMode();
+ lyxerr << "default creation: m2: " << m << "\n";
MathInset::idx_type start = 0;
// this fails on \bigg[...\bigg]
//MathArray opt;