diff options
| author | Colin Guthrie <pulse@colin.guthr.ie> | 2008-05-06 00:17:17 +0000 | 
|---|---|---|
| committer | Colin Guthrie <pulse@colin.guthr.ie> | 2008-10-08 20:32:06 +0100 | 
| commit | d423605bd9f5fb18b44fde5424b075c977de25ad (patch) | |
| tree | 3d414b4aeed4c799e2d3905c2654a1fc0840f00e /src/modules/rtp/rtsp.h | |
| parent | a0d3582fb1bddbb8fb6a7da98bbfeb05b517088e (diff) | |
Move closer to an asynchronous structure (still some parsing code to be converted).
Move type definition into .c file to keep it private
Add more utility functions to add/remove headers and return the serverport now the structure is private.
This commit will break the test application but I will fix that in due course
git-svn-id: file:///home/lennart/svn/public/pulseaudio/branches/coling@2365 fefdeb5f-60dc-0310-8127-8f9354f1896f
Diffstat (limited to 'src/modules/rtp/rtsp.h')
| -rw-r--r-- | src/modules/rtp/rtsp.h | 31 | 
1 files changed, 18 insertions, 13 deletions
diff --git a/src/modules/rtp/rtsp.h b/src/modules/rtp/rtsp.h index 181d0854..6458f851 100644 --- a/src/modules/rtp/rtsp.h +++ b/src/modules/rtp/rtsp.h @@ -36,30 +36,35 @@  #include "headerlist.h" -typedef struct pa_rtsp_context { -    pa_socket_client *sc; -    pa_iochannel *io; -    const char* useragent; -    pa_headerlist* headers; -    char* localip; -    char* url; -    uint32_t port; -    uint32_t cseq; -    char* session; -    char* transport; -} pa_rtsp_context; +typedef struct pa_rtsp_context pa_rtsp_context; +typedef enum { +  STATE_CONNECT, +  STATE_ANNOUNCE, +  STATE_SETUP, +  STATE_RECORD, +  STATE_TEARDOWN, +  STATE_SET_PARAMETER, +  STATE_FLUSH +} pa_rtsp_state; +typedef void (*pa_rtsp_cb_t)(pa_rtsp_context *c, pa_rtsp_state state, pa_headerlist* hl, void *userdata);  pa_rtsp_context* pa_rtsp_context_new(const char* useragent);  void pa_rtsp_context_free(pa_rtsp_context* c);  int pa_rtsp_connect(pa_rtsp_context* c, pa_mainloop_api *mainloop, const char* hostname, uint16_t port); +void pa_rtsp_set_callback(pa_rtsp_context *c, pa_rtsp_cb_t callback, void *userdata); +  void pa_rtsp_disconnect(pa_rtsp_context* c);  const char* pa_rtsp_localip(pa_rtsp_context* c); +uint32_t pa_rtsp_serverport(pa_rtsp_context* c);  void pa_rtsp_set_url(pa_rtsp_context* c, const char* url); +void pa_rtsp_add_header(pa_rtsp_context *c, const char* key, const char* value); +void pa_rtsp_remove_header(pa_rtsp_context *c, const char* key); +  int pa_rtsp_announce(pa_rtsp_context* c, const char* sdp); -int pa_rtsp_setup(pa_rtsp_context* c, pa_headerlist** response_headers); +int pa_rtsp_setup(pa_rtsp_context* c);  int pa_rtsp_record(pa_rtsp_context* c);  int pa_rtsp_teardown(pa_rtsp_context* c);  | 
