diff options
author | Bruno Haible <bruno@clisp.org> | 2009-01-14 22:51:53 +0100 |
---|---|---|
committer | Bruno Haible <bruno@clisp.org> | 2009-01-14 22:51:53 +0100 |
commit | ca9a412390987a580aab19b5cc2322bcccc001ee (patch) | |
tree | 79b34476c9396478462adab6f7ea6d9c90dcc6c5 /lib/progname.c | |
parent | 1a8e08bd78b26fcb631d19c99b923b2c8c7ff305 (diff) | |
download | gnulib-ca9a412390987a580aab19b5cc2322bcccc001ee.tar.gz |
Add more comments.
Diffstat (limited to 'lib/progname.c')
-rw-r--r-- | lib/progname.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/lib/progname.c b/lib/progname.c index 2b77a5883c..9854b5e7cc 100644 --- a/lib/progname.c +++ b/lib/progname.c @@ -1,5 +1,5 @@ /* Program name management. - Copyright (C) 2001-2003, 2005-2008 Free Software Foundation, Inc. + Copyright (C) 2001-2003, 2005-2009 Free Software Foundation, Inc. Written by Bruno Haible <haible@clisp.cons.org>, 2001. This program is free software: you can redistribute it and/or modify @@ -35,6 +35,8 @@ set_program_name (const char *argv0) { /* libtool creates a temporary executable whose name is sometimes prefixed with "lt-" (depends on the platform). It also makes argv[0] absolute. + But the name of the temporary executable is a detail that should not be + visible to the end user and to the test suite. Remove this "<dirname>/.libs/" or "<dirname>/.libs/lt-" prefix here. */ const char *slash; const char *base; @@ -47,5 +49,15 @@ set_program_name (const char *argv0) if (strncmp (base, "lt-", 3) == 0) argv0 = base + 3; } + + /* But don't strip off a leading <dirname>/ in general, because when the user + runs + /some/hidden/place/bin/cp foo foo + he should get the error message + /some/hidden/place/bin/cp: `foo' and `foo' are the same file + not + cp: `foo' and `foo' are the same file + */ + program_name = argv0; } |