* \author John Levon
* \author Angus Leeming
*
- * Full author contact details are available in file CREDITS
+ * Full author contact details are available in file CREDITS.
*/
#include <config.h>
-
#include "ControlInclude.h"
-
#include "helper_funcs.h"
+#include "Kernel.h"
-#include "BufferView.h"
+#include "buffer.h"
+#include "format.h"
#include "funcrequest.h"
#include "gettext.h"
-#include "lyxfunc.h"
#include "lyxrc.h"
-#include "frontends/Alert.h"
+#include "insets/insetinclude.h"
+#include "support/filefilterlist.h"
#include "support/filetools.h"
#include <utility>
using std::pair;
+using std::string;
+
+namespace lyx {
+using support::FileFilterList;
+using support::IsFileReadable;
+using support::MakeAbsPath;
+using support::OnlyPath;
-ControlInclude::ControlInclude(LyXView & lv, Dialogs & d)
- : ControlInset<InsetInclude, InsetInclude::Params>(lv, d)
+namespace frontend {
+
+ControlInclude::ControlInclude(Dialog & parent)
+ : Dialog::Controller(parent)
{}
-void ControlInclude::applyParamsToInset()
+bool ControlInclude::initialiseParams(string const & data)
+{
+ InsetIncludeMailer::string2params(data, params_);
+ return true;
+}
+
+
+void ControlInclude::clearParams()
+{
+ params_ = InsetCommandParams();
+}
+
+
+void ControlInclude::dispatchParams()
+{
+ string const lfun = InsetIncludeMailer::params2string(params_);
+ kernel().dispatch(FuncRequest(getLfun(), lfun));
+}
+
+
+void ControlInclude::setParams(InsetCommandParams const & params)
{
- inset()->set(params());
- bufferview()->updateInset(inset(), true);
+ params_ = params;
}
-string const ControlInclude::Browse(string const & in_name, Type in_type)
+string const ControlInclude::browse(string const & in_name, Type in_type) const
{
string const title = _("Select document to include");
// input TeX, verbatim, or LyX file ?
- string pattern;
+ FileFilterList filters;
switch (in_type) {
+ case INCLUDE:
case INPUT:
- pattern = _("*.(tex|lyx)| LaTeX/LyX Documents (*.tex *.lyx)");
+ filters = FileFilterList(_("LaTeX/LyX Documents (*.tex *.lyx)"));
break;
-
case VERBATIM:
- pattern = _("*| All files (*)");
- break;
-
- case INCLUDE:
- pattern = _("*.(tex|lyx)| LaTeX/LyX Documents (*.tex *.lyx)");
break;
}
pair<string, string> dir1(N_("Documents|#o#O"),
string(lyxrc.document_path));
- string const docpath = OnlyPath(params().masterFilename_);
+ string const docpath = OnlyPath(kernel().buffer().fileName());
- return browseRelFile(&lv_, in_name, docpath, title, pattern, false, dir1);
+ return browseRelFile(in_name, docpath, title,
+ filters, false, dir1);
}
void ControlInclude::load(string const & file)
{
- lyxfunc().dispatch(FuncRequest(LFUN_CHILDOPEN, file));
+ string const ext = support::GetExtension(file);
+ if (ext == "lyx")
+ kernel().dispatch(FuncRequest(LFUN_CHILDOPEN, file));
+ else
+ // tex file or other text file in verbatim mode
+ formats.edit(kernel().buffer(), file, "text");
}
bool ControlInclude::fileExists(string const & file)
{
string const fileWithAbsPath
- = MakeAbsPath(file, OnlyPath(params().masterFilename_));
+ = MakeAbsPath(file,
+ OnlyPath(kernel().buffer().fileName()));
if (IsFileReadable(fileWithAbsPath))
return true;
return false;
}
+
+} // namespace frontend
+} // namespace lyx