diff options
| author | Lars Hjemli <hjemli@gmail.com> | 2007-07-22 23:57:48 +0200 | 
|---|---|---|
| committer | Lars Hjemli <hjemli@gmail.com> | 2007-07-22 23:57:56 +0200 | 
| commit | 1d4aaff696ee1b9085dda0f0f3d84d9d20d96db0 (patch) | |
| tree | 6674c5168d967c3efdbf8f445e7e975d54e43629 /ui-shared.c | |
| parent | Add ui-tag.c (diff) | |
| parent | link raw blob from tree file view (diff) | |
| download | cgit-1d4aaff696ee1b9085dda0f0f3d84d9d20d96db0.tar.gz cgit-1d4aaff696ee1b9085dda0f0f3d84d9d20d96db0.tar.bz2 cgit-1d4aaff696ee1b9085dda0f0f3d84d9d20d96db0.zip | |
Merge branch 'master' of git://git.klever.net/patchwork/cgit
* 'master' of git://git.klever.net/patchwork/cgit:
  link raw blob from tree file view
  fix: changed view link to blob in summary.
  allow selective enabling of snapshots
  shorten snapshot names to repo basename
  introduce cgit_repobasename
  added snapshot filename to the link
  add plain uncompressed tar snapshort format
  introduced .tar.bz2 snapshots
  compress .tar.gz using gzip as a filter
  added a chk_non_negative check
  css: adjust vertical-align of commit info th cells
  add support for snapshot tarballs
Conflicts:
	ui-summary.c
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to '')
| -rw-r--r-- | ui-shared.c | 41 | 
1 files changed, 37 insertions, 4 deletions
| diff --git a/ui-shared.c b/ui-shared.c index fd71c12..ca2ee82 100644 --- a/ui-shared.c +++ b/ui-shared.c @@ -57,13 +57,13 @@ char *cgit_repourl(const char *reponame)  	}  } -char *cgit_pageurl(const char *reponame, const char *pagename, -		   const char *query) +char *cgit_fileurl(const char *reponame, const char *pagename, +		   const char *filename, const char *query)  {  	if (cgit_virtual_root) {  		if (query) -			return fmt("%s/%s/%s/?%s", cgit_virtual_root, reponame, -				   pagename, query); +			return fmt("%s/%s/%s/%s?%s", cgit_virtual_root, reponame, +				   pagename, filename?filename:"", query);  		else  			return fmt("%s/%s/%s/", cgit_virtual_root, reponame,  				   pagename); @@ -75,6 +75,37 @@ char *cgit_pageurl(const char *reponame, const char *pagename,  	}  } +char *cgit_pageurl(const char *reponame, const char *pagename, +		   const char *query) +{ +	return cgit_fileurl(reponame,pagename,0,query); +} + +const char *cgit_repobasename(const char *reponame) +{ +	/* I assume we don't need to store more than one repo basename */ +	static char rvbuf[1024]; +	int p; +	const char *rv; +	strncpy(rvbuf,reponame,sizeof(rvbuf)); +	if(rvbuf[sizeof(rvbuf)-1]) +		die("cgit_repobasename: truncated repository name '%s'", reponame); +	p = strlen(rvbuf)-1; +	/* strip trailing slashes */ +	while(p && rvbuf[p]=='/') rvbuf[p--]=0; +	/* strip trailing .git */ +	if(p>=3 && !strncmp(&rvbuf[p-3],".git",4)) { +		p -= 3; rvbuf[p--] = 0; +	} +	/* strip more trailing slashes if any */ +	while( p && rvbuf[p]=='/') rvbuf[p--]=0; +	/* find last slash in the remaining string */ +	rv = strrchr(rvbuf,'/'); +	if(rv) +		return ++rv; +	return rvbuf; +} +  char *cgit_currurl()  {  	if (!cgit_virtual_root) @@ -392,3 +423,5 @@ void cgit_print_snapshot_start(const char *mimetype, const char *filename,  					 ttl_seconds(item->ttl)));  	html("\n");  } + +/* vim:set sw=8: */ | 
