decoder/audiofile: implement scan_stream() instead of scan_file()
This commit is contained in:
		
							
								
								
									
										1
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								NEWS
									
									
									
									
									
								
							| @@ -30,6 +30,7 @@ ver 0.19 (not yet released) | |||||||
|   - volume: improved software volume dithering |   - volume: improved software volume dithering | ||||||
| * decoder: | * decoder: | ||||||
|   - vorbis, flac, opus: honor DESCRIPTION= tag in Xiph-based files as a comment to the song |   - vorbis, flac, opus: honor DESCRIPTION= tag in Xiph-based files as a comment to the song | ||||||
|  |   - audiofile: support scanning remote files | ||||||
| * encoder: | * encoder: | ||||||
|   - shine: new encoder plugin |   - shine: new encoder plugin | ||||||
| * threads: | * threads: | ||||||
|   | |||||||
| @@ -63,19 +63,6 @@ audiofile_get_duration(AFfilehandle fh) | |||||||
| 	return frame_count / rate; | 	return frame_count / rate; | ||||||
| } | } | ||||||
|  |  | ||||||
| gcc_pure |  | ||||||
| static int |  | ||||||
| audiofile_get_duration(Path path_fs) |  | ||||||
| { |  | ||||||
| 	AFfilehandle af_fp = afOpenFile(path_fs.c_str(), "r", nullptr); |  | ||||||
| 	if (af_fp == AF_NULL_FILEHANDLE) { |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	int total_time = int(audiofile_get_duration(af_fp)); |  | ||||||
| 	afCloseFile(af_fp); |  | ||||||
| 	return total_time; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static ssize_t | static ssize_t | ||||||
| audiofile_file_read(AFvirtualfile *vfile, void *data, size_t length) | audiofile_file_read(AFvirtualfile *vfile, void *data, size_t length) | ||||||
| { | { | ||||||
| @@ -250,18 +237,31 @@ audiofile_stream_decode(Decoder &decoder, InputStream &is) | |||||||
| 	afCloseFile(af_fp); | 	afCloseFile(af_fp); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | gcc_pure | ||||||
|  | static int | ||||||
|  | audiofile_get_duration(InputStream &is) | ||||||
|  | { | ||||||
|  | 	if (!is.IsSeekable()) | ||||||
|  | 		return -1; | ||||||
|  |  | ||||||
|  | 	AudioFileInputStream afis{nullptr, is}; | ||||||
|  | 	AFvirtualfile *vf = setup_virtual_fops(afis); | ||||||
|  | 	AFfilehandle fh = afOpenVirtualFile(vf, "r", nullptr); | ||||||
|  | 	if (fh == AF_NULL_FILEHANDLE) | ||||||
|  | 		return -1; | ||||||
|  |  | ||||||
|  | 	int duration = int(audiofile_get_duration(fh)); | ||||||
|  | 	afCloseFile(fh); | ||||||
|  | 	return duration; | ||||||
|  | } | ||||||
|  |  | ||||||
| static bool | static bool | ||||||
| audiofile_scan_file(Path path_fs, | audiofile_scan_stream(InputStream &is, | ||||||
| 		      const struct tag_handler *handler, void *handler_ctx) | 		      const struct tag_handler *handler, void *handler_ctx) | ||||||
| { | { | ||||||
| 	int total_time = audiofile_get_duration(path_fs); | 	int total_time = audiofile_get_duration(is); | ||||||
|  | 	if (total_time < 0) | ||||||
| 	if (total_time < 0) { |  | ||||||
| 		FormatWarning(audiofile_domain, |  | ||||||
| 			      "Failed to get total song time from: %s", |  | ||||||
| 			      path_fs.c_str()); |  | ||||||
| 		return false; | 		return false; | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	tag_handler_invoke_duration(handler, handler_ctx, total_time); | 	tag_handler_invoke_duration(handler, handler_ctx, total_time); | ||||||
| 	return true; | 	return true; | ||||||
| @@ -283,8 +283,8 @@ const struct DecoderPlugin audiofile_decoder_plugin = { | |||||||
| 	nullptr, | 	nullptr, | ||||||
| 	audiofile_stream_decode, | 	audiofile_stream_decode, | ||||||
| 	nullptr, | 	nullptr, | ||||||
| 	audiofile_scan_file, |  | ||||||
| 	nullptr, | 	nullptr, | ||||||
|  | 	audiofile_scan_stream, | ||||||
| 	nullptr, | 	nullptr, | ||||||
| 	audiofile_suffixes, | 	audiofile_suffixes, | ||||||
| 	audiofile_mime_types, | 	audiofile_mime_types, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Max Kellermann
					Max Kellermann