The ultimate goal is for "git help" to classify common commands by group. Toward this end, a subsequent patch will add a new "common groups" section to command-list.txt preceding the actual command list. As preparation, teach existing command-list.txt parsing machinery, which doesn't care about grouping, to skip over this upcoming "common groups" section. Signed-off-by: Eric Sunshine <sunshine@sunshineco.com> Signed-off-by: Sébastien Guimmara <sebastien.guimmara@gmail.com> Reviewed-by: Eric Sunshine <sunshine@sunshineco.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			79 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
#!/usr/bin/perl -w
 | 
						|
 | 
						|
use File::Compare qw(compare);
 | 
						|
 | 
						|
sub format_one {
 | 
						|
	my ($out, $nameattr) = @_;
 | 
						|
	my ($name, $attr) = @$nameattr;
 | 
						|
	my ($state, $description);
 | 
						|
	$state = 0;
 | 
						|
	open I, '<', "$name.txt" or die "No such file $name.txt";
 | 
						|
	while (<I>) {
 | 
						|
		if (/^NAME$/) {
 | 
						|
			$state = 1;
 | 
						|
			next;
 | 
						|
		}
 | 
						|
		if ($state == 1 && /^----$/) {
 | 
						|
			$state = 2;
 | 
						|
			next;
 | 
						|
		}
 | 
						|
		next if ($state != 2);
 | 
						|
		chomp;
 | 
						|
		$description = $_;
 | 
						|
		last;
 | 
						|
	}
 | 
						|
	close I;
 | 
						|
	if (!defined $description) {
 | 
						|
		die "No description found in $name.txt";
 | 
						|
	}
 | 
						|
	if (my ($verify_name, $text) = ($description =~ /^($name) - (.*)/)) {
 | 
						|
		print $out "linkgit:$name\[1\]::\n\t";
 | 
						|
		if ($attr =~ / deprecated /) {
 | 
						|
			print $out "(deprecated) ";
 | 
						|
		}
 | 
						|
		print $out "$text.\n\n";
 | 
						|
	}
 | 
						|
	else {
 | 
						|
		die "Description does not match $name: $description";
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
while (<>) {
 | 
						|
	last if /^### command list/;
 | 
						|
}
 | 
						|
 | 
						|
my %cmds = ();
 | 
						|
for (sort <>) {
 | 
						|
	next if /^#/;
 | 
						|
 | 
						|
	chomp;
 | 
						|
	my ($name, $cat, $attr) = /^(\S+)\s+(.*?)(?:\s+(.*))?$/;
 | 
						|
	$attr = '' unless defined $attr;
 | 
						|
	push @{$cmds{$cat}}, [$name, " $attr "];
 | 
						|
}
 | 
						|
 | 
						|
for my $cat (qw(ancillaryinterrogators
 | 
						|
		ancillarymanipulators
 | 
						|
		mainporcelain
 | 
						|
		plumbinginterrogators
 | 
						|
		plumbingmanipulators
 | 
						|
		synchingrepositories
 | 
						|
		foreignscminterface
 | 
						|
		purehelpers
 | 
						|
		synchelpers)) {
 | 
						|
	my $out = "cmds-$cat.txt";
 | 
						|
	open O, '>', "$out+" or die "Cannot open output file $out+";
 | 
						|
	for (@{$cmds{$cat}}) {
 | 
						|
		format_one(\*O, $_);
 | 
						|
	}
 | 
						|
	close O;
 | 
						|
 | 
						|
	if (-f "$out" && compare("$out", "$out+") == 0) {
 | 
						|
		unlink "$out+";
 | 
						|
	}
 | 
						|
	else {
 | 
						|
		print STDERR "$out\n";
 | 
						|
		rename "$out+", "$out";
 | 
						|
	}
 | 
						|
}
 |