Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse code

This commit was manufactured by cvs2svn to create tag 'RELEASE_1_2_3'.

  • Loading branch information...
commit ea13b365c7ecab7dc3117517eeb7f5561ad81713 1 parent 46baad7
SVN Migration authored

Showing 5,540 changed files with 0 additions and 64,146 deletions. Show diff stats Hide diff stats

  1. +0 508 .gdbinit
  2. +0 277 CODING_STANDARDS
  3. +0 2  CREDITS
  4. +0 14,191 ChangeLog
  5. BIN  ChangeLog.1999.gz
  6. BIN  ChangeLog.2000.gz
  7. BIN  ChangeLog.2001.gz
  8. BIN  ChangeLog.2002.gz
  9. BIN  ChangeLog.2003.gz
  10. BIN  ChangeLog.2004.gz
  11. +0 532 EXTENSIONS
  12. +0 1,996 INSTALL
  13. +0 23 Makefile.frag
  14. +0 76 Makefile.gcov
  15. +0 100 Makefile.global
  16. +0 2,450 NEWS
  17. +0 123 README.CVS-RULES
  18. +0 39 README.EXTENSIONS
  19. +0 194 README.EXT_SKEL
  20. +0 130 README.PARAMETER_PARSING_API
  21. +0 155 README.PHP4-TO-PHP5-THIN-CHANGES
  22. +0 57 README.QNX
  23. +0 155 README.SELF-CONTAINED-EXTENSIONS
  24. +0 379 README.STREAMS
  25. +0 126 README.SUBMITTING_PATCH
  26. +0 179 README.TESTING
  27. +0 137 README.TESTING2
  28. +0 123 README.UNIX-BUILD-SYSTEM
  29. +0 1,022 README.UPDATE_5_2
  30. +0 174 README.WIN32-BUILD-SYSTEM
  31. +0 112 README.Zeus
  32. +0 196 README.input_filter
  33. +0 144 TODO
  34. +0 4 TODO-5.1
  35. +0 109 TODO-PHP5
  36. +0 26 TSRM/LICENSE
  37. +0 6 TSRM/Makefile.am
  38. +0 2  TSRM/TODO
  39. +0 764 TSRM/TSRM.c
  40. +0 186 TSRM/TSRM.dsp
  41. +0 172 TSRM/TSRM.h
  42. +0 1  TSRM/acconfig.h
  43. +0 5 TSRM/acinclude.m4
  44. +0 43 TSRM/build.mk
  45. +0 33 TSRM/buildconf
  46. +0 10 TSRM/config.w32
  47. +0 31 TSRM/configure.in
  48. +0 47 TSRM/readdir.h
  49. +0 173 TSRM/threads.m4
  50. +0 128 TSRM/tsrm.m4
  51. +0 20 TSRM/tsrm_config.w32.h
  52. +0 60 TSRM/tsrm_config_common.h
  53. +0 240 TSRM/tsrm_nw.c
  54. +0 29 TSRM/tsrm_nw.h
  55. +0 63 TSRM/tsrm_strtok_r.c
  56. +0 6 TSRM/tsrm_strtok_r.h
  57. +0 1,200 TSRM/tsrm_virtual_cwd.c
  58. +0 310 TSRM/tsrm_virtual_cwd.h
  59. +0 396 TSRM/tsrm_win32.c
  60. +0 106 TSRM/tsrm_win32.h
  61. +0 548 UPGRADING
  62. +0 22,097 Zend/ChangeLog
  63. +0 186 Zend/FlexLexer.h
  64. +0 56 Zend/LICENSE
  65. +0 54 Zend/Makefile.am
  66. +0 1  Zend/Makefile.frag
  67. +0 195 Zend/OBJECTS2_HOWTO
  68. +0 13 Zend/README.ZEND_MM
  69. +0 108 Zend/README.ZEND_VM
  70. +0 136 Zend/RFCs/001.txt
  71. +0 169 Zend/RFCs/002.txt
  72. +0 72 Zend/RFCs/003.txt
  73. +0 1,166 Zend/ZEND_CHANGES
  74. +0 594 Zend/Zend.dsp
  75. +0 390 Zend/Zend.m4
  76. +0 258 Zend/ZendCore.dep
  77. +0 728 Zend/ZendTS.dsp
  78. +0 121 Zend/acconfig.h
  79. +0 107 Zend/acinclude.m4
  80. +0 420 Zend/bench.php
  81. +0 43 Zend/build.mk
  82. +0 33 Zend/buildconf
  83. +0 51 Zend/configure.in
  84. +0 1,648 Zend/flex.skl
  85. +0 19 Zend/header
  86. +0 54 Zend/tests/001.phpt
  87. +0 108 Zend/tests/002.phpt
  88. +0 81 Zend/tests/003.phpt
  89. +0 25 Zend/tests/004.phpt
  90. +0 27 Zend/tests/005.phpt
  91. +0 31 Zend/tests/006.phpt
  92. +0 63 Zend/tests/007.phpt
  93. +0 53 Zend/tests/008.phpt
  94. +0 46 Zend/tests/009.phpt
  95. +0 59 Zend/tests/010.phpt
  96. +0 89 Zend/tests/011.phpt
  97. +0 34 Zend/tests/012.phpt
  98. +0 34 Zend/tests/013.phpt
  99. +0 3  Zend/tests/014.inc
  100. +0 52 Zend/tests/014.phpt
  101. +0 35 Zend/tests/015.phpt
  102. +0 12 Zend/tests/016.phpt
  103. +0 82 Zend/tests/017.phpt
  104. +0 14 Zend/tests/abstract-static.phpt
  105. +0 15 Zend/tests/array_type_hint_001.phpt
  106. +0 22 Zend/tests/bug19859.phpt
  107. +0 43 Zend/tests/bug20240.phpt
  108. +0 26 Zend/tests/bug20242.phpt
  109. +0 37 Zend/tests/bug21478.phpt
  110. +0 36 Zend/tests/bug21888.phpt
  111. +0 31 Zend/tests/bug22725.phpt
  112. +0 34 Zend/tests/bug22836.phpt
  113. +0 12 Zend/tests/bug23104.phpt
  114. +0 24 Zend/tests/bug24436.phpt
  115. +0 30 Zend/tests/bug24635.phpt
  116. +0 13 Zend/tests/bug24699.phpt
  117. +0 9 Zend/tests/bug24773.phpt
  118. +0 28 Zend/tests/bug24884.phpt
  119. +0 19 Zend/tests/bug26010.phpt
  120. +0 9 Zend/tests/bug26077.phpt
  121. +0 74 Zend/tests/bug26166.phpt
  122. +0 29 Zend/tests/bug26229.phpt
  123. +0 13 Zend/tests/bug26281.phpt
  124. +0 22 Zend/tests/bug26696.phpt
  125. +0 24 Zend/tests/bug26697.phpt
  126. +0 73 Zend/tests/bug26698.phpt
  127. +0 22 Zend/tests/bug26801.phpt
  128. +0 37 Zend/tests/bug26802.phpt
  129. +0 28 Zend/tests/bug27268.phpt
  130. +0 23 Zend/tests/bug27304.phpt
  131. +0 12 Zend/tests/bug27598.phpt
  132. +0 18 Zend/tests/bug27669.phpt
  133. +0 10 Zend/tests/bug27731.phpt
  134. +0 72 Zend/tests/bug27798.phpt
  135. +0 46 Zend/tests/bug28072.phpt
  136. +0 23 Zend/tests/bug28377.phpt
  137. +0 65 Zend/tests/bug28442.phpt
  138. +0 81 Zend/tests/bug28444.phpt
  139. +0 11 Zend/tests/bug29015.phpt
  140. +0 27 Zend/tests/bug29104.phpt
  141. +0 104 Zend/tests/bug29210.phpt
  142. +0 34 Zend/tests/bug29368.phpt
  143. +0 31 Zend/tests/bug29505.phpt
  144. +0 41 Zend/tests/bug29674.phpt
  145. +0 62 Zend/tests/bug29689.phpt
  146. +0 13 Zend/tests/bug29883.phpt
  147. +0 23 Zend/tests/bug29890.phpt
  148. +0 28 Zend/tests/bug29896.phpt
  149. +0 16 Zend/tests/bug29944.phpt
  150. +0 18 Zend/tests/bug30080.phpt
  151. +0 30 Zend/tests/bug30140.phpt
  152. +0 34 Zend/tests/bug30161.phpt
  153. +0 52 Zend/tests/bug30162.phpt
  154. +0 40 Zend/tests/bug30332.phpt
  155. +0 24 Zend/tests/bug30346.phpt
  156. +0 30 Zend/tests/bug30394.phpt
  157. +0 18 Zend/tests/bug30407.phpt
  158. +0 36 Zend/tests/bug30451.phpt
  159. +0 10 Zend/tests/bug30519.phpt
  160. +0 39 Zend/tests/bug30702.phpt
  161. +0 29 Zend/tests/bug30707.phpt
  162. +0 32 Zend/tests/bug30725.phpt
  163. +0 35 Zend/tests/bug30791.phpt
  164. +0 27 Zend/tests/bug30820.phpt
  165. +0 61 Zend/tests/bug30828.phpt
  166. +0 31 Zend/tests/bug30889.phpt
  167. +0 13 Zend/tests/bug30922.phpt
  168. +0 21 Zend/tests/bug30998.phpt
  169. +0 53 Zend/tests/bug31098.phpt
  170. +0 48 Zend/tests/bug31102.phpt
  171. +0 18 Zend/tests/bug31177-2.phpt
  172. +0 44 Zend/tests/bug31177.phpt
  173. +0 29 Zend/tests/bug31341.phpt
  174. +0 22 Zend/tests/bug31525.phpt
  175. +0 97 Zend/tests/bug31683.phpt
  176. +0 16 Zend/tests/bug31720.phpt
  177. +0 25 Zend/tests/bug31828.phpt
  178. +0 18 Zend/tests/bug32080.phpt
  179. +0 36 Zend/tests/bug32226.phpt
  180. +0 47 Zend/tests/bug32252.phpt
  181. +0 126 Zend/tests/bug32290.phpt
  182. +0 60 Zend/tests/bug32296.phpt
  183. +0 80 Zend/tests/bug32322.phpt
  184. +0 19 Zend/tests/bug32427.phpt
  185. +0 13 Zend/tests/bug32428.phpt
  186. +0 28 Zend/tests/bug32429.phpt
  187. +0 27 Zend/tests/bug32596.phpt
  188. +0 39 Zend/tests/bug32660.phpt
  189. +0 62 Zend/tests/bug32674.phpt
  190. +0 21 Zend/tests/bug32799.phpt
  191. +0 10 Zend/tests/bug32833.phpt
  192. +0 38 Zend/tests/bug32852.phpt
  193. +0 29 Zend/tests/bug32993.phpt
  194. +0 22 Zend/tests/bug33116.phpt
  195. +0 27 Zend/tests/bug33171.phpt
  196. +0 25 Zend/tests/bug33243.phpt
  197. +0 25 Zend/tests/bug33257.phpt
  198. +0 28 Zend/tests/bug33277.phpt
  199. +0 19 Zend/tests/bug33282.phpt
  200. +0 8 Zend/tests/bug33318.phpt
  201. +0 66 Zend/tests/bug33512.phpt
  202. +0 21 Zend/tests/bug33558.phpt
  203. +0 32 Zend/tests/bug33710.phpt
  204. +0 45 Zend/tests/bug33732.phpt
  205. +0 40 Zend/tests/bug33771.phpt
  206. +0 22 Zend/tests/bug33802.phpt
  207. +0 29 Zend/tests/bug33996.phpt
  208. +0 30 Zend/tests/bug33999.phpt
  209. +0 28 Zend/tests/bug34045.phpt
  210. +0 24 Zend/tests/bug34062.phpt
  211. +0 35 Zend/tests/bug34064.phpt
  212. +0 15 Zend/tests/bug34065.phpt
  213. +0 10 Zend/tests/bug34137.phpt
  214. +0 18 Zend/tests/bug34199.phpt
  215. +0 36 Zend/tests/bug34260.phpt
  216. +0 34 Zend/tests/bug34310.phpt
  217. +0 15 Zend/tests/bug34358.phpt
  218. +0 27 Zend/tests/bug34467.phpt
  219. +0 38 Zend/tests/bug34518.phpt
  220. +0 18 Zend/tests/bug34617.phpt
  221. +0 25 Zend/tests/bug34678.phpt
  222. +0 28 Zend/tests/bug34712.phpt
  223. +0 33 Zend/tests/bug34767.phpt
  224. +0 22 Zend/tests/bug34786.phpt
  225. +0 27 Zend/tests/bug34873.phpt
  226. +0 11 Zend/tests/bug34879.phpt
  227. +0 33 Zend/tests/bug34893.phpt
  228. +0 21 Zend/tests/bug35017.phpt
  229. +0 14 Zend/tests/bug35106.phpt
  230. +0 41 Zend/tests/bug35239.phpt
  231. +0 30 Zend/tests/bug35393.phpt
  232. +0 19 Zend/tests/bug35411.phpt
  233. +0 27 Zend/tests/bug35437.phpt
  234. +0 11 Zend/tests/bug35470.phpt
  235. +0 31 Zend/tests/bug35509.phpt
  236. +0 36 Zend/tests/bug35634.phpt
  237. +0 25 Zend/tests/bug35655.phpt
  238. +0 30 Zend/tests/bug36006.phpt
  239. +0 14 Zend/tests/bug36037.phpt
  240. +0 13 Zend/tests/bug36071.phpt
  241. +0 54 Zend/tests/bug36214.phpt
  242. +0 14 Zend/tests/bug36268.phpt
  243. +0 12 Zend/tests/bug36303.phpt
  244. +0 22 Zend/tests/bug36513.phpt
  245. +0 15 Zend/tests/bug36568.phpt
  246. +0 27 Zend/tests/bug36759.phpt
  247. +0 23 Zend/tests/bug37046.phpt
  248. +0 21 Zend/tests/bug37138.phpt
  249. +0 16 Zend/tests/bug37144.phpt
  250. +0 55 Zend/tests/bug37212.phpt
  251. +0 135 Zend/tests/bug37632.phpt
  252. +0 53 Zend/tests/bug37667.phpt
  253. +0 16 Zend/tests/bug37707.phpt
  254. +0 28 Zend/tests/bug37811.phpt
  255. +0 50 Zend/tests/bug38047.phpt
  256. +0 19 Zend/tests/bug38146.phpt
  257. +0 10 Zend/tests/bug38211.phpt
  258. +0 92 Zend/tests/bug38220.phpt
  259. +0 18 Zend/tests/bug38234.phpt
  260. +0 45 Zend/tests/bug38287.phpt
  261. +0 25 Zend/tests/bug38461.phpt
  262. +0 16 Zend/tests/bug38623.phpt
  263. +0 34 Zend/tests/bug38624.phpt
  264. +0 42 Zend/tests/bug38772.phpt
  265. +0 29 Zend/tests/bug38779.phpt
  266. +0 45 Zend/tests/bug38779_1.phpt
  267. +0 17 Zend/tests/bug38808.phpt
  268. +0 17 Zend/tests/bug38942.phpt
  269. +0 24 Zend/tests/bug39003.phpt
  270. +0 11 Zend/tests/bug39017.phpt
  271. +0 19 Zend/tests/bug39036.phpt
  272. +0 45 Zend/tests/bug39297.phpt
  273. +0 9 Zend/tests/bug39304.phpt
  274. +0 45 Zend/tests/bug39438.phpt
  275. +0 16 Zend/tests/bug39445.phpt
  276. +0 40 Zend/tests/bug39449.phpt
  277. +0 15 Zend/tests/bug39602.phpt
  278. +0 30 Zend/tests/bug39721.phpt
  279. +0 20 Zend/tests/bug39775.phpt
  280. +0 13 Zend/tests/bug39825.phpt
  281. +0 88 Zend/tests/bug39944.phpt
  282. +0 17 Zend/tests/bug39990.phpt
  283. +0 28 Zend/tests/bug_debug_backtrace.phpt
  284. +0 23 Zend/tests/catch.phpt
  285. +0 33 Zend/tests/catch_002.phpt
  286. +0 38 Zend/tests/catch_003.phpt
  287. +0 43 Zend/tests/catch_004.phpt
  288. +0 34 Zend/tests/dtor_scope.phpt
  289. +0 26 Zend/tests/error_reporting01.phpt
  290. +0 27 Zend/tests/error_reporting02.phpt
  291. +0 35 Zend/tests/error_reporting03.phpt
  292. +0 23 Zend/tests/error_reporting04.phpt
  293. +0 34 Zend/tests/error_reporting05.phpt
  294. +0 30 Zend/tests/error_reporting06.phpt
  295. +0 30 Zend/tests/error_reporting07.phpt
  296. +0 32 Zend/tests/error_reporting08.phpt
  297. +0 31 Zend/tests/error_reporting09.phpt
  298. +0 35 Zend/tests/error_reporting10.phpt
  299. +0 14 Zend/tests/foreach_undefined.phpt
  300. +0 12 Zend/tests/halt01.phpt
  301. +0 13 Zend/tests/halt02.phpt
  302. +0 10 Zend/tests/halt03.phpt
  303. +0 18 Zend/tests/instanceof.phpt
  304. +0 29 Zend/tests/int_overflow_32bit.phpt
  305. +0 29 Zend/tests/int_overflow_64bit.phpt
  306. +0 29 Zend/tests/int_underflow_32bit.phpt
Sorry, we could not display the entire diff because too many files (5,540) changed.
508 .gdbinit
... ... @@ -1,508 +0,0 @@
1   -define ____executor_globals
2   - if basic_functions_module.zts
3   - set $tsrm_ls = ts_resource_ex(0, 0)
4   - set $eg = ((zend_executor_globals) (*((void ***) $tsrm_ls))[executor_globals_id-1])
5   - else
6   - set $eg = executor_globals
7   - end
8   -end
9   -
10   -document ____executor_globals
11   - portable way of accessing executor_globals
12   - ZTS detection is automatically based on ext/standard module struct
13   -end
14   -
15   -define dump_bt
16   - set $t = $arg0
17   - while $t
18   - printf "[0x%08x] ", $t
19   - if $t->function_state.function->common.function_name
20   - printf "%s() ", $t->function_state.function->common.function_name
21   - else
22   - printf "??? "
23   - end
24   - if $t->op_array != 0
25   - printf "%s:%d ", $t->op_array->filename, $t->opline->lineno
26   - end
27   - set $t = $t->prev_execute_data
28   - printf "\n"
29   - end
30   -end
31   -
32   -document dump_bt
33   - dumps the current execution stack. usage: dump_bt executor_globals.current_execute_data
34   -end
35   -
36   -define printzv
37   - set $ind = 1
38   - ____printzv $arg0 0
39   -end
40   -
41   -document printzv
42   - prints content of zval
43   -end
44   -
45   -define ____printzv_contents
46   - set $zvalue = $arg0
47   - set $type = $zvalue->type
48   -
49   - printf "(refcount=%d) ", $zvalue->refcount
50   - if $type == 0
51   - printf "NULL"
52   - end
53   - if $type == 1
54   - printf "long: %ld", $zvalue->value.lval
55   - end
56   - if $type == 2
57   - printf "double: %lf", $zvalue->value.dval
58   - end
59   - if $type == 3
60   - printf "bool: "
61   - if $zvalue->value.lval
62   - printf "true"
63   - else
64   - printf "false"
65   - end
66   - end
67   - if $type == 4
68   - printf "array(%d): ", $zvalue->value.ht->nNumOfElements
69   - if ! $arg1
70   - printf "{\n"
71   - set $ind = $ind + 1
72   - ____print_ht $zvalue->value.ht
73   - set $ind = $ind - 1
74   - set $i = $ind
75   - while $i > 0
76   - printf " "
77   - set $i = $i - 1
78   - end
79   - printf "}"
80   - end
81   - set $type = 0
82   - end
83   - if $type == 5
84   - printf "object"
85   - ____executor_globals
86   - set $handle = $zvalue->value.obj.handle
87   - set $handlers = $zvalue->value.obj.handlers
88   - if basic_functions_module.zts
89   - set $zobj = zend_objects_get_address($zvalue, $tsrm_ls)
90   - else
91   - set $zobj = zend_objects_get_address($zvalue)
92   - end
93   - if $handlers->get_class_entry == &zend_std_object_get_class
94   - set $cname = $zobj->ce.name
95   - else
96   - set $cname = "Unknown"
97   - end
98   - printf "(%s) #%d", $cname, $handle
99   - if ! $arg1
100   - if $handlers->get_properties == &zend_std_get_properties
101   - set $ht = $zobj->properties
102   - if $ht
103   - printf "(%d): ", $ht->nNumOfElements
104   - printf "{\n"
105   - set $ind = $ind + 1
106   - ____print_ht $ht
107   - set $ind = $ind - 1
108   - set $i = $ind
109   - while $i > 0
110   - printf " "
111   - set $i = $i - 1
112   - end
113   - printf "}"
114   - else
115   - echo "no properties found"
116   - end
117   - end
118   - end
119   - set $type = 0
120   - end
121   - if $type == 6
122   - printf "string(%d): ", $zvalue->value.str.len
123   - ____print_str $zvalue->value.str.val $zvalue->value.str.len
124   - end
125   - if $type == 7
126   - printf "resource: #%d", $zvalue->value.lval
127   - end
128   - if $type == 8
129   - printf "constant"
130   - end
131   - if $type == 9
132   - printf "const_array"
133   - end
134   - if $type > 9
135   - printf "unknown type %d", $type
136   - end
137   - printf "\n"
138   -end
139   -
140   -define ____printzv
141   - ____executor_globals
142   - set $zvalue = $arg0
143   -
144   - printf "[0x%08x] ", $zvalue
145   -
146   - if $zvalue == $eg.uninitialized_zval_ptr
147   - printf "*uninitialized* "
148   - end
149   -
150   - set $zcontents = (zval*) $zvalue
151   - if $arg1
152   - ____printzv_contents $zcontents $arg1
153   - else
154   - ____printzv_contents $zcontents 0
155   - end
156   -end
157   -
158   -define ____print_const_table
159   - set $ht = $arg0
160   - set $p = $ht->pListHead
161   -
162   - while $p != 0
163   - set $const = (zend_constant *) $p->pData
164   -
165   - set $i = $ind
166   - while $i > 0
167   - printf " "
168   - set $i = $i - 1
169   - end
170   -
171   - if $p->nKeyLength > 0
172   - ____print_str $p->arKey $p->nKeyLength
173   - printf " => "
174   - else
175   - printf "%d => ", $p->h
176   - end
177   -
178   - ____printzv_contents &$const->value 0
179   - set $p = $p->pListNext
180   - end
181   -end
182   -
183   -define print_const_table
184   - set $ind = 1
185   - printf "[0x%08x] {\n", $arg0
186   - ____print_const_table $arg0
187   - printf "}\n"
188   -end
189   -
190   -define ____print_ht
191   - set $ht = $arg0
192   - set $p = $ht->pListHead
193   -
194   - while $p != 0
195   - set $zval = *(zval **)$p->pData
196   -
197   - set $i = $ind
198   - while $i > 0
199   - printf " "
200   - set $i = $i - 1
201   - end
202   -
203   - if $p->nKeyLength > 0
204   - ____print_str $p->arKey $p->nKeyLength
205   - printf " => "
206   - else
207   - printf "%d => ", $p->h
208   - end
209   -
210   - ____printzv $zval 1
211   - set $p = $p->pListNext
212   - end
213   -end
214   -
215   -define print_ht
216   - set $ind = 1
217   - printf "[0x%08x] {\n", $arg0
218   - ____print_ht $arg0
219   - printf "}\n"
220   -end
221   -
222   -document print_ht
223   - dumps elements of HashTable made of zval
224   -end
225   -
226   -define ____print_ft
227   - set $ht = $arg0
228   - set $p = $ht->pListHead
229   -
230   - while $p != 0
231   - set $func = (zend_function*)$p->pData
232   -
233   - set $i = $ind
234   - while $i > 0
235   - printf " "
236   - set $i = $i - 1
237   - end
238   -
239   - if $p->nKeyLength > 0
240   - ____print_str $p->arKey $p->nKeyLength
241   - printf " => "
242   - else
243   - printf "%d => ", $p->h
244   - end
245   -
246   - printf "\"%s\"\n", $func->common.function_name
247   - set $p = $p->pListNext
248   - end
249   -end
250   -
251   -define print_ft
252   - set $ind = 1
253   - printf "[0x%08x] {\n", $arg0
254   - ____print_ft $arg0
255   - printf "}\n"
256   -end
257   -
258   -document print_ft
259   - dumps a function table (HashTable)
260   -end
261   -
262   -define ____print_inh_class
263   - set $ce = $arg0
264   - if $ce->ce_flags & 0x10 || $ce->ce_flags & 0x20
265   - printf "abstract "
266   - else
267   - if $ce->ce_flags & 0x40
268   - printf "final "
269   - end
270   - end
271   - printf "class %s", $ce->name
272   - if $ce->parent != 0
273   - printf " extends %s", $ce->parent->name
274   - end
275   - if $ce->num_interfaces != 0
276   - printf " implements"
277   - set $tmp = 0
278   - while $tmp < $ce->num_interfaces
279   - printf " %s", $ce->interfaces[$tmp]->name
280   - set $tmp = $tmp + 1
281   - if $tmp < $ce->num_interfaces
282   - printf ","
283   - end
284   - end
285   - end
286   - set $ce = $ce->parent
287   -end
288   -
289   -define ____print_inh_iface
290   - set $ce = $arg0
291   - printf "interface %s", $ce->name
292   - if $ce->num_interfaces != 0
293   - set $ce = $ce->interfaces[0]
294   - printf " extends %s", $ce->name
295   - else
296   - set $ce = 0
297   - end
298   -end
299   -
300   -define print_inh
301   - set $ce = $arg0
302   - set $depth = 0
303   - while $ce != 0
304   - set $tmp = $depth
305   - while $tmp != 0
306   - printf " "
307   - set $tmp = $tmp - 1
308   - end
309   - set $depth = $depth + 1
310   - if $ce->ce_flags & 0x80
311   - ____print_inh_iface $ce
312   - else
313   - ____print_inh_class $ce
314   - end
315   - printf " {\n"
316   - end
317   - while $depth != 0
318   - set $tmp = $depth
319   - while $tmp != 1
320   - printf " "
321   - set $tmp = $tmp - 1
322   - end
323   - printf "}\n"
324   - set $depth = $depth - 1
325   - end
326   -end
327   -
328   -define print_pi
329   - set $pi = $arg0
330   - printf "[0x%08x] {\n", $pi
331   - printf " h = %lu\n", $pi->h
332   - printf " flags = %d (", $pi->flags
333   - if $pi->flags & 0x100
334   - printf "ZEND_ACC_PUBLIC"
335   - else
336   - if $pi->flags & 0x200
337   - printf "ZEND_ACC_PROTECTED"
338   - else
339   - if $pi->flags & 0x400
340   - printf "ZEND_ACC_PRIVATE"
341   - else
342   - if $pi->flags & 0x800
343   - printf "ZEND_ACC_CHANGED"
344   - end
345   - end
346   - end
347   - end
348   - printf ")\n"
349   - printf " name = "
350   - ____print_str $pi->name $pi->name_length
351   - printf "\n}\n"
352   -end
353   -
354   -define ____print_str
355   - set $tmp = 0
356   - set $str = $arg0
357   - printf "\""
358   - while $tmp < $arg1
359   - if $str[$tmp] > 32 && $str[$tmp] < 127
360   - printf "%c", $str[$tmp]
361   - else
362   - printf "\\%o", $str[$tmp]
363   - end
364   - set $tmp = $tmp + 1
365   - end
366   - printf "\""
367   -end
368   -
369   -define printzn
370   - ____executor_globals
371   - set $ind = 0
372   - set $znode = $arg0
373   - if $znode->op_type == 1
374   - set $optype = "IS_CONST"
375   - end
376   - if $znode->op_type == 2
377   - set $optype = "IS_TMP_VAR"
378   - end
379   - if $znode->op_type == 4
380   - set $optype = "IS_VAR"
381   - end
382   - if $znode->op_type == 8
383   - set $optype = "IS_UNUSED"
384   - end
385   -
386   - printf "[0x%08x] %s", $znode, $optype
387   -
388   - if $znode->op_type == 1
389   - printf ": "
390   - ____printzv &$znode->u.constant 0
391   - end
392   - if $znode->op_type == 2
393   - printf ": "
394   - set $tvar = (union _temp_variable *)((char *)$eg.current_execute_data->Ts + $znode->u.var)
395   - ____printzv ((union _temp_variable *)$tvar)->tmp_var 0
396   - end
397   - if $znode->op_type == 4
398   - printf ": "
399   - set $tvar = (union _temp_variable *)((char *)$eg.current_execute_data->Ts + $znode->u.var)
400   - ____printzv *$tvar->var.ptr_ptr 0
401   - end
402   - if $znode->op_type == 8
403   - printf "\n"
404   - end
405   -end
406   -
407   -document printzn
408   - print type and content of znode.
409   - usage: printzn &opline->op1
410   -end
411   -
412   -define printzops
413   - printf "op1 => "
414   - printzn &execute_data->opline.op1
415   - printf "op2 => "
416   - printzn &execute_data->opline.op2
417   - printf "result => "
418   - printzn &execute_data->opline.result
419   -end
420   -
421   -document printzops
422   - dump operands of the current opline
423   -end
424   -
425   -define zbacktrace
426   - ____executor_globals
427   - dump_bt $eg.current_execute_data
428   -end
429   -
430   -document zbacktrace
431   - prints backtrace.
432   - This command is almost a short cut for
433   - > (gdb) ____executor_globals
434   - > (gdb) dump_bt $eg.current_execute_data
435   -end
436   -
437   -define zmemcheck
438   - set $p = alloc_globals.head
439   - set $stat = "?"
440   - set $total_size = 0
441   - if $arg0 != 0
442   - set $not_found = 1
443   - else
444   - set $not_found = 0
445   - end
446   - printf " block size status file:line\n"
447   - printf "-------------------------------------------------------------------------------\n"
448   - while $p
449   - set $aptr = $p + sizeof(struct _zend_mem_header) + sizeof(align_test)
450   - if $arg0 == 0 || (void *)$aptr == (void *)$arg0
451   - if $p->magic == 0x7312f8dc
452   - set $stat = "OK"
453   - end
454   - if $p->magic == 0x99954317
455   - set $stat = "FREED"
456   - end
457   - if $p->magic == 0xfb8277dc
458   - set $stat = "CACHED"
459   - end
460   - set $filename = strrchr($p->filename, '/')
461   - if !$filename
462   - set $filename = $p->filename
463   - else
464   - set $filename = $filename + 1
465   - end
466   - printf " 0x%08x ", $aptr
467   - if $p->size == sizeof(struct _zval_struct) && ((struct _zval_struct *)$aptr)->type >= 0 && ((struct _zval_struct *)$aptr)->type < 10
468   - printf "ZVAL?(%-2d) ", $p->size
469   - else
470   - printf "%-9d ", $p->size
471   - end
472   - set $total_size = $total_size + $p->size
473   - printf "%-06s %s:%d", $stat, $filename, $p->lineno
474   - if $p->orig_filename
475   - set $orig_filename = strrchr($p->orig_filename, '/')
476   - if !$orig_filename
477   - set $orig_filename = $p->orig_filename
478   - else
479   - set $orig_filename = $orig_filename + 1
480   - end
481   - printf " <= %s:%d\n", $orig_filename, $p->orig_lineno
482   - else
483   - printf "\n"
484   - end
485   - if $arg0 != 0
486   - set $p = 0
487   - set $not_found = 0
488   - else
489   - set $p = $p->pNext
490   - end
491   - else
492   - set $p = $p->pNext
493   - end
494   - end
495   - if $not_found
496   - printf "no such block that begins at 0x%08x.\n", $aptr
497   - end
498   - if $arg0 == 0
499   - printf "-------------------------------------------------------------------------------\n"
500   - printf " total: %d bytes\n", $total_size
501   - end
502   -end
503   -
504   -document zmemcheck
505   - show status of a memory block.
506   - usage: zmemcheck [ptr].
507   - if ptr is 0, all blocks will be listed.
508   -end
277 CODING_STANDARDS
... ... @@ -1,277 +0,0 @@
1   -PHP Coding Standards
2   -====================
3   -
4   -
5   -This file lists several standards that any programmer, adding or changing
6   -code in PHP, should follow. Since this file was added at a very late
7   -stage of the development of PHP v3.0, the code base does not (yet) fully
8   -follow it, but it's going in that general direction. Since we are now
9   -well into the version 4 releases, many sections have been recoded to use
10   -these rules.
11   -
12   -
13   -Code Implementation
14   --------------------
15   -
16   -[0] Document your code in source files and the manual. [tm]
17   -
18   -[1] Functions that are given pointers to resources should not free them
19   -
20   -For instance, function int mail(char *to, char *from) should NOT free
21   -to and/or from.
22   -Exceptions:
23   -
24   - - The function's designated behavior is freeing that resource. E.g. efree()
25   - - The function is given a boolean argument, that controls whether or not
26   - the function may free its arguments (if true - the function must free its
27   - arguments, if false - it must not)
28   - - Low-level parser routines, that are tightly integrated with the token
29   - cache and the bison code for minimum memory copying overhead.
30   -
31   -[2] Functions that are tightly integrated with other functions within the
32   - same module, and rely on each other non-trivial behavior, should be
33   - documented as such and declared 'static'. They should be avoided if
34   - possible.
35   -
36   -[3] Use definitions and macros whenever possible, so that constants have
37   - meaningful names and can be easily manipulated. The only exceptions
38   - to this rule are 0 and 1, when used as false and true (respectively).
39   - Any other use of a numeric constant to specify different behavior
40   - or actions should be done through a #define.
41   -
42   -[4] When writing functions that deal with strings, be sure to remember
43   - that PHP holds the length property of each string, and that it
44   - shouldn't be calculated with strlen(). Write your functions in a such
45   - a way so that they'll take advantage of the length property, both
46   - for efficiency and in order for them to be binary-safe.
47   - Functions that change strings and obtain their new lengths while
48   - doing so, should return that new length, so it doesn't have to be
49   - recalculated with strlen() (e.g. php_addslashes())
50   -
51   -[5] NEVER USE strncat(). If you're absolutely sure you know what you're doing,
52   - check its man page again, and only then, consider using it, and even then,
53   - try avoiding it.
54   -
55   -[6] Use PHP_* macros in the PHP source, and ZEND_* macros in the Zend
56   - part of the source. Although the PHP_* macro's are mostly aliased to the
57   - ZEND_* macros it gives a better understanding on what kind of macro you're
58   - calling.
59   -
60   -[7] When commenting out code using a #if statement, do NOT use 0 only. Instead
61   - use "<cvs username here>_0". For example, #if FOO_0, where FOO is your
62   - cvs user foo. This allows easier tracking of why code was commented out,
63   - especially in bundled libraries.
64   -
65   -[8] Do not define functions that are not available. For instance, if a
66   - library is missing a function, do not define the PHP version of the
67   - function, and do not raise a run-time error about the function not
68   - existing. End users should use function_exists() to test for the
69   - existence of a function
70   -
71   -[9] Prefer emalloc(), efree(), estrdup(), etc. to their standard C library
72   - counterparts. These functions implement an internal "safety-net"
73   - mechanism that ensures the deallocation of any unfreed memory at the
74   - end of a request. They also provide useful allocation and overflow
75   - information while running in debug mode.
76   -
77   - In almost all cases, memory returned to the engine must be allocated
78   - using emalloc().
79   -
80   - The use of malloc() should be limited to cases where a third-party
81   - library may need to control or free the memory, or when the memory in
82   - question needs to survive between multiple requests.
83   -
84   -Naming Conventions
85   -------------------
86   -
87   -[1] Function names for user-level functions should be enclosed with in
88   - the PHP_FUNCTION() macro. They should be in lowercase, with words
89   - underscore delimited, with care taken to minimize the letter count.
90   - Abbreviations should not be used when they greatly decrease the
91   - readability of the function name itself.
92   -
93   - Good:
94   - 'mcrypt_enc_self_test'
95   - 'mysql_list_fields'
96   -
97   - Ok:
98   - 'mcrypt_module_get_algo_supported_key_sizes'
99   - (could be 'mcrypt_mod_get_algo_sup_key_sizes'?)
100   - 'get_html_translation_table'
101   - (could be 'html_get_trans_table'?)
102   -
103   - Bad:
104   - 'hw_GetObjectByQueryCollObj'
105   - 'pg_setclientencoding'
106   - 'jf_n_s_i'
107   -
108   -[2] If they are part of a "parent set" of functions, that parent should
109   - be included in the user function name, and should be clearly related
110   - to the parent program or function family. This should be in the form
111   - of parent_*.
112   -
113   - A family of 'foo' functions, for example:
114   - Good:
115   - 'foo_select_bar'
116   - 'foo_insert_baz'
117   - 'foo_delete_baz'
118   -
119   - Bad:
120   - 'fooselect_bar'
121   - 'fooinsertbaz'
122   - 'delete_foo_baz'
123   -
124   -[3] Function names used by user functions should be prefixed
125   - with "_php_", and followed by a word or an underscore-delimited list of
126   - words, in lowercase letters, that describes the function. If applicable,
127   - they should be declared 'static'.
128   -
129   -[4] Variable names must be meaningful. One letter variable names must be
130   - avoided, except for places where the variable has no real meaning or
131   - a trivial meaning (e.g. for (i=0; i<100; i++) ...).
132   -
133   -[5] Variable names should be in lowercase. Use underscores to separate
134   - between words.
135   -
136   -[6] Method names follow the 'studlyCaps' (also referred to as 'bumpy case'
137   - or 'camel caps') naming convention, with care taken to minimize the
138   - letter count. The initial letter of the name is lowercase, and each
139   - letter that starts a new 'word' is capitalized.
140   -
141   - Good:
142   - 'connect()'
143   - 'getData()'
144   - 'buildSomeWidget()'
145   -
146   - Bad:
147   - 'get_Data()'
148   - 'buildsomewidget'
149   - 'getI()'
150   -
151   -[7] Classes should be given descriptive names. Avoid using abbreviations where
152   - possible. Each word in the class name should start with a capital letter,
153   - without underscore delimiters (CampelCaps starting with a capital letter).
154   - The class name should be prefixed with the name of the 'parent set' (e.g.
155   - the name of the extension).
156   -
157   - Good:
158   - 'Curl'
159   - 'FooBar'
160   -
161   - Bad:
162   - 'foobar'
163   - 'foo_bar'
164   -
165   -Syntax and indentation
166   -----------------------
167   -
168   -[1] Never use C++ style comments (i.e. // comment). Always use C-style
169   - comments instead. PHP is written in C, and is aimed at compiling
170   - under any ANSI-C compliant compiler. Even though many compilers
171   - accept C++-style comments in C code, you have to ensure that your
172   - code would compile with other compilers as well.
173   - The only exception to this rule is code that is Win32-specific,
174   - because the Win32 port is MS-Visual C++ specific, and this compiler
175   - is known to accept C++-style comments in C code.
176   -
177   -[2] Use K&R-style. Of course, we can't and don't want to
178   - force anybody to use a style he or she is not used to, but,
179   - at the very least, when you write code that goes into the core
180   - of PHP or one of its standard modules, please maintain the K&R
181   - style. This applies to just about everything, starting with
182   - indentation and comment styles and up to function declaration
183   - syntax.
184   -
185   - (see also http://www.catb.org/~esr/jargon/html/I/indent-style.html)
186   -
187   -[3] Be generous with whitespace and braces. Always prefer:
188   -
189   - if (foo) {
190   - bar;
191   - }
192   -
193   - to:
194   -
195   - if(foo)bar;
196   -
197   - Keep one empty line between the variable declaration section and
198   - the statements in a block, as well as between logical statement
199   - groups in a block. Maintain at least one empty line between
200   - two functions, preferably two.
201   -
202   -[4] When indenting, use the tab character. A tab is expected to represent
203   - four spaces. It is important to maintain consistency in indenture so
204   - that definitions, comments, and control structures line up correctly.
205   -
206   -[5] Preprocessor statements (#if and such) MUST start at column one. To
207   - indent preprocessor directives you should put the # at the beginning
208   - of a line, followed by any number of whitespace.
209   -
210   -Testing
211   --------
212   -
213   -[1] Extensions should be well tested using *.phpt tests. Read about that
214   - in README.TESTING.
215   -
216   -Documentation and Folding Hooks
217   --------------------------------
218   -
219   -In order to make sure that the online documentation stays in line with
220   -the code, each user-level function should have its user-level function
221   -prototype before it along with a brief one-line description of what the
222   -function does. It would look like this:
223   -
224   -/* {{{ proto int abs(int number)
225   - Returns the absolute value of the number */
226   -PHP_FUNCTION(abs)
227   -{
228   - ...
229   -}
230   -/* }}} */
231   -
232   -The {{{ symbols are the default folding symbols for the folding mode in
233   -Emacs and vim (set fdm=marker). Folding is very useful when dealing with
234   -large files because you can scroll through the file quickly and just unfold
235   -the function you wish to work on. The }}} at the end of each function marks
236   -the end of the fold, and should be on a separate line.
237   -
238   -The "proto" keyword there is just a helper for the doc/genfuncsummary script
239   -which generates a full function summary. Having this keyword in front of the
240   -function prototypes allows us to put folds elsewhere in the code without
241   -messing up the function summary.
242   -
243   -Optional arguments are written like this:
244   -
245   -/* {{{ proto object imap_header(int stream_id, int msg_no [, int from_length [, int subject_length [, string default_host]]])
246   - Returns a header object with the defined parameters */
247   -
248   -And yes, please keep the prototype on a single line, even if that line
249   -is massive.
250   -
251   -New and Experimental Functions
252   ------------------------------------
253   -To reduce the problems normally associated with the first public
254   -implementation of a new set of functions, it has been suggested
255   -that the first implementation include a file labeled 'EXPERIMENTAL'
256   -in the function directory, and that the functions follow the
257   -standard prefixing conventions during their initial implementation.
258   -
259   -The file labelled 'EXPERIMENTAL' should include the following
260   -information:
261   - Any authoring information (known bugs, future directions of the module).
262   - Ongoing status notes which may not be appropriate for CVS comments.
263   -
264   -Aliases & Legacy Documentation
265   ------------------------------------
266   -You may also have some deprecated aliases with close to duplicate
267   -names, for example, somedb_select_result and somedb_selectresult. For
268   -documentation purposes, these will only be documented by the most
269   -current name, with the aliases listed in the documentation for
270   -the parent function. For ease of reference, user-functions with
271   -completely different names, that alias to the same function (such as
272   -highlight_file and show_source), will be separately documented. The
273   -proto should still be included, describing which function is aliased.
274   -
275   -Backwards compatible functions and names should be maintained as long
276   -as the code can be reasonably be kept as part of the codebase. See
277   -/phpdoc/README for more information on documentation.
2  CREDITS
... ... @@ -1,2 +0,0 @@
1   -For the list of people who've put work into PHP, please see
2   -http://www.php.net/credits.php
14,191 ChangeLog
0 additions, 14,191 deletions not shown
BIN  ChangeLog.1999.gz
Binary file not shown
BIN  ChangeLog.2000.gz
Binary file not shown
BIN  ChangeLog.2001.gz
Binary file not shown
BIN  ChangeLog.2002.gz
Binary file not shown
BIN  ChangeLog.2003.gz
Binary file not shown
BIN  ChangeLog.2004.gz
Binary file not shown
532 EXTENSIONS
... ... @@ -1,532 +0,0 @@
1   - List of PHP maintainers
2   - =======================
3   -
4   -Maintenance legend
5   -------------------
6   - Supported: Someone is actually paid to look after this.
7   - Maintained: Someone actually looks after it.
8   - Odd Fixes: It has a maintainer but they don't have time to do
9   - much other than throw the odd patch in. See below.
10   - Orphan: No current maintainer [but maybe you could take the
11   - role as you write your new code].
12   - Obsolete: Old code. Something tagged obsolete generally means
13   - it has been replaced by a better system and you
14   - should be using that.
15   - Unknown: Not known at this time.
16   -
17   -Status legend
18   --------------
19   - Working: Working under both Windows and Unix.
20   - Windows: Working only under Windows.
21   - Unix: Working only under Unix.
22   - Experimental: Under development or initial release.
23   - Not Working: Not working.
24   - Unknown: Status unknown.
25   -
26   -
27   -== Server APIs ==
28   -
29   --------------------------------------------------------------------------------
30   -EXTENSION: aolserver
31   -MAINTENANCE: Unknown
32   -STATUS: Unknown
33   --------------------------------------------------------------------------------
34   -EXTENSION: apache
35   -PRIMARY MAINTAINER: Rasmus Lerdorf <rasmus@php.net>
36   -MAINTENANCE: Maintained
37   -STATUS: Working
38   --------------------------------------------------------------------------------
39   -EXTENSION: apache_hooks
40   -MAINTENANCE: Unknown
41   -STATUS: Unknown
42   --------------------------------------------------------------------------------
43   -EXTENSION: apache2filter
44   -PRIMARY MAINTAINER: Aaron Bannert <aaron@php.net>
45   -MAINTENANCE: Maintained
46   -STATUS: Experimental
47   --------------------------------------------------------------------------------
48   -EXTENSION: apache2handler
49   -PRIMARY MAINTAINER: Aaron Bannert <aaron@php.net>, Ilia Alshanetsky <iliaa@php.net>
50   -MAINTENANCE: Maintained
51   -STATUS: Working
52   --------------------------------------------------------------------------------
53   -EXTENSION: caudium
54   -MAINTENANCE: Unknown
55   -STATUS: Unknown
56   --------------------------------------------------------------------------------
57   -EXTENSION: cgi
58   -MAINTENANCE: Unknown
59   -STATUS: Working
60   --------------------------------------------------------------------------------
61   -EXTENSION: cli
62   -MAINTENANCE: Marcus Boerger <helly@php.net>, Edin Kadribasic <edink@php.net>
63   -STATUS: Working
64   -SINCE: 4.3.0
65   --------------------------------------------------------------------------------
66   -EXTENSION: continuity
67   -PRIMARY MAINTAINER: Alex Leigh <aleigh@php.net>
68   -MAINTENANCE: Unknown
69   -STATUS: Unknown
70   --------------------------------------------------------------------------------
71   -EXTENSION: embed
72   -PRIMARY MAINTAINER: Edin Kadribasic <edink@php.net>
73   -MAINTENANCE: Maintained
74   -STATUS: Working
75   --------------------------------------------------------------------------------
76   -EXTENSION: isapi
77   -MAINTENANCE: Unknown
78   -STATUS: Working
79   --------------------------------------------------------------------------------
80   -EXTENSION: milter
81   -MAINTENANCE: Unknown
82   -STATUS: Unknown
83   --------------------------------------------------------------------------------
84   -EXTENSION: nsapi
85   -PRIMARY MAINTAINER: Uwe Schindler <thetaphi@php.net>
86   -MAINTENANCE: Maintained
87   -STATUS: Working
88   --------------------------------------------------------------------------------
89   -EXTENSION: phttpd
90   -MAINTENANCE: Unknown
91   -STATUS: Unknown
92   --------------------------------------------------------------------------------
93   -EXTENSION: pi3web
94   -MAINTENANCE: Unknown
95   -STATUS: Unknown
96   --------------------------------------------------------------------------------
97   -EXTENSION: roxen
98   -MAINTENANCE: Unknown
99   -STATUS: Unknown
100   --------------------------------------------------------------------------------
101   -EXTENSION: thttpd
102   -PRIMARY MAINTAINER: Sascha Schumann <sascha@schumann.cx>
103   -MAINTENANCE: Odd fixes
104   -STATUS: Working
105   --------------------------------------------------------------------------------
106   -EXTENSION: tux
107   -MAINTENANCE: Unknown
108   -STATUS: Unknown
109   --------------------------------------------------------------------------------
110   -EXTENSION: webjames
111   -PRIMARY MAINTAINER: Alex Waugh <alex@alexwaugh.com>
112   -MAINTENANCE: Maintained
113   -STATUS: Experimental
114   --------------------------------------------------------------------------------
115   -
116   -
117   -== Database extensions ==
118   -
119   --------------------------------------------------------------------------------
120   -EXTENSION: dba
121   -PRIMARY MAINTAINER: Marcus B�rger <helly@php.net>
122   -MAINTENANCE: Maintained
123   -STATUS: Working
124   -COMMENT: DBM abstraction for db2, db3, db4, dbm, ndbm, gdbm, ini
125   --------------------------------------------------------------------------------
126   -EXTENSION: dbase
127   -MAINTENANCE: Orphaned
128   -STATUS: Working
129   --------------------------------------------------------------------------------
130   -EXTENSION: dbx
131   -PRIMARY MAINTAINER: Marc Boeren <M.Boeren@guidance.nl>
132   -MAINTENANCE: Maintained
133   -STATUS: Working
134   -SINCE: 4.0.6
135   -COMMENT: DB abstraction for odbc, mysql, pgsql, mssql, fbsql and more, see documentation
136   --------------------------------------------------------------------------------
137   -EXTENSION: fbsql
138   -PRIMARY MAINTAINER: Frank M. Kromann <fmk@swwwing.com>
139   -MAINTENANCE: Unknown
140   -STATUS: Unknown
141   --------------------------------------------------------------------------------
142   -EXTENSION: informix
143   -PRIMARY MAINTAINER: Danny Heijl <Danny.Heijl@cevi.be>
144   -MAINTENANCE: Maintained
145   -STATUS: Working
146   --------------------------------------------------------------------------------
147   -EXTENSION: ingres_ii
148   -PRIMARY MAINTAINER: David H�not <henot@php.net>
149   -MAINTENANCE: Maintained
150   -STATUS: Experimental
151   -SINCE: 4.0.2
152   --------------------------------------------------------------------------------
153   -EXTENSION: interbase
154   -PRIMARY MAINTAINER: Ard Biesheuvel <ard@ard.nu>, Jouni Ahto <jouni.ahto@exdec.fi>
155   -MAINTENANCE: Maintained
156   -STATUS: Working
157   --------------------------------------------------------------------------------
158   -EXTENSION: msql
159   -MAINTENANCE: Unknown
160   -STATUS: Working
161   --------------------------------------------------------------------------------
162   -EXTENSION: mssql
163   -PRIMARY MAINTAINER: Frank M. Kromann <fmk@swwwing.com>
164   -MAINTENANCE: Maintained
165   -STATUS: Working
166   -COMMENT: Tested on phpts and isapi versions
167   --------------------------------------------------------------------------------
168   -EXTENSION: mysql
169   -PRIMARY MAINTAINER: Zak Greant <zak@mysql.com>, Georg Richter <georg@php.net>
170   -MAINTENANCE: Maintained
171   -STATUS: Working
172   --------------------------------------------------------------------------------
173   -EXTENSION: mysqli
174   -PRIMARY MAINTAINER: Georg Richter <georg@php.net>, Andrey Hristov <andrey@php.net>
175   -MAINTENANCE: Maintained
176   -STATUS: Working
177   -SINCE: 5.0
178   --------------------------------------------------------------------------------
179   -EXTENSION: oci8
180   -PRIMARY MAINTAINER: Antony Dovgal <tony2001@php.net>
181   -MAINTENANCE: Maintained
182   -STATUS: Working
183   --------------------------------------------------------------------------------
184   -EXTENSION: odbc
185   -PRIMARY MAINTAINER: Daniel R. Kalowsky <kalowsky@php.net>
186   -MAINTENANCE: Maintained
187   -STATUS: Working
188   -COMMENT: Working
189   --------------------------------------------------------------------------------
190   -EXTENSION: oracle
191   -MAINTENANCE: Orphaned
192   -STATUS: Working
193   -COMMENT: Using the new OCI8 driver is encouraged where possible.
194   --------------------------------------------------------------------------------
195   -EXTENSION: ovrimos
196   -MAINTENANCE: Unknown
197   -STATUS: Unknown
198   --------------------------------------------------------------------------------
199   -EXTENSION: pgsql
200   -PRIMARY MAINTAINER: Marcus Boerger <helly@php.net>, Yasuo Ohgaki <yohgaki@php.net>