From: "H.Merijn Brand" <h.m.brand@xs4all.nl>
To: git@vger.kernel.org
Subject: Feature suggestion: git-hist
Date: Wed, 30 Jul 2008 13:38:59 +0200 [thread overview]
Message-ID: <20080730133859.368bbd92@pc09.procura.nl> (raw)
[-- Attachment #1: Type: text/plain, Size: 6480 bytes --]
I've talked about this with Arjen, and he suggested to put it here.
Please Cc me too, as I have little time to follow this quite busy list.
Suggestion
Add a new command: 'git-hist' that will show a blame log of a
single file with each line `tagged' with the most recent tag
plus the number of changes since that tag.
Relationale.
Coming from SCCS, each file `keeps' a version in a keyword like
%R%.%L% which is included in the file when a release is made.
The unix command 'what' will show all SCCS id's when used on a
object, like
% what probev | head -10
probev:
$Revision: 92453-07 linker linker crt0.o B.11.60 070209$
probev.ic 5.27 [07/11/14]
Make info: HP-UX B.11.00 9000/800; 14 Jul 2008, 14:52; v04.3.6.04:v82BC anrs.ic 5.5 [07/04/10]
arsmon.ic 5.19 [08/07/09]
controle.ic 5.40 [2008-03-18]
goedmut.ic 5.19 [07/05/16]
gvh.ic 5.8 [06/06/13]
inw.ic 5.8 [06/06/12]
All software has bugs, so has ours, and we ship updates, just as
git makes updates available to the world. I just updated to the
most recent 1.5.6.4.
We make our updates available to our customers, but they
sometimes wait weeks or months to install the updates, but still
complain about bugs that already have been fixed and for which
they already received an update.
I can ask them what version they have, and I can then check if
the complaint was already addressed in an update that was
already released. In SCCS this was easy: they tell me the output
of the what command, I check if the bug was fixed in a newer
version and the answer is present. No such luck in git, as the
stamps are (non-sequitive) SHA id's. As we moved to git, we now
have to update those id's by hand, as the customers are used to
it. (At least we can now use readable date formats)
Implementation
Attached is my perl script git-hist, which is how I currently
use it, which will show the blame log of a file, with each line
prefixed with the tag plus changes since. So I can tell that if
the customer runs release version 0.34, the line in question has
been added before or after.
* Tag all releases with a version number like 5.10.0 or
5.10.1-RC2
(give or take the annoying quircks that git refuses some characters
in tag names, which changed without warning in the 1.5.x track so
I had to manually rename all my 'v 0.53' tags to loose the space)
* Count changes since last tag
# git-hist *pm | perl -ne'63..83 and print'
09d4472 2007-12-06 13:25:58 63: allow_loose_quotes => 0,
09d4472 2007-12-06 13:25:58 64: allow_loose_escapes => 0,
09d4472 2007-12-06 13:25:58 65: allow_whitespace => 0,
caf4798 2008-02-19 17:56:36 0.34 + 004 66: blank_is_undef => 0,
09d4472 2007-12-06 13:25:58 67: verbatim => 0,
09d4472 2007-12-06 13:25:58 68: types => undef,
09d4472 2007-12-06 13:25:58 69:
8648db0 2008-03-27 18:37:54 0.37 + 002 70:
09d4472 2007-12-06 13:25:58 71: _EOF => 0,
09d4472 2007-12-06 13:25:58 72: _STATUS => undef,
09d4472 2007-12-06 13:25:58 73: _FIELDS => undef,
09d4472 2007-12-06 13:25:58 74: _FFLAGS => undef,
09d4472 2007-12-06 13:25:58 75: _STRING => undef,
09d4472 2007-12-06 13:25:58 76: _ERROR_INPUT => undef,
2b95026 2008-04-04 11:10:09 0.37 + 006 77: _COLUMN_NAMES => undef,
ce53d02 2008-04-06 00:40:26 0.37 + 016 78: _BOUND_COLUMNS => undef,
09d4472 2007-12-06 13:25:58 79: );
caf4798 2008-02-19 17:56:36 0.34 + 004 80: my $last_new_err = "";
09d4472 2007-12-06 13:25:58 81:
09d4472 2007-12-06 13:25:58 82: sub new
09d4472 2007-12-06 13:25:58 83: {
Or for a perl file
# git-hist xsutils.c | perl -ne'30..50 and print'
02ca0a6 2005-04-21 17:38:30 perl-5.9.2 + 104 30: PERL_XS_EXPORT_C void XS_attributes_bootstrap(pTHX_ CV *cv);
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 31:
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 32:
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 33: /*
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 34: * Note that only ${pkg}::bootstrap definitions should go here.
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 35: * This helps keep down the start-up time, which is especially
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 36: * relevant for users who don't invoke any features which are
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 37: * (partially) implemented here.
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 38: *
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 39: * The various bootstrap definitions can take care of doing
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 40: * package-specific newXS() calls. Since the layout of the
2136f35 2000-02-04 05:58:57 perl-5.005 + 2832 41: * bundled *.pm files is in a version-specific directory,
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 42: * version checks in these bootstrap calls are optional.
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 43: */
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 44:
02d011f 2006-05-02 19:46:38 perl-5.9.3 + 950 45: static const char file[] = __FILE__;
02d011f 2006-05-02 19:46:38 perl-5.9.3 + 950 46:
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 47: void
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 48: Perl_boot_core_xsutils(pTHX)
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 49: {
d66c5aa 1999-09-07 19:25:07 perl-5.005 + 1988 50: newXS("attributes::bootstrap", XS_attributes_bootstrap, file);
--
H.Merijn Brand Amsterdam Perl Mongers http://amsterdam.pm.org/
using & porting perl 5.6.2, 5.8.x, 5.10.x, 5.11.x on HP-UX 10.20, 11.00,
11.11, 11.23, and 11.31, SuSE 10.1, 10.2, and 10.3, AIX 5.2, and Cygwin.
http://mirrors.develooper.com/hpux/ http://www.test-smoke.org/
http://qa.perl.org http://www.goldmark.org/jeff/stupid-disclaimers/
[-- Attachment #2: git-hist --]
[-- Type: application/octet-stream, Size: 1102 bytes --]
#!/pro/bin/perl
# git-hist file ...
# (c) 2008 H.Merijn Brand for PROCURA B.V.
use strict;
use warnings;
sub pr_time
{
my @d = @_;
sprintf "%4d-%02d-%02d %02d:%02d:%02d", 1900 + $d[5], ++$d[4], @d[3,2,1,0];
} # pr_time
my @hsh;
my %log;
{ local @ARGV = ("git-log --pretty=format:'%h %ct %s' |");
while (<>) {
my ($hsh, $time, $text) = (m/^(\S+)\s+([0-9]+)\s+(.*)/);
push @hsh, $hsh;
$log{$hsh} = [ "", $text, pr_time localtime $time ];
}
}
{ local @ARGV = ("git-show-ref --tags |");
while (<>) {
m{(\S{7}).*/(.*)} or next;
$log{$1}[0] = $2;
}
}
{ my $tag = "";
my $inc;
foreach my $hsh (reverse @hsh) {
if ($log{$hsh}[0]) {
$tag = $log{$hsh}[0];
$inc = "001";
}
elsif ($tag) {
$log{$hsh}[0] = sprintf "%-13s + %s", $tag, $inc++;
}
}
}
foreach my $file (@ARGV) {
open my $blame, "-|", "git-blame $file" or next;
while (<$blame>) {
my ($hsh, $lnr, $txt) =
m/^\^?([0-9a-f]{7}).*?\s+([0-9]+)\)(.*)/ or next;
printf "%.7s %s %-20s %5d:%s\n",
$hsh, $log{$hsh}[2], $log{$hsh}[0], $lnr, $txt;
}
}
next reply other threads:[~2008-07-30 11:52 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-07-30 11:38 H.Merijn Brand [this message]
2008-07-30 12:03 ` Feature suggestion: git-hist Pieter de Bie
2008-07-30 12:14 ` H.Merijn Brand
2008-07-30 13:33 ` Lars Noschinski
2008-07-30 13:58 ` H.Merijn Brand
2008-07-30 14:55 ` Miklos Vajna
2008-07-30 15:03 ` H.Merijn Brand
2008-07-30 15:23 ` Santi Béjar
2008-07-30 15:58 ` Avery Pennarun
2008-07-30 16:34 ` Lars Noschinski
2008-07-30 15:18 ` Santi Béjar
2008-07-30 15:29 ` H.Merijn Brand
[not found] ` <FA2D570A-B2B1-4994-AA6A-9C0C55E69900@silverinsanity.com>
2008-07-30 16:26 ` Merging submodules (was Re: Feature suggestion: git-hist) H.Merijn Brand
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20080730133859.368bbd92@pc09.procura.nl \
--to=h.m.brand@xs4all.nl \
--cc=git@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.