source: roaraudio/libroar/vio_magic.c @ 1298:b87039ebf291

Last change on this file since 1298:b87039ebf291 was 1298:b87039ebf291, checked in by phi, 15 years ago

wrote some basic code

File size: 3.5 KB
Line 
1
2
3/*
4 *      Copyright (C) Philipp 'ph3-der-loewe' Schafft - 2009
5 *
6 *  This file is part of libroar a part of RoarAudio,
7 *  a cross-platform sound system for both, home and professional use.
8 *  See README for details.
9 *
10 *  This file is free software; you can redistribute it and/or modify
11 *  it under the terms of the GNU General Public License version 3
12 *  as published by the Free Software Foundation.
13 *
14 *  libroar is distributed in the hope that it will be useful,
15 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 *  GNU General Public License for more details.
18 *
19 *  You should have received a copy of the GNU General Public License
20 *  along with this software; see the file COPYING.  If not, write to
21 *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
22 *
23 *  NOTE for everyone want's to change something and send patches:
24 *  read README and HACKING! There a addition information on
25 *  the license of this document you need to read before you send
26 *  any patches.
27 *
28 *  NOTE for uses of non-GPL (LGPL,...) software using libesd, libartsc
29 *  or libpulse*:
30 *  The libs libroaresd, libroararts and libroarpulse link this lib
31 *  and are therefore GPL. Because of this it may be illigal to use
32 *  them with any software that uses libesd, libartsc or libpulse*.
33 */
34
35#include "libroar.h"
36
37int     roar_vio_open_magic    (struct roar_vio_calls * calls, struct roar_vio_calls * dst, int * codec);
38int     roar_vio_magic_close   (struct roar_vio_calls * vio);
39
40ssize_t roar_vio_magic_read    (struct roar_vio_calls * vio, void *buf, size_t count) {
41 struct roar_vio_magic * self = (struct roar_vio_magic *)(vio->inst);
42 void * calls;
43 size_t len;
44
45 if (self == NULL)
46  return -1;
47
48 if ( roar_stack_get_cur(&(self->vios), &calls) == -1 )
49  return -1;
50
51 if ( roar_buffer_get_len(&(self->inp), &len) == -1 )
52  return -1;
53
54 if ( len ) {
55  len = len > count ? count : len;
56  if ( roar_buffer_shift_out(&(self->inp), buf, &len) == -1 )
57   return -1;
58 }
59
60 count -= len;
61 buf += len;
62
63 if ( count ) {
64  if ( (count = roar_vio_read((struct roar_vio_calls*) calls, buf, count)) == -1 )
65   return len;
66
67  return len+count;
68 }
69
70 return len;
71}
72
73ssize_t roar_vio_magic_write   (struct roar_vio_calls * vio, void *buf, size_t count) {
74 struct roar_vio_magic * self = (struct roar_vio_magic *)(vio->inst);
75 void * calls;
76
77 if (self == NULL)
78  return -1;
79
80 if ( roar_stack_get_cur(&(self->vios), &calls) == -1 )
81  return -1;
82
83 return roar_vio_write((struct roar_vio_calls*)calls, buf, count);
84}
85
86off_t   roar_vio_magic_lseek   (struct roar_vio_calls * vio, off_t offset, int whence) {
87 struct roar_vio_magic * self = (struct roar_vio_magic *)(vio->inst);
88 void * calls;
89
90 if (self == NULL)
91  return -1;
92
93 if ( roar_stack_get_cur(&(self->vios), &calls) == -1 )
94  return -1;
95
96 return roar_vio_lseek((struct roar_vio_calls*)calls, offset, whence);
97}
98
99int     roar_vio_magic_nonblock(struct roar_vio_calls * vio, int state) {
100 struct roar_vio_magic * self = (struct roar_vio_magic *)(vio->inst);
101 void * calls;
102
103 if (self == NULL)
104  return -1;
105
106 if ( roar_stack_get_cur(&(self->vios), &calls) == -1 )
107  return -1;
108
109 return roar_vio_nonblock((struct roar_vio_calls*)calls, state);
110}
111
112int     roar_vio_magic_sync    (struct roar_vio_calls * vio) {
113 struct roar_vio_magic * self = (struct roar_vio_magic *)(vio->inst);
114 void * calls;
115
116 if (self == NULL)
117  return -1;
118
119 if ( roar_stack_get_cur(&(self->vios), &calls) == -1 )
120  return -1;
121
122 return roar_vio_sync((struct roar_vio_calls*)calls);
123}
124
125//ll
Note: See TracBrowser for help on using the repository browser.