add anonymous functions
This commit is contained in:
@@ -0,0 +1,96 @@
|
||||
#include "parentheses-and-anonymous-function.h"
|
||||
#include "../assignable/identifier/identifier.h"
|
||||
#include "../function/function.h"
|
||||
#include "../../memory.h"
|
||||
#include <stddef.h>
|
||||
#include <string.h>
|
||||
|
||||
ParsedValueReturn parse_parentheses(char *file, DArray *tokens, size_t *index) {
|
||||
(*index)++;
|
||||
skip_newlines_and_indents(tokens, index);
|
||||
ArErr err = error_if_finished(file, tokens, index);
|
||||
if (err.exists) {
|
||||
// darray_free(&list, free_parsed);
|
||||
return (ParsedValueReturn){err, NULL};
|
||||
}
|
||||
DArray list;
|
||||
darray_init(&list, sizeof(ParsedValue));
|
||||
Token *token = darray_get(tokens, *index);
|
||||
if (token->type != TOKEN_RPAREN) {
|
||||
while (*index < tokens->size) {
|
||||
ParsedValueReturn parsedItem = parse_token(file, tokens, index, true);
|
||||
if (parsedItem.err.exists) {
|
||||
darray_free(&list, free_parsed);
|
||||
return parsedItem;
|
||||
}
|
||||
darray_push(&list, parsedItem.value);
|
||||
free(parsedItem.value);
|
||||
skip_newlines_and_indents(tokens, index);
|
||||
ArErr err = error_if_finished(file, tokens, index);
|
||||
if (err.exists) {
|
||||
darray_free(&list, free_parsed);
|
||||
return (ParsedValueReturn){err, NULL};
|
||||
}
|
||||
token = darray_get(tokens, *index);
|
||||
if (token->type == TOKEN_RPAREN) {
|
||||
break;
|
||||
} else if (token->type != TOKEN_COMMA) {
|
||||
darray_free(&list, free_parsed);
|
||||
return (ParsedValueReturn){create_err(token->line, token->column,
|
||||
token->length, file,
|
||||
"Syntax Error", "expected comma"),
|
||||
NULL};
|
||||
}
|
||||
skip_newlines_and_indents(tokens, index);
|
||||
err = error_if_finished(file, tokens, index);
|
||||
if (err.exists) {
|
||||
darray_free(&list, free_parsed);
|
||||
return (ParsedValueReturn){err, NULL};
|
||||
}
|
||||
}
|
||||
}
|
||||
(*index)++;
|
||||
if (*index < tokens->size) {
|
||||
token = darray_get(tokens, *index);
|
||||
if (token->type == TOKEN_ASSIGN) {
|
||||
(*index)++;
|
||||
ArErr err = error_if_finished(file, tokens, index);
|
||||
if (err.exists) {
|
||||
darray_free(&list, free_parsed);
|
||||
return (ParsedValueReturn){err, NULL};
|
||||
}
|
||||
DArray parameters;
|
||||
darray_init(¶meters, sizeof(char *));
|
||||
for (size_t i = 0; i < list.size; i++) {
|
||||
ParsedValue *item = darray_get(&list, i);
|
||||
if (item->type != AST_IDENTIFIER) {
|
||||
return (ParsedValueReturn){
|
||||
create_err(token->line, token->column, token->length, file,
|
||||
"Syntax Error", "expected identifier"),
|
||||
NULL};
|
||||
}
|
||||
char *param = strdup(((ParsedIdentifier *)item->data)->name);
|
||||
darray_push(¶meters, ¶m);
|
||||
}
|
||||
darray_free(&list, free_parsed);
|
||||
ParsedValueReturn parsedBody = parse_token(file, tokens, index, true);
|
||||
if (parsedBody.err.exists) {
|
||||
darray_free(¶meters, free_parameter);
|
||||
return parsedBody;
|
||||
}
|
||||
return (ParsedValueReturn){
|
||||
no_err,
|
||||
create_parsed_function("anonymous", parameters, parsedBody.value)};
|
||||
}
|
||||
}
|
||||
if (list.size != 1) {
|
||||
return (ParsedValueReturn){create_err(token->line, token->column,
|
||||
token->length, file, "Syntax Error",
|
||||
"expected 1 body"),
|
||||
NULL};
|
||||
}
|
||||
ParsedValue *parsedValue = checked_malloc(sizeof(ParsedValue));
|
||||
memcpy(parsedValue, darray_get(&list, 0), sizeof(ParsedValue));
|
||||
darray_free(&list, NULL);
|
||||
return (ParsedValueReturn){no_err, parsedValue};
|
||||
}
|
||||
@@ -0,0 +1,14 @@
|
||||
/*
|
||||
* SPDX-FileCopyrightText: 2025 William Bell
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
*/
|
||||
|
||||
#ifndef parentheses_and_anonymous_function_H
|
||||
#define parentheses_and_anonymous_function_H
|
||||
#include "../parser.h"
|
||||
#include "../../lexer/token.h"
|
||||
|
||||
ParsedValueReturn parse_parentheses(char *file, DArray *tokens, size_t *index);
|
||||
|
||||
#endif // parentheses_and_anonymous_function_H
|
||||
@@ -13,6 +13,7 @@
|
||||
#include "assignable/identifier/identifier.h"
|
||||
#include "declaration/declaration.h"
|
||||
#include "dictionary/dictionary.h"
|
||||
#include "parentheses-and-anonymous-function/parentheses-and-anonymous-function.h"
|
||||
#include "dowrap/dowrap.h"
|
||||
#include "function/function.h"
|
||||
#include "if/if.h"
|
||||
@@ -128,6 +129,9 @@ ParsedValueReturn parse_token_full(char *file, DArray *tokens, size_t *index,
|
||||
case TOKEN_LBRACKET:
|
||||
output = parse_list(file, tokens, index);
|
||||
break;
|
||||
case TOKEN_LPAREN:
|
||||
output = parse_parentheses(file, tokens, index);
|
||||
break;
|
||||
case TOKEN_LBRACE:
|
||||
output = parse_dictionary(file, tokens, index);
|
||||
break;
|
||||
|
||||
Reference in New Issue
Block a user