• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdepim API Reference
  • KDE Home
  • Contact Us
 

kalarm/lib

  • sources
  • kde-4.14
  • kdepim
  • kalarm
  • lib
filedialog.cpp
Go to the documentation of this file.
1 /*
2  * filedialog.cpp - file save dialogue, with append option & confirm overwrite
3  * Program: kalarm
4  * Copyright © 2009 by David Jarvie <djarvie@kde.org>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License along
17  * with this program; if not, write to the Free Software Foundation, Inc.,
18  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19  */
20 
21 #include "kalarm.h" //krazy:exclude=includes (kalarm.h must be first)
22 #include "filedialog.h"
23 #include "autoqpointer.h"
24 
25 #include <kabstractfilewidget.h>
26 #include <klocale.h>
27 #include <krecentdocument.h>
28 #include <kdebug.h>
29 
30 #include <QCheckBox>
31 
32 
33 QCheckBox* FileDialog::mAppendCheck = 0;
34 
35 
36 QString FileDialog::getSaveFileName(const KUrl& dir, const QString& filter, QWidget* parent, const QString& caption, bool* append)
37 {
38  bool defaultDir = dir.isEmpty();
39  bool specialDir = !defaultDir && dir.protocol() == QLatin1String("kfiledialog");
40  // Use AutoQPointer to guard against crash on application exit while
41  // the dialogue is still open. It prevents double deletion (both on
42  // deletion of parent, and on return from this function).
43  AutoQPointer<FileDialog> dlg = new FileDialog(specialDir ? dir : KUrl(), filter, parent);
44  if (!specialDir && !defaultDir)
45  {
46  if (!dir.isLocalFile())
47  kWarning() << "FileDialog::getSaveFileName called with non-local start dir " << dir;
48  dlg->setSelection(dir.isLocalFile() ? dir.toLocalFile() : dir.path()); // may also be a filename
49  }
50  dlg->setOperationMode(Saving);
51  dlg->setMode(KFile::File | KFile::LocalOnly);
52  dlg->setConfirmOverwrite(true);
53  if (!caption.isEmpty())
54  dlg->setCaption(caption);
55  mAppendCheck = 0;
56  if (append)
57  {
58  // Show an 'append' option in the dialogue.
59  // Note that the dialogue will take ownership of the QCheckBox.
60  mAppendCheck = new QCheckBox(i18nc("@option:check", "Append to existing file"), 0);
61  connect(mAppendCheck, SIGNAL(toggled(bool)), dlg, SLOT(appendToggled(bool)));
62  dlg->fileWidget()->setCustomWidget(mAppendCheck);
63  *append = false;
64  }
65  dlg->setWindowModality(Qt::WindowModal);
66  dlg->exec();
67  if (!dlg)
68  return QString(); // dialogue was deleted
69 
70  QString filename = dlg->selectedFile();
71  if (!filename.isEmpty())
72  {
73  if (append)
74  *append = mAppendCheck->isChecked();
75  KRecentDocument::add(filename);
76  }
77  return filename;
78 }
79 
80 void FileDialog::appendToggled(bool ticked)
81 {
82  setConfirmOverwrite(!ticked);
83 }
84 #include "moc_filedialog.cpp"
85 // vim: et sw=4:
QWidget
FileDialog::getSaveFileName
static QString getSaveFileName(const KUrl &dir=KUrl(), const QString &filter=QString(), QWidget *parent=0, const QString &caption=QString(), bool *append=0)
Definition: filedialog.cpp:36
autoqpointer.h
QCheckBox
QString::isEmpty
bool isEmpty() const
QString
AutoQPointer
A QPointer which when destructed, deletes the object it points to.
Definition: autoqpointer.h:33
QAbstractButton::isChecked
bool isChecked() const
QLatin1String
FileDialog::FileDialog
FileDialog(const KUrl &startDir, const QString &filter, QWidget *parent, QWidget *widget=0)
Definition: filedialog.h:32
filedialog.h
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:35:02 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

kalarm/lib

Skip menu "kalarm/lib"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members

kdepim API Reference

Skip menu "kdepim API Reference"
  • akonadi_next
  • akregator
  • blogilo
  • calendarsupport
  • console
  •   kabcclient
  •   konsolekalendar
  • kaddressbook
  • kalarm
  •   lib
  • kdgantt2
  • kjots
  • kleopatra
  • kmail
  • knode
  • knotes
  • kontact
  • korgac
  • korganizer
  • ktimetracker
  • libkdepim
  • libkleo
  • libkpgp
  • mailcommon
  • messagelist
  • messageviewer
  • pimprint

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal