index: add argument --no-warnings
When creating an index apk warns if a dependency is missing a provider. However when using a multi-arch repository, it's not an error that a certain architecture is missing a dependency because that dependency could be in an other architecture. Since apk index doesn't know about this, add an argument to disable that warning. Maintainer note: rebased for new option handling, and minor stylistic adjustments. Signed-off-by: Fredrik Gustafsson <fredrigu@axis.com>cute-signatures
parent
1d7123d837
commit
6863928677
|
@ -30,6 +30,11 @@ will accept it. See *abuild-sign*(1) for details.
|
||||||
Read an existing index from _INDEX_ to speed up the creation of the new
|
Read an existing index from _INDEX_ to speed up the creation of the new
|
||||||
index by reusing data when possible.
|
index by reusing data when possible.
|
||||||
|
|
||||||
|
*--no-warnings*
|
||||||
|
Disable the warning about missing dependencies. This happens when A,
|
||||||
|
depends on package B, that does not have a provider in the indexed
|
||||||
|
repository.
|
||||||
|
|
||||||
# AUTHORS
|
# AUTHORS
|
||||||
|
|
||||||
Natanael Copa <ncopa@alpinelinux.org>++
|
Natanael Copa <ncopa@alpinelinux.org>++
|
||||||
|
|
|
@ -19,6 +19,8 @@
|
||||||
#include "apk_database.h"
|
#include "apk_database.h"
|
||||||
#include "apk_print.h"
|
#include "apk_print.h"
|
||||||
|
|
||||||
|
#define APK_INDEXF_NO_WARNINGS 0x0001
|
||||||
|
|
||||||
struct counts {
|
struct counts {
|
||||||
int unsatisfied;
|
int unsatisfied;
|
||||||
};
|
};
|
||||||
|
@ -30,11 +32,13 @@ struct index_ctx {
|
||||||
apk_blob_t *rewrite_arch;
|
apk_blob_t *rewrite_arch;
|
||||||
time_t index_mtime;
|
time_t index_mtime;
|
||||||
int method;
|
int method;
|
||||||
|
unsigned short index_flags;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
OPT_INDEX_description,
|
OPT_INDEX_description,
|
||||||
OPT_INDEX_index,
|
OPT_INDEX_index,
|
||||||
|
OPT_INDEX_no_warnings,
|
||||||
OPT_INDEX_output,
|
OPT_INDEX_output,
|
||||||
OPT_INDEX_rewrite_arch,
|
OPT_INDEX_rewrite_arch,
|
||||||
};
|
};
|
||||||
|
@ -43,6 +47,7 @@ static const char option_desc[] =
|
||||||
APK_OPTAPPLET
|
APK_OPTAPPLET
|
||||||
APK_OPT2R("description", "d")
|
APK_OPT2R("description", "d")
|
||||||
APK_OPT2R("index", "x")
|
APK_OPT2R("index", "x")
|
||||||
|
APK_OPT1n("no-warnings")
|
||||||
APK_OPT2R("output", "o")
|
APK_OPT2R("output", "o")
|
||||||
APK_OPT1R("rewrite-arch");
|
APK_OPT1R("rewrite-arch");
|
||||||
|
|
||||||
|
@ -63,6 +68,9 @@ static int option_parse_applet(void *ctx, struct apk_db_options *dbopts, int opt
|
||||||
case OPT_INDEX_rewrite_arch:
|
case OPT_INDEX_rewrite_arch:
|
||||||
ictx->rewrite_arch = apk_blob_atomize(APK_BLOB_STR(optarg));
|
ictx->rewrite_arch = apk_blob_atomize(APK_BLOB_STR(optarg));
|
||||||
break;
|
break;
|
||||||
|
case OPT_INDEX_no_warnings:
|
||||||
|
ictx->index_flags |= APK_INDEXF_NO_WARNINGS;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return -ENOTSUP;
|
return -ENOTSUP;
|
||||||
}
|
}
|
||||||
|
@ -244,7 +252,9 @@ static int index_main(void *ctx, struct apk_database *db, struct apk_string_arra
|
||||||
}
|
}
|
||||||
|
|
||||||
total = r;
|
total = r;
|
||||||
|
if (!(ictx->index_flags & APK_INDEXF_NO_WARNINGS)) {
|
||||||
apk_hash_foreach(&db->available.names, warn_if_no_providers, &counts);
|
apk_hash_foreach(&db->available.names, warn_if_no_providers, &counts);
|
||||||
|
}
|
||||||
|
|
||||||
if (counts.unsatisfied != 0)
|
if (counts.unsatisfied != 0)
|
||||||
apk_warning("Total of %d unsatisfiable package "
|
apk_warning("Total of %d unsatisfiable package "
|
||||||
|
|
Loading…
Reference in New Issue