diff options
| author | Jacob Pipkin <d4wnr4z0r@yahoo.com> | 2012-05-12 01:27:50 -0500 | 
|---|---|---|
| committer | Jacob Pipkin <d4wnr4z0r@yahoo.com> | 2012-05-12 01:27:50 -0500 | 
| commit | 0d6317b47fb61e4781956aeda279cda156a016c0 (patch) | |
| tree | 301b053a5a3972f34ca703313a51d81bcf834d7a | |
| parent | 50477bd2822def28ac8403f968383d359d3126b7 (diff) | |
| download | sbotools2-0d6317b47fb61e4781956aeda279cda156a016c0.tar.xz | |
groundwork for supporting installation of -compat32 SlackBuilds
| -rw-r--r-- | SBO-Lib/lib/SBO/Lib.pm | 152 | ||||
| -rwxr-xr-x | sboupgrade | 35 | 
2 files changed, 133 insertions, 54 deletions
| diff --git a/SBO-Lib/lib/SBO/Lib.pm b/SBO-Lib/lib/SBO/Lib.pm index 2746621..bb6ca3c 100644 --- a/SBO-Lib/lib/SBO/Lib.pm +++ b/SBO-Lib/lib/SBO/Lib.pm @@ -28,6 +28,7 @@ require Exporter;  	make_distclean  	do_upgradepkg  	get_sbo_location +	get_pkg_name  );  use warnings FATAL => 'all'; @@ -301,23 +302,18 @@ sub get_arch {  	return $arch;  } -# this is a bit wonky - if running a 64-bit system, we have to first see if -# DOWNLOAD_x86_64 is defined, and make sure it's not set to "UNSUPPORTED"; -# then if that doesn't yield anything, go through again pulling the DOWNLOAD -# contents. -# -# would like to think of a better way to handle this. -#  sub get_sbo_downloads { -	script_error ('get_sbo_downloads requires two arguments.') -		unless exists $_[1]; +	script_error ('get_sbo_downloads requires three arguments.') +		unless exists $_[2];  	script_error ('get_sbo_downloads given a non-directory.') unless -d $_[1]; -	my ($sbo,$location) = @_; +	my ($sbo,$location,$only32) = @_;  	my $arch = get_arch ();  	my (@links,@md5s);  	if ($arch eq 'x86_64') { -		@links = find_download_info ($sbo,$location,'download',1); -		@md5s = find_download_info ($sbo,$location,'md5sum',1); +		unless ($only32) { +			@links = find_download_info ($sbo,$location,'download',1); +			@md5s = find_download_info ($sbo,$location,'md5sum',1); +		}  	}  	unless (exists $links[0]) {  		@links = find_download_info ($sbo,$location,'download',0); @@ -428,9 +424,15 @@ sub rewrite_slackbuild {  		unless exists $_[1];  	my ($slackbuild,%changes) = @_;  	copy ($slackbuild,"$slackbuild.orig"); +	my $libdir_regex = qr/^\s*LIBDIRSUFFIX="64"\s*$/;  	tie my @sb_file,'Tie::File',$slackbuild;  	FIRST: for my $line (@sb_file) {  		SECOND: while (my ($key,$value) = each %changes) { +			if ($key eq 'libdirsuffix') { +				if ($line =~ $libdir_regex) { +					$line =~ s/64/$value/; +				} +			}  			if ($key eq 'arch_out') {  				if (index ($line,'makepkg') != -1) {  					$line =~ s/\$ARCH/$value/; @@ -454,24 +456,10 @@ sub revert_slackbuild {  	return 1;  } -sub do_slackbuild { -	script_error ('do_slackbuild requires two arguments.') unless exists $_[1]; -	my ($jobs,$sbo,$location) = @_; -	my $sbo_home = $config{SBO_HOME}; -	my $arch = get_arch (); -	my $x32; -	if ($arch eq 'x86_64') { -		$x32 = check_x32 ($sbo,$location); -		if ($x32) { -			if (! check_multilib () ) { -				print "$sbo is 32-bit only, however, this system does not appear  -to be multilib ready.\n"; -				exit 1 -			} -		} -	} -	my $version = get_sbo_version ($sbo,$location); -	my @downloads = get_sbo_downloads ($sbo,$location); +sub create_symlinks { +	script_error ('create_symlinks requires two arguments.') +		unless exists $_[1]; +	my ($location,@downloads) = @_;  	my @symlinks;  	for my $c (keys @downloads) {  		my $link = $downloads[$c]{link}; @@ -484,11 +472,28 @@ to be multilib ready.\n";  		push (@symlinks,$symlink);  		symlink ($filename,$symlink);  	} +	return @symlinks; +} + +sub prep_sbo_file { +	script_error ('prep_sbo_file requires two arguments') unless exists $_[1]; +	my ($sbo,$location) = @_;  	chdir ($location);  	chmod (0755,"$location/$sbo.SlackBuild"); +	return 1; +} + +sub perform_sbo { +	script_error ('perform_sbo requires five arguments') unless exists $_[4]; +	my ($sbo,$location,$arch,$c32,$x32) = @_;  	my $cmd; -	if ($arch eq 'x86_64' and $x32) { -		my %changes = (arch_out => 'i486'); +	if ($arch eq 'x86_64' and ($c32 || $x32) ) { +		my %changes; +		if ($c32) { +			%changes = (libdirsuffix => ''); +		} elsif ($x32) { +			%changes = (arch_out => 'i486'); +		}  		rewrite_slackbuild ("$location/$sbo.SlackBuild",%changes);  		$cmd = ". /etc/profile.d/32dev.sh && $location/$sbo.SlackBuild";  	} else { @@ -497,6 +502,87 @@ to be multilib ready.\n";  	my $out = system ($cmd);  	revert_slackbuild ("$location/$sbo.SlackBuild");  	die unless $out == 0; +	return 1; +} + +sub get_pkg_name { +	script_error ('get_pkg_name requires three arguments') unless exists $_[2]; +	my ($sbo,$version,$compat32) = @_; +	if ($compat32 eq 'TRUE') { +		$sbo = "$sbo-compat32" unless $sbo =~ /-compat32$/; +	} +	my $pkg; +	my $pkg_regex = qr/^(\Q$sbo\E-\Q$version\E-[^-]+-.*_SBo.t[xblg]z)$/; +	opendir my $diread, '/tmp/'; +	FIRST: while (my $ls = readdir $diread) { +		if ($ls =~ $pkg_regex) { +			chomp ($pkg = "/tmp/$1"); +			last FIRST; +		} +	} +	return $pkg; +} + +sub sb_compat32 { +	script_error ('sb_compat32 requires six arguments.') unless exists $_[5]; +	my ($jobs,$sbo,$location,$arch,$version,@downloads) = @_; +	unless ($arch eq 'x86_64') { +		print 'You can only create compat32 packages on x86_64 systems.'; +		exit 1; +	} else { +		if (! check_multilib () ) { +			print "This system does not appear to be setup for multilib.\n"; +			exit 1; +		} +		if (! -f '/usr/sbin/convertpkg-compat32') { +			print "compat32 pkgs require /usr/sbin/convertpkg-compat32.\n"; +			exit 1; +		} +	} +	my @symlinks = create_symlinks ($location,@downloads); +	prep_sbo_file ($sbo,$location); +	perform_sbo ($sbo,$location,$arch,1,1); +	my $pkg = get_pkg_name ($sbo,$version,'FALSE'); +	my $cmd = '/usr/sbin/convertpkg-compat32'; +	my @args = ('-i',"$pkg",'-d','/tmp'); +	my $out = system ($cmd,@args); +	return @symlinks; +} + +sub sb_normal { +	script_error ('sb_normal requires six arguments.') unless exists $_[5]; +	my ($jobs,$sbo,$location,$arch,$version,@downloads) = @_; +	my $x32; +	if ($arch eq 'x86_64') { +		$x32 = check_x32 ($sbo,$location); +		if ($x32) { +			if (! check_multilib () ) { +				print "$sbo is 32-bit only, however, this system does not appear  +to be setup for multilib.\n"; +				exit 1 +			} +		} +	} +	my @symlinks = create_symlinks ($location,@downloads); +	prep_sbo_file ($sbo,$location); +	perform_sbo ($sbo,$location,$arch,0,$x32); +	return @symlinks; +} + +sub do_slackbuild { +	script_error ('do_slackbuild requires two arguments.') unless exists $_[1]; +	my ($jobs,$sbo,$location,$compat32) = @_; +	my $arch = get_arch (); +	my $version = get_sbo_version ($sbo,$location); +	my $c32 = $compat32 eq 'TRUE' ? 1 : 0; +	my @downloads = get_sbo_downloads ($sbo,$location,$c32); +	my @symlinks; +	if ($compat32 eq 'TRUE') { +		@symlinks = sb_compat32 ($jobs,$sbo,$location,$arch,$version, +			@downloads); +	} else { +		@symlinks = sb_normal ($jobs,$sbo,$location,$arch,$version,@downloads); +	}  	unlink ($_) for (@symlinks);  	return $version;  } @@ -516,7 +602,7 @@ sub make_distclean {  	my ($sbo,$version,$location) = @_;  	make_clean ($sbo,$version);  	print "Distcleaning for $sbo-$version...\n"; -	my @downloads = get_sbo_downloads ($sbo,$location); +	my @downloads = get_sbo_downloads ($sbo,$location,0);  	for my $c (keys @downloads) {  		my $filename = get_filename_from_link ($downloads[$c]{link});  		unlink ($filename) if -f $filename; @@ -28,9 +28,9 @@ Options:    -c: do not clean working files/directories after the build.    -d: clean distfiles afterward.    -f: force an update, even if the "upgrade" version is the same or lower. +  -i: do not run installpkg at the end of the build process.    -N: install any new SBo's listed.    -r: skip viewing of the SBo README. -  -i: do not run installpkg at the end of the build process.  Example:    $self -d libsexy @@ -41,11 +41,11 @@ EOF  }  my %options; -getopts ('hvacdfj:Nrio',\%options); +getopts ('hvacdfj:Nriop',\%options); -show_usage () && exit(0) if exists $options{h}; -show_version () && exit(0) if exists $options{v}; +show_usage () && exit (0) if exists $options{h}; +show_version () && exit (0) if exists $options{v};  my $noclean = exists $options{c} ? 'FALSE' : $config{NOCLEAN};  my $distclean = exists $options{d} ? 'TRUE' : $config{DISTCLEAN};  my $force = exists $options{f} ? 'TRUE' : 'FALSE'; @@ -55,6 +55,7 @@ my $install_new = exists $options{N} ? 'TRUE' : 'FALSE';  my $no_readme = exists $options{r} ? 'TRUE' : 'FALSE';  my $no_install = exists $options{i} ? 'TRUE' : 'FALSE';  my $only_new = exists $options{o} ? 'TRUE' : 'FALSE'; +my $compat32 = exists $options{p} ? 'TRUE' : 'FALSE';  show_usage () and exit (1) unless exists $ARGV[0]; @@ -92,13 +93,14 @@ sub readme_prompt {  sub process_sbos {  	script_error ('process_sbos requires an argument.') unless exists $_[0]; -	my @todo = @_; +	my (@todo) = @_;  	my @failures;  	for my $sbo (@todo) {  		readme_prompt ($sbo) unless $no_readme eq 'TRUE'; +		$compat32 = 'TRUE' if $sbo =~ /-compat32$/;  		my $version;  		eval { -			$version = do_slackbuild ($jobs,$sbo,$locations{$sbo}); +			$version = do_slackbuild ($jobs,$sbo,$locations{$sbo},$compat32);  		};  		if ($@) {  			push (@failures,$sbo); @@ -110,16 +112,7 @@ sub process_sbos {  			} else {  				make_distclean ($sbo,$version,$locations{$sbo});  			} -			my $pkg; -			my $pkg_regex = qr/^(\Q$sbo\E-\Q$version\E-[^-]+-.*_SBo.t[xblg]z)$/; -			opendir my $diread, '/tmp/'; -			FIRST: while (my $ls = readdir $diread) { -				if ($ls =~ $pkg_regex) { -					chomp ($pkg = "/tmp/$1"); -					last FIRST; -				} -			} - +			my $pkg = get_pkg_name ($sbo,$version,$compat32);  			do_upgradepkg ($pkg) unless $no_install eq 'TRUE';  			unless ($config{PKG_DIR} eq 'FALSE') { @@ -182,21 +175,21 @@ unless ($only_new eq 'TRUE') {  if ($install_new eq 'TRUE') {  	my @todo_install;  	my $has = 'FALSE'; -	for (@ARGV) { +	for my $sbo (@ARGV) { +		my $name = $compat32 eq 'TRUE' ? "$sbo-compat32" : $sbo;  		SECOND: for my $index (keys @installed) { -			if ($_ eq $installed[$index]{name}) { +			if ($name eq $installed[$index]{name}) {  				$has = 'TRUE';  				last SECOND;  			}  		}  		unless ($has eq 'TRUE') { -			push (@todo_install,$_); +			push (@todo_install,$sbo);  		} else { -			print "$_ already installed.\n"; +			print "$name already installed.\n";  		}  		$has = 'FALSE';  	} -  	@failed = process_sbos (@todo_install) if exists $todo_install[0];  	print_failures ();  } | 
