mirror of
https://github.com/HDFGroup/hdf5.git
synced 2024-11-27 02:10:55 +08:00
1c1679b2d4
---------------------- ./bin/release ./src/H5.c ./src/H5private.h ./src/H5public.h ./src/H5Fpublic.h Changed the version number constants to names that begin with H5_VERS_ and added macros that check that the version numbers in the include files match the version number of the library. ./MANIFEST ./html/H5.user.html ./html/Version.html [NEW] ./html/version.obj [NEW] ./html/version.gif [NEW] Documented version numbers and the macros, constants, and functions associated with them. ./bin/versinc A perl script that increments the minor version number and sets the patch level back to zero. This is intended to be invoked from the top of the source tree by a cvs commit anywhere in the source tree. Quincey? ./src/H5O.c ./src/H5Oprivate.h Added H5O_count() to count the number of object header messages of a particular type. Quincey needs this for the attribute package. ./test/dsets.c Fixed warnings. Enabled the small strip-mine buffer test. ./config/linux Added optimizations for the Pentium-Pro for production mode.
227 lines
6.3 KiB
Perl
Executable File
227 lines
6.3 KiB
Perl
Executable File
#! /usr/local/bin/perl -w
|
|
require 5.003;
|
|
use Cwd;
|
|
|
|
# Builds a release. Arguments are zero or more of the words.
|
|
#
|
|
# tar -- build a tar file *.tar
|
|
# compress -- build a compressed tar file *.tar.Z
|
|
# gzip -- build a compressed tar file *.tar.gz
|
|
# bzip2 -- build a compressed tar file *.tar.bz2
|
|
#
|
|
# If no arguments are given then `gzip' is assumed. If the only argument
|
|
# is the word `all' then all forms are used.
|
|
|
|
$releases = "./releases"; # Directory for release tarballs
|
|
|
|
##############################################################################
|
|
# Read version info, return an array (MAJOR,MINOR,RELEASE,PATCHLEVEL) or
|
|
# a string "MAJOR.MINOR.RELEASE PATCHLEVEL"
|
|
#
|
|
sub getver () {
|
|
my @ver;
|
|
|
|
open SRC, "./src/H5public.h" or die "cannot read HDF5 version";
|
|
while (<SRC>) {
|
|
$ver[0] = $1 if /define\s+H5_VERS_MAJOR\s+(\d+)/;
|
|
$ver[1] = $1 if /define\s+H5_VERS_MINOR\s+(\d+)/;
|
|
$ver[2] = $1 if /define\s+H5_VERS_RELEASE\s+(\d+)/;
|
|
$ver[3] = $1 if /define\s+H5_VERS_PATCH\s+(\d+)/;
|
|
}
|
|
close SRC;
|
|
wantarray ? @ver : "$ver[0].$ver[1].$ver[2]".chr(ord('a')+$ver[3]);
|
|
}
|
|
|
|
##############################################################################
|
|
# Set version information. Input is a string or an array.
|
|
#
|
|
sub setver ($;$$$) {
|
|
my @ver = @_;
|
|
local $_;
|
|
|
|
if ($ver[0]=~/\D/) {
|
|
@ver = $ver[0] =~ /^(\d+)\.(\d+)\.(\d+)([a-z])$/ or return "";
|
|
$ver[3] = ord($ver[3])-ord('a');
|
|
}
|
|
|
|
$_ = `cat ./src/H5public.h`;
|
|
s/(define\s+H5_VERS_MAJOR\s+)(\d+)/$1$ver[0]/;
|
|
s/(define\s+H5_VERS_MINOR\s+)(\d+)/$1$ver[1]/;
|
|
s/(define\s+H5_VERS_RELEASE\s+)(\d+)/$1$ver[2]/;
|
|
s/(define\s+H5_VERS_PATCH\s+)(\d+)/$1$ver[3]/;
|
|
open SRC, "> ./src/H5public.h" or return "";
|
|
print SRC $_;
|
|
close SRC;
|
|
|
|
return 1;
|
|
}
|
|
|
|
##############################################################################
|
|
# Make sure MANIFEST contains all the necessary files. If we are running
|
|
# under CVS then look at the CVS/Entries files to get the names that should
|
|
# be in the manifest. Otherwise we really can't do anything.
|
|
#
|
|
sub manifest () {
|
|
my ($fname, %manifest);
|
|
my $nprobs=0;
|
|
|
|
# We can't do anything if we're not running under cvs.
|
|
return "" unless -d "CVS";
|
|
|
|
# Read the files from the manifest.
|
|
open MANIFEST, "MANIFEST" or die "unable to read manifest";
|
|
while (<MANIFEST>) {
|
|
chomp;
|
|
$manifest{$_} = 1;
|
|
}
|
|
close MANIFEST;
|
|
|
|
# Read files from CVS/Entries
|
|
open FIND, "find . -name Entries -print | sort |" or
|
|
die "unable to find CVS entries";
|
|
while (defined($fname=<FIND>)) {
|
|
chomp $fname;
|
|
my ($dir) = $fname =~ m%(.*)/CVS/Entries%;
|
|
open ENTRIES, $fname or die "unable to open $fname";
|
|
while (<ENTRIES>) {
|
|
my ($ename);
|
|
next unless ($ename) = m%^/([^/]+)/[^-]%;
|
|
$ename = "$dir/" . $ename;
|
|
if (exists $manifest{$ename}) {
|
|
delete $manifest{$ename};
|
|
} else {
|
|
print "NEW: $ename\n";
|
|
$nprobs++;
|
|
}
|
|
}
|
|
close ENTRIES;
|
|
}
|
|
close FIND;
|
|
|
|
for (sort keys %manifest) {
|
|
print "OLD: $_\n";
|
|
$nprobs++;
|
|
}
|
|
|
|
if ($nprobs) {
|
|
print "Please add the new files to MANIFEST and remove the old\n";
|
|
print "files and try again. The MANIFEST should contain all files\n";
|
|
print "that are to be distributed for a release.\n";
|
|
exit 1;
|
|
}
|
|
}
|
|
|
|
|
|
##############################################################################
|
|
# Build a release
|
|
#
|
|
sub release (@) {
|
|
my @types = @_;
|
|
my ($ver, $status, $created_symlink);
|
|
local $_;
|
|
|
|
# Make sure no one forgot to update MANIFEST
|
|
manifest;
|
|
|
|
# Make sure the version number is correct.
|
|
print "Building an HDF release...\n";
|
|
print "HDF version to release [", ($ver=getver), "] ";
|
|
return "" unless defined ($_=<STDIN>);
|
|
chomp;
|
|
(setver ($ver=$_) or die "cannot set version") if /\S/;
|
|
|
|
# Clean the source tree, showing only errors.
|
|
print "Cleaning source tree...\n";
|
|
$status = system "make distclean >/dev/null";
|
|
die "cannot make distclean" if $status >> 8;
|
|
|
|
# Move default top-level makefile into place.
|
|
$status = system "cp Makefile.dist Makefile";
|
|
die "cannot install default Makefile" if $status >> 8;
|
|
|
|
# Make sure release directory exists
|
|
(mkdir $releases, 0777 or die "cannot create $releases")
|
|
unless -d $releases;
|
|
die "no manifest" unless -r "MANIFEST";
|
|
|
|
# We build the release from above the root of the source tree so the
|
|
# hdf5 directory appears as part of the name in the tar file. We create
|
|
# a temporary symlink called something like `hdf5-1.0.0a' that points to
|
|
# our current working directory.
|
|
$_ = cwd;
|
|
my ($parent,$root) = m%(.*)/(.*)$% or die "cannot split directory";
|
|
if ($root ne "hdf5-$ver" && ! -e "../hdf5-$ver") {
|
|
symlink $root, "../hdf5-$ver" or die "cannot create link";
|
|
$created_symlink = 1;
|
|
}
|
|
my $name = "$root/$releases/hdf5-$ver";
|
|
|
|
# Build the releases.
|
|
@types = ("gzip") unless @types;
|
|
@types = qw/tar gzip compress bzip2/ if 1==@types && "all" eq $types[0];
|
|
$_ = `cat MANIFEST`;
|
|
s/^\.\///mg;
|
|
@filelist = ("Makefile", split /\s*\n/, $_);
|
|
$filelist = join " ", map {"hdf5-$ver/$_"} @filelist;
|
|
|
|
chdir ".." or die;
|
|
for (@types) {
|
|
print "Compressing with $_...\n";
|
|
|
|
/^tar$/ && do {
|
|
$status = system "tar cf $name.tar $filelist";
|
|
next;
|
|
};
|
|
|
|
/^gzip$/ && do {
|
|
$status = system "tar cf - $filelist |gzip -9 >$name.tar.gz";
|
|
next;
|
|
};
|
|
|
|
/^compress$/ && do {
|
|
$status = system "tar cf - $filelist |compress -c >$name.tar.Z";
|
|
next;
|
|
};
|
|
|
|
/^bzip2$/ && do {
|
|
$status = system "tar cf - $filelist |bzip2 -9 >$name.tar.bz2";
|
|
next;
|
|
};
|
|
} continue {
|
|
print STDERR "$_ failed\n" if $status >> 8;
|
|
}
|
|
chdir $root or die;
|
|
|
|
# Remove the temporary symlink we created above.
|
|
unlink "../hdf5-$ver" if $created_symlink;
|
|
|
|
|
|
# Update version info
|
|
print <<EOF;
|
|
|
|
If this is a real release then the version number for continued development
|
|
should be incremented. Otherwise just press return.
|
|
|
|
EOF
|
|
print "Set development version to [", ($ver=getver), "] ";
|
|
return "" unless defined ($_ = <STDIN>);
|
|
chomp;
|
|
(setver ($ver=$_) or die "cannot set version") if /\S/;
|
|
|
|
if (-d "CVS") {
|
|
my $tag = $ver;
|
|
$tag =~ s/\./-/g;
|
|
print "Tag CVS sources with \"$tag\"? [n] ";
|
|
chomp ($_ = <STDIN>);
|
|
if ($_ eq 'y') {
|
|
print "Tagging CVS sources...\n";
|
|
my $status = system "cvs tag -R $tag";
|
|
die "cvs tag failed" if $status >> 8;
|
|
}
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
release @ARGV;
|