git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] Optional grouping of projects by category.
@ 2008-07-27  0:36 Sebastien Cevey
  2008-07-27  8:53 ` Jakub Narebski
  0 siblings, 1 reply; 4+ messages in thread
From: Sebastien Cevey @ 2008-07-27  0:36 UTC (permalink / raw)
  To: git

This adds the GITWEB_GROUP_CATEGORIES option which, if enabled, will
result in grouping projects by category on the project list page.  The
category is specified for each project by the $GIT_DIR/category file
or the 'category' variable in its configuration file.

The feature is inspired from Sham Chukoury's patch for the XMMS2
gitweb, but has been rewritten for the current gitweb development
HEAD.

Thanks to Florian Ragwitz for Perl tips.

Signed-off-by: Sebastien Cevey <seb@cine7.net>
---

We used to run a modified gitweb for XMMS2 Git repositories which,
among other things, grouped projects by categories.  The feature was
lost when we caught up with upstream gitweb, but I've rehacked this
feature back on top of the current HEAD.

I assume this might be a wanted feature, or at least it was in Jakub's
old wishlist he posted on 2006-06-21 02:51:18.

Feedback on the idea and implementation are welcome.

 Makefile           |    2 +
 gitweb/README      |   11 ++++
 gitweb/gitweb.css  |    5 ++
 gitweb/gitweb.perl |  129 ++++++++++++++++++++++++++++++++++++++--------------
 4 files changed, 112 insertions(+), 35 deletions(-)

diff --git a/Makefile b/Makefile
index 798a2f2..2309260 100644
--- a/Makefile
+++ b/Makefile
@@ -208,6 +208,7 @@ GITWEB_EXPORT_OK =
 GITWEB_STRICT_EXPORT =
 GITWEB_BASE_URL =
 GITWEB_LIST =
+GITWEB_GROUP_CATEGORIES =
 GITWEB_HOMETEXT = indextext.html
 GITWEB_CSS = gitweb.css
 GITWEB_LOGO = git-logo.png
@@ -1145,6 +1146,7 @@ gitweb/gitweb.cgi: gitweb/gitweb.perl
 	    -e 's|++GITWEB_STRICT_EXPORT++|$(GITWEB_STRICT_EXPORT)|g' \
 	    -e 's|++GITWEB_BASE_URL++|$(GITWEB_BASE_URL)|g' \
 	    -e 's|++GITWEB_LIST++|$(GITWEB_LIST)|g' \
+	    -e 's|++GITWEB_GROUP_CATEGORIES++|$(GITWEB_GROUP_CATEGORIES)|g' \
 	    -e 's|++GITWEB_HOMETEXT++|$(GITWEB_HOMETEXT)|g' \
 	    -e 's|++GITWEB_CSS++|$(GITWEB_CSS)|g' \
 	    -e 's|++GITWEB_LOGO++|$(GITWEB_LOGO)|g' \
diff --git a/gitweb/README b/gitweb/README
index 6908036..2b77c20 100644
--- a/gitweb/README
+++ b/gitweb/README
@@ -38,6 +38,11 @@ You can specify the following configuration variables when building GIT:
    using gitweb" in INSTALL file for gitweb to find out how to generate
    such file from scan of a directory. [No default, which means use root
    directory for projects]
+ * GITWEB_GROUP_CATEGORIES
+   Groups projects by category on the main projects list page if set
+   to true.  The category of a project is determined by the
+   $GIT_DIR/category file or the 'category' variable in its
+   configuration file.  [No default / Not set]
  * GITWEB_EXPORT_OK
    Show repository only if this file exists (in repository).  Only
    effective if this variable evaluates to true.  [No default / Not set]
@@ -188,6 +193,12 @@ not include variables usually directly set during build):
    full description is available as 'title' attribute (usually shown on
    mouseover).  By default set to 25, which might be too small if you
    use long project descriptions.
+ * $projects_list_group_categories
+   Enables the grouping of projects by category on the project list page.
+ * $project_list_default_category
+   Default category for projects for which none is specified.  If set
+   to the empty string, such projects will remain uncategorized and
+   listed at the top, above categorized projects.
  * @git_base_url_list
    List of git base URLs used for URL to where fetch project from, shown
    in project summary page.  Full URL is "$git_base_url/$project".
diff --git a/gitweb/gitweb.css b/gitweb/gitweb.css
index aa0eeca..7f1e2cc 100644
--- a/gitweb/gitweb.css
+++ b/gitweb/gitweb.css
@@ -264,6 +264,11 @@ td.current_head {
 	text-decoration: underline;
 }
 
+td.category {
+	padding-top: 1em;
+	font-weight: bold;
+}
+
 table.diff_tree span.file_status.new {
 	color: #008000;
 }
diff --git a/gitweb/gitweb.perl b/gitweb/gitweb.perl
index 90cd99b..fe8ae72 100755
--- a/gitweb/gitweb.perl
+++ b/gitweb/gitweb.perl
@@ -78,6 +78,13 @@ our $projects_list = "++GITWEB_LIST++";
 # the width (in characters) of the projects list "Description" column
 our $projects_list_description_width = 25;
 
+# group projects by category on the projects list
+our $projects_list_group_categories = "++GITWEB_GROUP_CATEGORIES++";
+
+# default category if none specified
+# (leave the empty string for no category)
+our $project_list_default_category = "";
+
 # default order of projects list
 # valid values are none, project, descr, owner, and age
 our $default_projects_order = "project";
@@ -1710,18 +1717,28 @@ sub git_get_path_by_hash {
 ## ......................................................................
 ## git utility functions, directly accessing git repository
 
-sub git_get_project_description {
-	my $path = shift;
+sub git_get_project_config_from_file {
+	my ($name, $path) = @_;
 
 	$git_dir = "$projectroot/$path";
-	open my $fd, "$git_dir/description"
-		or return git_get_project_config('description');
-	my $descr = <$fd>;
+	open my $fd, "<", "$git_dir/$name"
+		or return git_get_project_config($name);
+	my $conf = <$fd>;
 	close $fd;
-	if (defined $descr) {
-		chomp $descr;
+	if (defined $conf) {
+		chomp $conf;
 	}
-	return $descr;
+	return $conf;
+}
+
+sub git_get_project_description {
+	my $path = shift;
+	return git_get_project_config_from_file('description', $path);
+}
+
+sub git_get_project_category {
+	my $path = shift;
+	return git_get_project_config_from_file('category', $path);
 }
 
 sub git_get_project_url_list {
@@ -3535,8 +3552,9 @@ sub git_patchset_body {
 
 # . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
 
-# fills project list info (age, description, owner, forks) for each
-# project in the list, removing invalid projects from returned list
+# fills project list info (age, description, owner, category, forks)
+# for each project in the list, removing invalid projects from
+# returned list
 # NOTE: modifies $projlist, but does not remove entries from it
 sub fill_project_list_info {
 	my ($projlist, $check_forks) = @_;
@@ -3558,6 +3576,11 @@ sub fill_project_list_info {
 		if (!defined $pr->{'owner'}) {
 			$pr->{'owner'} = git_get_project_owner("$pr->{'path'}") || "";
 		}
+		if ($projects_list_group_categories && !defined $pr->{'cat'}) {
+			my $cat = git_get_project_category($pr->{'path'}) ||
+			                                   $project_list_default_category;
+			$pr->{'cat'} = to_utf8($cat);
+		}
 		if ($check_forks) {
 			my $pname = $pr->{'path'};
 			if (($pname =~ s/\.git$//) &&
@@ -3574,6 +3597,17 @@ sub fill_project_list_info {
 	return @projects;
 }
 
+sub build_sorted_category_list {
+	my ($projlist) = @_;
+	my %categories;
+
+	for my $pr (@{ $projlist }) {
+		push @{$categories{ $pr->{'cat'} }}, $pr;
+	}
+
+	return %categories;
+}
+
 # print 'sort by' <th> element, either sorting by $key if $name eq $order
 # (changing $list), or generating 'sort by $name' replay link otherwise
 sub print_sort_th {
@@ -3604,36 +3638,15 @@ sub print_sort_th_num {
 	print_sort_th(0, @_);
 }
 
-sub git_project_list_body {
-	my ($projlist, $order, $from, $to, $extra, $no_header) = @_;
-
-	my ($check_forks) = gitweb_check_feature('forks');
-	my @projects = fill_project_list_info($projlist, $check_forks);
+sub print_project_rows {
+	my ($projects, $from, $to, $check_forks) = @_;
 
-	$order ||= $default_projects_order;
 	$from = 0 unless defined $from;
-	$to = $#projects if (!defined $to || $#projects < $to);
+	$to = $#$projects if (!defined $to || $#$projects < $to);
 
-	print "<table class=\"project_list\">\n";
-	unless ($no_header) {
-		print "<tr>\n";
-		if ($check_forks) {
-			print "<th></th>\n";
-		}
-		print_sort_th_str('project', $order, 'path',
-		                  'Project', \@projects);
-		print_sort_th_str('descr', $order, 'descr_long',
-		                  'Description', \@projects);
-		print_sort_th_str('owner', $order, 'owner',
-		                  'Owner', \@projects);
-		print_sort_th_num('age', $order, 'age',
-		                  'Last Change', \@projects);
-		print "<th></th>\n" . # for links
-		      "</tr>\n";
-	}
 	my $alternate = 1;
 	for (my $i = $from; $i <= $to; $i++) {
-		my $pr = $projects[$i];
+		my $pr = $projects->[$i];
 		if ($alternate) {
 			print "<tr class=\"dark\">\n";
 		} else {
@@ -3665,6 +3678,52 @@ sub git_project_list_body {
 		      "</td>\n" .
 		      "</tr>\n";
 	}
+}
+
+sub git_project_list_body {
+	my ($projlist, $order, $from, $to, $extra, $no_header) = @_;
+
+	my ($check_forks) = gitweb_check_feature('forks');
+	my @all_projects = fill_project_list_info($projlist, $check_forks);
+
+	$order ||= $default_projects_order;
+
+	print "<table class=\"project_list\">\n";
+	unless ($no_header) {
+		print "<tr>\n";
+		if ($check_forks) {
+			print "<th></th>\n";
+		}
+		print_sort_th_str('project', $order, 'path',
+		                  'Project', \@all_projects);
+		print_sort_th_str('descr', $order, 'descr_long',
+		                  'Description', \@all_projects);
+		print_sort_th_str('owner', $order, 'owner',
+		                  'Owner', \@all_projects);
+		print_sort_th_num('age', $order, 'age',
+		                  'Last Change', \@all_projects);
+		print "<th></th>\n" . # for links
+		      "</tr>\n";
+	}
+
+	if ($projects_list_group_categories) {
+		my %categories = build_sorted_category_list(\@all_projects);
+		foreach my $cat (sort keys %categories) {
+			unless ($cat eq "") {
+				print "<tr>\n";
+				if ($check_forks) {
+					print "<td></td>\n";
+				}
+				print "<td class=\"category\" colspan=\"5\">" . $cat . "</td>\n";
+				print "</tr>\n";
+			}
+
+			print_project_rows($categories{$cat}, $from, $to, $check_forks);
+		}
+	} else {
+		print_project_rows(\@all_projects, $from, $to, $check_forks);
+	}
+
 	if (defined $extra) {
 		print "<tr>\n";
 		if ($check_forks) {
-- 
1.5.3.7

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH] Optional grouping of projects by category.
  2008-07-27  0:36 [PATCH] Optional grouping of projects by category Sebastien Cevey
@ 2008-07-27  8:53 ` Jakub Narebski
  2008-07-28 18:03   ` Sébastien Cevey
  2008-09-05 12:06   ` Sébastien Cevey
  0 siblings, 2 replies; 4+ messages in thread
