check.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. #include "mapcalc.h"
  2. #include "func_proto.h"
  3. int c_int0(int argc, int *argt)
  4. {
  5. if (argc > 0)
  6. return E_ARG_HI;
  7. argt[0] = CELL_TYPE;
  8. return 0;
  9. }
  10. int c_double0(int argc, int *argt)
  11. {
  12. if (argc > 0)
  13. return E_ARG_HI;
  14. argt[0] = DCELL_TYPE;
  15. return 0;
  16. }
  17. int c_double1(int argc, int *argt)
  18. {
  19. if (argc < 1)
  20. return E_ARG_LO;
  21. if (argc > 1)
  22. return E_ARG_HI;
  23. argt[0] = DCELL_TYPE;
  24. argt[1] = DCELL_TYPE;
  25. return 0;
  26. }
  27. int c_double12(int argc, int *argt)
  28. {
  29. if (argc < 1)
  30. return E_ARG_LO;
  31. if (argc > 2)
  32. return E_ARG_HI;
  33. argt[0] = DCELL_TYPE;
  34. argt[1] = DCELL_TYPE;
  35. if (argc == 2)
  36. argt[2] = DCELL_TYPE;
  37. return 0;
  38. }
  39. int c_unop(int argc, int *argt)
  40. {
  41. if (argc < 1)
  42. return E_ARG_LO;
  43. if (argc > 1)
  44. return E_ARG_HI;
  45. argt[0] = argt[1];
  46. return 0;
  47. }
  48. int c_binop(int argc, int *argt)
  49. {
  50. if (argc < 2)
  51. return E_ARG_LO;
  52. if (argc > 2)
  53. return E_ARG_HI;
  54. argt[0] = CELL_TYPE;
  55. if (argt[1] == FCELL_TYPE || argt[2] == FCELL_TYPE)
  56. argt[0] = FCELL_TYPE;
  57. if (argt[1] == DCELL_TYPE || argt[2] == DCELL_TYPE)
  58. argt[0] = DCELL_TYPE;
  59. argt[1] = argt[0];
  60. argt[2] = argt[0];
  61. return 0;
  62. }
  63. int c_varop(int argc, int *argt)
  64. {
  65. int i;
  66. if (argc < 1)
  67. return E_ARG_LO;
  68. argt[0] = CELL_TYPE;
  69. for (i = 1; i <= argc; i++)
  70. if (argt[i] == FCELL_TYPE)
  71. argt[0] = FCELL_TYPE;
  72. for (i = 1; i <= argc; i++)
  73. if (argt[i] == DCELL_TYPE)
  74. argt[0] = DCELL_TYPE;
  75. for (i = 1; i <= argc; i++)
  76. argt[i] = argt[0];
  77. return 0;
  78. }
  79. int c_cmpop(int argc, int *argt)
  80. {
  81. int arg_type;
  82. if (argc < 2)
  83. return E_ARG_LO;
  84. if (argc > 2)
  85. return E_ARG_HI;
  86. argt[0] = CELL_TYPE;
  87. arg_type = CELL_TYPE;
  88. if (argt[1] == FCELL_TYPE || argt[2] == FCELL_TYPE)
  89. arg_type = FCELL_TYPE;
  90. if (argt[1] == DCELL_TYPE || argt[2] == DCELL_TYPE)
  91. arg_type = DCELL_TYPE;
  92. argt[1] = arg_type;
  93. argt[2] = arg_type;
  94. return 0;
  95. }
  96. int c_logop(int argc, int *argt)
  97. {
  98. int i;
  99. if (argc < 1)
  100. return E_ARG_LO;
  101. for (i = 1; i <= argc; i++)
  102. if (argt[i] != CELL_TYPE)
  103. return E_ARG_TYPE;
  104. argt[0] = CELL_TYPE;
  105. return 0;
  106. }
  107. int c_shiftop(int argc, int *argt)
  108. {
  109. if (argc < 2)
  110. return E_ARG_LO;
  111. if (argc > 2)
  112. return E_ARG_HI;
  113. if (argt[1] != CELL_TYPE || argt[2] != CELL_TYPE)
  114. return E_ARG_TYPE;
  115. argt[0] = CELL_TYPE;
  116. return 0;
  117. }