#include "insets/Inset.h"
#include "BufferView.h"
-#include "dimension.h"
+#include "Color.h"
+#include "Dimension.h"
#include "gettext.h"
-#include "LColor.h"
-#include "lyx_main.h"
-#include "lyxrc.h"
-#include "metricsinfo.h"
+#include "LyX.h"
+#include "LyXRC.h"
+#include "MetricsInfo.h"
#include "frontends/FontMetrics.h"
#include "frontends/Painter.h"
#include "graphics/PreviewLoader.h"
#include "graphics/Previews.h"
-#include "support/filename.h"
+#include "support/FileName.h"
#include "support/lstrings.h"
#include <boost/bind.hpp>
using support::FileName;
using std::string;
-using std::auto_ptr;
LyXRC_PreviewStatus RenderPreview::status()
}
-RenderPreview::RenderPreview(InsetBase const * inset)
+RenderPreview::RenderPreview(Inset const * inset)
: parent_(inset)
{}
RenderPreview::RenderPreview(RenderPreview const & other,
- InsetBase const * inset)
+ Inset const * inset)
: RenderBase(other),
boost::signals::trackable(),
snippet_(other.snippet_),
{}
-auto_ptr<RenderBase> RenderPreview::clone(InsetBase const * inset) const
+RenderPreview::~RenderPreview()
{
- return auto_ptr<RenderBase>(new RenderPreview(*this, inset));
+ if (ploader_connection_.connected())
+ ploader_connection_.disconnect();
+}
+
+
+RenderBase * RenderPreview::clone(Inset const * inset) const
+{
+ return new RenderPreview(*this, inset);
}
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::Status const status = loader.status(snippet);
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 =
- getPreviewImage(*mi.base.bv->buffer());
+ getPreviewImage(mi.base.bv->buffer());
if (pimage) {
dim.asc = pimage->ascent();
dim.asc = 50;
dim.des = 0;
- LyXFont font(mi.base.font);
- font.setFamily(LyXFont::SANS_FAMILY);
- font.setSize(LyXFont::SIZE_FOOTNOTE);
+ Font font(mi.base.font);
+ font.setFamily(Font::SANS_FAMILY);
+ font.setSize(Font::SIZE_FOOTNOTE);
docstring const stat = statusMessage(mi.base.bv, snippet_);
dim.wid = 15 + theFontMetrics(font).width(stat);
}
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 =
- getPreviewImage(*pi.base.bv->buffer());
+ getPreviewImage(pi.base.bv->buffer());
graphics::Image const * const image = pimage ? pimage->image() : 0;
if (image) {
*image);
} else {
- int const offset = InsetOld::TEXT_TO_INSET_OFFSET;
+ int const offset = Inset::TEXT_TO_INSET_OFFSET;
pi.pain.rectangle(x + offset,
y - dim_.asc,
dim_.wid - 2 * offset,
dim_.asc + dim_.des,
- LColor::foreground);
+ Color::foreground);
- LyXFont font(pi.base.font);
- font.setFamily(LyXFont::SANS_FAMILY);
- font.setSize(LyXFont::SIZE_FOOTNOTE);
+ Font font(pi.base.font);
+ font.setFamily(Font::SANS_FAMILY);
+ font.setSize(Font::SIZE_FOOTNOTE);
docstring const stat = statusMessage(pi.base.bv, snippet_);
pi.pain.text(x + offset + 6,
}
-RenderMonitoredPreview::RenderMonitoredPreview(InsetBase const * inset)
+RenderMonitoredPreview::RenderMonitoredPreview(Inset const * inset)
: RenderPreview(inset),
monitor_(FileName(), 2000)
{}