]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/controllers/ControlInclude.C
Add a buffer_path arg to InsetGraphicsMailer's params2string, string2params.
[lyx.git] / src / frontends / controllers / ControlInclude.C
index eef0c3d23a401fbd103d8bad349034ceb772d643..3f4af1cece46378c7054ae5d71fd93c57387e839 100644 (file)
 /**
  * \file ControlInclude.C
- * Copyright 2001 the LyX Team
- * Read the file COPYING
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
  *
  * \author Alejandro Aguilar Sierra
- * \author John Levon, moz@compsoc.man.ac.uk
- * \author Angus Leeming, a.leeming@.ac.uk
+ * \author John Levon
+ * \author Angus Leeming
+ *
+ * Full author contact details are available in file CREDITS
  */
 
 #include <config.h>
-#include <utility>
-
-#ifdef __GNUG__
-#pragma implementation
-#endif
 
 #include "ControlInclude.h"
-#include "buffer.h"
-#include "Dialogs.h"
-#include "LyXView.h"
-#include "gettext.h"
-
 #include "helper_funcs.h"
+
+#include "funcrequest.h"
+#include "gettext.h"
 #include "lyxrc.h"
 
+#include "support/filetools.h"
+
+#include <utility>
+
+using namespace lyx::support;
+
 using std::pair;
-using std::make_pair;
-using SigC::slot;
 
-ControlInclude::ControlInclude(LyXView & lv, Dialogs & d)
-       : ControlInset<InsetInclude, InsetInclude::Params>(lv, d)
+
+ControlInclude::ControlInclude(Dialog & parent)
+       : Dialog::Controller(parent)
+{}
+
+
+bool ControlInclude::initialiseParams(string const & data)
+{
+       InsetInclude::Params params;
+       InsetIncludeMailer::string2params(data, params);
+       inset_.reset(new InsetInclude(params));
+       return true;
+}
+
+
+void ControlInclude::clearParams()
 {
-       d_.showInclude.connect(slot(this, &ControlInclude::showInset));
+       inset_.reset();
 }
 
 
-void ControlInclude::applyParamsToInset()
+void ControlInclude::dispatchParams()
 {
-       inset()->set(params());
-       lv_.view()->updateInset(inset(), true);
+       InsetInclude::Params p = params();
+       string const lfun = InsetIncludeMailer::params2string(p);
+       kernel().dispatch(FuncRequest(LFUN_INSET_APPLY, lfun));
 }
 
 
+void ControlInclude::setParams(InsetInclude::Params const & params)
+{
+       inset_->set(params);
+}
+
 string const ControlInclude::Browse(string const & in_name, Type in_type)
 {
-       string const title = N_("Select document to include");
+       string const title = _("Select document to include");
 
-       string pattern;
-                  
        // input TeX, verbatim, or LyX file ?
+       string pattern;
        switch (in_type) {
        case INPUT:
-           pattern = _("*.tex| LaTeX Documents (*.tex)");
+           pattern = _("*.(tex|lyx)| LaTeX/LyX Documents (*.tex *.lyx)");
            break;
 
        case VERBATIM:
-           pattern = _("*| All files ");
+           pattern = _("*| All files (*)");
            break;
 
        case INCLUDE:
-           pattern = _("*.lyx| LyX Documents (*.lyx)");
+           pattern = _("*.(tex|lyx)| LaTeX/LyX Documents (*.tex *.lyx)");
            break;
        }
-       
-       pair<string, string> dir1(N_("Documents"), string(lyxrc.document_path));
 
-       return browseFile(&lv_, in_name, title, pattern, dir1,
-                         make_pair(string(), string()));
+       pair<string, string> dir1(N_("Documents|#o#O"),
+                                 string(lyxrc.document_path));
+
+       string const docpath = OnlyPath(params().masterFilename_);
+
+       return browseRelFile(in_name, docpath, title, pattern, false, dir1);
+}
+
+
+void ControlInclude::load(string const & file)
+{
+       kernel().dispatch(FuncRequest(LFUN_CHILDOPEN, file));
+}
+
+
+bool ControlInclude::fileExists(string const & file)
+{
+       string const fileWithAbsPath
+               = MakeAbsPath(file, OnlyPath(params().masterFilename_));
+
+       if (IsFileReadable(fileWithAbsPath))
+               return true;
+
+       return false;
 }