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
|
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include <string.h>
#define ES_PRINT (...) (espik_debug_print (__FILE__, __LINE__, __FUNCTION__, ))
inline void espik_debug_print (char *fmt, ...)
{
va_list ap;
/* char c, *s;
int d, e;
*/
char* output;
output = malloc(sizeof(char)*
( strlen(__FUNCTION__)
+ strlen(fmt) ) );
snprintf (output, "%s: %s", __FUNCTION__, fmt);
va_start (ap, output);
vfprintf (stderr, output, ap);
fprintf (stderr, "\n");
// printf("fct : %s\n", *(fct+1));
/* while (*fct)
{
// fprintf (stderr, ">fct : %c\n", *(fct+1));
switch (*fct++)
{
case 's': s = va_arg (ap, char*);
fprintf (stderr, "%s", s);
break;
case 'd': d = va_arg (ap, int);
fprintf (stderr, "%d", d);
break;
default :
// case 'c':
e = va_arg (ap, int);
fprintf (stderr, "%c", (char)e);
break;
// default : fprintf (stderr, "Unknown type : %c\n", *fct);
}
// fprintf (stderr, "<fct : %c\n", *fct);
}
fprintf (stderr, "\n");
*/
va_end (ap);
}
int main()
{
int a = 10;
/* char b = 'c';
char c[] = "totomadit";
*/
espik_debug_print ("a : %d\n", a);
return (0);
}
|