source: roaraudio/libroar/stream.c @ 487:a25cdf58b8fe

Last change on this file since 487:a25cdf58b8fe was 487:a25cdf58b8fe, checked in by phi, 16 years ago

added Af_INET support to roar_simple_new_stream_obj()

File size: 4.6 KB
Line 
1//stream.c:
2
3#include "libroar.h"
4
5int roar_stream_connect (struct roar_connection * con, struct roar_stream * s, int dir) {
6 struct roar_message m;
7
8 s->dir = dir;
9
10 m.cmd     = ROAR_CMD_NEW_STREAM;
11 m.stream  = -1;
12 m.pos     = 0;
13
14 roar_stream_s2m(s, &m);
15
16 if ( roar_req(con, &m, NULL) != 0 )
17  return -1;
18
19 if ( m.cmd == ROAR_CMD_OK ) {
20  s->id = m.stream;
21
22  ROAR_DBG("roar_stream_connect(*) = 0");
23  return 0;
24 }
25
26 ROAR_ERR("roar_stream_connect(*): Connecting new stream faild!");
27 ROAR_DBG("roar_stream_connect(*) = -1");
28 return -1;
29}
30
31int roar_stream_new (struct roar_stream * s, unsigned int rate,
32                     unsigned int channels, unsigned int bits, unsigned int codec) {
33
34
35 s->fh         = -1;
36 s->id         = -1;
37 s->pos        = 0;
38 s->pos_rel_id = -1;
39
40 s->dir        = ROAR_DIR_DEFAULT;
41
42 s->datalen    = 0;
43 s->offset     = 0;
44
45 s->database   = NULL;
46 s->dataoff    = NULL;
47
48 s->info.rate     = rate;
49 s->info.channels = channels;
50 s->info.bits     = bits;
51 s->info.codec    = codec;
52
53 if ( bits > ROAR_BITS_MAX )
54  return -1;
55
56 return 0;
57}
58
59int roar_stream_exec    (struct roar_connection * con, struct roar_stream * s) {
60 struct roar_message m;
61
62 m.cmd     = ROAR_CMD_EXEC_STREAM;
63 m.stream  = s->id;
64 m.datalen = 0;
65 m.pos     = 0;
66
67 if ( roar_req(con, &m, NULL) == -1 )
68  return -1;
69
70 if ( m.cmd == ROAR_CMD_OK )
71  return 0;
72 return -1;
73}
74
75int roar_stream_connect_to (struct roar_connection * con, struct roar_stream * s, int type, char * host, int port) {
76 struct roar_message m;
77
78 if ( roar_stream_connect_to_ask(con, s, type, host, port) == -1 )
79  return -1;
80
81 if ( roar_recv_message(con, &m, NULL) == -1 )
82  return -1;
83
84 if ( m.cmd == ROAR_CMD_OK )
85  return 0;
86 return -1;
87}
88
89int roar_stream_connect_to_ask (struct roar_connection * con, struct roar_stream * s, int type, char * host, int port) {
90 struct roar_message m;
91 int len = 0;
92
93 if ( host == NULL )
94  return -1;
95
96 ROAR_DBG("roar_stream_connect_to_ask(*): Ask the server to connect to: %s:%i", host, port);
97
98 m.cmd     = ROAR_CMD_CON_STREAM;
99 m.stream  = s->id;
100 m.pos     = 0;
101
102 m.data[0] = 0;
103 m.data[1] = type;
104 ((uint16_t*)&(m.data))[1] = ROAR_HOST2NET16(port);
105
106 len = strlen(host);
107
108 if ( len > 76 )
109  return -1;
110
111 strncpy(&(m.data[4]), host, len);
112
113 m.datalen = len + 4;
114
115 if ( roar_send_message(con, &m, NULL) == -1 )
116  return -1;
117
118 return 0;
119}
120
121int roar_stream_add_data (struct roar_connection * con, struct roar_stream * s, char * data, size_t len) {
122 struct roar_message m;
123
124 m.cmd     = ROAR_CMD_ADD_DATA;
125 m.stream  = s->id;
126 m.pos     = 0;
127 m.datalen = len;
128
129// if ( roar_req(con, &m, (void**)&data) == -1 )
130//  return -1;
131 if ( roar_send_message(con, &m, data) != 0 )
132  return -1;
133
134 if ( roar_recv_message(con, &m, NULL) == -1 )
135  return -1;
136
137 if ( m.cmd == ROAR_CMD_OK )
138  return 0;
139 return -1;
140}
141
142int roar_stream_get_info (struct roar_connection * con, struct roar_stream * s, struct roar_stream_info * info) {
143 struct roar_message m;
144 uint16_t * data = (uint16_t *) m.data;
145 int i;
146
147 m.cmd     = ROAR_CMD_GET_STREAM_PARA;
148 m.stream  = s->id;
149 m.datalen = 4;
150 m.pos     = 0;
151
152 data[0] = 0; // Version and reserved
153 data[1] = 1; // stream
154
155 for (i = 0; i < m.datalen/2; i++) {
156  data[i] = ROAR_HOST2NET16(data[i]);
157 }
158
159 if ( roar_req(con, &m, NULL) == -1 )
160  return -1;
161
162 if ( m.cmd != ROAR_CMD_OK )
163  return -1;
164
165 for (i = 0; i < m.datalen/2; i++) {
166  data[i] = ROAR_NET2HOST16(data[i]);
167 }
168
169 if ( m.datalen < 3*2 )
170  return -1;
171
172 if ( data[0] != 0 || data[1] != 1 )
173  return -1;
174
175 info->block_size = data[2];
176
177 return 0;
178}
179
180#define _ROAR_STREAM_MESSAGE_LEN ((5+1)*4)
181
182int roar_stream_s2m     (struct roar_stream * s, struct roar_message * m) {
183 uint32_t * data;
184 int i;
185
186 if ( !(s && m) )
187  return -1;
188
189 m->datalen = _ROAR_STREAM_MESSAGE_LEN;
190 data = (uint32_t*) m->data;
191
192 data[0] = s->dir;
193 data[1] = s->pos_rel_id;
194 data[2] = s->info.rate;
195 data[3] = s->info.bits;
196 data[4] = s->info.channels;
197 data[5] = s->info.codec;
198
199 for (i = 0; i < _ROAR_STREAM_MESSAGE_LEN/4; i++)
200  data[i] = ROAR_HOST2NET32(data[i]);
201
202 ROAR_DBG("roar_stream_s2m(*): s->info:");
203 roar_debug_audio_info_print(&s->info);
204
205 return 0;
206}
207int roar_stream_m2s     (struct roar_stream * s, struct roar_message * m) {
208 uint32_t * data;
209 int i;
210
211 if ( !(s && m) )
212  return -1;
213
214 if ( m->datalen != _ROAR_STREAM_MESSAGE_LEN )
215  return -1;
216
217 data = (uint32_t*) m->data;
218
219 for (i = 0; i < _ROAR_STREAM_MESSAGE_LEN/4; i++)
220  data[i] = ROAR_NET2HOST32(data[i]);
221
222 s->id            = m->stream;
223 s->dir           = data[0];
224 s->pos_rel_id    = data[1];
225 s->info.rate     = data[2];
226 s->info.bits     = data[3];
227 s->info.channels = data[4];
228 s->info.codec    = data[5];
229
230 ROAR_DBG("roar_stream_m2s(*): s->info:");
231 roar_debug_audio_info_print(&s->info);
232
233 return 0;
234}
235
236//ll
Note: See TracBrowser for help on using the repository browser.