verbose.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*!
  2. * \file lib/gis/verbose.c
  3. *
  4. * \brief GIS Library - Subroutines to manage verbosity level
  5. *
  6. * Note that verbosity can be controlled by GRASS_VERBOSE environment
  7. * variable.
  8. *
  9. * See relevant subroutines:
  10. * - G_percent()
  11. * - G_important_message()
  12. * - G_message()
  13. * - G_verbose_message()
  14. * - G_warning()
  15. * - G_fatal_error()
  16. *
  17. * (C) 2001-2008, 2012-2013 by the GRASS Development Team
  18. *
  19. * This program is free software under the GNU General Public License
  20. * (>=v2). Read the file COPYING that comes with GRASS for details.
  21. *
  22. * \author Jachym Cepicky - jachym.cepicky at gmail.com
  23. */
  24. #include <stdlib.h>
  25. #include <grass/config.h>
  26. #include <grass/gis.h>
  27. /*! \brief Maximum verbosity level */
  28. #define MAXLEVEL 3
  29. /*! \brief Standard verbosity level */
  30. #define STDLEVEL 2
  31. /*! \brief Minimum verbosity level (quiet) */
  32. #define MINLEVEL 0
  33. static struct state {
  34. int initialized;
  35. int verbose; /* current verbosity level */
  36. } state;
  37. static struct state *st = &state;
  38. /*!
  39. * \brief Get current verbosity level.
  40. *
  41. * Currently, there are 5 levels of verbosity (see return codes)
  42. *
  43. * \return -1 - nothing will be printed (also errors and warnings will be also discarded)
  44. * \return 0 - nothing will be printed except of errors and warnings
  45. * (G_fatal_error(), G_warning()). Triggered by <tt>--q</tt> or <tt>--quiet</tt> flag..
  46. * \return 1 - only progress information (G_percent()) and important messages (G_important_message()) will be printed
  47. * \return 2 - all messages (G_message() and G_important_message()) will be printed
  48. * \return 3 - also verbose messages (G_verbose_message()) will be printed. Triggered by <tt>--v</tt> or <tt>--verbose</tt> flag.
  49. */
  50. int G_verbose(void)
  51. {
  52. const char *verstr; /* string for GRASS_VERBOSE content */
  53. if (G_is_initialized(&(st->initialized)))
  54. return st->verbose;
  55. /* verbose not defined -> get it from env. */
  56. verstr = getenv("GRASS_VERBOSE");
  57. st->verbose = verstr ? atoi(verstr) : STDLEVEL;
  58. G_initialize_done(&(st->initialized));
  59. return st->verbose;
  60. }
  61. /*!
  62. * \brief Get max verbosity level.
  63. *
  64. * \return max verbosity level
  65. */
  66. int G_verbose_max(void)
  67. {
  68. return MAXLEVEL;
  69. }
  70. /*!
  71. * \brief Get standard verbosity level.
  72. *
  73. * \return standard verbosity level
  74. */
  75. int G_verbose_std(void)
  76. {
  77. return STDLEVEL;
  78. }
  79. /*!
  80. * \brief Get min verbosity level.
  81. *
  82. * \return min verbosity level
  83. */
  84. int G_verbose_min(void)
  85. {
  86. return MINLEVEL;
  87. }
  88. /*!
  89. * \brief Set verbosity level.
  90. *
  91. * - -1 - nothing will be printed (also errors and warnings will be also discarded)
  92. * - 0 - nothing will be printed except of errors and warnings
  93. * (G_fatal_error(), G_warning()). Triggered by <tt>--q</tt> or <tt>--quiet</tt> flag.
  94. * - 1 - only progress information (G_percent()) and important messages (G_important_message()) will be printed
  95. * - 2 - all messages (G_message() and G_important_message()) will be printed
  96. * - 3 - also verbose messages (G_verbose_message()) will be printed. Triggered by <tt>--v</tt> or <tt>--verbose</tt> flag.
  97. *
  98. * \param level new verbosity level (-1,0,1,2,3)
  99. *
  100. * \return 0 on invalid verbosity level (verbosity level untouched)
  101. * \return 1 on success
  102. */
  103. int G_set_verbose(int level)
  104. {
  105. if (level == -1 || (level >= MINLEVEL && level <= MAXLEVEL)) {
  106. st->verbose = level;
  107. if (!G_is_initialized(&(st->initialized)))
  108. G_initialize_done(&(st->initialized));
  109. return 1;
  110. }
  111. return 0;
  112. }