[R] How to comment in R

Duncan Murdoch murdoch at stats.uwo.ca
Wed Feb 11 21:11:27 CET 2009


On 2/11/2009 2:27 PM, Wacek Kusnierczyk wrote:
> Duncan Murdoch wrote:
>> On 2/11/2009 1:21 PM, Stavros Macrakis wrote:
>>> On Wed, Feb 11, 2009 at 12:32 PM, Greg Snow <Greg.Snow at imail.org> wrote:
>>>> ...The c-style of /* */ allows both types and you can comment out
>>>> part of a line, but it is not simple to match and has its own
>>>> restrictions.  Friedl in his regular expressions book takes 10 pages
>>>> to develop a pattern to match these (and the final pattern is almost
>>>> 2 full lines of text in the book).  And this is without allowing
>>>> nesting....
>>>
>>> Though there is a real debate about the value of multiline, possibly
>>> nested, comments, the regular expression argument is a red herring.
>>> Lexical analysis of multiline comments is a solved problem (and not a
>>> particularly difficult one!), and matters only to language and editor
>>> implementors.  Emacs handles them with no problem.
>>
>> I agree about that.  I think the lack of multiline comments comes from
>> design considerations rather than implementation ones.   They're just
>> not needed, and having two types of comments would lead to weird
>> interactions, e.g. is the block comment closed in the lines below?
>>
>>   /*
>> #  */
> 
> it's still a simple design decision which, once made, can be implemented
> coherently.

I agree it's a design decision and once made implementation would be 
easy, but I don't agree that it's a simple design decision.  If it was, 
you'd be able to tell me the obvious answer to my question.  If the 
answer isn't obvious, then it's a source of errors in programs when 
people assume the wrong behaviour.

In another message, you pointed out the ugly construct

x <- "
# not a comment
"

which arises because R allows multi-line string literals, and also gives 
priority to string content over # comments.  This is a bad design, in my 
opinion.  (There shouldn't be multi-line string literals.) You probably 
haven't studied Rd syntax as closely as I have lately, but in an Rd 
file, # comments are treated as R treats them (i.e. within a string they 
don't do anything), % comments are always in effect.  You should see how 
many people get confused by the handling of % comments in Rd files.  But 
that's not something we can change:  there are something like 100000 Rd 
files on CRAN.

So if the behaviour isn't very obvious in cases like the one quoted 
above, and if the new syntax doesn't add any new expressiveness, I would 
be opposed to adding it.

Duncan Murdoch




More information about the R-help mailing list