2012-04-12 10:23:33 -04:00
|
|
|
class Pry
|
|
|
|
module Helpers
|
|
|
|
|
|
|
|
# This class contains methods useful for extracting
|
|
|
|
# documentation from methods and classes.
|
|
|
|
module DocumentationHelpers
|
2013-02-01 04:24:01 -05:00
|
|
|
|
|
|
|
module_function
|
|
|
|
|
2012-07-09 18:20:29 -04:00
|
|
|
def process_rdoc(comment)
|
2012-04-12 10:23:33 -04:00
|
|
|
comment = comment.dup
|
2013-02-01 04:24:01 -05:00
|
|
|
comment.gsub(/<code>(?:\s*\n)?(.*?)\s*<\/code>/m) { CodeRay.scan($1, :ruby).term }.
|
|
|
|
gsub(/<em>(?:\s*\n)?(.*?)\s*<\/em>/m) { "\e[1m#{$1}\e[0m" }.
|
|
|
|
gsub(/<i>(?:\s*\n)?(.*?)\s*<\/i>/m) { "\e[1m#{$1}\e[0m" }.
|
2015-06-24 09:36:03 -04:00
|
|
|
gsub(/<tt>(?:\s*\n)?(.*?)\s*<\/tt>/m) { CodeRay.scan($1, :ruby).term }.
|
2018-10-12 12:54:00 -04:00
|
|
|
gsub(/\B\+(\w+?)\+\B/) { "\e[32m#{$1}\e[0m" }.
|
|
|
|
gsub(/((?:^[ \t]+.+(?:\n+|\Z))+)/) { CodeRay.scan($1, :ruby).term }.
|
2013-02-01 04:24:01 -05:00
|
|
|
gsub(/`(?:\s*\n)?([^\e]*?)\s*`/) { "`#{CodeRay.scan($1, :ruby).term}`" }
|
2012-04-12 10:23:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def process_yardoc_tag(comment, tag)
|
|
|
|
in_tag_block = nil
|
|
|
|
comment.lines.map do |v|
|
|
|
|
if in_tag_block && v !~ /^\S/
|
|
|
|
Pry::Helpers::Text.strip_color Pry::Helpers::Text.strip_color(v)
|
|
|
|
elsif in_tag_block
|
|
|
|
in_tag_block = false
|
|
|
|
v
|
|
|
|
else
|
|
|
|
in_tag_block = true if v =~ /^@#{tag}/
|
|
|
|
v
|
|
|
|
end
|
|
|
|
end.join
|
|
|
|
end
|
|
|
|
|
|
|
|
def process_yardoc(comment)
|
|
|
|
yard_tags = ["param", "return", "option", "yield", "attr", "attr_reader", "attr_writer",
|
2012-06-23 05:13:44 -04:00
|
|
|
"deprecate", "example", "raise"]
|
2012-04-12 10:23:33 -04:00
|
|
|
(yard_tags - ["example"]).inject(comment) { |a, v| process_yardoc_tag(a, v) }.
|
2014-05-01 04:14:33 -04:00
|
|
|
gsub(/^@(#{yard_tags.join("|")})/) { "\e[33m#{$1}\e[0m" }
|
2012-04-12 10:23:33 -04:00
|
|
|
end
|
|
|
|
|
2012-07-09 18:20:29 -04:00
|
|
|
def process_comment_markup(comment)
|
|
|
|
process_yardoc process_rdoc(comment)
|
2012-04-12 10:23:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
# @param [String] code
|
|
|
|
# @return [String]
|
|
|
|
def strip_comments_from_c_code(code)
|
|
|
|
code.sub(/\A\s*\/\*.*?\*\/\s*/m, '')
|
|
|
|
end
|
|
|
|
|
2013-02-01 04:24:01 -05:00
|
|
|
# Given a string that makes up a comment in a source-code file parse out the content
|
|
|
|
# that the user is intended to read. (i.e. without leading indentation, #-characters
|
|
|
|
# or shebangs)
|
|
|
|
#
|
2012-04-12 10:23:33 -04:00
|
|
|
# @param [String] comment
|
|
|
|
# @return [String]
|
2013-02-01 04:24:01 -05:00
|
|
|
def get_comment_content(comment)
|
2012-04-12 10:23:33 -04:00
|
|
|
comment = comment.dup
|
2013-02-01 04:24:01 -05:00
|
|
|
# Remove #!/usr/bin/ruby
|
|
|
|
comment.gsub!(/\A\#!.*$/, '')
|
|
|
|
# Remove leading empty comment lines
|
2012-04-12 10:23:33 -04:00
|
|
|
comment.gsub!(/\A\#+?$/, '')
|
|
|
|
comment.gsub!(/^\s*#/, '')
|
|
|
|
strip_leading_whitespace(comment)
|
|
|
|
end
|
|
|
|
|
|
|
|
# @param [String] text
|
|
|
|
# @return [String]
|
|
|
|
def strip_leading_whitespace(text)
|
|
|
|
Pry::Helpers::CommandHelpers.unindent(text)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|