X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=src%2Fafb-context.h;h=5560585805bde1f67f3c35fc89b88cadde4625d7;hb=58ca325302568bfd7ddbdd5d2d4a31b49d0be85a;hp=35709e2002fb7710564975f3e47ec22ac2d90aa3;hpb=a38382e89710db2c298f7f101e3ba0cf3681287c;p=src%2Fapp-framework-binder.git diff --git a/src/afb-context.h b/src/afb-context.h index 35709e20..55605858 100644 --- a/src/afb-context.h +++ b/src/afb-context.h @@ -17,11 +17,11 @@ #pragma once -struct AFB_clientCtx; +struct afb_session; struct afb_context { - struct AFB_clientCtx *session; + struct afb_session *session; union { unsigned flags; struct { @@ -32,16 +32,14 @@ struct afb_context unsigned refreshed: 1; unsigned closing: 1; unsigned closed: 1; - unsigned loa_in: 3; - unsigned loa_out: 3; - unsigned loa_changing: 1; - unsigned loa_changed: 1; }; }; - int api_index; + void *api_key; + struct afb_context *super; }; -extern void afb_context_init(struct afb_context *context, struct AFB_clientCtx *session, const char *token); +extern void afb_context_init(struct afb_context *context, struct afb_session *session, const char *token); +extern void afb_context_subinit(struct afb_context *context, struct afb_context *super); extern int afb_context_connect(struct afb_context *context, const char *uuid, const char *token); extern void afb_context_disconnect(struct afb_context *context); extern const char *afb_context_sent_token(struct afb_context *context); @@ -49,10 +47,12 @@ extern const char *afb_context_sent_uuid(struct afb_context *context); extern void *afb_context_get(struct afb_context *context); extern void afb_context_set(struct afb_context *context, void *value, void (*free_value)(void*)); +extern void *afb_context_data(struct afb_context *context, void *(*make_value)(void), void (*free_value)(void*)); extern void afb_context_close(struct afb_context *context); extern void afb_context_refresh(struct afb_context *context); extern int afb_context_check(struct afb_context *context); extern int afb_context_check_loa(struct afb_context *context, unsigned loa); extern int afb_context_change_loa(struct afb_context *context, unsigned loa); +extern unsigned afb_context_get_loa(struct afb_context *context);