From f53b702fecb08d1b8ee090bc48c12faeb5d4b49c Mon Sep 17 00:00:00 2001 From: ticktock35 Date: Mon, 15 Dec 2008 00:15:01 -0500 Subject: opkg: implement opkg_find_package() git-svn-id: http://opkg.googlecode.com/svn/trunk@99 e8e0d7a0-c8d9-11dd-a880-a1081c7ac358 --- (limited to 'tests') diff --git a/tests/libopkg_test.c b/tests/libopkg_test.c index 8c64b5e..6288bd4 100644 --- a/tests/libopkg_test.c +++ b/tests/libopkg_test.c @@ -2,6 +2,8 @@ #include #include +opkg_package_t *find_pkg = NULL; + void progress_callback (opkg_t *opkg, const opkg_progress_data_t *progress, void *data) { @@ -23,7 +25,13 @@ package_list_callback (opkg_t *opkg, opkg_package_t *pkg, void *data) printf ("\rPackage count: %d Installed, %d Total Available", install_count, total_count); fflush (stdout); - opkg_package_free (pkg); + if (!find_pkg) + { + /* store the first package to print out later */ + find_pkg = pkg; + } + else + opkg_package_free (pkg); } void @@ -32,10 +40,36 @@ package_list_upgradable_callback (opkg_t *opkg, opkg_package_t *pkg, void *data) printf ("%s - %s\n", pkg->name, pkg->version); } +void +print_package (opkg_package_t *pkg) +{ + printf ( + "Name: %s\n" + "Version: %s\n" + "Repository: %s\n" + "Architecture: %s\n" + "Description: %s\n" + "Tags: %s\n" + "URL: %s\n" + "Size: %d\n" + "Installed: %s\n", + pkg->name, + pkg->version, + pkg->repository, + pkg->architecture, + pkg->description, + pkg->tags, + pkg->url, + pkg->size, + (pkg->installed ? "True" : "False") + ); +} + int main (int argc, char **argv) { opkg_t *opkg; + opkg_package_t *pkg; int err; opkg = opkg_new (); @@ -47,6 +81,25 @@ main (int argc, char **argv) err = opkg_update_package_lists (opkg, progress_callback, "Updating..."); printf ("\nopkg_update_package_lists returned %d\n", err); + opkg_list_packages (opkg, package_list_callback, NULL); + printf ("\n"); + + if (find_pkg) + { + printf ("Finding package \"%s\"\n", find_pkg->name); + pkg = opkg_find_package (opkg, find_pkg->name, find_pkg->version, find_pkg->architecture, find_pkg->repository); + if (pkg) + { + print_package (pkg); + opkg_package_free (find_pkg); + opkg_package_free (pkg); + } + else + printf ("Package \"%s\" not found!\n", find_pkg->name); + } + else + printf ("No package available to test find_package.\n"); + err = opkg_install_package (opkg, "aspell", progress_callback, "Installing..."); printf ("\nopkg_install_package returned %d\n", err); @@ -62,8 +115,7 @@ main (int argc, char **argv) err = opkg_upgrade_all (opkg, progress_callback, "Upgrading all..."); printf ("\nopkg_upgrade_all returned %d\n", err); - opkg_list_packages (opkg, package_list_callback, NULL); - printf ("\n"); - opkg_free (opkg); + + return 0; } -- cgit v0.9.1