From: Jakub Narebski @ 2008-07-27  8:53 UTC (permalink / raw)
  To: Sebastien Cevey; +Cc: git

Sebastien Cevey <seb@cine7.net> writes:

> This adds the GITWEB_GROUP_CATEGORIES option which, if enabled, will
> result in grouping projects by category on the project list page.  The
> category is specified for each project by the $GIT_DIR/category file
> or the 'category' variable in its configuration file.
> 
> The feature is inspired from Sham Chukoury's patch for the XMMS2
> gitweb, but has been rewritten for the current gitweb development
> HEAD.
> 
> Thanks to Florian Ragwitz for Perl tips.

Thanks a lot.  I don't know if it is a good time, with git being in
feature freeze, and GSoC project about adding caching to gitweb in the
works, but I'll take this patch and resend it if needed.  I'll try to
comment on it soon.

That said, I think that the subject (oneline commit summary) should
include 'gitweb', e.g.

  "gitweb: Optional grouping of projects by category"

-- 
Jakub Narebski
Poland
ShadeHawk on #git

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] Optional grouping of projects by category.
  2008-07-27  8:53 ` Jakub Narebski
@ 2008-07-28 18:03   ` Sébastien Cevey
  2008-09-05 12:06   ` Sébastien Cevey
  1 sibling, 0 replies; 4+ messages in thread
From: Sébastien Cevey @ 2008-07-28 18:03 UTC (permalink / raw)
  To: Jakub Narebski; +Cc: git

At Sun, 27 Jul 2008 01:53:43 -0700 (PDT), Jakub Narebski wrote:

> Thanks a lot.  I don't know if it is a good time, with git being in
> feature freeze, and GSoC project about adding caching to gitweb in
> the works, but I'll take this patch and resend it if needed.  I'll
> try to comment on it soon.

Great, looking forward to that, thanks!

-- 
Sébastien Cevey / inso.cc

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] Optional grouping of projects by category.
  2008-07-27  8:53 ` Jakub Narebski
  2008-07-28 18:03   ` Sébastien Cevey
@ 2008-09-05 12:06   ` Sébastien Cevey
  1 sibling, 0 replies; 4+ messages in thread
From: Sébastien Cevey @ 2008-09-05 12:06 UTC (permalink / raw)
  To: Jakub Narebski; +Cc: git

At Sun, 27 Jul 2008 01:53:43 -0700 (PDT), Jakub Narebski wrote:

Hello,

> Thanks a lot.  I don't know if it is a good time, with git being in
> feature freeze, and GSoC project about adding caching to gitweb in
> the works, but I'll take this patch and resend it if needed.

I just saw a gitweb feature patch was merged three days ago, so I was
wondering if the feature freeze is over?  I wanted to ping you and ask
if you want me to resend the patch, or if you had time to take a look
at it?

Thanks!

-- 
Sébastien Cevey / inso.cc

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2008-09-05 12:18 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-07-27  0:36 [PATCH] Optional grouping of projects by category Sebastien Cevey
2008-07-27  8:53 ` Jakub Narebski
2008-07-28 18:03   ` Sébastien Cevey
2008-09-05 12:06   ` Sébastien Cevey

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).