main.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. /****************************************************************************
  2. *
  3. * MODULE: db.columns
  4. * AUTHOR(S): Radim Blazek <radim.blazek gmail.com> (original contributor)
  5. * Glynn Clements <glynn gclements.plus.com>, Markus Neteler <neteler itc.it>
  6. * PURPOSE: list the column names for a table
  7. * COPYRIGHT: (C) 2002-2006 by the GRASS Development Team
  8. *
  9. * This program is free software under the GNU General Public
  10. * License (>=v2). Read the file COPYING that comes with GRASS
  11. * for details.
  12. *
  13. *****************************************************************************/
  14. #include <stdlib.h>
  15. #include <grass/gis.h>
  16. #include <grass/dbmi.h>
  17. #include <grass/glocale.h>
  18. struct
  19. {
  20. char *driver, *database, *table;
  21. } parms;
  22. /* function prototypes */
  23. static void parse_command_line(int, char **);
  24. int main(int argc, char **argv)
  25. {
  26. dbDriver *driver;
  27. dbHandle handle;
  28. dbTable *table;
  29. dbString table_name;
  30. int col, ncols;
  31. parse_command_line(argc, argv);
  32. if (!db_table_exists(parms.driver, parms.database, parms.table)) {
  33. G_warning(_("Table <%s> not found in database <%s> using driver <%s>"),
  34. parms.table, parms.database, parms.driver);
  35. exit(EXIT_FAILURE);
  36. }
  37. driver = db_start_driver(parms.driver);
  38. if (driver == NULL)
  39. G_fatal_error(_("Unable to start driver <%s>"), parms.driver);
  40. db_init_handle(&handle);
  41. db_set_handle(&handle, parms.database, NULL);
  42. if (db_open_database(driver, &handle) != DB_OK)
  43. G_fatal_error(_("Unable to open database <%s>"), parms.database);
  44. db_set_error_handler_driver(driver);
  45. db_init_string(&table_name);
  46. db_set_string(&table_name, parms.table);
  47. if (db_describe_table(driver, &table_name, &table) != DB_OK)
  48. G_fatal_error(_("Unable to describe table <%s>"), parms.table);
  49. db_close_database(driver);
  50. db_shutdown_driver(driver);
  51. ncols = db_get_table_number_of_columns(table);
  52. for (col = 0; col < ncols; col++)
  53. fprintf(stdout, "%s\n",
  54. db_get_column_name(db_get_table_column(table, col)));
  55. exit(EXIT_SUCCESS);
  56. }
  57. static void parse_command_line(int argc, char **argv)
  58. {
  59. struct Option *driver, *database, *table;
  60. struct GModule *module;
  61. const char *drv, *db;
  62. /* Initialize the GIS calls */
  63. G_gisinit(argv[0]);
  64. table = G_define_standard_option(G_OPT_DB_TABLE);
  65. table->required = YES;
  66. driver = G_define_standard_option(G_OPT_DB_DRIVER);
  67. driver->options = db_list_drivers();
  68. if ((drv = db_get_default_driver_name()))
  69. driver->answer = (char *) drv;
  70. database = G_define_standard_option(G_OPT_DB_DATABASE);
  71. if ((db = db_get_default_database_name()))
  72. database->answer = (char *) db;
  73. /* Set description */
  74. module = G_define_module();
  75. G_add_keyword(_("database"));
  76. G_add_keyword(_("attribute table"));
  77. module->description = _("List all columns for a given table.");
  78. if (G_parser(argc, argv))
  79. exit(EXIT_FAILURE);
  80. parms.driver = driver->answer;
  81. parms.database = database->answer;
  82. parms.table = table->answer;
  83. }