X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=tests%2Flib%2Fcommon.c;h=8c2829a365eb7f6e90f4a63c8fa583cdd7936f4c;hb=dc3fffef7b84cc4af1a7c99828fd57a106cd2257;hp=60e2be04244a34b821d5e93bb14a57d85530e42d;hpb=3842465694945829d76452ff83924aa0103c6293;p=babeltrace.git diff --git a/tests/lib/common.c b/tests/lib/common.c index 60e2be04..8c2829a3 100644 --- a/tests/lib/common.c +++ b/tests/lib/common.c @@ -19,23 +19,38 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ -#include -#include +#include +#include +#include -struct bt_context *create_context_with_path(const char *path) +void recursive_rmdir(const char *path) { - struct bt_context *ctx; - int ret; + struct dirent *entry; + DIR *dir = opendir(path); - ctx = bt_context_create(); - if (!ctx) { - return NULL; + if (!dir) { + perror("# opendir"); + return; } - ret = bt_context_add_trace(ctx, path, "ctf", NULL, NULL, NULL); - if (ret < 0) { - bt_context_put(ctx); - return NULL; + while ((entry = readdir(dir))) { + struct stat st; + char filename[PATH_MAX]; + + if (snprintf(filename, sizeof(filename), "%s/%s", + path, entry->d_name) <= 0) { + continue; + } + + if (stat(filename, &st)) { + continue; + } + + if (S_ISREG(st.st_mode)) { + unlinkat(bt_dirfd(dir), entry->d_name, 0); + } } - return ctx; + + rmdir(path); + closedir(dir); }