struct _atom_ctx
{
- GError *error;
+ AtomError *error;
gpointer config_data;
+ AtomBackend *backend;
+ GHashTable *bemap;
};
+AtomCtx *
+atom_ctx_new ()
+{
+ AtomCtx *ctx;
+ 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_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, GError *error)
+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)
{
return ctx->config_data;
}
+
+void
+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);
+ }
+}