valuefmt.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <grass/gis.h>
  4. #include <grass/dbmi.h>
  5. /*!
  6. \fn
  7. \brief
  8. \return
  9. \param
  10. */
  11. int
  12. db_convert_Cstring_to_value(const char *Cstring, int sqltype, dbValue * value)
  13. {
  14. int i;
  15. double d;
  16. switch (db_sqltype_to_Ctype(sqltype)) {
  17. case DB_C_TYPE_STRING:
  18. return db_set_value_string(value, Cstring);
  19. case DB_C_TYPE_INT:
  20. i = 0;
  21. sscanf(Cstring, "%d", &i);
  22. db_set_value_int(value, i);
  23. break;
  24. case DB_C_TYPE_DOUBLE:
  25. d = 0.0;
  26. sscanf(Cstring, "%lf", &d);
  27. db_set_value_double(value, d);
  28. break;
  29. case DB_C_TYPE_DATETIME:
  30. return db_convert_Cstring_to_value_datetime(Cstring, sqltype, value);
  31. default:
  32. db_error("db_convert_Cstring_to_value(): unrecognized sqltype");
  33. return DB_FAILED;
  34. }
  35. return DB_OK;
  36. }
  37. /*!
  38. \fn
  39. \brief
  40. \return
  41. \param
  42. */
  43. int
  44. db_convert_value_to_string(dbValue * value, int sqltype, dbString * string)
  45. {
  46. char buf[64];
  47. const char *bp = buf;
  48. if (db_test_value_isnull(value)) {
  49. *buf = 0;
  50. }
  51. else {
  52. switch (db_sqltype_to_Ctype(sqltype)) {
  53. case DB_C_TYPE_INT:
  54. sprintf(buf, "%d", db_get_value_int(value));
  55. break;
  56. case DB_C_TYPE_DOUBLE:
  57. sprintf(buf, "%.15g", db_get_value_double(value));
  58. G_trim_decimal(buf);
  59. break;
  60. case DB_C_TYPE_STRING:
  61. bp = db_get_value_string(value);
  62. break;
  63. case DB_C_TYPE_DATETIME:
  64. return db_convert_value_datetime_into_string(value, sqltype,
  65. string);
  66. default:
  67. db_error
  68. ("db_convert_value_into_string(): unrecongized sqltype-type");
  69. return DB_FAILED;
  70. }
  71. }
  72. return db_set_string(string, bp);
  73. }