summaryrefslogtreecommitdiffstats
path: root/packaging/SGI/idb.pl
diff options
context:
space:
mode:
Diffstat (limited to 'packaging/SGI/idb.pl')
-rwxr-xr-xpackaging/SGI/idb.pl236
1 files changed, 0 insertions, 236 deletions
diff --git a/packaging/SGI/idb.pl b/packaging/SGI/idb.pl
deleted file mode 100755
index 4e32bdb5267..00000000000
--- a/packaging/SGI/idb.pl
+++ /dev/null
@@ -1,236 +0,0 @@
-#!/usr/bin/perl
-
-# This perl script automatically generates the samba.idb file
-
-$curdir = $ENV{"PWD"};
-
-# get a complete list of all files in the tree
-chdir '../../';
-&dodir('.');
-chdir $curdir;
-
-# We don't want the files listed in .cvsignore in the source tree
-open(IGNORES,"../../source/.cvsignore");
-while (<IGNORES>) {
- chop;
- $ignores{$_}++;
-}
-close IGNORES;
-
-# get the names of all the binary files to be installed
-open(MAKEFILE,"Makefile");
-@makefile = <MAKEFILE>;
-@sprogs = grep(/^SPROGS /,@makefile);
-@progs1 = grep(/^PROGS1 /,@makefile);
-@progs = grep(/^PROGS /,@makefile);
-@scripts = grep(/^SCRIPTS /,@makefile);
-@codepage = grep(/^CODEPAGELIST/,@makefile);
-close MAKEFILE;
-
-if (@sprogs) {
- @sprogs[0] =~ s/^.*\=//;
- @sprogs[0] =~ s/^.*\)//;
- @sprogs = split(' ',@sprogs[0]);
-}
-if (@progs) {
- @progs[0] =~ s/^.*\=//;
- @progs[0] =~ s/^.*\)//;
- @progs = split(' ',@progs[0]);
-}
-if (@progs1) {
- @progs1[0] =~ s/^.*\=//;
- @progs1[0] =~ s/^.*\)//;
- @progs1 = split(' ',@progs1[0]);
-}
-if (@scripts) {
- @scripts[0] =~ s/^.*\=//;
- @scripts[0] =~ s/^.*\)//;
- @scripts = split(' ',@scripts[0]);
-}
-if (@codepage) {
- @codepage[0] =~ s/^.*\=//;
- @codepage[0] =~ s/^.*\)//;
- chdir '../../source';
- # if we have codepages we need to create them for the package
- system("./installcp.sh . ../packaging/SGI/codepage . @codepage[0]");
- chdir $curdir;
- @codepage = sort split(' ',@codepage[0]);
-}
-
-# add my local files to the list of binaries to install
-@bins = sort (@sprogs,@progs,@progs1,@scripts,("psfixes.pl","sambalp","smbprint"));
-
-# the files installed in docs include all the original files in docs plus all
-# the "*.doc" files from the source tree
-@docs = sort byfilename grep (!/^docs\/$/ & (/^source\/.*\.doc$/ | /^docs\//),@allfiles);
-
-@catman = sort grep(/^packaging\/SGI\/catman/ & !/\/$/, @allfiles);
-@catman = sort bydirnum @catman;
-
-# strip out all the generated directories and the "*.o" files from the source
-# release
-@allfiles = grep(!/^.*\.o$/ & !/^packaging\/SGI\/bins/ & !/^packaging\/SGI\/catman/ & !/^packaging\/SGI\/html/ & !/^packaging\/SGI\/codepage/, @allfiles);
-
-open(IDB,">samba.idb");
-
-print IDB "f 0644 root sys etc/config/samba packaging/SGI/samba.config samba.sw.base config(update)\n";
-print IDB "f 0755 root sys etc/init.d/samba packaging/SGI/samba.rc samba.sw.base\n";
-print IDB "l 0000 root sys etc/rc0.d/K39samba packaging/SGI samba.sw.base symval(../init.d/samba)\n";
-print IDB "l 0000 root sys etc/rc2.d/S81samba packaging/SGI samba.sw.base symval(../init.d/samba)\n";
-
-@copyfile = grep (/^COPY/,@allfiles);
-print IDB "d 0755 root sys usr/relnotes/samba packaging/SGI samba.man.relnotes\n";
-print IDB "f 0644 root sys usr/relnotes/samba/@copyfile[0] @copyfile[0] samba.man.relnotes\n";
-print IDB "f 0644 root sys usr/relnotes/samba/legal_notice.html packaging/SGI/legal_notice.html samba.man.relnotes\n";
-print IDB "f 0644 root sys usr/relnotes/samba/samba-relnotes.html packaging/SGI/relnotes.html samba.man.relnotes\n";
-
-print IDB "d 0755 root sys usr/samba packaging/SGI samba.sw.base\n";
-print IDB "f 0444 root sys usr/samba/README packaging/SGI/README samba.sw.base\n";
-
-print IDB "d 0755 root sys usr/samba/bin packaging/SGI samba.sw.base\n";
-while(@bins) {
- $nextfile = shift @bins;
- if ($nextfile eq "smbpasswd") {
- print IDB "f 4555 root sys usr/samba/bin/$nextfile source/$nextfile samba.sw.base\n";
- }
- elsif ($nextfile eq "psfixes.pl") {
- print IDB "f 0755 root sys usr/samba/bin/$nextfile packaging/SGI/$nextfile samba.sw.base\n";
- }
- elsif ($nextfile eq "sambalp") {
- print IDB "f 0755 root sys usr/samba/bin/$nextfile packaging/SGI/$nextfile samba.sw.base\n";
- }
- elsif ($nextfile eq "smbprint") {
- print IDB "f 0755 root sys usr/samba/bin/$nextfile packaging/SGI/$nextfile samba.sw.base\n";
- }
- else {
- print IDB "f 0755 root sys usr/samba/bin/$nextfile source/$nextfile samba.sw.base\n";
- }
-}
-
-print IDB "d 0755 root sys usr/samba/docs docs samba.man.doc\n";
-while (@docs) {
- $nextfile = shift @docs;
- next if ($nextfile eq "CVS");
- ($junk,$file) = split(/\//,$nextfile,2);
- if (grep(/\/$/,$nextfile)) {
- chop $nextfile;
- chop $file;
- print IDB "d 0755 root sys usr/samba/docs/$file $nextfile samba.man.doc\n";
- }
- else {
- print IDB "f 0644 root sys usr/samba/docs/$file $nextfile samba.man.doc\n";
- }
-}
-
-print IDB "f 0755 root sys usr/samba/inetd.sh packaging/SGI/inetd.sh samba.sw.base\n";
-print IDB "d 0755 root sys usr/samba/lib packaging/SGI samba.sw.base\n";
-if (@codepage) {
- print IDB "d 0755 root sys usr/samba/lib/codepage packaging/SGI samba.sw.base\n";
- while (@codepage) {
- $nextpage = shift @codepage;
- print IDB "f 0644 root sys usr/samba/lib/codepage/codepage.$nextpage packaging/SGI/codepage/codepage.$nextpage samba.sw.base\n";
- }
-}
-print IDB "f 0644 root sys usr/samba/lib/smb.conf packaging/SGI/smb.conf samba.sw.base config(update)\n";
-print IDB "f 0755 root sys usr/samba/mkprintcap.sh packaging/SGI/mkprintcap.sh samba.sw.base exitop(/usr/samba/mkprintcap.sh) removeop(rm /usr/samba/printcap)\n";
-
-print IDB "d 0755 root sys usr/samba/src packaging/SGI samba.src.samba\n";
-while (@allfiles) {
- $nextfile = shift @allfiles;
- ($file = $nextfile) =~ s/^.*\///;
- next if grep(/packaging\/SGI/& (/Makefile/ | /samba\.spec/ | /samba\.idb/),$nextfile);
- next if grep(/source/,$nextfile) && ($ignores{$file});
- next if ($nextfile eq "CVS");
- if (grep(/\/$/,$nextfile)) {
- chop $nextfile;
- print IDB "d 0755 root sys usr/samba/src/$nextfile $nextfile samba.src.samba\n";
- }
- else {
- if (grep(/SGI/ & (/\.sh$/ | /\.pl$/ | /mkman$/),$nextfile)) {
- print IDB "f 0755 root sys usr/samba/src/$nextfile $nextfile samba.src.samba\n";
- }
- else {
- print IDB "f 0644 root sys usr/samba/src/$nextfile $nextfile samba.src.samba\n";
- }
- }
-}
-
-print IDB "d 0755 root sys usr/samba/var packaging/SGI samba.sw.base\n";
-print IDB "d 0755 root sys usr/samba/var/locks packaging/SGI samba.sw.base\n";
-
-print IDB "d 0755 root sys usr/share/catman/u_man packaging/SGI samba.man.manpages\n";
-$olddirnum = "0";
-while (@catman) {
- $nextfile = shift @catman;
- ($file = $nextfile) =~ s/^packaging\/SGI\/catman\///;
- ($dirnum = $file) =~ s/^[\D]*//;
- $dirnum =~ s/\.Z//;
- if ($dirnum ne $olddirnum) {
- print IDB "d 0755 root sys usr/share/catman/u_man/cat$dirnum packaging/SGI samba.man.manpages\n";
- $olddirnum = $dirnum;
- }
- print IDB "f 0664 root sys usr/share/catman/u_man/cat$dirnum/$file $nextfile samba.man.manpages\n";
-}
-
-close IDB;
-print "\n\nsamba.idb file has been created\n";
-
-sub dodir {
- local($dir, $nlink) = @_;
- local($dev,$ino,$mode,$subcount);
-
- ($dev,$ino,$mode,$nlink) = stat('.') unless $nlink;
-
- opendir(DIR,'.') || die "Can't open $dir";
- local(@filenames) = sort readdir(DIR);
- closedir(DIR);
-
- if ($nlink ==2) { # This dir has no subdirectories.
- for (@filenames) {
- next if $_ eq '.';
- next if $_ eq '..';
- $this = substr($dir,2)."/$_";
- push(@allfiles,$this);
- }
- }
- else {
- $subcount = $nlink -2;
- for (@filenames) {
- next if $_ eq '.';
- next if $_ eq '..';
- next if $_ eq 'CVS';
- ($dev,$ino,$mode,$nlink) = lstat($_);
- $name = "$dir/$_";
- $this = substr($name,2);
- $this .= '/' if -d;
- push(@allfiles,$this);
- next if $subcount == 0; # seen all the subdirs?
-
- next unless -d _;
-
- chdir $_ || die "Can't cd to $name";
- &dodir($name,$nlink);
- chdir '..';
- --$subcount;
- }
- }
-}
-
-sub byfilename {
- ($f0,$f1) = split(/\//,$a,2);
- ($f0,$f2) = split(/\//,$b,2);
- $f1 cmp $f2;
-}
-
-sub bydirnum {
- ($f1 = $a) =~ s/^.*\///;
- ($f2 = $b) =~ s/^.*\///;
- ($dir1 = $a) =~ s/^[\D]*//;
- ($dir2 = $b) =~ s/^[\D]*//;
- if (!($dir1 <=> $dir2)) {
- $f1 cmp $f2;
- }
- else {
- $dir1 <=> $dir2;
- }
-}