mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-02 11:58:40 +00:00
pbx: Create pbx_sw.c for management of 'struct ast_sw'.
This changes context switches from a linked list to a vector, makes 'struct ast_sw' opaque to pbx.c. Although ast_walk_context_switches is maintained the procedure is no longer efficient except for the first call (inc==NULL). This functionality is replaced by two new functions implemented by vector macros. * ast_context_switches_count (AST_VECTOR_SIZE) * ast_context_switches_get (AST_VECTOR_GET) As with ast_walk_context_switches callers of these functions are expected to have locked contexts. Only a few places in Asterisk walked the switches, they have been converted to use the new functions. Change-Id: I08deb016df22eee8288eb03de62593e45a1f0998
This commit is contained in:
@@ -1229,9 +1229,9 @@ const char *ast_get_extension_name(struct ast_exten *exten);
|
||||
struct ast_context *ast_get_extension_context(struct ast_exten *exten);
|
||||
const char *ast_get_include_name(const struct ast_include *include);
|
||||
const char *ast_get_ignorepat_name(const struct ast_ignorepat *ip);
|
||||
const char *ast_get_switch_name(struct ast_sw *sw);
|
||||
const char *ast_get_switch_data(struct ast_sw *sw);
|
||||
int ast_get_switch_eval(struct ast_sw *sw);
|
||||
const char *ast_get_switch_name(const struct ast_sw *sw);
|
||||
const char *ast_get_switch_data(const struct ast_sw *sw);
|
||||
int ast_get_switch_eval(const struct ast_sw *sw);
|
||||
|
||||
/*! @} */
|
||||
|
||||
@@ -1251,7 +1251,7 @@ const char *ast_get_context_registrar(struct ast_context *c);
|
||||
const char *ast_get_extension_registrar(struct ast_exten *e);
|
||||
const char *ast_get_include_registrar(const struct ast_include *i);
|
||||
const char *ast_get_ignorepat_registrar(const struct ast_ignorepat *ip);
|
||||
const char *ast_get_switch_registrar(struct ast_sw *sw);
|
||||
const char *ast_get_switch_registrar(const struct ast_sw *sw);
|
||||
/*! @} */
|
||||
|
||||
/*! @name Walking functions ... */
|
||||
@@ -1265,7 +1265,8 @@ const struct ast_include *ast_walk_context_includes(const struct ast_context *co
|
||||
const struct ast_include *inc);
|
||||
const struct ast_ignorepat *ast_walk_context_ignorepats(const struct ast_context *con,
|
||||
const struct ast_ignorepat *ip);
|
||||
struct ast_sw *ast_walk_context_switches(struct ast_context *con, struct ast_sw *sw);
|
||||
const struct ast_sw *ast_walk_context_switches(const struct ast_context *con,
|
||||
const struct ast_sw *sw);
|
||||
/*! @} */
|
||||
|
||||
/*! @name Iterator functions ... */
|
||||
@@ -1274,6 +1275,8 @@ int ast_context_includes_count(const struct ast_context *con);
|
||||
const struct ast_include *ast_context_includes_get(const struct ast_context *con, int idx);
|
||||
int ast_context_ignorepats_count(const struct ast_context *con);
|
||||
const struct ast_ignorepat *ast_context_ignorepats_get(const struct ast_context *con, int idx);
|
||||
int ast_context_switches_count(const struct ast_context *con);
|
||||
const struct ast_sw *ast_context_switches_get(const struct ast_context *con, int idx);
|
||||
/*! @} */
|
||||
|
||||
/*!
|
||||
|
||||
Reference in New Issue
Block a user