[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]