summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordefault <nobody@localhost>2022-09-20 12:50:37 +0200
committerdefault <nobody@localhost>2022-09-20 12:50:37 +0200
commit922b04b4d79c01d13a0de71edf934f019f5a9771 (patch)
tree3d9af6fd42033e5dabfd6cd0187c1130ab6ecb6d
parente923a4f5ec586d9dcec90e585b8d50cfbeafb8a1 (diff)
New function dequeue().
-rw-r--r--data.c20
-rw-r--r--main.c5
-rw-r--r--snac.h1
3 files changed, 25 insertions, 1 deletions
diff --git a/data.c b/data.c
index e875f90..0c0d6a2 100644
--- a/data.c
+++ b/data.c
@@ -587,3 +587,23 @@ d_char *queue(snac *snac)
return list;
}
+
+
+d_char *dequeue(snac *snac, char *fn)
+/* dequeues a message */
+{
+ FILE *f;
+ d_char *obj = NULL;
+
+ if ((f = fopen(fn, "r")) != NULL) {
+ /* delete right now */
+ unlink(fn);
+
+ xs *j = xs_readall(f);
+ obj = xs_json_loads(j);
+
+ fclose(f);
+ }
+
+ return obj;
+}
diff --git a/main.c b/main.c
index dd072e2..42606c2 100644
--- a/main.c
+++ b/main.c
@@ -21,7 +21,10 @@ int main(int argc, char *argv[])
p = list;
while (xs_list_iter(&p, &fn)) {
- printf("%s\n", fn);
+ xs *obj;
+
+ obj = dequeue(&snac, fn);
+ printf("%s\n", xs_dict_get(obj, "actor"));
}
}
diff --git a/snac.h b/snac.h
index 9e8432d..d2df160 100644
--- a/snac.h
+++ b/snac.h
@@ -60,3 +60,4 @@ int is_muted(snac *snac, char *actor);
void enqueue(snac *snac, char *actor, char *msg, int retries);
d_char *queue(snac *snac);
+d_char *dequeue(snac *snac, char *fn);