File: messages.c

package info (click to toggle)
proxytunnel 1.9.0%2Bsvn250-6
  • links: PTS
  • area: main
  • in suites: buster, stretch
  • size: 452 kB
  • ctags: 368
  • sloc: ansic: 2,082; makefile: 79; pascal: 18
file content (54 lines) | stat: -rw-r--r-- 1,515 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/* Proxytunnel - (C) 2001-2008 Jos Visser / Mark Janssen    */
/* Contact:                  josv@osp.nl / maniac@maniac.nl */

/*
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 */

#include <stdio.h>
#include <stdarg.h>
#include <string.h>
#include <errno.h>
#include <syslog.h>
#include "proxytunnel.h"

/*
 * Give a message to the user
 */
void message( char *s, ... ) {
	va_list ap;
	char buf[1024];

	va_start( ap, s );
	vsnprintf( (char *)buf, sizeof( buf ), s, ap );
	va_end( ap );

	if ( i_am_daemon )
		syslog( LOG_NOTICE, "%s", buf );
	else
		fputs( buf, stderr );
}

/* My own perror function (uses the internal message) */
void my_perror( char *msg ) {
	if (errno == 0) {
		message( "error: %s.\n", msg );
	} else {
		char *errstr = strerror( errno );
		message( "error: %s: [%d] %s\n", msg, errno, errstr );
	}
}

// vim:noexpandtab:ts=4