Date: Sun, 10 Jul 2005 23:13:12 +0200 From: Olivier Certner <olivier.certner@free.fr> To: freebsd-hackers@freebsd.org Subject: Bug in portupgrade Message-ID: <200507102313.12719.olivier.certner@free.fr>
next in thread | raw e-mail | index | archive | help
Hi,
There is a bug with portupgrade when it is used to upgrade already compiled
and installed ports for which some dependencies have been deleted in the
package database. This causes a crash in the function 'deorigin' in pkgdb.rb.
Since I don't know the internals of portupgrade, I don't know if it's normal
to call 'deorigin' with its argument set to nil. If it is, then the patch
below might be useful (beware, I don't know any ruby, I've just tried
something and it works), if it is not, I only can provide the stack (see
below) in order for maintainers to seek the faulty callers.
Regards,
Olivier
---------------
/usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:323:in `deorigin': cannot convert
nil into String (PkgDB::DBError)
from /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:916:in `tsort_build'
from /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:915:in `each'
from /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:915:in `tsort_build'
from /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:907:in `each'
from /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:907:in `tsort_build'
from /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:929:in `sort_build'
from /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb:933:in `sort_build!'
from /usr/local/sbin/portupgrade:674:in `main'
from /usr/local/sbin/portupgrade:207:in `initialize'
from /usr/local/sbin/portupgrade:207:in `new'
from /usr/local/sbin/portupgrade:207:in `main'
from /usr/local/sbin/portupgrade:1869
---------------
*** /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb~ Mon Jul 4 00:05:41 2005
--- /usr/local/lib/ruby/site_ruby/1.8/pkgdb.rb Mon Jul 4 00:09:34 2005
***************
*** 313,323 ****
def deorigin(origin)
open_db
! if str = @db['?' + origin]
! str.split
else
nil
end
rescue => e
raise DBError, e.message
end
--- 313,328 ----
def deorigin(origin)
open_db
! if origin != nil
! if str = @db['?' + origin]
! str.split
! else
! nil
! end
else
nil
end
+
rescue => e
raise DBError, e.message
end
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200507102313.12719.olivier.certner>
