/* BEGIN_COMMON_COPYRIGHT_HEADER
 * (c)LGPL2+
 *
 * LXQt - a lightweight, Qt based, desktop toolset
 * http://razor-qt.org
 *
 * Copyright: 2012-2013 Razor team
 * Authors:
 *   Petr Vanek <petr@scribus.info>
 *
 * This program or library is free software; you can redistribute it
 * and/or modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.

 * You should have received a copy of the GNU Lesser General
 * Public License along with this library; if not, write to the
 * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301 USA
 *
 * END_COMMON_COPYRIGHT_HEADER */

#ifndef LXQTAPPLICATION_H
#define LXQTAPPLICATION_H

#include <QApplication>
#include <QProxyStyle>
#include "lxqtglobals.h"

namespace LxQt
{

/*! \brief LXQt wrapper around QApplication.
 * It loads various LXQt related stuff by default (window icon, icon theme...)
 *
 * \note This wrapper is intended to be used only inside LXQt project. Using it
 *       in external application will automatically require linking to various
 *       LXQt libraries.
 *
 */
class LXQT_API Application : public QApplication
{
    Q_OBJECT

public:
    /*! Construct a LXQt application object.
     * \param argc standard argc as in QApplication
     * \param argv standard argv as in QApplication
     */
    Application(int &argc, char **argv);
    /*! Construct a LXQt application object.
     * \param argc standard argc as in QApplication
     * \param argv standard argv as in QApplication
     * \param handleQuitSignals flag if signals SIGINT, SIGTERM, SIGHUP should be handled internaly (\sa quit() application)
     */
    Application(int &argc, char **argv, bool handleQuitSignals);
    virtual ~Application() {}
    /*! Install UNIX signal handler for signals defined in \param signalList
     * Upon receiving of any of this signals the \sa unixSignal signal is emitted
     */
    void listenToUnixSignals(QList<int> const & signolList);

private slots:
    void updateTheme();

signals:
    void themeChanged();
    /*! Signal is emitted upon receival of registered unix signal
     * \param signo the received unix signal number
     */
    void unixSignal(int signo);
};

#if defined(lxqtApp)
#undef lxqtApp
#endif
#define lxqtApp (static_cast<LxQt::Application *>(qApp))

} // namespace LxQt
#endif // LXQTAPPLICATION_H