[GRASS-SVN] r63597 - grass/branches/releasebranch_7_0/lib/vector/Vlib

svn_grass at osgeo.org svn_grass at osgeo.org
Thu Dec 18 10:47:41 PST 2014


Author: mmetz
Date: 2014-12-18 10:47:41 -0800 (Thu, 18 Dec 2014)
New Revision: 63597

Modified:
   grass/branches/releasebranch_7_0/lib/vector/Vlib/ascii.c
Log:
Vlib: fix segfault in ascii export (backport r63596)

Modified: grass/branches/releasebranch_7_0/lib/vector/Vlib/ascii.c
===================================================================
--- grass/branches/releasebranch_7_0/lib/vector/Vlib/ascii.c	2014-12-18 18:45:36 UTC (rev 63596)
+++ grass/branches/releasebranch_7_0/lib/vector/Vlib/ascii.c	2014-12-18 18:47:41 UTC (rev 63597)
@@ -419,11 +419,11 @@
 	    db_shutdown_driver(driver);
 	}
 	else {
+	    int icol, ncols;
+	    const char *col_name;
             int len_all = 0;
             
             if (column_names[0] && strcmp(column_names[0], "*") == 0) {
-                int icol, ncols;
-                const char *col_name;
                 
                 /* all columns */
                 db_set_string(&dbstring, Fi->table);
@@ -433,24 +433,21 @@
                 }
                 
                 ncols = db_get_table_number_of_columns(Table);
-                /* key column skipped */
                 columns = (char **) G_malloc(ncols * sizeof(char *));
                 icol = 0;
                 for (i = 0; i < ncols; i++) {
                     col_name = db_get_column_name(db_get_table_column(Table, i));
+		    /* key column skipped */
                     if (strcmp(Fi->key, col_name) != 0)
 			columns[icol++] = G_store(col_name);
                 }
-                columns[ncols - 1] = NULL;
+                columns[icol] = NULL;
                 
                 db_zero_string(&dbstring);
                 db_free_table(Table);
                 Table = NULL;
             }
             else {
-                int icol, ncols;
-                const char *col_name;
-
 		ncols = 0;
 		while (column_names[ncols])
 		    ncols++;
@@ -466,33 +463,43 @@
                 columns[icol] = NULL;
             }
             
-            /* selected columns only */
-            i = 0;
-            while (columns[i])
-                len_all += strlen(columns[i++]);
-            
-	    coltypes = G_malloc(i * sizeof(int));
-	    
-	    all_columns = G_malloc(len_all + i + 2);
+	    if (columns[0]) {
+		/* selected columns only */
+		i = 0;
+		while (columns[i])
+		    len_all += strlen(columns[i++]);
+		
+		coltypes = G_malloc(i * sizeof(int));
+		
+		all_columns = G_malloc(len_all + i + 2);
 
-	    i = 0;
-	    strcpy(all_columns, columns[0]);
-	    while (columns[i]) {
-		/* get column types */
-		coltypes[i] = db_column_Ctype(driver, Fi->table, columns[i]);
-		if (coltypes[i] < 0) {
-		    db_close_database(driver);
-		    db_shutdown_driver(driver);
-		    G_warning(_("Unknown type of column <%s>, export cancelled"),
-		              columns[i]);
-		    return -1;
+		i = 0;
+		strcpy(all_columns, columns[0]);
+		while (columns[i]) {
+		    /* get column types */
+		    coltypes[i] = db_column_Ctype(driver, Fi->table, columns[i]);
+		    if (coltypes[i] < 0) {
+			db_close_database(driver);
+			db_shutdown_driver(driver);
+			G_warning(_("Unknown type of column <%s>, export cancelled"),
+				  columns[i]);
+			return -1;
+		    }
+		    if (i > 0) {
+			strcat(all_columns, ",");
+			strcat(all_columns, columns[i]);
+		    }
+		    i++;
 		}
-		if (i > 0) {
-		    strcat(all_columns, ",");
-		    strcat(all_columns, columns[i]);
-		}
-		i++;
 	    }
+	    else {
+		/* no column or only key column selected */
+		G_free(columns);
+		columns = NULL;
+
+		db_close_database(driver);
+		db_shutdown_driver(driver);
+	    }
 	}
     }
 



More information about the grass-commit mailing list