-
-
Notifications
You must be signed in to change notification settings - Fork 29
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
Suggestion: special glyphs/icons for syntax elements #302
Comments
@fitdev |
That looks pretty good! Would it also be possible to customize the font alpha (opacity) and font size? I think this feature should be selectively applied:
I appreciate the work you put into this extension! |
I saw this feature yesterday and wanted to comment, but decided to wait a bit. Thank you for asking :) I do like it in general! Provided it can be:
Ideally such decorations should be selectable from a set of predefined symbols/icons/glyphs; or can be defined by user text instead, where a user provides text, color, and maybe font style. And in all cases position / alignment should be selectable, likely from 2 to 6 possibilities: Above/Below x Left/Center/Right. Hopefully it won;t be too hard to implement by extending the current notion of user defined syntax highlights. Though in terms of priorities, I would prefer an update on symbol searching / browsing first (i.e. Object-Browser like functionality with all the goodies that are currently available via context menus). |
It is possible to make such kind of decorations via the syntax highlight to decorate a category of syntax elements, for instance, all There's already an existing similar implementation in Codist that I myself seldom use. If you enable the Smart Bar feature, select a symbol and click the Mark Symbol command on the Smart Bar, you can mark that symbol with one of the 9 predefined but customizable syntax styles. The decoration can be implemented into those "predefined" styles, so when you "Mark" a symbol, the above decoration can be applied to it. Summary: It should not be very hard to implement, if we take the above implementations that we already have: Mark Symbol + Syntax Highlight, but available styles are limited to 9 (the number can be enlarged without great efforts though). What's left undone is the various decoration styles suggested in your comments (font family and style, font size, color, opacity, alignments, decoration text, etc.), the configuration module and persistence of marked symbols. Actually I am attempting to squeeze some time to implement the #231. |
Personally I am not interested as much in such a specific scenario. However, for such custom styles, maybe an additional area / tab can be used to define them similar to how Comment Tagger is implemented. So, for example a specific syntax element kind (like a 'class' for example) + a user-defined RegEx = a certain user-defined style. This is just an idea about how this might be surfaced. But again, this level of customization is not really something I would be using often.
I didn't know about that. Thank you for mentioning it.
That's great to know! |
Hmm, it was discussed in #266.
Thank you for your comment. @Decimation |
@wmjordan Sorry for the late response, but I would like to revisit this feature proposal. I think it would be quite useful. As @wmjordan demonstrated here, it is possible to implement this feature. We have also briefly discussed potential behavior(s) of this feature, but not very rigorously. I will describe how this feature could be implemented, potential usages, advantages/disadvantages, etc. Enhanced Syntax HighlightingFor clarity, this feature will be referred to as ESH (Enhanced Syntax Highlighting). ScopeThis describes how ESH would apply to certain language constructs, tokens, and other elements. 1. Default Codist Syntax HighlightingESH would use the default Codist syntax highlighting engine (seen here?) and behave like other forms of syntax highlighting. 2. Type-specific Syntax HighlightingESH would only apply to specific types, such as 3. Token-specific Syntax HighlightingESH would only apply to user-defined tokens; e.g., a variable name. This could raise the issue of maintaining a handle on the applied tokens, an issue similar to the one we discussed in #231. 4. Regex-specific Syntax HighlightingESH would apply to tokens matching a regex filter, as we have previously hypothesized. However, this is likely far too costly for performance. Use-caseESH could be used to improve readability and disambiguate language constructs. Here are some examples: Example 1Suppose a user wants to customize Example ESH Configuration GUICurrent GUI: Hypothetical ESH view: Note: this GUI mockup doesn't include options for positioning the glyph |
Seems reasonable. Ability to control placement (position) would be nice though. |
I have little idea about what to display on top of those "highlighted" elements. I tried to implement a demo and found that there were too many decorations which distracted me. |
Revisiting & RevisingI was going through my old issues on GitHub and came across this old thread. An idea came to me which I will describe. For clarity, the term symbol will hereafter refer to syntactic-language tokens or elements. Example: variable identifiers, type names, etc. This feature will have the placeholder name Symbol Tracker (ST for brevity). The ProblemWe are in agreement that the scope of this idea is too broad; i.e., there is no need to apply the aforementioned syntax decorations to symbols in a manner similar to custom syntax highlighting. As @wmjordan said, it's too annoying. It's like too much syntactic sugar — almost hyperglycemia levels! @fitdev seems to corroborate. RevisionTighten the ScopeIndividual symbol-specific decorations could be useful, for reasons I will describe. I only broach the idea briefly here. Repurpose the Use-caseTracking symbols during development is a very common task:
The new purpose of this feature would be analogous to the previous examples. ST would track or pin usages or occurrences of a given symbol within a given scope. The tracked symbol would have these decorations applied. ST could function as a simple toggle for the tracked symbol. The scope and symbol could be inferred by the already-available APIs, or input manually. Examples:
In essence, ST is a "search" or "find usages" feature with the features described. (Future) Further RevisionAs I was further developing these ideas, it occurred to me that much of what I propose in this revision is very similar to my Favorites idea (#231). That being said, these two features could be easily merged into one feature or they could mutually augment each other. |
Proposal
Add the ability to decorate a syntax element with special glyphs. These glyphs could be:
Example
Here is a rough example.
Red bounding box shows the boundaries within which the glyph can be placed.
The user would choose where the glyph is placed (e.g., top left, top center, ...) relative to the center of the syntax element.
Example 1
glyph is
★
placed top right
Example 2
glyph is
🔅
placed top left
The text was updated successfully, but these errors were encountered: