mysql.pp 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. unit mysql;
  2. {
  3. Import unit for the mysql header files.
  4. Translated form the original mysql.h by Michael Van Canneyt
  5. ([email protected])
  6. }
  7. interface
  8. uses mysql_com;
  9. {$ifdef win32}
  10. Const mysqllib = 'libmysql';
  11. {$else}
  12. Const mysqllib = 'mysqlclient';
  13. {$endif}
  14. {$ifndef win32}
  15. {$linklib c}
  16. {$linklib m}
  17. { You need to specify the path to libgcc on the command line. }
  18. { On my machine this is '-k-L/usr/lib/gcc-lib/i486-linux/2.7.2.1' }
  19. {$linklib gcc}
  20. {$endif}
  21. { All is 4-byte aligned on my machine. }
  22. {$packrecords 4}
  23. type
  24. my_bool = byte;
  25. gptr = pchar;
  26. Socket = Longint;
  27. PCardinal = ^Cardinal;
  28. {$ifdef linux}
  29. Var
  30. mysql_port : cardinal; external name 'mysql_port';
  31. mysql_unix_port : pchar; external name 'mysql_unix_port';
  32. {$endif}
  33. {
  34. #define IS_PRI_KEY(n) ((n) & PRI_KEY_FLAG)
  35. #define IS_NOT_NULL(n) ((n) & NOT_NULL_FLAG)
  36. #define IS_BLOB(n) ((n) & BLOB_FLAG)
  37. #define IS_NUM(t) ((t) <= FIELD_TYPE_INT24)
  38. }
  39. Type
  40. st_mysql_field = record
  41. name : Pchar; { Name of column }
  42. table : pchar; { Table of column if column was a field }
  43. def: pchar; { Default value (set by mysql_list_fields) }
  44. ftype : enum_field_types; { Type of field. See mysql_com.h for types }
  45. length : cardinal; { Width of column }
  46. max_length : cardinal; { Max width of selected set }
  47. flags : cardinal; { Div flags }
  48. decimals : cardinal; { Number of decimals in field }
  49. end;
  50. TMYSQL_FIELD = st_mysql_field;
  51. PMYSQL_FIELD = ^TMYSQL_FIELD;
  52. TMYSQL_ROW = PPchar; { return data as array of strings }
  53. TMYSQL_FIELD_OFFSET = cardinal; { offset to current field }
  54. PST_MYSQL_Rows = ^st_mysql_rows;
  55. st_mysql_rows = Record
  56. next : pst_mysql_rows; { list of rows }
  57. Data : TMYSQL_ROW;
  58. end;
  59. TMYSQL_ROWS = st_mysql_rows;
  60. PMYSQL_ROWS = ^TMYSQL_ROWS;
  61. TMYSQL_ROW_OFFSET = PMYSQL_ROWS; { offset to current row }
  62. st_mysql_data = record
  63. rows, fields : cardinal;
  64. data : PMYSQL_ROWS;
  65. alloc : TMEM_ROOT;
  66. end;
  67. TMYSQL_DATA = st_mysql_data;
  68. PMYSQL_DATA = ^TMYSQL_DATA;
  69. mysql_status = (MYSQL_STATUS_READY,
  70. MYSQL_STATUS_GET_RESULT,
  71. MYSQL_STATUS_USE_RESULT);
  72. st_mysql = Record
  73. net : TNET; { Communication parameters }
  74. host,user,passwd,unix_socket,server_version,host_info, info,db : pchar;
  75. port,client_flag,server_capabilities : cardinal;
  76. protocol_version : cardinal;
  77. field_count : cardinal;
  78. thread_id : cardinal; { Id for connection in server }
  79. affected_rows : cardinal;
  80. insert_id : cardinal; { id if insert on table with NEXTNR }
  81. extra_info : cardinal; { Used by mysqlshow }
  82. status : mysql_status;
  83. fields : PMYSQL_FIELD;
  84. field_alloc : TMEM_ROOT;
  85. free_me : my_bool; { If free in mysql_close }
  86. reconnect : my_bool; { set to 1 if automatic reconnect }
  87. end;
  88. TMYSQL = st_mysql;
  89. PMYSQL = ^TMYSQL;
  90. st_mysql_res = record
  91. row_count : cardinal;
  92. field_count, current_field : cardinal;
  93. fields : PMYSQL_FIELD;
  94. data : PMYSQL_DATA;
  95. data_cursor : PMYSQL_ROWS;
  96. field_alloc : TMEM_ROOT;
  97. row : TMYSQL_ROW; { If unbuffered read }
  98. current_row : TMYSQL_ROW; { buffer to current row }
  99. lengths : pcardinal; { column lengths of current row }
  100. handle : PMYSQL; { for unbuffered reads }
  101. eof : my_bool; { Used my mysql_fetch_row }
  102. end;
  103. TMYSQL_RES = st_mysql_res;
  104. PMYSQL_RES = ^TMYSQL_RES;
  105. { Translated Macros }
  106. Function mysql_num_rows (res : PMYSQL_RES) : Cardinal;
  107. Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
  108. Function mysql_eof(res : PMYSQL_RES) : my_bool;
  109. Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
  110. Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
  111. Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
  112. Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
  113. Function mysql_affected_rows(mysql : PMYSQL): Cardinal;
  114. Function mysql_insert_id(mysql : PMYSQL): Cardinal;
  115. Function mysql_errno(mysql : PMYSQL) : Cardinal;
  116. Function mysql_info(mysql : PMYSQL): Pchar;
  117. Function mysql_reload(mysql : PMYSQL) : Longint;
  118. Function mysql_thread_id(mysql : PMYSQL) : Cardinal;
  119. Function mysql_error(mysql : PMYSQL) : pchar;
  120. { Original functions }
  121. Function mysql_connect (mysql : PMYSQL; host,user,passwd: pchar) : PMYSQL; cdecl;
  122. Function mysql_real_connect (mysql : PMYSQL; const host,user,passwd : pchar;
  123. port : cardinal;
  124. unix_socket : pchar;
  125. clientflag : cardinal) : PMYSQL;cdecl;
  126. Function mysql_close(sock : PMYSQL) : longint; cdecl;
  127. Function mysql_select_db(MYSQL : PMYSQL; db : Pchar) : longint; cdecl;
  128. Function mysql_query(mysql : PMYSQL; q : pchar) : longint; cdecl;
  129. Function mysql_real_query(mysql : PMYSQL; q : Pchar; length : longint) : longint; cdecl;
  130. Function mysql_create_db(mysql : PMYSQL; db : pchar) : longint; cdecl;
  131. Function mysql_drop_db(mysql : PMYSQL; DB : Pchar) : longint; cdecl;
  132. Function mysql_shutdown(mysql : PMYSQL) : longint; cdecl;
  133. Function mysql_dump_debug_info(mysql : PMYSQL) : longint; cdecl;
  134. Function mysql_refresh(mysql : PMYSQL; refresh_options : cardinal) : longint; cdecl;
  135. Function mysql_kill(mysql : PMYSQL; pid : Cardinal) : longint; cdecl;
  136. Function mysql_stat(mysql : PMYSQL) : Pchar; cdecl;
  137. Function mysql_get_server_info(mysql : PMYSQL) : pchar; cdecl;
  138. Function mysql_get_client_info : pchar; cdecl;
  139. Function mysql_get_host_info(mysql : PMYSQL) : pchar; cdecl;
  140. Function mysql_get_proto_info(mysql : PMYSQL) : Cardinal; cdecl;
  141. Function mysql_list_dbs(mysql : PMYSQL;wild : Pchar) : PMYSQL_RES; cdecl;
  142. Function mysql_list_tables(mysql : PMYSQL;Wild : Pchar) : PMYSQL_RES; cdecl;
  143. Function mysql_list_fields(mysql : PMYSQL; table,wild : pchar) : PMYSQL_RES; cdecl;
  144. Function mysql_list_processes(mysql : PMYSQL) : PMYSQL_RES; cdecl;
  145. Function mysql_store_result(mysql : PMYSQL) : PMYSQL_RES; cdecl;
  146. Function mysql_use_result(mysql : PMYSQL) : PMYSQL_RES; cdecl;
  147. Procedure mysql_free_result(res : PMYSQL_RES);cdecl;
  148. Procedure mysql_data_seek(mysql : PMYSQL_RES; offs : cardinal);cdecl;
  149. Function mysql_row_seek(mysql : PMYSQL_RES; Offs: TMYSQL_ROW_OFFSET): TMYSQL_ROW_OFFSET; cdecl;
  150. Function mysql_field_seek(musql : PMYSQL_RES;offs : TMYSQL_FIELD_OFFSET): TMYSQL_FIELD_OFFSET; cdecl;
  151. Function mysql_fetch_row(mysql : PMYSQL_RES) : TMYSQL_ROW; cdecl;
  152. Function mysql_fetch_lengths(mysql : PMYSQL_RES) : PCardinal; cdecl;
  153. Function mysql_fetch_field(handle : PMYSQL_RES) : PMYSQL_FIELD; cdecl;
  154. Function mysql_escape_string(escto,escfrom : pchar; length : Cardinal) : cardinal; cdecl;
  155. Procedure mysql_debug(debug : pchar);cdecl;
  156. implementation
  157. function mysql_connect (mysql : PMYSQL; host,user,passwd: pchar) : PMYSQL;cdecl; external mysqllib name 'mysql_connect';
  158. function mysql_real_connect (mysql : PMYSQL; const host,user,passwd : pchar;
  159. port : cardinal;
  160. unix_socket : pchar;
  161. clientflag : cardinal) : PMYSQL;cdecl; external mysqllib;
  162. function mysql_close(sock : PMYSQL) : longint ;cdecl; external mysqllib name 'mysql_close';
  163. function mysql_select_db(MYSQL : PMYSQL; db : Pchar) : longint;cdecl; external mysqllib name 'mysql_select_db';
  164. function mysql_query(mysql : PMYSQL; q : pchar) : longint;cdecl; external mysqllib name 'mysql_query';
  165. function mysql_real_query(mysql : PMYSQL; q : Pchar; length : longint) : longint;cdecl; external mysqllib name 'mysql_real_query';
  166. function mysql_create_db(mysql : PMYSQL; db : pchar) : longint;cdecl; external mysqllib name 'mysql_create_db';
  167. Function mysql_drop_db(mysql : PMYSQL; DB : Pchar) : longint;cdecl; external mysqllib name 'mysql_drop_db';
  168. Function mysql_shutdown(mysql : PMYSQL) : longint;cdecl; external mysqllib name 'mysql_shutdown';
  169. Function mysql_dump_debug_info(mysql : PMYSQL) : longint;cdecl; external mysqllib name 'mysql_dump_debug_info';
  170. Function mysql_refresh(mysql : PMYSQL; refresh_options : cardinal) : longint;cdecl; external mysqllib name 'mysql_refresh';
  171. Function mysql_kill(mysql : PMYSQL; pid : Cardinal) : longint;cdecl; external mysqllib name 'mysql_kill';
  172. Function mysql_stat(mysql : PMYSQL) : Pchar;cdecl; external mysqllib name 'mysql_stat';
  173. Function mysql_get_server_info(mysql : PMYSQL) : pchar;cdecl; external mysqllib name 'mysql_get_server_info';
  174. Function mysql_get_client_info : pchar;cdecl; external mysqllib;
  175. Function mysql_get_host_info(mysql : PMYSQL) : pchar;cdecl; external mysqllib name 'mysql_get_host_info';
  176. Function mysql_get_proto_info(mysql : PMYSQL) : Cardinal;cdecl; external mysqllib name 'mysql_get_proto_info';
  177. Function mysql_list_dbs(mysql : PMYSQL;wild : Pchar) : PMYSQL_RES;cdecl; external mysqllib name 'mysql_list_dbs';
  178. Function mysql_list_tables(mysql : PMYSQL;Wild : Pchar) : PMYSQL_RES;cdecl; external mysqllib name 'mysql_list_tables';
  179. Function mysql_list_fields(mysql : PMYSQL; table,wild : pchar) : PMYSQL_RES;cdecl; external mysqllib name 'mysql_list_fields';
  180. Function mysql_list_processes(mysql : PMYSQL) : PMYSQL_RES;cdecl; external mysqllib name 'mysql_list_processes';
  181. Function mysql_store_result(mysql : PMYSQL) : PMYSQL_RES;cdecl; external mysqllib name 'mysql_store_result';
  182. Function mysql_use_result(mysql : PMYSQL) : PMYSQL_RES;cdecl; external mysqllib name 'mysql_use_result';
  183. Procedure mysql_free_result(res : PMYSQL_RES);cdecl; external mysqllib name 'mysql_free_result';
  184. Procedure mysql_data_seek(mysql : PMYSQL_RES; offs : cardinal);cdecl; external mysqllib name 'mysql_data_seek';
  185. Function mysql_row_seek(mysql : PMYSQL_RES; Offs: TMYSQL_ROW_OFFSET): TMYSQL_ROW_OFFSET;cdecl; external mysqllib name 'mysql_row_seek';
  186. Function mysql_field_seek(musql : PMYSQL_RES;offs : TMYSQL_FIELD_OFFSET): TMYSQL_FIELD_OFFSET;cdecl; external mysqllib name 'mysql_field_seek';
  187. function mysql_fetch_row(mysql : PMYSQL_RES) : TMYSQL_ROW;cdecl; external mysqllib name 'mysql_fetch_row';
  188. function mysql_fetch_lengths(mysql : PMYSQL_RES) : PCardinal;cdecl; external mysqllib name 'mysql_fetch_lengths';
  189. function mysql_fetch_field(handle : PMYSQL_RES) : PMYSQL_FIELD;cdecl; external mysqllib name 'mysql_fetch_field';
  190. Function mysql_escape_string(escto,escfrom : pchar; length : Cardinal) : cardinal;cdecl; external mysqllib name 'mysql_escape_string';
  191. Procedure mysql_debug(debug : pchar);cdecl; external mysqllib name 'mysql_debug';
  192. Function mysql_error(mysql : PMYSQL) : pchar;
  193. begin
  194. mysql_error:=mysql^.net.last_error
  195. end;
  196. Function mysql_num_rows (res : PMYSQL_RES) : Cardinal;
  197. begin
  198. mysql_num_rows:=res^.row_count
  199. end;
  200. Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
  201. begin
  202. mysql_num_fields:=res^.field_count
  203. end;
  204. Function mysql_eof(res : PMYSQL_RES) : my_bool;
  205. begin
  206. mysql_eof:=res^.eof
  207. end;
  208. Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
  209. begin
  210. mysql_fetch_field_direct:=res^.fields[fieldnr];
  211. end;
  212. Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
  213. begin
  214. mysql_fetch_fields:=res^.fields
  215. end;
  216. Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
  217. begin
  218. mysql_row_tell:=res^.data_cursor
  219. end;
  220. Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
  221. begin
  222. mysql_field_tell:=res^.current_field
  223. end;
  224. Function mysql_affected_rows(mysql : PMYSQL): Cardinal;
  225. begin
  226. mysql_affected_rows:=mysql^.affected_rows
  227. end;
  228. Function mysql_insert_id(mysql : PMYSQL): Cardinal;
  229. begin
  230. mysql_insert_id:=mysql^.insert_id
  231. end;
  232. Function mysql_errno(mysql : PMYSQL) : Cardinal;
  233. begin
  234. mysql_errno:=mysql^.net.last_errno
  235. end;
  236. Function mysql_info(mysql : PMYSQL): Pchar;
  237. begin
  238. mysql_info:=mysql^.info
  239. end;
  240. Function mysql_reload(mysql : PMYSQL) : Longint;
  241. begin
  242. mysql_reload:=mysql_refresh(mysql,REFRESH_GRANT)
  243. end;
  244. Function mysql_thread_id(mysql : PMysql) : Cardinal;
  245. begin
  246. mysql_thread_id:=mysql^.thread_id
  247. end;
  248. end.