Skip to content
Merged
Show file tree
Hide file tree
Changes from 15 commits
Commits
Show all changes
85 commits
Select commit Hold shift + click to select a range
d0ba2f3
Change imports to Qt6
greghope667 Apr 3, 2023
78baa69
Changes for PyQt6 compatibility
greghope667 Apr 3, 2023
0020e77
Update tests for pyqt6
greghope667 Apr 3, 2023
e192159
Switch to pyqt6rc for ui files
greghope667 Apr 4, 2023
3ace7fe
Use new Icon() function to import svg
greghope667 Apr 4, 2023
d74ab50
Remove PyQt5 rcc usage
greghope667 Apr 4, 2023
388c201
Remove Qt5 from dependencies
greghope667 Apr 4, 2023
fcbc5c8
Add empty __init__ file for import detection in pyqt6rc
greghope667 Apr 4, 2023
2c7f162
More Qt5->Qt6 tweaks
greghope667 Apr 4, 2023
1652b03
Bump versions for building on Mac
greghope667 Apr 13, 2023
c428339
Fixes for CI system
greghope667 May 3, 2023
750870f
Use temporary qt6 plugin manager
greghope667 Jun 17, 2023
327a818
CI file updates
greghope667 Jun 17, 2023
e292cc0
Change icon code to allow imports from other modules
greghope667 Jun 28, 2023
6482889
UserRole -> ItemDataRole.UserRole
greghope667 Jul 13, 2023
359c02a
Merge branch 'master' of https://github.com/openstenoproject/plover i…
greghope667 Jul 18, 2023
d215bea
Add news fragment
greghope667 Jul 19, 2023
365f969
Merge remote-tracking branch 'origin/main' into pyqt6-migration
mkrnr Feb 2, 2025
a5901fd
Set plover-plugins-manager to 0.7.1 to match gregs version
mkrnr Feb 2, 2025
f9c5174
Revert changes to MANIFEST.in
mkrnr Feb 2, 2025
d96d602
Remove plover-plugins-manager dependency
mkrnr Feb 2, 2025
7c47798
Integrate plugins manager
mkrnr Feb 2, 2025
0121d46
Add new package to setup.cfg
mkrnr Feb 2, 2025
a4836ea
Fix paths and dependencies
mkrnr Feb 3, 2025
c585a3d
Add missing dist dependencies
mkrnr Feb 3, 2025
7605220
Fix plover_plugins install command
mkrnr Feb 5, 2025
bd4b1c0
Add exclude to MANIFEST
mkrnr Feb 5, 2025
e9a9962
Fix build warnings
mkrnr Feb 5, 2025
4d18359
Merge remote-tracking branch 'origin/main' into pyqt6-migration
mkrnr Feb 9, 2025
130a647
Merge branch 'main' into pyqt6-migration
mkrnr Feb 9, 2025
581654a
Bump PyQt6 to 6.5.0 for dark mode
mkrnr Feb 9, 2025
b7029b6
Fix plugins_manager imports
mkrnr Feb 9, 2025
e74dc3a
Remove QT_MAC_WANTS_LAYER workaround for mac
mkrnr Feb 9, 2025
3b5ed0e
Merge remote-tracking branch 'origin/main' into pyqt6-migration
mkrnr Feb 15, 2025
fb5c47b
Add news entry regarding the integration of plugins manager
mkrnr Feb 15, 2025
4511ecc
Update install_git_button to Qt6
mkrnr Feb 16, 2025
ffc8158
Merge remote-tracking branch 'origin/main' into pyqt6-migration
mkrnr Feb 18, 2025
911c64a
Implement unsupported feature in plugins manager
mkrnr Feb 22, 2025
765875b
Set version 5.0.0-alpha.1 and update maintainer
mkrnr Feb 22, 2025
dc6f15b
Revert generation of NEWS entry
mkrnr Feb 22, 2025
d8e2b2b
Clear github actions cache
mkrnr Feb 23, 2025
7eca10b
Regenerate ci.yml
mkrnr Feb 23, 2025
d6af3c4
Rewrite unsupported plugins logic and hard-code plover version for now
mkrnr Feb 24, 2025
b714158
Set version to 5.0.0.dev1 to follow PEP 440
mkrnr Feb 27, 2025
1d8545d
Fix setup.get_version to only extend version and not replace by tag
mkrnr Feb 27, 2025
7e94602
Replace pyqt6rc with PyQt6.uic
mkrnr Feb 28, 2025
656f19a
Migrate PyQt6 to PySide6
mkrnr Mar 1, 2025
a57e5bc
Fix GitHub actions
mkrnr Mar 2, 2025
6a7356b
Fix GitHub actions
mkrnr Mar 2, 2025
0bd7bc8
Fix pip in GitHub actions
mkrnr Mar 2, 2025
d39caca
Fix GitHub actions
mkrnr Mar 2, 2025
a6c8269
Reset github actions cache
mkrnr Mar 2, 2025
d94dd25
Fix Qt resource path generation to remove workaround
mkrnr Mar 3, 2025
0cc7d43
Fix MANIFEST.in
mkrnr Mar 3, 2025
1d4adf3
Remove setup-python parameter from install-qt-action
mkrnr Mar 3, 2025
8ff5d96
Generate ci workflows
mkrnr Mar 3, 2025
be0850b
Reorder GitHub actions to make sure correct python version
mkrnr Mar 3, 2025
c2f1e3e
Add try except for macOS NotificationHandler
mkrnr Mar 3, 2025
bdbcd9f
Fix logging for macOS
mkrnr Mar 4, 2025
7be2441
Fix resource paths for tray icon and dictionaries widget
mkrnr Mar 4, 2025
ab79a2d
Update slot method names and add annotations
mkrnr Mar 6, 2025
a7a775a
Extend developers list
mkrnr Mar 6, 2025
3457532
Update pyobjc and PyYAML versions
mkrnr Mar 6, 2025
ea0d78b
Make WindowState a mixin class
mkrnr Mar 9, 2025
f08c107
Fix font selection
mkrnr Mar 9, 2025
0b32109
Remove printout of notifications when no notification center is avail…
mkrnr Mar 9, 2025
6ee072c
Remove Qt build dependency
mkrnr Mar 11, 2025
185557d
Merge remote-tracking branch 'origin/main' into pyqt6-migration
mkrnr Mar 11, 2025
b42b297
Replace PySide6 dependency with PySide6-Essentials
mkrnr Mar 11, 2025
cde483f
Fix open and save calls in dictionaries_widget
mkrnr Mar 13, 2025
ee9b392
Fix drag and drop in dictionaries widget
mkrnr Mar 24, 2025
a83c9bd
Fix checkbox in dictionaries widget
mkrnr Mar 24, 2025
5753a1b
Fix test_dictionaries_widget and bump pgkinfo
mkrnr Mar 24, 2025
a299989
Bump PySide6-Essentials to 6.5.3
mkrnr Mar 31, 2025
ea8694c
Revert "Bump PySide6-Essentials to 6.5.3"
mkrnr Mar 31, 2025
4a42bb9
Fix windows NotificationHandler and handler method name
mkrnr Apr 1, 2025
e96a78b
Clean up macOS NotificationHandler
mkrnr Apr 1, 2025
cc977a9
Update method name in DBusNotificationHandler
mkrnr Apr 5, 2025
1af4e59
Remove wayland from linux appimage blacklist
mkrnr Apr 9, 2025
49a384b
Add back plugins_install tox command
mkrnr Apr 9, 2025
5361df4
Remove Strip 32-bit support section to make bdist_app work on apple s…
mkrnr Apr 10, 2025
78dfcca
Update Environment setup doc
mkrnr Apr 16, 2025
1443ee9
Ignore doc folder and markdown files in GH actions
mkrnr Apr 16, 2025
677ee3b
Update doc file to test github actions ignore
mkrnr Apr 16, 2025
012d964
Revert "Ignore doc folder and markdown files in GH actions"
mkrnr Apr 16, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 14 additions & 11 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -36,15 +36,15 @@ jobs:
id: set_cache
run: |
job_cache_extra_deps=(); job_id=test_linux; job_name='Test (Linux)'; job_needs=(); job_os=Linux; job_platform=ubuntu-22.04; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_linux_py-3.9_ubuntu-22.04; job_skip_cache_path=.skip_cache_test_linux; job_skiplists=(job_test os_linux); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=Linux; analyze_set_job_skip_cache_key
job_cache_extra_deps=(osx/deps.sh); job_id=test_macos; job_name='Test (macOS)'; job_needs=(); job_os=macOS; job_platform=macos-10.15; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_macos_py-3.9_macos-10.15; job_skip_cache_path=.skip_cache_test_macos; job_skiplists=(job_test os_macos); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=macOS; analyze_set_job_skip_cache_key
job_cache_extra_deps=(osx/deps.sh); job_id=test_macos; job_name='Test (macOS)'; job_needs=(); job_os=macOS; job_platform=macos-latest; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_macos_py-3.9_macos-latest; job_skip_cache_path=.skip_cache_test_macos; job_skiplists=(job_test os_macos); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=macOS; analyze_set_job_skip_cache_key
job_cache_extra_deps=(); job_id=test_windows; job_name='Test (Windows)'; job_needs=(); job_os=Windows; job_platform=windows-2019; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_windows_py-3.9_windows-2019; job_skip_cache_path=.skip_cache_test_windows; job_skiplists=(job_test os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=Windows; analyze_set_job_skip_cache_key
job_cache_extra_deps=(); job_id=test_python_37; job_name='Test (Python 3.7)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.7; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_python_37_py-3.7_ubuntu-latest; job_skip_cache_path=.skip_cache_test_python_37; job_skiplists=(job_test os_linux os_macos os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant='Python 3.7'; analyze_set_job_skip_cache_key
job_cache_extra_deps=(); job_id=test_python_38; job_name='Test (Python 3.8)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.8; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_python_38_py-3.8_ubuntu-latest; job_skip_cache_path=.skip_cache_test_python_38; job_skiplists=(job_test os_linux os_macos os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant='Python 3.8'; analyze_set_job_skip_cache_key
job_cache_extra_deps=(); job_id=test_python_310; job_name='Test (Python 3.10)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.10; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_python_310_py-3.10_ubuntu-latest; job_skip_cache_path=.skip_cache_test_python_310; job_skiplists=(job_test os_linux os_macos os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant='Python 3.10'; analyze_set_job_skip_cache_key
job_cache_extra_deps=(); job_id=test_qt_gui; job_name='Test (Qt GUI)'; job_needs=(); job_os=Linux; job_platform=ubuntu-22.04; job_python=3.9; job_reqs=(reqs/dist.txt reqs/dist_extra_gui_qt.txt reqs/test.txt); job_skip_cache_name=skip_test_qt_gui_py-3.9_ubuntu-22.04; job_skip_cache_path=.skip_cache_test_qt_gui; job_skiplists=(job_test_gui_qt); job_test_args=test/gui_qt; job_type=test_gui_qt; job_variant='Qt GUI'; analyze_set_job_skip_cache_key
job_cache_extra_deps=(); job_id=test_packaging; job_name='Test (Packaging)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.9; job_reqs=(reqs/packaging.txt reqs/setup.txt); job_skip_cache_name=skip_test_packaging_py-3.9_ubuntu-latest; job_skip_cache_path=.skip_cache_test_packaging; job_skiplists=(job_test_packaging); job_type=test_packaging; job_variant=Packaging; analyze_set_job_skip_cache_key
job_cache_extra_deps=('reqs/dist_*.txt' linux/appimage/deps.sh); job_id=build_linux; job_name='Build (Linux)'; job_needs=(test_linux); job_os=Linux; job_platform=ubuntu-22.04; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_linux_py-3.9_ubuntu-22.04; job_skip_cache_path=.skip_cache_build_linux; job_skiplists=(job_build os_linux); job_type=build; job_variant=Linux; analyze_set_job_skip_cache_key
job_cache_extra_deps=('reqs/dist_*.txt' osx/deps.sh); job_id=build_macos; job_name='Build (macOS)'; job_needs=(test_macos); job_os=macOS; job_platform=macos-10.15; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_macos_py-3.9_macos-10.15; job_skip_cache_path=.skip_cache_build_macos; job_skiplists=(job_build os_macos); job_type=build; job_variant=macOS; analyze_set_job_skip_cache_key
job_cache_extra_deps=('reqs/dist_*.txt' osx/deps.sh); job_id=build_macos; job_name='Build (macOS)'; job_needs=(test_macos); job_os=macOS; job_platform=macos-latest; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_macos_py-3.9_macos-latest; job_skip_cache_path=.skip_cache_build_macos; job_skiplists=(job_build os_macos); job_type=build; job_variant=macOS; analyze_set_job_skip_cache_key
job_cache_extra_deps=('reqs/dist_*.txt' windows/dist_deps.sh); job_id=build_windows; job_name='Build (Windows)'; job_needs=(test_windows); job_os=Windows; job_platform=windows-2019; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_windows_py-3.9_windows-2019; job_skip_cache_path=.skip_cache_build_windows; job_skiplists=(job_build os_windows); job_type=build; job_variant=Windows; analyze_set_job_skip_cache_key

- name: Check skip cache for Test (Linux)
Expand Down Expand Up @@ -142,15 +142,15 @@ jobs:
run: |
analyze_set_release_info
job_cache_extra_deps=(); job_id=test_linux; job_name='Test (Linux)'; job_needs=(); job_os=Linux; job_platform=ubuntu-22.04; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_linux_py-3.9_ubuntu-22.04; job_skip_cache_path=.skip_cache_test_linux; job_skiplists=(job_test os_linux); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=Linux; analyze_set_job_skip_job
job_cache_extra_deps=(osx/deps.sh); job_id=test_macos; job_name='Test (macOS)'; job_needs=(); job_os=macOS; job_platform=macos-10.15; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_macos_py-3.9_macos-10.15; job_skip_cache_path=.skip_cache_test_macos; job_skiplists=(job_test os_macos); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=macOS; analyze_set_job_skip_job
job_cache_extra_deps=(osx/deps.sh); job_id=test_macos; job_name='Test (macOS)'; job_needs=(); job_os=macOS; job_platform=macos-latest; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_macos_py-3.9_macos-latest; job_skip_cache_path=.skip_cache_test_macos; job_skiplists=(job_test os_macos); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=macOS; analyze_set_job_skip_job
job_cache_extra_deps=(); job_id=test_windows; job_name='Test (Windows)'; job_needs=(); job_os=Windows; job_platform=windows-2019; job_python=3.9; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_windows_py-3.9_windows-2019; job_skip_cache_path=.skip_cache_test_windows; job_skiplists=(job_test os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant=Windows; analyze_set_job_skip_job
job_cache_extra_deps=(); job_id=test_python_37; job_name='Test (Python 3.7)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.7; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_python_37_py-3.7_ubuntu-latest; job_skip_cache_path=.skip_cache_test_python_37; job_skiplists=(job_test os_linux os_macos os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant='Python 3.7'; analyze_set_job_skip_job
job_cache_extra_deps=(); job_id=test_python_38; job_name='Test (Python 3.8)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.8; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_python_38_py-3.8_ubuntu-latest; job_skip_cache_path=.skip_cache_test_python_38; job_skiplists=(job_test os_linux os_macos os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant='Python 3.8'; analyze_set_job_skip_job
job_cache_extra_deps=(); job_id=test_python_310; job_name='Test (Python 3.10)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.10; job_reqs=(reqs/dist.txt reqs/test.txt); job_skip_cache_name=skip_test_python_310_py-3.10_ubuntu-latest; job_skip_cache_path=.skip_cache_test_python_310; job_skiplists=(job_test os_linux os_macos os_windows); job_test_args='-p no:pytest-qt --ignore=test/gui_qt'; job_type=test; job_variant='Python 3.10'; analyze_set_job_skip_job
job_cache_extra_deps=(); job_id=test_qt_gui; job_name='Test (Qt GUI)'; job_needs=(); job_os=Linux; job_platform=ubuntu-22.04; job_python=3.9; job_reqs=(reqs/dist.txt reqs/dist_extra_gui_qt.txt reqs/test.txt); job_skip_cache_name=skip_test_qt_gui_py-3.9_ubuntu-22.04; job_skip_cache_path=.skip_cache_test_qt_gui; job_skiplists=(job_test_gui_qt); job_test_args=test/gui_qt; job_type=test_gui_qt; job_variant='Qt GUI'; analyze_set_job_skip_job
job_cache_extra_deps=(); job_id=test_packaging; job_name='Test (Packaging)'; job_needs=(); job_os=Linux; job_platform=ubuntu-latest; job_python=3.9; job_reqs=(reqs/packaging.txt reqs/setup.txt); job_skip_cache_name=skip_test_packaging_py-3.9_ubuntu-latest; job_skip_cache_path=.skip_cache_test_packaging; job_skiplists=(job_test_packaging); job_type=test_packaging; job_variant=Packaging; analyze_set_job_skip_job
job_cache_extra_deps=('reqs/dist_*.txt' linux/appimage/deps.sh); job_id=build_linux; job_name='Build (Linux)'; job_needs=(test_linux); job_os=Linux; job_platform=ubuntu-22.04; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_linux_py-3.9_ubuntu-22.04; job_skip_cache_path=.skip_cache_build_linux; job_skiplists=(job_build os_linux); job_type=build; job_variant=Linux; analyze_set_job_skip_job
job_cache_extra_deps=('reqs/dist_*.txt' osx/deps.sh); job_id=build_macos; job_name='Build (macOS)'; job_needs=(test_macos); job_os=macOS; job_platform=macos-10.15; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_macos_py-3.9_macos-10.15; job_skip_cache_path=.skip_cache_build_macos; job_skiplists=(job_build os_macos); job_type=build; job_variant=macOS; analyze_set_job_skip_job
job_cache_extra_deps=('reqs/dist_*.txt' osx/deps.sh); job_id=build_macos; job_name='Build (macOS)'; job_needs=(test_macos); job_os=macOS; job_platform=macos-latest; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_macos_py-3.9_macos-latest; job_skip_cache_path=.skip_cache_build_macos; job_skiplists=(job_build os_macos); job_type=build; job_variant=macOS; analyze_set_job_skip_job
job_cache_extra_deps=('reqs/dist_*.txt' windows/dist_deps.sh); job_id=build_windows; job_name='Build (Windows)'; job_needs=(test_windows); job_os=Windows; job_platform=windows-2019; job_python=3.9; job_reqs=(reqs/build.txt reqs/setup.txt); job_skip_cache_name=skip_build_windows_py-3.9_windows-2019; job_skip_cache_path=.skip_cache_build_windows; job_skiplists=(job_build os_windows); job_type=build; job_variant=Windows; analyze_set_job_skip_job

outputs:
Expand Down Expand Up @@ -241,7 +241,7 @@ jobs:
test_macos:

name: Test (macOS)
runs-on: macos-10.15
runs-on: macos-latest
needs: [analyze, ]
if: >-
!cancelled()
Expand All @@ -254,7 +254,7 @@ jobs:

- name: Set cache name
id: set_cache
run: setup_cache_name '3.9' 'macos-10.15'
run: setup_cache_name '3.9' 'macos-latest'

- name: Setup cache
uses: actions/cache@v2
Expand Down Expand Up @@ -554,6 +554,9 @@ jobs:
- name: Setup pip options
run: setup_pip_options

- name: Install system dependencies
run: apt_get_install libdbus-1-dev libdbus-glib-1-dev libudev-dev libusb-1.0-0-dev libegl-dev

- name: Setup Python environment
run: setup_python_env -c reqs/constraints.txt -r reqs/dist.txt -r reqs/dist_extra_gui_qt.txt -r reqs/test.txt
- name: Build UI
Expand Down Expand Up @@ -667,7 +670,7 @@ jobs:

- name: List cache contents
run: list_cache

outputs:
version: ${{ steps.set_version.outputs.version }}
# }}}
Expand Down Expand Up @@ -710,7 +713,7 @@ jobs:
run: setup_pip_options

- name: Install system dependencies
run: apt_get_install libdbus-1-dev libdbus-glib-1-dev libudev-dev libusb-1.0-0-dev
run: apt_get_install libdbus-1-dev libdbus-glib-1-dev libudev-dev libusb-1.0-0-dev libegl-dev

- name: Setup Python environment
run: setup_python_env -c reqs/constraints.txt -r reqs/build.txt -r reqs/setup.txt
Expand Down Expand Up @@ -749,7 +752,7 @@ jobs:
build_macos:

name: Build (macOS)
runs-on: macos-10.15
runs-on: macos-latest
needs: [analyze, test_macos]
if: >-
!cancelled()
Expand All @@ -766,7 +769,7 @@ jobs:

- name: Set cache name
id: set_cache
run: setup_cache_name '3.9' 'macos-10.15'
run: setup_cache_name '3.9' 'macos-latest'

- name: Setup cache
uses: actions/cache@v2
Expand Down Expand Up @@ -958,4 +961,4 @@ jobs:
run: publish_github_release
# }}}

# vim: foldmethod=marker foldlevel=0
# vim: foldmethod=marker foldlevel=0
2 changes: 1 addition & 1 deletion .github/workflows/ci/workflow_context.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ vars:
variant: macOS
python: '3.9'
os: macOS
platform: macos-10.15
platform: macos-latest

- &dist_win
variant: Windows
Expand Down
6 changes: 3 additions & 3 deletions .github/workflows/ci/workflow_template.yml
Original file line number Diff line number Diff line change
Expand Up @@ -127,9 +127,9 @@ jobs:
run: setup_osx_python '<@ j.python @>'

<% endif %>
<% if j.type == 'build' and j.os == 'Linux' %>
<% if j.type in ['build', 'test_gui_qt'] and j.os == 'Linux' %>
- name: Install system dependencies
run: apt_get_install libdbus-1-dev libdbus-glib-1-dev libudev-dev libusb-1.0-0-dev
run: apt_get_install libdbus-1-dev libdbus-glib-1-dev libudev-dev libusb-1.0-0-dev libegl-dev

<% endif %>
- name: Setup Python environment
Expand Down Expand Up @@ -256,7 +256,7 @@ jobs:
- name: List cache contents
run: list_cache
<% if j.type == 'test_packaging' %>

outputs:
version: ${{ steps.set_version.outputs.version }}
<% endif %>
Expand Down
7 changes: 1 addition & 6 deletions MANIFEST.in
Original file line number Diff line number Diff line change
Expand Up @@ -28,10 +28,5 @@ include test/*.py
include test/gui_qt/*.py
include tox.ini
include windows/*
# Exclude: CI/Git/GitHub specific files,
# as well as generated Python files (UI).
exclude .gitignore
exclude plover/gui_qt/*_rc.py

exclude plover/gui_qt/*_ui.py
exclude plover/gui_qt/.gitignore
prune .github
33 changes: 15 additions & 18 deletions linux/appimage/blacklist.txt
Original file line number Diff line number Diff line change
Expand Up @@ -31,16 +31,14 @@
# Plover.
:usr/lib/python${pyversion}/site-packages/plover
gui_qt/*.ui
gui_qt/resources
messages/**/*.po
messages/plover.pot

# PyQt5.
# PyQt6.
:usr/bin
pylupdate5
pyrcc5
pyuic5
:usr/lib/python${pyversion}/site-packages/PyQt5
pylupdate6
pyuic6
:usr/lib/python${pyversion}/site-packages/PyQt6
**/*Designer*
**/*[Hh]elp*
**/*[Qq]ml*
Expand All @@ -49,19 +47,18 @@
**/*[Ww]ayland*
**/*[Ww]eb[Ee]ngine*
bindings
Qt5/plugins/egldeviceintegrations
Qt5/plugins/geoservices
Qt5/plugins/platforms/libqeglfs.so
Qt5/plugins/platforms/libqlinuxfb.so
Qt5/plugins/platforms/libqminimal.so
Qt5/plugins/platforms/libqminimalegl.so
Qt5/plugins/platforms/libqoffscreen.so
Qt5/plugins/platforms/libqvnc.so
Qt5/plugins/platforms/libqwebgl.so
Qt5/plugins/sceneparsers
Qt5/plugins/webview
Qt6/plugins/egldeviceintegrations
Qt6/plugins/geoservices
Qt6/plugins/platforms/libqeglfs.so
Qt6/plugins/platforms/libqlinuxfb.so
Qt6/plugins/platforms/libqminimal.so
Qt6/plugins/platforms/libqminimalegl.so
Qt6/plugins/platforms/libqoffscreen.so
Qt6/plugins/platforms/libqvnc.so
Qt6/plugins/platforms/libqwebgl.so
Qt6/plugins/sceneparsers
Qt6/plugins/webview
pylupdate*
pyrcc*
uic

# vim: ft=config
48 changes: 23 additions & 25 deletions osx/app_resources/dist_blacklist.txt
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,8 @@
turtle*
**/*.exe
*/test*
# PyQt5.
:lib/python$python_base_version/site-packages/PyQt5
# PyQt6.
:lib/python$python_base_version/site-packages/PyQt6
**/*AxContainer*
**/*Bluetooth*
**/*CLucene*
Expand All @@ -35,34 +35,32 @@
**/*Serial*
**/*Sql*
**/*Test*
Qt5/plugins/audio
Qt5/plugins/bearer
Qt5/plugins/generic
Qt5/plugins/geoservices
Qt5/plugins/mediaservice
Qt5/plugins/playlistformats
Qt5/plugins/position
Qt5/plugins/printsupport
Qt5/plugins/sceneparsers
Qt5/plugins/sensor*
Qt5/plugins/sqldrivers
Qt5/qml
Qt5/resources
Qt5/translations/qt_help_*
Qt5/translations/qtconnectivity_*
Qt5/translations/qtdeclarative_*
Qt5/translations/qtlocation_*
Qt5/translations/qtmultimedia_*
Qt5/translations/qtquick*
Qt5/translations/qtserialport_*
Qt5/translations/qtwebsockets_*
Qt6/plugins/audio
Qt6/plugins/bearer
Qt6/plugins/generic
Qt6/plugins/geoservices
Qt6/plugins/mediaservice
Qt6/plugins/playlistformats
Qt6/plugins/position
Qt6/plugins/printsupport
Qt6/plugins/sceneparsers
Qt6/plugins/sensor*
Qt6/plugins/sqldrivers
Qt6/qml
Qt6/resources
Qt6/translations/qt_help_*
Qt6/translations/qtconnectivity_*
Qt6/translations/qtdeclarative_*
Qt6/translations/qtlocation_*
Qt6/translations/qtmultimedia_*
Qt6/translations/qtquick*
Qt6/translations/qtserialport_*
Qt6/translations/qtwebsockets_*
pylupdate*
pyrcc*
uic
# Plover.
:lib/python$python_base_version/site-packages/plover
gui_qt/*.ui
gui_qt/resources
messages/**/*.po
messages/plover.pot

Expand Down
2 changes: 1 addition & 1 deletion plover/gui_qt/about_dialog.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@

import re

from PyQt5.QtWidgets import QDialog
from PyQt6.QtWidgets import QDialog

import plover

Expand Down
4 changes: 2 additions & 2 deletions plover/gui_qt/add_translation_dialog.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
from PyQt5.QtWidgets import QDialogButtonBox
from PyQt6.QtWidgets import QDialogButtonBox

from plover import _

Expand Down Expand Up @@ -29,7 +29,7 @@ def __init__(self, engine, dictionary_path=None):
self.finished.connect(self.save_state)

def on_mapping_valid(self, valid):
self.buttonBox.button(QDialogButtonBox.Ok).setEnabled(valid)
self.buttonBox.button(QDialogButtonBox.StandardButton.Ok).setEnabled(valid)

def on_config_changed(self, config_update):
if 'translation_frame_opacity' in config_update:
Expand Down
8 changes: 4 additions & 4 deletions plover/gui_qt/add_translation_widget.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
from html import escape as html_escape
from os.path import split as os_path_split

from PyQt5.QtCore import QEvent, pyqtSignal
from PyQt5.QtWidgets import QApplication, QWidget
from PyQt6.QtCore import QEvent, pyqtSignal
from PyQt6.QtWidgets import QApplication, QWidget

from plover import _
from plover.misc import shorten_path
Expand Down Expand Up @@ -106,12 +106,12 @@ def select_dictionary(self, dictionary_path):
self._update_items()

def eventFilter(self, watched, event):
if event.type() == QEvent.FocusIn:
if event.type() == QEvent.Type.FocusIn:
if watched == self.strokes:
self._focus_strokes()
elif watched == self.translation:
self._focus_translation()
elif event.type() == QEvent.FocusOut:
elif event.type() == QEvent.Type.FocusOut:
if watched in (self.strokes, self.translation):
self._unfocus()
return False
Expand Down
Loading