close_nat.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*!
  2. \file close_nat.c
  3. \brief Vector library - Close map (native format)
  4. Higher level functions for reading/writing/manipulating vectors.
  5. (C) 2001-2009 by the GRASS Development Team
  6. This program is free software under the GNU General Public License
  7. (>=v2). Read the file COPYING that comes with GRASS for details.
  8. \author Original author CERL, probably Dave Gerdes or Mike Higgins.
  9. \author Update to GRASS 5.7 Radim Blazek and David D. Gray.
  10. */
  11. #include <grass/vector.h>
  12. #include <stdlib.h>
  13. /*!
  14. \brief Close vector map file
  15. \param Map vector map to be closed
  16. \return 0 on success
  17. \return non-zero on error
  18. */
  19. int V1_close_nat(struct Map_info *Map)
  20. {
  21. struct Coor_info CInfo;
  22. G_debug(1, "V1_close_nat(): name = %s mapset= %s", Map->name,
  23. Map->mapset);
  24. if (!VECT_OPEN(Map))
  25. return 1;
  26. if (Map->mode == GV_MODE_WRITE || Map->mode == GV_MODE_RW) {
  27. Vect_coor_info(Map, &CInfo);
  28. Map->head.size = CInfo.size;
  29. dig__write_head(Map);
  30. Vect__write_head(Map);
  31. Vect_write_dblinks(Map);
  32. }
  33. /* close coor file */
  34. fclose(Map->dig_fp.file);
  35. dig_file_free(&(Map->dig_fp));
  36. return 0;
  37. }