summaryrefslogtreecommitdiffstats
path: root/tools/lib
diff options
context:
space:
mode:
Diffstat (limited to 'tools/lib')
-rw-r--r--tools/lib/h5diff.c34
-rw-r--r--tools/lib/h5diff.h12
-rw-r--r--tools/lib/h5diff_array.c362
-rw-r--r--tools/lib/h5diff_dset.c110
-rw-r--r--tools/lib/h5trav.c4
5 files changed, 271 insertions, 251 deletions
diff --git a/tools/lib/h5diff.c b/tools/lib/h5diff.c
index 8a013c7..9f20f4a 100644
--- a/tools/lib/h5diff.c
+++ b/tools/lib/h5diff.c
@@ -39,7 +39,7 @@ int h5diff(const char *fname1,
const char *fname2,
const char *objname1,
const char *objname2,
- diff_opt_t options)
+ diff_opt_t *options)
{
int nobjects1, nobjects2;
trav_info_t *info1=NULL;
@@ -148,7 +148,7 @@ int diff_match( hid_t file1_id,
hid_t file2_id,
int nobjects2,
trav_info_t *info2,
- diff_opt_t options )
+ diff_opt_t *options )
{
int more_names_exist = (nobjects1>0 && nobjects2>0) ? 1 : 0;
trav_table_t *table=NULL;
@@ -223,7 +223,7 @@ int diff_match( hid_t file1_id,
*-------------------------------------------------------------------------
*/
- if (options.verbose)
+ if (options->verbose)
{
printf("\n");
printf("file1 file2\n");
@@ -281,7 +281,7 @@ int diff_compare( hid_t file1_id,
const char *obj2_name,
int nobjects2,
trav_info_t *info2,
- diff_opt_t options )
+ diff_opt_t *options )
{
int f1=0, f2=0;
@@ -308,7 +308,7 @@ int diff_compare( hid_t file1_id,
obj2_name=info2[j].name;
/* objects are not the same type */
- if ( info1[i].type != info2[j].type )
+ if ( info1[i].type != info2[j].type && options->verbose)
{
printf("Comparison not supported\n");
printf("<%s> is of type %s and <%s> is of type %s\n",
@@ -345,7 +345,7 @@ int diff( hid_t file1_id,
const char *obj1_name,
hid_t file2_id,
const char *obj2_name,
- diff_opt_t options,
+ diff_opt_t *options,
int type )
{
int nfound=0;
@@ -357,14 +357,16 @@ int diff( hid_t file1_id,
break;
default:
- printf("Comparison not supported\n");
- printf("<%s> is of type %s and <%s> is of type %s\n",
- obj1_name, get_type(type),
- obj2_name, get_type(type) );
+ if (options->verbose) {
+ printf("Comparison not supported\n");
+ printf("<%s> is of type %s and <%s> is of type %s\n",
+ obj1_name, get_type(type),
+ obj2_name, get_type(type) );
+ }
break;
}
- if (options.verbose)
+ if (options->verbose)
printf("\n");
return nfound;
}
@@ -398,19 +400,19 @@ void diff_list( const char *filename, int nobjects, trav_info_t *info )
switch ( info[i].type )
{
case H5G_GROUP:
- printf("%s %20s\n", info[i].name, "group" );
+ printf(" %-10s %s\n", "group", info[i].name );
break;
case H5G_DATASET:
- printf("%s %20s\n", info[i].name, "dataset" );
+ printf(" %-10s %s\n", "dataset", info[i].name );
break;
case H5G_TYPE:
- printf("%s %20s\n", info[i].name, "datatype" );
+ printf(" %-10s %s\n", "datatype", info[i].name );
break;
case H5G_LINK:
- printf("%s %20s\n", info[i].name, "link" );
+ printf(" %-10s %s\n", "link", info[i].name );
break;
default:
- printf("%s %20s\n", info[i].name, "User defined object" );
+ printf(" %-10s %s\n", "User defined object", info[i].name );
break;
}
}
diff --git a/tools/lib/h5diff.h b/tools/lib/h5diff.h
index 3313765..e9230bc 100644
--- a/tools/lib/h5diff.h
+++ b/tools/lib/h5diff.h
@@ -74,7 +74,7 @@ int h5diff(const char *fname1,
const char *fname2,
const char *objname1,
const char *objname2,
- diff_opt_t options);
+ diff_opt_t *options);
#ifdef __cplusplus
@@ -93,13 +93,13 @@ int diff_dataset( hid_t file1_id,
hid_t file2_id,
const char *obj1_name,
const char *obj2_name,
- diff_opt_t options );
+ diff_opt_t *options );
int diff( hid_t file1_id,
const char *obj1_name,
hid_t file2_id,
const char *obj2_name,
- diff_opt_t options,
+ diff_opt_t *options,
int type );
int diff_compare( hid_t file1_id,
@@ -112,7 +112,7 @@ int diff_compare( hid_t file1_id,
const char *obj2_name,
int nobjects2,
trav_info_t *info2,
- diff_opt_t options );
+ diff_opt_t *options );
int diff_match( hid_t file1_id,
int nobjects1,
@@ -120,14 +120,14 @@ int diff_match( hid_t file1_id,
hid_t file2_id,
int nobjects2,
trav_info_t *info2,
- diff_opt_t options );
+ diff_opt_t *options );
int diff_array( void *buf1,
void *buf2,
hsize_t tot_cnt,
int rank,
hsize_t *dims,
- diff_opt_t options,
+ diff_opt_t *options,
const char *obj1,
const char *obj2,
hid_t m_type );
diff --git a/tools/lib/h5diff_array.c b/tools/lib/h5diff_array.c
index f9518de..c47a835 100644
--- a/tools/lib/h5diff_array.c
+++ b/tools/lib/h5diff_array.c
@@ -39,7 +39,7 @@ int diff_array( void *buf1,
hsize_t tot_cnt,
int rank,
hsize_t *dims,
- diff_opt_t options,
+ diff_opt_t *options,
const char *obj1,
const char *obj2,
hid_t m_type )
@@ -91,13 +91,13 @@ int diff_array( void *buf1,
memcpy(&temp1_char, _buf1, sizeof(char));
memcpy(&temp2_char, _buf2, sizeof(char));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (abs(temp1_char-temp2_char) > options.delta)
+ if (abs(temp1_char-temp2_char) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -107,13 +107,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_char!=0 && abs(1-temp2_char/temp1_char) > options.percent )
+ if ( temp1_char!=0 && abs(1-temp2_char/temp1_char) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -124,14 +124,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_char!=0 && abs(1-temp2_char/temp1_char) > options.percent &&
- abs(temp1_char-temp2_char) > options.delta )
+ if ( temp1_char!=0 && abs(1-temp2_char/temp1_char) > options->percent &&
+ abs(temp1_char-temp2_char) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -143,9 +143,9 @@ int diff_array( void *buf1,
}
else if (temp1_char != temp2_char)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -175,13 +175,13 @@ int diff_array( void *buf1,
memcpy(&temp1_uchar, _buf1, sizeof(unsigned char));
memcpy(&temp2_uchar, _buf2, sizeof(unsigned char));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (abs(temp1_uchar-temp2_uchar) > options.delta)
+ if (abs(temp1_uchar-temp2_uchar) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -191,13 +191,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_uchar!=0 && abs(1-temp2_uchar/temp1_uchar) > options.percent )
+ if ( temp1_uchar!=0 && abs(1-temp2_uchar/temp1_uchar) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -208,14 +208,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_uchar!=0 && abs(1-temp2_uchar/temp1_uchar) > options.percent &&
- abs(temp1_uchar-temp2_uchar) > options.delta )
+ if ( temp1_uchar!=0 && abs(1-temp2_uchar/temp1_uchar) > options->percent &&
+ abs(temp1_uchar-temp2_uchar) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -227,9 +227,9 @@ int diff_array( void *buf1,
}
else if (temp1_uchar != temp2_uchar)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -260,13 +260,13 @@ int diff_array( void *buf1,
memcpy(&temp1_short, _buf1, sizeof(short));
memcpy(&temp2_short, _buf2, sizeof(short));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (abs(temp1_short-temp2_short) > options.delta)
+ if (abs(temp1_short-temp2_short) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -276,13 +276,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_short!=0 && abs(1-temp2_short/temp1_short) > options.percent )
+ if ( temp1_short!=0 && abs(1-temp2_short/temp1_short) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -293,14 +293,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_short!=0 && abs(1-temp2_short/temp1_short) > options.percent &&
- abs(temp1_short-temp2_short) > options.delta )
+ if ( temp1_short!=0 && abs(1-temp2_short/temp1_short) > options->percent &&
+ abs(temp1_short-temp2_short) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -312,9 +312,9 @@ int diff_array( void *buf1,
}
else if (temp1_short != temp2_short)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -344,13 +344,13 @@ int diff_array( void *buf1,
memcpy(&temp1_ushort, _buf1, sizeof(unsigned short));
memcpy(&temp2_ushort, _buf2, sizeof(unsigned short));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (abs(temp1_ushort-temp2_ushort) > options.delta)
+ if (abs(temp1_ushort-temp2_ushort) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -360,13 +360,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_ushort!=0 && abs(1-temp2_ushort/temp1_ushort) > options.percent )
+ if ( temp1_ushort!=0 && abs(1-temp2_ushort/temp1_ushort) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -377,14 +377,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_ushort!=0 && abs(1-temp2_ushort/temp1_ushort) > options.percent &&
- abs(temp1_ushort-temp2_ushort) > options.delta )
+ if ( temp1_ushort!=0 && abs(1-temp2_ushort/temp1_ushort) > options->percent &&
+ abs(temp1_ushort-temp2_ushort) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -396,9 +396,9 @@ int diff_array( void *buf1,
}
else if (temp1_ushort != temp2_ushort)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -429,13 +429,13 @@ int diff_array( void *buf1,
memcpy(&temp1_int, _buf1, sizeof(int));
memcpy(&temp2_int, _buf2, sizeof(int));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (abs(temp1_int-temp2_int) > options.delta)
+ if (abs(temp1_int-temp2_int) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -445,13 +445,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_int!=0 && abs(1-temp2_int/temp1_int) > options.percent )
+ if ( temp1_int!=0 && abs(1-temp2_int/temp1_int) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -462,14 +462,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_int!=0 && abs(1-temp2_int/temp1_int) > options.percent &&
- abs(temp1_int-temp2_int) > options.delta )
+ if ( temp1_int!=0 && abs(1-temp2_int/temp1_int) > options->percent &&
+ abs(temp1_int-temp2_int) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -481,9 +481,9 @@ int diff_array( void *buf1,
}
else if (temp1_int != temp2_int)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -514,13 +514,13 @@ int diff_array( void *buf1,
memcpy(&temp1_uint, _buf1, sizeof(unsigned int));
memcpy(&temp2_uint, _buf2, sizeof(unsigned int));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (abs((int)(temp1_uint-temp2_uint)) > options.delta)
+ if (abs((int)(temp1_uint-temp2_uint)) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -530,13 +530,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_uint!=0 && abs((int)(1-temp2_uint/temp1_uint)) > options.percent )
+ if ( temp1_uint!=0 && abs((int)(1-temp2_uint/temp1_uint)) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -547,14 +547,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_uint!=0 && abs((int)(1-temp2_uint/temp1_uint)) > options.percent &&
- abs((int)(temp1_uint-temp2_uint)) > options.delta )
+ if ( temp1_uint!=0 && abs((int)(1-temp2_uint/temp1_uint)) > options->percent &&
+ abs((int)(temp1_uint-temp2_uint)) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -566,9 +566,9 @@ int diff_array( void *buf1,
}
else if (temp1_uint != temp2_uint)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -599,13 +599,13 @@ int diff_array( void *buf1,
memcpy(&temp1_long, _buf1, sizeof(long));
memcpy(&temp2_long, _buf2, sizeof(long));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (labs(temp1_long-temp2_long) > (long)options.delta)
+ if (labs(temp1_long-temp2_long) > (long)options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -615,13 +615,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_long!=0 && labs(1-temp2_long/temp1_long) > (long)options.percent )
+ if ( temp1_long!=0 && labs(1-temp2_long/temp1_long) > (long)options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -632,14 +632,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_long!=0 && labs(1-temp2_long/temp1_long) > (long)options.percent &&
- labs(temp1_long-temp2_long) > (long)options.delta )
+ if ( temp1_long!=0 && labs(1-temp2_long/temp1_long) > (long)options->percent &&
+ labs(temp1_long-temp2_long) > (long)options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -651,9 +651,9 @@ int diff_array( void *buf1,
}
else if (temp1_long != temp2_long)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -683,13 +683,13 @@ int diff_array( void *buf1,
memcpy(&temp1_ulong, _buf1, sizeof(unsigned long));
memcpy(&temp2_ulong, _buf2, sizeof(unsigned long));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (labs((long)(temp1_ulong-temp2_ulong)) > (long)options.delta)
+ if (labs((long)(temp1_ulong-temp2_ulong)) > (long)options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -699,13 +699,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_ulong!=0 && labs((long)(1-temp2_ulong/temp1_ulong)) > (long)options.percent )
+ if ( temp1_ulong!=0 && labs((long)(1-temp2_ulong/temp1_ulong)) > (long)options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -716,14 +716,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_ulong!=0 && labs((long)(1-temp2_ulong/temp1_ulong)) > (long)options.percent &&
- labs((long)(temp1_ulong-temp2_ulong)) > (long)options.delta )
+ if ( temp1_ulong!=0 && labs((long)(1-temp2_ulong/temp1_ulong)) > (long)options->percent &&
+ labs((long)(temp1_ulong-temp2_ulong)) > (long)options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -735,9 +735,9 @@ int diff_array( void *buf1,
}
else if (temp1_ulong != temp2_ulong)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -767,13 +767,13 @@ int diff_array( void *buf1,
memcpy(&temp1_llong, _buf1, sizeof(long_long));
memcpy(&temp2_llong, _buf2, sizeof(long_long));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (labs((long)(temp1_llong-temp2_llong)) > (long)options.delta)
+ if (labs((long)(temp1_llong-temp2_llong)) > (long)options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -783,13 +783,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_llong!=0 && labs((long)(1-temp2_llong/temp1_llong)) > (long)options.percent )
+ if ( temp1_llong!=0 && labs((long)(1-temp2_llong/temp1_llong)) > (long)options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -800,14 +800,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_llong!=0 && labs((long)(1-temp2_llong/temp1_llong)) > (long)options.percent &&
- labs((long)(temp1_llong-temp2_llong)) > (long)options.delta )
+ if ( temp1_llong!=0 && labs((long)(1-temp2_llong/temp1_llong)) > (long)options->percent &&
+ labs((long)(temp1_llong-temp2_llong)) > (long)options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -819,9 +819,9 @@ int diff_array( void *buf1,
}
else if (temp1_llong != temp2_llong)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -851,13 +851,13 @@ int diff_array( void *buf1,
memcpy(&temp1_ullong, _buf1, sizeof(unsigned long_long));
memcpy(&temp2_ullong, _buf2, sizeof(unsigned long_long));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (labs((long)(temp1_ullong-temp2_ullong)) > (long)options.delta)
+ if (labs((long)(temp1_ullong-temp2_ullong)) > (long)options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -868,13 +868,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_ullong!=0 && labs((long)(1-temp2_ullong/temp1_ullong)) > (long)options.percent )
+ if ( temp1_ullong!=0 && labs((long)(1-temp2_ullong/temp1_ullong)) > (long)options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -886,14 +886,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_ullong!=0 && labs((long)(1-temp2_ullong/temp1_ullong)) > (long)options.percent &&
- labs((long)(temp1_ullong-temp2_ullong)) > (long)options.delta )
+ if ( temp1_ullong!=0 && labs((long)(1-temp2_ullong/temp1_ullong)) > (long)options->percent &&
+ labs((long)(temp1_ullong-temp2_ullong)) > (long)options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -906,9 +906,9 @@ int diff_array( void *buf1,
}
else if (temp1_ullong != temp2_ullong)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -939,13 +939,13 @@ int diff_array( void *buf1,
memcpy(&temp1_float, _buf1, sizeof(float));
memcpy(&temp2_float, _buf2, sizeof(float));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (fabs(temp1_float-temp2_float) > options.delta)
+ if (fabs(temp1_float-temp2_float) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -955,13 +955,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_float!=0 && fabs(1-temp2_float/temp1_float) > options.percent )
+ if ( temp1_float!=0 && fabs(1-temp2_float/temp1_float) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -972,14 +972,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_float!=0 && fabs(1-temp2_float/temp1_float) > options.percent &&
- fabs(temp1_float-temp2_float) > options.delta )
+ if ( temp1_float!=0 && fabs(1-temp2_float/temp1_float) > options->percent &&
+ fabs(temp1_float-temp2_float) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -991,9 +991,9 @@ int diff_array( void *buf1,
}
else if (temp1_float != temp2_float)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -1023,13 +1023,13 @@ int diff_array( void *buf1,
memcpy(&temp1_double, _buf1, sizeof(double));
memcpy(&temp2_double, _buf2, sizeof(double));
/* -d and !-p */
- if (options.d && !options.p)
+ if (options->d && !options->p)
{
- if (fabs(temp1_double-temp2_double) > options.delta)
+ if (fabs(temp1_double-temp2_double) > options->delta)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -1039,13 +1039,13 @@ int diff_array( void *buf1,
}
}
/* !-d and -p */
- else if (!options.d && options.p)
+ else if (!options->d && options->p)
{
- if ( temp1_double!=0 && fabs(1-temp2_double/temp1_double) > options.percent )
+ if ( temp1_double!=0 && fabs(1-temp2_double/temp1_double) > options->percent )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -1056,14 +1056,14 @@ int diff_array( void *buf1,
}
}
/* -d and -p */
- else if ( options.d && options.p)
+ else if ( options->d && options->p)
{
- if ( temp1_double!=0 && fabs(1-temp2_double/temp1_double) > options.percent &&
- fabs(temp1_double-temp2_double) > options.delta )
+ if ( temp1_double!=0 && fabs(1-temp2_double/temp1_double) > options->percent &&
+ fabs(temp1_double-temp2_double) > options->delta )
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,1,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
@@ -1075,9 +1075,9 @@ int diff_array( void *buf1,
}
else if (temp1_double != temp2_double)
{
- if (options.n && nfound>=options.count)
+ if (options->n && nfound>=options->count)
return nfound;
- if ( options.r==0 )
+ if ( options->r==0 )
{
print_pos(&ph,0,i,acc,pos,rank,obj1,obj2);
printf(SPACES);
diff --git a/tools/lib/h5diff_dset.c b/tools/lib/h5diff_dset.c
index 15a8769..f668297 100644
--- a/tools/lib/h5diff_dset.c
+++ b/tools/lib/h5diff_dset.c
@@ -40,7 +40,7 @@ int diff_dataset( hid_t file1_id,
hid_t file2_id,
const char *obj1_name,
const char *obj2_name,
- diff_opt_t options )
+ diff_opt_t *options )
{
hid_t dset1_id =-1;
hid_t dset2_id =-1;
@@ -139,10 +139,12 @@ int diff_dataset( hid_t file1_id,
if ( tclass1 != tclass2 )
{
- printf("Comparison not supported\n");
- printf("<%s> is of class %s and <%s> is of class %s\n",
- obj1_name, get_class(tclass1),
- obj2_name, get_class(tclass2) );
+ if (options->verbose) {
+ printf("Comparison not supported\n");
+ printf("<%s> is of class %s and <%s> is of class %s\n",
+ obj1_name, get_class(tclass1),
+ obj2_name, get_class(tclass2) );
+ }
goto out;
}
@@ -163,10 +165,12 @@ int diff_dataset( hid_t file1_id,
case H5T_ENUM:
case H5T_VLEN:
case H5T_ARRAY:
- printf("Comparison not supported\n");
- printf("<%s> is of class %s and <%s> is of class %s\n",
- obj1_name, get_class(tclass1),
- obj2_name, get_class(tclass2) );
+ if (options->verbose ) {
+ printf("Comparison not supported\n");
+ printf("<%s> is of class %s and <%s> is of class %s\n",
+ obj1_name, get_class(tclass1),
+ obj2_name, get_class(tclass2) );
+ }
goto out;
default:
break;
@@ -179,16 +183,18 @@ int diff_dataset( hid_t file1_id,
if ( rank1 != rank2 )
{
- printf("Comparison not supported\n");
- printf("<%s> has rank %d, dimensions ", obj1_name, rank1);
- print_dims(rank1,dims1);
- printf(", max dimensions ");
- print_dims(rank1,maxdim1);
- printf("\n" );
- printf("<%s> has rank %d, dimensions ", obj2_name, rank2);
- print_dims(rank2,dims2);
- printf(", max dimensions ");
- print_dims(rank2,maxdim2);
+ if (options->verbose) {
+ printf("Comparison not supported\n");
+ printf("<%s> has rank %d, dimensions ", obj1_name, rank1);
+ print_dims(rank1,dims1);
+ printf(", max dimensions ");
+ print_dims(rank1,maxdim1);
+ printf("\n" );
+ printf("<%s> has rank %d, dimensions ", obj2_name, rank2);
+ print_dims(rank2,dims2);
+ printf(", max dimensions ");
+ print_dims(rank2,maxdim2);
+ }
goto out;
}
@@ -213,16 +219,18 @@ int diff_dataset( hid_t file1_id,
if (dim_diff==1)
{
- printf("Comparison not supported\n");
- printf("<%s> has rank %d, dimensions ", obj1_name, rank1);
- print_dims(rank1,dims1);
- printf(", max dimensions ");
- print_dims(rank1,maxdim1);
- printf("\n" );
- printf("<%s> has rank %d, dimensions ", obj2_name, rank2);
- print_dims(rank2,dims2);
- printf(", max dimensions ");
- print_dims(rank2,maxdim2);
+ if (options->verbose) {
+ printf("Comparison not supported\n");
+ printf("<%s> has rank %d, dimensions ", obj1_name, rank1);
+ print_dims(rank1,dims1);
+ printf(", max dimensions ");
+ print_dims(rank1,maxdim1);
+ printf("\n" );
+ printf("<%s> has rank %d, dimensions ", obj2_name, rank2);
+ print_dims(rank2,dims2);
+ printf(", max dimensions ");
+ print_dims(rank2,maxdim2);
+ }
goto out;
}
@@ -232,13 +240,15 @@ int diff_dataset( hid_t file1_id,
*/
if (maxdim_diff==1)
{
- printf( "Warning: Different maximum dimensions\n");
- printf("<%s> has max dimensions ", obj1_name);
- print_dims(rank1,maxdim1);
- printf("\n");
- printf("<%s> has max dimensions ", obj2_name);
- print_dims(rank2,maxdim2);
- printf("\n");
+ if (options->verbose) {
+ printf( "Warning: Different maximum dimensions\n");
+ printf("<%s> has max dimensions ", obj1_name);
+ print_dims(rank1,maxdim1);
+ printf("\n");
+ printf("<%s> has max dimensions ", obj2_name);
+ print_dims(rank2,maxdim2);
+ printf("\n");
+ }
}
/*-------------------------------------------------------------------------
@@ -265,7 +275,7 @@ int diff_dataset( hid_t file1_id,
*-------------------------------------------------------------------------
*/
- if ( (H5Tequal(f_type1, f_type2)==0) )
+ if ( (H5Tequal(f_type1, f_type2)==0) && options->verbose)
{
printf("Warning: Different storage datatype\n");
printf("<%s> has file datatype ", obj1_name);
@@ -298,13 +308,15 @@ int diff_dataset( hid_t file1_id,
can1=diff_can(m_type1);
can2=diff_can(m_type2);
- if ( can1==0 || can2==0 )
+ if ( (can1==0 || can2==0))
{
- printf("Comparison not supported\n");
- if ( can1==0 )
- printf("<%s> type is not supported\n", obj1_name);
- if ( can2==0 )
- printf("<%s> type is not supported\n", obj2_name);
+ if (options->verbose) {
+ printf("Comparison not supported\n");
+ if ( can1==0 )
+ printf("<%s> type is not supported\n", obj1_name);
+ if ( can2==0 )
+ printf("<%s> type is not supported\n", obj2_name);
+ }
goto out;
}
@@ -317,9 +329,11 @@ int diff_dataset( hid_t file1_id,
sign2=H5Tget_sign(m_type2);
if ( sign1 != sign2 )
{
- printf("Comparison not supported\n");
- printf("<%s> has sign %s\n", obj1_name, get_sign(sign1));
- printf("<%s> has sign %s", obj2_name, get_sign(sign2));
+ if (options->verbose) {
+ printf("Comparison not supported\n");
+ printf("<%s> has sign %s\n", obj1_name, get_sign(sign1));
+ printf("<%s> has sign %s", obj2_name, get_sign(sign2));
+ }
goto out;
}
@@ -374,12 +388,12 @@ int diff_dataset( hid_t file1_id,
* array compare
*-------------------------------------------------------------------------
*/
- if (options.verbose)
+ if (options->verbose)
printf( "Comparing <%s> with <%s>\n", obj1_name, obj2_name );
name1=diff_basename(obj1_name);
name2=diff_basename(obj2_name);
nfound = diff_array(buf1,buf2,tot_cnt1,rank1,dims1,options,name1,name2,m_type1);
- if (options.verbose)
+ if (options->verbose)
printf("%d differences found\n", nfound );
/*-------------------------------------------------------------------------
diff --git a/tools/lib/h5trav.c b/tools/lib/h5trav.c
index 09c2033..ba74b6c 100644
--- a/tools/lib/h5trav.c
+++ b/tools/lib/h5trav.c
@@ -360,7 +360,9 @@ int traverse( hid_t loc_id,
}
else
{
+#if defined (H5_TRAV_DEBUG)
printf("%s %s\n", "HARDLINK", table->objs[j].objname);
+#endif
}
}
@@ -397,7 +399,9 @@ int traverse( hid_t loc_id,
}
else
{
+#if defined (H5_TRAV_DEBUG)
printf("%s %s\n", "HARDLINK", table->objs[j].objname);
+#endif
}
}