refactor common code in query_search/sync_search
Signed-off-by: Simon Gomizelj <simongmzlj@gmail.com> Signed-off-by: Allan McRae <allan@archlinux.org>
This commit is contained in:
parent
8b03b1a877
commit
098cfe516d
4 changed files with 95 additions and 127 deletions
|
@ -341,4 +341,92 @@ void dump_pkg_changelog(alpm_pkg_t *pkg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_installed(alpm_db_t *db_local, alpm_pkg_t *pkg)
|
||||||
|
{
|
||||||
|
const char *pkgname = alpm_pkg_get_name(pkg);
|
||||||
|
const char *pkgver = alpm_pkg_get_version(pkg);
|
||||||
|
alpm_pkg_t *lpkg = alpm_db_get_pkg(db_local, pkgname);
|
||||||
|
if(lpkg) {
|
||||||
|
const char *lpkgver = alpm_pkg_get_version(lpkg);
|
||||||
|
if(strcmp(lpkgver, pkgver) == 0) {
|
||||||
|
printf(" [%s]", _("installed"));
|
||||||
|
} else {
|
||||||
|
printf(" [%s: %s]", _("installed"), lpkgver);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display the defails of a search.
|
||||||
|
* @param db the database we're searching
|
||||||
|
* @param targets the targets we're searching for
|
||||||
|
* @param show_status show if the package is also in the local db
|
||||||
|
*/
|
||||||
|
int dump_pkg_search(alpm_db_t *db, alpm_list_t *targets, int show_status)
|
||||||
|
{
|
||||||
|
int freelist = 0;
|
||||||
|
alpm_db_t *db_local;
|
||||||
|
alpm_list_t *i, *searchlist;
|
||||||
|
unsigned short cols;
|
||||||
|
|
||||||
|
if(show_status) {
|
||||||
|
db_local = alpm_get_localdb(config->handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* if we have a targets list, search for packages matching it */
|
||||||
|
if(targets) {
|
||||||
|
searchlist = alpm_db_search(db, targets);
|
||||||
|
freelist = 1;
|
||||||
|
} else {
|
||||||
|
searchlist = alpm_db_get_pkgcache(db);
|
||||||
|
freelist = 0;
|
||||||
|
}
|
||||||
|
if(searchlist == NULL) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
cols = getcols(fileno(stdout));
|
||||||
|
for(i = searchlist; i; i = alpm_list_next(i)) {
|
||||||
|
alpm_list_t *grp;
|
||||||
|
alpm_pkg_t *pkg = i->data;
|
||||||
|
|
||||||
|
if(config->quiet) {
|
||||||
|
fputs(alpm_pkg_get_name(pkg), stdout);
|
||||||
|
} else {
|
||||||
|
printf("%s/%s %s", alpm_db_get_name(db),
|
||||||
|
alpm_pkg_get_name(pkg), alpm_pkg_get_version(pkg));
|
||||||
|
|
||||||
|
if((grp = alpm_pkg_get_groups(pkg)) != NULL) {
|
||||||
|
alpm_list_t *k;
|
||||||
|
fputs(" (", stdout);
|
||||||
|
for(k = grp; k; k = alpm_list_next(k)) {
|
||||||
|
const char *group = k->data;
|
||||||
|
fputs(group, stdout);
|
||||||
|
if(alpm_list_next(k)) {
|
||||||
|
/* only print a spacer if there are more groups */
|
||||||
|
putchar(' ');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
putchar(')');
|
||||||
|
}
|
||||||
|
|
||||||
|
if(show_status) {
|
||||||
|
print_installed(db_local, pkg);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* we need a newline and initial indent first */
|
||||||
|
fputs("\n ", stdout);
|
||||||
|
indentprint(alpm_pkg_get_desc(pkg), 4, cols);
|
||||||
|
}
|
||||||
|
fputc('\n', stdout);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* we only want to free if the list was a search list */
|
||||||
|
if(freelist) {
|
||||||
|
alpm_list_free(searchlist);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/* vim: set ts=2 sw=2 noet: */
|
/* vim: set ts=2 sw=2 noet: */
|
||||||
|
|
|
@ -28,6 +28,9 @@ void dump_pkg_backups(alpm_pkg_t *pkg);
|
||||||
void dump_pkg_files(alpm_pkg_t *pkg, int quiet);
|
void dump_pkg_files(alpm_pkg_t *pkg, int quiet);
|
||||||
void dump_pkg_changelog(alpm_pkg_t *pkg);
|
void dump_pkg_changelog(alpm_pkg_t *pkg);
|
||||||
|
|
||||||
|
void print_installed(alpm_db_t *db_local, alpm_pkg_t *pkg);
|
||||||
|
int dump_pkg_search(alpm_db_t *db, alpm_list_t *targets, int show_status);
|
||||||
|
|
||||||
#endif /* _PM_PACKAGE_H */
|
#endif /* _PM_PACKAGE_H */
|
||||||
|
|
||||||
/* vim: set ts=2 sw=2 noet: */
|
/* vim: set ts=2 sw=2 noet: */
|
||||||
|
|
|
@ -262,62 +262,8 @@ targcleanup:
|
||||||
/* search the local database for a matching package */
|
/* search the local database for a matching package */
|
||||||
static int query_search(alpm_list_t *targets)
|
static int query_search(alpm_list_t *targets)
|
||||||
{
|
{
|
||||||
alpm_list_t *i, *searchlist;
|
|
||||||
int freelist;
|
|
||||||
alpm_db_t *db_local = alpm_get_localdb(config->handle);
|
alpm_db_t *db_local = alpm_get_localdb(config->handle);
|
||||||
unsigned short cols;
|
return dump_pkg_search(db_local, targets, 0);
|
||||||
|
|
||||||
/* if we have a targets list, search for packages matching it */
|
|
||||||
if(targets) {
|
|
||||||
searchlist = alpm_db_search(db_local, targets);
|
|
||||||
freelist = 1;
|
|
||||||
} else {
|
|
||||||
searchlist = alpm_db_get_pkgcache(db_local);
|
|
||||||
freelist = 0;
|
|
||||||
}
|
|
||||||
if(searchlist == NULL) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
cols = getcols(fileno(stdout));
|
|
||||||
for(i = searchlist; i; i = alpm_list_next(i)) {
|
|
||||||
alpm_list_t *grp;
|
|
||||||
alpm_pkg_t *pkg = i->data;
|
|
||||||
|
|
||||||
if(!config->quiet) {
|
|
||||||
printf(LOCAL_PREFIX "%s %s", alpm_pkg_get_name(pkg), alpm_pkg_get_version(pkg));
|
|
||||||
} else {
|
|
||||||
fputs(alpm_pkg_get_name(pkg), stdout);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if(!config->quiet) {
|
|
||||||
if((grp = alpm_pkg_get_groups(pkg)) != NULL) {
|
|
||||||
alpm_list_t *k;
|
|
||||||
fputs(" (", stdout);
|
|
||||||
for(k = grp; k; k = alpm_list_next(k)) {
|
|
||||||
const char *group = k->data;
|
|
||||||
fputs(group, stdout);
|
|
||||||
if(alpm_list_next(k)) {
|
|
||||||
/* only print a spacer if there are more groups */
|
|
||||||
putchar(' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
putchar(')');
|
|
||||||
}
|
|
||||||
|
|
||||||
/* we need a newline and initial indent first */
|
|
||||||
fputs("\n ", stdout);
|
|
||||||
indentprint(alpm_pkg_get_desc(pkg), 4, cols);
|
|
||||||
}
|
|
||||||
fputc('\n', stdout);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* we only want to free if the list was a search list */
|
|
||||||
if(freelist) {
|
|
||||||
alpm_list_free(searchlist);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int query_group(alpm_list_t *targets)
|
static int query_group(alpm_list_t *targets)
|
||||||
|
|
|
@ -352,87 +352,18 @@ static int sync_synctree(int level, alpm_list_t *syncs)
|
||||||
return (success > 0);
|
return (success > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_installed(alpm_db_t *db_local, alpm_pkg_t *pkg)
|
|
||||||
{
|
|
||||||
const char *pkgname = alpm_pkg_get_name(pkg);
|
|
||||||
const char *pkgver = alpm_pkg_get_version(pkg);
|
|
||||||
alpm_pkg_t *lpkg = alpm_db_get_pkg(db_local, pkgname);
|
|
||||||
if(lpkg) {
|
|
||||||
const char *lpkgver = alpm_pkg_get_version(lpkg);
|
|
||||||
if(strcmp(lpkgver, pkgver) == 0) {
|
|
||||||
printf(" [%s]", _("installed"));
|
|
||||||
} else {
|
|
||||||
printf(" [%s: %s]", _("installed"), lpkgver);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* search the sync dbs for a matching package */
|
/* search the sync dbs for a matching package */
|
||||||
static int sync_search(alpm_list_t *syncs, alpm_list_t *targets)
|
static int sync_search(alpm_list_t *syncs, alpm_list_t *targets)
|
||||||
{
|
{
|
||||||
alpm_list_t *i, *j, *ret;
|
alpm_list_t *i;
|
||||||
int freelist;
|
|
||||||
int found = 0;
|
int found = 0;
|
||||||
alpm_db_t *db_local = alpm_get_localdb(config->handle);
|
|
||||||
|
|
||||||
for(i = syncs; i; i = alpm_list_next(i)) {
|
for(i = syncs; i; i = alpm_list_next(i)) {
|
||||||
alpm_db_t *db = i->data;
|
alpm_db_t *db = i->data;
|
||||||
unsigned short cols;
|
found += !dump_pkg_search(db, targets, 1);
|
||||||
/* if we have a targets list, search for packages matching it */
|
|
||||||
if(targets) {
|
|
||||||
ret = alpm_db_search(db, targets);
|
|
||||||
freelist = 1;
|
|
||||||
} else {
|
|
||||||
ret = alpm_db_get_pkgcache(db);
|
|
||||||
freelist = 0;
|
|
||||||
}
|
|
||||||
if(ret == NULL) {
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
found = 1;
|
|
||||||
}
|
|
||||||
cols = getcols(fileno(stdout));
|
|
||||||
for(j = ret; j; j = alpm_list_next(j)) {
|
|
||||||
alpm_list_t *grp;
|
|
||||||
alpm_pkg_t *pkg = j->data;
|
|
||||||
|
|
||||||
if(!config->quiet) {
|
|
||||||
printf("%s/%s %s", alpm_db_get_name(db), alpm_pkg_get_name(pkg),
|
|
||||||
alpm_pkg_get_version(pkg));
|
|
||||||
} else {
|
|
||||||
fputs(alpm_pkg_get_name(pkg), stdout);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!config->quiet) {
|
return (found == 0);
|
||||||
if((grp = alpm_pkg_get_groups(pkg)) != NULL) {
|
|
||||||
alpm_list_t *k;
|
|
||||||
fputs(" (", stdout);
|
|
||||||
for(k = grp; k; k = alpm_list_next(k)) {
|
|
||||||
const char *group = k->data;
|
|
||||||
fputs(group, stdout);
|
|
||||||
if(alpm_list_next(k)) {
|
|
||||||
/* only print a spacer if there are more groups */
|
|
||||||
putchar(' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
putchar(')');
|
|
||||||
}
|
|
||||||
|
|
||||||
print_installed(db_local, pkg);
|
|
||||||
|
|
||||||
/* we need a newline and initial indent first */
|
|
||||||
fputs("\n ", stdout);
|
|
||||||
indentprint(alpm_pkg_get_desc(pkg), 4, cols);
|
|
||||||
}
|
|
||||||
fputc('\n', stdout);
|
|
||||||
}
|
|
||||||
/* we only want to free if the list was a search list */
|
|
||||||
if(freelist) {
|
|
||||||
alpm_list_free(ret);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return !found;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int sync_group(int level, alpm_list_t *syncs, alpm_list_t *targets)
|
static int sync_group(int level, alpm_list_t *syncs, alpm_list_t *targets)
|
||||||
|
|
Loading…
Add table
Reference in a new issue