hilite.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. /* hlite.c, generic syntax highlighting, Ait Emacs, Kevin Bloom, BSD 3-Clause, 2023 */
  2. #include "header.h"
  3. #include "util.h"
  4. int state = ID_DEFAULT;
  5. int next_state = ID_DEFAULT;
  6. int skip_count = 0;
  7. char_t get_at(buffer_t *bp, point_t pt)
  8. {
  9. return (*ptr(bp, pt));
  10. }
  11. void set_parse_state(buffer_t *bp, point_t pt)
  12. {
  13. register point_t po;
  14. state = ID_DEFAULT;
  15. next_state = ID_DEFAULT;
  16. skip_count = 0;
  17. for (po =0; po < pt; po++)
  18. parse_text(bp, po);
  19. }
  20. int parse_text(buffer_t *bp, point_t pt)
  21. {
  22. // if(bp->b_keywords == NULL)
  23. // return state;
  24. if (skip_count-- > 0)
  25. return state;
  26. char_t c_now = get_at(bp, pt);
  27. char_t c_next = get_at(bp, pt + 1);
  28. state = next_state;
  29. if (state == ID_DEFAULT &&
  30. bp->b_keywords != NULL &&
  31. bp->b_keywords->mlc != NULL &&
  32. c_now == bp->b_keywords->mlc[0] &&
  33. c_next == bp->b_keywords->mlc[1]) {
  34. skip_count = 1;
  35. return (next_state = state = ID_BLOCK_COMMENT);
  36. }
  37. if (state == ID_BLOCK_COMMENT &&
  38. bp->b_keywords != NULL &&
  39. bp->b_keywords->emlc != NULL &&
  40. c_now == bp->b_keywords->emlc[0] &&
  41. c_next == bp->b_keywords->emlc[1]) {
  42. skip_count = 1;
  43. next_state = ID_DEFAULT;
  44. return ID_BLOCK_COMMENT;
  45. }
  46. if (state == ID_DEFAULT &&
  47. bp->b_keywords != NULL &&
  48. c_now == bp->b_keywords->slc[0] &&
  49. c_next == bp->b_keywords->slc[1]) {
  50. skip_count = 1;
  51. return (next_state = state = ID_LINE_COMMENT);
  52. }
  53. if (state == ID_LINE_COMMENT && c_now == '\n')
  54. return (next_state = ID_DEFAULT);
  55. if (state == ID_DEFAULT && c_now == '"')
  56. return (next_state = ID_DOUBLE_STRING);
  57. if (state == ID_DEFAULT &&
  58. bp->b_keywords != NULL &&
  59. bp->b_keywords->bqas &&
  60. c_now == '`')
  61. return (next_state = ID_BACK_STRING);
  62. if (state == ID_DEFAULT &&
  63. bp->b_keywords != NULL &&
  64. bp->b_keywords->sqas &&
  65. c_now == '\'')
  66. return (next_state = ID_SINGLE_STRING);
  67. if (state == ID_DOUBLE_STRING && c_now == '\\') {
  68. skip_count = 1;
  69. return (next_state = ID_DOUBLE_STRING);
  70. }
  71. if (state == ID_DOUBLE_STRING && c_now == '"') {
  72. next_state = ID_DEFAULT;
  73. return ID_DOUBLE_STRING;
  74. }
  75. if (state == ID_DEFAULT &&
  76. bp->b_keywords != NULL &&
  77. bp->b_keywords->sqas &&
  78. c_now == '\'')
  79. return (next_state = ID_SINGLE_STRING);
  80. if (state == ID_SINGLE_STRING && c_now == '\\') {
  81. skip_count = 1;
  82. return (next_state = ID_SINGLE_STRING);
  83. }
  84. if (state == ID_DEFAULT &&
  85. bp->b_keywords != NULL &&
  86. bp->b_keywords->bqas &&
  87. c_now == '`')
  88. return (next_state = ID_BACK_STRING);
  89. if (state == ID_BACK_STRING && c_now == '\\') {
  90. skip_count = 1;
  91. return (next_state = ID_BACK_STRING);
  92. }
  93. if (state == ID_SINGLE_STRING && c_now == '\'') {
  94. next_state = ID_DEFAULT;
  95. return ID_SINGLE_STRING;
  96. }
  97. if (state == ID_BACK_STRING && c_now == '`') {
  98. next_state = ID_DEFAULT;
  99. return ID_BACK_STRING;
  100. }
  101. if (state != ID_DEFAULT)
  102. return (next_state = state);
  103. // if (state == ID_DEFAULT && c_now >= '0' && c_now <= '9') {
  104. // next_state = ID_DEFAULT;
  105. // return (state = ID_DIGITS);
  106. // }
  107. // if (state == ID_DEFAULT && 1 == is_symbol(c_now)) {
  108. // next_state = ID_DEFAULT;
  109. // return (state = ID_SYMBOL);
  110. // }
  111. return (next_state = state);
  112. }