[GRASS-SVN] r34140 - grass/trunk/general/g.findfile
svn_grass at osgeo.org
svn_grass at osgeo.org
Sun Nov 2 14:31:40 EST 2008
Author: glynn
Date: 2008-11-02 14:31:39 -0500 (Sun, 02 Nov 2008)
New Revision: 34140
Modified:
grass/trunk/general/g.findfile/main.c
Log:
Add -n (no quotes) flag
Use meaningful variable names for options
Fix buffer size (GPATH_MAX)
Modified: grass/trunk/general/g.findfile/main.c
===================================================================
--- grass/trunk/general/g.findfile/main.c 2008-11-02 11:54:33 UTC (rev 34139)
+++ grass/trunk/general/g.findfile/main.c 2008-11-02 19:31:39 UTC (rev 34140)
@@ -23,12 +23,13 @@
int main(int argc, char *argv[])
{
- char file[1024], name[GNAME_MAX], *mapset;
+ char file[GPATH_MAX], name[GNAME_MAX], *mapset;
char *search_mapset;
struct GModule *module;
- struct Option *opt1;
- struct Option *opt2;
- struct Option *opt3;
+ struct Option *elem_opt;
+ struct Option *mapset_opt;
+ struct Option *file_opt;
+ struct Flag *n_flag;
module = G_define_module();
module->keywords = _("general");
@@ -40,58 +41,63 @@
/* Define the different options */
- opt1 = G_define_option();
- opt1->key = "element";
- opt1->type = TYPE_STRING;
- opt1->required = YES;
- opt1->description = _("Name of an element");
+ elem_opt = G_define_option();
+ elem_opt->key = "element";
+ elem_opt->type = TYPE_STRING;
+ elem_opt->required = YES;
+ elem_opt->description = _("Name of an element");
- opt3 = G_define_option();
- opt3->key = "file";
- opt3->type = TYPE_STRING;
- opt3->required = YES;
- opt3->description = _("Name of an existing map");
+ file_opt = G_define_option();
+ file_opt->key = "file";
+ file_opt->type = TYPE_STRING;
+ file_opt->required = YES;
+ file_opt->description = _("Name of an existing map");
- opt2 = G_define_option();
- opt2->key = "mapset";
- opt2->type = TYPE_STRING;
- opt2->required = NO;
- opt2->description = _("Name of a mapset");
- opt2->answer = "";
+ mapset_opt = G_define_option();
+ mapset_opt->key = "mapset";
+ mapset_opt->type = TYPE_STRING;
+ mapset_opt->required = NO;
+ mapset_opt->description = _("Name of a mapset");
+ mapset_opt->answer = "";
+ n_flag = G_define_flag();
+ n_flag->key = 'n';
+ n_flag->description = _("Don't add quotes");
+
if (G_parser(argc, argv))
exit(EXIT_FAILURE);
- search_mapset = opt2->answer;
+ search_mapset = mapset_opt->answer;
if (strcmp(".", search_mapset) == 0)
search_mapset = G_mapset();
- if (opt2->answer && strlen(opt2->answer) > 0) {
- char **map_mapset = G_tokenize(opt3->answer, "@");
+ if (mapset_opt->answer && strlen(mapset_opt->answer) > 0) {
+ char **map_mapset = G_tokenize(file_opt->answer, "@");
if (G_number_of_tokens(map_mapset) > 1) {
- if (strcmp(map_mapset[1], opt2->answer))
+ if (strcmp(map_mapset[1], mapset_opt->answer))
G_fatal_error(_("Parameter 'file' contains reference to <%s> mapset, "
"but mapset parameter <%s> does not correspond"),
- map_mapset[1], opt2->answer);
+ map_mapset[1], mapset_opt->answer);
else
- strcpy(name, opt3->answer);
+ strcpy(name, file_opt->answer);
}
if (G_number_of_tokens(map_mapset) == 1)
- strcpy(name, opt3->answer);
+ strcpy(name, file_opt->answer);
G_free_tokens(map_mapset);
}
else
- strcpy(name, opt3->answer);
+ strcpy(name, file_opt->answer);
- mapset = G_find_file2(opt1->answer, name, search_mapset);
+ mapset = G_find_file2(elem_opt->answer, name, search_mapset);
if (mapset) {
- fprintf(stdout, "name='%s'\n", name);
- fprintf(stdout, "mapset='%s'\n", mapset);
- fprintf(stdout, "fullname='%s'\n",
- G_fully_qualified_name(name, mapset));
- G__file_name(file, opt1->answer, name, mapset);
- fprintf(stdout, "file='%s'\n", file);
+ const char *qchar = n_flag->answer ? "" : "'";
+ const char *qual = G_fully_qualified_name(name, mapset);
+ G__file_name(file, elem_opt->answer, name, mapset);
+ fprintf(stdout, "name=%s%s%s\n", qchar, name, qchar);
+ fprintf(stdout, "mapset=%s%s%s\n", qchar, mapset, qchar);
+ fprintf(stdout, "fullname=%s%s%s\n", qchar, qual, qchar);
+ fprintf(stdout, "file=%s%s%s\n", qchar, file, qchar);
}
else {
fprintf(stdout, "name=\n");
More information about the grass-commit
mailing list