*
* Full author contact details are available in file CREDITS
*/
-#include <config.h>
+#include <config.h>
#include "insetbibtex.h"
#include "buffer.h"
#include "debug.h"
#include "funcrequest.h"
#include "gettext.h"
+#include "latexrunparams.h"
#include "support/filetools.h"
#include "support/path.h"
#include <fstream>
#include <cstdlib>
+using namespace lyx::support;
+
using std::ostream;
using std::ifstream;
using std::getline;
using std::pair;
-InsetBibtex::InsetBibtex(InsetCommandParams const & p, bool)
+InsetBibtex::InsetBibtex(InsetCommandParams const & p)
: InsetCommand(p)
{}
InsetBibtex::~InsetBibtex()
{
- InsetCommandMailer mailer("bibtex", *this);
- mailer.hideDialog();
+ InsetCommandMailer("bibtex", *this).hideDialog();
}
-dispatch_result InsetBibtex::localDispatch(FuncRequest const & cmd)
+std::auto_ptr<InsetBase> InsetBibtex::clone() const
{
- Inset::RESULT result = UNDISPATCHED;
+ return std::auto_ptr<InsetBase>(new InsetBibtex(*this));
+}
+
+dispatch_result InsetBibtex::localDispatch(FuncRequest const & cmd)
+{
switch (cmd.action) {
+
+ case LFUN_INSET_EDIT:
+ InsetCommandMailer("bibtex", *this).showDialog(cmd.view());
+ return DISPATCHED;
+
case LFUN_INSET_MODIFY: {
InsetCommandParams p;
InsetCommandMailer::string2params(cmd.argument, p);
if (p.getCmdName().empty())
- break;
-
- if (view() && p.getContents() != params().getContents()) {
- view()->ChangeCitationsIfUnique(params().getContents(),
- p.getContents());
- }
-
+ return DISPATCHED;
setParams(p);
- cmd.view()->updateInset(this, true);
- result = DISPATCHED;
+ return DISPATCHED;
}
- break;
+
default:
- result = InsetCommand::localDispatch(cmd);
+ return InsetCommand::localDispatch(cmd);
}
- return result;
}
string const InsetBibtex::getScreenLabel(Buffer const *) const
int InsetBibtex::latex(Buffer const * buffer, ostream & os,
- bool /*fragile*/, bool/*fs*/) const
+ LatexRunParams const & runparams) const
{
// changing the sequence of the commands
// 1. \bibliographystyle{style}
}
}
- if (!buffer->niceFile
+ if (!runparams.nice
&& IsFileReadable(MakeAbsPath(style, buffer->filePath()) + ".bst")) {
style = MakeAbsPath(style, buffer->filePath());
}
// have a comma-separated list of bibliographies
string db_out;
while (!adb.empty()) {
- if (!buffer->niceFile &&
+ if (!runparams.nice &&
IsFileReadable(MakeAbsPath(adb, buffer->filePath())+".bib"))
adb = os::external_path(MakeAbsPath(adb, buffer->filePath()));
db_out += adb;
vector<string> const InsetBibtex::getFiles(Buffer const & buffer) const
{
- // Doesn't appear to be used (Angus, 31 July 2001)
Path p(buffer.filePath());
vector<string> vec;
// This method returns a comma separated list of Bibtex entries
-void InsetBibtex::fillWithBibKeys
- (Buffer const * buffer, vector<pair<string, string> > & keys) const
+void InsetBibtex::fillWithBibKeys(Buffer const * buffer,
+ std::vector<std::pair<string, string> > & keys) const
{
- lyx::Assert(buffer);
+ Assert(buffer);
vector<string> const files = getFiles(*buffer);
for (vector<string>::const_iterator it = files.begin();
it != files.end(); ++ it) {
}
-void InsetBibtex::edit(BufferView * bv, int, int, mouse_button::state)
-{
- InsetCommandMailer mailer("bibtex", *this);
- mailer.showDialog(bv);
-}
-
-
-void InsetBibtex::edit(BufferView * bv, bool)
-{
- edit(bv, 0, 0, mouse_button::none);
-}
-
-
bool InsetBibtex::addDatabase(string const & db)
{
string contents(getContents());