-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | cgit.c | 34 | ||||
-rw-r--r-- | cgit.h | 1 | ||||
-rw-r--r-- | ui-view.c | 40 |
4 files changed, 43 insertions, 34 deletions
@@ -1,25 +1,25 @@ | |||
1 | CGIT_VERSION = 0.1-pre | 1 | CGIT_VERSION = 0.1-pre |
2 | 2 | ||
3 | INSTALL_BIN = /var/www/htdocs/cgit.cgi | 3 | INSTALL_BIN = /var/www/htdocs/cgit.cgi |
4 | INSTALL_CSS = /var/www/htdocs/cgit.css | 4 | INSTALL_CSS = /var/www/htdocs/cgit.css |
5 | CACHE_ROOT = /var/cache/cgit | 5 | CACHE_ROOT = /var/cache/cgit |
6 | 6 | ||
7 | EXTLIBS = ../git/libgit.a ../git/xdiff/lib.a -lz -lcrypto | 7 | EXTLIBS = ../git/libgit.a ../git/xdiff/lib.a -lz -lcrypto |
8 | OBJECTS = cache.o parsing.o html.o ui-shared.o ui-repolist.o ui-summary.o \ | 8 | OBJECTS = cache.o parsing.o html.o ui-shared.o ui-repolist.o ui-summary.o \ |
9 | ui-log.o | 9 | ui-log.o ui-view.c |
10 | 10 | ||
11 | CFLAGS += -Wall | 11 | CFLAGS += -Wall |
12 | 12 | ||
13 | all: cgit | 13 | all: cgit |
14 | 14 | ||
15 | install: all | 15 | install: all |
16 | install cgit $(INSTALL_BIN) | 16 | install cgit $(INSTALL_BIN) |
17 | install cgit.css $(INSTALL_CSS) | 17 | install cgit.css $(INSTALL_CSS) |
18 | rm -rf $(CACHE_ROOT)/* | 18 | rm -rf $(CACHE_ROOT)/* |
19 | 19 | ||
20 | cgit: cgit.c cgit.h git.h $(OBJECTS) | 20 | cgit: cgit.c cgit.h git.h $(OBJECTS) |
21 | $(CC) $(CFLAGS) -DCGIT_VERSION='"$(CGIT_VERSION)"' cgit.c -o cgit \ | 21 | $(CC) $(CFLAGS) -DCGIT_VERSION='"$(CGIT_VERSION)"' cgit.c -o cgit \ |
22 | $(OBJECTS) $(EXTLIBS) | 22 | $(OBJECTS) $(EXTLIBS) |
23 | 23 | ||
24 | $(OBJECTS): cgit.h git.h | 24 | $(OBJECTS): cgit.h git.h |
25 | 25 | ||
@@ -71,86 +71,54 @@ void cgit_repo_config_cb(const char *name, const char *value) | |||
71 | 71 | ||
72 | void cgit_querystring_cb(const char *name, const char *value) | 72 | void cgit_querystring_cb(const char *name, const char *value) |
73 | { | 73 | { |
74 | if (!strcmp(name,"r")) | 74 | if (!strcmp(name,"r")) |
75 | cgit_query_repo = xstrdup(value); | 75 | cgit_query_repo = xstrdup(value); |
76 | else if (!strcmp(name, "p")) | 76 | else if (!strcmp(name, "p")) |
77 | cgit_query_page = xstrdup(value); | 77 | cgit_query_page = xstrdup(value); |
78 | else if (!strcmp(name, "h")) { | 78 | else if (!strcmp(name, "h")) { |
79 | cgit_query_head = xstrdup(value); | 79 | cgit_query_head = xstrdup(value); |
80 | cgit_query_has_symref = 1; | 80 | cgit_query_has_symref = 1; |
81 | } else if (!strcmp(name, "id")) { | 81 | } else if (!strcmp(name, "id")) { |
82 | cgit_query_sha1 = xstrdup(value); | 82 | cgit_query_sha1 = xstrdup(value); |
83 | cgit_query_has_sha1 = 1; | 83 | cgit_query_has_sha1 = 1; |
84 | } | 84 | } |
85 | } | 85 | } |
86 | 86 | ||
87 | static void cgit_print_object(char *hex) | ||
88 | { | ||
89 | unsigned char sha1[20]; | ||
90 | //struct object *object; | ||
91 | char type[20]; | ||
92 | unsigned char *buf; | ||
93 | unsigned long size; | ||
94 | |||
95 | if (get_sha1_hex(hex, sha1)){ | ||
96 | cgit_print_error(fmt("Bad hex value: %s", hex)); | ||
97 | return; | ||
98 | } | ||
99 | |||
100 | if (sha1_object_info(sha1, type, NULL)){ | ||
101 | cgit_print_error("Bad object name"); | ||
102 | return; | ||
103 | } | ||
104 | |||
105 | buf = read_sha1_file(sha1, type, &size); | ||
106 | if (!buf) { | ||
107 | cgit_print_error("Error reading object"); | ||
108 | return; | ||
109 | } | ||
110 | |||
111 | buf[size] = '\0'; | ||
112 | html("<h2>Object view</h2>"); | ||
113 | htmlf("sha1=%s<br/>type=%s<br/>size=%i<br/>", hex, type, size); | ||
114 | html("<pre>"); | ||
115 | html_txt(buf); | ||
116 | html("</pre>"); | ||
117 | } | ||
118 | |||
119 | static void cgit_print_repo_page(struct cacheitem *item) | 87 | static void cgit_print_repo_page(struct cacheitem *item) |
120 | { | 88 | { |
121 | if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) || | 89 | if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) || |
122 | cgit_read_config("info/cgit", cgit_repo_config_cb)) { | 90 | cgit_read_config("info/cgit", cgit_repo_config_cb)) { |
123 | char *title = fmt("%s - %s", cgit_root_title, "Bad request"); | 91 | char *title = fmt("%s - %s", cgit_root_title, "Bad request"); |
124 | cgit_print_docstart(title, item); | 92 | cgit_print_docstart(title, item); |
125 | cgit_print_pageheader(title); | 93 | cgit_print_pageheader(title); |
126 | cgit_print_error(fmt("Unable to scan repository: %s", | 94 | cgit_print_error(fmt("Unable to scan repository: %s", |
127 | strerror(errno))); | 95 | strerror(errno))); |
128 | cgit_print_docend(); | 96 | cgit_print_docend(); |
129 | return; | 97 | return; |
130 | } | 98 | } |
131 | setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1); | 99 | setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1); |
132 | char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc); | 100 | char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc); |
133 | cgit_print_docstart(title, item); | 101 | cgit_print_docstart(title, item); |
134 | cgit_print_pageheader(title); | 102 | cgit_print_pageheader(title); |
135 | if (!cgit_query_page) | 103 | if (!cgit_query_page) |
136 | cgit_print_summary(); | 104 | cgit_print_summary(); |
137 | else if (!strcmp(cgit_query_page, "log")) { | 105 | else if (!strcmp(cgit_query_page, "log")) { |
138 | cgit_print_log(cgit_query_head, 0, 100); | 106 | cgit_print_log(cgit_query_head, 0, 100); |
139 | } else if (!strcmp(cgit_query_page, "view")) { | 107 | } else if (!strcmp(cgit_query_page, "view")) { |
140 | cgit_print_object(cgit_query_sha1); | 108 | cgit_print_view(cgit_query_sha1); |
141 | } | 109 | } |
142 | cgit_print_docend(); | 110 | cgit_print_docend(); |
143 | } | 111 | } |
144 | 112 | ||
145 | static void cgit_fill_cache(struct cacheitem *item) | 113 | static void cgit_fill_cache(struct cacheitem *item) |
146 | { | 114 | { |
147 | htmlfd = item->fd; | 115 | htmlfd = item->fd; |
148 | item->st.st_mtime = time(NULL); | 116 | item->st.st_mtime = time(NULL); |
149 | if (cgit_query_repo) | 117 | if (cgit_query_repo) |
150 | cgit_print_repo_page(item); | 118 | cgit_print_repo_page(item); |
151 | else | 119 | else |
152 | cgit_print_repolist(item); | 120 | cgit_print_repolist(item); |
153 | } | 121 | } |
154 | 122 | ||
155 | static void cgit_refresh_cache(struct cacheitem *item) | 123 | static void cgit_refresh_cache(struct cacheitem *item) |
156 | { | 124 | { |
@@ -64,21 +64,22 @@ extern int cache_lock(struct cacheitem *item); | |||
64 | extern int cache_unlock(struct cacheitem *item); | 64 | extern int cache_unlock(struct cacheitem *item); |
65 | extern int cache_exist(struct cacheitem *item); | 65 | extern int cache_exist(struct cacheitem *item); |
66 | extern int cache_expired(struct cacheitem *item); | 66 | extern int cache_expired(struct cacheitem *item); |
67 | 67 | ||
68 | extern char *cgit_repourl(const char *reponame); | 68 | extern char *cgit_repourl(const char *reponame); |
69 | extern char *cgit_pageurl(const char *reponame, const char *pagename, | 69 | extern char *cgit_pageurl(const char *reponame, const char *pagename, |
70 | const char *query); | 70 | const char *query); |
71 | 71 | ||
72 | extern void cgit_print_error(char *msg); | 72 | extern void cgit_print_error(char *msg); |
73 | extern void cgit_print_docstart(char *title, struct cacheitem *item); | 73 | extern void cgit_print_docstart(char *title, struct cacheitem *item); |
74 | extern void cgit_print_docend(); | 74 | extern void cgit_print_docend(); |
75 | extern void cgit_print_pageheader(char *title); | 75 | extern void cgit_print_pageheader(char *title); |
76 | 76 | ||
77 | extern void cgit_print_repolist(struct cacheitem *item); | 77 | extern void cgit_print_repolist(struct cacheitem *item); |
78 | extern void cgit_print_summary(); | 78 | extern void cgit_print_summary(); |
79 | extern void cgit_print_log(const char *tip, int ofs, int cnt); | 79 | extern void cgit_print_log(const char *tip, int ofs, int cnt); |
80 | extern void cgit_print_view(char *hex); | ||
80 | 81 | ||
81 | extern void cgit_repo_config_cb(const char *name, const char *value); | 82 | extern void cgit_repo_config_cb(const char *name, const char *value); |
82 | 83 | ||
83 | 84 | ||
84 | #endif /* CGIT_H */ | 85 | #endif /* CGIT_H */ |
diff --git a/ui-view.c b/ui-view.c new file mode 100644 index 0000000..193c685 --- a/dev/null +++ b/ui-view.c | |||
@@ -0,0 +1,40 @@ | |||
1 | /* ui-view.c: functions to output _any_ object, given it's sha1 | ||
2 | * | ||
3 | * Copyright (C) 2006 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 | |||
11 | void cgit_print_view(char *hex) | ||
12 | { | ||
13 | unsigned char sha1[20]; | ||
14 | char type[20]; | ||
15 | unsigned char *buf; | ||
16 | unsigned long size; | ||
17 | |||
18 | if (get_sha1_hex(hex, sha1)){ | ||
19 | cgit_print_error(fmt("Bad hex value: %s", hex)); | ||
20 | return; | ||
21 | } | ||
22 | |||
23 | if (sha1_object_info(sha1, type, NULL)){ | ||
24 | cgit_print_error("Bad object name"); | ||
25 | return; | ||
26 | } | ||
27 | |||
28 | buf = read_sha1_file(sha1, type, &size); | ||
29 | if (!buf) { | ||
30 | cgit_print_error("Error reading object"); | ||
31 | return; | ||
32 | } | ||
33 | |||
34 | buf[size] = '\0'; | ||
35 | html("<h2>Object view</h2>"); | ||
36 | htmlf("sha1=%s<br/>type=%s<br/>size=%i<br/>", hex, type, size); | ||
37 | html("<pre>"); | ||
38 | html_txt(buf); | ||
39 | html("</pre>"); | ||
40 | } | ||