diff options
| author | Bruce Hill <bruce@bruce-hill.com> | 2024-09-13 19:59:28 -0400 |
|---|---|---|
| committer | Bruce Hill <bruce@bruce-hill.com> | 2024-09-13 19:59:28 -0400 |
| commit | 51c346bbc5f6c5179b56b09b75eec466acbe7ad7 (patch) | |
| tree | f20dc8b2ecec208dda83896be3448f9d6a8881b2 /builtins/functiontype.c | |
| parent | eae0a36b3921a9b4a93e8efa7b5f9d6b843c607b (diff) | |
Code cleanup
Diffstat (limited to 'builtins/functiontype.c')
| -rw-r--r-- | builtins/functiontype.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/builtins/functiontype.c b/builtins/functiontype.c new file mode 100644 index 00000000..c376ba26 --- /dev/null +++ b/builtins/functiontype.c @@ -0,0 +1,35 @@ +// Logic for handling function type values + +#include "datatypes.h" +#include "table.h" +#include "text.h" +#include "types.h" +#include "util.h" + +static Table_t function_names = {}; + +public void register_function(void *fn, Text_t name) +{ + Table$set(&function_names, &fn, &name, Table$info(Function$info("???"), &Text$info)); +} + +public Text_t *get_function_name(void *fn) +{ + return Table$get(function_names, &fn, Table$info(Function$info("???"), &Text$info)); +} + +public Text_t Func$as_text(const void *fn, bool colorize, const TypeInfo *type) +{ + (void)fn; + Text_t text = Text$from_str(type->FunctionInfo.type_str); + if (fn) { + Text_t *name = get_function_name(*(void**)fn); + if (name) + text = *name; + } + if (fn && colorize) + text = Text$concat(Text("\x1b[32;1m"), text, Text("\x1b[m")); + return text; +} + +// vim: ts=4 sw=0 et cino=L2,l1,(0,W4,m1,\:0 |
