#include <sstream>
-using std::endl;
using std::string;
-using std::auto_ptr;
using std::istringstream;
using std::ostream;
using std::ostringstream;
using std::vector;
+using lyx::support::DocFileName;
namespace {
os << "External\n"
<< "\ttemplate " << templatename() << '\n';
- if (!filename.empty())
- os << "\tfilename "
- << filename.outputFilename(buffer.filePath())
- << '\n';
+ if (!filename.empty()) {
+ // when we save, we still use the original filename
+ EmbeddedFiles::EmbeddedFileList::const_iterator it =
+ buffer.embeddedFiles().find(filename.toFilesystemEncoding());
+ if (it != buffer.embeddedFiles().end())
+ os << "\tfilename " << DocFileName(it->absFilename()).outputFilename(buffer.filePath()) << '\n';
+ else
+ os << "\tfilename " << filename.outputFilename(buffer.filePath()) << '\n';
+ }
if (display != defaultDisplayType)
os << "\tdisplay "
lex.eatLine();
string const name = lex.getString();
filename.set(name, buffer.filePath());
+ // maybe this file is embedded
+ EmbeddedFiles::EmbeddedFileList::const_iterator it = buffer.embeddedFiles().find(filename.toFilesystemEncoding());
+ if (it != buffer.embeddedFiles().end())
+ // using available file, embedded or external, depending on file availability and
+ // embedding status.
+ filename = DocFileName(it->availableFile(&buffer));
break;
}
{}
-auto_ptr<Inset> InsetExternal::doClone() const
+Inset * InsetExternal::clone() const
{
- return auto_ptr<Inset>(new InsetExternal(*this));
+ return new InsetExternal(*this);
}
}
+void InsetExternal::registerEmbeddedFiles(Buffer const &,
+ EmbeddedFiles & files) const
+{
+ files.registerFile(params_.filename.absFilename(), false, this);
+}
+
+
void InsetExternal::edit(Cursor & cur, bool)
{
InsetExternalMailer(*this).showDialog(&cur.bv());
}
-bool InsetExternal::metrics(MetricsInfo & mi, Dimension & dim) const
+void InsetExternal::metrics(MetricsInfo & mi, Dimension & dim) const
{
renderer_->metrics(mi, dim);
- bool const changed = dim_ != dim;
- dim_ = dim;
- return changed;
}
void InsetExternal::draw(PainterInfo & pi, int x, int y) const
{
- setPosCache(pi, x, y);
renderer_->draw(pi, x, y);
}
BOOST_ASSERT(false);
}
if (gparams.display == graphics::DefaultDisplay)
- gparams.display = lyxrc.display_graphics;
+ gparams.display = graphics::DisplayType(lyxrc.display_graphics);
// Override the above if we're not using a gui
if (!use_gui)
gparams.display = graphics::NoDisplay;
bool preview_wanted(InsetExternalParams const & params)
{
return params.display == external::PreviewDisplay &&
- support::isFileReadable(params.filename);
+ params.filename.isFileReadable();
}