f0ab104f070bc7f569404826fea1828ed985638cvboxsync/*
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * Copyright 2001 Red Hat Inc., Durham, North Carolina.
f0ab104f070bc7f569404826fea1828ed985638cvboxsync *
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * All Rights Reserved.
f0ab104f070bc7f569404826fea1828ed985638cvboxsync *
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * Permission is hereby granted, free of charge, to any person obtaining
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * a copy of this software and associated documentation files (the
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * "Software"), to deal in the Software without restriction, including
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * without limitation on the rights to use, copy, modify, merge,
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * publish, distribute, sublicense, and/or sell copies of the Software,
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * and to permit persons to whom the Software is furnished to do so,
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * subject to the following conditions:
f0ab104f070bc7f569404826fea1828ed985638cvboxsync *
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * The above copyright notice and this permission notice (including the
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * next paragraph) shall be included in all copies or substantial
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * portions of the Software.
f0ab104f070bc7f569404826fea1828ed985638cvboxsync *
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * NON-INFRINGEMENT. IN NO EVENT SHALL RED HAT AND/OR THEIR SUPPLIERS
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * SOFTWARE.
f0ab104f070bc7f569404826fea1828ed985638cvboxsync */
f0ab104f070bc7f569404826fea1828ed985638cvboxsync
f0ab104f070bc7f569404826fea1828ed985638cvboxsync/*
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * Authors:
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * Rickard E. (Rik) Faith <faith@redhat.com>
f0ab104f070bc7f569404826fea1828ed985638cvboxsync *
f0ab104f070bc7f569404826fea1828ed985638cvboxsync */
f0ab104f070bc7f569404826fea1828ed985638cvboxsync
f0ab104f070bc7f569404826fea1828ed985638cvboxsync/** \file
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * This header is included by all files that need to use the DMX logging
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * facilities. */
f0ab104f070bc7f569404826fea1828ed985638cvboxsync
f0ab104f070bc7f569404826fea1828ed985638cvboxsync#ifndef _DMXLOG_H_
f0ab104f070bc7f569404826fea1828ed985638cvboxsync#define _DMXLOG_H_
f0ab104f070bc7f569404826fea1828ed985638cvboxsync
f0ab104f070bc7f569404826fea1828ed985638cvboxsync/** Logging levels -- output is tunable with #dmxSetLogLevel. */
f0ab104f070bc7f569404826fea1828ed985638cvboxsynctypedef enum {
f0ab104f070bc7f569404826fea1828ed985638cvboxsync dmxDebug, /**< Usually verbose debugging info */
f0ab104f070bc7f569404826fea1828ed985638cvboxsync dmxInfo, /**< Non-warning information */
f0ab104f070bc7f569404826fea1828ed985638cvboxsync dmxWarning, /**< A warning that may indicate DMX
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * will not function as the user
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * intends. */
f0ab104f070bc7f569404826fea1828ed985638cvboxsync dmxError, /**< A non-fatal error that probably
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * indicates DMX will not function as
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * desired.*/
f0ab104f070bc7f569404826fea1828ed985638cvboxsync dmxFatal /**< A fatal error that will cause DMX
f0ab104f070bc7f569404826fea1828ed985638cvboxsync * to shut down. */
f0ab104f070bc7f569404826fea1828ed985638cvboxsync} dmxLogLevel;
f0ab104f070bc7f569404826fea1828ed985638cvboxsync
f0ab104f070bc7f569404826fea1828ed985638cvboxsync/* Logging functions used by Xserver/hw/dmx routines. */
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern dmxLogLevel dmxSetLogLevel(dmxLogLevel newLevel);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern dmxLogLevel dmxGetLogLevel(void);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLog(dmxLogLevel logLevel, const char *format, ...);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogCont(dmxLogLevel logLevel, const char *format, ...);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern const char *dmxEventName(int type);
f0ab104f070bc7f569404826fea1828ed985638cvboxsync
f0ab104f070bc7f569404826fea1828ed985638cvboxsync#ifndef DMX_LOG_STANDALONE
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogOutput(DMXScreenInfo *dmxScreen, const char *format, ...);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogOutputCont(DMXScreenInfo *dmxScreen, const char *format,
f0ab104f070bc7f569404826fea1828ed985638cvboxsync ...);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogOutputWarning(DMXScreenInfo *dmxScreen, const char *format,
f0ab104f070bc7f569404826fea1828ed985638cvboxsync ...);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogInput(DMXInputInfo *dmxInput, const char *format, ...);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogInputCont(DMXInputInfo *dmxInput, const char *format, ...);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogArgs(dmxLogLevel logLevel, int argc, char **argv);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern void dmxLogVisual(DMXScreenInfo *dmxScreen, XVisualInfo *vi,
f0ab104f070bc7f569404826fea1828ed985638cvboxsync int defaultVisual);
f0ab104f070bc7f569404826fea1828ed985638cvboxsyncextern const char *dmxXInputEventName(int type);
f0ab104f070bc7f569404826fea1828ed985638cvboxsync#endif
f0ab104f070bc7f569404826fea1828ed985638cvboxsync
f0ab104f070bc7f569404826fea1828ed985638cvboxsync#endif