msg-printf.c 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2009 Openmoko Inc.
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation, either version 3 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. #include <stdio.h>
  18. #include <stdarg.h>
  19. #include "msg.h"
  20. static int loglevel = MSG_LEVEL_MAX;
  21. void msg(int level, const char *format, ...)
  22. {
  23. va_list ap;
  24. FILE *stream = stdout;
  25. int clear_color = 0;
  26. if (level > loglevel)
  27. return;
  28. if (level == MSG_DEBUG) {
  29. fprintf(stream, "\033[33m"); /* yellow */
  30. clear_color = 1;
  31. }
  32. if (level == MSG_ERROR) {
  33. stream = stderr;
  34. fprintf(stream, "\033[31m"); /* red */
  35. clear_color = 1;
  36. }
  37. va_start(ap, format);
  38. vfprintf(stream, format, ap);
  39. va_end(ap);
  40. if (clear_color)
  41. fprintf(stream, "\033[0;m");
  42. }
  43. void set_loglevel(int level)
  44. {
  45. loglevel = level;
  46. }