xbps-uhelper: restore compat.

Add 'digest' and 'fetch' actions again for compatibility,
but don't mention them in usage().

This way previous versions of xbps-src (that don't require xbps-0.54)
still work without changes.
This commit is contained in:
Juan RP 2019-06-20 10:53:30 +02:00
parent 490cce2ff8
commit e7738555b2
No known key found for this signature in database
GPG Key ID: AF19F6CB482F9368
2 changed files with 55 additions and 2 deletions

View File

@ -2,7 +2,7 @@ TOPDIR = ../..
-include $(TOPDIR)/config.mk -include $(TOPDIR)/config.mk
BIN = xbps-uhelper BIN = xbps-uhelper
OBJS = main.o OBJS = main.o ../xbps-install/fetch_cb.o
MAN = MAN =
include $(TOPDIR)/mk/prog.mk include $(TOPDIR)/mk/prog.mk

View File

@ -35,6 +35,7 @@
#include <getopt.h> #include <getopt.h>
#include <xbps.h> #include <xbps.h>
#include "../xbps-install/defs.h"
static void __attribute__((noreturn)) static void __attribute__((noreturn))
usage(void) usage(void)
@ -79,13 +80,29 @@ usage(void)
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
static char *
fname(char *url)
{
char *filename;
if ((filename = strrchr(url, '>'))) {
*filename = '\0';
} else {
filename = strrchr(url, '/');
}
if (filename == NULL)
return NULL;
return filename + 1;
}
int int
main(int argc, char **argv) main(int argc, char **argv)
{ {
xbps_dictionary_t dict; xbps_dictionary_t dict;
struct xbps_handle xh; struct xbps_handle xh;
struct xferstat xfer;
const char *version, *rootdir = NULL, *confdir = NULL; const char *version, *rootdir = NULL, *confdir = NULL;
char *pkgname; char *pkgname, *filename;
int flags = 0, c, rv = 0; int flags = 0, c, rv = 0;
const struct option longopts[] = { const struct option longopts[] = {
{ NULL, 0, NULL, 0 } { NULL, 0, NULL, 0 }
@ -123,10 +140,13 @@ main(int argc, char **argv)
if ((strcmp(argv[0], "version") == 0) || if ((strcmp(argv[0], "version") == 0) ||
(strcmp(argv[0], "real-version") == 0) || (strcmp(argv[0], "real-version") == 0) ||
(strcmp(argv[0], "arch") == 0) || (strcmp(argv[0], "arch") == 0) ||
(strcmp(argv[0], "fetch") == 0) ||
(strcmp(argv[0], "getsystemdir") == 0)) { (strcmp(argv[0], "getsystemdir") == 0)) {
/* /*
* Initialize libxbps. * Initialize libxbps.
*/ */
xh.fetch_cb = fetch_file_progress_cb;
xh.fetch_cb_data = &xfer;
xh.flags = flags; xh.flags = flags;
if (rootdir) if (rootdir)
xbps_strlcpy(xh.rootdir, rootdir, sizeof(xh.rootdir)); xbps_strlcpy(xh.rootdir, rootdir, sizeof(xh.rootdir));
@ -268,6 +288,39 @@ main(int argc, char **argv)
usage(); usage();
printf("%s\n", XBPS_SYSDEFCONF_PATH); printf("%s\n", XBPS_SYSDEFCONF_PATH);
} else if (strcmp(argv[0], "digest") == 0) {
/* Prints SHA256 hashes for specified files */
if (argc < 2)
usage();
for (int i = 1; i < argc; i++) {
filename = xbps_file_hash(argv[i]);
if (filename == NULL) {
fprintf(stderr,
"E: couldn't get hash for %s (%s)\n",
argv[i], strerror(errno));
exit(EXIT_FAILURE);
}
printf("%s\n", filename);
}
} else if (strcmp(argv[0], "fetch") == 0) {
/* Fetch a file from specified URL */
if (argc < 2)
usage();
for (int i = 1; i < argc; i++) {
filename = fname(argv[i]);
rv = xbps_fetch_file_dest(&xh, argv[i], filename, "v");
if (rv == -1) {
fprintf(stderr, "%s: %s\n", argv[i],
xbps_fetch_error_string());
} else if (rv == 0) {
printf("%s: file is identical with remote.\n", argv[i]);
} else {
rv = 0;
}
}
} else { } else {
usage(); usage();
} }