mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-10-29 05:40:27 -04:00 
			
		
		
		
	spa: add spa_json_begin_array/object and relaxed versions
Add spa_json_begin_array/object to replace spa_json_init+spa_json_begin_array/object This function is better because it does not waste a useless spa_json structure as an iterator. The relaxed versions also error out when the container is mismatched because parsing a mismatched container is not going to give any results anyway.
This commit is contained in:
		
							parent
							
								
									feccb882b6
								
							
						
					
					
						commit
						cd81b5f39a
					
				
					 51 changed files with 401 additions and 452 deletions
				
			
		|  | @ -1074,15 +1074,14 @@ static uint32_t channel_from_name(const char *name) | |||
| 
 | ||||
| static void parse_position(struct spa_audio_info_raw *info, const char *val, size_t len) | ||||
| { | ||||
| 	struct spa_json it[2]; | ||||
| 	struct spa_json it[1]; | ||||
| 	char v[256]; | ||||
| 
 | ||||
| 	spa_json_init(&it[0], val, len); | ||||
|         if (spa_json_enter_array(&it[0], &it[1]) <= 0) | ||||
|                 spa_json_init(&it[1], val, len); | ||||
|         if (spa_json_begin_array_relax(&it[0], val, len) <= 0) | ||||
| 		return; | ||||
| 
 | ||||
| 	info->channels = 0; | ||||
| 	while (spa_json_get_string(&it[1], v, sizeof(v)) > 0 && | ||||
| 	while (spa_json_get_string(&it[0], v, sizeof(v)) > 0 && | ||||
| 	    info->channels < SPA_AUDIO_MAX_CHANNELS) { | ||||
| 		info->position[info->channels++] = channel_from_name(v); | ||||
| 	} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Wim Taymans
						Wim Taymans