#include "insets/RenderPreview.h"
#include "insets/Inset.h"
+#include "Buffer.h"
#include "BufferView.h"
#include "Dimension.h"
#include "LyX.h"
#include "graphics/PreviewImage.h"
#include "graphics/PreviewLoader.h"
-#include "graphics/Previews.h"
#include "support/FileName.h"
#include "support/gettext.h"
#include "support/lassert.h"
#include "support/lstrings.h"
-#include <boost/bind.hpp>
-
using namespace std;
using namespace lyx::support;
namespace lyx {
-LyXRC_PreviewStatus RenderPreview::status()
+bool RenderPreview::previewText()
{
- return graphics::Previews::status();
+ // Use a switch to trigger a warning if the enum is changed.
+ switch(lyxrc.preview) {
+ case LyXRC::PREVIEW_ON:
+ case LyXRC::PREVIEW_NO_MATH:
+ return true;
+ case LyXRC::PREVIEW_OFF:
+ break;
+ }
+
+ return false;
+}
+
+
+bool RenderPreview::previewMath()
+{
+ // Use a switch to trigger a warning if the enum is changed.
+ switch(lyxrc.preview) {
+ case LyXRC::PREVIEW_ON:
+ return true;
+ case LyXRC::PREVIEW_NO_MATH:
+ case LyXRC::PREVIEW_OFF:
+ break;
+ }
+
+ return false;
}
RenderPreview::RenderPreview(RenderPreview const & other,
Inset const * inset)
: RenderBase(other),
- boost::signals::trackable(),
snippet_(other.snippet_),
parent_(inset)
{}
-RenderPreview::~RenderPreview()
-{
- if (ploader_connection_.connected())
- ploader_connection_.disconnect();
-}
-
-
RenderBase * RenderPreview::clone(Inset const * inset) const
{
return new RenderPreview(*this, inset);
namespace {
-graphics::PreviewLoader & getPreviewLoader(Buffer const & buffer)
-{
- return thePreviews().loader(buffer);
-}
-
-
docstring const statusMessage(BufferView const * bv, string const & snippet)
{
- LASSERT(bv, /**/);
+ LASSERT(bv, return docstring());
Buffer const & buffer = bv->buffer();
- graphics::PreviewLoader const & loader = getPreviewLoader(buffer);
- graphics::PreviewLoader::Status const status = loader.status(snippet);
+ graphics::PreviewLoader const * loader = buffer.loader();
+ // please coverity (probably worth the check anyway)
+ if (!loader)
+ return docstring();
+ graphics::PreviewLoader::Status const status = loader->status(snippet);
docstring message;
switch (status) {
return message;
}
-} // namespace anon
+} // namespace
graphics::PreviewImage const *
RenderPreview::getPreviewImage(Buffer const & buffer) const
{
- graphics::PreviewLoader const & loader = getPreviewLoader(buffer);
- return loader.preview(snippet_);
+ graphics::PreviewLoader const * loader = buffer.loader();
+ LASSERT(loader, return nullptr);
+ return loader->preview(snippet_);
}
void RenderPreview::metrics(MetricsInfo & mi, Dimension & dim) const
{
- LASSERT(mi.base.bv, /**/);
+ LBUFERR(mi.base.bv);
graphics::PreviewImage const * const pimage =
getPreviewImage(mi.base.bv->buffer());
if (pimage) {
+ // If prepared, load the picture before dim calculation. See bug #5627.
+ pimage->image();
dim = pimage->dim();
} else {
dim.asc = 50;
FontInfo font(mi.base.font);
font.setFamily(SANS_FAMILY);
- font.setSize(FONT_SIZE_FOOTNOTE);
+ font.setSize(FOOTNOTE_SIZE);
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
+void RenderPreview::draw(PainterInfo & pi, int x, int y, bool const) const
{
- LASSERT(pi.base.bv, /**/);
+ LBUFERR(pi.base.bv);
graphics::PreviewImage const * const pimage =
getPreviewImage(pi.base.bv->buffer());
if (image) {
pi.pain.image(x, y - dim_.asc, dim_.wid, dim_.height(),
*image);
-
} else {
- int const offset = Inset::TEXT_TO_INSET_OFFSET;
+ int const offset = Inset::textOffset(pi.base.bv);
pi.pain.rectangle(x + offset,
y - dim_.asc,
FontInfo font(pi.base.font);
font.setFamily(SANS_FAMILY);
- font.setSize(FONT_SIZE_FOOTNOTE);
+ font.setSize(FOOTNOTE_SIZE);
docstring const stat = statusMessage(pi.base.bv, snippet_);
pi.pain.text(x + offset + 6,
y - theFontMetrics(font).maxAscent() - 4,
stat, font);
}
+ pi.change.paintCue(pi, x, y - dim_.asc,
+ x + dim_.width(), y - dim_.asc + dim_.height());
}
-void RenderPreview::startLoading(Buffer const & buffer) const
+void RenderPreview::startLoading(Buffer const & buffer, bool forexport) const
{
- if (status() == LyXRC::PREVIEW_OFF || snippet_.empty())
+ if (!forexport && (lyxrc.preview == LyXRC::PREVIEW_OFF || snippet_.empty()))
return;
- graphics::PreviewLoader const & loader = getPreviewLoader(buffer);
- loader.startLoading();
+ graphics::PreviewLoader * loader = buffer.loader();
+ LASSERT(loader, return);
+ loader->startLoading(forexport);
}
void RenderPreview::addPreview(docstring const & latex_snippet,
- Buffer const & buffer)
+ Buffer const & buffer,
+ bool ignore_lyxrc)
{
- if (status() == LyXRC::PREVIEW_OFF)
+ if (lyxrc.preview == LyXRC::PREVIEW_OFF && !ignore_lyxrc)
return;
- graphics::PreviewLoader & loader = getPreviewLoader(buffer);
- addPreview(latex_snippet, loader);
+ graphics::PreviewLoader * loader = buffer.loader();
+ LASSERT(loader, return);
+ addPreview(latex_snippet, *loader, ignore_lyxrc);
}
void RenderPreview::addPreview(docstring const & latex_snippet,
- graphics::PreviewLoader & ploader)
+ graphics::PreviewLoader & ploader,
+ bool ignore_lyxrc)
{
- if (status() == LyXRC::PREVIEW_OFF)
+ if (lyxrc.preview == LyXRC::PREVIEW_OFF && !ignore_lyxrc)
return;
// FIXME UNICODE
// If this is the first time of calling, connect to the
// PreviewLoader signal that'll inform us when the preview image
// is ready for loading.
- if (!ploader_connection_.connected()) {
- ploader_connection_ = ploader.connect(
- boost::bind(&RenderPreview::imageReady, this, _1));
- }
+ if (!ploader_connection_.connected())
+ // This is a scoped connection.
+ ploader_connection_ =
+ ploader.connect([this](graphics::PreviewImage const & pi){
+ imageReady(pi);
+ });
ploader.add(snippet_);
}
if (snippet_.empty())
return;
- graphics::PreviewLoader & loader = getPreviewLoader(buffer);
- loader.remove(snippet_);
+ graphics::PreviewLoader * loader = buffer.loader();
+ LASSERT(loader, return);
+ loader->remove(snippet_);
snippet_.erase();
}
RenderMonitoredPreview::RenderMonitoredPreview(Inset const * inset)
- : RenderPreview(inset), monitor_(FileName(), 2000)
-{}
+ : RenderPreview(inset)
+{
+ setAbsFile(FileName());
+}
void RenderMonitoredPreview::setAbsFile(FileName const & file)
{
- monitor_.reset(file);
+ bool mon = monitoring();
+ if (mon)
+ stopMonitoring();
+ filename_ = file;
+ if (mon)
+ startMonitoring();
}
-void RenderMonitoredPreview::draw(PainterInfo & pi, int x, int y) const
+void RenderMonitoredPreview::draw(PainterInfo & pi, int x, int y, bool const) const
{
RenderPreview::draw(pi, x, y);
- if (!monitoring())
- startMonitoring();
+ startMonitoring();
+ monitor_->checkModifiedAsync();
}
-boost::signals::connection
-RenderMonitoredPreview::fileChanged(slot_type const & slot)
+connection RenderMonitoredPreview::connect(slot const & slot)
{
- return monitor_.connect(slot);
+ return changed_.connect(slot);
}
+
+bool RenderMonitoredPreview::monitoring() const
+{
+ return (bool) monitor_;
+}
+
+
+void RenderMonitoredPreview::startMonitoring() const
+{
+ if (!monitoring()) {
+ monitor_ = FileSystemWatcher::activeMonitor(filename_);
+ // Disconnected at the same time as this is destroyed.
+ monitor_->connect([this](bool /* exists */){ changed_(); });
+ }
+}
+
+
+void RenderMonitoredPreview::stopMonitoring() const
+{
+ monitor_ = nullptr;
+}
+
+
+
+
} // namespace lyx