- 
                Notifications
    You must be signed in to change notification settings 
- Fork 445
Autolink directive #1264
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
base: master
Are you sure you want to change the base?
Autolink directive #1264
Conversation
        
          
                lib/rdoc/options.rb
              
                Outdated
          
        
      |  | ||
| def self.boolean(flag, message = nil) | ||
| if flag == true or flag == false | ||
| @autolink = flag | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| @autolink = flag | |
| flag | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Updated!
| Can you add more examples in the description on how this would be used? I think it'd be like this? class MyClass # Mentioning MyClass in plain text won't be linked by default
  # :autolink: false
endFor not linking to specific words, like  Using directives for it could have a few downsides: 
 So for ease of maintenance and understanding, I still prefer #1259 as the solution to #1254 | 
| 
 The inverse can be true. 
 There is unexpected linking risk, too. In general, WiKi style autolinking is a sweet trap, for Ruby that capitalized words have the special meaning at least, I think. | 
956c7fb    to
    ee5f96a      
    Compare
  
            
          
                lib/rdoc/code_object.rb
              
                Outdated
          
        
      | autolink = @metadata["autolink"] | ||
| if autolink | ||
| RDoc::Options.boolean(autolink, "autolink") | ||
| else | ||
| true | ||
| end | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we simplify this?
| autolink = @metadata["autolink"] | |
| if autolink | |
| RDoc::Options.boolean(autolink, "autolink") | |
| else | |
| true | |
| end | |
| RDoc::Options.boolean(@metadata["autolink"] || true, "autolink") | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fetch may be better?
| autolink = @metadata["autolink"] | |
| if autolink | |
| RDoc::Options.boolean(autolink, "autolink") | |
| else | |
| true | |
| end | |
| RDoc::Options.boolean(@metadata.fetch("autolink", true), "autolink") | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes.
| 
 I agree that this will be a better long-term direction 👍 But given this could be a breaking change, can you open an issue to expand this idea and we can discuss about the steps needed to get there? | 
| What I don't like is we have to manage excluded words, like #1266, to add to each ".rdoc_options" file. | 
d4d5a4d    to
    aeb7529      
    Compare
  
    aeb7529    to
    afb19dd      
    Compare
  
    | I'm not sure about introducing a new directive value type that just represents boolean. Since the goal is to allow classes/modules/methods to declare that they shouldn't be autolinked, maybe a  | 
To control cross-reference linking.
Fix #1254.