/******************************************************************************
*
*  NSSDC/CDF           Create an example CDF using the New Standard Interface
*                      that was introduced in CDF 3.1.  
*
*  History:
*
*   V1.0  10-Jan-2006, D. Han              Original version
*
******************************************************************************/

/******************************************************************************
*
* Note(s):
*
*   This program would have to be modified to run on a DEC Alpha because the
* C language `long' data type is 8 bytes rather than 4 (the CDF data type of
* CDF_INT4 is always 4 bytes).
*
******************************************************************************/

/******************************************************************************
* Necessary include files.
******************************************************************************/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "cdf.h"

/******************************************************************************
* Function prototypes.
******************************************************************************/

void StatusHandler ();

/******************************************************************************
* MAIN.
******************************************************************************/
main () {

CDFid id;            /* CDF identifier. */
CDFstatus status;    /* CDF completion status. */

FILE *fp;            /* File pointer - used to read input data file. */

char  *title[] = {"CDF title", "Author: CDF"};
short lat[181];
int   time, i, j, *image;
long  TimeVarNum, LatVarNum, ImageVarNum, attrNum, recNum, titleAttrNum,
      dimIndices[2], dimCounts[2], dimInterval[2], dimSizes[2], dimVarys[2];
long  cType,                     /* Compression type */
      cParms[CDF_MAX_PARMS];     /* Compression parameters */

/******************************************************************************
* Create the CDF.
******************************************************************************/
status = CDFcreateCDF ("example1", &id);
if (status != CDF_OK) StatusHandler (status);

/******************************************************************************
* Create zVariables.
******************************************************************************/
status = CDFcreatezVar (id, 
                        "Time",    /* Variable name - case sensitive */
                        CDF_INT4,  /* Data type */
                        1L,        /* Number of elements */
                        0L,        /* Dimentionality     */
                        dimSizes,  /* Dummy dimension sizes since dim = 0 */
                        VARY,      /* Record variance */
                        VARY,      /* Dimension variance */
                        &TimeVarNum);
if (status != CDF_OK) StatusHandler (status);

dimSizes[0] = 181;
dimVarys[0] = VARY;
dimVarys[1] = VARY;
status = CDFcreatezVar (id, "Latitude", CDF_INT2, 1L, 1L, dimSizes,
                         VARY, dimVarys, &LatVarNum);
if (status != CDF_OK) StatusHandler (status);

dimSizes[0] = 10;
dimSizes[1] = 20;
dimVarys[0] = VARY;
dimVarys[1] = VARY;
status = CDFcreatezVar (id, "Image", CDF_INT4, 1L, 2L, dimSizes,
                         VARY, dimVarys, &ImageVarNum);
if (status != CDF_OK) StatusHandler (status);

/* Define compression for the 'Image' variable. */
cType = GZIP_COMPRESSION;
cParms[0] = 5;              /* GZIP compression level */
status = CDFsetzVarCompression (id, ImageVarNum, cType, cParms);
if (status != CDF_OK) StatusHandler (status);

/******************************************************************************
* Create global and variable attributes.
******************************************************************************/
status = CDFcreateAttr (id, "TITLE", GLOBAL_SCOPE, &titleAttrNum);
if (status != CDF_OK) StatusHandler (status);

status = CDFcreateAttr (id, "FIELDNAM", VARIABLE_SCOPE, &attrNum);
if (status != CDF_OK) StatusHandler (status);

status = CDFcreateAttr (id, "UNITS", VARIABLE_SCOPE, &attrNum);
if (status != CDF_OK) StatusHandler (status);

/******************************************************************************
* Write TITLE gAttribute gEntry.
******************************************************************************/
status = CDFputAttrgEntry (id, titleAttrNum, 
                           0L,        /* Attribute entry number */
                           CDF_CHAR, strlen(title[0]), title[0]); 
if (status != CDF_OK) StatusHandler (status);

status = CDFputAttrgEntry (id, titleAttrNum, 
                           1L,        /* Attribute entry number */
                           CDF_CHAR, strlen(title[1]), title[1]); 
if (status != CDF_OK) StatusHandler (status);

/******************************************************************************
* Write vAttribute zEntries for 'Time' zVariable.
******************************************************************************/
status = CDFputAttrzEntry (id, CDFgetAttrNum(id,"FIELDNAM"), 
                           CDFvarNum(id,"Time"), CDF_CHAR, 19L,
                           "Time of observation");
if (status != CDF_OK) StatusHandler (status);

status = CDFputAttrzEntry (id, CDFgetAttrNum(id,"UNITS"), 
                           CDFvarNum(id,"Time"), CDF_CHAR, 11L,
                           "Hour/Minute");

/******************************************************************************
* Write data for 'Time' zVariable.
******************************************************************************/
recNum = 0L;
time = 23;
status = CDFputzVarRecordData (id, TimeVarNum, recNum, &time);
if (status != CDF_OK) StatusHandler (status);
recNum = 1L;
time = 24;
status = CDFputzVarRecordData (id, TimeVarNum, recNum, &time);
if (status != CDF_OK) StatusHandler (status);

/******************************************************************************
* Write data for 'Latitude' zVariable.
******************************************************************************/
dimIndices[0] = 0;
dimCounts[0] = 181;
dimInterval[0] = 1;
for (i=-90; i <= 90; i++)
   lat[i+90] = i;

status = CDFhyperPutzVarData (id, LatVarNum,
                              0L,           /* record start */
                              1L,           /* # of records to write */
                              1L,           /* record interval */
                              dimIndices,   /* dimension dimIndices */
                              dimCounts,    /* dimension counts */
                              dimInterval,  /* dimension interval */
                              lat);
                              
if (status != CDF_OK) StatusHandler (status);

/******************************************************************************
* Write data for 'Image' zVariable.
******************************************************************************/
dimIndices[0] = 0;
dimIndices[1] = 0;
dimCounts[0] = 10; 
dimCounts[1] = 20;
dimInterval[0] = 1;
dimInterval[1] = 1;

image = (int *) malloc (sizeof(int) * 600);
for (i=0; i <= 600; i++)     /* Load 3 records of data */
   *(image+i) = i;

status = CDFhyperPutzVarData (id, ImageVarNum,
                              0L,           /* record start */
                              3L,           /* # of records to write */
                              1L,           /* record interval */
                              dimIndices,   /* dimension dimIndices */
                              dimCounts,    /* dimension counts */
                              dimInterval,  /* dimension interval */
                              image);

if (status != CDF_OK) StatusHandler (status);

/******************************************************************************
* Close CDF.
******************************************************************************/
status = CDFcloseCDF (id);
if (status != CDF_OK) StatusHandler (status);

return;
}

/******************************************************************************
* Status handler.
******************************************************************************/
void StatusHandler (status)
CDFstatus status;
{
char message[CDF_ERRTEXT_LEN+1];

if (status < CDF_WARN) {
  printf ("An error has occurred, halting...\n");
  CDFgetStatusText (status, message);
  printf ("%s\n", message);
  exit (status);
}
else
  if (status < CDF_OK) {
    printf ("Warning, function may not have completed as expected...\n");
    CDFgetStatusText (status, message);
    printf ("%s\n", message);
  }
  else
    if (status > CDF_OK) {
      printf ("Function completed successfully, but be advised that...\n");
      CDFgetStatusText (status, message);
      printf ("%s\n", message);
    }       
return;
}


syntax highlighted by Code2HTML, v. 0.9.1