mirror of
git://git.savannah.gnu.org/libtool.git
synced 2024-11-27 06:09:57 +08:00
fda42eb8c6
* AUTHORS, HACKING, Makefile.am, NEWS, README.md, TODO, bootstrap, bootstrap.conf, build-aux/edit-readme-alpha, build-aux/git-hooks/commit-msg, build-aux/ltmain.in, cfg.mk, configure.ac, doc/libtool.texi, gl/build-aux/bootstrap.in, gl/build-aux/extract-trace, gl/build-aux/funclib.sh, gl/build-aux/inline-source, gl/build-aux/options-parser, libltdl/README, libltdl/configure.ac, libltdl/libltdl/lt__alloc.h, libltdl/libltdl/lt__argz_.h, libltdl/libltdl/lt__dirent.h, libltdl/libltdl/lt__glibc.h, libltdl/libltdl/lt__private.h, libltdl/libltdl/lt__strl.h, libltdl/libltdl/lt_dlloader.h, libltdl/libltdl/lt_error.h, libltdl/libltdl/lt_system.h, libltdl/libltdl/slist.h, libltdl/loaders/dld_link.c, libltdl/loaders/dlopen.c, libltdl/loaders/dyld.c, libltdl/loaders/load_add_on.c, libltdl/loaders/loadlibrary.c, libltdl/loaders/preopen.c, libltdl/loaders/shl_load.c, libltdl/lt__alloc.c, libltdl/lt__argz.c, libltdl/lt__dirent.c, libltdl/lt__strl.c, libltdl/lt_dlloader.c, libltdl/lt_error.c, libltdl/ltdl.c, libltdl/ltdl.h, libltdl/ltdl.mk, libltdl/slist.c, libtoolize.in, m4/autobuild.m4, m4/libtool.m4, m4/ltargz.m4, m4/ltdl.m4, m4/ltoptions.m4, m4/ltsugar.m4, m4/ltversion.in, m4/lt~obsolete.m4, m4/m4.m4, tests/am-subdir.at, tests/archive-in-archive.at, tests/bindir.at, tests/cdemo.at, tests/cmdline_wrap.at, tests/configure-iface.at, tests/convenience.at, tests/ctor.at, tests/cwrapper.at, tests/darwin.at, tests/demo.at, tests/depdemo.at, tests/deplib-in-subdir.at, tests/deplibs-ident.at, tests/deplibs-mingw.at, tests/destdir.at, tests/dlloader-api.at, tests/dumpbin-symbols.at, tests/duplicate_conv.at, tests/duplicate_deps.at, tests/duplicate_members.at, tests/early-libtool.at, tests/exceptions.at, tests/execute-mode.at, tests/exeext.at, tests/export-def.at, tests/export.at, tests/f77demo.at, tests/fail.at, tests/fcdemo.at, tests/flags.at, tests/help.at, tests/indirect_deps.at, tests/infer-tag.at, tests/inherited_flags.at, tests/install.at, tests/lalib-syntax.at, tests/libtool.at, tests/libtoolize.at, tests/link-order.at, tests/link-order2.at, tests/loadlibrary.at, tests/localization.at, tests/lt_dladvise.at, tests/lt_dlexit.at, tests/lt_dlopen.at, tests/lt_dlopen_a.at, tests/lt_dlopenext.at, tests/ltdl-api.at, tests/ltdl-libdir.at, tests/mdemo.at, tests/need_lib_prefix.at, tests/no-executables.at, tests/nocase.at, tests/nonrecursive.at, tests/old-ltdl-iface.at, tests/old-m4-iface.at, tests/pic_flag.at, tests/recursive.at, tests/resident.at, tests/runpath-in-lalib.at, tests/search-path.at, tests/shlibpath.at, tests/slist.at, tests/standalone.at, tests/static.at, tests/stresstest.at, tests/subproject.at, tests/sysroot.at, tests/tagdemo.at, tests/template.at, tests/testsuite.at, tests/versioning.at, tests/with-pic.at: Update copyright statement to include 2015. * cfg.mk: Adjust old_NEWS_hash accordingly. Signed-off-by: Gary V. Vaughan <gary@gnu.org>
171 lines
5.2 KiB
Plaintext
171 lines
5.2 KiB
Plaintext
# slist.at -- test slist.c -*- Autotest -*-
|
|
#
|
|
# Copyright (C) 2009, 2011-2015 Free Software Foundation, Inc.
|
|
#
|
|
# This file is part of GNU Libtool.
|
|
#
|
|
# GNU Libtool 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 2 of
|
|
# the License, or (at your option) any later version.
|
|
#
|
|
# GNU Libtool 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 GNU Libtool; see the file COPYING. If not, a copy
|
|
# can be downloaded from http://www.gnu.org/licenses/gpl.html,
|
|
# or obtained by writing to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
####
|
|
|
|
AT_SETUP([SList functionality])
|
|
|
|
AT_DATA([test-slist.c], [[
|
|
#include <config.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <assert.h>
|
|
#include <stdio.h>
|
|
#include "slist.h"
|
|
|
|
#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
|
|
|
|
void *find_string (SList *item, void *data)
|
|
{
|
|
if (data != NULL && STREQ ((const char *) item->userdata, (const char *)data))
|
|
return item;
|
|
else
|
|
return NULL;
|
|
}
|
|
|
|
void boxed_delete (void *item)
|
|
{
|
|
free (slist_unbox ((SList *) item));
|
|
}
|
|
|
|
void *print_item (SList *item, void *userdata)
|
|
{
|
|
userdata = userdata; /* unused */
|
|
printf ("%s\n", (const char*)item->userdata);
|
|
return NULL;
|
|
}
|
|
|
|
int list_compare (const SList *item1, const SList *item2, void *userdata)
|
|
{
|
|
userdata = userdata;
|
|
return strcmp ((const char *) item1->userdata, (const char *)item2->userdata);
|
|
}
|
|
|
|
int main ()
|
|
{
|
|
int i;
|
|
SList *empty_list = NULL, *list = NULL, *item, *list_save;
|
|
char *data = NULL;
|
|
|
|
/* slist_cons */
|
|
list = slist_cons (NULL, NULL);
|
|
|
|
for (i=0; i < 10; ++i) {
|
|
data = (char *) malloc (42);
|
|
assert (data);
|
|
sprintf (data, "foo%d", i);
|
|
list = slist_cons (slist_box (data), list);
|
|
}
|
|
list_save = list;
|
|
list = slist_cons (NULL, list);
|
|
assert (list == list_save);
|
|
|
|
|
|
/* slist_find */
|
|
assert (slist_find (NULL, find_string, (void *) "whatever") == NULL);
|
|
assert (slist_find (empty_list, find_string, (void *) "whatever") == NULL);
|
|
assert (slist_find (list, find_string, (void *) "foo10") == NULL);
|
|
item = (SList *) slist_find (list, find_string, (void *) "foo1");
|
|
assert (item != NULL);
|
|
assert (STREQ ((const char *) item->userdata, "foo1"));
|
|
|
|
item = slist_nth (list, 10);
|
|
assert (item != NULL && STREQ ((const char *) item->userdata, "foo0"));
|
|
|
|
puts ("list as inserted:");
|
|
slist_foreach (list, print_item, NULL);
|
|
puts ("reversed list:");
|
|
list = slist_reverse (list);
|
|
slist_foreach (list, print_item, NULL);
|
|
|
|
item = slist_nth (list, 1);
|
|
assert (item != NULL && STREQ ((const char *) item->userdata, "foo0"));
|
|
|
|
assert (10 == slist_length (list));
|
|
|
|
/* slist_tail is the second item, not the last one */
|
|
item = slist_tail (list);
|
|
assert (item != NULL && STREQ ((const char *) item->userdata, "foo1"));
|
|
|
|
assert (slist_tail (slist_nth (list, 10)) == NULL);
|
|
|
|
/* slist_sort and implicitly, slist_sort_merge */
|
|
assert (slist_sort (NULL, list_compare, NULL) == NULL);
|
|
list = slist_sort (list, list_compare, NULL);
|
|
puts ("list after no-op sort:");
|
|
slist_foreach (list, print_item, NULL);
|
|
|
|
list = slist_reverse (list);
|
|
puts ("reversed list:");
|
|
slist_foreach (list, print_item, NULL);
|
|
puts ("sorting reversed list:");
|
|
list = slist_sort (list, list_compare, NULL);
|
|
slist_foreach (list, print_item, NULL);
|
|
|
|
/* slist_remove */
|
|
assert (slist_remove (NULL, find_string, NULL) == NULL);
|
|
assert (slist_remove (&empty_list, find_string, NULL) == NULL);
|
|
|
|
list_save = list;
|
|
assert (slist_remove (&list, find_string, NULL) == NULL);
|
|
assert (list_save == list);
|
|
|
|
/* remove entries: middle, last, first, not present */
|
|
/* slist_reverse above has left us with increasing order */
|
|
list_save = list;
|
|
item = slist_remove (&list, find_string, (void *) "foo5");
|
|
assert (list_save == list);
|
|
assert (item != NULL && STREQ (data = (char *) slist_unbox (item), "foo5"));
|
|
free (data);
|
|
|
|
list_save = list;
|
|
item = slist_remove (&list, find_string, (void *) "foo9");
|
|
assert (list_save == list);
|
|
assert (item != NULL && STREQ (data = (char *) slist_unbox (item), "foo9"));
|
|
free (data);
|
|
|
|
list_save = list;
|
|
item = slist_remove (&list, find_string, (void *) "foo0");
|
|
assert (list_save != list);
|
|
assert (item != NULL && STREQ (data = (char *) slist_unbox (item), "foo0"));
|
|
free (data);
|
|
|
|
list_save = list;
|
|
item = slist_remove (&list, find_string, (void *) "foo5");
|
|
assert (list_save == list);
|
|
assert (item == NULL);
|
|
|
|
assert (slist_delete (list, boxed_delete) == NULL);
|
|
return 0;
|
|
}
|
|
]])
|
|
|
|
CPPFLAGS="-I$top_srcdir/libltdl -I$top_srcdir/libltdl/libltdl -I$abs_top_builddir"
|
|
AT_CHECK([$CC $CPPFLAGS $CFLAGS -c test-slist.c],
|
|
[], [ignore], [ignore])
|
|
AT_CHECK([$CC $CPPFLAGS $CFLAGS -c $top_srcdir/libltdl/slist.c],
|
|
[], [ignore], [ignore])
|
|
AT_CHECK([$CC $CFLAGS $LDFLAGS -o test-slist test-slist.$OBJEXT slist.$OBJEXT],
|
|
[], [ignore], [ignore])
|
|
LT_AT_EXEC_CHECK([./test-slist], [], [ignore], [ignore])
|
|
|
|
AT_CLEANUP
|