source: roaraudio/libroar/vio_string.c @ 3033:a3426e8335fb

Last change on this file since 3033:a3426e8335fb was 3033:a3426e8335fb, checked in by phi, 14 years ago

wrote lseek based optimized fgets()

File size: 3.5 KB
Line 
1//vio_string.c:
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_putc    (struct roar_vio_calls * vio, char c) {
38 return roar_vio_write(vio, &c, 1);
39}
40
41int     roar_vio_getc    (struct roar_vio_calls * vio) {
42 unsigned char c;
43
44 if ( roar_vio_read(vio, &c, 1) != 1 )
45  return EOF;
46
47 return c;
48}
49
50int     roar_vio_printf(struct roar_vio_calls * vio, const char *format, ...) {
51 va_list ap;
52 int ret;
53 char buf[8192];
54
55 va_start(ap, format);
56 ret = vsnprintf(buf, 8192, format, ap);
57 va_end(ap);
58
59 return roar_vio_write(vio, buf, ret);
60}
61
62char *  roar_vio_fgets   (struct roar_vio_calls * vio, char * s, size_t size) {
63 size_t  have = 0;
64 size_t  need = size;
65 ssize_t ret;
66 char    cur;
67 char    buf[1024];
68 off_t   offs;
69 char  * eol;
70
71 if ( size == 0 )
72  return s;
73
74 if ( vio == NULL || s == NULL )
75  return NULL;
76
77 // space for the \0
78 size -= 1;
79
80 if ( (offs = roar_vio_lseek(vio, 0, SEEK_CUR)) == (off_t)-1 ) {
81  // need to use the one byte at a time methode
82  while ( have < size ) {
83   if ( roar_vio_read(vio, &cur, 1) != 1 )
84    break;
85
86   s[have] = cur;
87     have++;
88
89   if ( cur == '\n' )
90    break;
91  }
92 } else {
93  // can use the optimized version
94  eol = NULL;
95
96  memset(s, '+', size);
97
98  while ( have < size && eol == NULL ) {
99   ret = roar_vio_read(vio, buf, need > 1023 ? 1023 : need);
100
101   if ( ret == -1 || ret == 0 )
102    break;
103
104   ROAR_DBG("roar_vio_fgets(*): have=%u", (unsigned int) have);
105
106   buf[1023] = 0;
107   if ( (eol = strstr(buf, "\n")) == NULL ) {
108    memcpy(s, buf, ret);
109    s    += ret;
110    have += ret;
111    need -= ret;
112   } else {
113    offs = eol - buf - ret + 1;
114    if ( roar_vio_lseek(vio, offs, SEEK_CUR) == -1 )
115     return NULL;
116
117    ROAR_DBG("roar_vio_fgets(*): have=%u", (unsigned int) have);
118    ROAR_DBG("roar_vio_fgets(*): eol - buf=%lli", (long long) (eol - buf));
119
120    ret = (size_t)(eol - buf);
121    ret++;
122    ROAR_DBG("roar_vio_fgets(*): ret=%lli", (long long) ret);
123
124    memcpy(s, buf, ret);
125    have += ret;
126
127    ROAR_DBG("roar_vio_fgets(*): have=%u", (unsigned int) have);
128
129    break;
130   }
131   ROAR_DBG("roar_vio_fgets(*): have=%u", (unsigned int) have);
132  }
133
134 }
135
136 ROAR_DBG("roar_vio_fgets(*): have=%u", (unsigned int) have);
137
138 if ( !have )
139  return NULL;
140
141 s[have] = 0;
142
143 return s;
144}
145
146//ll
Note: See TracBrowser for help on using the repository browser.