Magellan Linux

Annotation of /trunk/qt/patches/qt-3.3.4-gcc4-volatile.patch

Parent Directory Parent Directory | Revision Log Revision Log


Revision 153 - (hide annotations) (download)
Tue May 8 20:52:56 2007 UTC (17 years, 1 month ago) by niro
File size: 2480 byte(s)
-import

1 niro 153 diff -Nur qt-x11-free-3.3.4.orig/src/tools/qlocale.cpp qt-x11-free-3.3.4/src/tools/qlocale.cpp
2     --- qt-x11-free-3.3.4.orig/src/tools/qlocale.cpp 2005-01-21 18:16:05.000000000 +0100
3     +++ qt-x11-free-3.3.4/src/tools/qlocale.cpp 2005-08-20 16:05:53.000000000 +0200
4     @@ -72,6 +72,12 @@
5     # define NAN DBL_QNAN
6     #endif
7    
8     +#if (defined(Q_CC_GNU) && defined(Q_OS_WIN)) || __GNUC__ == 4 || defined(QT_QLOCALE_NEEDS_VOLATILE)
9     +# define NEEDS_VOLATILE volatile
10     +#else
11     +# define NEEDS_VOLATILE
12     +#endif
13     +
14     enum {
15     LittleEndian,
16     BigEndian
17     @@ -4068,9 +4074,9 @@
18     #error Exactly one of IEEE_BIG_OR_LITTLE_ENDIAN, VAX, or IBM should be defined.
19     #endif
20    
21     -inline ULong getWord0(double x)
22     +inline ULong getWord0(const NEEDS_VOLATILE double x)
23     {
24     - uchar *ptr = (uchar *)&x;
25     + const NEEDS_VOLATILE uchar *ptr = reinterpret_cast<const NEEDS_VOLATILE uchar *>(&x);
26     if (ByteOrder == BigEndian) {
27     return (ptr[0]<<24) + (ptr[1]<<16) + (ptr[2]<<8) + ptr[3];
28     } else {
29     @@ -4078,9 +4084,9 @@
30     }
31     }
32    
33     -inline void setWord0(double *x, ULong l)
34     +inline void setWord0(NEEDS_VOLATILE double *x, ULong l)
35     {
36     - uchar *ptr = (uchar *)x;
37     + NEEDS_VOLATILE uchar *ptr = reinterpret_cast<NEEDS_VOLATILE uchar *>(x);
38     if (ByteOrder == BigEndian) {
39     ptr[0] = (uchar)(l>>24);
40     ptr[1] = (uchar)(l>>16);
41     @@ -4094,18 +4100,18 @@
42     }
43     }
44    
45     -inline ULong getWord1(double x)
46     +inline ULong getWord1(const NEEDS_VOLATILE double x)
47     {
48     - uchar *ptr = (uchar *)&x;
49     + const NEEDS_VOLATILE uchar *ptr = reinterpret_cast<const NEEDS_VOLATILE uchar *>(&x);
50     if (ByteOrder == BigEndian) {
51     return (ptr[4]<<24) + (ptr[5]<<16) + (ptr[6]<<8) + ptr[7];
52     } else {
53     return (ptr[3]<<24) + (ptr[2]<<16) + (ptr[1]<<8) + ptr[0];
54     }
55     }
56     -inline void setWord1(double *x, ULong l)
57     +inline void setWord1(NEEDS_VOLATILE double *x, ULong l)
58     {
59     - uchar *ptr = (uchar *)x;
60     + NEEDS_VOLATILE uchar *ptr = reinterpret_cast<uchar NEEDS_VOLATILE *>(x);
61     if (ByteOrder == BigEndian) {
62     ptr[4] = (uchar)(l>>24);
63     ptr[5] = (uchar)(l>>16);
64     @@ -5679,11 +5685,11 @@
65     #ifdef Q_OS_LINUX
66     fesetenv(&envp);
67     #endif
68     -
69     +
70     return s;
71     }
72    
73     -static char *_qdtoa( double d, int mode, int ndigits, int *decpt, int *sign, char **rve, char **resultp)
74     +static char *_qdtoa( NEEDS_VOLATILE double d, int mode, int ndigits, int *decpt, int *sign, char **rve, char **resultp)
75     {
76     /*
77     Arguments ndigits, decpt, sign are similar to those