cseg_read.c 862 B

123456789101112131415161718192021222324252627282930313233343536373839
  1. #include <grass/gis.h>
  2. #include <grass/raster.h>
  3. #include <grass/segment.h>
  4. #include "Gwater.h"
  5. static char *me = "cseg_read_cell";
  6. int cseg_read_cell(CSEG * cseg, char *map_name, char *mapset)
  7. {
  8. GW_LARGE_INT row, nrows;
  9. int map_fd;
  10. CELL *buffer;
  11. cseg->name = NULL;
  12. cseg->mapset = NULL;
  13. map_fd = Rast_open_old(map_name, mapset);
  14. nrows = Rast_window_rows();
  15. buffer = Rast_allocate_c_buf();
  16. for (row = 0; row < nrows; row++) {
  17. Rast_get_c_row(map_fd, buffer, row);
  18. if (Segment_put_row(&(cseg->seg), buffer, row) < 0) {
  19. G_free(buffer);
  20. Rast_close(map_fd);
  21. G_warning("%s(): unable to segment put row for [%s] in [%s]",
  22. me, map_name, mapset);
  23. return (-1);
  24. }
  25. }
  26. Rast_close(map_fd);
  27. G_free(buffer);
  28. cseg->name = G_store(map_name);
  29. cseg->mapset = G_store(mapset);
  30. return 0;
  31. }