From: Karel Zak Date: Mon, 29 Apr 2013 13:29:48 +0000 (+0200) Subject: libfdisk: add new 'ask' type TABLE X-Git-Tag: v2.24-rc1~266 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=0c870c1c73985a5e153a35209a650bcacce94c5b;p=thirdparty%2Futil-linux.git libfdisk: add new 'ask' type TABLE The new type could be used to print table-like output (for example list of the partitions). Signed-off-by: Karel Zak --- diff --git a/fdisks/fdisk-ask.c b/fdisks/fdisk-ask.c index 61dc0c2df2..11c4dd5ff1 100644 --- a/fdisks/fdisk-ask.c +++ b/fdisks/fdisk-ask.c @@ -199,6 +199,9 @@ int ask_callback(struct fdisk_context *cxt, struct fdisk_ask *ask, ask->data.yesno.result = rpmatch(buf); DBG(ASK, dbgprint("yes-no ask: reply '%s' [rc=%d]", buf, rc)); break; + case FDISK_ASKTYPE_TABLE: + tt_print_table(fdisk_ask_get_table(ask)); + break; default: warnx(_("internal error: unsupported dialog type %d"), fdisk_ask_get_type(ask)); return -EINVAL; diff --git a/libfdisk/src/ask.c b/libfdisk/src/ask.c index 1b4791af36..a95d54233e 100644 --- a/libfdisk/src/ask.c +++ b/libfdisk/src/ask.c @@ -408,6 +408,33 @@ int fdisk_ask_yesno_set_result(struct fdisk_ask *ask, uint64_t result) return 0; } +struct tt *fdisk_ask_get_table(struct fdisk_ask *ask) +{ + assert(ask); + assert(fdisk_is_ask(ask, TABLE)); + return ask->data.table; +} + +int fdisk_print_table(struct fdisk_context *cxt, struct tt *tb) +{ + struct fdisk_ask *ask; + int rc; + + assert(cxt); + assert(tb); + + ask = fdisk_new_ask(); + if (!ask) + return -ENOMEM; + + fdisk_ask_set_type(ask, FDISK_ASKTYPE_TABLE); + ask->data.table = tb; + + rc = fdisk_do_ask(cxt, ask); + + fdisk_free_ask(ask); + return rc; +} #define is_print_ask(a) (fdisk_is_ask(a, WARN) || fdisk_is_ask(a, WARNX) || fdisk_is_ask(a, INFO)) diff --git a/libfdisk/src/fdiskP.h b/libfdisk/src/fdiskP.h index 541b753966..01b9ec6f42 100644 --- a/libfdisk/src/fdiskP.h +++ b/libfdisk/src/fdiskP.h @@ -21,6 +21,7 @@ #include "libfdisk.h" #include "nls.h" /* temporary before dialog API will be implamented */ +#include "tt.h" /* features */ #define CONFIG_LIBFDISK_ASSERT @@ -237,6 +238,8 @@ struct fdisk_ask { struct ask_yesno { int result; /* TRUE or FALSE */ } yesno; + /* FDISK_ASKTYPE_TABLE, see include/tt.h */ + struct tt *table; } data; }; @@ -319,4 +322,7 @@ extern void gpt_list_table(struct fdisk_context *cxt, int xtra); /* ask.c */ extern int fdisk_ask_partnum(struct fdisk_context *cxt, size_t *partnum, int wantnew); +extern struct tt *fdisk_ask_get_table(struct fdisk_ask *ask); +extern int fdisk_print_table(struct fdisk_context *cxt, struct tt *tb); + #endif /* _LIBFDISK_PRIVATE_H */ diff --git a/libfdisk/src/libfdisk.h b/libfdisk/src/libfdisk.h index 8a440672b3..c3e6ad582d 100644 --- a/libfdisk/src/libfdisk.h +++ b/libfdisk/src/libfdisk.h @@ -32,6 +32,7 @@ struct fdisk_context; struct fdisk_label; struct fdisk_parttype; struct fdisk_ask; +struct tt; /* * Supported partition table types (labels) @@ -58,7 +59,8 @@ enum { FDISK_ASKTYPE_WARN, FDISK_ASKTYPE_WARNX, FDISK_ASKTYPE_INFO, - FDISK_ASKTYPE_YESNO + FDISK_ASKTYPE_YESNO, + FDISK_ASKTYPE_TABLE };