class KFileDialog

A file selection dialog. More...

Definition#include <kfiledialog.h>
InheritsKDialogBase (kdeui) [public ]
List of all Methods
Annotated List
Files
Globals
Hierarchy
Index

Public Methods

Signals

Public Static Methods

Protected Methods

Protected Slots

Protected Members


Detailed Description

Provide a user (and developer) friendly way to select files and directories.

The widget can be used as a drop in replacement for the QFileDialog widget, but has greater functionality and a nicer GUI.

You will usually want to use one of the static methods getOpenFileName(), getSaveFileName(), getOpenURL() or for multiple files getOpenFileNames() or getOpenURLs().

The dialog has been designed to allow applications to customise it by subclassing. It uses geometry management to ensure that subclasses can easily add children that will be incorporated into the layout.

 KFileDialog (const QString& urlName, const QString& filter, QWidget *parent, const char *name, bool modal)

KFileDialog

Construct a file dialog.

Parameters:
urlNameThe URL of the directory to start in. Use QString::null to start in the current working directory, or the last directory where a file has been selected.
filterA shell glob that specifies which files to display. See setFilter() for details on how to use this argument.
acceptURLsIf set to false, KFileDialog will just accept files on the local filesystem.

 ~KFileDialog ()

~KFileDialog

Destruct the file dialog.

KURL  selectedURL ()

selectedURL

[const]

Returns: The selected fully qualified filename.

KURL::List  selectedURLs ()

selectedURLs

[const]

Returns: The list of selected URLs.

KURL  baseURL ()

baseURL

[const]

Returns: the currently shown directory.

QString  selectedFile ()

selectedFile

[const]

Retrieve the full path of the selected file in the local filesystem. (Local files only)

QStringList  selectedFiles ()

selectedFiles

[const]

Retrieve a list of all selected local files.

void  setURL (const KURL &url, bool clearforward = true)

setURL

Set the directory to view.

Parameters:
urlURL to show.
clearforwardIndicates whether the forward queue should be cleared.

void  setSelection (const QString& name)

setSelection

Set the file name to preselect to name

This takes absolute URLs and relative file names.

void  setKeepLocation ( bool keep )

setKeepLocation

Sets whether the filename/url should be kept when changing directories. This is for example useful when having a predefined filename where the full path for that file is searched.

getSaveFileName() and getSaveURL() set this to true by default, so that you can type in the filename and change the directory without having to type the name again.

bool  keepsLocation ()

keepsLocation

[const]

Returns: whether the contents of the location edit are kept when changing directories.

void  setFilter (const QString& filter)

setFilter

Set the filter to be used to filter.

You can set more filters for the user to select seperated by '\n'. Every filter entry is defined through namefilter|text to diplay. If no | is found in the expression, just the namefilter is shown. Examples:


 kfile->setFilter("*.cpp|C++ Source Files\n*.h|Header files");
 kfile->setFilter("*.cpp");
 kfile->setFilter("*.cpp|Sources (*.cpp)");
 kfile->setFilter("*.cpp *.cc *.C|C++ Source Files\n*.h *.H|Header files");

Note: The text to display is not parsed in any way. So, if you want to show the suffix to select by a specific filter, you must repeat it.

See also: filterChanged()

QString  currentFilter ()

currentFilter

[const]

Retrieve the current filter as entered by the user or one of the predefined set via setFilter().

Parameters:
filterContains the new filter (only the extension part, not the explanation), for example, "*.cpp" or "*.cpp *.cc".

See also: setFilter(), filterChanged()

void  setFilterMimeType (const QString &label, const KMimeType::List &types, const KMimeType::Ptr &defaultType)

setFilterMimeType

Set the filter up to specify the output type.

Do not use in conjunction with setFilter()

Parameters:
labelthe label to use instead of "Filter:"
typesa list of mimetypes that can be used as output format
defaultTypethe default mimetype to use as output format.

KMimeType::Ptr  currentFilterMimeType ()

currentFilterMimeType

The mimetype for the desired output format.

This is only valid if setFilterMimeType() has been called previously.

See also: setFilterMimeType()

void  setPreviewWidget (const QWidget *w)

setPreviewWidget

Add a preview widget and enter the preview mode.

In this mode the dialog is split and the right part contains your widget. This widget has to inherit QWidget and it has to implement a slot showPreview(const KURL &); which is called every time the file changes. You may want to look at koffice/lib/kofficecore/koFilterManager.cc for some hints :)

QString  getOpenFileName (const QString& dir= QString::null, const QString& filter= QString::null, QWidget *parent= 0, const QString& caption = QString::null)

getOpenFileName

[static]

Create a modal file dialog and return the selected filename or an empty string if none was chosen.

Note that with this method the user must select an existing filename.

