]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/controllers/ControlGraphics.C
fix crash due to invalidated iterator
[lyx.git] / src / frontends / controllers / ControlGraphics.C
index 6bc9979f828a30865d27092f1752b96c28d98901..f409c02b0e0d2a715eb656e2ec2583a29e882115 100644 (file)
-/* This file is part of
- * ======================================================
- *
- *           LyX, The Document Processor
- *
- *           Copyright 2001 The LyX Team.
+/**
+ * \file ControlGraphics.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
  *
- * ======================================================
+ * \author Angus Leeming
+ * \author Herbert Voß
  *
- * \file ControlGraphics.C
- * \author Angus Leeming <a.leeming@ic.ac.uk>
- * \author Herbert Voss <voss@perce.de>
+ * Full author contact details are available in file CREDITS.
  */
 
 #include <config.h>
 
-#ifdef __GNUG__
-#pragma implementation
-#endif
-
 #include "ControlGraphics.h"
 
 #include "helper_funcs.h"
 
-#include "converter.h"
-#include "buffer.h"
-#include "BufferView.h"
-#include "Dialogs.h"
-#include "frontends/LyXView.h"
+#include "funcrequest.h"
 #include "gettext.h"
 #include "lyxrc.h"
 
 #include "graphics/GraphicsCache.h"
-#include "graphics/GraphicsConverter.h"
+#include "graphics/GraphicsCacheItem.h"
 #include "graphics/GraphicsImage.h"
 
 #include "insets/insetgraphics.h"
-#include "insets/insetgraphicsParams.h"
 
-#include "support/lstrings.h"
+#include "support/convert.h"
+#include "support/filefilterlist.h"
 #include "support/filetools.h"
-#include "support/FileInfo.h"
+#include "support/package.h"
+#include "support/types.h"
+
+#include <boost/filesystem/operations.hpp>
 
-using std::pair;
 using std::make_pair;
+using std::string;
+using std::pair;
 using std::vector;
 
