Added map from atom:IDs to backend requests
[cascardo/atompub.git] / src / ctx.c
index e9d940b..a472dae 100644 (file)
--- a/src/ctx.c
+++ b/src/ctx.c
@@ -26,6 +26,7 @@ struct _atom_ctx
   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;
 }
 
@@ -46,6 +49,8 @@ atom_ctx_delete (AtomCtx *ctx)
     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);
 }
 
@@ -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);
+    }
+}