18 #define VARIANT_GROUP 1 24 xmlNode *xml_obj = rsc->
xml;
25 xmlNode *xml_native_rsc = NULL;
26 group_variant_data_t *group_data = NULL;
28 const char *group_colocated = g_hash_table_lookup(rsc->
meta,
"collocated");
29 const char *clone_id = NULL;
33 group_data = calloc(1,
sizeof(group_variant_data_t));
34 group_data->num_children = 0;
35 group_data->first_child = NULL;
36 group_data->last_child = NULL;
39 group_data->ordered = TRUE;
40 group_data->colocated = TRUE;
42 if (group_ordered != NULL) {
45 if (group_colocated != NULL) {
51 for (xml_native_rsc = __xml_first_child_element(xml_obj); xml_native_rsc != NULL;
52 xml_native_rsc = __xml_next_element(xml_native_rsc)) {
57 if (
common_unpack(xml_native_rsc, &new_rsc, rsc, data_set) == FALSE) {
59 if (new_rsc != NULL && new_rsc->
fns != NULL) {
65 group_data->num_children++;
68 if (group_data->first_child == NULL) {
69 group_data->first_child = new_rsc;
71 group_data->last_child = new_rsc;
76 if (group_data->num_children == 0) {
87 pe_rsc_trace(rsc,
"Added %d children to resource %s...", group_data->num_children, rsc->
id);
95 gboolean c_all = TRUE;
96 gboolean c_any = FALSE;
99 for (; gIter != NULL; gIter = gIter->next) {
102 if (child_rsc->
fns->
active(child_rsc, all)) {
109 if (c_any == FALSE) {
111 }
else if (all && c_all == FALSE) {
118 group_print_xml(
resource_t * rsc,
const char *pre_text,
long options,
void *print_data)
121 char *child_text =
crm_concat(pre_text,
" ",
' ');
127 for (; gIter != NULL; gIter = gIter->next) {
130 child_rsc->
fns->
print(child_rsc, child_text, options, print_data);
140 char *child_text = NULL;
143 if (pre_text == NULL) {
148 group_print_xml(rsc, pre_text, options, print_data);
154 status_print(
"%sResource Group: %s", pre_text ? pre_text :
"", rsc->
id);
167 for (; gIter != NULL; gIter = gIter->next) {
170 if (options & pe_print_html) {
173 child_rsc->
fns->
print(child_rsc, child_text, options, print_data);
174 if (options & pe_print_html) {
180 if (options & pe_print_html) {
198 child_rsc->
fns->
free(child_rsc);
213 for (; gIter != NULL; gIter = gIter->next) {
217 if (role > group_role) {
#define CRM_CHECK(expr, failure_action)
void group_free(resource_t *rsc)
gboolean group_active(resource_t *rsc, gboolean all)
void(* free)(resource_t *)
#define crm_config_err(fmt...)
#define XML_RSC_ATTR_INCARNATION
gboolean common_unpack(xmlNode *xml_obj, resource_t **rsc, resource_t *parent, pe_working_set_t *data_set)
void common_free(resource_t *rsc)
const char * crm_xml_add(xmlNode *node, const char *name, const char *value)
Create an XML attribute with specified name and value.
#define status_print(fmt, args...)
enum rsc_role_e(* state)(const resource_t *, gboolean)
void print_rscs_brief(GListPtr rsc_list, const char *pre_text, long options, void *print_data, gboolean print_all)
const char * role2text(enum rsc_role_e role)
gboolean group_unpack(resource_t *rsc, pe_working_set_t *data_set)
const char * crm_element_value(const xmlNode *data, const char *name)
Retrieve the value of an XML attribute.
#define XML_CIB_TAG_RESOURCE
resource_object_functions_t * fns
#define XML_RSC_ATTR_ORDERED
gboolean crm_str_eq(const char *a, const char *b, gboolean use_case)
gboolean(* active)(resource_t *, gboolean)
#define crm_config_warn(fmt...)
enum rsc_role_e group_resource_state(const resource_t *rsc, gboolean current)
void(* print)(resource_t *, const char *, long, void *)
int crm_str_to_boolean(const char *s, int *ret)
Cluster status and scheduling.
void group_print(resource_t *rsc, const char *pre_text, long options, void *print_data)
#define pe_rsc_trace(rsc, fmt, args...)
char * crm_concat(const char *prefix, const char *suffix, char join)