From f08792ba20b0d4eeaef278d0c539611a4cab3144 Mon Sep 17 00:00:00 2001 From: Laurent Destailleur Date: Wed, 26 Dec 2007 18:45:41 +0000 Subject: [PATCH] Maj pour release --- build/makepack-dolibarr.pl | 629 +++++++++++---------- build/tgz/{tar.exclude => tar_exclude.txt} | 0 build/zip/zip_exclude.txt | 82 +++ 3 files changed, 398 insertions(+), 313 deletions(-) rename build/tgz/{tar.exclude => tar_exclude.txt} (100%) create mode 100644 build/zip/zip_exclude.txt diff --git a/build/makepack-dolibarr.pl b/build/makepack-dolibarr.pl index c585059d1ff..100e5e0887a 100644 --- a/build/makepack-dolibarr.pl +++ b/build/makepack-dolibarr.pl @@ -1,313 +1,316 @@ -#!/usr/bin/perl -#---------------------------------------------------------------------------- -# \file build/makepack-dolibarr.pl -# \brief Dolibarr package builder (tgz, zip, rpm, deb, exe) -# \version $Revision$ -# \author (c)2004-2006 Laurent Destailleur -#---------------------------------------------------------------------------- - -use Cwd; - -$PROJECT="dolibarr"; -$MAJOR="2"; -$MINOR="2"; -$BUILD="0"; # Mettre x pour release, ou x-betay pour beta -$RPMSUBVERSION="1"; # A incrementer au moment de la release - -@LISTETARGET=("TGZ","ZIP","RPM","DEB","EXE"); # Possible packages -%REQUIREMENTTARGET=( # Tool requirement for each package -"TGZ"=>"tar", -"ZIP"=>"7z", -"RPM"=>"rpmbuild", -"DEB"=>"dpkg-buildpackage", -"EXE"=>"makensis.exe" -); -%ALTERNATEPATH=( -"7z"=>"7-ZIP", -"makensis.exe"=>"NSIS" -); - -$FILENAME="$PROJECT"; -$FILENAMETGZ="$PROJECT-$MAJOR.$MINOR.$BUILD"; -$FILENAMEZIP="$PROJECT-$MAJOR.$MINOR.$BUILD"; -$FILENAMERPM="$PROJECT-$MAJOR.$MINOR.$BUILD-$RPMSUBVERSION"; -$FILENAMEDEB="$PROJECT-$MAJOR.$MINOR.$BUILD"; -$FILENAMEEXE="$PROJECT-$MAJOR.$MINOR.$BUILD"; -if (-d "/usr/src/redhat") { - # redhat - $RPMDIR="/usr/src/redhat"; -} -if (-d "/usr/src/RPM") { - # mandrake - $RPMDIR="/usr/src/RPM"; -} - - -use vars qw/ $REVISION $VERSION /; -$REVISION='$Revision$'; $REVISION =~ /\s(.*)\s/; $REVISION=$1; -$VERSION="1.0 (build $REVISION)"; - - - -#------------------------------------------------------------------------------ -# MAIN -#------------------------------------------------------------------------------ -($DIR=$0) =~ s/([^\/\\]+)$//; ($PROG=$1) =~ s/\.([^\.]*)$//; $Extension=$1; -$DIR||='.'; $DIR =~ s/([^\/\\])[\\\/]+$/$1/; - -$SOURCE="$DIR/../../dolibarr"; -$DESTI="$SOURCE/build"; - -# Detect OS type -# -------------- -if ("$^O" =~ /linux/i || (-d "/etc" && -d "/var" && "$^O" !~ /cygwin/i)) { $OS='linux'; $CR=''; } -elsif (-d "/etc" && -d "/Users") { $OS='macosx'; $CR=''; } -elsif ("$^O" =~ /cygwin/i || "$^O" =~ /win32/i) { $OS='windows'; $CR="\r"; } -if (! $OS) { - print "makepack-dolbarr.pl was not able to detect your OS.\n"; - print "Can't continue.\n"; - print "makepack-dolibarr.pl aborted.\n"; - sleep 2; - exit 1; -} - -# Define buildroot -# ---------------- -if ($OS =~ /linux/) { - $TEMP=$ENV{"TEMP"}||$ENV{"TMP"}||"/tmp"; -} -if ($OS =~ /macos/) { - $TEMP=$ENV{"TEMP"}||$ENV{"TMP"}||"/tmp"; -} -if ($OS =~ /windows/) { - $TEMP=$ENV{"TEMP"}||$ENV{"TMP"}||"c:/temp"; - $PROGPATH=$ENV{"ProgramFiles"}; -} -if (! $TEMP || ! -d $TEMP) { - print "Error: A temporary directory can not be find.\n"; - print "Check that TEMP or TMP environment variable is set correctly.\n"; - print "makepack-dolibarr.pl aborted.\n"; - sleep 2; - exit 2; -} -$BUILDROOT="$TEMP/buildroot"; - - -my $copyalreadydone=0; -my $batch=0; - -print "Makepack version $VERSION\n"; -print "Building package name: $PROJECT\n"; -print "Building package version: $MAJOR.$MINOR.$BUILD\n"; - -for (0..@ARGV-1) { - if ($ARGV[$_] =~ /^-*target=(\w+)/i) { $target=$1; $batch=1; } -} - -# Choose package targets -#----------------------- -if ($target) { - $CHOOSEDTARGET{uc($target)}=1; -} -else { - my $found=0; - my $NUM_SCRIPT; - while (! $found) { - my $cpt=0; - printf(" %d - %3s (%s)\n",$cpt,"All","Need ".join(",",values %REQUIREMENTTARGET)); - foreach my $target (@LISTETARGET) { - $cpt++; - printf(" %d - %3s (%s)\n",$cpt,$target,"Need ".$REQUIREMENTTARGET{$target}); - } - - # On demande de choisir le fichier à passer - print "Choose one package number or several separated with space: "; - $NUM_SCRIPT=; - chomp($NUM_SCRIPT); - if ($NUM_SCRIPT =~ s/-//g) { - # Do not do copy - $copyalreadydone=1; - } - if ($NUM_SCRIPT !~ /^[0-$cpt\s]+$/) - { - print "This is not a valid package number list.\n"; - $found = 0; - } - else - { - $found = 1; - } - } - print "\n"; - if ($NUM_SCRIPT) { - foreach my $num (split(/\s+/,$NUM_SCRIPT)) { - $CHOOSEDTARGET{$LISTETARGET[$num-1]}=1; - } - } - else { - foreach my $key (@LISTETARGET) { - $CHOOSEDTARGET{$key}=1; - } - } -} - -# Test if requirement is ok -#-------------------------- -foreach my $target (keys %CHOOSEDTARGET) { - foreach my $req (split(/[,\s]/,$REQUIREMENTTARGET{$target})) { - # Test - print "Test requirement for target $target: Search '$req'... "; - $ret=`"$req" 2>&1`; - $coderetour=$?; $coderetour2=$coderetour>>8; - if ($coderetour != 0 && (($coderetour2 == 1 && $OS =~ /windows/ && $ret !~ /Usage/i) || ($coderetour2 == 127 && $OS !~ /windows/)) && $PROGPATH) { - # Not found error, we try in PROGPATH - $ret=`"$PROGPATH/$ALTERNATEPATH{$req}/$req\" 2>&1`; - $coderetour=$?; $coderetour2=$coderetour>>8; - $REQUIREMENTTARGET{$target}="$PROGPATH/$ALTERNATEPATH{$req}/$req"; - } - - if ($coderetour != 0 && (($coderetour2 == 1 && $OS =~ /windows/ && $ret !~ /Usage/i) || ($coderetour2 == 127 && $OS !~ /windows/))) { - # Not found error - print "Not found\nCan't build target $target. Requirement '$req' not found in PATH\n"; - $CHOOSEDTARGET{$target}=-1; - last; - } else { - # Pas erreur ou erreur autre que programme absent - print " Found ".$REQUIREMENTTARGET{$target}."\n"; - } - } -} - -print "\n"; - -# Check if there is at least on target to build -#---------------------------------------------- -$nboftargetok=0; -foreach my $target (keys %CHOOSEDTARGET) { - if ($CHOOSEDTARGET{$target} < 0) { next; } - $nboftargetok++; -} - -if ($nboftargetok) { - - # Update buildroot - #----------------- - if (! $copyalreadydone) { - print "Delete directory $BUILDROOT\n"; - $ret=`rm -fr "$BUILDROOT"`; - - mkdir "$BUILDROOT"; - print "Copy $SOURCE into $BUILDROOT\n"; - mkdir "$BUILDROOT"; - $ret=`cp -pr "$SOURCE" "$BUILDROOT"`; - } - print "Clean $BUILDROOT\n"; - $ret=`rm -fr $BUILDROOT/$PROJECT/index.php`; - $ret=`rm -fr $BUILDROOT/$PROJECT/documents`; - $ret=`rm -fr $BUILDROOT/$PROJECT/document`; - $ret=`rm -fr $BUILDROOT/$PROJECT/build`; - $ret=`rm -fr $BUILDROOT/$PROJECT/Thumbs.db $BUILDROOT/$PROJECT/*/Thumbs.db $BUILDROOT/$PROJECT/*/*/Thumbs.db $BUILDROOT/$PROJECT/*/*/*/Thumbs.db`; - $ret=`rm -fr $BUILDROOT/$PROJECT/CVS* $BUILDROOT/$PROJECT/*/CVS* $BUILDROOT/$PROJECT/*/*/CVS* $BUILDROOT/$PROJECT/*/*/*/CVS* $BUILDROOT/$PROJECT/*/*/*/*/CVS* $BUILDROOT/$PROJECT/*/*/*/*/*/CVS*`; - rename("$BUILDROOT/$PROJECT","$BUILDROOT/$FILENAMETGZ"); - - - # Build package for each target - #------------------------------ - foreach my $target (keys %CHOOSEDTARGET) { - if ($CHOOSEDTARGET{$target} < 0) { next; } - - print "\nBuild package for target $target\n"; - - if ($target eq 'TGZ') { - unlink $FILENAMETGZ.tgz; - print "Compress $FILENAMETGZ into $FILENAMETGZ.tgz...\n"; - $cmd="tar --exclude-from \"$DESTI/tgz/tar.exclude\" --directory \"$BUILDROOT\" -czvf \"$FILENAMETGZ.tgz\" $FILENAMETGZ"; - $ret=`$cmd`; - if ($OS =~ /windows/i) - { - print "Move $FILENAMETGZ.tgz to $DESTI/$FILENAMETGZ.tgz\n"; - $ret=`mv "$FILENAMETGZ.tgz" "$DESTI/$FILENAMETGZ.tgz"`; - } - else - { - $ret=`mv "$FILENAMETGZ.tgz" "$DESTI/$FILENAMETGZ.tgz"`; - } - next; - } - - if ($target eq 'ZIP') { - unlink $FILENAMEZIP.zip; - print "Compress $FILENAMETGZ into $FILENAMEZIP.zip...\n"; - chdir("$BUILDROOT"); - #print "cd $BUILDROOTNT & 7z a -r -tzip -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*\n"; - #$ret=`cd $BUILDROOTNT & 7z a -r -tzip -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*`; - $ret=`7z a -r -tzip -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*`; - print "Move $FILENAMEZIP.zip to $DESTI\n"; - rename("$BUILDROOT/$FILENAMEZIP.zip","$DESTI/$FILENAMEZIP.zip"); - next; - } - - if ($target eq 'RPM') { # Linux only - $BUILDFIC="$FILENAME.spec"; - unlink $FILENAMETGZ.tgz; - print "Compress $FILENAMETGZ into $FILENAMETGZ.tgz...\n"; - $ret=`tar --exclude-from "$SOURCE/build/tgz/tar.exclude" --directory "$BUILDROOT" -czvf "$BUILDROOT/$FILENAMETGZ.tgz" $FILENAMETGZ`; - - print "Move $FILENAMETGZ.tgz to $RPMDIR/SOURCES/$FILENAMETGZ.tgz\n"; - $cmd="mv \"$BUILDROOT/$FILENAMETGZ.tgz\" \"$RPMDIR/SOURCES/$FILENAMETGZ.tgz\""; - $ret=`$cmd`; - - print "Copy $SOURCE/make/rpm/${BUILDFIC} to $BUILDROOT\n"; -# $ret=`cp -p "$SOURCE/make/rpm/${BUILDFIC}" "$BUILDROOT"`; - open (SPECFROM,"<$SOURCE/make/rpm/${BUILDFIC}") || die "Error"; - open (SPECTO,">$BUILDROOT/$BUILDFIC") || die "Error"; - while () { - $_ =~ s/__VERSION__/$MAJOR.$MINOR.$BUILD/; - print SPECTO $_; - } - close SPECFROM; - close SPECTO; - - print "Launch RPM build (rpm --clean -ba $BUILDROOT/${BUILDFIC})\n"; - $ret=`rpm --clean -ba $BUILDROOT/${BUILDFIC}`; - - print "Move $RPMDIR/RPMS/noarch/${FILENAMERPM}.noarch.rpm into $DESTI/${FILENAMERPM}.noarch.rpm\n"; - $cmd="mv \"$RPMDIR/RPMS/noarch/${FILENAMERPM}.noarch.rpm\" \"$DESTI/${FILENAMERPM}.noarch.rpm\""; - $ret=`$cmd`; - next; - } - - if ($target eq 'DEB') { - print "Automatic build for DEB is not yet supported.\n"; - } - - if ($target eq 'EXE') { - unlink "$FILENAMEEXE.exe"; - print "Compress into $FILENAMEEXE.exe by $FILENAMEEXE.nsi...\n"; - $command="\"$REQUIREMENTTARGET{$target}\" /DMUI_VERSION_DOT=$MAJOR.$MINOR.$BUILD /X\"SetCompressor bzip2\" \"$SOURCE\\build\\exe\\$FILENAME.nsi\""; - print "$command\n"; - $ret=`$command`; - print "Move $FILENAMEEXE.exe to $DESTI\n"; - rename("$SOURCE\\build\\exe\\$FILENAMEEXE.exe","$DESTI/$FILENAMEEXE.exe"); - next; - } - - } - -} - -print "\n----- Summary -----\n"; -foreach my $target (keys %CHOOSEDTARGET) { - if ($CHOOSEDTARGET{$target} < 0) { - print "Package $target not built (bad requirement).\n"; - } else { - print "Package $target built succeessfully in $DESTI\n"; - } -} - -if (! $btach) { - print "\nPress key to finish..."; - my $WAITKEY=; -} - -0; +#!/usr/bin/perl +#---------------------------------------------------------------------------- +# \file build/makepack-dolibarr.pl +# \brief Dolibarr package builder (tgz, zip, rpm, deb, exe) +# \version $Revision$ +# \author (c)2004-2006 Laurent Destailleur +#---------------------------------------------------------------------------- + +use Cwd; + +$PROJECT="dolibarr"; +$MAJOR="2"; +$MINOR="2"; +$BUILD="0"; # Mettre x pour release, ou x-betay pour beta +$RPMSUBVERSION="1"; # A incrementer au moment de la release + +@LISTETARGET=("TGZ","ZIP","RPM","DEB","EXE"); # Possible packages +%REQUIREMENTTARGET=( # Tool requirement for each package +"TGZ"=>"tar", +"ZIP"=>"7z", +"RPM"=>"rpmbuild", +"DEB"=>"dpkg-buildpackage", +"EXE"=>"makensis.exe" +); +%ALTERNATEPATH=( +"7z"=>"7-ZIP", +"makensis.exe"=>"NSIS" +); + +$FILENAME="$PROJECT"; +$FILENAMETGZ="$PROJECT-$MAJOR.$MINOR.$BUILD"; +$FILENAMEZIP="$PROJECT-$MAJOR.$MINOR.$BUILD"; +$FILENAMERPM="$PROJECT-$MAJOR.$MINOR.$BUILD-$RPMSUBVERSION"; +$FILENAMEDEB="$PROJECT-$MAJOR.$MINOR.$BUILD"; +$FILENAMEEXE="$PROJECT-$MAJOR.$MINOR.$BUILD"; +if (-d "/usr/src/redhat") { + # redhat + $RPMDIR="/usr/src/redhat"; +} +if (-d "/usr/src/RPM") { + # mandrake + $RPMDIR="/usr/src/RPM"; +} + + +use vars qw/ $REVISION $VERSION /; +$REVISION='$Revision$'; $REVISION =~ /\s(.*)\s/; $REVISION=$1; +$VERSION="1.0 (build $REVISION)"; + + + +#------------------------------------------------------------------------------ +# MAIN +#------------------------------------------------------------------------------ +($DIR=$0) =~ s/([^\/\\]+)$//; ($PROG=$1) =~ s/\.([^\.]*)$//; $Extension=$1; +$DIR||='.'; $DIR =~ s/([^\/\\])[\\\/]+$/$1/; + +$SOURCE="$DIR/../../dolibarr"; +$DESTI="$SOURCE/build"; + +# Detect OS type +# -------------- +if ("$^O" =~ /linux/i || (-d "/etc" && -d "/var" && "$^O" !~ /cygwin/i)) { $OS='linux'; $CR=''; } +elsif (-d "/etc" && -d "/Users") { $OS='macosx'; $CR=''; } +elsif ("$^O" =~ /cygwin/i || "$^O" =~ /win32/i) { $OS='windows'; $CR="\r"; } +if (! $OS) { + print "makepack-dolbarr.pl was not able to detect your OS.\n"; + print "Can't continue.\n"; + print "makepack-dolibarr.pl aborted.\n"; + sleep 2; + exit 1; +} + +# Define buildroot +# ---------------- +if ($OS =~ /linux/) { + $TEMP=$ENV{"TEMP"}||$ENV{"TMP"}||"/tmp"; +} +if ($OS =~ /macos/) { + $TEMP=$ENV{"TEMP"}||$ENV{"TMP"}||"/tmp"; +} +if ($OS =~ /windows/) { + $TEMP=$ENV{"TEMP"}||$ENV{"TMP"}||"c:/temp"; + $PROGPATH=$ENV{"ProgramFiles"}; +} +if (! $TEMP || ! -d $TEMP) { + print "Error: A temporary directory can not be find.\n"; + print "Check that TEMP or TMP environment variable is set correctly.\n"; + print "makepack-dolibarr.pl aborted.\n"; + sleep 2; + exit 2; +} +$BUILDROOT="$TEMP/buildroot"; + + +my $copyalreadydone=0; +my $batch=0; + +print "Makepack version $VERSION\n"; +print "Building package name: $PROJECT\n"; +print "Building package version: $MAJOR.$MINOR.$BUILD\n"; + +for (0..@ARGV-1) { + if ($ARGV[$_] =~ /^-*target=(\w+)/i) { $target=$1; $batch=1; } +} + +# Choose package targets +#----------------------- +if ($target) { + $CHOOSEDTARGET{uc($target)}=1; +} +else { + my $found=0; + my $NUM_SCRIPT; + while (! $found) { + my $cpt=0; + printf(" %d - %3s (%s)\n",$cpt,"All","Need ".join(",",values %REQUIREMENTTARGET)); + foreach my $target (@LISTETARGET) { + $cpt++; + printf(" %d - %3s (%s)\n",$cpt,$target,"Need ".$REQUIREMENTTARGET{$target}); + } + + # On demande de choisir le fichier à passer + print "Choose one package number or several separated with space: "; + $NUM_SCRIPT=; + chomp($NUM_SCRIPT); + if ($NUM_SCRIPT =~ s/-//g) { + # Do not do copy + $copyalreadydone=1; + } + if ($NUM_SCRIPT !~ /^[0-$cpt\s]+$/) + { + print "This is not a valid package number list.\n"; + $found = 0; + } + else + { + $found = 1; + } + } + print "\n"; + if ($NUM_SCRIPT) { + foreach my $num (split(/\s+/,$NUM_SCRIPT)) { + $CHOOSEDTARGET{$LISTETARGET[$num-1]}=1; + } + } + else { + foreach my $key (@LISTETARGET) { + $CHOOSEDTARGET{$key}=1; + } + } +} + +# Test if requirement is ok +#-------------------------- +foreach my $target (keys %CHOOSEDTARGET) { + foreach my $req (split(/[,\s]/,$REQUIREMENTTARGET{$target})) { + # Test + print "Test requirement for target $target: Search '$req'... "; + $ret=`"$req" 2>&1`; + $coderetour=$?; $coderetour2=$coderetour>>8; + if ($coderetour != 0 && (($coderetour2 == 1 && $OS =~ /windows/ && $ret !~ /Usage/i) || ($coderetour2 == 127 && $OS !~ /windows/)) && $PROGPATH) { + # Not found error, we try in PROGPATH + $ret=`"$PROGPATH/$ALTERNATEPATH{$req}/$req\" 2>&1`; + $coderetour=$?; $coderetour2=$coderetour>>8; + $REQUIREMENTTARGET{$target}="$PROGPATH/$ALTERNATEPATH{$req}/$req"; + } + + if ($coderetour != 0 && (($coderetour2 == 1 && $OS =~ /windows/ && $ret !~ /Usage/i) || ($coderetour2 == 127 && $OS !~ /windows/))) { + # Not found error + print "Not found\nCan't build target $target. Requirement '$req' not found in PATH\n"; + $CHOOSEDTARGET{$target}=-1; + last; + } else { + # Pas erreur ou erreur autre que programme absent + print " Found ".$REQUIREMENTTARGET{$target}."\n"; + } + } +} + +print "\n"; + +# Check if there is at least on target to build +#---------------------------------------------- +$nboftargetok=0; +foreach my $target (keys %CHOOSEDTARGET) { + if ($CHOOSEDTARGET{$target} < 0) { next; } + $nboftargetok++; +} + +if ($nboftargetok) { + + # Update buildroot + #----------------- + if (! $copyalreadydone) { + print "Delete directory $BUILDROOT\n"; + $ret=`rm -fr "$BUILDROOT"`; + + mkdir "$BUILDROOT"; + print "Copy $SOURCE into $BUILDROOT\n"; + mkdir "$BUILDROOT"; + $ret=`cp -pr "$SOURCE" "$BUILDROOT"`; + } + print "Clean $BUILDROOT\n"; + $ret=`rm -fr $BUILDROOT/$PROJECT/index.php`; + $ret=`rm -fr $BUILDROOT/$PROJECT/documents`; + $ret=`rm -fr $BUILDROOT/$PROJECT/document`; + $ret=`rm -fr $BUILDROOT/$PROJECT/build`; + $ret=`rm -fr $BUILDROOT/$PROJECT/Thumbs.db $BUILDROOT/$PROJECT/*/Thumbs.db $BUILDROOT/$PROJECT/*/*/Thumbs.db $BUILDROOT/$PROJECT/*/*/*/Thumbs.db $BUILDROOT/$PROJECT/*/*/*/*/Thumbs.db`; + $ret=`rm -fr $BUILDROOT/$PROJECT/CVS* $BUILDROOT/$PROJECT/*/CVS* $BUILDROOT/$PROJECT/*/*/CVS* $BUILDROOT/$PROJECT/*/*/*/CVS* $BUILDROOT/$PROJECT/*/*/*/*/CVS* $BUILDROOT/$PROJECT/*/*/*/*/*/CVS*`; + rename("$BUILDROOT/$PROJECT","$BUILDROOT/$FILENAMETGZ"); + + + # Build package for each target + #------------------------------ + foreach my $target (keys %CHOOSEDTARGET) { + if ($CHOOSEDTARGET{$target} < 0) { next; } + + print "\nBuild package for target $target\n"; + + if ($target eq 'TGZ') { + unlink $FILENAMETGZ.tgz; + print "Compress $FILENAMETGZ into $FILENAMETGZ.tgz...\n"; + $cmd="tar --exclude-from \"$DESTI/tgz/tar_exclude.txt\" --directory \"$BUILDROOT\" -czvf \"$FILENAMETGZ.tgz\" $FILENAMETGZ"; + $ret=`$cmd`; + if ($OS =~ /windows/i) + { + print "Move $FILENAMETGZ.tgz to $DESTI/$FILENAMETGZ.tgz\n"; + $ret=`mv "$FILENAMETGZ.tgz" "$DESTI/$FILENAMETGZ.tgz"`; + } + else + { + $ret=`mv "$FILENAMETGZ.tgz" "$DESTI/$FILENAMETGZ.tgz"`; + } + next; + } + + if ($target eq 'ZIP') { + unlink $FILENAMEZIP.zip; + print "Compress $FILENAMETGZ into $FILENAMEZIP.zip...\n"; + chdir("$BUILDROOT"); + #print "cd $BUILDROOTNT & 7z a -r -tzip -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*\n"; + #$ret=`cd $BUILDROOTNT & 7z a -r -tzip -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*`; + print "7z a -r -tzip -xr\@\"$DESTI\/zip\/zip_exclude.txt\" -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*"; + $ret= `7z a -r -tzip -xr\@\"$DESTI\/zip\/zip_exclude.txt\" -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*`; + #$ret=`7z a -r -tzip -mx $BUILDROOT/$FILENAMEZIP.zip $FILENAMETGZ\\*.*`; + print $ret; + print "Move $FILENAMEZIP.zip to $DESTI\n"; + rename("$BUILDROOT/$FILENAMEZIP.zip","$DESTI/$FILENAMEZIP.zip"); + next; + } + + if ($target eq 'RPM') { # Linux only + $BUILDFIC="$FILENAME.spec"; + unlink $FILENAMETGZ.tgz; + print "Compress $FILENAMETGZ into $FILENAMETGZ.tgz...\n"; + $ret=`tar --exclude-from "$SOURCE/build/tgz/tar_exclude.txt" --directory "$BUILDROOT" -czvf "$BUILDROOT/$FILENAMETGZ.tgz" $FILENAMETGZ`; + + print "Move $FILENAMETGZ.tgz to $RPMDIR/SOURCES/$FILENAMETGZ.tgz\n"; + $cmd="mv \"$BUILDROOT/$FILENAMETGZ.tgz\" \"$RPMDIR/SOURCES/$FILENAMETGZ.tgz\""; + $ret=`$cmd`; + + print "Copy $SOURCE/make/rpm/${BUILDFIC} to $BUILDROOT\n"; +# $ret=`cp -p "$SOURCE/make/rpm/${BUILDFIC}" "$BUILDROOT"`; + open (SPECFROM,"<$SOURCE/make/rpm/${BUILDFIC}") || die "Error"; + open (SPECTO,">$BUILDROOT/$BUILDFIC") || die "Error"; + while () { + $_ =~ s/__VERSION__/$MAJOR.$MINOR.$BUILD/; + print SPECTO $_; + } + close SPECFROM; + close SPECTO; + + print "Launch RPM build (rpm --clean -ba $BUILDROOT/${BUILDFIC})\n"; + $ret=`rpm --clean -ba $BUILDROOT/${BUILDFIC}`; + + print "Move $RPMDIR/RPMS/noarch/${FILENAMERPM}.noarch.rpm into $DESTI/${FILENAMERPM}.noarch.rpm\n"; + $cmd="mv \"$RPMDIR/RPMS/noarch/${FILENAMERPM}.noarch.rpm\" \"$DESTI/${FILENAMERPM}.noarch.rpm\""; + $ret=`$cmd`; + next; + } + + if ($target eq 'DEB') { + print "Automatic build for DEB is not yet supported.\n"; + } + + if ($target eq 'EXE') { + unlink "$FILENAMEEXE.exe"; + print "Compress into $FILENAMEEXE.exe by $FILENAMEEXE.nsi...\n"; + $command="\"$REQUIREMENTTARGET{$target}\" /DMUI_VERSION_DOT=$MAJOR.$MINOR.$BUILD /X\"SetCompressor bzip2\" \"$SOURCE\\build\\exe\\$FILENAME.nsi\""; + print "$command\n"; + $ret=`$command`; + print "Move $FILENAMEEXE.exe to $DESTI\n"; + rename("$SOURCE\\build\\exe\\$FILENAMEEXE.exe","$DESTI/$FILENAMEEXE.exe"); + next; + } + + } + +} + +print "\n----- Summary -----\n"; +foreach my $target (keys %CHOOSEDTARGET) { + if ($CHOOSEDTARGET{$target} < 0) { + print "Package $target not built (bad requirement).\n"; + } else { + print "Package $target built succeessfully in $DESTI\n"; + } +} + +if (! $btach) { + print "\nPress key to finish..."; + my $WAITKEY=; +} + +0; diff --git a/build/tgz/tar.exclude b/build/tgz/tar_exclude.txt similarity index 100% rename from build/tgz/tar.exclude rename to build/tgz/tar_exclude.txt diff --git a/build/zip/zip_exclude.txt b/build/zip/zip_exclude.txt new file mode 100644 index 00000000000..53f7c272130 --- /dev/null +++ b/build/zip/zip_exclude.txt @@ -0,0 +1,82 @@ +*/build/* +*/dev/fpdf/* +*/dev/ldap/* +*/dev/purgedemo/* +*/dev/generate* +*/doc/dev/dolibarr-phpdoc/* +*/doc/dev/barcode/* +*/doc/dev/compta/* +*/doc/dev/dbmodel/* +*/doc/dev/normes/* +*/doc/dev/html/* +*/doc/dev/iso-normes/* +*/doc/plaquette/* +*/doc/wiki/* +*/document/* +*/documents/* +*/htdocs/conf/conf.php +*/htdocs/avoir/* +*/htdocs/document/* +*/htdocs/documents/* +*/htdocs/lolix/* +*/htdocs/postnuke/* +*/htdocs/telephonie/* +*/htdocs/voyage/* +*/htdocs/includes/jpgraph2/* +*/htdocs/includes/fckeditor/_samples/* +*/htdocs/includes/fckeditor/_testcases/* +*/htdocs/includes/nusoap/samples/* +*/htdocs/includes/phplot5/doc/* +*/htdocs/includes/phplot5/examples/* +*/htdocs/includes/scriptaculous/test/* +*/htdocs/includes/treemenu/docs/* +*/htdocs/includes/treemenu/images/* +*/htdocs/includes/treemenu/imagesAlt/* +*/htdocs/includes/treemenu/imagesAlt2/* +*/htdocs/includes/modules/modBarcode.class.php +*/htdocs/includes/modules/modBookmark4u.class.php +*/htdocs/includes/modules/modClickToDial.class.php +*/htdocs/includes/modules/modDocument.class.php +*/htdocs/includes/modules/modDomain.class.php +*/htdocs/includes/modules/modDroitPret.class.php +*/htdocs/includes/modules/modEditeur.class.php +*/htdocs/includes/modules/modPostnuke.class.php +*/htdocs/includes/triggers/interface_user.class.php +*/htdocs/includes/triggers/interface_contractfrombill.class.php-NORUN +*/htdocs/oscommerce_ws/ws_client_demo/* +*/htdocs/theme/rodolphe/* +*/mssql/* +*/scripts/addons/* +*/scripts/courrier/* +*/scripts/lolix/* +*/CVS/* +*~ +*.#* +*.cache* +*.cvsignore* +*.htaccess* +*.settings* +*.project* +Thumbs.db +data_dev.sql +dolibarr*.tar.gz +dolibarr*.tgz +dolibarr*.exe +dolibarr*.rpm +dolibarr*.deb +dolibarr*.zip +cvschangelogbuilder_dolibarr* +*/deneb/* +*/janus/* +*/jupiter/* +*/lune/* +*/mars/* +*/mercure/* +*/pluton/* +*/saturne/* +*/venus/* +*/bigorneau/* +*/tourteau/* +*/bulot/* +*/huitre/* +*/pdf_huitre.modules.php \ No newline at end of file