Parameters:
dirThis specifies the path the dialog will start in.
filterThis is a space seperated list of shell globs.
parentThe widget the dialog will be centered on initially.
captionThe name of the dialog widget.

QStringList  getOpenFileNames (const QString& dir= QString::null, const QString& filter= QString::null, QWidget *parent = 0, const QString& caption= QString::null)

getOpenFileNames

[static]

Create a modal file dialog and return the selected filenames or an empty list if none was chosen.

Note that with this method the user must select an existing filename.

Parameters:
dirThis specifies the path the dialog will start in.
filterThis is a space seperated list of shell globs.
parentThe widget the dialog will be centered on initially.
captionThe name of the dialog widget.

KURL  getOpenURL (const QString& url = QString::null, const QString& filter= QString::null, QWidget *parent= 0, const QString& caption = QString::null)

getOpenURL

[static]

Create a modal file dialog and return the selected URL or an empty string if none was chosen.

Note that with this method the user must select an existing URL.

Parameters:
urlThis specifies the path the dialog will start in.
filterThis is a space seperated list of shell globs.
parentThe widget the dialog will be centered on initially.
captionThe name of the dialog widget.

KURL::List  getOpenURLs (const QString& url= QString::null, const QString& filter= QString::null, QWidget *parent = 0, const QString& caption= QString::null)

getOpenURLs

[static]

Create a modal file dialog and return the selected URLs or an empty list if none was chosen.

Note that with this method the user must select an existing filename.

Parameters:
urlThis specifies the path the dialog will start in.
filterThis is a space seperated list of shell globs.
parentThe widget the dialog will be centered on initially.
captionThe name of the dialog widget.

QString  getSaveFileName (const QString& dir= QString::null, const QString& filter= QString::null, QWidget *parent= 0, const QString& caption = QString::null)

getSaveFileName

[static]

Create a modal file dialog and return the selected filename or an empty string if none was chosen.

Note that with this method the user need not select an existing filename.

Parameters:
dirThis specifies the path the dialog will start in.
filterThis is a space seperated list of shell globs.
parentThe widget the dialog will be centered on initially.
captionThe name of the dialog widget.

KURL  getSaveURL (const QString& url= QString::null, const QString& filter= QString::null, QWidget *parent= 0, const QString& caption = QString::null)

getSaveURL

[static]

Create a modal file dialog and returns the selected filename or an empty string if none was chosen.

Note that with this method the user need not select an existing filename.

Parameters:
urlThis specifies the path the dialog will start in.
filterThis is a space seperated list of shell globs.
parentThe widget the dialog will be centered on initially.
captionThe name of the dialog widget.

QString  getExistingDirectory (const QString & url = QString::null, QWidget * parent = 0, const QString& caption= QString::null)

getExistingDirectory

[static]

Create a modal file dialog and returns the selected directory or an empty string if none was chosen.

Note that with this method the user need not select an existing directory.

Parameters:
urlThe directory the dialog will start in.
parentThe widget the dialog will be centered on initially.
captionThe name of the dialog widget.

void  show ()

show

[virtual]

void  setMode ( KFile::Mode m )

setMode

Set the mode of the dialog.

The mode is defined as (in kfile.h):

    enum Mode {
                      File         = 1,
                      Directory    = 2,
                      Files        = 4,
                      ExistingOnly = 8,
                      LocalOnly    = 16
                    };

You can OR the values, e.g.


 KFile::Mode mode = static_cast<KFile::Mode>( KFile::Files |
                                              KFile::ExistingOnly |
                                              KFile::LocalOnly );
 setMode( mode );

You need an explicit cast, which looks a little ugly, but is unavoidable without using (even uglier) #defines.

KFile::Mode  mode ()

mode

[const]

Retrieve the mode of the filedialog.

See also: setMode()

void  setLocationLabel (const QString& text)

setLocationLabel

Set the text to be displayed in front of the selection.

The default is "Location". Most useful if you want to make clear what the location is used for.

KToolBartoolBar ()

toolBar

[const]

Retrieve a pointer to the toolbar.

You can use this to insert custom items into it, e.g.:


      yourAction = new KAction( i18n("Your Action"), 0,
                                this, SLOT( yourSlot() ),
                                this, "action name" );
      yourAction->plug( kfileDialog->toolBar() );

QPushButtonokButton ()

okButton

[const]

Returns: a pointer to the OK-Button in the filedialog. You may use it e.g. to set a custom text to it.

QPushButtoncancelButton ()

cancelButton

[const]

Returns: a pointer to the Cancel-Button in the filedialog. You may use it e.g. to set a custom text to it.

void  fileSelected (const QString&)

fileSelected

[signal]

Emitted when the user selects a file. It is only emitted in single- selection mode. The best way to get notified about selected file(s) is to connect to the okClicked() signal inherited from KDialogBase and call selectedFile(), selectedFiles(), selectedURL() or selectedURLs().

