|
|
|
body {
|
|
|
|
font-family: sans-serif;
|
|
|
|
font-size: small;
|
|
|
|
border: solid #d9d8d1;
|
|
|
|
border-width: 1px;
|
|
|
|
margin: 10px;
|
|
|
|
background-color: #ffffff;
|
|
|
|
color: #000000;
|
|
|
|
}
|
|
|
|
|
|
|
|
a {
|
|
|
|
color: #0000cc;
|
|
|
|
}
|
|
|
|
|
|
|
|
a:hover, a:visited, a:active {
|
|
|
|
color: #880000;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.cntrl {
|
|
|
|
border: dashed #aaaaaa;
|
|
|
|
border-width: 1px;
|
|
|
|
padding: 0px 2px 0px 2px;
|
|
|
|
margin: 0px 2px 0px 2px;
|
|
|
|
}
|
|
|
|
|
|
|
|
img.logo {
|
|
|
|
float: right;
|
|
|
|
border-width: 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
img.avatar {
|
|
|
|
vertical-align: middle;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.list img.avatar {
|
|
|
|
border-style: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_header {
|
|
|
|
height: 25px;
|
|
|
|
padding: 8px;
|
|
|
|
font-size: 150%;
|
|
|
|
font-weight: bold;
|
|
|
|
background-color: #d9d8d1;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_header a:visited, a.header {
|
|
|
|
color: #0000cc;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_header a:hover {
|
|
|
|
color: #880000;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_nav {
|
|
|
|
padding: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_nav a:visited {
|
|
|
|
color: #0000cc;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_path {
|
|
|
|
padding: 8px;
|
|
|
|
font-weight: bold;
|
|
|
|
border: solid #d9d8d1;
|
|
|
|
border-width: 0px 0px 1px;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_footer {
|
|
|
|
height: 17px;
|
|
|
|
padding: 4px 8px;
|
|
|
|
background-color: #d9d8d1;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_footer_text {
|
|
|
|
float: left;
|
|
|
|
color: #555555;
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
div#generating_info {
|
|
|
|
margin: 4px;
|
|
|
|
font-size: smaller;
|
|
|
|
text-align: center;
|
|
|
|
color: #505050;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.page_body {
|
|
|
|
padding: 8px;
|
|
|
|
font-family: monospace;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.title, a.title {
|
|
|
|
display: block;
|
|
|
|
padding: 6px 8px;
|
|
|
|
font-weight: bold;
|
|
|
|
background-color: #edece6;
|
|
|
|
text-decoration: none;
|
|
|
|
color: #000000;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.readme {
|
|
|
|
padding: 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.title:hover {
|
|
|
|
background-color: #d9d8d1;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.title_text {
|
|
|
|
padding: 6px 0px;
|
|
|
|
border: solid #d9d8d1;
|
|
|
|
border-width: 0px 0px 1px;
|
|
|
|
font-family: monospace;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.log_body {
|
|
|
|
padding: 8px 8px 8px 150px;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.age {
|
|
|
|
position: relative;
|
|
|
|
float: left;
|
|
|
|
width: 142px;
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.signoff {
|
|
|
|
color: #888888;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.log_link {
|
|
|
|
padding: 0px 8px;
|
|
|
|
font-size: 70%;
|
|
|
|
font-family: sans-serif;
|
|
|
|
font-style: normal;
|
|
|
|
position: relative;
|
|
|
|
float: left;
|
|
|
|
width: 136px;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.list_head {
|
|
|
|
padding: 6px 8px 4px;
|
|
|
|
border: solid #d9d8d1;
|
|
|
|
border-width: 1px 0px 0px;
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
.author_date, .author {
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.author_date {
|
|
|
|
padding: 8px;
|
|
|
|
border: solid #d9d8d1;
|
|
|
|
border-width: 0px 0px 1px 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.list {
|
|
|
|
text-decoration: none;
|
|
|
|
color: #000000;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.subject, a.name {
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.tags a.subject {
|
|
|
|
font-weight: normal;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.list:hover {
|
|
|
|
text-decoration: underline;
|
|
|
|
color: #880000;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.text {
|
|
|
|
text-decoration: none;
|
|
|
|
color: #0000cc;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.text:visited {
|
|
|
|
text-decoration: none;
|
|
|
|
color: #880000;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.text:hover {
|
|
|
|
text-decoration: underline;
|
|
|
|
color: #880000;
|
|
|
|
}
|
|
|
|
|
|
|
|
table {
|
|
|
|
padding: 8px 4px;
|
|
|
|
border-spacing: 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.diff_tree {
|
|
|
|
font-family: monospace;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.combined.diff_tree th {
|
|
|
|
text-align: center;
|
|
|
|
}
|
|
|
|
|
gitweb: Add combined diff support to git_difftree_body
You have to pass all parents as final parameters of git_difftree_body
subroutine; the number of parents of a diff must be equal to the
number derived from parsing git-diff-tree output, raw combined diff
for git_difftree_body to display combined diff correctly (but it is
not checked).
Currently the possibility of displaying diffree of combined diff is
not used in gitweb code; git_difftree_body is always caled for
ordinary diff, and with only one parent.
Description of output for combined diff:
----------------------------------------
The difftree table for combined diff starts with a cell with pathname
of changed blob (changed file), which if possible is hidden link
(class="list") to the 'blob' view of final version (if it exists),
like for difftree for ordinary diff. If file was deleted in the final
commit then filename is not hyperlinked.
There is no cell with single file status (new, deleted, mode change,
rename), as for combined diff as there is no single status: different
parents might have different status.
If git_difftree_body was called from git_commitdiff (for 'commitdiff'
action) there is inner link to anchor to appropriate fragment (patch)
in patchset body; the "patch" link does not replace "diff" link like
for ordinary diff.
Each of "diff" links is in separate cell, contrary to output for
ordinary diff in which all links are (at least for now) in a single
cell.
For each parent, if file was not present we leave cell empty. If file
was deleted in the result, we provide link to 'blob' view. Otherwise
we provide link to 'commitdiff' view, even if patch (diff) consist
only of extended diff header, and contents is not changed (pure
rename, pure mode change). The only difference is that link to
"blobdiff" view with no contents change is with 'nochange' class.
At last, there is provided link to current version of file as "blob"
link, if the file was not deleted in the result, and lik to history of
a file, if there exists one. (The link to file history might be
confused, at least for now, by renames.)
Note that git-diff-tree raw output dor combined diff does not provide
filename before change for renames and copies; we use
git_get_path_by_hash to get "src" filename for renames (this means
additional call to git-ls-tree for a _whole_ tree).
Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>
18 years ago
|
|
|
table.combined.diff_tree td {
|
|
|
|
padding-right: 24px;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.combined.diff_tree th.link,
|
gitweb: Add combined diff support to git_difftree_body
You have to pass all parents as final parameters of git_difftree_body
subroutine; the number of parents of a diff must be equal to the
number derived from parsing git-diff-tree output, raw combined diff
for git_difftree_body to display combined diff correctly (but it is
not checked).
Currently the possibility of displaying diffree of combined diff is
not used in gitweb code; git_difftree_body is always caled for
ordinary diff, and with only one parent.
Description of output for combined diff:
----------------------------------------
The difftree table for combined diff starts with a cell with pathname
of changed blob (changed file), which if possible is hidden link
(class="list") to the 'blob' view of final version (if it exists),
like for difftree for ordinary diff. If file was deleted in the final
commit then filename is not hyperlinked.
There is no cell with single file status (new, deleted, mode change,
rename), as for combined diff as there is no single status: different
parents might have different status.
If git_difftree_body was called from git_commitdiff (for 'commitdiff'
action) there is inner link to anchor to appropriate fragment (patch)
in patchset body; the "patch" link does not replace "diff" link like
for ordinary diff.
Each of "diff" links is in separate cell, contrary to output for
ordinary diff in which all links are (at least for now) in a single
cell.
For each parent, if file was not present we leave cell empty. If file
was deleted in the result, we provide link to 'blob' view. Otherwise
we provide link to 'commitdiff' view, even if patch (diff) consist
only of extended diff header, and contents is not changed (pure
rename, pure mode change). The only difference is that link to
"blobdiff" view with no contents change is with 'nochange' class.
At last, there is provided link to current version of file as "blob"
link, if the file was not deleted in the result, and lik to history of
a file, if there exists one. (The link to file history might be
confused, at least for now, by renames.)
Note that git-diff-tree raw output dor combined diff does not provide
filename before change for renames and copies; we use
git_get_path_by_hash to get "src" filename for renames (this means
additional call to git-ls-tree for a _whole_ tree).
Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>
18 years ago
|
|
|
table.combined.diff_tree td.link {
|
|
|
|
padding: 0px 2px;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.combined.diff_tree td.nochange a {
|
|
|
|
color: #6666ff;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.combined.diff_tree td.nochange a:hover,
|
|
|
|
table.combined.diff_tree td.nochange a:visited {
|
|
|
|
color: #d06666;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.blame {
|
|
|
|
border-collapse: collapse;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.blame td {
|
|
|
|
padding: 0px 5px;
|
|
|
|
font-size: 100%;
|
|
|
|
vertical-align: top;
|
|
|
|
}
|
|
|
|
|
|
|
|
th {
|
|
|
|
padding: 2px 5px;
|
|
|
|
font-size: 100%;
|
|
|
|
text-align: left;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* do not change row style on hover for 'blame' view */
|
|
|
|
tr.light,
|
|
|
|
table.blame .light:hover {
|
|
|
|
background-color: #ffffff;
|
|
|
|
}
|
|
|
|
|
|
|
|
tr.dark,
|
|
|
|
table.blame .dark:hover {
|
|
|
|
background-color: #f6f6f0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* currently both use the same, but it can change */
|
|
|
|
tr.light:hover,
|
|
|
|
tr.dark:hover {
|
|
|
|
background-color: #edece6;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* boundary commits in 'blame' view */
|
|
|
|
/* and commits without "previous" */
|
|
|
|
tr.boundary td.sha1,
|
|
|
|
tr.no-previous td.linenr {
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* for 'blame_incremental', during processing */
|
|
|
|
tr.color1 { background-color: #f6fff6; }
|
|
|
|
tr.color2 { background-color: #f6f6ff; }
|
|
|
|
tr.color3 { background-color: #fff6f6; }
|
|
|
|
|
|
|
|
td {
|
|
|
|
padding: 2px 5px;
|
|
|
|
font-size: 100%;
|
|
|
|
vertical-align: top;
|
|
|
|
}
|
|
|
|
|
|
|
|
td.link, td.selflink {
|
|
|
|
padding: 2px 5px;
|
|
|
|
font-family: sans-serif;
|
|
|
|
font-size: 70%;
|
|
|
|
}
|
|
|
|
|
|
|
|
td.selflink {
|
|
|
|
padding-right: 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
td.sha1 {
|
|
|
|
font-family: monospace;
|
|
|
|
}
|
|
|
|
|
|
|
|
.error {
|
|
|
|
color: red;
|
|
|
|
background-color: yellow;
|
|
|
|
}
|
|
|
|
|
|
|
|
td.current_head {
|
|
|
|
text-decoration: underline;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.diff_tree span.file_status.new {
|
|
|
|
color: #008000;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.diff_tree span.file_status.deleted {
|
|
|
|
color: #c00000;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.diff_tree span.file_status.moved,
|
|
|
|
table.diff_tree span.file_status.mode_chnge {
|
|
|
|
color: #777777;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.diff_tree span.file_status.copied {
|
|
|
|
color: #70a070;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* noage: "No commits" */
|
|
|
|
table.project_list td.noage {
|
|
|
|
color: #808080;
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* age2: 60*60*24*2 <= age */
|
|
|
|
table.project_list td.age2, table.blame td.age2 {
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* age1: 60*60*2 <= age < 60*60*24*2 */
|
|
|
|
table.project_list td.age1 {
|
|
|
|
color: #009900;
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.blame td.age1 {
|
|
|
|
color: #009900;
|
|
|
|
background: transparent;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* age0: age < 60*60*2 */
|
|
|
|
table.project_list td.age0 {
|
|
|
|
color: #009900;
|
|
|
|
font-style: italic;
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
|
|
|
|
table.blame td.age0 {
|
|
|
|
color: #009900;
|
|
|
|
background: transparent;
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
|
|
|
|
|
|
|
td.pre, div.pre, div.diff {
|
|
|
|
font-family: monospace;
|
|
|
|
font-size: 12px;
|
|
|
|
white-space: pre;
|
|
|
|
}
|
|
|
|
|
|
|
|
td.mode {
|
|
|
|
font-family: monospace;
|
|
|
|
}
|
|
|
|
|
gitweb: Incremental blame (using JavaScript)
Add 'blame_incremental' view, which uses "git blame --incremental"
and JavaScript (Ajax), where 'blame' use "git blame --porcelain".
* gitweb generates initial info by putting file contents (from
"git cat-file") together with line numbers in blame table
* then gitweb makes web browser JavaScript engine call startBlame()
function from gitweb.js
* startBlame() opens XMLHttpRequest connection to 'blame_data' view,
which in turn calls "git blame --incremental" for a file, and
streams output of git-blame to JavaScript (gitweb.js)
* XMLHttpRequest event handler updates line info in blame view as soon
as it gets data from 'blame_data' (from server), and it also updates
progress info
* when 'blame_data' ends, and gitweb.js finishes updating line info,
it fixes colors to match (as far as possible) ordinary 'blame' view,
and updates information about how long it took to generate page.
Gitweb deals with streamed 'blame_data' server errors by displaying
them in the progress info area (just in case).
The 'blame_incremental' view tries to be equivalent to 'blame' action;
there are however a few differences in output between 'blame' and
'blame_incremental' view:
* 'blame_incremental' always used query form for this part of link(s)
which is generated by JavaScript code. The difference is visible
if we use path_info link (pass some or all arguments in path_info).
Changing this would require implementing something akin to href()
subroutine from gitweb.perl in JavaScript (in gitweb.js).
* 'blame_incremental' always uses "rowspan" attribute, even if
rowspan="1". This simplifies code, and is not visible to user.
* The progress bar and progress info are still there even after
JavaScript part of 'blame_incremental' finishes work.
Note that currently no link generated by gitweb leads to this new view.
This code is based on patch by Petr Baudis <pasky@suse.cz> patch, which
in turn was tweaked up version of Fredrik Kuivinen <frekui@gmail.com>'s
proof of concept patch.
This patch adds GITWEB_JS compile configuration option, and modifies
git-instaweb.sh to take gitweb.js into account. The code for
git-instaweb.sh was taken from Pasky's patch.
Signed-off-by: Fredrik Kuivinen <frekui@gmail.com>
Signed-off-by: Petr Baudis <pasky@suse.cz>
Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
16 years ago
|
|
|
/* progress of blame_interactive */
|
|
|
|
div#progress_bar {
|
|
|
|
height: 2px;
|
|
|
|
margin-bottom: -2px;
|
|
|
|
background-color: #d8d9d0;
|
|
|
|
}
|
|
|
|
div#progress_info {
|
|
|
|
float: right;
|
|
|
|
text-align: right;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* format of (optional) objects size in 'tree' view */
|
|
|
|
td.size {
|
|
|
|
font-family: monospace;
|
|
|
|
text-align: right;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* styling of diffs (patchsets): commitdiff and blobdiff views */
|
|
|
|
div.diff.header,
|
|
|
|
div.diff.extended_header {
|
|
|
|
white-space: normal;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.header {
|
|
|
|
font-weight: bold;
|
|
|
|
|
|
|
|
background-color: #edece6;
|
|
|
|
|
|
|
|
margin-top: 4px;
|
|
|
|
padding: 4px 0px 2px 0px;
|
|
|
|
border: solid #d9d8d1;
|
|
|
|
border-width: 1px 0px 1px 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.header a.path {
|
|
|
|
text-decoration: underline;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.extended_header,
|
|
|
|
div.diff.extended_header a.path,
|
|
|
|
div.diff.extended_header a.hash {
|
|
|
|
color: #777777;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.extended_header .info {
|
|
|
|
color: #b0b0b0;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.extended_header {
|
|
|
|
background-color: #f6f5ee;
|
|
|
|
padding: 2px 0px 2px 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff a.list,
|
|
|
|
div.diff a.path,
|
|
|
|
div.diff a.hash {
|
|
|
|
text-decoration: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff a.list:hover,
|
|
|
|
div.diff a.path:hover,
|
|
|
|
div.diff a.hash:hover {
|
|
|
|
text-decoration: underline;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.to_file a.path,
|
|
|
|
div.diff.to_file {
|
|
|
|
color: #007000;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.add {
|
|
|
|
color: #008800;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.from_file a.path,
|
|
|
|
div.diff.from_file {
|
|
|
|
color: #aa0000;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.rem {
|
|
|
|
color: #cc0000;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.chunk_header a,
|
|
|
|
div.diff.chunk_header {
|
|
|
|
color: #990099;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.chunk_header {
|
|
|
|
border: dotted #ffe0ff;
|
|
|
|
border-width: 1px 0px 0px 0px;
|
|
|
|
margin-top: 2px;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.chunk_header span.chunk_info {
|
|
|
|
background-color: #ffeeff;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.chunk_header span.section {
|
|
|
|
color: #aa22aa;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.incomplete {
|
|
|
|
color: #cccccc;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.diff.nodifferences {
|
|
|
|
font-weight: bold;
|
|
|
|
color: #600000;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.index_include {
|
|
|
|
border: solid #d9d8d1;
|
|
|
|
border-width: 0px 0px 1px;
|
|
|
|
padding: 12px 8px;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.search {
|
|
|
|
font-size: 100%;
|
|
|
|
font-weight: normal;
|
|
|
|
margin: 4px 8px;
|
|
|
|
float: right;
|
|
|
|
top: 56px;
|
|
|
|
right: 12px
|
|
|
|
}
|
|
|
|
|
|
|
|
p.projsearch {
|
|
|
|
text-align: center;
|
|
|
|
}
|
|
|
|
|
|
|
|
td.linenr {
|
|
|
|
text-align: right;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.linenr {
|
|
|
|
color: #999999;
|
|
|
|
text-decoration: none
|
|
|
|
}
|
|
|
|
|
|
|
|
a.rss_logo {
|
|
|
|
float: right;
|
|
|
|
padding: 3px 0px;
|
|
|
|
width: 35px;
|
|
|
|
line-height: 10px;
|
|
|
|
border: 1px solid;
|
|
|
|
border-color: #fcc7a5 #7d3302 #3e1a01 #ff954e;
|
|
|
|
color: #ffffff;
|
|
|
|
background-color: #ff6600;
|
|
|
|
font-weight: bold;
|
|
|
|
font-family: sans-serif;
|
|
|
|
font-size: 70%;
|
|
|
|
text-align: center;
|
|
|
|
text-decoration: none;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.rss_logo:hover {
|
|
|
|
background-color: #ee5500;
|
|
|
|
}
|
|
|
|
|
gitweb: Use feed link according to current view
Michael G. Noll said in comments to the "Switching my code repository from
Subversion (SVN) to git" article (http://tinyurl.com/37v67l) in his "My
digital moleskine" blog, that one of the things he is missing in gitweb
from SVN::Web is an RSS feed with news/information of the current view
(including RSS feed for single file or directory).
This is not exactly true, as since refactoring feed generation in af6feeb
(gitweb: Refactor feed generation, make output prettier, add Atom feed,
2006-11-19), gitweb can generate feeds (RSS or Atom) for history of a
given branch, history limited to a given directory, or history of a given
file. Nevertheless this required handcrafting the URL to get wanted RSS
feed.
This commit makes gitweb select feed links in the HTML header and in
page footer depending on current view (action). It is more elaborate,
and I guess more correct, than simple patch adding $hash ('h')
parameter to *all* URLs, including feed links, by Jean-Baptiste Quenot
Subject: [PATCH] gitweb: Add hash parameter in feed URL when a hash
is specified in the current request
Message-ID: <ae63f8b50803211138y6355fd11pa64cda50a1f53011@mail.gmail.com>
If $hash ('h') or $hash_base ('hb') parameter is a branch name
(i.e. it starts with 'refs/heads/'; all generated URLs use this form
to discriminate between tags and heads), it is used in feed URLs; if
$file_name ('f') is defined, it is used in feed URLs. Feed title is
set according to the kind of web feed: it is either 'log' for generic
feed, 'log of <branch>', 'history of <filename>' for generic history
(using implicit or explicit HEAD, i.e. current branch) or 'history of
<filename> on <branch>'.
There are special cases: 'heads' and 'forks' views should use OPML
providing list of available feeds; 'tags' probably also should use
OPML; there is no web feed equivalent to 'search' view. Currently all
those cases fallback to (show) default feed. Such feed link uses
"generic" class, and is shown in slightly lighter color for
distinction.
Currently feed can have but one starting point, and does not support
negative (exclude) commit arguments. Therefore for now for *diff
views it is chosen that feed follow the "to" part: to-name, to-commit
for 'blobdiff', 'treediff' and 'commitdiff' views.
Generating parameters for href() for feed link was separated
(refactored) into get_feed_info() subroutine.
Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
17 years ago
|
|
|
a.rss_logo.generic {
|
|
|
|
background-color: #ff8800;
|
|
|
|
}
|
|
|
|
|
|
|
|
a.rss_logo.generic:hover {
|
|
|
|
background-color: #ee7700;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.refs span {
|
|
|
|
padding: 0px 4px;
|
|
|
|
font-size: 70%;
|
|
|
|
font-weight: normal;
|
|
|
|
border: 1px solid;
|
|
|
|
background-color: #ffaaff;
|
|
|
|
border-color: #ffccff #ff00ee #ff00ee #ffccff;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.refs span a {
|
|
|
|
text-decoration: none;
|
|
|
|
color: inherit;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.refs span a:hover {
|
|
|
|
text-decoration: underline;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.refs span.indirect {
|
|
|
|
font-style: italic;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.refs span.ref {
|
|
|
|
background-color: #aaaaff;
|
|
|
|
border-color: #ccccff #0033cc #0033cc #ccccff;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.refs span.tag {
|
|
|
|
background-color: #ffffaa;
|
|
|
|
border-color: #ffffcc #ffee00 #ffee00 #ffffcc;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.refs span.head {
|
|
|
|
background-color: #aaffaa;
|
|
|
|
border-color: #ccffcc #00cc33 #00cc33 #ccffcc;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.atnight {
|
|
|
|
color: #cc0000;
|
|
|
|
}
|
|
|
|
|
|
|
|
span.match {
|
|
|
|
color: #e00000;
|
|
|
|
}
|
|
|
|
|
|
|
|
div.binary {
|
|
|
|
font-style: italic;
|
|
|
|
}
|