/************************************************************************** ** ** Copyright (C) 2013 Kläralvdalens Datakonsult AB, a KDAB Group company. ** Contact: Kläralvdalens Datakonsult AB (info@kdab.com) ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ****************************************************************************/ #ifndef SCRIPTMANAGER_H #define SCRIPTMANAGER_H #include #include #include QT_BEGIN_NAMESPACE class QFileSystemWatcher; class QSignalMapper; QT_END_NAMESPACE namespace ProjectExplorer { class Project; } namespace Scripting { namespace Internal { class ScriptRunner; /** * \brief Manager for scripts. * * Manage all scripts available to the user, and run them. * The scripts could be: * - in the default script directory: userRessource/scripts * - in a qtc-scripts directory of a project * * Scripts directory are watched using a QFileSystemWatcher, to update * the list of script in case one is added or deleted. */ class ScriptManager : public QObject { Q_OBJECT public: struct Script { QString name; QString fileName; QString projectName; }; typedef QList