File: printtab.c

package info (click to toggle)
grass 8.4.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 277,040 kB
  • sloc: ansic: 460,798; python: 227,732; cpp: 42,026; sh: 11,262; makefile: 7,007; xml: 3,637; sql: 968; lex: 520; javascript: 484; yacc: 450; asm: 387; perl: 157; sed: 25; objc: 6; ruby: 4
file content (78 lines) | stat: -rw-r--r-- 2,389 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#include <grass/gis.h>
#include <grass/dbmi.h>
#include "local_proto.h"
#include <grass/glocale.h>

int print_table_definition(dbDriver *driver, dbTable *table)
{
    int ncols, col, nrows;
    dbColumn *column;
    char buf[1024];
    dbString stmt;

    fprintf(stdout, "table:%s\n", db_get_table_name(table));
    fprintf(stdout, "description:%s\n", db_get_table_description(table));
    print_priv("insert", db_get_table_insert_priv(table));
    print_priv("delete", db_get_table_delete_priv(table));

    ncols = db_get_table_number_of_columns(table);

    db_init_string(&stmt);
    sprintf(buf, "select * from %s", db_get_table_name(table));
    db_set_string(&stmt, buf);
    nrows = db_get_table_number_of_rows(driver, &stmt);
    fprintf(stdout, "ncols:%d\n", ncols);
    fprintf(stdout, "nrows:%d\n", nrows);
    for (col = 0; col < ncols; col++) {
        column = db_get_table_column(table, col);
        fprintf(stdout, "\n");
        print_column_definition(column);
    }

    return 0;
}

int print_column_definition(dbColumn *column)
{
    dbString value_string;

    fprintf(stdout, "column:%s\n", db_get_column_name(column));
    fprintf(stdout, "description:%s\n", db_get_column_description(column));
    fprintf(stdout, "type:%s\n",
            db_sqltype_name(db_get_column_sqltype(column)));
    fprintf(stdout, "len:%d\n", db_get_column_length(column));
    fprintf(stdout, "scale:%d\n", db_get_column_scale(column));
    fprintf(stdout, "precision:%d\n", db_get_column_precision(column));
    fprintf(stdout, "default:");
    if (db_test_column_has_default_value(column)) {
        db_init_string(&value_string);
        db_convert_column_default_value_to_string(column, &value_string);
        fprintf(stdout, "%s", db_get_string(&value_string));
    }
    fprintf(stdout, "\n");
    fprintf(stdout, "nullok:%s\n",
            db_test_column_null_allowed(column) ? "yes" : "no");
    print_priv("select", db_get_column_select_priv(column));
    print_priv("update", db_get_column_update_priv(column));

    return 0;
}

int print_priv(char *label, int priv)
{
    fprintf(stdout, "%s:", label);
    switch (priv) {
    case DB_GRANTED:
        fprintf(stdout, "yes");
        break;
    case DB_NOT_GRANTED:
        fprintf(stdout, "no");
        break;
    default:
        fprintf(stdout, "?");
        break;
    }
    fprintf(stdout, "\n");

    return 0;
}