File: dimmap.c

package info (click to toggle)
netcdf-parallel 1%3A4.7.4-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 105,352 kB
  • sloc: ansic: 229,114; sh: 11,180; yacc: 2,561; makefile: 1,390; lex: 1,173; xml: 173; awk: 2
file content (73 lines) | stat: -rw-r--r-- 1,934 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*********************************************************************
 *   Copyright 2018, UCAR/Unidata
 *   See netcdf/COPYRIGHT file for copying and redistribution conditions.
 *   $Id $
 *********************************************************************/

#include <netcdf.h>		/* just for error codes */
#include "utils.h"

static struct {
    size_t ndims;
    int *odimids;
    int *idimids;
    int *ounlims;
    int *iunlims;
} dimmap;

/* initialize a dimmap for n dimension ids */
int
dimmap_init(size_t n) {
    int stat = NC_NOERR;
    int i;
    dimmap.ndims = n;
    dimmap.odimids = emalloc(n * sizeof(int));
    dimmap.idimids = emalloc(n * sizeof(int));
    dimmap.ounlims = emalloc(n * sizeof(int));
    dimmap.iunlims = emalloc(n * sizeof(int));
    for(i = 0; i < n; i++) {
	dimmap.odimids[i] = -1;
	dimmap.idimids[i] = -1;
	dimmap.ounlims[i] = 0;
	dimmap.iunlims[i] = 0;
    }
    return stat;
}

/* store association between an input dimid and an output dimid, which
 * should be ints between 0 and ndims-1, inclusive */
int
dimmap_store(int idimid, int odimid, int iunlim, int ounlim) {
    int stat = NC_NOERR;
    dimmap.odimids[idimid] = odimid; /* used to map input dimids to output dimids */
    dimmap.idimids[odimid] = idimid; /* used to map output dimids to input dimids */
    dimmap.ounlims[odimid] = ounlim;
    dimmap.iunlims[idimid] = iunlim;
    return stat;
}

/* return odimid associated with specified idimid, or -1 if not found */
int
dimmap_odimid(int idimid) {
    return dimmap.odimids[idimid];
}

/* return idimid associated with specified odimid, or -1 if not found */
int
dimmap_idimid(int odimid) {
    return dimmap.idimids[odimid];
}

/* return whether odimid dimension is unlimited */
int
dimmap_ounlim(int odimid) {
    return dimmap.ounlims[odimid];
}

/* return whether idimid dimension is unlimited */
int
dimmap_iunlim(int idimid) {
    return dimmap.iunlims[idimid];
   
}