mirror of
https://github.com/HDFGroup/hdf5.git
synced 2024-11-27 02:10:55 +08:00
[svn-r13553]
New feature Add a tests script for h52gif tool. A simple script that just runs the tool from a pre-saved HDF5 file and produces a gif file. A HDF5 test generator program is also added Note: the .am file needs further development, right now it is not producing the test
This commit is contained in:
parent
c64ac252cd
commit
be8b1c0592
@ -25,12 +25,14 @@ INCLUDES=-I$(top_srcdir)/src -I$(top_srcdir)/tools/lib -I$(top_srcdir)/hl/src
|
||||
|
||||
# These are our main targets, the tools
|
||||
|
||||
bin_PROGRAMS=gif2h5 h52gif
|
||||
bin_PROGRAMS=gif2h5 h52gif h52gifgentst
|
||||
|
||||
gif2h5_SOURCES=gif2hdf.c gif2mem.c decompress.c gifread.c writehdf.c
|
||||
gif2h5_SOURCES=gif2hdf.c gif2mem.c decompress.c gifread.c writehdf.c
|
||||
|
||||
h52gif_SOURCES=hdf2gif.c hdfgifwr.c readhdf.c
|
||||
|
||||
h52gifgentst_SOURCES=h52gifgentst.c
|
||||
|
||||
# Programs all depend on the hdf5 library, the tools library, and the HL
|
||||
# library.
|
||||
LDADD=$(LIBH5_HL) $(LIBH5TOOLS) $(LIBHDF5)
|
||||
|
104
hl/tools/gif2h5/h52gifgentst.c
Normal file
104
hl/tools/gif2h5/h52gifgentst.c
Normal file
@ -0,0 +1,104 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* 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 <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include "hdf5.h"
|
||||
#include "H5IM.h"
|
||||
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Program: h52giftst
|
||||
*
|
||||
* Purpose: generate files for h52gif testing
|
||||
*
|
||||
* Programmer: Pedro Vicente, pvn@hdfgroup.org
|
||||
*
|
||||
* Date: March 15, 2007
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#define FILENAME "h52giftst.h5"
|
||||
#define WIDTH (hsize_t)400
|
||||
#define HEIGHT (hsize_t)200
|
||||
#define PAL_ENTRIES 256
|
||||
#define IMAGE1_NAME "1234567"
|
||||
#define PAL_NAME "palette"
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: main
|
||||
*
|
||||
* Purpose: main program
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
int main(void)
|
||||
{
|
||||
hid_t fid;
|
||||
int i, j, n, space;
|
||||
unsigned char buf [ WIDTH*HEIGHT ];
|
||||
unsigned char pal[ PAL_ENTRIES * 3 ]; /* palette array */
|
||||
hsize_t pal_dims[2] = {PAL_ENTRIES,3}; /* palette dimensions */
|
||||
|
||||
|
||||
/* create a file */
|
||||
if ((fid = H5Fcreate(FILENAME, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT))<0)
|
||||
return 1;
|
||||
|
||||
/* create an image */
|
||||
space = WIDTH*HEIGHT / PAL_ENTRIES;
|
||||
for (i=0, j=0, n=0; i < WIDTH*HEIGHT; i++, j++ )
|
||||
{
|
||||
buf[i] = n;
|
||||
if ( j > space )
|
||||
{
|
||||
n++;
|
||||
j=0;
|
||||
}
|
||||
if (n>PAL_ENTRIES-1) n=0;
|
||||
}
|
||||
|
||||
/* make the image */
|
||||
if (H5IMmake_image_8bit( fid, IMAGE1_NAME, WIDTH, HEIGHT, buf )<0)
|
||||
return 1;
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* define a palette, blue to red tones
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
for ( i=0, n=0; i<PAL_ENTRIES*3; i+=3, n++)
|
||||
{
|
||||
pal[i] =n; /* red */
|
||||
pal[i+1]=0; /* green */
|
||||
pal[i+2]=255-n; /* blue */
|
||||
}
|
||||
|
||||
/* make a palette */
|
||||
if (H5IMmake_palette( fid, PAL_NAME, pal_dims, pal )<0)
|
||||
return 1;
|
||||
|
||||
/* attach the palette to the image */
|
||||
if (H5IMlink_palette( fid, IMAGE1_NAME, PAL_NAME )<0)
|
||||
return 1;
|
||||
|
||||
if(H5Fclose(fid)<0)
|
||||
return 1;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
46
hl/tools/gif2h5/h52giftest.sh
Normal file
46
hl/tools/gif2h5/h52giftest.sh
Normal file
@ -0,0 +1,46 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# 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.
|
||||
#
|
||||
# HDF Utilities Test script
|
||||
|
||||
# initialize errors variable
|
||||
errors=0
|
||||
|
||||
TESTING() {
|
||||
SPACES=" "
|
||||
echo "Testing $* $SPACES" | cut -c1-70 | tr -d '\012'
|
||||
}
|
||||
|
||||
TOOLTEST()
|
||||
{
|
||||
err=0
|
||||
$RUNSERIAL ./h52gif $*
|
||||
|
||||
|
||||
if [ $err -eq 1 ]; then
|
||||
errors="` expr $errors + 1 `";
|
||||
echo "*FAILED*"
|
||||
else
|
||||
echo " PASSED"
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
|
||||
TESTING "h52giftst.h5 image1.gif -i 1234567 -p palette" ;
|
||||
TOOLTEST h52giftst.h5 image1.gif -i 1234567 -p palette
|
||||
|
||||
|
||||
exit $errors
|
Loading…
Reference in New Issue
Block a user