kdeconnect-kde/plugins
Alexander Lohnau 7091f333f9 Do not mark plugin classes as exported
This is not needed, because only a symbol to create the KPluginFactory
instance must be exported. The KPluginFactory macros or rather the underlying
Q_PLUGIN_METADATA macro already take care of that.

In other plugin code of KDE, we also do not export classes.
The size of the generated plugin files is nearly identical, but removing
the macros avoids confusion for developers.
2023-07-22 20:51:19 +00:00
..
battery Use pragma once in plugins 2023-07-22 20:51:19 +00:00
bigscreen Do not mark plugin classes as exported 2023-07-22 20:51:19 +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 Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
mmtelephony Use pragma once in plugins 2023-07-22 20:51:19 +00:00
mousepad Use pragma once in plugins 2023-07-22 20:51:19 +00:00
mpriscontrol Do not mark plugin classes as exported 2023-07-22 20:51:19 +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 Use pragma once in plugins 2023-07-22 20:51:19 +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 Do not mark plugin classes as exported 2023-07-22 20:51:19 +00:00
sendnotifications Use pragma once in plugins 2023-07-22 20:51:19 +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.