- eval '(exit $?0)' && eval 'exec perl -S $0 ${1+"$@"}'
- & eval 'exec perl -S $0 $argv:q'
- if 0;
- # THE PRECEEDING STUFF EXECS perl via $PATH
- # -*-Fundamental-*-
- # (I'm a Emacsian Fundamentalist)
- # $Id: //guest/richard_geiger/utils/cvs2p4_meta/MANIFEST#9 $
- #
- # Copyright (c) 1996 Network Appliance, Inc.
- #
- # You may distribute under the terms of the Artistic License, as
- # specified in the README file included in the cvs2p4
- # distribution.
- #
- # Original Author: Richard Geiger for Network Appliance, Inc.
- #
- # $Id: //guest/richard_geiger/utils/cvs2p4_meta/MANIFEST#9 $
- # Here is the manifest.
- # You can update the checksums with "-gen"
- #
- require 5.000;
- use Carp;
- $| = 1;
- ($Myname = $0) =~ s%^.*/%%;
- $Mydirname = &dirname($0);
- chdir $Mydirname || die;
- #path sum1 sum2 opts
- $manifest = <<'MANIFEST';
- MANIFEST:-:-
- Artistic:08887:6:mode=444
- README:37455:13:mode=444
- NEWS:20203:15:mode=444
- bin/genmetadata:31193:24:mode=555
- bin/genchanges:43246:5:mode=555
- bin/dochanges:17037:17:mode=555
- bin/dolabels:47713:4:mode=555
- bin/revmap:03064:2:mode=555
- lib/util.pl:00782:3:mode=444
- test/file,v:23982:4:mode=444
- test/phone.gif,v:28326:1:mode=444
- test/dollar$file,v:32426:1:mode=444
- test/space file,v:32426:1:mode=444
- test/datefile_readd,v:30938:1:mode=444
- test/Attic/datefile,v:12361:1:mode=444
- test/config:30867:6:mode=444
- test/runtest:02218:6:mode=555
- test/norm:06427:1:mode=555
- test/metadata.good:21208:2:mode=444
- test/lines.good:21288:1:mode=444
- test/changes.good:30668:2:mode=444
- test/p4_changes_-l.good:04922:4:mode=444
- test/p4_describe.good:20411:10:mode=444
- test/p4_filesat.good:45485:1:mode=444
- test/p4_labels.good:06140:1:mode=444
- MANIFEST
- @manifest = split(/\n/, $manifest);
- $Usage = <<LIT;
- $Myname: usage: $Myname [-gen|-tar <vers>]
- LIT
- sub x
- {
- my ($cmd) = @_;
- print "$Myname: $cmd\n";
- if (! $noexec)
- {
- $status = system $cmd;
- if ($status)
- { printf "$Myname: *** exit status %d\n", $status / 256; exit 1; }
- }
- }
- sub dirname
- {
- my ($dir) = @_;
- $dir =~ s%^$%.%; $dir = "$dir/";
- if ($dir =~ m%^/[^/]*//*$%) { return "/"; }
- if ($dir =~ m%^.*[^/]//*[^/][^/]*//*$%)
- { $dir =~ s%^(.*[^/])//*[^/][^/]*//*$%$1%; { return $dir; } }
- return ".";
- }
- sub usage
- {
- print STDERR $Usage;
- exit 1;
- }
- sub help
- {
- print STDERR <<LIT;
- $Usage
- $Myname is used to help verify the completeness of the cvs2p4
- distribution kit.
- LIT
- exit 1;
- }
- $uname = `/bin/uname -a`; chop $uname;
- ($u_os, $u_host, $u_osrel) = split(/\s+/, $uname);
- if ($u_os eq "SunOS" && $u_osrel =~ /^5\./)
- { $sum = "/usr/ucb/sum"; }
- elsif ($u_os eq "SunOS" && $u_osrel =~ /^4\./)
- { $sum = "/bin/sum"; }
- elsif ($u_os eq "OSF1" && $u_osrel =~ /^V[34]\./)
- { $sum = "/bin/sum" }
- elsif ($u_os eq "FreeBSD" && $u_osrel =~ /^2\.\./)
- { $sum = "NONE" }
- elsif ($u_os eq "Linux" && $u_osrel =~ /^2\./)
- { $sum = "/usr/bin/sum" }
- else
- { print STDERR "\n$Myname: warning: not tested for \"$u_os $u_osrel\".\n\n"; }
- # Take our chances with $PATH
- #
- if (! defined($sum)) { $sum = "sum"; }
- if (! defined($tar)) { $tar = "tar"; }
- $op = "check";
- while ($#ARGV >= 0)
- {
- if ($ARGV[0] eq "-gen") { $op = "gen"; shift; next; }
- elsif ($ARGV[0] eq "-tar")
- {
- $op = "tar"; shift;
- if ($#ARGV < 0) { usage; }
- $vers = $ARGV[0]; shift;
- next;
- }
- elsif ($ARGV[0] eq "-help") { &help; }
- elsif ($ARGV[0] =~ /^-/) { &usage; }
- if ($Args ne "") { $Args .= " "; }
- push(@Args, $ARGV[0]);
- shift;
- }
- if ($#Args != -1) { &usage; }
- if ($op eq "gen")
- {
- @mestat = stat($Myname);
- if (! open(ME, "<$Myname"))
- {
- print "Can't open myself for modification: $!\n";
- exit 1;
- }
- if (! open(NEWME, ">$Myname.gen"))
- {
- print "Can't open myself for modification: $!\n";
- exit 1;
- }
- while (<ME>) { print NEWME; if (/^\$manifest = <<'MANIFEST';$/) { last; } }
- }
- elsif ($op eq "tar")
- { $tarcmd = "$tar cvf cvs2p4-$vers.tar"; }
- if ($op eq "check" && $sum eq "NONE")
- { print "\n[Checksums will not be checked on this $u_os system.]\n\n"; }
- $status = 0;
- foreach $ent (@manifest)
- {
- ($path, $sum1, $sum2, $opts) = split(/:/, $ent);
- if ($op eq "check" || $op eq "gen")
- {
- if (! lstat($path))
- { print "? $path... not found (couldn't stat)\n"; $status |= 1; }
- else
- {
- $linktarg = "";
- if ($opts =~ /\bsymlink=([^,\s]+)\b/)
- { $linktarg = $1; }
- else
- {
- if ($sum ne "NONE")
- {
- $sums = `$sum '$path'`; chop $sums;
- ($csum1, $csum2) = split(/\s+/, $sums);
- }
- }
- if ($op eq "check")
- {
- if ($linktarg ne "")
- {
- if (! -l $path)
- { print "? $path... symlink not found\n"; $status |= 1; }
- else
- {
- $link = readlink $path;
- if ($link ne $linktarg)
- { print "? $path... symlink should be \"$linktarg\"\n"; $status |= 2; }
- else
- { print " $path\n"; }
- }
- }
- else
- {
- if ($path =~ /(\/){0,1}$Myname$/)
- { print " $path\n"; next; }
- if ($sum ne "NONE" && ($csum1 != $sum1 || $csum2 != $sum2))
- { print "M $path... modified (checksums mismatch)\n"; $status |= 2; }
- else
- { print " $path\n"; }
- }
- }
- elsif ($op eq "gen")
- {
- if ($path =~ /(\/){0,1}$Myname$/)
- {
- print NEWME "$path:-:-\n";
- print "$path\n"; next;
- }
- if ($linktarg ne "")
- {
- $_ = sprintf("$path:-:-:$opts\n");
- print NEWME;
- print "$path\n";
- }
- else
- {
- $_ = sprintf("$path:$csum1:$csum2:$opts\n");
- print NEWME;
- print "$path - checksum generated\n";
- }
- }
- }
- next;
- }
- elsif ($op eq "tar")
- {
- if ($opts =~ /\bmode=([0-9]+)\b/)
- {
- $mode = $1;
- &x("/bin/chmod $mode '$path'");
- }
- @modes = lstat("$path");
- $owners{$path} = $modes[4];
- $groups{$path} = $modes[5];
- chown(0, 0, "$path")
- || print STDERR "WARNING: can't \"chown 0, 0, cvs2p4-$vers/$path\": $!\n";
- $tarcmd .= " 'cvs2p4-$vers/$path'";
- }
- }
- if ($op eq "gen")
- {
- while (<ME>) { if (/^MANIFEST$/) { print NEWME; last; }}
- while (<ME>) { print NEWME; } close NEWME;
- unlink "$Myname.old";
- rename "$Myname", "$Myname.old" || die;
- rename "$Myname.gen", "$Myname" || die;
- chmod $mestat[2], "$Myname" || die;
- }
- elsif ($op eq "tar")
- {
- $Here = `/bin/pwd`; chop $Here;
- ($Herename = $Here) =~ s%^.*/%%;
- $Parent = &dirname($Here);
- &x("/bin/mv $Parent/$Herename $Parent/cvs2p4-$vers");
- chdir $Parent || die;
- &x("$tarcmd")
- &x("/bin/mv $Parent/cvs2p4-$vers $Parent/$Herename");
- &x("/bin/mv $Parent/cvs2p4-$vers.tar $Parent/$Herename/cvs2p4-$vers.tar");
- chdir $Here || die;
- foreach $path (keys(%owners))
- {
- $own = $owners{$path}; $grp = $groups{$path};
- chown ($own, $grp, "$path") ||
- print STDERR "WARNING: can't \"chown $own, $grp, $path\": $!\n";
- }
- }
- print "\n";
- if ($status == 0) { print "All ok\n"; }
- if ($status & 1) { print "*** some files are missing\n"; }
- if ($status & 2) { print "*** some files have been modified\n"; }
- exit $status;
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#9 | 1745 | Richard Geiger | Package 2.0b6 (and add the two new test files) | 23 years ago | |
#8 | 1730 | Richard Geiger | Package 2.0b5 | 23 years ago | |
#7 | 1729 | Richard Geiger | Changes for 2.0b5. | 23 years ago | |
#6 | 1727 | Richard Geiger | package 2.0b4 | 23 years ago | |
#5 | 1661 | Richard Geiger | package 2.0b3 | 23 years ago | |
#4 | 1656 | Richard Geiger |
Roll cvs2p4 2.0 to beta 2. cc: michael |
23 years ago | |
#3 | 1651 | Richard Geiger | tarball for 2.0b1 | 23 years ago | |
#2 | 1650 | Richard Geiger | 2.0b1 changes. | 23 years ago | |
#1 | 1636 | Richard Geiger | Branch for working on a direct-metadata generation verison of cvs2p4 | 23 years ago | |
//guest/richard_geiger/utils/cvs2p4/MANIFEST | |||||
#27 | 1437 | Richard Geiger | Fix for 1.3.3 - labels on revived Attic files. | 23 years ago | |
#26 | 1408 | Richard Geiger | Put the date on the release in NEWS. | 23 years ago | |
#25 | 1407 | Richard Geiger | === Release 1.3.2 - Reduce the memory footprint of bin/genmetadata. Previously, it was &...nbsp; holding and sorting a complete copy of the metadata file "in-core" (as well as a copy of all of the RCS revision tags data!). This adds up quick, and some users saw genmetadata gobbling memory voraciously (and in some cases being running out, causing thrashing and/or process termination by the OS). genmetadata now keeps the metadata in a temp file, (sorting it in primary-key-sized chunks), and the revision tag information in a db-backed hash. - Fix the label handling so that _all_ perforce revisions based on the labeled cvs revision are included in the generated labels. Previously, one of the N "correct" Perforce revisions were being tagged (effectively, at random). This stems from the fact that lazy copying and branching are explicit in Perforce, but implicit in CVS. I.e., the "#1" revision in a new Perforce branch _appears_ to be a separate entity (identical to the revision from which it was branched. This means that to use the converted labels, it will be up to _you_ to remember what labels go with what branches: but that's the way it is in CVS, too. - A minor change in revmap to have a meaningful usage message, and properly handle the new rrevmap format. - dochanges correctly deletes revmap database files for either *.db or *.pag/*.dat style databases. « |
23 years ago | |
#24 | 1204 | Richard Geiger | Package 1.3.1 | 23 years ago | |
#23 | 1185 | Richard Geiger |
Changes for 1.3 (Labels!) |
23 years ago | |
#22 | 1032 | Richard Geiger | Publish 1.2.17 | 23 years ago | |
#21 | 795 | Richard Geiger | 1.2.16 update | 24 years ago | |
#20 | 791 | Richard Geiger |
Update for a new release; my change-of-venue noted; desensitized to conflicting P4CONFIG. |
24 years ago | |
#19 | 475 | Richard Geiger | Package cvs2p4 1.2.15 | 24 years ago | |
#18 | 460 | Richard Geiger | Publish 1.2.14 | 24 years ago | |
#17 | 422 | Richard Geiger | Package 1.2.13 | 25 years ago | |
#16 | 417 | Richard Geiger | Packaging for 1.2.12 | 25 years ago | |
#15 | 399 | Richard Geiger | 1.2.11 | 25 years ago | |
#14 | 393 | Richard Geiger | 1.2.10 | 25 years ago | |
#13 | 392 | Richard Geiger | CHanges for 1.2.10 (tolerate empty RCS file) | 25 years ago | |
#12 | 343 | Richard Geiger | 1.2.9 | 25 years ago | |
#11 | 331 | Richard Geiger |
1.2.8 - handle cr/lf in ,v's ... Yuck |
25 years ago | |
#10 | 305 | Richard Geiger | Changes for 1.2.7 | 25 years ago | |
#9 | 283 | Richard Geiger | MANIFEST includes itself once more. | 25 years ago | |
#8 | 253 | Richard Geiger | "MANIFEST" itself must handle shell metacharacters in filenames, since we added a couple... to the tests! « |
25 years ago | |
#7 | 252 | Richard Geiger | MANIFEST checksums for 1.2.6 | 25 years ago | |
#6 | 251 | Richard Geiger | Changes for 1.2.6 - metacharacters in filenames. | 25 years ago | |
#5 | 247 | Richard Geiger | Just correct the version number at the top of the README, so this doesn't rool the versio...n number! « |
25 years ago | |
#4 | 240 | Richard Geiger | Version 1.2.5, to account for post-1999 RCS behavior. (Courtesy of David Simon, Goldman S...achs) « |
25 years ago | |
#3 | 229 | Richard Geiger | Packaging for 1.2.4 release. | 26 years ago | |
#2 | 180 | Richard Geiger | 1.2.3 release. | 26 years ago | |
#1 | 130 | Richard Geiger | CVS-to-Perforce converter. This is release 1.2.2 (first submit to the Perforce Public Dep...ot) « |
26 years ago |