# File rdoc/generators/html_generator.rb, line 1440 def build_class_list(from, html_file, class_dir) @classes << HtmlClass.new(from, html_file, class_dir, @options) from.each_classmodule do |mod| build_class_list(mod, html_file, class_dir) end end
Generate:
a list of HtmlFile objects for each TopLevel object.
a list of HtmlClass objects for each first level class or module in the TopLevel objects
a complete list of all hyperlinkable terms (file, class, module, and method names)
# File rdoc/generators/html_generator.rb, line 1429 def build_indices @toplevels.each do |toplevel| @files << HtmlFile.new(toplevel, @options, FILE_DIR) end RDoc::TopLevel.all_classes_and_modules.each do |cls| build_class_list(cls, @files[0], CLASS_DIR) end end
# File rdoc/generators/html_generator.rb, line 1493 def gen_an_index(collection, title) res = [] collection.sort.each do |f| if f.document_self res << { "href" => f.path, "name" => f.index_name } end end return { "entries" => res, 'list_title' => title, 'index_url' => main_url, } end
# File rdoc/generators/html_generator.rb, line 1484 def gen_class_index gen_an_index(@classes, 'Classes') end
# File rdoc/generators/html_generator.rb, line 1480 def gen_file_index gen_an_index(@files, 'Files') end
# File rdoc/generators/html_generator.rb, line 1472 def gen_into(list) res = [] list.each do |item| res << item.value_hash end res end
# File rdoc/generators/html_generator.rb, line 1488 def gen_method_index gen_an_index(HtmlMethod.all_methods, 'Methods') end
Build the initial indices and output objects based on an array of TopLevel objects containing the extracted information.
# File rdoc/generators/html_generator.rb, line 1409 def generate(info) @toplevels = info @files = [] @classes = [] @hyperlinks = {} build_indices generate_xml end
Generate all the HTML. For the one-file case, we generate all the information in to one big hash
# File rdoc/generators/html_generator.rb, line 1451 def generate_xml values = { 'charset' => @options.charset, 'files' => gen_into(@files), 'classes' => gen_into(@classes), 'title' => CGI.escapeHTML(@options.title), } # this method is defined in the template file write_extra_pages if defined? write_extra_pages template = TemplatePage.new(RDoc::Page::ONE_PAGE) if @options.op_name opfile = File.open(@options.op_name, "w") else opfile = $stdout end template.write_html_on(opfile, values) end