void  fileHighlighted (const QString&)

fileHighlighted

[signal]

Emitted when the user highlights a file.

void  selectionChanged ()

selectionChanged

[signal]

Emitted when the user hilights one or more files in multiselection mode.

Note: fileHighlighted() or fileSelected() are not emitted in multiselection mode. You may use selectedItems() to ask for the current highlighted items.

See also: fileSelected

void  filterChanged ( const QString& filter )

filterChanged

[signal]

Emitted when the filter changed, i.e. the user entered an own filter or chose one of the predefined set via setFilter().

Parameters:
filtercontains the new filter (only the extension part, not the explanation), i.e. "*.cpp" or "*.cpp *.cc".

See also: setFilter(), currentFilter()

KToolBar * toolbar

toolbar

[protected: ]

static KURL * lastDirectory

lastDirectory

[protected: ]

QPopupMenu * bookmarksMenu

bookmarksMenu

[protected: ]

KURLComboBox * locationEdit

locationEdit

[protected: ]

KFileFilter * filterWidget

filterWidget

[protected: ]

KFileBookmarkManager * bookmarks

bookmarks

[protected: ]

QStringList history

history

[protected: ]

void  addDirEntry (KFileViewItem *entry, bool disableUpdating)

addDirEntry

[protected: ]

adds a entry of the current directory. If disableUpdating is set to true, it will care about clever updating

void  initGUI ()

initGUI

[protected: virtual]

rebuild geometry managment.

void  multiSelectionChanged ()

multiSelectionChanged

[protected: ]

called when an item is highlighted/selected in multiselection mode. handles setting the locationEdit.

void  readConfig ( KConfig *, const QString& group = QString::null )

readConfig

[protected: virtual]

Reads configuration and applies it (size, recent directories, ...)

void  saveConfig ( KConfig *, const QString& group = QString::null )

saveConfig

[protected: virtual]

Saves the current configuration

void  readRecentFiles ( KConfig * )

readRecentFiles

[protected: virtual]

Reads the recent used files and inserts them into the location combobox

void  saveRecentFiles ( KConfig * )

saveRecentFiles

[protected: virtual]

Saves the entries from the location combobox.

KURL::List  tokenize (const QString& line)

tokenize

[protected: const]

Parses the string "line" for files. If line doesn't contain any ", the whole line will be interpreted as one file. If the number of " is odd, an empty list will be returned. Otherwise, all items enclosed in " " will be returned as correct urls.

void  urlEntered ( const KURL& )

urlEntered

[protected slots: slot]

void  pathComboActivated ( const KURL& url )

pathComboActivated

[protected slots: slot]

void  pathComboReturnPressed ( const QString& url )

pathComboReturnPressed

[protected slots: slot]

void  locationActivated ( const QString& url )

locationActivated

[protected slots: slot]

void  toolbarCallback (int)

toolbarCallback

[protected slots: slot]

void  toolbarPressedCallback (int)

toolbarPressedCallback

[protected slots: slot]

void  slotFilterChanged ()

slotFilterChanged

[protected slots: slot]

void  pathComboChanged ( const QString& )

pathComboChanged

[protected slots: slot]

void  fileHighlighted (const KFileViewItem *i)

fileHighlighted

[protected slots: slot]

void  fileSelected (const KFileViewItem *i)

fileSelected

[protected slots: slot]

void  slotStatResult (KIO::Job* job)

slotStatResult

[protected slots: slot]

void  slotLoadingFinished ()

slotLoadingFinished

[protected slots: slot]

void  dirCompletion ( const QString& )

dirCompletion

[protected slots: slot]

void  fileCompletion ( const QString& )

fileCompletion

[protected slots: slot]

void  updateStatusLine (int dirs, int files)

updateStatusLine

[protected slots: virtual slot]

void  slotOk ()

slotOk

[protected slots: virtual slot]

Reimplemented from KDialogBase.

void  accept ()

accept

[protected slots: virtual slot]

void  slotCancel ()

slotCancel

[protected slots: virtual slot]

Reimplemented from KDialogBase.

void  addToBookmarks ()

addToBookmarks

[protected slots: slot]

Add the current location to the global bookmarks list

void  bookmarksChanged ()

bookmarksChanged

[protected slots: slot]

void  fillBookmarkMenu ( KFileBookmark *parent, QPopupMenu *menu, int &id )

fillBookmarkMenu

[protected slots: slot]

KFileDialogPrivate * d

d

[protected: ]

KDirOperator * ops

ops

[protected: ]

bool autoDirectoryFollowing

autoDirectoryFollowing

[protected: ]

KURL::List&  parseSelectedURLs ()

parseSelectedURLs

[protected: const]