From 802e252b29ca8a40a0f161d5c316edcf9c35b152 Mon Sep 17 00:00:00 2001 From: Dave Wysochanski Date: Tue, 12 Oct 2010 16:11:34 +0000 Subject: [PATCH] Refactor and add code for (lv) 'lv_path' get function. --- lib/metadata/lv.c | 22 ++++++++++++++++++++++ lib/metadata/lv.h | 1 + lib/report/properties.c | 2 +- lib/report/report.c | 11 +---------- 4 files changed, 25 insertions(+), 11 deletions(-) diff --git a/lib/metadata/lv.c b/lib/metadata/lv.c index add0a4d48..d63ce2957 100644 --- a/lib/metadata/lv.c +++ b/lib/metadata/lv.c @@ -16,6 +16,28 @@ #include "lib.h" #include "metadata.h" #include "activate.h" +#include "toolcontext.h" + +char *lv_path_dup(struct dm_pool *mem, const struct logical_volume *lv) +{ + char *repstr; + size_t len; + + len = strlen(lv->vg->cmd->dev_dir) + strlen(lv->vg->name) + + strlen(lv->name) + 2; + + if (!(repstr = dm_pool_zalloc(mem, len))) { + log_error("dm_pool_alloc failed"); + return 0; + } + + if (dm_snprintf(repstr, len, "%s%s/%s", + lv->vg->cmd->dev_dir, lv->vg->name, lv->name) < 0) { + log_error("lvpath snprintf failed"); + return 0; + } + return repstr; +} char *lv_uuid_dup(const struct logical_volume *lv) { diff --git a/lib/metadata/lv.h b/lib/metadata/lv.h index 54ed7e094..eee281150 100644 --- a/lib/metadata/lv.h +++ b/lib/metadata/lv.h @@ -52,5 +52,6 @@ uint64_t lv_size(const struct logical_volume *lv); char *lv_attr_dup(struct dm_pool *mem, const struct logical_volume *lv); char *lv_uuid_dup(const struct logical_volume *lv); char *lv_tags_dup(const struct logical_volume *lv); +char *lv_path_dup(struct dm_pool *mem, const struct logical_volume *lv); #endif diff --git a/lib/report/properties.c b/lib/report/properties.c index eec4c61c3..8890e273e 100644 --- a/lib/report/properties.c +++ b/lib/report/properties.c @@ -101,7 +101,7 @@ GET_LV_STR_PROPERTY_FN(lv_uuid, lv_uuid_dup(lv)) #define _lv_uuid_set _not_implemented_set #define _lv_name_get _not_implemented_get #define _lv_name_set _not_implemented_set -#define _lv_path_get _not_implemented_get +GET_LV_STR_PROPERTY_FN(lv_path, lv_path_dup(lv->vg->vgmem, lv)) #define _lv_path_set _not_implemented_set GET_LV_STR_PROPERTY_FN(lv_attr, lv_attr_dup(lv->vg->vgmem, lv)) #define _lv_attr_set _not_implemented_set diff --git a/lib/report/report.c b/lib/report/report.c index 95f4550d2..32559b898 100644 --- a/lib/report/report.c +++ b/lib/report/report.c @@ -350,18 +350,9 @@ static int _lvpath_disp(struct dm_report *rh, struct dm_pool *mem, { const struct logical_volume *lv = (const struct logical_volume *) data; char *repstr; - size_t len; - len = strlen(lv->vg->cmd->dev_dir) + strlen(lv->vg->name) + strlen(lv->name) + 2; - if (!(repstr = dm_pool_zalloc(mem, len))) { - log_error("dm_pool_alloc failed"); + if (!(repstr = lv_path_dup(mem, lv))) return 0; - } - - if (dm_snprintf(repstr, len, "%s%s/%s", lv->vg->cmd->dev_dir, lv->vg->name, lv->name) < 0) { - log_error("lvpath snprintf failed"); - return 0; - } dm_report_field_set_value(field, repstr, NULL); -- 2.43.5