Skip to content
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

Implementation of GC to enable multi zoom level support for win32 #1214

Merged

Conversation

amartya4256
Copy link
Contributor

@amartya4256 amartya4256 commented May 6, 2024

Addressed issues

Requires

Note: Only the last commit in this PR is to be reviewed. Previous commit(s) belong to the prerequisite PR(s)

Unlocks

Description

This pull request is a base pull request for several following PRs which implement multi zoom level support for different components (resources, widgets, etc).

In this PR, the focus is on GC to enable it to use the zoom level information which is added to widget. Also, it provides zoom level information in GCData which can later be used by resources like Image, Region, etc which don't have the zoom information since they are not a widget. Also, GC now uses the DPIUtil methods with zoom for getting the size as per the zoom level. This zoom in GC is derived from the GCData where we add the zoom information.

Copy link
Contributor

github-actions bot commented May 7, 2024

Test Results

   418 files  ±0     418 suites  ±0   9m 15s ⏱️ +27s
 4 121 tests ±0   4 113 ✅ ±0   8 💤 ±0  0 ❌ ±0 
16 313 runs  ±0  16 221 ✅ ±0  92 💤 ±0  0 ❌ ±0 

Results for commit f23c721. ± Comparison against base commit 567a8b4.

♻️ This comment has been updated with latest results.

@iloveeclipse iloveeclipse removed their request for review May 7, 2024 14:02
Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @amartya4256 , thank you for your contribution.

I noticed some problems with the visibility of some fields (the most serious one is allowing to set the deviceZoom and nativeDeviceZoom separately.

Could you please look into it?
Thank you.

@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch from 3a3458a to 18b420d Compare May 8, 2024 09:54
@laeubi
Copy link
Contributor

laeubi commented May 8, 2024

I just wanted to note that (platform dependent) package private or even public fields / methods are quite common, they should just be documented in this case as platform dependent.

@fedejeanne
Copy link
Contributor

I just wanted to note that (platform dependent) package private or even public fields / methods are quite common, they should just be documented in this case as platform dependent.

@laeubi Is it really necessary to specify that a package private field/method inside a fragment is platform-dependent? I mean the fragment is already platform-dependent and the field/method can't be seen outside the fragment. Or am I missing something?

@fedejeanne fedejeanne dismissed their stale review May 10, 2024 07:25

My requests were addressed.

@laeubi
Copy link
Contributor

laeubi commented May 10, 2024

@fedejeanne I have only seen it on public field, so maybe in my sentence it should read as an XOR so:

Either the field is package private or instead public but clearly documented to be platform dependent.

:-)

Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The tests are broken

@HeikoKlare
Copy link
Contributor

The tests are broken

Note that new test classes in a test plug-in usually need to be added to the plug-ins test suite. In the win32 SWT tests, this is the AllWin32Tests test suite. If you do so for the new GCWin32Tests, the PR build will fail on Windows because of the test failures mentioned by @fedejeanne.

If you cannot provide reasonable, sufficient tests via public API only, you need to add the test cases in the win32 fragments, as prepared for the DefaultSWTFontRegistry and ScalingSWTFontRegistry in #1203.

@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch 2 times, most recently from 27f3996 to 40f7c63 Compare May 13, 2024 16:17
@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch from 40f7c63 to 90e57ec Compare May 14, 2024 07:20
Copy link
Contributor

@HeikoKlare HeikoKlare left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have some remarks and questions regarding the current design for which I need some clarification before I can approve this. The essential problem I have here is with respect to responsibilities. My understanding is that in the proposed implementation Controls are reponsible for updating zoom data used by a GC indirectly via changing values in GCData. This leads to visibility problems, duplicated logic for setting these values across package borders etc.. Since these values only seem to be a cache of information provided by the underlying Drawable of a GC, I do not understand why (1) this caching is necessary and (2) why GC cannot simply listen for zoom change events at the Control and then update the data itself but requires the Control to take care of it.
And even if the information really have to be provided to GCData (e.g., because they will be required by other Resources, as mentioned in the PR description), I would still expect the GC to be responsible for updating them and not the Controls. Then you should also get rid of the current visibility problems.

Please also extend the commit description with information about

  • why these changes are necessary, and
  • what they do,

so that people are able to understand the changes only by the commit, even without the PR.

Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It seems that some fields added here will not be necessary in future PRs (see Shell and Widget), please remove them.

Also, the method GCData::setNativeZoomForGCData suffers from a code smell, it would be nice if it's not necessary or if it can be done differently.

Have the tests been addressed yet?

@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch from 90e57ec to ffac213 Compare May 15, 2024 14:11
@amartya4256
Copy link
Contributor Author

It seems that some fields added here will not be necessary in future PRs (see Shell and Widget), please remove them.

Also, the method GCData::setNativeZoomForGCData suffers from a code smell, it would be nice if it's not necessary or if it can be done differently.

Have the tests been addressed yet?

I updated this PR with respect to the PR #1229. It should look more consistent now.

@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch 2 times, most recently from 6d41ade to ddd2019 Compare May 15, 2024 14:18
@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch 3 times, most recently from 34ba421 to 8b87c03 Compare May 29, 2024 11:41
@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch from 8b87c03 to e8042f4 Compare May 31, 2024 14:17
@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch 2 times, most recently from 40aebd9 to e24d0b0 Compare June 4, 2024 09:23
@fedejeanne fedejeanne force-pushed the multi_zoom_level_GC branch from e24d0b0 to fc43e74 Compare June 5, 2024 07:43
Copy link
Contributor

@HeikoKlare HeikoKlare left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The changes look good now. Only the "actual" commit of this PR seems to contain the changes that have been extracted into #1258. Could you please rebase this PR onto its dependencies (i.e., the PRs that need to be merged before)?

@HeikoKlare HeikoKlare dismissed their stale review June 5, 2024 08:33

Removing my request for changes as concerns have been addressed, but cannot give approval because commit trace has to be adapted.

@HeikoKlare
Copy link
Contributor

@amartya4256 merging the required PR introduced a conflict in this PR, so please resolve and rebase on master once you find the time

@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch from fc43e74 to bfe1d1c Compare June 6, 2024 08:34
@amartya4256
Copy link
Contributor Author

@amartya4256 merging the required PR introduced a conflict in this PR, so please resolve and rebase on master once you find the time

This PR now depends on #1258 because of splitting the OS bindings to a separate PR. I have rebased it to the PR and I would update the description.

@amartya4256 amartya4256 requested a review from HeikoKlare June 6, 2024 08:38
@HeikoKlare HeikoKlare force-pushed the multi_zoom_level_GC branch from bfe1d1c to 2ea5502 Compare June 6, 2024 09:39
Copy link
Contributor

@HeikoKlare HeikoKlare left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The changes themselves still look good.
@amartya4256 Could you please improve the commit message with some more details on how GC is changed to enhance multi-zoom support?

@amartya4256 amartya4256 force-pushed the multi_zoom_level_GC branch from 2ea5502 to 63c791a Compare June 6, 2024 09:57
Copy link
Contributor

@fedejeanne fedejeanne left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM. I'm going to test it tomorrow and merge it.

This commit contributes to multi zoom level support of GC which can be extended by other resources and widgets.

Contributes to
eclipse-platform#62 and eclipse-platform#131
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants