From fa532bb7d63965c8bd89fe0bb9546fb7d47e0692 Mon Sep 17 00:00:00 2001 From: geos_one Date: Tue, 21 Aug 2007 12:19:06 +0000 Subject: [PATCH] Add missing things --- .../scripts/deputils/checkdeps.rb | 127 ------ .../experimental/scripts/deputils/oneelf.rb | 19 - .../experimental/scripts/deputils/pkgutil.rb | 60 --- branches/experimental/scripts/echangelog | 403 ------------------ .../files/digest-novell-novlc1-1.3.6_p1-r5 | 3 + trunk/novell4gentoo/scripts/echangelog | 403 ------------------ trunk/novell4gentoo/scripts/redigest | 7 - 7 files changed, 3 insertions(+), 1019 deletions(-) delete mode 100755 branches/experimental/scripts/deputils/checkdeps.rb delete mode 100755 branches/experimental/scripts/deputils/oneelf.rb delete mode 100755 branches/experimental/scripts/deputils/pkgutil.rb delete mode 100755 branches/experimental/scripts/echangelog create mode 100644 trunk/novell4gentoo/app-admin/novell-novlc1/files/digest-novell-novlc1-1.3.6_p1-r5 delete mode 100755 trunk/novell4gentoo/scripts/echangelog delete mode 100644 trunk/novell4gentoo/scripts/redigest diff --git a/branches/experimental/scripts/deputils/checkdeps.rb b/branches/experimental/scripts/deputils/checkdeps.rb deleted file mode 100755 index 65762132..00000000 --- a/branches/experimental/scripts/deputils/checkdeps.rb +++ /dev/null @@ -1,127 +0,0 @@ -#!/usr/bin/ruby -w - -# Licensed under GPL-2 or later -# Author: Petteri Räty - -$: << File.dirname(__FILE__) -require "pkgutil.rb" - -$verbose = false -$quiet = false - -pkgs_to_check=[] - -def print_help(exit_value) - puts 'Usage: checkdeps.rb opts|pkgs' - puts - puts 'Options:' - puts '-q, --quiet' - puts '-v, --verbose' - puts '-h, --help' - puts '-d, --debug' - puts - puts 'Everything else is passed to qfile as it is' - exit(exit_value) -end - -ARGV.each do | arg | - if arg =~ /^(-v|--verbose)$/ - $verbose = true - elsif arg =~ /^(-h|--help)$/ - print_help(0) - elsif arg =~ /^(-q|--quiet)$/ - $quiet = true - elsif arg =~ /^(-d|--debug)$/ - $DEBUG = true - $verbose = true - else - pkgs_to_check << arg - end -end - -pkgs_to_check.length == 0 && print_help(1) - -class ElfObj - attr_reader :path, :pkgs - - def initialize(path) - @path = path - @pkgs = [] - end - - def <<(pkg) - if ! @pkgs.index(pkg) - @pkgs << pkg - else - nil - end - end - - def <=>(r) - return @path <=> r.path - end - - def to_s() - puts 'ElfObj to_s:' if $DEBUG - s = "\t" + @path - s+="\t" + @path + "\n\t\t" + @pkgs.sort.join("\n\t\t") if $DEBUG - s - end -end - - -def handle_new_lib(obj,lib) - puts 'library: ' + lib if $DEBUG - $lib_hash[lib]=nil - pkg = get_pkg_of_lib(lib) - - if ! pkg - return - end - - if obj_table = $pkg_hash[pkg] - obj_table << obj - else - $pkg_hash[pkg]=[obj] - obj << pkg - end -end - -$lib_hash ={} -$pkg_hash ={} - -qlist = IO.popen("qlist #{pkgs_to_check.join(' ')}") - -scan_elf = ScanElf.instance - -while obj = qlist.gets - obj.rstrip! - if is_elf(obj) - puts 'obj: ' + obj if $DEBUG - elf_obj = ElfObj.new(obj) - scan_elf.each(obj) do | lib | - handle_new_lib(elf_obj,lib) unless $lib_hash.key?(lib) - end - else - puts "#{file} is not executable or a normal file" if $verbose - end -end - -qlist.close - -if $? != 0 - $stderr.puts('qlist did not run succesfully.') - $stderr.puts('Please emerge portage-utils if you don\'t already have it.') -end - -$pkg_hash.sort.each do | pair | - puts 'Key: ' if $DEBUG - puts pair[0] - puts 'Value: ' if $DEBUG - puts pair[1].uniq.sort unless $quiet - puts 'end Hash.' if $DEBUG -end - -if $verbose - puts $lib_hash.keys -end diff --git a/branches/experimental/scripts/deputils/oneelf.rb b/branches/experimental/scripts/deputils/oneelf.rb deleted file mode 100755 index ac0c419e..00000000 --- a/branches/experimental/scripts/deputils/oneelf.rb +++ /dev/null @@ -1,19 +0,0 @@ -#!/usr/bin/ruby -w - -# Licensed under GPL-2 or later -# Author: Petteri Räty - -$: << File.dirname(__FILE__) -require "pkgutil.rb" - -elf = ARGV[0] - -if ! elf || ! is_elf(elf) - $stderr.puts 'This program takes one arguments that should be an elf file.' - exit 1 -end - -run_scanelf(elf) do | lib | - puts lib - puts "\t" + get_pkg_of_lib(lib) -end \ No newline at end of file diff --git a/branches/experimental/scripts/deputils/pkgutil.rb b/branches/experimental/scripts/deputils/pkgutil.rb deleted file mode 100755 index 12f03857..00000000 --- a/branches/experimental/scripts/deputils/pkgutil.rb +++ /dev/null @@ -1,60 +0,0 @@ -# Licensed under GPL-2 or later -# Author: Petteri Räty - -MAGIC="\x7FELF" -def is_elf(file) - File.executable?(file) && File.file?(file) && File.read(file, 4) == MAGIC -end - -def get_pkg_of_lib(lib) - command='qfile -qC ' + lib - output = `#{command}`.split("\n") - output.uniq! - output.join(' || ') -end - -def handle_extra_output(prog) - $stderr.puts 'This program expects only one line' - $stderr.puts 'of output from scanelf. Extra lines:' - while line = scanelf.gets - $stderr.puts line - end - exit 2 -end - -def run_scanelf(elf) - scanelf = IO.popen("scanelf -q -F '%n#F' #{elf}") - first_line = scanelf.gets - handle_extra_output(scanelf) if not scanelf.eof? - scanelf.close - - libs = first_line.split(',') - for lib in libs - yield lib - end -end - -class ScanElf - private_class_method :new - @@instance = nil - - def ScanElf.instance - @@instance = new unless @@instance - @@instance - end - - def initialize - @process = IO.popen('scanelf -q -F "%n#F" -f /dev/stdin','r+') - end - - def each(elf) - @process.puts(elf) - result = @process.gets - - libs = result.split(',') - for lib in libs - yield lib - end - end -end - \ No newline at end of file diff --git a/branches/experimental/scripts/echangelog b/branches/experimental/scripts/echangelog deleted file mode 100755 index 9e4cff8e..00000000 --- a/branches/experimental/scripts/echangelog +++ /dev/null @@ -1,403 +0,0 @@ -#!/usr/bin/perl -w -# -# echangelog: Update the ChangeLog for an ebuild. For example: -# -# $ echangelog 'Add ~alpha to KEYWORDS' -# 4a5,7 -# > 10 Feb 2003; Aron Griffis oaf-0.6.8-r1.ebuild : -# > Add ~alpha to KEYWORDS -# > - -use strict; -use POSIX qw(strftime getcwd setlocale); - -# Fix bug 21022 by restricting to C locale -setlocale(&POSIX::LC_ALL, "C"); - -use Text::Wrap; -$Text::Wrap::columns = 77; -$Text::Wrap::unexpand = 0; - -# Global variables -my (@files, @ebuilds, @conflicts, @trivial, @unknown, @new_versions, %actions); -my ($input, $editor, $entry, $user, $date, $text, $version, $year, $vcs); - -my %vcs = ( cvs => { diff => "cvs -f -U0 diff", - status => "cvs -fn up", - add => "cvs -f add", - skip => 6, - entries => "CVS/Entries" }, - svn => { diff => "svn diff -N", - status => "svn status", - add => "svn add", - skip => 4, - entries => ".svn/entries" }, - git => { diff => "git diff", - status => "git up", - add => "git add", - skip => 0, - entries => "wtf" }, - nov => { diff => "", - status => "", - add => "", - skip => 0, - entries => "wtf" } -); - -# Figure out what kind of repo we are in. - -if ( -d "CVS" ) { - $vcs = "cvs"; -} elsif ( -d '.svn' ) { - $vcs = "svn"; -} elsif ( -d '.git' ) { - $vcs = "git"; -} else { - print STDERR "** NOTE: No CVS, .git, .svn directories found, cannot know modifications\n"; - $vcs = "nov"; -} - -# Read the current ChangeLog -if (-f 'ChangeLog') { - open I, '; } - close I; -} else { - # No ChangeLog here, maybe we should make one... - if (<*.ebuild>) { - open I, '<../../skel.ChangeLog' - or die "Can't open ../../skel.ChangeLog for input: $!\n"; - { local $/ = undef; $text = ; } - close I; - my ($cwd) = getcwd(); - $cwd =~ m|.*/(\w+-\w+)/([^/]+)| - or die "Can't figure out category/package.. sorry!\n"; - my ($category, $package_name) = ($1, $2); - $text =~ s/^\*.*//ms; # don't need the fake entry - $text =~ s//$category/; - $text =~ s//$package_name/; - } else { - die "This should be run in a directory with ebuilds...\n"; - } -} - -# Figure out what has changed around here -open C, $vcs{$vcs}{status}.' 2>&1 |' or die "Can't run ".$vcs{$vcs}{status}.": $!\n"; -while () { - if (/^C\s+\+?\s+(\S+)/) { - push @conflicts, $1; - next; - } elsif (/^\?\s+\+?\s+(\S+)/) { - push @unknown, $1; - $actions{$1} = '+'; - next; - } elsif (/^([ARMD])\s+\+?\s+(\S+)/) { - push @files, $2; - ($actions{$2} = $1) =~ tr/ARDM/+--/d; - } -} - -# Separate out the trivial files for now -@files = grep { - !/files.digest|Manifest|ChangeLog|^files$|^\.$/ or do { push @trivial, $_; 0; } -} @files; - -@unknown = grep { - !/files.digest|Manifest|ChangeLog|^files$|^\.$/ or do { push @trivial, $_; 0; } -} @unknown; - -# Don't allow any conflicts -if (@conflicts) { - print STDERR < $nb[$i]); - return $retval if $retval; - next; - } - - # char vs. char - if ($na[$i] =~ /^\D/ and $nb[$i] =~ /^\D/) { - $retval = ($na[$i] cmp $nb[$i]); - return $retval if $retval; - next; - } - - # num vs. char - $retval = ($na[$i] =~ /\d/ and -1 or +1); - return $retval; - } - - # - # compare suffix second - # - if (defined $sa and !defined $sb) { - return +2 if $sa eq "p"; - return -2; - } - if (defined $sb and !defined $sa) { - return -3 if $sb eq "p"; - return +3; - } - - if (defined $sa) { # and defined $sb - $retval = ($sa cmp $sb); - if ($retval) { - return +4 if $sa eq "p"; - return -4 if $sb eq "p"; - return $retval; # suffixes happen to be alphabetical order, mostly - } - - # compare suffix number - return +5 if defined $sna and !defined $snb; - return -5 if defined $snb and !defined $sna; - if (defined $sna) { # and defined $snb - $retval = ($sna <=> $snb); - return $retval if $retval; - } - } - - # - # compare rev third - # - return +6 if defined $ra and !defined $rb; - return -6 if defined $rb and !defined $ra; - if (defined $ra) { # and defined $rb - return ($ra <=> $rb); - } - - # - # nothing left to compare - # - return 0; -} -@files = sort sortfunc @files; - -# Forget ebuilds that only have changed copyrights, unless that's all -# the changed files we have -# does not work with svn TODO -#@ebuilds = grep /\.ebuild$/, @files; -#@files = grep !/\.ebuild$/, @files; - -if (@ebuilds) { - open C, $vcs{$vcs}{diff}.@ebuilds." 2>&1 |" or die "Can't run: ".$vcs{$vcs}{diff}."$!\n"; - $_ = ; - while (defined $_) { - if (/^$vcs diff: (([^\/]*?)\.ebuild) was removed/) { - push @files, $1; - } - elsif (/^Index: (([^\/]*?)\.ebuild)\s*$/) { - my ($f, $v) = ($1, $2); - # check if more than just copyright date changed. - # skip some lines - foreach(1..$vcs{$vcs}{skip}){ - $_ = ; - } - while () { - last if /^[A-Za-z]/; - if (/^[-+](?!# Copyright)/) { - push @files, $f; - last; - } - } - # at this point we've either added $f to @files or not, - # and we have the next line in $_ for processing - next; - } - elsif (/^$vcs.*?: (([^\/]*?)\.ebuild) is a new entry/) { - push @files, $1; - push @new_versions, $2; # new ebuild, will create a new entry - } - # other cvs output is ignored - $_ = ; - } -} -close C; - -# When a package move occurs, the versions appear to be new even though they are -# not. Trim them from @new_versions in that case. -@new_versions = grep { $text !~ /^\*\Q$_\E\s/m } @new_versions; - -# Check if we have any files left, otherwise re-insert ebuild list -# (of course, both might be empty anyway) -@files = @ebuilds unless (@files); - -# Allow ChangeLog entries with no changed files, but give a fat warning -unless (@files) { - print STDERR "**\n"; - print STDERR "** NOTE: No non-trivial changed files found. Normally echangelog\n"; - print STDERR "** should be run after all affected files have been added and/or\n"; - print STDERR "** modified. Did you forget to cvs add?\n"; - print STDERR "**\n"; - @files = sort sortfunc @trivial; - @files = qw/ChangeLog/ unless @files; # last resort to put something in the list -} - -# Get the input from the cmdline, editor or stdin -if ($ARGV[0]) { - $input = "@ARGV"; -} else { - # Testing for defined() allows ECHANGELOG_EDITOR='' to cancel EDITOR - $editor = defined($ENV{'ECHANGELOG_EDITOR'}) ? $ENV{'ECHANGELOG_EDITOR'} : - $ENV{'EDITOR'} || undef; - if ($editor) { - system("$editor ChangeLog.new"); - if ($? != 0) { - # This usually happens when the editor got forcefully killed; and - # the terminal is probably messed up: so we reset things. - system('/usr/bin/stty sane'); - print STDERR "Editor died! Reverting to stdin method.\n"; - undef $editor; - } else { - if (open I, "; - close I; - } else { - print STDERR "Error opening ChangeLog.new: $!\n"; - print STDERR "Reverting to stdin method.\n"; - undef $editor; - } - unlink 'ChangeLog.new'; - } - } - unless ($editor) { - print "Please type the log entry: use Ctrl-d to finish, Ctrl-c to abort...\n"; - local $/ = undef; - $input = <>; - } -} -die "Empty entry; aborting\n" unless $input =~ /\S/; - -# If there are any long lines, then wrap the input at $columns chars -# (leaving 2 chars on left, one char on right, after adding indentation below). -$input =~ s/^\s*(.*?)\s*\z/$1/s; # trim whitespace -$input = Text::Wrap::fill('', '', $input) if ($input =~ /^.{80}/m); -$input =~ s/^/ /gm; # add indentation - -# Prepend the user info to the input -unless ($user = $ENV{'ECHANGELOG_USER'}) { - my ($fullname, $username) = (getpwuid($<))[6,0]; - $fullname =~ s/,.*//; # remove GECOS, bug 80011 - $user = sprintf "%s <%s\@gentoo.org>", $fullname, $username; -} -# Make sure that we didn't get "root" -die "Please set ECHANGELOG_USER or run as non-root\n" if $user =~ /ChangeLog.new' or die "Can't open ChangeLog.new for output: $!\n"; -print O $text or die "Can't write ChangeLog.new: $!\n"; -close O or die "Can't close ChangeLog.new: $!\n"; - -# Update affected ebuild copyright dates. There is no reason to update the -# copyright lines on ebuilds that haven't changed. I verified this with an IP -# lawyer. -for my $e (grep /\.ebuild$/, @files) { - my ($etext, $netext); - open E, "<$e" or warn("Can't read $e to update copyright year\n"), next; - { local $/ = undef; $etext = ; } - close E; - - # Attempt the substitution and compare - $netext = update_copyright($etext); - next if $netext eq $etext; # skip this file if no change. - - # Write the new ebuild - open E, ">$e.new" or warn("Can't open $e.new\n"), next; - print E $netext and - close E or warn("Can't write $e.new\n"), next; - - # Move things around and show the diff - system "diff -U 0 $e $e.new"; - rename "$e.new", $e or warn("Can't rename $e.new: $!\n"); -} - -# Move things around and show the ChangeLog diff -system 'diff -Nu ChangeLog ChangeLog.new'; -rename 'ChangeLog.new', 'ChangeLog' or die "Can't rename ChangeLog.new: $!\n"; - -# Okay, now we have a starter ChangeLog to work with. -# The text will be added just like with any other ChangeLog below. -# Add the new ChangeLog to cvs before continuing. -if (open F, $vcs{$vcs}{entries} ) { - system("$vcs{$vcs}{add} ChangeLog") unless (scalar grep /\/?ChangeLog\/?/, ); -} - -# vim:sw=4 ts=8 expandtab diff --git a/trunk/novell4gentoo/app-admin/novell-novlc1/files/digest-novell-novlc1-1.3.6_p1-r5 b/trunk/novell4gentoo/app-admin/novell-novlc1/files/digest-novell-novlc1-1.3.6_p1-r5 new file mode 100644 index 00000000..f1a5e246 --- /dev/null +++ b/trunk/novell4gentoo/app-admin/novell-novlc1/files/digest-novell-novlc1-1.3.6_p1-r5 @@ -0,0 +1,3 @@ +MD5 414399d86aa3e7e6fba34937e69e59d3 c1_136f-linux.tar.gz 39985363 +RMD160 f6a18cd0c9802c41ae35fb587e08f807776de92f c1_136f-linux.tar.gz 39985363 +SHA256 1263d8e3610719d9f353ac43501b596bfcef126c24f749af8cee1247148927a9 c1_136f-linux.tar.gz 39985363 diff --git a/trunk/novell4gentoo/scripts/echangelog b/trunk/novell4gentoo/scripts/echangelog deleted file mode 100755 index 9e4cff8e..00000000 --- a/trunk/novell4gentoo/scripts/echangelog +++ /dev/null @@ -1,403 +0,0 @@ -#!/usr/bin/perl -w -# -# echangelog: Update the ChangeLog for an ebuild. For example: -# -# $ echangelog 'Add ~alpha to KEYWORDS' -# 4a5,7 -# > 10 Feb 2003; Aron Griffis oaf-0.6.8-r1.ebuild : -# > Add ~alpha to KEYWORDS -# > - -use strict; -use POSIX qw(strftime getcwd setlocale); - -# Fix bug 21022 by restricting to C locale -setlocale(&POSIX::LC_ALL, "C"); - -use Text::Wrap; -$Text::Wrap::columns = 77; -$Text::Wrap::unexpand = 0; - -# Global variables -my (@files, @ebuilds, @conflicts, @trivial, @unknown, @new_versions, %actions); -my ($input, $editor, $entry, $user, $date, $text, $version, $year, $vcs); - -my %vcs = ( cvs => { diff => "cvs -f -U0 diff", - status => "cvs -fn up", - add => "cvs -f add", - skip => 6, - entries => "CVS/Entries" }, - svn => { diff => "svn diff -N", - status => "svn status", - add => "svn add", - skip => 4, - entries => ".svn/entries" }, - git => { diff => "git diff", - status => "git up", - add => "git add", - skip => 0, - entries => "wtf" }, - nov => { diff => "", - status => "", - add => "", - skip => 0, - entries => "wtf" } -); - -# Figure out what kind of repo we are in. - -if ( -d "CVS" ) { - $vcs = "cvs"; -} elsif ( -d '.svn' ) { - $vcs = "svn"; -} elsif ( -d '.git' ) { - $vcs = "git"; -} else { - print STDERR "** NOTE: No CVS, .git, .svn directories found, cannot know modifications\n"; - $vcs = "nov"; -} - -# Read the current ChangeLog -if (-f 'ChangeLog') { - open I, '; } - close I; -} else { - # No ChangeLog here, maybe we should make one... - if (<*.ebuild>) { - open I, '<../../skel.ChangeLog' - or die "Can't open ../../skel.ChangeLog for input: $!\n"; - { local $/ = undef; $text = ; } - close I; - my ($cwd) = getcwd(); - $cwd =~ m|.*/(\w+-\w+)/([^/]+)| - or die "Can't figure out category/package.. sorry!\n"; - my ($category, $package_name) = ($1, $2); - $text =~ s/^\*.*//ms; # don't need the fake entry - $text =~ s//$category/; - $text =~ s//$package_name/; - } else { - die "This should be run in a directory with ebuilds...\n"; - } -} - -# Figure out what has changed around here -open C, $vcs{$vcs}{status}.' 2>&1 |' or die "Can't run ".$vcs{$vcs}{status}.": $!\n"; -while () { - if (/^C\s+\+?\s+(\S+)/) { - push @conflicts, $1; - next; - } elsif (/^\?\s+\+?\s+(\S+)/) { - push @unknown, $1; - $actions{$1} = '+'; - next; - } elsif (/^([ARMD])\s+\+?\s+(\S+)/) { - push @files, $2; - ($actions{$2} = $1) =~ tr/ARDM/+--/d; - } -} - -# Separate out the trivial files for now -@files = grep { - !/files.digest|Manifest|ChangeLog|^files$|^\.$/ or do { push @trivial, $_; 0; } -} @files; - -@unknown = grep { - !/files.digest|Manifest|ChangeLog|^files$|^\.$/ or do { push @trivial, $_; 0; } -} @unknown; - -# Don't allow any conflicts -if (@conflicts) { - print STDERR < $nb[$i]); - return $retval if $retval; - next; - } - - # char vs. char - if ($na[$i] =~ /^\D/ and $nb[$i] =~ /^\D/) { - $retval = ($na[$i] cmp $nb[$i]); - return $retval if $retval; - next; - } - - # num vs. char - $retval = ($na[$i] =~ /\d/ and -1 or +1); - return $retval; - } - - # - # compare suffix second - # - if (defined $sa and !defined $sb) { - return +2 if $sa eq "p"; - return -2; - } - if (defined $sb and !defined $sa) { - return -3 if $sb eq "p"; - return +3; - } - - if (defined $sa) { # and defined $sb - $retval = ($sa cmp $sb); - if ($retval) { - return +4 if $sa eq "p"; - return -4 if $sb eq "p"; - return $retval; # suffixes happen to be alphabetical order, mostly - } - - # compare suffix number - return +5 if defined $sna and !defined $snb; - return -5 if defined $snb and !defined $sna; - if (defined $sna) { # and defined $snb - $retval = ($sna <=> $snb); - return $retval if $retval; - } - } - - # - # compare rev third - # - return +6 if defined $ra and !defined $rb; - return -6 if defined $rb and !defined $ra; - if (defined $ra) { # and defined $rb - return ($ra <=> $rb); - } - - # - # nothing left to compare - # - return 0; -} -@files = sort sortfunc @files; - -# Forget ebuilds that only have changed copyrights, unless that's all -# the changed files we have -# does not work with svn TODO -#@ebuilds = grep /\.ebuild$/, @files; -#@files = grep !/\.ebuild$/, @files; - -if (@ebuilds) { - open C, $vcs{$vcs}{diff}.@ebuilds." 2>&1 |" or die "Can't run: ".$vcs{$vcs}{diff}."$!\n"; - $_ = ; - while (defined $_) { - if (/^$vcs diff: (([^\/]*?)\.ebuild) was removed/) { - push @files, $1; - } - elsif (/^Index: (([^\/]*?)\.ebuild)\s*$/) { - my ($f, $v) = ($1, $2); - # check if more than just copyright date changed. - # skip some lines - foreach(1..$vcs{$vcs}{skip}){ - $_ = ; - } - while () { - last if /^[A-Za-z]/; - if (/^[-+](?!# Copyright)/) { - push @files, $f; - last; - } - } - # at this point we've either added $f to @files or not, - # and we have the next line in $_ for processing - next; - } - elsif (/^$vcs.*?: (([^\/]*?)\.ebuild) is a new entry/) { - push @files, $1; - push @new_versions, $2; # new ebuild, will create a new entry - } - # other cvs output is ignored - $_ = ; - } -} -close C; - -# When a package move occurs, the versions appear to be new even though they are -# not. Trim them from @new_versions in that case. -@new_versions = grep { $text !~ /^\*\Q$_\E\s/m } @new_versions; - -# Check if we have any files left, otherwise re-insert ebuild list -# (of course, both might be empty anyway) -@files = @ebuilds unless (@files); - -# Allow ChangeLog entries with no changed files, but give a fat warning -unless (@files) { - print STDERR "**\n"; - print STDERR "** NOTE: No non-trivial changed files found. Normally echangelog\n"; - print STDERR "** should be run after all affected files have been added and/or\n"; - print STDERR "** modified. Did you forget to cvs add?\n"; - print STDERR "**\n"; - @files = sort sortfunc @trivial; - @files = qw/ChangeLog/ unless @files; # last resort to put something in the list -} - -# Get the input from the cmdline, editor or stdin -if ($ARGV[0]) { - $input = "@ARGV"; -} else { - # Testing for defined() allows ECHANGELOG_EDITOR='' to cancel EDITOR - $editor = defined($ENV{'ECHANGELOG_EDITOR'}) ? $ENV{'ECHANGELOG_EDITOR'} : - $ENV{'EDITOR'} || undef; - if ($editor) { - system("$editor ChangeLog.new"); - if ($? != 0) { - # This usually happens when the editor got forcefully killed; and - # the terminal is probably messed up: so we reset things. - system('/usr/bin/stty sane'); - print STDERR "Editor died! Reverting to stdin method.\n"; - undef $editor; - } else { - if (open I, "; - close I; - } else { - print STDERR "Error opening ChangeLog.new: $!\n"; - print STDERR "Reverting to stdin method.\n"; - undef $editor; - } - unlink 'ChangeLog.new'; - } - } - unless ($editor) { - print "Please type the log entry: use Ctrl-d to finish, Ctrl-c to abort...\n"; - local $/ = undef; - $input = <>; - } -} -die "Empty entry; aborting\n" unless $input =~ /\S/; - -# If there are any long lines, then wrap the input at $columns chars -# (leaving 2 chars on left, one char on right, after adding indentation below). -$input =~ s/^\s*(.*?)\s*\z/$1/s; # trim whitespace -$input = Text::Wrap::fill('', '', $input) if ($input =~ /^.{80}/m); -$input =~ s/^/ /gm; # add indentation - -# Prepend the user info to the input -unless ($user = $ENV{'ECHANGELOG_USER'}) { - my ($fullname, $username) = (getpwuid($<))[6,0]; - $fullname =~ s/,.*//; # remove GECOS, bug 80011 - $user = sprintf "%s <%s\@gentoo.org>", $fullname, $username; -} -# Make sure that we didn't get "root" -die "Please set ECHANGELOG_USER or run as non-root\n" if $user =~ /ChangeLog.new' or die "Can't open ChangeLog.new for output: $!\n"; -print O $text or die "Can't write ChangeLog.new: $!\n"; -close O or die "Can't close ChangeLog.new: $!\n"; - -# Update affected ebuild copyright dates. There is no reason to update the -# copyright lines on ebuilds that haven't changed. I verified this with an IP -# lawyer. -for my $e (grep /\.ebuild$/, @files) { - my ($etext, $netext); - open E, "<$e" or warn("Can't read $e to update copyright year\n"), next; - { local $/ = undef; $etext = ; } - close E; - - # Attempt the substitution and compare - $netext = update_copyright($etext); - next if $netext eq $etext; # skip this file if no change. - - # Write the new ebuild - open E, ">$e.new" or warn("Can't open $e.new\n"), next; - print E $netext and - close E or warn("Can't write $e.new\n"), next; - - # Move things around and show the diff - system "diff -U 0 $e $e.new"; - rename "$e.new", $e or warn("Can't rename $e.new: $!\n"); -} - -# Move things around and show the ChangeLog diff -system 'diff -Nu ChangeLog ChangeLog.new'; -rename 'ChangeLog.new', 'ChangeLog' or die "Can't rename ChangeLog.new: $!\n"; - -# Okay, now we have a starter ChangeLog to work with. -# The text will be added just like with any other ChangeLog below. -# Add the new ChangeLog to cvs before continuing. -if (open F, $vcs{$vcs}{entries} ) { - system("$vcs{$vcs}{add} ChangeLog") unless (scalar grep /\/?ChangeLog\/?/, ); -} - -# vim:sw=4 ts=8 expandtab diff --git a/trunk/novell4gentoo/scripts/redigest b/trunk/novell4gentoo/scripts/redigest deleted file mode 100644 index 3a5850bd..00000000 --- a/trunk/novell4gentoo/scripts/redigest +++ /dev/null @@ -1,7 +0,0 @@ -#!/bin/sh - -EBUILD=`find ${PWD} -type f -name '*.ebuild'` - -for J in $EBUILD ; do - ebuild $J digest -done \ No newline at end of file