diff options
author | unknown <monty@hundin.mysql.fi> | 2001-09-17 23:43:53 +0300 |
---|---|---|
committer | unknown <monty@hundin.mysql.fi> | 2001-09-17 23:43:53 +0300 |
commit | ffe994614f09f79104a20fe75b1e2986d062523a (patch) | |
tree | 6197f5bbc2fc564444d37f990227096a4582226f /support-files | |
parent | 45ea63fec3b9cf740c363508730bb2ce63de719a (diff) | |
download | mariadb-git-ffe994614f09f79104a20fe75b1e2986d062523a.tar.gz |
Added unique error for DEADLOCK
Include missing man pages into binary distribution
BitKeeper/deleted/.del-make_mysql_pkg.sh~c616a18bed4b9c2:
Delete: support-files/make_mysql_pkg.sh
Docs/manual.texi:
Changelog
extra/perror.c:
Added missing error codes
include/my_base.h:
Added unique error for DEADLOCK
include/mysql.h:
Portability fix for the LCC windows compiler
include/mysqld_error.h:
Added unique error for DEADLOCK
scripts/make_binary_distribution.sh:
Include missing man pages into binary distribution
sql/ha_berkeley.cc:
Added unique error for DEADLOCK
sql/ha_berkeley.h:
Added unique error for DEADLOCK
sql/handler.h:
Added unique error for DEADLOCK
sql/mysqld.cc:
Portability fix
sql/share/czech/errmsg.txt:
Added unique error for DEADLOCK
sql/share/danish/errmsg.txt:
Added unique error for DEADLOCK
sql/share/dutch/errmsg.txt:
Added unique error for DEADLOCK
sql/share/english/errmsg.txt:
Added unique error for DEADLOCK
sql/share/estonian/errmsg.txt:
Added unique error for DEADLOCK
sql/share/french/errmsg.txt:
Added unique error for DEADLOCK
sql/share/german/errmsg.txt:
Added unique error for DEADLOCK
sql/share/greek/errmsg.txt:
Added unique error for DEADLOCK
sql/share/hungarian/errmsg.txt:
Added unique error for DEADLOCK
sql/share/italian/errmsg.txt:
Added unique error for DEADLOCK
sql/share/japanese/errmsg.txt:
Added unique error for DEADLOCK
sql/share/korean/errmsg.txt:
Added unique error for DEADLOCK
sql/share/norwegian-ny/errmsg.txt:
Added unique error for DEADLOCK
sql/share/norwegian/errmsg.txt:
Added unique error for DEADLOCK
sql/share/polish/errmsg.txt:
Added unique error for DEADLOCK
sql/share/portuguese/errmsg.txt:
Added unique error for DEADLOCK
sql/share/romanian/errmsg.txt:
Added unique error for DEADLOCK
sql/share/russian/errmsg.txt:
Added unique error for DEADLOCK
sql/share/slovak/errmsg.txt:
Added unique error for DEADLOCK
sql/share/spanish/errmsg.txt:
Added unique error for DEADLOCK
sql/share/swedish/errmsg.txt:
Added unique error for DEADLOCK
sql/share/ukrainian/errmsg.txt:
Added unique error for DEADLOCK
Diffstat (limited to 'support-files')
-rw-r--r-- | support-files/make_mysql_pkg.pl | 414 | ||||
-rw-r--r-- | support-files/make_mysql_pkg.sh | 159 |
2 files changed, 414 insertions, 159 deletions
diff --git a/support-files/make_mysql_pkg.pl b/support-files/make_mysql_pkg.pl new file mode 100644 index 00000000000..75345c7275b --- /dev/null +++ b/support-files/make_mysql_pkg.pl @@ -0,0 +1,414 @@ +#!/usr/bin/perl -w +# +# +# make_mysql_pkg.pl +# +# This script creates a Mac OS X installation package +# of MySQL for Apple's Installer application. +# +# To use it: +# +# 1.) Unpack the mysql source tarball and cd into the directory +# 2.) execute this script +# +# +# Written by Marc Liyanage (http://www.entropy.ch) +# +# History: +# +# When Who What +# ------------------------------------------------------------- +# 2001-09-16 Marc Liyanage First version + +use strict; +use DirHandle; + +my $data = {}; + +$data->{PREFIX_DIR} = "/usr/local"; +$data->{CONFIG} = "--prefix=$data->{PREFIX_DIR} --with-innodb"; + + + + + +prepare($data); +configure_source($data); +make($data); +make_binary_distribution($data); +create_pax_root($data); +create_package($data); +cleanup($data); + +print "Package $data->{PACKAGE_TARBALL_FILENAME} created\n"; + + + + + + +# Subroutines follow here... + + + + +# Prepares data in the global $data hash, like version numbers, +# directory names etc. Also makes sure that no old stuff +# is in our way. +# +sub prepare { + + my ($data) = @_; + + # Keep the current wd for reference + # + $data->{OLDWD} = `pwd`; + chomp($data->{OLDWD}); + + # Look for configure script + # + unless (-f "configure") { + abort($data, "Unable to find 'configure', make sure you're in the MySQL source toplevel directory!"); + } + + # Try to find version number there + # + my $mysql_version_h = `cat configure`; + ($data->{VERSION}) = $mysql_version_h =~ /^VERSION=(.+?)$/m; + + unless ($data->{VERSION} =~ /\d+/) { + abort($data, "Unable to find MySQL version number!"); + } + + debug($data, "found MySQL version number $data->{VERSION}"); + + + # PAXROOT_DIR is where we will build our own little + # fake /usr/local directory. Make sure it doesn't exist, + # then try to create it. + # + $data->{PAXROOT_DIR} = "/tmp/mysql-$data->{VERSION}-paxroot"; + + if (-e $data->{PAXROOT_DIR}) { + abort($data, "$data->{PAXROOT_DIR} exists, please remove first"); + } + + if (system("mkdir $data->{PAXROOT_DIR}")) { + abort($data, "Unable to mkdir $data->{PAXROOT_DIR}, please make sure you have the right permissions!"); + } + + + # PACKAGE_DIR is where we will build the package directory + # hierarchy, according to the standard .pkg layout. + # + $data->{PACKAGE_NAME} = "mysql-$data->{VERSION}.pkg"; + $data->{PACKAGE_DIR} = "/tmp/$data->{PACKAGE_NAME}"; + + if (-e $data->{PACKAGE_DIR}) { + abort($data, "$data->{PACKAGE_DIR} exists, please remove first"); + } + + if (system("mkdir $data->{PACKAGE_DIR}")) { + abort($data, "Unable to mkdir $data->{PACKAGE_DIR}, please make sure you have the right permissions!"); + } + + +} + + + +# Configure the MySQL source with our options +# +sub configure_source { + + my ($data) = @_; + + if (system("./configure $data->{CONFIG}")) { + abort($data, "Unable to configure!"); + } + +} + + + + +# Build the software +# +sub make { + + my ($data) = @_; + + if (system("make")) { + abort($data, "Unable to make!"); + } + +} + + + +# We don't ever install the software, but instead we use an +# included script to create a binary distribution +# tarball. +# +sub make_binary_distribution { + + my ($data) = @_; + + if (system("./scripts/make_binary_distribution > make_binary_distribution.out")) { + abort($data, "Unable to make_binary_distribution!"); + } + + my @output = `cat make_binary_distribution.out`; + my $last_line = $output[-1]; + unlink("make_binary_distribution.out"); + + my ($tarball_filename, $tarball_directory) = $last_line =~ /^((.+)\.tar\.gz) created/i; + + unless ($tarball_filename and -f $tarball_filename) { + abort($data, "Unable determine the output filename of scripts/make_binary_distribution!"); + } + + $data->{BINARY_TARBALL_FILENAME} = $tarball_filename; + $data->{BINARY_TARBALL_DIRECTORY} = $tarball_directory; + +} + + + + +# Now we build a fake /usr/local directory hierarchy. +# This will be fed to the pax tool to create +# the archive. +# +sub create_pax_root { + + my ($data) = @_; + + # Go there and try to extract the binary distribution + # tarball which we created in the previous step. + # + chdir($data->{PAXROOT_DIR}); + my $tarfile = "$data->{OLDWD}/$data->{BINARY_TARBALL_FILENAME}"; + + if(system("tar -xzf $tarfile")) { + abort($data, "Unable to extract $tarfile inside $data->{PAXROOT_DIR}"); + } + + # Rename it to what we want it to be in the + # installed /usr/local directory later on, i.e. + # mysql-<version>. Then create a symlink from + # mysql to mysql-<version> + # + rename($data->{BINARY_TARBALL_DIRECTORY}, "mysql-$data->{VERSION}"); + symlink("mysql-$data->{VERSION}", "mysql"); + + + # We create a bunch of symlinks in /usr/local/bin and + # /usr/local/share/man so that the end-user will not + # have to adjust PATH and MANPATH to include the + # /usr/local/mysql/bin and man directories. + # + system("mkdir -p $_") foreach qw(bin share/man); + + + # First create the symlinks in the bin directory + # + chdir("bin"); + symlink("../mysql/bin/$_", "$_") foreach (grep {$_ !~ /^\.+$/} DirHandle->new("../mysql/bin")->read()); + + + # Now include the man pages. Two problems here: + # 1.) the make_binary_distribution script does not seem + # to include the man pages, so we have to copy them over + # now. + # 2.) The man pages could be in different sections, so + # we have to recursively copy *and* symlink them. + # + + # First find out what's there in the source distribution. + # Store the names of the manpages in anonymous + # arrays which in turn will be stored in a hash, using + # the section numbers as hash keys. + # + chdir($data->{OLDWD}); + my %man_sections; + foreach my $manpage (grep {$_ =~ /^.+\.(\d+)$/} DirHandle->new("man")->read()) { + + my ($section) = $manpage =~ /\.(\d+)$/; + + $man_sections{$section} ||= []; + push @{$man_sections{$section}}, "$manpage"; + + } + + + # Now iterate through the sections and man pages, + # and copy/symlink the man pages + # + chdir("$data->{PAXROOT_DIR}/share/man/"); + + foreach my $section (keys(%man_sections)) { + + system("mkdir -p $data->{PAXROOT_DIR}/mysql/man/man$section/"); + system("mkdir -p man$section"); + chdir("man$section"); + + foreach my $manpage (@{$man_sections{$section}}) { + + system("cp $data->{OLDWD}/man/$manpage $data->{PAXROOT_DIR}/mysql/man/man$section/"); + symlink("../../../mysql/man/man$section/$manpage", $manpage) + + } + + chdir(".."); + + } + + +} + + + +# Take the pax root directory, create a few auxiliary +# files and then pack everything up into a tarball +# +sub create_package { + + my ($data) = @_; + + # Create the resources directory in which all + # interesting files for this package will be stored + # + $data->{PKG_RESOURCES_DIR} = "$data->{PACKAGE_DIR}/Contents/Resources"; + + if (system("mkdir -p $data->{PKG_RESOURCES_DIR}")) { + abort("Unable to create package resources dir $data->{PKG_RESOURCES_DIR}"); + } + + + # Create the big archive with all the files using + # the pax tool + # + chdir($data->{PAXROOT_DIR}); + if(system("pax -w . | gzip -c > $data->{PKG_RESOURCES_DIR}/mysql-$data->{VERSION}.pax.gz")) { + abort("Unable to create package pax file"); + } + + + # Create the "Bill Of Materials" (bom) file. + # + if(system("mkbom . $data->{PKG_RESOURCES_DIR}/mysql-$data->{VERSION}.bom")) { + abort("Unable to create package bom file"); + } + + + # Create the ".sizes" file with some information about the package + # + my $size_uncompressed = `du -sk $data->{PAXROOT_DIR} | cut -f 1`; + chomp($size_uncompressed); + + my $size_compressed = `du -sk $data->{PACKAGE_DIR} | cut -f 1`; + chomp($size_compressed); + + my $numfiles = `find /tmp/mysql-3.23.42-paxroot/ | wc -l`; + $numfiles--; + + open(SIZESFILE, ">$data->{PKG_RESOURCES_DIR}/mysql-$data->{VERSION}.sizes") or abort("Unable to write open sizes file $data->{PKG_RESOURCES_DIR}/mysql-$data->{VERSION}.sizes"); + print SIZESFILE "NumFiles $numfiles\n"; + print SIZESFILE "InstalledSize $size_uncompressed\n"; + print SIZESFILE "CompressedSize $size_compressed\n"; + close(SIZESFILE); + + + # Create the ".info" file with more information abou the package. + # + open(INFOFILE, ">$data->{PKG_RESOURCES_DIR}/mysql-$data->{VERSION}.info") or abort("Unable to write open sizes file $data->{PKG_RESOURCES_DIR}/mysql-$data->{VERSION}.info"); + my $infodata = join("", <DATA>); + $infodata =~ s/<%(.+?)%>/$data->{$1}/eg; + abort("Unable to get info file data from __DATA__!") unless ($infodata =~ /\w+/); + print INFOFILE $infodata; + close(INFOFILE); + + + + # Finally, create the .tar.gz file for the package, + # this is our end result + # + chdir($data->{PACKAGE_DIR}); + chdir(".."); + + $data->{PACKAGE_TARBALL_FILENAME} = "$data->{PACKAGE_NAME}.tar.gz"; + + if(system("tar -czf $data->{OLDWD}/$data->{PACKAGE_TARBALL_FILENAME} $data->{PACKAGE_NAME}")) { + abort("Unable to create package tar file $data->{OLDWD}/$data->{PACKAGE_TARBALL_FILENAME}"); + } + + + +} + + +# Abort with an error message +# +sub abort { + + my ($data, $errormessage) = @_; + + my ($caller) = (caller(1))[3]; + $caller =~ s/^main:://; + + print "*** Error: $caller(): $errormessage\n"; + + exit 1; + +} + + +# Output informative messages +# +sub debug { + + my ($data, $message) = @_; + + my ($caller) = (caller(1))[3]; + $caller =~ s/^main:://; + + print "*** Info: $caller(): $message\n"; + +} + + + +# Remove temporary items +# +sub cleanup { + + my ($data) = @_; + + chdir($data->{OLDWD}); + + system("rm -rf $data->{PACKAGE_DIR}"); + system("rm -rf $data->{PAXROOT_DIR}"); + system("rm $data->{BINARY_TARBALL_FILENAME}"); + +} + + + + +__DATA__ +Title MySQL +Version <%VERSION%> +Description The MySQL database server in a convenient Mac OS X package. Some additional configuration is necessary, please see http://www.entropy.ch/software/macosx/mysql/ +DefaultLocation /usr/local +Diskname (null) +DeleteWarning +NeedsAuthorization YES +DisableStop NO +UseUserMask NO +Application NO +Relocatable NO +Required NO +InstallOnly NO +RequiresReboot NO +InstallFat NO
\ No newline at end of file diff --git a/support-files/make_mysql_pkg.sh b/support-files/make_mysql_pkg.sh deleted file mode 100644 index b0eb817fff4..00000000000 --- a/support-files/make_mysql_pkg.sh +++ /dev/null @@ -1,159 +0,0 @@ -#!/bin/sh -# -# make_mysql_pkg.sh -# -# This script creates a Mac OS X installation package -# for Apple's Installer application. -# -# To use it: -# -# 1.) unpack the MySQL source tarball -# 2.) cd to into the resulting directory and stay there for the next steps -# 3.) "configure" the source (preferably with --mandir=/usr/local/share/man) -# 4.) "make" the package -# 5.) invoke this script with superuser privileges (sudo or in a root shell) -# -# Written by Marc Liyanage (http://www.entropy.ch) -# -# History: -# -# When Who What -# ------------------------------------------------------------- -# 2001-09-13 Marc Liyanage First version - - -# Find the version number of this particular MySQL build -# -OLDWD=`pwd` -VERSION_H_FILE=$OLDWD/include/mysql_version.h - -if [ ! -e $VERSION_H_FILE ] -then -echo $VERSION_H_FILE not found, make sure you are in the mysql source dir -exit 1 -fi - -MYSQLVERSION=`egrep 'MYSQL_SERVER_VERSION' $VERSION_H_FILE | perl -e '$_ = <>; $_ =~ /"(.+?)"/; print $1'` - - - -# We will temporarily rename /usr/local to this name -# and then mkdir a new, empty /usr/local -# -LOCAL_TMPDIR=/usr/local.tmp - -# At the end, we'll keep our temporary /usr/local -# to this name -# -LOCAL_BACKUPDIR=/usr/local.mysql-package - -# Where do we create the package directory -# -PKG_DIR=/tmp/mysql-$MYSQLVERSION.pkg - -# Where is the resources directory within the -# package directory -# -PKG_RESOURCES_DIR=$PKG_DIR/Contents/Resources - -# Check if old stuff is in our way -# -if [ -e $LOCAL_BACKUPDIR ] -then -echo $LOCAL_BACKUPDIR exists, please remove first... -exit 1 -fi - -if [ -e $LOCAL_TMPDIR ] -then -echo $LOCAL_TMPDIR exists, please remove first... -exit 1 -fi - -if [ -e $PKG_DIR ] -then -echo $PKG_DIR exists, please remove first... -exit 1 -fi - -# Now create the package dir -# -mkdir -p $PKG_RESOURCES_DIR - -# Move the existing /usr/local out of our way -# -mv /usr/local $LOCAL_TMPDIR - -# Now create our new empty temporary /usr/local -# -mkdir /usr/local - -# And install MySQL there -# -make install - - -# cd there so the next few commands will use it -# as base directory -# -cd /usr/local - -# First, create the gzipped pax archive file -# which contains the actual files -# -pax -w . | gzip -c > $PKG_RESOURCES_DIR/mysql-$MYSQLVERSION.pax.gz - -# Create the bom ("Bill Of Materials") file -# -mkbom . $PKG_RESOURCES_DIR/mysql-$MYSQLVERSION.bom - -# Create the sizes file with the package space -# requirement numbers and file count -# -SIZE_UNCOMPRESSED=`du -sk /usr/local | cut -f 1` -SIZE_COMPRESSED=`du -sk $PKG_DIR | cut -f 1` -NUMFILES=`find /usr/local | wc -l | perl -e '$_ = <>; $_ =~ /\s+(\d+)/; print $1 - 1'` - -echo NumFiles $NUMFILES >> $PKG_RESOURCES_DIR/mysql-$MYSQLVERSION.sizes -echo InstalledSize $SIZE_UNCOMPRESSED >> $PKG_RESOURCES_DIR/mysql-$MYSQLVERSION.sizes -echo CompressedSize $SIZE_COMPRESSED >> $PKG_RESOURCES_DIR/mysql-$MYSQLVERSION.sizes - - -# Finally create the info file which drives the "Installer" application -# -cat >$PKG_RESOURCES_DIR/mysql-$MYSQLVERSION.info <<- EOF - Title MySQL - Version $MYSQLVERSION - Description The MySQL database server in a convenient Mac OS X package. Some additional configuration is necessary, please see http://www.entropy.ch/software/macosx/mysql/ - DefaultLocation /usr/local - Diskname (null) - DeleteWarning - NeedsAuthorization YES - DisableStop NO - UseUserMask NO - Application NO - Relocatable NO - Required NO - InstallOnly NO - RequiresReboot NO - InstallFat NO -EOF - -# Create a .tar.gz file for the package directory -# -cd $PKG_DIR -cd .. -DIRNAME=`dirname $PKG_DIR` -BASENAME=`basename $PKG_DIR` -FILENAME=$BASENAME.tar.gz -tar -cvzf $FILENAME $BASENAME - -# Move our temporary /usr/local out of the way -# and the original one back -# -mv /usr/local $LOCAL_BACKUPDIR -mv $LOCAL_TMPDIR /usr/local - -echo output package is in $DIRNAME/$FILENAME - - |