/* This file is part of
- * ======================================================
+ * ======================================================
*
* LyX, The Document Processor
*
* \author Herbert Voss <voss@perce.de>
*/
-#include <config.h>
+#include <config.h>
#include <fstream>
#ifdef __GNUG__
#pragma implementation
-#endif
+#endif
#include "ViewBase.h"
#include "ButtonControllerBase.h"
#include "ControlGraphics.h"
#include "ControlInset.tmpl"
#include "buffer.h"
+#include "BufferView.h"
#include "Dialogs.h"
#include "LyXView.h"
#include "gettext.h"
#include "insets/insetgraphicsParams.h" // need operator!=()
#include "support/FileInfo.h" // for FileInfo
-#include "helper_funcs.h" // for browseFile
+#include "helper_funcs.h"
#include "support/lstrings.h"
#include "support/filetools.h" // for AddName, zippedFile
-#include "frontends/Alert.h"
-#include "BufferView.h"
using std::pair;
using std::make_pair;
{
// Set the parameters in the inset, it also returns true if the new
// parameters are different from what was in the inset already.
- bool changed = inset()->setParams(params());
+ bool changed = inset()->setParams(params(), lv_.buffer()->filePath());
// Tell LyX we've got a change, and mark the document dirty,
// if it changed.
lv_.view()->updateInset(inset(), changed);
// We need these in the file browser.
extern string system_lyxdir;
extern string user_lyxdir;
-
+
string const ControlGraphics::Browse(string const & in_name)
{
string const title = N_("Select graphics file");
- // FIXME: currently we need the second '|' to prevent mis-interpretation
+ // FIXME: currently we need the second '|' to prevent mis-interpretation
string const pattern = "*.(ps|eps|png|jpeg|jpg|gif|gz)|";
- // Does user clipart directory exist?
- string clipdir = AddName (user_lyxdir, "clipart");
- FileInfo fileInfo(clipdir);
- if (!(fileInfo.isOK() && fileInfo.isDir()))
- // No - bail out to system clipart directory
- clipdir = AddName (system_lyxdir, "clipart");
+ // Does user clipart directory exist?
+ string clipdir = AddName (user_lyxdir, "clipart");
+ FileInfo fileInfo(clipdir);
+ if (!(fileInfo.isOK() && fileInfo.isDir()))
+ // No - bail out to system clipart directory
+ clipdir = AddName (system_lyxdir, "clipart");
pair<string, string> dir1(N_("Clipart|#C#c"), clipdir);
pair<string, string> dir2(N_("Documents|#o#O"), string(lyxrc.document_path));
// Show the file browser dialog
- return browseFile(&lv_, in_name, title, pattern, dir1, dir2);
+ return browseRelFile(&lv_, in_name, lv_.buffer()->filePath(),
+ title, pattern, dir1, dir2);
}
-
+
string const ControlGraphics::readBB(string const & file)
{
-// in a file it's an entry like %%BoundingBox:23 45 321 345
-// the first number can following without a space, so we have
-// to check a bit more.
-// on the other hand some plot programs write the bb at the
-// end of the file. Than we have in the header a
-// %%BoundingBox: (atend)
-// In this case we must check until the end.
+ // in a file it's an entry like %%BoundingBox:23 45 321 345
+ // The first number can following without a space, so we have
+ // to be a little careful.
+ // On the other hand some plot programs write the bb at the
+ // end of the file. Than we have in the header:
+ // %%BoundingBox: (atend)
+ // In this case we must check the end.
string file_ = file;
if (zippedFile(file_))
file_ = unzipFile(file_);
+
+ string const format = getExtFromContents(file_);
+ if (format != "eps" && format != "ps")
+ return string();
+
std::ifstream is(file_.c_str());
- if (!contains(getExtFromContents(file_),"ps")) // bb exists?
- return string();
while (is) {
string s;
is >> s;
string a, b, c, d;
is >> a >> b >> c >> d;
if (is && !contains(a,"atend")) { // bb at the end?
- if (s != "%%BoundingBox:")
+ if (s != "%%BoundingBox:")
return (s.substr(14)+" "+a+" "+b+" "+c+" ");
else
return (a+" "+b+" "+c+" "+d+" ");
}
-void ControlGraphics::checkFilename(string const & fname) {
- if (!IsFileReadable(fname))
- Alert::alert(_("Warning!"),
- _("Filename") + ' '
- + fname + _(" does not exist!"));
-
+bool ControlGraphics::isFilenameValid(string const & fname) const
+{
+ // It may be that the filename is relative.
+ string const name = MakeAbsPath(fname, lv_.buffer()->filePath());
+ return IsFileReadable(name);
}