ruby-changes:6122
From: nobu <ko1@a...>
Date: Sat, 28 Jun 2008 21:16:18 +0900 (JST)
Subject: [ruby-changes:6122] Ruby:r17634 (trunk, mvm): * include/ruby/intern.h (rb_str_new2, rb_tainted_str_new2,
nobu 2008-06-28 21:15:55 +0900 (Sat, 28 Jun 2008)
New Revision: 17634
Modified files:
branches/mvm/.merged-trunk-revision
branches/mvm/ChangeLog
branches/mvm/include/ruby/intern.h
trunk/ChangeLog
trunk/include/ruby/intern.h
Log:
* include/ruby/intern.h (rb_str_new2, rb_tainted_str_new2,
rb_usascii_str_new2): use inline versions only for constant
literals.
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=17634&r2=17633&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/mvm/ChangeLog?r1=17634&r2=17633&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/include/ruby/intern.h?r1=17634&r2=17633&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/mvm/include/ruby/intern.h?r1=17634&r2=17633&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/mvm/.merged-trunk-revision?r1=17634&r2=17633&diff_format=u
Index: include/ruby/intern.h
===================================================================
--- include/ruby/intern.h (revision 17633)
+++ include/ruby/intern.h (revision 17634)
@@ -535,10 +535,25 @@
VALUE rb_str_tmp_new(long);
VALUE rb_usascii_str_new(const char*, long);
VALUE rb_usascii_str_new2(const char*);
-#if __GNUC__ >= 4 && defined __OPTIMIZE__ && __OPTIMIZE__
-#define rb_str_new2(str) ({const char *_s = (str); rb_str_new(_s, strlen(_s));})
-#define rb_tainted_str_new2(str) ({const char *_s = (str); rb_tainted_str_new(_s, strlen(_s));})
-#define rb_usascii_str_new2(str) ({const char *_s = (str); rb_usascii_str_new(_s, strlen(_s));})
+#if defined __GNUC__
+#define rb_str_new2(str) ( \
+{ \
+ (__builtin_constant_p(str)) ? \
+ rb_str_new(str, strlen(str)) : \
+ rb_str_new2(str); \
+})
+#define rb_tainted_str_new2(str) ( \
+{ \
+ (__builtin_constant_p(str)) ? \
+ rb_tainted_str_new(str, strlen(str)) : \
+ rb_tainted_str_new2(str); \
+})
+#define rb_usascii_str_new2(str) ( \
+{ \
+ (__builtin_constant_p(str)) ? \
+ rb_usascii_str_new(str, strlen(str)) : \
+ rb_usascii_str_new2(str); \
+})
#endif
void rb_str_free(VALUE);
void rb_str_shared_replace(VALUE, VALUE);
Index: ChangeLog
===================================================================
--- ChangeLog (revision 17633)
+++ ChangeLog (revision 17634)
@@ -1,7 +1,8 @@
-Sat Jun 28 20:50:35 2008 Nobuyoshi Nakada <nobu@r...>
+Sat Jun 28 21:15:43 2008 Nobuyoshi Nakada <nobu@r...>
* include/ruby/intern.h (rb_str_new2, rb_tainted_str_new2,
- rb_usascii_str_new2): use inline versions for gcc 4 or lator.
+ rb_usascii_str_new2): use inline versions only for constant
+ literals.
Sat Jun 28 13:12:06 2008 Tanaka Akira <akr@f...>
Index: mvm/include/ruby/intern.h
===================================================================
--- mvm/include/ruby/intern.h (revision 17633)
+++ mvm/include/ruby/intern.h (revision 17634)
@@ -535,10 +535,25 @@
VALUE rb_str_tmp_new(long);
VALUE rb_usascii_str_new(const char*, long);
VALUE rb_usascii_str_new2(const char*);
-#if __GNUC__ >= 4 && defined __OPTIMIZE__ && __OPTIMIZE__
-#define rb_str_new2(str) ({const char *_s = (str); rb_str_new(_s, strlen(_s));})
-#define rb_tainted_str_new2(str) ({const char *_s = (str); rb_tainted_str_new(_s, strlen(_s));})
-#define rb_usascii_str_new2(str) ({const char *_s = (str); rb_usascii_str_new(_s, strlen(_s));})
+#if defined __GNUC__
+#define rb_str_new2(str) ( \
+{ \
+ (__builtin_constant_p(str)) ? \
+ rb_str_new(str, strlen(str)) : \
+ rb_str_new2(str); \
+})
+#define rb_tainted_str_new2(str) ( \
+{ \
+ (__builtin_constant_p(str)) ? \
+ rb_tainted_str_new(str, strlen(str)) : \
+ rb_tainted_str_new2(str); \
+})
+#define rb_usascii_str_new2(str) ( \
+{ \
+ (__builtin_constant_p(str)) ? \
+ rb_usascii_str_new(str, strlen(str)) : \
+ rb_usascii_str_new2(str); \
+})
#endif
void rb_str_free(VALUE);
void rb_str_shared_replace(VALUE, VALUE);
Index: mvm/ChangeLog
===================================================================
--- mvm/ChangeLog (revision 17633)
+++ mvm/ChangeLog (revision 17634)
@@ -1,7 +1,8 @@
-Sat Jun 28 20:50:35 2008 Nobuyoshi Nakada <nobu@r...>
+Sat Jun 28 21:15:43 2008 Nobuyoshi Nakada <nobu@r...>
* include/ruby/intern.h (rb_str_new2, rb_tainted_str_new2,
- rb_usascii_str_new2): use inline versions for gcc 4 or lator.
+ rb_usascii_str_new2): use inline versions only for constant
+ literals.
Sat Jun 28 13:12:06 2008 Tanaka Akira <akr@f...>
Index: mvm/.merged-trunk-revision
===================================================================
--- mvm/.merged-trunk-revision (revision 17633)
+++ mvm/.merged-trunk-revision (revision 17634)
@@ -1 +1 @@
-17632
+17634
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/