/*
* Copyright (C) 2023 Patrick McDermott
*
* This file is part of opkg-opk.
*
* opkg-opk is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* opkg-opk is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with opkg-opk. If not, see .
*/
#include
#include
#include
#include "defs.h"
#include "dirent.h"
int
main()
{
struct opkg_opk_dirent foo = {
.name = "foo",
.parent = NULL,
};
struct opkg_opk_dirent bar = {
.name = "bar",
.parent = &foo,
};
struct opkg_opk_dirent baz = {
.name = "baz",
.parent = &bar,
};
char name[9];
char pref[4];
char *full_name;
puts("1..4");
if (opkg_opk_dirent_name_prefix(&baz, 0, name, sizeof(name),
pref, sizeof(pref)) != OPKG_OPK_OK ||
strcmp(pref, "foo") != 0 ||
strcmp(name, "bar/baz") != 0) {
fputs("not ", stdout);
}
printf("ok 1 - \"%s\" + \"%s\"\n", pref, name);
if (opkg_opk_dirent_name_prefix(&baz, 1, name, sizeof(name),
pref, sizeof(pref)) != OPKG_OPK_OK ||
strcmp(pref, "foo") != 0 ||
strcmp(name, "bar/baz/") != 0) {
fputs("not ", stdout);
}
printf("ok 2 - \"%s\" + \"%s\"\n", pref, name);
full_name = opkg_opk_dirent_name_alloc(&baz, 0);
if (full_name == NULL || strcmp(full_name, "foo/bar/baz") != 0) {
fputs("not ", stdout);
}
printf("ok 3 - \"%s\"\n", full_name);
free(full_name);
full_name = opkg_opk_dirent_name_alloc(&baz, 1);
if (full_name == NULL || strcmp(full_name, "foo/bar/baz/") != 0) {
fputs("not ", stdout);
}
printf("ok 4 - \"%s\"\n", full_name);
free(full_name);
return EXIT_SUCCESS;
}