forked from hluk/CopyQ
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathHACKING
64 lines (43 loc) · 1.92 KB
/
HACKING
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
You can post issues or request new features at
<https://github.com/hluk/CopyQ/issues>. If you have a patch you can submit new
pull requests at <https://github.com/hluk/CopyQ>.
Translations
------------
Weblate is the preferred way to translate CopyQ. Follow instructions at
https://hosted.weblate.org/engage/copyq/.
Writing Platform-dependent Code
-------------------------------
To be able to fully use this software on different platform there need to be
support for platform-specific features as system-wide shortcuts, focusing and
pasting to other windows.
To port the code to other platforms:
1. create new directory "src/platform/<PLATFORM_NAME>",
2. implement interface from "src/platform/platformnativeinterface.h",
3. modify "platform.cmake" and "platform.pri" to be able to compile
the platform-dependent code on given platforms with "cmake" and "qmake".
System-wide shortcuts are handled using third-party library libqxt in "qxt/".
Writing Plugins
---------------
Plugins in this application are used to display different types of data (MIME
formats) as items in clipboard history and other tabs.
See existing plugins in "plugins" directory. Simply just copy one plugin
directory and start rewriting the code and modify "plugins/CMakeLists.txt" to
contain path to the new directory.
Any plugin class must implement ItemLoaderInterface from
"src/include/itemwidget.h" and must be QObject. Mainly any object of this class
should be able to instantiate ItemWidget object (using create() method) if
suitable data are available.
Running Tests
-------------
After changing code or implementing new features, it's important to check if
unit tests are not failing.
Following command will execute all tests.
copyq tests
Or run
copyq tests --help
to get more information about tests.
OS X Specific Notes
-------------------
To build a DMG file for OS X, run:
/path/to/qmake CONFIG+=release WITH_WEBKIT=1
make dmg