Blame lib/debug.c

Packit Service 51e54d
/*
Packit Service 51e54d
 * debug.c: debugging messages
Packit Service 51e54d
 * Copyright (C) 2007, 2010 Colin Watson.
Packit Service 51e54d
 *
Packit Service 51e54d
 * This file is part of libpipeline.
Packit Service 51e54d
 *
Packit Service 51e54d
 * libpipeline is free software; you can redistribute it and/or modify
Packit Service 51e54d
 * it under the terms of the GNU General Public License as published by
Packit Service 51e54d
 * the Free Software Foundation; either version 2 of the License, or (at
Packit Service 51e54d
 * your option) any later version.
Packit Service 51e54d
 *
Packit Service 51e54d
 * libpipeline is distributed in the hope that it will be useful, but
Packit Service 51e54d
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 51e54d
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 51e54d
 * General Public License for more details.
Packit Service 51e54d
 *
Packit Service 51e54d
 * You should have received a copy of the GNU General Public License
Packit Service 51e54d
 * along with libpipeline; if not, write to the Free Software
Packit Service 51e54d
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301
Packit Service 51e54d
 * USA
Packit Service 51e54d
 */
Packit Service 51e54d
Packit Service 51e54d
#ifdef HAVE_CONFIG_H
Packit Service 51e54d
#  include "config.h"
Packit Service 51e54d
#endif
Packit Service 51e54d
Packit Service 51e54d
#include <stdlib.h>
Packit Service 51e54d
#include <stdio.h>
Packit Service 51e54d
#include <stdarg.h>
Packit Service 51e54d
#include <string.h>
Packit Service 51e54d
#include <errno.h>
Packit Service 51e54d
Packit Service 51e54d
#include "pipeline-private.h"
Packit Service 51e54d
Packit Service 51e54d
int debug_level = 0;
Packit Service 51e54d
Packit Service 51e54d
void init_debug (void)
Packit Service 51e54d
{
Packit Service 51e54d
	static int inited = 0;
Packit Service 51e54d
	const char *pipeline_debug;
Packit Service 51e54d
Packit Service 51e54d
	if (inited)
Packit Service 51e54d
		return;
Packit Service 51e54d
	inited = 1;
Packit Service 51e54d
Packit Service 51e54d
	pipeline_debug = getenv ("PIPELINE_DEBUG");
Packit Service 51e54d
	if (pipeline_debug && !strcmp (pipeline_debug, "1"))
Packit Service 51e54d
		debug_level = 1;
Packit Service 51e54d
}
Packit Service 51e54d
Packit Service 51e54d
static void vdebug (const char *message, va_list args)
Packit Service 51e54d
{
Packit Service 51e54d
	if (debug_level)
Packit Service 51e54d
		vfprintf (stderr, message, args);
Packit Service 51e54d
}
Packit Service 51e54d
Packit Service 51e54d
void debug (const char *message, ...)
Packit Service 51e54d
{
Packit Service 51e54d
	init_debug ();
Packit Service 51e54d
Packit Service 51e54d
	if (debug_level) {
Packit Service 51e54d
		va_list args;
Packit Service 51e54d
Packit Service 51e54d
		va_start (args, message);
Packit Service 51e54d
		vdebug (message, args);
Packit Service 51e54d
		va_end (args);
Packit Service 51e54d
	}
Packit Service 51e54d
}