From 9c1dde4763c8f319ade00f2df21a1276f9d88248 Mon Sep 17 00:00:00 2001 From: jacopodl Date: Fri, 26 Jul 2024 17:33:51 +0200 Subject: [PATCH] feat: add 'id' builtin function to retrieve unique object identifier --- argon/vm/mod/builtins.cpp | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/argon/vm/mod/builtins.cpp b/argon/vm/mod/builtins.cpp index cd72dd01..f69627b0 100644 --- a/argon/vm/mod/builtins.cpp +++ b/argon/vm/mod/builtins.cpp @@ -161,6 +161,18 @@ ARGON_FUNCTION(builtins_getattr, getattr, return res; } +ARGON_FUNCTION(builtins_id, id, + "Return the identity of an object.\n" + "\n" + "Returns a unique integer identifier for an object. This identifier remains constant throughout the object's lifetime. " + "The same identifier may be reused for different objects that exist at separate times.\n" + "\n" + "- Parameter obj: Object to check.\n" + "- Returns: Object memory address (UInt).\n", + ": obj", false, false) { + return (ArObject *) UIntNew(*((uintptr_t *) args)); +} + ARGON_FUNCTION(builtins_iscallable, iscallable, "Return true if argument appears callable, false otherwise.\n" "\n" @@ -339,7 +351,7 @@ ARGON_FUNCTION(builtins_show, show, Release(aux); } - ret = ListNew((ArObject*)target); + ret = ListNew((ArObject *) target); Release(target); @@ -417,6 +429,7 @@ const ModuleEntry builtins_entries[] = { //MODULE_EXPORT_FUNCTION(builtins_exit), MODULE_EXPORT_FUNCTION(builtins_eval), MODULE_EXPORT_FUNCTION(builtins_getattr), + MODULE_EXPORT_FUNCTION(builtins_id), MODULE_EXPORT_FUNCTION(builtins_iscallable), MODULE_EXPORT_FUNCTION(builtins_implements), MODULE_EXPORT_FUNCTION(builtins_len),