summaryrefslogtreecommitdiff
path: root/src/sys/np/core/np_parse.c
diff options
context:
space:
mode:
authorIan Moffett <ian@osmora.org>2025-10-02 20:06:06 -0400
committerIan Moffett <ian@osmora.org>2025-10-02 20:06:06 -0400
commitc904bc2b78045bd81cfc3603422c385cbf7adc75 (patch)
treec5a0dd4b35a8ee69512b18c12f774b3699a24d0a /src/sys/np/core/np_parse.c
parentee1e4b1e7cce34ff049c5ee48c8bbeef6c6e5596 (diff)
kern: np: Add support for return statements
This commit introduces lexical, parsing and code generation support for the return statements. As of now, one is only able to return unsigned integers but this will be expanded upon in the future Signed-off-by: Ian Moffett <ian@osmora.org>
Diffstat (limited to 'src/sys/np/core/np_parse.c')
-rw-r--r--src/sys/np/core/np_parse.c37
1 files changed, 36 insertions, 1 deletions
diff --git a/src/sys/np/core/np_parse.c b/src/sys/np/core/np_parse.c
index 4119d8b..b7b854b 100644
--- a/src/sys/np/core/np_parse.c
+++ b/src/sys/np/core/np_parse.c
@@ -84,7 +84,8 @@ static const char *stoktab[] = {
/* Keywords */
[TT_BEGIN] = "<TT_BEGIN>",
[TT_PROC] = "<TT_PROC>",
- [TT_END] = "<TT_END>"
+ [TT_END] = "<TT_END>",
+ [TT_RETURN] = "<TT_RETURN>"
};
/*
@@ -173,6 +174,35 @@ parse_type(struct np_work *work, struct lex_token *tok)
}
/*
+ * Parse a return statement
+ *
+ * @work: Input work
+ * @tok: Current token
+ *
+ * Returns zero on success
+ */
+static int
+parse_return(struct np_work *work, struct lex_token *tok)
+{
+ tt_t tt;
+
+ /*
+ * For now we'll only accept numbers as return values
+ * so we must see one after the return statement
+ */
+ tt = parse_expect(work, "return", TT_NUMBER, tok);
+ if (tt == TT_NONE) {
+ return -1;
+ }
+
+#define PIIR_PUSH(BYTE) piir_push(work->piir_stack, (BYTE))
+ PIIR_PUSH(PIIR_RET_NUM);
+ PIIR_PUSH(tok->val);
+#undef PIIR_PUSH
+ return 0;
+}
+
+/*
* Parse a procedure / function
*
* @work: Input work
@@ -311,6 +341,11 @@ parse_token(struct np_work *work, struct lex_token *tok)
/* XXX: NOP for testing */
PIIR_PUSH(PIIR_NOP);
break;
+ case TT_RETURN:
+ if ((error = parse_return(work, tok)) != 0) {
+ return -1;
+ }
+ break;
}
#undef PIIR_PUSH
return 0;