[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: netcdf-2.4.2 nclong problem
- Subject: Re: netcdf-2.4.2 nclong problem
- Date: Thu, 18 Jul 1996 13:54:55 -0600
Willa,
> I appreciate it very much if anyone can offer me a clue about what
> would cause the problem with netcdf-2.4.2 described below.
>
> I changed all "long" to "nclong" in my programs and recompiled them
> with netcdf-2.4.2. All programs failed on ncvarget() function
> with this error: (I have tested both on Solaris and DEC/OSF1)
>
> ncvarget: xxx: Invalid Coordinates
>
> where xxx is variable name. I have checked input arguments "nclong start"
> and "nclong count" which all contain right values. Besides, all
> these programs are working with old netcdf library.
You should not change all occurrences of "long" to "nclong", only in
declarations that declare types for *data* associated with the NC_LONG
netCDF external data type (32-bit integer). In particular, the C prototype
for ncvarget is:
extern int ncvarget(int ncid, int varid, const long* start,
const long* count, void* value)
so the types of the "start" and "count" variables should be "long*", not
"nclong*". The latter should result in a compile error, and won't work
correctly on platforms where the "nclong" typedef is different from "long".
Only the declaration for variables corresponding to the "value" argument in
the ncvarget/put and ncattget/put functions needs to be changed from "long"
to "nclong". Or, as the release notes say:
This means that C/C++ programs on platforms with
sizeof(long) > sizeof(int)
(e.g. the DEC Alpha) will have to be recompiled and must use nclong as
the variable type corresponding to NC_LONG data. All programs that use
NC_LONG data should also use the nclong data type to declare such data
for portability.
The requirement that NC_LONG data be declared with the "nclong" typedef was
first introduced in netCDF version 2.3.2, although programs that use "long"
instead still work on platforms where sizeof(long) == sizeof(int).
This is explained more fully in the Users Guide in the section "Language Types
Corresponding to NetCDF Data Types", available on-line at
http://www.unidata.ucar.edu/packages/netcdf/guide_9.html#SEC56
Please let me know if this needs further clarification.
--Russ
______________________________________________________________________________
Russ Rew UCAR Unidata Program
address@hidden http://www.unidata.ucar.edu