/**************************************************************************** ** ** Copyright (C) 1992-2007 Trolltech ASA. All rights reserved. ** ** This file is part of the QtGui module of the Qt Toolkit. ** ** This file may be used under the terms of the GNU General Public ** License version 2.0 as published by the Free Software Foundation ** and appearing in the file LICENSE.GPL included in the packaging of ** this file. Please review the following information to ensure GNU ** General Public Licensing requirements will be met: ** http://trolltech.com/products/qt/licenses/licensing/opensource/ ** ** If you are unsure which license is appropriate for your use, please ** review the following information: ** http://trolltech.com/products/qt/licenses/licensing/licensingoverview ** or contact the sales department at sales@trolltech.com. ** ** In addition, as a special exception, Trolltech gives you certain ** additional rights. These rights are described in the Trolltech GPL ** Exception version 1.0, which can be found at ** http://www.trolltech.com/products/qt/gplexception/ and in the file ** GPL_EXCEPTION.txt in this package. ** ** In addition, as a special exception, Trolltech, as the sole copyright ** holder for Qt Designer, grants users of the Qt/Eclipse Integration ** plug-in the right for the Qt/Eclipse Integration to link to ** functionality provided by Qt Designer and its related libraries. ** ** Trolltech reserves all rights not expressly granted herein. ** ** Trolltech ASA (c) 2007 ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ****************************************************************************/ #include "qdesktopservices.h" #ifndef QT_NO_DESKTOPSERVICES #include #include #include #include inline static bool launch(const QUrl &url, const QString &client) { return (QProcess::startDetached(client + QLatin1Char(' ') + QString::fromLatin1(url.toEncoded().constData()))); } static bool openDocument(const QUrl &url) { if (!url.isValid()) return false; if (launch(url, QLatin1String("xdg-open"))) return true; if (X11->desktopEnvironment == DE_GNOME && launch(url, QLatin1String("gnome-open"))) { return true; } else { if (X11->desktopEnvironment == DE_KDE && launch(url, QLatin1String("kfmclient exec"))) return true; } if (launch(url, QLatin1String("firefox"))) return true; if (launch(url, QLatin1String("mozilla"))) return true; if (launch(url, QLatin1String("netscape"))) return true; if (launch(url, QLatin1String("opera"))) return true; return false; } static bool launchWebBrowser(const QUrl &url) { if (!url.isValid()) return false; if (url.scheme() == QLatin1String("mailto")) return openDocument(url); if (launch(url, QLatin1String("xdg-open"))) return true; if (launch(url, QString::fromLocal8Bit(getenv("DEFAULT_BROWSER")))) return true; if (launch(url, QString::fromLocal8Bit(getenv("BROWSER")))) return true; if (X11->desktopEnvironment == DE_GNOME && launch(url, QLatin1String("gnome-open"))) { return true; } else { if (X11->desktopEnvironment == DE_KDE && launch(url, QLatin1String("kfmclient openURL"))) return true; } if (launch(url, QLatin1String("firefox"))) return true; if (launch(url, QLatin1String("mozilla"))) return true; if (launch(url, QLatin1String("netscape"))) return true; if (launch(url, QLatin1String("opera"))) return true; return false; } /* enum Location { // -> StandardLocation Desktop, // -> add Path suffix to each value Documents, Fonts, Applications, Music, Movies, Pictures, Temp, Home }; QString storageLocation(Location type); // -> location() ### Qt 5: rename to path() QString displayName(Location type); */ /* \enum QDesktopServices::Location This enum describes the different locations that can be queried by QDesktopServices::storageLocation and QDesktopServices::displayName. \value Desktop Returns the users desktop. \value Documents Returns the users document. \value Fonts Returns the users fonts. \value Applications Returns the users applications. \value Music Returns the users music. \value Movies Returns the users movies. \value Pictures Returns the users pictures. \value Temp Returns the system's temporary directory. \value Home Returns the user's home directory. \sa storageLocation() displayName() */ /* Returns the default system directory where file of type belong or an invalid QUrl if it is unable to figure out. */ /* QString QDesktopServices::storageLocation(const Location type) { QDir emptyDir; switch (type) { case Desktop: return QDir::homePath()+"/Desktop"; break; case Documents: if (emptyDir.exists(QDir::homePath()+"/Documents")) return QDir::homePath()+"/Documents"; break; case Pictures: if (emptyDir.exists(QDir::homePath()+"/Pictures")) return QDir::homePath()+"/Pictures"; break; case Fonts: return QDir::homePath()+"/.fonts"; break; case Music: if (emptyDir.exists(QDir::homePath()+"/Music")) return QDir::homePath()+"/Music"; break; case Movies: if (emptyDir.exists(QDir::homePath()+"/Movies")) return QDir::homePath()+"/Movies"; break; case QDesktopServices::Home: return QDir::homePath(); break; case QDesktopServices::Temp: return QDir::tempPath(); break; case Applications: default: break; } return QString(); } */ /* Returns a localized display name for a location type or an empty QString if it is unable to figure out. */ /* QString QDesktopServices::displayName(const Location type) { Q_UNUSED(type); switch (type) { case Desktop: return QObject::tr("Desktop"); break; case Documents: return QObject::tr("Documents"); break; case Pictures: return QObject::tr("Pictures"); break; case Fonts: return QObject::tr("Fonts"); break; case Music: return QObject::tr("Music"); break; case Movies: return QObject::tr("Movies"); break; case QDesktopServices::Home: return QObject::tr("Home"); break; case QDesktopServices::Temp: return QObject::tr("Temp"); break; case Applications: return QObject::tr("Applications"); default: break; } return QString(); } */ #endif // QT_NO_DESKTOPSERVICES