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

Compile certain CanvasItem._edit_*() functions with DEBUG_ENABLED #98736

Merged

Conversation

YeldhamDev
Copy link
Member

@YeldhamDev YeldhamDev commented Nov 1, 2024

This fixes the errors while compiling using target=template_debug which were introduced with #97257.

The functions that PR makes use of are:

  • _edit_is_selected_on_click()
  • _edit_use_rect()
  • _edit_get_rect()

But after some talk with other members of the dev team, I chose to make the entire CanvasItem._edit_*() family of functions be compiled with DEBUG_ENABLED instead of TOOLS_ENABLED, as it's cleaner code-wise. If this is considered too much, I can change this so only the stated functions are affected. Only the functions specified now use DEBUG_ENABLED.

@YeldhamDev YeldhamDev added this to the 4.4 milestone Nov 1, 2024
@YeldhamDev YeldhamDev requested review from a team as code owners November 1, 2024 19:35
@clayjohn
Copy link
Member

clayjohn commented Nov 1, 2024

This should only be exposing the functions that need to be exposed. Its bad enough that we have editor code in our scene functions, we shouldn't make the situation worse by unconditionally exposing editor code.

I would limit this PR to just the functions that are breaking builds currently.

Copy link
Contributor

@dsnopek dsnopek left a comment

Choose a reason for hiding this comment

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

Thanks!

This is compiling for me now on Android. I also tested using the game editor feature with "Remote Debug" to my phone, and it worked great!

I chose to make the entire CanvasItem._edit_*() family of functions be compiled with DEBUG_ENABLED instead of TOOLS_ENABLED, as it's cleaner code-wise. If this is considered too much, I can change this so only the stated functions are affected.

I'm personally OK with this. It makes sense to me that more editor-only functionality is needed in game to allow this tighter integration between the game and editor.

But it would be good to get input from folks who work on the editor more.

@dsnopek
Copy link
Contributor

dsnopek commented Nov 1, 2024

@clayjohn:

we shouldn't make the situation worse by unconditionally exposing editor code.

It not quite unconditionally: this is only for debug builds.

But I don't do too much work in the editor, so I'm not the one to say whether or not including these functions in debug builds is problematic.

@clayjohn
Copy link
Member

clayjohn commented Nov 1, 2024

But I don't do too much work in the editor, so I'm not the one to say whether or not including these functions in debug builds is problematic.

Its not that it will be problematic at run time. The problem is that this reinforces the coupling between the editor and the scene system. Ideally we would have no editor-only code in the scene code. We made compromises for specific functions, but we protected them behind an editor check. Now we are removing that check and exposing them more widely. A new contributor may now unknowingly use these functions elsewhere. Then we may see requests to expose this code to runtime. Then we end up with bloat and technical debt.

Ideally in cases like this we would provide an API through the scene system that allows moving all the editor logic into the editor rather than piling on editor logic into the scene system.

A good illustration of this problem is in our best practices guideline. Prefer Local Solutions:
https://docs.godotengine.org/en/latest/contributing/development/best_practices_for_engine_contributors.html#prefer-local-solutions

@YeldhamDev YeldhamDev force-pushed the i_love_introducing_regressions branch from a401812 to acfdfb8 Compare November 1, 2024 21:41
@YeldhamDev YeldhamDev changed the title Compile CanvasItem._edit_*() functions with DEBUG_ENABLED Compile certain CanvasItem._edit_*() functions with DEBUG_ENABLED Nov 1, 2024
@YeldhamDev
Copy link
Member Author

@clayjohn Understood, changes made.

@dsnopek
Copy link
Contributor

dsnopek commented Nov 1, 2024

I think something needs to be done for this one:

#ifdef TOOLS_ENABLED

Maybe changing to:

#if defined(TOOLS_ENABLED) || defined(DEBUG_ENABLED)

Otherwise, I'm seeing an error about missing override

EDIT: Not for this PR, but CI doesn't appear to be making any target=template_debug builds. If it was, then I think CI would have caught this (as well as the original issue with PR #97257).

@YeldhamDev YeldhamDev force-pushed the i_love_introducing_regressions branch from acfdfb8 to 5e6412c Compare November 1, 2024 23:25
@YeldhamDev
Copy link
Member Author

@dsnopek Missed that one, thank you. Strangely, my compiler didn't spit any errors about this while also compiling with target=template_debug.

@dsnopek
Copy link
Contributor

dsnopek commented Nov 2, 2024

It's building for me again! Just in case, I also re-tested using the "Game" editor with "Remote Debug" and an Android app, and that's still working fine.

Copy link
Contributor

@Repiteo Repiteo left a comment

Choose a reason for hiding this comment

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

We should try to trail #endif with a comment of their conditionals where possible. You don't have to change every instance in these files to account for that, just the TOOLS_ENABLED & DEBUG_ENABLED sections that were affected. I can't give suggestions on unchanged sections of code, so this is a non-exhaustive list of instances:

scene/2d/animated_sprite_2d.cpp Outdated Show resolved Hide resolved
scene/2d/animated_sprite_2d.h Outdated Show resolved Hide resolved
scene/2d/back_buffer_copy.h Outdated Show resolved Hide resolved
scene/2d/light_2d.cpp Outdated Show resolved Hide resolved
scene/2d/light_2d.h Outdated Show resolved Hide resolved
scene/gui/control.cpp Outdated Show resolved Hide resolved
scene/gui/control.h Outdated Show resolved Hide resolved
scene/main/canvas_item.cpp Outdated Show resolved Hide resolved
scene/main/canvas_item.h Outdated Show resolved Hide resolved
scene/resources/2d/navigation_polygon.h Outdated Show resolved Hide resolved
@YeldhamDev YeldhamDev force-pushed the i_love_introducing_regressions branch from 5e6412c to 08fd3bc Compare November 2, 2024 18:41
@YeldhamDev YeldhamDev force-pushed the i_love_introducing_regressions branch from 08fd3bc to 58e79bf Compare November 2, 2024 18:43
@YeldhamDev YeldhamDev requested a review from Repiteo November 2, 2024 18:44
@clayjohn clayjohn merged commit 1bffd6c into godotengine:master Nov 2, 2024
20 checks passed
@clayjohn
Copy link
Member

clayjohn commented Nov 2, 2024

Thank you!

Doing a quick merge so we avoid leaving master in a slightly broken state

@YeldhamDev YeldhamDev deleted the i_love_introducing_regressions branch November 3, 2024 04:40
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.

4 participants