]> git.cameronkatri.com Git - cgit.git/log
cgit.git
16 years agoui-repolist + ui-shared: Use cgit_summary_link()
Lars Hjemli [Sun, 5 Oct 2008 15:16:36 +0000 (17:16 +0200)]
ui-repolist + ui-shared: Use cgit_summary_link()

This makes is possible to use cgit with repository urls containing special
url characters like '#' and '?'.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-shared.c: add cgit_summary_link()
Lars Hjemli [Sun, 5 Oct 2008 14:55:50 +0000 (16:55 +0200)]
ui-shared.c: add cgit_summary_link()

This function can be used to generate a link to the summary page for the
currently active repo.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-shared.c: use html_url_path() in repolink()
Lars Hjemli [Sun, 5 Oct 2008 14:54:44 +0000 (16:54 +0200)]
ui-shared.c: use html_url_path() in repolink()

This makes sure that reponames and paths are properly escaped when used
as urls.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agohtml.c: add html_url_path
Lars Hjemli [Sun, 5 Oct 2008 14:52:57 +0000 (16:52 +0200)]
html.c: add html_url_path

This function can be used to generate properly escaped path-components
for links.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-shared.c: use html_url_arg()
Lars Hjemli [Sun, 5 Oct 2008 10:52:25 +0000 (12:52 +0200)]
ui-shared.c: use html_url_arg()

The link-generating functions are updated to use the new html_url_arg
function, thereby fixing links to strange repos, branches and files.

Also, the test-suite is updated to verify some cases of strange urls.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agohtml.c: add html_url_arg
Lars Hjemli [Sun, 5 Oct 2008 10:49:46 +0000 (12:49 +0200)]
html.c: add html_url_arg

This function can be used to properly escape querystring parameter values.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-diff: make diffstat header a link to the full diff
Lars Hjemli [Tue, 23 Sep 2008 15:54:45 +0000 (17:54 +0200)]
ui-diff: make diffstat header a link to the full diff

When printing a path-filtered diff it wasn't obvious how to get back to
the full diff (clicking the 'diff' tab would do this). Making the diffstat
heading into a link seems to improve the usability.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-diff: fix links from diffstat
Lars Hjemli [Tue, 23 Sep 2008 15:47:26 +0000 (17:47 +0200)]
ui-diff: fix links from diffstat

The links in the diffstat is supposed to work as a filter for the diff,
but this only worked when a single rev was supplied, i.e. the filtered
diff was always against the parent of the specified rev.

With this patch it is now possible to use the diffstat as a 'filter menu'
for urls like http://hjemli.net/git/cgit/diff/?id=v0.7.2&id2=v0.7.1

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd LDFLAGS to makefile.
Harley Laue [Fri, 19 Sep 2008 02:06:18 +0000 (21:06 -0500)]
Add LDFLAGS to makefile.

This will allow for creating static builds which is useful for chrooted
environments.

Signed-off-by: Harley Laue <losinggeneration@gmail.com>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-repolist: enable filtering of repos by path
Lars Hjemli [Sun, 14 Sep 2008 18:18:10 +0000 (20:18 +0200)]
ui-repolist: enable filtering of repos by path

If a repo url is specified but no exact match is found in the list of
repos the url will now be used as a prefix-filter.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd support for --scan-tree=<path> option to cgit
Lars Hjemli [Sun, 14 Sep 2008 22:07:12 +0000 (00:07 +0200)]
Add support for --scan-tree=<path> option to cgit

This option makes cgit scan a directory tree looking for git repositories,
generating suitable definitions for a cgitrc file on stdout.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoTeach cgit how to use PATH_INFO
Lars Hjemli [Sat, 9 Aug 2008 19:11:41 +0000 (21:11 +0200)]
Teach cgit how to use PATH_INFO

This commit makes cgit use the cgi variables SCRIPT_NAME and PATH_INFO
when virtual-root is unspecified in cgitrc and no url-parameter is
specified on the querystring. This has two nice effects:

* Virtual urls works out of the box, no more need for rewrite-rules in httpd.
* Virtual urls with special querystring characters are handled correctly.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'lh/parsing'
Lars Hjemli [Mon, 15 Sep 2008 20:41:25 +0000 (22:41 +0200)]
Merge branch 'lh/parsing'

