1 #ifndef HEADER_CURL_RTSP_H
2 #define HEADER_CURL_RTSP_H
3 /***************************************************************************
5 * Project ___| | | | _ \| |
7 * | (__| |_| | _ <| |___
8 * \___|\___/|_| \_\_____|
10 * Copyright (C) 1998 - 2022, Daniel Stenberg, <daniel@haxx.se>, et al.
12 * This software is licensed as described in the file COPYING, which
13 * you should have received as part of this distribution. The terms
14 * are also available at https://curl.se/docs/copyright.html.
16 * You may opt to use, copy, modify, merge, publish, distribute and/or sell
17 * copies of the Software, and permit persons to whom the Software is
18 * furnished to do so, under the terms of the COPYING file.
20 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
21 * KIND, either express or implied.
23 * SPDX-License-Identifier: curl
25 ***************************************************************************/
27 #define CURL_DISABLE_RTSP 1
30 #ifndef CURL_DISABLE_RTSP
32 extern const struct Curl_handler Curl_handler_rtsp;
34 CURLcode Curl_rtsp_parseheader(struct Curl_easy *data, char *header);
38 #define Curl_rtsp_parseheader(x,y) CURLE_NOT_BUILT_IN
40 #endif /* CURL_DISABLE_RTSP */
43 * RTSP Connection data
45 * Currently, only used for tracking incomplete RTP data reads
53 /****************************************************************************
55 ***************************************************************************/
58 * http_wrapper MUST be the first element of this structure for the wrap
59 * logic to work. In this way, we get a cheap polymorphism because
60 * &(data->state.proto.rtsp) == &(data->state.proto.http) per the C spec
62 * HTTP functions can safely treat this as an HTTP struct, but RTSP aware
63 * functions can also index into the later elements.
65 struct HTTP http_wrapper; /*wrap HTTP to do the heavy lifting */
67 long CSeq_sent; /* CSeq of this request */
68 long CSeq_recv; /* CSeq received */
72 #endif /* HEADER_CURL_RTSP_H */