mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	spa: add spa_json_object_next
This gets the next key and value from an object. This function is better because it will skip key/value pairs that don't fit in the array to hold the key. The previous code patter would stop parsing the object as soon as a key larger than the available space was found.
This commit is contained in:
		
							parent
							
								
									cd81b5f39a
								
							
						
					
					
						commit
						ce390d5b22
					
				
					 24 changed files with 171 additions and 269 deletions
				
			
		| 
						 | 
				
			
			@ -1689,6 +1689,8 @@ static int create_servers(struct pw_protocol *this, struct pw_impl_core *core,
 | 
			
		|||
		char key[256];
 | 
			
		||||
		char name[PATH_MAX];
 | 
			
		||||
		char selinux_context[PATH_MAX];
 | 
			
		||||
		const char *value;
 | 
			
		||||
		int len;
 | 
			
		||||
 | 
			
		||||
		info.uid = getuid();
 | 
			
		||||
		info.gid = getgid();
 | 
			
		||||
| 
						 | 
				
			
			@ -1696,13 +1698,7 @@ static int create_servers(struct pw_protocol *this, struct pw_impl_core *core,
 | 
			
		|||
		pw_properties_clear(p);
 | 
			
		||||
		pw_properties_update(p, &props->dict);
 | 
			
		||||
 | 
			
		||||
		while (spa_json_get_string(&it[1], key, sizeof(key)) > 0) {
 | 
			
		||||
			const char *value;
 | 
			
		||||
			int len;
 | 
			
		||||
 | 
			
		||||
			if ((len = spa_json_next(&it[1], &value)) <= 0)
 | 
			
		||||
				goto error_invalid;
 | 
			
		||||
 | 
			
		||||
		while ((len = spa_json_object_next(&it[1], key, sizeof(key), &value)) > 0) {
 | 
			
		||||
			if (spa_streq(key, "name")) {
 | 
			
		||||
				if (spa_json_parse_stringn(value, len, name, sizeof(name)) < 0)
 | 
			
		||||
					goto error_invalid;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue