xeval.c 1.3 KB

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