aboutsummaryrefslogtreecommitdiffstatshomepage
Commit message (Collapse)AuthorAge
...
* CGIT 0.8.2v0.8.2Lars Hjemli2009-02-01
| | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com>
* Use GIT-1.6.1.1Lars Hjemli2009-02-01
| | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com>
* Merge branch 'lh/binary'Lars Hjemli2009-02-01
|\
| * shared.c: avoid SEGFAULT when checking for binary buffersLars Hjemli2009-02-01
| | | | | | | | | | | | | | Before calling buffer_is_binary() we need to verify that the buffer is valid. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
| * ui-tree: show hexdump of binary blobsLars Hjemli2009-01-31
| | | | | | | | |<
                       cgit - cgi for git


This is an attempt to create a fast web interface for the git scm, using a
builtin cache to decrease server io-pressure.


Installation

Building cgit involves building a proper version of git. How to do this
depends on how you obtained the cgit sources:

a) If you're working in a cloned cgit repository, you first need to
initialize and update the git submodule:

  $ git submodule init     # register the git submodule in .git/config
  $ $EDITOR .git/config    # if you want to specify a different url for git
  $ git submodule update   # clone/fetch and checkout correct git version

b) If you're building from a cgit tarball, you can download a proper git
version like this:

  $ make get-git


When either a) or b) has been performed, you can build and install cgit like
this:

  $ make
  $ sudo make install

This will install cgit.cgi and cgit.css into "/var/www/htdocs/cgit". You can
configure this location (and a few other things) by providing a "cgit.conf"
file (see the Makefile for details).


Dependencies:
  -git 1.5.3
  -zip lib
  -crypto lib
  -openssl lib


Apache configuration

A new Directory-section must probably be added for cgit, possibly something
like this:

  <Directory "/var/www/htdocs/cgit/">
      AllowOverride None
      Options ExecCGI
      Order allow,deny
      Allow from all
  </Directory>


Runtime configuration

The file /etc/cgitrc is read by cgit before handling a request. In addition
to runtime parameters, this file also contains a list of the repositories
displayed by cgit.

A template cgitrc is shipped with the sources, and all parameters and default
values are documented in this file.


The cache

When cgit is invoked it looks for a cachefile matching the request and
returns it to the client. If no such cachefile exist (or if it has expired),
the content for the request is written into the proper cachefile before the
file is returned.

If the cachefile has expired but cgit is unable to obtain a lock for it, the
stale cachefile is returned to the client. This is done to favour page
throughput over page freshness.

The generated content contains the complete response to the client, including
the http-headers "Modified" and "Expires".


The missing features

* Submodule links in the directory listing page have a fixed format per
  repository. This should probably be extended to a generic map between
  submodule path and url.

* Branch- and tag-lists in the summary page can get very long, they should
  probably only show something like the ten "latest modified" branches and
  a similar number of "most recent" tags.

* There should be a new page for browsing refs/heads and refs/tags, with links
  from the summary page whenever the branch/tag lists overflow.

* The log-page should have more/better search options (author, committer,
  pickaxe, paths) and possibly support arbitrary revision specifiers.

* A set of test-scripts is required before cgit-1.0 can be released.

