2002-09-25 14:26:13 +00:00
|
|
|
|
/**
|
2007-04-25 01:24:38 +00:00
|
|
|
|
* \file InsetText.cpp
|
2002-09-25 14:26:13 +00:00
|
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
|
* Licence details can be found in the file COPYING.
|
2002-03-21 17:09:55 +00:00
|
|
|
|
*
|
2002-09-25 14:26:13 +00:00
|
|
|
|
* \author J<EFBFBD>rgen Vigna
|
2000-02-25 12:06:15 +00:00
|
|
|
|
*
|
2003-08-23 00:17:00 +00:00
|
|
|
|
* Full author contact details are available in file CREDITS.
|
2000-02-25 12:06:15 +00:00
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
|
2007-04-25 01:24:38 +00:00
|
|
|
|
#include "InsetText.h"
|
|
|
|
|
#include "InsetNewline.h"
|
2002-08-13 14:40:38 +00:00
|
|
|
|
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "Buffer.h"
|
2007-08-12 21:43:58 +00:00
|
|
|
|
#include "buffer_funcs.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "BufferParams.h"
|
2000-02-25 12:06:15 +00:00
|
|
|
|
#include "BufferView.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "CoordCache.h"
|
2000-04-10 14:29:05 +00:00
|
|
|
|
#include "CutAndPaste.h"
|
2007-04-26 14:56:30 +00:00
|
|
|
|
#include "Cursor.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "DispatchResult.h"
|
|
|
|
|
#include "ErrorList.h"
|
|
|
|
|
#include "FuncRequest.h"
|
2007-10-18 15:29:51 +00:00
|
|
|
|
#include "InsetList.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "Intl.h"
|
2002-08-13 14:40:38 +00:00
|
|
|
|
#include "lyxfind.h"
|
2007-04-26 11:30:54 +00:00
|
|
|
|
#include "Lexer.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "LyXRC.h"
|
2007-04-29 23:33:02 +00:00
|
|
|
|
#include "Text.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "MetricsInfo.h"
|
|
|
|
|
#include "OutputParams.h"
|
2003-11-05 12:06:20 +00:00
|
|
|
|
#include "output_docbook.h"
|
|
|
|
|
#include "output_latex.h"
|
|
|
|
|
#include "output_plaintext.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "Paragraph.h"
|
2003-09-05 09:01:27 +00:00
|
|
|
|
#include "paragraph_funcs.h"
|
2001-06-25 00:06:33 +00:00
|
|
|
|
#include "ParagraphParameters.h"
|
2007-08-12 21:43:58 +00:00
|
|
|
|
#include "ParIterator.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "Row.h"
|
2003-09-05 09:01:27 +00:00
|
|
|
|
#include "sgml.h"
|
2007-11-07 23:25:08 +00:00
|
|
|
|
#include "TextClass.h"
|
2007-10-11 09:59:01 +00:00
|
|
|
|
#include "TextMetrics.h"
|
2007-04-26 04:41:58 +00:00
|
|
|
|
#include "TexRow.h"
|
2000-04-04 00:19:15 +00:00
|
|
|
|
|
2007-04-28 20:44:46 +00:00
|
|
|
|
#include "frontends/alert.h"
|
2002-08-13 14:40:38 +00:00
|
|
|
|
#include "frontends/Painter.h"
|
2001-12-18 03:21:10 +00:00
|
|
|
|
|
2008-02-18 07:14:42 +00:00
|
|
|
|
#include "support/debug.h"
|
|
|
|
|
#include "support/gettext.h"
|
2007-11-13 23:50:28 +00:00
|
|
|
|
#include "support/lstrings.h"
|
2001-12-18 03:21:10 +00:00
|
|
|
|
|
2002-08-14 18:38:59 +00:00
|
|
|
|
#include <boost/bind.hpp>
|
2007-11-13 23:50:28 +00:00
|
|
|
|
#include <boost/assert.hpp>
|
2006-09-10 10:53:23 +00:00
|
|
|
|
|
2007-12-12 10:16:00 +00:00
|
|
|
|
using namespace std;
|
2007-12-12 18:57:56 +00:00
|
|
|
|
using namespace lyx::support;
|
2007-12-12 10:16:00 +00:00
|
|
|
|
|
|
|
|
|
using boost::bind;
|
|
|
|
|
using boost::ref;
|
2003-09-09 22:13:45 +00:00
|
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
|
namespace lyx {
|
2003-09-09 22:13:45 +00:00
|
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
|
using graphics::PreviewLoader;
|
|
|
|
|
|
2003-08-01 12:52:59 +00:00
|
|
|
|
|
2008-02-21 19:42:34 +00:00
|
|
|
|
class TextCompletionList : public Inset::CompletionList {
|
|
|
|
|
public:
|
|
|
|
|
///
|
|
|
|
|
TextCompletionList(Cursor const & cur)
|
|
|
|
|
: buf_(cur.buffer()), it_(buf_.registeredWords().begin()), pos_(0) {}
|
|
|
|
|
///
|
|
|
|
|
virtual ~TextCompletionList() {}
|
|
|
|
|
|
|
|
|
|
///
|
|
|
|
|
virtual size_t size() const {
|
|
|
|
|
return buf_.registeredWords().size();
|
|
|
|
|
}
|
|
|
|
|
///
|
|
|
|
|
virtual docstring data(size_t idx) const {
|
2008-02-21 22:39:46 +00:00
|
|
|
|
std::set<docstring>::const_iterator it
|
2008-02-21 19:42:34 +00:00
|
|
|
|
= buf_.registeredWords().begin();
|
|
|
|
|
for (size_t i = 0; i < idx; ++i)
|
|
|
|
|
it++;
|
|
|
|
|
return *it;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
Buffer const & buf_;
|
2008-02-21 22:39:46 +00:00
|
|
|
|
std::set<docstring>::const_iterator const it_;
|
2008-02-21 19:42:34 +00:00
|
|
|
|
size_t pos_;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
2002-03-03 20:25:07 +00:00
|
|
|
|
InsetText::InsetText(BufferParams const & bp)
|
2007-10-25 12:41:02 +00:00
|
|
|
|
: drawFrame_(false), frame_color_(Color_insetframe)
|
2003-12-01 13:35:49 +00:00
|
|
|
|
{
|
|
|
|
|
paragraphs().push_back(Paragraph());
|
It used to be that things like InsetFlex, InsetCaption, and the like used the default layout, whatever that is---usually Standard. That gave rise to bug 2178, the solution to which is to define a new empty layout, which insets like these use instead of the default. See r22966.
So, when we have an older LyX file, it will look like this:
\begin_inset ERT
status open
\begin_layout Standard
this that
\end_layout
\end_inset
which is now invalid, because ERT uses only PlainLayout. So I had put some code into Text::readParToken, where the layout for a paragraph gets set as it is read:
if (par.forceEmptyLayout()) {
// in this case only the empty layout is allowed
layoutname = tclass.emptyLayoutName();
} else if (par.useEmptyLayout()) {
// in this case, default layout maps to empty layout
if (layoutname == tclass.defaultLayoutName())
layoutname = tclass.emptyLayoutName();
} else {
// otherwise, the empty layout maps to the default
if (layoutname == tclass.emptyLayoutName())
layoutname = tclass.defaultLayoutName();
}
This turns out not to work, because par.forceEmptyLayout() and par.useEmptyLayout() always return false here, because par.inInset() always returns a null pointer, because the paragraph's inset hasn't yet been set when Text::readParagraph() gets called from Text::read() gets called from InsetText::read(). The solution is to set the paragraph's inset when it is created, which means passing a pointer to the various read() routines along the way.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23057 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-19 02:35:07 +00:00
|
|
|
|
Paragraph & ourpar = paragraphs().back();
|
Fix bug 4037 and related problems. The patch has been cleaned up a bit
from the one posted to the list.
The basic idea has two parts. First, we hard code an "empty layout"
(called PlainLayout, for want of a better name) in TextClass and read it
before doing anything else. It can therefore be customized by classes,
if they want---say, to make it left-aligned. Second, InsetText's are
divided into three types: (i) normal ones, that use the "default" layout
defined by the text class; (ii) highly restrictive ones, such as ERT and
(not quite an inset) table cells, which demand the empty layout; (iii)
middling ones, which default to an empty layout and use the empty layout
in place of the default. (This is so we don't get the same problem we
had with ERT in e.g. footnotes.) The type of inset is signaled by new
methods InsetText::forceEmptyLayout() and InsetText::useEmptyLayout().
(The latter might better be called: useEmptyLayoutInsteadOfDefault(),
but that's silly.) The old InsetText::forceDefaultParagraphs() has been
split into these, plus a new method InsetText::allowParagraphCustomization().
A lot of the changes just adapt to this change.
The other big change is in GuiToolbar: We want to show LyXDefault and
the "default" layout only when they're active.
There are a handful of places where I'm not entirely sure whether we
should be using forceEmptyLayout or !allowParagraphCustomization() or
both. The InsetCaption is one of these. These places, and some others,
are marked with FIXMEs, so I'd appreciate it if people would search
through the patch and let me know whether these need changing. If they
don't, the FIXMEs can be deleted.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22966 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-12 17:31:07 +00:00
|
|
|
|
if (useEmptyLayout())
|
It used to be that things like InsetFlex, InsetCaption, and the like used the default layout, whatever that is---usually Standard. That gave rise to bug 2178, the solution to which is to define a new empty layout, which insets like these use instead of the default. See r22966.
So, when we have an older LyX file, it will look like this:
\begin_inset ERT
status open
\begin_layout Standard
this that
\end_layout
\end_inset
which is now invalid, because ERT uses only PlainLayout. So I had put some code into Text::readParToken, where the layout for a paragraph gets set as it is read:
if (par.forceEmptyLayout()) {
// in this case only the empty layout is allowed
layoutname = tclass.emptyLayoutName();
} else if (par.useEmptyLayout()) {
// in this case, default layout maps to empty layout
if (layoutname == tclass.defaultLayoutName())
layoutname = tclass.emptyLayoutName();
} else {
// otherwise, the empty layout maps to the default
if (layoutname == tclass.emptyLayoutName())
layoutname = tclass.defaultLayoutName();
}
This turns out not to work, because par.forceEmptyLayout() and par.useEmptyLayout() always return false here, because par.inInset() always returns a null pointer, because the paragraph's inset hasn't yet been set when Text::readParagraph() gets called from Text::read() gets called from InsetText::read(). The solution is to set the paragraph's inset when it is created, which means passing a pointer to the various read() routines along the way.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23057 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-19 02:35:07 +00:00
|
|
|
|
ourpar.layout(bp.getTextClass().emptyLayout());
|
Fix bug 4037 and related problems. The patch has been cleaned up a bit
from the one posted to the list.
The basic idea has two parts. First, we hard code an "empty layout"
(called PlainLayout, for want of a better name) in TextClass and read it
before doing anything else. It can therefore be customized by classes,
if they want---say, to make it left-aligned. Second, InsetText's are
divided into three types: (i) normal ones, that use the "default" layout
defined by the text class; (ii) highly restrictive ones, such as ERT and
(not quite an inset) table cells, which demand the empty layout; (iii)
middling ones, which default to an empty layout and use the empty layout
in place of the default. (This is so we don't get the same problem we
had with ERT in e.g. footnotes.) The type of inset is signaled by new
methods InsetText::forceEmptyLayout() and InsetText::useEmptyLayout().
(The latter might better be called: useEmptyLayoutInsteadOfDefault(),
but that's silly.) The old InsetText::forceDefaultParagraphs() has been
split into these, plus a new method InsetText::allowParagraphCustomization().
A lot of the changes just adapt to this change.
The other big change is in GuiToolbar: We want to show LyXDefault and
the "default" layout only when they're active.
There are a handful of places where I'm not entirely sure whether we
should be using forceEmptyLayout or !allowParagraphCustomization() or
both. The InsetCaption is one of these. These places, and some others,
are marked with FIXMEs, so I'd appreciate it if people would search
through the patch and let me know whether these need changing. If they
don't, the FIXMEs can be deleted.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22966 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-12 17:31:07 +00:00
|
|
|
|
else
|
It used to be that things like InsetFlex, InsetCaption, and the like used the default layout, whatever that is---usually Standard. That gave rise to bug 2178, the solution to which is to define a new empty layout, which insets like these use instead of the default. See r22966.
So, when we have an older LyX file, it will look like this:
\begin_inset ERT
status open
\begin_layout Standard
this that
\end_layout
\end_inset
which is now invalid, because ERT uses only PlainLayout. So I had put some code into Text::readParToken, where the layout for a paragraph gets set as it is read:
if (par.forceEmptyLayout()) {
// in this case only the empty layout is allowed
layoutname = tclass.emptyLayoutName();
} else if (par.useEmptyLayout()) {
// in this case, default layout maps to empty layout
if (layoutname == tclass.defaultLayoutName())
layoutname = tclass.emptyLayoutName();
} else {
// otherwise, the empty layout maps to the default
if (layoutname == tclass.emptyLayoutName())
layoutname = tclass.defaultLayoutName();
}
This turns out not to work, because par.forceEmptyLayout() and par.useEmptyLayout() always return false here, because par.inInset() always returns a null pointer, because the paragraph's inset hasn't yet been set when Text::readParagraph() gets called from Text::read() gets called from InsetText::read(). The solution is to set the paragraph's inset when it is created, which means passing a pointer to the various read() routines along the way.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23057 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-19 02:35:07 +00:00
|
|
|
|
ourpar.layout(bp.getTextClass().defaultLayout());
|
|
|
|
|
ourpar.setInsetOwner(this);
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2003-05-26 09:13:55 +00:00
|
|
|
|
InsetText::InsetText(InsetText const & in)
|
2007-04-29 13:39:47 +00:00
|
|
|
|
: Inset(in), text_()
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2004-12-17 16:27:12 +00:00
|
|
|
|
text_.autoBreakRows_ = in.text_.autoBreakRows_;
|
2003-10-08 14:29:16 +00:00
|
|
|
|
drawFrame_ = in.drawFrame_;
|
|
|
|
|
frame_color_ = in.frame_color_;
|
2003-12-01 13:35:49 +00:00
|
|
|
|
text_.paragraphs() = in.text_.paragraphs();
|
It used to be that things like InsetFlex, InsetCaption, and the like used the default layout, whatever that is---usually Standard. That gave rise to bug 2178, the solution to which is to define a new empty layout, which insets like these use instead of the default. See r22966.
So, when we have an older LyX file, it will look like this:
\begin_inset ERT
status open
\begin_layout Standard
this that
\end_layout
\end_inset
which is now invalid, because ERT uses only PlainLayout. So I had put some code into Text::readParToken, where the layout for a paragraph gets set as it is read:
if (par.forceEmptyLayout()) {
// in this case only the empty layout is allowed
layoutname = tclass.emptyLayoutName();
} else if (par.useEmptyLayout()) {
// in this case, default layout maps to empty layout
if (layoutname == tclass.defaultLayoutName())
layoutname = tclass.emptyLayoutName();
} else {
// otherwise, the empty layout maps to the default
if (layoutname == tclass.emptyLayoutName())
layoutname = tclass.defaultLayoutName();
}
This turns out not to work, because par.forceEmptyLayout() and par.useEmptyLayout() always return false here, because par.inInset() always returns a null pointer, because the paragraph's inset hasn't yet been set when Text::readParagraph() gets called from Text::read() gets called from InsetText::read(). The solution is to set the paragraph's inset when it is created, which means passing a pointer to the various read() routines along the way.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23057 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-19 02:35:07 +00:00
|
|
|
|
setParagraphOwner();
|
2000-06-12 11:27:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-09-14 17:53:12 +00:00
|
|
|
|
|
2005-02-15 19:53:42 +00:00
|
|
|
|
InsetText::InsetText()
|
2004-11-23 23:04:52 +00:00
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
|
It used to be that things like InsetFlex, InsetCaption, and the like used the default layout, whatever that is---usually Standard. That gave rise to bug 2178, the solution to which is to define a new empty layout, which insets like these use instead of the default. See r22966.
So, when we have an older LyX file, it will look like this:
\begin_inset ERT
status open
\begin_layout Standard
this that
\end_layout
\end_inset
which is now invalid, because ERT uses only PlainLayout. So I had put some code into Text::readParToken, where the layout for a paragraph gets set as it is read:
if (par.forceEmptyLayout()) {
// in this case only the empty layout is allowed
layoutname = tclass.emptyLayoutName();
} else if (par.useEmptyLayout()) {
// in this case, default layout maps to empty layout
if (layoutname == tclass.defaultLayoutName())
layoutname = tclass.emptyLayoutName();
} else {
// otherwise, the empty layout maps to the default
if (layoutname == tclass.emptyLayoutName())
layoutname = tclass.defaultLayoutName();
}
This turns out not to work, because par.forceEmptyLayout() and par.useEmptyLayout() always return false here, because par.inInset() always returns a null pointer, because the paragraph's inset hasn't yet been set when Text::readParagraph() gets called from Text::read() gets called from InsetText::read(). The solution is to set the paragraph's inset when it is created, which means passing a pointer to the various read() routines along the way.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23057 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-19 02:35:07 +00:00
|
|
|
|
void InsetText::setParagraphOwner()
|
2000-03-28 16:18:02 +00:00
|
|
|
|
{
|
2004-11-23 23:04:52 +00:00
|
|
|
|
for_each(paragraphs().begin(), paragraphs().end(),
|
|
|
|
|
bind(&Paragraph::setInsetOwner, _1, this));
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2005-09-07 10:37:05 +00:00
|
|
|
|
void InsetText::clear()
|
2000-07-14 14:57:20 +00:00
|
|
|
|
{
|
2003-12-01 13:35:49 +00:00
|
|
|
|
ParagraphList & pars = paragraphs();
|
2003-03-03 23:19:01 +00:00
|
|
|
|
|
2002-03-04 16:10:47 +00:00
|
|
|
|
// This is a gross hack...
|
2007-08-23 19:59:07 +00:00
|
|
|
|
LayoutPtr old_layout = pars.begin()->layout();
|
2002-03-21 17:09:55 +00:00
|
|
|
|
|
2003-12-01 13:35:49 +00:00
|
|
|
|
pars.clear();
|
|
|
|
|
pars.push_back(Paragraph());
|
|
|
|
|
pars.begin()->setInsetOwner(this);
|
|
|
|
|
pars.begin()->layout(old_layout);
|
2000-07-14 14:57:20 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-08-30 18:03:17 +00:00
|
|
|
|
Inset * InsetText::clone() const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2007-08-30 18:03:17 +00:00
|
|
|
|
return new InsetText(*this);
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-09-17 21:45:14 +00:00
|
|
|
|
Dimension const InsetText::dimension(BufferView const & bv) const
|
|
|
|
|
{
|
|
|
|
|
TextMetrics const & tm = bv.textMetrics(&text_);
|
|
|
|
|
Dimension dim = tm.dimension();
|
|
|
|
|
dim.wid += 2 * TEXT_TO_INSET_OFFSET;
|
|
|
|
|
dim.des += TEXT_TO_INSET_OFFSET;
|
|
|
|
|
dim.asc += TEXT_TO_INSET_OFFSET;
|
|
|
|
|
return dim;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2003-08-28 07:41:31 +00:00
|
|
|
|
void InsetText::write(Buffer const & buf, ostream & os) const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2001-04-02 14:02:58 +00:00
|
|
|
|
os << "Text\n";
|
2003-12-02 12:39:14 +00:00
|
|
|
|
text_.write(buf, os);
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-03-02 02:19:43 +00:00
|
|
|
|
|
2007-04-26 11:30:54 +00:00
|
|
|
|
void InsetText::read(Buffer const & buf, Lexer & lex)
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2005-09-07 10:37:05 +00:00
|
|
|
|
clear();
|
2002-03-21 17:09:55 +00:00
|
|
|
|
|
2003-03-12 05:46:35 +00:00
|
|
|
|
// delete the initial paragraph
|
2003-12-01 13:35:49 +00:00
|
|
|
|
Paragraph oldpar = *paragraphs().begin();
|
|
|
|
|
paragraphs().clear();
|
2006-08-13 16:16:43 +00:00
|
|
|
|
ErrorList errorList;
|
It used to be that things like InsetFlex, InsetCaption, and the like used the default layout, whatever that is---usually Standard. That gave rise to bug 2178, the solution to which is to define a new empty layout, which insets like these use instead of the default. See r22966.
So, when we have an older LyX file, it will look like this:
\begin_inset ERT
status open
\begin_layout Standard
this that
\end_layout
\end_inset
which is now invalid, because ERT uses only PlainLayout. So I had put some code into Text::readParToken, where the layout for a paragraph gets set as it is read:
if (par.forceEmptyLayout()) {
// in this case only the empty layout is allowed
layoutname = tclass.emptyLayoutName();
} else if (par.useEmptyLayout()) {
// in this case, default layout maps to empty layout
if (layoutname == tclass.defaultLayoutName())
layoutname = tclass.emptyLayoutName();
} else {
// otherwise, the empty layout maps to the default
if (layoutname == tclass.emptyLayoutName())
layoutname = tclass.defaultLayoutName();
}
This turns out not to work, because par.forceEmptyLayout() and par.useEmptyLayout() always return false here, because par.inInset() always returns a null pointer, because the paragraph's inset hasn't yet been set when Text::readParagraph() gets called from Text::read() gets called from InsetText::read(). The solution is to set the paragraph's inset when it is created, which means passing a pointer to the various read() routines along the way.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@23057 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-19 02:35:07 +00:00
|
|
|
|
bool res = text_.read(buf, lex, errorList, this);
|
2003-03-12 05:46:35 +00:00
|
|
|
|
|
2003-12-03 15:27:16 +00:00
|
|
|
|
if (!res) {
|
2001-04-02 14:02:58 +00:00
|
|
|
|
lex.printError("Missing \\end_inset at this point. "
|
|
|
|
|
"Read: `$$Token'");
|
|
|
|
|
}
|
2003-10-02 12:01:24 +00:00
|
|
|
|
|
|
|
|
|
// sanity check
|
2004-11-30 01:59:49 +00:00
|
|
|
|
// ensure we have at least one paragraph.
|
2003-12-01 13:35:49 +00:00
|
|
|
|
if (paragraphs().empty())
|
|
|
|
|
paragraphs().push_back(oldpar);
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-09-21 20:39:47 +00:00
|
|
|
|
void InsetText::metrics(MetricsInfo & mi, Dimension & dim) const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2006-12-29 23:54:48 +00:00
|
|
|
|
TextMetrics & tm = mi.base.bv->textMetrics(&text_);
|
|
|
|
|
|
2003-08-02 11:30:30 +00:00
|
|
|
|
//lyxerr << "InsetText::metrics: width: " << mi.base.textwidth << endl;
|
2007-09-02 13:50:37 +00:00
|
|
|
|
|
2006-02-05 13:20:16 +00:00
|
|
|
|
// Hand font through to contained lyxtext:
|
2007-10-28 18:51:54 +00:00
|
|
|
|
tm.font_.fontInfo() = mi.base.font;
|
2007-09-17 21:45:14 +00:00
|
|
|
|
mi.base.textwidth -= 2 * TEXT_TO_INSET_OFFSET;
|
2007-09-18 08:52:38 +00:00
|
|
|
|
if (hasFixedWidth())
|
|
|
|
|
tm.metrics(mi, dim, mi.base.textwidth);
|
|
|
|
|
else
|
|
|
|
|
tm.metrics(mi, dim);
|
2007-09-17 21:45:14 +00:00
|
|
|
|
mi.base.textwidth += 2 * TEXT_TO_INSET_OFFSET;
|
|
|
|
|
dim.asc += TEXT_TO_INSET_OFFSET;
|
|
|
|
|
dim.des += TEXT_TO_INSET_OFFSET;
|
|
|
|
|
dim.wid += 2 * TEXT_TO_INSET_OFFSET;
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2003-08-19 16:46:47 +00:00
|
|
|
|
void InsetText::draw(PainterInfo & pi, int x, int y) const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2006-12-29 23:54:48 +00:00
|
|
|
|
TextMetrics & tm = pi.base.bv->textMetrics(&text_);
|
|
|
|
|
|
2007-08-30 22:12:13 +00:00
|
|
|
|
if (drawFrame_ || pi.full_repaint) {
|
2008-02-14 08:24:52 +00:00
|
|
|
|
int const w = tm.width() + TEXT_TO_INSET_OFFSET;
|
2007-09-17 21:45:14 +00:00
|
|
|
|
int const yframe = y - TEXT_TO_INSET_OFFSET - tm.ascent();
|
|
|
|
|
int const h = tm.height() + 2 * TEXT_TO_INSET_OFFSET;
|
2008-02-14 08:24:52 +00:00
|
|
|
|
int const xframe = x + TEXT_TO_INSET_OFFSET / 2;
|
2007-08-30 22:12:13 +00:00
|
|
|
|
if (pi.full_repaint)
|
2008-02-14 08:24:52 +00:00
|
|
|
|
pi.pain.fillRectangle(xframe, yframe, w, h, backgroundColor());
|
2007-08-30 22:12:13 +00:00
|
|
|
|
if (drawFrame_)
|
2008-02-14 08:24:52 +00:00
|
|
|
|
pi.pain.rectangle(xframe, yframe, w, h, frameColor());
|
2005-07-17 01:13:36 +00:00
|
|
|
|
}
|
2007-09-17 21:45:14 +00:00
|
|
|
|
tm.draw(pi, x + TEXT_TO_INSET_OFFSET, y);
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-09-09 18:52:00 +00:00
|
|
|
|
docstring const InsetText::editMessage() const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2006-09-09 18:52:00 +00:00
|
|
|
|
return _("Opened Text Inset");
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2008-02-11 08:20:13 +00:00
|
|
|
|
void InsetText::edit(Cursor & cur, bool front, EntryDirection entry_from)
|
2001-04-02 14:02:58 +00:00
|
|
|
|
{
|
2008-02-10 19:52:45 +00:00
|
|
|
|
pit_type const pit = front ? 0 : paragraphs().size() - 1;
|
|
|
|
|
pos_type pos = front ? 0 : paragraphs().back().size();
|
|
|
|
|
|
|
|
|
|
// if visual information is not to be ignored, move to extreme right/left
|
2008-02-11 08:20:13 +00:00
|
|
|
|
if (entry_from != ENTRY_DIRECTION_IGNORE) {
|
2008-02-10 19:52:45 +00:00
|
|
|
|
Cursor temp_cur = cur;
|
|
|
|
|
temp_cur.pit() = pit;
|
|
|
|
|
temp_cur.pos() = pos;
|
2008-02-11 08:20:13 +00:00
|
|
|
|
temp_cur.posVisToRowExtremity(entry_from == ENTRY_DIRECTION_LEFT);
|
2008-02-10 19:52:45 +00:00
|
|
|
|
pos = temp_cur.pos();
|
|
|
|
|
}
|
|
|
|
|
|
2004-11-30 01:59:49 +00:00
|
|
|
|
text_.setCursor(cur.top(), pit, pos);
|
2004-01-20 14:25:24 +00:00
|
|
|
|
cur.clearSelection();
|
2007-10-18 11:51:17 +00:00
|
|
|
|
cur.finishUndo();
|
2003-11-04 12:36:59 +00:00
|
|
|
|
}
|
2003-05-16 07:44:00 +00:00
|
|
|
|
|
|
|
|
|
|
2007-04-29 13:39:47 +00:00
|
|
|
|
Inset * InsetText::editXY(Cursor & cur, int x, int y)
|
2003-11-04 12:36:59 +00:00
|
|
|
|
{
|
2007-09-02 09:44:08 +00:00
|
|
|
|
return cur.bv().textMetrics(&text_).editXY(cur, x, y);
|
2003-11-04 12:36:59 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-04-26 14:56:30 +00:00
|
|
|
|
void InsetText::doDispatch(Cursor & cur, FuncRequest & cmd)
|
2003-11-04 12:36:59 +00:00
|
|
|
|
{
|
2007-11-15 20:04:51 +00:00
|
|
|
|
LYXERR(Debug::ACTION, "InsetText::doDispatch()"
|
|
|
|
|
<< " [ cmd.action = " << cmd.action << ']');
|
2006-09-08 14:08:26 +00:00
|
|
|
|
text_.dispatch(cur, cmd);
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-04-26 14:56:30 +00:00
|
|
|
|
bool InsetText::getStatus(Cursor & cur, FuncRequest const & cmd,
|
2004-03-18 13:57:20 +00:00
|
|
|
|
FuncStatus & status) const
|
|
|
|
|
{
|
2006-09-08 14:08:26 +00:00
|
|
|
|
return text_.getStatus(cur, cmd, status);
|
2004-03-18 13:57:20 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-10-20 09:29:19 +00:00
|
|
|
|
void InsetText::setChange(Change const & change)
|
|
|
|
|
{
|
|
|
|
|
ParagraphList::iterator pit = paragraphs().begin();
|
|
|
|
|
ParagraphList::iterator end = paragraphs().end();
|
|
|
|
|
for (; pit != end; ++pit) {
|
|
|
|
|
pit->setChange(change);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-01-23 21:53:16 +00:00
|
|
|
|
void InsetText::acceptChanges(BufferParams const & bparams)
|
2006-10-24 06:11:45 +00:00
|
|
|
|
{
|
2007-01-25 22:28:15 +00:00
|
|
|
|
text_.acceptChanges(bparams);
|
2006-10-24 21:38:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-01-23 21:53:16 +00:00
|
|
|
|
void InsetText::rejectChanges(BufferParams const & bparams)
|
2006-10-24 21:38:47 +00:00
|
|
|
|
{
|
2007-01-25 22:28:15 +00:00
|
|
|
|
text_.rejectChanges(bparams);
|
2006-10-24 06:11:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-10-19 16:51:30 +00:00
|
|
|
|
int InsetText::latex(Buffer const & buf, odocstream & os,
|
2007-05-28 22:27:45 +00:00
|
|
|
|
OutputParams const & runparams) const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2001-04-02 14:02:58 +00:00
|
|
|
|
TexRow texrow;
|
2008-01-25 13:27:08 +00:00
|
|
|
|
latexParagraphs(buf, text_, os, texrow, runparams);
|
2001-04-02 14:02:58 +00:00
|
|
|
|
return texrow.rows();
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-10-19 16:51:30 +00:00
|
|
|
|
int InsetText::plaintext(Buffer const & buf, odocstream & os,
|
2007-05-28 22:27:45 +00:00
|
|
|
|
OutputParams const & runparams) const
|
2000-09-26 15:25:14 +00:00
|
|
|
|
{
|
2003-12-01 13:35:49 +00:00
|
|
|
|
ParagraphList::const_iterator beg = paragraphs().begin();
|
|
|
|
|
ParagraphList::const_iterator end = paragraphs().end();
|
2003-05-27 22:41:04 +00:00
|
|
|
|
ParagraphList::const_iterator it = beg;
|
2005-07-15 19:10:25 +00:00
|
|
|
|
bool ref_printed = false;
|
2007-02-15 22:04:33 +00:00
|
|
|
|
int len = 0;
|
|
|
|
|
for (; it != end; ++it) {
|
|
|
|
|
if (it != beg) {
|
|
|
|
|
os << '\n';
|
|
|
|
|
if (runparams.linelen > 0)
|
|
|
|
|
os << '\n';
|
|
|
|
|
}
|
|
|
|
|
odocstringstream oss;
|
2007-01-18 22:29:50 +00:00
|
|
|
|
writePlaintextParagraph(buf, *it, oss, runparams, ref_printed);
|
2007-02-15 22:04:33 +00:00
|
|
|
|
docstring const str = oss.str();
|
|
|
|
|
os << str;
|
|
|
|
|
// FIXME: len is not computed fully correctly; in principle,
|
|
|
|
|
// we have to count the characters after the last '\n'
|
|
|
|
|
len = str.size();
|
|
|
|
|
}
|
2003-10-31 18:45:43 +00:00
|
|
|
|
|
2007-02-15 22:04:33 +00:00
|
|
|
|
return len;
|
2000-09-26 15:25:14 +00:00
|
|
|
|
}
|
|
|
|
|
|
2003-07-27 18:56:26 +00:00
|
|
|
|
|
2006-10-19 21:00:33 +00:00
|
|
|
|
int InsetText::docbook(Buffer const & buf, odocstream & os,
|
2007-05-28 22:27:45 +00:00
|
|
|
|
OutputParams const & runparams) const
|
2000-10-27 10:04:51 +00:00
|
|
|
|
{
|
2004-10-24 00:02:39 +00:00
|
|
|
|
docbookParagraphs(paragraphs(), buf, os, runparams);
|
2003-10-30 08:47:16 +00:00
|
|
|
|
return 0;
|
2000-10-27 10:04:51 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2001-06-28 10:25:20 +00:00
|
|
|
|
void InsetText::validate(LaTeXFeatures & features) const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2003-12-01 13:35:49 +00:00
|
|
|
|
for_each(paragraphs().begin(), paragraphs().end(),
|
2004-11-23 23:04:52 +00:00
|
|
|
|
bind(&Paragraph::validate, _1, ref(features)));
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
Move BufferView cached pointer out of LyXText:
* LyXText
- bv(), bv_owner, : deleted.
- These methods now need a (Buffer const &) argument: getFont(), applyOuterFont(), getLayoutFont(), getLabelFont(), setCharFont(), setLayout(), singleWidth(), leftMargin(), rightMargin(), computeRowMetrics(), isMainText(), spacing(), isRTL(), cursorX(), rowBreakPoint(), setRowWidth(), labelFill(), labelEnd().
- These methods now need a (BufferView const &) argument and are propably candidates for future removal when 1.6 is opened for development: redoParagraph(), x2pos(), getRowNearY(), getColumnNearX(), checkInsetHit(), setHeightOfRow().
- recUndo(): now need a LCursor argument.
* CoordCache::get(LyXText const *, pit_type):
- now const.
- use const_iterator instead of iterator.
* FontIterator:
- add (Buffer const &) argument to ctor
- buffer_: new const reference to applicable BufferView.
* InsetBase
- xo(), yo(), covers() and neverIndent() are now const.
* InsetText::setViewCache(): deleted
All other changes are due to the LyXText and InsetBase API changes.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@15618 a592a061-630c-0410-9148-cb99ea01b6c8
2006-10-30 12:45:33 +00:00
|
|
|
|
void InsetText::cursorPos(BufferView const & bv,
|
2006-10-17 16:23:27 +00:00
|
|
|
|
CursorSlice const & sl, bool boundary, int & x, int & y) const
|
2003-05-03 18:05:53 +00:00
|
|
|
|
{
|
2007-09-17 21:45:14 +00:00
|
|
|
|
x = bv.textMetrics(&text_).cursorX(sl, boundary) + TEXT_TO_INSET_OFFSET;
|
2007-09-02 09:44:08 +00:00
|
|
|
|
y = bv.textMetrics(&text_).cursorY(sl, boundary);
|
2000-02-25 12:06:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2003-11-10 09:06:48 +00:00
|
|
|
|
bool InsetText::showInsetDialog(BufferView *) const
|
2000-02-25 12:06:15 +00:00
|
|
|
|
{
|
2001-04-02 14:02:58 +00:00
|
|
|
|
return false;
|
2001-03-26 14:47:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-04-29 18:17:15 +00:00
|
|
|
|
void InsetText::setText(docstring const & data, Font const & font, bool trackChanges)
|
2001-01-03 16:04:05 +00:00
|
|
|
|
{
|
2005-09-07 10:37:05 +00:00
|
|
|
|
clear();
|
2004-11-23 23:04:52 +00:00
|
|
|
|
Paragraph & first = paragraphs().front();
|
2002-08-12 00:15:19 +00:00
|
|
|
|
for (unsigned int i = 0; i < data.length(); ++i)
|
2006-10-20 11:44:58 +00:00
|
|
|
|
first.insertChar(i, data[i], font, trackChanges);
|
2001-01-03 16:04:05 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2001-06-28 10:25:20 +00:00
|
|
|
|
void InsetText::setAutoBreakRows(bool flag)
|
2000-05-15 14:49:36 +00:00
|
|
|
|
{
|
2005-07-17 01:13:36 +00:00
|
|
|
|
if (flag == text_.autoBreakRows_)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
text_.autoBreakRows_ = flag;
|
|
|
|
|
if (flag)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
// remove previously existing newlines
|
|
|
|
|
ParagraphList::iterator it = paragraphs().begin();
|
|
|
|
|
ParagraphList::iterator end = paragraphs().end();
|
|
|
|
|
for (; it != end; ++it)
|
|
|
|
|
for (int i = 0; i < it->size(); ++i)
|
|
|
|
|
if (it->isNewline(i))
|
2006-10-19 17:46:50 +00:00
|
|
|
|
// do not track the change, because the user
|
|
|
|
|
// is not allowed to revert/reject it
|
2006-10-21 17:05:20 +00:00
|
|
|
|
it->eraseChar(i, false);
|
2000-05-15 14:49:36 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-06-28 13:35:52 +00:00
|
|
|
|
|
2004-08-14 15:55:22 +00:00
|
|
|
|
void InsetText::setDrawFrame(bool flag)
|
2000-05-15 14:49:36 +00:00
|
|
|
|
{
|
2004-08-14 15:55:22 +00:00
|
|
|
|
drawFrame_ = flag;
|
2000-05-15 14:49:36 +00:00
|
|
|
|
}
|
|
|
|
|
|
2000-06-28 13:35:52 +00:00
|
|
|
|
|
2007-10-25 12:41:02 +00:00
|
|
|
|
ColorCode InsetText::frameColor() const
|
2003-09-16 10:30:59 +00:00
|
|
|
|
{
|
2007-10-29 10:46:13 +00:00
|
|
|
|
return frame_color_;
|
2003-09-16 10:30:59 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2007-10-25 12:41:02 +00:00
|
|
|
|
void InsetText::setFrameColor(ColorCode col)
|
2000-05-15 14:49:36 +00:00
|
|
|
|
{
|
2003-09-16 10:01:29 +00:00
|
|
|
|
frame_color_ = col;
|
2000-06-19 15:33:58 +00:00
|
|
|
|
}
|
2000-06-28 13:35:52 +00:00
|
|
|
|
|
2000-09-27 18:13:30 +00:00
|
|
|
|
|
2003-05-19 17:03:12 +00:00
|
|
|
|
void InsetText::appendParagraphs(Buffer * buffer, ParagraphList & plist)
|
2002-03-21 15:58:54 +00:00
|
|
|
|
{
|
2006-10-20 14:06:18 +00:00
|
|
|
|
// There is little we can do here to keep track of changes.
|
|
|
|
|
// As of 2006/10/20, appendParagraphs is used exclusively by
|
|
|
|
|
// LyXTabular::setMultiColumn. In this context, the paragraph break
|
|
|
|
|
// is lost irreversibly and the appended text doesn't really change
|
|
|
|
|
|
2004-11-23 23:04:52 +00:00
|
|
|
|
ParagraphList & pl = paragraphs();
|
2004-11-24 21:58:42 +00:00
|
|
|
|
|
2003-04-28 16:22:32 +00:00
|
|
|
|
ParagraphList::iterator pit = plist.begin();
|
2004-11-23 23:04:52 +00:00
|
|
|
|
ParagraphList::iterator ins = pl.insert(pl.end(), *pit);
|
2003-04-28 16:22:32 +00:00
|
|
|
|
++pit;
|
2006-03-23 20:11:06 +00:00
|
|
|
|
mergeParagraph(buffer->params(), pl,
|
2007-12-12 19:28:07 +00:00
|
|
|
|
distance(pl.begin(), ins) - 1);
|
2003-04-28 16:22:32 +00:00
|
|
|
|
|
2004-11-23 23:04:52 +00:00
|
|
|
|
for_each(pit, plist.end(),
|
2007-05-28 22:27:45 +00:00
|
|
|
|
bind(&ParagraphList::push_back, ref(pl), _1));
|
2002-03-21 15:58:54 +00:00
|
|
|
|
}
|
2002-08-02 16:39:43 +00:00
|
|
|
|
|
|
|
|
|
|
2003-07-18 16:13:33 +00:00
|
|
|
|
void InsetText::addPreview(PreviewLoader & loader) const
|
2002-08-02 16:39:43 +00:00
|
|
|
|
{
|
2003-12-01 13:35:49 +00:00
|
|
|
|
ParagraphList::const_iterator pit = paragraphs().begin();
|
|
|
|
|
ParagraphList::const_iterator pend = paragraphs().end();
|
2003-04-02 21:19:35 +00:00
|
|
|
|
|
|
|
|
|
for (; pit != pend; ++pit) {
|
2007-10-18 15:29:51 +00:00
|
|
|
|
InsetList::const_iterator it = pit->insetList().begin();
|
|
|
|
|
InsetList::const_iterator end = pit->insetList().end();
|
2003-08-04 15:59:01 +00:00
|
|
|
|
for (; it != end; ++it)
|
2003-05-29 01:13:18 +00:00
|
|
|
|
it->inset->addPreview(loader);
|
2002-08-02 16:39:43 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2003-12-01 13:35:49 +00:00
|
|
|
|
|
|
|
|
|
|
2005-09-10 06:51:58 +00:00
|
|
|
|
//FIXME: instead of this hack, which only works by chance,
|
|
|
|
|
// cells should have their own insetcell type, which returns CELL_CODE!
|
Move BufferView cached pointer out of LyXText:
* LyXText
- bv(), bv_owner, : deleted.
- These methods now need a (Buffer const &) argument: getFont(), applyOuterFont(), getLayoutFont(), getLabelFont(), setCharFont(), setLayout(), singleWidth(), leftMargin(), rightMargin(), computeRowMetrics(), isMainText(), spacing(), isRTL(), cursorX(), rowBreakPoint(), setRowWidth(), labelFill(), labelEnd().
- These methods now need a (BufferView const &) argument and are propably candidates for future removal when 1.6 is opened for development: redoParagraph(), x2pos(), getRowNearY(), getColumnNearX(), checkInsetHit(), setHeightOfRow().
- recUndo(): now need a LCursor argument.
* CoordCache::get(LyXText const *, pit_type):
- now const.
- use const_iterator instead of iterator.
* FontIterator:
- add (Buffer const &) argument to ctor
- buffer_: new const reference to applicable BufferView.
* InsetBase
- xo(), yo(), covers() and neverIndent() are now const.
* InsetText::setViewCache(): deleted
All other changes are due to the LyXText and InsetBase API changes.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@15618 a592a061-630c-0410-9148-cb99ea01b6c8
2006-10-30 12:45:33 +00:00
|
|
|
|
bool InsetText::neverIndent(Buffer const & buffer) const
|
2005-09-10 06:51:58 +00:00
|
|
|
|
{
|
|
|
|
|
// this is only true for tabular cells
|
Move BufferView cached pointer out of LyXText:
* LyXText
- bv(), bv_owner, : deleted.
- These methods now need a (Buffer const &) argument: getFont(), applyOuterFont(), getLayoutFont(), getLabelFont(), setCharFont(), setLayout(), singleWidth(), leftMargin(), rightMargin(), computeRowMetrics(), isMainText(), spacing(), isRTL(), cursorX(), rowBreakPoint(), setRowWidth(), labelFill(), labelEnd().
- These methods now need a (BufferView const &) argument and are propably candidates for future removal when 1.6 is opened for development: redoParagraph(), x2pos(), getRowNearY(), getColumnNearX(), checkInsetHit(), setHeightOfRow().
- recUndo(): now need a LCursor argument.
* CoordCache::get(LyXText const *, pit_type):
- now const.
- use const_iterator instead of iterator.
* FontIterator:
- add (Buffer const &) argument to ctor
- buffer_: new const reference to applicable BufferView.
* InsetBase
- xo(), yo(), covers() and neverIndent() are now const.
* InsetText::setViewCache(): deleted
All other changes are due to the LyXText and InsetBase API changes.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@15618 a592a061-630c-0410-9148-cb99ea01b6c8
2006-10-30 12:45:33 +00:00
|
|
|
|
return !text_.isMainText(buffer) && lyxCode() == TEXT_CODE;
|
2005-09-10 06:51:58 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2004-03-28 22:00:22 +00:00
|
|
|
|
ParagraphList const & InsetText::paragraphs() const
|
|
|
|
|
{
|
|
|
|
|
return text_.paragraphs();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList & InsetText::paragraphs()
|
2003-12-01 13:35:49 +00:00
|
|
|
|
{
|
2004-03-28 22:00:22 +00:00
|
|
|
|
return text_.paragraphs();
|
2003-12-01 13:35:49 +00:00
|
|
|
|
}
|
2006-10-21 00:16:43 +00:00
|
|
|
|
|
|
|
|
|
|
2007-08-12 21:43:58 +00:00
|
|
|
|
void InsetText::updateLabels(Buffer const & buf, ParIterator const & it)
|
|
|
|
|
{
|
|
|
|
|
ParIterator it2 = it;
|
|
|
|
|
it2.forwardPos();
|
|
|
|
|
BOOST_ASSERT(&it2.inset() == this && it2.pit() == 0);
|
|
|
|
|
lyx::updateLabels(buf, it2);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2008-02-21 19:42:34 +00:00
|
|
|
|
bool InsetText::completionSupported(Cursor const & cur) const
|
|
|
|
|
{
|
|
|
|
|
Cursor const & bvCur = cur.bv().cursor();
|
|
|
|
|
if (&bvCur.inset() != this)
|
|
|
|
|
return false;
|
|
|
|
|
Paragraph const & par = cur.paragraph();
|
|
|
|
|
return cur.pos() > 0
|
2008-02-22 09:00:22 +00:00
|
|
|
|
&& (cur.pos() >= par.size() || !par.isLetter(cur.pos()))
|
2008-02-21 19:42:34 +00:00
|
|
|
|
&& par.isLetter(cur.pos() - 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool InsetText::inlineCompletionSupported(Cursor const & cur) const
|
|
|
|
|
{
|
|
|
|
|
return completionSupported(cur);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool InsetText::automaticInlineCompletion() const
|
|
|
|
|
{
|
|
|
|
|
return lyxrc.completion_inline_text;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool InsetText::automaticPopupCompletion() const
|
|
|
|
|
{
|
|
|
|
|
return lyxrc.completion_popup_text;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2008-02-21 23:36:02 +00:00
|
|
|
|
Inset::CompletionList const * InsetText::completionList(Cursor const & cur) const
|
2008-02-21 19:42:34 +00:00
|
|
|
|
{
|
|
|
|
|
if (!completionSupported(cur))
|
2008-02-21 23:36:02 +00:00
|
|
|
|
return 0;
|
2008-02-21 19:42:34 +00:00
|
|
|
|
|
2008-02-21 23:36:02 +00:00
|
|
|
|
return new TextCompletionList(cur);
|
2008-02-21 19:42:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
docstring InsetText::previousWord(Buffer const & buffer, CursorSlice const & sl) const
|
|
|
|
|
{
|
|
|
|
|
CursorSlice from = sl;
|
|
|
|
|
CursorSlice to = sl;
|
|
|
|
|
text_.getWord(from, to, PREVIOUS_WORD);
|
|
|
|
|
if (sl == from || to == from)
|
|
|
|
|
return docstring();
|
|
|
|
|
|
|
|
|
|
Paragraph const & par = sl.paragraph();
|
|
|
|
|
return par.asString(buffer, from.pos(), to.pos(), false);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
docstring InsetText::completionPrefix(Cursor const & cur) const
|
|
|
|
|
{
|
|
|
|
|
if (!completionSupported(cur))
|
|
|
|
|
return docstring();
|
|
|
|
|
|
|
|
|
|
return previousWord(cur.buffer(), cur.top());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool InsetText::insertCompletion(Cursor & cur, docstring const & s,
|
|
|
|
|
bool finished)
|
|
|
|
|
{
|
|
|
|
|
if (!completionSupported(cur))
|
|
|
|
|
return false;
|
2008-02-21 19:43:16 +00:00
|
|
|
|
|
|
|
|
|
BOOST_ASSERT(cur.bv().cursor() == cur);
|
2008-02-21 19:42:34 +00:00
|
|
|
|
cur.insert(s);
|
2008-02-21 19:43:16 +00:00
|
|
|
|
cur.bv().cursor() = cur;
|
2008-02-21 19:42:34 +00:00
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void InsetText::completionPosAndDim(Cursor const & cur, int & x, int & y,
|
|
|
|
|
Dimension & dim) const
|
|
|
|
|
{
|
|
|
|
|
// get word in front of cursor
|
|
|
|
|
docstring word = previousWord(cur.buffer(), cur.top());
|
|
|
|
|
DocIterator wordStart = cur;
|
|
|
|
|
wordStart.pos() -= word.length();
|
|
|
|
|
|
|
|
|
|
// get position on screen of the word start
|
|
|
|
|
Point lxy = cur.bv().getPos(wordStart, false);
|
|
|
|
|
x = lxy.x_;
|
|
|
|
|
y = lxy.y_;
|
|
|
|
|
|
|
|
|
|
// Calculate dimensions of the word
|
|
|
|
|
TextMetrics const & tm = cur.bv().textMetrics(&text_);
|
|
|
|
|
dim = tm.rowHeight(cur.pit(), wordStart.pos(), cur.pos(), false);
|
|
|
|
|
Point rxy = cur.bv().getPos(cur, cur.boundary());
|
|
|
|
|
dim.wid = abs(rxy.x_ - x);
|
|
|
|
|
x = (rxy.x_ < x) ? x - dim.wid : x; // for RTL
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
|
} // namespace lyx
|