init_head.c 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*!
  2. \file lib/vector/Vlib/init_head.c
  3. \brief Vector library - init header of vector maps
  4. Higher level functions for reading/writing/manipulating vectors.
  5. Initialize Head structure. To make sure that we are not writing out
  6. garbage to a file.
  7. (C) 2001-2009 by the GRASS Development Team
  8. This program is free software under the GNU General Public License
  9. (>=v2). Read the file COPYING that comes with GRASS for details.
  10. \author Original author CERL, probably Dave Gerdes or Mike Higgins.
  11. \author Update to GRASS 5.7 Radim Blazek and David D. Gray.
  12. \author Various updates by Martin Landa <landa.martin gmail.com>, 2009
  13. */
  14. #include <string.h>
  15. #include <grass/vector.h>
  16. /*!
  17. \brief Initialize Map_info head structure (dig_head)
  18. \param[in,out] Map pointer to Map_info structure
  19. */
  20. void Vect__init_head(struct Map_info *Map)
  21. {
  22. char buf[64];
  23. G_zero(&(Map->head), sizeof(struct dig_head));
  24. /* organization */
  25. Vect_set_organization(Map, "");
  26. /* date */
  27. Vect_set_date(Map, "");
  28. /* user name */
  29. sprintf(buf, "%s", G_whoami());
  30. Vect_set_person(Map, buf);
  31. /* map name */
  32. Vect_set_map_name(Map, "");
  33. /* source date */
  34. sprintf(buf, "%s", G_date());
  35. Vect_set_map_date(Map, buf);
  36. /* comments */
  37. Vect_set_comment(Map, "");
  38. /* scale, threshold */
  39. Vect_set_scale(Map, 1);
  40. Vect_set_thresh(Map, 0.0);
  41. /* proj, zone */
  42. Vect_set_proj(Map, -1);
  43. Vect_set_zone(Map, -1);
  44. /* support variables */
  45. Map->plus.Spidx_built = FALSE;
  46. Map->plus.release_support = FALSE;
  47. Map->plus.update_cidx = FALSE;
  48. }
  49. /*!
  50. \brief Copy header data from one to another map
  51. \param from target vector map
  52. \param[out] to destination vector map
  53. \return 0
  54. */
  55. int Vect_copy_head_data(const struct Map_info *from, struct Map_info *to)
  56. {
  57. Vect_set_organization(to, Vect_get_organization(from));
  58. Vect_set_date(to, Vect_get_date(from));
  59. Vect_set_person(to, Vect_get_person(from));
  60. Vect_set_map_name(to, Vect_get_map_name(from));
  61. Vect_set_map_date(to, Vect_get_map_date(from));
  62. Vect_set_comment(to, Vect_get_comment(from));
  63. Vect_set_scale(to, Vect_get_scale(from));
  64. Vect_set_zone(to, Vect_get_zone(from));
  65. Vect_set_thresh(to, Vect_get_thresh(from));
  66. return 0;
  67. }