[svn-commits] dlee: branch dlee/detyped r387968 - in /team/dlee/detyped: include/asterisk/ ...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Wed May 8 11:15:39 CDT 2013
Author: dlee
Date: Wed May 8 11:15:38 2013
New Revision: 387968
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=387968
Log:
Create and initialize new message types.
Created a set of macros to make it less boilerplate-ish.
Modified:
team/dlee/detyped/include/asterisk/stasis.h
team/dlee/detyped/main/stasis_channels.c
Modified: team/dlee/detyped/include/asterisk/stasis.h
URL: http://svnview.digium.com/svn/asterisk/team/dlee/detyped/include/asterisk/stasis.h?view=diff&rev=387968&r1=387967&r2=387968
==============================================================================
--- team/dlee/detyped/include/asterisk/stasis.h (original)
+++ team/dlee/detyped/include/asterisk/stasis.h Wed May 8 11:15:38 2013
@@ -526,6 +526,38 @@
/*! @{ */
+/*!
+ * \brief Boiler-plate removing macro for defining message types.
+ *
+ * \param name Name of message type.
+ * \since 12
+ */
+#define STASIS_TYPE_DEFN(name) \
+ static struct stasis_message_type *__ ## name; \
+ struct stasis_message_type *name(void) { \
+ ast_assert(__ ## name != NULL); \
+ return __ ## name; \
+ }
+
+/*!
+ * \brief Boiler-plate removing macro for initializing message types.
+ *
+ * \param name Name of message type.
+ * \return 0 if initialization is successful.
+ * \return Non-zero on failure.
+ * \since 12
+ */
+#define STASIS_TYPE_INIT(name) \
+ ({ \
+ __ ## name = stasis_message_type_create(#name); \
+ __ ## name ? 0 : -1; \
+ })
+
+#define STASIS_TYPE_CLEANUP(name) \
+ ({ \
+ ao2_cleanup(__ ## name); \
+ __ ## name = NULL; \
+ })
/*! @} */
Modified: team/dlee/detyped/main/stasis_channels.c
URL: http://svnview.digium.com/svn/asterisk/team/dlee/detyped/main/stasis_channels.c?view=diff&rev=387968&r1=387967&r2=387968
==============================================================================
--- team/dlee/detyped/main/stasis_channels.c (original)
+++ team/dlee/detyped/main/stasis_channels.c Wed May 8 11:15:38 2013
@@ -38,27 +38,23 @@
#define NUM_MULTI_CHANNEL_BLOB_BUCKETS 7
-/*! \brief Message type for channel snapshot messages */
-static struct stasis_message_type *channel_snapshot_type;
-
-/*! \brief Message type for channel dial messages */
-static struct stasis_message_type *channel_dial_type;
+/*!
+ * @{ \brief Define channel message types.
+ */
+STASIS_TYPE_DEFN(ast_channel_snapshot_type);
+STASIS_TYPE_DEFN(ast_channel_dial_type);
+STASIS_TYPE_DEFN(ast_channel_varset_type);
+STASIS_TYPE_DEFN(ast_channel_user_event_type);
+STASIS_TYPE_DEFN(ast_channel_hangup_request_type);
+STASIS_TYPE_DEFN(ast_channel_dtmf_begin_type);
+STASIS_TYPE_DEFN(ast_channel_dtmf_end_type);
+/*! @} */
/*! \brief Topic for all channels */
struct stasis_topic *channel_topic_all;
/*! \brief Caching topic for all channels */
struct stasis_caching_topic *channel_topic_all_cached;
-
-struct stasis_message_type *ast_channel_dial_type(void)
-{
- return channel_dial_type;
-}
-
-struct stasis_message_type *ast_channel_snapshot_type(void)
-{
- return channel_snapshot_type;
-}
struct stasis_topic *ast_channel_topic_all(void)
{
@@ -297,17 +293,10 @@
RAII_VAR(struct ast_multi_channel_blob *, obj,
ao2_alloc(sizeof(*obj), multi_channel_blob_dtor),
ao2_cleanup);
- struct ast_json *type;
ast_assert(blob != NULL);
if (!obj) {
- return NULL;
- }
-
- type = ast_json_object_get(blob, "type");
- if (type == NULL) {
- ast_log(LOG_ERROR, "Invalid ast_multi_channel_blob; missing type field\n");
return NULL;
}
@@ -461,10 +450,13 @@
void ast_stasis_channels_shutdown(void)
{
- ao2_cleanup(channel_snapshot_type);
- channel_snapshot_type = NULL;
- ao2_cleanup(channel_dial_type);
- channel_dial_type = NULL;
+ STASIS_TYPE_CLEANUP(ast_channel_snapshot_type);
+ STASIS_TYPE_CLEANUP(ast_channel_dial_type);
+ STASIS_TYPE_CLEANUP(ast_channel_varset_type);
+ STASIS_TYPE_CLEANUP(ast_channel_user_event_type);
+ STASIS_TYPE_CLEANUP(ast_channel_hangup_request_type);
+ STASIS_TYPE_CLEANUP(ast_channel_dtmf_begin_type);
+ STASIS_TYPE_CLEANUP(ast_channel_dtmf_end_type);
ao2_cleanup(channel_topic_all);
channel_topic_all = NULL;
channel_topic_all_cached = stasis_caching_unsubscribe(channel_topic_all_cached);
@@ -472,8 +464,14 @@
void ast_stasis_channels_init(void)
{
- channel_snapshot_type = stasis_message_type_create("ast_channel_snapshot");
- channel_dial_type = stasis_message_type_create("ast_channel_dial");
+ STASIS_TYPE_INIT(ast_channel_snapshot_type);
+ STASIS_TYPE_INIT(ast_channel_dial_type);
+ STASIS_TYPE_INIT(ast_channel_varset_type);
+ STASIS_TYPE_INIT(ast_channel_user_event_type);
+ STASIS_TYPE_INIT(ast_channel_hangup_request_type);
+ STASIS_TYPE_INIT(ast_channel_dtmf_begin_type);
+ STASIS_TYPE_INIT(ast_channel_dtmf_end_type);
+
channel_topic_all = stasis_topic_create("ast_channel_topic_all");
channel_topic_all_cached = stasis_caching_topic_create(channel_topic_all, channel_snapshot_get_id);
}
More information about the svn-commits
mailing list