summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2008-10-05 19:12:08 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-10-05 19:12:08 (UTC)
commit8b5fc6de036cf159ffa61a55158044749bd6f4d9 (patch) (unidiff)
treec1accdd309b0af0f17fd97e91b8980185db79b21
parent2e884f3162771880a2a5260713d6b7d1aa25bc6f (diff)
downloadcgit-8b5fc6de036cf159ffa61a55158044749bd6f4d9.zip
cgit-8b5fc6de036cf159ffa61a55158044749bd6f4d9.tar.gz
cgit-8b5fc6de036cf159ffa61a55158044749bd6f4d9.tar.bz2
ui-shared: generate proper links in cgit_object_link()
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ui-shared.c22
1 files changed, 7 insertions, 15 deletions
diff --git a/ui-shared.c b/ui-shared.c
index 1e12529..a959224 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -266,215 +266,207 @@ void cgit_tree_link(char *name, char *title, char *class, char *head,
266 char *rev, char *path) 266 char *rev, char *path)
267{ 267{
268 reporevlink("tree", name, title, class, head, rev, path); 268 reporevlink("tree", name, title, class, head, rev, path);
269} 269}
270 270
271void cgit_plain_link(char *name, char *title, char *class, char *head, 271void cgit_plain_link(char *name, char *title, char *class, char *head,
272 char *rev, char *path) 272 char *rev, char *path)
273{ 273{
274 reporevlink("plain", name, title, class, head, rev, path); 274 reporevlink("plain", name, title, class, head, rev, path);
275} 275}
276 276
277void cgit_log_link(char *name, char *title, char *class, char *head, 277void cgit_log_link(char *name, char *title, char *class, char *head,
278 char *rev, char *path, int ofs, char *grep, char *pattern) 278 char *rev, char *path, int ofs, char *grep, char *pattern)
279{ 279{
280 char *delim; 280 char *delim;
281 281
282 delim = repolink(title, class, "log", head, path); 282 delim = repolink(title, class, "log", head, path);
283 if (rev && strcmp(rev, ctx.qry.head)) { 283 if (rev && strcmp(rev, ctx.qry.head)) {
284 html(delim); 284 html(delim);
285 html("id="); 285 html("id=");
286 html_url_arg(rev); 286 html_url_arg(rev);
287 delim = "&"; 287 delim = "&";
288 } 288 }
289 if (grep && pattern) { 289 if (grep && pattern) {
290 html(delim); 290 html(delim);
291 html("qt="); 291 html("qt=");
292 html_url_arg(grep); 292 html_url_arg(grep);
293 delim = "&"; 293 delim = "&";
294 html(delim); 294 html(delim);
295 html("q="); 295 html("q=");
296 html_url_arg(pattern); 296 html_url_arg(pattern);
297 } 297 }
298 if (ofs > 0) { 298 if (ofs > 0) {
299 html(delim); 299 html(delim);
300 html("ofs="); 300 html("ofs=");
301 htmlf("%d", ofs); 301 htmlf("%d", ofs);
302 } 302 }
303 html("'>"); 303 html("'>");
304 html_txt(name); 304 html_txt(name);
305 html("</a>"); 305 html("</a>");
306} 306}
307 307
308void cgit_commit_link(char *name, char *title, char *class, char *head, 308void cgit_commit_link(char *name, char *title, char *class, char *head,
309 char *rev) 309 char *rev)
310{ 310{
311 if (strlen(name) > ctx.cfg.max_msg_len && ctx.cfg.max_msg_len >= 15) { 311 if (strlen(name) > ctx.cfg.max_msg_len && ctx.cfg.max_msg_len >= 15) {
312 name[ctx.cfg.max_msg_len] = '\0'; 312 name[ctx.cfg.max_msg_len] = '\0';
313 name[ctx.cfg.max_msg_len - 1] = '.'; 313 name[ctx.cfg.max_msg_len - 1] = '.';
314 name[ctx.cfg.max_msg_len - 2] = '.'; 314 name[ctx.cfg.max_msg_len - 2] = '.';
315 name[ctx.cfg.max_msg_len - 3] = '.'; 315 name[ctx.cfg.max_msg_len - 3] = '.';
316 } 316 }
317 reporevlink("commit", name, title, class, head, rev, NULL); 317 reporevlink("commit", name, title, class, head, rev, NULL);
318} 318}
319 319
320void cgit_refs_link(char *name, char *title, char *class, char *head, 320void cgit_refs_link(char *name, char *title, char *class, char *head,
321 char *rev, char *path) 321 char *rev, char *path)
322{ 322{
323 reporevlink("refs", name, title, class, head, rev, path); 323 reporevlink("refs", name, title, class, head, rev, path);
324} 324}
325 325
326void cgit_snapshot_link(char *name, char *title, char *class, char *head, 326void cgit_snapshot_link(char *name, char *title, char *class, char *head,
327 char *rev, char *archivename) 327 char *rev, char *archivename)
328{ 328{
329 reporevlink("snapshot", name, title, class, head, rev, archivename); 329 reporevlink("snapshot", name, title, class, head, rev, archivename);
330} 330}
331 331
332void cgit_diff_link(char *name, char *title, char *class, char *head, 332void cgit_diff_link(char *name, char *title, char *class, char *head,
333 char *new_rev, char *old_rev, char *path) 333 char *new_rev, char *old_rev, char *path)
334{ 334{
335 char *delim; 335 char *delim;
336 336
337 delim = repolink(title, class, "diff", head, path); 337 delim = repolink(title, class, "diff", head, path);
338 if (new_rev && strcmp(new_rev, ctx.qry.head)) { 338 if (new_rev && strcmp(new_rev, ctx.qry.head)) {
339 html(delim); 339 html(delim);
340 html("id="); 340 html("id=");
341 html_url_arg(new_rev); 341 html_url_arg(new_rev);
342 delim = "&amp;"; 342 delim = "&amp;";
343 } 343 }
344 if (old_rev) { 344 if (old_rev) {
345 html(delim); 345 html(delim);
346 html("id2="); 346 html("id2=");
347 html_url_arg(old_rev); 347 html_url_arg(old_rev);
348 } 348 }
349 html("'>"); 349 html("'>");
350 html_txt(name); 350 html_txt(name);
351 html("</a>"); 351 html("</a>");
352} 352}
353 353
354void cgit_patch_link(char *name, char *title, char *class, char *head, 354void cgit_patch_link(char *name, char *title, char *class, char *head,
355 char *rev) 355 char *rev)
356{ 356{
357 reporevlink("patch", name, title, class, head, rev, NULL); 357 reporevlink("patch", name, title, class, head, rev, NULL);
358} 358}
359 359
360void cgit_object_link(struct object *obj) 360void cgit_object_link(struct object *obj)
361{ 361{
362 char *page, *arg, *url; 362 char *page, *rev, *name;
363 363
364 if (obj->type == OBJ_COMMIT) { 364 if (obj->type == OBJ_COMMIT) {
365 cgit_commit_link(fmt("commit %s", sha1_to_hex(obj->sha1)), NULL, NULL, 365 cgit_commit_link(fmt("commit %s", sha1_to_hex(obj->sha1)), NULL, NULL,
366 ctx.qry.head, sha1_to_hex(obj->sha1)); 366 ctx.qry.head, sha1_to_hex(obj->sha1));
367 return; 367 return;
368 } else if (obj->type == OBJ_TREE) { 368 } else if (obj->type == OBJ_TREE)
369 page = "tree"; 369 page = "tree";
370 arg = "id"; 370 else if (obj->type == OBJ_TAG)
371 } else if (obj->type == OBJ_TAG) {
372 page = "tag"; 371 page = "tag";
373 arg = "id"; 372 else
374 } else {
375 page = "blob"; 373 page = "blob";
376 arg = "id"; 374 rev = sha1_to_hex(obj->sha1);
377 } 375 name = fmt("%s %s", typename(obj->type), rev);
378 376 reporevlink(page, name, NULL, NULL, ctx.qry.head, rev, NULL);
379 url = cgit_pageurl(ctx.qry.repo, page,
380 fmt("%s=%s", arg, sha1_to_hex(obj->sha1)));
381 html_link_open(url, NULL, NULL);
382 htmlf("%s %s", typename(obj->type),
383 sha1_to_hex(obj->sha1));
384 html_link_close();
385} 377}
386 378
387void cgit_print_date(time_t secs, char *format, int local_time) 379void cgit_print_date(time_t secs, char *format, int local_time)
388{ 380{
389 char buf[64]; 381 char buf[64];
390 struct tm *time; 382 struct tm *time;
391 383
392 if (!secs) 384 if (!secs)
393 return; 385 return;
394 if(local_time) 386 if(local_time)
395 time = localtime(&secs); 387 time = localtime(&secs);
396 else 388 else
397 time = gmtime(&secs); 389 time = gmtime(&secs);
398 strftime(buf, sizeof(buf)-1, format, time); 390 strftime(buf, sizeof(buf)-1, format, time);
399 html_txt(buf); 391 html_txt(buf);
400} 392}
401 393
402void cgit_print_age(time_t t, time_t max_relative, char *format) 394void cgit_print_age(time_t t, time_t max_relative, char *format)
403{ 395{
404 time_t now, secs; 396 time_t now, secs;
405 397
406 if (!t) 398 if (!t)
407 return; 399 return;
408 time(&now); 400 time(&now);
409 secs = now - t; 401 secs = now - t;
410 402
411 if (secs > max_relative && max_relative >= 0) { 403 if (secs > max_relative && max_relative >= 0) {
412 cgit_print_date(t, format, ctx.cfg.local_time); 404 cgit_print_date(t, format, ctx.cfg.local_time);
413 return; 405 return;
414 } 406 }
415 407
416 if (secs < TM_HOUR * 2) { 408 if (secs < TM_HOUR * 2) {
417 htmlf("<span class='age-mins'>%.0f min.</span>", 409 htmlf("<span class='age-mins'>%.0f min.</span>",
418 secs * 1.0 / TM_MIN); 410 secs * 1.0 / TM_MIN);
419 return; 411 return;
420 } 412 }
421 if (secs < TM_DAY * 2) { 413 if (secs < TM_DAY * 2) {
422 htmlf("<span class='age-hours'>%.0f hours</span>", 414 htmlf("<span class='age-hours'>%.0f hours</span>",
423 secs * 1.0 / TM_HOUR); 415 secs * 1.0 / TM_HOUR);
424 return; 416 return;
425 } 417 }
426 if (secs < TM_WEEK * 2) { 418 if (secs < TM_WEEK * 2) {
427 htmlf("<span class='age-days'>%.0f days</span>", 419 htmlf("<span class='age-days'>%.0f days</span>",
428 secs * 1.0 / TM_DAY); 420 secs * 1.0 / TM_DAY);
429 return; 421 return;
430 } 422 }
431 if (secs < TM_MONTH * 2) { 423 if (secs < TM_MONTH * 2) {
432 htmlf("<span class='age-weeks'>%.0f weeks</span>", 424 htmlf("<span class='age-weeks'>%.0f weeks</span>",
433 secs * 1.0 / TM_WEEK); 425 secs * 1.0 / TM_WEEK);
434 return; 426 return;
435 } 427 }
436 if (secs < TM_YEAR * 2) { 428 if (secs < TM_YEAR * 2) {
437 htmlf("<span class='age-months'>%.0f months</span>", 429 htmlf("<span class='age-months'>%.0f months</span>",
438 secs * 1.0 / TM_MONTH); 430 secs * 1.0 / TM_MONTH);
439 return; 431 return;
440 } 432 }
441 htmlf("<span class='age-years'>%.0f years</span>", 433 htmlf("<span class='age-years'>%.0f years</span>",
442 secs * 1.0 / TM_YEAR); 434 secs * 1.0 / TM_YEAR);
443} 435}
444 436
445void cgit_print_http_headers(struct cgit_context *ctx) 437void cgit_print_http_headers(struct cgit_context *ctx)
446{ 438{
447 if (ctx->page.mimetype && ctx->page.charset) 439 if (ctx->page.mimetype && ctx->page.charset)
448 htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype, 440 htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype,
449 ctx->page.charset); 441 ctx->page.charset);
450 else if (ctx->page.mimetype) 442 else if (ctx->page.mimetype)
451 htmlf("Content-Type: %s\n", ctx->page.mimetype); 443 htmlf("Content-Type: %s\n", ctx->page.mimetype);
452 if (ctx->page.size) 444 if (ctx->page.size)
453 htmlf("Content-Length: %ld\n", ctx->page.size); 445 htmlf("Content-Length: %ld\n", ctx->page.size);
454 if (ctx->page.filename) 446 if (ctx->page.filename)
455 htmlf("Content-Disposition: inline; filename=\"%s\"\n", 447 htmlf("Content-Disposition: inline; filename=\"%s\"\n",
456 ctx->page.filename); 448 ctx->page.filename);
457 htmlf("Last-Modified: %s\n", http_date(ctx->page.modified)); 449 htmlf("Last-Modified: %s\n", http_date(ctx->page.modified));
458 htmlf("Expires: %s\n", http_date(ctx->page.expires)); 450 htmlf("Expires: %s\n", http_date(ctx->page.expires));
459 html("\n"); 451 html("\n");
460} 452}
461 453
462void cgit_print_docstart(struct cgit_context *ctx) 454void cgit_print_docstart(struct cgit_context *ctx)
463{ 455{
464 char *host = cgit_hosturl(); 456 char *host = cgit_hosturl();
465 html(cgit_doctype); 457 html(cgit_doctype);
466 html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); 458 html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n");
467 html("<head>\n"); 459 html("<head>\n");
468 html("<title>"); 460 html("<title>");
469 html_txt(ctx->page.title); 461 html_txt(ctx->page.title);
470 html("</title>\n"); 462 html("</title>\n");
471 htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version); 463 htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version);
472 if (ctx->cfg.robots && *ctx->cfg.robots) 464 if (ctx->cfg.robots && *ctx->cfg.robots)
473 htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots); 465 htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots);
474 html("<link rel='stylesheet' type='text/css' href='"); 466 html("<link rel='stylesheet' type='text/css' href='");
475 html_attr(ctx->cfg.css); 467 html_attr(ctx->cfg.css);
476 html("'/>\n"); 468 html("'/>\n");
477 if (ctx->cfg.favicon) { 469 if (ctx->cfg.favicon) {
478 html("<link rel='shortcut icon' href='"); 470 html("<link rel='shortcut icon' href='");
479 html_attr(ctx->cfg.favicon); 471 html_attr(ctx->cfg.favicon);
480 html("'/>\n"); 472 html("'/>\n");