28 #include <stdlib.h> |
28 #include <stdlib.h> |
29 #include <string.h> |
29 #include <string.h> |
30 #include <stdarg.h> |
30 #include <stdarg.h> |
31 |
31 |
32 #include "iec_std_lib_generated.h" |
32 #include "iec_std_lib_generated.h" |
33 |
|
34 #define __print_BOOL(name) printf(" %s = (BOOL) %s\n",#name, name?"TRUE":"FALSE"); |
|
35 #define __print_SINT(name) printf(" %s = (SINT) %d\n",#name, name); |
|
36 #define __print_INT(name) printf(" %s = (INT) %d\n",#name, name); |
|
37 #define __print_DINT(name) printf(" %s = (DINT) %d\n",#name, name); |
|
38 #define __print_LINT(name) printf(" %s = (LINT) %d\n",#name, name); |
|
39 #define __print_USINT(name) printf(" %s = (USINT) %u\n",#name, name); |
|
40 #define __print_UINT(name) printf(" %s = (UINT) %u\n",#name, name); |
|
41 #define __print_UDINT(name) printf(" %s = (UDINT) %u\n",#name, name); |
|
42 #define __print_ULINT(name) printf(" %s = (ULINT) %lu\n",#name, name); |
|
43 #define __print_REAL(name) printf(" %s = (REAL) %f\n",#name, (double)name); |
|
44 #define __print_LREAL(name) printf(" %s = (LREAL) %f\n",#name, (double)name); |
|
45 #define __print_TIME(name) {STRING __tmp = __time_to_string(name);__tmp.body[__tmp.len] = 0; printf(" %s = (TIME) %*s\n",#name, __tmp.len, &__tmp.body);} |
|
46 #define __print_DATE(name) {STRING __tmp = __date_to_string(name);__tmp.body[__tmp.len] = 0; printf(" %s = (DATE) %*s\n",#name, __tmp.len, &__tmp.body);} |
|
47 #define __print_TOD(name) {STRING __tmp = __tod_to_string(name);__tmp.body[__tmp.len] = 0; printf(" %s = (TOD) %*s\n",#name, __tmp.len, &__tmp.body);} |
|
48 #define __print_DT(name) {STRING __tmp = __dt_to_string(name);__tmp.body[__tmp.len] = 0; printf(" %s = (DT) %*s\n",#name, __tmp.len, &__tmp.body);} |
|
49 #define __print_STRING(name) printf(" %s = (STRING) {%d, \"%*s\"}\n",#name, name.len, name.len, &name.body); |
|
50 #define __print_BYTE(name) printf(" %s = (BYTE) 0x%2.2x\n",#name, name); |
|
51 #define __print_WORD(name) printf(" %s = (WORD) 0x%4.4x\n",#name, name); |
|
52 #define __print_DWORD(name) printf(" %s = (DWORD) 0x%8.8x\n",#name, name); |
|
53 #define __print_LWORD(name) printf(" %s = (LWORD) 0x%16.16lx\n",#name, name); |
|
54 |
33 |
55 #ifdef DEBUG_IEC |
34 #ifdef DEBUG_IEC |
56 #define DBG(...) printf(__VA_ARGS__); |
35 #define DBG(...) printf(__VA_ARGS__); |
57 #define DBG_TYPE(TYPENAME, name) __print_##TYPENAME(name); |
36 #define DBG_TYPE(TYPENAME, name) __print_##TYPENAME(name); |
58 #else |
37 #else |