mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
man: put some commands into advanced usage section
and separate commands with --
This commit is contained in:
parent
eb9586bd3b
commit
62abae1525
@ -144,12 +144,12 @@ Makefile: Makefile.in
|
|||||||
|
|
||||||
man-generator:
|
man-generator:
|
||||||
$(CC) -DMAN_PAGE_GENERATOR -I$(top_builddir)/tools $(CFLAGS) $(top_srcdir)/tools/command.c -o $@
|
$(CC) -DMAN_PAGE_GENERATOR -I$(top_builddir)/tools $(CFLAGS) $(top_srcdir)/tools/command.c -o $@
|
||||||
- ./man-generator lvmconfig > test.gen
|
- ./man-generator --primary lvmconfig > test.gen
|
||||||
if [ ! -s test.gen ] ; then cp genfiles/*.gen $(top_builddir)/man; fi;
|
if [ ! -s test.gen ] ; then cp genfiles/*.gen $(top_builddir)/man; fi;
|
||||||
|
|
||||||
$(MAN8GEN): man-generator
|
$(MAN8GEN): man-generator
|
||||||
echo "Generating $@" ;
|
echo "Generating $@" ;
|
||||||
if [ ! -e $@.gen ]; then ./man-generator $(basename $@) $(top_srcdir)/man/$@.des > $@.gen; fi
|
if [ ! -e $@.gen ]; then ./man-generator --primary $(basename $@) $(top_srcdir)/man/$@.des > $@.gen; ./man-generator --secondary $(basename $@) >> $@.gen; fi
|
||||||
if [ -f $(top_srcdir)/man/$@.end ]; then cat $(top_srcdir)/man/$@.end >> $@.gen; fi;
|
if [ -f $(top_srcdir)/man/$@.end ]; then cat $(top_srcdir)/man/$@.end >> $@.gen; fi;
|
||||||
cat $(top_srcdir)/man/see_also.end >> $@.gen
|
cat $(top_srcdir)/man/see_also.end >> $@.gen
|
||||||
$(SED) -e "s+#VERSION#+$(LVM_VERSION)+;s+#DEFAULT_SYS_DIR#+$(DEFAULT_SYS_DIR)+;s+#DEFAULT_ARCHIVE_DIR#+$(DEFAULT_ARCHIVE_DIR)+;s+#DEFAULT_BACKUP_DIR#+$(DEFAULT_BACKUP_DIR)+;s+#DEFAULT_PROFILE_DIR#+$(DEFAULT_PROFILE_DIR)+;s+#DEFAULT_CACHE_DIR#+$(DEFAULT_CACHE_DIR)+;s+#DEFAULT_LOCK_DIR#+$(DEFAULT_LOCK_DIR)+;s+#CLVMD_PATH#+@CLVMD_PATH@+;s+#LVM_PATH#+@LVM_PATH@+;s+#DEFAULT_RUN_DIR#+@DEFAULT_RUN_DIR@+;s+#DEFAULT_PID_DIR#+@DEFAULT_PID_DIR@+;s+#SYSTEMD_GENERATOR_DIR#+$(SYSTEMD_GENERATOR_DIR)+;s+#DEFAULT_MANGLING#+$(DEFAULT_MANGLING)+;" $@.gen > $@
|
$(SED) -e "s+#VERSION#+$(LVM_VERSION)+;s+#DEFAULT_SYS_DIR#+$(DEFAULT_SYS_DIR)+;s+#DEFAULT_ARCHIVE_DIR#+$(DEFAULT_ARCHIVE_DIR)+;s+#DEFAULT_BACKUP_DIR#+$(DEFAULT_BACKUP_DIR)+;s+#DEFAULT_PROFILE_DIR#+$(DEFAULT_PROFILE_DIR)+;s+#DEFAULT_CACHE_DIR#+$(DEFAULT_CACHE_DIR)+;s+#DEFAULT_LOCK_DIR#+$(DEFAULT_LOCK_DIR)+;s+#CLVMD_PATH#+@CLVMD_PATH@+;s+#LVM_PATH#+@LVM_PATH@+;s+#DEFAULT_RUN_DIR#+@DEFAULT_RUN_DIR@+;s+#DEFAULT_PID_DIR#+@DEFAULT_PID_DIR@+;s+#SYSTEMD_GENERATOR_DIR#+$(SYSTEMD_GENERATOR_DIR)+;s+#DEFAULT_MANGLING#+$(DEFAULT_MANGLING)+;" $@.gen > $@
|
||||||
|
106
tools/command.c
106
tools/command.c
@ -2866,7 +2866,7 @@ static void include_description_file(char *name, char *des_file)
|
|||||||
close(fd);
|
close(fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void print_man(char *name, char *des_file, int include_primary, int include_secondary)
|
void print_man(char *name, char *des_file, int secondary)
|
||||||
{
|
{
|
||||||
struct command_name *cname;
|
struct command_name *cname;
|
||||||
struct command *cmd, *prev_cmd = NULL;
|
struct command *cmd, *prev_cmd = NULL;
|
||||||
@ -2905,10 +2905,7 @@ void print_man(char *name, char *des_file, int include_primary, int include_seco
|
|||||||
if (cmd->cmd_flags & CMD_FLAG_PREVIOUS_SYNTAX)
|
if (cmd->cmd_flags & CMD_FLAG_PREVIOUS_SYNTAX)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if ((cmd->cmd_flags & CMD_FLAG_SECONDARY_SYNTAX) && !include_secondary)
|
if ((cmd->cmd_flags & CMD_FLAG_SECONDARY_SYNTAX) && !secondary)
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!(cmd->cmd_flags & CMD_FLAG_SECONDARY_SYNTAX) && !include_primary)
|
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strcmp(name, cmd->name))
|
if (strcmp(name, cmd->name))
|
||||||
@ -2995,6 +2992,12 @@ void print_man(char *name, char *des_file, int include_primary, int include_seco
|
|||||||
printf(".SH VARIABLES\n");
|
printf(".SH VARIABLES\n");
|
||||||
printf(".br\n");
|
printf(".br\n");
|
||||||
print_man_all_positions_desc(cname);
|
print_man_all_positions_desc(cname);
|
||||||
|
} else {
|
||||||
|
if (cname->variants > 2) {
|
||||||
|
printf("--\n");
|
||||||
|
printf("\n");
|
||||||
|
printf(".br\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("\n");
|
printf("\n");
|
||||||
@ -3002,20 +3005,107 @@ void print_man(char *name, char *des_file, int include_primary, int include_seco
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_man_secondary(char *name)
|
||||||
|
{
|
||||||
|
struct command *cmd;
|
||||||
|
char *lvmname = name;
|
||||||
|
int header = 0;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (!strncmp(name, "lvm-", 4)) {
|
||||||
|
name[3] = ' ';
|
||||||
|
name += 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < COMMAND_COUNT; i++) {
|
||||||
|
|
||||||
|
cmd = &commands[i];
|
||||||
|
|
||||||
|
if (cmd->cmd_flags & CMD_FLAG_PREVIOUS_SYNTAX)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (!(cmd->cmd_flags & CMD_FLAG_SECONDARY_SYNTAX))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (strcmp(name, cmd->name))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (!header) {
|
||||||
|
printf(".SH ADVANCED USAGE\n");
|
||||||
|
printf("Alternate command forms, advanced command usage, and listing of all valid syntax for completeness.\n");
|
||||||
|
printf(".P\n");
|
||||||
|
header = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cmd->desc) {
|
||||||
|
print_desc_man(cmd->desc);
|
||||||
|
printf(".P\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
print_man_usage(lvmname, cmd);
|
||||||
|
|
||||||
|
printf("--\n");
|
||||||
|
printf("\n");
|
||||||
|
printf(".br\n");
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
char *cmdname = NULL;
|
||||||
|
char *desfile = NULL;
|
||||||
|
int primary = 0;
|
||||||
|
int secondary = 0;
|
||||||
|
|
||||||
memset(&commands, 0, sizeof(commands));
|
memset(&commands, 0, sizeof(commands));
|
||||||
|
|
||||||
if (argc < 2) {
|
static struct option long_options[] = {
|
||||||
log_error("Usage: %s <command> [/path/to/description-file]", argv[0]);
|
{"primary", no_argument, 0, 'p' },
|
||||||
|
{"secondary", no_argument, 0, 's' },
|
||||||
|
{0, 0, 0, 0 }
|
||||||
|
};
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
int c;
|
||||||
|
int option_index = 0;
|
||||||
|
|
||||||
|
c = getopt_long(argc, argv, "ps", long_options, &option_index);
|
||||||
|
if (c == -1)
|
||||||
|
break;
|
||||||
|
|
||||||
|
switch (c) {
|
||||||
|
case '0':
|
||||||
|
break;
|
||||||
|
case 'p':
|
||||||
|
primary = 1;
|
||||||
|
break;
|
||||||
|
case 's':
|
||||||
|
secondary = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!primary && !secondary) {
|
||||||
|
log_error("Usage: %s --primary|--secondary <command> [/path/to/description-file]", argv[0]);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (optind < argc)
|
||||||
|
cmdname = strdup(argv[optind++]);
|
||||||
|
|
||||||
|
if (optind < argc)
|
||||||
|
desfile = argv[optind++];
|
||||||
|
|
||||||
define_commands(NULL);
|
define_commands(NULL);
|
||||||
|
|
||||||
factor_common_options();
|
factor_common_options();
|
||||||
|
|
||||||
print_man(argv[1], (argc > 2) ? argv[2] : NULL, 1, 1);
|
if (primary)
|
||||||
|
print_man(cmdname, desfile, secondary);
|
||||||
|
else if (secondary)
|
||||||
|
print_man_secondary(cmdname);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -1720,7 +1720,7 @@ static int _usage(const char *name, int longhelp)
|
|||||||
print_usage_common_cmd(cname, cmd);
|
print_usage_common_cmd(cname, cmd);
|
||||||
print_usage_common_lvm(cname, cmd);
|
print_usage_common_lvm(cname, cmd);
|
||||||
} else
|
} else
|
||||||
log_print("Use --longhelp to show all options.");
|
log_print("Use --longhelp to show all options and advanced commands.");
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user