Feature: Auto-share default with compatibility-aware grouping#560
Merged
cvanelteren merged 38 commits intomainfrom Feb 11, 2026
Merged
Feature: Auto-share default with compatibility-aware grouping#560cvanelteren merged 38 commits intomainfrom
cvanelteren merged 38 commits intomainfrom
Conversation
for more information, see https://pre-commit.ci
beckermr
approved these changes
Feb 11, 2026
K-Mirembe-Mercy
pushed a commit
to K-Mirembe-Mercy/UltraPlot
that referenced
this pull request
Mar 22, 2026
…lot#560) This PR adds compatibility-aware auto sharing for subplot axes so mixed axis families (e.g., cartesian + polar/geo) no longer produce avoidable sharing warnings or incorrect sharing side effects by default. ## Why this change UltraPlot’s sharing model has explicit levels (`0` to `4`), but real figures often mix projections and axis types that are not compatible for full sharing. Previously, default sharing behavior could still attempt incompatible sharing, which led to noisy warnings and confusing outcomes. ## What this PR changes - Adds `share='auto'` as a first-class sharing mode in figure/subplot parsing and docs. - Keeps existing explicit levels (`0..4`, aliases) fully supported and unchanged in intent. - In auto mode, sharing starts from level-3 semantics but only applies within compatible axis groups. - Introduces compatibility checks used before sharing: - axis family/class compatibility - scale compatibility - units/converter compatibility - projection-related compatibility - Partitions candidate shared axes into compatible groups, then shares per group. - Deduplicates incompatible-share warnings so users see concise diagnostics instead of repeated noise. - Updates cartesian `set_xscale` / `set_yscale` flow to unshare + refresh in auto mode when scale changes would invalidate compatibility. - Documents auto-sharing behavior and mixed-axis examples in `docs/subplots.p`. --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
This PR changes default subplot sharing to a compatibility-aware
share='auto'mode, while preserving explicit share levels (0..4, aliases) as hard overrides.The goal is to avoid noisy/inaccurate default sharing for mixed axis families (for example cartesian + polar) and to keep expected shared behavior for compatible grids.
Design Changes
share='auto'inFigure(sharex/sharey/share).xscale/yscale)False/0,labels/1,limits/2,True/3,all/4):Behavioral Expectations
subplots.share='auto'):share='all', etc.):Tests Added
Docs Updated
sharex/sharey/sharenow documents'auto'and explicit override semantics.'auto'and includes a mixed cartesian/polar example.Out of Scope