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

KCalUtils Library

  • sources
  • kde-4.14
  • kdepimlibs
  • kcalutils
vcaldrag.cpp
1 /*
2  This file is part of the kcalutils library.
3 
4  Copyright (c) 1998 Preston Brown <pbrown@kde.org>
5  Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org>
6 
7  This library is free software; you can redistribute it and/or
8  modify it under the terms of the GNU Library General Public
9  License as published by the Free Software Foundation; either
10  version 2 of the License, or (at your option) any later version.
11 
12  This library is distributed in the hope that it will be useful,
13  but WITHOUT ANY WARRANTY; without even the implied warranty of
14  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  Library General Public License for more details.
16 
17  You should have received a copy of the GNU Library General Public License
18  along with this library; see the file COPYING.LIB. If not, write to
19  the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20  Boston, MA 02110-1301, USA.
21 */
22 #include "vcaldrag.h"
23 
24 #include <kcalcore/vcalformat.h>
25 using namespace KCalCore;
26 
27 #include <QtCore/QMimeData>
28 #include <QtCore/QString>
29 
30 using namespace KCalUtils;
31 using namespace VCalDrag;
32 
33 QString VCalDrag::mimeType()
34 {
35  return QLatin1String("text/x-vCalendar");
36 }
37 
38 bool VCalDrag::populateMimeData(QMimeData *e,
39  const MemoryCalendar::Ptr &cal)
40 {
41  VCalFormat format;
42  QString calstr(format.toString(cal));
43  if (calstr.length() > 0) {
44  e->setData(mimeType(), calstr.toUtf8());
45  }
46  return canDecode(e);
47 }
48 
49 bool VCalDrag::canDecode(const QMimeData *me)
50 {
51  return me->hasFormat(mimeType());
52 }
53 
54 bool VCalDrag::fromMimeData(const QMimeData *de,
55  const MemoryCalendar::Ptr &cal)
56 {
57  if (!canDecode(de)) {
58  return false;
59  }
60 
61  bool success = false;
62  QByteArray payload = de->data(mimeType());
63  if (payload.size()) {
64  QString txt = QString::fromUtf8(payload.data());
65 
66  VCalFormat format;
67  success = format.fromString(cal, txt);
68  }
69 
70  return success;
71 }
QMimeData::data
QByteArray data(const QString &mimeType) const
QByteArray
QMimeData::hasFormat
virtual bool hasFormat(const QString &mimeType) const
KCalCore::VCalFormat::toString
QString toString(const Calendar::Ptr &calendar, const QString &notebook=QString(), bool deleted=false)
QMimeData
QString::fromUtf8
QString fromUtf8(const char *str, int size)
QSharedPointer
QString
QLatin1String
QByteArray::data
char * data()
vcalformat.h
QMimeData::setData
void setData(const QString &mimeType, const QByteArray &data)
KCalCore::VCalFormat
QByteArray::size
int size() const
KCalCore::VCalFormat::fromString
bool fromString(const Calendar::Ptr &calendar, const QString &string, bool deleted=false, const QString &notebook=QString())
QString::toUtf8
QByteArray toUtf8() const
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:37:46 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

KCalUtils Library

Skip menu "KCalUtils Library"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Members
  • File List
  • Related Pages

kdepimlibs API Reference

Skip menu "kdepimlibs API Reference"
  • akonadi
  •   contact
  •   kmime
  •   socialutils
  • kabc
  • kalarmcal
  • kblog
  • kcal
  • kcalcore
  • kcalutils
  • kholidays
  • kimap
  • kioslave
  •   imap4
  •   mbox
  •   nntp
  • kldap
  • kmbox
  • kmime
  • kontactinterface
  • kpimidentities
  • kpimtextedit
  • kpimutils
  • kresources
  • ktnef
  • kxmlrpcclient
  • mailtransport
  • microblog
  • qgpgme
  • syndication
  •   atom
  •   rdf
  •   rss2

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