lyx_mirror/src/frontends/qt/FileDialog.h

88 lines
2.1 KiB
C
Raw Normal View History

// -*- C++ -*-
/**
* \file FileDialog.h
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author unknown
* \author John Levon
*
* Full author contact details are available in file CREDITS.
*/
#ifndef FILEDIALOG_H
#define FILEDIALOG_H
#include <QString>
#include <utility>
namespace lyx {
/**
* \class FileDialog
* \brief GUI-I definition of file dialog interface
*/
class FileDialog
{
/// noncopyable
FileDialog(FileDialog const &);
void operator=(FileDialog const &);
public:
/// label, directory path button
typedef std::pair<QString, QString> Button;
/// result type
enum ResultType {
Later, /**< modeless chooser, no result */
Chosen /**< string contains filename */
};
/// result return
typedef std::pair<FileDialog::ResultType, QString> Result;
/**
* Constructs a file dialog with title \param title.
*
* 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);
~FileDialog();
void setButton1(QString const & label, QString const & dir);
void setButton2(QString const & label, QString const & dir);
/// Choose a file for opening, starting in directory \c path.
Result open(QString const & path, QStringList const & filters,
QString const & suggested = QString());
/// Choose a directory, starting in directory \c path.
Result opendir(QString const & path = QString(),
QString const & suggested = QString());
/// Choose a file for saving, starting in directory \c path.
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;
Private * private_;
/// the dialog title
QString title_;
};
} // namespace lyx
#endif // FILEDIALOG_H