runtime_arith.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. #include <stdlib.h>
  2. #include <stdio.h>
  3. #include <string.h>
  4. #include <errno.h>
  5. #include "sans.h"
  6. #include "garbagecollector.h"
  7. #include "runtime.h"
  8. sdata bltn__plus(sdata x, sdata y) {
  9. if (x.tag == tnumb && y.tag == tnumb) {
  10. return SDNUMB(x.data.ivalue + y.data.ivalue);
  11. }
  12. log_err("runtime_eq/bltn_eq: non-number argument\n");
  13. exit(-1);
  14. }
  15. // subtraction
  16. sdata bltn__(sdata x, sdata y) {
  17. if (x.tag == tnumb && y.tag == tnumb) {
  18. return SDNUMB(x.data.ivalue - y.data.ivalue);
  19. }
  20. log_err("runtime_eq/bltn_minus: non-number argument\n");
  21. exit(-1);
  22. }
  23. // multiply
  24. sdata bltn__star(sdata x, sdata y) {
  25. if (x.tag == tnumb && y.tag == tnumb) {
  26. return SDNUMB(x.data.ivalue * y.data.ivalue);
  27. }
  28. log_err("runtime_eq/bltn_minus: non-number argument\n");
  29. exit(-1);
  30. }
  31. // divide
  32. sdata bltn__slash(sdata x, sdata y) {
  33. if (x.tag == tnumb && y.tag == tnumb) {
  34. return SDNUMB(x.data.ivalue / y.data.ivalue);
  35. }
  36. log_err("runtime_eq/bltn_minus: non-number argument\n");
  37. exit(-1);
  38. }
  39. // modulo
  40. sdata bltn_modulo(sdata x, sdata y) {
  41. if (x.tag == tnumb && y.tag == tnumb) {
  42. return SDNUMB(x.data.ivalue % y.data.ivalue);
  43. }
  44. log_err("runtime_eq/bltn_minus: non-number argument\n");
  45. exit(-1);
  46. }
  47. // =
  48. sdata bltn__eql(sdata x, sdata y) {
  49. if (x.tag == tnumb && y.tag == tnumb) {
  50. return SDBOOL(x.data.ivalue == y.data.ivalue);
  51. }
  52. log_err("runtime_eq/bltn_minus: non-number argument\n");
  53. exit(-1);
  54. }
  55. // >
  56. sdata bltn__to(sdata x, sdata y) {
  57. if (x.tag == tnumb && y.tag == tnumb) {
  58. return SDBOOL(x.data.ivalue > y.data.ivalue);
  59. }
  60. log_err("runtime_eq/bltn_minus: non-number argument\n");
  61. exit(-1);
  62. }
  63. // <
  64. sdata bltn__lt(sdata x, sdata y) {
  65. if (x.tag == tnumb && y.tag == tnumb) {
  66. return SDBOOL(x.data.ivalue < y.data.ivalue);
  67. }
  68. log_err("runtime_eq/bltn_minus: non-number argument\n");
  69. exit(-1);
  70. }
  71. // >=
  72. sdata bltn__to_eql(sdata x, sdata y) {
  73. if (x.tag == tnumb && y.tag == tnumb) {
  74. return SDBOOL(x.data.ivalue >= y.data.ivalue);
  75. }
  76. log_err("runtime_eq/bltn_minus: non-number argument\n");
  77. exit(-1);
  78. }
  79. // <=
  80. sdata bltn__lt_eql(sdata x, sdata y) {
  81. if (x.tag == tnumb && y.tag == tnumb) {
  82. return SDBOOL(x.data.ivalue <= y.data.ivalue);
  83. }
  84. log_err("runtime_eq/bltn_minus: non-number argument\n");
  85. exit(-1);
  86. }