summaryrefslogtreecommitdiff
path: root/src/app_index.c
diff options
context:
space:
mode:
authorTimo Teräs <timo.teras@iki.fi>2020-08-24 13:35:36 +0300
committerTimo Teräs <timo.teras@iki.fi>2020-08-24 13:35:36 +0300
commitedb45ae46449ddabcac3dea6b3f42c6cec01510a (patch)
treea27a046df30e4ead8f36c559dabdecb2fa1d7ea5 /src/app_index.c
parent82de29cf7bad3d9cbb0aeb4dbe756ad2bde73eb3 (diff)
downloadapk-tools-edb45ae46449ddabcac3dea6b3f42c6cec01510a.tar.gz
apk-tools-edb45ae46449ddabcac3dea6b3f42c6cec01510a.tar.bz2
apk-tools-edb45ae46449ddabcac3dea6b3f42c6cec01510a.tar.xz
apk-tools-edb45ae46449ddabcac3dea6b3f42c6cec01510a.zip
enforce options definitions to bind the enum and the descriptor
This uses some macro trickery to make sure that there's one-to-one mapping with the option index enum and the descriptor. The down side is that enum's are generated via #define's and editors might not pick them up for auto completion, but the benefits are more: it's no longer possible have mismatching enum value and descriptor index, and the amount of source code lines is less.
Diffstat (limited to 'src/app_index.c')
-rw-r--r--src/app_index.c23
1 files changed, 8 insertions, 15 deletions
diff --git a/src/app_index.c b/src/app_index.c
index 53e53b0..18c240f 100644
--- a/src/app_index.c
+++ b/src/app_index.c
@@ -33,21 +33,14 @@ struct index_ctx {
unsigned short index_flags;
};
-enum {
- OPT_INDEX_description,
- OPT_INDEX_index,
- OPT_INDEX_no_warnings,
- OPT_INDEX_output,
- OPT_INDEX_rewrite_arch,
-};
-
-static const char option_desc[] =
- APK_OPTAPPLET
- APK_OPT2R("description", "d")
- APK_OPT2R("index", "x")
- APK_OPT1n("no-warnings")
- APK_OPT2R("output", "o")
- APK_OPT1R("rewrite-arch");
+#define INDEX_OPTIONS(OPT) \
+ OPT(OPT_INDEX_description, APK_OPT_ARG APK_OPT_SH("d") "description") \
+ OPT(OPT_INDEX_index, APK_OPT_ARG APK_OPT_SH("x") "index") \
+ OPT(OPT_INDEX_no_warnings, "no-warnings") \
+ OPT(OPT_INDEX_output, APK_OPT_ARG APK_OPT_SH("o") "output") \
+ OPT(OPT_INDEX_rewrite_arch, APK_OPT_ARG "rewrite-arch")
+
+APK_OPT_APPLET(option_desc, INDEX_OPTIONS);
static int option_parse_applet(void *ctx, struct apk_db_options *dbopts, int opt, const char *optarg)
{