flyerhzm-metric_fu 1.0.0
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.
- data/HISTORY +164 -0
- data/MIT-LICENSE +22 -0
- data/Manifest.txt +25 -0
- data/README.textile +27 -0
- data/Rakefile +18 -0
- data/TODO +9 -0
- data/lib/base/base_template.rb +145 -0
- data/lib/base/configuration.rb +180 -0
- data/lib/base/generator.rb +167 -0
- data/lib/base/graph.rb +39 -0
- data/lib/base/md5_tracker.rb +52 -0
- data/lib/base/report.rb +100 -0
- data/lib/generators/churn.rb +90 -0
- data/lib/generators/flay.rb +34 -0
- data/lib/generators/flog.rb +167 -0
- data/lib/generators/rails_best_practices.rb +31 -0
- data/lib/generators/rcov.rb +87 -0
- data/lib/generators/reek.rb +64 -0
- data/lib/generators/roodi.rb +32 -0
- data/lib/generators/saikuro.rb +208 -0
- data/lib/generators/stats.rb +43 -0
- data/lib/graphs/engines/bluff.rb +98 -0
- data/lib/graphs/engines/gchart.rb +119 -0
- data/lib/graphs/flay_grapher.rb +20 -0
- data/lib/graphs/flog_grapher.rb +40 -0
- data/lib/graphs/grapher.rb +11 -0
- data/lib/graphs/rails_best_practices_grapher.rb +20 -0
- data/lib/graphs/rcov_grapher.rb +20 -0
- data/lib/graphs/reek_grapher.rb +32 -0
- data/lib/graphs/roodi_grapher.rb +20 -0
- data/lib/metric_fu.rb +31 -0
- data/lib/templates/awesome/awesome_template.rb +37 -0
- data/lib/templates/awesome/churn.html.erb +19 -0
- data/lib/templates/awesome/css/buttons.css +82 -0
- data/lib/templates/awesome/css/default.css +75 -0
- data/lib/templates/awesome/css/integrity.css +335 -0
- data/lib/templates/awesome/css/reset.css +7 -0
- data/lib/templates/awesome/flay.html.erb +33 -0
- data/lib/templates/awesome/flog.html.erb +53 -0
- data/lib/templates/awesome/index.html.erb +31 -0
- data/lib/templates/awesome/layout.html.erb +30 -0
- data/lib/templates/awesome/rails_best_practices.html.erb +27 -0
- data/lib/templates/awesome/rcov.html.erb +42 -0
- data/lib/templates/awesome/reek.html.erb +40 -0
- data/lib/templates/awesome/roodi.html.erb +27 -0
- data/lib/templates/awesome/saikuro.html.erb +71 -0
- data/lib/templates/awesome/stats.html.erb +41 -0
- data/lib/templates/javascripts/bluff-min.js +1 -0
- data/lib/templates/javascripts/excanvas.js +19 -0
- data/lib/templates/javascripts/js-class.js +1 -0
- data/lib/templates/standard/churn.html.erb +31 -0
- data/lib/templates/standard/default.css +64 -0
- data/lib/templates/standard/flay.html.erb +34 -0
- data/lib/templates/standard/flog.html.erb +53 -0
- data/lib/templates/standard/index.html.erb +41 -0
- data/lib/templates/standard/rails_best_practices.html.erb +29 -0
- data/lib/templates/standard/rcov.html.erb +43 -0
- data/lib/templates/standard/reek.html.erb +42 -0
- data/lib/templates/standard/roodi.html.erb +29 -0
- data/lib/templates/standard/saikuro.html.erb +84 -0
- data/lib/templates/standard/standard_template.rb +26 -0
- data/lib/templates/standard/stats.html.erb +55 -0
- data/spec/base/base_template_spec.rb +161 -0
- data/spec/base/configuration_spec.rb +269 -0
- data/spec/base/generator_spec.rb +244 -0
- data/spec/base/graph_spec.rb +24 -0
- data/spec/base/md5_tracker_spec.rb +57 -0
- data/spec/base/report_spec.rb +139 -0
- data/spec/generators/churn_spec.rb +152 -0
- data/spec/generators/flay_spec.rb +104 -0
- data/spec/generators/flog_spec.rb +238 -0
- data/spec/generators/reek_spec.rb +126 -0
- data/spec/generators/saikuro_spec.rb +58 -0
- data/spec/generators/stats_spec.rb +74 -0
- data/spec/graphs/engines/bluff_spec.rb +15 -0
- data/spec/graphs/engines/gchart_spec.rb +15 -0
- data/spec/graphs/flay_grapher_spec.rb +37 -0
- data/spec/graphs/flog_grapher_spec.rb +45 -0
- data/spec/graphs/rcov_grapher_spec.rb +37 -0
- data/spec/graphs/reek_grapher_spec.rb +46 -0
- data/spec/graphs/roodi_grapher_spec.rb +37 -0
- data/spec/resources/saikuro/app/controllers/sessions_controller.rb_cyclo.html +10 -0
- data/spec/resources/saikuro/app/controllers/users_controller.rb_cyclo.html +16 -0
- data/spec/resources/saikuro/index_cyclo.html +155 -0
- data/spec/resources/saikuro_sfiles/thing.rb_cyclo.html +11 -0
- data/spec/resources/yml/20090630.yml +7844 -0
- data/spec/spec.opts +8 -0
- data/spec/spec_helper.rb +7 -0
- data/tasks/metric_fu.rake +22 -0
- data/vendor/_fonts/monaco.ttf +0 -0
- data/vendor/saikuro/saikuro.rb +1219 -0
- metadata +234 -0
@@ -0,0 +1,37 @@
|
|
1
|
+
require 'ftools'
|
2
|
+
|
3
|
+
class AwesomeTemplate < MetricFu::Template
|
4
|
+
|
5
|
+
def write
|
6
|
+
# Getting rid of the crap before and after the project name from integrity
|
7
|
+
@name = File.basename(Dir.pwd).gsub(/^\w+-|-\w+$/, "")
|
8
|
+
|
9
|
+
# Copy Bluff javascripts to output directory
|
10
|
+
Dir[File.join(this_directory, '..', 'javascripts', '*')].each do |f|
|
11
|
+
File.copy(f, File.join(MetricFu.output_directory, File.basename(f)))
|
12
|
+
end
|
13
|
+
|
14
|
+
report.each_pair do |section, contents|
|
15
|
+
if template_exists?(section)
|
16
|
+
create_instance_var(section, contents)
|
17
|
+
@html = erbify(section)
|
18
|
+
html = erbify('layout')
|
19
|
+
fn = output_filename(section)
|
20
|
+
MetricFu.report.save_output(html, MetricFu.output_directory, fn)
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
# Instance variables we need should already be created from above
|
25
|
+
if template_exists?('index')
|
26
|
+
@html = erbify('index')
|
27
|
+
html = erbify('layout')
|
28
|
+
fn = output_filename('index')
|
29
|
+
MetricFu.report.save_output(html, MetricFu.output_directory, fn)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
def this_directory
|
34
|
+
File.dirname(__FILE__)
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
@@ -0,0 +1,19 @@
|
|
1
|
+
<h3>Source Control Churn Results</h3>
|
2
|
+
<p>Files that change a lot in your project may be bad a sign.
|
3
|
+
This task uses your source control log to identify those files.
|
4
|
+
</p>
|
5
|
+
<table>
|
6
|
+
<tr>
|
7
|
+
<th>File Path</th>
|
8
|
+
<th>Times Changed</th>
|
9
|
+
</tr>
|
10
|
+
<% count = 0 %>
|
11
|
+
<% @churn[:changes].each do |change| %>
|
12
|
+
<tr>
|
13
|
+
<td><%= link_to_filename(change[:file_path]) %></td>
|
14
|
+
<td><%= change[:times_changed] %></td>
|
15
|
+
</tr>
|
16
|
+
<% count += 1 %>
|
17
|
+
<% end %>
|
18
|
+
</table>
|
19
|
+
<p>Generated on <%= Time.now.localtime %></p>
|
@@ -0,0 +1,82 @@
|
|
1
|
+
/* --------------------------------------------------------------
|
2
|
+
|
3
|
+
buttons.css
|
4
|
+
* Gives you some great CSS-only buttons.
|
5
|
+
|
6
|
+
Created by Kevin Hale [particletree.com]
|
7
|
+
* particletree.com/features/rediscovering-the-button-element
|
8
|
+
|
9
|
+
See Readme.txt in this folder for instructions.
|
10
|
+
|
11
|
+
-------------------------------------------------------------- */
|
12
|
+
|
13
|
+
button {
|
14
|
+
display:block;
|
15
|
+
float:left;
|
16
|
+
margin:0 0.583em 0.667em 0;
|
17
|
+
padding:5px 10px 5px 7px; /* Links */
|
18
|
+
|
19
|
+
border:1px solid #dedede;
|
20
|
+
border-top:1px solid #eee;
|
21
|
+
border-left:1px solid #eee;
|
22
|
+
|
23
|
+
background-color:#f5f5f5;
|
24
|
+
font-family:"Lucida Grande", Tahoma, Arial, Verdana, sans-serif;
|
25
|
+
font-size:100%;
|
26
|
+
line-height:130%;
|
27
|
+
text-decoration:none;
|
28
|
+
font-weight:bold;
|
29
|
+
color:#565656;
|
30
|
+
cursor:pointer;
|
31
|
+
}
|
32
|
+
button {
|
33
|
+
width:auto;
|
34
|
+
overflow:visible;
|
35
|
+
padding:4px 10px 3px 7px; /* IE6 */
|
36
|
+
}
|
37
|
+
button[type] {
|
38
|
+
padding:4px 10px 4px 7px; /* Firefox */
|
39
|
+
line-height:17px; /* Safari */
|
40
|
+
}
|
41
|
+
*:first-child+html button[type] {
|
42
|
+
padding:4px 10px 3px 7px; /* IE7 */
|
43
|
+
}
|
44
|
+
button img {
|
45
|
+
margin:0 3px -3px 0 !important;
|
46
|
+
padding:0;
|
47
|
+
border:none;
|
48
|
+
width:16px;
|
49
|
+
height:16px;
|
50
|
+
float:none;
|
51
|
+
}
|
52
|
+
|
53
|
+
|
54
|
+
/* Button colors
|
55
|
+
-------------------------------------------------------------- */
|
56
|
+
|
57
|
+
/* Standard */
|
58
|
+
button:hover {
|
59
|
+
background-color:#dff4ff;
|
60
|
+
border:1px solid #c2e1ef;
|
61
|
+
color:#336699;
|
62
|
+
}
|
63
|
+
|
64
|
+
/* Positive */
|
65
|
+
body .positive {
|
66
|
+
color:#529214;
|
67
|
+
}
|
68
|
+
button.positive:hover {
|
69
|
+
background-color:#E6EFC2;
|
70
|
+
border:1px solid #C6D880;
|
71
|
+
color:#529214;
|
72
|
+
}
|
73
|
+
|
74
|
+
/* Negative */
|
75
|
+
body .negative {
|
76
|
+
color:#d12f19;
|
77
|
+
}
|
78
|
+
button.negative:hover {
|
79
|
+
background:#fbe3e4;
|
80
|
+
border:1px solid #fbc2c4;
|
81
|
+
color:#d12f19;
|
82
|
+
}
|
@@ -0,0 +1,75 @@
|
|
1
|
+
table {
|
2
|
+
margin-top: 20px;
|
3
|
+
border-collapse: collapse;
|
4
|
+
border: 1px solid #666;
|
5
|
+
background: #fff;
|
6
|
+
margin-bottom: 20px;
|
7
|
+
}
|
8
|
+
|
9
|
+
table tr.light {
|
10
|
+
background: #fff;
|
11
|
+
}
|
12
|
+
|
13
|
+
table tr.dark {
|
14
|
+
background: #f9f9f9;
|
15
|
+
}
|
16
|
+
|
17
|
+
table tr:hover {
|
18
|
+
background: #FFFFC0;
|
19
|
+
}
|
20
|
+
|
21
|
+
table td, table th {
|
22
|
+
padding: 4px;
|
23
|
+
font-size: 11px;
|
24
|
+
}
|
25
|
+
table th {
|
26
|
+
text-align: center;
|
27
|
+
color: #337022;
|
28
|
+
background: #DDFFCC;
|
29
|
+
font-weight: bold;
|
30
|
+
border: #99D688 1px solid;
|
31
|
+
}
|
32
|
+
|
33
|
+
table td {
|
34
|
+
border: #d0d0d0 1px solid;
|
35
|
+
}
|
36
|
+
|
37
|
+
table td.score {
|
38
|
+
text-align: right;
|
39
|
+
}
|
40
|
+
|
41
|
+
.warning {
|
42
|
+
background: yellow;
|
43
|
+
}
|
44
|
+
.rcov_code td {
|
45
|
+
border-bottom: 1px solid #ddd ;
|
46
|
+
padding: 0;
|
47
|
+
margin: 0;
|
48
|
+
}
|
49
|
+
.rcov_code tr {
|
50
|
+
border: 0px;
|
51
|
+
padding:0px;
|
52
|
+
margin: 0px;
|
53
|
+
}
|
54
|
+
.rcov_code pre {
|
55
|
+
border: 0px;
|
56
|
+
padding: 0px;
|
57
|
+
margin: 0px;
|
58
|
+
}
|
59
|
+
.rcov_run {}
|
60
|
+
.rcov_not_run {
|
61
|
+
background-color: #d88;
|
62
|
+
}
|
63
|
+
.rcov_run a, .rcov_not_run a {
|
64
|
+
text-decoration: none;
|
65
|
+
}
|
66
|
+
.rcov_run a {
|
67
|
+
color: #333;
|
68
|
+
}
|
69
|
+
.rcov_not_run a {
|
70
|
+
color: #000;
|
71
|
+
}
|
72
|
+
.rcov_overflow {
|
73
|
+
overflow: auto;
|
74
|
+
font-size: 50%;
|
75
|
+
}
|
@@ -0,0 +1,335 @@
|
|
1
|
+
html {
|
2
|
+
background-color: #e0e0e0; }
|
3
|
+
|
4
|
+
body {
|
5
|
+
font-size: 100%;
|
6
|
+
font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
|
7
|
+
color: #333333; }
|
8
|
+
|
9
|
+
a {
|
10
|
+
color: #ed1556;
|
11
|
+
text-decoration: none; }
|
12
|
+
a:hover {
|
13
|
+
color: #ffffff;
|
14
|
+
background-color: #ed1556; }
|
15
|
+
|
16
|
+
#header, #content, #footer {
|
17
|
+
margin: 0 auto;
|
18
|
+
background: #eeeeee;
|
19
|
+
padding: 0 2em;
|
20
|
+
z-index: 0;
|
21
|
+
position: relative;
|
22
|
+
font-size: 1em; }
|
23
|
+
|
24
|
+
#header {
|
25
|
+
background: #ffffff; }
|
26
|
+
#header h1 {
|
27
|
+
font-weight: bold;
|
28
|
+
font-size: 1.5em; }
|
29
|
+
#header address.watermark {
|
30
|
+
position: absolute;
|
31
|
+
font-weight: bold;
|
32
|
+
right: 3em;
|
33
|
+
top: 0;
|
34
|
+
font-size: .75em;
|
35
|
+
color: #cccccc; }
|
36
|
+
#header address.watermark a {
|
37
|
+
color: #cccccc;
|
38
|
+
font-weight: bold;
|
39
|
+
font-size: 2em; }
|
40
|
+
#header address.watermark a:hover {
|
41
|
+
background: transparent;
|
42
|
+
color: #aaaaaa; }
|
43
|
+
|
44
|
+
#content {
|
45
|
+
padding-top: 1em;
|
46
|
+
padding-bottom: 2em; }
|
47
|
+
#content strong {
|
48
|
+
font-weight: bold; }
|
49
|
+
#content em {
|
50
|
+
font-style: italic; }
|
51
|
+
#content h1, #content h2, #content h3, #content h4, #content h5, #content h6 {
|
52
|
+
color: #4e4e4e; }
|
53
|
+
#content h1 {
|
54
|
+
font-size: 2em;
|
55
|
+
font-weight: bold;
|
56
|
+
margin-bottom: .75em;
|
57
|
+
padding: .25em 0;
|
58
|
+
line-height: 1.2;
|
59
|
+
border-bottom: 1px solid #c0c0c0; }
|
60
|
+
#content h2 {
|
61
|
+
font-weight: bold;
|
62
|
+
font-size: 1.5em;
|
63
|
+
margin: 1em 0 .2em; }
|
64
|
+
#content h3 {
|
65
|
+
font-weight: bold;
|
66
|
+
font-size: 1.25em;
|
67
|
+
margin: .25em 0; }
|
68
|
+
#content h4, #content h5, #content h6 {
|
69
|
+
font-weight: bold;
|
70
|
+
margin-top: .5em; }
|
71
|
+
#content code, #content pre, #content textarea, #content input {
|
72
|
+
font-family: Monaco, Deja Vu Sans Mono, Inconsolata, Consolas, monospace; }
|
73
|
+
#content form p {
|
74
|
+
margin-top: 1em;
|
75
|
+
position: relative; }
|
76
|
+
#content form p.checkbox label {
|
77
|
+
margin-top: 0 !important; }
|
78
|
+
#content form input.text, #content form textarea {
|
79
|
+
width: 30em;
|
80
|
+
padding: .2em .4em;
|
81
|
+
color: #4e4e4e; }
|
82
|
+
#content form input.text {
|
83
|
+
height: 1.4em; }
|
84
|
+
#content form label {
|
85
|
+
float: left;
|
86
|
+
display: block;
|
87
|
+
margin-top: .5em;
|
88
|
+
width: 8em;
|
89
|
+
margin-right: .75em; }
|
90
|
+
#content form .with_errors label {
|
91
|
+
background: red;
|
92
|
+
color: white;
|
93
|
+
position: relative;
|
94
|
+
top: -.7em; }
|
95
|
+
#content form .with_errors.required label {
|
96
|
+
position: static;
|
97
|
+
margin-right: .25em;
|
98
|
+
padding: 0 .2em; }
|
99
|
+
#content form .with_errors input, #content form .with_errors textarea {
|
100
|
+
border: 2px solid #f22;
|
101
|
+
background: #fee;
|
102
|
+
color: #222222; }
|
103
|
+
#content form .required label {
|
104
|
+
float: none;
|
105
|
+
display: block;
|
106
|
+
width: auto;
|
107
|
+
position: relative;
|
108
|
+
font-weight: bold;
|
109
|
+
margin-top: 1em;
|
110
|
+
text-indent: -.65em; }
|
111
|
+
#content form .required label:before {
|
112
|
+
content: "* ";
|
113
|
+
color: #ed1556; }
|
114
|
+
#content form .required input.text {
|
115
|
+
width: 25.6em;
|
116
|
+
font-size: 24px;
|
117
|
+
font-weight: bold; }
|
118
|
+
#content form .normal {
|
119
|
+
margin-top: 2em; }
|
120
|
+
#content form h2.notifier label {
|
121
|
+
float: none;
|
122
|
+
width: auto;
|
123
|
+
margin-right: 0; }
|
124
|
+
#content form h2.notifier label .warning {
|
125
|
+
font-size: .5em;
|
126
|
+
font-weight: normal;
|
127
|
+
color: #999999; }
|
128
|
+
#content form fieldset {
|
129
|
+
padding-bottom: 1em;
|
130
|
+
margin-left: 1.35em;
|
131
|
+
border-bottom: 1px solid #c0c0c0;
|
132
|
+
margin-bottom: 1em; }
|
133
|
+
#content form fieldset h3 {
|
134
|
+
margin-top: 1em;
|
135
|
+
margin-bottom: 0; }
|
136
|
+
#content form fieldset p.normal {
|
137
|
+
margin-top: 1em; }
|
138
|
+
#content form fieldset p label {
|
139
|
+
width: 6.7em; }
|
140
|
+
#content form p.submit {
|
141
|
+
margin-top: 2em; }
|
142
|
+
#content form p.submit:after {
|
143
|
+
display: block;
|
144
|
+
clear: both;
|
145
|
+
float: none;
|
146
|
+
content: ".";
|
147
|
+
text-indent: -9999em;
|
148
|
+
text-align: left; }
|
149
|
+
#content form p.submit.destroy button, #content form p.submit.manual-build button {
|
150
|
+
float: none;
|
151
|
+
display: inline; }
|
152
|
+
#content form p.submit.manual-build button {
|
153
|
+
margin-right: 0; }
|
154
|
+
#content #build form, #content #last_build form {
|
155
|
+
font-size: .75em; }
|
156
|
+
#content #build form p.submit, #content #last_build form p.submit {
|
157
|
+
margin: 0;
|
158
|
+
padding: 0;
|
159
|
+
position: absolute;
|
160
|
+
right: .5em;
|
161
|
+
top: 1.25em; }
|
162
|
+
#content .blank_slate p, #content .error p {
|
163
|
+
position: relative;
|
164
|
+
top: .3em; }
|
165
|
+
#content .blank_slate h1, #content .error h1 {
|
166
|
+
border-width: 0;
|
167
|
+
margin: 0;
|
168
|
+
padding: 0; }
|
169
|
+
#content .blank_slate h1 button, #content .error h1 button {
|
170
|
+
float: none;
|
171
|
+
border: 0 none;
|
172
|
+
background: transparent;
|
173
|
+
display: inline;
|
174
|
+
color: #ed1556;
|
175
|
+
padding: 0.25em 0;
|
176
|
+
margin: 0; }
|
177
|
+
#content .blank_slate h1 button:hover, #content .error h1 button:hover {
|
178
|
+
background: #ed1556;
|
179
|
+
color: #ffffff; }
|
180
|
+
#content .error dt {
|
181
|
+
margin-top: 1.4em;
|
182
|
+
margin-bottom: .3em;
|
183
|
+
font-size: 1.75em;
|
184
|
+
font-family: Georgia, Times New Roman, serif; }
|
185
|
+
#content .error dd {
|
186
|
+
line-height: 1.4; }
|
187
|
+
#content .error .backtrace {
|
188
|
+
margin: 1em 0;
|
189
|
+
overflow: scroll;
|
190
|
+
height: 30em;
|
191
|
+
border: 1px solid #c0c0c0;
|
192
|
+
line-height: 1.6; }
|
193
|
+
#content #projects {
|
194
|
+
margin: 1em 0 2em;
|
195
|
+
border-top: 1px solid #c0c0c0; }
|
196
|
+
#content #projects li {
|
197
|
+
position: relative;
|
198
|
+
border-bottom: 1px solid #c0c0c0; }
|
199
|
+
#content #projects li.odd {
|
200
|
+
background: #e6e6e6; }
|
201
|
+
#content #projects li.building {
|
202
|
+
background: transparent url(/spinner.gif) no-repeat scroll right; }
|
203
|
+
#content #projects li a {
|
204
|
+
font-size: 2em;
|
205
|
+
padding: .25em;
|
206
|
+
line-height: 1.2;
|
207
|
+
font-weight: bold;
|
208
|
+
display: block; }
|
209
|
+
#content #projects li a.success {
|
210
|
+
color: #337022; }
|
211
|
+
#content #projects li a.failed {
|
212
|
+
color: #ff1100; }
|
213
|
+
#content #projects li .meta {
|
214
|
+
position: absolute;
|
215
|
+
right: .6em;
|
216
|
+
top: 1.5em;
|
217
|
+
font-size: 0.8em;
|
218
|
+
color: #999999;
|
219
|
+
text-align: right; }
|
220
|
+
#content #projects li.building .meta {
|
221
|
+
right: 1.6em; }
|
222
|
+
#content #projects li.success .meta {
|
223
|
+
color: #337022; }
|
224
|
+
#content #projects li.failed .meta {
|
225
|
+
color: #ff1100; }
|
226
|
+
#content #previous_builds li a {
|
227
|
+
display: block;
|
228
|
+
padding: .25em;
|
229
|
+
margin-bottom: .25em;
|
230
|
+
border-width: 1px;
|
231
|
+
border-style: solid; }
|
232
|
+
#content #previous_builds li a strong {
|
233
|
+
font-size: 1.3em; }
|
234
|
+
#content #previous_builds li a .attribution {
|
235
|
+
font-size: .9em; }
|
236
|
+
#content #projects li.success a, #content #previous_builds li.success a {
|
237
|
+
background-color: #bbf8aa;
|
238
|
+
border-color: #99d688;
|
239
|
+
color: #337022; }
|
240
|
+
#content #projects li.success a .attribution, #content #previous_builds li.success a .attribution {
|
241
|
+
color: #77b466; }
|
242
|
+
#content #projects li.success a:hover, #content #previous_builds li.success a:hover {
|
243
|
+
background-color: #ddffcc; }
|
244
|
+
#content #projects li.failed a, #content #previous_builds li.failed a {
|
245
|
+
background-color: #ffbbaa;
|
246
|
+
border-color: #dd9988;
|
247
|
+
color: #ff1100; }
|
248
|
+
#content #projects li.failed a .attribution, #content #previous_builds li.failed a .attribution {
|
249
|
+
color: #bb7766; }
|
250
|
+
#content #projects li.failed a:hover, #content #previous_builds li.failed a:hover {
|
251
|
+
background-color: #ffddcc; }
|
252
|
+
#content #build, #content #last_build {
|
253
|
+
position: relative; }
|
254
|
+
#content #build h1, #content #build blockquote, #content #last_build h1, #content #last_build blockquote {
|
255
|
+
border-width: 0 1px;
|
256
|
+
border-style: solid; }
|
257
|
+
#content #build h1, #content #last_build h1 {
|
258
|
+
border-top-width: 1px; }
|
259
|
+
#content #build blockquote, #content #last_build blockquote {
|
260
|
+
bottom-bottom-width: 1px;
|
261
|
+
line-height: 1.4; }
|
262
|
+
#content #build.success h1, #content #build.success blockquote, #content #last_build.success h1, #content #last_build.success blockquote {
|
263
|
+
background-color: #bbf8aa;
|
264
|
+
border-color: #99d688 #ccffbb #ccffbb #99d688; }
|
265
|
+
#content #build.success h1, #content #last_build.success h1 {
|
266
|
+
color: #337022; }
|
267
|
+
#content #build.success .meta, #content #last_build.success .meta {
|
268
|
+
color: #77b466; }
|
269
|
+
#content #build.failed h1, #content #build.failed blockquote, #content #last_build.failed h1, #content #last_build.failed blockquote {
|
270
|
+
background-color: #ffbbaa;
|
271
|
+
border-color: #dd9988 #ffccbb #ffccbb #dd9988; }
|
272
|
+
#content #build.failed h1, #content #last_build.failed h1 {
|
273
|
+
color: #ff1100; }
|
274
|
+
#content #build.failed .meta, #content #last_build.failed .meta {
|
275
|
+
color: #bb7766; }
|
276
|
+
#content #build h1, #content #last_build h1 {
|
277
|
+
margin-top: .5em;
|
278
|
+
margin-bottom: 0;
|
279
|
+
padding: .25em;
|
280
|
+
color: #337022; }
|
281
|
+
#content #build blockquote, #content #last_build blockquote {
|
282
|
+
padding: .75em;
|
283
|
+
margin-bottom: 2em; }
|
284
|
+
#content #build blockquote .meta, #content #last_build blockquote .meta {
|
285
|
+
margin-top: 1em;
|
286
|
+
display: block;
|
287
|
+
font-size: .9em; }
|
288
|
+
#content #build pre.output, #content #last_build pre.output {
|
289
|
+
background: #111;
|
290
|
+
color: #fff;
|
291
|
+
padding: .5em;
|
292
|
+
overflow: auto;
|
293
|
+
max-height: 50em;
|
294
|
+
font-size: .825em; }
|
295
|
+
#content #build pre.output .color30, #content #last_build pre.output .color30 {
|
296
|
+
color: #333; }
|
297
|
+
#content #build pre.output .color31, #content #last_build pre.output .color31 {
|
298
|
+
color: #e33; }
|
299
|
+
#content #build pre.output .color32, #content #last_build pre.output .color32 {
|
300
|
+
color: #3e3; }
|
301
|
+
#content #build pre.output .color33, #content #last_build pre.output .color33 {
|
302
|
+
color: #ee3; }
|
303
|
+
#content #build pre.output .color34, #content #last_build pre.output .color34 {
|
304
|
+
color: #33e; }
|
305
|
+
#content #build pre.output .color35, #content #last_build pre.output .color35 {
|
306
|
+
color: #e3e; }
|
307
|
+
#content #build pre.output .color36, #content #last_build pre.output .color36 {
|
308
|
+
color: #3ee; }
|
309
|
+
#content #build pre.output .color37, #content #last_build pre.output .color37 {
|
310
|
+
color: #fff; }
|
311
|
+
#content #push_path {
|
312
|
+
display: block;
|
313
|
+
margin-top: 1em;
|
314
|
+
margin-left: 2em; }
|
315
|
+
|
316
|
+
a.success {
|
317
|
+
color: #bbf8aa; }
|
318
|
+
a.success:hover {
|
319
|
+
background-color: #bbf8aa;
|
320
|
+
color: white; }
|
321
|
+
a.failed {
|
322
|
+
color: #ffbbaa; }
|
323
|
+
a.failed:hover {
|
324
|
+
background-color: #ffbbaa;
|
325
|
+
color: white; }
|
326
|
+
|
327
|
+
#footer {
|
328
|
+
padding: 1.5em 2.5em;
|
329
|
+
border-top: 1px solid #ccc;
|
330
|
+
font-size: .8em;
|
331
|
+
color: #666;
|
332
|
+
text-align: right; }
|
333
|
+
#footer strong {
|
334
|
+
font-weight: bold; }
|
335
|
+
|