Update entry xml node before using it
[cascardo/atompub.git] / src / ctx.c
index 73f17fc..a472dae 100644 (file)
--- a/src/ctx.c
+++ b/src/ctx.c
 
 struct _atom_ctx
 {
-  GError *error;
+  AtomError *error;
   gpointer config_data;
   AtomBackend *backend;
+  GHashTable *bemap;
 };
 
 AtomCtx *
@@ -36,6 +37,8 @@ atom_ctx_new ()
   ctx->error = NULL;
   ctx->config_data = NULL;
   ctx->backend = NULL;
+  ctx->bemap = g_hash_table_new_full (g_str_hash, g_str_equal,
+                                      g_free, g_free);
   return ctx;
 }
 
@@ -43,21 +46,23 @@ void
 atom_ctx_delete (AtomCtx *ctx)
 {
   if (ctx->error)
-    g_error_free (ctx->error);
+    atom_error_delete (ctx->error);
   if (ctx->backend)
     atom_backend_delete (ctx->backend);
+  if (ctx->bemap)
+    g_hash_table_destroy (ctx->bemap);
   g_slice_free (AtomCtx, ctx);
 }
 
 void
-atom_error_set (AtomCtx *ctx, GError *error)
+atom_error_set (AtomCtx *ctx, AtomError *error)
 {
   if (ctx->error)
-    g_error_free (ctx->error);
+    atom_error_delete (ctx->error);
   ctx->error = error;
 }
 
-GError *
+AtomError *
 atom_error_get (AtomCtx *ctx)
 {
   return ctx->error;
@@ -86,3 +91,16 @@ atom_backend_set (AtomCtx *ctx, AtomBackend *backend)
 {
   ctx->backend = backend;
 }
+
+void
+atom_map_backend_requests (AtomCtx *ctx, char **reqs,
+                           AtomEntry **entries, size_t len)
+{
+  int i;
+  for (i = 0; i < len; i++)
+    {
+      char *key = g_strdup (atom_entry_id (entries[i]));
+      char *val = g_strdup (reqs[i]);
+      g_hash_table_replace (ctx->bemap, key, val);
+    }
+}