author | Lars Hjemli <hjemli@gmail.com> | 2008-10-05 19:12:08 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-10-05 19:12:08 (UTC) |
commit | 8b5fc6de036cf159ffa61a55158044749bd6f4d9 (patch) (unidiff) | |
tree | c1accdd309b0af0f17fd97e91b8980185db79b21 | |
parent | 2e884f3162771880a2a5260713d6b7d1aa25bc6f (diff) | |
download | cgit-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>
-rw-r--r-- | ui-shared.c | 22 |
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 | ||
271 | void cgit_plain_link(char *name, char *title, char *class, char *head, | 271 | void 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 | ||
277 | void cgit_log_link(char *name, char *title, char *class, char *head, | 277 | void 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 | ||
308 | void cgit_commit_link(char *name, char *title, char *class, char *head, | 308 | void 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 | ||
320 | void cgit_refs_link(char *name, char *title, char *class, char *head, | 320 | void 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 | ||
326 | void cgit_snapshot_link(char *name, char *title, char *class, char *head, | 326 | void 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 | ||
332 | void cgit_diff_link(char *name, char *title, char *class, char *head, | 332 | void 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 = "&"; | 342 | delim = "&"; |
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 | ||
354 | void cgit_patch_link(char *name, char *title, char *class, char *head, | 354 | void 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 | ||
360 | void cgit_object_link(struct object *obj) | 360 | void 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 | ||
387 | void cgit_print_date(time_t secs, char *format, int local_time) | 379 | void 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 | ||
402 | void cgit_print_age(time_t t, time_t max_relative, char *format) | 394 | void 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 | ||
445 | void cgit_print_http_headers(struct cgit_context *ctx) | 437 | void 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 | ||
462 | void cgit_print_docstart(struct cgit_context *ctx) | 454 | void 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"); |