]> 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 b4290964fc76006419e0f27b98fe17152efa3959..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 "ViewBase.h"
-#include "ButtonControllerBase.h"
 #include "ControlGraphics.h"
-#include "ControlInset.tmpl"
 
 #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 <boost/bind.hpp>
+#include "support/package.h"
+#include "support/types.h"
 
-#include <fstream>
+#include <boost/filesystem/operations.hpp>
 
-using std::pair;
 using std::make_pair;
-using std::ifstream;
+using std::string;
+using std::pair;
 using std::vector;
 
-namespace {
-
-// FIXME: currently we need the second '|' to prevent mis-interpretation!
-// All supported graphic formats with their file-extension and the
-// gzip-ext for zipped (e)ps-files.
-// string const grfx_pattern =
-//     "*.(agr|bmp|eps|epsi|fits|gif|jpg|obj|pdf|pbm|pgm|png|"
-//     "ppm|ps|tif|tiff|xbm|xpm|xwd|gz)|";
-vector<string> const grfx_formats()
-{
-       vector<string> native_formats = grfx::GCache::get().loadableFormats();
-       // We can load any format that can be loaded natively together with
-       // those that can be converted to one of these native formats.
-       vector<string> browsable_formats = native_formats;
-
-       grfx::GConverter const & gconverter = grfx::GConverter::get();
-
-       vector<string>::const_iterator to_end = native_formats.end();
-
-       Formats::const_iterator from_it = formats.begin();
-       Formats::const_iterator from_end = formats.end();
-       for (; from_it != from_end; ++from_it) {
-               string const from = from_it->name();
-
-               vector<string>::const_iterator to_it = native_formats.begin();
-               for (; to_it != to_end; ++to_it) {
-                       if (gconverter.isReachable(from, *to_it)) {
-                               browsable_formats.push_back(from);
-                               break;
-                       }
-               }
-       }
-
-       browsable_formats.push_back("gz");
-
-       return browsable_formats;
-}
+namespace fs = boost::filesystem;
 
+namespace lyx {
 
-string const xforms_pattern()
-{
-       vector<string> const browsable_formats = grfx_formats();
-       string const answer =
-               "*.(" + getStringFromVector(browsable_formats, "|") +")|";
-       return answer;
-}
+using support::AddName;
+using support::FileFilterList;
+using support::IsFileReadable;
+using support::MakeAbsPath;
+using support::package;
+using support::readBB_from_PSFile;
 
-}
+namespace frontend {
 
 
-ControlGraphics::ControlGraphics(LyXView & lv, Dialogs & d)
-       : ControlInset<InsetGraphics, InsetGraphicsParams>(lv, d)
-{
-       d_.showGraphics = boost::bind(&ControlGraphics::showInset, this, _1);
-}
+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, ::xforms_pattern(), 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
-       grfx::GCache & gc = grfx::GCache::get();
-       return ("0 0 " +
-               tostr(gc.raw_width(abs_file)) + ' ' +
-               tostr(gc.raw_height(abs_file)));
+       int width = 0;
+       int height = 0;
+
+       graphics::Cache & gc = graphics::Cache::get();
+       if (gc.inCache(abs_file)) {
+               graphics::Image const * image = gc.item(abs_file)->image();
+
+               if (image) {
+                       width  = image->getWidth();
+                       height = image->getHeight();
+               }
+       }
+
+       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;
@@ -217,12 +189,13 @@ vector<RotationOriginPair> getRotationOriginData()
                return data;
 
        data.resize(rorigin_size);
-       for (lyx::size_type i = 0; i < rorigin_size; ++i) {
-               data[i] = std::make_pair(_(rorigin_gui_strs[i]),
-                                        rorigin_lyx_strs[i]);
+       for (size_type i = 0; i < rorigin_size; ++i) {
+               data[i] = make_pair(_(rorigin_gui_strs[i]),
+                                   rorigin_lyx_strs[i]);
        }
 
        return data;
 }
 
-} // namespace frnt
+} // namespace frontend
+} // namespace lyx