mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-14 04:21:56 +00:00
* BufferView::buffer() returns a reference instead of a pointer.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@19691 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
c1b155fbe8
commit
0fcae6cc10
@ -227,14 +227,14 @@ bool reverseDirectionNeeded(Cursor const & cur)
|
|||||||
* cursor gets stuck.
|
* cursor gets stuck.
|
||||||
*/
|
*/
|
||||||
return cur.bottom().paragraph().isRightToLeftPar(
|
return cur.bottom().paragraph().isRightToLeftPar(
|
||||||
cur.bv().buffer()->params());
|
cur.bv().buffer().params());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool isWithinRtlParagraph(Cursor const & cur)
|
bool isWithinRtlParagraph(Cursor const & cur)
|
||||||
{
|
{
|
||||||
return cur.innerParagraph().isRightToLeftPar(
|
return cur.innerParagraph().isRightToLeftPar(
|
||||||
cur.bv().buffer()->params());
|
cur.bv().buffer().params());
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace lyx
|
} // namespace lyx
|
||||||
|
@ -145,15 +145,15 @@ BufferView::~BufferView()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Buffer * BufferView::buffer()
|
Buffer & BufferView::buffer()
|
||||||
{
|
{
|
||||||
return &buffer_;
|
return buffer_;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Buffer const * BufferView::buffer() const
|
Buffer const & BufferView::buffer() const
|
||||||
{
|
{
|
||||||
return &buffer_;
|
return buffer_;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -85,8 +85,8 @@ public:
|
|||||||
~BufferView();
|
~BufferView();
|
||||||
|
|
||||||
/// return the buffer being viewed.
|
/// return the buffer being viewed.
|
||||||
Buffer * buffer();
|
Buffer & buffer();
|
||||||
Buffer const * buffer() const;
|
Buffer const & buffer() const;
|
||||||
|
|
||||||
/// perform pending metrics updates.
|
/// perform pending metrics updates.
|
||||||
/** \c Update::FitCursor means first to do a FitCursor, and to
|
/** \c Update::FitCursor means first to do a FitCursor, and to
|
||||||
|
@ -206,7 +206,7 @@ namespace {
|
|||||||
// << " xlow: " << xlow << " xhigh: " << xhigh
|
// << " xlow: " << xlow << " xhigh: " << xhigh
|
||||||
// << " ylow: " << ylow << " yhigh: " << yhigh
|
// << " ylow: " << ylow << " yhigh: " << yhigh
|
||||||
// << endl;
|
// << endl;
|
||||||
Inset & inset = bv.buffer()->inset();
|
Inset & inset = bv.buffer().inset();
|
||||||
DocIterator it = doc_iterator_begin(inset);
|
DocIterator it = doc_iterator_begin(inset);
|
||||||
it.pit() = from;
|
it.pit() = from;
|
||||||
DocIterator et = doc_iterator_end(inset);
|
DocIterator et = doc_iterator_end(inset);
|
||||||
@ -351,8 +351,7 @@ BufferView & Cursor::bv() const
|
|||||||
Buffer & Cursor::buffer() const
|
Buffer & Cursor::buffer() const
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(bv_);
|
BOOST_ASSERT(bv_);
|
||||||
BOOST_ASSERT(bv_->buffer());
|
return bv_->buffer();
|
||||||
return *bv_->buffer();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1336,7 +1335,7 @@ docstring Cursor::selectionAsString(bool label) const
|
|||||||
return docstring();
|
return docstring();
|
||||||
|
|
||||||
if (inTexted()) {
|
if (inTexted()) {
|
||||||
Buffer const & buffer = *bv().buffer();
|
Buffer const & buffer = bv().buffer();
|
||||||
ParagraphList const & pars = text()->paragraphs();
|
ParagraphList const & pars = text()->paragraphs();
|
||||||
|
|
||||||
// should be const ...
|
// should be const ...
|
||||||
@ -1398,8 +1397,6 @@ Encoding const * Cursor::getEncoding() const
|
|||||||
{
|
{
|
||||||
if (empty())
|
if (empty())
|
||||||
return 0;
|
return 0;
|
||||||
if (!bv().buffer())
|
|
||||||
return 0;
|
|
||||||
int s = 0;
|
int s = 0;
|
||||||
// go up until first non-0 text is hit
|
// go up until first non-0 text is hit
|
||||||
// (innermost text is 0 in mathed)
|
// (innermost text is 0 in mathed)
|
||||||
@ -1409,7 +1406,7 @@ Encoding const * Cursor::getEncoding() const
|
|||||||
CursorSlice const & sl = operator[](s);
|
CursorSlice const & sl = operator[](s);
|
||||||
Text const & text = *sl.text();
|
Text const & text = *sl.text();
|
||||||
Font font = text.getPar(sl.pit()).getFont(
|
Font font = text.getPar(sl.pit()).getFont(
|
||||||
bv().buffer()->params(), sl.pos(), outerFont(sl.pit(), text.paragraphs()));
|
bv().buffer().params(), sl.pos(), outerFont(sl.pit(), text.paragraphs()));
|
||||||
return font.language()->encoding();
|
return font.language()->encoding();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1469,7 +1466,7 @@ Font Cursor::getFont() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// get font at the position
|
// get font at the position
|
||||||
Font font = par.getFont(bv().buffer()->params(), pos,
|
Font font = par.getFont(bv().buffer().params(), pos,
|
||||||
outerFont(sl.pit(), text.paragraphs()));
|
outerFont(sl.pit(), text.paragraphs()));
|
||||||
|
|
||||||
return font;
|
return font;
|
||||||
|
@ -764,7 +764,7 @@ FuncStatus LyXFunc::getStatus(FuncRequest const & cmd) const
|
|||||||
|
|
||||||
bool LyXFunc::ensureBufferClean(BufferView * bv)
|
bool LyXFunc::ensureBufferClean(BufferView * bv)
|
||||||
{
|
{
|
||||||
Buffer & buf = *bv->buffer();
|
Buffer & buf = bv->buffer();
|
||||||
if (buf.isClean())
|
if (buf.isClean())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
@ -1313,7 +1313,7 @@ bool Text::backspace(Cursor & cur)
|
|||||||
bool Text::dissolveInset(Cursor & cur) {
|
bool Text::dissolveInset(Cursor & cur) {
|
||||||
BOOST_ASSERT(this == cur.text());
|
BOOST_ASSERT(this == cur.text());
|
||||||
|
|
||||||
if (isMainText(*cur.bv().buffer()) || cur.inset().nargs() != 1)
|
if (isMainText(cur.bv().buffer()) || cur.inset().nargs() != 1)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
recordUndoInset(cur);
|
recordUndoInset(cur);
|
||||||
@ -1449,7 +1449,7 @@ void Text::drawRowSelection(PainterInfo & pi, int x, Row const & row,
|
|||||||
bool drawOnBegMargin, bool drawOnEndMargin) const
|
bool drawOnBegMargin, bool drawOnEndMargin) const
|
||||||
{
|
{
|
||||||
BufferView & bv = *pi.base.bv;
|
BufferView & bv = *pi.base.bv;
|
||||||
Buffer & buffer = *bv.buffer();
|
Buffer & buffer = bv.buffer();
|
||||||
TextMetrics const & tm = bv.textMetrics(this);
|
TextMetrics const & tm = bv.textMetrics(this);
|
||||||
DocIterator cur = beg;
|
DocIterator cur = beg;
|
||||||
int x1 = cursorX(bv, beg.top(), beg.boundary());
|
int x1 = cursorX(bv, beg.top(), beg.boundary());
|
||||||
@ -1662,7 +1662,7 @@ int Text::cursorX(BufferView const & bv, CursorSlice const & sl,
|
|||||||
|
|
||||||
pos_type cursor_vpos = 0;
|
pos_type cursor_vpos = 0;
|
||||||
|
|
||||||
Buffer const & buffer = *bv.buffer();
|
Buffer const & buffer = bv.buffer();
|
||||||
RowMetrics const m = tm.computeRowMetrics(pit, row);
|
RowMetrics const m = tm.computeRowMetrics(pit, row);
|
||||||
double x = m.x;
|
double x = m.x;
|
||||||
Bidi bidi;
|
Bidi bidi;
|
||||||
|
@ -371,7 +371,7 @@ void Text::setLayout(Cursor & cur, docstring const & layout)
|
|||||||
BOOST_ASSERT(this == cur.text());
|
BOOST_ASSERT(this == cur.text());
|
||||||
// special handling of new environment insets
|
// special handling of new environment insets
|
||||||
BufferView & bv = cur.bv();
|
BufferView & bv = cur.bv();
|
||||||
BufferParams const & params = bv.buffer()->params();
|
BufferParams const & params = bv.buffer().params();
|
||||||
Layout_ptr const & lyxlayout = params.getTextClass()[layout];
|
Layout_ptr const & lyxlayout = params.getTextClass()[layout];
|
||||||
if (lyxlayout->is_environment) {
|
if (lyxlayout->is_environment) {
|
||||||
// move everything in a new environment inset
|
// move everything in a new environment inset
|
||||||
|
@ -820,15 +820,15 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
cur.message(_("Paste"));
|
cur.message(_("Paste"));
|
||||||
cap::replaceSelection(cur);
|
cap::replaceSelection(cur);
|
||||||
if (cmd.argument().empty() && !theClipboard().isInternal())
|
if (cmd.argument().empty() && !theClipboard().isInternal())
|
||||||
pasteClipboard(cur, bv->buffer()->errorList("Paste"));
|
pasteClipboard(cur, bv->buffer().errorList("Paste"));
|
||||||
else {
|
else {
|
||||||
string const arg(to_utf8(cmd.argument()));
|
string const arg(to_utf8(cmd.argument()));
|
||||||
pasteFromStack(cur, bv->buffer()->errorList("Paste"),
|
pasteFromStack(cur, bv->buffer().errorList("Paste"),
|
||||||
isStrUnsignedInt(arg) ?
|
isStrUnsignedInt(arg) ?
|
||||||
convert<unsigned int>(arg) :
|
convert<unsigned int>(arg) :
|
||||||
0);
|
0);
|
||||||
}
|
}
|
||||||
bv->buffer()->errors("Paste");
|
bv->buffer().errors("Paste");
|
||||||
cur.clearSelection(); // bug 393
|
cur.clearSelection(); // bug 393
|
||||||
finishUndo();
|
finishUndo();
|
||||||
break;
|
break;
|
||||||
@ -881,7 +881,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
|
|
||||||
// Derive layout number from given argument (string)
|
// Derive layout number from given argument (string)
|
||||||
// and current buffer's textclass (number)
|
// and current buffer's textclass (number)
|
||||||
TextClass const & tclass = bv->buffer()->params().getTextClass();
|
TextClass const & tclass = bv->buffer().params().getTextClass();
|
||||||
if (layout.empty())
|
if (layout.empty())
|
||||||
layout = tclass.defaultLayoutName();
|
layout = tclass.defaultLayoutName();
|
||||||
bool hasLayout = tclass.hasLayout(layout);
|
bool hasLayout = tclass.hasLayout(layout);
|
||||||
@ -925,9 +925,9 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
|
|
||||||
case LFUN_CLIPBOARD_PASTE:
|
case LFUN_CLIPBOARD_PASTE:
|
||||||
cur.clearSelection();
|
cur.clearSelection();
|
||||||
pasteClipboard(cur, bv->buffer()->errorList("Paste"),
|
pasteClipboard(cur, bv->buffer().errorList("Paste"),
|
||||||
cmd.argument() == "paragraph");
|
cmd.argument() == "paragraph");
|
||||||
bv->buffer()->errors("Paste");
|
bv->buffer().errors("Paste");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_PRIMARY_SELECTION_PASTE:
|
case LFUN_PRIMARY_SELECTION_PASTE:
|
||||||
@ -953,7 +953,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
case LFUN_QUOTE_INSERT: {
|
case LFUN_QUOTE_INSERT: {
|
||||||
Paragraph & par = cur.paragraph();
|
Paragraph & par = cur.paragraph();
|
||||||
pos_type pos = cur.pos();
|
pos_type pos = cur.pos();
|
||||||
BufferParams const & bufparams = bv->buffer()->params();
|
BufferParams const & bufparams = bv->buffer().params();
|
||||||
Layout_ptr const & style = par.layout();
|
Layout_ptr const & style = par.layout();
|
||||||
if (!style->pass_thru
|
if (!style->pass_thru
|
||||||
&& par.getFontSettings(bufparams, pos).language()->lang() != "hebrew") {
|
&& par.getFontSettings(bufparams, pos).language()->lang() != "hebrew") {
|
||||||
@ -1031,9 +1031,9 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
cap::copySelectionToStack();
|
cap::copySelectionToStack();
|
||||||
|
|
||||||
cap::pasteSelection(bv->cursor(),
|
cap::pasteSelection(bv->cursor(),
|
||||||
bv->buffer()->errorList("Paste"));
|
bv->buffer().errorList("Paste"));
|
||||||
bv->buffer()->errors("Paste");
|
bv->buffer().errors("Paste");
|
||||||
bv->buffer()->markDirty();
|
bv->buffer().markDirty();
|
||||||
finishUndo();
|
finishUndo();
|
||||||
} else {
|
} else {
|
||||||
lyx::dispatch(FuncRequest(LFUN_PRIMARY_SELECTION_PASTE, "paragraph"));
|
lyx::dispatch(FuncRequest(LFUN_PRIMARY_SELECTION_PASTE, "paragraph"));
|
||||||
@ -1212,7 +1212,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
// inside it.
|
// inside it.
|
||||||
doInsertInset(cur, this, cmd, true, true);
|
doInsertInset(cur, this, cmd, true, true);
|
||||||
cur.posRight();
|
cur.posRight();
|
||||||
updateLabels(*bv->buffer());
|
updateLabels(bv->buffer());
|
||||||
break;
|
break;
|
||||||
case LFUN_NOTE_INSERT:
|
case LFUN_NOTE_INSERT:
|
||||||
case LFUN_CHARSTYLE_INSERT:
|
case LFUN_CHARSTYLE_INSERT:
|
||||||
@ -1249,7 +1249,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
cur.posRight();
|
cur.posRight();
|
||||||
ParagraphList & pars = cur.text()->paragraphs();
|
ParagraphList & pars = cur.text()->paragraphs();
|
||||||
|
|
||||||
TextClass const & tclass = bv->buffer()->params().getTextClass();
|
TextClass const & tclass = bv->buffer().params().getTextClass();
|
||||||
|
|
||||||
// add a separate paragraph for the caption inset
|
// add a separate paragraph for the caption inset
|
||||||
pars.push_back(Paragraph());
|
pars.push_back(Paragraph());
|
||||||
@ -1516,7 +1516,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_FLOAT_LIST: {
|
case LFUN_FLOAT_LIST: {
|
||||||
TextClass const & tclass = bv->buffer()->params().getTextClass();
|
TextClass const & tclass = bv->buffer().params().getTextClass();
|
||||||
if (tclass.floats().typeExist(to_utf8(cmd.argument()))) {
|
if (tclass.floats().typeExist(to_utf8(cmd.argument()))) {
|
||||||
recordUndo(cur);
|
recordUndo(cur);
|
||||||
if (cur.selection())
|
if (cur.selection())
|
||||||
@ -1896,7 +1896,7 @@ bool Text::getStatus(Cursor & cur, FuncRequest const & cmd,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_INSET_DISSOLVE:
|
case LFUN_INSET_DISSOLVE:
|
||||||
enable = !isMainText(*cur.bv().buffer()) && cur.inset().nargs() == 1;
|
enable = !isMainText(cur.bv().buffer()) && cur.inset().nargs() == 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LFUN_CHANGE_ACCEPT:
|
case LFUN_CHANGE_ACCEPT:
|
||||||
|
@ -115,7 +115,7 @@ TextMetrics::TextMetrics(BufferView * bv, Text * text)
|
|||||||
dim_.asc = 10;
|
dim_.asc = 10;
|
||||||
dim_.des = 10;
|
dim_.des = 10;
|
||||||
|
|
||||||
//text_->updateLabels(*bv->buffer());
|
//text_->updateLabels(bv->buffer());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -172,13 +172,13 @@ bool TextMetrics::metrics(MetricsInfo & mi, Dimension & dim)
|
|||||||
|
|
||||||
int TextMetrics::rightMargin(ParagraphMetrics const & pm) const
|
int TextMetrics::rightMargin(ParagraphMetrics const & pm) const
|
||||||
{
|
{
|
||||||
return main_text_? pm.rightMargin(*bv_->buffer()) : 0;
|
return main_text_? pm.rightMargin(bv_->buffer()) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int TextMetrics::rightMargin(pit_type const pit) const
|
int TextMetrics::rightMargin(pit_type const pit) const
|
||||||
{
|
{
|
||||||
return main_text_? par_metrics_[pit].rightMargin(*bv_->buffer()) : 0;
|
return main_text_? par_metrics_[pit].rightMargin(bv_->buffer()) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -191,7 +191,7 @@ bool TextMetrics::redoParagraph(pit_type const pit)
|
|||||||
// reinitialize paragraph dimension.
|
// reinitialize paragraph dimension.
|
||||||
pm.dim() = Dimension();
|
pm.dim() = Dimension();
|
||||||
Paragraph & par = text_->getPar(pit);
|
Paragraph & par = text_->getPar(pit);
|
||||||
Buffer & buffer = *bv_->buffer();
|
Buffer & buffer = bv_->buffer();
|
||||||
main_text_ = (text_ == &buffer.text());
|
main_text_ = (text_ == &buffer.text());
|
||||||
bool changed = false;
|
bool changed = false;
|
||||||
|
|
||||||
@ -275,7 +275,7 @@ RowMetrics TextMetrics::computeRowMetrics(pit_type const pit,
|
|||||||
Row const & row) const
|
Row const & row) const
|
||||||
{
|
{
|
||||||
RowMetrics result;
|
RowMetrics result;
|
||||||
Buffer & buffer = *bv_->buffer();
|
Buffer & buffer = bv_->buffer();
|
||||||
Paragraph const & par = text_->getPar(pit);
|
Paragraph const & par = text_->getPar(pit);
|
||||||
|
|
||||||
double w = dim_.wid - row.width();
|
double w = dim_.wid - row.width();
|
||||||
@ -397,7 +397,7 @@ RowMetrics TextMetrics::computeRowMetrics(pit_type const pit,
|
|||||||
|
|
||||||
int TextMetrics::labelFill(pit_type const pit, Row const & row) const
|
int TextMetrics::labelFill(pit_type const pit, Row const & row) const
|
||||||
{
|
{
|
||||||
Buffer & buffer = *bv_->buffer();
|
Buffer & buffer = bv_->buffer();
|
||||||
Paragraph const & par = text_->getPar(pit);
|
Paragraph const & par = text_->getPar(pit);
|
||||||
|
|
||||||
pos_type last = par.beginOfBody();
|
pos_type last = par.beginOfBody();
|
||||||
@ -448,14 +448,14 @@ int TextMetrics::labelEnd(pit_type const pit) const
|
|||||||
if (text_->getPar(pit).layout()->margintype != MARGIN_MANUAL)
|
if (text_->getPar(pit).layout()->margintype != MARGIN_MANUAL)
|
||||||
return 0;
|
return 0;
|
||||||
// return the beginning of the body
|
// return the beginning of the body
|
||||||
return text_->leftMargin(*bv_->buffer(), max_width_, pit);
|
return text_->leftMargin(bv_->buffer(), max_width_, pit);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void TextMetrics::rowBreakPoint(int width, pit_type const pit,
|
void TextMetrics::rowBreakPoint(int width, pit_type const pit,
|
||||||
Row & row) const
|
Row & row) const
|
||||||
{
|
{
|
||||||
Buffer & buffer = *bv_->buffer();
|
Buffer & buffer = bv_->buffer();
|
||||||
ParagraphMetrics const & pm = par_metrics_[pit];
|
ParagraphMetrics const & pm = par_metrics_[pit];
|
||||||
Paragraph const & par = text_->getPar(pit);
|
Paragraph const & par = text_->getPar(pit);
|
||||||
pos_type const end = par.size();
|
pos_type const end = par.size();
|
||||||
@ -571,7 +571,7 @@ void TextMetrics::rowBreakPoint(int width, pit_type const pit,
|
|||||||
void TextMetrics::setRowWidth(int right_margin,
|
void TextMetrics::setRowWidth(int right_margin,
|
||||||
pit_type const pit, Row & row) const
|
pit_type const pit, Row & row) const
|
||||||
{
|
{
|
||||||
Buffer & buffer = *bv_->buffer();
|
Buffer & buffer = bv_->buffer();
|
||||||
// get the pure distance
|
// get the pure distance
|
||||||
pos_type const end = row.endpos();
|
pos_type const end = row.endpos();
|
||||||
ParagraphMetrics const & pm = par_metrics_[pit];
|
ParagraphMetrics const & pm = par_metrics_[pit];
|
||||||
@ -628,7 +628,7 @@ void TextMetrics::setHeightOfRow(pit_type const pit,
|
|||||||
// increase but not decrease the height. Just some point to
|
// increase but not decrease the height. Just some point to
|
||||||
// start with so we don't have to do the assignment below too
|
// start with so we don't have to do the assignment below too
|
||||||
// often.
|
// often.
|
||||||
Buffer const & buffer = *bv_->buffer();
|
Buffer const & buffer = bv_->buffer();
|
||||||
Font font = text_->getFont(buffer, par, row.pos());
|
Font font = text_->getFont(buffer, par, row.pos());
|
||||||
Font::FONT_SIZE const tmpsize = font.size();
|
Font::FONT_SIZE const tmpsize = font.size();
|
||||||
font = text_->getLayoutFont(buffer, pit);
|
font = text_->getLayoutFont(buffer, pit);
|
||||||
@ -808,7 +808,7 @@ void TextMetrics::setHeightOfRow(pit_type const pit,
|
|||||||
pos_type TextMetrics::getColumnNearX(pit_type const pit,
|
pos_type TextMetrics::getColumnNearX(pit_type const pit,
|
||||||
Row const & row, int & x, bool & boundary) const
|
Row const & row, int & x, bool & boundary) const
|
||||||
{
|
{
|
||||||
Buffer const & buffer = *bv_->buffer();
|
Buffer const & buffer = bv_->buffer();
|
||||||
|
|
||||||
/// For the main Text, it is possible that this pit is not
|
/// For the main Text, it is possible that this pit is not
|
||||||
/// yet in the CoordCache when moving cursor up.
|
/// yet in the CoordCache when moving cursor up.
|
||||||
@ -957,7 +957,7 @@ pos_type TextMetrics::x2pos(pit_type pit, int row, int x) const
|
|||||||
|
|
||||||
int TextMetrics::singleWidth(pit_type pit, pos_type pos) const
|
int TextMetrics::singleWidth(pit_type pit, pos_type pos) const
|
||||||
{
|
{
|
||||||
Buffer const & buffer = *bv_->buffer();
|
Buffer const & buffer = bv_->buffer();
|
||||||
ParagraphMetrics const & pm = par_metrics_[pit];
|
ParagraphMetrics const & pm = par_metrics_[pit];
|
||||||
|
|
||||||
return pm.singleWidth(pos, text_->getFont(buffer, text_->getPar(pit), pos));
|
return pm.singleWidth(pos, text_->getFont(buffer, text_->getPar(pit), pos));
|
||||||
|
50
src/Undo.cpp
50
src/Undo.cpp
@ -133,7 +133,7 @@ void recordUndo(Undo::undo_kind kind,
|
|||||||
BOOST_ASSERT(last_pit <= cur.lastpit());
|
BOOST_ASSERT(last_pit <= cur.lastpit());
|
||||||
|
|
||||||
doRecordUndo(kind, cur, first_pit, last_pit, cur,
|
doRecordUndo(kind, cur, first_pit, last_pit, cur,
|
||||||
cur.bv().buffer()->params(), false, stack);
|
cur.bv().buffer().params(), false, stack);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -154,8 +154,8 @@ bool textUndoOrRedo(BufferView & bv,
|
|||||||
stack.pop();
|
stack.pop();
|
||||||
|
|
||||||
// We will store in otherstack the part of the document under 'undo'
|
// We will store in otherstack the part of the document under 'undo'
|
||||||
Buffer * buf = bv.buffer();
|
Buffer & buf = bv.buffer();
|
||||||
DocIterator cell_dit = undo.cell.asDocIterator(&buf->inset());
|
DocIterator cell_dit = undo.cell.asDocIterator(&buf.inset());
|
||||||
|
|
||||||
doRecordUndo(Undo::ATOMIC, cell_dit,
|
doRecordUndo(Undo::ATOMIC, cell_dit,
|
||||||
undo.from, cell_dit.lastpit() - undo.end, bv.cursor(),
|
undo.from, cell_dit.lastpit() - undo.end, bv.cursor(),
|
||||||
@ -165,13 +165,13 @@ bool textUndoOrRedo(BufferView & bv,
|
|||||||
// This does the actual undo/redo.
|
// This does the actual undo/redo.
|
||||||
//lyxerr << "undo, performing: " << undo << std::endl;
|
//lyxerr << "undo, performing: " << undo << std::endl;
|
||||||
bool labelsUpdateNeeded = false;
|
bool labelsUpdateNeeded = false;
|
||||||
DocIterator dit = undo.cell.asDocIterator(&buf->inset());
|
DocIterator dit = undo.cell.asDocIterator(&buf.inset());
|
||||||
if (undo.isFullBuffer) {
|
if (undo.isFullBuffer) {
|
||||||
BOOST_ASSERT(undo.pars);
|
BOOST_ASSERT(undo.pars);
|
||||||
// This is a full document
|
// This is a full document
|
||||||
otherstack.top().bparams = buf->params();
|
otherstack.top().bparams = buf.params();
|
||||||
buf->params() = undo.bparams;
|
buf.params() = undo.bparams;
|
||||||
std::swap(buf->paragraphs(), *undo.pars);
|
std::swap(buf.paragraphs(), *undo.pars);
|
||||||
delete undo.pars;
|
delete undo.pars;
|
||||||
undo.pars = 0;
|
undo.pars = 0;
|
||||||
} else if (dit.inMathed()) {
|
} else if (dit.inMathed()) {
|
||||||
@ -217,13 +217,13 @@ bool textUndoOrRedo(BufferView & bv,
|
|||||||
|
|
||||||
// Set cursor
|
// Set cursor
|
||||||
Cursor & cur = bv.cursor();
|
Cursor & cur = bv.cursor();
|
||||||
cur.setCursor(undo.cursor.asDocIterator(&buf->inset()));
|
cur.setCursor(undo.cursor.asDocIterator(&buf.inset()));
|
||||||
cur.selection() = false;
|
cur.selection() = false;
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
cur.fixIfBroken();
|
cur.fixIfBroken();
|
||||||
|
|
||||||
if (labelsUpdateNeeded)
|
if (labelsUpdateNeeded)
|
||||||
updateLabels(*buf);
|
updateLabels(buf);
|
||||||
finishUndo();
|
finishUndo();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -240,27 +240,27 @@ void finishUndo()
|
|||||||
|
|
||||||
bool textUndo(BufferView & bv)
|
bool textUndo(BufferView & bv)
|
||||||
{
|
{
|
||||||
return textUndoOrRedo(bv, bv.buffer()->undostack(),
|
return textUndoOrRedo(bv, bv.buffer().undostack(),
|
||||||
bv.buffer()->redostack());
|
bv.buffer().redostack());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool textRedo(BufferView & bv)
|
bool textRedo(BufferView & bv)
|
||||||
{
|
{
|
||||||
return textUndoOrRedo(bv, bv.buffer()->redostack(),
|
return textUndoOrRedo(bv, bv.buffer().redostack(),
|
||||||
bv.buffer()->undostack());
|
bv.buffer().undostack());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void recordUndo(Undo::undo_kind kind,
|
void recordUndo(Undo::undo_kind kind,
|
||||||
Cursor & cur, pit_type first, pit_type last)
|
Cursor & cur, pit_type first, pit_type last)
|
||||||
{
|
{
|
||||||
Buffer * buf = cur.bv().buffer();
|
Buffer & buf = cur.bv().buffer();
|
||||||
recordUndo(kind, cur, first, last, buf->undostack());
|
recordUndo(kind, cur, first, last, buf.undostack());
|
||||||
buf->redostack().clear();
|
buf.redostack().clear();
|
||||||
//lyxerr << "undostack:\n";
|
//lyxerr << "undostack:\n";
|
||||||
//for (size_t i = 0, n = buf->undostack().size(); i != n && i < 6; ++i)
|
//for (size_t i = 0, n = buf.undostack().size(); i != n && i < 6; ++i)
|
||||||
// lyxerr << " " << i << ": " << buf->undostack()[i] << std::endl;
|
// lyxerr << " " << i << ": " << buf.undostack()[i] << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -274,9 +274,9 @@ void recordUndoInset(Cursor & cur, Undo::undo_kind kind)
|
|||||||
{
|
{
|
||||||
Cursor c = cur;
|
Cursor c = cur;
|
||||||
c.pop();
|
c.pop();
|
||||||
Buffer * buf = cur.bv().buffer();
|
Buffer & buf = cur.bv().buffer();
|
||||||
doRecordUndo(kind, c, c.pit(), c.pit(), cur,
|
doRecordUndo(kind, c, c.pit(), c.pit(), cur,
|
||||||
buf->params(), false, buf->undostack());
|
buf.params(), false, buf.undostack());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -301,15 +301,15 @@ void recordUndo(Cursor & cur, Undo::undo_kind kind,
|
|||||||
|
|
||||||
void recordUndoFullDocument(BufferView * bv)
|
void recordUndoFullDocument(BufferView * bv)
|
||||||
{
|
{
|
||||||
Buffer * buf = bv->buffer();
|
Buffer & buf = bv->buffer();
|
||||||
doRecordUndo(
|
doRecordUndo(
|
||||||
Undo::ATOMIC,
|
Undo::ATOMIC,
|
||||||
doc_iterator_begin(buf->inset()),
|
doc_iterator_begin(buf.inset()),
|
||||||
0, buf->paragraphs().size() - 1,
|
0, buf.paragraphs().size() - 1,
|
||||||
bv->cursor(),
|
bv->cursor(),
|
||||||
buf->params(),
|
buf.params(),
|
||||||
true,
|
true,
|
||||||
buf->undostack()
|
buf.undostack()
|
||||||
);
|
);
|
||||||
undo_finished = false;
|
undo_finished = false;
|
||||||
}
|
}
|
||||||
|
@ -519,7 +519,7 @@ int VSpace::inPixels(BufferView const & bv) const
|
|||||||
switch (kind_) {
|
switch (kind_) {
|
||||||
|
|
||||||
case DEFSKIP:
|
case DEFSKIP:
|
||||||
return bv.buffer()->params().getDefSkip().inPixels(bv);
|
return bv.buffer().params().getDefSkip().inPixels(bv);
|
||||||
|
|
||||||
// This is how the skips are normally defined by LateX.
|
// This is how the skips are normally defined by LateX.
|
||||||
// But there should be some way to change this per document.
|
// But there should be some way to change this per document.
|
||||||
|
@ -175,7 +175,7 @@ Point coordOffset(BufferView const & bv, DocIterator const & dit,
|
|||||||
// of xx:yy
|
// of xx:yy
|
||||||
if (sl.text()) {
|
if (sl.text()) {
|
||||||
bool boundary_i = boundary && i + 1 == dit.depth();
|
bool boundary_i = boundary && i + 1 == dit.depth();
|
||||||
bool rtl = sl.text()->isRTL(*bv.buffer(), sl, boundary_i);
|
bool rtl = sl.text()->isRTL(bv.buffer(), sl, boundary_i);
|
||||||
if (rtl)
|
if (rtl)
|
||||||
x -= lastw;
|
x -= lastw;
|
||||||
}
|
}
|
||||||
@ -217,7 +217,7 @@ Point coordOffset(BufferView const & bv, DocIterator const & dit,
|
|||||||
// In the RTL case place the nested inset at the left of the cursor in
|
// In the RTL case place the nested inset at the left of the cursor in
|
||||||
// the outer paragraph
|
// the outer paragraph
|
||||||
bool boundary_1 = boundary && 1 == dit.depth();
|
bool boundary_1 = boundary && 1 == dit.depth();
|
||||||
bool rtl = dit.bottom().text()->isRTL(*bv.buffer(), dit.bottom(), boundary_1);
|
bool rtl = dit.bottom().text()->isRTL(bv.buffer(), dit.bottom(), boundary_1);
|
||||||
if (rtl)
|
if (rtl)
|
||||||
x -= lastw;
|
x -= lastw;
|
||||||
|
|
||||||
|
@ -253,7 +253,7 @@ int AutoSaveBuffer::generateChild()
|
|||||||
|
|
||||||
FileName const tmp_ret(tempName(FileName(), "lyxauto"));
|
FileName const tmp_ret(tempName(FileName(), "lyxauto"));
|
||||||
if (!tmp_ret.empty()) {
|
if (!tmp_ret.empty()) {
|
||||||
bv_.buffer()->writeFile(tmp_ret);
|
bv_.buffer().writeFile(tmp_ret);
|
||||||
// assume successful write of tmp_ret
|
// assume successful write of tmp_ret
|
||||||
if (!rename(tmp_ret, fname_)) {
|
if (!rename(tmp_ret, fname_)) {
|
||||||
failed = true;
|
failed = true;
|
||||||
@ -269,12 +269,11 @@ int AutoSaveBuffer::generateChild()
|
|||||||
|
|
||||||
if (failed) {
|
if (failed) {
|
||||||
// failed to write/rename tmp_ret so try writing direct
|
// failed to write/rename tmp_ret so try writing direct
|
||||||
if (!bv_.buffer()->writeFile(fname_)) {
|
if (!bv_.buffer().writeFile(fname_)) {
|
||||||
// It is dangerous to do this in the child,
|
// It is dangerous to do this in the child,
|
||||||
// but safe in the parent, so...
|
// but safe in the parent, so...
|
||||||
if (pid == -1) // emit message signal.
|
if (pid == -1) // emit message signal.
|
||||||
bv_.buffer()
|
bv_.buffer().message(_("Autosave failed!"));
|
||||||
->message(_("Autosave failed!"));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (pid == 0) { // we are the child so...
|
if (pid == 0) { // we are the child so...
|
||||||
@ -291,29 +290,26 @@ void autoSave(BufferView * bv)
|
|||||||
// should probably be moved into BufferList (Lgb)
|
// should probably be moved into BufferList (Lgb)
|
||||||
// Perfect target for a thread...
|
// Perfect target for a thread...
|
||||||
{
|
{
|
||||||
if (!bv->buffer())
|
if (bv->buffer().isBakClean() || bv->buffer().isReadonly()) {
|
||||||
return;
|
|
||||||
|
|
||||||
if (bv->buffer()->isBakClean() || bv->buffer()->isReadonly()) {
|
|
||||||
// We don't save now, but we'll try again later
|
// We don't save now, but we'll try again later
|
||||||
bv->buffer()->resetAutosaveTimers();
|
bv->buffer().resetAutosaveTimers();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// emit message signal.
|
// emit message signal.
|
||||||
bv->buffer()->message(_("Autosaving current document..."));
|
bv->buffer().message(_("Autosaving current document..."));
|
||||||
|
|
||||||
// create autosave filename
|
// create autosave filename
|
||||||
string fname = bv->buffer()->filePath();
|
string fname = bv->buffer().filePath();
|
||||||
fname += '#';
|
fname += '#';
|
||||||
fname += onlyFilename(bv->buffer()->fileName());
|
fname += onlyFilename(bv->buffer().fileName());
|
||||||
fname += '#';
|
fname += '#';
|
||||||
|
|
||||||
AutoSaveBuffer autosave(*bv, FileName(fname));
|
AutoSaveBuffer autosave(*bv, FileName(fname));
|
||||||
autosave.start();
|
autosave.start();
|
||||||
|
|
||||||
bv->buffer()->markBakClean();
|
bv->buffer().markBakClean();
|
||||||
bv->buffer()->resetAutosaveTimers();
|
bv->buffer().resetAutosaveTimers();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -342,9 +338,6 @@ void newFile(LyXView & lv, string const & filename)
|
|||||||
// Insert plain text file (if filename is empty, prompt for one)
|
// Insert plain text file (if filename is empty, prompt for one)
|
||||||
void insertPlaintextFile(BufferView * bv, string const & f, bool asParagraph)
|
void insertPlaintextFile(BufferView * bv, string const & f, bool asParagraph)
|
||||||
{
|
{
|
||||||
if (!bv->buffer())
|
|
||||||
return;
|
|
||||||
|
|
||||||
docstring const tmpstr =
|
docstring const tmpstr =
|
||||||
getContentsOfPlaintextFile(bv, f, asParagraph);
|
getContentsOfPlaintextFile(bv, f, asParagraph);
|
||||||
|
|
||||||
@ -373,7 +366,7 @@ docstring const getContentsOfPlaintextFile(BufferView * bv, string const & f,
|
|||||||
: LFUN_FILE_INSERT_PLAINTEXT) );
|
: LFUN_FILE_INSERT_PLAINTEXT) );
|
||||||
|
|
||||||
FileDialog::Result result =
|
FileDialog::Result result =
|
||||||
fileDlg.open(from_utf8(bv->buffer()->filePath()),
|
fileDlg.open(from_utf8(bv->buffer().filePath()),
|
||||||
FileFilterList(), docstring());
|
FileFilterList(), docstring());
|
||||||
|
|
||||||
if (result.first == FileDialog::Later)
|
if (result.first == FileDialog::Later)
|
||||||
|
@ -82,7 +82,7 @@ using support::compare_ascii_no_case;
|
|||||||
|
|
||||||
Inset * createInset(BufferView * bv, FuncRequest const & cmd)
|
Inset * createInset(BufferView * bv, FuncRequest const & cmd)
|
||||||
{
|
{
|
||||||
BufferParams const & params = bv->buffer()->params();
|
BufferParams const & params = bv->buffer().params();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
@ -207,7 +207,7 @@ Inset * createInset(BufferView * bv, FuncRequest const & cmd)
|
|||||||
r = 2;
|
r = 2;
|
||||||
if (c <= 0)
|
if (c <= 0)
|
||||||
c = 2;
|
c = 2;
|
||||||
return new InsetTabular(*bv->buffer(), r, c);
|
return new InsetTabular(bv->buffer(), r, c);
|
||||||
}
|
}
|
||||||
|
|
||||||
case LFUN_CAPTION_INSERT: {
|
case LFUN_CAPTION_INSERT: {
|
||||||
@ -270,7 +270,7 @@ Inset * createInset(BufferView * bv, FuncRequest const & cmd)
|
|||||||
return new InsetListings(params, par);
|
return new InsetListings(params, par);
|
||||||
|
|
||||||
} else if (name == "external") {
|
} else if (name == "external") {
|
||||||
Buffer const & buffer = *bv->buffer();
|
Buffer const & buffer = bv->buffer();
|
||||||
InsetExternalParams iep;
|
InsetExternalParams iep;
|
||||||
InsetExternalMailer::string2params(to_utf8(cmd.argument()),
|
InsetExternalMailer::string2params(to_utf8(cmd.argument()),
|
||||||
buffer, iep);
|
buffer, iep);
|
||||||
@ -279,7 +279,7 @@ Inset * createInset(BufferView * bv, FuncRequest const & cmd)
|
|||||||
return inset.release();
|
return inset.release();
|
||||||
|
|
||||||
} else if (name == "graphics") {
|
} else if (name == "graphics") {
|
||||||
Buffer const & buffer = *bv->buffer();
|
Buffer const & buffer = bv->buffer();
|
||||||
InsetGraphicsParams igp;
|
InsetGraphicsParams igp;
|
||||||
InsetGraphicsMailer::string2params(to_utf8(cmd.argument()),
|
InsetGraphicsMailer::string2params(to_utf8(cmd.argument()),
|
||||||
buffer, igp);
|
buffer, igp);
|
||||||
@ -314,7 +314,7 @@ Inset * createInset(BufferView * bv, FuncRequest const & cmd)
|
|||||||
InsetCommandParams icp(name);
|
InsetCommandParams icp(name);
|
||||||
InsetCommandMailer::string2params(name, to_utf8(cmd.argument()),
|
InsetCommandMailer::string2params(name, to_utf8(cmd.argument()),
|
||||||
icp);
|
icp);
|
||||||
return new InsetRef(icp, *bv->buffer());
|
return new InsetRef(icp, bv->buffer());
|
||||||
|
|
||||||
} else if (name == "toc") {
|
} else if (name == "toc") {
|
||||||
InsetCommandParams icp("tableofcontents");
|
InsetCommandParams icp("tableofcontents");
|
||||||
|
@ -95,7 +95,7 @@ Buffer * LyXView::buffer()
|
|||||||
{
|
{
|
||||||
WorkArea * work_area = currentWorkArea();
|
WorkArea * work_area = currentWorkArea();
|
||||||
if (work_area)
|
if (work_area)
|
||||||
return work_area->bufferView().buffer();
|
return &work_area->bufferView().buffer();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,7 +104,7 @@ Buffer const * LyXView::buffer() const
|
|||||||
{
|
{
|
||||||
WorkArea const * work_area = currentWorkArea();
|
WorkArea const * work_area = currentWorkArea();
|
||||||
if (work_area)
|
if (work_area)
|
||||||
return work_area->bufferView().buffer();
|
return &work_area->bufferView().buffer();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -445,7 +445,7 @@ Buffer const * const LyXView::updateInset(Inset const * inset)
|
|||||||
BOOST_ASSERT(work_area);
|
BOOST_ASSERT(work_area);
|
||||||
work_area->scheduleRedraw();
|
work_area->scheduleRedraw();
|
||||||
}
|
}
|
||||||
return work_area->bufferView().buffer();
|
return &work_area->bufferView().buffer();
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace frontend
|
} // namespace frontend
|
||||||
|
@ -97,7 +97,7 @@ WorkArea::~WorkArea()
|
|||||||
// restore to the left of the top level inset.
|
// restore to the left of the top level inset.
|
||||||
Cursor & cur = buffer_view_->cursor();
|
Cursor & cur = buffer_view_->cursor();
|
||||||
LyX::ref().session().lastFilePos().save(
|
LyX::ref().session().lastFilePos().save(
|
||||||
support::FileName(buffer_view_->buffer()->fileName()),
|
support::FileName(buffer_view_->buffer().fileName()),
|
||||||
boost::tie(cur.bottom().pit(), cur.bottom().pos()) );
|
boost::tie(cur.bottom().pit(), cur.bottom().pos()) );
|
||||||
|
|
||||||
delete buffer_view_;
|
delete buffer_view_;
|
||||||
@ -291,7 +291,7 @@ void WorkArea::showCursor()
|
|||||||
|
|
||||||
Text const & text = *buffer_view_->cursor().innerText();
|
Text const & text = *buffer_view_->cursor().innerText();
|
||||||
Font const & realfont = text.real_current_font;
|
Font const & realfont = text.real_current_font;
|
||||||
BufferParams const & bp = buffer_view_->buffer()->params();
|
BufferParams const & bp = buffer_view_->buffer().params();
|
||||||
bool const samelang = realfont.language() == bp.language;
|
bool const samelang = realfont.language() == bp.language;
|
||||||
bool const isrtl = realfont.isVisibleRightToLeft();
|
bool const isrtl = realfont.isVisibleRightToLeft();
|
||||||
|
|
||||||
|
@ -44,18 +44,18 @@ void ControlErrorList::clearParams()
|
|||||||
|
|
||||||
ErrorList const & ControlErrorList::errorList() const
|
ErrorList const & ControlErrorList::errorList() const
|
||||||
{
|
{
|
||||||
return kernel().bufferview()->buffer()->errorList(error_type_);
|
return kernel().bufferview()->buffer().errorList(error_type_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool ControlErrorList::initialiseParams(string const & error_type)
|
bool ControlErrorList::initialiseParams(string const & error_type)
|
||||||
{
|
{
|
||||||
error_type_ = error_type;
|
error_type_ = error_type;
|
||||||
Buffer * buf = kernel().bufferview()->buffer();
|
Buffer const & buf = kernel().bufferview()->buffer();
|
||||||
// FIXME UNICODE
|
// FIXME UNICODE
|
||||||
docstring const title = bformat(_("%1$s Errors (%2$s)"),
|
docstring const title = bformat(_("%1$s Errors (%2$s)"),
|
||||||
_(error_type),
|
_(error_type),
|
||||||
lyx::from_utf8(buf->fileName()));
|
lyx::from_utf8(buf.fileName()));
|
||||||
name_ = lyx::to_utf8(title);
|
name_ = lyx::to_utf8(title);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -148,7 +148,7 @@ bool isLetter(DocIterator const & dit)
|
|||||||
|
|
||||||
WordLangTuple nextWord(Cursor & cur, ptrdiff_t & progress)
|
WordLangTuple nextWord(Cursor & cur, ptrdiff_t & progress)
|
||||||
{
|
{
|
||||||
BufferParams const & bp = cur.bv().buffer()->params();
|
BufferParams const & bp = cur.bv().buffer().params();
|
||||||
bool inword = false;
|
bool inword = false;
|
||||||
bool ignoreword = false;
|
bool ignoreword = false;
|
||||||
cur.resetAnchor();
|
cur.resetAnchor();
|
||||||
|
@ -54,7 +54,7 @@ docstring const ControlViewSource::updateContent(bool fullSource)
|
|||||||
if (par_begin > par_end)
|
if (par_begin > par_end)
|
||||||
std::swap(par_begin, par_end);
|
std::swap(par_begin, par_end);
|
||||||
lyx::odocstringstream ostr;
|
lyx::odocstringstream ostr;
|
||||||
view->buffer()->getSourceCode(ostr, par_begin, par_end + 1, fullSource);
|
view->buffer().getSourceCode(ostr, par_begin, par_end + 1, fullSource);
|
||||||
return ostr.str();
|
return ostr.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -65,11 +65,11 @@ std::pair<int, int> ControlViewSource::getRows() const
|
|||||||
CursorSlice beg = view->cursor().selectionBegin().bottom();
|
CursorSlice beg = view->cursor().selectionBegin().bottom();
|
||||||
CursorSlice end = view->cursor().selectionEnd().bottom();
|
CursorSlice end = view->cursor().selectionEnd().bottom();
|
||||||
|
|
||||||
int begrow = view->buffer()->texrow().
|
int begrow = view->buffer().texrow().
|
||||||
getRowFromIdPos(beg.paragraph().id(), beg.pos());
|
getRowFromIdPos(beg.paragraph().id(), beg.pos());
|
||||||
int endrow = view->buffer()->texrow().
|
int endrow = view->buffer().texrow().
|
||||||
getRowFromIdPos(end.paragraph().id(), end.pos());
|
getRowFromIdPos(end.paragraph().id(), end.pos());
|
||||||
int nextendrow = view->buffer()->texrow().
|
int nextendrow = view->buffer().texrow().
|
||||||
getRowFromIdPos(end.paragraph().id(), end.pos() + 1);
|
getRowFromIdPos(end.paragraph().id(), end.pos() + 1);
|
||||||
return std::make_pair(begrow, endrow == nextendrow ? endrow : (nextendrow - 1));
|
return std::make_pair(begrow, endrow == nextendrow ? endrow : (nextendrow - 1));
|
||||||
}
|
}
|
||||||
|
@ -49,9 +49,7 @@ void Kernel::disconnect(string const & name) const
|
|||||||
|
|
||||||
bool Kernel::isBufferAvailable() const
|
bool Kernel::isBufferAvailable() const
|
||||||
{
|
{
|
||||||
if (!lyxview_.view())
|
return lyxview_.buffer() != 0;
|
||||||
return false;
|
|
||||||
return lyxview_.view()->buffer() != 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -647,7 +647,7 @@ void GuiView::currentTabChanged(int i)
|
|||||||
BOOST_ASSERT(wa);
|
BOOST_ASSERT(wa);
|
||||||
BufferView & bv = wa->bufferView();
|
BufferView & bv = wa->bufferView();
|
||||||
connectBufferView(bv);
|
connectBufferView(bv);
|
||||||
connectBuffer(*bv.buffer());
|
connectBuffer(bv.buffer());
|
||||||
bv.updateMetrics(false);
|
bv.updateMetrics(false);
|
||||||
bv.cursor().fixIfBroken();
|
bv.cursor().fixIfBroken();
|
||||||
wa->setUpdatesEnabled(true);
|
wa->setUpdatesEnabled(true);
|
||||||
@ -666,7 +666,7 @@ void GuiView::currentTabChanged(int i)
|
|||||||
updateStatusBar();
|
updateStatusBar();
|
||||||
|
|
||||||
lyxerr << "currentTabChanged " << i
|
lyxerr << "currentTabChanged " << i
|
||||||
<< "File" << wa->bufferView().buffer()->fileName() << endl;
|
<< "File" << bv.buffer().fileName() << endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -846,7 +846,7 @@ WorkArea * GuiView::workArea(Buffer & buffer)
|
|||||||
for (int i = 0; i != d.tab_widget_->count(); ++i) {
|
for (int i = 0; i != d.tab_widget_->count(); ++i) {
|
||||||
GuiWorkArea * wa = dynamic_cast<GuiWorkArea *>(d.tab_widget_->widget(i));
|
GuiWorkArea * wa = dynamic_cast<GuiWorkArea *>(d.tab_widget_->widget(i));
|
||||||
BOOST_ASSERT(wa);
|
BOOST_ASSERT(wa);
|
||||||
if (wa->bufferView().buffer() == &buffer)
|
if (&wa->bufferView().buffer() == &buffer)
|
||||||
return wa;
|
return wa;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -69,7 +69,7 @@ void InsetBibitem::doDispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (p["key"] != params()["key"])
|
if (p["key"] != params()["key"])
|
||||||
cur.bv().buffer()->changeRefsIfUnique(params()["key"],
|
cur.bv().buffer().changeRefsIfUnique(params()["key"],
|
||||||
p["key"], Inset::CITE_CODE);
|
p["key"], Inset::CITE_CODE);
|
||||||
setParams(p);
|
setParams(p);
|
||||||
}
|
}
|
||||||
|
@ -600,7 +600,7 @@ void InsetCollapsable::setStatus(Cursor & cur, CollapseStatus status)
|
|||||||
// Because the collapse status is part of the inset and thus an
|
// Because the collapse status is part of the inset and thus an
|
||||||
// integral part of the Buffer contents a changed status must be
|
// integral part of the Buffer contents a changed status must be
|
||||||
// signaled to all views of current buffer.
|
// signaled to all views of current buffer.
|
||||||
cur.bv().buffer()->changed();
|
cur.bv().buffer().changed();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ bool InsetCommand::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
{
|
{
|
||||||
if (updateButtonLabel_) {
|
if (updateButtonLabel_) {
|
||||||
updateButtonLabel_ = false;
|
updateButtonLabel_ = false;
|
||||||
button_.update(getScreenLabel(*mi.base.bv->buffer()),
|
button_.update(getScreenLabel(mi.base.bv->buffer()),
|
||||||
editable() != NOT_EDITABLE);
|
editable() != NOT_EDITABLE);
|
||||||
}
|
}
|
||||||
button_.metrics(mi, dim);
|
button_.metrics(mi, dim);
|
||||||
|
@ -32,7 +32,7 @@ InsetFootlike::InsetFootlike(InsetFootlike const & in)
|
|||||||
bool InsetFootlike::metrics(MetricsInfo & mi, Dimension & dim) const
|
bool InsetFootlike::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
Font tmpfont = mi.base.font;
|
Font tmpfont = mi.base.font;
|
||||||
mi.base.font = mi.base.bv->buffer()->params().getFont();
|
mi.base.font = mi.base.bv->buffer().params().getFont();
|
||||||
InsetCollapsable::metrics(mi, dim);
|
InsetCollapsable::metrics(mi, dim);
|
||||||
mi.base.font = tmpfont;
|
mi.base.font = tmpfont;
|
||||||
bool const changed = dim_ != dim;
|
bool const changed = dim_ != dim;
|
||||||
@ -44,7 +44,7 @@ bool InsetFootlike::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
void InsetFootlike::draw(PainterInfo & pi, int x, int y) const
|
void InsetFootlike::draw(PainterInfo & pi, int x, int y) const
|
||||||
{
|
{
|
||||||
Font tmpfont = pi.base.font;
|
Font tmpfont = pi.base.font;
|
||||||
pi.base.font = pi.base.bv->buffer()->params().getFont();
|
pi.base.font = pi.base.bv->buffer().params().getFont();
|
||||||
InsetCollapsable::draw(pi, x, y);
|
InsetCollapsable::draw(pi, x, y);
|
||||||
pi.base.font = tmpfont;
|
pi.base.font = tmpfont;
|
||||||
}
|
}
|
||||||
|
@ -181,7 +181,7 @@ void InsetGraphics::doDispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
{
|
{
|
||||||
switch (cmd.action) {
|
switch (cmd.action) {
|
||||||
case LFUN_GRAPHICS_EDIT: {
|
case LFUN_GRAPHICS_EDIT: {
|
||||||
Buffer const & buffer = *cur.bv().buffer();
|
Buffer const & buffer = cur.bv().buffer();
|
||||||
InsetGraphicsParams p;
|
InsetGraphicsParams p;
|
||||||
InsetGraphicsMailer::string2params(to_utf8(cmd.argument()), buffer, p);
|
InsetGraphicsMailer::string2params(to_utf8(cmd.argument()), buffer, p);
|
||||||
editGraphics(p, buffer);
|
editGraphics(p, buffer);
|
||||||
|
@ -148,7 +148,7 @@ void InsetInclude::doDispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
if (par_old.getParamValue("label") !=
|
if (par_old.getParamValue("label") !=
|
||||||
par_new.getParamValue("label")
|
par_new.getParamValue("label")
|
||||||
&& !par_new.getParamValue("label").empty())
|
&& !par_new.getParamValue("label").empty())
|
||||||
cur.bv().buffer()->changeRefsIfUnique(
|
cur.bv().buffer().changeRefsIfUnique(
|
||||||
from_utf8(par_old.getParamValue("label")),
|
from_utf8(par_old.getParamValue("label")),
|
||||||
from_utf8(par_new.getParamValue("label")),
|
from_utf8(par_new.getParamValue("label")),
|
||||||
Inset::REF_CODE);
|
Inset::REF_CODE);
|
||||||
@ -770,7 +770,7 @@ bool InsetInclude::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
bool use_preview = false;
|
bool use_preview = false;
|
||||||
if (RenderPreview::status() != LyXRC::PREVIEW_OFF) {
|
if (RenderPreview::status() != LyXRC::PREVIEW_OFF) {
|
||||||
graphics::PreviewImage const * pimage =
|
graphics::PreviewImage const * pimage =
|
||||||
preview_->getPreviewImage(*mi.base.bv->buffer());
|
preview_->getPreviewImage(mi.base.bv->buffer());
|
||||||
use_preview = pimage && pimage->image();
|
use_preview = pimage && pimage->image();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -779,7 +779,7 @@ bool InsetInclude::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
} else {
|
} else {
|
||||||
if (!set_label_) {
|
if (!set_label_) {
|
||||||
set_label_ = true;
|
set_label_ = true;
|
||||||
button_.update(getScreenLabel(*mi.base.bv->buffer()),
|
button_.update(getScreenLabel(mi.base.bv->buffer()),
|
||||||
true);
|
true);
|
||||||
}
|
}
|
||||||
button_.metrics(mi, dim);
|
button_.metrics(mi, dim);
|
||||||
@ -803,7 +803,7 @@ void InsetInclude::draw(PainterInfo & pi, int x, int y) const
|
|||||||
bool use_preview = false;
|
bool use_preview = false;
|
||||||
if (RenderPreview::status() != LyXRC::PREVIEW_OFF) {
|
if (RenderPreview::status() != LyXRC::PREVIEW_OFF) {
|
||||||
graphics::PreviewImage const * pimage =
|
graphics::PreviewImage const * pimage =
|
||||||
preview_->getPreviewImage(*pi.base.bv->buffer());
|
preview_->getPreviewImage(pi.base.bv->buffer());
|
||||||
use_preview = pimage && pimage->image();
|
use_preview = pimage && pimage->image();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ void InsetLabel::doDispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (p["name"] != params()["name"])
|
if (p["name"] != params()["name"])
|
||||||
cur.bv().buffer()->changeRefsIfUnique(params()["name"],
|
cur.bv().buffer().changeRefsIfUnique(params()["name"],
|
||||||
p["name"], Inset::REF_CODE);
|
p["name"], Inset::REF_CODE);
|
||||||
setParams(p);
|
setParams(p);
|
||||||
break;
|
break;
|
||||||
|
@ -1098,14 +1098,14 @@ void toggleFixedWidth(Cursor & cur, InsetText * inset, bool fixedWidth)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
// merge all paragraphs to one
|
// merge all paragraphs to one
|
||||||
BufferParams const & bp = cur.bv().buffer()->params();
|
BufferParams const & bp = cur.bv().buffer().params();
|
||||||
while (inset->paragraphs().size() > 1)
|
while (inset->paragraphs().size() > 1)
|
||||||
mergeParagraph(bp, inset->paragraphs(), 0);
|
mergeParagraph(bp, inset->paragraphs(), 0);
|
||||||
|
|
||||||
// reset layout
|
// reset layout
|
||||||
cur.push(*inset);
|
cur.push(*inset);
|
||||||
// undo information has already been recorded
|
// undo information has already been recorded
|
||||||
inset->getText(0)->setLayout(*cur.bv().buffer(), 0, cur.lastpit() + 1,
|
inset->getText(0)->setLayout(cur.bv().buffer(), 0, cur.lastpit() + 1,
|
||||||
bp.getTextClass().defaultLayoutName());
|
bp.getTextClass().defaultLayoutName());
|
||||||
cur.pop();
|
cur.pop();
|
||||||
}
|
}
|
||||||
@ -4167,12 +4167,12 @@ void InsetTabular::tabularFeatures(Cursor & cur,
|
|||||||
|
|
||||||
case Tabular::APPEND_ROW:
|
case Tabular::APPEND_ROW:
|
||||||
// append the row into the tabular
|
// append the row into the tabular
|
||||||
tabular.appendRow(bv.buffer()->params(), cur.idx());
|
tabular.appendRow(bv.buffer().params(), cur.idx());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Tabular::APPEND_COLUMN:
|
case Tabular::APPEND_COLUMN:
|
||||||
// append the column into the tabular
|
// append the column into the tabular
|
||||||
tabular.appendColumn(bv.buffer()->params(), cur.idx());
|
tabular.appendColumn(bv.buffer().params(), cur.idx());
|
||||||
cur.idx() = tabular.getCellNumber(row, column);
|
cur.idx() = tabular.getCellNumber(row, column);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -4199,11 +4199,11 @@ void InsetTabular::tabularFeatures(Cursor & cur,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Tabular::COPY_ROW:
|
case Tabular::COPY_ROW:
|
||||||
tabular.copyRow(bv.buffer()->params(), row);
|
tabular.copyRow(bv.buffer().params(), row);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Tabular::COPY_COLUMN:
|
case Tabular::COPY_COLUMN:
|
||||||
tabular.copyColumn(bv.buffer()->params(), column);
|
tabular.copyColumn(bv.buffer().params(), column);
|
||||||
cur.idx() = tabular.getCellNumber(row, column);
|
cur.idx() = tabular.getCellNumber(row, column);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -4302,14 +4302,14 @@ void InsetTabular::tabularFeatures(Cursor & cur,
|
|||||||
if (tabular.isMultiColumn(cur.idx()))
|
if (tabular.isMultiColumn(cur.idx()))
|
||||||
tabular.unsetMultiColumn(cur.idx());
|
tabular.unsetMultiColumn(cur.idx());
|
||||||
else
|
else
|
||||||
tabular.setMultiColumn(bv.buffer(), cur.idx(), 1);
|
tabular.setMultiColumn(&bv.buffer(), cur.idx(), 1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// we have a selection so this means we just add all this
|
// we have a selection so this means we just add all this
|
||||||
// cells to form a multicolumn cell
|
// cells to form a multicolumn cell
|
||||||
idx_type const s_start = cur.selBegin().idx();
|
idx_type const s_start = cur.selBegin().idx();
|
||||||
idx_type const s_end = cur.selEnd().idx();
|
idx_type const s_end = cur.selEnd().idx();
|
||||||
tabular.setMultiColumn(bv.buffer(), s_start, s_end - s_start + 1);
|
tabular.setMultiColumn(&bv.buffer(), s_start, s_end - s_start + 1);
|
||||||
cur.idx() = s_start;
|
cur.idx() = s_start;
|
||||||
cur.pit() = 0;
|
cur.pit() = 0;
|
||||||
cur.pos() = 0;
|
cur.pos() = 0;
|
||||||
@ -4619,7 +4619,7 @@ bool InsetTabular::isRightToLeft(Cursor & cur) const
|
|||||||
BOOST_ASSERT(cur.depth() > 1);
|
BOOST_ASSERT(cur.depth() > 1);
|
||||||
Paragraph const & parentpar = cur[cur.depth() - 2].paragraph();
|
Paragraph const & parentpar = cur[cur.depth() - 2].paragraph();
|
||||||
pos_type const parentpos = cur[cur.depth() - 2].pos();
|
pos_type const parentpos = cur[cur.depth() - 2].pos();
|
||||||
return parentpar.getFontSettings(cur.bv().buffer()->params(),
|
return parentpar.getFontSettings(cur.bv().buffer().params(),
|
||||||
parentpos).language()->rightToLeft();
|
parentpos).language()->rightToLeft();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4684,7 +4684,7 @@ bool InsetTabular::insertPlaintextString(BufferView & bv, docstring const & buf,
|
|||||||
if (buf.length() <= 0)
|
if (buf.length() <= 0)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
Buffer const & buffer = *bv.buffer();
|
Buffer const & buffer = bv.buffer();
|
||||||
|
|
||||||
col_type cols = 1;
|
col_type cols = 1;
|
||||||
row_type rows = 1;
|
row_type rows = 1;
|
||||||
|
@ -25,7 +25,7 @@ using std::string;
|
|||||||
void MailInset::showDialog(BufferView * bv) const
|
void MailInset::showDialog(BufferView * bv) const
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(bv);
|
BOOST_ASSERT(bv);
|
||||||
bv->showInsetDialog(name(), inset2string(*bv->buffer()),
|
bv->showInsetDialog(name(), inset2string(bv->buffer()),
|
||||||
&inset());
|
&inset());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -33,7 +33,7 @@ void MailInset::showDialog(BufferView * bv) const
|
|||||||
void MailInset::updateDialog(BufferView * bv) const
|
void MailInset::updateDialog(BufferView * bv) const
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(bv);
|
BOOST_ASSERT(bv);
|
||||||
bv->updateDialog(name(), inset2string(*bv->buffer()));
|
bv->updateDialog(name(), inset2string(bv->buffer()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -86,9 +86,9 @@ graphics::PreviewLoader & getPreviewLoader(Buffer const & buffer)
|
|||||||
|
|
||||||
docstring const statusMessage(BufferView const * bv, string const & snippet)
|
docstring const statusMessage(BufferView const * bv, string const & snippet)
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(bv && bv->buffer());
|
BOOST_ASSERT(bv);
|
||||||
|
|
||||||
Buffer const & buffer = *bv->buffer();
|
Buffer const & buffer = bv->buffer();
|
||||||
graphics::PreviewLoader const & loader = getPreviewLoader(buffer);
|
graphics::PreviewLoader const & loader = getPreviewLoader(buffer);
|
||||||
graphics::PreviewLoader::Status const status = loader.status(snippet);
|
graphics::PreviewLoader::Status const status = loader.status(snippet);
|
||||||
|
|
||||||
@ -122,10 +122,10 @@ RenderPreview::getPreviewImage(Buffer const & buffer) const
|
|||||||
|
|
||||||
bool RenderPreview::metrics(MetricsInfo & mi, Dimension & dim) const
|
bool RenderPreview::metrics(MetricsInfo & mi, Dimension & dim) const
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(mi.base.bv && mi.base.bv->buffer());
|
BOOST_ASSERT(mi.base.bv);
|
||||||
|
|
||||||
graphics::PreviewImage const * const pimage =
|
graphics::PreviewImage const * const pimage =
|
||||||
getPreviewImage(*mi.base.bv->buffer());
|
getPreviewImage(mi.base.bv->buffer());
|
||||||
|
|
||||||
if (pimage) {
|
if (pimage) {
|
||||||
dim.asc = pimage->ascent();
|
dim.asc = pimage->ascent();
|
||||||
@ -150,10 +150,10 @@ bool RenderPreview::metrics(MetricsInfo & mi, Dimension & dim) const
|
|||||||
|
|
||||||
void RenderPreview::draw(PainterInfo & pi, int x, int y) const
|
void RenderPreview::draw(PainterInfo & pi, int x, int y) const
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(pi.base.bv && pi.base.bv->buffer());
|
BOOST_ASSERT(pi.base.bv);
|
||||||
|
|
||||||
graphics::PreviewImage const * const pimage =
|
graphics::PreviewImage const * const pimage =
|
||||||
getPreviewImage(*pi.base.bv->buffer());
|
getPreviewImage(pi.base.bv->buffer());
|
||||||
graphics::Image const * const image = pimage ? pimage->image() : 0;
|
graphics::Image const * const image = pimage ? pimage->image() : 0;
|
||||||
|
|
||||||
if (image) {
|
if (image) {
|
||||||
|
@ -144,7 +144,7 @@ bool searchAllowed(BufferView * bv, docstring const & str)
|
|||||||
_("Search string is empty"));
|
_("Search string is empty"));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return bv->buffer();
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -172,7 +172,7 @@ int replaceAll(BufferView * bv,
|
|||||||
docstring const & searchstr, docstring const & replacestr,
|
docstring const & searchstr, docstring const & replacestr,
|
||||||
bool cs, bool mw)
|
bool cs, bool mw)
|
||||||
{
|
{
|
||||||
Buffer & buf = *bv->buffer();
|
Buffer & buf = bv->buffer();
|
||||||
|
|
||||||
if (!searchAllowed(bv, searchstr) || buf.isReadonly())
|
if (!searchAllowed(bv, searchstr) || buf.isReadonly())
|
||||||
return 0;
|
return 0;
|
||||||
@ -227,7 +227,7 @@ bool stringSelected(BufferView * bv, docstring const & searchstr,
|
|||||||
int replace(BufferView * bv, docstring const & searchstr,
|
int replace(BufferView * bv, docstring const & searchstr,
|
||||||
docstring const & replacestr, bool cs, bool mw, bool fw)
|
docstring const & replacestr, bool cs, bool mw, bool fw)
|
||||||
{
|
{
|
||||||
if (!searchAllowed(bv, searchstr) || bv->buffer()->isReadonly())
|
if (!searchAllowed(bv, searchstr) || bv->buffer().isReadonly())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (!stringSelected(bv, searchstr, cs, mw, fw))
|
if (!stringSelected(bv, searchstr, cs, mw, fw))
|
||||||
@ -235,7 +235,7 @@ int replace(BufferView * bv, docstring const & searchstr,
|
|||||||
|
|
||||||
Cursor & cur = bv->cursor();
|
Cursor & cur = bv->cursor();
|
||||||
cap::replaceSelectionWithString(cur, replacestr, fw);
|
cap::replaceSelectionWithString(cur, replacestr, fw);
|
||||||
bv->buffer()->markDirty();
|
bv->buffer().markDirty();
|
||||||
find(bv, searchstr, cs, mw, fw, false);
|
find(bv, searchstr, cs, mw, fw, false);
|
||||||
bv->update();
|
bv->update();
|
||||||
|
|
||||||
@ -317,25 +317,24 @@ void replace(BufferView * bv, FuncRequest const & ev, bool has_deleted)
|
|||||||
bool all = parse_bool(howto);
|
bool all = parse_bool(howto);
|
||||||
bool forward = parse_bool(howto);
|
bool forward = parse_bool(howto);
|
||||||
|
|
||||||
Buffer * buf = bv->buffer();
|
|
||||||
|
|
||||||
if (!has_deleted) {
|
if (!has_deleted) {
|
||||||
int const replace_count = all
|
int const replace_count = all
|
||||||
? replaceAll(bv, search, rplc, casesensitive, matchword)
|
? replaceAll(bv, search, rplc, casesensitive, matchword)
|
||||||
: replace(bv, search, rplc, casesensitive, matchword, forward);
|
: replace(bv, search, rplc, casesensitive, matchword, forward);
|
||||||
|
|
||||||
|
Buffer & buf = bv->buffer();
|
||||||
if (replace_count == 0) {
|
if (replace_count == 0) {
|
||||||
// emit message signal.
|
// emit message signal.
|
||||||
buf->message(_("String not found!"));
|
buf.message(_("String not found!"));
|
||||||
} else {
|
} else {
|
||||||
if (replace_count == 1) {
|
if (replace_count == 1) {
|
||||||
// emit message signal.
|
// emit message signal.
|
||||||
buf->message(_("String has been replaced."));
|
buf.message(_("String has been replaced."));
|
||||||
} else {
|
} else {
|
||||||
docstring str = convert<docstring>(replace_count);
|
docstring str = convert<docstring>(replace_count);
|
||||||
str += _(" strings have been replaced.");
|
str += _(" strings have been replaced.");
|
||||||
// emit message signal.
|
// emit message signal.
|
||||||
buf->message(str);
|
buf.message(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -353,9 +352,6 @@ void replace(BufferView * bv, FuncRequest const & ev, bool has_deleted)
|
|||||||
|
|
||||||
bool findNextChange(BufferView * bv)
|
bool findNextChange(BufferView * bv)
|
||||||
{
|
{
|
||||||
if (!bv->buffer())
|
|
||||||
return false;
|
|
||||||
|
|
||||||
DocIterator cur = bv->cursor();
|
DocIterator cur = bv->cursor();
|
||||||
|
|
||||||
if (!findChange(cur))
|
if (!findChange(cur))
|
||||||
|
@ -277,7 +277,7 @@ bool InsetMathHull::previewState(BufferView * bv) const
|
|||||||
{
|
{
|
||||||
if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) {
|
if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) {
|
||||||
graphics::PreviewImage const * pimage =
|
graphics::PreviewImage const * pimage =
|
||||||
preview_->getPreviewImage(*bv->buffer());
|
preview_->getPreviewImage(bv->buffer());
|
||||||
return pimage && pimage->image();
|
return pimage && pimage->image();
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -1060,7 +1060,7 @@ void InsetMathHull::doDispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
if (type_ == hullSimple || type_ == hullEquation) {
|
if (type_ == hullSimple || type_ == hullEquation) {
|
||||||
recordUndoInset(cur);
|
recordUndoInset(cur);
|
||||||
bool const align =
|
bool const align =
|
||||||
cur.bv().buffer()->params().use_amsmath == BufferParams::package_on;
|
cur.bv().buffer().params().use_amsmath == BufferParams::package_on;
|
||||||
mutate(align ? hullAlign : hullEqnArray);
|
mutate(align ? hullAlign : hullEqnArray);
|
||||||
cur.idx() = 0;
|
cur.idx() = 0;
|
||||||
cur.pos() = cur.lastpos();
|
cur.pos() = cur.lastpos();
|
||||||
@ -1129,7 +1129,7 @@ void InsetMathHull::doDispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
numbered(r, true);
|
numbered(r, true);
|
||||||
docstring old = label(r);
|
docstring old = label(r);
|
||||||
if (str != old) {
|
if (str != old) {
|
||||||
cur.bv().buffer()->changeRefsIfUnique(old, str,
|
cur.bv().buffer().changeRefsIfUnique(old, str,
|
||||||
Inset::REF_CODE);
|
Inset::REF_CODE);
|
||||||
label(r, str);
|
label(r, str);
|
||||||
}
|
}
|
||||||
|
@ -258,7 +258,7 @@ void MathData::metrics(MetricsInfo & mi) const
|
|||||||
dim_.wid = 0;
|
dim_.wid = 0;
|
||||||
Dimension d;
|
Dimension d;
|
||||||
//BufferView & bv = *mi.base.bv;
|
//BufferView & bv = *mi.base.bv;
|
||||||
//Buffer const & buf = *bv.buffer();
|
//Buffer const & buf = bv.buffer();
|
||||||
for (size_t i = 0, n = size(); i != n; ++i) {
|
for (size_t i = 0, n = size(); i != n; ++i) {
|
||||||
MathAtom const & at = operator[](i);
|
MathAtom const & at = operator[](i);
|
||||||
#if 0
|
#if 0
|
||||||
|
@ -145,7 +145,7 @@ RowPainter::RowPainter(PainterInfo & pi,
|
|||||||
xo_(x), yo_(y), width_(text_metrics_.width())
|
xo_(x), yo_(y), width_(text_metrics_.width())
|
||||||
{
|
{
|
||||||
RowMetrics m = text_metrics_.computeRowMetrics(pit_, row_);
|
RowMetrics m = text_metrics_.computeRowMetrics(pit_, row_);
|
||||||
bidi_.computeTables(par_, *bv_.buffer(), row_);
|
bidi_.computeTables(par_, bv_.buffer(), row_);
|
||||||
x_ = m.x + xo_;
|
x_ = m.x + xo_;
|
||||||
|
|
||||||
//lyxerr << "RowPainter: x: " << x_ << " xo: " << xo_ << " yo: " << yo_ << endl;
|
//lyxerr << "RowPainter: x: " << x_ << " xo: " << xo_ << " yo: " << yo_ << endl;
|
||||||
@ -162,13 +162,13 @@ RowPainter::RowPainter(PainterInfo & pi,
|
|||||||
|
|
||||||
Font const RowPainter::getLabelFont() const
|
Font const RowPainter::getLabelFont() const
|
||||||
{
|
{
|
||||||
return text_.getLabelFont(*bv_.buffer(), par_);
|
return text_.getLabelFont(bv_.buffer(), par_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int RowPainter::leftMargin() const
|
int RowPainter::leftMargin() const
|
||||||
{
|
{
|
||||||
return text_.leftMargin(*bv_.buffer(), max_width_, pit_, row_.pos());
|
return text_.leftMargin(bv_.buffer(), max_width_, pit_, row_.pos());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -185,7 +185,7 @@ void RowPainter::paintInset(pos_type const pos, Font const & font)
|
|||||||
// FIXME: We should always use font, see documentation of
|
// FIXME: We should always use font, see documentation of
|
||||||
// noFontChange() in Inset.h.
|
// noFontChange() in Inset.h.
|
||||||
pi.base.font = inset->noFontChange() ?
|
pi.base.font = inset->noFontChange() ?
|
||||||
bv_.buffer()->params().getFont() :
|
bv_.buffer().params().getFont() :
|
||||||
font;
|
font;
|
||||||
pi.ltr_pos = (bidi_.level(pos) % 2 == 0);
|
pi.ltr_pos = (bidi_.level(pos) % 2 == 0);
|
||||||
pi.erased_ = erased_ || par_.isDeleted(pos);
|
pi.erased_ = erased_ || par_.isDeleted(pos);
|
||||||
@ -257,7 +257,7 @@ void RowPainter::paintHebrewComposeChar(pos_type & vpos, Font const & font)
|
|||||||
if (!Encodings::isComposeChar_hebrew(c)) {
|
if (!Encodings::isComposeChar_hebrew(c)) {
|
||||||
if (isPrintableNonspace(c)) {
|
if (isPrintableNonspace(c)) {
|
||||||
int const width2 = pm_.singleWidth(i,
|
int const width2 = pm_.singleWidth(i,
|
||||||
text_.getFont(*bv_.buffer(), par_, i));
|
text_.getFont(bv_.buffer(), par_, i));
|
||||||
dx = (c == 0x05e8 || // resh
|
dx = (c == 0x05e8 || // resh
|
||||||
c == 0x05d3) // dalet
|
c == 0x05d3) // dalet
|
||||||
? width2 - width
|
? width2 - width
|
||||||
@ -291,7 +291,7 @@ void RowPainter::paintArabicComposeChar(pos_type & vpos, Font const & font)
|
|||||||
if (!Encodings::isComposeChar_arabic(c)) {
|
if (!Encodings::isComposeChar_arabic(c)) {
|
||||||
if (isPrintableNonspace(c)) {
|
if (isPrintableNonspace(c)) {
|
||||||
int const width2 = pm_.singleWidth(i,
|
int const width2 = pm_.singleWidth(i,
|
||||||
text_.getFont(*bv_.buffer(), par_, i));
|
text_.getFont(bv_.buffer(), par_, i));
|
||||||
dx = (width2 - width) / 2;
|
dx = (width2 - width) / 2;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -400,7 +400,7 @@ void RowPainter::paintForeignMark(double orig_x, Font const & font, int desc)
|
|||||||
return;
|
return;
|
||||||
if (font.language() == latex_language)
|
if (font.language() == latex_language)
|
||||||
return;
|
return;
|
||||||
if (font.language() == bv_.buffer()->params().language)
|
if (font.language() == bv_.buffer().params().language)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int const y = yo_ + 1 + desc;
|
int const y = yo_ + 1 + desc;
|
||||||
@ -411,7 +411,7 @@ void RowPainter::paintForeignMark(double orig_x, Font const & font, int desc)
|
|||||||
void RowPainter::paintFromPos(pos_type & vpos)
|
void RowPainter::paintFromPos(pos_type & vpos)
|
||||||
{
|
{
|
||||||
pos_type const pos = bidi_.vis2log(vpos);
|
pos_type const pos = bidi_.vis2log(vpos);
|
||||||
Font orig_font = text_.getFont(*bv_.buffer(), par_, pos);
|
Font orig_font = text_.getFont(bv_.buffer(), par_, pos);
|
||||||
|
|
||||||
double const orig_x = x_;
|
double const orig_x = x_;
|
||||||
|
|
||||||
@ -472,7 +472,7 @@ void RowPainter::paintChangeBar()
|
|||||||
void RowPainter::paintAppendix()
|
void RowPainter::paintAppendix()
|
||||||
{
|
{
|
||||||
// only draw the appendix frame once (for the main text)
|
// only draw the appendix frame once (for the main text)
|
||||||
if (!par_.params().appendix() || !text_.isMainText(*bv_.buffer()))
|
if (!par_.params().appendix() || !text_.isMainText(bv_.buffer()))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int y = yo_ - row_.ascent();
|
int y = yo_ - row_.ascent();
|
||||||
@ -512,7 +512,7 @@ void RowPainter::paintDepthBar()
|
|||||||
int const w = nestMargin() / 5;
|
int const w = nestMargin() / 5;
|
||||||
int x = int(xo_) + w * i;
|
int x = int(xo_) + w * i;
|
||||||
// only consider the changebar space if we're drawing outermost text
|
// only consider the changebar space if we're drawing outermost text
|
||||||
if (text_.isMainText(*bv_.buffer()))
|
if (text_.isMainText(bv_.buffer()))
|
||||||
x += changebarMargin();
|
x += changebarMargin();
|
||||||
|
|
||||||
int const starty = yo_ - row_.ascent();
|
int const starty = yo_ - row_.ascent();
|
||||||
@ -563,7 +563,7 @@ void RowPainter::paintFirst()
|
|||||||
if (parparams.startOfAppendix())
|
if (parparams.startOfAppendix())
|
||||||
y_top += paintAppendixStart(yo_ - row_.ascent() + 2 * defaultRowHeight());
|
y_top += paintAppendixStart(yo_ - row_.ascent() + 2 * defaultRowHeight());
|
||||||
|
|
||||||
Buffer const & buffer = *bv_.buffer();
|
Buffer const & buffer = bv_.buffer();
|
||||||
|
|
||||||
Layout_ptr const & layout = par_.layout();
|
Layout_ptr const & layout = par_.layout();
|
||||||
|
|
||||||
@ -676,13 +676,13 @@ void RowPainter::paintFirst()
|
|||||||
|
|
||||||
void RowPainter::paintLast()
|
void RowPainter::paintLast()
|
||||||
{
|
{
|
||||||
bool const is_rtl = text_.isRTL(*bv_.buffer(), par_);
|
bool const is_rtl = text_.isRTL(bv_.buffer(), par_);
|
||||||
int const endlabel = getEndLabel(pit_, text_.paragraphs());
|
int const endlabel = getEndLabel(pit_, text_.paragraphs());
|
||||||
|
|
||||||
// paint imaginary end-of-paragraph character
|
// paint imaginary end-of-paragraph character
|
||||||
|
|
||||||
if (par_.isInserted(par_.size()) || par_.isDeleted(par_.size())) {
|
if (par_.isInserted(par_.size()) || par_.isDeleted(par_.size())) {
|
||||||
FontMetrics const & fm = theFontMetrics(bv_.buffer()->params().getFont());
|
FontMetrics const & fm = theFontMetrics(bv_.buffer().params().getFont());
|
||||||
int const length = fm.maxAscent() / 2;
|
int const length = fm.maxAscent() / 2;
|
||||||
Color::color col = par_.isInserted(par_.size()) ? Color::addedtext : Color::deletedtext;
|
Color::color col = par_.isInserted(par_.size()) ? Color::addedtext : Color::deletedtext;
|
||||||
|
|
||||||
@ -754,7 +754,7 @@ void RowPainter::paintText()
|
|||||||
// Use font span to speed things up, see below
|
// Use font span to speed things up, see below
|
||||||
FontSpan font_span;
|
FontSpan font_span;
|
||||||
Font font;
|
Font font;
|
||||||
Buffer const & buffer = *bv_.buffer();
|
Buffer const & buffer = bv_.buffer();
|
||||||
|
|
||||||
// If the last logical character is a separator, don't paint it, unless
|
// If the last logical character is a separator, don't paint it, unless
|
||||||
// it's in the last row of a paragraph; see skipped_sep_vpos declaration
|
// it's in the last row of a paragraph; see skipped_sep_vpos declaration
|
||||||
@ -807,7 +807,7 @@ void RowPainter::paintText()
|
|||||||
if (running_strikeout && (highly_editable_inset || !is_struckout)) {
|
if (running_strikeout && (highly_editable_inset || !is_struckout)) {
|
||||||
// Calculate 1/3 height of the buffer's default font
|
// Calculate 1/3 height of the buffer's default font
|
||||||
FontMetrics const & fm
|
FontMetrics const & fm
|
||||||
= theFontMetrics(bv_.buffer()->params().getFont());
|
= theFontMetrics(bv_.buffer().params().getFont());
|
||||||
int const middle = yo_ - fm.maxAscent() / 3;
|
int const middle = yo_ - fm.maxAscent() / 3;
|
||||||
pain_.line(last_strikeout_x, middle, int(x_), middle,
|
pain_.line(last_strikeout_x, middle, int(x_), middle,
|
||||||
Color::deletedtext, Painter::line_solid, Painter::line_thin);
|
Color::deletedtext, Painter::line_solid, Painter::line_thin);
|
||||||
@ -848,7 +848,7 @@ void RowPainter::paintText()
|
|||||||
x_ += 2;
|
x_ += 2;
|
||||||
++vpos;
|
++vpos;
|
||||||
} else if (par_.isSeparator(pos)) {
|
} else if (par_.isSeparator(pos)) {
|
||||||
Font orig_font = text_.getFont(*bv_.buffer(), par_, pos);
|
Font orig_font = text_.getFont(bv_.buffer(), par_, pos);
|
||||||
double const orig_x = x_;
|
double const orig_x = x_;
|
||||||
x_ += width_pos;
|
x_ += width_pos;
|
||||||
if (pos >= body_pos)
|
if (pos >= body_pos)
|
||||||
@ -864,7 +864,7 @@ void RowPainter::paintText()
|
|||||||
if (running_strikeout) {
|
if (running_strikeout) {
|
||||||
// calculate 1/3 height of the buffer's default font
|
// calculate 1/3 height of the buffer's default font
|
||||||
FontMetrics const & fm
|
FontMetrics const & fm
|
||||||
= theFontMetrics(bv_.buffer()->params().getFont());
|
= theFontMetrics(bv_.buffer().params().getFont());
|
||||||
int const middle = yo_ - fm.maxAscent() / 3;
|
int const middle = yo_ - fm.maxAscent() / 3;
|
||||||
pain_.line(last_strikeout_x, middle, int(x_), middle,
|
pain_.line(last_strikeout_x, middle, int(x_), middle,
|
||||||
Color::deletedtext, Painter::line_solid, Painter::line_thin);
|
Color::deletedtext, Painter::line_solid, Painter::line_thin);
|
||||||
@ -1018,7 +1018,7 @@ void paintPar
|
|||||||
// Instrumentation for testing row cache (see also
|
// Instrumentation for testing row cache (see also
|
||||||
// 12 lines lower):
|
// 12 lines lower):
|
||||||
if (lyxerr.debugging(Debug::PAINTING)) {
|
if (lyxerr.debugging(Debug::PAINTING)) {
|
||||||
if (text.isMainText(*pi.base.bv->buffer()))
|
if (text.isMainText(pi.base.bv->buffer()))
|
||||||
LYXERR(Debug::PAINTING) << "#";
|
LYXERR(Debug::PAINTING) << "#";
|
||||||
else
|
else
|
||||||
LYXERR(Debug::PAINTING) << "[" <<
|
LYXERR(Debug::PAINTING) << "[" <<
|
||||||
@ -1050,8 +1050,7 @@ void paintPar
|
|||||||
void paintText(BufferView & bv,
|
void paintText(BufferView & bv,
|
||||||
Painter & pain)
|
Painter & pain)
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(bv.buffer());
|
Buffer const & buffer = bv.buffer();
|
||||||
Buffer const & buffer = *bv.buffer();
|
|
||||||
Text & text = buffer.text();
|
Text & text = buffer.text();
|
||||||
bool const select = bv.cursor().selection();
|
bool const select = bv.cursor().selection();
|
||||||
ViewMetricsInfo const & vi = bv.viewMetricsInfo();
|
ViewMetricsInfo const & vi = bv.viewMetricsInfo();
|
||||||
|
@ -31,9 +31,9 @@ namespace toc {
|
|||||||
|
|
||||||
void outline(OutlineOp mode, Cursor & cur)
|
void outline(OutlineOp mode, Cursor & cur)
|
||||||
{
|
{
|
||||||
Buffer * buf = & cur.buffer();
|
Buffer & buf = cur.buffer();
|
||||||
pit_type & pit = cur.pit();
|
pit_type & pit = cur.pit();
|
||||||
ParagraphList & pars = buf->text().paragraphs();
|
ParagraphList & pars = buf.text().paragraphs();
|
||||||
ParagraphList::iterator bgn = pars.begin();
|
ParagraphList::iterator bgn = pars.begin();
|
||||||
// The first paragraph of the area to be copied:
|
// The first paragraph of the area to be copied:
|
||||||
ParagraphList::iterator start = boost::next(bgn, pit);
|
ParagraphList::iterator start = boost::next(bgn, pit);
|
||||||
@ -42,9 +42,9 @@ void outline(OutlineOp mode, Cursor & cur)
|
|||||||
ParagraphList::iterator end = pars.end();
|
ParagraphList::iterator end = pars.end();
|
||||||
|
|
||||||
TextClass::const_iterator lit =
|
TextClass::const_iterator lit =
|
||||||
buf->params().getTextClass().begin();
|
buf.params().getTextClass().begin();
|
||||||
TextClass::const_iterator const lend =
|
TextClass::const_iterator const lend =
|
||||||
buf->params().getTextClass().end();
|
buf.params().getTextClass().end();
|
||||||
|
|
||||||
int const thistoclevel = start->layout()->toclevel;
|
int const thistoclevel = start->layout()->toclevel;
|
||||||
int toclevel;
|
int toclevel;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user