#ifndef ANVIL_CLIENT_H #define ANVIL_CLIENT_H enum anvil_client_flags { /* if connect() fails with ENOENT, hide the error */ ANVIL_CLIENT_FLAG_HIDE_ENOENT = 0x01 }; /* reply=NULL if query failed */ typedef void anvil_callback_t(const char *reply, void *context); /* If reconnect_callback is specified, it's called when connection is lost. If the callback returns FALSE, reconnection isn't attempted. */ struct anvil_client * anvil_client_init(const char *path, bool (*reconnect_callback)(void), enum anvil_client_flags flags) ATTR_NULL(2); void anvil_client_deinit(struct anvil_client **client); /* Connect to anvil. If retry=TRUE, try connecting for a while */ int anvil_client_connect(struct anvil_client *client, bool retry); /* Send a query to anvil, expect a one line reply. The returned pointer can be used to abort the query later. It becomes invalid when callback is called (= the callback must not call it). Returns NULL if the query couldn't be sent. */ struct anvil_query * anvil_client_query(struct anvil_client *client, const char *query, anvil_callback_t *callback, void *context); void anvil_client_query_abort(struct anvil_client *client, struct anvil_query **query); /* Send a command to anvil, don't expect any replies. */ void anvil_client_cmd(struct anvil_client *client, const char *cmd); /* Returns TRUE if anvil is connected to. */ bool anvil_client_is_connected(struct anvil_client *client); #endif