File: f03lib.c

package info (click to toggle)
netcdf-fortran 4.4.4%2Bds-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 8,420 kB
  • ctags: 8,797
  • sloc: fortran: 51,087; f90: 20,357; sh: 11,601; ansic: 7,034; makefile: 548; pascal: 313; xml: 173
file content (116 lines) | stat: -rwxr-xr-x 1,863 bytes parent folder | download | duplicates (4)
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
 * $Id: fort03.c,v 1.9 2007/07/28 13:14:00 rick Exp $
 *
 * This file contains support functions for FORTRAN code.  For example,
 * under HP-UX A.09.05, the U77 library doesn't contain the exit()
 * routine -- so we create one here.
 */

/*
   Modified fortlib.c - We remove all cfortran.h stuff to make 
   compiling easier. Also functions are modified to be extern
   and not static so FORTRAN can see them

   Version 1. July  2007 first vesion 
   Version 2. April 2009 - modified for netCDF 4.0.1
      
   Modified by: Richard Weed, Ph.D
   Center for Advanced Vehicular Systems
   Misssissippi State University
   rweed@.cavs.msstate.edu
*/

#include <stdlib.h>
#include <limits.h>
#include <float.h>


extern double
myrand(int iflag)
{
    if (iflag != 0)
	srand(iflag);

    /*
     * Return a pseudo-random value between 0.0 and 1.0.
     *
     * We don't use RAND_MAX here because not all compilation
     * environments define it (e.g. gcc(1) under SunOS 4.1.3).
     */
    return (rand() % 32768) / 32767.0;
}


extern int
myshift(int value, int amount)
{
    if (amount < 0)
	value >>= -amount;
    else
    if (amount > 0)
	value <<= amount;
    return value;
}

#include <signal.h>
extern void
nc_ignorefpe(int doit)
{
	if(doit)
		(void) signal(SIGFPE, SIG_IGN);
}

extern double cmax_uchar()
{
    return UCHAR_MAX;
}

extern double cmin_schar()
{
    return SCHAR_MIN;
}

extern double cmax_schar()
{
    return SCHAR_MAX;
}

extern double cmin_short()
{
    return SHRT_MIN;
}

extern double cmax_short()
{
    return SHRT_MAX;
}

extern double cmin_int()
{
    return INT_MIN;
}

extern double cmax_int()
{
    return INT_MAX;
}

extern double cmin_long()
{
    return LONG_MIN;
}

extern double cmax_long()
{
    return LONG_MAX;
}

extern double cmax_float()
{
    return FLT_MAX;
}

extern double cmax_double()
{
    return DBL_MAX;
}