forked from rack/rack-cache
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRakefile
74 lines (64 loc) · 2.11 KB
/
Rakefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
require 'bundler/setup'
require 'bundler/gem_tasks'
require 'rake/clean'
require 'bump/tasks'
task :default => :test
CLEAN.include %w[coverage/ doc/api doc/gh-pages tags]
CLOBBER.include %w[dist]
desc 'Run tests'
task :test do
sh "bundle exec mtest test"
end
desc 'Generate test coverage report'
task :rcov do
sh "rcov -I.:lib:test test/*_test.rb"
end
# DOC =======================================================================
desc 'Build all documentation'
task :doc => %w[doc:api doc:markdown]
desc 'Build API documentation (doc/api)'
task 'doc:api' => 'doc/api/index.html'
file 'doc/api/index.html' => FileList['lib/**/*.rb'] do |f|
rm_rf 'doc/api'
sh((<<-SH).gsub(/[\s\n]+/, ' ').strip)
rdoc
--op doc/api
--charset utf8
--fmt hanna
--line-numbers
--main cache.rb
--title 'Rack::Cache API Documentation'
#{f.prerequisites.join(' ')}
SH
end
CLEAN.include 'doc/api'
desc 'Build markdown documentation files'
task 'doc:markdown'
FileList['doc/*.markdown'].each do |source|
dest = "doc/#{File.basename(source, '.markdown')}.html"
file dest => [source, 'doc/layout.html.erb'] do |f|
puts "markdown: #{source} -> #{dest}" if verbose
require 'erb' unless defined? ERB
require 'rdiscount' unless defined? RDiscount
template = File.read(source)
content = Markdown.new(ERB.new(template, 0, "%<>").result(binding), :smart).to_html
content.match("<h1>(.*)</h1>")[1] rescue ''
layout = ERB.new(File.read("doc/layout.html.erb"), 0, "%<>")
output = layout.result(binding)
File.open(dest, 'w') { |io| io.write(output) }
end
task 'doc:markdown' => dest
CLEAN.include dest
end
desc 'Move documentation to directory for github pages'
task 'doc:gh-pages' => [:clean, :doc] do
html_files = FileList['doc/*.markdown'].map { |file| file.gsub('.markdown', '.html')}
css_files = FileList['doc/*.css']
FileUtils.mkdir('doc/gh-pages')
FileUtils.cp_r('doc/api/', 'doc/gh-pages/api')
FileUtils.cp([*html_files, *css_files], 'doc/gh-pages')
end
desc 'Start the documentation development server'
task 'doc:server' do
sh 'cd doc && thin --rackup server.ru --port 3035 start'
end