summaryrefslogtreecommitdiff
path: root/xs.h
diff options
context:
space:
mode:
authordefault <nobody@localhost>2024-08-11 21:50:45 +0200
committerdefault <nobody@localhost>2024-08-11 21:50:45 +0200
commit45278afdf116c6f7ced29b6ada7fe6c6a67b04b4 (patch)
tree7c6be932dc60f467e1bbdd151b083aeb2deab7ce /xs.h
parent3dbeee863e5004612993047dfe5650c1d59531c5 (diff)
Backport from xs.
Diffstat (limited to 'xs.h')
-rw-r--r--xs.h18
1 files changed, 13 insertions, 5 deletions
diff --git a/xs.h b/xs.h
index 608dc3a..ae851eb 100644
--- a/xs.h
+++ b/xs.h
@@ -60,6 +60,7 @@ xstype xs_type(const xs_val *data);
int xs_size(const xs_val *data);
int xs_is_null(const xs_val *data);
int xs_cmp(const xs_val *v1, const xs_val *v2);
+const xs_val *xs_or(const xs_val *v1, const xs_val *v2);
xs_val *xs_dup(const xs_val *data);
xs_val *xs_expand(xs_val *data, int offset, int size);
xs_val *xs_collapse(xs_val *data, int offset, int size);
@@ -119,8 +120,8 @@ xs_dict *xs_dict_new(void);
xs_dict *xs_dict_append(xs_dict *dict, const xs_str *key, const xs_val *value);
xs_dict *xs_dict_prepend(xs_dict *dict, const xs_str *key, const xs_val *value);
int xs_dict_next(const xs_dict *dict, const xs_str **key, const xs_val **value, int *ctxt);
-const xs_val *xs_dict_get_def(const xs_dict *dict, const xs_str *key, const xs_val *def);
-#define xs_dict_get(dict, key) xs_dict_get_def(dict, key, NULL)
+const xs_val *xs_dict_get(const xs_dict *dict, const xs_str *key);
+#define xs_dict_get_def(dict, key, def) xs_or(xs_dict_get(dict, key), def)
xs_dict *xs_dict_del(xs_dict *dict, const xs_str *key);
xs_dict *xs_dict_set(xs_dict *dict, const xs_str *key, const xs_val *data);
xs_dict *xs_dict_gc(const xs_dict *dict);
@@ -360,6 +361,13 @@ int xs_cmp(const xs_val *v1, const xs_val *v2)
}
+const xs_val *xs_or(const xs_val *v1, const xs_val *v2)
+/* returns v1 if it's not NULL, else v2 */
+{
+ return v1 == NULL ? v2 : v1;
+}
+
+
xs_val *xs_dup(const xs_val *data)
/* creates a duplicate of data */
{
@@ -1211,8 +1219,8 @@ xs_dict *xs_dict_del(xs_dict *dict, const xs_str *key)
}
-const xs_val *xs_dict_get_def(const xs_dict *dict, const xs_str *key, const xs_str *def)
-/* gets a value by key, or returns def */
+const xs_val *xs_dict_get(const xs_dict *dict, const xs_str *key)
+/* gets a value by key, or NULL */
{
if (xs_type(dict) == XSTYPE_DICT) {
int *o = _xs_dict_locate(dict, key);
@@ -1226,7 +1234,7 @@ const xs_val *xs_dict_get_def(const xs_dict *dict, const xs_str *key, const xs_s
}
}
- return def;
+ return NULL;
}