Top Level Namespace
- Includes:
- RakeFileUtils
Defined Under Namespace
Modules: FileUtils, Rake, RakeFileUtils, Sys, Test Classes: CompositePublisher, HostInfo, Module, SshDirPublisher, SshFilePublisher, SshFreshDirPublisher, String, Time
Constant Summary collapse
- RAKEVERSION =
Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 by Jim Weirich ([email protected])
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ++
'0.8.7.1'
- FileList =
Alias FileList to be available at the top level.
Rake::FileList
- CLEAN =
Rake::FileList["**/*~", "**/*.bak", "**/core"]
- CLOBBER =
Rake::FileList.new
- Task =
The following classes used to be in the top level namespace. Loading this file enables compatibility with older Rakefile that referenced Task from the top level.
Rake::Task
- FileTask =
Rake::FileTask
- FileCreationTask =
Rake::FileCreationTask
- RakeApp =
Rake::Application
Constants included from FileUtils
FileUtils::LN_SUPPORTED, FileUtils::RUBY
Instance Method Summary collapse
-
#desc(description) ⇒ Object
Describe the next rake task.
-
#directory(dir) ⇒ Object
Declare a set of files tasks to create the given directories on demand.
-
#file(*args, &block) ⇒ Object
Declare a file task.
-
#file_create(args, &block) ⇒ Object
Declare a file creation task.
-
#import(*fns) ⇒ Object
Import the partial Rakefiles
fn
. -
#multitask(args, &block) ⇒ Object
Declare a task that performs its prerequisites in parallel.
-
#namespace(name = nil, &block) ⇒ Object
Create a new rake namespace and use it for evaluating the given block.
-
#rule(*args, &block) ⇒ Object
Declare a rule for auto-tasks.
-
#task(*args, &block) ⇒ Object
Declare a basic task.
Methods included from RakeFileUtils
#nowrite, #verbose, #when_writing
Methods included from FileUtils
#ruby, #safe_ln, #sh, #split_all
Instance Method Details
#desc(description) ⇒ Object
Describe the next rake task.
Example:
desc "Run the Unit Tests"
task :test => [:build]
runtests
end
96 97 98 |
# File 'lib/rake/dsl.rb', line 96 def desc(description) Rake.application.last_description = description end |
#directory(dir) ⇒ Object
Declare a set of files tasks to create the given directories on demand.
Example:
directory "testdata/doc"
43 44 45 46 47 48 49 |
# File 'lib/rake/dsl.rb', line 43 def directory(dir) Rake.each_dir_parent(dir) do |d| file_create d do |t| mkdir_p t.name if ! File.exist?(t.name) end end end |
#file(*args, &block) ⇒ Object
Declare a file task.
Example:
file "config.cfg" => ["config.template"] do
open("config.cfg", "w") do |outfile|
open("config.template") do |infile|
while line = infile.gets
outfile.puts line
end
end
end
end
28 29 30 |
# File 'lib/rake/dsl.rb', line 28 def file(*args, &block) Rake::FileTask.define_task(*args, &block) end |
#file_create(args, &block) ⇒ Object
Declare a file creation task. (Mainly used for the directory command).
34 35 36 |
# File 'lib/rake/dsl.rb', line 34 def file_create(args, &block) Rake::FileCreationTask.define_task(args, &block) end |
#import(*fns) ⇒ Object
Import the partial Rakefiles fn
. Imported files are loaded after the current file is completely loaded. This allows the import statement to appear anywhere in the importing file, and yet allowing the imported files to depend on objects defined in the importing file.
A common use of the import statement is to include files containing dependency declarations.
See also the –rakelibdir command line option.
Example:
import ".depend", "my_rules"
113 114 115 116 117 |
# File 'lib/rake/dsl.rb', line 113 def import(*fns) fns.each do |fn| Rake.application.add_import(fn) end end |
#multitask(args, &block) ⇒ Object
Declare a task that performs its prerequisites in parallel. Multitasks does not guarantee that its prerequisites will execute in any given order (which is obvious when you think about it)
Example:
multitask :deploy => [:deploy_gem, :deploy_rdoc]
58 59 60 |
# File 'lib/rake/dsl.rb', line 58 def multitask(args, &block) Rake::MultiTask.define_task(args, &block) end |
#namespace(name = nil, &block) ⇒ Object
Create a new rake namespace and use it for evaluating the given block. Returns a NameSpace object that can be used to lookup tasks defined in the namespace.
E.g.
ns = namespace "nested" do
task :run
end
task_run = ns[:run] # find :run in the given namespace.
73 74 75 |
# File 'lib/rake/dsl.rb', line 73 def namespace(name=nil, &block) Rake.application.in_namespace(name, &block) end |
#rule(*args, &block) ⇒ Object
Declare a rule for auto-tasks.
Example:
rule '.o' => '.c' do |t|
sh %{cc -o #{t.name} #{t.source}}
end
84 85 86 |
# File 'lib/rake/dsl.rb', line 84 def rule(*args, &block) Rake::Task.create_rule(*args, &block) end |
#task(*args, &block) ⇒ Object
Declare a basic task.
Example:
task :clobber => [:clean] do
rm_rf "html"
end
10 11 12 |
# File 'lib/rake/dsl.rb', line 10 def task(*args, &block) Rake::Task.define_task(*args, &block) end |