Qt for Python Development Notes: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
mNo edit summary
 
(638 intermediate revisions by 14 users not shown)
Line 1: Line 1:
== 2018 ==
[[Category:Qt for Python]]


==== 22. March 2018 ====
==2024==
- Topics to cover:
    - Release process (do we follow Qt?) 


==== 15. March 2018 ====
===13. June 2024===
- Fix to create 3.6 Linux wheels under review.


==== 08. March 2018 ====
* General
- msvcrt.dll to be shipped on Windows
** Python 3.9 story: the decision was made without considering that 3.9 is still getting security releases, so we have decided to keep supporting Python 3.9 for PySide 6.8 LTS, but we might drop it in the middle of some bug-fix releases.
- wheel snapshots are automatically generated
*** Things that are considered to support certain python versions are: Internal CI Python versions for each OS, Python version lifecycle https://devguide.python.org/versions/, features that will improve user experience from new versions.
  - start with public availability under http://download.qt.io/snapshots/ci/
*** Python stubs (pyi) might be compatible with 3.10+
  - snapshots to public pypi server under discussions
** Qt Group is sponsoring EuroPython 2024: and we will give a talk!
- discussion on how to increase value of official pyside mailing list http://lists.qt-project.org/mailman/listinfo/pyside
* Infra & Releases
- looking at build issues on Windows (improving error handling)
** 6.7.2 packages are ready to be released.
- Participation in Python User Group meeting in Berlin (https://www.meetup.com/Python-Users-Berlin-PUB/events/xhqwhpyxfblb/)
** Boot2Qt had a few issues that were solved.
- [https://bugreports.qt.io/browse/PYSIDE-595 PYSIDE-595] - Heap Type conversions ongoing
** Starting process to test windows arm64 (discussion around libclang)
  - test bed created for easier development
** Nightly builds:
- [https://bugreports.qt.io/browse/PYSIDE-363 Documentation]
*** Possible solution for linux and macOS arm64 android builds.
  -> Managed to make libxml, libxsl an optional dependency falling back to QtXmlPatterns (despite [https://bugreports.qt.io/browse/QTBUG-66925 QTBUG-66925])
*** Maybe also for non-unity builds? it has been failing in some corner cases.
  -> Small fixes to doc modifications
*** We could have dev-android branch so we don't block the normal dev development.
  -> Fix class inheritance diagrams for nested classes
*** nightly builds merge automatically if everything passes.
*** PyPy integrations might join a similar configuration as well.
* Bugs & Features
** Android wheels from macOS host through coin successful. Assembling the final patch. Coin still running tests for an Android build and error-ing still needs to be resolved.
** [https://bugreports.qt.io/browse/PYSIDE-2702 PYSIDE-2702] - Flatpak base app implementation started.
** [https://bugreports.qt.io/browse/PYSIDE-2781 PYSIDE-2781] - pyside6-deploy failure investigation ongoing. Could be a Nuitka issue. User using the latest Nuitka.
** Working on improve our typing implementations.
** QtAsyncio: internal presentation including the theory behind and some live examples.
** Lazy load: disabled for PyPy, fixing some shiboken-tests
** QtScrypt: development continues
** [https://bugreports.qt.io/browse/PYSIDE-2780 PYSIDE-2780] refcount bug in the lazy import fixed
** [https://bugreports.qt.io/browse/PYSIDE-2751 PYSIDE-2751] 3.13 compatibility patches are ready, nogil under development
** [https://bugreports.qt.io/browse/PYSIDE-2701 PYSIDE-2701] reduction of binary sizes under investigation, estimating the achievable reduction


==== 01. March 2018 ====
===06. June 2024===
- automatic snapshot process almost in place (pending reviews) (RTA to follow)
- general bug fixing (including build and version problems)
- most community Pyside1 pages point to official Pyside 2 (Qt for Python) wiki pages
- [https://bugreports.qt.io/browse/PYSIDE-595 PYSIDE-595] - Heap Type conversions ongoing
- documentation improving
  -> class diagrams being generated
  -> missing links and references
  -> dependencies to qdoc bugs
  -> snapshot process in works
- added support for scoped enums in pyside
- Important things discussed:
  - PySide2 versioning (current proposal WIP patch at https://codereview.qt-project.org/#/c/221767/)
    - Do official releases follow Qt branch names? -
        -> yes (minor release of Pyside is bound to same minor release of Qt
        -> patch level version may differ
    - Will we have snapshots, and if so, will they be uploaded to pip? How will we handle snapshot versions?
        -> tentative yes, if public pip server supports snapshots Pyside should be good citizen
    - alpha / beta / RC versioning?
        -> Pyside should follow the Qt schema
    - Probably need to take into account PEPs for versions pushed to Pypi.
    - Shiboken / PySide2 versions in sync?
        -> yes, they should be in sync
    - Will we specify a version for 5.6 branch?
        -> yes, but no packages being made
    - Are we sticking to the package name PySide2, but follow Qt 5.x versions as PySide2 versions?
        -> Pyside2_5.11.0 as in https://codereview.qt-project.org/#/c/221767/
  - Do we want to deploy msvcrt dlls into Windows packages?
    -> needs more research - is it really needed ?
  - Do we want to ship debug symbols for Qt inside the PySide2 packages?
    -> not for now
  - Do we want to ship debug Qt shared libraries for macOS packages? (not possible on Windows, not applicable on Linux afaik).
    -> not for now
  - How will the pip upload process look like? Manual uploads? Who takes care of it?
    -> Qt release team will take care of it
  - Current branching policies:
    -> 5.6 branch stops being merged into 5.9 (after pending patches have merged) -> cherry-pick mode
    -> 5.9 is base line for patches and being forward merged to 5.11
    -> no packages from 5.9 & 5.6 (interested parties need to get it from git)
    -> 5.11 becomes branch for first TP
    -> dev is feature development
    -> all first TP release related patches go to 5.9 (and 5.11 subsequently)


==== 22. February 2018 ====
* General
- dev branch is still/again broken in CI, seems like pyside issues
** Maintenance work next week will keep the CI offline (Monday morning, phase I + Wednesday, phase II)
- changes to create automatic snapshots out of CI is still under review
** PySide 6.8 will support Python 3.10+
- Numerous small fixes to the [https://bugreports.qt.io/browse/PYSIDE-363 doc] generation, significantly bringing down the number of documentation warnings
** Must read https://peps.python.org/pep-0741/
- Massaged build rules to improve built packages
* Infra & Releases
    - Removed unnecessary _utils.py file [https://bugreports.qt.io/browse/PYSIDE-600 PYSIDE-600]
** Some issues with the macOS CI units.
    - Changed wheel package names to contain both PySide2 version and Qt version against which it was built [https://bugreports.qt.io/browse/PYSIDE-613 PYSIDE-613]
** Local raspberry pi 4 (aarch64) for testing: 10.9.78.82
    - Finally got libclang to be deployed into packages
** qtpip 0.1.2 release: mostly issues around the commercial version tag and the usage of '+' and '.'
    - Improved build process not to copy unnecessary symlinks and duplicating libraries when creating wheel (so that you don't get 3x size increase because of 3x number of WebEngine libraries) [https://bugreports.qt.io/browse/PYSIDE-495 PYSIDE-495]
** 6.5.6 commercial LTS was released.
    - Fixed wheel package names to contain correct minimum deployment target with which macOS was built with (on further analysis, this will need further improvement) [https://bugreports.qt.io/browse/PYSIDE-612 PYSIDE-612]
** 6.7.2 release will happen soon (due to an issue with designer)
    - Fixed rpath handling for QtWebEngineProcess when creating standalone packages on macOS [https://bugreports.qt.io/browse/PYSIDE-605 PYSIDE-605]
** the Python 3.9 macOS CI configuration will be updated to 3.11, and the windows with 3.11 will be updated to 3.12
- Added CMake build rules for scriptable application example [https://bugreports.qt.io/browse/PYSIDE-597 PYSIDE-597]
* Bugs & Features
- Investigated and fixed a heap corruption bug in a test that caused constant crashes on macOS CI runs
** https://bugreports.qt.io/browse/PYSIDE-2622 - Standalone mode for Deployment as per many requests from users
- Reduced number of warnings when running shiboken to create user bindings (like scriptable application example) [https://bugreports.qt.io/browse/PYSIDE-587 PYSIDE-587]
** Deployment tests fixed with a custom PySide6 build. There might be corner cases that were missed.
- [https://bugreports.qt.io/browse/PYSIDE-595 PYSIDE-595]: Making slow progress, still debugging. It's a difficult process, but assumption is that it will work.
** https://codereview.qt-project.org/c/pyside/pyside-setup/+/537466 ready, but waiting for macOS x86_64 to update Python to 3.11 - https://codereview.qt-project.org/c/qt/qt5/+/565565/4 (Thanks Simo)
- Havent's merge [https://codereview.qt-project.org/#/c/220083/ this new patch] because we should be 200% sure it's properly working.
** Patches ready for updating python syntax to drop typing.Optional (and use | instead) that will go in once we drop 3.9
- Working on a few bugs [https://bugreports.qt.io/browse/PYSIDE-106 PYSIDE-106] [https://bugreports.qt.io/browse/PYSIDE-570 PYSIDE-570]
** Preparing presentation and improvements to QtAsyncio
- One of the bugs [https://bugreports.qt.io/browse/PYSIDE-611 PYSIDE-611] was valid only for 5.6, but I noticed a strange behaviour on 5.9, so I will keep working on it, even after we move 5.6 to cherry pick mode.
** PYSIDE-2440 will be prepared.
** op codes changing in Python, is altering some of our internal implementation, like the forgiveness mode.
** https://bugreports.qt.io/browse/PYSIDE-2751 planned work for the no-gil feature in Python 3.13
** smart pointers with lazy loading were not working, but a fix was merged.
** Qt Designer had a regression that motivated 6.7.2
** Qt 6.8 adaption taking a lot of work due to doc changes and QtGraphs
** PYSIDE-2772 issue ended up being a user problem


==== 15. February 2018 ====
===30. May 2024===
- CI broken, 5.6 & dev branch broken, 5.9 just got working again
- first TP will be 5.11 based (needs 5.11 git branches, 5.6 branch goes into cherry-pick mode, 5.9 branch remains main target)
- more modules added to doc, qt3d & qtquick has some special handling
- snippet work ongoing
- snapshot generation on the agenda
- lots of bug fixing e.g.: [https://bugreports.qt.io/browse/PYSIDE-104 PYSIDE-104]
- [https://bugreports.qt.io/browse/PYSIDE-560 PYSIDE-560]


==== 8. February 2018 ====
* General
- Looking through previous EuroPython talks to write a proposal for this year.         
** PySide 6.8 will most probably support Python 3.10+
- Working on a few bugs (fixed a couple related to objects references),               
** Evaluating arm64 wheels for Windows
    - that sadly will open new issues with memory management. A further analysis on this matter could improve the current memory leaks on PySide.                          
* Infra & Releases
- Trying to "organise" a little the typesystem XML files.                             
** Discussion about the Qt for Python in boot2qt
- Working on [https://bugreports.qt.io/browse/PYSIDE-104 PYSIDE-104] that ended up being a general issue on PySide about a proper verification between slots and signals arguments, to find the best match.
** PyPy releases has been on hold due to some internal CI problems.
- Merged a few build related changes in 5.6
** Commercial packages will now be available on the following day after community packages.
  - Pending change for [https://bugreports.qt.io/browse/PYSIDE-593 PYSIDE-593]
** qtpip is planned to support aarch64
  - Pending change for [https://bugreports.qt.io/browse/PYSIDE-605 PYSIDE-605]
** 6.5.6 commercial lts will be released next week
  - Merged changes for [https://bugreports.qt.io/browse/PYSIDE-603 PYSIDE-603] and [https://bugreports.qt.io/browse/PYSIDE-604 PYSIDE-604]
* Bugs & Features
- Investigated and attached minimal reproducible example for [https://bugreports.qt.io/browse/PYSIDE-585 PYSIDE-585]
** [https://bugreports.qt.io/browse/PYSIDE-2766 PYSIDE-2766] - Android wheels from macOS successful. Patches for review.
- Investigated some macOS build related aspects for package release
*** Testing a sample app now + Modifying https://codereview.qt-project.org/c/pyside/pyside-setup/+/537466
- 5.6 CI is unblocked, but 5.9 CI is blocked due to qtbase issues (version bumping)
** 6.8 adaption is in progress [qtcharts is a bit unstable]
- [https://bugreports.qt.io/browse/PYSIDE-560 PYSIDE-560] waiting for view
** c++20 research to improve libshiboken
- [https://bugreports.qt.io/browse/PYSIDE-595 PYSIDE-595] work ongoing, not ready yet
** qtscrypt progressing to support signal/slot
- [https://bugreports.qt.io/browse/PYSIDE-363 PYSIDE-363]  Documentation: Fixed images, fix handling of qdocconf files  that contain several modules. Looking at snippet resolution.
** dev will support python 3.10+ [for 6.8+]
- Problems with Qt3D due to refactoring of Qt3Dextras in 5.10. Pushed  [https://codereview.qt-project.org/#/c/219105/ patch] suggestion.
** PYSIDE-2767 pyi improvements.
** lazy init for nested types disrupted the smart pointer support.
** https://bugreports.qt.io/browse/PYSIDE-2440 type hints optionallity is planned to be implemented.


==== 1. February 2018 ====
===23. May 2024===
- Continued work on documentation [https://bugreports.qt.io/browse/PYSIDE-363 PYSIDE-363], fixed static pages, add more modules, fixed parameters to qdoc, images
* General
- The GettingStarted wiki is getting better, besides a cleaning it a bit
* Infra & Releases
  - moved the topics around to have guidelines by supported platform (''a la Qt'')
** Preparing 6.7.1 with a lot of fixes
  - have received feedback and trying to add more information
** 5.15.17 LTS released
- Addressed bugs:
* Bugs & Features
  - [https://bugreports.qt.io/browse/PYSIDE-34 PYSIDE-34]
** [https://bugreports.qt.io/browse/PYSIDE-2747 PYSIDE-2747] Fixed PySide to run on Fedora 40 with 3.12-3
  - [https://bugreports.qt.io/browse/PYSIDE-264 PYSIDE-264]
** [https://bugreports.qt.io/browse/PYSIDE-2749 PYSIDE-2749] Worked on a performance regression related to Lazy Init
  - cleaning a bit Shiboken's XML files.
** [https://bugreports.qt.io/browse/PYSIDE-2758 PYSIDE-2758] Added QQuickWebEngineProfile.setUrlRequestInterceptor()
  - [https://bugreports.qt.io/browse/PYSIDE-560 PYSIDE-560]
** [https://bugreports.qt.io/browse/PYSIDE-2762 PYSIDE-2762] Fixed a type hinting bug
    - ported to 5.9, extended to 18 header files
** Brushed up and fixed a few examples
    - solved unicode problem
** 6.8 Adaption
    - reduced the patches to be minimal (avoid many #ifdef's, use a verbose macro name if possible)
** Python 3.13 check
    - made everything compile but one announced file: "object.h" depends on the heaptypes solution ([https://bugreports.qt.io/browse/PYSIDE-595 PYSIDE-595]). Removed WIP status,review pending.
** [https://bugreports.qt.io/browse/PYSIDE-2751 PYSIDE-2751] Python 3.13 first step towards --disable-gil compatibility (no ob_refcnt)
  - [https://bugreports.qt.io/browse/PYSIDE-595 PYSIDE-595]
** pyside6-deploy. Ignore files with .webp, .cpp.o, .qsb and .qen extension as Nuitka errors with them.
    - Started experimenting
** Close to macOS cross compilation
    - turned out that the signature extension barfed because it could no longer find the type "__name__". The function PyType_Type.tp_new needs to be called to provide the "ht_name" attribute that is used in heaptypes.
- solving the attribution file issues.
- Pending patches to fix libICU issues
- Pending patches to fix OpenSSL issues [https://bugreports.qt.io/browse/PYSIDE-599 PYSIDE-599]
- Pending patches to deploy libclang library for shiboken
- Improved documentation about OpenSSL dependency
- Pending patches for cleaning up build scripts a bit (logging and refactoring)
- Pending patches to reduce barrage of warnings [https://bugreports.qt.io/browse/PYSIDE-587 PYSIDE-587]
- Pending patch for adding CMake build rules for the scriptable_application example (useful as a reference on how to use shiboken for custom bindings) [https://bugreports.qt.io/browse/PYSIDE-597 PYSIDE-597]
- Old 5.6 CI integration issue fix, but a new issue appeared that was fixed for 5.9 and dev, but still blocks 5.6
- Updated the qml basics tutorial


==== 25. January 2018 ====
===16. May 2024===
- Pyside not renamed
* General
- Releasing preparation
* Infra & Releases
  - pip packages created by coin
** 5.15.17 commercial lts needs to be re-packaged one more time due to 3rd party components updates.
  - Automated release testing (RTA) (installing pip, launching an example)
** 6.7.1 release will also be re-packed. LE for release is 20th of May
  - final selection of release package targets to be define closer to release (depending on current stable ABI work)
* Bugs & Features
- Investigation doc issues when using prefix & shadow builds
** [https://bugreports.qt.io/browse/PYSIDE-2753 PYSIDE-2753] - Added missing libQt6DeclarativeOpcUa binary to wheels
- Need to identify prime demos/examples
** [https://bugreports.qt.io/browse/PYSIDE-2750 PYSIDE-2750] - Added missing libQt6VirtualKeyboardSettings binary to wheels
- Started to rework [[PySide2 GettingStarted|Getting Started Guide]] wiki
** Exclude .qsb, .webp, .cpp.o and .qen from deployment due to Nuitka error. Error report raised in Nuitka - https://github.com/Nuitka/Nuitka/issues/2854
- Addressed cmake build issues
** Working on macOS cross compilation. The clang parser of shiboken generator needs some changes for cross compilation. Tricky changes incoming.
- Handling libICU issues (causing linker issues when importing QtCore)
** [https://bugreports.qt.io/browse/PYSIDE-2748 PYSIDE-2748] - Fixed a type hint error
- Continued work on [https://bugreports.qt.io/browse/PYSIDE-560 PYSIDE-560]
** [https://bugreports.qt.io/browse/PYSIDE-2747 PYSIDE-2747] - Diagnostics and minor fixes for a crash on Fedora, no real fix though
-  
** [https://bugreports.qt.io/browse/PYSIDE-2711 PYSIDE-2711] - Fixed a bug in QWidget/QObject.parent()
** Work on type discovery in libshiboken, added helpers to dump internal state, performance considerations
** [https://bugreports.qt.io/browse/PYSIDE-2620 PYSIDE-2620] - Adapting to 6.8
** [https://bugreports.qt.io/browse/PYSIDE-2745 PYSIDE-2745] - Fixed a bug with exceptions in 0-delay singleShot timer slots
** [https://bugreports.qt.io/browse/PYSIDE-2404 PYSIDE-2404] - Lazy Loading completed by supporting subtypes. This gives 8-9% more performance.
** Support for Python 3.13 started - first compatibility before switching to disable-gil
** Possibilities explored to lazy load signatures or save space.


==== 18. January 2018 ====
===2. May 2024===
  - macOS framework fix (should ignore qt4 system headers)
  - another patch on top to fix OpenGL integer types on mac / Linux (GLuint64, GLint64)
  - Fixed so that PySide 5.6/5.9 is not linked against the Python shared / static library (this was wrong because the symbols need to be picked up by the dynamic loader from the python interpreter itself). http://bugreports.qt.io/browse/PYSIDE-522
  - Completed move of examples from pyside-examples.git to pyside-setup
  - added additional OpenGL2 core example
  - fixed testrunner (these silently failed since forever) https://codereview.qt-project.org/#/c/216732/
  - fixed issues whereby wrong QObject ctors were selected
  - removed webkit from Pyside2 build 
  - talk about Windows specific instructions for [[PySide2 GettingStarted|Getting Started Guide]]
  - Qt3D issues in Qt 5.10 fixes
  - clazy warning fixes
  - Stable ABI work (started to convert implementations) (see [https://bugreports.qt.io/browse/PYSIDE-560 PYSIDE-560])
    - requires adoption of HeapTypes
  - QML tutorial updates
  - Doc snapshots being prepared


==== 11. January 2018 ====
* General
- multi pyside packages (not easy to do)
** OKR reviews for the next quarter.
  - unlikely to achieve until TP
** Got a long document with feedback of a few tools we provided, that will help us improving our tooling!
  - a package per python release (3.4, 3.5, 3.6, 2.7)
** Started the planning of moving away from '<file>.pyproject' to 'pyproject.toml' for pyside projects, in order to add options for our tools.
  - package per platform (win 32bit|64bit, mac, linux)
* Infra & Releases
  - long term task to convert to reduced Python API (to support multi 3x packages)
** 5.15.17 commercial lts needs to be re-packaged due to 3rd party components updates.
  => have to cut some targets: one 3x and 2.7 release
** 6.7.1 to be released next week.
  -> create doc howto to encourage custom builds for not covered platform combo
** Add new mechanism to test snapshot wheels.
  -> do we need commercial for release
* Bugs & Features
- pysinstaller is an installer
** [https://bugreports.qt.io/browse/PYSIDE-2698 PYSIDE-2698] - ListProperty features fixed. Added tests to check all the features.
    -> deployqt tool not necessary
** [https://bugreports.qt.io/browse/PYSIDE-2705 PYSIDE-2705] - issues with signal disconnect warnings fixed
    -> documentation required stating the option
** macOS cross compilation for Android - stuck on a CMake issue. Progressing well.
- rename import options
** [https://bugreports.qt.io/browse/PYSIDE-2709 PYSIDE-2709] - Analysis ongoing for this QML registration regression
  - rename via alias possible
** Work on improving/documenting type discovery in shiboken
  -> still an issue when looking up particular types but probably manageable 
** Enumeration support in QtScrypt
  - renaming option: Qt4Pyton, QtPy, QtPython, Python4Qt, Qt
** [https://bugreports.qt.io/browse/PYSIDE-2676 PYSIDE-2676] - PEP 697 extension in Python 3.12 fixed
- example shift
** BT bug research, cannot be reproduced and application doesn't hang. Connection is not successful.
  - https://codereview.qt-project.org/#/c/215900/
*** Issue might require special hw
- Basics for doc generation toolchain
** Documenting QtAsyncio implementation details.
- Issues where cmake picks up platform Qt references where it should use a Qt custom install
*** An internal presentation is being prepared.
- Qt3D bindings still under progress
** Possible QtAsyncio feature, 'run' supporting context managers.
- [https://bugreports.qt.io/browse/PYSIDE-34 PYSIDE-34] & [https://bugreports.qt.io/browse/PYSIDE-560 PYSIDE-560]  
** macOS cross compilation for android being tried
- Documentation
  - minor doc fixes
  - documenting examples


==== 4. January 2018 ====
  - multi pyside packages (not easy to do)
  - renaming Pyside to "Qt for Python"
    - quite challenging due to implied import and lib changes
    - alias for existing imports would be beneficial
  - discussion around existing function test
    -> working assumption is that we ignore added function and check for existing base line only
    -> effort too large to maintain every single new addition
  - discussed issues around concurrent existing Qt builds while building pyside (potential cross leakage)
  - various fixes to doc generation steps (see [https://bugreports.qt.io/browse/PYSIDE-363 PYSIDE-363])
  - discussed need for good examples as part of documentation
    -> considered options to cleanup and remove need for submodule


== 2017 ==  
===25. April 2024===
* General
** Successful talk at PyCon DE. Good response.
* Infra & Releases
** Preparing 6.7.1
** 5.15.17 Commercial LTS is also soon to be prepared
** sccache seems to be not properly behaving (on windows) because we are not getting enough output.
** PySide6_DS wheel to be adjusted and hopefully be released soon.
* Bugs & Features
** Added a number of new classes
** PYSIDE-2676 issues on ubuntu (might be related to a windows issue as well)
** Implementation of Lazy Groups in order to avoid the regression in 6.7.0 due to multiple inheritance.
** Alternative for Lazy Groups (Fix for the regression on 6.7.0)
*** Work on regressions introduced by lazy initialization [https://bugreports.qt.io/browse/PYSIDE-2675 PYSIDE-2675]
** Work on a crash in Python 3.12 [https://bugreports.qt.io/browse/PYSIDE-2676 PYSIDE-2676]
** Fixed memory leaks [https://bugreports.qt.io/browse/PYSIDE-1617 PYSIDE-1617]
** Work on our QML list property support [https://bugreports.qt.io/browse/PYSIDE-2698 PYSIDE-2698]
** Added pyside6-balsamui (ui tool for pyside6-balsam) - PYSIDE-2629
** Also checking out List Property error with `count` and `at` parameters - [https://bugreports.qt.io/browse/PYSIDE-2698 PYSIDE-2698]
** Updating old example (calqlatr) - https://codereview.qt-project.org/c/pyside/pyside-setup/+/523055 for responsive layout
** QtAsyncio: refinements to the current implementation, and solved a bug report.
*** Trying to add support to Keyboard interruptions (handlers)
*** Plan to improve exceptions handling


<div class="mw-collapsible mw-collapsed" style="overflow:auto;">
===18. April 2024===


==== 21. December 2017 ====
* General
- Issues building for Windows for Python 2 and 3 (on coin)
** Bug fixing week
- discussing potential pyside demo/example for RTA purposes
** PyConDE (Mon-Wed next week)
- Continued work on macOS / Qt 4 header issues, progress is there
** Planning a workshop for TQtC solution engineers (internal)
  - breaks GL signature test on Linux, needs further investigation
** Possibility to include shiboken into the Axivion infra
- Investigated PyInstaller (potential option to deploy apps written with Pyside)
* Infra & Releases
  - seems to work almost out-of-the-box for deploying PySide apps
** 5.15.17 commercial LTS was postponed to Friday. Still need test on Windows.
- Investigated building one package compatible with multiple Python 3.x minor versions
** 6.5.6 release planned
  - not possible currently, will require a lot of work, possibly not feasible
** 6.7.1 release has been postponed to the first week of May
  => we need to build 3.4,3.5,3.6 * win, linux, mac packages = 9 packages
** DS-compatibility wheel postponed due to CI issues
  => 3 more for each platform and Python 2.x
** We might need to create a testing platform in order to check other errors that are not detectable with simple tests.
  => commercial packages?
* Bugs & Features
- lots of discussions and fixing of doc tool chain (qdoc in dev currently broken)
** Few new type hints issues from 6.7.0 release, needs to be address on 6.7.1
  - adding documentation has begun in earnest
** QtAsyncio issue related to Task groups. Tricky, because it can be related to Qt Events.
- continued work on PYSIDE-578
** PYSIDE-2629 Adding more Qt-tools to the wheels
** PYSIDE-2622 Adding a new option to the deploy tool (exposing an option from Nuitka)
** PYSIDE-2675 Lazy loading issues with trees of polymorphic classes.
*** first approach made things less effective
*** The impact of the solution was reduced a bit, by disabling the feature for special multiple-inheritance cases
*** New idea on 'groups' that be handled differently, so we have group or classes grouped and dependant
** 825 qml bug is still around
*** PYSIDE-2676 seems to be a new approach to fix it
** A few customer bugs made it the bug fixing week.
** PYSIDE-2675 type discovery code, class inheritance
** QtAudio -> QAudio refactory
** Virtual function compatibility to modify the signature (from typesystem)
** PYSIDE-2492 uic issues for Enum compatibility
*** More improvements for Python projects (import options)
** PYSIDE-2685 nan type definition
** Removing code from shiboken
** 6.8 Adaption already started
** PYSIDE-2689 sphinx directives doesn't seems to be compatible with the search context.


==== 7. December 2017 ====
===11. April 2024===
- pip wheel installation
* General
  - adding support for simultaneously python 2 and 3 builds
** Bug fixing week.
  - open issues: test installation towards multi python 3 versions
** Qt 6.6.3 Library split broke our release, so we provided 6.6.3.1 as a fix.
  - delivery channel for Pyside binaries (pip server? local install from qt account download?)
** Qt 6.7.0 also had an issue with a binary incompatibility change on QtAudio and QAudio
- investigate options to have sth like pyinstallqt (pysinstaller is a possibility)
** Maybe we implement a simple channel of communicating this details, in order to avoid breakage [maybe architect meetings]
  - final keyword support by shiboken
** Qt Creator 13 creates venvs automatically. This needs to be revisited to avoid multiple environments to be created.
- Qt3D bindings patch close to completion - > requires some Qt changes in 5.9.4 or later Qt
** New epics with brainstorming ideas.
  - fixing pyside build issues when encountering Qt 4 headers on macOS
* Infra & Releases
- PYSIDE-578 (testing procedure/testrunner) -> adds heuristic to adapt to failure rates (flakiness handling)
** 6.7.0 was released, we found a couple of issues we are trying to solve, and 6.7.1 will soon be released due to a binary compatibility break, and other small breakage.
  - concerns that running all tests 5 times adds too much load on the CI (test runs needed)
** 5.15.17 commercial LTS to be release next week.
** QtDS packages a bit delay due to CI errors.
** Qt Installer (Maintenance tool) has still some issues with the structure.
* Bugs & Features
** Adding new Qt tools to the wheels (wrappers)
** PYSIDE-2602 special virtual function research
** PYSIDE-2669 designer issue
** PYSIDE-2675 Addressing the lazy import issues that were found in 6.7.0
*** Studying the possible solution, but it needs to consider other cases as well.
*** the *-import handling seems to be related, and affecting the mro content, duplicating some entries.
*** the type discovery handler might be related as well
** Still working on the qml 825 bug issues.


==== 30. November 2017 ====
===4. April 2024===
- packaging related coin changes
* General
- last weeks merges between 5.6 and 5.9+ blocking coin have been fixed (in particular on RHEL)
** Large part of the team at conferences/on Easter holiday
  - 5.9 + 5.6 are passing, dev has some private Qt changes which will affect pyside/dev
* Infra & Releases
- lots of coin infrastructure issues
** Released 6.6.3.1 release with fixes for Quick Controls/Multimedia
- RTA test wheels added (install and launch single example)
** Preparing for 6.7.0
- crash bugs in 5.6 branch reported but not details known yet (waiting for more details)
* Bugs & Features
- some discussion what changes should be put to 5.6 vs 5.9 branch
** [https://bugreports.qt.io/browse/PYSIDE-2646 PYSIDE-2646] Improved cleanup of signal manager objects
- Qt3D bindings started
** [https://bugreports.qt.io/browse/PYSIDE-2662 PYSIDE-2662] Fix for a signal in OpcUA
  - some changes in qt3d/5.9 required)
** [https://bugreports.qt.io/browse/PYSIDE-2663 PYSIDE-2663] Fixed a crash in webengine bindings
  - shiboken bugs discovered in the process (virtual function guessing & some comparison operators for namespace generated)
** [https://bugreports.qt.io/browse/PYSIDE-2668 PYSIDE-2668] Fixed an error in enums
- small regression related to rpath handling on Linux
- open pip wheel issues:
  - handling of multi Python version wheels
- testrunner bugs addressed and reducing flakiness
- issues in Pyside when building with gcc 7.x
- qdoc from qt5/dev is required for pyside due to webxml support
  - it is a problem for the pyside/5.9 branch


==== 23. November 2017 ====
===28. March 2024===
- pip wheel support issues on Linux solved (not yet verified)
* General
  -> libICU usage on Linux should be enabled via pyside setup script
* Infra & Releases
  -> downloaded from qt account download area
** Prepared 6.6.3.1 release; 6.6.3 was unfortunately broken due to missing libraries (Quick Controls/Multimedia)
  - discussion how to do wheel builds for different Qt base lines -> implies to different wheel packages
* Bugs & Features
  - need to evaluate how different python versions on various Linux distros impact wheel binaries
** [https://bugreports.qt.io/browse/PYSIDE-2654 PYSIDE-2654] Fixed multiple inheritance when no __init__ is in a subclass
  - target: 6 wheels (2 per platform for 2.7 & 3.5+ Python)
** Still investigating a crash on Ubuntu with Python 3.12 and bug_825.py . The crash is deeply hiding in Qt6.
  - OpenGL example
** [https://bugreports.qt.io/browse/PYSIDE-2652 PYSIDE-2652] Fixed an int overflow
  - merge 5.6-> 5.9 attempted
** [https://bugreports.qt.io/browse/PYSIDE-2649 PYSIDE-2649] Work on building without OpenGL
    - signature update to match Qt 5.9 ABI/signatures
** [https://bugreports.qt.io/browse/PYSIDE-2653 PYSIDE-2653] Fixed a syntax error in type hints
    - plenty of testing flakiness and also test crashes
  - improvements to signature tests


==== 16. November 2017 ====
===21. March 2024===
- Build system cleanup. It is now possible to build only a subset of Qt modules per cmd line option
* General
  -  this is not complete and may need further patches
** Ideas to improve the module.
- Added QAxContainer, more classes from 5.10
** Most of the team is going on vacation the following weeks.
- Preparing to add Qt3D
* Infra & Releases
- Removed flaky test
** 6.7.0 to be released the first week of April [delayed]
- further research on how pip wheels might be used for Pyside
** 6.2.12 Commercial LTS to be release in the following days [delayed]
  - seems to work well on win & macOS
** 6.6.3 to be release next week [delayed]
  - problems on Linux related to libICU (or in general due to different system libraries)
* Bugs & Features
- implemented and tested --standalone feature for the main Qt platforms [https://bugreports.qt.io/browse/PYSIDE-558 PYSIDE-558]
** 6.8 adaption patches are being worked
- open question remains how 3rdparty Pyside deployment path might look like
** PYSIDE-2638 fix crash QLayout when None is passed
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510]
** Documentation updates: for tooling and examples.
** QtRhi missing API provided
** Memory leak regression being worked out
** Shiboken Qt namespaces patches being cherry picked to previous versions.
** Android deployment and qml tool documentations
** Android wheels generation on the CI process is being improved.
** Debugging deep into Nuitka to understand a problem with the lazy loading functionality.
** QAsyncio bug fixed
** Adding more tools docs pages for our tools.


==== 9. November 2017 ====
===14. March 2024===
- Work on simplifying the build system, made it possible to specify a module subset to build
* General
- [https://bugreports.qt.io/browse/PYSIDE-558 PYSIDE-558] Fixing rpaths and making --standalone work on the 3 platforms. Result: Self-contained binary wheels. Needs Review.
** PyConDE schedule is out, don't miss Shyam's talk https://pretalx.com/pyconde-pydata-2024/talk/W7YDRX/
- Trying to setup the project for building the docs. I managed to build the rsts from the patch in gerrit but running sphinx on those rsts results in errors about python 2 style code.
** Python 3.13.0a5 is out.
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510] work continued
* Infra & Releases
** 6.7.0 in preparation, docs adjustments and new pages will come. Branching on Monday.
** 6.2.12 LTS release in preparation.
** 6.6.3 will be release next week.
** qtpip 0.1.1 to be released
** dev is already Python 3.8 free, and we support 3.9+ for 6.7+
* Bugs & Features
** Triaging and fixing issues in general: 2638 layout crash.
** PYSIDE-2690 namespaces support continues
** Lazy initialization got merged
*** New improvements might land in future versions
** PYSIDE-2635 OpcUA example problem
** PYSIDE-2633 remoteobjects issue
** Using new icons on the examples
** Testing libclang 18
** QObject.connect bug when a callable is a QObject (workaround with manual overload)
** QIOPipe implementation for QAsyncio (base in the Qt/C++ one)
** New use cases for QAsyncio and aiohttp
** permission API changes got merge
** android wheel compilation was adapted for qt 6.7.0 (PR on python-for-android was merged)
** PYSIDE-1639 QLocale issue was fixed


==== 2. November 2017 ====
===07. March 2024===
- Releasing:
* General
  - continued work on macOS installer
** Participation in FOSS Backstage
  - binaries must be patched during the install from repo (rpath setting)
* Infra & Releases
  - adopting the scripts from Qt for Pyside
** 6.5.5 Commercial LTS was released
  - made pip install work on Mac -> would be alternative to online installer approach
** 5.15.13 OSS Package will be released tomorrow
      - two deployment choices available
** qtpip 0.1.1 release delayed
- discussions on how void* pointer should be handled, two options on the table
** Python 3.8 deprecation is still pending due to CI configuration dependencies.
  - add additional Pyside module handling such pointers
* Bugs & Features
  - add feature to shiboken to transparently add the support to any arbitrary C++/pyside project using shiboken
** permission api changes are mostly merged, one pending https://codereview.qt-project.org/c/pyside/pyside-setup/+/536759/15
- documentation snapshot generated
** all deployment fixes are in.
- simplified setup-pyside and related build script options
** lazy initialization work continues, and some issues were fixed already.
*** Ubuntu 22.04 | Python 3.10.2 |is showing an issue with scriptableapplication
** Continue implementing more API for QtAsyncio which is currently working well
** two pending change for 6.7.0 and 6.6.3 to be merged.
** PYSIDE-2590 qt namespaces support required a patch for Qt/C++
** PYSIDE-2619 gentoo issue with a build
** PYSIDE-2624 typing issue with '/' is being researched
** Qt Icon Teams issues were discovered
** PYSIDE-2602 virtual function research on a special signature
** One regression related to the QObject.connect changes.


==== 26. October 2017 ====
===29. February 2024===
- Releasing:
  - test repo for online installer created (mac seems to deploy)
  - first evaluation of suggested installer approach on various platforms
- Documentation:
  - Qt doc team joined the effort
  - first experiences are collected
  - should new documentation be done in rst rather than qdoc format?
  - Getting started, General platform requirements and general fixes turning up during generation
- [https://bugreports.qt.io/browse/PYSIDE-571 PYSIDE-571] received further fixes and reviews
- REDHAT not working on Coin (caused by gcc header issues)
- other minor improvements


==== 19. October 2017 ====
* General
- Discuss open Pyside 2 release & documentation
** Leap day!
- Release packaging suggestion
** Documentation changes
  - Qt for Python installed via Qt installer and python scripts pointed to module via PYTHON_PATH
* Infra & Releases
  - create test online repository for Qt installer
** 6.7.0 will drop support of Python 3.8
  - follow up how this Pyside installation approach might impact deployment of Python apps using Qt for Python
** 6.5.5 to be released in the following days
  - Linux distros shipping Pyside? (not sure yet either)
** 6.7.0 RC marks our feature freeze, some exceptions will be discussed in order to release on time.
- coin
** qtpip 0.1.1 to be released soon for new indexing and shiboken_wizard package
  - breakage in CI provisioning due to competing Python binaries coming from MSVC 2017
** General update of Python versions in our CI configuration is being planned (for dev-6.7)
  - coin template needs updating
* Bugs & Features
- [https://bugreports.qt.io/browse/PYSIDE-571 PYSIDE-571] work progressing (ready for review)
** PYSIDE-2599 QMatrix3x3 issues with QVariant
- lots of fixes in Pyside dev branch and  
** PYSIDE-2605 Embedding an application, using .style() - qAPP
- feedback from Qt World Summit:
** PYSIDE-2590 QT_NAMESPACES support
  - is Pyside on Android and iOS?
** PYSIDE-2602 clash on signature for QtWebEngine returning tuple
  - iOS probably out since platform cannot have interpreted code
** Preparing 6.5.5 and 6.7.0 releases.
  - Scriptable application use case was a sought after feature
** PYSIDE-2612 CMake issue from Anaconda builds when find_package
  - qdoc got WebXML patch -> open question which version to use for doc generation across the various pyside versions
** macOS permissions changes are almost all merged
    - add script to support single command to generate documentation
** Windows BTLE services crash
** QIO-class are required for some new QAsyncio API using pipes
** Lazy loading moving forward, but still a few issues are around
*** A couple of shiboken tests seems to have outdated imports that are not helping.
*** shiboken compatibility types missing
** Typing issues being solved in order to improve the pyi quality


==== 12. October 2017 ====
===22. February 2024===
- no update due to Qt World Summit 2017
* General
** Brainstorming discussion about new JIRA items.
* Infra & Releases
** 6.6.2 was released!
** qtpip getting a new minor version in order to be able to install new shiboken wizard
* Bugs & Features
** Permission API issue failing on the release framework. QtLocation problems were addressed.
** QtAsyncio blog post was published.
** Definition of done for QtAsyncio story, some functions will be implemented, but other ones (until reaching the whole set of user facing API) will be implemented in the future.
** Lazy initialization of numpy support in PySide, to improve the general lazy loading effort.
** Starting documenting pyside6-* tools
** PYSIDE-2610 Qt3D issues
** 6.7 adaption was a lot of work, namespaces were something tricky.
** 6.7 changelog drafted.
** Started to improve the type hinting issues.


==== 05. October 2017 ====
===15. February 2024===
- Qt DataVisualization port has finished including an example
- Coin no progress due to pending Qt 5.9.2 release
- webxml support being implemented inside qdoc (beginning of the pyside documentation toolchain)


==== 28. September 2017 ====
* General
- 5.6 and 5.9 branches are *finally* enforced by CI - yeeeaaahh
** Brainstorming session was held.
- Dev branch is still missing some forward merges before it can be enabled.
** Europython Call for Proposal is open!
- port of QtDataVisualization progressing
* Infra & Releases
- fixed bugs: [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510], [https://bugreports.qt.io/browse/PYSIDE-517 PYSIDE-517], [https://bugreports.qt.io/browse/PYSIDE-562 PYSIDE-562], [https://bugreports.qt.io/browse/PYSIDE-564 PYSIDE-564]
** 6.6.2 release waiting for Qt/C++ packages to be done.
- [https://bugreports.qt.io/browse/PYSIDE-156 PYSIDE-156] in progress, first example of qApp protection, benchmark of impact ongoing
** Commercial 6.5.5 LTS to be out next week.
** Some improvements to the CI and macOS behavior
** Cherry pick bot on commercial repositories.
* Bugs & Features
** singleShot changes are merged, keep an eye on strange behavior.
** 6.7 adaption: metaobjectdump improvements
** 6.6.2 fixes with the commercial shibokenwizard
** lupdate support for pyside improved (qm files)
** pyside6-project problems with dry-run were fixed. Some improvements planned.
** CI android wheels upgrade [skip armv7 in the meantime]
** Lazy imports research continues, we see lots of improvements on apple M* devices.


==== 21. September 2017 ====


- Prototyping and exploring of Pyside packaging options
===8. February 2024===
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510] done and merged
- [https://bugreports.qt.io/browse/PYSIDE-156 PYSIDE-156] being addressed thanks to [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510]
- [https://bugreports.qt.io/browse/PYSIDE-487 PYSIDE-487] Qt Data Visualization port progressing


==== 14. September 2017 ====
* General
- Coin
** We got a PyConDE 2024 talk accepted (python -> android deployment)!
  - 5.6 testing is back online (5.9 target unblocking pending a merge)
* Infra & Releases
  - Packaging of Pyside started to become a discussion topic
** Addressing some issues with the android wheels
      - Standard PIP deployment
** 6.6.2 got delayed until next week
      - Separate delivery via the usual Qt account channel
** Preparing for the 6.7 switch on dev
- void* support has a pending patch (https://codereview.qt-project.org/#/c/205124/ and related example https://codereview.qt-project.org/#/c/205272/)
* Bugs & Features
- Documentation work ongoing
** macOS: permission api patches ready for review
  - WebXML support was added to qdoc - see [https://bugreports.qt.io/browse/PYSIDE-363 PYSIDE-363]
** singleShot patches merged
  - inputting the resulting WebXML to shiboken gave promising results
** Lazy initialization was finished, and ready for discussion.
  - Qt Creator gain ability to fold away Python license headers
** Check compatibility with the new REST module (from Qt/C++)
- Signature patch (https://codereview.qt-project.org/#/c/198654/)
** Preparations for 6.7 continues.


==== 7. September 2017 ====
===1. February 2024===
- Pyside CI broken (timeout for tests is zero)
  - Pyside provisioning scripts are very fragile
  - Qt's own  provisioning is interfering when e.g. Pyside relevant tools get changed by Qt
  - new ideas and redesign is likely to be needed
- New Bindings: QRegularExpression, QVersionNumber, QUuid,
- Discussions around Documentation for pyside
  - couple of options for generation pipeline
    1.) qdoc generates WebXML -> Shiboken converts WebXML to ReST (used to work in Qt 4 days)
    2.) qdoc is lib which creates AST - > shiboken uses the AST to generate ReST
    3.) \pyside to document python classes (lots of documentation effort and not ReST integratable)
    4.) minimalistic approach is to merely link to the Qt object class reference (python specific docs are somewhat separate
- [https://bugreports.qt.io/browse/PYSIDE-516 PYSIDE-516] further investigation how to deal with void* APIs
  -> prototyping ongoing
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510] redesigned once again (no more internal Python dependencies, Python version independent implementation)
 
==== 31. August 2017 ====
- 5.9 passes on all platforms but one (10.10 still failing)
  -> fix for provisioning scripts pending
- 5.6 no problems at hand (all passing)
- [https://bugreports.qt.io/browse/PYSIDE-516 PYSIDE-516] hit a dead end
  -> fundamental way of passing vertex data (void*) pointer between Python and C++ not addressed yet
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510] complete


==== 24. August 2017 ====
* General
- Coin 5.9 provisioning is in place, but there are some issues with paths to tools which are being addressed
** Interest from KDE to enable flatpak packages (maybe base pyside app).
- Build issue on Windows 10 5.9 branch, addressed by patch in review https://codereview.qt-project.org/#/c/203406/
** Discussion on adding more tutorials of specific functionality.
- Fix to macOS build when old Qt 4.8 is present, addressed by patch https://codereview.qt-project.org/#/c/203313/
** CI Maintenance Break next Monday (first Monday of each month)
- [https://bugreports.qt.io/browse/PYSIDE-516 PYSIDE-516] progress on bringing in more of the QOpenGL classes
* Infra & Releases
- [https://bugreports.qt.io/browse/PYSIDE-560 PYSIDE-560] stable ABI was investigated, decision is required
** no unity build discussion and checks
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510] finalizing license modifications
** 6.6.2 to be released next week.
- [https://bugreports.qt.io/browse/PYSIDE-156 PYSIDE-156] ongoing implementation for fixing qApp crashes
** More granularity on the commercial wheels: shiboken wizard wheel.
- [https://bugreports.qt.io/browse/PYSIDE-552 PYSIDE-552] in process of being merged
* Bugs & Features
- [https://bugreports.qt.io/browse/PYSIDE-562 PYSIDE-562] pending patch
** singleShot timer implementation (to use underlying c++ impl) - still an issue with a context object, and a signal as a functor. A new QObject::connect might handle the situation. More changes to come in order to fix newly discovered issues.
- [https://bugreports.qt.io/browse/PYSIDE-563 PYSIDE-563] in process of being merged
** Android: using the master branch on python-for-android, and other changes related for macOS deployment.
- PySide 2 presentation being prepared for Qt World Summit 2017
** PYSIDE-2597 optimization for the deployment procedure
** Lazy initialization: works continues, and it's looking good. 13 bugs to go on lazy mode. The new implementation seems to be working better.
** 6.7 adaptation still in progress (many changes from Qt)
** General documentation adjustments
** Improvements on shiboken: better error messages
** Qt Namespaces compatibility attempts.
** Moving away from a couple of setup.py options towards pyproject.toml after upgrading 'build' to 1.0.x
** Design Studio compatibility wheel work continues


==== 17. August 2017 ====
- Almost everyone is still on holiday - not much progress
- PySide 5.9 branch CI changes are still pending integration / ongoing due to issues with the CI infrastructure switch
- Investigation ongoing regarding QSSL classes on 5.9 branch
- PYSIDE-510 - ongoing work to make separation of different licensed code
- PYSIDE-156 - initial work to stop crashes when using methods that require an allocated QApplication instance
- PYSIDE-558 - initial investigation on how to proceed
- Updated the PySide2 wiki documentation to clear up build steps and requirements.


==== 10. August 2017 ====
===25. January 2024===
- holiday time is hampering project at the moment -  not much progress
- CI changesin Qt affected Pyside project such that focus was on different CI matters
- [https://bugreports.qt.io/browse/PYSIDE-557 PYSIDE-557] being addressed
- some very minor issues were fixed


==== 03. August 2017 ====
* General
- PYSIDE-510 under code review https://codereview.qt-project.org/198654
** Configuring additional embedded devices for RTA
  - > license issues have to be addressed
** Focus on spending some time on embedded linux, in order to see usability, and compatibility with Boot2Qt images.
  - > some testing aspects still open (delayed till later on)
** Conferences: submissions to PyCon SK, PyCon DE, PyCon LT, PyCon US
  - > investigation of impact on deployment across multiple python run-time versions required
* Infra & Releases
- missing bindings script/wiki page updated: [[PySide2_Missing_Bindings|Missing PySide2 bindings]]
** Decouple of the commercial wheels in order to have a finer granularity and simpler tree on the Qt Installer (Maintenance Tool)
- first working array support has been delivered (some adjustments still required), now proceeding to extend for OpenGL [https://bugreports.qt.io/browse/PYSIDE-516 PYSIDE-516]
** Qt for Python 6.6.2 is waiting for Qt to be released (by the end of the month)
- Missing classes in works (e.g. QAbstractnativeEventFilter, QFileLock,....)
** The next 5.15.13 LTS open source release will include a new fix for a missing symbol (PyIndex_Check)
  - > revealed some issues of handling void* pointers
** New CI configuration without '--unity' for manual testing, to spot issues.
* Bugs & Features
** VS Code will use .flake8 (formerly setup.cfg) file for configuration once merged
** PYSIDE-2575: Added a new argument to QtAsyncio to configure whether the QCoreApplication at the core of QtAsyncio should be shut down when asyncio finishes (requested by user).
** SingleShot timer issue: Slight "complexity explosion" because correct implementation for one case requires implementation of QObject.connect overload with context arguments (and we implement QObject.connect ourselves, see PySide::qobjectConnectCallback).
** Scripting: code simplification, and massage it to a Qt module.
** Documentation updates to fix issues we had.
** Unity build some issues when building without.
** 6.7 updates, adapting some warning messages
** QTBUG-99313 related issues
** macOS permissions: made an example to work (for deployed apps) - patches incoming
** Android wheels provisioning and configuration in order to generate the base-wheels.
** armv7 complications due to an upstream find_python command.
** Lazy initialization: re-wrote approach from scratch, to reduce the patches to one that can be analyzed easily. Some complications with this approach that needs to be improve. It can be tried with https://codereview.qt-project.org/c/pyside/pyside-setup/+/496118
*** https://peps.python.org/pep-0690/ was rejected, but the idea can be implemented per-module
** Moving entry_points declaration to pyproject.toml from setup.py
** Drop the bdist_wheel steps from the CI (old wheels)
** Started working on split commercial wheels, wheels for QtDS and examples on QtCreator.


==== 27. July 2017 ====
===18. January 2024===
- Fix for [https://bugreports.qt.io/browse/PYSIDE-331 PYSIDE-331] causes lots crashes in auto tests
  -> more investigation ongoing
- coin
  - since 5.6 is now enforced by Qt CI the focus shifted to the 5.9 branch of Pyside
  - still encountering build issues on 5.6 though
  - cmake upgrade for macOS 10.10
  - missing virtual env for macOS 10.12 being deployed
  - msvc 2013 being removed from CI targets
  - clang on OpenSuSE deployment ongoing
  - lots of effort went into debugging the above Coin issues
- numpy support for 2d array feature development progressing ([https://bugreports.qt.io/browse/PYSIDE-354 PYSIDE-354])


==== 20. July 2017 ====
* General
- coin
* Infra & Releases
  - license test passing
** Commercial LTS 6.2.11 was released
  - setup issues wit Python 3 and msvc 2008 vs 2015 issues
** Add missing tags OSS LTS 5.15.x
  => need to install newer Python 3 binaries
** 6.6.2 scheduled by the end of the month
  => otherwise looks like enforced testing can be set alive on 5.6 branch
** Release documentation to be written to have tasks on JIRA
  - 5.9 still having clang header issues
* Bugs & Features
- 2D array support work in progress
** Python Scripting: looking into stable API, and cleanup
- [https://bugreports.qt.io/browse/PYSIDE-331 PYSIDE-331] -> waiting for PYSIDE-510 dependency
** PYSIDE-2577 doxygen issue
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510]-> issues with Python 2.x left
** PYSIDE-2570 closing some roadmap items
- need to get a handling what functions are not supported by pyside due to exclusions or missing support in shiboken
** Polishing documentation to use more sphinx directives
** Qt 6.7 adaption
** Addressing some flake8 issues in the build_script
** macOS permission API work continues: limitation for interpreted script, only compatible when deployed. Working around nuitka.
** singleShot: trying to solve a corner case when no sender is specified (for using the C++ function directly)
** Fixing some CI problems with 3.11 -> 3.12 changes.
** PYSIDE-2404 adding more information regarding the lazy evaluation, new approach might work.
** pyside6 is now an official recipe on the python-for-android!
** Improvements to the doc build process


==== 13. July 2017 ====
===11. January 2024===
- coin
  - Production coin was updated today and all fixes are finally executed
  - 5.6
  - macOS 10.11 machines have Python 2.6, which causes test script to fail due its usage of a
          module added in 2.7. Investigation in progress on the best way to fix this.
  - build failure with Windows 8.1 (msvc2013-x86)
  - 5.9
  - macOS 10.12 missing virtual env (https://codereview.qt-project.org/200006)
  - Rest Linux/macOS configs are failing various build issues
  - dev is still pending for qt5 merge from 5.9 
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510] development completed, test added, needs review
- [https://bugreports.qt.io/browse/PYSIDE-331 PYSIDE-331] ongoing work
- [https://bugreports.qt.io/browse/PYSIDE-550 PYSIDE-550] investigated, needs a working solution to allow proper building on distros that separate Qt private headers into separate packages
- [https://bugreports.qt.io/browse/PYSIDE-354 PYSIDE-354] ongoing work on C / C++ array support in PySide, some questions remains on how to deal with xml syntax and multiple dimensions.


==== 29. June 2017 ====
* General
- coin
** Hackathon at TQtC
  - Qt 5.6 all coin changes for Pyside are done but waiting for coin production update (after Qt 5.9.1 release)
** CI process presentation
  - Pyside/Qt 5.6 on new OpenNebula infrastructure confirmed to run
* Infra & Releases
  - Qt 5.9 based setup still misses clang libs (merge pending)
** Commercial LTS 6.5.4 release starting (to be finished today)
  - Pyside/Qt 5.9 test failure fixes on macOS
** Commercial LTS 6.2.11 still pending release
- worked on array support (passing arrays between Pyside and Qt API) - work in progress ([https://bugreports.qt.io/browse/PYSIDE-354 PYSIDE-354])
** 6.6.2 schedule by the end of the month.
- continued work on debug builds across the platforms
** CI still showing some issues after the maintenance break.
- embedded Python example under review (further testing across the platforms)
** Update of the Python versions are pending.
- [https://bugreports.qt.io/browse/PYSIDE-510 PYSIDE-510] finished (not yet merged) -> revealed a few more  problems in [https://bugreports.qt.io/browse/PYSIDE-331 PYSIDE-331] & [https://bugreports.qt.io/browse/PYSIDE-308 PYSIDE-308]
* Bugs & Features
- added a way to dynamically detect the available Qt modules in Pyside
** Fixing a few small issues with QtAsyncio
** Documentation for the QtAsyncio is currently in review.
** New behavior for singleShot (relying on the C++ impl)
** macOS request permission API work continues.
** 6.7 adaptions patches
** M2M fixes on the current impl
** Native interfaces were added (new ones) to public headers
** favicon issue with out docs
** Making our doc diagram generation optional
** Improvements for the doc build process


==== 22. June 2017 ====
===04.January 2024===
- building pyside on Win with debug and non-debug
* General
- QSSL* classes do not build on macOS & Windows (patch in progress)
** Happy new year fellow readers :D
- dll name handling work finished (build system issues were addressed)
** New OKR organization
- PYSIDE-531 discussions
** Keeping in an eye on Conferences
- coin
** PyPy is now on 3.10
  - followup from 18 May (windows issues in coin)
** Ideas on the wheel organization for the Qt Installer
  - test runner changes being merged should address this
* Infra & Releases
  - new regression on macOS targets though
** CI Maintenance break continues. Some new issues were discovered.
  - 5.9 issues due to clang continue to exist (will be addressed after 5.6 is enforced)
** Pending releases: 6.2.11 and 6.5.4
** Android [https://download.qt.io/snapshots/ci/pyside/test/Android/aarch64/ wheels for testing] purposes are available (not for production)  
** Xcode issues with a new M3
** Planning the inclusion of Python 3.12 in the CI
* Bugs & Features
** async: A few bug fixes were pushed and ready for review
** async: the module is missing from our docs
** async: we have been getting some interests from users, so new issues are appearing.
** new android tag added to the examples for a better browsing
** pyside6 designer pyenv crash was fixed
** pyside cmake module update crash was fixed
** working on the request permission API for macOS
** docs: free functions as separate section and other improvements
** Python scripting in c++ works continues
** PyPy 3.10 compatibility patches
** nogil: working again on a compatibility with PEP703
*** locking mechanism for our modules.
** Typing adjustments, we need '/' in our signatures due to not having keywords parameters.


==== 15. June 2017 ====
==2023==
- dll name handling fixed across the platforms (e.g. pkgconfig handling)
- PYSIDE-500 fixed
- PYSIDE-331 is still not done (in parts a module by module fix is required)
- PYSIDE-510 ongoing
- no further progress on coin
- Getting started guide has been updated dealing with Qt 5.6 and Qt 5.9 based Pyside builds
- scriptable Pyside example been developed to demonstrate SDK-like usage of Pyside
- lots of small infrastructure changes/fixes


==== 8. June 2017 ====
*[[Qt for Python Development Notes 2023]]
- Proposed solution for PYSIDE-500
- Further work on example for PYSIDE-526, work on shiboken2 command line handling to ease usage with qmake
- Updated Getting started Wiki
- Introspection work continued (PYSIDE-510)


==== 1. June 2017 ====
==2022==
- PYSIDE-500
- https://wiki.qt.io/PySide2_GettingStarted needs a serious cleanup
  - 5.6 vs 5.9 differences not explained
  - specify exact version matching conditions
- pyside repo merge completed
  - Coin changes required to catchup - > recent CI issues have caused delay
- Introspection work continued (PYSIDE-510) -> not yet complete
- qtcharts and related examples have been ported (5.9 only)
- license header checks of Pyside for Coin able to distinguish branches
- Array support for Pyside missing (numpy_array support?)


==== 18. May 2017 ====
*[[Qt for Python Development Notes 2022]]
- Coin
  - Win nodes didn't run the cleanup functions -> test failures due to artifacts -> no solution yet
  - Clang issues persist and this must be addressed in the broader scope of Qt/qdoc depending on libclang too
    -> until this point in time the setup is a manual one for pyside/5.9+
- merge of psyide repositories -> no objections against the plan in the community
  -> merge will happen in the next few days (pyside.git, pyside-setup.git and shiboken.git become one repo)
  -> examples, wiki and tools will remain as they are
- QOpenGL* porting continuing
- qttext2speech ported to Pyside2
- failing QML tests in Qt 5.9 based Pyside
- PYSIDE-510 - introspection solution in the works
- Qt World Summit Berlin 2017 (talk for Pyside being handed in)


==== 12. May 2017 ====
==2021==
- looked into the Windows tests failures, and the reason might be related to how we copy around build artifacts, leading to an incorrect folder structure. Coin team to look at it.
- Fixed a small regression in 5.9 with building on macOS after some cmake changes that happened in 5.6
- Implemented, tested, reviewed and committed the multimedia widgets examples
- documentation from Pyside1 days can not be generated anymore
  -> new approach required using exiting Qt5 doc tools
- QOpenGL* port to Pyside has started -> missing support for arrays in shiboken
  - more thorough design discussion needed
- Coin
  - provisioning for clang in Qt CI ongoing: https://codereview.qt-project.org/#/c/192517/10


==== 04. May 2017 ====
*[[Qt for Python Development Notes 2021]]
- Coin
  - libclang 4.0 provisioning available (code reviews ongoing -> enabler for Pyside and qdoc testing)
  - 5.6 coin issues resolved
  - macOS related CI/cmake failures were resolved
  - some CI sync issues among pyside submodules (always submodules HEAD is tested)
  => may have to change once we come closer to the final release ->
  => fine as long as we are in heavy development mode
  - discussion around Ubuntu and OpenSuse configurations
  - minimal cmake requirements not met on all distros
    - 5.6 only be build using RedHat 6.6
    - 5.9 builds have updated Linux distros -> may be able to obtain a new cmake version without hacking the standard toolchain
- QtMultimedia and QRaster* API bindings further completed
- added tests and examples for the above bindings/APIs
- PYSIDE-510 (required for simplified and more generic testing of bindings)
- PYSIDE-504 work is ongoing
- PYSIDE-507 -> avoid hardcoded includes when certain Qt modules are not available
- brief discussion whether to merge the shiboken and pyside repo
  -> advantages from a CI perspective and reduces pyside setup complexity


==== 26. April 2017 ====
==2020==
- Coin
  - provision for 5.9+ branches -> we would like to use libclang 4.0
  - test still not yet executed due to branch mismatch which pulls in dev branches
- missing bindings in QtCore/QtGui/QtMultimedia - work in progress
- clang support done (except for a Mac issue)
  - Pyside clang version required Qt 5.7 or later
- [https://bugreports.qt.io/browse/PYSIDE-500 PYSIDE-500] done
- work on PYSIDE-500, 502, 504, 497 will continue
- qdoc work started trying to recover whatever documentation is left from Pyside 1.x


==== 20. April 2017 ====
*[[Qt for Python Development Notes 2020]]
- Fix for [https://bugreports.qt.io/browse/PYSIDE-331 PYSIDE-331] broke the Windows build; under investigation
- Refactoring, fixed build warnings
- Looked at debug builds on Windows


==== 13. April 2017 ====
==2019==
- discussion around merge policies between 5.9 and 5.6 branch
- Linux debug library issues fixed
- PYSIDE-488 fixed via workaround
- fixed a unit tests
- worked on qdoc/html generation in Pyside (failed so far - waiting for qdoc maintainer feedback)
- PYSIDE-331 patches merged -> more bugs found in the meantime


==== 6. April 2017 ====
*[[Qt for Python Development Notes 2019]]
- 5.6 branch created
- 5.9 branch to be created as well (easier setup for Qt 5.9 testing in Coin)
- Coin
    - not passing build platforms have been disabled
    - otherwise COIN passing on 5.6 (except for 2 failing test) -> soon to be enforced
    - license checker passing in dev
- clang changes merged to dev branch (after reviews)
  - clang provisioning on Coin still missing
- for now shiboken is not a generic C++ bindings generator (targeting Qt use cases only)
- TODO: enabling the generation of documentation from repos
- fixed mixed usage of debug and release build (no debug builds for windows)
- [PYSIDE-331] work continuing - fixed, tests are missing


==== 30. March 2017 ====
==2018==
- Coin
    - some platforms passing and will be enabled by default
    - MinGW, some OSX and cross compile targets remain out
- will branch pyside dev branches to 5.6, new dev becomes clang branch
    - regular merges from 5.6 -> dev will start happening
    - Pyside 5.6 branch will continue to work against Qt 5.6
- need reviews for [https://bugreports.qt.io/browse/PYSIDE-323 PYSIDE-323] to merge clang changes
    - Qt 5.10, 5.9 (on main desktop plawtforms working)
    - for now the Pyside dev development will be based on Qt 5.9 (to be bumped up later on)
- [PYSIDE-331] - in progress
- [PYSIDE-156] -


==== 23. March 2017 ====
*[[Qt for Python Development Notes 2018]]
- Coin
  - progressing
- More tests fixed
- wip/clang branch created, will receive Clang parser port with instructions
- Refactoring of shiboken, replaced QtXml classes by QXmlStreamReader allowing for stricter error checking
 
==== 16. March 2017 ====
- Coin
  - the fixes are still integrating or are under review (no further progress until this is done)
- clang parser replacement [https://bugreports.qt.io/browse/PYSIDE-323 PYSIDE-323]
  - most test failures related to clang are fixed
  - tests ran pretty much through on Qt 5.9 (Windows and Linux - Mac not yet verified)
  - code cleanups in shiboken
  - will create feature branch on all pyside repos to get the clang patch series under CI control
  - merges from regular pyside branches into clang branch will commence
  - readme required that explains how clang is to be built (if not provided by platform)
- [PYSIDE-331] - in progress
 
==== 09. March 2017 ====
- Coin
  - lots of changes in Gerrit for Pyside and coin
  - the outcome has to be check once everything merged
  - upcoming clang dependencies in shiboken introduces new requirements for Coin
  - clang changes to be dealt with after pyside branching
- clang
  - first complete bindings generation with Qt 5.6 and Qt 5.9
  - some failing unit tests which have to be looked at individually
  - actual merge depends on pyside branching which in turn depends on recent Coin changes
- smart pointer support
  - patches generally done, gerrit review ongoing
  - rather large patch
- created list of missing bindings in Pyside ([https://wiki.qt.io/PySide2_Missing_Bindings Missing Bindings])
  - mostly class level view, global functions at al not covered
- Jira cleanup
  - PYSIDE-464, PYSIDE-217, Pyside-224 fixed
  - most bugs reviewed now and valid ~100 bugs were identified
 
==== 02. March 2017 ====
- Coin
  - Coin runs tests on Windows and OSX (some failures in the test - to be investigated)
  - Windows provisioning somewhat blocked due to CI issues
  - no progress on Linux
  - OSX 10.8 ran tests with expected results
  - OSX 10.9 has issues due to Pyside not supporting namespace builds of Qt
- clang
  - preprocessor has remaining issue
      -> with clang compiler but gcc seems OK
      -> Qt Core wrapper close to compiling (QHash issues remaining)
- Smart pointer work continues
  - some uses cases work, other use cases might remain
- [https://bugreports.qt.io/browse/PYSIDE-364 PYSIDE-364] was fixed (patch pending)
- General error review on bugreports.qt.io
  - 50% done (prioritized bugs are handled/checked bugs - "done" bugs)
- ran address and leak sanitizer over Pyside which resulted in some worrying cases (need to be addressed going forward)
 
==== 22. February 2017 ====
- [https://bugreports.qt.io/browse/PYSIDE-462 PYSIDE-462] Improved solution approved
- [https://bugreports.qt.io/browse/PYSIDE-205 PYSIDE-205] Hard-to-detect memory leak plugged
  - slow memory leak found in shiboken with thousands of false positives
  - used differential analysis of valgrind output
- Clang: Fixed Preprocessor handling (set defines, include paths), got minimal binding tests to pass, now adapting MetaBuilder and PySide to what Clang finds when parsing Qt. Good news: Very little need to set Q_DOC or other magic defines
- Coin: Slow progress, currently struggling with provisioning
- extensive bug triaging ongoing in Pyside Jira project
 
==== 16. February 2017 ====
- Coin (no update - other priorities in release/CI team)
- Clang (progressing on pre-processor work)
- PYSIDE-315 closed
- PYSIDE-462 more review needed
- Shared pointer API very slowly progressing (lots of different fixes needed)
- QMimeDataBase support added
- QUrlQuery support blocked on QDOC defines in Qt sources (shiboken sets the wrong define)
- chasing memory leaks (PSYIDE-205)
- extensive bug triaging ongoing in Pyside Jira project
  - confirming and testing the reported bugs (70 of 200 processed)
  - some smaller bugs were fixed in the process
- quite a few bugs were discovered this week while working on the above items, e.g.:
  - deployment of pyside applications partly broken due to hard-coded install paths in Qt libs
  - Qt events are swallowed when Pyside error/exception occurs
-
 
==== 9. February 2017 ====
- Clang progressed
  - pure C++ tests for API extractions are passing (C++ parsing based on clang)
  - even works with cmake
  - old C++ preprocessor still to be replaced
  - working through old preprocessor and checking what magic it did and how clang might be able to replace it
- PYSIDE-315 & PYSIDE-462 fixes pending for review
- COIN
  - continue progress an getting more platforms to pass (unblocking one step at a time)
  - Windows (32bit) and mac are building, Win 64bit still not building
  - OSX and Windows are stopping in the test runner phase
  - missing cmake update still on Linux (provisioning update required)
 
==== 26 January 2017 ====
- PYSIDE-315
  - principle fix merged but some minor improvements still pending
- Pyside-462
  - essentially a feature request as C++ default parameters are not yet supported by Pyside
  - discussion ongoing how to address the problem
- COIN
  - 10.11, 10.9 & 10.8 build passes
  - 10.10 still failing during build
  - Progress on Windows and running into new problems further down the path
  - Redhat failed to general brokenness of the platform in CI
  - Ubuntu no further progress
- clang parser work progressing
  - completeness of work is currently measured by passing unit tests
  - there is a long way to go
  - see [https://bugreports.qt.io/browse/PYSIDE-323 PYSIDE-323] and associated patches for progress monitoring
- Fixed regression which prevented Pyside to compile with Qt 5.5.1
- shared pointer support
- no update on 2nd February 2017 (next week)
 
==== 19 January 2017 ====
- PYSIDE-315
  - a possible fix is pending, some minor performance improvements are still possible
  - caused by different signal/slot ordering in Qt4 and Qt 5
- COIN
  - issues on 10.8 and 10.9 platforms should pass now
  - 10.11 & 10.10 still have issues
  - Windows timeout problem fix in COIN (but no COIN update until 5.8.0 released)
  - Linux builds are failing
    - Ubuntu 14.04 fails due to cmake issue
    - Redhat 6.6 & OpenSuse 13.01 deferred
  - current COIN freeze for 5.8.0 release affecting patching of COIN for Pyside
  - next steps in priority -> run tests on 10.8/10.9 and get Linux running
- PYSIDE-79 regression fixed as well (some interaction between PYSIDE-315 & PYSIDE-79)
- PYSIDE-462 to be looked at next
- clang parser work progressing
 
==== 12 January 2017 ====
- PYSIDE-315
  - sorting of slots/signal connection changed on Qt side and Pyside side has not caught up
  - had similar connection issues on the QML side, need to investigate whether there is a connection
- PYSIDE-79
  - caused a regressions (not yet investigated)
- fixed OpenGL types not being recognized on MacOS (partly fixed)
- API's with shared/smart pointers in Qt don't work
  - has potential long term effects and investigation has started into the reasons
- Refactoring shiboken in preparation for clang
- COIN currently runs tests with namespaced Qt
  - short term fix to exclude namespaced Qt builds with Pyside (broken on MacOS 10.9)
  - other failures: missing libraries on MacOS (10.11), missing provisioning on Windows, cmake issues on 10.10
  - unknown state on Linux (current Redhat too old)
- Prioritization after status round:
  - PYSIDE-315 to be investigated based on recent signal/slot patches for QML
  - Smart pointer issues reduced in priority to provide space for PYSIDE-315 & PYSIDE-79 regression
- verify that COIN runs testrunner (not just building Pyside)
  -> not yet verified since we are still failing builds in COIN
 
==== 5 January 2017 ====
- COIN update
  - COIN changes merged (no further patches pending)
  - need to run an integration test
  - issues related to different build platforms still to be expected
- Continue with clang
  - backtracking a bit (reusing some node API's during parsing but otherwise use clang to populate the tree)
- test blacklisting reviewed (some removed - mostly signal related ones, one new regression)
- regressions in QtQuick were worked around (caused by recent Qt Quick changes)
- issues with macos framework style includes in Qt
- PYSIDE-315 debugging ongoing, very hard to track down
    - was it a regression from a previous Pyside release (e.g. Qt 5.4?!?
- hard-copied Qt 5.4 based headers still in existence
  - updated needed but would shut Qt 5.4 users out
</div>
 
== 2016 ==
<div class="mw-collapsible mw-collapsed" style="overflow:auto;">
 
==== 22 December 2016 ====
- lots of discussions around the COIN patches
  - source archive setup being under review
  - Qt 5.6 provisioning patches merged
  - CI uses Python 2.7 at this stage
- clang C++ parsing continues
- fix of some Pyside unit tests (now have a clean slate again)
- finished QtQuick port
- some overflow problems have been fixed in shiboken
 
==== 15 December 2016 ====
- COIN changes pending for testing infrastructure
    -> https://codereview.qt-project.org/177136 (Pyside change)
    -> https://codereview.qt-project.org/176968 (Coin change)
    -> https://codereview.qt-project.org/179662 (Provisioning changes)
    -> https://codereview.qt-project.org/179663 (Provisioning changes)
- waiting for COIN development team to review/accept the pending changes
- no update in PYSIDE-315 (under investigation)
- Flushed out a couple of shiboken, QML, qml example bugs
- Some bugs related to parser delayed until clang parser task done (https://bugreports.qt.io/browse/PYSIDE-322)
- most basic shiboken API extractor test to pass (global enumeration test)
- some trouble with int size data types
    -> Python 2 & 3 are different and the relevant C++ data types are yet again different from platform to platform
 
==== 8 December 2016 ====
- COIN patches pending approval
  - Windows provisioning reviewed
  - Linux, Pyside, COIN itself
- Clang changes progressing, comparing AST tree from old parser and clang
- PYSIDE-79 done
- PYSIDE-315 under investigation
- QtQuick patches taking shape (some template magic and function pointer
  features in Qt cannot be parsed by shiboken)
 
==== 1 December 2016 ====
- COIN
- PYSIDE-79 there seems to be a final work around (https://codereview.qt-project.org/#/c/176374/)
    - fixing a few tests in the process
- clang update
  - dumping AST, identifying the required info
  - work in progress...
- problems with global static QObjects on the Qt side calling back into Python during app exit
  - may require some changes on the Qt side
 
==== 24 November 2016 ====
- automatic COIN triggering for submodules work in progress
  - several discussions on this topic this week
- Clang investigation (what library to use)
- fixing bugs on Qt side for Pyside
- Qt QML support almost done, work will continue with Qt Quick
- PYSIDE-79 work story continues
  - reference counting not quite accurate but point of deallocation of ref count not identifiable
 
==== 17 November 2016 ====
- Pyside team suffering from sickness -> not much progress this week
- Pyside-79 fix had a lot of negative side effects (breaking existing tests)
  - internal object reference counting is the predominant issue at hand
  - continue to work on the bug (no resolution yet as delayed due to sickness)
- COIN some progress but still open discussions on branching policy required
 
==== 11 November 2016 ====
- PYSIDE-79 being fixed
- PYSIDE-315 to be addressed
- Shiboken and Clang
  - familiarizing with clang and its parser's inner working
  - added experimental qmake project definition for shiboken (makes work in Qt Creator easier)
- Qt QML on Pyside work progressing
- work on COIN did not progress due to conflicting priorities inside COIN development
 
==== 3 November 2016 ====
- working through the QML stack esnuring all required API's are exported (https://codereview.qt-project.org/#/c/175682/)
- small build system patches
- PYSIDE-79 work progressing
- OpenGL support fixed (PYSIDE-314)
- COIN issues
    - repo interdepencies not working yet, suggestion under discussion and to be implemented
    - most license checks have been fixed
    - Qt 5.6 based Pyside to skip check
    - after branching for C++11 work the dev branch should work from license check perspective
    - eventually the entire CI needs to run through (more hidden problems could be hidden)
- Started working on C++11 compliant parser for shiboken
    - libclang will be used
    - first target is to replace the AST tree implementation
    - requires clang setup in the CI
 
==== 27 October 2016 ====
- Work on WebKit/WebEngine support
- Further work on [https://bugreports.qt.io/browse/PYSIDE-431 COIN] support
- Planning meeting
- Workshop for C++11 support in Pyside ([https://bugreports.qt.io/browse/PYSIDE-323 PYSIDE-323])
 
==== 20 October 2016 ====
- [https://bugreports.qt.io/browse/PYSIDE-355 Qt Quick support] submitted
- [https://bugreports.qt.io/browse/PYSIDE-314 QtOpenGL support] submitted
- Further work on [https://bugreports.qt.io/browse/PYSIDE-431 COIN] support, license headers
==== 13 October 2016 ====
- Qt CI update
  - Coin changes have merged but integration not yet working
  - Qt CI enables on Pyside side merged
  => COIN integration fails with license issues
  => requires review of license conditions for all files, some files are not even relicensable
  => skipping license check for now, most likely to be done later again but requires changes to license check script
  - more issues of interworking between QtCI and Pyside expected (won't be visible until license problems resolved)
  Open issue: does a change in Pyside repo trigger a rebuild of everything?
- Qt QML support progressing and first patches merged
  - serious bugs have been fixed, more complex QML examples are now working
 
==== 29 September 2016 ====
- Coin integration close but not merged
- Bugfixing in particular on the shiboken parser side
- QML/Python binding and tests fixed -> general check all day-to-day aspects of QML are working
- QML examples porting
    -> still some failing tests
    -> Check all QML/Quick class are exported
 
==== 22 September 2016 ====
- Refactored Shiboken, udnerstanding build sequences
- black list for unit tests defined and tested
- fixing of tests
- QML example fixing continued (QML bindings not working)
- Pyside side for COIN done (pending integration checks)
- COIN integration still wip due to long test and retest cycles
- pyside and shiboken repo to be relicensed similar to other Qt products
=> this should address any issues regarding the status of generated code too
==== 16 September 2016 ====
- Pyside side for CI testing ready for testing
- status of COIN side to be determined. Code exists need help from CI team to confirm status.
- build system infrastructure improvements in pyside setup
- Qt logging now working
- and more
- Update on bug handling
  - PYSIDE-88 continuing
  - PYSIDE-349 (Multimedia ported)
  - PYSIDE-344 fix pending on codereview
  - make debug builds of Pyside work (OSX works, Linux has work in progress patch, Windows side awaiting contribution)
- QML support work in progress
  - examples are slowly ported with aim to identify bugs
 
==== 25 August 2016 ====
- Properly implementing QML experience in Pyside
- Unit test fixing
- automated CI testing for Pyside
  - working locally but still failures occurring on various other test machines
 
==== 4 August 2016 ====
- Additional Pyside examples under review
- Fixed warnings coming from Shiboken
 
==== 21 July 2016 ====
 
- main Pyside 2 example port done
- additional examples to fill gaps are being ported (as per prio list)
- CI patches running, but still gaps (should be done by next week)
- about 86% of auto test working (failing count of test 80+ auto test)
- [[pyside-Teststatus|Project Test Status]]
 
==== 14 July 2016 ====
 
- Pyside 2 examples ported
- OpenGL & SVG not working
- QtQuick 2 is in strange situation (QtQml depends on QtQuick)
- Python 3 realed Unicode handling not working with Qt
- QMessageBox hangs
- no documentation for any example
- lots of warnings when building wrapper
- results: https://paste.kde.org/pgje2toyh/mlbqic
- COIN setup for pyside https://codereview.qt-project.org/#/c/158336/
- Qt 5.7 still blocked due to missing C++11 support in shiboken
    - food for ideas: https://steveire.wordpress.com/
 
 
==== 7 July 2016 ====
 
- automated CI testing
- patches for Pyside and Qt CI side required
- Testing somewhat more complicated due to closed nature of Qt CI
- script to port examples to Qt 5 -> https://bugreports.qt.io/issues/?jql=labels%20%3D%20exampleport5
- all examples to remain BSD licensed
</div>

Latest revision as of 09:45, 13 June 2024


2024

13. June 2024

  • General
    • Python 3.9 story: the decision was made without considering that 3.9 is still getting security releases, so we have decided to keep supporting Python 3.9 for PySide 6.8 LTS, but we might drop it in the middle of some bug-fix releases.
      • Things that are considered to support certain python versions are: Internal CI Python versions for each OS, Python version lifecycle https://devguide.python.org/versions/, features that will improve user experience from new versions.
      • Python stubs (pyi) might be compatible with 3.10+
    • Qt Group is sponsoring EuroPython 2024: and we will give a talk!
  • Infra & Releases
    • 6.7.2 packages are ready to be released.
    • Boot2Qt had a few issues that were solved.
    • Starting process to test windows arm64 (discussion around libclang)
    • Nightly builds:
      • Possible solution for linux and macOS arm64 android builds.
      • Maybe also for non-unity builds? it has been failing in some corner cases.
      • We could have dev-android branch so we don't block the normal dev development.
      • nightly builds merge automatically if everything passes.
      • PyPy integrations might join a similar configuration as well.
  • Bugs & Features
    • Android wheels from macOS host through coin successful. Assembling the final patch. Coin still running tests for an Android build and error-ing still needs to be resolved.
    • PYSIDE-2702 - Flatpak base app implementation started.
    • PYSIDE-2781 - pyside6-deploy failure investigation ongoing. Could be a Nuitka issue. User using the latest Nuitka.
    • Working on improve our typing implementations.
    • QtAsyncio: internal presentation including the theory behind and some live examples.
    • Lazy load: disabled for PyPy, fixing some shiboken-tests
    • QtScrypt: development continues
    • PYSIDE-2780 refcount bug in the lazy import fixed
    • PYSIDE-2751 3.13 compatibility patches are ready, nogil under development
    • PYSIDE-2701 reduction of binary sizes under investigation, estimating the achievable reduction

06. June 2024

  • General
    • Maintenance work next week will keep the CI offline (Monday morning, phase I + Wednesday, phase II)
    • PySide 6.8 will support Python 3.10+
    • Must read https://peps.python.org/pep-0741/
  • Infra & Releases
    • Some issues with the macOS CI units.
    • Local raspberry pi 4 (aarch64) for testing: 10.9.78.82
    • qtpip 0.1.2 release: mostly issues around the commercial version tag and the usage of '+' and '.'
    • 6.5.6 commercial LTS was released.
    • 6.7.2 release will happen soon (due to an issue with designer)
    • the Python 3.9 macOS CI configuration will be updated to 3.11, and the windows with 3.11 will be updated to 3.12
  • Bugs & Features
    • https://bugreports.qt.io/browse/PYSIDE-2622 - Standalone mode for Deployment as per many requests from users
    • Deployment tests fixed with a custom PySide6 build. There might be corner cases that were missed.
    • https://codereview.qt-project.org/c/pyside/pyside-setup/+/537466 ready, but waiting for macOS x86_64 to update Python to 3.11 - https://codereview.qt-project.org/c/qt/qt5/+/565565/4 (Thanks Simo)
    • Patches ready for updating python syntax to drop typing.Optional (and use | instead) that will go in once we drop 3.9
    • Preparing presentation and improvements to QtAsyncio
    • PYSIDE-2440 will be prepared.
    • op codes changing in Python, is altering some of our internal implementation, like the forgiveness mode.
    • https://bugreports.qt.io/browse/PYSIDE-2751 planned work for the no-gil feature in Python 3.13
    • smart pointers with lazy loading were not working, but a fix was merged.
    • Qt Designer had a regression that motivated 6.7.2
    • Qt 6.8 adaption taking a lot of work due to doc changes and QtGraphs
    • PYSIDE-2772 issue ended up being a user problem

30. May 2024

  • General
    • PySide 6.8 will most probably support Python 3.10+
    • Evaluating arm64 wheels for Windows
  • Infra & Releases
    • Discussion about the Qt for Python in boot2qt
    • PyPy releases has been on hold due to some internal CI problems.
    • Commercial packages will now be available on the following day after community packages.
    • qtpip is planned to support aarch64
    • 6.5.6 commercial lts will be released next week
  • Bugs & Features

23. May 2024

  • General
  • Infra & Releases
    • Preparing 6.7.1 with a lot of fixes
    • 5.15.17 LTS released
  • Bugs & Features
    • PYSIDE-2747 Fixed PySide to run on Fedora 40 with 3.12-3
    • PYSIDE-2749 Worked on a performance regression related to Lazy Init
    • PYSIDE-2758 Added QQuickWebEngineProfile.setUrlRequestInterceptor()
    • PYSIDE-2762 Fixed a type hinting bug
    • Brushed up and fixed a few examples
    • 6.8 Adaption
    • Python 3.13 check
    • PYSIDE-2751 Python 3.13 first step towards --disable-gil compatibility (no ob_refcnt)
    • pyside6-deploy. Ignore files with .webp, .cpp.o, .qsb and .qen extension as Nuitka errors with them.
    • Close to macOS cross compilation

16. May 2024

  • General
  • Infra & Releases
    • 5.15.17 commercial lts needs to be re-packaged one more time due to 3rd party components updates.
    • 6.7.1 release will also be re-packed. LE for release is 20th of May
  • Bugs & Features
    • PYSIDE-2753 - Added missing libQt6DeclarativeOpcUa binary to wheels
    • PYSIDE-2750 - Added missing libQt6VirtualKeyboardSettings binary to wheels
    • Exclude .qsb, .webp, .cpp.o and .qen from deployment due to Nuitka error. Error report raised in Nuitka - https://github.com/Nuitka/Nuitka/issues/2854
    • Working on macOS cross compilation. The clang parser of shiboken generator needs some changes for cross compilation. Tricky changes incoming.
    • PYSIDE-2748 - Fixed a type hint error
    • PYSIDE-2747 - Diagnostics and minor fixes for a crash on Fedora, no real fix though
    • PYSIDE-2711 - Fixed a bug in QWidget/QObject.parent()
    • Work on type discovery in libshiboken, added helpers to dump internal state, performance considerations
    • PYSIDE-2620 - Adapting to 6.8
    • PYSIDE-2745 - Fixed a bug with exceptions in 0-delay singleShot timer slots
    • PYSIDE-2404 - Lazy Loading completed by supporting subtypes. This gives 8-9% more performance.
    • Support for Python 3.13 started - first compatibility before switching to disable-gil
    • Possibilities explored to lazy load signatures or save space.

2. May 2024

  • General
    • OKR reviews for the next quarter.
    • Got a long document with feedback of a few tools we provided, that will help us improving our tooling!
    • Started the planning of moving away from '<file>.pyproject' to 'pyproject.toml' for pyside projects, in order to add options for our tools.
  • Infra & Releases
    • 5.15.17 commercial lts needs to be re-packaged due to 3rd party components updates.
    • 6.7.1 to be released next week.
    • Add new mechanism to test snapshot wheels.
  • Bugs & Features
    • PYSIDE-2698 - ListProperty features fixed. Added tests to check all the features.
    • PYSIDE-2705 - issues with signal disconnect warnings fixed
    • macOS cross compilation for Android - stuck on a CMake issue. Progressing well.
    • PYSIDE-2709 - Analysis ongoing for this QML registration regression
    • Work on improving/documenting type discovery in shiboken
    • Enumeration support in QtScrypt
    • PYSIDE-2676 - PEP 697 extension in Python 3.12 fixed
    • BT bug research, cannot be reproduced and application doesn't hang. Connection is not successful.
      • Issue might require special hw
    • Documenting QtAsyncio implementation details.
      • An internal presentation is being prepared.
    • Possible QtAsyncio feature, 'run' supporting context managers.
    • macOS cross compilation for android being tried


25. April 2024

  • General
    • Successful talk at PyCon DE. Good response.
  • Infra & Releases
    • Preparing 6.7.1
    • 5.15.17 Commercial LTS is also soon to be prepared
    • sccache seems to be not properly behaving (on windows) because we are not getting enough output.
    • PySide6_DS wheel to be adjusted and hopefully be released soon.
  • Bugs & Features
    • Added a number of new classes
    • PYSIDE-2676 issues on ubuntu (might be related to a windows issue as well)
    • Implementation of Lazy Groups in order to avoid the regression in 6.7.0 due to multiple inheritance.
    • Alternative for Lazy Groups (Fix for the regression on 6.7.0)
      • Work on regressions introduced by lazy initialization PYSIDE-2675
    • Work on a crash in Python 3.12 PYSIDE-2676
    • Fixed memory leaks PYSIDE-1617
    • Work on our QML list property support PYSIDE-2698
    • Added pyside6-balsamui (ui tool for pyside6-balsam) - PYSIDE-2629
    • Also checking out List Property error with `count` and `at` parameters - PYSIDE-2698
    • Updating old example (calqlatr) - https://codereview.qt-project.org/c/pyside/pyside-setup/+/523055 for responsive layout
    • QtAsyncio: refinements to the current implementation, and solved a bug report.
      • Trying to add support to Keyboard interruptions (handlers)
      • Plan to improve exceptions handling

18. April 2024

  • General
    • Bug fixing week
    • PyConDE (Mon-Wed next week)
    • Planning a workshop for TQtC solution engineers (internal)
    • Possibility to include shiboken into the Axivion infra
  • Infra & Releases
    • 5.15.17 commercial LTS was postponed to Friday. Still need test on Windows.
    • 6.5.6 release planned
    • 6.7.1 release has been postponed to the first week of May
    • DS-compatibility wheel postponed due to CI issues
    • We might need to create a testing platform in order to check other errors that are not detectable with simple tests.
  • Bugs & Features
    • Few new type hints issues from 6.7.0 release, needs to be address on 6.7.1
    • QtAsyncio issue related to Task groups. Tricky, because it can be related to Qt Events.
    • PYSIDE-2629 Adding more Qt-tools to the wheels
    • PYSIDE-2622 Adding a new option to the deploy tool (exposing an option from Nuitka)
    • PYSIDE-2675 Lazy loading issues with trees of polymorphic classes.
      • first approach made things less effective
      • The impact of the solution was reduced a bit, by disabling the feature for special multiple-inheritance cases
      • New idea on 'groups' that be handled differently, so we have group or classes grouped and dependant
    • 825 qml bug is still around
      • PYSIDE-2676 seems to be a new approach to fix it
    • A few customer bugs made it the bug fixing week.
    • PYSIDE-2675 type discovery code, class inheritance
    • QtAudio -> QAudio refactory
    • Virtual function compatibility to modify the signature (from typesystem)
    • PYSIDE-2492 uic issues for Enum compatibility
      • More improvements for Python projects (import options)
    • PYSIDE-2685 nan type definition
    • Removing code from shiboken
    • 6.8 Adaption already started
    • PYSIDE-2689 sphinx directives doesn't seems to be compatible with the search context.

11. April 2024

  • General
    • Bug fixing week.
    • Qt 6.6.3 Library split broke our release, so we provided 6.6.3.1 as a fix.
    • Qt 6.7.0 also had an issue with a binary incompatibility change on QtAudio and QAudio
    • Maybe we implement a simple channel of communicating this details, in order to avoid breakage [maybe architect meetings]
    • Qt Creator 13 creates venvs automatically. This needs to be revisited to avoid multiple environments to be created.
    • New epics with brainstorming ideas.
  • Infra & Releases
    • 6.7.0 was released, we found a couple of issues we are trying to solve, and 6.7.1 will soon be released due to a binary compatibility break, and other small breakage.
    • 5.15.17 commercial LTS to be release next week.
    • QtDS packages a bit delay due to CI errors.
    • Qt Installer (Maintenance tool) has still some issues with the structure.
  • Bugs & Features
    • Adding new Qt tools to the wheels (wrappers)
    • PYSIDE-2602 special virtual function research
    • PYSIDE-2669 designer issue
    • PYSIDE-2675 Addressing the lazy import issues that were found in 6.7.0
      • Studying the possible solution, but it needs to consider other cases as well.
      • the *-import handling seems to be related, and affecting the mro content, duplicating some entries.
      • the type discovery handler might be related as well
    • Still working on the qml 825 bug issues.

4. April 2024

  • General
    • Large part of the team at conferences/on Easter holiday
  • Infra & Releases
    • Released 6.6.3.1 release with fixes for Quick Controls/Multimedia
    • Preparing for 6.7.0
  • Bugs & Features

28. March 2024

  • General
  • Infra & Releases
    • Prepared 6.6.3.1 release; 6.6.3 was unfortunately broken due to missing libraries (Quick Controls/Multimedia)
  • Bugs & Features
    • PYSIDE-2654 Fixed multiple inheritance when no __init__ is in a subclass
    • Still investigating a crash on Ubuntu with Python 3.12 and bug_825.py . The crash is deeply hiding in Qt6.
    • PYSIDE-2652 Fixed an int overflow
    • PYSIDE-2649 Work on building without OpenGL
    • PYSIDE-2653 Fixed a syntax error in type hints

21. March 2024

  • General
    • Ideas to improve the module.
    • Most of the team is going on vacation the following weeks.
  • Infra & Releases
    • 6.7.0 to be released the first week of April [delayed]
    • 6.2.12 Commercial LTS to be release in the following days [delayed]
    • 6.6.3 to be release next week [delayed]
  • Bugs & Features
    • 6.8 adaption patches are being worked
    • PYSIDE-2638 fix crash QLayout when None is passed
    • Documentation updates: for tooling and examples.
    • QtRhi missing API provided
    • Memory leak regression being worked out
    • Shiboken Qt namespaces patches being cherry picked to previous versions.
    • Android deployment and qml tool documentations
    • Android wheels generation on the CI process is being improved.
    • Debugging deep into Nuitka to understand a problem with the lazy loading functionality.
    • QAsyncio bug fixed
    • Adding more tools docs pages for our tools.

14. March 2024

  • General
  • Infra & Releases
    • 6.7.0 in preparation, docs adjustments and new pages will come. Branching on Monday.
    • 6.2.12 LTS release in preparation.
    • 6.6.3 will be release next week.
    • qtpip 0.1.1 to be released
    • dev is already Python 3.8 free, and we support 3.9+ for 6.7+
  • Bugs & Features
    • Triaging and fixing issues in general: 2638 layout crash.
    • PYSIDE-2690 namespaces support continues
    • Lazy initialization got merged
      • New improvements might land in future versions
    • PYSIDE-2635 OpcUA example problem
    • PYSIDE-2633 remoteobjects issue
    • Using new icons on the examples
    • Testing libclang 18
    • QObject.connect bug when a callable is a QObject (workaround with manual overload)
    • QIOPipe implementation for QAsyncio (base in the Qt/C++ one)
    • New use cases for QAsyncio and aiohttp
    • permission API changes got merge
    • android wheel compilation was adapted for qt 6.7.0 (PR on python-for-android was merged)
    • PYSIDE-1639 QLocale issue was fixed

07. March 2024

  • General
    • Participation in FOSS Backstage
  • Infra & Releases
    • 6.5.5 Commercial LTS was released
    • 5.15.13 OSS Package will be released tomorrow
    • qtpip 0.1.1 release delayed
    • Python 3.8 deprecation is still pending due to CI configuration dependencies.
  • Bugs & Features
    • permission api changes are mostly merged, one pending https://codereview.qt-project.org/c/pyside/pyside-setup/+/536759/15
    • all deployment fixes are in.
    • lazy initialization work continues, and some issues were fixed already.
      • Ubuntu 22.04 | Python 3.10.2 |is showing an issue with scriptableapplication
    • Continue implementing more API for QtAsyncio which is currently working well
    • two pending change for 6.7.0 and 6.6.3 to be merged.
    • PYSIDE-2590 qt namespaces support required a patch for Qt/C++
    • PYSIDE-2619 gentoo issue with a build
    • PYSIDE-2624 typing issue with '/' is being researched
    • Qt Icon Teams issues were discovered
    • PYSIDE-2602 virtual function research on a special signature
    • One regression related to the QObject.connect changes.

29. February 2024

  • General
    • Leap day!
    • Documentation changes
  • Infra & Releases
    • 6.7.0 will drop support of Python 3.8
    • 6.5.5 to be released in the following days
    • 6.7.0 RC marks our feature freeze, some exceptions will be discussed in order to release on time.
    • qtpip 0.1.1 to be released soon for new indexing and shiboken_wizard package
    • General update of Python versions in our CI configuration is being planned (for dev-6.7)
  • Bugs & Features
    • PYSIDE-2599 QMatrix3x3 issues with QVariant
    • PYSIDE-2605 Embedding an application, using .style() - qAPP
    • PYSIDE-2590 QT_NAMESPACES support
    • PYSIDE-2602 clash on signature for QtWebEngine returning tuple
    • Preparing 6.5.5 and 6.7.0 releases.
    • PYSIDE-2612 CMake issue from Anaconda builds when find_package
    • macOS permissions changes are almost all merged
    • Windows BTLE services crash
    • QIO-class are required for some new QAsyncio API using pipes
    • Lazy loading moving forward, but still a few issues are around
      • A couple of shiboken tests seems to have outdated imports that are not helping.
      • shiboken compatibility types missing
    • Typing issues being solved in order to improve the pyi quality

22. February 2024

  • General
    • Brainstorming discussion about new JIRA items.
  • Infra & Releases
    • 6.6.2 was released!
    • qtpip getting a new minor version in order to be able to install new shiboken wizard
  • Bugs & Features
    • Permission API issue failing on the release framework. QtLocation problems were addressed.
    • QtAsyncio blog post was published.
    • Definition of done for QtAsyncio story, some functions will be implemented, but other ones (until reaching the whole set of user facing API) will be implemented in the future.
    • Lazy initialization of numpy support in PySide, to improve the general lazy loading effort.
    • Starting documenting pyside6-* tools
    • PYSIDE-2610 Qt3D issues
    • 6.7 adaption was a lot of work, namespaces were something tricky.
    • 6.7 changelog drafted.
    • Started to improve the type hinting issues.

15. February 2024

  • General
    • Brainstorming session was held.
    • Europython Call for Proposal is open!
  • Infra & Releases
    • 6.6.2 release waiting for Qt/C++ packages to be done.
    • Commercial 6.5.5 LTS to be out next week.
    • Some improvements to the CI and macOS behavior
    • Cherry pick bot on commercial repositories.
  • Bugs & Features
    • singleShot changes are merged, keep an eye on strange behavior.
    • 6.7 adaption: metaobjectdump improvements
    • 6.6.2 fixes with the commercial shibokenwizard
    • lupdate support for pyside improved (qm files)
    • pyside6-project problems with dry-run were fixed. Some improvements planned.
    • CI android wheels upgrade [skip armv7 in the meantime]
    • Lazy imports research continues, we see lots of improvements on apple M* devices.


8. February 2024

  • General
    • We got a PyConDE 2024 talk accepted (python -> android deployment)!
  • Infra & Releases
    • Addressing some issues with the android wheels
    • 6.6.2 got delayed until next week
    • Preparing for the 6.7 switch on dev
  • Bugs & Features
    • macOS: permission api patches ready for review
    • singleShot patches merged
    • Lazy initialization was finished, and ready for discussion.
    • Check compatibility with the new REST module (from Qt/C++)
    • Preparations for 6.7 continues.

1. February 2024

  • General
    • Interest from KDE to enable flatpak packages (maybe base pyside app).
    • Discussion on adding more tutorials of specific functionality.
    • CI Maintenance Break next Monday (first Monday of each month)
  • Infra & Releases
    • no unity build discussion and checks
    • 6.6.2 to be released next week.
    • More granularity on the commercial wheels: shiboken wizard wheel.
  • Bugs & Features
    • singleShot timer implementation (to use underlying c++ impl) - still an issue with a context object, and a signal as a functor. A new QObject::connect might handle the situation. More changes to come in order to fix newly discovered issues.
    • Android: using the master branch on python-for-android, and other changes related for macOS deployment.
    • PYSIDE-2597 optimization for the deployment procedure
    • Lazy initialization: works continues, and it's looking good. 13 bugs to go on lazy mode. The new implementation seems to be working better.
    • 6.7 adaptation still in progress (many changes from Qt)
    • General documentation adjustments
    • Improvements on shiboken: better error messages
    • Qt Namespaces compatibility attempts.
    • Moving away from a couple of setup.py options towards pyproject.toml after upgrading 'build' to 1.0.x
    • Design Studio compatibility wheel work continues


25. January 2024

  • General
    • Configuring additional embedded devices for RTA
    • Focus on spending some time on embedded linux, in order to see usability, and compatibility with Boot2Qt images.
    • Conferences: submissions to PyCon SK, PyCon DE, PyCon LT, PyCon US
  • Infra & Releases
    • Decouple of the commercial wheels in order to have a finer granularity and simpler tree on the Qt Installer (Maintenance Tool)
    • Qt for Python 6.6.2 is waiting for Qt to be released (by the end of the month)
    • The next 5.15.13 LTS open source release will include a new fix for a missing symbol (PyIndex_Check)
    • New CI configuration without '--unity' for manual testing, to spot issues.
  • Bugs & Features
    • VS Code will use .flake8 (formerly setup.cfg) file for configuration once merged
    • PYSIDE-2575: Added a new argument to QtAsyncio to configure whether the QCoreApplication at the core of QtAsyncio should be shut down when asyncio finishes (requested by user).
    • SingleShot timer issue: Slight "complexity explosion" because correct implementation for one case requires implementation of QObject.connect overload with context arguments (and we implement QObject.connect ourselves, see PySide::qobjectConnectCallback).
    • Scripting: code simplification, and massage it to a Qt module.
    • Documentation updates to fix issues we had.
    • Unity build some issues when building without.
    • 6.7 updates, adapting some warning messages
    • QTBUG-99313 related issues
    • macOS permissions: made an example to work (for deployed apps) - patches incoming
    • Android wheels provisioning and configuration in order to generate the base-wheels.
    • armv7 complications due to an upstream find_python command.
    • Lazy initialization: re-wrote approach from scratch, to reduce the patches to one that can be analyzed easily. Some complications with this approach that needs to be improve. It can be tried with https://codereview.qt-project.org/c/pyside/pyside-setup/+/496118
    • Moving entry_points declaration to pyproject.toml from setup.py
    • Drop the bdist_wheel steps from the CI (old wheels)
    • Started working on split commercial wheels, wheels for QtDS and examples on QtCreator.

18. January 2024

  • General
  • Infra & Releases
    • Commercial LTS 6.2.11 was released
    • Add missing tags OSS LTS 5.15.x
    • 6.6.2 scheduled by the end of the month
    • Release documentation to be written to have tasks on JIRA
  • Bugs & Features
    • Python Scripting: looking into stable API, and cleanup
    • PYSIDE-2577 doxygen issue
    • PYSIDE-2570 closing some roadmap items
    • Polishing documentation to use more sphinx directives
    • Qt 6.7 adaption
    • Addressing some flake8 issues in the build_script
    • macOS permission API work continues: limitation for interpreted script, only compatible when deployed. Working around nuitka.
    • singleShot: trying to solve a corner case when no sender is specified (for using the C++ function directly)
    • Fixing some CI problems with 3.11 -> 3.12 changes.
    • PYSIDE-2404 adding more information regarding the lazy evaluation, new approach might work.
    • pyside6 is now an official recipe on the python-for-android!
    • Improvements to the doc build process

11. January 2024

  • General
    • Hackathon at TQtC
    • CI process presentation
  • Infra & Releases
    • Commercial LTS 6.5.4 release starting (to be finished today)
    • Commercial LTS 6.2.11 still pending release
    • 6.6.2 schedule by the end of the month.
    • CI still showing some issues after the maintenance break.
    • Update of the Python versions are pending.
  • Bugs & Features
    • Fixing a few small issues with QtAsyncio
    • Documentation for the QtAsyncio is currently in review.
    • New behavior for singleShot (relying on the C++ impl)
    • macOS request permission API work continues.
    • 6.7 adaptions patches
    • M2M fixes on the current impl
    • Native interfaces were added (new ones) to public headers
    • favicon issue with out docs
    • Making our doc diagram generation optional
    • Improvements for the doc build process

04.January 2024

  • General
    • Happy new year fellow readers :D
    • New OKR organization
    • Keeping in an eye on Conferences
    • PyPy is now on 3.10
    • Ideas on the wheel organization for the Qt Installer
  • Infra & Releases
    • CI Maintenance break continues. Some new issues were discovered.
    • Pending releases: 6.2.11 and 6.5.4
    • Android wheels for testing purposes are available (not for production)
    • Xcode issues with a new M3
    • Planning the inclusion of Python 3.12 in the CI
  • Bugs & Features
    • async: A few bug fixes were pushed and ready for review
    • async: the module is missing from our docs
    • async: we have been getting some interests from users, so new issues are appearing.
    • new android tag added to the examples for a better browsing
    • pyside6 designer pyenv crash was fixed
    • pyside cmake module update crash was fixed
    • working on the request permission API for macOS
    • docs: free functions as separate section and other improvements
    • Python scripting in c++ works continues
    • PyPy 3.10 compatibility patches
    • nogil: working again on a compatibility with PEP703
      • locking mechanism for our modules.
    • Typing adjustments, we need '/' in our signatures due to not having keywords parameters.

2023

2022

2021

2020

2019

2018