From: "Ramsay Jones" <ramsay@ramsay1.demon.co.uk>
To: "Gerrit Pape" <pape@smarden.org>
Cc: <git@vger.kernel.org>
Subject: RE: [PATCH] Build on Debian GNU/Hurd
Date: Thu, 21 Sep 2006 18:37:56 +0100 [thread overview]
Message-ID: <000001c6dda4$ad0b1ec0$c47eedc1@ramsay1.demon.co.uk> (raw)
In-Reply-To: <20060919170335.28054.qmail@14e0e1fe2bc371.315fe32.mid.smarden.org>
On Tues Sept 19, 2006 at 18:04, Gerrit Pape wrote:
> On Fri, Sep 15, 2006 at 10:35:57PM -0700, Junio C Hamano wrote:
> > Gerrit Pape <pape@smarden.org> writes:
> > > Patch from Cyril Brulebois to make the build process detect
> and support the
> > > Debian GNU/Hurd architecture, see
> > > http://bugs.debian.org/379841
> > >
> > > Signed-off-by: Gerrit Pape <pape@smarden.org>
> > >
> > > +ifeq ($(uname_S),GNU)
> > > + # GNU stands for GNU/Hurd
> > > + NO_STRLCPY = YesPlease
> > > + ALL_CFLAGS += -DPATH_MAX=4096
> > > +endif
> >
> > Two questions come to mind. (1) Does GNU stand for GNU/Hurd and
> > nobody else? (2) Does everybody else have PATH_MAX?
>
> I'm not that familiar with the Hurd, but (1) seems to be so according
> to http://www.gnu.org/software/hurd/hurd.html; it looks like either GNU
> or GNU/Hurd is used. (2) For IRIX64 PATH_MAX also is defined explicitly
>
> git$ grep -B7 -A3 PATH_MAX Makefile
> ifeq ($(uname_S),IRIX64)
> NO_IPV6=YesPlease
> NO_SETENV=YesPlease
> NO_STRCASESTR=YesPlease
> NO_STRLCPY = YesPlease
> NO_SOCKADDR_STORAGE=YesPlease
> SHELL_PATH=/usr/gnu/bin/bash
> ALL_CFLAGS += -DPATH_MAX=1024
> # for now, build 32-bit version
> ALL_LDFLAGS += -L/usr/lib32
> endif
>
> that's where I got it from.
>
> > Adding NO_STRLCPY I do not have much problems with, but
> > something like the attached may be cleaner to deal with PATH_MAX;
> > of course now there is an issue of what the appropriate value
> > for that symbol should be.
>
> It's been so before it seems, I'm not sure why it changed.
Because without the change (below), git would not compile for me ;-)
Indeed it would not compile for any system that:
1) defines PATH_MAX in limits.h
AND 2) conditionally defines PATH_MAX to a different value.
(Actually, it does not have to be a different value, just a different
token sequence, including the presence/absence of whitespace/comments)
Note that other systems use a different "PATH_MAX value", (a value of
1024 is common), and in particular, earlier version of linux use a
value of 4095.
> http://www.debian.org/ports/hurd/hurd-devel-debian says one cannot
> expect PATH_MAX to be defined on a POSIX system,
Correct. Although PATH_MAX is a POSIX symbol, it is not required to be
defined; it *may* be defined in limits.h and, if so, must have a value
of at least 256.
The symbol _PC_PATH_MAX *may* also be defined and, if so, may be used
in a call to pathconf() to *maybe* determine a "PATH_MAX value" at
runtime; it can return a value, indicate no limit, or an "indeterminate"
limit.
... so defining it
> conditionally IMHO is the right thing.
IMHO, setting the value in the Makefile, for systems that don't define
PATH_MAX, is a much better solution. In fact, that is what I thought was
already being done.
All the best,
Ramsay
>
> git$ PAGER=cat git log -p 579d1fb..8e76483
> commit 8e76483ce0ce256b01345abc4ca97b1f94aed354
> Author: Ramsay Allan Jones <ramsay@ramsay1.demon.co.uk>
> Date: Sun Jul 30 17:00:40 2006 +0100
>
> Fix header breakage due to redefining PATH_MAX.
>
> The header builtin.h was, incorrectly, redefining PATH_MAX which
> causes a header order dependency in builtin-write-tree.c. The fix
> is to simply include <limits.h> directly to obtain the correct
> definition of PATH_MAX.
>
> Signed-off-by: Ramsay Allan Jones <ramsay@ramsay1.demon.co.uk>
> Signed-off-by: Junio C Hamano <junkio@cox.net>
>
> diff --git a/builtin.h b/builtin.h
> index 1c8637a..88c4d84 100644
> --- a/builtin.h
> +++ b/builtin.h
> @@ -2,10 +2,7 @@ #ifndef BUILTIN_H
> #define BUILTIN_H
>
> #include <stdio.h>
> -
> -#ifndef PATH_MAX
> -# define PATH_MAX 4096
> -#endif
> +#include <limits.h>
>
> extern const char git_version_string[];
>
next prev parent reply other threads:[~2006-09-21 17:38 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-09-15 12:58 [PATCH] Build on Debian GNU/Hurd Gerrit Pape
2006-09-15 15:47 ` Martin Waitz
2006-09-16 5:35 ` Junio C Hamano
2006-09-19 17:03 ` Gerrit Pape
2006-09-21 17:37 ` Ramsay Jones [this message]
2006-09-21 17:53 ` Linus Torvalds
2006-09-22 17:22 ` Ramsay Jones
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='000001c6dda4$ad0b1ec0$c47eedc1@ramsay1.demon.co.uk' \
--to=ramsay@ramsay1.demon.co.uk \
--cc=git@vger.kernel.org \
--cc=pape@smarden.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).