Patches/bugreports/suggestions/comments are always welcome, please feel free
to contact the author: hjemli@gmail.com
of commit decorationsLars Hjemli2009-01-27 | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | Add decorations to commit pagesJustin Waters2009-01-27 | | | | | | | | | | | | | | | | | | | | | This adds the tag and branch head decorations to the commit pages. This is similar to how commits are displayed in the standard gitweb interface. Signed-off-by: Justin Waters <justin.waters@timesys.com> * | | Merge branch 'og/tree-view-selection'Lars Hjemli2009-01-27 |\ \ \ | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | changed objects are outputted, allowing for selections of code onlyOnne Gorter2009-01-10 | | | | * | | | Merge branch 'lh/stats'Lars Hjemli2009-01-27 |\ \ \ \ | |_|/ / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Conflicts: cgit.c cgit.css cgit.h ui-tree.c Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | ui-stats.c: reuse cgit_add_hidden_formfields()Lars Hjemli2008-12-07 | | | | | | | | | | | | | | | | | | | | | | | | | | | | This makes sure that the currect branch and path is preserved when changing the stats period or author count. Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | ui-shared: externalize add_hidden_formfields()Lars Hjemli2008-12-07 | | | | | | | | | | | | | | | | | | | | | | | | This function will be reused by ui-stats.c in the next commit. Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | ui-tree: add link to stats page per pathLars Hjemli2008-12-07 | | | | | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | ui-shared: add and use cgit_stats_link()Lars Hjemli2008-12-07 | | | | | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | ui-stats: replace 'enable-stats' setting with 'max-stats'Lars Hjemli2008-12-07 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The new 'max-stats' and 'repo.max-stats' settings makes it possible to define the maximum statistics period, both globally and per repo. Hence, it is now feasible to allow statistics on repositories with a high commit frequency, like linux-2.6, by setting repo.max-stats to e.g. 'month'. Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | ui-stats: enable path-filtered statsLars Hjemli2008-12-07 | | | | | | | | | | | | | | | | | | | | | | | | | | | | When a path is specified on the querystring the commit statistics will now be filtered by this path. Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | Add a 'stats' page to each repoLars Hjemli2008-12-06 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This new page, which is disabled by default, can be used to print some statistics about the number of commits per period in the repository, where period can be either weeks, months, quarters or years. The function can be activated globally by setting 'enable-stats=1' in cgitrc and disabled for individual repos by setting 'repo.enable-stats=0'. Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | Merge branch 'stable'Lars Hjemli2009-01-12 |\ \ \ \ | | |_|/ | |/| | | * | | Makefile: install cgit.{css,png} in CGIT_DATA_PATHTodd Zullinger2009-01-12 | | | | | | | | | | | | | | | | | | | | | | | | | | | | CGIT_DATA_PATH defaults to CGIT_SCRIPT_PATH, but allows users to install the cgi and the data files in different locations. Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | Makefile: add INSTALL var to set install commandTodd Zullinger2009-01-12 | | | | | | | | | | | | | | | | | | | | | | | | | | | | This also explicitly sets the modes for installed files (755 for the .cgi, 644 for the .css and .png). Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | Fix tar.bz2 snapshot exampleTodd Zullinger2009-01-12 | | | | | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | Merge branch 'stable'Lars Hjemli2009-01-11 |\| | | | * | | Avoid SEGFAULT on invalid requestsLars Hjemli2009-01-11 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When an unknown page is requested, either on the querystring or via PATH_INFO, we end up with a null-referencing cgit_cmd. This null- pointer is then used as argument to the hc() function (which decides what tab to render as 'active'), but this function failed to check if a valid cmd was specified and a SEGFAULT would occur. This patch fixes the issue by introducing a 'fallback-cmd' which specifies what tab to render as 'active' when no valid cmd is requested. While at it, we now also keep track of the active repository even if an invalid cmd was requested since we want to show the error message about the invalid request in the correct context. Noticed-by: Robin Redeker <elmex@ta-sa.org> Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | Make all tags viewableRobin Redeker2009-01-11 | | | | | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | Merge branch 'stable'Lars Hjemli2009-01-11 |\| | | | * | | ui-tag: escape tagnames properlyLars Hjemli2009-01-11 | | | | | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | Change toggle to more meaningful termJustin Waters2009-01-11 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In the log interface, there is a toggle link at the top, but it isn't clear what's being toggled. I've changed it to "Expand" and "Collapse" to make it clear that you are getting more and less information, respectively. Signed-off-by: Justin Waters <justin.waters@timesys.com> * | | | Merge branch 'snapshot-fixes'Lars Hjemli2009-01-11 |\ \ \ \ | * | | | tests/t0107-snapshot.sh: make testscript match updated snapshot behaviorLars Hjemli2008-12-28 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Since cgit now returns a 404 error when the snapshot filename cannot be resolved to a commit object, the testscript needs to request a valid snapshot name. Also, the script assumed that the toplevel directory in the snapshot would get the name of the repository but it's now named similar to the requested snapshot. Signed-off-by: Lars Hjemli <hjemli@gmail.com> | * | | | return 404 if snapshot is not foundNatanael Copa2008-12-28 | | | | | | | | | | | | | | | | | | | | Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | | Merge branch 'lh/mimetypes'Lars Hjemli2009-01-11 |\ \ \ \ \ | * | | | | ui-snapshot.c: change mime-type for tar.gz and tar.bz2Lars Hjemli2008-12-26 | |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The updated mime-types seems to work better than the old ones with both safari and firefox. Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | | Merge branch 'lh/virtual-root'Lars Hjemli2009-01-11 |\ \ \ \ \ | * | | | | Untie logic for SCRIPT_NAME and PATH_INFOLars Hjemli2008-12-26 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | SCRIPT_NAME is used as fallback for virtual-root when virtual-root is unspecified in cgitrc and PATH_INFO is used as fallback for the query- string parameter 'url' when the latter is unspecified. But until now, the use of PATH_INFO depended on virtual-root also being unspecified, i.e. it was impossible to use PATH_INFO when virtual-root was specified. This commit makes the fallback on SCRIPT_NAME and PATH_INFO independent code paths, i.e. it is now possible to specify virtual-root in cgitrc while still using PATH_INFO (instead of rewrite rules) to get 'pretty urls'. Noticed-by: Jack Moffitt <jack@chesspark.com> Noticed-by: LiKai Liu <liulk@cs.bu.edu> Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | | | Merge branch 'stable'Lars Hjemli2009-01-11 |\ \ \ \ \ \ | | |_|/ / / | |/| | | | | * | | | | Makefile: avoid libcurl when building gitLars Hjemli2009-01-10 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We don't need support for fetching/pushing in libgit.a, hence we don't need to link with libcurl. Noticed-by: Robin Redeker <elmex@ta-sa.org> Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | | | ui-log: show name-decorations in log outputLars Hjemli2009-01-11 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Commits are now decorated with a clickable 'label' for each ref pointing at it, similar to how gitweb and gitk displays commit decorations. Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | | | ui-refs: avoid SEGFAULT on lightweight tagsRobin Redeker2009-01-10 | |_|_|_|/ |/| | | | | | | | | | | | | | | | | | | Signed-off-by: Robin Redeker <elmex@ta-sa.org> Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | | Merge branch 'stable'Lars Hjemli2009-01-06 |\| | | | | * | | | ui-tree.c: do not add blank line when displaying blobsLars Hjemli2009-01-06 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Also, fix a related bug in the test-suite. Noticed-by: Jim Meyering <jim@meyering.net> Signed-off-by: Lars Hjemli <hjemli@gmail.com> * | | | | Merge branch 'stable'Lars Hjemli2008-12-30 |\| | | | | |_|/ / |/| | |