Merge pull request #2035 from DennisHeimbigner/badchunkpath.dmh

Fix chunk key when using dimension_separator - high priority
This commit is contained in:
Ward Fisher 2021-07-19 09:07:33 -07:00 committed by GitHub
commit 847c12e716
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 3 additions and 4 deletions

View File

@ -4,7 +4,7 @@
name: Run netCDF Tests name: Run netCDF Tests
on: [pull_request,push] on: [pull_request]
jobs: jobs:

View File

@ -7,6 +7,7 @@ This file contains a high-level description of this package's evolution. Release
## 4.8.1 - TBD ## 4.8.1 - TBD
* [Bug Fix] Fix dimension_separator bug in libnczarr. See [Github #2035](https://github.com/Unidata/netcdf-c/issues/2035).
* [Bug Fix] Fix bugs in libdap4. See [Github #2005](https://github.com/Unidata/netcdf-c/issues/2005). * [Bug Fix] Fix bugs in libdap4. See [Github #2005](https://github.com/Unidata/netcdf-c/issues/2005).
* [Bug Fix] Store NCZarr fillvalue as a singleton instead of a 1-element array. See [Github #2017](https://github.com/Unidata/netcdf-c/issues/2017). * [Bug Fix] Store NCZarr fillvalue as a singleton instead of a 1-element array. See [Github #2017](https://github.com/Unidata/netcdf-c/issues/2017).
* [Bug Fixes] The netcdf-c library was incorrectly determining the scope of dimension; similar to the type scope problem. See [Github #2012](https://github.com/Unidata/netcdf-c/pull/2012) for more information. * [Bug Fixes] The netcdf-c library was incorrectly determining the scope of dimension; similar to the type scope problem. See [Github #2012](https://github.com/Unidata/netcdf-c/pull/2012) for more information.

View File

@ -894,13 +894,11 @@ NCZ_chunkpath(struct ChunkKey key,char dimsep)
{ {
size_t plen = nulllen(key.varkey)+1+nulllen(key.chunkkey); size_t plen = nulllen(key.varkey)+1+nulllen(key.chunkkey);
char* path = (char*)malloc(plen+1); char* path = (char*)malloc(plen+1);
char sdimsep[2];
if(path == NULL) return NULL; if(path == NULL) return NULL;
path[0] = '\0'; path[0] = '\0';
strlcat(path,key.varkey,plen+1); strlcat(path,key.varkey,plen+1);
sdimsep[0] = dimsep; sdimsep[1] = '\0'; strlcat(path,"/",plen+1);
strlcat(path,sdimsep,plen+1);
strlcat(path,key.chunkkey,plen+1); strlcat(path,key.chunkkey,plen+1);
return path; return path;
} }