| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 | 
							-  /*
 
-  * libwebsockets - small server side websockets and web server implementation
 
-  *
 
-  * Copyright (C) 2010 - 2019 Andy Green <andy@warmcat.com>
 
-  *
 
-  * Permission is hereby granted, free of charge, to any person obtaining a copy
 
-  * of this software and associated documentation files (the "Software"), to
 
-  * deal in the Software without restriction, including without limitation the
 
-  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
 
-  * sell copies of the Software, and to permit persons to whom the Software is
 
-  * furnished to do so, subject to the following conditions:
 
-  *
 
-  * The above copyright notice and this permission notice shall be included in
 
-  * all copies or substantial portions of the Software.
 
-  *
 
-  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 
-  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 
-  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 
-  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 
-  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 
-  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 
-  * IN THE SOFTWARE.
 
-  *
 
-  * must be included manually as
 
-  *
 
-  *  #include <libwebsockets/lws-dbus.h>
 
-  *
 
-  * if dbus apis needed
 
-  */
 
- #if !defined(__LWS_DBUS_H__)
 
- #define __LWS_DBUS_H__
 
- #include <dbus/dbus.h>
 
- /* helper type to simplify implementing methods as individual functions */
 
- typedef DBusHandlerResult (*lws_dbus_message_handler)(DBusConnection *conn,
 
- 			   DBusMessage *message, DBusMessage **reply, void *d);
 
- struct lws_dbus_ctx;
 
- typedef void (*lws_dbus_closing_t)(struct lws_dbus_ctx *ctx);
 
- struct lws_dbus_ctx {
 
- 	struct lws_dll2_owner owner; /* dbusserver ctx: HEAD of accepted list */
 
- 	struct lws_dll2 next; /* dbusserver ctx: HEAD of accepted list */
 
- 	struct lws_vhost *vh; /* the vhost we logically bind to in lws */
 
- 	int tsi;	/* the lws thread service index (0 if only one service
 
- 			   thread as is the default */
 
- 	DBusConnection *conn;
 
- 	DBusServer *dbs;
 
- 	DBusWatch *w[4];
 
-  	DBusPendingCall *pc;
 
-  	char hup;
 
-  	char timeouts;
 
-  	/* cb_closing callback will be called after the connection and this
 
-  	 * related ctx struct have effectively gone out of scope.
 
-  	 *
 
-  	 * The callback should close and clean up the connection and free the
 
-  	 * ctx.
 
-  	 */
 
-  	lws_dbus_closing_t cb_closing;
 
- };
 
- /**
 
-  * lws_dbus_connection_setup() - bind dbus connection object to lws event loop
 
-  *
 
-  * \param ctx: additional information about the connection
 
-  * \param conn: the DBusConnection object to bind
 
-  *
 
-  * This configures a DBusConnection object to use lws for watchers and timeout
 
-  * operations.
 
-  */
 
- LWS_VISIBLE LWS_EXTERN int
 
- lws_dbus_connection_setup(struct lws_dbus_ctx *ctx, DBusConnection *conn,
 
- 			  lws_dbus_closing_t cb_closing);
 
- /**
 
-  * lws_dbus_server_listen() - bind dbus connection object to lws event loop
 
-  *
 
-  * \param ctx: additional information about the connection
 
-  * \param ads: the DBUS address to listen on, eg, "unix:abstract=mysocket"
 
-  * \param err: a DBusError object to take any extra error information
 
-  * \param new_conn: a callback function to prepare new accepted connections
 
-  *
 
-  * This creates a DBusServer and binds it to the lws event loop, and your
 
-  * callback to accept new connections.
 
-  */
 
- LWS_VISIBLE LWS_EXTERN DBusServer *
 
- lws_dbus_server_listen(struct lws_dbus_ctx *ctx, const char *ads,
 
- 		       DBusError *err, DBusNewConnectionFunction new_conn);
 
- #endif
 
 
  |