[svn-r13589]

h5repack code cleaning (required reconfigure)

tested: linux (32, 64, parallel), solaris
This commit is contained in:
Pedro Vicente Nunes 2007-04-04 15:25:42 -05:00
parent 3431f74c43
commit 1d312bff80
17 changed files with 261 additions and 280 deletions

View File

@ -951,7 +951,6 @@
./tools/lib/h5diff_util.c
./tools/lib/h5trav.c
./tools/lib/h5trav.h
./tools/lib/h5trav_table.c
./tools/lib/h5tools.c
./tools/lib/h5tools.h
./tools/lib/h5tools_filters.c

View File

@ -412,6 +412,8 @@ H5Lunpack_elink_val(const void *_ext_linkval, size_t link_size,
herr_t ret_value = SUCCEED; /* Return value */
FUNC_ENTER_API(H5Lunpack_elink_val, FAIL)
H5TRACE5("e", "*xz*Iu**s**s", _ext_linkval, link_size, flags, filename,
obj_path);
/* Sanity check external link buffer */
if(ext_linkval == NULL )

View File

@ -15,8 +15,8 @@
#include <stdlib.h>
#include <string.h>
#include "h5tools_utils.h"
#include "h5repack.h"
#include "h5tools_utils.h"
extern char *progname;

View File

@ -19,8 +19,7 @@
#include "hdf5.h"
#include "h5trav.h"
#include "h5diff.h"
#include "h5tools.h"
#define H5FOPENERROR "unable to open file"

View File

@ -16,10 +16,10 @@
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "h5repack.h"
#include "H5private.h"
#include "h5tools.h"
#include "h5tools_utils.h"
#include "h5repack.h"
extern char *progname;

View File

@ -13,9 +13,8 @@
* access to either file, you may request a copy from help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include "hdf5.h"
#include "h5test.h"
#include "h5repack.h"
#include "h5test.h"
/*-------------------------------------------------------------------------

View File

@ -16,9 +16,11 @@
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "h5repack.h"
#include "H5private.h"
#include "h5tools_utils.h"
#include "h5repack.h"
#include "h5diff.h"
#include "h5tools.h"
extern char *progname;

View File

@ -15,8 +15,8 @@
#include <stdlib.h>
#include <string.h>
#include "h5tools_utils.h"
#include "h5repack.h"
#include "h5tools_utils.h"
extern char *progname;

View File

@ -17,8 +17,8 @@
#include <string.h>
#include <stdio.h>
#include <ctype.h>
#include "h5tools_utils.h"
#include "h5repack.h"
#include "h5tools_utils.h"
extern char *progname;

View File

@ -18,8 +18,11 @@
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include "H5private.h"
#include "h5repack.h"
#include "H5private.h"
#include "h5diff.h"
#include "h5tools.h"
/*-------------------------------------------------------------------------
* local functions

View File

@ -13,10 +13,9 @@
* access to either file, you may request a copy from help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include "hdf5.h"
#include "h5repack.h"
#include "h5test.h"
#include "h5tools_utils.h"
#include "h5repack.h"
extern char *progname;

View File

@ -13,11 +13,10 @@
* access to either file, you may request a copy from help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include "hdf5.h"
#include "h5test.h"
#include "h5repack.h"
#include "h5test.h"
#include "h5diff.h"
#include "h5tools.h"
#define GOERROR {H5_FAILED(); goto error;}

View File

@ -14,9 +14,8 @@
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include <stdio.h>
#include "hdf5.h"
#include "h5test.h"
#include "h5repack.h"
#include "h5test.h"

View File

@ -28,7 +28,7 @@ noinst_LTLIBRARIES=libh5tools.la
libh5tools_la_SOURCES=h5tools.c h5tools_str.c h5tools_utils.c h5diff.c \
h5diff_array.c h5diff_attr.c h5diff_dset.c h5diff_util.c h5trav.c \
h5trav_table.c h5tools_filters.c h5tools_ref.c h5tools_type.c
h5tools_filters.c h5tools_ref.c h5tools_type.c
# Test program. Link using libhdf5 and libh5tools
TEST_PROG=talign

View File

@ -69,8 +69,8 @@ LTLIBRARIES = $(noinst_LTLIBRARIES)
libh5tools_la_LIBADD =
am_libh5tools_la_OBJECTS = h5tools.lo h5tools_str.lo h5tools_utils.lo \
h5diff.lo h5diff_array.lo h5diff_attr.lo h5diff_dset.lo \
h5diff_util.lo h5trav.lo h5trav_table.lo h5tools_filters.lo \
h5tools_ref.lo h5tools_type.lo
h5diff_util.lo h5trav.lo h5tools_filters.lo h5tools_ref.lo \
h5tools_type.lo
libh5tools_la_OBJECTS = $(am_libh5tools_la_OBJECTS)
am__EXEEXT_1 = talign$(EXEEXT)
talign_SOURCES = talign.c
@ -338,7 +338,7 @@ INCLUDES = -I$(top_srcdir)/src
noinst_LTLIBRARIES = libh5tools.la
libh5tools_la_SOURCES = h5tools.c h5tools_str.c h5tools_utils.c h5diff.c \
h5diff_array.c h5diff_attr.c h5diff_dset.c h5diff_util.c h5trav.c \
h5trav_table.c h5tools_filters.c h5tools_ref.c h5tools_type.c
h5tools_filters.c h5tools_ref.c h5tools_type.c
# Test program. Link using libhdf5 and libh5tools
@ -437,7 +437,6 @@ distclean-compile:
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/h5tools_type.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/h5tools_utils.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/h5trav.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/h5trav_table.Plo@am__quote@
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/talign.Po@am__quote@
.c.o:

View File

@ -715,3 +715,241 @@ static int traverse( hid_t loc_id,
return inserted_objs;
}
/*-------------------------------------------------------------------------
* Function: trav_table_search
*
* Purpose: Search in the table for OBJNO
*
* Return: index of object in table
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
int trav_table_search(haddr_t objno, trav_table_t *table )
{
unsigned int i;
for (i = 0; i < table->nobjs; i++)
if (table->objs[i].objno == objno)
return i;
return -1;
}
/*-------------------------------------------------------------------------
* Function: trav_table_add
*
* Purpose: Add OBJNO, NAME and TYPE of object to table
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_add(haddr_t objno,
char *name,
H5G_obj_t type,
trav_table_t *table)
{
unsigned int i;
if (table->nobjs == table->size) {
table->size *= 2;
table->objs =
(trav_obj_t*)HDrealloc(table->objs, table->size * sizeof(trav_obj_t));
for (i = table->nobjs; i < table->size; i++) {
table->objs[i].objno = 0;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
table->objs[i].displayed = 0;
table->objs[i].type = H5G_UNKNOWN;
table->objs[i].name = NULL;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
table->objs[i].sizelinks = 0;
}
}
i = table->nobjs++;
table->objs[i].objno = objno;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
HDfree(table->objs[i].name);
table->objs[i].name = (char *)HDstrdup(name);
table->objs[i].type = type;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
}
/*-------------------------------------------------------------------------
* Function: trav_table_addflags
*
* Purpose: Add FLAGS, NAME and TYPE of object to table
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_addflags(unsigned *flags,
char *name,
H5G_obj_t type,
trav_table_t *table)
{
unsigned int i;
if (table->nobjs == table->size) {
table->size *= 2;
table->objs =
(trav_obj_t*)HDrealloc(table->objs, table->size * sizeof(trav_obj_t));
for (i = table->nobjs; i < table->size; i++) {
table->objs[i].objno = 0;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
table->objs[i].displayed = 0;
table->objs[i].type = H5G_UNKNOWN;
table->objs[i].name = NULL;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
table->objs[i].sizelinks = 0;
}
}
i = table->nobjs++;
table->objs[i].objno = 0;
table->objs[i].flags[0] = flags[0];
table->objs[i].flags[1] = flags[1];
HDfree(table->objs[i].name);
table->objs[i].name = (char *)HDstrdup(name);
table->objs[i].type = type;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
}
/*-------------------------------------------------------------------------
* Function: trav_table_init
*
* Purpose: Initialize the table
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_init( trav_table_t **tbl )
{
unsigned int i;
trav_table_t* table = (trav_table_t*) HDmalloc(sizeof(trav_table_t));
table->size = 20;
table->nobjs = 0;
table->objs =
(trav_obj_t*)HDmalloc(table->size * sizeof(trav_obj_t));
for (i = 0; i < table->size; i++) {
table->objs[i].objno = 0;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
table->objs[i].displayed = 0;
table->objs[i].type = H5G_UNKNOWN;
table->objs[i].name = NULL;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
table->objs[i].sizelinks = 0;
}
*tbl = table;
}
/*-------------------------------------------------------------------------
* Function: trav_table_free
*
* Purpose: free table memory
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_free( trav_table_t *table )
{
unsigned int i, j;
for ( i = 0; i < table->nobjs; i++)
{
HDfree( table->objs[i].name );
if (table->objs[i].nlinks)
{
for ( j=0; j<table->objs[i].nlinks; j++)
HDfree( table->objs[i].links[j].new_name );
HDfree(table->objs[i].links);
}
}
HDfree(table->objs);
HDfree(table);
}
/*-------------------------------------------------------------------------
* Function: trav_table_addlink
*
* Purpose: Add a hardlink name to the object
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: December 17, 2003
*
*-------------------------------------------------------------------------
*/
void trav_table_addlink(trav_table_t *table,
int j /* the object index */,
char *path )
{
unsigned int k;
/* already inserted */
if (strcmp(table->objs[j].name,path)==0)
return;
/* allocate space if necessary */
if (table->objs[j].nlinks == (unsigned)table->objs[j].sizelinks) {
table->objs[j].sizelinks += 2;
table->objs[j].links =
(trav_link_t*)HDrealloc(table->objs[j].links,
table->objs[j].sizelinks * sizeof(trav_link_t));
}
/* insert it */
k=table->objs[j].nlinks++;
table->objs[j].links[k].new_name = (char*)HDstrdup(path);
}

View File

@ -1,257 +0,0 @@
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Copyright by The HDF Group. *
* Copyright by the Board of Trustees of the University of Illinois. *
* All rights reserved. *
* *
* This file is part of HDF5. The full HDF5 copyright notice, including *
* terms governing use, modification, and redistribution, is contained in *
* the files COPYING and Copyright.html. COPYING can be found at the root *
* of the source code distribution tree; Copyright.html can be found at the *
* root level of an installed copy of the electronic HDF5 document set and *
* is linked from the top-level documents page. It can also be found at *
* http://hdfgroup.org/HDF5/doc/Copyright.html. If you do not have *
* access to either file, you may request a copy from help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include "h5trav.h"
#include "H5private.h"
/*-------------------------------------------------------------------------
* Function: trav_table_search
*
* Purpose: Search in the table for OBJNO
*
* Return: index of object in table
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
int trav_table_search(haddr_t objno, trav_table_t *table )
{
unsigned int i;
for (i = 0; i < table->nobjs; i++)
if (table->objs[i].objno == objno)
return i;
return -1;
}
/*-------------------------------------------------------------------------
* Function: trav_table_add
*
* Purpose: Add OBJNO, NAME and TYPE of object to table
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_add(haddr_t objno,
char *name,
H5G_obj_t type,
trav_table_t *table)
{
unsigned int i;
if (table->nobjs == table->size) {
table->size *= 2;
table->objs =
(trav_obj_t*)HDrealloc(table->objs, table->size * sizeof(trav_obj_t));
for (i = table->nobjs; i < table->size; i++) {
table->objs[i].objno = 0;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
table->objs[i].displayed = 0;
table->objs[i].type = H5G_UNKNOWN;
table->objs[i].name = NULL;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
table->objs[i].sizelinks = 0;
}
}
i = table->nobjs++;
table->objs[i].objno = objno;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
HDfree(table->objs[i].name);
table->objs[i].name = (char *)HDstrdup(name);
table->objs[i].type = type;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
}
/*-------------------------------------------------------------------------
* Function: trav_table_addflags
*
* Purpose: Add FLAGS, NAME and TYPE of object to table
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_addflags(unsigned *flags,
char *name,
H5G_obj_t type,
trav_table_t *table)
{
unsigned int i;
if (table->nobjs == table->size) {
table->size *= 2;
table->objs =
(trav_obj_t*)HDrealloc(table->objs, table->size * sizeof(trav_obj_t));
for (i = table->nobjs; i < table->size; i++) {
table->objs[i].objno = 0;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
table->objs[i].displayed = 0;
table->objs[i].type = H5G_UNKNOWN;
table->objs[i].name = NULL;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
table->objs[i].sizelinks = 0;
}
}
i = table->nobjs++;
table->objs[i].objno = 0;
table->objs[i].flags[0] = flags[0];
table->objs[i].flags[1] = flags[1];
HDfree(table->objs[i].name);
table->objs[i].name = (char *)HDstrdup(name);
table->objs[i].type = type;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
}
/*-------------------------------------------------------------------------
* Function: trav_table_init
*
* Purpose: Initialize the table
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_init( trav_table_t **tbl )
{
unsigned int i;
trav_table_t* table = (trav_table_t*) HDmalloc(sizeof(trav_table_t));
table->size = 20;
table->nobjs = 0;
table->objs =
(trav_obj_t*)HDmalloc(table->size * sizeof(trav_obj_t));
for (i = 0; i < table->size; i++) {
table->objs[i].objno = 0;
table->objs[i].flags[0] = table->objs[i].flags[1] = 0;
table->objs[i].displayed = 0;
table->objs[i].type = H5G_UNKNOWN;
table->objs[i].name = NULL;
table->objs[i].links = NULL;
table->objs[i].nlinks = 0;
table->objs[i].sizelinks = 0;
}
*tbl = table;
}
/*-------------------------------------------------------------------------
* Function: trav_table_free
*
* Purpose: free table memory
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: November 4, 2002
*
*-------------------------------------------------------------------------
*/
void trav_table_free( trav_table_t *table )
{
unsigned int i, j;
for ( i = 0; i < table->nobjs; i++)
{
HDfree( table->objs[i].name );
if (table->objs[i].nlinks)
{
for ( j=0; j<table->objs[i].nlinks; j++)
HDfree( table->objs[i].links[j].new_name );
HDfree(table->objs[i].links);
}
}
HDfree(table->objs);
HDfree(table);
}
/*-------------------------------------------------------------------------
* Function: trav_table_addlink
*
* Purpose: Add a hardlink name to the object
*
* Return: void
*
* Programmer: Pedro Vicente, pvn@ncsa.uiuc.edu
*
* Date: December 17, 2003
*
*-------------------------------------------------------------------------
*/
void trav_table_addlink(trav_table_t *table,
int j /* the object index */,
char *path )
{
unsigned int k;
/* already inserted */
if (strcmp(table->objs[j].name,path)==0)
return;
/* allocate space if necessary */
if (table->objs[j].nlinks == (unsigned)table->objs[j].sizelinks) {
table->objs[j].sizelinks += 2;
table->objs[j].links =
(trav_link_t*)HDrealloc(table->objs[j].links,
table->objs[j].sizelinks * sizeof(trav_link_t));
}
/* insert it */
k=table->objs[j].nlinks++;
table->objs[j].links[k].new_name = (char*)HDstrdup(path);
}