-ControlGraphics::ControlGraphics(LyXView & lv, Dialogs & d)
-       : ControlInset<InsetGraphics, InsetGraphicsParams>(lv, d)
+namespace fs = boost::filesystem;
+
+namespace lyx {
+
+using support::AddName;
+using support::FileFilterList;
+using support::IsFileReadable;
+using support::MakeAbsPath;
+using support::package;
+using support::readBB_from_PSFile;
+
+namespace frontend {
+
+
+ControlGraphics::ControlGraphics(Dialog & parent)
+       : Dialog::Controller(parent)
 {}
 
 
-InsetGraphicsParams const ControlGraphics::getParams(string const &)
+bool ControlGraphics::initialiseParams(string const & data)
 {
-       return InsetGraphicsParams();
+       InsetGraphicsParams params;
+       InsetGraphicsMailer::string2params(data, kernel().buffer(), params);
+       params_.reset(new InsetGraphicsParams(params));
+       return true;
 }
 
 
-InsetGraphicsParams const
-ControlGraphics::getParams(InsetGraphics const & inset)
+void ControlGraphics::clearParams()
 {
-       return inset.params();
+       params_.reset();
 }
 
 
-void ControlGraphics::applyParamsToInset()
+void ControlGraphics::dispatchParams()
 {
-       // 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(), lv_.buffer()->filePath());
-       // Tell LyX we've got a change, and mark the document dirty,
-       // if it changed.
-       lv_.view()->updateInset(inset(), changed);
+       InsetGraphicsParams tmp_params(params());
+       string const lfun =
+               InsetGraphicsMailer::params2string(tmp_params, kernel().buffer());
+       kernel().dispatch(FuncRequest(getLfun(), lfun));
 }
 
 
-void ControlGraphics::applyParamsNoInset()
-{}
-
-
-// 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 ControlGraphics::browse(string const & in_name) const
 {
        string const title = _("Select graphics file");
 
        // Does user clipart directory exist?
-       string clipdir = AddName (user_lyxdir, "clipart");
-       FileInfo fileInfo(clipdir);
-       if (!(fileInfo.isOK() && fileInfo.isDir()))
+       string clipdir = AddName (package().user_support(), "clipart");
+       if (!(fs::exists(clipdir) && fs::is_directory(clipdir)))
                // No - bail out to system clipart directory
-               clipdir = AddName (system_lyxdir, "clipart");
+               clipdir = AddName (package().system_support(), "clipart");
        pair<string, string> dir1(_("Clipart|#C#c"), clipdir);
        pair<string, string> dir2(_("Documents|#o#O"), string(lyxrc.document_path));
        // Show the file browser dialog
-       return browseRelFile(&lv_, in_name, lv_.buffer()->filePath(),
-                            title, "*.*", dir1, dir2);
+       return browseRelFile(in_name, kernel().bufferFilepath(),
+                            title,
+                            FileFilterList(),
+                            false, dir1, dir2);
 }
 
 
 string const ControlGraphics::readBB(string const & file)
 {
-       string const abs_file = MakeAbsPath(file, lv_.buffer()->filePath());
+       string const abs_file =
+               MakeAbsPath(file, kernel().bufferFilepath());
 
-       string const from = getExtFromContents(abs_file);
-       // Check if we have a Postscript file, then it's easy
-       if (contains(from, "ps"))
-               return readBB_from_PSFile(abs_file);
+       // try to get it from the file, if possible. Zipped files are
+       // unzipped in the readBB_from_PSFile-Function
+       string const bb = readBB_from_PSFile(abs_file);
+       if (!bb.empty())
+               return bb;
 
        // we don't, so ask the Graphics Cache if it has loaded the file
        int width = 0;
        int height = 0;
 
-       grfx::GCache & gc = grfx::GCache::get();
-       grfx::ImagePtr const image = gc.image(abs_file);
+       graphics::Cache & gc = graphics::Cache::get();
+       if (gc.inCache(abs_file)) {
+               graphics::Image const * image = gc.item(abs_file)->image();
 
-       if (image.get()) {
-               width  = image->getWidth();
-               height = image->getHeight();
+               if (image) {
+                       width  = image->getWidth();
+                       height = image->getHeight();
+               }
        }
 
-       return ("0 0 " + tostr(width) + ' ' + tostr(height));
+       return ("0 0 " + convert<string>(width) + ' ' + convert<string>(height));
 }
 
 
 bool ControlGraphics::isFilenameValid(string const & fname) const
 {
        // It may be that the filename is relative.
-       string const name = MakeAbsPath(fname, lv_.buffer()->filePath());
+       string const name = MakeAbsPath(fname, kernel().bufferFilepath());
        return IsFileReadable(name);
 }
 
 
-namespace frnt {
+void ControlGraphics::editGraphics()
+{
+       BOOST_ASSERT(params_.get());
+
+       dialog().view().apply();
+       string const lfun =
+               InsetGraphicsMailer::params2string(params(), kernel().buffer());
+       kernel().dispatch(FuncRequest(LFUN_GRAPHICS_EDIT, lfun));
+}
+
 
 namespace {
 
+char const * const bb_units[] = { "bp", "cm", "mm", "in" };
+size_t const bb_size = sizeof(bb_units) / sizeof(char *);
+
 // These are the strings that are stored in the LyX file and which
 // correspond to the LaTeX identifiers shown in the comments at the
 // end of each line.
 char const * const rorigin_lyx_strs[] = {
-       "center",                                        // c
-       "leftTop",   "leftBottom",   "leftBaseline",     // lt lb lB
-       "centerTop", "centerBottom", "centerBaseline",   // ct cb cB
-       "rightTop",  "rightBottom",  "rightBaseline" };  // rt rb rB
+       // the LaTeX default is leftBaseline
+       "",
+       "leftTop",  "leftBottom", "leftBaseline", // lt lb lB
+       "center", "centerTop", "centerBottom", "centerBaseline", // c ct cb cB
+       "rightTop", "rightBottom", "rightBaseline" }; // rt rb rB
 
 // These are the strings, corresponding to the above, that the GUI should
 // use. Note that they can/should be translated.
 char const * const rorigin_gui_strs[] = {
-       N_("center"),
-       N_("left top"),   N_("left bottom"),   N_("left baseline"),
-       N_("center top"), N_("center bottom"), N_("center baseline"),
-       N_("right top"),  N_("right bottom"),  N_("right baseline") };
+       N_("Default"),
+       N_("Top left"), N_("Bottom left"), N_("Baseline left"),
+       N_("Center"), N_("Top center"), N_("Bottom center"), N_("Baseline center"),
+       N_("Top right"), N_("Bottom right"), N_("Baseline right") };
 
 size_t const rorigin_size = sizeof(rorigin_lyx_strs) / sizeof(char *);
 
 } // namespace anon
 
 
+vector<string> const getBBUnits()
+{
+       return vector<string> (bb_units, bb_units + bb_size);
+}
+
+
 vector<RotationOriginPair> getRotationOriginData()
 {
        static vector<RotationOriginPair> data;
@@ -167,7 +189,7 @@ vector<RotationOriginPair> getRotationOriginData()
                return data;
 
        data.resize(rorigin_size);
-       for (lyx::size_type i = 0; i < rorigin_size; ++i) {
+       for (size_type i = 0; i < rorigin_size; ++i) {
                data[i] = make_pair(_(rorigin_gui_strs[i]),
                                    rorigin_lyx_strs[i]);
        }
@@ -175,4 +197,5 @@ vector<RotationOriginPair> getRotationOriginData()
        return data;
 }
 
-} // namespace frnt
+} // namespace frontend
+} // namespace lyx