case LFUN_INSET_MODIFY: {
Assert(cmd.view());
- Buffer const & buffer = *cmd.view()->buffer();
+ Buffer const * buffer = cmd.view()->buffer();
InsetExternal::Params p;
- InsetExternalMailer::string2params(cmd.argument, buffer, p);
- setParams(p);
+ InsetExternalMailer::string2params(cmd.argument, *buffer, p);
+ setParams(p, buffer);
cmd.view()->updateInset(this);
return DISPATCHED;
}
}
-string const getScreenLabel(InsetExternal::Params const & params)
+string const getScreenLabel(InsetExternal::Params const & params,
+ Buffer const * buffer)
{
ExternalTemplate const * const ptr = getTemplatePtr(params);
if (!ptr)
return bformat(_("External template %1$s is not installed"),
params.templatename);
- return doSubstitution(params, 0, ptr->guiName);
+ return doSubstitution(params, buffer, ptr->guiName);
}
} // namespace anon
}
-void InsetExternal::setParams(Params const & p)
+void InsetExternal::setParams(Params const & p, Buffer const * buffer)
{
// The stored params; what we would like to happen in an ideal world.
params_.filename = p.filename;
renderer_.reset(button_ptr);
}
- button_ptr->update(getScreenLabel(params_), true);
+ button_ptr->update(getScreenLabel(params_, buffer), true);
} else {
GraphicRenderer * graphic_ptr =
}
-string const InsetExternal::editMessage() const
-{
- return getScreenLabel(params_);
-}
-
-
void InsetExternal::write(Buffer const * buffer, ostream & os) const
{
os << "External\n"
lex.popTable();
// Replace the inset's store
- setParams(params);
+ setParams(params, buffer);
lyxerr[Debug::INFO] << "InsetExternal::Read: "
<< "template: '" << params_.templatename
Buffer const * buffer, string const & s)
{
string result;
- string const absfilename = params.filename.absFilename();
- string const basename = ChangeExtension(absfilename, string());
- string filepath;
+ string const buffer_path = buffer ? buffer->filePath() : string();
+ string const filename = params.filename.outputFilename(buffer_path);
+ string const basename = ChangeExtension(filename, string());
+ string const filepath = OnlyPath(filename);
- result = subst(s, "$$FName", absfilename);
+ result = subst(s, "$$FName", filename);
result = subst(result, "$$Basename", basename);
result = subst(result, "$$FPath", filepath);
result = subst(result, "$$Tempname", params.tempname);
Buffer const & buffer)
{
InsetExternal inset;
- inset.setParams(params);
+ inset.setParams(params, &buffer);
ostringstream data;
data << name_ << ' ';
inset.write(&buffer, data);
void metrics(MetricsInfo &, Dimension &) const;
///
void draw(PainterInfo & pi, int x, int y) const;
- /// what appears in the minibuffer when opening
- virtual string const editMessage() const;
///
virtual EDITABLE editable() const { return IS_EDITABLE; }
///
Params const & params() const;
/// Set the inset parameters.
- virtual void setParams(Params const &);
+ virtual void setParams(Params const &, Buffer const *);
/** update the file represented by the template.
If \param external_in_tmpdir == true, then the generated file is