translatorchooser.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464
  1. /*
  2. * translator.c
  3. *
  4. * $Id$
  5. *
  6. * The iODBC driver manager.
  7. *
  8. * Copyright (C) 1996-2021 OpenLink Software <[email protected]>
  9. * All Rights Reserved.
  10. *
  11. * This software is released under the terms of either of the following
  12. * licenses:
  13. *
  14. * - GNU Library General Public License (see LICENSE.LGPL)
  15. * - The BSD License (see LICENSE.BSD).
  16. *
  17. * Note that the only valid version of the LGPL license as far as this
  18. * project is concerned is the original GNU Library General Public License
  19. * Version 2, dated June 1991.
  20. *
  21. * While not mandated by the BSD license, any patches you make to the
  22. * iODBC source code may be contributed back into the iODBC project
  23. * at your discretion. Contributions will benefit the Open Source and
  24. * Data Access community as a whole. Submissions may be made at:
  25. *
  26. * http://www.iodbc.org
  27. *
  28. *
  29. * GNU Library Generic Public License Version 2
  30. * ============================================
  31. * This library is free software; you can redistribute it and/or
  32. * modify it under the terms of the GNU Library General Public
  33. * License as published by the Free Software Foundation; only
  34. * Version 2 of the License dated June 1991.
  35. *
  36. * This library is distributed in the hope that it will be useful,
  37. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  38. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  39. * Library General Public License for more details.
  40. *
  41. * You should have received a copy of the GNU Library General Public
  42. * License along with this library; if not, write to the Free
  43. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  44. *
  45. *
  46. * The BSD License
  47. * ===============
  48. * Redistribution and use in source and binary forms, with or without
  49. * modification, are permitted provided that the following conditions
  50. * are met:
  51. *
  52. * 1. Redistributions of source code must retain the above copyright
  53. * notice, this list of conditions and the following disclaimer.
  54. * 2. Redistributions in binary form must reproduce the above copyright
  55. * notice, this list of conditions and the following disclaimer in
  56. * the documentation and/or other materials provided with the
  57. * distribution.
  58. * 3. Neither the name of OpenLink Software Inc. nor the names of its
  59. * contributors may be used to endorse or promote products derived
  60. * from this software without specific prior written permission.
  61. *
  62. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  63. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  64. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  65. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL OPENLINK OR
  66. * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  67. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  68. * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  69. * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  70. * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  71. * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  72. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  73. */
  74. #include <sys/stat.h>
  75. #include <unistd.h>
  76. #include <time.h>
  77. #include "gui.h"
  78. #include "img.xpm"
  79. static void
  80. translator_list_select (GtkWidget *widget, gint row, gint column,
  81. GdkEvent *event, TTRANSLATORCHOOSER *choose_t)
  82. {
  83. LPSTR translator = NULL;
  84. if (choose_t)
  85. {
  86. /* Get the directory name */
  87. gtk_clist_get_text (GTK_CLIST (choose_t->translatorlist), row, 0,
  88. &translator);
  89. if (translator && event && event->type == GDK_2BUTTON_PRESS)
  90. gtk_signal_emit_by_name (GTK_OBJECT (choose_t->b_finish), "clicked",
  91. choose_t);
  92. }
  93. }
  94. static void
  95. translatorchooser_ok_clicked (GtkWidget *widget,
  96. TTRANSLATORCHOOSER *choose_t)
  97. {
  98. char *szTranslator;
  99. if (choose_t)
  100. {
  101. if (GTK_CLIST (choose_t->translatorlist)->selection != NULL)
  102. {
  103. gtk_clist_get_text (GTK_CLIST (choose_t->translatorlist),
  104. GPOINTER_TO_INT (GTK_CLIST (choose_t->translatorlist)->
  105. selection->data), 0, &szTranslator);
  106. choose_t->translator = dm_SQL_A2W (szTranslator, SQL_NTS);
  107. }
  108. else
  109. choose_t->translator = NULL;
  110. choose_t->translatorlist = NULL;
  111. gtk_signal_disconnect_by_func (GTK_OBJECT (choose_t->mainwnd),
  112. GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
  113. gtk_main_quit ();
  114. gtk_widget_destroy (choose_t->mainwnd);
  115. }
  116. }
  117. static void
  118. translatorchooser_cancel_clicked (GtkWidget *widget,
  119. TTRANSLATORCHOOSER *choose_t)
  120. {
  121. if (choose_t)
  122. {
  123. choose_t->translatorlist = NULL;
  124. gtk_signal_disconnect_by_func (GTK_OBJECT (choose_t->mainwnd),
  125. GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
  126. gtk_main_quit ();
  127. gtk_widget_destroy (choose_t->mainwnd);
  128. }
  129. }
  130. static gint
  131. delete_event (GtkWidget *widget,
  132. GdkEvent *event, TTRANSLATORCHOOSER *choose_t)
  133. {
  134. translatorchooser_cancel_clicked (widget, choose_t);
  135. return FALSE;
  136. }
  137. void
  138. addtranslators_to_list (GtkWidget *widget, GtkWidget *dlg)
  139. {
  140. char *curr, *buffer = (char *) malloc (sizeof (char) * 65536), *szDriver;
  141. char driver[1024], _date[1024], _size[1024];
  142. char *data[4];
  143. int len, i;
  144. BOOL careabout;
  145. UWORD confMode = ODBC_USER_DSN;
  146. struct stat _stat;
  147. if (!buffer || !GTK_IS_CLIST (widget))
  148. return;
  149. gtk_clist_clear (GTK_CLIST (widget));
  150. /* Get the current config mode */
  151. while (confMode != ODBC_SYSTEM_DSN + 1)
  152. {
  153. /* Get the list of drivers in the user context */
  154. SQLSetConfigMode (confMode);
  155. #ifdef WIN32
  156. len =
  157. SQLGetPrivateProfileString ("ODBC 32 bit Translators",
  158. NULL, "", buffer, 65535, "odbcinst.ini");
  159. #else
  160. len =
  161. SQLGetPrivateProfileString ("ODBC Translators",
  162. NULL, "", buffer, 65535, "odbcinst.ini");
  163. #endif
  164. if (len)
  165. goto process;
  166. goto end;
  167. process:
  168. for (curr = buffer; *curr; curr += (STRLEN (curr) + 1))
  169. {
  170. /* Shadowing system odbcinst.ini */
  171. for (i = 0, careabout = TRUE; i < GTK_CLIST (widget)->rows; i++)
  172. {
  173. gtk_clist_get_text (GTK_CLIST (widget), i, 0, &szDriver);
  174. if (!strcmp (szDriver, curr))
  175. {
  176. careabout = FALSE;
  177. break;
  178. }
  179. }
  180. if (!careabout)
  181. continue;
  182. SQLSetConfigMode (confMode);
  183. #ifdef WIN32
  184. SQLGetPrivateProfileString ("ODBC 32 bit Translators",
  185. curr, "", driver, sizeof (driver), "odbcinst.ini");
  186. #else
  187. SQLGetPrivateProfileString ("ODBC Translators",
  188. curr, "", driver, sizeof (driver), "odbcinst.ini");
  189. #endif
  190. /* Check if the driver is installed */
  191. if (strcasecmp (driver, "Installed"))
  192. goto end;
  193. /* Get the driver library name */
  194. SQLSetConfigMode (confMode);
  195. if (!SQLGetPrivateProfileString (curr,
  196. "Translator", "", driver, sizeof (driver), "odbcinst.ini"))
  197. {
  198. SQLSetConfigMode (confMode);
  199. SQLGetPrivateProfileString ("Default",
  200. "Translator", "", driver, sizeof (driver), "odbcinst.ini");
  201. }
  202. if (STRLEN (curr) && STRLEN (driver))
  203. {
  204. data[0] = curr;
  205. data[1] = driver;
  206. /* Get some information about the driver */
  207. if (!stat (driver, &_stat))
  208. {
  209. sprintf (_size, "%lu Kb",
  210. (unsigned long) _stat.st_size / 1024L);
  211. sprintf (_date, "%s", ctime (&_stat.st_mtime));
  212. data[2] = _date;
  213. data[3] = _size;
  214. gtk_clist_append (GTK_CLIST (widget), data);
  215. }
  216. }
  217. }
  218. end:
  219. if (confMode == ODBC_USER_DSN)
  220. confMode = ODBC_SYSTEM_DSN;
  221. else
  222. confMode = ODBC_SYSTEM_DSN + 1;
  223. }
  224. if (GTK_CLIST (widget)->rows > 0)
  225. {
  226. gtk_clist_columns_autosize (GTK_CLIST (widget));
  227. gtk_clist_sort (GTK_CLIST (widget));
  228. }
  229. /* Make the clean up */
  230. free (buffer);
  231. }
  232. void
  233. create_translatorchooser (HWND hwnd, TTRANSLATORCHOOSER *choose_t)
  234. {
  235. GdkPixmap *pixmap;
  236. GdkBitmap *mask;
  237. GtkStyle *style;
  238. GtkWidget *translatorchooser;
  239. GtkWidget *vbox41;
  240. GtkWidget *hbox57;
  241. GtkWidget *frame97;
  242. GtkWidget *alignment81;
  243. GtkWidget *pixmap1;
  244. GtkWidget *frame98;
  245. GtkWidget *alignment82;
  246. GtkWidget *scrolledwindow21;
  247. GtkWidget *clist1;
  248. GtkWidget *label158;
  249. GtkWidget *label159;
  250. GtkWidget *label160;
  251. GtkWidget *label161;
  252. GtkWidget *label162;
  253. GtkWidget *hbuttonbox3;
  254. GtkWidget *b_finish;
  255. GtkWidget *b_cancel;
  256. if (hwnd == NULL || !GTK_IS_WIDGET (hwnd))
  257. return;
  258. translatorchooser = gtk_dialog_new ();
  259. gtk_widget_set_name (translatorchooser, "translatorchooser");
  260. gtk_widget_set_size_request (translatorchooser, 515, 335);
  261. gtk_window_set_title (GTK_WINDOW (translatorchooser), _("Choose a Translator"));
  262. gtk_window_set_position (GTK_WINDOW (translatorchooser), GTK_WIN_POS_CENTER_ON_PARENT);
  263. gtk_window_set_modal (GTK_WINDOW (translatorchooser), TRUE);
  264. gtk_window_set_default_size (GTK_WINDOW (translatorchooser), 600, 450);
  265. gtk_window_set_type_hint (GTK_WINDOW (translatorchooser), GDK_WINDOW_TYPE_HINT_DIALOG);
  266. #if GTK_CHECK_VERSION(2,0,0)
  267. gtk_widget_show (translatorchooser);
  268. #endif
  269. vbox41 = GTK_DIALOG (translatorchooser)->vbox;
  270. gtk_widget_set_name (vbox41, "vbox41");
  271. gtk_widget_show (vbox41);
  272. hbox57 = gtk_hbox_new (FALSE, 0);
  273. gtk_widget_set_name (hbox57, "hbox57");
  274. gtk_widget_show (hbox57);
  275. gtk_box_pack_start (GTK_BOX (vbox41), hbox57, TRUE, TRUE, 0);
  276. frame97 = gtk_frame_new (NULL);
  277. gtk_widget_set_name (frame97, "frame97");
  278. gtk_widget_show (frame97);
  279. gtk_box_pack_start (GTK_BOX (hbox57), frame97, FALSE, TRUE, 0);
  280. gtk_container_set_border_width (GTK_CONTAINER (frame97), 10);
  281. gtk_frame_set_shadow_type (GTK_FRAME (frame97), GTK_SHADOW_NONE);
  282. alignment81 = gtk_alignment_new (0.5, 0.5, 1, 1);
  283. gtk_widget_set_name (alignment81, "alignment81");
  284. gtk_widget_show (alignment81);
  285. gtk_container_add (GTK_CONTAINER (frame97), alignment81);
  286. gtk_widget_set_size_request (alignment81, 140, -1);
  287. #if GTK_CHECK_VERSION(2,0,0)
  288. style = gtk_widget_get_style (translatorchooser);
  289. pixmap =
  290. gdk_pixmap_create_from_xpm_d (translatorchooser->window, &mask,
  291. &style->bg[GTK_STATE_NORMAL], (gchar **) img_xpm);
  292. #else
  293. style = gtk_widget_get_style (GTK_WIDGET (hwnd));
  294. pixmap =
  295. gdk_pixmap_create_from_xpm_d (GTK_WIDGET (hwnd)->window, &mask,
  296. &style->bg[GTK_STATE_NORMAL], (gchar **) img_xpm);
  297. #endif
  298. pixmap1 = gtk_pixmap_new (pixmap, mask);
  299. gtk_widget_set_name (pixmap1, "pixmap1");
  300. gtk_widget_show (pixmap1);
  301. gtk_container_add (GTK_CONTAINER (alignment81), pixmap1);
  302. frame98 = gtk_frame_new (NULL);
  303. gtk_widget_set_name (frame98, "frame98");
  304. gtk_widget_show (frame98);
  305. gtk_box_pack_start (GTK_BOX (hbox57), frame98, TRUE, TRUE, 0);
  306. gtk_frame_set_shadow_type (GTK_FRAME (frame98), GTK_SHADOW_NONE);
  307. alignment82 = gtk_alignment_new (0.5, 0.5, 1, 1);
  308. gtk_widget_set_name (alignment82, "alignment82");
  309. gtk_widget_show (alignment82);
  310. gtk_container_add (GTK_CONTAINER (frame98), alignment82);
  311. gtk_alignment_set_padding (GTK_ALIGNMENT (alignment82), 0, 10, 0, 0);
  312. scrolledwindow21 = gtk_scrolled_window_new (NULL, NULL);
  313. gtk_widget_set_name (scrolledwindow21, "scrolledwindow21");
  314. gtk_widget_show (scrolledwindow21);
  315. gtk_container_add (GTK_CONTAINER (alignment82), scrolledwindow21);
  316. clist1 = gtk_clist_new (4);
  317. gtk_widget_set_name (clist1, "clist1");
  318. gtk_widget_show (clist1);
  319. gtk_container_add (GTK_CONTAINER (scrolledwindow21), clist1);
  320. gtk_clist_set_column_width (GTK_CLIST (clist1), 0, 165);
  321. gtk_clist_set_column_width (GTK_CLIST (clist1), 1, 118);
  322. gtk_clist_set_column_width (GTK_CLIST (clist1), 2, 80);
  323. gtk_clist_set_column_width (GTK_CLIST (clist1), 3, 80);
  324. gtk_clist_column_titles_show (GTK_CLIST (clist1));
  325. label158 = gtk_label_new (_("Name"));
  326. gtk_widget_set_name (label158, "label158");
  327. gtk_widget_show (label158);
  328. gtk_clist_set_column_widget (GTK_CLIST (clist1), 0, label158);
  329. gtk_widget_set_size_request (label158, 165, -1);
  330. label159 = gtk_label_new (_("File"));
  331. gtk_widget_set_name (label159, "label159");
  332. gtk_widget_show (label159);
  333. gtk_clist_set_column_widget (GTK_CLIST (clist1), 1, label159);
  334. gtk_widget_set_size_request (label159, 118, -1);
  335. label160 = gtk_label_new (_("Date"));
  336. gtk_widget_set_name (label160, "label160");
  337. gtk_widget_show (label160);
  338. gtk_clist_set_column_widget (GTK_CLIST (clist1), 2, label160);
  339. gtk_widget_set_size_request (label160, 80, -1);
  340. label161 = gtk_label_new (_("Size"));
  341. gtk_widget_set_name (label161, "label161");
  342. gtk_widget_show (label161);
  343. gtk_clist_set_column_widget (GTK_CLIST (clist1), 3, label161);
  344. gtk_widget_set_size_request (label161, 80, -1);
  345. label162 = gtk_label_new (_("Select which ODBC Translator you want to use"));
  346. gtk_widget_set_name (label162, "label162");
  347. gtk_widget_show (label162);
  348. gtk_frame_set_label_widget (GTK_FRAME (frame98), label162);
  349. gtk_label_set_use_markup (GTK_LABEL (label162), TRUE);
  350. hbuttonbox3 = GTK_DIALOG (translatorchooser)->action_area;
  351. gtk_widget_set_name (hbuttonbox3, "hbuttonbox3");
  352. gtk_widget_show (hbuttonbox3);
  353. gtk_button_box_set_layout (GTK_BUTTON_BOX (hbuttonbox3), GTK_BUTTONBOX_END);
  354. b_finish = gtk_button_new_from_stock ("gtk-ok");
  355. gtk_widget_set_name (b_finish, "b_finish");
  356. gtk_widget_show (b_finish);
  357. gtk_dialog_add_action_widget (GTK_DIALOG (translatorchooser), b_finish, GTK_RESPONSE_OK);
  358. GTK_WIDGET_SET_FLAGS (b_finish, GTK_CAN_DEFAULT);
  359. b_cancel = gtk_button_new_from_stock ("gtk-cancel");
  360. gtk_widget_set_name (b_cancel, "b_cancel");
  361. gtk_widget_show (b_cancel);
  362. gtk_dialog_add_action_widget (GTK_DIALOG (translatorchooser), b_cancel, GTK_RESPONSE_CANCEL);
  363. GTK_WIDGET_SET_FLAGS (b_cancel, GTK_CAN_DEFAULT);
  364. /* Store pointers to all widgets, for use by lookup_widget(). */
  365. GLADE_HOOKUP_OBJECT_NO_REF (translatorchooser, translatorchooser, "translatorchooser");
  366. GLADE_HOOKUP_OBJECT_NO_REF (translatorchooser, vbox41, "vbox41");
  367. GLADE_HOOKUP_OBJECT (translatorchooser, hbox57, "hbox57");
  368. GLADE_HOOKUP_OBJECT (translatorchooser, frame97, "frame97");
  369. GLADE_HOOKUP_OBJECT (translatorchooser, alignment81, "alignment81");
  370. GLADE_HOOKUP_OBJECT (translatorchooser, pixmap1, "pixmap1");
  371. GLADE_HOOKUP_OBJECT (translatorchooser, frame98, "frame98");
  372. GLADE_HOOKUP_OBJECT (translatorchooser, alignment82, "alignment82");
  373. GLADE_HOOKUP_OBJECT (translatorchooser, scrolledwindow21, "scrolledwindow21");
  374. GLADE_HOOKUP_OBJECT (translatorchooser, clist1, "clist1");
  375. GLADE_HOOKUP_OBJECT (translatorchooser, label158, "label158");
  376. GLADE_HOOKUP_OBJECT (translatorchooser, label159, "label159");
  377. GLADE_HOOKUP_OBJECT (translatorchooser, label160, "label160");
  378. GLADE_HOOKUP_OBJECT (translatorchooser, label161, "label161");
  379. GLADE_HOOKUP_OBJECT (translatorchooser, label162, "label162");
  380. GLADE_HOOKUP_OBJECT_NO_REF (translatorchooser, hbuttonbox3, "hbuttonbox3");
  381. GLADE_HOOKUP_OBJECT (translatorchooser, b_finish, "b_finish");
  382. GLADE_HOOKUP_OBJECT (translatorchooser, b_cancel, "b_cancel");
  383. /* Ok button events */
  384. gtk_signal_connect (GTK_OBJECT (b_finish), "clicked",
  385. GTK_SIGNAL_FUNC (translatorchooser_ok_clicked), choose_t);
  386. /* Cancel button events */
  387. gtk_signal_connect (GTK_OBJECT (b_cancel), "clicked",
  388. GTK_SIGNAL_FUNC (translatorchooser_cancel_clicked), choose_t);
  389. /* Close window button events */
  390. gtk_signal_connect (GTK_OBJECT (translatorchooser), "delete_event",
  391. GTK_SIGNAL_FUNC (delete_event), choose_t);
  392. gtk_signal_connect (GTK_OBJECT (translatorchooser), "destroy",
  393. GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
  394. /* Translator list events */
  395. gtk_signal_connect (GTK_OBJECT (clist1), "select_row",
  396. GTK_SIGNAL_FUNC (translator_list_select), choose_t);
  397. addtranslators_to_list (clist1, translatorchooser);
  398. choose_t->translatorlist = clist1;
  399. choose_t->translator = NULL;
  400. choose_t->mainwnd = translatorchooser;
  401. choose_t->b_finish = b_finish;
  402. gtk_widget_show_all (translatorchooser);
  403. gtk_main ();
  404. }