On Tue, Apr 22, 2008 at 11:50 PM, Mike Meyer <[EMAIL PROTECTED]> wrote:
> On Tue, 22 Apr 2008 22:40:21 -0700 > "Garrett Cooper" <[EMAIL PROTECTED]> wrote: > > > Hi all, > > I made an oops in a program, which uncovered "feature" in strdup(2) > > that I wasn't aware of before. So I was wondering, is strdup(pointer = > NULL) > > supposed to segfault should this just return NULL and set errno? > > Yes, it's supposed to segfault. Check out what, say, strcpy does if > you ask it to copy a NULL pointer. And this is an improvement from the > bad old days, when they would happily walk through memory starting at > 0..... > > Besides, errno is used to signal errors from system calls. strdup > isn't a system call, it's a library function (says so at the top of > the man page). > > > Good news is that Linux does the same thing (yay?), so at least > FreeBSD > > isn't alone.. > > Do you have examples of systems where strdup doesn't behave this way? > > <mike No, I don't, but then again I just noticed this. -Garrett _______________________________________________ freebsd-hackers@freebsd.org mailing list http://lists.freebsd.org/mailman/listinfo/freebsd-hackers To unsubscribe, send any mail to "[EMAIL PROTECTED]"