Class: YARD::Rake::YardocTask

Inherits:
Rake::TaskLib
  • Object
show all
Defined in:
lib/yard/rake/yardoc_task.rb

Overview

The rake task to run CLI::Yardoc and generate documentation.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name = :yard) {|_self| ... } ⇒ YardocTask

Creates a new task with name name.

Parameters:

  • name (String, Symbol) (defaults to: :yard)

    the name of the rake task

Yields:

  • a block to allow any options to be modified on the task

Yield Parameters:

  • _self (YardocTask)

    the task object to allow any parameters to be changed.


42
43
44
45
46
47
48
49
50
51
52
# File 'lib/yard/rake/yardoc_task.rb', line 42

def initialize(name = :yard)
  @name = name
  @options = []
  @files = []
  
  yield self if block_given?
  self.options +=  ENV['OPTS'].split(/[ ,]/) if ENV['OPTS'] 
  self.files   += ENV['FILES'].split(/[ ,]/) if ENV['FILES']
  
  define
end

Instance Attribute Details

#afterProc

Runs a Proc after the task

Returns:

  • (Proc)

    a proc to call after running the task


28
29
30
# File 'lib/yard/rake/yardoc_task.rb', line 28

def after
  @after
end

#beforeProc

Runs a Proc before the task

Returns:

  • (Proc)

    a proc to call before running the task


24
25
26
# File 'lib/yard/rake/yardoc_task.rb', line 24

def before
  @before
end

#filesArray<String>

The Ruby source files (and any extra documentation files separated by '-') to process

Returns:


20
21
22
# File 'lib/yard/rake/yardoc_task.rb', line 20

def files
  @files
end

#nameString

The name of the task

Returns:


11
12
13
# File 'lib/yard/rake/yardoc_task.rb', line 11

def name
  @name
end

#optionsHash

Options to pass to CLI::Yardoc

Returns:

  • (Hash)

    the options passed to the commandline utility


15
16
17
# File 'lib/yard/rake/yardoc_task.rb', line 15

def options
  @options
end

#verifierProc

Returns an optional lambda to run against all objects being generated. Any object that the lambda returns false for will be excluded from documentation.

Returns:

  • (Proc)

    an optional lambda to run against all objects being generated. Any object that the lambda returns false for will be excluded from documentation.

See Also:


34
35
36
# File 'lib/yard/rake/yardoc_task.rb', line 34

def verifier
  @verifier
end

Instance Method Details

#definevoid (protected)

This method returns an undefined value.

Defines the rake task


58
59
60
61
62
63
64
65
66
67
# File 'lib/yard/rake/yardoc_task.rb', line 58

def define
  desc "Generate YARD Documentation"
  task(name) do
    before.call if before.is_a?(Proc)
    yardoc = YARD::CLI::Yardoc.new
    yardoc.options[:verifier] = verifier if verifier
    yardoc.run *(options + files) 
    after.call if after.is_a?(Proc)
  end
end