⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dbus_dict_helpers.c

📁 WLAN无线网络管理的最新程序
💻 C
📖 第 1 页 / 共 2 页
字号:
                                             DBusMessageIter *iter_dict_entry,                                             DBusMessageIter *iter_dict_val,                                             DBusMessageIter *iter_array){	if (!iter_dict || !iter_dict_entry || !iter_dict_val || !iter_array)		return FALSE;	if (!_wpa_dbus_add_dict_entry_start(iter_dict, iter_dict_entry,					    key, DBUS_TYPE_ARRAY))		return FALSE;	if (!dbus_message_iter_open_container(iter_dict_entry,					      DBUS_TYPE_VARIANT,					      DBUS_TYPE_ARRAY_AS_STRING					      DBUS_TYPE_STRING_AS_STRING,					      iter_dict_val))		return FALSE;	if (!dbus_message_iter_open_container(iter_dict_val, DBUS_TYPE_ARRAY,					      DBUS_TYPE_BYTE_AS_STRING,					      iter_array))		return FALSE;	return TRUE;}/** * Add a single string element to a string array dict entry * * @param iter_array A valid DBusMessageIter returned from *                   {@link wpa_dbus_dict_begin_string_array}'s *                   iter_array parameter * @param elem The string element to be added to the dict entry's string array * @return TRUE on success, FALSE on failure * */dbus_bool_t wpa_dbus_dict_string_array_add_element(DBusMessageIter *iter_array,						   const char *elem){	if (!iter_array || !elem)		return FALSE;	return dbus_message_iter_append_basic(iter_array, DBUS_TYPE_STRING,					      &elem);}/** * End a string array dict entry * * @param iter_dict A valid DBusMessageIter returned from *                  {@link nmu_dbus_dict_open_write} * @param iter_dict_entry A private DBusMessageIter returned from *                        {@link wpa_dbus_dict_end_string_array} * @param iter_dict_val A private DBusMessageIter returned from *                      {@link wpa_dbus_dict_end_string_array} * @param iter_array A DBusMessageIter returned from *                   {@link wpa_dbus_dict_end_string_array} * @return TRUE on success, FALSE on failure * */dbus_bool_t wpa_dbus_dict_end_string_array(DBusMessageIter *iter_dict,                                           DBusMessageIter *iter_dict_entry,                                           DBusMessageIter *iter_dict_val,                                           DBusMessageIter *iter_array){	if (!iter_dict || !iter_dict_entry || !iter_dict_val || !iter_array)		return FALSE;	if (!dbus_message_iter_close_container(iter_dict_val, iter_array))		return FALSE;	if (!_wpa_dbus_add_dict_entry_end(iter_dict, iter_dict_entry,					  iter_dict_val))		return FALSE;	return TRUE;}/** * Convenience function to add an entire string array to the dict. * * @param iter_dict A valid DBusMessageIter returned from *                  {@link nmu_dbus_dict_open_write} * @param key The key of the dict item * @param items The array of strings * @param num_items The number of strings in the array * @return TRUE on success, FALSE on failure * */dbus_bool_t wpa_dbus_dict_append_string_array(DBusMessageIter *iter_dict,					      const char *key,					      const char **items,					      const dbus_uint32_t num_items){        DBusMessageIter iter_dict_entry, iter_dict_val, iter_array;        dbus_uint32_t i;	if (!key)		return FALSE;	if (!items && (num_items != 0))		return FALSE;	if (!wpa_dbus_dict_begin_string_array(iter_dict, key,					      &iter_dict_entry, &iter_dict_val,					      &iter_array))		return FALSE;	for (i = 0; i < num_items; i++) {		if (!wpa_dbus_dict_string_array_add_element(&iter_array,							    items[i]))			return FALSE;	}	if (!wpa_dbus_dict_end_string_array(iter_dict, &iter_dict_entry,					    &iter_dict_val, &iter_array))		return FALSE;	return TRUE;}/*****************************************************//* Stuff for reading dicts                           *//*****************************************************//** * Start reading from a dbus dict. * * @param iter A valid DBusMessageIter pointing to the start of the dict * @param iter_dict (out) A DBusMessageIter to be passed to *    {@link wpa_dbus_dict_read_next_entry} * @return TRUE on success, FALSE on failure * */dbus_bool_t wpa_dbus_dict_open_read(DBusMessageIter *iter,				    DBusMessageIter *iter_dict){	if (!iter || !iter_dict)		return FALSE;	if (dbus_message_iter_get_arg_type(iter) != DBUS_TYPE_ARRAY ||	    dbus_message_iter_get_element_type(iter) != DBUS_TYPE_DICT_ENTRY)		return FALSE;	dbus_message_iter_recurse(iter, iter_dict);	return TRUE;}static dbus_bool_t _wpa_dbus_dict_entry_get_byte_array(	DBusMessageIter *iter, int array_len, int array_type,	struct wpa_dbus_dict_entry *entry){	dbus_uint32_t i = 0;	dbus_bool_t success = FALSE;	char byte;	/* Zero-length arrays are valid. */	if (array_len == 0) {		entry->bytearray_value = NULL;		entry->array_type = DBUS_TYPE_BYTE;		success = TRUE;		goto done;	}	entry->bytearray_value = wpa_zalloc(array_len * sizeof(char));	if (!entry->bytearray_value) {		perror("_wpa_dbus_dict_entry_get_byte_array[dbus]: out of "		       "memory");		goto done;	}	entry->array_type = DBUS_TYPE_BYTE;	entry->array_len = array_len;	while (dbus_message_iter_get_arg_type(iter) == DBUS_TYPE_BYTE) {		dbus_message_iter_get_basic(iter, &byte);		entry->bytearray_value[i++] = byte;		dbus_message_iter_next(iter);	}	success = TRUE;done:	return success;}static dbus_bool_t _wpa_dbus_dict_entry_get_string_array(	DBusMessageIter *iter, int array_len, int array_type,	struct wpa_dbus_dict_entry *entry){	dbus_uint32_t count = 0;	dbus_bool_t success = FALSE;	char **buffer;	entry->strarray_value = NULL;	entry->array_type = DBUS_TYPE_STRING;	/* Zero-length arrays are valid. */	if (array_len == 0) {		success = TRUE;		goto done;	}	buffer = wpa_zalloc(sizeof (char *) * 8);	if (buffer == NULL) {		perror("_wpa_dbus_dict_entry_get_string_array[dbus] out of "		       "memory trying to retrieve a string array");		goto done;	}	entry->strarray_value = buffer;	entry->array_len = 0;	while (dbus_message_iter_get_arg_type(iter) == DBUS_TYPE_STRING) {		const char *value;		char *str;		if ((count % 8) == 0 && count != 0) {			char **tmp;			tmp = realloc(buffer, sizeof(char *) * (count + 8));			if (tmp == NULL) {				perror("_wpa_dbus_dict_entry_get_string_array["				       "dbus] out of memory trying to "				       "retrieve the string array");				free(buffer);				buffer = NULL;				goto done;			}			buffer = tmp;		}		entry->strarray_value = buffer;		dbus_message_iter_get_basic(iter, &value);		str = strdup(value);		if (str == NULL) {			perror("_wpa_dbus_dict_entry_get_string_array[dbus] "			       "out of memory trying to duplicate the string "			       "array");			goto done;		}		entry->strarray_value[count] = str;		entry->array_len = ++count;		dbus_message_iter_next(iter);	}	success = TRUE;done:	return success;}static dbus_bool_t _wpa_dbus_dict_entry_get_array(	DBusMessageIter *iter_dict_val, struct wpa_dbus_dict_entry *entry){	int array_type = dbus_message_iter_get_element_type(iter_dict_val);	int array_len;	dbus_bool_t success = FALSE;	DBusMessageIter iter_array;	if (!entry)		return FALSE;	dbus_message_iter_recurse(iter_dict_val, &iter_array); 	array_len = dbus_message_iter_get_array_len(&iter_array);	if (array_len < 0)		return FALSE; 	switch (array_type) {	case DBUS_TYPE_BYTE:		success = _wpa_dbus_dict_entry_get_byte_array(&iter_array,							      array_len,							      array_type,							      entry);		break;	case DBUS_TYPE_STRING:		success = _wpa_dbus_dict_entry_get_string_array(&iter_array,								array_len,								array_type,								entry);		break;	default:		break;	}	return success;}static dbus_bool_t _wpa_dbus_dict_fill_value_from_variant(	struct wpa_dbus_dict_entry *entry, DBusMessageIter *iter_dict_val){	dbus_bool_t success = TRUE;	switch (entry->type) {	case DBUS_TYPE_STRING: {		const char *v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->str_value = strdup(v);		break;	}	case DBUS_TYPE_BOOLEAN: {		dbus_bool_t v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->bool_value = v;		break;	}	case DBUS_TYPE_BYTE: {		char v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->byte_value = v;		break;	}	case DBUS_TYPE_INT16: {		dbus_int16_t v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->int16_value = v;		break;	}	case DBUS_TYPE_UINT16: {		dbus_uint16_t v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->uint16_value = v;		break;	}	case DBUS_TYPE_INT32: {		dbus_int32_t v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->int32_value = v;		break;	}	case DBUS_TYPE_UINT32: {		dbus_uint32_t v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->uint32_value = v;		break;	}	case DBUS_TYPE_INT64: {		dbus_int64_t v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->int64_value = v;		break;	}	case DBUS_TYPE_UINT64: {		dbus_uint64_t v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->uint64_value = v;		break;	}	case DBUS_TYPE_DOUBLE: {		double v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->double_value = v;		break;	}	case DBUS_TYPE_OBJECT_PATH: {		char *v;		dbus_message_iter_get_basic(iter_dict_val, &v);		entry->str_value = strdup(v);		break;	}	case DBUS_TYPE_ARRAY: {		success = _wpa_dbus_dict_entry_get_array(iter_dict_val, entry);		break;	}	default:		success = FALSE;		break;	}	return success;}/** * Read the current key/value entry from the dict.  Entries are dynamically * allocated when needed and must be freed after use with the * {@link wpa_dbus_dict_entry_clear} function. * * The returned entry object will be filled with the type and value of the next * entry in the dict, or the type will be DBUS_TYPE_INVALID if an error * occurred. * * @param iter_dict A valid DBusMessageIter returned from *    {@link wpa_dbus_dict_open_read} * @param entry A valid dict entry object into which the dict key and value *    will be placed * @return TRUE on success, FALSE on failure * */dbus_bool_t wpa_dbus_dict_get_entry(DBusMessageIter *iter_dict,				    struct wpa_dbus_dict_entry * entry){	DBusMessageIter iter_dict_entry, iter_dict_val;	int type;	const char *key;	if (!iter_dict || !entry)		goto error;	if (dbus_message_iter_get_arg_type(iter_dict) != DBUS_TYPE_DICT_ENTRY)		goto error;	dbus_message_iter_recurse(iter_dict, &iter_dict_entry);	dbus_message_iter_get_basic(&iter_dict_entry, &key);	entry->key = key;	if (!dbus_message_iter_next(&iter_dict_entry))		goto error;	type = dbus_message_iter_get_arg_type(&iter_dict_entry);	if (type != DBUS_TYPE_VARIANT)		goto error;	dbus_message_iter_recurse(&iter_dict_entry, &iter_dict_val);	entry->type = dbus_message_iter_get_arg_type(&iter_dict_val);	if (!_wpa_dbus_dict_fill_value_from_variant(entry, &iter_dict_val))		goto error;	dbus_message_iter_next(iter_dict);	return TRUE;error:	if (entry) {		wpa_dbus_dict_entry_clear(entry);		entry->type = DBUS_TYPE_INVALID;		entry->array_type = DBUS_TYPE_INVALID;	}	return FALSE;}/** * Return whether or not there are additional dictionary entries. * * @param iter_dict A valid DBusMessageIter returned from *    {@link wpa_dbus_dict_open_read} * @return TRUE if more dict entries exists, FALSE if no more dict entries * exist */dbus_bool_t wpa_dbus_dict_has_dict_entry(DBusMessageIter *iter_dict){	if (!iter_dict) {		perror("wpa_dbus_dict_has_dict_entry[dbus]: out of memory");		return FALSE;	}	return dbus_message_iter_get_arg_type(iter_dict) ==		DBUS_TYPE_DICT_ENTRY;}/** * Free any memory used by the entry object. * * @param entry The entry object */void wpa_dbus_dict_entry_clear(struct wpa_dbus_dict_entry *entry){	if (!entry)		return;	switch (entry->type) {	case DBUS_TYPE_OBJECT_PATH:	case DBUS_TYPE_STRING:		free(entry->str_value);		break;	case DBUS_TYPE_ARRAY:		switch (entry->array_type) {		case DBUS_TYPE_BYTE:			free(entry->bytearray_value);			break;		}		break;	}	memset(entry, 0, sizeof(struct wpa_dbus_dict_entry));}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -