2012-11-02 15:04:25 +01:00
|
|
|
/*-
|
2015-01-28 18:06:58 +01:00
|
|
|
* Copyright (c) 2008-2015 Juan Romero Pardines.
|
2012-11-02 15:04:25 +01:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <fnmatch.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <strings.h>
|
|
|
|
#include <sys/ioctl.h>
|
2014-10-30 11:23:10 +01:00
|
|
|
#include <assert.h>
|
2012-11-02 15:04:25 +01:00
|
|
|
|
2013-06-20 12:31:02 +02:00
|
|
|
#include <xbps.h>
|
2012-11-02 15:04:25 +01:00
|
|
|
#include "defs.h"
|
|
|
|
|
2013-06-12 10:04:10 +02:00
|
|
|
int
|
2012-11-02 15:04:25 +01:00
|
|
|
get_maxcols(void)
|
|
|
|
{
|
|
|
|
struct winsize ws;
|
|
|
|
|
2016-04-24 14:02:52 +02:00
|
|
|
if (!isatty(STDOUT_FILENO)) {
|
2015-04-15 18:40:34 +02:00
|
|
|
/* not a TTY, don't use any limit */
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (ioctl(STDOUT_FILENO, TIOCGWINSZ, &ws) == -1) {
|
|
|
|
/* 80x24 terminal */
|
|
|
|
return 80;
|
|
|
|
}
|
|
|
|
/* TTY columns */
|
|
|
|
return ws.ws_col;
|
2012-11-02 15:04:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2013-06-12 10:04:10 +02:00
|
|
|
print_package_line(const char *str, int maxcols, bool reset)
|
2012-11-02 15:04:25 +01:00
|
|
|
{
|
2013-06-12 10:04:10 +02:00
|
|
|
static int cols;
|
2012-11-02 15:04:25 +01:00
|
|
|
static bool first;
|
|
|
|
|
|
|
|
if (reset) {
|
|
|
|
cols = 0;
|
|
|
|
first = false;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
cols += strlen(str) + 4;
|
|
|
|
if (cols <= maxcols) {
|
|
|
|
if (first == false) {
|
|
|
|
printf(" ");
|
|
|
|
first = true;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
printf("\n ");
|
|
|
|
cols = strlen(str) + 4;
|
|
|
|
}
|
|
|
|
printf("%s ", str);
|
|
|
|
}
|
2014-10-30 11:23:10 +01:00
|
|
|
|
|
|
|
static unsigned int
|
|
|
|
find_longest_pkgname(struct transaction *trans)
|
|
|
|
{
|
|
|
|
xbps_object_t obj;
|
|
|
|
const char *pkgver;
|
2020-02-08 19:31:29 +01:00
|
|
|
char pkgname[XBPS_NAME_SIZE];
|
2014-10-30 11:23:10 +01:00
|
|
|
unsigned int len = 0, max = 0;
|
|
|
|
|
|
|
|
while ((obj = xbps_object_iterator_next(trans->iter)) != NULL) {
|
|
|
|
xbps_dictionary_get_cstring_nocopy(obj, "pkgver", &pkgver);
|
2020-02-08 19:31:29 +01:00
|
|
|
if (!xbps_pkg_name(pkgname, sizeof(pkgname), pkgver)) {
|
|
|
|
abort();
|
|
|
|
}
|
2014-10-30 11:23:10 +01:00
|
|
|
len = strlen(pkgname);
|
|
|
|
if (max == 0 || len > max)
|
|
|
|
max = len;
|
|
|
|
}
|
|
|
|
xbps_object_iterator_reset(trans->iter);
|
|
|
|
return max+1;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
print_trans_colmode(struct transaction *trans, int cols)
|
|
|
|
{
|
|
|
|
xbps_object_t obj;
|
|
|
|
uint64_t dlsize = 0;
|
|
|
|
char size[8];
|
|
|
|
unsigned int x, blen, pnamelen;
|
|
|
|
int hdrlen;
|
|
|
|
|
|
|
|
pnamelen = find_longest_pkgname(trans);
|
|
|
|
/* header length */
|
2014-12-09 12:33:58 +01:00
|
|
|
hdrlen = pnamelen + 61;
|
2014-10-30 11:23:10 +01:00
|
|
|
if (cols <= hdrlen)
|
|
|
|
return false;
|
|
|
|
|
2014-12-09 12:33:58 +01:00
|
|
|
printf("\nName ");
|
|
|
|
if (pnamelen < 5)
|
|
|
|
pnamelen = 5;
|
|
|
|
|
|
|
|
for (x = 5; x < pnamelen; x++)
|
2014-10-30 11:23:10 +01:00
|
|
|
printf(" ");
|
2014-12-09 12:33:58 +01:00
|
|
|
|
2014-11-05 10:16:57 +01:00
|
|
|
printf("Action Version New version Download size\n");
|
2014-10-30 11:23:10 +01:00
|
|
|
|
|
|
|
while ((obj = xbps_object_iterator_next(trans->iter)) != NULL) {
|
|
|
|
xbps_dictionary_t ipkgd;
|
|
|
|
const char *pkgver, *ipkgver, *ver, *iver, *tract;
|
2020-02-08 19:31:29 +01:00
|
|
|
char pkgname[XBPS_NAME_SIZE];
|
2014-10-30 11:23:10 +01:00
|
|
|
bool dload = false;
|
|
|
|
|
|
|
|
ver = iver = NULL;
|
|
|
|
|
|
|
|
xbps_dictionary_get_cstring_nocopy(obj, "pkgver", &pkgver);
|
|
|
|
xbps_dictionary_get_cstring_nocopy(obj, "transaction", &tract);
|
|
|
|
xbps_dictionary_get_uint64(obj, "filename-size", &dlsize);
|
|
|
|
xbps_dictionary_get_bool(obj, "download", &dload);
|
|
|
|
|
2020-02-08 19:31:29 +01:00
|
|
|
if (!xbps_pkg_name(pkgname, sizeof(pkgname), pkgver)) {
|
|
|
|
abort();
|
|
|
|
}
|
2014-10-30 11:23:10 +01:00
|
|
|
|
2020-01-25 13:05:46 +01:00
|
|
|
if (trans->xhp->flags & XBPS_FLAG_DOWNLOAD_ONLY) {
|
|
|
|
tract = "download";
|
|
|
|
}
|
|
|
|
|
2014-11-05 10:16:57 +01:00
|
|
|
if (strcmp(tract, "install") == 0) {
|
|
|
|
trans->inst_pkgcnt++;
|
|
|
|
} else if (strcmp(tract, "update") == 0) {
|
|
|
|
trans->up_pkgcnt++;
|
|
|
|
} else if (strcmp(tract, "remove") == 0) {
|
|
|
|
trans->rm_pkgcnt++;
|
|
|
|
} else if (strcmp(tract, "configure") == 0) {
|
|
|
|
trans->cf_pkgcnt++;
|
|
|
|
}
|
2020-01-25 13:05:46 +01:00
|
|
|
ipkgd = xbps_pkgdb_get_pkg(trans->xhp, pkgname);
|
|
|
|
|
2019-06-21 16:26:08 +02:00
|
|
|
if (trans->xhp->flags & XBPS_FLAG_DOWNLOAD_ONLY) {
|
2020-01-25 13:05:46 +01:00
|
|
|
ipkgd = NULL;
|
2019-06-21 16:26:08 +02:00
|
|
|
}
|
2014-11-05 10:16:57 +01:00
|
|
|
if (dload) {
|
|
|
|
trans->dl_pkgcnt++;
|
|
|
|
}
|
2015-01-29 09:58:32 +01:00
|
|
|
if (ipkgd) {
|
2014-10-30 11:23:10 +01:00
|
|
|
xbps_dictionary_get_cstring_nocopy(ipkgd, "pkgver", &ipkgver);
|
|
|
|
iver = xbps_pkg_version(ipkgver);
|
|
|
|
}
|
|
|
|
ver = xbps_pkg_version(pkgver);
|
2015-01-29 09:58:32 +01:00
|
|
|
if (iver) {
|
|
|
|
int rv = xbps_cmpver(iver, ver);
|
2019-03-15 14:06:24 +01:00
|
|
|
if (rv == 1 && strcmp(tract, "hold"))
|
2015-01-29 09:58:32 +01:00
|
|
|
tract = "downgrade";
|
2015-02-02 09:49:16 +01:00
|
|
|
else if (rv == 0 && strcmp(tract, "remove"))
|
2015-01-29 09:58:32 +01:00
|
|
|
tract = "reinstall";
|
|
|
|
}
|
2014-10-30 11:23:10 +01:00
|
|
|
/* print pkgname and some blanks */
|
|
|
|
blen = pnamelen - strlen(pkgname);
|
|
|
|
printf("%s", pkgname);
|
|
|
|
for (x = 0; x < blen; x++)
|
|
|
|
printf(" ");
|
|
|
|
|
|
|
|
/* print action */
|
|
|
|
printf("%s ", tract);
|
2014-11-05 10:16:57 +01:00
|
|
|
for (x = strlen(tract); x < 9; x++)
|
2014-10-30 11:23:10 +01:00
|
|
|
printf(" ");
|
|
|
|
|
|
|
|
/* print installed version */
|
|
|
|
if (iver == NULL)
|
|
|
|
iver = "-";
|
|
|
|
|
|
|
|
/* print new version */
|
|
|
|
printf("%s ", iver);
|
2014-11-05 10:16:57 +01:00
|
|
|
for (x = strlen(iver); x < 17; x++)
|
2014-10-30 11:23:10 +01:00
|
|
|
printf(" ");
|
|
|
|
|
|
|
|
if (strcmp(tract, "remove") == 0) {
|
|
|
|
ver = "-";
|
|
|
|
}
|
|
|
|
if (dload)
|
|
|
|
(void)xbps_humanize_number(size, (int64_t)dlsize);
|
|
|
|
else {
|
|
|
|
size[0] = '-';
|
|
|
|
size[1] = '\0';
|
|
|
|
}
|
|
|
|
printf("%s ", ver);
|
2014-11-05 10:16:57 +01:00
|
|
|
for (x = strlen(ver); x < 22; x++)
|
2014-10-30 11:23:10 +01:00
|
|
|
printf(" ");
|
|
|
|
/* print download size */
|
|
|
|
printf("%s ", size);
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
xbps_object_iterator_reset(trans->iter);
|
|
|
|
return true;
|
|
|
|
}
|