Re: Разные архитектуры
Maxim Dounin
mdounin на mdounin.ru
Чт Ноя 24 10:51:52 UTC 2011
Hello!
On Thu, Nov 24, 2011 at 02:35:35PM +0400, Igor Sysoev wrote:
> On Thu, Nov 24, 2011 at 02:34:33PM +0400, Igor Sysoev wrote:
> > On Thu, Nov 24, 2011 at 02:13:07PM +0400, Dmitry E. Oboukhov wrote:
> > > Есть архитектуры [1], на которых отсутствует макрос PATH_MAX.
> > >
> > > Есть так же много размышлений (например [2]) в сети на тему почему
> > > PATH_MAX использовать не стоит итп.
> > >
> > > Ну и есть в частности результат в виде логов, что nginx на этих
> > > платформах недоступен (как пример [3]).
> > >
> > > grep на предмет использования PATH_MAX показывает всего два места где
> > > это применяется:
> > >
> > > $ grep NGX_MAX_PATH -r src
> > >
> > > src/http/ngx_http_variables.c: u_char
> > > real[NGX_MAX_PATH];
> > > src/os/unix/ngx_files.h:#define NGX_MAX_PATH PATH_MAX
> > > src/core/nginx.c: p = ngx_pnalloc(cycle->pool, NGX_MAX_PATH);
> > > src/core/nginx.c: if (ngx_getcwd(p, NGX_MAX_PATH) == 0) {
> > > rc/core/ngx_file.h:#define NGX_MAX_PATH_LEVEL 3
> > >
> > >
> > > И вроде их оба несложно пофиксить для более успешного продвижения
> > > nginx на другие архитектуры.
> > >
> > > Что кто думает по этому поводу? Ну кроме "hurd не нужен"?
> > >
> > > 1. http://www.gnu.org/s/hurd/community/gsoc/project_ideas/maxpath.html
> > > 2. http://insanecoding.blogspot.com/2007/11/pathmax-simply-isnt.html
> > > 3. https://buildd.debian.org/status/fetch.php?pkg=nginx&arch=hurd-i386&ver=1.1.8-2&stamp=1322127530
> >
> > И как узнать необходимую длину ?
> >
> > http://pubs.opengroup.org/onlinepubs/000095399/functions/getcwd.html
> >
> > If buf is a null pointer, the behavior of getcwd() is unspecified.
Тут можно просто взять большой буфер, благо его размер передаётся.
Если не влезет - будет ERANGE.
> > http://pubs.opengroup.org/onlinepubs/7908799/xsh/realpath.html
> >
> > Ничего про NULL буфер нет.
>
> Вернее, есть:
>
> [EINVAL]
> Either the file_name or resolved_name argument is a null pointer.
Появилось в Issue 7:
http://pubs.opengroup.org/onlinepubs/9699919799/functions/realpath.html
Т.е. если PATH_MAX определён, надо действовать по старому. Если
не определён - можно пытаться использовать интерфейс из Issue 7.
Maxim Dounin
Подробная информация о списке рассылки nginx-ru