File: ilaunchconfiguration.h

package info (click to toggle)
kdevelop 4%3A24.12.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 71,888 kB
  • sloc: cpp: 290,869; python: 3,626; javascript: 3,518; sh: 1,316; ansic: 703; xml: 401; php: 95; lisp: 66; makefile: 31; sed: 12
file content (66 lines) | stat: -rw-r--r-- 1,698 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/*
    SPDX-FileCopyrightText: 2009 Andreas Pakulat <apaku@gmx.de>

    SPDX-License-Identifier: LGPL-2.0-or-later
*/

#ifndef KDEVPLATFORM_ILAUNCHCONFIGURATION_H
#define KDEVPLATFORM_ILAUNCHCONFIGURATION_H

#include "interfacesexport.h"

class KConfigGroup;
class QString;

namespace KDevelop
{

class LaunchConfigurationType;
class IProject;

/**
 * A specific configuration to start a launchable, this could be a native
 * compiled application, or some script file or byte-compiled file or something else
 * Provides access to the various configurations, as well as their type and name
 */
class KDEVPLATFORMINTERFACES_EXPORT ILaunchConfiguration
{
public:
    virtual ~ILaunchConfiguration();

    /**
     * Access to the configuration group for this launch configuration.
     * @returns the config to read values from
     */
    virtual const KConfigGroup config() const = 0;
    
    /**
     * Access to the configuration group for this launch configuration.
     * @returns the config to write to
     */
    virtual KConfigGroup config() = 0;
    
    /**
     * Each launch configuration has a type, which identifies which launcher and launch modes
     * are supported.
     * @returns the configuration type
     */
    virtual LaunchConfigurationType* type() const = 0;
    
    /**
     * The user-chosen name for the launch configuration.
     * @returns the config name.
     */
    virtual QString name() const = 0;
    
    /**
     * Provides access to the project where the launch config is stored.
     * @returns the project in which the configuration is stored or 0 if the configuration is stored globally
     */
    virtual IProject* project() const = 0;
};

}

#endif