Add function to search for reserved operators.
This commit is contained in:
parent
ab2311def9
commit
d25c1a379a
@ -8,7 +8,7 @@ project(libabacus)
|
||||
|
||||
add_compile_options(-pedantic -Wall)
|
||||
|
||||
add_library(abacus STATIC src/lexer.c src/util.c src/table.c src/parser.c src/libabacus.c src/tree.c src/debug.c src/parsetype.c)
|
||||
add_library(abacus STATIC src/lexer.c src/util.c src/table.c src/parser.c src/libabacus.c src/tree.c src/debug.c src/parsetype.c src/reserved.c)
|
||||
add_executable(libabacus src/main.c)
|
||||
add_subdirectory(external/liblex)
|
||||
|
||||
|
41
include/reserved.h
Normal file
41
include/reserved.h
Normal file
@ -0,0 +1,41 @@
|
||||
#ifndef LIBABACUS_RESERVED_H
|
||||
#define LIBABACUS_RESERVED_H
|
||||
|
||||
#include "result.h"
|
||||
#include "parsetype.h"
|
||||
#include "tree.h"
|
||||
#include "value.h"
|
||||
#include "libabacus.h"
|
||||
|
||||
/**
|
||||
* Struct that represents a reserved operator that contains
|
||||
* interpreter-internal behavior.
|
||||
*/
|
||||
struct libab_reserved_operator_s {
|
||||
/**
|
||||
* The reserved operator.
|
||||
*/
|
||||
const char* op;
|
||||
/**
|
||||
* The precedence of this operator.
|
||||
*/
|
||||
int precedence;
|
||||
/**
|
||||
* The associativity of this operator.
|
||||
*/
|
||||
int associativity;
|
||||
};
|
||||
|
||||
typedef struct libab_reserved_operator_s libab_reserved_operator;
|
||||
|
||||
/**
|
||||
* Attempts to find a reserved operator with the given name.
|
||||
* This function operates under the assumption that there are
|
||||
* few reserved operators in libabacus. As such, it does effectively
|
||||
* a polynomial time search - strcmp for every element until the operator is found.
|
||||
* @param name the name to search for.
|
||||
* @return the reserved operator, if it is found.
|
||||
*/
|
||||
const libab_reserved_operator* libab_find_reserved_operator(const char* name);
|
||||
|
||||
#endif
|
21
src/reserved.c
Normal file
21
src/reserved.c
Normal file
@ -0,0 +1,21 @@
|
||||
#include "reserved.h"
|
||||
#include "string.h"
|
||||
|
||||
static const libab_reserved_operator libab_reserved_operators[] = {
|
||||
{
|
||||
"=", /* Assignment */
|
||||
0, /* Lowest precedence */
|
||||
1 /* Right associative, a = b = 6 should be a = (b = 6) */
|
||||
}
|
||||
};
|
||||
|
||||
const libab_reserved_operator* libab_find_reserved_operator(const char* name) {
|
||||
static const size_t element_count =
|
||||
sizeof(libab_reserved_operators) / sizeof(libab_reserved_operator);
|
||||
size_t i;
|
||||
for(i = 0; i < element_count; i++) {
|
||||
if(strcmp(name, libab_reserved_operators[i].op) == 0)
|
||||
return &libab_reserved_operators[i];
|
||||
}
|
||||
return NULL;
|
||||
}
|
Loading…
Reference in New Issue
Block a user