/[smeserver]/rpms/php/sme8/php-5.2.5-systzdata.patch
ViewVC logotype

Contents of /rpms/php/sme8/php-5.2.5-systzdata.patch

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.2 - (show annotations) (download)
Mon Jun 20 19:27:01 2011 UTC (13 years, 4 months ago) by slords
Branch: MAIN
CVS Tags: HEAD
Changes since 1.1: +0 -0 lines
FILE REMOVED
Import upstream sources

1
2 Add support for use of the system timezone database, rather
3 than embedding a copy. Discussed upstream but was not desired.
4
5 History:
6 r3: fix a crash if /usr/share/zoneinfo doesn't exist (Raphael Geissert)
7 r2: add filesystem trawl to set up name alias index
8 r1: initial revision
9
10 --- php-5.2.5/ext/date/lib/timelib.m4.systzdata
11 +++ php-5.2.5/ext/date/lib/timelib.m4
12 @@ -78,3 +78,17 @@ stdlib.h
13
14 dnl Check for strtoll, atoll
15 AC_CHECK_FUNCS(strtoll atoll strftime)
16 +
17 +PHP_ARG_WITH(system-tzdata, for use of system timezone data,
18 +[ --with-system-tzdata[=DIR] to specify use of system timezone data],
19 +no, no)
20 +
21 +if test "$PHP_SYSTEM_TZDATA" != "no"; then
22 + AC_DEFINE(HAVE_SYSTEM_TZDATA, 1, [Define if system timezone data is used])
23 +
24 + if test "$PHP_SYSTEM_TZDATA" != "yes"; then
25 + AC_DEFINE_UNQUOTED(HAVE_SYSTEM_TZDATA_PREFIX, "$PHP_SYSTEM_TZDATA",
26 + [Define for location of system timezone data])
27 + fi
28 +fi
29 +
30 --- php-5.2.5/ext/date/lib/parse_tz.c.systzdata
31 +++ php-5.2.5/ext/date/lib/parse_tz.c
32 @@ -20,6 +20,16 @@
33
34 #include "timelib.h"
35
36 +#ifdef HAVE_SYSTEM_TZDATA
37 +#include <sys/mman.h>
38 +#include <sys/stat.h>
39 +#include <limits.h>
40 +#include <fcntl.h>
41 +#include <unistd.h>
42 +
43 +#include "php_scandir.h"
44 +#endif
45 +
46 #include <stdio.h>
47
48 #ifdef HAVE_LOCALE_H
49 @@ -31,7 +41,10 @@
50 #else
51 #include <strings.h>
52 #endif
53 +
54 +#ifndef HAVE_SYSTEM_TZDATA
55 #include "timezonedb.h"
56 +#endif
57
58 #if (defined(__APPLE__) || defined(__APPLE_CC__)) && (defined(__BIG_ENDIAN__) || defined(__LITTLE_ENDIAN__))
59 # if defined(__LITTLE_ENDIAN__)
60 @@ -206,6 +219,195 @@ void timelib_dump_tzinfo(timelib_tzinfo
61 }
62 }
63
64 +#ifdef HAVE_SYSTEM_TZDATA
65 +
66 +#ifdef HAVE_SYSTEM_TZDATA_PREFIX
67 +#define ZONEINFO_PREFIX HAVE_SYSTEM_TZDATA_PREFIX
68 +#else
69 +#define ZONEINFO_PREFIX "/usr/share/zoneinfo"
70 +#endif
71 +
72 +static const timelib_tzdb *timezonedb_system = NULL;
73 +
74 +/* Filter out some non-tzdata files and the posix/right databases, if
75 + * present. */
76 +static int index_filter(const struct dirent *ent)
77 +{
78 + return strcmp(ent->d_name, ".") != 0
79 + && strcmp(ent->d_name, "..") != 0
80 + && strcmp(ent->d_name, "posix") != 0
81 + && strcmp(ent->d_name, "posixrules") != 0
82 + && strcmp(ent->d_name, "right") != 0
83 + && strstr(ent->d_name, ".tab") == NULL;
84 +}
85 +
86 +/* Create the zone identifier index by trawling the filesystem. */
87 +static void create_zone_index(timelib_tzdb *db)
88 +{
89 + size_t dirstack_size, dirstack_top;
90 + size_t index_size, index_next;
91 + timelib_tzdb_index_entry *db_index;
92 + char **dirstack;
93 +
94 + /* LIFO stack to hold directory entries to scan; each slot is a
95 + * directory name relative to the zoneinfo prefix. */
96 + dirstack_size = 32;
97 + dirstack = malloc(dirstack_size * sizeof *dirstack);
98 + dirstack_top = 1;
99 + dirstack[0] = strdup("");
100 +
101 + /* Index array. */
102 + index_size = 64;
103 + db_index = malloc(index_size * sizeof *db_index);
104 + index_next = 0;
105 +
106 + do {
107 + struct dirent **ents;
108 + char name[PATH_MAX], *top;
109 + int count;
110 +
111 + /* Pop the top stack entry, and iterate through its contents. */
112 + top = dirstack[--dirstack_top];
113 + snprintf(name, sizeof name, ZONEINFO_PREFIX "/%s", top);
114 +
115 + count = php_scandir(name, &ents, index_filter, php_alphasort);
116 +
117 + while (count > 0) {
118 + struct stat st;
119 + const char *leaf = ents[count - 1]->d_name;
120 +
121 + snprintf(name, sizeof name, ZONEINFO_PREFIX "/%s/%s",
122 + top, leaf);
123 +
124 + if (strlen(name) && stat(name, &st) == 0) {
125 + /* Name, relative to the zoneinfo prefix. */
126 + const char *root = top;
127 +
128 + if (root[0] == '/') root++;
129 +
130 + snprintf(name, sizeof name, "%s%s%s", root,
131 + *root ? "/": "", leaf);
132 +
133 + if (S_ISDIR(st.st_mode)) {
134 + if (dirstack_top == dirstack_size) {
135 + dirstack_size *= 2;
136 + dirstack = realloc(dirstack,
137 + dirstack_size * sizeof *dirstack);
138 + }
139 + dirstack[dirstack_top++] = strdup(name);
140 + }
141 + else {
142 + if (index_next == index_size) {
143 + index_size *= 2;
144 + db_index = realloc(db_index,
145 + index_size * sizeof *db_index);
146 + }
147 +
148 + db_index[index_next].id = strdup(name);
149 + db_index[index_next++].pos = 0;
150 + }
151 + }
152 +
153 + free(ents[--count]);
154 + }
155 +
156 + if (count != -1) free(ents);
157 + free(top);
158 + } while (dirstack_top);
159 +
160 + db->index = db_index;
161 + db->index_size = index_next;
162 +
163 + free(dirstack);
164 +}
165 +
166 +/* Return the mmap()ed tzfile if found, else NULL. On success, the
167 + * length of the mapped data is placed in *length. */
168 +static char *map_tzfile(const char *timezone, size_t *length)
169 +{
170 + char fname[PATH_MAX];
171 + struct stat st;
172 + char *p;
173 + int fd;
174 +
175 + if (strstr(timezone, "..") != NULL) {
176 + return NULL;
177 + }
178 +
179 + snprintf(fname, sizeof fname, ZONEINFO_PREFIX "/%s", timezone);
180 +
181 + fd = open(fname, O_RDONLY);
182 + if (fd == -1) {
183 + return NULL;
184 + } else if (fstat(fd, &st) != 0 || st.st_size < 21) {
185 + close(fd);
186 + return NULL;
187 + }
188 +
189 + *length = st.st_size;
190 + p = mmap(NULL, st.st_size, PROT_READ, MAP_SHARED, fd, 0);
191 + close(fd);
192 +
193 + return p != MAP_FAILED ? p : NULL;
194 +}
195 +
196 +const timelib_tzdb *timelib_builtin_db(void)
197 +{
198 + if (timezonedb_system == NULL) {
199 + timelib_tzdb *tmp = malloc(sizeof *tmp);
200 +
201 + tmp->version = "0.system";
202 + tmp->data = NULL;
203 + create_zone_index(tmp);
204 + timezonedb_system = tmp;
205 + }
206 +
207 + return timezonedb_system;
208 +}
209 +
210 +const timelib_tzdb_index_entry *timelib_timezone_builtin_identifiers_list(int *count)
211 +{
212 + *count = timezonedb_system->index_size;
213 + return timezonedb_system->index;
214 +}
215 +
216 +int timelib_timezone_id_is_valid(char *timezone, const timelib_tzdb *tzdb)
217 +{
218 + char fname[PATH_MAX];
219 +
220 + if (strstr(timezone, "..") != NULL) {
221 + return 0;
222 + }
223 +
224 + snprintf(fname, sizeof fname, ZONEINFO_PREFIX "/%s", timezone);
225 +
226 + return access(fname, R_OK) == 0 ? 1 : 0;
227 +}
228 +
229 +timelib_tzinfo *timelib_parse_tzfile(char *timezone, const timelib_tzdb *tzdb)
230 +{
231 + char *tzf, *orig;
232 + timelib_tzinfo *tmp;
233 + size_t len;
234 +
235 + orig = map_tzfile(timezone, &len);
236 + if (orig == NULL) {
237 + return NULL;
238 + }
239 +
240 + tmp = timelib_tzinfo_ctor(timezone);
241 +
242 + tzf = orig + 20;
243 + read_header(&tzf, tmp);
244 + read_transistions(&tzf, tmp);
245 + read_types(&tzf, tmp);
246 +
247 + munmap(orig, len);
248 +
249 + return tmp;
250 +}
251 +#else /* !HAVE_SYSTEM_TZDATA */
252 +
253 static int seek_to_tz_position(const unsigned char **tzf, char *timezone, const timelib_tzdb *tzdb)
254 {
255 int left = 0, right = tzdb->index_size - 1;
256 @@ -279,6 +481,7 @@ timelib_tzinfo *timelib_parse_tzfile(cha
257
258 return tmp;
259 }
260 +#endif
261
262 static ttinfo* fetch_timezone_offset(timelib_tzinfo *tz, timelib_sll ts, timelib_sll *transition_time)
263 {

admin@koozali.org
ViewVC Help
Powered by ViewVC 1.2.1 RSS 2.0 feed