aboutsummaryrefslogtreecommitdiffhomepage
path: root/preprocess.c
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2025-07-21 17:44:22 +0900
committernsfisis <nsfisis@gmail.com>2025-08-15 10:04:29 +0900
commitadfe15f9fa0f4e69b343679dca6cf12fc96e3819 (patch)
tree8c50b5fe714c4cfb4337e9cbc7a56dc21d394abd /preprocess.c
parent6daa56323634e1142f2d22a756a77a74382cf3a7 (diff)
downloadducc-adfe15f9fa0f4e69b343679dca6cf12fc96e3819.tar.gz
ducc-adfe15f9fa0f4e69b343679dca6cf12fc96e3819.tar.zst
ducc-adfe15f9fa0f4e69b343679dca6cf12fc96e3819.zip
feat: define __ducc__ macro
Diffstat (limited to 'preprocess.c')
-rw-r--r--preprocess.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/preprocess.c b/preprocess.c
index 202ff40..a8b3b91 100644
--- a/preprocess.c
+++ b/preprocess.c
@@ -48,6 +48,17 @@ PpDefines* pp_defines_new() {
return pp_defines;
}
+void add_predefined_macros(PpDefines* pp_defines) {
+ PpDefine* pp_define = pp_defines->data + pp_defines->len;
+ pp_define->name.len = strlen("__ducc__");
+ pp_define->name.data = "__ducc__";
+ pp_define->tokens = calloc(1, sizeof(PpToken));
+ pp_define->tokens[0].kind = PpTokenKind_pp_number;
+ pp_define->tokens[0].raw.len = strlen("1");
+ pp_define->tokens[0].raw.data = "1";
+ pp_defines->len += 1;
+}
+
Preprocessor* preprocessor_new(char* src, int include_depth, PpDefines* pp_defines) {
if (include_depth >= 32) {
fatal_error("include depth limit exceeded");
@@ -427,5 +438,7 @@ PpToken* do_preprocess(char* src, int depth, PpDefines* pp_defines) {
}
PpToken* preprocess(char* src) {
- return do_preprocess(src, 0, pp_defines_new());
+ PpDefines* pp_defines = pp_defines_new();
+ add_predefined_macros(pp_defines);
+ return do_preprocess(src, 0, pp_defines);
}