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/