module Fastlane class DocsGenerator def self.run(ff, output_path = nil) output_path ||= File.join(FastlaneCore::FastlaneFolder.path || '.', 'README.md') output = ["fastlane documentation"] output << "================" output << "# Installation" output << "" output << "Make sure you have the latest version of the Xcode command line tools installed:" output << "" output << "```" output << "xcode-select --install" output << "```" output << "" output << "## Choose your installation method:" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "" output << "
Homebrew" output << "Installer Script" output << "Rubygems" output << "
macOSmacOSmacOS or Linux with Ruby 2.0.0 or above
brew cask install fastlaneDownload the zip file. Then double click on the install script (or run it in a terminal window).sudo gem install fastlane -NV
" output << "# Available Actions" all_keys = ff.runner.lanes.keys.reject(&:nil?) all_keys.unshift(nil) # because we want root elements on top. always! They have key nil all_keys.each do |platform| lanes = ff.runner.lanes[platform] if lanes.nil? || lanes.empty? || lanes.all? { |_, lane| lane.is_private } next end output << "## #{formatted_platform(platform)}" if platform lanes.each do |lane_name, lane| next if lane.is_private output << render(platform, lane_name, lane.description.join("\n\n")) end output << "" output << "----" output << "" end output << "This README.md is auto-generated and will be re-generated every time [fastlane](https://fastlane.tools) is run." output << "More information about fastlane can be found on [fastlane.tools](https://fastlane.tools)." output << "The documentation of fastlane can be found on [docs.fastlane.tools](https://docs.fastlane.tools)." output << "" File.write(output_path, output.join("\n")) UI.success "Successfully generated documentation at path '#{File.expand_path(output_path)}'" if FastlaneCore::Globals.verbose? end ##################################################### # @!group Helper ##################################################### def self.formatted_platform(pl) pl = pl.to_s return "iOS" if pl == 'ios' return "Mac" if pl == 'mac' return "Android" if pl == 'android' return pl end # @param platform [String] # @param lane [Fastlane::Lane] # @param description [String] def self.render(platform, lane, description) full_name = [platform, lane].reject(&:nil?).join(' ') output = [] output << "### #{full_name}" output << "```" output << "fastlane #{full_name}" output << "```" output << description output end end end