]> git.sesse.net Git - vlc/blob - extras/contrib/src/Patches/live-uselocale.patch
Contribs: Update live555 patch for locale.
[vlc] / extras / contrib / src / Patches / live-uselocale.patch
1 Copyright (C) 2008 Rémi Denis-Courmont, adaptation by Felix Kühne (C) 2009.
2 Licensed under GNU General Public License version 2 or higher.
3 diff -ru live-orig/config.mingw live/config.mingw
4 --- live-orig/config.mingw      2009-02-13 09:09:42.000000000 +0100
5 +++ live/config.mingw   2009-02-20 14:17:20.000000000 +0100
6 @@ -1,4 +1,4 @@
7 -COMPILE_OPTS =         $(INCLUDES) -I. -O -DSOCKLEN_T=int
8 +COMPILE_OPTS =         $(INCLUDES) -I. -O -DSOCKLEN_T=int -DLOCALE_NOT_USED
9  C =                    c
10  C_COMPILER =           $(CC)
11  C_FLAGS =              $(COMPILE_OPTS) -DUSE_OUR_BZERO=1 -D__MINGW32__
12 diff -ru live-orig/liveMedia/Locale.cpp live/liveMedia/Locale.cpp
13 --- live-orig/liveMedia/Locale.cpp      2009-02-13 09:09:42.000000000 +0100
14 +++ live/liveMedia/Locale.cpp   2009-02-20 14:17:20.000000000 +0100
15 @@ -22,19 +22,18 @@
16  #include "Locale.hh"
17  #include <strDup.hh>
18  
19 -Locale::Locale(char const* newLocale, int category)
20 -  : fCategory(category) {
21 +Locale::Locale(char const* newLocale, int category) {
22  #ifndef LOCALE_NOT_USED
23 -  fPrevLocale = strDup(setlocale(category, NULL));
24 -  setlocale(category, newLocale);
25 +  fLocale = newlocale(category, newLocale, NULL);
26 +  fPrevLocale = uselocale(fLocale);
27  #endif
28  }
29  
30  Locale::~Locale() {
31  #ifndef LOCALE_NOT_USED
32 -  if (fPrevLocale != NULL) {
33 -    setlocale(fCategory, fPrevLocale);
34 -    delete[] fPrevLocale;
35 +  if (fLocale != (locale_t)0) {
36 +    uselocale(fPrevLocale);
37 +    freelocale(fLocale);
38    }
39  #endif
40  }
41 --- live/liveMedia/RTSPCommon.cpp.orig  2009-01-26 20:18:41.000000000 +0100
42 +++ live/liveMedia/RTSPCommon.cpp       2009-03-25 20:35:43.000000000 +0100
43 @@ -146,7 +146,7 @@
44    char const* fields = buf + 7;
45    while (*fields == ' ') ++fields;
46    double start, end;
47 -  Locale("C", LC_NUMERIC);
48 +  Locale("C", LC_NUMERIC_MASK);
49    if (sscanf(fields, "npt = %lf - %lf", &start, &end) == 2) {
50      rangeStart = start;
51      rangeEnd = end;diff -ru live-orig/liveMedia/RTSPCommon.cpp live/liveMedia/RTSPCommon.cpp
52 diff -ru live-orig/liveMedia/include/Locale.hh live/liveMedia/include/Locale.hh
53 --- live-orig/liveMedia/include/Locale.hh       2009-02-13 09:09:42.000000000 +0100
54 +++ live/liveMedia/include/Locale.hh    2009-02-20 14:17:20.000000000 +0100
55 @@ -27,23 +27,26 @@
56  
57  #ifndef LOCALE_NOT_USED
58  #include <locale.h>
59 +#ifdef __APPLE__
60 +#include <xlocale.h>
61 +#endif
62  #else
63 -#ifndef LC_ALL
64 -#define LC_ALL 0
65 +#ifndef LC_ALL_MASK
66 +#define LC_ALL_MASK 0
67  #endif
68 -#ifndef LC_NUMERIC
69 -#define LC_NUMERIC 4
70 +#ifndef LC_NUMERIC_MASK
71 +#define LC_NUMERIC_MASK 0
72  #endif
73 +typedef int locale_t;
74  #endif
75  
76  class Locale {
77  public:
78 -  Locale(char const* newLocale, int category = LC_ALL);
79 +  Locale(char const* newLocale, int category = LC_ALL_MASK);
80    virtual ~Locale();
81  
82  private:
83 -  int fCategory;
84 -  char* fPrevLocale;
85 +  locale_t fLocale, fPrevLocale;
86  };
87  
88  #endif
89 --- live/liveMedia/RTSPClient.cpp.orig  2009-01-26 20:18:41.000000000 +0100
90 +++ live/liveMedia/RTSPClient.cpp       2009-03-25 20:35:18.000000000 +0100
91 @@ -1019,7 +1019,7 @@
92      // This is the default value; we don't need a "Scale:" header:
93      buf[0] = '\0';
94    } else {
95 -    Locale("C", LC_NUMERIC);
96 +    Locale("C", LC_NUMERIC_MASK);
97      sprintf(buf, "Scale: %f\r\n", scale);
98    }
99  
100 @@ -1033,11 +1033,11 @@
101      buf[0] = '\0';
102    } else if (end < 0) {
103      // There's no end time:
104 -    Locale("C", LC_NUMERIC);
105 +    Locale("C", LC_NUMERIC_MASK);
106      sprintf(buf, "Range: npt=%.3f-\r\n", start);
107    } else {
108      // There's both a start and an end time; include them both in the "Range:" hdr
109 -    Locale("C", LC_NUMERIC);
110 +    Locale("C", LC_NUMERIC_MASK);
111      sprintf(buf, "Range: npt=%.3f-%.3f\r\n", start, end);
112    }
113  
114 @@ -2342,7 +2342,7 @@
115    if (_strncasecmp(line, "Scale: ", 7) != 0) return False;
116    line += 7;
117  
118 -  Locale("C", LC_NUMERIC);
119 +  Locale("C", LC_NUMERIC_MASK);
120    return sscanf(line, "%f", &scale) == 1;
121  }
122