mirror of
				https://github.com/alsa-project/alsa-lib.git
				synced 2025-11-03 09:01:52 -05:00 
			
		
		
		
	Encapsulated conf API
This commit is contained in:
		
							parent
							
								
									8f0cb26fdf
								
							
						
					
					
						commit
						3e091c8822
					
				
					 26 changed files with 473 additions and 404 deletions
				
			
		| 
						 | 
				
			
			@ -197,27 +197,28 @@ int snd_ctl_open(snd_ctl_t **ctlp, char *name)
 | 
			
		|||
		ERR("Unknown control %s", name);
 | 
			
		||||
		return -ENOENT;
 | 
			
		||||
	}
 | 
			
		||||
	if (snd_config_type(ctl_conf) != SND_CONFIG_TYPE_COMPOUND)
 | 
			
		||||
	if (snd_config_get_type(ctl_conf) != SND_CONFIG_TYPE_COMPOUND)
 | 
			
		||||
		return -EINVAL;
 | 
			
		||||
	err = snd_config_search(ctl_conf, "type", &conf);
 | 
			
		||||
	if (err < 0)
 | 
			
		||||
		return err;
 | 
			
		||||
	err = snd_config_string_get(conf, &str);
 | 
			
		||||
	err = snd_config_get_string(conf, &str);
 | 
			
		||||
	if (err < 0)
 | 
			
		||||
		return err;
 | 
			
		||||
	err = snd_config_searchv(snd_config, &type_conf, "ctltype", str, 0);
 | 
			
		||||
	snd_config_foreach(i, type_conf) {
 | 
			
		||||
		snd_config_t *n = snd_config_entry(i);
 | 
			
		||||
		if (strcmp(n->id, "comment") == 0)
 | 
			
		||||
		snd_config_t *n = snd_config_iterator_entry(i);
 | 
			
		||||
		const char *id = snd_config_get_id(n);
 | 
			
		||||
		if (strcmp(id, "comment") == 0)
 | 
			
		||||
			continue;
 | 
			
		||||
		if (strcmp(n->id, "lib") == 0) {
 | 
			
		||||
			err = snd_config_string_get(n, &lib);
 | 
			
		||||
		if (strcmp(id, "lib") == 0) {
 | 
			
		||||
			err = snd_config_get_string(n, &lib);
 | 
			
		||||
			if (err < 0)
 | 
			
		||||
				return -EINVAL;
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		if (strcmp(n->id, "open") == 0) {
 | 
			
		||||
			err = snd_config_string_get(n, &open);
 | 
			
		||||
		if (strcmp(id, "open") == 0) {
 | 
			
		||||
			err = snd_config_get_string(n, &open);
 | 
			
		||||
			if (err < 0)
 | 
			
		||||
				return -EINVAL;
 | 
			
		||||
			continue;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -235,15 +235,16 @@ int _snd_ctl_hw_open(snd_ctl_t **handlep, char *name, snd_config_t *conf)
 | 
			
		|||
	const char *str;
 | 
			
		||||
	int err;
 | 
			
		||||
	snd_config_foreach(i, conf) {
 | 
			
		||||
		snd_config_t *n = snd_config_entry(i);
 | 
			
		||||
		if (strcmp(n->id, "comment") == 0)
 | 
			
		||||
		snd_config_t *n = snd_config_iterator_entry(i);
 | 
			
		||||
		const char *id = snd_config_get_id(n);
 | 
			
		||||
		if (strcmp(id, "comment") == 0)
 | 
			
		||||
			continue;
 | 
			
		||||
		if (strcmp(n->id, "type") == 0)
 | 
			
		||||
		if (strcmp(id, "type") == 0)
 | 
			
		||||
			continue;
 | 
			
		||||
		if (strcmp(n->id, "card") == 0) {
 | 
			
		||||
			err = snd_config_integer_get(n, &card);
 | 
			
		||||
		if (strcmp(id, "card") == 0) {
 | 
			
		||||
			err = snd_config_get_integer(n, &card);
 | 
			
		||||
			if (err < 0) {
 | 
			
		||||
				err = snd_config_string_get(n, &str);
 | 
			
		||||
				err = snd_config_get_string(n, &str);
 | 
			
		||||
				if (err < 0)
 | 
			
		||||
					return -EINVAL;
 | 
			
		||||
				card = snd_card_get_index(str);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -479,28 +479,29 @@ int _snd_ctl_shm_open(snd_ctl_t **handlep, char *name, snd_config_t *conf)
 | 
			
		|||
	int local;
 | 
			
		||||
	struct hostent *h;
 | 
			
		||||
	snd_config_foreach(i, conf) {
 | 
			
		||||
		snd_config_t *n = snd_config_entry(i);
 | 
			
		||||
		if (strcmp(n->id, "comment") == 0)
 | 
			
		||||
		snd_config_t *n = snd_config_iterator_entry(i);
 | 
			
		||||
		const char *id = snd_config_get_id(n);
 | 
			
		||||
		if (strcmp(id, "comment") == 0)
 | 
			
		||||
			continue;
 | 
			
		||||
		if (strcmp(n->id, "type") == 0)
 | 
			
		||||
		if (strcmp(id, "type") == 0)
 | 
			
		||||
			continue;
 | 
			
		||||
		if (strcmp(n->id, "server") == 0) {
 | 
			
		||||
			err = snd_config_string_get(n, &server);
 | 
			
		||||
		if (strcmp(id, "server") == 0) {
 | 
			
		||||
			err = snd_config_get_string(n, &server);
 | 
			
		||||
			if (err < 0) {
 | 
			
		||||
				ERR("Invalid type for %s", n->id);
 | 
			
		||||
				ERR("Invalid type for %s", id);
 | 
			
		||||
				return -EINVAL;
 | 
			
		||||
			}
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		if (strcmp(n->id, "sname") == 0) {
 | 
			
		||||
			err = snd_config_string_get(n, &sname);
 | 
			
		||||
		if (strcmp(id, "sname") == 0) {
 | 
			
		||||
			err = snd_config_get_string(n, &sname);
 | 
			
		||||
			if (err < 0) {
 | 
			
		||||
				ERR("Invalid type for %s", n->id);
 | 
			
		||||
				ERR("Invalid type for %s", id);
 | 
			
		||||
				return -EINVAL;
 | 
			
		||||
			}
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		ERR("Unknown field %s", n->id);
 | 
			
		||||
		ERR("Unknown field %s", id);
 | 
			
		||||
		return -EINVAL;
 | 
			
		||||
	}
 | 
			
		||||
	if (!sname) {
 | 
			
		||||
| 
						 | 
				
			
			@ -517,34 +518,35 @@ int _snd_ctl_shm_open(snd_ctl_t **handlep, char *name, snd_config_t *conf)
 | 
			
		|||
		return -EINVAL;
 | 
			
		||||
	}
 | 
			
		||||
	snd_config_foreach(i, conf) {
 | 
			
		||||
		snd_config_t *n = snd_config_entry(i);
 | 
			
		||||
		if (strcmp(n->id, "comment") == 0)
 | 
			
		||||
		snd_config_t *n = snd_config_iterator_entry(i);
 | 
			
		||||
		const char *id = snd_config_get_id(n);
 | 
			
		||||
		if (strcmp(id, "comment") == 0)
 | 
			
		||||
			continue;
 | 
			
		||||
		if (strcmp(n->id, "host") == 0) {
 | 
			
		||||
			err = snd_config_string_get(n, &host);
 | 
			
		||||
		if (strcmp(id, "host") == 0) {
 | 
			
		||||
			err = snd_config_get_string(n, &host);
 | 
			
		||||
			if (err < 0) {
 | 
			
		||||
				ERR("Invalid type for %s", n->id);
 | 
			
		||||
				ERR("Invalid type for %s", id);
 | 
			
		||||
				return -EINVAL;
 | 
			
		||||
			}
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		if (strcmp(n->id, "socket") == 0) {
 | 
			
		||||
			err = snd_config_string_get(n, &socket);
 | 
			
		||||
		if (strcmp(id, "socket") == 0) {
 | 
			
		||||
			err = snd_config_get_string(n, &socket);
 | 
			
		||||
			if (err < 0) {
 | 
			
		||||
				ERR("Invalid type for %s", n->id);
 | 
			
		||||
				ERR("Invalid type for %s", id);
 | 
			
		||||
				return -EINVAL;
 | 
			
		||||
			}
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		if (strcmp(n->id, "port") == 0) {
 | 
			
		||||
			err = snd_config_integer_get(n, &port);
 | 
			
		||||
		if (strcmp(id, "port") == 0) {
 | 
			
		||||
			err = snd_config_get_integer(n, &port);
 | 
			
		||||
			if (err < 0) {
 | 
			
		||||
				ERR("Invalid type for %s", n->id);
 | 
			
		||||
				ERR("Invalid type for %s", id);
 | 
			
		||||
				return -EINVAL;
 | 
			
		||||
			}
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		ERR("Unknown field %s", n->id);
 | 
			
		||||
		ERR("Unknown field %s", id);
 | 
			
		||||
		return -EINVAL;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue