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); |