ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: "Dmitry V. Levin" <ldv@altlinux.org>
To: ALT Devel discussion list <devel@lists.altlinux.org>
Subject: Re: [devel] glibc: обработка пустых подстрок в PATH, LD_PRELOAD etc
Date: Sat, 29 Mar 2008 04:03:05 +0300
Message-ID: <20080329010305.GB9619@wo.int.altlinux.org> (raw)
In-Reply-To: <200803271326.42171.khedin@mail.ru>

[-- Attachment #1: Type: text/plain, Size: 1834 bytes --]

On Thu, Mar 27, 2008 at 01:26:42PM +0300, Konstantin S. Uvarin wrote:
>   Давно не дает мне покоя один вопрос: для чего glibc интерпретирует пустую 
> подстроку в $PATH, $LD_PRELOAD и т.п. как текущий каталог? Ведь если 
> пользователю нужно именно текущий каталог указать, он и укажет PATH=$PATH:.

Это требование стандарта (legacy feature).
Привожу цитату из SUSv3 про $PATH полностью (жаль, что вы её не нашли раньше):

"This variable shall represent the sequence of path prefixes that certain
functions and utilities apply in searching for an executable file known
only by a filename.  The prefixes shall be separated by a colon ( ':' ).
When a non-zero-length prefix is applied to this filename, a slash shall
be inserted between the prefix and the filename.  A zero-length prefix is
a legacy feature that indicates the current working directory.	It appears
as two adjacent colons ( "::" ), as an initial colon preceding the rest
of the list, or as a trailing colon following the rest of the list.
A strictly conforming application shall use an actual pathname (such
as .) to represent the current working directory in PATH .  The list
shall be searched from beginning to end, applying the filename to each
prefix, until an executable file with the specified name and appropriate
execution permissions is found.  If the pathname being sought contains
a slash, the search through the path prefixes shall not be performed.
If the pathname begins with a slash, the specified path is resolved
(see Pathname Resolution).  If PATH is unset or is set to null, the path
search is implementation-defined."

>   А так получается, что команда PATH=$PATH:$SOMEVAR делает не то, что 
> задумывалось, если SOMEVAR неопределена. 

Тогда пишите правильно, например,
PATH="$PATH${SOMEVAR:+:$SOMEVAR}"


-- 
ldv

[-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --]

      parent reply	other threads:[~2008-03-29  1:03 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-03-27 10:26 [devel] [JT] " Konstantin S. Uvarin
2008-03-27 10:38 ` Slava Semushin
2008-03-29  1:03 ` Dmitry V. Levin [this message]

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=20080329010305.GB9619@wo.int.altlinux.org \
    --to=ldv@altlinux.org \
    --cc=devel@lists.altlinux.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

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git