[GRASS-SVN] r42152 -
grass/branches/releasebranch_6_4/general/g.message
svn_grass at osgeo.org
svn_grass at osgeo.org
Sat May 8 07:38:39 EDT 2010
Author: martinl
Date: 2010-05-08 07:38:39 -0400 (Sat, 08 May 2010)
New Revision: 42152
Modified:
grass/branches/releasebranch_6_4/general/g.message/main.c
Log:
g.message: flag for progress info message
(merge r42147 from trunk)
Modified: grass/branches/releasebranch_6_4/general/g.message/main.c
===================================================================
--- grass/branches/releasebranch_6_4/general/g.message/main.c 2010-05-08 11:38:06 UTC (rev 42151)
+++ grass/branches/releasebranch_6_4/general/g.message/main.c 2010-05-08 11:38:39 UTC (rev 42152)
@@ -4,10 +4,11 @@
* MODULE: g.message
* AUTHOR(S): Jachym Cepicky - jachym AT les-ejk cz
* Hamish Bowman - hamish_nospam AT yahoo com
+ * Martin Landa - landa.martin AT gmail.com
* PURPOSE: Provides a means of reporting the contents of GRASS
* projection information files and creating
* new projection information files.
- * COPYRIGHT: (C) 2007 by the GRASS Development Team
+ * COPYRIGHT: (C) 2007,2010 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
@@ -21,7 +22,7 @@
int main(int argc, char *argv[])
{
- struct Flag *warning, *fatal, *debug_flag, *verbose, *important;
+ struct Flag *warning, *fatal, *percent, *debug_flag, *verbose, *important;
struct Option *message, *debug_opt;
struct GModule *module;
int debug_level;
@@ -30,83 +31,95 @@
module = G_define_module();
module->keywords = _("general");
+ G_add_keyword(_("scripts"));
module->label =
- _("Prints a message, warning, or fatal error the GRASS way.");
+ _("Prints a message, warning, progress info, or fatal error in the GRASS way.");
module->description =
_("This module should be used in scripts for messages served to user.");
warning = G_define_flag();
warning->key = 'w';
- warning->guisection = "Input";
- warning->description = _("Print message as GRASS warning");
+ warning->guisection = _("Type");
+ warning->description = _("Print message as warning");
fatal = G_define_flag();
fatal->key = 'e';
- fatal->guisection = "Input";
- fatal->description = _("Print message as GRASS fatal error");
+ fatal->guisection = _("Type");
+ fatal->description = _("Print message as fatal error");
debug_flag = G_define_flag();
debug_flag->key = 'd';
- debug_flag->guisection = "Input";
- debug_flag->description = _("Print message as GRASS debug message");
+ debug_flag->guisection = _("Type");
+ debug_flag->description = _("Print message as debug message");
+ percent = G_define_flag();
+ percent->key = 'p';
+ percent->guisection = _("Type");
+ percent->description = _("Print message as progress info");
+
important = G_define_flag();
important->key = 'i';
- important->guisection = "Input";
- important->description = _("Print message in all but full quiet mode");
+ important->guisection = _("Level");
+ important->description = _("Don't print message in quiet mode");
verbose = G_define_flag();
verbose->key = 'v';
- verbose->guisection = "Input";
- verbose->description = _("Print message only if in verbose mode");
+ verbose->guisection = _("Level");
+ verbose->description = _("Print message only in verbose mode");
message = G_define_option();
message->key = "message";
message->type = TYPE_STRING;
message->key_desc = "string";
message->required = YES;
- message->guisection = "Input";
message->description = _("Text of the message to be printed");
debug_opt = G_define_option();
debug_opt->key = "debug";
debug_opt->type = TYPE_INTEGER;
debug_opt->required = NO;
- debug_opt->guisection = "Input";
+ debug_opt->guisection = _("Level");
debug_opt->answer = "1";
debug_opt->options = "0-5";
debug_opt->description = _("Level to use for debug messages");
-
if (G_parser(argc, argv))
exit(EXIT_FAILURE);
if (fatal->answer + warning->answer + debug_flag->answer +
verbose->answer > 1)
- G_fatal_error(_("Select only one message level."));
+ G_fatal_error(_("Select only one message level"));
debug_level = atoi(debug_opt->answer);
-
-
- if (fatal->answer)
+
+ if (fatal->answer) {
G_fatal_error(message->answer);
-
- else if (warning->answer)
+ }
+ else if (warning->answer) {
G_warning(message->answer);
-
- else if (debug_flag->answer)
+ }
+ else if (percent->answer) {
+ int i, n, s;
+ i = n = s = -1;
+ sscanf(message->answer, "%d %d %d", &i, &n, &s);
+ if (s == -1)
+ G_fatal_error(_("Unable to parse input message"));
+ G_percent(i, n, s);
+ fprintf(stderr, "\n");
+ }
+ else if (debug_flag->answer) {
G_debug(debug_level, message->answer);
-
- else if (verbose->answer)
+ }
+ else if (verbose->answer) {
G_verbose_message(message->answer);
-
- else if (important->answer)
+ }
+ else if (important->answer) {
G_important_message(message->answer);
-
- else
+ }
+ else {
G_message(message->answer);
+ }
-
exit(EXIT_SUCCESS);
}
More information about the grass-commit
mailing list