* lh/parsing:
  ui-tag: show the taggers email
  parsing.c: be prepared for unexpected content in commit/tag objects

16 years agoui-tag: show the taggers email
Lars Hjemli [Mon, 15 Sep 2008 20:40:02 +0000 (22:40 +0200)]
ui-tag: show the taggers email

If it's specified there's no point in hiding it.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoparsing.c: be prepared for unexpected content in commit/tag objects
Lars Hjemli [Sun, 14 Sep 2008 07:45:37 +0000 (09:45 +0200)]
parsing.c: be prepared for unexpected content in commit/tag objects

When parsing commits and tags cgit made too many assumptions about the
formatting of said objects. This patch tries to make the code be more
prepared to handle 'malformed' objects.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'ew/http_host'
Lars Hjemli [Mon, 15 Sep 2008 19:47:14 +0000 (21:47 +0200)]
Merge branch 'ew/http_host'

* ew/http_host:
  use Host: header to generate cgit_hosturl

16 years agoUpdate Makefile to use GIT-1.6.0.1
Lars Hjemli [Tue, 2 Sep 2008 22:18:09 +0000 (00:18 +0200)]
Update Makefile to use GIT-1.6.0.1

When updating the git submodule to 1.6.0.1 (and 1.6.0), the Makefile was
left behind. This fixes it.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agouse Host: header to generate cgit_hosturl
Eric Wong [Mon, 1 Sep 2008 06:30:33 +0000 (23:30 -0700)]
use Host: header to generate cgit_hosturl

