On 12/13/2012 07:17 PM, Yehuda Sadeh wrote: > On Thu, Dec 13, 2012 at 7:37 AM, Stratos Psomadakis <[email protected]> wrote: >> Signed-off-by: Stratos Psomadakis <[email protected]> >> --- >> Hi Josh, >> >> This patch adds the '--json' flag to enable dumping the showmapped output in > I think that it should be "--format=json" rather than --json. This > will make it more in line with other tools. Also, then you could have > the unpopular --format=xml.
Hi,
the problem is that --format is arleady used in rbd (to select the rbd
image format). So, you could either use --output-format= for
plain/json/xml output (but then you would be inconsistent wrt the other
tools), or change --format to --image-format (or something like that),
and use --format to select the output formatting.
>
>> json format (as you suggested). I'm not sure if any other rbd subcommands
>> could
>> make use of this flag (so the patch is showmapped-specific atm).
>>
>> Comments?
>>
>> Thanks,
>> Stratos
>>
>> man/rbd.8 | 5 +++++
>> src/rbd.cc | 54 +++++++++++++++++++++++++++++++++++++++++-------------
>> 2 files changed, 46 insertions(+), 13 deletions(-)
>>
>> diff --git a/man/rbd.8 b/man/rbd.8
>> index 6004244..7bf4c39 100644
>> --- a/man/rbd.8
>> +++ b/man/rbd.8
>> @@ -132,6 +132,11 @@ be open from more than one client at once, like during
>> live migration of a virtual machine, or for use underneath
>> a clustered filesystem.
>> .UNINDENT
>> +.INDENT 0.0
>> +.TP
>> +.B \-\-json
>> +Dump output in json format (currently used only by showmapped).
>> +.UNINDENT
>> .SH COMMANDS
>> .INDENT 0.0
>> .TP
>> diff --git a/src/rbd.cc b/src/rbd.cc
>> index 3db8978..82a72ba 100644
>> --- a/src/rbd.cc
>> +++ b/src/rbd.cc
>> @@ -47,6 +47,8 @@
>> #include "include/rbd_types.h"
>> #include "common/TextTable.h"
>>
>> +#include "common/Formatter.h"
>> +
>> #if defined(__linux__)
>> #include <linux/fs.h>
>> #endif
>> @@ -126,7 +128,8 @@ void usage()
>> " format 2 supports cloning\n"
>> " --id <username> rados user (without 'client.' prefix) to
>> authenticate as\n"
>> " --keyfile <path> file containing secret key for use with
>> cephx\n"
>> -" --shared <tag> take a shared (rather than exclusive)
>> lock\n";
>> +" --shared <tag> take a shared (rather than exclusive)
>> lock\n"
>> +" --json dump output in json format (currently used
>> only by showmapped)\n";
>> }
>>
>> static string feature_str(uint64_t features)
>> @@ -1198,7 +1201,7 @@ void do_closedir(DIR *dp)
>> closedir(dp);
>> }
>>
>> -static int do_kernel_showmapped()
>> +static int do_kernel_showmapped(bool dump_json)
>> {
>> int r;
>> bool have_output = false;
>> @@ -1220,12 +1223,18 @@ static int do_kernel_showmapped()
>> return r;
>> }
>>
>> + JSONFormatter jsf(false);
>> TextTable tbl;
>> - tbl.define_column("id", TextTable::LEFT, TextTable::LEFT);
>> - tbl.define_column("pool", TextTable::LEFT, TextTable::LEFT);
>> - tbl.define_column("image", TextTable::LEFT, TextTable::LEFT);
>> - tbl.define_column("snap", TextTable::LEFT, TextTable::LEFT);
>> - tbl.define_column("device", TextTable::LEFT, TextTable::LEFT);
>> + if(dump_json == false) {
>> + tbl.define_column("id", TextTable::LEFT, TextTable::LEFT);
>> + tbl.define_column("pool", TextTable::LEFT, TextTable::LEFT);
>> + tbl.define_column("image", TextTable::LEFT, TextTable::LEFT);
>> + tbl.define_column("snap", TextTable::LEFT, TextTable::LEFT);
>> + tbl.define_column("device", TextTable::LEFT, TextTable::LEFT);
>> + }
>> + else {
>> + jsf.open_object_section("devices");
>> + }
>>
>> do {
>> if (strcmp(dent->d_name, ".") == 0 || strcmp(dent->d_name, "..") == 0)
>> @@ -1262,13 +1271,30 @@ static int do_kernel_showmapped()
>> << cpp_strerror(-r) << std::endl;
>> continue;
>> }
>> -
>> - tbl << dent->d_name << pool << name << snap << dev << TextTable::endrow;
>> +
>> + if (dump_json == false) {
>> + tbl << dent->d_name << pool << name << snap << dev <<
>> TextTable::endrow;
>> + }
>> + else {
>> + jsf.open_object_section(dent->d_name);
>> + jsf.dump_string("pool", pool);
>> + jsf.dump_string("name", name);
>> + jsf.dump_string("snap", snap);
>> + jsf.dump_string("device", dev);
>> + jsf.close_section();
>> + }
>> have_output = true;
>>
>> } while ((dent = readdir(device_dir.get())));
>> - if (have_output)
>> - cout << tbl;
>> +
>> + if (dump_json == false) {
>> + if (have_output)
>> + cout << tbl;
>> + }
>> + else {
>> + jsf.close_section();
>> + jsf.flush(cout);
>> + }
>>
>> return 0;
>> }
>> @@ -1505,7 +1531,7 @@ int main(int argc, const char **argv)
>> const char *poolname = NULL;
>> uint64_t size = 0; // in bytes
>> int order = 0;
>> - bool format_specified = false;
>> + bool format_specified = false, dump_json = false;
>> int format = 1;
>> uint64_t features = RBD_FEATURE_LAYERING;
>> const char *imgname = NULL, *snapname = NULL, *destname = NULL,
>> @@ -1579,6 +1605,8 @@ int main(int argc, const char **argv)
>> imgname = strdup(val.c_str());
>> } else if (ceph_argparse_witharg(args, i, &val, "--shared", (char
>> *)NULL)) {
>> lock_tag = strdup(val.c_str());
>> + } else if (ceph_argparse_flag(args, i, "--json", (char *) NULL)) {
>> + dump_json = true;
>> } else {
>> ++i;
>> }
>> @@ -2130,7 +2158,7 @@ if (!set_conf_param(v, p1, p2, p3)) { \
>> break;
>>
>> case OPT_SHOWMAPPED:
>> - r = do_kernel_showmapped();
>> + r = do_kernel_showmapped(dump_json);
>> if (r < 0) {
>> cerr << "rbd: showmapped failed: " << cpp_strerror(-r) << std::endl;
>> return EXIT_FAILURE;
>> --
>> 1.7.10.4
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
>> the body of a message to [email protected]
>> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
Stratos Psomadakis
<[email protected]>
signature.asc
Description: OpenPGP digital signature
