kde-workspace/plasma
Ivailo Monev fcbb39812a plasma: do not merge KUnitConversion into anonymous namespace
Signed-off-by: Ivailo Monev <xakepa10@gmail.com>
2021-06-11 00:07:59 +03:00
..
applets plasma: do not merge KUnitConversion into anonymous namespace 2021-06-11 00:07:59 +03:00
containmentactions generic: replace installation paths with KDE4_ prefixed 2020-02-08 20:13:13 +00:00
containments generic: replace installation paths with KDE4_ prefixed 2020-02-08 20:13:13 +00:00
dataengines plasma: remove unused sensorclient header 2021-06-10 23:23:01 +03:00
declarativeimports generic: consistent library variables usage 2021-02-26 20:14:30 +02:00
design remove remote widgets design 2014-12-09 23:17:22 +00:00
desktoptheme generic: replace installation paths with KDE4_ prefixed 2020-02-08 20:13:13 +00:00
kpart generic: replace installation paths with KDE4_ prefixed 2020-02-08 20:13:13 +00:00
runners plasma: do not disable deprecated warnings 2021-06-10 07:07:58 +03:00
scriptengine generic: prepare for Katie changes 2021-02-18 21:52:42 +02:00
shells plasma: disable debug message in ControllerWindow::resizeEvent() 2021-01-03 00:39:56 +02:00
toolboxes generic: replace installation paths with KDE4_ prefixed 2020-02-08 20:13:13 +00:00
tools plasma: organize sub-directories 2015-12-24 22:48:47 +02:00
wallpapers plasma: do not attempt to connect to non-existing slot 2021-03-17 06:30:54 +02:00
.emacs-dirvars initial import 2014-11-13 19:30:51 +02:00
CMakeLists.txt generic: generate export headers via generate_export_header() 2021-03-10 18:42:58 +02:00
HACKING initial import 2014-11-13 19:30:51 +02:00
README initial import 2014-11-13 19:30:51 +02:00

PLASMA
======

The applications and plugins that provide the panels/desktop/dashboard parts of
the primary user interface for the KDE Plasma workspaces (Plasma Desktop, Netbook, etc).
Much of the functionality is provided by libplasma, which is found in kdelibs/plasma/.

For more information, please visit the Plasma website at http://plasma.kde.org.

Directory Structure
===================

Each top level directory denotes which workspace (desktop, netbook, screensaver, etc.)
the components within it apply to. There is a directory named "generic" for components
that do not apply to a specific workspace.

Within each of these top level directories, the following hierarchy exists:

               applets: Applets (aka "plasmoids" or "widgets") that are considered central
                        to the workspace in question

          containments: Standard containment objects that provide management for the
                        Plasma contents shown on panels, desktops, screensavers, etc.

           dataengines: DataEngines considered generally useful; more specific/niche
                        DataEngines can be found in kdeplasma-addons or extragear/plasma/

               runners: Provides matches to queries; used by KRunner, Kickoff, others

              shell(s): The application(s) that provide the Plasma viewing environment
                        for a given workspace / formfactor. They also provide
                        implementations of dialog placement, screen geometry, remote
                        widget notifications, access request UI, containment
                        management UI, etc. Essentially all the framework pieces needed
                        to provide appropriate rendering of an environment for a given
                        form factor or target device.

    containmentactions: Plugins that provide actions for context menus and other input
                        triggered action sets


In addition to the above, the generic directory also contains:

            wallpapers: Background rendering plugins for containments
         scriptengines: Glue between libplasma and APIs provided via dynamic languages or
                        3rd party systems; note that the Javascript scriptengines
                 tools: useful applications for working with Plasma apps, including:
                            * engineexplorer: a graphical utility to examine engines
                            * wallpaperviewer: a tool to view Plasma wallpaper plugins
                            * plasmoidviewer: a viewer for individual Plasma applets,
                              particularly useful for edevel and debugging

KDE Base Runtime
================
A number of important components live in the kdebase-runtime package in the plasma/
directory, including:

* The javascript ScriptEngines for Plasmoids, DataEngines and Runners
* plasmapkg: Installs, removes and lists plasma packages
* remotewidgetshelper: a small help tool for Plasma applets that are remoted over
  the network

The default SVG themes also exist in kdebase-runtime under desktopthemes/