aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Thorpe <thorpej@gcc.gnu.org>2002-11-26 00:31:31 +0000
committerJason Thorpe <thorpej@gcc.gnu.org>2002-11-26 00:31:31 +0000
commit152a5a9c947ff82ced5cb47beb197f53330ea12c (patch)
treefb57bd2526716f6ab368a2f04bc887feb665ac9b /gcc
parenta4967b8db12d7f2d9b0d80830507f806c4c36e5b (diff)
downloadgcc-152a5a9c947ff82ced5cb47beb197f53330ea12c.zip
gcc-152a5a9c947ff82ced5cb47beb197f53330ea12c.tar.gz
gcc-152a5a9c947ff82ced5cb47beb197f53330ea12c.tar.bz2
gcc.c (static_spec_functions): Add if-exists-else spec function.
* gcc.c (static_spec_functions): Add if-exists-else spec function. (if_exists_else_spec_function): New function. * doc/invoke.texi: Document the if-exists-else spec function. * config/netbsd-elf.h (NETBSD_STARTFILE_SPEC): For -static, use "%:if-exists-else(crtbeginT%O%s crtbegin%O%s)". From-SVN: r59480
Diffstat (limited to 'gcc')
-rw-r--r--gcc/config/netbsd-elf.h4
-rw-r--r--gcc/doc/invoke.texi15
-rw-r--r--gcc/gcc.c22
3 files changed, 39 insertions, 2 deletions
diff --git a/gcc/config/netbsd-elf.h b/gcc/config/netbsd-elf.h
index 4846ba6..cb38b93 100644
--- a/gcc/config/netbsd-elf.h
+++ b/gcc/config/netbsd-elf.h
@@ -53,7 +53,9 @@ Boston, MA 02111-1307, USA. */
%{p:gcrt0%O%s} \
%{!p:crt0%O%s}}} \
%:if-exists(crti%O%s) \
- %{!shared:crtbegin%O%s} %{shared:crtbeginS%O%s}"
+ %{static:%:if-exists-else(crtbeginT%O%s crtbegin%O%s)} \
+ %{!static: \
+ %{!shared:crtbegin%O%s} %{shared:crtbeginS%O%s}}"
#undef STARTFILE_SPEC
#define STARTFILE_SPEC NETBSD_STARTFILE_SPEC
diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
index 36ca755..79579b9 100644
--- a/gcc/doc/invoke.texi
+++ b/gcc/doc/invoke.texi
@@ -4986,7 +4986,20 @@ pathname. Here is a small example of its usage:
*startfile:
crt0%O%s %:if-exists(crti%O%s) crtbegin%O%s
@end smallexample
-@end table
+
+@item @code{if-exists-else}
+The @code{if-exists-else} spec function is similar to the @code{if-exists}
+spec function, except that it takes two arguments. The first argument is
+an absolute pathname to a file. If the file exists, @code{if-exists-else}
+returns the pathname. If it does not exist, it returns the second argument.
+This way, @code{if-exists-else} can be used to select one file or another,
+based on the existence of the first. Here is a small example of its usage:
+
+@smallexample
+*startfile:
+crt0%O%s %:if-exists(crti%O%s) %:if-exists-else(crtbeginT%O%s crtbegin%O%s)
+@end smallexample
+@end table
@item %@{@code{S}@}
Substitutes the @code{-S} switch, if that switch was given to GCC@.
diff --git a/gcc/gcc.c b/gcc/gcc.c
index a193437..d7ec126 100644
--- a/gcc/gcc.c
+++ b/gcc/gcc.c
@@ -328,6 +328,7 @@ static const char *convert_filename PARAMS ((const char *, int, int));
#endif
static const char *if_exists_spec_function PARAMS ((int, const char **));
+static const char *if_exists_else_spec_function PARAMS ((int, const char **));
/* The Specs Language
@@ -1451,6 +1452,7 @@ static struct spec_list *specs = (struct spec_list *) 0;
static const struct spec_function static_spec_functions[] =
{
{ "if-exists", if_exists_spec_function },
+ { "if-exists-else", if_exists_else_spec_function },
{ 0, 0 }
};
@@ -7264,3 +7266,23 @@ if_exists_spec_function (argc, argv)
return NULL;
}
+
+/* if-exists-else built-in spec function.
+
+ This is like if-exists, but takes an additional argument which
+ is returned if the first argument does not exist. */
+
+static const char *
+if_exists_else_spec_function (argc, argv)
+ int argc;
+ const char **argv;
+{
+ /* Must have exactly two arguments. */
+ if (argc != 2)
+ return NULL;
+
+ if (IS_ABSOLUTE_PATHNAME (argv[0]) && ! access (argv[0], R_OK))
+ return argv[0];
+
+ return argv[1];
+}