Update entry xml node before using it
[cascardo/atompub.git] / src / ctx.c
index 9b81a3b..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 *
@@ -34,15 +36,38 @@ atom_ctx_new ()
   ctx = g_slice_new (AtomCtx);
   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;
 }
 
 void
-atom_error_set (AtomCtx *ctx, GError *error)
+atom_ctx_delete (AtomCtx *ctx)
 {
+  if (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, AtomError *error)
+{
+  if (ctx->error)
+    atom_error_delete (ctx->error);
   ctx->error = error;
 }
 
+AtomError *
+atom_error_get (AtomCtx *ctx)
+{
+  return ctx->error;
+}
+
 void *
 atom_config_data (AtomCtx *ctx)
 {
@@ -54,3 +79,28 @@ atom_config_data_set (AtomCtx *ctx, void *data)
 {
   ctx->config_data = data;
 }
+
+AtomBackend *
+atom_backend (AtomCtx *ctx)
+{
+  return ctx->backend;
+}
+
+void
+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);
+    }
+}