summaryrefslogtreecommitdiff
path: root/src/lib/batch.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/batch.c')
-rw-r--r--src/lib/batch.c75
1 files changed, 58 insertions, 17 deletions
diff --git a/src/lib/batch.c b/src/lib/batch.c
index e728557..91def77 100644
--- a/src/lib/batch.c
+++ b/src/lib/batch.c
@@ -7,44 +7,65 @@
#include "mdb.h"
static int setkey_helper(void *thr_data);
-/*static int delkey_helper(void *thr_data);*/
+static int delkey_helper(void *thr_data);
+static int *clone(int n);
-
-tablist_t *copy;
-char *str;
+tablist_t *setkey_copy;
+char *setkey_str;
mtx_t setkey_mtx;
int setkeys(tablist_t **list, char *pair)
{
int rc;
- copy = calloc(list[0]->len, sizeof(tablist_t));
- memcpy(copy, *list, list[0]->len * sizeof(tablist_t));
- str = pair;
+ setkey_copy = calloc(list[0]->len, sizeof(tablist_t));
+ memcpy(setkey_copy, *list, list[0]->len * sizeof(tablist_t));
+ setkey_str = pair;
thrd_t *thrds = calloc(list[0]->len, sizeof(thrd_t));
if (mtx_init(&setkey_mtx, mtx_plain) != thrd_success)
return 1;
- for (int i = 0; i < copy[0].len; ++i) {
- int *arg = calloc(1, sizeof(int));
- *arg = i;
- thrd_create(&thrds[i], setkey_helper, arg);
- }
- for (int i = 0; i < copy[0].len; ++i) {
+ for (int i = 0; i < setkey_copy[0].len; ++i)
+ thrd_create(&thrds[i], setkey_helper, clone(i));
+ for (int i = 0; i < setkey_copy[0].len; ++i) {
thrd_join(thrds[i], &rc);
if (rc)
break;
}
if (!rc)
- memcpy(*list, copy, copy[0].len * sizeof(tablist_t));
+ memcpy(*list, setkey_copy, setkey_copy[0].len * sizeof(tablist_t));
free(thrds);
- free(copy);
+ free(setkey_copy);
return rc;
}
+tablist_t *delkey_copy;
+char *delkey_str;
+
+mtx_t delkey_mtx;
int delkeys(tablist_t *list, char *key)
{
- return 0;
+ int rc;
+ delkey_copy = calloc(list[0].len, sizeof(tablist_t));
+ memcpy(delkey_copy, list, list[0].len * sizeof(tablist_t));
+ delkey_str = key;
+
+ thrd_t *thrds = calloc(list[0].len, sizeof(thrd_t));
+ if (mtx_init(&delkey_mtx, mtx_plain) != thrd_success)
+ return 1;
+
+ for (int i = 0; i < delkey_copy[0].len; ++i)
+ thrd_create(&thrds[i], delkey_helper, clone(i));
+ for (int i = 0; i < delkey_copy[0].len; ++i) {
+ thrd_join(thrds[i], &rc);
+ if (rc)
+ break;
+ }
+ if (!rc)
+ memcpy(list, delkey_copy, delkey_copy[0].len * sizeof(tablist_t));
+ free(thrds);
+ free(delkey_copy);
+ return rc;
}
static int setkey_helper(void *thr_data)
@@ -53,9 +74,29 @@ static int setkey_helper(void *thr_data)
int rc;
mtx_lock(&setkey_mtx);
- rc = setkey(&copy, *id, str);
+ rc = setkey(&setkey_copy, *id, setkey_str);
mtx_unlock(&setkey_mtx);
free(id);
return rc;
}
+
+static int delkey_helper(void *thr_data)
+{
+ int *id = (int *) thr_data;
+ int rc;
+
+ mtx_lock(&delkey_mtx);
+ rc = delkey(delkey_copy, *id, delkey_str);
+ mtx_unlock(&delkey_mtx);
+
+ free(id);
+ return rc;
+}
+
+static int *clone(int n)
+{
+ int *c = calloc(1, sizeof(int));
+ *c = n;
+ return c;
+}