diff options
| -rw-r--r-- | Makefile | 11 | ||||
| -rw-r--r-- | cache.c | 2 | ||||
| -rw-r--r-- | cgit.h | 1 | ||||
| -rw-r--r-- | cgitrc | 2 | ||||
| -rw-r--r-- | cmd.c | 7 | ||||
| m--------- | git | 0 | ||||
| -rw-r--r-- | ui-atom.c | 129 | ||||
| -rw-r--r-- | ui-atom.h | 6 | ||||
| -rw-r--r-- | ui-shared.c | 23 | ||||
| -rw-r--r-- | ui-shared.h | 1 |
10 files changed, 175 insertions, 7 deletions
| @@ -4,7 +4,7 @@ CGIT_SCRIPT_PATH = /var/www/htdocs/cgit | |||
| 4 | CGIT_CONFIG = /etc/cgitrc | 4 | CGIT_CONFIG = /etc/cgitrc |
| 5 | CACHE_ROOT = /var/cache/cgit | 5 | CACHE_ROOT = /var/cache/cgit |
| 6 | SHA1_HEADER = <openssl/sha.h> | 6 | SHA1_HEADER = <openssl/sha.h> |
| 7 | GIT_VER = 1.5.6 | 7 | GIT_VER = 1.6.0.rc1 |
| 8 | GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2 | 8 | GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2 |
| 9 | 9 | ||
| 10 | # | 10 | # |
| @@ -55,6 +55,7 @@ OBJECTS += configfile.o | |||
| 55 | OBJECTS += html.o | 55 | OBJECTS += html.o |
| 56 | OBJECTS += parsing.o | 56 | OBJECTS += parsing.o |
| 57 | OBJECTS += shared.o | 57 | OBJECTS += shared.o |
| 58 | OBJECTS += ui-atom.o | ||
| 58 | OBJECTS += ui-blob.o | 59 | OBJECTS += ui-blob.o |
| 59 | OBJECTS += ui-clone.o | 60 | OBJECTS += ui-clone.o |
| 60 | OBJECTS += ui-commit.o | 61 | OBJECTS += ui-commit.o |
| @@ -75,7 +76,7 @@ ifdef NEEDS_LIBICONV | |||
| 75 | endif | 76 | endif |
| 76 | 77 | ||
| 77 | 78 | ||
| 78 | .PHONY: all git test install uninstall clean force-version get-git | 79 | .PHONY: all libgit test install uninstall clean force-version get-git |
| 79 | 80 | ||
| 80 | all: cgit | 81 | all: cgit |
| 81 | 82 | ||
| @@ -92,17 +93,15 @@ CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' | |||
| 92 | CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"' | 93 | CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"' |
| 93 | 94 | ||
| 94 | 95 | ||
| 95 | cgit: $(OBJECTS) git/libgit.a git/xdiff/lib.a | 96 | cgit: $(OBJECTS) libgit |
| 96 | $(QUIET_CC)$(CC) $(CFLAGS) -o cgit $(OBJECTS) $(EXTLIBS) | 97 | $(QUIET_CC)$(CC) $(CFLAGS) -o cgit $(OBJECTS) $(EXTLIBS) |
| 97 | 98 | ||
| 98 | cgit.o: VERSION | 99 | cgit.o: VERSION |
| 99 | 100 | ||
| 100 | -include $(OBJECTS:.o=.d) | 101 | -include $(OBJECTS:.o=.d) |
| 101 | 102 | ||
| 102 | git/libgit.a: git | 103 | libgit: |
| 103 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) libgit.a | 104 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) libgit.a |
| 104 | |||
| 105 | git/xdiff/lib.a: git | ||
| 106 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) xdiff/lib.a | 105 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) xdiff/lib.a |
| 107 | 106 | ||
| 108 | test: all | 107 | test: all |
| @@ -416,7 +416,7 @@ int cache_ls(const char *path) | |||
| 416 | fullname, strerror(err), err); | 416 | fullname, strerror(err), err); |
| 417 | continue; | 417 | continue; |
| 418 | } | 418 | } |
| 419 | printf("%s %s %10lld %s\n", | 419 | printf("%s %s %10zd %s\n", |
| 420 | name, | 420 | name, |
| 421 | sprintftime("%Y-%m-%d %H:%M:%S", | 421 | sprintftime("%Y-%m-%d %H:%M:%S", |
| 422 | slot.cache_st.st_mtime), | 422 | slot.cache_st.st_mtime), |
| @@ -24,6 +24,7 @@ | |||
| 24 | */ | 24 | */ |
| 25 | #define FMT_LONGDATE "%Y-%m-%d %H:%M:%S (%Z)" | 25 | #define FMT_LONGDATE "%Y-%m-%d %H:%M:%S (%Z)" |
| 26 | #define FMT_SHORTDATE "%Y-%m-%d" | 26 | #define FMT_SHORTDATE "%Y-%m-%d" |
| 27 | #define FMT_ATOMDATE "%Y-%m-%dT%H:%M:%SZ" | ||
| 27 | 28 | ||
| 28 | 29 | ||
| 29 | /* | 30 | /* |
| @@ -44,6 +44,8 @@ | |||
| 44 | ## print all tags. | 44 | ## print all tags. |
| 45 | #summary-tags=0 | 45 | #summary-tags=0 |
| 46 | 46 | ||
| 47 | ## Enable/disable display of localtime vs. GMT. Set to 1 for localtime. | ||
| 48 | #local-time=0 | ||
| 47 | 49 | ||
| 48 | ## The "Idle" column on the repository index page can read a timestamp | 50 | ## The "Idle" column on the repository index page can read a timestamp |
| 49 | ## from the specified agefile (if this file cannot be found, the mtime | 51 | ## from the specified agefile (if this file cannot be found, the mtime |
| @@ -10,6 +10,7 @@ | |||
| 10 | #include "cmd.h" | 10 | #include "cmd.h" |
| 11 | #include "cache.h" | 11 | #include "cache.h" |
| 12 | #include "ui-shared.h" | 12 | #include "ui-shared.h" |
| 13 | #include "ui-atom.h" | ||
| 13 | #include "ui-blob.h" | 14 | #include "ui-blob.h" |
| 14 | #include "ui-clone.h" | 15 | #include "ui-clone.h" |
| 15 | #include "ui-commit.h" | 16 | #include "ui-commit.h" |
| @@ -29,6 +30,11 @@ static void HEAD_fn(struct cgit_context *ctx) | |||
| 29 | cgit_clone_head(ctx); | 30 | cgit_clone_head(ctx); |
| 30 | } | 31 | } |
| 31 | 32 | ||
| 33 | static void atom_fn(struct cgit_context *ctx) | ||
| 34 | { | ||
| 35 | cgit_print_atom(ctx->qry.head, ctx->qry.path, 10); | ||
| 36 | } | ||
| 37 | |||
| 32 | static void about_fn(struct cgit_context *ctx) | 38 | static void about_fn(struct cgit_context *ctx) |
| 33 | { | 39 | { |
| 34 | if (ctx->repo) | 40 | if (ctx->repo) |
| @@ -125,6 +131,7 @@ struct cgit_cmd *cgit_get_cmd(struct cgit_context *ctx) | |||
| 125 | { | 131 | { |
| 126 | static struct cgit_cmd cmds[] = { | 132 | static struct cgit_cmd cmds[] = { |
| 127 | def_cmd(HEAD, 1, 0), | 133 | def_cmd(HEAD, 1, 0), |
| 134 | def_cmd(atom, 1, 0), | ||
| 128 | def_cmd(about, 0, 1), | 135 | def_cmd(about, 0, 1), |
| 129 | def_cmd(blob, 1, 0), | 136 | def_cmd(blob, 1, 0), |
| 130 | def_cmd(commit, 1, 1), | 137 | def_cmd(commit, 1, 1), |
diff --git a/git b/git | |||
| Subproject 93310a40eb022a0e36e7c618921931d8ffc31fd | Subproject 8e1db3871c767cb17b5e0eeb7bea8d967821a05 | ||
diff --git a/ui-atom.c b/ui-atom.c new file mode 100644 index 0000000..a6ea3ee --- /dev/null +++ b/ui-atom.c | |||
| @@ -0,0 +1,129 @@ | |||
| 1 | /* ui-atom.c: functions for atom feeds | ||
| 2 | * | ||
| 3 | * Copyright (C) 2008 Lars Hjemli | ||
| 4 | * | ||
| 5 | * Licensed under GNU General Public License v2 | ||
| 6 | * (see COPYING for full license text) | ||
| 7 | */ | ||
| 8 | |||
| 9 | #include "cgit.h" | ||
| 10 | #include "html.h" | ||
| 11 | #include "ui-shared.h" | ||
| 12 | |||
| 13 | void add_entry(struct commit *commit, char *host) | ||
| 14 | { | ||
| 15 | char delim = '&'; | ||
| 16 | char *hex; | ||
| 17 | char *mail, *t, *t2; | ||
| 18 | struct commitinfo *info; | ||
| 19 | |||
| 20 | info = cgit_parse_commit(commit); | ||
| 21 | hex = sha1_to_hex(commit->object.sha1); | ||
| 22 | html("<entry>\n"); | ||
| 23 | html("<title>"); | ||
| 24 | html_txt(info->subject); | ||
| 25 | html("</title>\n"); | ||
| 26 | html("<updated>"); | ||
| 27 | cgit_print_date(info->author_date, FMT_ATOMDATE, ctx.cfg.local_time); | ||
| 28 | html("</updated>\n"); | ||
| 29 | html("<author>\n"); | ||
| 30 | if (info->author) { | ||
| 31 | html("<name>"); | ||
| 32 | html_txt(info->author); | ||
| 33 | html("</name>\n"); | ||
| 34 | } | ||
| 35 | if (info->author_email) { | ||
| 36 | mail = xstrdup(info->author_email); | ||
| 37 | t = strchr(mail, '<'); | ||
| 38 | if (t) | ||
| 39 | t++; | ||
| 40 | else | ||
| 41 | t = mail; | ||
| 42 | t2 = strchr(t, '>'); | ||
| 43 | if (t2) | ||
| 44 | *t2 = '\0'; | ||
| 45 | html("<email>"); | ||
| 46 | html_txt(t); | ||
| 47 | html("</email>\n"); | ||
| 48 | free(mail); | ||
| 49 | } | ||
| 50 | html("</author>\n"); | ||
| 51 | html("<published>"); | ||
| 52 | cgit_print_date(info->author_date, FMT_ATOMDATE, ctx.cfg.local_time); | ||
| 53 | html("</published>\n"); | ||
| 54 | if (host) { | ||
| 55 | html("<link rel='alternate' type='text/html' href='http://"); | ||
| 56 | html_attr(host); | ||
| 57 | html_attr(cgit_pageurl(ctx.repo->url, "commit", NULL)); | ||
| 58 | if (ctx.cfg.virtual_root) | ||
| 59 | delim = '?'; | ||
| 60 | htmlf("%cid=%s", delim, hex); | ||
| 61 | html("'/>\n"); | ||
| 62 | } | ||
| 63 | htmlf("<id>%s</id>\n", hex); | ||
| 64 | html("<content type='text'>\n"); | ||
| 65 | html_txt(info->msg); | ||
| 66 | html("</content>\n"); | ||
| 67 | html("<content type='xhtml'>\n"); | ||
| 68 | html("<div xmlns='http://www.w3.org/1999/xhtml'>\n"); | ||
| 69 | html("<pre>\n"); | ||
| 70 | html_txt(info->msg); | ||
| 71 | html("</pre>\n"); | ||
| 72 | html("</div>\n"); | ||
| 73 | html("</content>\n"); | ||
| 74 | html("</entry>\n"); | ||
| 75 | cgit_free_commitinfo(info); | ||
| 76 | } | ||
| 77 | |||
| 78 | |||
| 79 | void cgit_print_atom(char *tip, char *path, int max_count) | ||
| 80 | { | ||
| 81 | char *host; | ||
| 82 | const char *argv[] = {NULL, tip, NULL, NULL, NULL}; | ||
| 83 | struct commit *commit; | ||
| 84 | struct rev_info rev; | ||
| 85 | int argc = 2; | ||
| 86 | |||
| 87 | if (!tip) | ||
| 88 | argv[1] = ctx.qry.head; | ||
| 89 | |||
| 90 | if (path) { | ||
| 91 | argv[argc++] = "--"; | ||
| 92 | argv[argc++] = path; | ||
| 93 | } | ||
| 94 | |||
| 95 | init_revisions(&rev, NULL); | ||
| 96 | rev.abbrev = DEFAULT_ABBREV; | ||
| 97 | rev.commit_format = CMIT_FMT_DEFAULT; | ||
| 98 | rev.verbose_header = 1; | ||
| 99 | rev.show_root_diff = 0; | ||
| 100 | rev.max_count = max_count; | ||
| 101 | setup_revisions(argc, argv, &rev, NULL); | ||
| 102 | prepare_revision_walk(&rev); | ||
| 103 | |||
| 104 | host = cgit_hosturl(); | ||
| 105 | ctx.page.mimetype = "text/xml"; | ||
| 106 | ctx.page.charset = "utf-8"; | ||
| 107 | cgit_print_http_headers(&ctx); | ||
| 108 | html("<feed xmlns='http://www.w3.org/2005/Atom'>\n"); | ||
| 109 | html("<title>"); | ||
| 110 | html_txt(ctx.repo->name); | ||
| 111 | html("</title>\n"); | ||
| 112 | html("<subtitle>"); | ||
| 113 | html_txt(ctx.repo->desc); | ||
| 114 | html("</subtitle>\n"); | ||
| 115 | if (host) { | ||
| 116 | html("<link rel='alternate' type='text/html' href='http://"); | ||
| 117 | html_attr(host); | ||
| 118 | html_attr(cgit_repourl(ctx.repo->url)); | ||
| 119 | html("'/>\n"); | ||
| 120 | } | ||
| 121 | while ((commit = get_revision(&rev)) != NULL) { | ||
| 122 | add_entry(commit, host); | ||
| 123 | free(commit->buffer); | ||
| 124 | commit->buffer = NULL; | ||
| 125 | free_commit_list(commit->parents); | ||
| 126 | commit->parents = NULL; | ||
| 127 | } | ||
| 128 | html("</feed>\n"); | ||
| 129 | } | ||
diff --git a/ui-atom.h b/ui-atom.h new file mode 100644 index 0000000..749ffd3 --- /dev/null +++ b/ui-atom.h | |||
| @@ -0,0 +1,6 @@ | |||
| 1 | #ifndef UI_ATOM_H | ||
| 2 | #define UI_ATOM_H | ||
| 3 | |||
| 4 | extern void cgit_print_atom(char *tip, char *path, int max_count); | ||
| 5 | |||
| 6 | #endif | ||
diff --git a/ui-shared.c b/ui-shared.c index a2e0dd2..4818e70 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
| @@ -34,6 +34,21 @@ void cgit_print_error(char *msg) | |||
| 34 | html("</div>\n"); | 34 | html("</div>\n"); |
| 35 | } | 35 | } |
| 36 | 36 | ||
| 37 | char *cgit_hosturl() | ||
| 38 | { | ||
| 39 | char *host, *port; | ||
| 40 | |||
| 41 | host = getenv("SERVER_NAME"); | ||
| 42 | if (!host) | ||
| 43 | return NULL; | ||
| 44 | port = getenv("SERVER_PORT"); | ||
| 45 | if (port && atoi(port) != 80) | ||
| 46 | host = xstrdup(fmt("%s:%d", host, atoi(port))); | ||
| 47 | else | ||
| 48 | host = xstrdup(host); | ||
| 49 | return host; | ||
| 50 | } | ||
| 51 | |||
| 37 | char *cgit_rooturl() | 52 | char *cgit_rooturl() |
| 38 | { | 53 | { |
| 39 | if (ctx.cfg.virtual_root) | 54 | if (ctx.cfg.virtual_root) |
| @@ -436,6 +451,7 @@ void cgit_print_http_headers(struct cgit_context *ctx) | |||
| 436 | 451 | ||
| 437 | void cgit_print_docstart(struct cgit_context *ctx) | 452 | void cgit_print_docstart(struct cgit_context *ctx) |
| 438 | { | 453 | { |
| 454 | char *host = cgit_hosturl(); | ||
| 439 | html(cgit_doctype); | 455 | html(cgit_doctype); |
| 440 | html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); | 456 | html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); |
| 441 | html("<head>\n"); | 457 | html("<head>\n"); |
| @@ -453,6 +469,13 @@ void cgit_print_docstart(struct cgit_context *ctx) | |||
| 453 | html_attr(ctx->cfg.favicon); | 469 | html_attr(ctx->cfg.favicon); |
| 454 | html("'/>\n"); | 470 | html("'/>\n"); |
| 455 | } | 471 | } |
| 472 | if (host && ctx->repo) { | ||
| 473 | html("<link rel='alternate' title='Atom feed' href='http://"); | ||
| 474 | html_attr(cgit_hosturl()); | ||
| 475 | html_attr(cgit_fileurl(ctx->repo->url, "atom", ctx->qry.path, | ||
| 476 | fmt("h=%s", ctx->qry.head))); | ||
| 477 | html("' type='application/atom+xml'/>"); | ||
| 478 | } | ||
| 456 | html("</head>\n"); | 479 | html("</head>\n"); |
| 457 | html("<body>\n"); | 480 | html("<body>\n"); |
| 458 | } | 481 | } |
diff --git a/ui-shared.h b/ui-shared.h index c5ce056..747f092 100644 --- a/ui-shared.h +++ b/ui-shared.h | |||
| @@ -1,6 +1,7 @@ | |||
| 1 | #ifndef UI_SHARED_H | 1 | #ifndef UI_SHARED_H |
| 2 | #define UI_SHARED_H | 2 | #define UI_SHARED_H |
| 3 | 3 | ||
| 4 | extern char *cgit_hosturl(); | ||
| 4 | extern char *cgit_repourl(const char *reponame); | 5 | extern char *cgit_repourl(const char *reponame); |
| 5 | extern char *cgit_fileurl(const char *reponame, const char *pagename, | 6 | extern char *cgit_fileurl(const char *reponame, const char *pagename, |
| 6 | const char *filename, const char *query); | 7 | const char *filename, const char *query); |
