xdr.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. #include <stdlib.h>
  2. #include <string.h>
  3. #include <grass/gis.h>
  4. #include "G.h"
  5. static void swap_int(void *dstp, const void *srcp) {
  6. unsigned char *dst = (unsigned char *) dstp;
  7. const unsigned char *src = (const unsigned char *) srcp;
  8. if (G__.little_endian) {
  9. dst[0] = src[3];
  10. dst[1] = src[2];
  11. dst[2] = src[1];
  12. dst[3] = src[0];
  13. }
  14. else
  15. memcpy(dst, src, 4);
  16. }
  17. static void swap_float(void *dstp, const void *srcp) {
  18. unsigned char *dst = (unsigned char *) dstp;
  19. const unsigned char *src = (const unsigned char *) srcp;
  20. if (G__.little_endian) {
  21. dst[0] = src[3];
  22. dst[1] = src[2];
  23. dst[2] = src[1];
  24. dst[3] = src[0];
  25. }
  26. else
  27. memcpy(dst, src, 4);
  28. }
  29. static void swap_double(void *dstp, const void *srcp) {
  30. unsigned char *dst = (unsigned char *) dstp;
  31. const unsigned char *src = (const unsigned char *) srcp;
  32. if (G__.little_endian) {
  33. dst[0] = src[7];
  34. dst[1] = src[6];
  35. dst[2] = src[5];
  36. dst[3] = src[4];
  37. dst[4] = src[3];
  38. dst[5] = src[2];
  39. dst[6] = src[1];
  40. dst[7] = src[0];
  41. }
  42. else
  43. memcpy(dst, src, 8);
  44. }
  45. void G_xdr_get_int(int *dst, const void *src)
  46. {
  47. swap_int(dst, src);
  48. }
  49. void G_xdr_put_int(void *dst, const int *src)
  50. {
  51. swap_int(dst, src);
  52. }
  53. void G_xdr_get_float(float *dst, const void *src)
  54. {
  55. swap_float(dst, src);
  56. }
  57. void G_xdr_put_float(void *dst, const float *src)
  58. {
  59. swap_float(dst, src);
  60. }
  61. void G_xdr_get_double(double *dst, const void *src)
  62. {
  63. swap_double(dst, src);
  64. }
  65. void G_xdr_put_double(void *dst, const double *src)
  66. {
  67. swap_double(dst, src);
  68. }