-
Notifications
You must be signed in to change notification settings - Fork 199
/
Copy pathCHANGELOG.rst
736 lines (539 loc) · 33.9 KB
/
CHANGELOG.rst
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
=========
Changelog
=========
Next Version
============================
Important misc changes
----------------------
- Bump action versions in pages.yml to satisfy part of issue #963.
- Bump action versions in build.yml to satisfy part of issue #963.
- Bump action versions in python-test.yml to satisfy part of issue #963.
- Bump Python version in build.yml to satisfy part of issue #964.
- Bump Python versions in python-test.yml to satisfy part of issue #964.
- Bump Python versions in setup.cfg to satisfy issue #969.
- Bump Python versions in setup.py to satisfy issue #970.
- Bump to all GitHub-supported Python versions to satisfy issue #986.
- Add `pyasyncore` dependency to `setup.py` for use in Python 3.12 to satisfy issues #946 and #964.
Other
+++++
- Add `show_recent_script_errors_dialog` to display errors with millisecond precision.
- Add **Environment** as an issue type in the `bug.yml` file.
Version 0.96.0
============================
Important misc changes
----------------------
- Script and phrase metadata are no longer stored as hidden dotfiles. Existing scripts should be automatically converted, but if switch back to versions prior to this one, you will need to copy or symlink them back to dotfile form.
- Scripting API files are now in Python packages, which may require adjusting imports if you have scripts that import them directly.
- Change the default phrase send mode to `ctrl+v` (paste using clipboard) rather than sending keys one at a time.
- This version represents some significant refactoring since the previous update, so bug reports will be highly appreciated.
- Add two sections to the issue template.
- Change all **sudo apt** references in **master** to **sudo apt-get** to satisfy part of issue #772.
- Bump Python version in **autokey.spec** AND **PKG-INFO**.
- Update the **README.rst** file to satisfy part of issue #681 and issue #779.
- Update the actions in the **build.yml** file to the latest versions in the GitHub Marketplace.
- Remove extra unneeded curly bracket from line 350 of engine.py for the API documentation.
- Update the actions in the **pages.yml** file to the latest versions in the GitHub Marketplace.
Features
---------
Scripting API
^^^^^^^^^^^^^
**engine API object**
- Deprecated: Confusingly named engine.create_abbreviation() and engine.create_hotkey() are deprecated and will be removed in the future. Use engine.create_phrase() with appropriate arguments instead.
- Extended: engine.create_phrase() now supports multiple new optional arguments, allowing to fully configure the created phrase. It can set everything the GUI can do.
- New: Scripts can use engine.get_triggered_abbreviation() to read which abbreviation triggered it’s execution.
The function returns a tuple containing the abbreviation and the trigger character (the character that 'completed' or 'confirmed' the abbreviation. Both tuple elements are None if the script was not triggered by an abbreviation. The trigger character is None if the script was configured to 'trigger immediately'. The function always returns a tuple, so direct tuple unpacking like abbreviation, trigger = engine.get_triggered_abbreviation() will always work.
- Allow creation of 'temporary' hotkeys and whole folders (which do not persist between sessions).
- Allow overriding existing hotkeys when creating phrases with hotkeys.
- Allow creation of folders.
- Add `set_clipboard_image` methods for both Gtk and Qt. Takes a file path to an image to load into the clipboard.
**keyboard API object**
- keyboard.send_keys() got a new optional parameter send_mode, allowing to specify how the given text is sent. It basically offers the same pasting options as are available to AutoKey Phrases.
- keyboard.send_keys() now raises a TypeError instead of a generic AssertionError, if parameters don’t match the expected types.
**New clipboard API method**
- Change the default phrase send mode to `ctrl+v` (paste using clipboard) rather than sending keys one at a time.
**New mouse API object**
- Add mouse drag, click and scroll options to the API.
Command line interface
++++++++++++++++++++++
- Added a --version command line switch. It prints the current AutoKey version on the standard output and then exits.
Graphical user interfaces
+++++++++++++++++++++++++
- (GTK) Warn user about missing required and optional programs on startup.
- (GTK) UI will now update when changes are detected to watched files.
- (GTK) refresh UI if script files are modified externally
- Use system monospace font
- Add setting to change GtkSourceView theme, (defaults to classic).
Other
+++++
- Add `wait_for_keyevent` scripting function.
- Rewrote script error logging system, with a neat Script Error Dialog to go with it.
- `<script>` script macros accept absolute paths.
- Macro arguments can be quoted, allowing arguments containing spaces.
- Macro arguments can contain angle bracket characters, if escaped.
- Add `<system>` macro for replacing phrase contents with output of an external process.
- Allow `autokey-run` to accept full paths to python scripts (if no full path is given, will treat as an existing Autokey script name instead).
- Expand unicode characters using code points (hacky workaround for being unable to send actual unicode).
- Allow disabling Capslock in settings
- Link to script `.py` and `.json` above editor.
- Add appropriate keywords to `.desktop` files for both UIs.
- Build debs and update pypi on new releases
Bug fixes
---------
- Both QT and GTK versions will reload hotkeys after a keymap change event.
- Fix locking issue
- Expose Alt_GR as a hotkey modifier on GTK.
- Fix issue with pip installation reporting a missing module
- Add missing closing backtick to the code snippet on line 113 of the `CHANGELOG.rst` file. Fixes issue `#906`_.
.. _`#906`: /~https://github.com/autokey/autokey/issues/906
Scripting API
+++++++++++++
- Fixed API call `system.exec_command()` crashing, if output capturing is active, but the executed command has empty output. Fixes issue #379
Packaging
+++++++++
- Fixed AutoKey PNG icon size. Now, the icon size is 96x96 pixels, fixing Lintian warnings on Debian. Fixes issue #369
Other changes
---------
- Add CI for testing
- Update pip installation requirements
- Add CONTRIBUTERS.rst
- Internal Code cleanup. The configuration handling module is split into multiple modules inside a dedicated package.
- Change clipboard wording in the AutoKey documentation.
- Update formatting and wording in the AutoKey GTK and Qt clipboard API documentation.
- Remove one reference to X in the AutoKey GTK clipboard API documentation.
- Remove one reference to mouse in the AutoKey Qt clipboard API documentation.
- AutoKey now has a working test environment again. `pytest` based unit-tests can be launched from the source checkout using `python3 setup.py test`
- Fix typo: Replace all occurrences of "they key" with "the key" in the AutoKey documentation.
- Rename the bug.yaml file to bug.yml.
- Add the `config.yml` file to the `/.github/ISSUE_TEMPLATE` directory to prevent blank issues from being offered and created. Fixes `#897`_
- Remove unnecessary white-space from the `config.yml` file.
.. _`#897`: /~https://github.com/autokey/autokey/issues/897
**New Dependencies (test-time only)**
The new unit tests introduce two new, *test-time only* dependencies. These are used for unit tests only and not during normal AutoKey execution.
- `pytest`
- `PyHamcrest`
Version 0.96.0-beta.11
============================
Bug fixes
---------
- Fix crash in qt macro recording window.
Version 0.96.0-beta.10
============================
Bug fixes
---------
- Beta: Fix Segfault from modifying files when open in off-screen AK window
Version 0.96.0-beta.9
============================
Bug fixes
---------
- Fix qt crashing when changing a hotkey
Version 0.96.0-beta.8
============================
Bug fixes
---------
- Fix installation not copying predefined user files (fix #578)
Version 0.96.0-beta.5
============================
Bug fixes
---------
- Fix clear button not unsetting hotkeys
Version 0.96.0-beta.4
============================
- Fix updating of sidecar files
Version 0.96.0-beta.3
============================
- Build debs and update pypi on new releases
- Add `set_clipboard_image` methods for both Gtk and Qt. Takes a file path to an image to load into the clipboard.
Version 0.96.0-beta.2
============================
- Fix issue with pip installation reporting a missing module
Version 0.96.0-beta.1
============================
Important misc changes
----------------------
- Script and phrase metadata are no longer stored as hidden dotfiles. Existing scripts should be automatically converted, but if switch back to versions prior to this one, you will need to copy or symlink them back to dotfile form.
- Scripting API files are now in Python packages, which may require adjusting imports if you have scripts that import them directly.
- Change the default phrase send mode to `ctrl+v` (paste using clipboard) rather than sending keys one at a time.
- This version represents some significant refactoring since the previous update, so bug reports will be highly appreciated.
Features
---------
Scripting API
^^^^^^^^^^^^^
**engine API object**
- Deprecated: Confusingly named engine.create_abbreviation() and engine.create_hotkey() are deprecated and will be removed in the future. Use engine.create_phrase() with appropriate arguments instead.
- Extended: engine.create_phrase() now supports multiple new optional arguments, allowing to fully configure the created phrase. It can set everything the GUI can do.
- New: Scripts can use engine.get_triggered_abbreviation() to read which abbreviation triggered it’s execution.
The function returns a tuple containing the abbreviation and the trigger character (the character that 'completed' or 'confirmed' the abbreviation. Both tuple elements are None if the script was not triggered by an abbreviation. The trigger character is None if the script was configured to 'trigger immediately'. The function always returns a tuple, so direct tuple unpacking like abbreviation, trigger = engine.get_triggered_abbreviation() will always work.
- Allow creation of 'temporary' hotkeys and whole folders (which do not persist between sessions).
- Allow overriding existing hotkeys when creating phrases with hotkeys.
- Allow creation of folders.
**keyboard API object**
- keyboard.send_keys() got a new optional parameter send_mode, allowing to specify how the given text is sent. It basically offers the same pasting options as are available to AutoKey Phrases.
- keyboard.send_keys() now raises a TypeError instead of a generic AssertionError, if parameters don’t match the expected types.
**New clipboard API method**
- Change the default phrase send mode to `ctrl+v` (paste using clipboard) rather than sending keys one at a time.
**New mouse API object**
- Add mouse drag, click and scroll options to the API.
Command line interface
++++++++++++++++++++++
- Added a --version command line switch. It prints the current AutoKey version on the standard output and then exits.
Graphical user interfaces
+++++++++++++++++++++++++
- (GTK) Warn user about missing required and optional programs on startup.
- (GTK) UI will now update when changes are detected to watched files.
- (GTK) refresh UI if script files are modified externally
- Use system monospace font
- Add setting to change GtkSourceView theme, (defaults to classic).
Other
+++++
- Add `wait_for_keyevent` scripting function.
- Rewrote script error logging system, with a neat Script Error Dialog to go with it.
- `<script>` script macros accept absolute paths.
- Macro arguments can be quoted, allowing arguments containing spaces.
- Macro arguments can contain angle bracket characters, if escaped.
- Add `<system>` macro for replacing phrase contents with output of an external process.
- Allow `autokey-run` to accept full paths to python scripts (if no full path is given, will treat as an existing Autokey script name instead).
- Expand unicode characters using code points (hacky workaround for being unable to send actual unicode).
- Allow disabling Capslock in settings
- Link to script `.py` and `.json` above editor.
- Add appropriate keywords to `.desktop` files for both UIs.
Bug fixes
---------
- Both QT and GTK versions will reload hotkeys after a keymap change event.
- Fix locking issue
- Expose Alt_GR as a hotkey modifier on GTK.
- (GTK) Fixed GUI lock-up, if multiple script error notifications are posted in quick succession. The notifications are now rate-limited and won’t post more than one notification per second. Fixes issue #383
Scripting API
+++++++++++++
- Fixed API call `system.exec_command()` crashing, if output capturing is active, but the executed command has empty output. Fixes issue #379
Packaging
+++++++++
- Fixed AutoKey PNG icon size. Now, the icon size is 96x96 pixels, fixing Lintian warnings on Debian. Fixes issue #369
Other changes
---------
- Add CI for testing
- Update pip installation requirements
- Add CONTRIBUTERS.rst
- Internal Code cleanup. The configuration handling module is split into multiple modules inside a dedicated package.
- AutoKey now has a working test environment again. `pytest` based unit-tests can be launched from the source checkout using `python3 setup.py test`
**New Dependencies (test-time only)**
The new unit tests introduce two new, *test-time only* dependencies. These are used for unit tests only and not during normal AutoKey execution.
- `pytest`
- `PyHamcrest`
Version 0.95.10 <2019-12-16>
============================
Bug fixes
---------
- Mitigate crashes when entering invalid Python regular expressions in the window filter dialogue. Fixes issue #212
- Added option to disable the handling of the Capslock modifier key.
Fixes issues when that key is remapped to something else, for example Ctrl.
The new option can be found in the settings dialogue. Fixes issues #95, #291
- API function `system.exec_command()` now only trims the last character in the output,
if it is actually a newline character. If the executed command does not output a newline at the end,
the full output is returned. Fixes issue #354
- Fixed wrong optional argument in man page for `autokey-run`. Fixed by pull request #361
- Removed unnecessarily set executable bit from several AutoKey SVG icons. Fixed by pull request #363
Version 0.95.9 <2019-12-07>
===========================
Bug fixes
---------
- Prevent data losses when deleting or moving directories from within AutoKey. AutoKey will only delete data it knows
and keep unknown user data. So adding $HOME and then removing it again will not purge everything below it.
Affected were deleting directories and moving them via drag & drop. Fixes issues #171, #332
Version 0.95.8 <2019-11-07>
===========================
Bug fixes
---------
- Qt GUI: Fix issue with Python 3.7.4 and PyQt 5.11-5.13.0 that prevented AutoKey from starting on certain
distributions shipping this configuration, notably Kubuntu 19.10. Fixes issues #313, #301
- Qt GUI: Fix crash when saving the currently edited item, after deselecting it in the tree view. Fixes issue #285
- Qt GUI: Disable Main window -> Tools -> Insert Macro when not editing a Phrase. Fixes issue #276
- Qt GUI: Add a warning that explains possible data loss when creating top level directories at used specified
locations. See issue #171
- GTK GUI: Fix application hang when setting a custom value for "Trigger on" in the Abbreviation settings dialogue.
Fixes issue #315
Version 0.95.7 <2019-04-29>
===========================
Bug fixes
---------
- GTK GUI: Fixed system tray icon context menu entry :code:`View script error`, which was non-functional,
if the main window is closed. The entry now opens the main window first as a workaround,
because a proper fix will require a major code overhaul. Fixes #222
- Qt GUI: Fixed the truncated GPLv3 license text shown in the About AutoKey dialogue.
The dialogue window now shows the full license text. Fixes #258
- Hardened the logic to read application window titles. AutoKey now works,
if applications do not set the :code:`_NET_WM_VISIBLE_NAME` property of their windows. Fixes #257
- Fixed Phrase expansion using the Keyboard method, which was broken if AutoKey was started for the first time.
Fixes #274
Other fixes
-----------
- Improved the debug logging output: Removed unnecessary output, clarified wordings, etc. See #230
- Qt GUI: Display the current Python version number in the About dialogue.
Version 0.95.6 <2019-02-09>
===========================
Bug fixes
---------
- Fix the combination of phrase settings :code:`Match phrase case to typed abbreviation` and
:code:`Trigger immediately` to cause Scripts and Phrases to trigger on each and every key press.
Fixes issue #254 introduced in 0.95.5.
Version 0.95.5 <2019-02-07>
===========================
Bug fixes
---------
- Fix window filter detection always returning Title: :code:`FocusProxy`, Class: `Focus-Proxy-Window.FocusProxy` on
Java AWT applications. It now detects the proper window title and WM_CLASS attribute for Java AWT applications.
Fixes issue #113
- GTK GUI: Fix the window filter detection dialogue. On clicking OK, it hung the whole application.
Now the dialogue window works as intended. Fixes issue #229
- Fix abbreviation case folding (ignore case option) with abbreviations defined as UPPER CASE in the abbreviation
dialogue. Options :code:`Ignore case` and :code:`Match case` now work with upper case abbreviations. Fixes issue #197
- Prevent the keyboard from staying grabbed by AutoKey if exceptions are thrown while AutoKey performs a
clipboard pasting action. Fixes issues #72, #225
- Prevent writing :code:`None` to the clipboard. This prevents autokey-gtk from deadlocking,
caused by an unreleased mutex. Fixes issue #226
- Restrict Phrase Undo functionality to phrases without special keys, because phrases containing special keys cannot
be reliably undone. Fixes issue #196
- Clarified autosave option wording in the settings window. The option now explicitly states what it does.
Fixes issue #194
- Force AutoKey to exit, if the X server connection closes, most probably at logout or session end. Fixes issue #198
Qt tray icon fixes and improvements
+++++++++++++++++++++++++++++++++++
- Added »View script error« entry to the Tray icon context menu, like in the GTK GUI. Part of issue #158
- Tray icon turns red, when scripts raise an error, like in the GTK GUI. Part of issue #158
- If changing the tray icon theme in the settings (light or dark), instantly apply the new theme,
without requiring an application restart. Part of issue #158
- The tray icon now works, after if it is disabled in the settings and then enabled again. Fixes issue #223
Other fixes
-----------
- Enable :code:`setup.py` to be directly called from the system shell. Fixes issue #218
- Cleaned up some legacy leftovers in the autokey repository
Version 0.95.4 <2018-10-14>
===========================
Bug fixes
---------
- Fix grabbed hotkeys being incorrectly received by other applications.
- Fixed crashes when processing `<code>` literals in strings.
It is now possible to place `<code>` and `<code/>` literals in Phrases.
Additionally, such literals can be typed in scripts using the keyboard.send_keys function.
- Increased the reliability of the window filter detection dialog in autokey-qt. The dialog allows sampling windows
to aid writing window filters. Due to timing issues in certain cases, sometimes the window title of the previously
active window was returned.
Version 0.95.3 <2018-08-21>
===========================
Features
--------
- Phrase expansion can now always be undone using the backspace key, if the feature is enabled in the settings.
Previously it was only be possible if the phrase was triggered by an abbreviation.
Now it also works when using hotkeys or selecting phrases from menus.
This also prevents crashes in `certain cases`_.
- Qt GUI: Add support for automatically starting `autokey-qt` during login. It can be configured in the settings
dialogue. The configuration option allows to choose which GUI is automatically started, if both `autokey-qt` and
`autokey-gtk` are installed simultaneously, and whether the main window should be shown automatically on launch.
- Qt GUI: Added the notification icon theme selection to the settings dialogue. The added section in the general
settings allow to choose between the light and dark theme, like in the `autokey-gtk` settings dialogue. Changing
this setting currently requires an application restart to take effect.
Bug fixes
---------
- Scripting API: The Python `__file__` global variable is now properly set for AutoKey scripts.
It contains the full path to the Python script file currently running. Previously, it contained the full path to
the `service.py` file of the currently running AutoKey instance.
- Crash fix: Skip import of the AT-SPI interface, if importing of `pyatspi` fails with a SyntaxError. This may happen
with certain versions of `pyatspi` on Python 3.7. For details see `#173`_
- Fix serializing the store during saving, if user stores recursive data structures. It now handles/skips lists that
contain themselves or other circular referenced data structures.
- GTK GUI: Fix autostart handling: Create the `$XDG_CONFIG_HOME/autostart` (`~/.config/autostart`) directory, if it is
not already present. Fixes `#149`_
- Qt GUI: Create the user data directories before initializing the logger system. This prevents crashes when autokey-qt
is used for the first time or when the user wiped all previous data. Fixes `#170`_
- Qt GUI: Fix saving the "Always prompt before running this script" checkbox content when editing scripts. This option
now works as intended again.
Packaging
---------
- Stop shipping the `autokey.png` icon file inside a `scalable` icon theme directory. Moved to the appropriate raster
image directory.
- Corrected broken dependency package name in setup.py. The library is called `python-xlib` and not `python3-xlib` on
PyPI.
.. _certain cases: /~https://github.com/autokey/autokey/issues/164
.. _`#173`: /~https://github.com/autokey/autokey/issues/173
.. _`#149`: /~https://github.com/autokey/autokey/issues/149
.. _`#170`: /~https://github.com/autokey/autokey/issues/170
Version 0.95.2 <2018-07-16>
===========================
- Fix broken imports in autokey-shell script
- Skip non-json-serializable data in script storage (both script local and global) during saving. This allows putting
non-serializable items (like function objects) into the store without crashing autokey during saving.
- Qt GUI: Fix minor bug when creating new items. Created items are now properly selected for renaming directly after
creation.
- Minor code simplifications. Removed unnecessary functions that were obsoleted during prior changes.
Version 0.95.1 <2018-06-30>
===========================
This is a small bug fixing release.
- Fix a long standing bug that errors occurring during phrase parsing or script execution can lock up the user keyboard.
Make sure to always release the keyboard after grabbing it. See `#72`_, launchpad_1551054_
- Qt GUI: Fix saving the content of the log view to a file using the context menu entry.
- Some small, internal code quality improvements.
.. _`#72`: /~https://github.com/autokey/autokey/issues/72
.. _launchpad_1551054: https://bugs.launchpad.net/ubuntu/+source/autokey/+bug/1551054
Version 0.95.0 <2018-06-28>
===========================
Rewritten the Qt GUI, ported to PyQt5
-------------------------------------
Resurrected, re-written and cleaned up the `autokey-qt` Qt GUI. `autokey-qt` is now a pure `PyQt5` application, only
dependent on currently supported libraries.
Added improvements
++++++++++++++++++
- The main window now keeps its complete state when closed and re-opened (excluding complete application restarts). This includes the currently selected item(s) in the tree view on the left of the main window, selected text and cursor position in the editor on the right if currently editing a script or phrase.
- The entries in the popup menu, that is shown when a hotkey assigned to a folder is pressed, now show icons based on their type (folder, phrase or script). This also works when items are configured to be shown in the system tray icon context menu.
- The *A* autokey application icons are now always displayed correctly, both in the main window and the system tray icon.
- Various menu actions now have system dependent keyboard shortcuts, that should adjust to the expected default of the user’s current platform/desktop environment.
- Added icons and descriptive tooltip texts to various buttons.
- The `enable monitoring` checkboxes (both in the `Settings` menu and the tray icon context menu) now properly react to pressing the global hotkey for this action and thus stay in sync. (Even if the hotkey is used while the menu is shown.)
Regressions
+++++++++++
- Customizing the main window toolbar entries and keyboard shortcuts to trigger various UI actions is no longer possible. This feature was provided by the KDE4 libraries and is currently dropped.
- The previous, KDE4-based About dialogue is replaced with a very minimalistic one.
- The settings dialogue heavily used the KDE4 functionalities. During the port to Qt5, the dialogue lost some visual style, but all core functionality is kept.
Runtime dependencies
++++++++++++++++++++
- Removed dependencies on deprecated and unmaintained PyQt4 and PyKDE4 libraries.
- Removed dependency on `dbus.mainloop.qt`, instead use the DBus support built into Qt5.
- Now depend on PyQt5, the Qt5 SVG module and the Qt5 QScintilla2 module.
Build-time dependencies
+++++++++++++++++++++++
Optionally depend on `pyrcc5` command line tool to compile Qt resources into a Python module.
Qt UI files are no longer compiled using `pykdeuic4`, Removed the old compiler wrapper script in commit 6eeeb92f_.
.. _6eeeb92f: /~https://github.com/autokey/autokey/commit/6eeeb92f14c694979c1367d51350c1e6509329b1
Known bugs
++++++++++
The system tray icon is shown, but non-functional, after enabling it in the settings dialogue. AutoKey Qt has to be restarted for the tray icon to start working. This should have no impact on the normal daily use.
Changed features
++++++++++++++++
The `hide tray icon` entry in the tray icon context menu now hides the icon for the current session only. The entry does not permanently disable the tray icon any more without any confirmation. Now, the only way to permanently disable the tray icon is through using the appropriate setting in the settings dialogue.
Fixed the broken `Clipboard` and `Mouse selection` phrase paste modes
---------------------------------------------------------------------
- Pasting using both `Clipboard` and `Mouse selection` works in both the Qt and GTK GUI. See `#101`_
- Fixed restoring the clipboard after a paste is performed. Both GUIs now restore the previous clipboard content, after a phrase is pasted.
.. _`#101`: /~https://github.com/autokey/autokey/issues/101
Scripting API Changes
---------------------
Additions
+++++++++
- Added a colour picker dialogue to the GTK dialog class, because the used `zenity` now supports it.
- The picked colour is returned as three integers using the ColourData NamedTuple, providing both index based access and attribute access, using the channel names (`r`, `g`, `b`). Additionally, ColourData provides some conversion methods.
Breaking changes
++++++++++++++++
- See Pull request `#148`_. The `dialog` classes for user input in scripts now return typed NamedTuple tuples instead of plain tuples. This change is safe as long as users do not perform needlessly restrictive type checks in their scripts (e.g. `if type(returned_data) == type(tuple()): ...`). User scripts doing so will break.
- The KDialog based colour picker now also returns a ColourData instance instead of a HTML style hex string, thus making this portable between both GTK and Qt GUIs. AutoKey users previously using the old KDE GUI and using the colour picker dialogue have to port their scripts. A simple fix is using the `html_code` property of the returned ColourData instance.
.. _`#148`: /~https://github.com/autokey/autokey/pull/148
Fixes
+++++
- Re-introduce the newline trimming for system.exec_command() function. During the porting to Python 3, the newline trimming was removed, causing users various issues with unexpected newline characters at end of output. Now properly remove the _last_ newline at end of command output. (See issues `#75`_, `#92`_, `#145`_)
- Applied various code style improvements to the scripting module.
.. _`#75`: /~https://github.com/autokey/autokey/issues/75
.. _`#92`: /~https://github.com/autokey/autokey/issues/92
.. _`#145`: /~https://github.com/autokey/autokey/issues/145
Other fixes and improvements
----------------------------
- Fix the KDialog based colour picker provided in the scripting API. Newer versions of KDialog require an additional parameter, which is added now.
- Fixed crashes related to mouse pasting when using the GTK GUI.
- Both `autokey-gtk` and `autokey-qt` are now automatically generated setuptools entry-points.
- `autokey-gtk` can now be launched directly from the autokey source tree.
From the shell, `cd` into the `lib` directory, then use
.. code-block:: sh
<path_to_autokey_source_dir>/lib$ python3 -m autokey.gtkui [-l] [-c]
# Or alternatively, to launch autokey-qt use:
<path_to_autokey_source_dir>/lib$ python3 -m autokey.qtui [-l] [-c]
- Various internal code style improvements at various locations, like added type hints, PEP8 style fixes, etc.
Version 0.94.0 <2018-05-12>
===========================
- Various README updates
- Ported autokey-run from the legacy optparse module to the new Python 3 argparse module
- Use $XDG_RUNTIME_DIR and $XDG_DATA_HOME directories for lock and log file
- Added support for function keys F13 to F35
- Refactored the iomediator modules into a package. Applied various code cleanups and fixes.
Version 0.93.10 <2017-02-17>
============================
- The scripting global storage now returns None if the requested key is not present.
- Improved the error messages in autokey-run. It is now clear that autokey has to run in the background for autokey-run to work.
- Added a LICENSE file containing the GPL v3 license terms.
Version 0.93.9 <2017-01-11>
===========================
Fixed a regression with setup.py install_requires keyword argument.
Updated the GitHub issue template.
Version 0.93.8 <2017-01-09>
===========================
- Readme updates
- Depend on Ubuntu appindicator
- Leverage libappindicator completely, fix "View script error"
Version 0.93.7 <2016-12-21>
===========================
This release contains various bug/crash fixes
- Renamed repository from autokey-py3 to autokey
- Moved the AutoKey source code out of src folder one level up.
- Removed donate button
- autokey-gtk script is now a setuptools generated entry point
- Require GTK 3.0 to fix autokey-gtk startup
- Updated various web links around the codebase
- New feature: Return the result of wait events in the iomediator module.
Version 0.93.6 <2016-08-13>
===========================
- Ensure Compatibility with official python-xlib
- Fixed several GTK related warnings
- GTK GUI: Add feature to trigger popupmenu items with letters, rather than numbers.
- Add an AUR link
Version 0.93.4 <2015-02-17>
===========================
Bugfix: Prevent clipboard related crashes with GTK3.
Version 0.93.3 <2015-02-20>
===========================
Bugfix for defining abbreviations by `@kuhanalog`_
.. _@kuhanalog: /~https://github.com/kuhanalog
Version 0.93.2 <2014-08-09>
===========================
Read user scripts with UTF-8 encoding.
Version 0.93.1 <2014-03-02>
===========================
Internal changes: Changed the data structure of the input stack.
Version 0.93.0 <2014-02-27 Thu>
===============================
Added functions “acknowledge_gnome_notification” and “move_to_pat”, more details `here`_.
.. _here: /~https://github.com/autokey/autokey/blob/master/new_features.rst
Version 0.92.0 <2014-02-21 Fri>
===============================
Added an interactive shell launcher, “autokey-shell”. “autokey-shell” allows you to run some AutoKey functions interactively. Read `this`_ for more details.
Version 0.91.0 <2014-02-14 Fri>
===============================
Added a new function “click_on_pat” for use in user scripts. See `this`_ for more details.
.. _this: /~https://github.com/autokey/autokey/blob/master/new_features.rst
First release <2014-01-31 Fri>
==============================
This describes some of the changes to the original AutoKey source code.
Python 3 related changes
------------------------
Python 3 is less tolerant of circular imports so some files were split into several files. Those pieces of the original have their file names prefixed with the original's.
Bug fixes
+++++++++
Eliminate possible deadlock.
Changed
.. code-block:: python
p = subprocess.Popen([…], stdout=subprocess.PIPE)
retCode = p.wait()
output = p.stdout.read()[:-1] # Drop trailing newline
to
.. code:: python
p = subprocess.Popen([…], stdout=subprocess.PIPE)
output = p.communicate()[0].decode()[:-1] # Drop trailing newline
retCode = p.returncode
The former may cause a deadlock, for more information, see `Python docs`_. This pattern appears several times in the source codes.
.. _Python docs: http://docs.python.org/3/library/subprocess.html#subprocess.Popen.wait
For a “gi.repository.Notify.Notification” object, test if method “attach_to_status_icon” exists before calling. After this fix, errors in user scripts will trigger a notification.
Respect XDG standard. Details `here`__.
__ https://code.google.com/p/autokey/issues/detail?id=266
Corrected a typo in manpage of autokey-run.
For the GTK GUI, after script error is viewed, tray icon is reverted back to original.
Other changes
+++++++++++++
In setup.py, the “/usr/” prefix to the directory names in the data_files argument were removed to allow for non-root install.
Removed the “WINDOWID” environment variable so that zenity is not tied to the window from which it was launched.
Modified the launcher and other files to allow for editable installs (“pip install -e”).
Added an “about” dialog for the Python 3 port.
Changed hyperlink for bug reports.