LCOV - code coverage report
Current view: top level - frmts/grib/degrib/g2clib - drstemplates.c (source / functions) Hit Total Coverage
Test: gdal_filtered.info Lines: 20 35 57.1 %
Date: 2025-01-18 12:42:00 Functions: 3 4 75.0 %

          Line data    Source code
       1             : #include <stdlib.h>
       2             : #include "grib2.h"
       3             : #include "drstemplates.h"
       4             : 
       5             : /* GDAL: in original g2clib, this is in drstemplates.h */
       6             : static const struct drstemplate templatesdrs[MAXDRSTEMP] = {
       7             :              // 5.0: Grid point data - Simple Packing
       8             :          { 0, 5, 0, {4,-2,-2,1,1} },
       9             :              // 5.2: Grid point data - Complex Packing
      10             :          { 2, 16, 0, {4,-2,-2,1,1,1,1,4,4,4,1,1,4,1,4,1} },
      11             :              // 5.3: Grid point data - Complex Packing and spatial differencing
      12             :          { 3, 18, 0, {4,-2,-2,1,1,1,1,4,4,4,1,1,4,1,4,1,1,1} },
      13             :              // 5.4: Grid point data - IEEE Floating Point Data
      14             :          { 4, 1, 0, {1} },
      15             :              // 5.50: Spectral Data - Simple Packing
      16             :          { 50, 5, 0, {4,-2,-2,1,4} },
      17             :              // 5.51: Spherical Harmonics data - Complex packing
      18             :          { 51, 10, 0, {4,-2,-2,1,-4,2,2,2,4,1} },
      19             : //           // 5.1: Matrix values at gridpoint - Simple packing
      20             : //         { 1, 15, 1, {4,-2,-2,1,1,1,4,2,2,1,1,1,1,1,1} },
      21             :              // 5.40: Grid point data - JPEG2000 encoding
      22             :          { 40, 7, 0, {4,-2,-2,1,1,1,1} },
      23             :              // 5.41: Grid point data - PNG encoding
      24             :          { 41, 5, 0, {4,-2,-2,1,1} },
      25             :              // 5.42: Grid point and spectral data - CCSDS szip
      26             :          { 42, 8, 0, {4,-2,-2,1,1,1,1,-2} },
      27             :              // 5.40000: Grid point data - JPEG2000 encoding
      28             :          { 40000, 7, 0, {4,-2,-2,1,1,1,1} },
      29             :              // 5.40010: Grid point data - PNG encoding
      30             :          { 40010, 5, 0, {4,-2,-2,1,1} }
      31             :       } ;
      32             : 
      33        2954 : const struct drstemplate *get_templatesdrs()
      34             : {
      35        2954 :     return templatesdrs;
      36             : }
      37             : 
      38             : 
      39         946 : g2int getdrsindex(g2int number)
      40             : /*!$$$  SUBPROGRAM DOCUMENTATION BLOCK
      41             : !                .      .    .                                       .
      42             : ! SUBPROGRAM:    getdrsindex
      43             : !   PRGMMR: Gilbert         ORG: W/NP11    DATE: 2001-06-28
      44             : !
      45             : ! ABSTRACT: This function returns the index of specified Data
      46             : !   Representation Template 5.NN (NN=number) in array templates.
      47             : !
      48             : ! PROGRAM HISTORY LOG:
      49             : ! 2001-06-28  Gilbert
      50             : !
      51             : ! USAGE:    index=getdrsindex(number)
      52             : !   INPUT ARGUMENT LIST:
      53             : !     number   - NN, indicating the number of the Data Representation
      54             : !                Template 5.NN that is being requested.
      55             : !
      56             : ! RETURNS:  Index of DRT 5.NN in array templates, if template exists.
      57             : !           = -1, otherwise.
      58             : !
      59             : ! REMARKS: None
      60             : !
      61             : ! ATTRIBUTES:
      62             : !   LANGUAGE: C
      63             : !   MACHINE:  IBM SP
      64             : !
      65             : !$$$*/
      66             : {
      67         946 :            g2int j,l_getdrsindex=-1;
      68             : 
      69        3332 :            for (j=0;j<MAXDRSTEMP;j++) {
      70        3332 :               if (number == templatesdrs[j].template_num) {
      71         946 :                  l_getdrsindex=j;
      72         946 :                  return(l_getdrsindex);
      73             :               }
      74             :            }
      75             : 
      76           0 :            return(l_getdrsindex);
      77             : }
      78             : 
      79             : 
      80         473 : gtemplate *getdrstemplate(g2int number)
      81             : /*!$$$  SUBPROGRAM DOCUMENTATION BLOCK
      82             : !                .      .    .                                       .
      83             : ! SUBPROGRAM:    getdrstemplate
      84             : !   PRGMMR: Gilbert         ORG: W/NP11    DATE: 2000-05-11
      85             : !
      86             : ! ABSTRACT: This subroutine returns DRS template information for a
      87             : !   specified Data Representation Template 5.NN.
      88             : !   The number of entries in the template is returned along with a map
      89             : !   of the number of octets occupied by each entry.  Also, a flag is
      90             : !   returned to indicate whether the template would need to be extended.
      91             : !
      92             : ! PROGRAM HISTORY LOG:
      93             : ! 2000-05-11  Gilbert
      94             : ! 2009-01-14  Vuong     Changed structure name template to gtemplate
      95             : !
      96             : ! USAGE:    new=getdrstemplate(number);
      97             : !   INPUT ARGUMENT LIST:
      98             : !     number   - NN, indicating the number of the Data Representation
      99             : !                Template 5.NN that is being requested.
     100             : !
     101             : !   RETURN VALUE:
     102             : !        - Pointer to the returned template struct.
     103             : !          Returns NULL pointer, if template not found.
     104             : !
     105             : ! REMARKS: None
     106             : !
     107             : ! ATTRIBUTES:
     108             : !   LANGUAGE: C
     109             : !   MACHINE:  IBM SP
     110             : !
     111             : !$$$*/
     112             : {
     113             :            g2int l_index;
     114             :            gtemplate *new;
     115             : 
     116         473 :            l_index=getdrsindex(number);
     117             : 
     118         473 :            if (l_index != -1) {
     119         473 :               new=(gtemplate *)malloc(sizeof(gtemplate));
     120         473 :               new->type=5;
     121         473 :               new->num=templatesdrs[l_index].template_num;
     122         473 :               new->maplen=templatesdrs[l_index].mapdrslen;
     123         473 :               new->needext=templatesdrs[l_index].needext;
     124         473 :               new->map=(g2int *)templatesdrs[l_index].mapdrs;
     125         473 :               new->extlen=0;
     126         473 :               new->ext=0;        //NULL
     127         473 :               return(new);
     128             :            }
     129             :            else {
     130           0 :              printf("getdrstemplate: DRS Template 5.%d not defined.\n",(int)number);
     131           0 :              return(0);        //NULL
     132             :            }
     133             : 
     134             :          return(0);        //NULL
     135             : }
     136             : 
     137           0 : gtemplate *extdrstemplate(g2int number,g2int *list)
     138             : /*!$$$  SUBPROGRAM DOCUMENTATION BLOCK
     139             : !                .      .    .                                       .
     140             : ! SUBPROGRAM:    extdrstemplate
     141             : !   PRGMMR: Gilbert         ORG: W/NP11    DATE: 2000-05-11
     142             : !
     143             : ! ABSTRACT: This subroutine generates the remaining octet map for a
     144             : !   given Data Representation Template, if required.  Some Templates can
     145             : !   vary depending on data values given in an earlier part of the
     146             : !   Template, and it is necessary to know some of the earlier entry
     147             : !   values to generate the full octet map of the Template.
     148             : !
     149             : ! PROGRAM HISTORY LOG:
     150             : ! 2000-05-11  Gilbert
     151             : ! 2009-01-14  Vuong     Changed structure name template to gtemplate
     152             : !
     153             : ! USAGE:    new=extdrstemplate(number,list);
     154             : !   INPUT ARGUMENT LIST:
     155             : !     number   - NN, indicating the number of the Data Representation
     156             : !                Template 5.NN that is being requested.
     157             : !     list()   - The list of values for each entry in the
     158             : !                the Data Representation Template 5.NN.
     159             : !
     160             : !   RETURN VALUE:
     161             : !        - Pointer to the returned template struct.
     162             : !          Returns NULL pointer, if template not found.
     163             : !
     164             : ! ATTRIBUTES:
     165             : !   LANGUAGE: C
     166             : !   MACHINE:  IBM SP
     167             : !
     168             : !$$$*/
     169             : {
     170             :            gtemplate *new;
     171             :            g2int l_index,i;
     172             : 
     173           0 :            l_index=getdrsindex(number);
     174           0 :            if (l_index == -1) return(0);
     175             : 
     176           0 :            new=getdrstemplate(number);
     177           0 :            if (new == NULL) return NULL;
     178             : 
     179           0 :            if ( ! new->needext ) return(new);
     180             : 
     181           0 :            if ( number == 1 ) {
     182           0 :               new->extlen=list[10]+list[12];
     183           0 :               new->ext=(g2int *)malloc(sizeof(g2int)*new->extlen);
     184           0 :               for (i=0;i<new->extlen;i++) {
     185           0 :                 new->ext[i]=4;
     186             :               }
     187             :            }
     188           0 :            return(new);
     189             : 
     190             : }
     191             : 

Generated by: LCOV version 1.14