level_list.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /*
  2. * This file is part of the zlog Library.
  3. *
  4. * Copyright (C) 2011 by Hardy Simpson <HardySimpson1984@gmail.com>
  5. *
  6. * Licensed under the LGPL v2.1, see the file COPYING in base directory.
  7. */
  8. #include <stdio.h>
  9. #include <ctype.h>
  10. #include <errno.h>
  11. #include "syslog.h"
  12. #include "zc_defs.h"
  13. #include "level.h"
  14. #include "level_list.h"
  15. /* zlog_level_list == zc_arraylist_t<zlog_level_t> */
  16. void zlog_level_list_profile(zc_arraylist_t *levels, int flag)
  17. {
  18. int i;
  19. zlog_level_t *a_level;
  20. zc_assert(levels,);
  21. zc_profile(flag, "--level_list[%p]--", levels);
  22. zc_arraylist_foreach(levels, i, a_level) {
  23. /* skip empty slots */
  24. if (a_level) zlog_level_profile(a_level, flag);
  25. }
  26. return;
  27. }
  28. /*******************************************************************************/
  29. void zlog_level_list_del(zc_arraylist_t *levels)
  30. {
  31. zc_assert(levels,);
  32. zc_arraylist_del(levels);
  33. zc_debug("zc_level_list_del[%p]", levels);
  34. return;
  35. }
  36. static int zlog_level_list_set_default(zc_arraylist_t *levels)
  37. {
  38. return zlog_level_list_set(levels, "* = 0, LOG_INFO")
  39. || zlog_level_list_set(levels, "DEBUG = 20, LOG_DEBUG")
  40. || zlog_level_list_set(levels, "INFO = 40, LOG_INFO")
  41. || zlog_level_list_set(levels, "NOTICE = 60, LOG_NOTICE")
  42. || zlog_level_list_set(levels, "WARN = 80, LOG_WARNING")
  43. || zlog_level_list_set(levels, "ERROR = 100, LOG_ERR")
  44. || zlog_level_list_set(levels, "FATAL = 120, LOG_ALERT")
  45. || zlog_level_list_set(levels, "UNKNOWN = 254, LOG_ERR")
  46. || zlog_level_list_set(levels, "! = 255, LOG_INFO");
  47. }
  48. zc_arraylist_t *zlog_level_list_new(void)
  49. {
  50. zc_arraylist_t *levels;
  51. levels = zc_arraylist_new((zc_arraylist_del_fn)zlog_level_del);
  52. if (!levels) {
  53. zc_error("zc_arraylist_new fail");
  54. return NULL;
  55. }
  56. if (zlog_level_list_set_default(levels)) {
  57. zc_error("zlog_level_set_default fail");
  58. goto err;
  59. }
  60. //zlog_level_list_profile(levels, ZC_DEBUG);
  61. return levels;
  62. err:
  63. zc_arraylist_del(levels);
  64. return NULL;
  65. }
  66. /*******************************************************************************/
  67. int zlog_level_list_set(zc_arraylist_t *levels, char *line)
  68. {
  69. zlog_level_t *a_level;
  70. a_level = zlog_level_new(line);
  71. if (!a_level) {
  72. zc_error("zlog_level_new fail");
  73. return -1;
  74. }
  75. if (zc_arraylist_set(levels, a_level->int_level, a_level)) {
  76. zc_error("zc_arraylist_set fail");
  77. goto err;
  78. }
  79. return 0;
  80. err:
  81. zc_error("line[%s]", line);
  82. zlog_level_del(a_level);
  83. return -1;
  84. }
  85. zlog_level_t *zlog_level_list_get(zc_arraylist_t *levels, int l)
  86. {
  87. zlog_level_t *a_level;
  88. #if 0
  89. if ((l <= 0) || (l > 254)) {
  90. /* illegal input from zlog() */
  91. zc_error("l[%d] not in (0,254), set to UNKOWN", l);
  92. l = 254;
  93. }
  94. #endif
  95. a_level = zc_arraylist_get(levels, l);
  96. if (a_level) {
  97. return a_level;
  98. } else {
  99. /* empty slot */
  100. zc_error("l[%d] not in (0,254), or has no level defined,"
  101. "see configure file define, set to UNKOWN", l);
  102. return zc_arraylist_get(levels, 254);
  103. }
  104. }
  105. /*******************************************************************************/
  106. int zlog_level_list_atoi(zc_arraylist_t *levels, char *str)
  107. {
  108. int i;
  109. zlog_level_t *a_level;
  110. if (str == NULL || *str == '\0') {
  111. zc_error("str is [%s], can't find level", str);
  112. return -1;
  113. }
  114. zc_arraylist_foreach(levels, i, a_level) {
  115. if (a_level && STRICMP(str, ==, a_level->str_uppercase)) {
  116. return i;
  117. }
  118. }
  119. zc_error("str[%s] can't found in level list", str);
  120. return -1;
  121. }