QP_rule_text(QP_rule_t *QPr) { pta=NULL; pta=(char **)malloc(sizeof(char *)*16); itostr(pta[0], (long long)QPr->rule_id); itostr(pta[1], (long long)QPr->active); pta[2]=strdup_null(QPr->username); pta[3]=strdup_null(QPr->schemaname); itostr(pta[4], (long long)QPr->flagIN); pta[5]=strdup_null(QPr->match_pattern); itostr(pta[6], (long long)QPr->negate_match_pattern); itostr(pta[7], (long long)QPr->flagOUT); pta[8]=strdup_null(QPr->replace_pattern); itostr(pta[9], (long long)QPr->destination_hostgroup); itostr(pta[10], (long long)QPr->cache_ttl); itostr(pta[11], (long long)QPr->reconnect); itostr(pta[12], (long long)QPr->timeout); itostr(pta[13], (long long)QPr->delay); itostr(pta[14], (long long)QPr->apply); itostr(pta[15], (long long)QPr->hits); }
neo4j_config_t *neo4j_config_dup(const neo4j_config_t *config) { if (config == NULL) { return neo4j_new_config(); } neo4j_config_t *dup = malloc(sizeof(neo4j_config_t)); if (config == NULL) { return NULL; } memcpy(dup, config, sizeof(neo4j_config_t)); if (strdup_null(&(dup->username), config->username)) { goto failure; } if (strdup_null(&(dup->password), config->password)) { goto failure; } #ifdef HAVE_TLS if (strdup_null(&(dup->tls_private_key_file), config->tls_private_key_file)) { goto failure; } if (strdup_null(&(dup->tls_ca_file), config->tls_ca_file)) { goto failure; } if (strdup_null(&(dup->tls_ca_dir), config->tls_ca_dir)) { goto failure; } #endif if (strdup_null(&(dup->known_hosts_file), config->known_hosts_file)) { goto failure; } return dup; int errsv; failure: errsv = errno; neo4j_config_free(dup); errno = errsv; return NULL; }
int stonith__lha_metadata(const char *agent, int timeout, char **output) { int rc = 0; char *buffer = NULL; static const char *no_parameter_info = "<!-- no value -->"; Stonith *stonith_obj = NULL; static gboolean need_init = TRUE; static Stonith *(*st_new_fn) (const char *) = NULL; static const char *(*st_info_fn) (Stonith *, int) = NULL; static void (*st_del_fn) (Stonith *) = NULL; static void (*st_log_fn) (Stonith *, PILLogFun) = NULL; if (need_init) { need_init = FALSE; st_new_fn = find_library_function(&lha_agents_lib, LHA_STONITH_LIBRARY, "stonith_new", FALSE); st_del_fn = find_library_function(&lha_agents_lib, LHA_STONITH_LIBRARY, "stonith_delete", FALSE); st_log_fn = find_library_function(&lha_agents_lib, LHA_STONITH_LIBRARY, "stonith_set_log", FALSE); st_info_fn = find_library_function(&lha_agents_lib, LHA_STONITH_LIBRARY, "stonith_get_info", FALSE); } if (lha_agents_lib && st_new_fn && st_del_fn && st_info_fn && st_log_fn) { char *xml_meta_longdesc = NULL; char *xml_meta_shortdesc = NULL; char *meta_param = NULL; char *meta_longdesc = NULL; char *meta_shortdesc = NULL; stonith_obj = (*st_new_fn) (agent); if (stonith_obj) { (*st_log_fn) (stonith_obj, (PILLogFun) & stonith_plugin); meta_longdesc = strdup_null((*st_info_fn) (stonith_obj, ST_DEVICEDESCR)); if (meta_longdesc == NULL) { crm_warn("no long description in %s's metadata.", agent); meta_longdesc = strdup(no_parameter_info); } meta_shortdesc = strdup_null((*st_info_fn) (stonith_obj, ST_DEVICEID)); if (meta_shortdesc == NULL) { crm_warn("no short description in %s's metadata.", agent); meta_shortdesc = strdup(no_parameter_info); } meta_param = strdup_null((*st_info_fn) (stonith_obj, ST_CONF_XML)); if (meta_param == NULL) { crm_warn("no list of parameters in %s's metadata.", agent); meta_param = strdup(no_parameter_info); } (*st_del_fn) (stonith_obj); } else { errno = EINVAL; crm_perror(LOG_ERR, "Agent %s not found", agent); return -EINVAL; } xml_meta_longdesc = (char *)xmlEncodeEntitiesReentrant(NULL, (const unsigned char *)meta_longdesc); xml_meta_shortdesc = (char *)xmlEncodeEntitiesReentrant(NULL, (const unsigned char *)meta_shortdesc); buffer = crm_strdup_printf(META_TEMPLATE, agent, xml_meta_longdesc, xml_meta_shortdesc, meta_param); xmlFree(xml_meta_longdesc); xmlFree(xml_meta_shortdesc); free(meta_shortdesc); free(meta_longdesc); free(meta_param); } if (output) { *output = buffer; } else { free(buffer); } return rc; }
char *strdup_n(char *s) { return s ? strdup_null(s) : NULL; }
/** * Callback for the plugin descriptor functions. */ static int vlc_plugin_setter (void *plugin, void *tgt, int propid, ...) { module_t **pprimary = plugin; module_t *module = tgt; module_config_t *item = tgt; va_list ap; int ret = 0; va_start (ap, propid); switch (propid) { case VLC_MODULE_CREATE: { module = *pprimary; module_t *submodule = vlc_module_create (module); if (unlikely(submodule == NULL)) { ret = -1; break; } *(va_arg (ap, module_t **)) = submodule; if (*pprimary == NULL) { *pprimary = submodule; break; } /* Inheritance. Ugly!! */ submodule->pp_shortcuts = xmalloc (sizeof ( *submodule->pp_shortcuts )); submodule->pp_shortcuts[0] = strdup_null (module->pp_shortcuts[0]); submodule->i_shortcuts = 1; /* object name */ submodule->psz_shortname = strdup_null (module->psz_shortname); submodule->psz_longname = strdup_null (module->psz_longname); submodule->psz_capability = strdup_null (module->psz_capability); break; } case VLC_CONFIG_CREATE: { int type = va_arg (ap, int); module_config_t **pp = va_arg (ap, module_config_t **); item = vlc_config_create (*pprimary, type); if (unlikely(item == NULL)) { ret = -1; break; } *pp = item; break; } case VLC_MODULE_SHORTCUT: { unsigned i_shortcuts = va_arg (ap, unsigned); unsigned index = module->i_shortcuts; /* The cache loader accept only a small number of shortcuts */ assert(i_shortcuts + index <= MODULE_SHORTCUT_MAX); const char *const *tab = va_arg (ap, const char *const *); char **pp = realloc (module->pp_shortcuts, sizeof (pp[0]) * (index + i_shortcuts)); if (unlikely(pp == NULL)) { ret = -1; break; } module->pp_shortcuts = pp; module->i_shortcuts = index + i_shortcuts; pp += index; for (unsigned i = 0; i < i_shortcuts; i++) pp[i] = strdup (tab[i]); break; } case VLC_MODULE_CAPABILITY: free (module->psz_capability); module->psz_capability = strdup (va_arg (ap, char *)); break; case VLC_MODULE_SCORE: module->i_score = va_arg (ap, int); break; case VLC_MODULE_CB_OPEN: module->pf_activate = va_arg (ap, void *); break; case VLC_MODULE_CB_CLOSE: module->pf_deactivate = va_arg (ap, void *); break; case VLC_MODULE_NO_UNLOAD: assert (module->parent == NULL); module->b_unloadable = false; break; case VLC_MODULE_NAME: { const char *value = va_arg (ap, const char *); assert (module->i_shortcuts == 0); module->pp_shortcuts = malloc( sizeof( *module->pp_shortcuts ) ); module->pp_shortcuts[0] = strdup (value); module->i_shortcuts = 1; assert (module->psz_longname == NULL); module->psz_longname = strdup (value); break; } case VLC_MODULE_SHORTNAME: assert (module->psz_shortname == NULL || module->parent != NULL); free (module->psz_shortname); module->psz_shortname = strdup (va_arg (ap, char *)); break; case VLC_MODULE_DESCRIPTION: // TODO: do not set this in VLC_MODULE_NAME free (module->psz_longname); module->psz_longname = strdup (va_arg (ap, char *)); break; case VLC_MODULE_HELP: assert (module->parent == NULL); assert (module->psz_help == NULL); module->psz_help = strdup (va_arg (ap, char *)); break; case VLC_MODULE_TEXTDOMAIN: assert (module->parent == NULL); assert (module->domain == NULL); module->domain = strdup (va_arg (ap, char *)); break; case VLC_CONFIG_NAME: { const char *name = va_arg (ap, const char *); assert (name != NULL); item->psz_name = strdup (name); break; } case VLC_CONFIG_VALUE: { if (IsConfigIntegerType (item->i_type) || !CONFIG_ITEM(item->i_type)) { item->orig.i = item->value.i = va_arg (ap, int64_t); } else if (IsConfigFloatType (item->i_type)) { item->orig.f = item->value.f = va_arg (ap, double); } else if (IsConfigStringType (item->i_type)) { const char *value = va_arg (ap, const char *); item->value.psz = value ? strdup (value) : NULL; item->orig.psz = value ? strdup (value) : NULL; } break; }