diff options
| -rw-r--r-- | Makefile | 2 | ||||
| -rw-r--r-- | cgit.c | 3 | ||||
| -rw-r--r-- | cgit.css | 6 | ||||
| -rw-r--r-- | cgit.h | 1 | ||||
| -rw-r--r-- | cgitrc.5.txt | 4 | ||||
| m--------- | git | 0 | ||||
| -rw-r--r-- | ui-commit.c | 2 | ||||
| -rw-r--r-- | ui-log.c | 2 | ||||
| -rw-r--r-- | ui-plain.c | 3 | ||||
| -rw-r--r-- | ui-tree.c | 35 |
10 files changed, 37 insertions, 21 deletions
| @@ -5,7 +5,7 @@ CGIT_DATA_PATH = $(CGIT_SCRIPT_PATH) | |||
| 5 | CGIT_CONFIG = /etc/cgitrc | 5 | CGIT_CONFIG = /etc/cgitrc |
| 6 | CACHE_ROOT = /var/cache/cgit | 6 | CACHE_ROOT = /var/cache/cgit |
| 7 | SHA1_HEADER = <openssl/sha.h> | 7 | SHA1_HEADER = <openssl/sha.h> |
| 8 | GIT_VER = 1.6.3.4 | 8 | GIT_VER = 1.6.4.3 |
| 9 | GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2 | 9 | GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2 |
| 10 | INSTALL = install | 10 | INSTALL = install |
| 11 | 11 | ||
| @@ -137,6 +137,8 @@ void config_cb(const char *name, const char *value) | |||
| 137 | ctx.cfg.enable_log_filecount = atoi(value); | 137 | ctx.cfg.enable_log_filecount = atoi(value); |
| 138 | else if (!strcmp(name, "enable-log-linecount")) | 138 | else if (!strcmp(name, "enable-log-linecount")) |
| 139 | ctx.cfg.enable_log_linecount = atoi(value); | 139 | ctx.cfg.enable_log_linecount = atoi(value); |
| 140 | else if (!strcmp(name, "enable-tree-linenumbers")) | ||
| 141 | ctx.cfg.enable_tree_linenumbers = atoi(value); | ||
| 140 | else if (!strcmp(name, "max-stats")) | 142 | else if (!strcmp(name, "max-stats")) |
| 141 | ctx.cfg.max_stats = cgit_find_stats_period(value, NULL); | 143 | ctx.cfg.max_stats = cgit_find_stats_period(value, NULL); |
| 142 | else if (!strcmp(name, "cache-size")) | 144 | else if (!strcmp(name, "cache-size")) |
| @@ -260,6 +262,7 @@ static void prepare_context(struct cgit_context *ctx) | |||
| 260 | ctx->cfg.css = "/cgit.css"; | 262 | ctx->cfg.css = "/cgit.css"; |
| 261 | ctx->cfg.logo = "/cgit.png"; | 263 | ctx->cfg.logo = "/cgit.png"; |
| 262 | ctx->cfg.local_time = 0; | 264 | ctx->cfg.local_time = 0; |
| 265 | ctx->cfg.enable_tree_linenumbers = 1; | ||
| 263 | ctx->cfg.max_repo_count = 50; | 266 | ctx->cfg.max_repo_count = 50; |
| 264 | ctx->cfg.max_commit_count = 50; | 267 | ctx->cfg.max_commit_count = 50; |
| 265 | ctx->cfg.max_lock_attempts = 5; | 268 | ctx->cfg.max_lock_attempts = 5; |
| @@ -237,16 +237,16 @@ table.blob { | |||
| 237 | } | 237 | } |
| 238 | 238 | ||
| 239 | table.blob td.lines { | 239 | table.blob td.lines { |
| 240 | margin: 0; padding: 0; | 240 | margin: 0; padding: 0 0 0 0.5em; |
| 241 | vertical-align: top; | 241 | vertical-align: top; |
| 242 | color: black; | 242 | color: black; |
| 243 | } | 243 | } |
| 244 | 244 | ||
| 245 | table.blob td.linenumbers { | 245 | table.blob td.linenumbers { |
| 246 | margin: 0; padding: 0; | 246 | margin: 0; padding: 0 0.5em 0 0.5em; |
| 247 | vertical-align: top; | 247 | vertical-align: top; |
| 248 | text-align: right; | ||
| 248 | border-right: 1px solid gray; | 249 | border-right: 1px solid gray; |
| 249 | background-color: #eee; | ||
| 250 | } | 250 | } |
| 251 | 251 | ||
| 252 | table.blob pre { | 252 | table.blob pre { |
| @@ -178,6 +178,7 @@ struct cgit_config { | |||
| 178 | int enable_index_links; | 178 | int enable_index_links; |
| 179 | int enable_log_filecount; | 179 | int enable_log_filecount; |
| 180 | int enable_log_linecount; | 180 | int enable_log_linecount; |
| 181 | int enable_tree_linenumbers; | ||
| 181 | int local_time; | 182 | int local_time; |
| 182 | int max_repo_count; | 183 | int max_repo_count; |
| 183 | int max_commit_count; | 184 | int max_commit_count; |
diff --git a/cgitrc.5.txt b/cgitrc.5.txt index 617b7c3..4dc383d 100644 --- a/cgitrc.5.txt +++ b/cgitrc.5.txt | |||
| @@ -107,6 +107,10 @@ enable-log-linecount:: | |||
| 107 | and removed lines for each commit on the repository log page. Default | 107 | and removed lines for each commit on the repository log page. Default |
| 108 | value: "0". | 108 | value: "0". |
| 109 | 109 | ||
| 110 | enable-tree-linenumbers:: | ||
| 111 | Flag which, when set to "1", will make cgit generate linenumber links | ||
| 112 | for plaintext blobs printed in the tree view. Default value: "1". | ||
| 113 | |||
| 110 | favicon:: | 114 | favicon:: |
| 111 | Url used as link to a shortcut icon for cgit. If specified, it is | 115 | Url used as link to a shortcut icon for cgit. If specified, it is |
| 112 | suggested to use the value "/favicon.ico" since certain browsers will | 116 | suggested to use the value "/favicon.ico" since certain browsers will |
diff --git a/git b/git | |||
| Subproject e276f018f2c1f0fc962fbe44a36708d1cdebada | Subproject 7fb6bcff2dece2ff9fbc5ebfe526d9b2a7e764c | ||
diff --git a/ui-commit.c b/ui-commit.c index d6b73ee..f5b0ae5 100644 --- a/ui-commit.c +++ b/ui-commit.c | |||
| @@ -35,7 +35,7 @@ void cgit_print_commit(char *hex) | |||
| 35 | } | 35 | } |
| 36 | info = cgit_parse_commit(commit); | 36 | info = cgit_parse_commit(commit); |
| 37 | 37 | ||
| 38 | load_ref_decorations(); | 38 | load_ref_decorations(DECORATE_FULL_REFS); |
| 39 | 39 | ||
| 40 | html("<table summary='commit info' class='commit-info'>\n"); | 40 | html("<table summary='commit info' class='commit-info'>\n"); |
| 41 | html("<tr><th>author</th><td>"); | 41 | html("<tr><th>author</th><td>"); |
| @@ -161,7 +161,7 @@ void cgit_print_log(const char *tip, int ofs, int cnt, char *grep, char *pattern | |||
| 161 | rev.verbose_header = 1; | 161 | rev.verbose_header = 1; |
| 162 | rev.show_root_diff = 0; | 162 | rev.show_root_diff = 0; |
| 163 | setup_revisions(argc, argv, &rev, NULL); | 163 | setup_revisions(argc, argv, &rev, NULL); |
| 164 | load_ref_decorations(); | 164 | load_ref_decorations(DECORATE_FULL_REFS); |
| 165 | rev.show_decorations = 1; | 165 | rev.show_decorations = 1; |
| 166 | rev.grep_filter.regflags |= REG_ICASE; | 166 | rev.grep_filter.regflags |= REG_ICASE; |
| 167 | compile_grep_patterns(&rev.grep_filter); | 167 | compile_grep_patterns(&rev.grep_filter); |
| @@ -60,7 +60,8 @@ static int walk_tree(const unsigned char *sha1, const char *base, int baselen, | |||
| 60 | if (S_ISDIR(mode)) | 60 | if (S_ISDIR(mode)) |
| 61 | return READ_TREE_RECURSIVE; | 61 | return READ_TREE_RECURSIVE; |
| 62 | 62 | ||
| 63 | if (S_ISREG(mode)) | 63 | if (S_ISREG(mode) && !strncmp(base, match_path, baselen) && |
| 64 | !strcmp(pathname, match_path + baselen)) | ||
| 64 | print_object(sha1, pathname); | 65 | print_object(sha1, pathname); |
| 65 | 66 | ||
| 66 | return 0; | 67 | return 0; |
| @@ -22,8 +22,28 @@ static void print_text_buffer(const char *name, char *buf, unsigned long size) | |||
| 22 | "<a class='no' id='n%1$d' name='n%1$d' href='#n%1$d'>%1$d</a>\n"; | 22 | "<a class='no' id='n%1$d' name='n%1$d' href='#n%1$d'>%1$d</a>\n"; |
| 23 | 23 | ||
| 24 | html("<table summary='blob content' class='blob'>\n"); | 24 | html("<table summary='blob content' class='blob'>\n"); |
| 25 | |||
| 26 | if (ctx.cfg.enable_tree_linenumbers) { | ||
| 27 | html("<tr><td class='linenumbers'><pre>"); | ||
| 28 | idx = 0; | ||
| 29 | lineno = 0; | ||
| 30 | |||
| 31 | if (size) { | ||
| 32 | htmlf(numberfmt, ++lineno); | ||
| 33 | while(idx < size - 1) { // skip absolute last newline | ||
| 34 | if (buf[idx] == '\n') | ||
| 35 | htmlf(numberfmt, ++lineno); | ||
| 36 | idx++; | ||
| 37 | } | ||
| 38 | } | ||
| 39 | html("</pre></td>\n"); | ||
| 40 | } | ||
| 41 | else { | ||
| 42 | html("<tr>\n"); | ||
| 43 | } | ||
| 44 | |||
| 25 | if (ctx.repo->source_filter) { | 45 | if (ctx.repo->source_filter) { |
| 26 | html("<tr><td class='lines'><pre><code>"); | 46 | html("<td class='lines'><pre><code>"); |
| 27 | ctx.repo->source_filter->argv[1] = xstrdup(name); | 47 | ctx.repo->source_filter->argv[1] = xstrdup(name); |
| 28 | cgit_open_filter(ctx.repo->source_filter); | 48 | cgit_open_filter(ctx.repo->source_filter); |
| 29 | write(STDOUT_FILENO, buf, size); | 49 | write(STDOUT_FILENO, buf, size); |
| @@ -32,19 +52,6 @@ static void print_text_buffer(const char *name, char *buf, unsigned long size) | |||
| 32 | return; | 52 | return; |
| 33 | } | 53 | } |
| 34 | 54 | ||
| 35 | html("<tr><td class='linenumbers'><pre>"); | ||
| 36 | idx = 0; | ||
| 37 | lineno = 0; | ||
| 38 | |||
| 39 | if (size) { | ||
| 40 | htmlf(numberfmt, ++lineno); | ||
| 41 | while(idx < size - 1) { // skip absolute last newline | ||
| 42 | if (buf[idx] == '\n') | ||
| 43 | htmlf(numberfmt, ++lineno); | ||
| 44 | idx++; | ||
| 45 | } | ||
| 46 | } | ||
| 47 | html("</pre></td>\n"); | ||
| 48 | html("<td class='lines'><pre><code>"); | 55 | html("<td class='lines'><pre><code>"); |
| 49 | html_txt(buf); | 56 | html_txt(buf); |
| 50 | html("</code></pre></td></tr></table>\n"); | 57 | html("</code></pre></td></tr></table>\n"); |
