struct _atom_ctx
{
- GError *error;
+ AtomError *error;
gpointer config_data;
+ AtomBackend *backend;
+ GHashTable *bemap;
};
AtomCtx *
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)
{
{
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);
+ }
+}