mirror of
git://sourceware.org/git/lvm2.git
synced 2024-12-22 17:35:59 +03:00
13e8c7e434
Sun May 3 12:32:30 CEST 2009 Petr Rockai <me@mornfall.net> * Rework the toollib interface (process_each_*) on top of new vg_read. Rebased 6/26/09 by Dave W. - Add skipping message to process_each_lv - Remove inconsistent_t.
111 lines
3.0 KiB
C
111 lines
3.0 KiB
C
/*
|
|
* Copyright (C) 2001-2004 Sistina Software, Inc. All rights reserved.
|
|
* Copyright (C) 2004-2007 Red Hat, Inc. All rights reserved.
|
|
*
|
|
* This file is part of LVM2.
|
|
*
|
|
* This copyrighted material is made available to anyone wishing to use,
|
|
* modify, copy, or redistribute it subject to the terms and conditions
|
|
* of the GNU Lesser General Public License v.2.1.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#include "tools.h"
|
|
|
|
static int vgdisplay_single(struct cmd_context *cmd, const char *vg_name,
|
|
struct volume_group *vg,
|
|
void *handle __attribute((unused)))
|
|
{
|
|
/* FIXME Do the active check here if activevolumegroups_ARG ? */
|
|
if (vg_read_error(vg))
|
|
return ECMD_FAILED;
|
|
|
|
vg_check_status(vg, EXPORTED_VG);
|
|
|
|
if (arg_count(cmd, colon_ARG)) {
|
|
vgdisplay_colons(vg);
|
|
return ECMD_PROCESSED;
|
|
}
|
|
|
|
if (arg_count(cmd, short_ARG)) {
|
|
vgdisplay_short(vg);
|
|
return ECMD_PROCESSED;
|
|
}
|
|
|
|
vgdisplay_full(vg); /* was vg_show */
|
|
|
|
if (arg_count(cmd, verbose_ARG)) {
|
|
vgdisplay_extents(vg);
|
|
|
|
process_each_lv_in_vg(cmd, vg, NULL, NULL, NULL,
|
|
(process_single_lv_fn_t)lvdisplay_full);
|
|
|
|
log_print("--- Physical volumes ---");
|
|
process_each_pv_in_vg(cmd, vg, NULL, NULL,
|
|
(process_single_pv_fn_t)pvdisplay_short);
|
|
}
|
|
|
|
check_current_backup(vg);
|
|
|
|
return ECMD_PROCESSED;
|
|
}
|
|
|
|
int vgdisplay(struct cmd_context *cmd, int argc, char **argv)
|
|
{
|
|
if (arg_count(cmd, columns_ARG)) {
|
|
if (arg_count(cmd, colon_ARG) ||
|
|
arg_count(cmd, activevolumegroups_ARG) ||
|
|
arg_count(cmd, short_ARG)) {
|
|
log_error("Incompatible options selected");
|
|
return EINVALID_CMD_LINE;
|
|
}
|
|
return vgs(cmd, argc, argv);
|
|
} else if (arg_count(cmd, aligned_ARG) ||
|
|
arg_count(cmd, noheadings_ARG) ||
|
|
arg_count(cmd, options_ARG) ||
|
|
arg_count(cmd, separator_ARG) ||
|
|
arg_count(cmd, sort_ARG) || arg_count(cmd, unbuffered_ARG)) {
|
|
log_error("Incompatible options selected");
|
|
return EINVALID_CMD_LINE;
|
|
}
|
|
|
|
if (arg_count(cmd, colon_ARG) && arg_count(cmd, short_ARG)) {
|
|
log_error("Option -c is not allowed with option -s");
|
|
return EINVALID_CMD_LINE;
|
|
}
|
|
|
|
if (argc && arg_count(cmd, activevolumegroups_ARG)) {
|
|
log_error("Option -A is not allowed with volume group names");
|
|
return EINVALID_CMD_LINE;
|
|
}
|
|
|
|
/* FIXME -D disk_ARG is now redundant */
|
|
|
|
/********* FIXME: Do without this - or else 2(+) passes!
|
|
Figure out longest volume group name
|
|
for (c = opt; opt < argc; opt++) {
|
|
len = strlen(argv[opt]);
|
|
if (len > max_len)
|
|
max_len = len;
|
|
}
|
|
**********/
|
|
|
|
return process_each_vg(cmd, argc, argv, 0, NULL,
|
|
vgdisplay_single);
|
|
|
|
/******** FIXME Need to count number processed
|
|
Add this to process_each_vg if arg_count(cmd,activevolumegroups_ARG) ?
|
|
|
|
if (opt == argc) {
|
|
log_print("no ");
|
|
if (arg_count(cmd,activevolumegroups_ARG))
|
|
printf("active ");
|
|
printf("volume groups found\n\n");
|
|
return LVM_E_NO_VG;
|
|
}
|
|
************/
|
|
}
|