Subject: Re: pkg/20978: mail/deliver is not compatible with recent NetBSD libc
To: None <jbernard@mines.edu>
From: Todd Vierling <tv@pobox.com>
List: netbsd-bugs
Date: 04/07/2003 10:50:33
On Tue, 1 Apr 2003 jbernard@mines.edu wrote:

: 	The problem is that it uses the basename function to construct file
: 	names [in lock.c (dotlock_name) and subs.c (unique)], and its usage
: 	of basename assumes that the function returns a pointer that
: 	references a location within the source string (which deliver then
: 	uses to modify the string).  However NetBSD's libc/gen/basename.c
: 	was changed on Oct. 17, 2002 (rev. 1.5 of basename.c) to always
: 	return a pointer to static storage containing the base name, so
: 	deliver fails to construct usable file names.

This is a severe problem.  I've seen other code which depends on basename
returning an in-situ pointer, and the change to libc (without versioning the
call because of the ABI change) is alarming.

NetBSDheads:  Is there really a reason not to return a pointer into the
existing string?

-- 
-- Todd Vierling <tv@pobox.com>