File: listtab.c

package info (click to toggle)
grass 6.0.2-6
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 40,044 kB
  • ctags: 31,303
  • sloc: ansic: 321,125; tcl: 25,676; sh: 11,176; cpp: 10,098; makefile: 5,025; fortran: 1,846; yacc: 493; lex: 462; perl: 133; sed: 1
file content (67 lines) | stat: -rw-r--r-- 1,531 bytes parent folder | download | duplicates (2)
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
#include <stdlib.h>
#include <string.h>
#include <dbmi.h>
#include "globals.h"
#include "proto.h"

int db__driver_list_tables(tlist, tcount, system)
     dbString **tlist;
     int *tcount;
     int system;
{
    int i, nrows, ncols, tablecol, schemacol;
    dbString *list;
    PGresult *res;
    char buf[1000];

    init_error();
    *tlist = NULL;
    *tcount = 0;

    res = PQexec(pg_conn, "select * from pg_tables where tablename !~ 'pg_*' order by tablename");
    
    if (!res || PQresultStatus(res) != PGRES_TUPLES_OK) {
	append_error ( "Cannot select table names\n" );
	append_error ( PQerrorMessage(pg_conn) );
	report_error();
	PQclear(res);
	return DB_FAILED;
    }

    /* Find table and schema col */
    ncols = PQnfields(res);
    schemacol = -1;
    for (i = 0; i < ncols; i++) {
	if ( strcmp(PQfname(res, i),"tablename") == 0 )
	    tablecol = i;

	if ( strcmp(PQfname(res, i),"schemaname") == 0 )
	    schemacol = i;
    }

    nrows = PQntuples(res);
    
    list = db_alloc_string_array(nrows);
    
    if (list == NULL ) {
	append_error ( "Cannot db_alloc_string_array()");
	report_error();
	return DB_FAILED;
    }

    for (i = 0; i < nrows; i++) {
	if ( schemacol >= 0 ) {
	   sprintf ( buf, "%s.%s", (char *) PQgetvalue(res, i, schemacol), 
		                   (char *) PQgetvalue(res, i, tablecol) );
	} else {
	   sprintf ( buf, "%s", (char *) PQgetvalue(res, i, tablecol) );
	}
	db_set_string(&list[i], buf );
    }

    PQclear(res);

    *tlist = list;
    *tcount = nrows;
    return DB_OK;
}