123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- #include <stdio.h>
- #include <stdlib.h>
- #include <sys/types.h>
- #include <unistd.h>
- #include "raster3d_intern.h"
- /*---------------------------------------------------------------------------*/
- int Rast3d_write_doubles(int fd, int useXdr, const double *i, int nofNum)
- {
- char xdrDoubleBuf[RASTER3D_XDR_DOUBLE_LENGTH * 1024];
- unsigned int n;
- if (nofNum <= 0)
- Rast3d_fatal_error("Rast3d_write_doubles: nofNum out of range");
- if (useXdr == RASTER3D_NO_XDR) {
- if (write(fd, i, sizeof(double) * nofNum) != sizeof(double) * nofNum) {
- Rast3d_error("Rast3d_write_doubles: writing to file failed");
- return 0;
- }
- else {
- return 1;
- }
- }
- do {
- int j;
- n = nofNum % 1024;
- if (n == 0)
- n = 1024;
- for (j = 0; j < n; j++)
- G_xdr_put_double(&xdrDoubleBuf[RASTER3D_XDR_DOUBLE_LENGTH * j], i);
- if (write(fd, xdrDoubleBuf, RASTER3D_XDR_DOUBLE_LENGTH * n) !=
- RASTER3D_XDR_DOUBLE_LENGTH * n) {
- Rast3d_error("Rast3d_write_doubles: writing xdr to file failed");
- return 0;
- }
- nofNum -= n;
- i += n;
- } while (nofNum);
- return 1;
- }
- /*---------------------------------------------------------------------------*/
- int Rast3d_read_doubles(int fd, int useXdr, double *i, int nofNum)
- {
- char xdrDoubleBuf[RASTER3D_XDR_DOUBLE_LENGTH * 1024];
- unsigned int n;
- if (nofNum <= 0)
- Rast3d_fatal_error("Rast3d_read_doubles: nofNum out of range");
- if (useXdr == RASTER3D_NO_XDR) {
- if (read(fd, i, sizeof(double) * nofNum) != sizeof(double) * nofNum) {
- Rast3d_error("Rast3d_read_doubles: reading from file failed");
- return 0;
- }
- else {
- return 1;
- }
- }
- do {
- int j;
- n = nofNum % 1024;
- if (n == 0)
- n = 1024;
- if (read(fd, xdrDoubleBuf, RASTER3D_XDR_DOUBLE_LENGTH * n) !=
- RASTER3D_XDR_DOUBLE_LENGTH * n) {
- Rast3d_error("Rast3d_read_doubles: reading xdr from file failed");
- return 0;
- }
- for (j = 0; j < n; j++)
- G_xdr_get_double(i, &xdrDoubleBuf[RASTER3D_XDR_DOUBLE_LENGTH * j]);
- nofNum -= n;
- i += n;
- } while (nofNum);
- return 1;
- }
|