kdeconnect-kde/plugins
Albert Vaca Cintora 59adbc2da4 Move all generated dbus interfaces to kdeconnectinterfaces exclude them from clazy
* Moves the XML definitions of DBus interfaces and code generation from the different plugins
  to kdeconnectinterfaces. Before each plugin had their own, some of them duplicated.
* Appends `// clazy:skip` to the generated interface files, so Clazy doesn't emit warnings
  about them because they are missing the NOTIFY/CONSTANT keywords on Q_PROPERTIES.
* Makes kdeconnectinterfaces static on Qt5 as well (removes a difference with Qt6).
* Moves the generated files to a `generated` directory and updates the includes so they are
  easily distinguished from other header files.
2023-07-24 12:18:47 +00:00
..
battery Use pragma once in plugins 2023-07-22 20:51:19 +00:00
bigscreen Move all generated dbus interfaces to kdeconnectinterfaces exclude them from clazy 2023-07-24 12:18:47 +00:00
clipboard Use pragma once in plugins 2023-07-22 20:51:19 +00:00
connectivity-report Use pragma once in plugins 2023-07-22 20:51:19 +00:00
contacts Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
findmyphone Use pragma once in plugins 2023-07-22 20:51:19 +00:00
findthisdevice Use pragma once in plugins 2023-07-22 20:51:19 +00:00
lockdevice Move all generated dbus interfaces to kdeconnectinterfaces exclude them from clazy 2023-07-24 12:18:47 +00:00
mmtelephony Use pragma once in plugins 2023-07-22 20:51:19 +00:00
mousepad Move all generated dbus interfaces to kdeconnectinterfaces exclude them from clazy 2023-07-24 12:18:47 +00:00
mpriscontrol Move all generated dbus interfaces to kdeconnectinterfaces exclude them from clazy 2023-07-24 12:18:47 +00:00
mprisremote Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
notifications Use pragma once in plugins 2023-07-22 20:51:19 +00:00
pausemusic Move all generated dbus interfaces to kdeconnectinterfaces exclude them from clazy 2023-07-24 12:18:47 +00:00
photo Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
ping Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
presenter Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
remotecommands Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
remotecontrol Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
remotekeyboard Use pragma once in plugins 2023-07-22 20:51:19 +00:00
remotesystemvolume Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
runcommand Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
screensaver-inhibit Move all generated dbus interfaces to kdeconnectinterfaces exclude them from clazy 2023-07-24 12:18:47 +00:00
sendnotifications SVN_SILENT made messages (.desktop file) - always resolve ours 2023-07-24 08:31:14 +00:00
sftp Use pragma once in plugins 2023-07-22 20:51:19 +00:00
share Use pragma once in plugins 2023-07-22 20:51:19 +00:00
sms Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
systemvolume Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
telephony Use pragma once in plugins 2023-07-22 20:51:19 +00:00
virtualmonitor Use pragma once in plugins 2023-07-22 20:51:19 +00:00
CMakeLists.txt Allow building against Qt6/KF6 2023-07-20 11:15:41 +03:00
kdeconnect.notifyrc SVN_SILENT made messages (.desktop file) - always resolve ours 2023-06-01 01:40:26 +00:00
Messages.sh Figure out Messages.sh after code refactoring 2014-06-17 18:45:47 +02:00
README.txt Fix file name on plugin's readme. 2022-11-27 01:40:51 +00:00

Writing a plugin for KDE Connect
=================================

For the desktop client (this project):
--------------------------------------

1. Enter the "plugins" directory.
2. Copy the "ping" under a different name ("findmyphone" in this example).
3. Add "add_subdirectory(findmyphone)" to CMakeLists.txt after the others "add_subdirectory".
4. Enter the new "findmyphone" directory.
5. Edit CMakeLists.txt by replacing "ping" with "findmyphone".
6. Rename other files in this directory by replacing "ping" with "findmyphone"
7. Write a description of your plugin into "README"
8. Edit findmyphoneplugin.cpp and findmyphoneplugin.h.
  A. Change license header.
  B. Replace (case sensitive) "ping" with "findmyphone", "PingPlugin" with "FindMyPhonePlugin" and "PING" with "FINDMYPHONE".
9. Edit kdeconnect_findmyphone.json file:
  A. Replace "ping" with "findmyphone".
  B. Change name, description, icon, author, email, version, website, license info.
  C. Remove all the translations
  D. Set X-KDEConnect-SupportedPacketType and X-KDEConnect-OutgoingPacketType to the packet type your plugin will receive
     and send, respectively. In this example this is "kdeconnect.findmyphone". Make sure that this matches what is defined in
     the findmyphoneplugin.h file (in the line "#define PACKET_TYPE_..."), and also in Android.
10. Now you have an empty skeleton to implement your new plugin logic.

For Android (project kdeconnect-android):
-----------------------------------------

1. Change directory to src/org/kde/kdeconnect/Plugins.
2. Copy "PingPlugin" under a different name ("FindMyPhonePlugin" in this example).
3. Enter the new "FindMyPhonePlugin" directory.
4. Rename "PingPlugin.java" to "FindMyPhonePlugin.java"
5. Edit it. Replace (case sensitive) "Ping" with "FindMyPhone", "ping" with "findmyphone", "PING" with "FINDMYPHONE"
   and "plugin_ping" with "plugin_findmyphone".
6. Open res/values/strings.xml. Find and copy the lines "pref_plugin_ping_desc" and "pref_plugin_ping" replacing "ping"
   with "findmyphone" and edit the plugin name and description between <string> </string>).
7. Now you have an empty skeleton to implement your new plugin logic.