[svn-r15804] Purpose: Add option to h5ls to enable external link traversal.

Description: Added -E option to h5ls.  When set, this alows h5ls to enter
external files (currently only through an external link).  The -r option by
itself will no longer allow h5ls to traverse external links.

Tested: kagiso, linew, smirom (h5committest)
This commit is contained in:
Neil Fortner 2008-10-07 09:54:26 -05:00
parent c05f2a85a3
commit 698a6d8845
16 changed files with 68 additions and 11 deletions

View File

@ -1159,6 +1159,10 @@
./tools/testfiles/textlinksrc-1.ls
./tools/testfiles/textlinksrc-2.ls
./tools/testfiles/textlinksrc-3.ls
./tools/testfiles/textlinksrc-4.ls
./tools/testfiles/textlinksrc-5.ls
./tools/testfiles/textlinksrc-6.ls
./tools/testfiles/textlinksrc-7.ls
./tools/testfiles/textlinktar.h5
./tools/testfiles/tfamily.ddl
./tools/testfiles/tfamily00000.h5

View File

@ -61,6 +61,7 @@ static hbool_t label_g = FALSE; /* label compound values? */
static hbool_t string_g = FALSE; /* print 1-byte numbers as ASCII? */
static hbool_t fullname_g = FALSE; /* print full path names */
static hbool_t recursive_g = FALSE; /* recursive descent listing */
static hbool_t follow_elink_g = FALSE; /* follow external links */
static hbool_t grp_literal_g = FALSE; /* list group, not contents */
static hbool_t hexdump_g = FALSE; /* show data as raw hexadecimal */
static hbool_t show_errors_g = FALSE; /* print HDF5 error messages */
@ -115,6 +116,7 @@ usage: %s [OPTIONS] [OBJECTS...]\n\
-a, --address Print addresses for raw data\n\
-d, --data Print the values of datasets\n\
-e, --errors Show all HDF5 error reporting\n\
-E, --external Allow traversal into external files\n\
-f, --full Print full path names instead of base names\n\
-g, --group Show information about a group, not its contents\n\
-l, --label Label members of compound datasets\n\
@ -1906,10 +1908,14 @@ list_lnk(const char *name, const H5L_info_t *linfo, void *_iter)
if(*path != '/')
HDfputc('/', stdout);
HDfputs(path, stdout);
HDfputs("} ", stdout);
HDfputc('}', stdout);
/* Recurse through the external link */
if(recursive_g) {
if(follow_elink_g) {
hbool_t orig_grp_literal = grp_literal_g;
HDfputc(' ', stdout);
/* Check if we have already seen this elink */
if(elink_trav_visited(iter->elink_list, filename, path)) {
HDfputs("{Already Visited}\n", stdout);
@ -1927,11 +1933,19 @@ list_lnk(const char *name, const H5L_info_t *linfo, void *_iter)
* target of an external link */
iter->ext_target = TRUE;
/* Prevent recursive listing of external link target if
* recursive_g is off */
if(!recursive_g)
grp_literal_g = TRUE;
/* Recurse through the external link */
if(visit_obj(iter->fid, name, iter) < 0) {
HDfree(buf);
grp_literal_g = orig_grp_literal;
goto done;
}
grp_literal_g = orig_grp_literal;
}
else
HDfputc('\n', stdout);
@ -2174,6 +2188,8 @@ main(int argc, const char *argv[])
data_g = TRUE;
} else if(!HDstrcmp(argv[argno], "--errors")) {
show_errors_g = TRUE;
} else if(!HDstrcmp(argv[argno], "--external")) {
follow_elink_g = TRUE;
} else if(!HDstrcmp(argv[argno], "--full")) {
fullname_g = TRUE;
} else if(!HDstrcmp(argv[argno], "--group")) {
@ -2255,6 +2271,10 @@ main(int argc, const char *argv[])
show_errors_g = TRUE;
break;
case 'E': /* --external */
follow_elink_g = TRUE;
break;
case 'f': /* --full */
fullname_g = TRUE;
break;

View File

@ -129,9 +129,13 @@ TOOLTEST tslink-1.ls 0 -w80 -r tslink.h5
# test for displaying external and user-defined links
TOOLTEST textlink-1.ls 0 -w80 -r textlink.h5
TOOLTEST textlinksrc-1.ls 0 -w80 -r textlinksrc.h5
TOOLTEST textlinksrc-2.ls 0 -w80 -rv textlinksrc.h5/ext_link5
TOOLTEST textlinksrc-3.ls 0 -w80 -r textlinksrc.h5/ext_link1
TOOLTEST textlinksrc-1.ls 0 -w80 -Er textlinksrc.h5
TOOLTEST textlinksrc-2.ls 0 -w80 -Erv textlinksrc.h5/ext_link5
TOOLTEST textlinksrc-3.ls 0 -w80 -Er textlinksrc.h5/ext_link1
TOOLTEST textlinksrc-4.ls 0 -w80 -r textlinksrc.h5
TOOLTEST textlinksrc-5.ls 0 -w80 -r textlinksrc.h5/ext_link1
TOOLTEST textlinksrc-6.ls 0 -w80 -E textlinksrc.h5
TOOLTEST textlinksrc-7.ls 0 -w80 -E textlinksrc.h5/ext_link1
TOOLTEST tudlink-1.ls 0 -w80 -r tudlink.h5
# tests for hard links

View File

@ -7,6 +7,7 @@ usage: h5ls [OPTIONS] [OBJECTS...]
-a, --address Print addresses for raw data
-d, --data Print the values of datasets
-e, --errors Show all HDF5 error reporting
-E, --external Allow traversal into external files
-f, --full Print full path names instead of base names
-g, --group Show information about a group, not its contents
-l, --label Label members of compound datasets

View File

@ -7,6 +7,7 @@ usage: h5ls [OPTIONS] [OBJECTS...]
-a, --address Print addresses for raw data
-d, --data Print the values of datasets
-e, --errors Show all HDF5 error reporting
-E, --external Allow traversal into external files
-f, --full Print full path names instead of base names
-g, --group Show information about a group, not its contents
-l, --label Label members of compound datasets

View File

@ -7,6 +7,7 @@ usage: h5ls [OPTIONS] [OBJECTS...]
-a, --address Print addresses for raw data
-d, --data Print the values of datasets
-e, --errors Show all HDF5 error reporting
-E, --external Allow traversal into external files
-f, --full Print full path names instead of base names
-g, --group Show information about a group, not its contents
-l, --label Label members of compound datasets

View File

@ -16,7 +16,7 @@
Data:
(0) 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19
/g1/g1.2 Group
/g1/g1.2/extlink External Link {somefile//somepath} {**NOT FOUND**}
/g1/g1.2/extlink External Link {somefile//somepath}
/g1/g1.2/g1.2.1 Group
/g1/g1.2/g1.2.1/slink Soft Link {somevalue}
/g2 Group

View File

@ -2,5 +2,5 @@
output for 'h5ls -w80 -r textlink.h5'
#############################
/ Group
/extlink1 External Link {filename//objname} {**NOT FOUND**}
/extlink2 External Link {anotherfile//anotherobj} {**NOT FOUND**}
/extlink1 External Link {filename//objname}
/extlink2 External Link {anotherfile//anotherobj}

View File

@ -1,5 +1,5 @@
#############################
output for 'h5ls -w80 -r textlinksrc.h5'
output for 'h5ls -w80 -Er textlinksrc.h5'
#############################
/ Group
/ext_link1 External Link {textlinktar.h5//group} {Group}

View File

@ -1,5 +1,5 @@
#############################
output for 'h5ls -w80 -rv textlinksrc.h5/ext_link5'
output for 'h5ls -w80 -Erv textlinksrc.h5/ext_link5'
#############################
Opened "textlinksrc.h5" with sec2 driver.
ext_link5 External Link {textlinktar.h5//empty_group} {Group

View File

@ -1,5 +1,5 @@
#############################
output for 'h5ls -w80 -r textlinksrc.h5/ext_link1'
output for 'h5ls -w80 -Er textlinksrc.h5/ext_link1'
#############################
ext_link1 External Link {textlinktar.h5//group} {Group}
/dset Dataset {6}

View File

@ -0,0 +1,9 @@
#############################
output for 'h5ls -w80 -r textlinksrc.h5'
#############################
/ Group
/ext_link1 External Link {textlinktar.h5//group}
/ext_link2 External Link {textlinktar.h5//dset}
/ext_link3 External Link {textlinktar.h5//type}
/ext_link4 External Link {textlinktar.h5//group/elink_t2}
/ext_link5 External Link {textlinktar.h5//empty_group}

View File

@ -0,0 +1,4 @@
#############################
output for 'h5ls -w80 -r textlinksrc.h5/ext_link1'
#############################
ext_link1 External Link {textlinktar.h5//group}

View File

@ -0,0 +1,8 @@
#############################
output for 'h5ls -w80 -E textlinksrc.h5'
#############################
ext_link1 External Link {textlinktar.h5//group} {Group}
ext_link2 External Link {textlinktar.h5//dset} {Dataset {6}}
ext_link3 External Link {textlinktar.h5//type} {Type}
ext_link4 External Link {textlinktar.h5//group/elink_t2} {**NOT FOUND**}
ext_link5 External Link {textlinktar.h5//empty_group} {Group}

View File

@ -0,0 +1,4 @@
#############################
output for 'h5ls -w80 -E textlinksrc.h5/ext_link1'
#############################
ext_link1 External Link {textlinktar.h5//group} {Group}

View File

@ -9,6 +9,7 @@ usage: h5ls [OPTIONS] [OBJECTS...]
-a, --address Print addresses for raw data
-d, --data Print the values of datasets
-e, --errors Show all HDF5 error reporting
-E, --external Allow traversal into external files
-f, --full Print full path names instead of base names
-g, --group Show information about a group, not its contents
-l, --label Label members of compound datasets