xor.c 737 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #include <grass/gis.h>
  2. #include <grass/raster.h>
  3. #include <grass/calc.h>
  4. /****************************************************************
  5. or(a,b,c,...) = a || b || c || ...
  6. ****************************************************************/
  7. int f_or(int argc, const int *argt, void **args)
  8. {
  9. CELL *res = args[0];
  10. int i, j;
  11. if (argc < 1)
  12. return E_ARG_LO;
  13. if (argt[0] != CELL_TYPE)
  14. return E_RES_TYPE;
  15. for (i = 1; i <= argc; i++)
  16. if (argt[i] != argt[0])
  17. return E_ARG_TYPE;
  18. for (i = 0; i < columns; i++) {
  19. res[i] = 0;
  20. for (j = 1; j <= argc; j++) {
  21. CELL *arg = args[j];
  22. if (IS_NULL_C(&arg[i])) {
  23. SET_NULL_C(&res[i]);
  24. break;
  25. }
  26. if (arg[i])
  27. res[i] = 1;
  28. }
  29. }
  30. return 0;
  31. }