mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-08 18:19:42 +00:00
API cosmetics
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23295 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
3c5f43af7d
commit
1cca0a86bd
@ -768,7 +768,7 @@ void BufferView::showCursor(DocIterator const & dit)
|
|||||||
else if (bot_pit == tm.last().first + 1)
|
else if (bot_pit == tm.last().first + 1)
|
||||||
tm.newParMetricsDown();
|
tm.newParMetricsDown();
|
||||||
|
|
||||||
if (tm.has(bot_pit)) {
|
if (tm.contains(bot_pit)) {
|
||||||
ParagraphMetrics const & pm = tm.parMetrics(bot_pit);
|
ParagraphMetrics const & pm = tm.parMetrics(bot_pit);
|
||||||
BOOST_ASSERT(!pm.rows().empty());
|
BOOST_ASSERT(!pm.rows().empty());
|
||||||
// FIXME: smooth scrolling doesn't work in mathed.
|
// FIXME: smooth scrolling doesn't work in mathed.
|
||||||
@ -1995,7 +1995,7 @@ Point BufferView::getPos(DocIterator const & dit, bool boundary) const
|
|||||||
{
|
{
|
||||||
CursorSlice const & bot = dit.bottom();
|
CursorSlice const & bot = dit.bottom();
|
||||||
TextMetrics const & tm = textMetrics(bot.text());
|
TextMetrics const & tm = textMetrics(bot.text());
|
||||||
if (!tm.has(bot.pit()))
|
if (!tm.contains(bot.pit()))
|
||||||
return Point(-1, -1);
|
return Point(-1, -1);
|
||||||
|
|
||||||
Point p = coordOffset(dit, boundary); // offset from outer paragraph
|
Point p = coordOffset(dit, boundary); // offset from outer paragraph
|
||||||
|
@ -1825,7 +1825,7 @@ void Cursor::setCurrentFont()
|
|||||||
// get font
|
// get font
|
||||||
BufferParams const & bufparams = buffer().params();
|
BufferParams const & bufparams = buffer().params();
|
||||||
current_font = par.getFontSettings(bufparams, cpos);
|
current_font = par.getFontSettings(bufparams, cpos);
|
||||||
real_current_font = tm.getDisplayFont(cpit, cpos);
|
real_current_font = tm.displayFont(cpit, cpos);
|
||||||
|
|
||||||
// special case for paragraph end
|
// special case for paragraph end
|
||||||
if (cs.pos() == lastpos()
|
if (cs.pos() == lastpos()
|
||||||
|
@ -23,7 +23,7 @@ namespace lyx {
|
|||||||
FontIterator::FontIterator(TextMetrics const & tm,
|
FontIterator::FontIterator(TextMetrics const & tm,
|
||||||
Paragraph const & par, pit_type pit, pos_type pos)
|
Paragraph const & par, pit_type pit, pos_type pos)
|
||||||
: tm_(tm), par_(par), pit_(pit), pos_(pos),
|
: tm_(tm), par_(par), pit_(pit), pos_(pos),
|
||||||
font_(tm.getDisplayFont(pit, pos)),
|
font_(tm.displayFont(pit, pos)),
|
||||||
endspan_(par.fontSpan(pos).last),
|
endspan_(par.fontSpan(pos).last),
|
||||||
bodypos_(par.beginOfBody())
|
bodypos_(par.beginOfBody())
|
||||||
{}
|
{}
|
||||||
@ -45,7 +45,7 @@ FontIterator & FontIterator::operator++()
|
|||||||
{
|
{
|
||||||
++pos_;
|
++pos_;
|
||||||
if (pos_ > endspan_ || pos_ == bodypos_) {
|
if (pos_ > endspan_ || pos_ == bodypos_) {
|
||||||
font_ = tm_.getDisplayFont(pit_, pos_);
|
font_ = tm_.displayFont(pit_, pos_);
|
||||||
endspan_ = par_.fontSpan(pos_).last;
|
endspan_ = par_.fontSpan(pos_).last;
|
||||||
}
|
}
|
||||||
return *this;
|
return *this;
|
||||||
|
10
src/Text.cpp
10
src/Text.cpp
@ -450,8 +450,8 @@ void Text::insertChar(Cursor & cur, char_type c)
|
|||||||
!(contains(number_seperators, c) &&
|
!(contains(number_seperators, c) &&
|
||||||
cur.pos() != 0 &&
|
cur.pos() != 0 &&
|
||||||
cur.pos() != cur.lastpos() &&
|
cur.pos() != cur.lastpos() &&
|
||||||
tm.getDisplayFont(pit, cur.pos()).fontInfo().number() == FONT_ON &&
|
tm.displayFont(pit, cur.pos()).fontInfo().number() == FONT_ON &&
|
||||||
tm.getDisplayFont(pit, cur.pos() - 1).fontInfo().number() == FONT_ON)
|
tm.displayFont(pit, cur.pos() - 1).fontInfo().number() == FONT_ON)
|
||||||
)
|
)
|
||||||
number(cur); // Set current_font.number to OFF
|
number(cur); // Set current_font.number to OFF
|
||||||
} else if (isDigit(c) &&
|
} else if (isDigit(c) &&
|
||||||
@ -469,7 +469,7 @@ void Text::insertChar(Cursor & cur, char_type c)
|
|||||||
tm.font_);
|
tm.font_);
|
||||||
} else if (contains(number_seperators, c)
|
} else if (contains(number_seperators, c)
|
||||||
&& cur.pos() >= 2
|
&& cur.pos() >= 2
|
||||||
&& tm.getDisplayFont(pit, cur.pos() - 2).fontInfo().number() == FONT_ON) {
|
&& tm.displayFont(pit, cur.pos() - 2).fontInfo().number() == FONT_ON) {
|
||||||
setCharFont(buffer, pit, cur.pos() - 1, cur.current_font,
|
setCharFont(buffer, pit, cur.pos() - 1, cur.current_font,
|
||||||
tm.font_);
|
tm.font_);
|
||||||
}
|
}
|
||||||
@ -502,7 +502,7 @@ void Text::insertChar(Cursor & cur, char_type c)
|
|||||||
if ((cur.pos() >= 2) && (par.isLineSeparator(cur.pos() - 1))) {
|
if ((cur.pos() >= 2) && (par.isLineSeparator(cur.pos() - 1))) {
|
||||||
// get font in front and behind the space in question. But do NOT
|
// get font in front and behind the space in question. But do NOT
|
||||||
// use getFont(cur.pos()) because the character c is not inserted yet
|
// use getFont(cur.pos()) because the character c is not inserted yet
|
||||||
Font const pre_space_font = tm.getDisplayFont(cur.pit(), cur.pos() - 2);
|
Font const pre_space_font = tm.displayFont(cur.pit(), cur.pos() - 2);
|
||||||
Font const & post_space_font = cur.real_current_font;
|
Font const & post_space_font = cur.real_current_font;
|
||||||
bool pre_space_rtl = pre_space_font.isVisibleRightToLeft();
|
bool pre_space_rtl = pre_space_font.isVisibleRightToLeft();
|
||||||
bool post_space_rtl = post_space_font.isVisibleRightToLeft();
|
bool post_space_rtl = post_space_font.isVisibleRightToLeft();
|
||||||
@ -515,7 +515,7 @@ void Text::insertChar(Cursor & cur, char_type c)
|
|||||||
(pre_space_rtl == par.isRTL(buffer.params())) ?
|
(pre_space_rtl == par.isRTL(buffer.params())) ?
|
||||||
pre_space_font.language() : post_space_font.language();
|
pre_space_font.language() : post_space_font.language();
|
||||||
|
|
||||||
Font space_font = tm.getDisplayFont(cur.pit(), cur.pos() - 1);
|
Font space_font = tm.displayFont(cur.pit(), cur.pos() - 1);
|
||||||
space_font.setLanguage(lang);
|
space_font.setLanguage(lang);
|
||||||
par.setFont(cur.pos() - 1, space_font);
|
par.setFont(cur.pos() - 1, space_font);
|
||||||
}
|
}
|
||||||
|
@ -48,9 +48,9 @@ public:
|
|||||||
bool empty() const;
|
bool empty() const;
|
||||||
|
|
||||||
///
|
///
|
||||||
FontInfo getLayoutFont(Buffer const & buffer, pit_type pit) const;
|
FontInfo layoutFont(Buffer const & buffer, pit_type pit) const;
|
||||||
///
|
///
|
||||||
FontInfo getLabelFont(Buffer const & buffer,
|
FontInfo labelFont(Buffer const & buffer,
|
||||||
Paragraph const & par) const;
|
Paragraph const & par) const;
|
||||||
/** Set font of character at position \p pos in paragraph \p pit.
|
/** Set font of character at position \p pos in paragraph \p pit.
|
||||||
* Must not be called if \p pos denotes an inset with text contents,
|
* Must not be called if \p pos denotes an inset with text contents,
|
||||||
@ -319,4 +319,4 @@ private:
|
|||||||
|
|
||||||
} // namespace lyx
|
} // namespace lyx
|
||||||
|
|
||||||
#endif // LYXTEXT_H
|
#endif // TEXT_H
|
||||||
|
@ -73,7 +73,7 @@ bool Text::isMainText(Buffer const & buffer) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
FontInfo Text::getLayoutFont(Buffer const & buffer, pit_type const pit) const
|
FontInfo Text::layoutFont(Buffer const & buffer, pit_type const pit) const
|
||||||
{
|
{
|
||||||
LayoutPtr const & layout = pars_[pit].layout();
|
LayoutPtr const & layout = pars_[pit].layout();
|
||||||
|
|
||||||
@ -94,7 +94,7 @@ FontInfo Text::getLayoutFont(Buffer const & buffer, pit_type const pit) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
FontInfo Text::getLabelFont(Buffer const & buffer, Paragraph const & par) const
|
FontInfo Text::labelFont(Buffer const & buffer, Paragraph const & par) const
|
||||||
{
|
{
|
||||||
LayoutPtr const & layout = par.layout();
|
LayoutPtr const & layout = par.layout();
|
||||||
|
|
||||||
@ -308,9 +308,9 @@ void Text::setFont(Cursor & cur, Font const & font, bool toggleall)
|
|||||||
FontInfo layoutfont;
|
FontInfo layoutfont;
|
||||||
pit_type pit = cur.pit();
|
pit_type pit = cur.pit();
|
||||||
if (cur.pos() < pars_[pit].beginOfBody())
|
if (cur.pos() < pars_[pit].beginOfBody())
|
||||||
layoutfont = getLabelFont(cur.buffer(), pars_[pit]);
|
layoutfont = labelFont(cur.buffer(), pars_[pit]);
|
||||||
else
|
else
|
||||||
layoutfont = getLayoutFont(cur.buffer(), pit);
|
layoutfont = layoutFont(cur.buffer(), pit);
|
||||||
|
|
||||||
// Update current font
|
// Update current font
|
||||||
cur.real_current_font.update(font,
|
cur.real_current_font.update(font,
|
||||||
@ -360,7 +360,7 @@ void Text::setFont(BufferView const & bv, CursorSlice const & begin,
|
|||||||
setInsetFont(bv, pit, pos, font, toggleall);
|
setInsetFont(bv, pit, pos, font, toggleall);
|
||||||
}
|
}
|
||||||
TextMetrics const & tm = bv.textMetrics(this);
|
TextMetrics const & tm = bv.textMetrics(this);
|
||||||
Font f = tm.getDisplayFont(pit, pos);
|
Font f = tm.displayFont(pit, pos);
|
||||||
f.update(font, language, toggleall);
|
f.update(font, language, toggleall);
|
||||||
setCharFont(buffer, pit, pos, f, tm.font_);
|
setCharFont(buffer, pit, pos, f, tm.font_);
|
||||||
}
|
}
|
||||||
@ -526,7 +526,7 @@ bool Text::setCursor(Cursor & cur, pit_type par, pos_type pos,
|
|||||||
bool setfont, bool boundary)
|
bool setfont, bool boundary)
|
||||||
{
|
{
|
||||||
TextMetrics const & tm = cur.bv().textMetrics(this);
|
TextMetrics const & tm = cur.bv().textMetrics(this);
|
||||||
bool const update_needed = !tm.has(par);
|
bool const update_needed = !tm.contains(par);
|
||||||
Cursor old = cur;
|
Cursor old = cur;
|
||||||
setCursorIntern(cur, par, pos, setfont, boundary);
|
setCursorIntern(cur, par, pos, setfont, boundary);
|
||||||
return cur.bv().checkDepm(cur, old) || update_needed;
|
return cur.bv().checkDepm(cur, old) || update_needed;
|
||||||
|
@ -387,7 +387,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
|||||||
|
|
||||||
BufferView * bv = &cur.bv();
|
BufferView * bv = &cur.bv();
|
||||||
TextMetrics & tm = bv->textMetrics(this);
|
TextMetrics & tm = bv->textMetrics(this);
|
||||||
if (!tm.has(cur.pit()))
|
if (!tm.contains(cur.pit()))
|
||||||
lyx::dispatch(FuncRequest(LFUN_SCREEN_RECENTER));
|
lyx::dispatch(FuncRequest(LFUN_SCREEN_RECENTER));
|
||||||
|
|
||||||
// FIXME: We use the update flag to indicates wether a singlePar or a
|
// FIXME: We use the update flag to indicates wether a singlePar or a
|
||||||
|
@ -128,7 +128,7 @@ TextMetrics::TextMetrics(BufferView * bv, Text * text)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool TextMetrics::has(pit_type pit) const
|
bool TextMetrics::contains(pit_type pit) const
|
||||||
{
|
{
|
||||||
return par_metrics_.find(pit) != par_metrics_.end();
|
return par_metrics_.find(pit) != par_metrics_.end();
|
||||||
}
|
}
|
||||||
@ -241,7 +241,7 @@ void TextMetrics::applyOuterFont(Font & font) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Font TextMetrics::getDisplayFont(pit_type pit, pos_type pos) const
|
Font TextMetrics::displayFont(pit_type pit, pos_type pos) const
|
||||||
{
|
{
|
||||||
BOOST_ASSERT(pos >= 0);
|
BOOST_ASSERT(pos >= 0);
|
||||||
|
|
||||||
@ -302,7 +302,7 @@ bool TextMetrics::isRTL(CursorSlice const & sl, bool boundary) const
|
|||||||
if (boundary && sl.pos() > 0)
|
if (boundary && sl.pos() > 0)
|
||||||
correction = -1;
|
correction = -1;
|
||||||
|
|
||||||
return getDisplayFont(sl.pit(), sl.pos() + correction).isVisibleRightToLeft();
|
return displayFont(sl.pit(), sl.pos() + correction).isVisibleRightToLeft();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -317,12 +317,12 @@ bool TextMetrics::isRTLBoundary(pit_type pit, pos_type pos) const
|
|||||||
|
|
||||||
Paragraph const & par = text_->getPar(pit);
|
Paragraph const & par = text_->getPar(pit);
|
||||||
|
|
||||||
bool left = getDisplayFont(pit, pos - 1).isVisibleRightToLeft();
|
bool left = displayFont(pit, pos - 1).isVisibleRightToLeft();
|
||||||
bool right;
|
bool right;
|
||||||
if (pos == par.size())
|
if (pos == par.size())
|
||||||
right = par.isRTL(bv_->buffer().params());
|
right = par.isRTL(bv_->buffer().params());
|
||||||
else
|
else
|
||||||
right = getDisplayFont(pit, pos).isVisibleRightToLeft();
|
right = displayFont(pit, pos).isVisibleRightToLeft();
|
||||||
return left != right;
|
return left != right;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -339,7 +339,7 @@ bool TextMetrics::isRTLBoundary(pit_type pit, pos_type pos,
|
|||||||
if (pos == par.size())
|
if (pos == par.size())
|
||||||
right = par.isRTL(bv_->buffer().params());
|
right = par.isRTL(bv_->buffer().params());
|
||||||
else
|
else
|
||||||
right = getDisplayFont(pit, pos).isVisibleRightToLeft();
|
right = displayFont(pit, pos).isVisibleRightToLeft();
|
||||||
return left != right;
|
return left != right;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -414,7 +414,7 @@ bool TextMetrics::redoParagraph(pit_type const pit)
|
|||||||
int const w = max_width_ - leftMargin(max_width_, pit, ii->pos)
|
int const w = max_width_ - leftMargin(max_width_, pit, ii->pos)
|
||||||
- right_margin;
|
- right_margin;
|
||||||
Font const & font = ii->inset->noFontChange() ?
|
Font const & font = ii->inset->noFontChange() ?
|
||||||
bufferfont : getDisplayFont(pit, ii->pos);
|
bufferfont : displayFont(pit, ii->pos);
|
||||||
MacroContext mc(buffer, parPos);
|
MacroContext mc(buffer, parPos);
|
||||||
MetricsInfo mi(bv_, font.fontInfo(), w, mc);
|
MetricsInfo mi(bv_, font.fontInfo(), w, mc);
|
||||||
ii->inset->metrics(mi, dim);
|
ii->inset->metrics(mi, dim);
|
||||||
@ -627,7 +627,7 @@ void TextMetrics::computeRowMetrics(pit_type const pit,
|
|||||||
if (body_pos > 0
|
if (body_pos > 0
|
||||||
&& (body_pos > end || !par.isLineSeparator(body_pos - 1)))
|
&& (body_pos > end || !par.isLineSeparator(body_pos - 1)))
|
||||||
{
|
{
|
||||||
row.x += theFontMetrics(text_->getLabelFont(buffer, par)).
|
row.x += theFontMetrics(text_->labelFont(buffer, par)).
|
||||||
width(layout->labelsep);
|
width(layout->labelsep);
|
||||||
if (body_pos <= end)
|
if (body_pos <= end)
|
||||||
row.x += row.label_hfill;
|
row.x += row.label_hfill;
|
||||||
@ -684,7 +684,7 @@ int TextMetrics::labelFill(pit_type const pit, Row const & row) const
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
FontMetrics const & fm
|
FontMetrics const & fm
|
||||||
= theFontMetrics(text_->getLabelFont(buffer, par));
|
= theFontMetrics(text_->labelFont(buffer, par));
|
||||||
|
|
||||||
return max(0, fm.width(label) - w);
|
return max(0, fm.width(label) - w);
|
||||||
}
|
}
|
||||||
@ -767,7 +767,7 @@ pit_type TextMetrics::rowBreakPoint(int width, pit_type const pit,
|
|||||||
// add the auto-hfill from label end to the body
|
// add the auto-hfill from label end to the body
|
||||||
if (body_pos && i == body_pos) {
|
if (body_pos && i == body_pos) {
|
||||||
FontMetrics const & fm = theFontMetrics(
|
FontMetrics const & fm = theFontMetrics(
|
||||||
text_->getLabelFont(buffer, par));
|
text_->labelFont(buffer, par));
|
||||||
int add = fm.width(layout->labelsep);
|
int add = fm.width(layout->labelsep);
|
||||||
if (par.isLineSeparator(i - 1))
|
if (par.isLineSeparator(i - 1))
|
||||||
add -= singleWidth(pit, i - 1);
|
add -= singleWidth(pit, i - 1);
|
||||||
@ -864,7 +864,7 @@ int TextMetrics::rowWidth(int right_margin, pit_type const pit,
|
|||||||
for ( ; i < end; ++i, ++fi) {
|
for ( ; i < end; ++i, ++fi) {
|
||||||
if (body_pos > 0 && i == body_pos) {
|
if (body_pos > 0 && i == body_pos) {
|
||||||
FontMetrics const & fm = theFontMetrics(
|
FontMetrics const & fm = theFontMetrics(
|
||||||
text_->getLabelFont(buffer, par));
|
text_->labelFont(buffer, par));
|
||||||
w += fm.width(par.layout()->labelsep);
|
w += fm.width(par.layout()->labelsep);
|
||||||
if (par.isLineSeparator(i - 1))
|
if (par.isLineSeparator(i - 1))
|
||||||
w -= singleWidth(pit, i - 1);
|
w -= singleWidth(pit, i - 1);
|
||||||
@ -883,7 +883,7 @@ int TextMetrics::rowWidth(int right_margin, pit_type const pit,
|
|||||||
|
|
||||||
if (body_pos > 0 && body_pos >= end) {
|
if (body_pos > 0 && body_pos >= end) {
|
||||||
FontMetrics const & fm = theFontMetrics(
|
FontMetrics const & fm = theFontMetrics(
|
||||||
text_->getLabelFont(buffer, par));
|
text_->labelFont(buffer, par));
|
||||||
w += fm.width(par.layout()->labelsep);
|
w += fm.width(par.layout()->labelsep);
|
||||||
if (end > 0 && par.isLineSeparator(end - 1))
|
if (end > 0 && par.isLineSeparator(end - 1))
|
||||||
w -= singleWidth(pit, end - 1);
|
w -= singleWidth(pit, end - 1);
|
||||||
@ -913,13 +913,13 @@ Dimension TextMetrics::rowHeight(pit_type const pit, pos_type const first,
|
|||||||
// 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 = getDisplayFont(pit, first);
|
Font font = displayFont(pit, first);
|
||||||
FontSize const tmpsize = font.fontInfo().size();
|
FontSize const tmpsize = font.fontInfo().size();
|
||||||
font.fontInfo() = text_->getLayoutFont(buffer, pit);
|
font.fontInfo() = text_->layoutFont(buffer, pit);
|
||||||
FontSize const size = font.fontInfo().size();
|
FontSize const size = font.fontInfo().size();
|
||||||
font.fontInfo().setSize(tmpsize);
|
font.fontInfo().setSize(tmpsize);
|
||||||
|
|
||||||
FontInfo labelfont = text_->getLabelFont(buffer, par);
|
FontInfo labelfont = text_->labelFont(buffer, par);
|
||||||
|
|
||||||
FontMetrics const & labelfont_metrics = theFontMetrics(labelfont);
|
FontMetrics const & labelfont_metrics = theFontMetrics(labelfont);
|
||||||
FontMetrics const & fontmetrics = theFontMetrics(font);
|
FontMetrics const & fontmetrics = theFontMetrics(font);
|
||||||
@ -1129,7 +1129,7 @@ pos_type TextMetrics::getColumnNearX(pit_type const pit,
|
|||||||
last_tmpx = tmpx;
|
last_tmpx = tmpx;
|
||||||
if (body_pos > 0 && c == body_pos - 1) {
|
if (body_pos > 0 && c == body_pos - 1) {
|
||||||
FontMetrics const & fm = theFontMetrics(
|
FontMetrics const & fm = theFontMetrics(
|
||||||
text_->getLabelFont(buffer, par));
|
text_->labelFont(buffer, par));
|
||||||
tmpx += row.label_hfill + fm.width(layout->labelsep);
|
tmpx += row.label_hfill + fm.width(layout->labelsep);
|
||||||
if (par.isLineSeparator(body_pos - 1))
|
if (par.isLineSeparator(body_pos - 1))
|
||||||
tmpx -= singleWidth(pit, body_pos - 1);
|
tmpx -= singleWidth(pit, body_pos - 1);
|
||||||
@ -1550,7 +1550,7 @@ int TextMetrics::cursorX(CursorSlice const & sl,
|
|||||||
// Inline completion RTL special case row_pos == cursor_pos:
|
// Inline completion RTL special case row_pos == cursor_pos:
|
||||||
// "__|b" => cursor_pos is right of __
|
// "__|b" => cursor_pos is right of __
|
||||||
if (row_pos == inlineCompletionVPos && row_pos == cursor_vpos) {
|
if (row_pos == inlineCompletionVPos && row_pos == cursor_vpos) {
|
||||||
font = getDisplayFont(pit, row_pos + 1);
|
font = displayFont(pit, row_pos + 1);
|
||||||
docstring const & completion = bv_->inlineCompletion();
|
docstring const & completion = bv_->inlineCompletion();
|
||||||
if (font.isRightToLeft() && completion.length() > 0)
|
if (font.isRightToLeft() && completion.length() > 0)
|
||||||
x += theFontMetrics(font.fontInfo()).width(completion);
|
x += theFontMetrics(font.fontInfo()).width(completion);
|
||||||
@ -1563,7 +1563,7 @@ int TextMetrics::cursorX(CursorSlice const & sl,
|
|||||||
pos_type pos = bidi.vis2log(vpos);
|
pos_type pos = bidi.vis2log(vpos);
|
||||||
if (body_pos > 0 && pos == body_pos - 1) {
|
if (body_pos > 0 && pos == body_pos - 1) {
|
||||||
FontMetrics const & labelfm = theFontMetrics(
|
FontMetrics const & labelfm = theFontMetrics(
|
||||||
text_->getLabelFont(buffer, par));
|
text_->labelFont(buffer, par));
|
||||||
x += row.label_hfill + labelfm.width(par.layout()->labelsep);
|
x += row.label_hfill + labelfm.width(par.layout()->labelsep);
|
||||||
if (par.isLineSeparator(body_pos - 1))
|
if (par.isLineSeparator(body_pos - 1))
|
||||||
x -= singleWidth(pit, body_pos - 1);
|
x -= singleWidth(pit, body_pos - 1);
|
||||||
@ -1572,7 +1572,7 @@ int TextMetrics::cursorX(CursorSlice const & sl,
|
|||||||
// Use font span to speed things up, see above
|
// Use font span to speed things up, see above
|
||||||
if (pos < font_span.first || pos > font_span.last) {
|
if (pos < font_span.first || pos > font_span.last) {
|
||||||
font_span = par.fontSpan(pos);
|
font_span = par.fontSpan(pos);
|
||||||
font = getDisplayFont(pit, pos);
|
font = displayFont(pit, pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
x += pm.singleWidth(pos, font);
|
x += pm.singleWidth(pos, font);
|
||||||
@ -1581,7 +1581,7 @@ int TextMetrics::cursorX(CursorSlice const & sl,
|
|||||||
// "a__|b", __ of b => non-boundary a-pos is right of __
|
// "a__|b", __ of b => non-boundary a-pos is right of __
|
||||||
if (vpos + 1 == inlineCompletionVPos
|
if (vpos + 1 == inlineCompletionVPos
|
||||||
&& (vpos + 1 < cursor_vpos || !boundary_correction)) {
|
&& (vpos + 1 < cursor_vpos || !boundary_correction)) {
|
||||||
font = getDisplayFont(pit, vpos + 1);
|
font = displayFont(pit, vpos + 1);
|
||||||
docstring const & completion = bv_->inlineCompletion();
|
docstring const & completion = bv_->inlineCompletion();
|
||||||
if (font.isRightToLeft() && completion.length() > 0)
|
if (font.isRightToLeft() && completion.length() > 0)
|
||||||
x += theFontMetrics(font.fontInfo()).width(completion);
|
x += theFontMetrics(font.fontInfo()).width(completion);
|
||||||
@ -1591,7 +1591,7 @@ int TextMetrics::cursorX(CursorSlice const & sl,
|
|||||||
// "b|__a", __ of b => non-boundary a-pos is in front of __
|
// "b|__a", __ of b => non-boundary a-pos is in front of __
|
||||||
if (vpos == inlineCompletionVPos
|
if (vpos == inlineCompletionVPos
|
||||||
&& (vpos + 1 < cursor_vpos || boundary_correction)) {
|
&& (vpos + 1 < cursor_vpos || boundary_correction)) {
|
||||||
font = getDisplayFont(pit, vpos);
|
font = displayFont(pit, vpos);
|
||||||
docstring const & completion = bv_->inlineCompletion();
|
docstring const & completion = bv_->inlineCompletion();
|
||||||
if (!font.isRightToLeft() && completion.length() > 0)
|
if (!font.isRightToLeft() && completion.length() > 0)
|
||||||
x += theFontMetrics(font.fontInfo()).width(completion);
|
x += theFontMetrics(font.fontInfo()).width(completion);
|
||||||
@ -1801,7 +1801,7 @@ int TextMetrics::leftMargin(int max_width,
|
|||||||
&& pit > 0 && pars[pit - 1].layout()->nextnoindent)
|
&& pit > 0 && pars[pit - 1].layout()->nextnoindent)
|
||||||
parindent.erase();
|
parindent.erase();
|
||||||
|
|
||||||
FontInfo const labelfont = text_->getLabelFont(buffer, par);
|
FontInfo const labelfont = text_->labelFont(buffer, par);
|
||||||
FontMetrics const & labelfont_metrics = theFontMetrics(labelfont);
|
FontMetrics const & labelfont_metrics = theFontMetrics(labelfont);
|
||||||
|
|
||||||
switch (layout->margintype) {
|
switch (layout->margintype) {
|
||||||
@ -1922,7 +1922,7 @@ int TextMetrics::singleWidth(pit_type pit, pos_type pos) const
|
|||||||
{
|
{
|
||||||
ParagraphMetrics const & pm = par_metrics_[pit];
|
ParagraphMetrics const & pm = par_metrics_[pit];
|
||||||
|
|
||||||
return pm.singleWidth(pos, getDisplayFont(pit, pos));
|
return pm.singleWidth(pos, displayFont(pit, pos));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ public:
|
|||||||
TextMetrics(BufferView *, Text *);
|
TextMetrics(BufferView *, Text *);
|
||||||
|
|
||||||
///
|
///
|
||||||
bool has(pit_type pit) const;
|
bool contains(pit_type pit) const;
|
||||||
///
|
///
|
||||||
ParagraphMetrics const & parMetrics(pit_type) const;
|
ParagraphMetrics const & parMetrics(pit_type) const;
|
||||||
///
|
///
|
||||||
@ -68,8 +68,7 @@ public:
|
|||||||
/// The difference is that this one is used for displaying, and thus we
|
/// The difference is that this one is used for displaying, and thus we
|
||||||
/// are allowed to make cosmetic improvements. For instance make footnotes
|
/// are allowed to make cosmetic improvements. For instance make footnotes
|
||||||
/// smaller. (Asger)
|
/// smaller. (Asger)
|
||||||
Font getDisplayFont(pit_type pit,
|
Font displayFont(pit_type pit, pos_type pos) const;
|
||||||
pos_type pos) const;
|
|
||||||
|
|
||||||
/// There are currently two font mechanisms in LyX:
|
/// There are currently two font mechanisms in LyX:
|
||||||
/// 1. The font attributes in a lyxtext, and
|
/// 1. The font attributes in a lyxtext, and
|
||||||
|
@ -345,7 +345,7 @@ bool getTokenValue(string const & str, char const * token, string & ret)
|
|||||||
{
|
{
|
||||||
ret.erase();
|
ret.erase();
|
||||||
size_t token_length = strlen(token);
|
size_t token_length = strlen(token);
|
||||||
string::size_type pos = str.find(token);
|
size_t pos = str.find(token);
|
||||||
|
|
||||||
if (pos == string::npos || pos + token_length + 1 >= str.length()
|
if (pos == string::npos || pos + token_length + 1 >= str.length()
|
||||||
|| str[pos + token_length] != '=')
|
|| str[pos + token_length] != '=')
|
||||||
@ -4697,8 +4697,8 @@ bool InsetTabular::insertPlaintextString(BufferView & bv, docstring const & buf,
|
|||||||
col_type cols = 1;
|
col_type cols = 1;
|
||||||
row_type rows = 1;
|
row_type rows = 1;
|
||||||
col_type maxCols = 1;
|
col_type maxCols = 1;
|
||||||
docstring::size_type const len = buf.length();
|
size_t const len = buf.length();
|
||||||
docstring::size_type p = 0;
|
size_t p = 0;
|
||||||
|
|
||||||
while (p < len &&
|
while (p < len &&
|
||||||
(p = buf.find_first_of(from_ascii("\t\n"), p)) != docstring::npos) {
|
(p = buf.find_first_of(from_ascii("\t\n"), p)) != docstring::npos) {
|
||||||
@ -4732,7 +4732,7 @@ bool InsetTabular::insertPlaintextString(BufferView & bv, docstring const & buf,
|
|||||||
row = tabular.cellRow(cell);
|
row = tabular.cellRow(cell);
|
||||||
}
|
}
|
||||||
|
|
||||||
docstring::size_type op = 0;
|
size_t op = 0;
|
||||||
idx_type const cells = loctab->cellCount();
|
idx_type const cells = loctab->cellCount();
|
||||||
p = 0;
|
p = 0;
|
||||||
cols = ocol;
|
cols = ocol;
|
||||||
@ -4750,7 +4750,7 @@ bool InsetTabular::insertPlaintextString(BufferView & bv, docstring const & buf,
|
|||||||
if (cols < columns) {
|
if (cols < columns) {
|
||||||
shared_ptr<InsetText> inset = loctab->getCellInset(cell);
|
shared_ptr<InsetText> inset = loctab->getCellInset(cell);
|
||||||
Font const font = bv.textMetrics(&inset->text_).
|
Font const font = bv.textMetrics(&inset->text_).
|
||||||
getDisplayFont(0, 0);
|
displayFont(0, 0);
|
||||||
inset->setText(buf.substr(op, p - op), font,
|
inset->setText(buf.substr(op, p - op), font,
|
||||||
buffer().params().trackChanges);
|
buffer().params().trackChanges);
|
||||||
++cols;
|
++cols;
|
||||||
@ -4762,7 +4762,7 @@ bool InsetTabular::insertPlaintextString(BufferView & bv, docstring const & buf,
|
|||||||
if (cols < columns) {
|
if (cols < columns) {
|
||||||
shared_ptr<InsetText> inset = tabular.getCellInset(cell);
|
shared_ptr<InsetText> inset = tabular.getCellInset(cell);
|
||||||
Font const font = bv.textMetrics(&inset->text_).
|
Font const font = bv.textMetrics(&inset->text_).
|
||||||
getDisplayFont(0, 0);
|
displayFont(0, 0);
|
||||||
inset->setText(buf.substr(op, p - op), font,
|
inset->setText(buf.substr(op, p - op), font,
|
||||||
buffer().params().trackChanges);
|
buffer().params().trackChanges);
|
||||||
}
|
}
|
||||||
@ -4778,7 +4778,7 @@ bool InsetTabular::insertPlaintextString(BufferView & bv, docstring const & buf,
|
|||||||
// check for the last cell if there is no trailing '\n'
|
// check for the last cell if there is no trailing '\n'
|
||||||
if (cell < cells && op < len) {
|
if (cell < cells && op < len) {
|
||||||
shared_ptr<InsetText> inset = loctab->getCellInset(cell);
|
shared_ptr<InsetText> inset = loctab->getCellInset(cell);
|
||||||
Font const font = bv.textMetrics(&inset->text_).getDisplayFont(0, 0);
|
Font const font = bv.textMetrics(&inset->text_).displayFont(0, 0);
|
||||||
inset->setText(buf.substr(op, len - op), font,
|
inset->setText(buf.substr(op, len - op), font,
|
||||||
buffer().params().trackChanges);
|
buffer().params().trackChanges);
|
||||||
}
|
}
|
||||||
|
@ -74,9 +74,9 @@ RowPainter::RowPainter(PainterInfo & pi,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
FontInfo const RowPainter::getLabelFont() const
|
FontInfo RowPainter::labelFont() const
|
||||||
{
|
{
|
||||||
return text_.getLabelFont(pi_.base.bv->buffer(), par_);
|
return text_.labelFont(pi_.base.bv->buffer(), par_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -93,7 +93,7 @@ int RowPainter::leftMargin() const
|
|||||||
|
|
||||||
void RowPainter::paintInset(Inset const * inset, pos_type const pos)
|
void RowPainter::paintInset(Inset const * inset, pos_type const pos)
|
||||||
{
|
{
|
||||||
Font const font = text_metrics_.getDisplayFont(pit_, pos);
|
Font const font = text_metrics_.displayFont(pit_, pos);
|
||||||
|
|
||||||
BOOST_ASSERT(inset);
|
BOOST_ASSERT(inset);
|
||||||
// Backup full_repaint status because some insets (InsetTabular)
|
// Backup full_repaint status because some insets (InsetTabular)
|
||||||
@ -174,7 +174,7 @@ void RowPainter::paintHebrewComposeChar(pos_type & vpos, FontInfo 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_metrics_.getDisplayFont(pit_, i));
|
text_metrics_.displayFont(pit_, i));
|
||||||
dx = (c == 0x05e8 || // resh
|
dx = (c == 0x05e8 || // resh
|
||||||
c == 0x05d3) // dalet
|
c == 0x05d3) // dalet
|
||||||
? width2 - width
|
? width2 - width
|
||||||
@ -208,7 +208,7 @@ void RowPainter::paintArabicComposeChar(pos_type & vpos, FontInfo 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_metrics_.getDisplayFont(pit_, i));
|
text_metrics_.displayFont(pit_, i));
|
||||||
dx = (width2 - width) / 2;
|
dx = (width2 - width) / 2;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -329,7 +329,7 @@ void RowPainter::paintForeignMark(double orig_x, Language const * lang,
|
|||||||
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 const orig_font = text_metrics_.getDisplayFont(pit_, pos);
|
Font const orig_font = text_metrics_.displayFont(pit_, pos);
|
||||||
double const orig_x = x_;
|
double const orig_x = x_;
|
||||||
|
|
||||||
// usual characters, no insets
|
// usual characters, no insets
|
||||||
@ -502,7 +502,7 @@ void RowPainter::paintFirst()
|
|||||||
|| layout->latextype != LATEX_ENVIRONMENT
|
|| layout->latextype != LATEX_ENVIRONMENT
|
||||||
|| is_seq)) {
|
|| is_seq)) {
|
||||||
|
|
||||||
FontInfo const font = getLabelFont();
|
FontInfo const font = labelFont();
|
||||||
FontMetrics const & fm = theFontMetrics(font);
|
FontMetrics const & fm = theFontMetrics(font);
|
||||||
|
|
||||||
docstring const str = par_.labelString();
|
docstring const str = par_.labelString();
|
||||||
@ -550,7 +550,7 @@ void RowPainter::paintFirst()
|
|||||||
(layout->labeltype == LABEL_TOP_ENVIRONMENT ||
|
(layout->labeltype == LABEL_TOP_ENVIRONMENT ||
|
||||||
layout->labeltype == LABEL_BIBLIO ||
|
layout->labeltype == LABEL_BIBLIO ||
|
||||||
layout->labeltype == LABEL_CENTERED_TOP_ENVIRONMENT)) {
|
layout->labeltype == LABEL_CENTERED_TOP_ENVIRONMENT)) {
|
||||||
FontInfo const font = getLabelFont();
|
FontInfo const font = labelFont();
|
||||||
docstring const str = par_.labelString();
|
docstring const str = par_.labelString();
|
||||||
if (!str.empty()) {
|
if (!str.empty()) {
|
||||||
double spacing_val = 1.0;
|
double spacing_val = 1.0;
|
||||||
@ -606,7 +606,7 @@ void RowPainter::paintLast()
|
|||||||
switch (endlabel) {
|
switch (endlabel) {
|
||||||
case END_LABEL_BOX:
|
case END_LABEL_BOX:
|
||||||
case END_LABEL_FILLED_BOX: {
|
case END_LABEL_FILLED_BOX: {
|
||||||
FontInfo const font = getLabelFont();
|
FontInfo const font = labelFont();
|
||||||
FontMetrics const & fm = theFontMetrics(font);
|
FontMetrics const & fm = theFontMetrics(font);
|
||||||
int const size = int(0.75 * fm.maxAscent());
|
int const size = int(0.75 * fm.maxAscent());
|
||||||
int const y = yo_ - size;
|
int const y = yo_ - size;
|
||||||
@ -627,7 +627,7 @@ void RowPainter::paintLast()
|
|||||||
}
|
}
|
||||||
|
|
||||||
case END_LABEL_STATIC: {
|
case END_LABEL_STATIC: {
|
||||||
FontInfo const font = getLabelFont();
|
FontInfo const font = labelFont();
|
||||||
FontMetrics const & fm = theFontMetrics(font);
|
FontMetrics const & fm = theFontMetrics(font);
|
||||||
docstring const & str = par_.layout()->endlabelstring();
|
docstring const & str = par_.layout()->endlabelstring();
|
||||||
double const x = is_rtl ?
|
double const x = is_rtl ?
|
||||||
@ -721,7 +721,7 @@ void RowPainter::paintText()
|
|||||||
// Use font span to speed things up, see above
|
// Use font span to speed things up, see above
|
||||||
if (vpos < font_span.first || vpos > font_span.last) {
|
if (vpos < font_span.first || vpos > font_span.last) {
|
||||||
font_span = par_.fontSpan(vpos);
|
font_span = par_.fontSpan(vpos);
|
||||||
font = text_metrics_.getDisplayFont(pit_, vpos);
|
font = text_metrics_.displayFont(pit_, vpos);
|
||||||
|
|
||||||
// split font span if inline completion is inside
|
// split font span if inline completion is inside
|
||||||
if (font_span.first <= inlineCompletionVPos
|
if (font_span.first <= inlineCompletionVPos
|
||||||
@ -761,7 +761,7 @@ void RowPainter::paintText()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (body_pos > 0 && pos == body_pos - 1) {
|
if (body_pos > 0 && pos == body_pos - 1) {
|
||||||
int const lwidth = theFontMetrics(getLabelFont())
|
int const lwidth = theFontMetrics(labelFont())
|
||||||
.width(layout->labelsep);
|
.width(layout->labelsep);
|
||||||
|
|
||||||
x_ += row_.label_hfill + lwidth - width_pos;
|
x_ += row_.label_hfill + lwidth - width_pos;
|
||||||
@ -772,7 +772,7 @@ void RowPainter::paintText()
|
|||||||
paintInlineCompletion(font);
|
paintInlineCompletion(font);
|
||||||
|
|
||||||
if (par_.isSeparator(pos)) {
|
if (par_.isSeparator(pos)) {
|
||||||
Font const orig_font = text_metrics_.getDisplayFont(pit_, pos);
|
Font const orig_font = text_metrics_.displayFont(pit_, 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)
|
||||||
|
@ -69,7 +69,7 @@ private:
|
|||||||
int leftMargin() const;
|
int leftMargin() const;
|
||||||
|
|
||||||
/// return the label font for this row
|
/// return the label font for this row
|
||||||
FontInfo const getLabelFont() const;
|
FontInfo labelFont() const;
|
||||||
|
|
||||||
/// contains painting related information.
|
/// contains painting related information.
|
||||||
PainterInfo & pi_;
|
PainterInfo & pi_;
|
||||||
|
Loading…
Reference in New Issue
Block a user