aboutsummaryrefslogtreecommitdiff
path: root/gcc/c-opts.c
diff options
context:
space:
mode:
authorDoug Gregor <dgregor@gcc.gnu.org>2006-11-01 16:29:06 +0000
committerDoug Gregor <dgregor@gcc.gnu.org>2006-11-01 16:29:06 +0000
commit966541e34dff4d48bded2823853a433c90289245 (patch)
tree875c5fa5548c28bdbec98cd7f7e0e301a08a6248 /gcc/c-opts.c
parentdfafdaa655b586f9f2f45aaaf4f0d3cc4aae6e82 (diff)
downloadgcc-966541e34dff4d48bded2823853a433c90289245.zip
gcc-966541e34dff4d48bded2823853a433c90289245.tar.gz
gcc-966541e34dff4d48bded2823853a433c90289245.tar.bz2
c-common.c (flag_cpp0x): New.
2006-11-01 Douglas Gregor <doug.gregor@gmail.com> * c-common.c (flag_cpp0x): New. * c-common.h (flag_cpp0x): New. * c-cppbuiltin.c (c_cpp_builtins): If C++0x extensions are supported, define __GXX_EXPERIMENTAL_CPP0X__. * c-opts.c (set_std_cxx0x): New. (c_common_handle_option): Handle -std=c++0x, -std=gnu++0x. * c.opt (std=c++0x): Document. (std=gnu++0x): Ditto. * doc/cpp.texi: Document __GXX_EXPERIMENTAL_CPP0X__. * doc/invoke.texi: Document -std=c++0x, -std=gnu++0x. From-SVN: r118386
Diffstat (limited to 'gcc/c-opts.c')
-rw-r--r--gcc/c-opts.c20
1 files changed, 19 insertions, 1 deletions
diff --git a/gcc/c-opts.c b/gcc/c-opts.c
index b74ce77..1abb374 100644
--- a/gcc/c-opts.c
+++ b/gcc/c-opts.c
@@ -109,6 +109,7 @@ static size_t include_cursor;
static void set_Wimplicit (int);
static void handle_OPT_d (const char *);
static void set_std_cxx98 (int);
+static void set_std_cxx0x (int);
static void set_std_c89 (int, int);
static void set_std_c99 (int);
static void check_deps_environment_vars (void);
@@ -789,7 +790,7 @@ c_common_handle_option (size_t scode, const char *arg, int value)
case OPT_fuse_cxa_atexit:
flag_use_cxa_atexit = value;
break;
-
+
case OPT_fuse_cxa_get_exception_ptr:
flag_use_cxa_get_exception_ptr = value;
break;
@@ -913,6 +914,12 @@ c_common_handle_option (size_t scode, const char *arg, int value)
set_std_cxx98 (code == OPT_std_c__98 /* ISO */);
break;
+ case OPT_std_c__0x:
+ case OPT_std_gnu__0x:
+ if (!preprocessing_asm_p)
+ set_std_cxx0x (code == OPT_std_c__0x /* ISO */);
+ break;
+
case OPT_std_c89:
case OPT_std_iso9899_1990:
case OPT_std_iso9899_199409:
@@ -1509,6 +1516,17 @@ set_std_cxx98 (int iso)
flag_iso = iso;
}
+/* Set the C++ 0x working draft "standard" (without GNU extensions if ISO). */
+static void
+set_std_cxx0x (int iso)
+{
+ cpp_set_lang (parse_in, iso ? CLK_CXX0X: CLK_GNUCXX0X);
+ flag_no_gnu_keywords = iso;
+ flag_no_nonansi_builtin = iso;
+ flag_iso = iso;
+ flag_cpp0x = 1;
+}
+
/* Handle setting implicit to ON. */
static void
set_Wimplicit (int on)