Blame lib/debug.c

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