Skip to content

MEP27 Part1: WindowGTK, Refactoring the FigureManagerGTK classes #28699

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

OceanWolf
Copy link
Member

PR summary

This PR exists as Part 1 of an attempt to resolve MEP 27 by splitting my previous PR (#4143) into smaller, more manageable, and thus easier to review chunks. Whilst my previous PR focussed solely on GTK3, this PR focuses solely on the windowing aspect of GTK3/4 with the rest of GTK3/4 refactor and MEP 27 infrastructure to follow in future PRs. Each of the other backends will then have the additional classes added in one PR per backend (~300 lines of code) This MEP has the ultimate goal of deprecating FigureManagerBase and all of its subclasses, in favour of a single GUI agnostic FigureManager class, similar to what FigureManagerGTK looks like in this PR.

The Window API of MEP27, implemented here, allows for the possibility for (multiple) toolbars to get placed along any edge of the window. I had written an example in my previous PR, but I have left that for a future PR, but can also easily get added here (~50 lines of code)

This PR has mainly been a copy/paste from my previous PR, but for: the addition of GTK4 which was released in the meantime; and taking into account other changes that have occurred in the MPL GTK codebase since then. In doing so, I have taken the opportunity to clean the codebase with respect to the differences between GTK3 and GTK4.

PR checklist

…tor, splitting up previous PRs into smaller easier to review chunks.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant