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

GDScript: Highlight comment markers (TODO, FIXME, etc.) #79761

Merged
merged 1 commit into from
Aug 7, 2023

Conversation

dalexeev
Copy link
Member

@dalexeev dalexeev added this to the 4.x milestone Jul 21, 2023
@dalexeev dalexeev requested a review from a team as a code owner July 21, 2023 18:37
@MewPurPur
Copy link
Contributor

Does it look good on light theme, where comments appear brighter rather than darker?

@dalexeev
Copy link
Member Author

The light theme looks like this:

I didn't choose these colors carefully, in the hope that someone with better taste would suggest other colors.

@dalexeev
Copy link
Member Author


Dark


Godot 2


Light

@dalexeev dalexeev force-pushed the gds-hl-comment-markers branch from 4ba459d to b373d6f Compare July 21, 2023 20:37
@MewPurPur
Copy link
Contributor

Tbh I like them, but I'd like it if a similar result for dark theme could get achieved with something like 0.6 alpha so it's more comment-like in all themes.

Copy link
Member

@Calinou Calinou left a comment

Choose a reason for hiding this comment

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

Tested locally (rebased on top of master 6588a4a), it works as expected.

See this example with the text from the original proposal for reference:

image

I like the use of multiple colors, it makes sense here.

The implementation itself looks good to me from a cursory look. I've also tested scenarios such as comments inside strings, and can confirm no highlighting is applied there (it shouldn't).

Changes to the list of keywords in the editor settings also work correctly without requiring a restart.

@dalexeev
Copy link
Member Author

dalexeev commented Jul 22, 2023

I'd like it if a similar result for dark theme could get achieved with something like 0.6 alpha so it's more comment-like in all themes

Indeed, the text_editor/theme/highlighting/comment_color editor setting has a translucent color.

But I checked the default themes and the colors look good in my opinion. I'm not sure if non-grayscale translucent colors will work for any theme. Let me know if you think it's worth looking into.

Notes:

  1. In this implementation, markers must consist of ASCII identifier characters. Should we add support for Unicode markers? To do this, I just need to replace is_ascii_identifier_char() with is_unicode_identifier_continue(), but I have performance concerns. On the other hand, this only applies to comments and this function will be optimized in the future, see Add Unicode support to String.to_*_case() methods #75846.
  2. I see an opportunity to use more than 3 hardcoded levels here. We can use one editor setting of type Dictionary "list of markers -> color". This shouldn't affect performance since we have a HashMap for marker colors. Is it worth it, or "three levels is enough for everyone"?
  3. This PR only implements it for GDScript. In the future, we should add this for C# and the shader language too.

@Calinou
Copy link
Member

Calinou commented Jul 23, 2023

  1. I see an opportunity to use more than 3 hardcoded levels here. We can use one editor setting of type Dictionary "list of markers -> color". This shouldn't affect performance since we have a HashMap for marker colors. Is it worth it, or "three levels is enough for everyone"?

I would wait until there's significant demand before implementing more settings (likely in a separate proposal if this PR is merged).

@dalexeev
Copy link
Member Author

Here is how it might look (dalexeev@46fb4c1):

The disadvantage is that you cannot reset the colors individually.

@Bromeon
Copy link
Contributor

Bromeon commented Aug 3, 2023

Some input on splitting into 3 groups, but that's bikeshedding territory 😬

  • HACK seems more like FIXME, TODO i.e. something that should be cleaned up, but is not critical
  • maybe CRITICAL could be added to the critical list
  • maybe INFO could be added to the notice list
  • not fully sure about difference between CAUTION and ATTENTION? (probably a native speaker knows better)

@dalexeev dalexeev force-pushed the gds-hl-comment-markers branch from b373d6f to 5423168 Compare August 7, 2023 08:34
@dalexeev
Copy link
Member Author

dalexeev commented Aug 7, 2023

Some input on splitting into 3 groups

Done.

  1. Should we add support for Unicode markers?

Done.

I also tweaked the colors a bit so they are brighter/clearer but still dimmer than the keywords. The light theme colors don't seem very good to me, if there are any suggestions I'll fix it.

@Calinou
Copy link
Member

Calinou commented Aug 7, 2023

I also tweaked the colors a bit so they are brighter/clearer but still dimmer than the keywords. The light theme colors don't seem very good to me, if there are any suggestions I'll fix it.

The new colors look great to me, even on light theme 🙂

Copy link
Member

@akien-mga akien-mga left a comment

Choose a reason for hiding this comment

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

Seems fine to me. Didn't review the highlighter code in depth but it's relatively low risk.
The feature proposal seems well appreciated by the community.

@akien-mga akien-mga merged commit 87c91dc into godotengine:master Aug 7, 2023
@akien-mga
Copy link
Member

Thanks!

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.

Highlight TODO, FIXME and similar keywords in comments in the script editor
6 participants