xfloat.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #include <stdlib.h>
  2. #include <grass/gis.h>
  3. #include <grass/raster.h>
  4. #include "globals.h"
  5. #include "expression.h"
  6. #include "func_proto.h"
  7. /**********************************************************************
  8. float(x)
  9. converts x to float
  10. **********************************************************************/
  11. int f_float(int argc, const int *argt, void **args)
  12. {
  13. FCELL *res = args[0];
  14. int i;
  15. if (argc < 1)
  16. return E_ARG_LO;
  17. if (argc > 1)
  18. return E_ARG_HI;
  19. if (argt[0] != FCELL_TYPE)
  20. return E_RES_TYPE;
  21. switch (argt[1]) {
  22. case CELL_TYPE:
  23. {
  24. CELL *arg1 = args[1];
  25. for (i = 0; i < columns; i++)
  26. if (IS_NULL_C(&arg1[i]))
  27. SET_NULL_F(&res[i]);
  28. else
  29. res[i] = (FCELL) arg1[i];
  30. return 0;
  31. }
  32. case FCELL_TYPE:
  33. {
  34. FCELL *arg1 = args[1];
  35. for (i = 0; i < columns; i++)
  36. if (IS_NULL_F(&arg1[i]))
  37. SET_NULL_F(&res[i]);
  38. else
  39. res[i] = (FCELL) arg1[i];
  40. return 0;
  41. }
  42. case DCELL_TYPE:
  43. {
  44. DCELL *arg1 = args[1];
  45. for (i = 0; i < columns; i++)
  46. if (IS_NULL_D(&arg1[i]))
  47. SET_NULL_F(&res[i]);
  48. else
  49. res[i] = (FCELL) arg1[i];
  50. return 0;
  51. }
  52. default:
  53. return E_INV_TYPE;
  54. }
  55. }
  56. int c_float(int argc, int *argt)
  57. {
  58. if (argc < 1)
  59. return E_ARG_LO;
  60. if (argc > 1)
  61. return E_ARG_HI;
  62. argt[0] = FCELL_TYPE;
  63. /* argt[1] = argt[1]; */
  64. return 0;
  65. }