Multiline Comment Workarounds?

后端 未结 10 1096
轮回少年
轮回少年 2020-11-30 18:36

I (sort of) already know the answer to this question. But I figured it is one that gets asked so frequently on the R Users list, that there should be one solid good answer.

相关标签:
10条回答
  • 2020-11-30 18:44

    You can do this easily in RStudio:

    select the code and click CTR+SHIFT+C to comment/uncomment code.

    0 讨论(0)
  • 2020-11-30 18:48

    I can think of two options. The first option is to use an editor that allows to block comment and uncomment (eg. Eclipse). The second option is to use an if statement. But that will only allow you to 'comment' correct R syntax. Hence a good editor is the prefered workaround.

    if(FALSE){
         #everything in this case is not executed
    
    }
    
    0 讨论(0)
  • 2020-11-30 18:51

    In Python you make a multiline comment with 3x single quotes before and after the comments. I tried this in R and it seems to work also.

    Eg.

    '''
    This is a comment
    This is a second comment
    '''
    
    0 讨论(0)
  • 2020-11-30 18:53

    [Update] Based on comments.

    # An empty function for Comments
    Comment <- function(`@Comments`) {invisible()}
    
    #### Comments ####
    Comment( `
    
      # Put anything in here except back-ticks.
    
      api_idea <- function() {
        return TRUE
      }
    
      # Just to show api_idea isn't really there...
      print( api_idea )
    
    `)
    ####
    
    #### Code. ####
    foo <- function() {
      print( "The above did not evaluate!")
    }
    foo()
    

    [Original Answer]

    Here's another way... check out the pic at the bottom. Cut and paste the code block into RStudio.

    Multiline comments that make using an IDE more effective are a "Good Thing", most IDEs or simple editors don't have highlighting of text within simple commented -out blocks; though some authors have taken the time to ensure parsing within here-strings. With R we don't have multi-line comments or here-strings either, but using invisible expressions in RStudio gives all that goodness.

    As long as there aren't any backticks in the section desired to be used for a multiline comments, here-strings, or non-executed comment blocks then this might be something worth-while.

    #### Intro Notes & Comments ####
    invisible( expression( `
    { <= put the brace here to reset the auto indenting...
    
      Base <- function()
      {      <^~~~~~~~~~~~~~~~ Use the function as a header and nesting marker for the comments
             that show up in the jump-menu.
             --->8---
      }
    
      External <- function()
      {
        If we used a function similar to:
          api_idea <- function() {
    
            some_api_example <- function( nested ) {
              stopifnot( some required check here )
            }
    
            print("Cut and paste this into RStudio to see the code-chunk quick-jump structure.")
            return converted object
          }
    
        #### Code. ####
        ^~~~~~~~~~~~~~~~~~~~~~~~~~ <= Notice that this comment section isnt in the jump menu!
                                      Putting an apostrophe in isn't causes RStudio to parse as text
                                      and needs to be matched prior to nested structure working again.
        api_idea2 <- function() {
    
        } # That isn't in the jump-menu, but the one below is...
    
        api_idea3 <- function() {
    
        }
    
      }
    
        # Just to show api_idea isn't really there...
        print( api_idea )
        }`) )
    ####
    
    #### Code. ####
    foo <- function() {
      print( "The above did not evaluate and cause an error!")
    }
    
    foo()
    
    ## [1] "The above did not evaluate and cause an error!"
    

    And here's the pic...

    Structured Comments

    0 讨论(0)
  • 2020-11-30 19:00

    If find it incredible that any language would not cater for this.

    This is probably the cleanest workaround:

    anything="
    first comment line
    second comment line
    "
    
    0 讨论(0)
  • 2020-11-30 19:00

    Apart from using the overkilled way to comment multi-line codes just by installing RStudio, you can use Notepad++ as it supports the syntax highlighting of R

    (Select multi-lines) -> Edit -> Comment/Uncomment -> Toggle Block Comment

    Note that you need to save the code as a .R source first (highlighted in red)

    Note that you need to save the code as a .R source first (highlighted in red)

    0 讨论(0)
提交回复
热议问题