13 #include <unistd.h> // unlink, close
17 #include <limits.h> // PATH_MAX
18 #endif /* HAVE_LIMITS_H */
23 #ifdef HAVE_C99_VARARGS_MACROS
24 #define PRINT_ERR(...) fprintf(stderr, "AUBIO-TESTS ERROR: " __VA_ARGS__)
25 #define PRINT_MSG(...) fprintf(stdout, __VA_ARGS__)
26 #define PRINT_DBG(...) fprintf(stderr, __VA_ARGS__)
27 #define PRINT_WRN(...) fprintf(stderr, "AUBIO-TESTS WARNING: " __VA_ARGS__)
29 #define PRINT_ERR(format, args...) fprintf(stderr, "AUBIO-TESTS ERROR: " format , ##args)
30 #define PRINT_MSG(format, args...) fprintf(stdout, format , ##args)
31 #define PRINT_DBG(format, args...) fprintf(stderr, format , ##args)
32 #define PRINT_WRN(format, args...) fprintf(stderr, "AUBIO-TESTS WARNING: " format, ##args)
36 #define M_PI (3.14159265358979323846)
40 #define RAND_MAX 32767
43 // are we on windows ? or are we using -std=c99 ?
44 #if defined(HAVE_WIN_HACKS) || defined(__STRICT_ANSI__)
45 // http://en.wikipedia.org/wiki/Linear_congruential_generator
46 // no srandom/random on win32
48 uint_t srandom_seed = 1029;
50 void srandom(uint_t new_seed) {
51 srandom_seed = new_seed;
55 srandom_seed = 1664525 * srandom_seed + 1013904223;
60 void utils_init_random (void);
62 void utils_init_random (void) {
64 struct tm *tm_struct = localtime(&now);
65 size_t **tm_address = (void*)&tm_struct;
66 int seed = tm_struct->tm_sec + (size_t)tm_address;
67 //PRINT_WRN("current seed: %d\n", seed);
71 // create_temp_sink / close_temp_sink
72 #if defined(__GNUC__) // mkstemp
74 int create_temp_sink(char *sink_path)
76 return mkstemp(sink_path);
79 int close_temp_sink(char *sink_path, int sink_fildes)
82 if ((err = close(sink_fildes)) != 0) return err;
83 if ((err = unlink(sink_path)) != 0) return err;
87 #elif (defined(HAVE_WIN_HACKS) //&& !defined(__GNUC__))
88 // windows workaround, where mkstemp does not exist...
89 int create_temp_sink(char *templ)
92 static const char letters[] = "abcdefg0123456789";
93 int letters_len = strlen(letters);
94 int templ_len = strlen(templ);
95 if (templ_len == 0) return 0;
97 for (i = 0; i < 6; i++)
99 templ[templ_len - i] = letters[rand() % letters_len];
104 int close_temp_sink(char* sink_path, int sink_fildes) {
105 // the file should be closed when not using mkstemp, no need to open it
106 if (sink_fildes == 0) return 1;
107 return _unlink(sink_path);
110 #else // windows workaround
111 // otherwise, we don't really know what to do yet
112 #error "mkstemp undefined, but not on windows. additional workaround required."
116 int run_on_default_sink( int main(int, char**) )
121 char sink_path[PATH_MAX] = "tmp_aubio_XXXXXX";
122 int fd = create_temp_sink(sink_path);
126 err = main(argc, argv);
127 close_temp_sink(sink_path, fd);