|  |  | @@ -326,4 +326,94 @@ extern int rtsp_rtp_port_max; | 
		
	
		
			
			|  |  |  | int rtsp_pause(AVFormatContext *s); | 
		
	
		
			
			|  |  |  | int rtsp_resume(AVFormatContext *s); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | /** | 
		
	
		
			
			|  |  |  | * Send a command to the RTSP server without waiting for the reply. | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @param s RTSP (de)muxer context | 
		
	
		
			
			|  |  |  | * @param cmd the full first line of the request | 
		
	
		
			
			|  |  |  | * @param send_content if non-null, the data to send as request body content | 
		
	
		
			
			|  |  |  | * @param send_content_length the length of the send_content data, or 0 if | 
		
	
		
			
			|  |  |  | *                            send_content is null | 
		
	
		
			
			|  |  |  | */ | 
		
	
		
			
			|  |  |  | void rtsp_send_cmd_with_content_async(AVFormatContext *s, | 
		
	
		
			
			|  |  |  | const char *cmd, | 
		
	
		
			
			|  |  |  | const unsigned char *send_content, | 
		
	
		
			
			|  |  |  | int send_content_length); | 
		
	
		
			
			|  |  |  | /** | 
		
	
		
			
			|  |  |  | * Send a command to the RTSP server without waiting for the reply. | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @see rtsp_send_cmd_with_content_async | 
		
	
		
			
			|  |  |  | */ | 
		
	
		
			
			|  |  |  | void rtsp_send_cmd_async(AVFormatContext *s, const char *cmd); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | /** | 
		
	
		
			
			|  |  |  | * Send a command to the RTSP server and wait for the reply. | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @param s RTSP (de)muxer context | 
		
	
		
			
			|  |  |  | * @param cmd the full first line of the request | 
		
	
		
			
			|  |  |  | * @param reply pointer where the RTSP message header will be stored | 
		
	
		
			
			|  |  |  | * @param content_ptr pointer where the RTSP message body, if any, will | 
		
	
		
			
			|  |  |  | *                    be stored (length is in reply) | 
		
	
		
			
			|  |  |  | * @param send_content if non-null, the data to send as request body content | 
		
	
		
			
			|  |  |  | * @param send_content_length the length of the send_content data, or 0 if | 
		
	
		
			
			|  |  |  | *                            send_content is null | 
		
	
		
			
			|  |  |  | */ | 
		
	
		
			
			|  |  |  | void rtsp_send_cmd_with_content(AVFormatContext *s, | 
		
	
		
			
			|  |  |  | const char *cmd, | 
		
	
		
			
			|  |  |  | RTSPMessageHeader *reply, | 
		
	
		
			
			|  |  |  | unsigned char **content_ptr, | 
		
	
		
			
			|  |  |  | const unsigned char *send_content, | 
		
	
		
			
			|  |  |  | int send_content_length); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | /** | 
		
	
		
			
			|  |  |  | * Send a command to the RTSP server and wait for the reply. | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @see rtsp_send_cmd_with_content | 
		
	
		
			
			|  |  |  | */ | 
		
	
		
			
			|  |  |  | void rtsp_send_cmd(AVFormatContext *s, const char *cmd, | 
		
	
		
			
			|  |  |  | RTSPMessageHeader *reply, unsigned char **content_ptr); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | /** | 
		
	
		
			
			|  |  |  | * Read a RTSP message from the server, or prepare to read data | 
		
	
		
			
			|  |  |  | * packets if we're reading data interleaved over the TCP/RTSP | 
		
	
		
			
			|  |  |  | * connection as well. | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @param s RTSP (de)muxer context | 
		
	
		
			
			|  |  |  | * @param reply pointer where the RTSP message header will be stored | 
		
	
		
			
			|  |  |  | * @param content_ptr pointer where the RTSP message body, if any, will | 
		
	
		
			
			|  |  |  | *                    be stored (length is in reply) | 
		
	
		
			
			|  |  |  | * @param return_on_interleaved_data whether the function may return if we | 
		
	
		
			
			|  |  |  | *                   encounter a data marker ('$'), which precedes data | 
		
	
		
			
			|  |  |  | *                   packets over interleaved TCP/RTSP connections. If this | 
		
	
		
			
			|  |  |  | *                   is set, this function will return 1 after encountering | 
		
	
		
			
			|  |  |  | *                   a '$'. If it is not set, the function will skip any | 
		
	
		
			
			|  |  |  | *                   data packets (if they are encountered), until a reply | 
		
	
		
			
			|  |  |  | *                   has been fully parsed. If no more data is available | 
		
	
		
			
			|  |  |  | *                   without parsing a reply, it will return an error. | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @returns 1 if a data packets is ready to be received, -1 on error, | 
		
	
		
			
			|  |  |  | *          and 0 on success. | 
		
	
		
			
			|  |  |  | */ | 
		
	
		
			
			|  |  |  | int rtsp_read_reply(AVFormatContext *s, RTSPMessageHeader *reply, | 
		
	
		
			
			|  |  |  | unsigned char **content_ptr, | 
		
	
		
			
			|  |  |  | int return_on_interleaved_data); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | /** | 
		
	
		
			
			|  |  |  | * Connect to the RTSP server and set up the individual media streams. | 
		
	
		
			
			|  |  |  | * This can be used for both muxers and demuxers. | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @param s RTSP (de)muxer context | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @returns 0 on success, < 0 on error. Cleans up all allocations done | 
		
	
		
			
			|  |  |  | *          within the function on error. | 
		
	
		
			
			|  |  |  | */ | 
		
	
		
			
			|  |  |  | int rtsp_connect(AVFormatContext *s); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | /** | 
		
	
		
			
			|  |  |  | * Close and free all streams within the RTSP (de)muxer | 
		
	
		
			
			|  |  |  | * | 
		
	
		
			
			|  |  |  | * @param s RTSP (de)muxer context | 
		
	
		
			
			|  |  |  | */ | 
		
	
		
			
			|  |  |  | void rtsp_close_streams(AVFormatContext *s); | 
		
	
		
			
			|  |  |  | 
 | 
		
	
		
			
			|  |  |  | #endif /* AVFORMAT_RTSP_H */ |