I run an instance of lighttpd for cgit behind nginx (nginx
doesn't execute CGI).  So the port (SERVER_PORT=33333) that
lighttpd runs on sends to cgit is different from the standard
port 80 that public clients connect to (via nginx).

This was causing the Atom feed URL to show the private port
number that lighttpd was running on.

Since the HTTP/1.1 "Host" header includes the port number if
running on a non-standard port, it allows non-client-facing HTTP
servers to transparently generate public URLs that clients can
see.

So use the "Host" header if it is available and fall back to
SERVER_NAME/SERVER_PORT for some clients that don't set
HTTP_HOST.

Signed-off-by: Eric Wong <normalperson@yhbt.net>
16 years agoUse GIT-1.6.0.1
Lars Hjemli [Mon, 1 Sep 2008 23:06:27 +0000 (01:06 +0200)]
Use GIT-1.6.0.1

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-plain: handle subdirectories
Lars Hjemli [Mon, 1 Sep 2008 22:53:04 +0000 (00:53 +0200)]
ui-plain: handle subdirectories

The callback from read_tree_recursive just needs to check the type of
each tree entry; if it's a dir we want to continue scanning, if it's a
regular file we'll assume it's the one we requested.

And while at it, remove some stray fprintfs.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoUse GIT-1.6.0
Lars Hjemli [Mon, 1 Sep 2008 20:50:35 +0000 (22:50 +0200)]
Use GIT-1.6.0

16 years agoMerge branch 'lh/plain'
Lars Hjemli [Mon, 1 Sep 2008 20:40:55 +0000 (22:40 +0200)]
Merge branch 'lh/plain'

* lh/plain:
  Supply status description to html_status()
  ui-tree: link to plain view instead of blob view
  Implement plain view

16 years agoMerge branch 'lh/clone'
Lars Hjemli [Mon, 1 Sep 2008 20:40:24 +0000 (22:40 +0200)]
Merge branch 'lh/clone'

* lh/clone:
  Add support for cloning over http

Conflicts:
cmd.c

16 years agocache.c: use %zd for off_t argument
Lars Hjemli [Sun, 10 Aug 2008 07:24:24 +0000 (09:24 +0200)]
cache.c: use %zd for off_t argument

Signed-off-by: Lars Hjemli <hjemli@gmail>
16 years agoSupply status description to html_status()
Lars Hjemli [Wed, 6 Aug 2008 20:57:44 +0000 (22:57 +0200)]
Supply status description to html_status()

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoUse GIT-1.6.0.rc1
Lars Hjemli [Wed, 6 Aug 2008 17:08:19 +0000 (19:08 +0200)]
Use GIT-1.6.0.rc1

Now that rc1 is released as a tarball `make get-git` should start working
again.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMakefile: Git dependency, take 3
Lars Hjemli [Wed, 6 Aug 2008 16:52:27 +0000 (18:52 +0200)]
Makefile: Git dependency, take 3

In commit a1266edfe the build instructions for the git libs where moved
to their real targets, which in turn depended on the phony target `git`.
But since `git` is an actual directory in cgit the git libs wouldn't be
recompiled when needed.

So with this patch (third time lucky), cgit is declared to depend on the
really phony target `libgit` and the build instructions for `libgit` is
to unconditionally rebuild git/libgit.a and git/xdiff/lib.a.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-tree: link to plain view instead of blob view
Lars Hjemli [Wed, 6 Aug 2008 09:07:13 +0000 (11:07 +0200)]
ui-tree: link to plain view instead of blob view

The urls for plain view makes it possible to download blobs without knowing
their SHA1, but the function needs to be promoted and the link from tree
view seems like a perfect fit.

PS: Although hidden, the blob view still is nice for direct blob access so
there's no point in removing it.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoImplement plain view
Lars Hjemli [Wed, 6 Aug 2008 08:53:50 +0000 (10:53 +0200)]
Implement plain view

This implements a way to access plain blobs by path (similar to the
tree view) instead of by sha1.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd support for cloning over http
Lars Hjemli [Tue, 5 Aug 2008 23:20:24 +0000 (01:20 +0200)]
Add support for cloning over http

This patch implements basic support for cloning over http, based on the
work on git-http-backend by Shawn O. Pearce.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'lh/atom'
Lars Hjemli [Wed, 6 Aug 2008 07:50:10 +0000 (09:50 +0200)]
Merge branch 'lh/atom'

16 years agocgitrc: explain new local-time option
Stefan Naewe [Tue, 5 Aug 2008 07:20:07 +0000 (09:20 +0200)]
cgitrc: explain new local-time option

Signed-off-by: Stefan Naewe <stefan.naewe@atlas-elektronik.com>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd atom-support
Lars Hjemli [Wed, 21 May 2008 06:17:54 +0000 (08:17 +0200)]
Add atom-support

This enables a page which generates atom feeds for the current branch and
path, heavily inspired by the atom-support in gitweb.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdded `local-time` option to cgitrc
Stefan Naewe [Fri, 1 Aug 2008 12:54:38 +0000 (14:54 +0200)]
Added `local-time` option to cgitrc

When `local-time` is set, commit, tag and patch timestamps will be printed
in the servers timezone. Also, regardless of the value of `local-time`,
these timestamps will now always show the timezone.

Signed-off-by: Stefan Naewe <stefan.naewe@atlas-elektronik.com>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMakefile: another take on git dependency rules
Lars Hjemli [Thu, 31 Jul 2008 23:25:51 +0000 (01:25 +0200)]
Makefile: another take on git dependency rules

When building cgit we depend on xdiff/lib.a and libgit.a in the git
directory, but the previous attempt on describing this dependency
failed since the build instructions for the libs was placed under the
phony `git` target.

This patch fixes the issue by moving the build instructions to their
real targets. It also makes it clear that only the `cgit` target
depends on the git binaries (since they're only used during linking).

And while at it, the patch also cleans up the list of phony targets.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoModify default value for a few cgitrc options
Lars Hjemli [Sun, 27 Jul 2008 10:58:37 +0000 (12:58 +0200)]
Modify default value for a few cgitrc options

The default max-length used when printing commit messages and repo
descriptions can be increased due to the new layout (no sidebar).

Also, on the repo summary page I believe it makes sense to only show the
ten most recent branches and tags by default, just as it makes sense to
show the ten most recent commit messages for the active branch.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoBe prepared for empty repositories
Lars Hjemli [Sun, 27 Jul 2008 10:32:08 +0000 (12:32 +0200)]
Be prepared for empty repositories

Before this patch, cgit would segfault on repositories with no refs.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-shared: show repo owner along with description
Lars Hjemli [Sun, 27 Jul 2008 10:22:16 +0000 (12:22 +0200)]
ui-shared: show repo owner along with description

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-summary: show clone urls
Lars Hjemli [Sun, 27 Jul 2008 09:54:06 +0000 (11:54 +0200)]
ui-summary: show clone urls

If either repo.clone-url or clone-prefix is specified in cgitrc, all
space-separated values in the config option is printed as a possible
clone url on the repo summary page.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMakefile: remove the `distclean` and `emptycache` targets
Lars Hjemli [Tue, 22 Jul 2008 18:06:16 +0000 (20:06 +0200)]
Makefile: remove the `distclean` and `emptycache` targets

The `distclean` was hardly useful while the `emptycache` was actively harmful.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMakefile: do not touch the git objects with `make clean`
Lars Hjemli [Tue, 22 Jul 2008 17:58:37 +0000 (19:58 +0200)]
Makefile: do not touch the git objects with `make clean`

I've been avoiding `make clean` for a long time due to its eagerness to kill
all the git objectfiles.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMakefile: fix git dependency rules
Lars Hjemli [Tue, 22 Jul 2008 17:30:06 +0000 (19:30 +0200)]
Makefile: fix git dependency rules

The objectfiles depends unconditionally on some specific git binaries while
those git binaries depends on the phony `git` target and this patch seems to
get these dependencies spelled out correctly.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agotests/Makefile: not everyone has `.` in $PATH
Lars Hjemli [Tue, 22 Jul 2008 17:01:31 +0000 (19:01 +0200)]
tests/Makefile: not everyone has `.` in $PATH

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdjust to new calling convention for read_tree_recursive()
Lars Hjemli [Mon, 21 Jul 2008 08:10:48 +0000 (10:10 +0200)]
Adjust to new calling convention for read_tree_recursive()

In GIT-1.6.0, read_tree_recursive takes an extra void pointer for callback
data. We might want to use this to avoid some global variables, but for now
lets just make sure that we can still compile.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoUse GIT-1.6.0-rc0
Lars Hjemli [Mon, 21 Jul 2008 07:57:25 +0000 (09:57 +0200)]
Use GIT-1.6.0-rc0

16 years agoAdd a favicon option to cgitrc
Lars Hjemli [Sat, 19 Jul 2008 18:40:30 +0000 (20:40 +0200)]
Add a favicon option to cgitrc

This option is used to specify a shortcut icon on all cgit pages.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd support for including a footer on all pages
Lars Hjemli [Thu, 26 Jun 2008 11:53:30 +0000 (13:53 +0200)]
Add support for including a footer on all pages

The new cgitrc option `footer` can be used to include a html-file which
replaces the standard 'generated by cgit' message at the bottom of each
page.

Suggested-by: Peter Danenberg <pcd@wikitex.org>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'master' of git://git.klever.net/patchwork/cgit
Lars Hjemli [Thu, 26 Jun 2008 10:54:44 +0000 (12:54 +0200)]
Merge branch 'master' of git://git.klever.net/patchwork/cgit

* 'master' of git://git.klever.net/patchwork/cgit:
  allow specification of directly linked blobs mimetypes
  allow blob extract blobs by head/path combination

16 years agoUse GIT-1.5.6
Lars Hjemli [Wed, 25 Jun 2008 15:39:25 +0000 (17:39 +0200)]
Use GIT-1.5.6

16 years agoallow specification of directly linked blobs mimetypes
Michael Krelin [Tue, 24 Jun 2008 21:42:32 +0000 (23:42 +0200)]
allow specification of directly linked blobs mimetypes

Signed-off-by: Michael Krelin <hacker@klever.net>
16 years agoallow blob extract blobs by head/path combination
Michael Krelin [Tue, 24 Jun 2008 21:33:24 +0000 (23:33 +0200)]
allow blob extract blobs by head/path combination

 If blob is invoked with no id=, it tries to look up h= and search for path= in
 there. Once found, proceed as normal, otherwise, fail as normal.

Signed-off-by: Michael Krelin <hacker@klever.net>
16 years agoAdded root-desc to default configuration.
Harley Laue [Wed, 21 May 2008 00:08:21 +0000 (19:08 -0500)]
Added root-desc to default configuration.

Signed-off-by: Harley Laue <losinggeneration@gmail.com>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-tree.c: avoid peeking at GITLINK objects
Lars Hjemli [Tue, 20 May 2008 20:32:22 +0000 (22:32 +0200)]
ui-tree.c: avoid peeking at GITLINK objects

When an object in the tree has GITLINK mode-bits we don't need to get any
more info about that particular object (and trying to get more info about
it will usually generate an annoying warning on stderr since the object
typically doesn't exist in the repo anyways).

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agocache.c: fix error checking in print_slot()
Lars Hjemli [Tue, 20 May 2008 15:56:47 +0000 (17:56 +0200)]
cache.c: fix error checking in print_slot()

The change to print_slot() in cdc6b2f8e7a8d43dcfe0475a9d3498333ea686b8 made
the function return correct errno for read errors while ignoring write errors,
which is not what was intended. This patch tries to rectify things.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agocache.c: do not ignore errors from print_slot()
Lars Hjemli [Sun, 18 May 2008 21:59:11 +0000 (23:59 +0200)]
cache.c: do not ignore errors from print_slot()

If print_slot() fails, the client will be served an inferior response.
This patch makes sure that such an error will be returned to main(), which
in turn will try to inform about the error in the response itself.

The error is also printed to the cache_log, i.e. stderr, which will make
the error message appear in error_log (atleast when httpd==apache).

Noticed-by: Jim Meyering <jim@meyering.net>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agocache.c: use xread()/xwrite() from libgit
Lars Hjemli [Sun, 18 May 2008 21:26:05 +0000 (23:26 +0200)]
cache.c: use xread()/xwrite() from libgit

These functions handles EINTR/EAGAIN errors during read/write operations,
which is something cache.c didn't.

While at it, fix a bug in print_slot() where errors during reading from the
cache slot might go by unnoticed.

Noticed-by: Jim Meyering <jim@meyering.net>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agocache.c: make all io-related functions return errno on error
Lars Hjemli [Sun, 18 May 2008 21:16:50 +0000 (23:16 +0200)]
cache.c: make all io-related functions return errno on error

We'll need proper return-values from these functions to make the cache
behave correctly (which includes giving proper error messages).

Noticed-by: Jim Meyering <jim@meyering.net>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agocache.c: read(2) returns -1 on error, not 0
Lars Hjemli [Sun, 18 May 2008 21:10:05 +0000 (23:10 +0200)]
cache.c: read(2) returns -1 on error, not 0

Noticed-by: Jim Meyering <jim@meyering.net>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoUse GIT-1.5.5.1
Lars Hjemli [Sun, 18 May 2008 19:40:28 +0000 (21:40 +0200)]
Use GIT-1.5.5.1

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoInclude commit-id in link from diff-stat
Lars Hjemli [Sun, 18 May 2008 19:21:32 +0000 (21:21 +0200)]
Include commit-id in link from diff-stat

This fixes a regression created by fe1230dece81450004d02fa8a470f8dab8f7fdd9,
and modifies a test to avoid future regressions.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-commit: handle root commits
Lars Hjemli [Sun, 18 May 2008 19:09:26 +0000 (21:09 +0200)]
ui-commit: handle root commits

Both cgit_print_diff() and cgit_diff_tree() handles root commits nicely,
but cgit_print_commit() forgot to check the case of 0 parents.

This fixes it, and adds tests to avoid future regressions.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd link to index page from repo header, remove page name
Lars Hjemli [Sat, 3 May 2008 10:44:20 +0000 (12:44 +0200)]
Add link to index page from repo header, remove page name

This makes it more obvious how to get back to the index, especially when the
config option `logo-link` is used. And the page name displayed in the header
provided no extra information. It only consumed space and deserved to die.

While at it, make sure that the different parts of the header doesn't wrap
when horizontal space is limited.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd footer with page creation time and cgit version on all pages
Lars Hjemli [Sat, 3 May 2008 09:07:41 +0000 (11:07 +0200)]
Add footer with page creation time and cgit version on all pages

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd a pager on the repolist
Lars Hjemli [Sat, 3 May 2008 08:54:39 +0000 (10:54 +0200)]
Add a pager on the repolist

This enables a pager on the repolist which restricts the number of entries
displayed per page, controlled by the new option `max-repo-count` (default
value 50).

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd cgit_index_link() function with support for offset
Lars Hjemli [Sat, 3 May 2008 08:37:02 +0000 (10:37 +0200)]
Add cgit_index_link() function with support for offset

This function will be used to build a pager in ui-repolist.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'lh/cache'
Lars Hjemli [Sat, 3 May 2008 08:10:07 +0000 (10:10 +0200)]
Merge branch 'lh/cache'

* lh/cache:
  Add page 'ls_cache'
  Redesign the caching layer

16 years agoPrint an error if filename is not found in html_include.
Harley Laue [Tue, 29 Apr 2008 15:59:53 +0000 (17:59 +0200)]
Print an error if filename is not found in html_include.

Normally when html_include cannot open the file it fails silently and
things can be a bit hard to figure out from just looking at apache's
log. This will be beneficial for those initially setting up their server
with cgit.

Signed-off-by: Harley Laue <losinggeneration@aim.com>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'lh/about'
Lars Hjemli [Mon, 28 Apr 2008 23:13:08 +0000 (01:13 +0200)]
Merge branch 'lh/about'

* lh/about:
  Add 'about site' and 'about repo' pages
  Prepare for 'about site' page / add 'root-readme' option to cgitrc
  Make it possible for a single cmd to work both with and without a repo
  Re-enable 'index-info' and add support for 'root-desc' in cgitrc
  Move included header-file out of repolist table
  Prepare for 'about repo' page

16 years agoAdd 'about site' and 'about repo' pages
Lars Hjemli [Mon, 28 Apr 2008 23:09:41 +0000 (01:09 +0200)]
Add 'about site' and 'about repo' pages

This commit uses the options and changes from the last few commits to
implement a new 'about' command which works both with and without a
repo.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoPrepare for 'about site' page / add 'root-readme' option to cgitrc
Lars Hjemli [Mon, 28 Apr 2008 23:06:30 +0000 (01:06 +0200)]
Prepare for 'about site' page / add 'root-readme' option to cgitrc

The new option names a file which will be included on a new page, next
to the current 'index' page.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMake it possible for a single cmd to work both with and without a repo
Lars Hjemli [Mon, 28 Apr 2008 23:01:30 +0000 (01:01 +0200)]
Make it possible for a single cmd to work both with and without a repo

When cgit_cmd.want_repo was 0, we used to assume that the cmd would never
be invoked for a repo. But soon this will become untrue (the 'about' cmd
is rapidly approching), so from now on we will initialize any requested
repo even if want_repo==0 (and return an error if want_repo==1 but no repo
is specified).

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoRe-enable 'index-info' and add support for 'root-desc' in cgitrc
Lars Hjemli [Mon, 28 Apr 2008 22:55:34 +0000 (00:55 +0200)]
Re-enable 'index-info' and add support for 'root-desc' in cgitrc

The 'index-info' option got lost when the layout was converted from
sidebar to old-fashioned header (noticed by Harley Laue, thanks!), and
this commit re-enables it.

But there is now also an alternative in the 'root-desc' option; where
'index-info' specifies a file to include, 'root-desc' specifies the text
literally. This might be nicer for the one-liner descriptions which these
options typically provides.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMove included header-file out of repolist table
Lars Hjemli [Mon, 28 Apr 2008 22:35:49 +0000 (00:35 +0200)]
Move included header-file out of repolist table

When the 'index-header' option is specified in cgitrc we used to print
the included file content inside the repolist table, which is bad style.

This commit makes the included file be printed before the table.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoPrepare for 'about repo' page
Lars Hjemli [Mon, 28 Apr 2008 21:06:57 +0000 (23:06 +0200)]
Prepare for 'about repo' page

Each repo can include an external file which used to be included on the
top of the summary page, but it will now soon get a page of it own.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd page 'ls_cache'
Lars Hjemli [Mon, 28 Apr 2008 10:10:13 +0000 (12:10 +0200)]
Add page 'ls_cache'

This new page will list all entries found in the current cache, which is
useful when reviewing the new cache implementation. There are no links to
the new page, but it's reachable by adding 'p=ls_cache' to any cgit url.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoRedesign the caching layer
Lars Hjemli [Mon, 28 Apr 2008 09:32:42 +0000 (11:32 +0200)]
Redesign the caching layer

The original caching layer in cgit has no upper bound on the number of
concurrent cache entries, so when cgit is traversed by a spider (like the
googlebot), the cache might end up filling your disk. Also, if any error
occurs in the cache layer, no content is returned to the client.

This patch redesigns the caching layer to avoid these flaws by
* giving the cache a bound number of slots
* disabling the cache for the current request when errors occur

The cache size limit is implemented by hashing the querystring (the cache
lookup key) and generating a cache filename based on this hash modulo the
cache size. In order to detect hash collisions, the full lookup key (i.e.
the querystring) is stored in the cache file (separated from its associated
content by ascii 0).

The cache filename is the reversed 8-digit hexadecimal representation of

  hash(key) % cache_size

which should make the filesystem lookup pretty fast (if directory content
is indexed/sorted); reversing the representation avoids the problem where
all keys have equal prefix.

There is a new config option, cache-size, which sets the upper bound for
the cache. Default value for this option is 0, which has the same effect
as setting nocache=1 (hence nocache is now deprecated).

Included in this patch is also a new testfile which verifies that the
new option works as intended.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoui-diff: remove test on object type
Lars Hjemli [Thu, 24 Apr 2008 21:40:51 +0000 (23:40 +0200)]
ui-diff: remove test on object type

By removing the test for commit objects it's now possible to specify a
tag name for the id query-string parameter (it already worked for id2).

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoIntegrate diffstat with diff
Lars Hjemli [Thu, 24 Apr 2008 21:32:02 +0000 (23:32 +0200)]
Integrate diffstat with diff

This creates a generic diffstat function in ui-diff, which then is
invoked from cgit_print_diff with the result that both commit and diff-
view gets a diffstat.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoFix commitdiff annoyance
Lars Hjemli [Thu, 17 Apr 2008 16:29:50 +0000 (18:29 +0200)]
Fix commitdiff annoyance

Someone were a bit sloppy when the commitdiff got included 'inline' in
commit 89aa3c0d0a4c6d9885272602005975b763ea1604. This patch deletes a
stray `)` and makes sure the diffstat summary `<div>` is closed before
the full diff is printed.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoCleanup page header
Lars Hjemli [Mon, 14 Apr 2008 22:00:11 +0000 (00:00 +0200)]
Cleanup page header

Fix some invalid html, remove dead code.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoFix search in repo index even if caching is enabled
Lars Hjemli [Mon, 14 Apr 2008 21:07:52 +0000 (23:07 +0200)]
Fix search in repo index even if caching is enabled

The repository index page needed to include the querystring in the cache
filename.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMake a few more columns in repolist and log view clickable
Lars Hjemli [Mon, 14 Apr 2008 20:23:48 +0000 (22:23 +0200)]
Make a few more columns in repolist and log view clickable

Less mouse movement is nice.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMake branches, tags and log play better together in the summary view
Lars Hjemli [Mon, 14 Apr 2008 20:13:38 +0000 (22:13 +0200)]
Make branches, tags and log play better together in the summary view

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoFix more css ugliness
Lars Hjemli [Mon, 14 Apr 2008 20:10:33 +0000 (22:10 +0200)]
Fix more css ugliness

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agocgit.css: set form margins
Lars Hjemli [Mon, 14 Apr 2008 08:17:33 +0000 (10:17 +0200)]
cgit.css: set form margins

According to the css2 spec, htmlforms have 1.12em top and bottom margins. That
doesn't play well with the placement of the search form, so lets force it to
use 0em margins.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoFix css font-family
Lars Hjemli [Mon, 14 Apr 2008 08:00:59 +0000 (10:00 +0200)]
Fix css font-family

When the sidebar was introduced in v0.7 the default font-family property
got messed up, but this commit should fix the issue.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'lh/layout'
Lars Hjemli [Sun, 13 Apr 2008 10:48:44 +0000 (12:48 +0200)]
Merge branch 'lh/layout'

* lh/layout:
  Make repository search case insensitive
  Remove 'patch' link from tab, add to commit view
  Implement minimal freetext search in the repolist
  More layout fixes
  Minor fixup in tree-view css
  Reintroduce the branch switcher
  Add fixed link to index page from repo header
  Include diff in commit view
  Replace sidebar/logo

16 years agoMake repository search case insensitive
Lars Hjemli [Sun, 13 Apr 2008 10:42:27 +0000 (12:42 +0200)]
Make repository search case insensitive

This reuses the strcasestr() compiled or linked by libgit.a to implement a
case insensitive variation of the repository search.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoRemove 'patch' link from tab, add to commit view
Lars Hjemli [Sun, 13 Apr 2008 10:20:00 +0000 (12:20 +0200)]
Remove 'patch' link from tab, add to commit view

It's a bit confusing to enter the patch view from the tab, since it has no
layout. And the commit view has always lacked showing the commit id. Both of
these warts are fixed by this commit, which adds a new header line in the
commit view which shows the commit id as a 'permalink' to the current commit
and also adds a link to the patch view of the current commit.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoImplement minimal freetext search in the repolist
Lars Hjemli [Sun, 13 Apr 2008 09:57:10 +0000 (11:57 +0200)]
Implement minimal freetext search in the repolist

This makes the repolist much more usable when there's a lot of repositories
registered in cgitrc.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMore layout fixes
Lars Hjemli [Sun, 13 Apr 2008 08:57:11 +0000 (10:57 +0200)]
More layout fixes

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMinor fixup in tree-view css
Lars Hjemli [Sat, 12 Apr 2008 18:18:16 +0000 (20:18 +0200)]
Minor fixup in tree-view css

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoReintroduce the branch switcher
Lars Hjemli [Sat, 12 Apr 2008 18:11:49 +0000 (20:11 +0200)]
Reintroduce the branch switcher

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoAdd fixed link to index page from repo header
Lars Hjemli [Sat, 12 Apr 2008 17:59:41 +0000 (19:59 +0200)]
Add fixed link to index page from repo header

This makes it easier to get back to the index page, and also re-enables
the usage of logo-link in cgitrc.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoInclude diff in commit view
Lars Hjemli [Sat, 12 Apr 2008 13:53:53 +0000 (15:53 +0200)]
Include diff in commit view

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoReplace sidebar/logo
Lars Hjemli [Sat, 12 Apr 2008 13:53:31 +0000 (15:53 +0200)]
Replace sidebar/logo

This replaces the sidebar with a more 'common' header layout and also
updates the logo.

Not quite finished yet, though.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoUse GIT-1.5.5
Lars Hjemli [Wed, 9 Apr 2008 16:05:30 +0000 (18:05 +0200)]
Use GIT-1.5.5

16 years agoDon't specify mimetype in ui-blob.c
Lars Hjemli [Tue, 25 Mar 2008 01:43:51 +0000 (02:43 +0100)]
Don't specify mimetype in ui-blob.c

But be sure to specify correct filename. This way, the client can hopefully
guess a sensible mimetype based on the filename suffix, and cgit can ignore
the issue altogether.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
16 years agoMerge branch 'lh/cleanup'
Lars Hjemli [Tue, 8 Apr 2008 19:29:21 +0000 (21:29 +0200)]
Merge branch 'lh/cleanup'

* lh/cleanup: (21 commits)
  Reset ctx.repo to NULL when the config parser is finished
  Move cgit_parse_query() from parsing.c to html.c as http_parse_querystring()
  Move function for configfile parsing into configfile.[ch]
  Add cache.h
  Remove global and obsolete cgit_cmd
  Makefile: copy the QUIET constructs from the Makefile in git.git
  Move cgit_version from shared.c to cgit.c
  Makefile: autobuild dependency rules
  Initial Makefile cleanup
  Move non-generic functions from shared.c to cgit.c
  Add ui-shared.h
  Add separate header-files for each page/view
  Refactor snapshot support
  Add command dispatcher
  Remove obsolete cacheitem parameter to ui-functions
  Add struct cgit_page to cgit_context
  Introduce html.h
  Improve initialization of git directory
  Move cgit_repo into cgit_context
  Add all config variables into struct cgit_context
  ...

16 years agoReset ctx.repo to NULL when the config parser is finished
Lars Hjemli [Tue, 8 Apr 2008 19:27:12 +0000 (21:27 +0200)]
Reset ctx.repo to NULL when the config parser is finished

This global variable is used by the config parsing callback to keep track
of the currently configured repository. If it is not reset to NULL when
the config parser is finished, and neither `url` or `r` is specified on the
querystring, cgit will wrongly consider the last configured repo as
selected.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>