Class: RDoc::Task
- Inherits:
-
Rake::TaskLib
- Object
- Rake::TaskLib
- RDoc::Task
- Defined in:
- lib/rdoc/task.rb
Overview
RDoc::Task creates the following rake tasks to generate and clean up RDoc output:
- rdoc
-
Main task for this RDoc task.
- clobber_rdoc
-
Delete all the rdoc files. This target is automatically added to the main clobber target.
- rerdoc
-
Rebuild the rdoc files from scratch, even if they are not out of date.
- rdoc:coverage
-
Print RDoc coverage report for all rdoc files.
Simple Example:
require 'rdoc/task'
RDoc::Task.new do |rdoc|
rdoc.main = "README.rdoc"
rdoc.rdoc_files.include("README.rdoc", "lib/**/*.rb")
end
The rdoc
object passed to the block is an RDoc::Task object. See the attributes list for the RDoc::Task class for available customization options.
Specifying different task names
You may wish to give the task a different name, such as if you are generating two sets of documentation. For instance, if you want to have a development set of documentation including private methods:
require 'rdoc/task'
RDoc::Task.new :rdoc_dev do |rdoc|
rdoc.main = "README.rdoc"
rdoc.rdoc_files.include("README.rdoc", "lib/**/*.rb")
rdoc. << "--all"
end
The tasks would then be named :rdoc_dev, :clobber_rdoc_dev, and :rerdoc_dev.
If you wish to have completely different task names, then pass a Hash as first argument. With the :rdoc
, :clobber_rdoc
and :rerdoc
options, you can customize the task names to your liking.
For example:
require 'rdoc/task'
RDoc::Task.new(:rdoc => "rdoc", :clobber_rdoc => "rdoc:clean",
:rerdoc => "rdoc:force")
This will create the tasks :rdoc
, :rdoc:clean
, :rdoc:force
, and :rdoc:coverage
.
Direct Known Subclasses
Instance Attribute Summary collapse
-
#external ⇒ Object
Whether to run the rdoc process as an external shell (default is false).
-
#generator ⇒ Object
Name of format generator (
--format
) used by rdoc. -
#main ⇒ Object
Name of file to be used as the main, top level file of the RDoc.
-
#markup ⇒ Object
The markup format; one of:
rdoc
(the default),markdown
,rd
,tomdoc
. -
#name ⇒ Object
Name of the main, top level task.
-
#options ⇒ Object
Additional list of options to be passed rdoc.
-
#rdoc_dir ⇒ Object
Name of directory to receive the html output files.
-
#rdoc_files ⇒ Object
List of files to be included in the rdoc generation.
-
#template ⇒ Object
Name of template to be used by rdoc.
-
#title ⇒ Object
Title of RDoc documentation.
Instance Method Summary collapse
-
#before_running_rdoc(&block) ⇒ Object
The block passed to this method will be called just before running the RDoc generator.
-
#check_names(names) ⇒ Object
Ensures that
names
only includes names for the :rdoc, :clobber_rdoc and :rerdoc. -
#clobber_task_description ⇒ Object
Task description for the clobber rdoc task or its renamed equivalent.
-
#coverage_task_description ⇒ Object
Task description for the coverage task or its renamed description.
-
#defaults ⇒ Object
Sets default task values.
-
#define ⇒ Object
Create the tasks defined by this task lib.
-
#initialize(name = :rdoc) {|_self| ... } ⇒ Task
constructor
Create an RDoc task with the given name.
-
#inline_source ⇒ Object
All source is inline now.
-
#inline_source=(value) ⇒ Object
All source is inline now.
-
#option_list ⇒ Object
List of options that will be supplied to RDoc.
-
#rdoc_task_description ⇒ Object
Task description for the rdoc task or its renamed equivalent.
-
#rerdoc_task_description ⇒ Object
Task description for the rerdoc task or its renamed description.
Constructor Details
#initialize(name = :rdoc) {|_self| ... } ⇒ Task
Create an RDoc task with the given name. See the RDoc::Task class overview for documentation.
157 158 159 160 161 162 163 164 165 166 167 |
# File 'lib/rdoc/task.rb', line 157 def initialize name = :rdoc # :yield: self defaults check_names name @name = name yield self if block_given? define end |
Instance Attribute Details
#external ⇒ Object
Whether to run the rdoc process as an external shell (default is false)
151 152 153 |
# File 'lib/rdoc/task.rb', line 151 def external @external end |
#generator ⇒ Object
Name of format generator (--format
) used by rdoc. (defaults to rdoc’s default)
136 137 138 |
# File 'lib/rdoc/task.rb', line 136 def generator @generator end |
#main ⇒ Object
Name of file to be used as the main, top level file of the RDoc. (default is none)
125 126 127 |
# File 'lib/rdoc/task.rb', line 125 def main @main end |
#markup ⇒ Object
The markup format; one of: rdoc
(the default), markdown
, rd
, tomdoc
. See Markup Formats.
109 110 111 |
# File 'lib/rdoc/task.rb', line 109 def markup @markup end |
#name ⇒ Object
Name of the main, top level task. (default is :rdoc)
104 105 106 |
# File 'lib/rdoc/task.rb', line 104 def name @name end |
#options ⇒ Object
Additional list of options to be passed rdoc. (default is [])
146 147 148 |
# File 'lib/rdoc/task.rb', line 146 def @options end |
#rdoc_dir ⇒ Object
Name of directory to receive the html output files. (default is “html”)
114 115 116 |
# File 'lib/rdoc/task.rb', line 114 def rdoc_dir @rdoc_dir end |
#rdoc_files ⇒ Object
List of files to be included in the rdoc generation. (default is [])
141 142 143 |
# File 'lib/rdoc/task.rb', line 141 def rdoc_files @rdoc_files end |
#template ⇒ Object
Name of template to be used by rdoc. (defaults to rdoc’s default)
130 131 132 |
# File 'lib/rdoc/task.rb', line 130 def template @template end |
#title ⇒ Object
Title of RDoc documentation. (defaults to rdoc’s default)
119 120 121 |
# File 'lib/rdoc/task.rb', line 119 def title @title end |
Instance Method Details
#before_running_rdoc(&block) ⇒ Object
The block passed to this method will be called just before running the RDoc generator. It is allowed to modify RDoc::Task attributes inside the block.
287 288 289 |
# File 'lib/rdoc/task.rb', line 287 def before_running_rdoc(&block) @before_running_rdoc = block end |
#check_names(names) ⇒ Object
Ensures that names
only includes names for the :rdoc, :clobber_rdoc and :rerdoc. If other names are given an ArgumentError is raised.
173 174 175 176 177 178 179 180 181 182 |
# File 'lib/rdoc/task.rb', line 173 def check_names names return unless Hash === names = names.keys.map { |k| k.to_sym } - [:rdoc, :clobber_rdoc, :rerdoc] unless .empty? then raise ArgumentError, "invalid options: #{.join ', '}" end end |
#clobber_task_description ⇒ Object
Task description for the clobber rdoc task or its renamed equivalent
187 188 189 |
# File 'lib/rdoc/task.rb', line 187 def clobber_task_description "Remove RDoc HTML files" end |
#coverage_task_description ⇒ Object
Task description for the coverage task or its renamed description
308 309 310 |
# File 'lib/rdoc/task.rb', line 308 def coverage_task_description "Print RDoc coverage report" end |
#defaults ⇒ Object
Sets default task values
194 195 196 197 198 199 200 201 202 203 |
# File 'lib/rdoc/task.rb', line 194 def defaults @name = :rdoc @rdoc_files = Rake::FileList.new @rdoc_dir = 'html' @main = nil @title = nil @template = nil @generator = nil @options = [] end |
#define ⇒ Object
Create the tasks defined by this task lib.
223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 |
# File 'lib/rdoc/task.rb', line 223 def define desc rdoc_task_description task rdoc_task_name desc rerdoc_task_description task rerdoc_task_name => [clobber_task_name, rdoc_task_name] desc clobber_task_description task clobber_task_name do rm_r @rdoc_dir rescue nil end task :clobber => [clobber_task_name] directory @rdoc_dir rdoc_target_deps = [ @rdoc_files, Rake.application.rakefile ].flatten.compact task rdoc_task_name => [rdoc_target] file rdoc_target => rdoc_target_deps do @before_running_rdoc.call if @before_running_rdoc args = option_list + @rdoc_files $stderr.puts "rdoc #{args.join ' '}" if Rake.application..trace RDoc::RDoc.new.document args end namespace rdoc_task_name do desc coverage_task_description task coverage_task_name do @before_running_rdoc.call if @before_running_rdoc opts = option_list << "-C" args = opts + @rdoc_files $stderr.puts "rdoc #{args.join ' '}" if Rake.application..trace RDoc::RDoc.new.document args end end self end |
#inline_source ⇒ Object
All source is inline now. This method is deprecated
208 209 210 211 |
# File 'lib/rdoc/task.rb', line 208 def inline_source # :nodoc: warn "RDoc::Task#inline_source is deprecated" true end |
#inline_source=(value) ⇒ Object
All source is inline now. This method is deprecated
216 217 218 |
# File 'lib/rdoc/task.rb', line 216 def inline_source=(value) # :nodoc: warn "RDoc::Task#inline_source is deprecated" end |
#option_list ⇒ Object
List of options that will be supplied to RDoc
271 272 273 274 275 276 277 278 279 280 |
# File 'lib/rdoc/task.rb', line 271 def option_list result = @options.dup result << "-o" << @rdoc_dir result << "--main" << main if main result << "--markup" << markup if markup result << "--title" << title if title result << "-T" << template if template result << '-f' << generator if generator result end |
#rdoc_task_description ⇒ Object
Task description for the rdoc task or its renamed equivalent
294 295 296 |
# File 'lib/rdoc/task.rb', line 294 def rdoc_task_description 'Build RDoc HTML files' end |
#rerdoc_task_description ⇒ Object
Task description for the rerdoc task or its renamed description
301 302 303 |
# File 'lib/rdoc/task.rb', line 301 def rerdoc_task_description "Rebuild RDoc HTML files" end |