Author Topic: Custom language, R - identifiers  (Read 2347 times)


  • Senior Community Member
  • Posts: 2620
  • Hero Points: 210
  • Text
Custom language, R - identifiers
« on: October 07, 2017, 02:09:02 pm »
Can I use a reg-ex for identifiers?

In R identifiers:
Start with A-Za-z, followed by A-Za-z0-9_.
Can also start with a ., but not followed by a digit.
A perl regex might look like: ((\.[A-Za-z_])|([A-Za-z))[A-Za-z0-9_.]*

But, a letter is defined by isalnum(c) -- locale dependent, so accented letters and such are allowed.
Annoying, but not so terrible. You could simple make the regex include all these letters and ignore locale.
(This only applies to letters. The only digits allowed are 0...9).

R also lets you quote identifiers (who created this stupid language??)
But, there are special rules that apply to decide if it is a name or a string.
backticks are preferred. For example (pay attention to ' vs ` )
> 'a bad name' = 5
> 'a bad name'
[1] "a bad name"
> 'a bad name'+1
Error in "a bad name" + 1 : non-numeric argument to binary operator
> `a bad name`
[1] 5
> `a bad name` + 1
[1] 6

R Studio colors backticks as identifiers, but not the assignment I show above.


  • SlickEdit Team Member
  • Senior Community Member
  • *
  • Posts: 6579
  • Hero Points: 511
Re: Custom language, R - identifiers
« Reply #1 on: October 08, 2017, 01:26:15 pm »
It's probably best to define the identifier start chars as A-Za-z_ and the follow chars as 0-9 (you can add regex character sets for a group of unicode characters if you need to).

Here's what we use for the Scala start and follow chars.
Code: [Select]
<idchars v="$_\p{Ll}\p{Lu} \p{Lt}\p{Lo}\p{Nl}0-9"/>

Then add a regex which specifically matches identifiers starting with a "." (choose "identifier" as the color). Also add a regex to match single quoted identifiers.

This should do the trick. You may need to use lookahead or lookbehind to help out. In Scala and some other language we support, use of single quote can have more than one meaning. We use lookahead or lookbehind to screen out certain matches.

FYI: I promise you Scala is way worse than R. We got a bunch of built-in very complicated regular expressions defined to handle it (not in color coding definition because they would have been too confusing).