MarkdownRubyDocumentation
Documentation DSL that provides method level comments and links or imports to other comments.
Comments can be written in MarkDown format and the current method can be transformed from Ruby code into a MarkDown readable format.
Static instance, class methods, and constants can be called and used inside of ERB tags.
All defined areas are generated into markdown file per class.
Why should you use this?
Allows creating business or technical documentation that can stays automatically in sync with Ruby Logic and available data.
Installation
Add this line to your application's Gemfile:
gem 'markdown_ruby_documentation'
And then execute:
$ bundle
Or install it yourself as:
$ gem install markdown_ruby_documentation
Usage
class RubyClassToBeInspected
MY_VALUE = 10
def i_am_a_documented_method
"Hello"
end
end
html_generator = MarkdownRubyDocumentation::HtmlGenerator.new(
dir: <Output Directory>
)
MarkdownRubyDocumentation::Generate.run(
subjects: [RubyClassToBeInspected],
output_object: html_generator
).call
Resulting file
# Ruby Class To Be Inspected
## I am a documented method
**I am Documentation**
"Hello"
10
ERB Methods
String Method Reference (method)
- Call an instance method in the current context with
"#method_name"
(Limitations: methods cannot take any arguments or depend on any uninitialized state, they may call other methods that follow this same requirements.) - Call an class method in the current context with
".method_name"
- Call an instance method from another class
"OtherClass#method_name"
print_method_source(method)
The source of a method block returned as text.
eval_method(method)
The result of evaluating a method.
print_mark_doc_from(method)
Prints out the mark doc from another method.
Prints out any comments proceeding a method def.
git_hub_method_url(method)
Creates a url to the method location on GitHub based on the current sha or it defaults to master.
git_hub_file_url(file_path || Class)
Creates a url to the file on GitHub based on the current sha or it defaults to master.
link_to_markdown
or link_to
(klass_or_path, title: String)
@param [Class, String, Pathname] klass_or_path
- String or Class representing a method reference ie. MyObject#call, MyObject.name
- Pathname representing the full path of the file location a method is defined
@param [String] title is the link display value
@return [String, Symbol] Creates link to a given generated markdown file or returns :non_project_location message.
- "title"
- :non_project_location
Example method reference inputs
- ".class_method_name" class method in the current scope.
- "Constant.class_method_name" class method on a specific constant.
- "SomeClass#instance_method_name" an instance method on a specific constant.
- "#instance_method_name" an instance method in the current scope.
__method__
returns #<current_method_name>
ruby_to_markdown
Converts case statements and if statements to bulleted markdown
option 1
- param [String] ruby_source
- param [Hash] disable_processors (optional) See processors list.
example ruby_to_markdown "def method_name\n'hello'\nend", readable_ruby_numbers: false*
option 2 - Assumes methods source of current method
- param [Hash] disable_processors (optional) See processors list.
example ruby_to_markdown(readable_ruby_numbers: false)
example ruby_to_markdown(ruby_operators_to_english: { proc: ->(replacement, match) { "do some alteration" }})
processors
- readable_ruby_numbers, options: proc(ruby_number_object, number_as_string)
- pretty_early_return, options: proc(replacement, match)
- convert_early_return_to_if_else, options: proc(replacement, match)
- ternary_to_if_else, options: proc(replacement, match)
- ruby_if_statement_to_md, options: proc(replacement, match)
- ruby_case_statement_to_md, options: proc(replacement, match)
- ruby_operators_to_english, options: proc(replacement, match)
- methods_as_local_links, options: method_to_class: { method_name => OwningConstant }, proc(replacement, match)
- question_mark_method_format, options: proc(replacement, match)
- remove_end_keyword, options: proc(replacement, match)
- constants_with_name_and_value, options: proc(replacement, match, opt={})
- remove_memoized_vars, options: proc(replacement, match)
- rescue_format, options: proc(replacement, match)
- boolean_blocks, options: proc(replacement, match)
format_link
format_link "#i_do_other_things" => I do other things
format_link "The method 10", "#i_do_other_things" => The method 10
Instance method that call other methods will results in an error.
methods_as_local_links
methods_as_local_links("i_return_one + i_return_two") => "^i_return_one
+ ^i_return_two
"
constants_with_name_and_value
constants_with_name_and_value("SOME_CONST_VALUE") => "SOME_CONST_VALUE => "1"
"
readable_ruby_numbers
Add commas to any ruby numbers. To provide additional formatting it yields a block given the number object.
hash_to_markdown_table(hash, key_name:, value_name:)
array_to_markdown_table(array, key_name:)
Development
After checking out the repo, run bin/setup
to install dependencies. Then, run rake spec
to run the tests. You can also run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run bundle exec rake release
, which will create a git tag for the version, push git commits and tags, and push the .gem
file to rubygems.org.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/business_rule_documentation. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.
License
The gem is available as open source under the terms of the MIT License.