File: shellextension.h

package info (click to toggle)
kdevelop 4%3A22.12.2-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 70,096 kB
  • sloc: cpp: 284,635; javascript: 3,558; python: 3,422; sh: 1,319; ansic: 685; xml: 331; php: 95; lisp: 66; makefile: 39; sed: 12
file content (73 lines) | stat: -rw-r--r-- 2,000 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
67
68
69
70
71
72
73
/*
    SPDX-FileCopyrightText: 2004 Alexander Dymo <adymo@kdevelop.org>

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

#ifndef KDEVPLATFORM_SHELLEXTENSION_H
#define KDEVPLATFORM_SHELLEXTENSION_H

#include <QString>
#include "shellexport.h"

namespace KDevelop
{

/**Default area parameters collection.*/
struct AreaParams {
    /**Unique name for the area.*/
    QString name;
    /**User-visible area title.*/
    QString title;
};

/**
Shell extension.
Provides application-dependent and shell-independent functionality.
Shell uses extensions to perform application dependent actions.
*/
class KDEVPLATFORMSHELL_EXPORT ShellExtension {
public:
    virtual ~ShellExtension() {}

    /**Returns an instance of a shell. Subclasses must create an instance of a shell
    by themselves. For example they could provide static init() method like:
    @code
    static void init()
    {
        s_instance = new MyExtension();
    }
    @endcode*/
    static ShellExtension *getInstance();

    /**Reimplement to return the path to the executable that needs to be executed for new sessions.*/
    virtual QString executableFilePath() = 0;

    /**Reimplement to return the name of KXMLGUI resource file for an application.*/
    virtual QString xmlFile() = 0;

    /**Reimplement to return the name of the default ui area.*/
    virtual AreaParams defaultArea() = 0;

    /**Reimplement to return the filename extension for project files.*/
    virtual QString projectFileExtension() = 0;

    /**Reimplement to return the description for project files.*/
    virtual QString projectFileDescription() = 0;

    /**
     * Reimplement to return the list of plugins that should
     * loaded by default.
     * If an empty list is returned, instead the plugin metadata is fallen back to,
     * by reading the bool value KPlugin/EnabledByDefault (default: true).
     */
    virtual QStringList defaultPlugins() = 0;

protected:
    ShellExtension();
    static ShellExtension *s_instance;
};

}
#endif