[GRASS-SVN] r36763 -
grass/branches/releasebranch_6_4/general/g.mapsets
svn_grass at osgeo.org
svn_grass at osgeo.org
Thu Apr 16 15:48:26 EDT 2009
Author: neteler
Date: 2009-04-16 15:48:26 -0400 (Thu, 16 Apr 2009)
New Revision: 36763
Removed:
grass/branches/releasebranch_6_4/general/g.mapsets/externs.h
Modified:
grass/branches/releasebranch_6_4/general/g.mapsets/Makefile
grass/branches/releasebranch_6_4/general/g.mapsets/dsply_maps.c
grass/branches/releasebranch_6_4/general/g.mapsets/dsply_path.c
grass/branches/releasebranch_6_4/general/g.mapsets/get_maps.c
grass/branches/releasebranch_6_4/general/g.mapsets/local_proto.h
grass/branches/releasebranch_6_4/general/g.mapsets/main.c
Log:
hcho: Removed unused variables; Dynamic buffer for large number of mapsets and long mapset names (bugfix for many mapsets with long names, merge from trunk, r36709)
Modified: grass/branches/releasebranch_6_4/general/g.mapsets/Makefile
===================================================================
--- grass/branches/releasebranch_6_4/general/g.mapsets/Makefile 2009-04-16 19:36:59 UTC (rev 36762)
+++ grass/branches/releasebranch_6_4/general/g.mapsets/Makefile 2009-04-16 19:48:26 UTC (rev 36763)
@@ -1,4 +1,3 @@
-
MODULE_TOPDIR = ../..
PGM = g.mapsets
Modified: grass/branches/releasebranch_6_4/general/g.mapsets/dsply_maps.c
===================================================================
--- grass/branches/releasebranch_6_4/general/g.mapsets/dsply_maps.c 2009-04-16 19:36:59 UTC (rev 36762)
+++ grass/branches/releasebranch_6_4/general/g.mapsets/dsply_maps.c 2009-04-16 19:48:26 UTC (rev 36763)
@@ -1,16 +1,17 @@
#include <string.h>
#include <stdio.h>
-#include "externs.h"
+#include <grass/glocale.h>
+#include "local_proto.h"
static int display1(void);
-static int display2(void);
+static int display2(const char *fs);
-int display_available_mapsets(int verbose)
+int display_available_mapsets(const char* fs)
{
- if (verbose)
+ if (!fs)
display1();
else
- display2();
+ display2(fs);
return 0;
}
@@ -19,7 +20,7 @@
{
int n;
- fprintf(stdout, "Available mapsets:");
+ fprintf(stdout, _("Available mapsets:"));
for (n = 0; n < nmapsets; n++) {
if (n % 4)
fprintf(stdout, " ");
@@ -29,13 +30,13 @@
}
fprintf(stdout, "\n");
if (nmapsets == 0)
- fprintf(stdout, "** no mapsets **\n");
+ fprintf(stdout, _("** no mapsets **\n"));
fprintf(stdout, "\n");
return 0;
}
-static int display2(void)
+static int display2(const char *fs)
{
int nleft, len, n;
char *name;
@@ -47,7 +48,9 @@
fprintf(stdout, "\n");
nleft = 78;
}
- fprintf(stdout, "%s ", name);
+ fprintf(stdout, "%s", name);
+ if (n < nmapsets-1)
+ fprintf(stdout, "%s", fs);
nleft -= (len + 1);
}
fprintf(stdout, "\n");
Modified: grass/branches/releasebranch_6_4/general/g.mapsets/dsply_path.c
===================================================================
--- grass/branches/releasebranch_6_4/general/g.mapsets/dsply_path.c 2009-04-16 19:36:59 UTC (rev 36762)
+++ grass/branches/releasebranch_6_4/general/g.mapsets/dsply_path.c 2009-04-16 19:48:26 UTC (rev 36763)
@@ -1,32 +1,32 @@
#include <string.h>
-#include "externs.h"
#include <grass/gis.h>
+#include <grass/glocale.h>
+#include "local_proto.h"
-int display_mapset_path(int verbose)
+int display_mapset_path(const char *fs)
{
int n;
int map; /* pointer into list of available mapsets */
int offset = 6; /* accounts for " <x>, " */
- char *name;
+ const char *name;
int len;
int nleft;
- if (verbose) {
+ if (!fs) {
/* account for largest mapset number in offset value */
for (n = nmapsets; n /= 10; offset++) ;
- fprintf(stdout, "Your mapset search list:\n");
- ncurr_mapsets = 0;
+ fprintf(stdout, _("Your mapset search list:\n"));
}
nleft = 78;
- for (n = 0; name = G__mapset_name(n); n++) {
+ for (n = 0; (name = G__mapset_name(n)); n++) {
/* match each mapset to its numeric equivalent */
- if (verbose) {
+ if (!fs) {
for (map = 0; map < nmapsets && strcmp(mapset_name[map], name);
map++) ;
if (map == nmapsets)
- G_fatal_error("%s not found in mapset list: call greg",
+ G_fatal_error(_("<%s> not found in mapset list"),
name);
}
@@ -36,21 +36,21 @@
nleft = 78;
}
- if (verbose) {
+ if (!fs) {
if (n)
fprintf(stdout, ", ");
fprintf(stdout, "%s <%d>", name, map + 1);
nleft -= (len + offset);
- curr_mapset[n] = map;
- ++ncurr_mapsets;
}
else {
- fprintf(stdout, "%s ", name);
+ fprintf(stdout, "%s", name);
+ if (G__mapset_name(n+1))
+ fprintf(stdout, "%s", fs);
nleft -= (len + 1);
}
}
fprintf(stdout, "\n");
- if (verbose)
+ if (!fs)
fprintf(stdout, "\n");
return 0;
Deleted: grass/branches/releasebranch_6_4/general/g.mapsets/externs.h
===================================================================
--- grass/branches/releasebranch_6_4/general/g.mapsets/externs.h 2009-04-16 19:36:59 UTC (rev 36762)
+++ grass/branches/releasebranch_6_4/general/g.mapsets/externs.h 2009-04-16 19:48:26 UTC (rev 36763)
@@ -1,19 +0,0 @@
-#ifdef MAIN
-char *mapset_name[GMAPSET_MAX];
-int nmapsets;
-int choice[GMAPSET_MAX];
-int nchoices;
-int curr_mapset[GMAPSET_MAX];
-int ncurr_mapsets;
-#else
-extern char *mapset_name[];
-extern int nmapsets;
-extern int choice[];
-extern int nchoices;
-extern int curr_mapset[];
-extern int ncurr_mapsets;
-#endif
-
-#define REPLACE 0
-#define ADD 1
-#define DELETE 2
Modified: grass/branches/releasebranch_6_4/general/g.mapsets/get_maps.c
===================================================================
--- grass/branches/releasebranch_6_4/general/g.mapsets/get_maps.c 2009-04-16 19:36:59 UTC (rev 36762)
+++ grass/branches/releasebranch_6_4/general/g.mapsets/get_maps.c 2009-04-16 19:48:26 UTC (rev 36763)
@@ -1,15 +1,18 @@
#include <stdio.h>
-#include "externs.h"
#include <grass/gis.h>
+#include "local_proto.h"
int get_available_mapsets(void)
{
char **ms;
+ int i;
ms = G_available_mapsets();
+ for (nmapsets = 0; ms[nmapsets]; nmapsets++);
- for (nmapsets = 0; ms[nmapsets]; nmapsets++)
- mapset_name[nmapsets] = G_store(ms[nmapsets]);
+ mapset_name = (char **)G_malloc(nmapsets*sizeof(char *));
+ for(i = 0; i < nmapsets; i++)
+ mapset_name[i] = G_store(ms[i]);
return 0;
}
Modified: grass/branches/releasebranch_6_4/general/g.mapsets/local_proto.h
===================================================================
--- grass/branches/releasebranch_6_4/general/g.mapsets/local_proto.h 2009-04-16 19:36:59 UTC (rev 36762)
+++ grass/branches/releasebranch_6_4/general/g.mapsets/local_proto.h 2009-04-16 19:48:26 UTC (rev 36763)
@@ -1,8 +1,17 @@
+#ifdef _MAIN_C_
+#define GLOBAL
+#else
+#define GLOBAL extern
+#endif
+
+GLOBAL char **mapset_name;
+GLOBAL int nmapsets;
+
/* dsply_maps.c */
-int display_available_mapsets(int);
+int display_available_mapsets(const char *);
/* dsply_path.c */
-int display_mapset_path(int);
+int display_mapset_path(const char *);
/* get_maps.c */
int get_available_mapsets(void);
Modified: grass/branches/releasebranch_6_4/general/g.mapsets/main.c
===================================================================
--- grass/branches/releasebranch_6_4/general/g.mapsets/main.c 2009-04-16 19:36:59 UTC (rev 36762)
+++ grass/branches/releasebranch_6_4/general/g.mapsets/main.c 2009-04-16 19:48:26 UTC (rev 36763)
@@ -7,9 +7,11 @@
* Glynn Clements <glynn gclements.plus.com>
* Hamish Bowman <hamish_nospam yahoo.com>,
* Markus Neteler <neteler itc.it>,
- * Moritz Lennert <mlennert club.worldonline.be>
+ * Moritz Lennert <mlennert club.worldonline.be>,
+ * Martin Landa <landa.martin gmail.com>,
+ * Huidae Cho <grass4u gmail.com>
* PURPOSE: set current mapset path
- * COPYRIGHT: (C) 1994-2008 by the GRASS Development Team
+ * COPYRIGHT: (C) 1994-2009 by the GRASS Development Team
*
* This program is free software under the GNU General Public
* License (>=v2). Read the file COPYING that comes with GRASS
@@ -17,7 +19,7 @@
*
*****************************************************************************/
-#define MAIN
+#define _MAIN_C_
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
@@ -25,27 +27,32 @@
#include <grass/spawn.h>
#include <grass/glocale.h>
#include "local_proto.h"
-#include "externs.h"
-static char Path[GPATH_MAX];
+static void append_mapset(char **, const char *);
int main(int argc, char *argv[])
{
int n;
int i;
int skip;
- char *cur_mapset;
+ const char *cur_mapset;
char **ptr;
char **tokens;
int no_tokens;
FILE *fp;
char path[GPATH_MAX];
- struct GModule *module;
- struct Option *opt1, *opt2, *opt3;
- struct Flag *print;
- struct Flag *list;
- struct Flag *tcl;
+ char *Path;
+ int nchoices;
+ struct GModule *module;
+ struct _opt {
+ struct Option *mapset, *add, *remove;
+ struct Option *fs;
+ struct Flag *print;
+ struct Flag *list;
+ struct Flag *dialog;
+ } opt;
+
G_gisinit(argv[0]);
module = G_define_module();
@@ -55,84 +62,88 @@
"search path, affecting the user's access to data existing "
"under the other GRASS mapsets in the current location.");
- opt1 = G_define_option();
- opt1->key = "mapset";
- opt1->type = TYPE_STRING;
- opt1->required = NO;
- opt1->multiple = YES;
- opt1->description = _("Name(s) of existing mapset(s)");
+ opt.mapset = G_define_option();
+ opt.mapset->key = "mapset";
+ opt.mapset->type = TYPE_STRING;
+ opt.mapset->required = NO;
+ opt.mapset->multiple = YES;
+ opt.mapset->description = _("Name(s) of existing mapset(s)");
- opt2 = G_define_option();
- opt2->key = "addmapset";
- opt2->type = TYPE_STRING;
- opt2->required = NO;
- opt2->multiple = YES;
- opt2->description =
+ opt.add = G_define_option();
+ opt.add->key = "addmapset";
+ opt.add->type = TYPE_STRING;
+ opt.add->required = NO;
+ opt.add->multiple = YES;
+ opt.add->description =
_("Name(s) of existing mapset(s) to add to search list");
- opt3 = G_define_option();
- opt3->key = "removemapset";
- opt3->type = TYPE_STRING;
- opt3->required = NO;
- opt3->multiple = YES;
- opt3->description =
+ opt.remove = G_define_option();
+ opt.remove->key = "removemapset";
+ opt.remove->type = TYPE_STRING;
+ opt.remove->required = NO;
+ opt.remove->multiple = YES;
+ opt.remove->description =
_("Name(s) of existing mapset(s) to remove from search list");
+
+ opt.fs = G_define_standard_option(G_OPT_F_SEP);
+ opt.fs->answer = " ";
+
+ opt.list = G_define_flag();
+ opt.list->key = 'l';
+ opt.list->description = _("List all available mapsets");
- list = G_define_flag();
- list->key = 'l';
- list->description = _("List all available mapsets");
+ opt.print = G_define_flag();
+ opt.print->key = 'p';
+ opt.print->description = _("Print current mapset search path");
- print = G_define_flag();
- print->key = 'p';
- print->description = _("Print current mapset search path");
+ opt.dialog = G_define_flag();
+ opt.dialog->key = 's';
+ opt.dialog->description = _("Show mapset selection dialog");
- tcl = G_define_flag();
- tcl->key = 's';
- tcl->description = _("Show mapset selection dialog");
-
- Path[0] = '\0';
+ Path = NULL;
+ nmapsets = 0;
nchoices = 0;
if (G_parser(argc, argv))
exit(EXIT_FAILURE);
- if (list->answer) {
+ if (opt.list->answer) {
get_available_mapsets();
- display_available_mapsets(0);
+ display_available_mapsets(opt.fs->answer);
}
- if (tcl->answer) {
+ if (opt.dialog->answer) {
sprintf(path, "%s/etc/g.mapsets.tcl", G_gisbase());
G_spawn(path, "g.mapsets.tcl", NULL);
}
- if (opt1->answer) {
- for (ptr = opt1->answers; *ptr != NULL; ptr++) {
- char *mapset;
+ if (opt.mapset->answer) {
+ for (ptr = opt.mapset->answers; *ptr != NULL; ptr++) {
+ const char *mapset;
mapset = *ptr;
if (G__mapset_permissions(mapset) < 0)
G_fatal_error(_("Mapset <%s> not found"), mapset);
nchoices++;
- strcat(Path, mapset);
- strcat(Path, " ");
+ append_mapset(&Path, mapset);
}
}
/* add to existing search path */
- if (opt2->answer) {
- char *oldname;
+ if (opt.add->answer) {
+ const char *oldname;
- Path[0] = '\0';
+ if (Path) {
+ G_free(Path);
+ Path = NULL;
+ }
/* read existing mapsets from SEARCH_PATH */
- for (n = 0; (oldname = G__mapset_name(n)); n++) {
- strcat(Path, oldname);
- strcat(Path, " ");
- }
+ for (n = 0; (oldname = G__mapset_name(n)); n++)
+ append_mapset(&Path, oldname);
/* fetch and add new mapsets from param list */
- for (ptr = opt2->answers; *ptr != NULL; ptr++) {
+ for (ptr = opt.add->answers; *ptr != NULL; ptr++) {
char *mapset;
mapset = *ptr;
@@ -147,22 +158,24 @@
mapset);
nchoices++;
- strcat(Path, mapset);
- strcat(Path, " ");
+ append_mapset(&Path, mapset);
}
}
/* remove from existing search path */
- if (opt3->answer) {
- char *oldname;
+ if (opt.remove->answer) {
+ const char *oldname;
- Path[0] = '\0';
+ if (Path) {
+ G_free(Path);
+ Path = NULL;
+ }
/* read existing mapsets from SEARCH_PATH */
for (n = 0; (oldname = G__mapset_name(n)); n++) {
int found = 0;
- for (ptr = opt3->answers; *ptr; ptr++)
+ for (ptr = opt.remove->answers; *ptr; ptr++)
if (strcmp(oldname, *ptr) == 0)
found = 1;
@@ -173,15 +186,26 @@
}
nchoices++;
- strcat(Path, oldname);
- strcat(Path, " ");
+ append_mapset(&Path, oldname);
}
}
/* stuffem sets nchoices */
if (nchoices == 0) {
- goto DISPLAY;
+ if (opt.print->answer)
+ display_mapset_path(opt.fs->answer);
+
+ if (Path)
+ G_free(Path);
+
+ if (nmapsets) {
+ for(nmapsets--; nmapsets >= 0; nmapsets--)
+ G_free(mapset_name[nmapsets]);
+ G_free(mapset_name);
+ }
+
+ exit(EXIT_SUCCESS);
}
/* note I'm assuming that mapsets cannot have ' 's in them */
@@ -230,9 +254,26 @@
fclose(fp);
G_free_tokens(tokens);
- DISPLAY:
- if (print->answer)
- display_mapset_path(0);
+ if (Path)
+ G_free(Path);
+ if (nmapsets) {
+ for(nmapsets--; nmapsets >= 0; nmapsets--)
+ G_free(mapset_name[nmapsets]);
+ G_free(mapset_name);
+ }
+
exit(EXIT_SUCCESS);
}
+
+static void append_mapset(char **path, const char *mapset)
+{
+ int len = (*path == NULL ? 0 : strlen(*path));
+
+ *path = (char *)G_realloc(*path, len + strlen(mapset) + 2);
+ if (!len)
+ *path[0] = '\0';
+ strcat(*path, mapset);
+ strcat(*path, " ");
+ return;
+}
More information about the grass-commit
mailing list