summaryrefslogtreecommitdiffhomepage
path: root/src/driver/pe_driver_ctx.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/driver/pe_driver_ctx.c')
-rw-r--r--src/driver/pe_driver_ctx.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/driver/pe_driver_ctx.c b/src/driver/pe_driver_ctx.c
index b99ee7f..955484a 100644
--- a/src/driver/pe_driver_ctx.c
+++ b/src/driver/pe_driver_ctx.c
@@ -31,6 +31,9 @@ static const char * const perk_cmd_name[PERK_CMD_CAP] = {
[PERK_CMD_AR] = "ar",
[PERK_CMD_NM] = "nm",
[PERK_CMD_SIZE] = "size",
+ [PERK_CMD_STRIP] = "strip",
+ [PERK_CMD_RANLIB] = "ranlib",
+ [PERK_CMD_STRINGS] = "strings",
};
/* perk command options */
@@ -40,6 +43,9 @@ static const struct argv_option * perk_cmd_options[PERK_CMD_CAP] = {
[PERK_CMD_AR] = pe_ar_options,
[PERK_CMD_NM] = pe_nm_options,
[PERK_CMD_SIZE] = pe_size_options,
+ [PERK_CMD_STRIP] = pe_strip_options,
+ [PERK_CMD_RANLIB] = pe_ranlib_options,
+ [PERK_CMD_STRINGS] = pe_strings_options,
};
/* default fd context */
@@ -114,6 +120,25 @@ static int pe_driver_usage(
cmdname,cmdname);
break;
+ case PERK_CMD_STRIP:
+ snprintf(header,sizeof(header),
+ PERK_STRIP_CMD_SYNOPSIS,
+ cmdname,cmdname,cmdname,cmdname,
+ cmdname,cmdname,cmdname);
+ break;
+
+ case PERK_CMD_RANLIB:
+ snprintf(header,sizeof(header),
+ PERK_RANLIB_CMD_SYNOPSIS,
+ cmdname,cmdname);
+ break;
+
+ case PERK_CMD_STRINGS:
+ snprintf(header,sizeof(header),
+ PERK_STRINGS_CMD_SYNOPSIS,
+ cmdname,cmdname);
+ break;
+
case PERK_CMD_PERK:
snprintf(header,sizeof(header),
PERK_PERK_CMD_SYNOPSIS,
@@ -507,6 +532,15 @@ int pe_lib_get_driver_ctx(
} else if (cctx.cmd == PERK_CMD_SIZE) {
argv_optv_init(pe_size_options,optv);
+
+ } else if (cctx.cmd == PERK_CMD_STRIP) {
+ argv_optv_init(pe_strip_options,optv);
+
+ } else if (cctx.cmd == PERK_CMD_RANLIB) {
+ argv_optv_init(pe_ranlib_options,optv);
+
+ } else if (cctx.cmd == PERK_CMD_STRINGS) {
+ argv_optv_init(pe_strings_options,optv);
}
/* process the selected tool's command-line arguments */