ast-inspect.c 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. #include "token.h"
  2. #include "parse.h"
  3. #include "symbol.h"
  4. #include "ast-inspect.h"
  5. #include "expression.h"
  6. static inline void inspect_ptr_list(AstNode *node, const char *name, void (*inspect)(AstNode *))
  7. {
  8. struct ptr_list *ptrlist = node->ptr;
  9. void *ptr;
  10. int i = 0;
  11. node->text = g_strdup_printf("%s %s:", node->text, name);
  12. FOR_EACH_PTR(ptrlist, ptr) {
  13. char *index = g_strdup_printf("%d: ", i++);
  14. ast_append_child(node, index, ptr, inspect);
  15. } END_FOR_EACH_PTR(ptr);
  16. }
  17. static const char *statement_type_name(enum statement_type type)
  18. {
  19. static const char *statement_type_name[] = {
  20. [STMT_NONE] = "STMT_NONE",
  21. [STMT_DECLARATION] = "STMT_DECLARATION",
  22. [STMT_EXPRESSION] = "STMT_EXPRESSION",
  23. [STMT_COMPOUND] = "STMT_COMPOUND",
  24. [STMT_IF] = "STMT_IF",
  25. [STMT_RETURN] = "STMT_RETURN",
  26. [STMT_CASE] = "STMT_CASE",
  27. [STMT_SWITCH] = "STMT_SWITCH",
  28. [STMT_ITERATOR] = "STMT_ITERATOR",
  29. [STMT_LABEL] = "STMT_LABEL",
  30. [STMT_GOTO] = "STMT_GOTO",
  31. [STMT_ASM] = "STMT_ASM",
  32. [STMT_CONTEXT] = "STMT_CONTEXT",
  33. [STMT_RANGE] = "STMT_RANGE",
  34. };
  35. return statement_type_name[type] ?: "UNKNOWN_STATEMENT_TYPE";
  36. }
  37. void inspect_statement(AstNode *node)
  38. {
  39. struct statement *stmt = node->ptr;
  40. node->text = g_strdup_printf("%s %s:", node->text, statement_type_name(stmt->type));
  41. switch (stmt->type) {
  42. case STMT_COMPOUND:
  43. ast_append_child(node, "stmts:", stmt->stmts, inspect_statement_list);
  44. break;
  45. case STMT_EXPRESSION:
  46. ast_append_child(node, "expression:", stmt->expression, inspect_expression);
  47. break;
  48. case STMT_IF:
  49. ast_append_child(node, "conditional:", stmt->if_conditional, inspect_expression);
  50. ast_append_child(node, "if_true:", stmt->if_true, inspect_statement);
  51. ast_append_child(node, "if_false:", stmt->if_false, inspect_statement);
  52. break;
  53. case STMT_ITERATOR:
  54. ast_append_child(node, "break:", stmt->iterator_break, inspect_symbol);
  55. ast_append_child(node, "continue:", stmt->iterator_continue, inspect_symbol);
  56. ast_append_child(node, "pre_statement:", stmt->iterator_pre_statement,
  57. inspect_statement);
  58. ast_append_child(node, "statement:", stmt->iterator_statement,
  59. inspect_statement);
  60. ast_append_child(node, "post_statement:", stmt->iterator_post_statement,
  61. inspect_statement);
  62. break;
  63. case STMT_SWITCH:
  64. ast_append_child(node, "switch_expression:", stmt->switch_expression, inspect_expression);
  65. ast_append_child(node, "switch_statement:", stmt->switch_statement, inspect_statement);
  66. ast_append_child(node, "switch_break:", stmt->switch_break, inspect_symbol);
  67. ast_append_child(node, "switch_case:", stmt->switch_case, inspect_symbol);
  68. break;
  69. case STMT_CASE:
  70. ast_append_child(node, "case_expression:", stmt->case_expression, inspect_expression);
  71. ast_append_child(node, "case_to:", stmt->case_to, inspect_expression);
  72. ast_append_child(node, "case_statement:", stmt->case_statement, inspect_statement);
  73. ast_append_child(node, "case_label:", stmt->case_label, inspect_symbol);
  74. break;
  75. case STMT_RETURN:
  76. ast_append_child(node, "ret_value:", stmt->ret_value, inspect_expression);
  77. ast_append_child(node, "ret_target:", stmt->ret_target, inspect_symbol);
  78. break;
  79. default:
  80. break;
  81. }
  82. }
  83. void inspect_statement_list(AstNode *node)
  84. {
  85. inspect_ptr_list(node, "statement_list", inspect_statement);
  86. }
  87. static const char *symbol_type_name(enum type type)
  88. {
  89. static const char *type_name[] = {
  90. [SYM_UNINITIALIZED] = "SYM_UNINITIALIZED",
  91. [SYM_PREPROCESSOR] = "SYM_PREPROCESSOR",
  92. [SYM_BASETYPE] = "SYM_BASETYPE",
  93. [SYM_NODE] = "SYM_NODE",
  94. [SYM_PTR] = "SYM_PTR",
  95. [SYM_FN] = "SYM_FN",
  96. [SYM_ARRAY] = "SYM_ARRAY",
  97. [SYM_STRUCT] = "SYM_STRUCT",
  98. [SYM_UNION] = "SYM_UNION",
  99. [SYM_ENUM] = "SYM_ENUM",
  100. [SYM_TYPEOF] = "SYM_TYPEOF",
  101. [SYM_BITFIELD] = "SYM_BITFIELD",
  102. [SYM_LABEL] = "SYM_LABEL",
  103. [SYM_RESTRICT] = "SYM_RESTRICT",
  104. [SYM_FOULED] = "SYM_FOULED",
  105. [SYM_KEYWORD] = "SYM_KEYWORD",
  106. [SYM_BAD] = "SYM_BAD",
  107. };
  108. return type_name[type] ?: "UNKNOWN_TYPE";
  109. }
  110. void inspect_symbol(AstNode *node)
  111. {
  112. struct symbol *sym = node->ptr;
  113. node->text = g_strdup_printf("%s %s: %s", node->text, symbol_type_name(sym->type),
  114. builtin_typename(sym) ?: show_ident(sym->ident));
  115. ast_append_child(node, "ctype.base_type:", sym->ctype.base_type,inspect_symbol);
  116. switch (sym->namespace) {
  117. case NS_PREPROCESSOR:
  118. break;
  119. default:
  120. ast_append_child(node, "arguments:", sym->arguments, inspect_symbol_list);
  121. ast_append_child(node, "symbol_list:", sym->symbol_list, inspect_symbol_list);
  122. ast_append_child(node, "stmt:", sym->stmt, inspect_statement);
  123. break;
  124. }
  125. }
  126. void inspect_symbol_list(AstNode *node)
  127. {
  128. inspect_ptr_list(node, "symbol_list", inspect_symbol);
  129. }
  130. static const char *expression_type_name(enum expression_type type)
  131. {
  132. static const char *expression_type_name[] = {
  133. [EXPR_VALUE] = "EXPR_VALUE",
  134. [EXPR_STRING] = "EXPR_STRING",
  135. [EXPR_SYMBOL] = "EXPR_SYMBOL",
  136. [EXPR_TYPE] = "EXPR_TYPE",
  137. [EXPR_BINOP] = "EXPR_BINOP",
  138. [EXPR_ASSIGNMENT] = "EXPR_ASSIGNMENT",
  139. [EXPR_LOGICAL] = "EXPR_LOGICAL",
  140. [EXPR_DEREF] = "EXPR_DEREF",
  141. [EXPR_PREOP] = "EXPR_PREOP",
  142. [EXPR_POSTOP] = "EXPR_POSTOP",
  143. [EXPR_CAST] = "EXPR_CAST",
  144. [EXPR_FORCE_CAST] = "EXPR_FORCE_CAST",
  145. [EXPR_IMPLIED_CAST] = "EXPR_IMPLIED_CAST",
  146. [EXPR_SIZEOF] = "EXPR_SIZEOF",
  147. [EXPR_ALIGNOF] = "EXPR_ALIGNOF",
  148. [EXPR_PTRSIZEOF] = "EXPR_PTRSIZEOF",
  149. [EXPR_CONDITIONAL] = "EXPR_CONDITIONAL",
  150. [EXPR_SELECT] = "EXPR_SELECT",
  151. [EXPR_STATEMENT] = "EXPR_STATEMENT",
  152. [EXPR_CALL] = "EXPR_CALL",
  153. [EXPR_COMMA] = "EXPR_COMMA",
  154. [EXPR_COMPARE] = "EXPR_COMPARE",
  155. [EXPR_LABEL] = "EXPR_LABEL",
  156. [EXPR_INITIALIZER] = "EXPR_INITIALIZER",
  157. [EXPR_IDENTIFIER] = "EXPR_IDENTIFIER",
  158. [EXPR_INDEX] = "EXPR_INDEX",
  159. [EXPR_POS] = "EXPR_POS",
  160. [EXPR_FVALUE] = "EXPR_FVALUE",
  161. [EXPR_SLICE] = "EXPR_SLICE",
  162. [EXPR_OFFSETOF] = "EXPR_OFFSETOF",
  163. };
  164. return expression_type_name[type] ?: "UNKNOWN_EXPRESSION_TYPE";
  165. }
  166. void inspect_expression(AstNode *node)
  167. {
  168. struct expression *expr = node->ptr;
  169. node->text = g_strdup_printf("%s %s", node->text, expression_type_name(expr->type));
  170. switch (expr->type) {
  171. case EXPR_STATEMENT:
  172. ast_append_child(node, "statement:", expr->statement, inspect_statement);
  173. break;
  174. case EXPR_BINOP:
  175. case EXPR_COMMA:
  176. case EXPR_COMPARE:
  177. case EXPR_LOGICAL:
  178. case EXPR_ASSIGNMENT:
  179. ast_append_child(node, "left:", expr->left, inspect_expression);
  180. ast_append_child(node, "right:", expr->right, inspect_expression);
  181. break;
  182. case EXPR_CAST:
  183. case EXPR_FORCE_CAST:
  184. case EXPR_IMPLIED_CAST:
  185. ast_append_child(node, "cast_type:", expr->cast_type, inspect_symbol);
  186. ast_append_child(node, "cast_expression:", expr->cast_expression, inspect_expression);
  187. break;
  188. case EXPR_PREOP:
  189. ast_append_child(node, "unop:", expr->unop, inspect_expression);
  190. break;
  191. default:
  192. break;
  193. }
  194. }