bin/xbps-query: simplify search result printing (with truncation)
This should also fix a useless error from lgtm
This commit is contained in:
parent
df5f2a9378
commit
a2c7f5fc29
@ -49,47 +49,42 @@ struct search_data {
|
|||||||
unsigned int maxcols;
|
unsigned int maxcols;
|
||||||
const char *pat, *prop, *repourl;
|
const char *pat, *prop, *repourl;
|
||||||
xbps_array_t results;
|
xbps_array_t results;
|
||||||
|
char *linebuf;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void
|
static void
|
||||||
print_results(struct xbps_handle *xhp, struct search_data *sd)
|
print_results(struct xbps_handle *xhp, struct search_data *sd)
|
||||||
{
|
{
|
||||||
const char *pkgver = NULL, *desc = NULL, *inststr = NULL;
|
const char *pkgver = NULL, *desc = NULL;
|
||||||
char tmp[256], *out;
|
unsigned int align = 0, len;
|
||||||
unsigned int j, tlen = 0, len = 0;
|
|
||||||
|
|
||||||
/* Iterate over results array and find out largest pkgver string */
|
/* Iterate over results array and find out largest pkgver string */
|
||||||
for (unsigned int i = 0; i < xbps_array_count(sd->results); i+=2) {
|
for (unsigned int i = 0; i < xbps_array_count(sd->results); i += 2) {
|
||||||
xbps_array_get_cstring_nocopy(sd->results, i, &pkgver);
|
xbps_array_get_cstring_nocopy(sd->results, i, &pkgver);
|
||||||
len = strlen(pkgver);
|
if ((len = strlen(pkgver)) > align)
|
||||||
if (tlen == 0 || len > tlen)
|
align = len;
|
||||||
tlen = len;
|
|
||||||
}
|
}
|
||||||
for (unsigned int i = 0; i < xbps_array_count(sd->results); i+=2) {
|
for (unsigned int i = 0; i < xbps_array_count(sd->results); i += 2) {
|
||||||
xbps_array_get_cstring_nocopy(sd->results, i, &pkgver);
|
xbps_array_get_cstring_nocopy(sd->results, i, &pkgver);
|
||||||
xbps_array_get_cstring_nocopy(sd->results, i+1, &desc);
|
xbps_array_get_cstring_nocopy(sd->results, i+1, &desc);
|
||||||
xbps_strlcpy(tmp, pkgver, sizeof(tmp));
|
|
||||||
for (j = strlen(tmp); j < tlen; j++)
|
|
||||||
tmp[j] = ' ';
|
|
||||||
|
|
||||||
tmp[j] = '\0';
|
if (sd->linebuf == NULL) {
|
||||||
if (xbps_pkgdb_get_pkg(xhp, pkgver))
|
printf("[%s] %-*s %s\n",
|
||||||
inststr = "[*]";
|
xbps_pkgdb_get_pkg(xhp, pkgver) ? "*" : "-",
|
||||||
else
|
align, pkgver, desc);
|
||||||
inststr = "[-]";
|
continue;
|
||||||
|
|
||||||
len = strlen(inststr) + strlen(tmp) + strlen(desc) + 3;
|
|
||||||
if (sd->maxcols && len > sd->maxcols) {
|
|
||||||
out = malloc(sd->maxcols+1);
|
|
||||||
assert(out);
|
|
||||||
snprintf(out, sd->maxcols-3, "%s %s %s",
|
|
||||||
inststr, tmp, desc);
|
|
||||||
xbps_strlcat(out, "...\n", sd->maxcols+1);
|
|
||||||
printf("%s", out);
|
|
||||||
free(out);
|
|
||||||
} else {
|
|
||||||
printf("%s %s %s\n", inststr, tmp, desc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
len = snprintf(sd->linebuf, sd->maxcols, "[%s] %-*s %s",
|
||||||
|
xbps_pkgdb_get_pkg(xhp, pkgver) ? "*" : "-",
|
||||||
|
align, pkgver, desc);
|
||||||
|
/* add ellipsis if the line was truncated */
|
||||||
|
if (len >= sd->maxcols && sd->maxcols > 4) {
|
||||||
|
for (unsigned int j = 0; j < 3; j++)
|
||||||
|
sd->linebuf[sd->maxcols-j-1] = '.';
|
||||||
|
sd->linebuf[sd->maxcols] = '\0';
|
||||||
|
}
|
||||||
|
puts(sd->linebuf);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -242,6 +237,12 @@ search(struct xbps_handle *xhp, bool repo_mode, const char *pat, const char *pro
|
|||||||
sd.prop = prop;
|
sd.prop = prop;
|
||||||
sd.maxcols = get_maxcols();
|
sd.maxcols = get_maxcols();
|
||||||
sd.results = xbps_array_create();
|
sd.results = xbps_array_create();
|
||||||
|
sd.linebuf = NULL;
|
||||||
|
if (sd.maxcols > 0) {
|
||||||
|
sd.linebuf = malloc(sd.maxcols);
|
||||||
|
if (sd.linebuf == NULL)
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
if (repo_mode) {
|
if (repo_mode) {
|
||||||
rv = xbps_rpool_foreach(xhp, search_repo_cb, &sd);
|
rv = xbps_rpool_foreach(xhp, search_repo_cb, &sd);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user