File: u_printf.c

package info (click to toggle)
ncftp 2%3A3.2.7-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,124 kB
  • sloc: ansic: 41,900; sh: 3,577; perl: 874; makefile: 854; cpp: 612
file content (60 lines) | stat: -rw-r--r-- 1,262 bytes parent folder | download | duplicates (2)
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
55
56
57
58
59
60
/* u_printf.c
 *
 * Copyright (c) 1996-2005 Mike Gleason, NcFTP Software.
 * All rights reserved.
 *
 */

#include "syshdrs.h"
#ifdef PRAGMA_HDRSTOP
#	pragma hdrstop
#endif

#if (defined(WIN32) || defined(_WINDOWS)) && !defined(__CYGWIN__)
#define _CRT_SECURE_NO_WARNINGS 1
#endif

/*VARARGS*/
void
PrintF(const FTPCIPtr cip, const char *const fmt, ...)
{
	va_list ap;
	char buf[1024];
	char tbuf[40];
	size_t tbuflen = 0;
	int x;
	time_t t;
	struct tm lt, *ltp;

	tbuf[0] = '\0';
	if ((x = cip->debugTimestamping) != 0) {
		ltp = Localtime(time(&t), &lt);
		if (x == 1) {
			tbuflen = strftime(tbuf, sizeof(tbuf), "%H:%M:%S", ltp);
		} else {
			tbuflen = strftime(tbuf, sizeof(tbuf), "%Y-%m-%d %H:%M:%S", ltp);
		}
		if (cip->debugLog != NULL)
			(void) fprintf(cip->debugLog, "%s  ", tbuf);
	}

	va_start(ap, fmt);

	if (cip->debugLog != NULL) {
		(void) vfprintf(cip->debugLog, fmt, ap);
		(void) fflush(cip->debugLog);
	}

	if (cip->debugLogProc != NULL) {
		if (tbuflen != 0)
			memcpy(buf, tbuf, tbuflen + 1);
#ifdef HAVE_VSNPRINTF
		(void) vsnprintf(buf + tbuflen, sizeof(buf) - tbuflen - 1, fmt, ap);
		buf[sizeof(buf) - 1] = '\0';
#else
		(void) vsprintf(buf + tbuflen, fmt, ap);
#endif
		(*cip->debugLogProc)(cip, buf);
	}
	va_end(ap);
}	/* PrintF */