create a confiburable egroupware-epl-all tar-ball for Debian builds not (easily) supporting multiple

This commit is contained in:
Ralf Becker 2016-05-27 11:51:57 +02:00
parent 1a94023640
commit 9d703caf3a

View File

@ -38,7 +38,9 @@ $config = array(
// these apps are placed in egroupware-epl-contrib archive // these apps are placed in egroupware-epl-contrib archive
'contrib' => array('phpgwapi', 'etemplate', 'jdots', 'phpbrain', 'wiki', 'sambaadmin', 'sitemgr', 'phpfreechat')), 'contrib' => array('phpgwapi', 'etemplate', 'jdots', 'phpbrain', 'wiki', 'sambaadmin', 'sitemgr', 'phpfreechat')),
'aliasdir' => 'egroupware', // directory created by the alias 'aliasdir' => 'egroupware', // directory created by the alias
'types' => array('tar.bz2','tar.gz','zip'), 'types' => array('tar.bz2','tar.gz','zip','all.tar.bz2'),
// add given extra-apps or (uncompressed!) archives to above all.tar.bz2 archive
'all-add' => array('contrib', __DIR__.'/../phpfreechat_data_public.tar'),
// diverse binaries we need // diverse binaries we need
'svn' => trim(`which svn`), 'svn' => trim(`which svn`),
'tar' => trim(`which tar`), 'tar' => trim(`which tar`),
@ -863,15 +865,20 @@ function do_create()
if($config['extra']) if($config['extra'])
{ {
$exclude = array(); $exclude = $exclude_all = array();
foreach($config['extra'] as $modules) foreach($config['extra'] as $name => $modules)
{ {
foreach((array)$modules as $module) foreach((array)$modules as $module)
{ {
$exclude[] = basename($module); $exclude[] = basename($module);
if (!empty($config['all-add']) && !in_array($module, $config['all-add']) && (is_int($name) || !in_array($name, $config['all-add'])))
{
$exclude_all[] = basename($module);
}
} }
} }
$exclude_extra = ' --exclude=egroupware/'.implode(' --exclude=egroupware/', $exclude); $exclude_extra = ' --exclude=egroupware/'.implode(' --exclude=egroupware/', $exclude);
$exclude_all_extra = $exclude_all ? ' --exclude=egroupware/'.implode(' --exclude=egroupware/', $exclude_all) : '';
} }
foreach($config['types'] as $type) foreach($config['types'] as $type)
{ {
@ -881,9 +888,21 @@ function do_create()
$file = $config['sourcedir'].'/'.$config['packagename'].'-'.$config['version'].'.'.$config['packaging'].'.'.$type; $file = $config['sourcedir'].'/'.$config['packagename'].'-'.$config['version'].'.'.$config['packaging'].'.'.$type;
switch($type) switch($type)
{ {
case 'all.tar.bz2': // single tar-ball for debian builds not easily supporting to use multiple
$cmd = $config['tar'].' --owner=root --group=root -cjf '.$file.$exclude_all_extra.' egroupware';
if (!empty($config['all-add']))
{
foreach((array)$config['all-add'] as $add)
{
if (substr($add, -4) != '.tar') continue; // probably a module
if (!($add = realpath($add))) throw new Exception("File '$add' not found!");
$cmd .= '; '.$config['tar'].' --owner=root --group=root -Ajf '.$file.' '.$add;
}
}
break;
case 'tar.bz2': case 'tar.bz2':
case 'tar.gz': case 'tar.gz':
$cmd = $config['tar'].' --owner=root --group=root -c'.$tar_type.'f '.$file.' '.$exclude_extra.' egroupware'; $cmd = $config['tar'].' --owner=root --group=root -c'.$tar_type.'f '.$file.$exclude_extra.' egroupware';
break; break;
case 'zip': case 'zip':
$cmd = file_exists($file) ? $config['rm'].' -f '.$file.'; ' : ''; $cmd = file_exists($file) ? $config['rm'].' -f '.$file.'; ' : '';
@ -902,6 +921,8 @@ function do_create()
$file = $config['sourcedir'].'/'.$config['packagename'].'-'.$name.'-'.$config['version'].'.'.$config['packaging'].'.'.$type; $file = $config['sourcedir'].'/'.$config['packagename'].'-'.$name.'-'.$config['version'].'.'.$config['packaging'].'.'.$type;
switch($type) switch($type)
{ {
case 'all.tar.bz2':
break; // nothing to do
case 'tar.bz2': case 'tar.bz2':
case 'tar.gz': case 'tar.gz':
$cmd = $config['tar'].' --owner=root --group=root -c'.$tar_type.'f '.$file.$dirs; $cmd = $config['tar'].' --owner=root --group=root -c'.$tar_type.'f '.$file.$dirs;