/* * Asterisk -- An open source telephony toolkit. * * Copyright (C) 2016, Fairview 5 Engineering, LLC * * George Joseph * * See http://www.asterisk.org for more information about * the Asterisk project. Please do not directly contact * any of the maintainers of this project for assistance; * the project provides a web site, mailing lists and IRC * channels for your use. * * This program is free software, distributed under the terms of * the GNU General Public License Version 2. See the LICENSE file * at the top of the source tree. */ #ifndef _RES_PJPROJECT_H #define _RES_PJPROJECT_H #include #include /*! * \brief Retrieve a pjproject build option * * \param option The build option requested * \param format_string A scanf-style format string to parse the option value into * \param ... Pointers to variables to receive the values parsed * * \retval The number of values parsed * * \since 13.8.0 * * \note The option requested must be from those returned by pj_dump_config() * which can be displayed with the 'pjsip show buildopts' CLI command. * * Sample Usage: * \code * * int max_hostname; * * ast_sip_get_pjproject_buildopt("PJ_MAX_HOSTNAME", "%d", &max_hostname); * * \endcode * */ int ast_pjproject_get_buildopt(char *option, char *format_string, ...) __attribute__((format(scanf, 2, 3))); /*! * \brief Begin PJPROJECT log interception for CLI output. * \since 13.8.0 * * \param fd CLI file descriptior to send intercepted output. * * \note ast_pjproject_log_intercept_begin() and * ast_pjproject_log_intercept_end() must always be called * in pairs. * * \return Nothing */ void ast_pjproject_log_intercept_begin(int fd); /*! * \brief End PJPROJECT log interception for CLI output. * \since 13.8.0 * * \note ast_pjproject_log_intercept_begin() and * ast_pjproject_log_intercept_end() must always be called * in pairs. * * \return Nothing */ void ast_pjproject_log_intercept_end(void); /*! * \brief Initialize the caching pool factory. * \since 13.21.0 * * \param cp Caching pool factory to initialize * \param policy Pool factory policy * \param max_capacity Total capacity to be retained in the cache. Zero disables caching. * * \return Nothing */ void ast_pjproject_caching_pool_init(pj_caching_pool *cp, const pj_pool_factory_policy *policy, pj_size_t max_capacity); /*! * \brief Destroy caching pool factory and all cached pools. * \since 13.21.0 * * \param cp Caching pool factory to destroy * * \return Nothing */ void ast_pjproject_caching_pool_destroy(pj_caching_pool *cp); #endif /* _RES_PJPROJECT_H */