GRASS 8 Programmer's Manual 8.6.0dev(2026)-1d1e47ad9d
Loading...
Searching...
No Matches
valuefmt.c
Go to the documentation of this file.
1/*!
2 \file lib/db/dbmi_base/valuefmt.c
3
4 \brief DBMI Library (base) - value formatting
5
6 (C) 1999-2009, 2011 by the GRASS Development Team
7
8 This program is free software under the GNU General Public License
9 (>=v2). Read the file COPYING that comes with GRASS for details.
10
11 \author Joel Jones (CERL/UIUC), Radim Blazek
12 \author Doxygenized by Martin Landa <landa.martin gmail.com> (2011)
13 */
14
15#include <stdio.h>
16#include <string.h>
17#include <grass/gis.h>
18#include <grass/dbmi.h>
19#include <grass/glocale.h>
20
21/*!
22 \brief Convert string to value
23
24 \param Cstring string buffer
25 \param sqltype SQL data type
26 \param[out] value pointer to dbValue
27
28 \return DB_OK on success
29 \return DB_FAILED on error
30 */
32 dbValue *value)
33{
34 int i;
35 double d;
36
39 return db_set_value_string(value, Cstring);
40 case DB_C_TYPE_INT:
41 i = 0;
42 sscanf(Cstring, "%d", &i);
43 db_set_value_int(value, i);
44 break;
46 d = 0.0;
47 sscanf(Cstring, "%lf", &d);
48 db_set_value_double(value, d);
49 break;
52 default:
53 db_error(_("db_convert_Cstring_to_value(): unrecognized sqltype"));
54 return DB_FAILED;
55 }
56 return DB_OK;
57}
58
59/*!
60 \brief Convert value to string
61
62 \param value pointer to dbValue
63 \param sqltype SQL data type
64 \param[out] string pointer to dbString
65
66 \return DB_OK on success
67 */
69{
70 char buf[64];
71 const char *bp = buf;
72
73 if (db_test_value_isnull(value)) {
74 *buf = 0;
75 }
76 else {
78 case DB_C_TYPE_INT:
79 snprintf(buf, sizeof(buf), "%d", db_get_value_int(value));
80 break;
82 snprintf(buf, sizeof(buf), "%.15g", db_get_value_double(value));
83 G_trim_decimal(buf);
84 break;
86 bp = db_get_value_string(value);
87 break;
90 string);
91 default:
93 _("db_convert_value_into_string(): unrecongized sqltype-type"));
94 return DB_FAILED;
95 }
96 }
97 return db_set_string(string, bp);
98}
Main header of GRASS DataBase Management Interface.
#define DB_C_TYPE_INT
Definition dbmi.h:108
#define DB_FAILED
Definition dbmi.h:72
#define DB_C_TYPE_STRING
Definition dbmi.h:107
#define DB_C_TYPE_DOUBLE
Definition dbmi.h:109
#define DB_OK
Definition dbmi.h:71
#define DB_C_TYPE_DATETIME
Definition dbmi.h:110
int db_test_value_isnull(dbValue *)
Check of value is null.
Definition value.c:26
double db_get_value_double(dbValue *)
Get double precision value.
Definition value.c:50
int db_set_value_string(dbValue *, const char *)
Set string value.
Definition value.c:219
int db_sqltype_to_Ctype(int)
Get C data type based on given SQL data type.
Definition sqlCtype.c:24
int db_convert_value_datetime_into_string(dbValue *, int, dbString *)
Convert datetime value into string.
Definition datetime.c:31
void db_set_value_double(dbValue *, double)
Set double precision value.
Definition value.c:207
int db_convert_Cstring_to_value_datetime(const char *, int, dbValue *)
Convert datetime string to value.
Definition datetime.c:203
void db_set_value_int(dbValue *, int)
Set integer value.
Definition value.c:195
int db_set_string(dbString *, const char *)
Inserts string to dbString (enlarge string)
Definition string.c:41
int db_get_value_int(dbValue *)
Get integer value.
Definition value.c:38
void db_error(const char *)
Report error message.
const char * db_get_value_string(dbValue *)
Get string value.
Definition value.c:92
void G_trim_decimal(char *)
Removes trailing zeros from decimal number.
Definition trim_dec.c:24
#define _(str)
Definition glocale.h:10
int db_convert_value_to_string(dbValue *value, int sqltype, dbString *string)
Convert value to string.
Definition valuefmt.c:68
int db_convert_Cstring_to_value(const char *Cstring, int sqltype, dbValue *value)
Convert string to value.
Definition valuefmt.c:31