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

Array-variables are highlighted as function #4

Open
jwortmann opened this issue Jan 13, 2021 · 2 comments
Open

Array-variables are highlighted as function #4

jwortmann opened this issue Jan 13, 2021 · 2 comments
Labels
suggested change For suggested changes to existing feature

Comments

@jwortmann
Copy link
Contributor

This syntax uses variable.function.fortran for identifiers preceding an opening parenthesis. This works fine for function and subroutine calls, but at the same time all array-variables are falsely highlighted as a function.

In general there is no way with a regex-based highlighting engine to distinguish between array access and a function call in Fortran. The built-in Matlab syntax in Sublime Text suffers from the same issue, and it uses the scope meta.variable.other.valid.matlab for all identifiers. And the (abandoned?) Fortran package from Package Control uses only a meta scope for such identifiers as well.

From personal experience I would say that array-variables occur much more often in code than function calls, so I would suggest to not use the variable.function scope for identifiers, but change it e.g. to variable.other.fortran, to minimize the number of incorrectly highlighted identifiers.

One exception to this, where variable.function can be used correctly is after the call keyword for subroutine calls.

Another thing I noticed is that built-in functions and subroutines use variable.function.function.intrinsic.fortran and variable.function.subroutine.intrinsic.fortran. I would suggest to use something like support.function.intrinsic.fortran and support.function.subroutine.fortran for these instead, because support.function is the usually used scope name for built-in functions and this way they get highlighted differently from user-defined functions (subroutines) by default in most color schemes.

@eirik-kjonstad
Copy link
Owner

We decided to use variable.function.fortran instead of variable.other.fortran, but you may be right that this is not the better choice for most developers. In my experience, function calls will dominate high-level code, where much of the code consists of calls to functions and subroutines. Array access will be more common in low-level code. What you encounter more often will depend on the code (or what part of a larger codebase) you are working on. Do you have any thoughts on this @saraidery ?

If these scopes are typically used for built-in functions, I think we can follow the convention. I see that the Python syntax is also using support.function for its built-in functions. Your suggestions seem good to me - I can make a pull request soon.

@jwortmann
Copy link
Contributor Author

If these scopes are typically used for built-in functions, I think we can follow the convention. I see that the Python syntax is also using support.function for its built-in functions. Your suggestions seem good to me - I can make a pull request soon.

In general support.function should be used for built-in or standard library functions, while variable.function is meant to be used for user-defined function calls.

I noticed that you also used support.function for C preprocessor statements and for OpenMP statements, and I could imagine that you perhaps chose this scope name because it gives a (for now) unique color in most color schemes. There are some smaller deviations in the built-in syntaxes for preprocessor statements and there was some not yet resolved discussion in sublimehq/Packages#1860, but the preprocessor keywords should probably use keyword instead; for example meta.preprocessor.fortran keyword.control.directive.fortran. And I would suggest to use a similar scope for OpenMP statements as well, perhaps meta.openmp.fortran keyword.control.directive.fortran here.
If a unique color for these is desired, the correct way would be to create a user-specific override for the color scheme.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
suggested change For suggested changes to existing feature
Projects
None yet
Development

No branches or pull requests

2 participants