dmxlog.h 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. * Copyright 2001 Red Hat Inc., Durham, North Carolina.
  3. *
  4. * All Rights Reserved.
  5. *
  6. * Permission is hereby granted, free of charge, to any person obtaining
  7. * a copy of this software and associated documentation files (the
  8. * "Software"), to deal in the Software without restriction, including
  9. * without limitation on the rights to use, copy, modify, merge,
  10. * publish, distribute, sublicense, and/or sell copies of the Software,
  11. * and to permit persons to whom the Software is furnished to do so,
  12. * subject to the following conditions:
  13. *
  14. * The above copyright notice and this permission notice (including the
  15. * next paragraph) shall be included in all copies or substantial
  16. * portions of the Software.
  17. *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  19. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  20. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  21. * NON-INFRINGEMENT. IN NO EVENT SHALL RED HAT AND/OR THEIR SUPPLIERS
  22. * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  23. * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  24. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  25. * SOFTWARE.
  26. */
  27. /*
  28. * Authors:
  29. * Rickard E. (Rik) Faith <faith@redhat.com>
  30. *
  31. */
  32. /** \file
  33. * This header is included by all files that need to use the DMX logging
  34. * facilities. */
  35. #ifndef _DMXLOG_H_
  36. #define _DMXLOG_H_
  37. /** Logging levels -- output is tunable with #dmxSetLogLevel. */
  38. typedef enum {
  39. dmxDebug, /**< Usually verbose debugging info */
  40. dmxInfo, /**< Non-warning information */
  41. dmxWarning, /**< A warning that may indicate DMX
  42. * will not function as the user
  43. * intends. */
  44. dmxError, /**< A non-fatal error that probably
  45. * indicates DMX will not function as
  46. * desired.*/
  47. dmxFatal /**< A fatal error that will cause DMX
  48. * to shut down. */
  49. } dmxLogLevel;
  50. /* Logging functions used by Xserver/hw/dmx routines. */
  51. extern dmxLogLevel dmxSetLogLevel(dmxLogLevel newLevel);
  52. extern dmxLogLevel dmxGetLogLevel(void);
  53. extern void dmxLog(dmxLogLevel logLevel, const char *format,
  54. ...) _X_ATTRIBUTE_PRINTF(2, 3);
  55. extern void dmxLogCont(dmxLogLevel logLevel, const char *format,
  56. ...) _X_ATTRIBUTE_PRINTF(2, 3);
  57. extern const char *dmxEventName(int type);
  58. #ifndef DMX_LOG_STANDALONE
  59. extern void dmxLogOutput(DMXScreenInfo * dmxScreen, const char *format,
  60. ...) _X_ATTRIBUTE_PRINTF(2, 3);
  61. extern void dmxLogOutputCont(DMXScreenInfo * dmxScreen, const char *format,
  62. ...) _X_ATTRIBUTE_PRINTF(2, 3);
  63. extern void dmxLogOutputWarning(DMXScreenInfo * dmxScreen, const char *format,
  64. ...) _X_ATTRIBUTE_PRINTF(2, 3);
  65. extern void dmxLogInput(DMXInputInfo * dmxInput, const char *format,
  66. ...) _X_ATTRIBUTE_PRINTF(2, 3);
  67. extern void dmxLogInputCont(DMXInputInfo * dmxInput, const char *format,
  68. ...) _X_ATTRIBUTE_PRINTF(2, 3);
  69. extern void dmxLogArgs(dmxLogLevel logLevel, int argc, char **argv);
  70. extern void dmxLogVisual(DMXScreenInfo * dmxScreen, XVisualInfo * vi,
  71. int defaultVisual);
  72. extern const char *dmxXInputEventName(int type);
  73. #endif
  74. #endif