rake 0.9.2.2 → 13.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/History.rdoc +2403 -0
- data/MIT-LICENSE +1 -1
- data/README.rdoc +64 -106
- data/doc/command_line_usage.rdoc +65 -21
- data/doc/glossary.rdoc +40 -49
- data/doc/jamis.rb +1 -0
- data/doc/rake.1 +156 -0
- data/doc/rakefile.rdoc +127 -62
- data/{bin → exe}/rake +1 -7
- data/lib/rake/application.rb +507 -271
- data/lib/rake/backtrace.rb +24 -0
- data/lib/rake/clean.rb +54 -8
- data/lib/rake/cloneable.rb +11 -19
- data/lib/rake/cpu_counter.rb +107 -0
- data/lib/rake/default_loader.rb +5 -0
- data/lib/rake/dsl_definition.rb +67 -48
- data/lib/rake/early_time.rb +5 -1
- data/lib/rake/ext/core.rb +5 -6
- data/lib/rake/ext/string.rb +61 -52
- data/lib/rake/file_creation_task.rb +4 -3
- data/lib/rake/file_list.rb +81 -49
- data/lib/rake/file_task.rb +15 -8
- data/lib/rake/file_utils.rb +63 -43
- data/lib/rake/file_utils_ext.rb +14 -25
- data/lib/rake/invocation_chain.rb +25 -19
- data/lib/rake/invocation_exception_mixin.rb +1 -0
- data/lib/rake/late_time.rb +18 -0
- data/lib/rake/linked_list.rb +112 -0
- data/lib/rake/loaders/makefile.rb +23 -9
- data/lib/rake/multi_task.rb +4 -6
- data/lib/rake/name_space.rb +36 -23
- data/lib/rake/packagetask.rb +71 -34
- data/lib/rake/phony.rb +16 -0
- data/lib/rake/private_reader.rb +21 -0
- data/lib/rake/promise.rb +100 -0
- data/lib/rake/pseudo_status.rb +8 -2
- data/lib/rake/rake_module.rb +41 -3
- data/lib/rake/rake_test_loader.rb +9 -4
- data/lib/rake/rule_recursion_overflow_error.rb +2 -2
- data/lib/rake/scope.rb +43 -0
- data/lib/rake/task.rb +186 -79
- data/lib/rake/task_argument_error.rb +1 -0
- data/lib/rake/task_arguments.rb +46 -15
- data/lib/rake/task_manager.rb +91 -67
- data/lib/rake/tasklib.rb +2 -12
- data/lib/rake/testtask.rb +61 -63
- data/lib/rake/thread_history_display.rb +49 -0
- data/lib/rake/thread_pool.rb +163 -0
- data/lib/rake/trace_output.rb +23 -0
- data/lib/rake/version.rb +5 -3
- data/lib/rake/win32.rb +14 -18
- data/lib/rake.rb +35 -33
- data/rake.gemspec +100 -0
- metadata +74 -176
- data/.gemtest +0 -0
- data/CHANGES +0 -522
- data/Rakefile +0 -369
- data/TODO +0 -20
- data/doc/rake.1.gz +0 -0
- data/doc/release_notes/rake-0.4.14.rdoc +0 -23
- data/doc/release_notes/rake-0.4.15.rdoc +0 -35
- data/doc/release_notes/rake-0.5.0.rdoc +0 -53
- data/doc/release_notes/rake-0.5.3.rdoc +0 -78
- data/doc/release_notes/rake-0.5.4.rdoc +0 -46
- data/doc/release_notes/rake-0.6.0.rdoc +0 -141
- data/doc/release_notes/rake-0.7.0.rdoc +0 -119
- data/doc/release_notes/rake-0.7.1.rdoc +0 -59
- data/doc/release_notes/rake-0.7.2.rdoc +0 -121
- data/doc/release_notes/rake-0.7.3.rdoc +0 -47
- data/doc/release_notes/rake-0.8.0.rdoc +0 -114
- data/doc/release_notes/rake-0.8.2.rdoc +0 -165
- data/doc/release_notes/rake-0.8.3.rdoc +0 -112
- data/doc/release_notes/rake-0.8.4.rdoc +0 -147
- data/doc/release_notes/rake-0.8.5.rdoc +0 -53
- data/doc/release_notes/rake-0.8.6.rdoc +0 -55
- data/doc/release_notes/rake-0.8.7.rdoc +0 -55
- data/doc/release_notes/rake-0.9.0.rdoc +0 -112
- data/doc/release_notes/rake-0.9.1.rdoc +0 -52
- data/doc/release_notes/rake-0.9.2.rdoc +0 -49
- data/install.rb +0 -90
- data/lib/rake/alt_system.rb +0 -109
- data/lib/rake/classic_namespace.rb +0 -11
- data/lib/rake/contrib/compositepublisher.rb +0 -21
- data/lib/rake/contrib/ftptools.rb +0 -150
- data/lib/rake/contrib/publisher.rb +0 -73
- data/lib/rake/contrib/rubyforgepublisher.rb +0 -16
- data/lib/rake/contrib/sshpublisher.rb +0 -50
- data/lib/rake/contrib/sys.rb +0 -191
- data/lib/rake/ext/module.rb +0 -39
- data/lib/rake/ext/time.rb +0 -14
- data/lib/rake/gempackagetask.rb +0 -15
- data/lib/rake/pathmap.rb +0 -1
- data/lib/rake/rdoctask.rb +0 -234
- data/lib/rake/ruby182_test_unit_fix.rb +0 -25
- data/lib/rake/runtest.rb +0 -21
- data/test/file_creation.rb +0 -34
- data/test/helper.rb +0 -492
- data/test/test_rake.rb +0 -40
- data/test/test_rake_application.rb +0 -489
- data/test/test_rake_application_options.rb +0 -335
- data/test/test_rake_clean.rb +0 -14
- data/test/test_rake_definitions.rb +0 -80
- data/test/test_rake_directory_task.rb +0 -46
- data/test/test_rake_dsl.rb +0 -77
- data/test/test_rake_early_time.rb +0 -31
- data/test/test_rake_extension.rb +0 -59
- data/test/test_rake_file_creation_task.rb +0 -56
- data/test/test_rake_file_list.rb +0 -628
- data/test/test_rake_file_list_path_map.rb +0 -8
- data/test/test_rake_file_task.rb +0 -102
- data/test/test_rake_file_utils.rb +0 -305
- data/test/test_rake_ftp_file.rb +0 -59
- data/test/test_rake_functional.rb +0 -450
- data/test/test_rake_invocation_chain.rb +0 -52
- data/test/test_rake_makefile_loader.rb +0 -44
- data/test/test_rake_multi_task.rb +0 -51
- data/test/test_rake_name_space.rb +0 -43
- data/test/test_rake_package_task.rb +0 -79
- data/test/test_rake_path_map.rb +0 -157
- data/test/test_rake_path_map_explode.rb +0 -34
- data/test/test_rake_path_map_partial.rb +0 -18
- data/test/test_rake_pseudo_status.rb +0 -21
- data/test/test_rake_rake_test_loader.rb +0 -21
- data/test/test_rake_rdoc_task.rb +0 -83
- data/test/test_rake_require.rb +0 -40
- data/test/test_rake_rules.rb +0 -327
- data/test/test_rake_task.rb +0 -267
- data/test/test_rake_task_argument_parsing.rb +0 -103
- data/test/test_rake_task_arguments.rb +0 -88
- data/test/test_rake_task_lib.rb +0 -9
- data/test/test_rake_task_manager.rb +0 -157
- data/test/test_rake_task_manager_argument_resolution.rb +0 -36
- data/test/test_rake_task_with_arguments.rb +0 -173
- data/test/test_rake_test_task.rb +0 -120
- data/test/test_rake_top_level_functions.rb +0 -111
- data/test/test_rake_win32.rb +0 -72
- data/test/test_sys.rb +0 -20
data/lib/rake/contrib/sys.rb
DELETED
|
@@ -1,191 +0,0 @@
|
|
|
1
|
-
warn 'Sys has been deprecated in favor of FileUtils'
|
|
2
|
-
|
|
3
|
-
#--
|
|
4
|
-
# Copyright 2003-2010 by Jim Weirich (jim.weirich@gmail.com)
|
|
5
|
-
# All rights reserved.
|
|
6
|
-
#++
|
|
7
|
-
#
|
|
8
|
-
begin
|
|
9
|
-
require 'ftools'
|
|
10
|
-
rescue LoadError
|
|
11
|
-
end
|
|
12
|
-
require 'rbconfig'
|
|
13
|
-
|
|
14
|
-
######################################################################
|
|
15
|
-
# Sys provides a number of file manipulation tools for the convenience
|
|
16
|
-
# of writing Rakefiles. All commands in this module will announce
|
|
17
|
-
# their activity on standard output if the $verbose flag is set
|
|
18
|
-
# ($verbose = true is the default). You can control this by globally
|
|
19
|
-
# setting $verbose or by using the +verbose+ and +quiet+ methods.
|
|
20
|
-
#
|
|
21
|
-
# Sys has been deprecated in favor of the FileUtils module available
|
|
22
|
-
# in Ruby 1.8.
|
|
23
|
-
#
|
|
24
|
-
module Sys
|
|
25
|
-
RUBY = RbConfig::CONFIG['ruby_install_name']
|
|
26
|
-
|
|
27
|
-
# Install all the files matching +wildcard+ into the +dest_dir+
|
|
28
|
-
# directory. The permission mode is set to +mode+.
|
|
29
|
-
def install(wildcard, dest_dir, mode)
|
|
30
|
-
Dir[wildcard].each do |fn|
|
|
31
|
-
File.install(fn, dest_dir, mode, $verbose)
|
|
32
|
-
end
|
|
33
|
-
end
|
|
34
|
-
|
|
35
|
-
# Run the system command +cmd+.
|
|
36
|
-
def run(cmd)
|
|
37
|
-
log cmd
|
|
38
|
-
system(cmd) or fail "Command Failed: [#{cmd}]"
|
|
39
|
-
end
|
|
40
|
-
|
|
41
|
-
# Run a Ruby interpreter with the given arguments.
|
|
42
|
-
def ruby(*args)
|
|
43
|
-
run "#{RUBY} #{args.join(' ')}"
|
|
44
|
-
end
|
|
45
|
-
|
|
46
|
-
# Copy a single file from +file_name+ to +dest_file+.
|
|
47
|
-
def copy(file_name, dest_file)
|
|
48
|
-
log "Copying file #{file_name} to #{dest_file}"
|
|
49
|
-
File.copy(file_name, dest_file)
|
|
50
|
-
end
|
|
51
|
-
|
|
52
|
-
# Copy all files matching +wildcard+ into the directory +dest_dir+.
|
|
53
|
-
def copy_files(wildcard, dest_dir)
|
|
54
|
-
for_matching_files(wildcard, dest_dir) { |from, to| copy(from, to) }
|
|
55
|
-
end
|
|
56
|
-
|
|
57
|
-
# Link +file_name+ to +dest_file+.
|
|
58
|
-
def link(file_name, dest_file)
|
|
59
|
-
log "Linking file #{file_name} to #{dest_file}"
|
|
60
|
-
File.link(file_name, dest_file)
|
|
61
|
-
end
|
|
62
|
-
|
|
63
|
-
# Link all files matching +wildcard+ into the directory +dest_dir+.
|
|
64
|
-
def link_files(wildcard, dest_dir)
|
|
65
|
-
for_matching_files(wildcard, dest_dir) { |from, to| link(from, to) }
|
|
66
|
-
end
|
|
67
|
-
|
|
68
|
-
# Symlink +file_name+ to +dest_file+.
|
|
69
|
-
def symlink(file_name, dest_file)
|
|
70
|
-
log "Symlinking file #{file_name} to #{dest_file}"
|
|
71
|
-
File.symlink(file_name, dest_file)
|
|
72
|
-
end
|
|
73
|
-
|
|
74
|
-
# Symlink all files matching +wildcard+ into the directory +dest_dir+.
|
|
75
|
-
def symlink_files(wildcard, dest_dir)
|
|
76
|
-
for_matching_files(wildcard, dest_dir) { |from, to| link(from, to) }
|
|
77
|
-
end
|
|
78
|
-
|
|
79
|
-
# Remove all files matching +wildcard+. If a matching file is a
|
|
80
|
-
# directory, it must be empty to be removed. used +delete_all+ to
|
|
81
|
-
# recursively delete directories.
|
|
82
|
-
def delete(*wildcards)
|
|
83
|
-
wildcards.each do |wildcard|
|
|
84
|
-
Dir[wildcard].each do |fn|
|
|
85
|
-
if File.directory?(fn)
|
|
86
|
-
log "Deleting directory #{fn}"
|
|
87
|
-
Dir.delete(fn)
|
|
88
|
-
else
|
|
89
|
-
log "Deleting file #{fn}"
|
|
90
|
-
File.delete(fn)
|
|
91
|
-
end
|
|
92
|
-
end
|
|
93
|
-
end
|
|
94
|
-
end
|
|
95
|
-
|
|
96
|
-
# Recursively delete all files and directories matching +wildcard+.
|
|
97
|
-
def delete_all(*wildcards)
|
|
98
|
-
wildcards.each do |wildcard|
|
|
99
|
-
Dir[wildcard].each do |fn|
|
|
100
|
-
next if ! File.exist?(fn)
|
|
101
|
-
if File.directory?(fn)
|
|
102
|
-
Dir["#{fn}/*"].each do |subfn|
|
|
103
|
-
next if subfn=='.' || subfn=='..'
|
|
104
|
-
delete_all(subfn)
|
|
105
|
-
end
|
|
106
|
-
log "Deleting directory #{fn}"
|
|
107
|
-
Dir.delete(fn)
|
|
108
|
-
else
|
|
109
|
-
log "Deleting file #{fn}"
|
|
110
|
-
File.delete(fn)
|
|
111
|
-
end
|
|
112
|
-
end
|
|
113
|
-
end
|
|
114
|
-
end
|
|
115
|
-
|
|
116
|
-
# Make the directories given in +dirs+.
|
|
117
|
-
def makedirs(*dirs)
|
|
118
|
-
dirs.each do |fn|
|
|
119
|
-
log "Making directory #{fn}"
|
|
120
|
-
File.makedirs(fn)
|
|
121
|
-
end
|
|
122
|
-
end
|
|
123
|
-
|
|
124
|
-
# Make +dir+ the current working directory for the duration of
|
|
125
|
-
# executing the given block.
|
|
126
|
-
def indir(dir)
|
|
127
|
-
olddir = Dir.pwd
|
|
128
|
-
Dir.chdir(dir)
|
|
129
|
-
yield
|
|
130
|
-
ensure
|
|
131
|
-
Dir.chdir(olddir)
|
|
132
|
-
end
|
|
133
|
-
|
|
134
|
-
# Split a file path into individual directory names.
|
|
135
|
-
#
|
|
136
|
-
# For example:
|
|
137
|
-
# split_all("a/b/c") => ['a', 'b', 'c']
|
|
138
|
-
def split_all(path)
|
|
139
|
-
head, tail = File.split(path)
|
|
140
|
-
return [tail] if head == '.' || tail == '/'
|
|
141
|
-
return [head, tail] if head == '/'
|
|
142
|
-
return split_all(head) + [tail]
|
|
143
|
-
end
|
|
144
|
-
|
|
145
|
-
# Write a message to standard error if $verbose is enabled.
|
|
146
|
-
def log(msg)
|
|
147
|
-
print " " if $trace && $verbose
|
|
148
|
-
$stderr.puts msg if $verbose
|
|
149
|
-
end
|
|
150
|
-
|
|
151
|
-
# Perform a block with $verbose disabled.
|
|
152
|
-
def quiet(&block)
|
|
153
|
-
with_verbose(false, &block)
|
|
154
|
-
end
|
|
155
|
-
|
|
156
|
-
# Perform a block with $verbose enabled.
|
|
157
|
-
def verbose(&block)
|
|
158
|
-
with_verbose(true, &block)
|
|
159
|
-
end
|
|
160
|
-
|
|
161
|
-
# Perform a block with each file matching a set of wildcards.
|
|
162
|
-
def for_files(*wildcards)
|
|
163
|
-
wildcards.each do |wildcard|
|
|
164
|
-
Dir[wildcard].each do |fn|
|
|
165
|
-
yield(fn)
|
|
166
|
-
end
|
|
167
|
-
end
|
|
168
|
-
end
|
|
169
|
-
|
|
170
|
-
extend(self)
|
|
171
|
-
|
|
172
|
-
private # ----------------------------------------------------------
|
|
173
|
-
|
|
174
|
-
def for_matching_files(wildcard, dest_dir)
|
|
175
|
-
Dir[wildcard].each do |fn|
|
|
176
|
-
dest_file = File.join(dest_dir, fn)
|
|
177
|
-
parent = File.dirname(dest_file)
|
|
178
|
-
makedirs(parent) if ! File.directory?(parent)
|
|
179
|
-
yield(fn, dest_file)
|
|
180
|
-
end
|
|
181
|
-
end
|
|
182
|
-
|
|
183
|
-
def with_verbose(v)
|
|
184
|
-
oldverbose = $verbose
|
|
185
|
-
$verbose = v
|
|
186
|
-
yield
|
|
187
|
-
ensure
|
|
188
|
-
$verbose = oldverbose
|
|
189
|
-
end
|
|
190
|
-
|
|
191
|
-
end
|
data/lib/rake/ext/module.rb
DELETED
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
require 'rake/ext/core'
|
|
2
|
-
require 'rake/task'
|
|
3
|
-
require 'rake/file_task'
|
|
4
|
-
require 'rake/file_creation_task'
|
|
5
|
-
require 'rake/application'
|
|
6
|
-
require 'rake/task_manager'
|
|
7
|
-
|
|
8
|
-
######################################################################
|
|
9
|
-
# Rake extensions to Module.
|
|
10
|
-
#
|
|
11
|
-
class Module
|
|
12
|
-
|
|
13
|
-
# Rename the original handler to make it available.
|
|
14
|
-
alias :rake_original_const_missing :const_missing
|
|
15
|
-
|
|
16
|
-
# Check for deprecated uses of top level (i.e. in Object) uses of
|
|
17
|
-
# Rake class names. If someone tries to reference the constant
|
|
18
|
-
# name, display a warning and return the proper object. Using the
|
|
19
|
-
# --classic-namespace command line option will define these
|
|
20
|
-
# constants in Object and avoid this handler.
|
|
21
|
-
def const_missing(const_name)
|
|
22
|
-
case const_name
|
|
23
|
-
when :Task
|
|
24
|
-
Rake.application.const_warning(const_name)
|
|
25
|
-
Rake::Task
|
|
26
|
-
when :FileTask
|
|
27
|
-
Rake.application.const_warning(const_name)
|
|
28
|
-
Rake::FileTask
|
|
29
|
-
when :FileCreationTask
|
|
30
|
-
Rake.application.const_warning(const_name)
|
|
31
|
-
Rake::FileCreationTask
|
|
32
|
-
when :RakeApp
|
|
33
|
-
Rake.application.const_warning(const_name)
|
|
34
|
-
Rake::Application
|
|
35
|
-
else
|
|
36
|
-
rake_original_const_missing(const_name)
|
|
37
|
-
end
|
|
38
|
-
end
|
|
39
|
-
end
|
data/lib/rake/ext/time.rb
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
#--
|
|
2
|
-
# Extensions to time to allow comparisons with an early time class.
|
|
3
|
-
|
|
4
|
-
class Time
|
|
5
|
-
alias rake_original_time_compare :<=>
|
|
6
|
-
def <=>(other)
|
|
7
|
-
if Rake::EarlyTime === other
|
|
8
|
-
- other.<=>(self)
|
|
9
|
-
else
|
|
10
|
-
rake_original_time_compare(other)
|
|
11
|
-
end
|
|
12
|
-
end
|
|
13
|
-
end
|
|
14
|
-
|
data/lib/rake/gempackagetask.rb
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
# rake/gempackagetask is deprecated in favor of rubygems/package_task
|
|
2
|
-
|
|
3
|
-
warn 'rake/gempackagetask is deprecated. Use rubygems/package_task instead'
|
|
4
|
-
|
|
5
|
-
require 'rubygems'
|
|
6
|
-
require 'rubygems/package_task'
|
|
7
|
-
|
|
8
|
-
require 'rake'
|
|
9
|
-
|
|
10
|
-
# :stopdoc:
|
|
11
|
-
|
|
12
|
-
module Rake
|
|
13
|
-
GemPackageTask = Gem::PackageTask
|
|
14
|
-
end
|
|
15
|
-
|
data/lib/rake/pathmap.rb
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
require 'rake/ext/string'
|
data/lib/rake/rdoctask.rb
DELETED
|
@@ -1,234 +0,0 @@
|
|
|
1
|
-
# rake/rdoctask is deprecated in favor of rdoc/task
|
|
2
|
-
|
|
3
|
-
if Rake.application
|
|
4
|
-
Rake.application.deprecate('require \'rake/rdoctask\'', 'require \'rdoc/task\' (in RDoc 2.4.2+)', __FILE__)
|
|
5
|
-
end
|
|
6
|
-
|
|
7
|
-
require 'rubygems'
|
|
8
|
-
|
|
9
|
-
begin
|
|
10
|
-
gem 'rdoc'
|
|
11
|
-
require 'rdoc'
|
|
12
|
-
require 'rdoc/task'
|
|
13
|
-
rescue LoadError, Gem::LoadError
|
|
14
|
-
end
|
|
15
|
-
|
|
16
|
-
# :stopdoc:
|
|
17
|
-
|
|
18
|
-
if defined?(RDoc::Task) then
|
|
19
|
-
module Rake
|
|
20
|
-
RDocTask = RDoc::Task unless const_defined? :RDocTask
|
|
21
|
-
end
|
|
22
|
-
else
|
|
23
|
-
require 'rake'
|
|
24
|
-
require 'rake/tasklib'
|
|
25
|
-
|
|
26
|
-
module Rake
|
|
27
|
-
|
|
28
|
-
# NOTE: Rake::RDocTask is deprecated in favor of RDoc:Task which is included
|
|
29
|
-
# in RDoc 2.4.2+. Use require 'rdoc/task' to require it.
|
|
30
|
-
#
|
|
31
|
-
# Create a documentation task that will generate the RDoc files for
|
|
32
|
-
# a project.
|
|
33
|
-
#
|
|
34
|
-
# The RDocTask will create the following targets:
|
|
35
|
-
#
|
|
36
|
-
# [<b><em>rdoc</em></b>]
|
|
37
|
-
# Main task for this RDOC task.
|
|
38
|
-
#
|
|
39
|
-
# [<b>:clobber_<em>rdoc</em></b>]
|
|
40
|
-
# Delete all the rdoc files. This target is automatically
|
|
41
|
-
# added to the main clobber target.
|
|
42
|
-
#
|
|
43
|
-
# [<b>:re<em>rdoc</em></b>]
|
|
44
|
-
# Rebuild the rdoc files from scratch, even if they are not out
|
|
45
|
-
# of date.
|
|
46
|
-
#
|
|
47
|
-
# Simple Example:
|
|
48
|
-
#
|
|
49
|
-
# Rake::RDocTask.new do |rd|
|
|
50
|
-
# rd.main = "README.rdoc"
|
|
51
|
-
# rd.rdoc_files.include("README.rdoc", "lib/**/*.rb")
|
|
52
|
-
# end
|
|
53
|
-
#
|
|
54
|
-
# The +rd+ object passed to the block is an RDocTask object. See the
|
|
55
|
-
# attributes list for the RDocTask class for available customization options.
|
|
56
|
-
#
|
|
57
|
-
# == Specifying different task names
|
|
58
|
-
#
|
|
59
|
-
# You may wish to give the task a different name, such as if you are
|
|
60
|
-
# generating two sets of documentation. For instance, if you want to have a
|
|
61
|
-
# development set of documentation including private methods:
|
|
62
|
-
#
|
|
63
|
-
# Rake::RDocTask.new(:rdoc_dev) do |rd|
|
|
64
|
-
# rd.main = "README.doc"
|
|
65
|
-
# rd.rdoc_files.include("README.rdoc", "lib/**/*.rb")
|
|
66
|
-
# rd.options << "--all"
|
|
67
|
-
# end
|
|
68
|
-
#
|
|
69
|
-
# The tasks would then be named :<em>rdoc_dev</em>, :clobber_<em>rdoc_dev</em>, and
|
|
70
|
-
# :re<em>rdoc_dev</em>.
|
|
71
|
-
#
|
|
72
|
-
# If you wish to have completely different task names, then pass a Hash as
|
|
73
|
-
# first argument. With the <tt>:rdoc</tt>, <tt>:clobber_rdoc</tt> and
|
|
74
|
-
# <tt>:rerdoc</tt> options, you can customize the task names to your liking.
|
|
75
|
-
# For example:
|
|
76
|
-
#
|
|
77
|
-
# Rake::RDocTask.new(:rdoc => "rdoc", :clobber_rdoc => "rdoc:clean", :rerdoc => "rdoc:force")
|
|
78
|
-
#
|
|
79
|
-
# This will create the tasks <tt>:rdoc</tt>, <tt>:rdoc_clean</tt> and
|
|
80
|
-
# <tt>:rdoc:force</tt>.
|
|
81
|
-
#
|
|
82
|
-
class RDocTask < TaskLib
|
|
83
|
-
# Name of the main, top level task. (default is :rdoc)
|
|
84
|
-
attr_accessor :name
|
|
85
|
-
|
|
86
|
-
# Name of directory to receive the html output files. (default is "html")
|
|
87
|
-
attr_accessor :rdoc_dir
|
|
88
|
-
|
|
89
|
-
# Title of RDoc documentation. (defaults to rdoc's default)
|
|
90
|
-
attr_accessor :title
|
|
91
|
-
|
|
92
|
-
# Name of file to be used as the main, top level file of the
|
|
93
|
-
# RDoc. (default is none)
|
|
94
|
-
attr_accessor :main
|
|
95
|
-
|
|
96
|
-
# Name of template to be used by rdoc. (defaults to rdoc's default)
|
|
97
|
-
attr_accessor :template
|
|
98
|
-
|
|
99
|
-
# List of files to be included in the rdoc generation. (default is [])
|
|
100
|
-
attr_accessor :rdoc_files
|
|
101
|
-
|
|
102
|
-
# Additional list of options to be passed rdoc. (default is [])
|
|
103
|
-
attr_accessor :options
|
|
104
|
-
|
|
105
|
-
# Whether to run the rdoc process as an external shell (default is false)
|
|
106
|
-
attr_accessor :external
|
|
107
|
-
|
|
108
|
-
attr_accessor :inline_source
|
|
109
|
-
|
|
110
|
-
# Create an RDoc task with the given name. See the RDocTask class overview
|
|
111
|
-
# for documentation.
|
|
112
|
-
def initialize(name = :rdoc) # :yield: self
|
|
113
|
-
if name.is_a?(Hash)
|
|
114
|
-
invalid_options = name.keys.map { |k| k.to_sym } - [:rdoc, :clobber_rdoc, :rerdoc]
|
|
115
|
-
if !invalid_options.empty?
|
|
116
|
-
raise ArgumentError, "Invalid option(s) passed to RDocTask.new: #{invalid_options.join(", ")}"
|
|
117
|
-
end
|
|
118
|
-
end
|
|
119
|
-
|
|
120
|
-
@name = name
|
|
121
|
-
@rdoc_files = Rake::FileList.new
|
|
122
|
-
@rdoc_dir = 'html'
|
|
123
|
-
@main = nil
|
|
124
|
-
@title = nil
|
|
125
|
-
@template = nil
|
|
126
|
-
@external = false
|
|
127
|
-
@inline_source = true
|
|
128
|
-
@options = []
|
|
129
|
-
yield self if block_given?
|
|
130
|
-
define
|
|
131
|
-
end
|
|
132
|
-
|
|
133
|
-
# Create the tasks defined by this task lib.
|
|
134
|
-
def define
|
|
135
|
-
if rdoc_task_name != "rdoc"
|
|
136
|
-
desc "Build the RDOC HTML Files"
|
|
137
|
-
else
|
|
138
|
-
desc "Build the #{rdoc_task_name} HTML Files"
|
|
139
|
-
end
|
|
140
|
-
task rdoc_task_name
|
|
141
|
-
|
|
142
|
-
desc "Force a rebuild of the RDOC files"
|
|
143
|
-
task rerdoc_task_name => [clobber_task_name, rdoc_task_name]
|
|
144
|
-
|
|
145
|
-
desc "Remove rdoc products"
|
|
146
|
-
task clobber_task_name do
|
|
147
|
-
rm_r rdoc_dir rescue nil
|
|
148
|
-
end
|
|
149
|
-
|
|
150
|
-
task :clobber => [clobber_task_name]
|
|
151
|
-
|
|
152
|
-
directory @rdoc_dir
|
|
153
|
-
task rdoc_task_name => [rdoc_target]
|
|
154
|
-
file rdoc_target => @rdoc_files + [Rake.application.rakefile] do
|
|
155
|
-
rm_r @rdoc_dir rescue nil
|
|
156
|
-
@before_running_rdoc.call if @before_running_rdoc
|
|
157
|
-
args = option_list + @rdoc_files
|
|
158
|
-
if @external
|
|
159
|
-
argstring = args.join(' ')
|
|
160
|
-
sh %{ruby -Ivendor vendor/rd #{argstring}}
|
|
161
|
-
else
|
|
162
|
-
require 'rdoc/rdoc'
|
|
163
|
-
RDoc::RDoc.new.document(args)
|
|
164
|
-
end
|
|
165
|
-
end
|
|
166
|
-
self
|
|
167
|
-
end
|
|
168
|
-
|
|
169
|
-
def option_list
|
|
170
|
-
result = @options.dup
|
|
171
|
-
result << "-o" << @rdoc_dir
|
|
172
|
-
result << "--main" << quote(main) if main
|
|
173
|
-
result << "--title" << quote(title) if title
|
|
174
|
-
result << "-T" << quote(template) if template
|
|
175
|
-
result << "--inline-source" if inline_source && !@options.include?("--inline-source") && !@options.include?("-S")
|
|
176
|
-
result
|
|
177
|
-
end
|
|
178
|
-
|
|
179
|
-
def quote(str)
|
|
180
|
-
if @external
|
|
181
|
-
"'#{str}'"
|
|
182
|
-
else
|
|
183
|
-
str
|
|
184
|
-
end
|
|
185
|
-
end
|
|
186
|
-
|
|
187
|
-
def option_string
|
|
188
|
-
option_list.join(' ')
|
|
189
|
-
end
|
|
190
|
-
|
|
191
|
-
# The block passed to this method will be called just before running the
|
|
192
|
-
# RDoc generator. It is allowed to modify RDocTask attributes inside the
|
|
193
|
-
# block.
|
|
194
|
-
def before_running_rdoc(&block)
|
|
195
|
-
@before_running_rdoc = block
|
|
196
|
-
end
|
|
197
|
-
|
|
198
|
-
private
|
|
199
|
-
|
|
200
|
-
def rdoc_target
|
|
201
|
-
"#{rdoc_dir}/index.html"
|
|
202
|
-
end
|
|
203
|
-
|
|
204
|
-
def rdoc_task_name
|
|
205
|
-
case name
|
|
206
|
-
when Hash
|
|
207
|
-
(name[:rdoc] || "rdoc").to_s
|
|
208
|
-
else
|
|
209
|
-
name.to_s
|
|
210
|
-
end
|
|
211
|
-
end
|
|
212
|
-
|
|
213
|
-
def clobber_task_name
|
|
214
|
-
case name
|
|
215
|
-
when Hash
|
|
216
|
-
(name[:clobber_rdoc] || "clobber_rdoc").to_s
|
|
217
|
-
else
|
|
218
|
-
"clobber_#{name}"
|
|
219
|
-
end
|
|
220
|
-
end
|
|
221
|
-
|
|
222
|
-
def rerdoc_task_name
|
|
223
|
-
case name
|
|
224
|
-
when Hash
|
|
225
|
-
(name[:rerdoc] || "rerdoc").to_s
|
|
226
|
-
else
|
|
227
|
-
"re#{name}"
|
|
228
|
-
end
|
|
229
|
-
end
|
|
230
|
-
|
|
231
|
-
end
|
|
232
|
-
end
|
|
233
|
-
end
|
|
234
|
-
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
# Local Rake override to fix bug in Ruby 0.8.2
|
|
2
|
-
module Test # :nodoc:
|
|
3
|
-
# Local Rake override to fix bug in Ruby 0.8.2
|
|
4
|
-
module Unit # :nodoc:
|
|
5
|
-
# Local Rake override to fix bug in Ruby 0.8.2
|
|
6
|
-
module Collector # :nodoc:
|
|
7
|
-
# Local Rake override to fix bug in Ruby 0.8.2
|
|
8
|
-
class Dir # :nodoc:
|
|
9
|
-
undef collect_file
|
|
10
|
-
def collect_file(name, suites, already_gathered) # :nodoc:
|
|
11
|
-
dir = File.dirname(File.expand_path(name))
|
|
12
|
-
$:.unshift(dir) unless $:.first == dir
|
|
13
|
-
if(@req)
|
|
14
|
-
@req.require(name)
|
|
15
|
-
else
|
|
16
|
-
require(name)
|
|
17
|
-
end
|
|
18
|
-
find_test_cases(already_gathered).each{|t| add_suite(suites, t.suite)}
|
|
19
|
-
ensure
|
|
20
|
-
$:.delete_at $:.rindex(dir)
|
|
21
|
-
end
|
|
22
|
-
end
|
|
23
|
-
end
|
|
24
|
-
end
|
|
25
|
-
end
|
data/lib/rake/runtest.rb
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
require 'test/unit'
|
|
2
|
-
require 'test/unit/assertions'
|
|
3
|
-
|
|
4
|
-
module Rake
|
|
5
|
-
include Test::Unit::Assertions
|
|
6
|
-
|
|
7
|
-
def run_tests(pattern='test/test*.rb', log_enabled=false)
|
|
8
|
-
Dir["#{pattern}"].each { |fn|
|
|
9
|
-
$stderr.puts fn if log_enabled
|
|
10
|
-
begin
|
|
11
|
-
require fn
|
|
12
|
-
rescue Exception => ex
|
|
13
|
-
$stderr.puts "Error in #{fn}: #{ex.message}"
|
|
14
|
-
$stderr.puts ex.backtrace
|
|
15
|
-
assert false
|
|
16
|
-
end
|
|
17
|
-
}
|
|
18
|
-
end
|
|
19
|
-
|
|
20
|
-
extend self
|
|
21
|
-
end
|
data/test/file_creation.rb
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
module FileCreation
|
|
2
|
-
OLDFILE = "old"
|
|
3
|
-
NEWFILE = "new"
|
|
4
|
-
|
|
5
|
-
def create_timed_files(oldfile, *newfiles)
|
|
6
|
-
return if (File.exist?(oldfile) &&
|
|
7
|
-
newfiles.all? { |newfile|
|
|
8
|
-
File.exist?(newfile) && File.stat(newfile).mtime > File.stat(oldfile).mtime
|
|
9
|
-
})
|
|
10
|
-
now = Time.now
|
|
11
|
-
|
|
12
|
-
create_file(oldfile, now - 60)
|
|
13
|
-
|
|
14
|
-
newfiles.each do |newfile|
|
|
15
|
-
create_file(newfile, now)
|
|
16
|
-
end
|
|
17
|
-
end
|
|
18
|
-
|
|
19
|
-
def create_dir(dirname)
|
|
20
|
-
FileUtils.mkdir_p(dirname) unless File.exist?(dirname)
|
|
21
|
-
File.stat(dirname).mtime
|
|
22
|
-
end
|
|
23
|
-
|
|
24
|
-
def create_file(name, file_time=nil)
|
|
25
|
-
create_dir(File.dirname(name))
|
|
26
|
-
FileUtils.touch(name) unless File.exist?(name)
|
|
27
|
-
File.utime(file_time, file_time, name) unless file_time.nil?
|
|
28
|
-
File.stat(name).mtime
|
|
29
|
-
end
|
|
30
|
-
|
|
31
|
-
def delete_file(name)
|
|
32
|
-
File.delete(name) rescue nil
|
|
33
|
-
end
|
|
34
|
-
end
|