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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
#include <stdio.h>
#include <stdarg.h>
#include <string.h>
#include "nullpo.h"
// #include "logs.h" // 布石してみる
static void nullpo_info_core (const char *file, int line, const char *func,
const char *fmt, va_list ap);
/*======================================
* Nullチェック 及び 情報出力
*--------------------------------------
*/
int nullpo_chk_f (const char *file, int line, const char *func,
const void *target, const char *fmt, ...)
{
va_list ap;
if (target != NULL)
return 0;
va_start (ap, fmt);
nullpo_info_core (file, line, func, fmt, ap);
va_end (ap);
return 1;
}
int nullpo_chk (const char *file, int line, const char *func,
const void *target)
{
if (target != NULL)
return 0;
nullpo_info_core (file, line, func, NULL, NULL);
return 1;
}
/*======================================
* nullpo情報出力(外部呼出し向けラッパ)
*--------------------------------------
*/
void nullpo_info_f (const char *file, int line, const char *func,
const char *fmt, ...)
{
va_list ap;
va_start (ap, fmt);
nullpo_info_core (file, line, func, fmt, ap);
va_end (ap);
}
void nullpo_info (const char *file, int line, const char *func)
{
nullpo_info_core (file, line, func, NULL, NULL);
}
/*======================================
* nullpo情報出力(Main)
*--------------------------------------
*/
static void nullpo_info_core (const char *file, int line, const char *func,
const char *fmt, va_list ap)
{
if (file == NULL)
file = "??";
func = func == NULL ? "unknown" : func[0] == '\0' ? "unknown" : func;
printf ("--- nullpo info --------------------------------------------\n");
printf ("%s:%d: in func `%s'\n", file, line, func);
if (fmt != NULL)
{
if (fmt[0] != '\0')
{
vprintf (fmt, ap);
// 最後に改行したか確認
if (fmt[strlen (fmt) - 1] != '\n')
printf ("\n");
}
}
printf ("--- end nullpo info ----------------------------------------\n");
// ここらでnullpoログをファイルに書き出せたら
// まとめて提出できるなと思っていたり。
}
|