#ifndef FILEDIALOG_H
#define FILEDIALOG_H
-#include "lfuns.h"
-
#include <QString>
#include <utility>
namespace lyx {
-namespace support { class FileFilterList; }
-
-
/**
* \class FileDialog
* \brief GUI-I definition of file dialog interface
/**
* Constructs a file dialog with title \param title.
- * If \param a is \const LFUN_SELECT_FILE_SYNC then a value
- * will be returned immediately upon performing a open(),
- * otherwise a callback Dispatch() will be invoked with the filename as
- * argument, of action \param a.
*
* Up to two optional extra buttons are allowed for specifying
* additional directories in the navigation (an empty
* directory is interpreted as FileName::getcwd())
*/
- FileDialog(QString const & title, kb_action a = LFUN_SELECT_FILE_SYNC);
+ FileDialog(QString const & title);
~FileDialog();
void setButton2(QString const & label, QString const & dir);
/// Choose a file for opening, starting in directory \c path.
- Result open(QString const & path,
- support::FileFilterList const & filters,
+ Result open(QString const & path, QStringList const & filters,
QString const & suggested = QString());
/// Choose a directory, starting in directory \c path.
QString const & suggested = QString());
/// Choose a file for saving, starting in directory \c path.
- Result save(QString const & path,
- support::FileFilterList const & filters,
+ Result save(QString const & path, QStringList const & filters,
QString const & suggested = QString());
+ /// Also retrieve the selected filter (selectedFilter can be 0 if
+ /// that output is not needed).
+ Result save(QString const & path, QStringList const & filters,
+ QString const & suggested, QString *selectedFilter);
+
private:
class Private;
friend class Private;
/// the dialog title
QString title_;
- /// success action to perform if not synchronous
- kb_action success_;
};
} // namespace lyx