X7ROOT File Manager
Current Path:
/opt/alt/ruby20/lib64/ruby/2.0.0/rdoc
opt
/
alt
/
ruby20
/
lib64
/
ruby
/
2.0.0
/
rdoc
/
ðŸ“
..
📄
alias.rb
(2.09 KB)
📄
anon_class.rb
(142 B)
📄
any_method.rb
(5.9 KB)
📄
attr.rb
(3.73 KB)
📄
class_module.rb
(19.15 KB)
📄
code_object.rb
(7.71 KB)
📄
code_objects.rb
(121 B)
📄
comment.rb
(5.39 KB)
📄
constant.rb
(3.34 KB)
ðŸ“
context
📄
context.rb
(28.26 KB)
📄
cross_reference.rb
(5.81 KB)
📄
encoding.rb
(2.74 KB)
📄
erb_partial.rb
(370 B)
📄
erbio.rb
(794 B)
📄
extend.rb
(2.53 KB)
ðŸ“
generator
📄
generator.rb
(1.72 KB)
📄
ghost_method.rb
(114 B)
📄
include.rb
(2.61 KB)
📄
known_classes.rb
(2.58 KB)
ðŸ“
markdown
📄
markdown.rb
(380.09 KB)
ðŸ“
markup
📄
markup.rb
(28.31 KB)
📄
meta_method.rb
(99 B)
📄
method_attr.rb
(8.57 KB)
📄
normal_class.rb
(2.06 KB)
📄
normal_module.rb
(1.36 KB)
📄
options.rb
(28.49 KB)
ðŸ“
parser
📄
parser.rb
(7.83 KB)
ðŸ“
rd
📄
rd.rb
(3.54 KB)
📄
rdoc.rb
(13.25 KB)
📄
require.rb
(935 B)
ðŸ“
ri
📄
ri.rb
(315 B)
📄
ruby_lex.rb
(27.23 KB)
📄
ruby_token.rb
(11.21 KB)
📄
rubygems_hook.rb
(4.91 KB)
📄
servlet.rb
(10.83 KB)
📄
single_class.rb
(330 B)
ðŸ“
stats
📄
stats.rb
(9.78 KB)
📄
store.rb
(22.32 KB)
📄
task.rb
(7.66 KB)
📄
test_case.rb
(3.46 KB)
📄
text.rb
(7.59 KB)
📄
token_stream.rb
(2.46 KB)
📄
tom_doc.rb
(5.7 KB)
📄
top_level.rb
(5.4 KB)
Editing: cross_reference.rb
## # RDoc::CrossReference is a reusable way to create cross references for names. class RDoc::CrossReference ## # Regular expression to match class references # # 1. There can be a '\\' in front of text to suppress the cross-reference # 2. There can be a '::' in front of class names to reference from the # top-level namespace. # 3. The method can be followed by parenthesis (not recommended) CLASS_REGEXP_STR = '\\\\?((?:\:{2})?[A-Z]\w*(?:\:\:\w+)*)' ## # Regular expression to match method references. # # See CLASS_REGEXP_STR METHOD_REGEXP_STR = '([a-z]\w*[!?=]?|%|===)(?:\([\w.+*/=<>-]*\))?' ## # Regular expressions matching text that should potentially have # cross-reference links generated are passed to add_special. Note that # these expressions are meant to pick up text for which cross-references # have been suppressed, since the suppression characters are removed by the # code that is triggered. CROSSREF_REGEXP = /(?:^|\s) ( (?: # A::B::C.meth #{CLASS_REGEXP_STR}(?:[.#]|::)#{METHOD_REGEXP_STR} # Stand-alone method (preceded by a #) | \\?\##{METHOD_REGEXP_STR} # Stand-alone method (preceded by ::) | ::#{METHOD_REGEXP_STR} # A::B::C # The stuff after CLASS_REGEXP_STR is a # nasty hack. CLASS_REGEXP_STR unfortunately matches # words like dog and cat (these are legal "class" # names in Fortran 95). When a word is flagged as a # potential cross-reference, limitations in the markup # engine suppress other processing, such as typesetting. # This is particularly noticeable for contractions. # In order that words like "can't" not # be flagged as potential cross-references, only # flag potential class cross-references if the character # after the cross-reference is a space, sentence # punctuation, tag start character, or attribute # marker. | #{CLASS_REGEXP_STR}(?=[@\s).?!,;<\000]|\z) # Things that look like filenames # The key thing is that there must be at least # one special character (period, slash, or # underscore). | (?:\.\.\/)*[-\/\w]+[_\/.][-\w\/.]+ # Things that have markup suppressed # Don't process things like '\<' in \<tt>, though. # TODO: including < is a hack, not very satisfying. | \\[^\s<] ) # labels for headings (?:@[\w+%-]+(?:\.[\w|%-]+)?)? )/x ## # Version of CROSSREF_REGEXP used when <tt>--hyperlink-all</tt> is specified. ALL_CROSSREF_REGEXP = / (?:^|\s) ( (?: # A::B::C.meth #{CLASS_REGEXP_STR}(?:[.#]|::)#{METHOD_REGEXP_STR} # Stand-alone method | \\?#{METHOD_REGEXP_STR} # A::B::C | #{CLASS_REGEXP_STR}(?=[@\s).?!,;<\000]|\z) # Things that look like filenames | (?:\.\.\/)*[-\/\w]+[_\/.][-\w\/.]+ # Things that have markup suppressed | \\[^\s<] ) # labels for headings (?:@[\w+%-]+)? )/x ## # Hash of references that have been looked-up to their replacements attr_accessor :seen ## # Allows cross-references to be created based on the given +context+ # (RDoc::Context). def initialize context @context = context @store = context.store @seen = {} end ## # Returns a reference to +name+. # # If the reference is found and +name+ is not documented +text+ will be # returned. If +name+ is escaped +name+ is returned. If +name+ is not # found +text+ is returned. def resolve name, text return @seen[name] if @seen.include? name if /#{CLASS_REGEXP_STR}([.#]|::)#{METHOD_REGEXP_STR}/o =~ name then type = $2 type = '' if type == '.' # will find either #method or ::method method = "#{type}#{$3}" container = @context.find_symbol_module($1) elsif /^([.#]|::)#{METHOD_REGEXP_STR}/o =~ name then type = $1 type = '' if type == '.' method = "#{type}#{$2}" container = @context else container = nil end if container then ref = container.find_local_symbol method unless ref || RDoc::TopLevel === container then ref = container.find_ancestor_local_symbol method end end ref = case name when /^\\(#{CLASS_REGEXP_STR})$/o then @context.find_symbol $1 else @context.find_symbol name end unless ref # Try a page name ref = @store.page name if not ref and name =~ /^\w+$/ ref = nil if RDoc::Alias === ref # external alias, can't link to it out = if name == '\\' then name elsif name =~ /^\\/ then # we remove the \ only in front of what we know: # other backslashes are treated later, only outside of <tt> ref ? $' : name elsif ref then if ref.display? then ref else text end else text end @seen[name] = out out end end
Upload File
Create Folder