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

ruby-changes:17837

From: shyouhei <ko1@a...>
Date: Mon, 22 Nov 2010 14:15:46 +0900 (JST)
Subject: [ruby-changes:17837] Ruby:r29849 (ruby_1_8): merge revision(s) 28835,28894:

shyouhei	2010-11-22 14:15:39 +0900 (Mon, 22 Nov 2010)

  New Revision: 29849

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=29849

  Log:
    merge revision(s) 28835,28894:
    * ext/win32ole/win32ole.c: NONAMELESSUNION defined only if gcc
      version is older than 3.4.4. [ruby-core:31567] [Bug #3637]
    * ext/win32ole/extconf.rb: ditto.
    * ext/win32ole/win32ole.c: fix checking version of GCC.

  Modified files:
    branches/ruby_1_8/ChangeLog
    branches/ruby_1_8/ext/win32ole/extconf.rb
    branches/ruby_1_8/ext/win32ole/win32ole.c

Index: ruby_1_8/ext/win32ole/win32ole.c
===================================================================
--- ruby_1_8/ext/win32ole/win32ole.c	(revision 29848)
+++ ruby_1_8/ext/win32ole/win32ole.c	(revision 29849)
@@ -17,6 +17,20 @@
 
 #include "ruby.h"
 #include "st.h"
+
+#define GNUC_OLDER_3_4_4 \
+    ((__GNUC__ < 3) || \
+     ((__GNUC__ <= 3) && (__GNUC_MINOR__ < 4)) || \
+     ((__GNUC__ <= 3) && (__GNUC_MINOR__ <= 4) && (__GNUC_PATCHLEVEL__ <= 4)))
+
+#if (defined(__GNUC__)) && (GNUC_OLDER_3_4_4) 
+#ifndef NONAMELESSUNION
+#define NONAMELESSUNION 1
+#endif
+#endif
+
+#include <ctype.h>
+
 #include <windows.h>
 #include <ocidl.h>
 #include <olectl.h>
@@ -37,13 +51,13 @@
 #define DOUTI(x) fprintf(stderr, "[%ld]:" #x "=%d\n",__LINE__,x)
 #define DOUTD(x) fprintf(stderr, "[%d]:" #x "=%f\n",__LINE__,x)
 
-#if defined NONAMELESSUNION && __GNUC__
+#if (defined(__GNUC__)) && (GNUC_OLDER_3_4_4) 
 #define V_UNION1(X, Y) ((X)->u.Y)
 #else
 #define V_UNION1(X, Y) ((X)->Y)
 #endif
 
-#if defined NONAMELESSUNION && __GNUC__
+#if (defined(__GNUC__)) && (GNUC_OLDER_3_4_4) 
 #undef V_UNION
 #define V_UNION(X,Y) ((X)->n1.n2.n3.Y)
 
Index: ruby_1_8/ext/win32ole/extconf.rb
===================================================================
--- ruby_1_8/ext/win32ole/extconf.rb	(revision 29848)
+++ ruby_1_8/ext/win32ole/extconf.rb	(revision 29849)
@@ -35,7 +35,5 @@
 case RUBY_PLATFORM
 when /mswin32/
   $CFLAGS += ' /W3'
-when /cygwin/, /mingw/
-  $defs << '-DNONAMELESSUNION'
 end
 create_win32ole_makefile
Index: ruby_1_8/ChangeLog
===================================================================
--- ruby_1_8/ChangeLog	(revision 29848)
+++ ruby_1_8/ChangeLog	(revision 29849)
@@ -1,3 +1,13 @@
+Mon Nov 22 14:13:45 2010  Masaki Suketa <masaki.suketa@n...>
+
+	* ext/win32ole/win32ole.c: fix checking version of GCC.
+
+Mon Nov 22 14:13:45 2010  Masaki Suketa <masaki.suketa@n...>
+
+	* ext/win32ole/win32ole.c: NONAMELESSUNION defined only if gcc
+	  version is older than 3.4.4. [ruby-core:31567] [Bug #3637]
+	* ext/win32ole/extconf.rb: ditto.
+
 Wed Nov 17 18:28:27 2010  Akinori MUSHA  <knu@i...>
 
 	* array.c (rb_ary_sort_by_bang): Add Array#sort_by!.

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

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