* Licence details can be found in the file COPYING.
*
* \author Angus Leeming
- * \author Herbert Voss
+ * \author Herbert Voß
*
- * Full author contact details are available in file CREDITS
+ * 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 "buffer.h"
-#include "BufferView.h"
-#include "converter.h"
+#include "funcrequest.h"
#include "gettext.h"
#include "lyxrc.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;
-// We need these in the file browser.
-extern string system_lyxdir;
-extern string user_lyxdir;
+namespace fs = boost::filesystem;
+namespace lyx {
-ControlGraphics::ControlGraphics(LyXView & lv, Dialogs & d)
- : ControlInset<InsetGraphics, InsetGraphicsParams>(lv, d)
+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(), buffer()->filePath());
-
- // Tell LyX we've got a change, and mark the document dirty,
- // if it changed.
- bufferview()->updateInset(inset(), changed);
+ InsetGraphicsParams tmp_params(params());
+ string const lfun =
+ InsetGraphicsMailer::params2string(tmp_params, kernel().buffer());
+ kernel().dispatch(FuncRequest(getLfun(), lfun));
}
-void ControlGraphics::applyParamsNoInset()
-{}
-
-
-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, 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, buffer()->filePath());
+ string const abs_file =
+ MakeAbsPath(file, kernel().bufferFilepath());
// try to get it from the file, if possible. Zipped files are
// unzipped in the readBB_from_PSFile-Function
int width = 0;
int height = 0;
- grfx::Cache & gc = grfx::Cache::get();
+ graphics::Cache & gc = graphics::Cache::get();
if (gc.inCache(abs_file)) {
- grfx::Image const * image = gc.item(abs_file)->image();
+ graphics::Image const * image = gc.item(abs_file)->image();
if (image) {
width = image->getWidth();
}
}
- 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, buffer()->filePath());
+ string const name = MakeAbsPath(fname, kernel().bufferFilepath());
return IsFileReadable(name);
}
-namespace {
-
-static char const * bb_units[] = { "bp", "cm", "mm", "in"};
-size_t const bb_size = sizeof(bb_units) / sizeof(char *);
-
-}
-
-
-vector<string> const ControlGraphics::getUnits()
+void ControlGraphics::editGraphics()
{
- static vector<string> data;
- if (!data.empty())
- return data;
+ BOOST_ASSERT(params_.get());
- data.resize(bb_size);
- for (lyx::size_type i = 0; i < bb_size; ++i) {
- data[i] = bb_units[i];
- }
- return data;
+ dialog().view().apply();
+ string const lfun =
+ InsetGraphicsMailer::params2string(params(), kernel().buffer());
+ kernel().dispatch(FuncRequest(LFUN_GRAPHICS_EDIT, lfun));
}
-namespace frnt {
-
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[] = {
// 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_("Top left"), N_("Bottom left"), N_("Left baseline"),
- N_("Center"), N_("Top center"), N_("Bottom center"), N_("Center baseline"),
- N_("Top right"), N_("Bottom right"), 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;
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]);
}
return data;
}
-} // namespace frnt
+} // namespace frontend
+} // namespace lyx