1 /*
2  * Copyright (C) 2000, Matias Atria
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  */
18 
19 #include <config.h>
20 #include <stdlib.h>
21 #include <string.h>
22 
23 #include "common.h"
24 
fsgetn(FILE * p,size_t n)25 long	fsgetn(FILE *p, size_t n)
26 {
27 	long	v;
28 
29 	v = fgetbyte(p);
30 	if(v & 0x80)
31 		v -= 0x100;
32 	while(--n > 0)
33 		v = (v << 8) | fgetbyte(p);
34 	return v;
35 }
36 
fugetn(FILE * p,size_t n)37 Ulong	fugetn(FILE *p, size_t n)
38 {
39 	Ulong	v;
40 
41 	v = fgetbyte(p);
42 	while(--n > 0)
43 		v = (v << 8) | fgetbyte(p);
44 	return v;
45 }
46 
msgetn(const Uchar * p,size_t n)47 long	msgetn(const Uchar *p, size_t n)
48 {
49 	long	v = (long)*p++;
50 
51 	if(v & 0x80)
52 		v -= 0x100;
53 	while(--n > 0)
54 		v = (v << 8) | *p++;
55 	return v;
56 }
57 
mugetn(const Uchar * p,size_t n)58 Ulong	mugetn(const Uchar *p, size_t n)
59 {
60 	Ulong	v = (Ulong)*p++;
61 
62 	while(--n > 0)
63 		v = (v << 8) | *p++;
64 	return v;
65 }
66 
read_string(FILE * in,int s,char * buffer,size_t len)67 char	*read_string(FILE *in, int s, char *buffer, size_t len)
68 {
69 	int	n;
70 	char	*str;
71 
72 	n = fugetn(in, s ? s : 1);
73 	if((str = buffer) == NULL || n + 1 > len)
74 		str = mdvi_malloc(n + 1);
75 	if(fread(str, 1, n, in) != n) {
76 		if(str != buffer) mdvi_free(str);
77 		return NULL;
78 	}
79 	str[n] = 0;
80 	return str;
81 }
82 
read_bcpl(FILE * in,char * buffer,size_t maxlen,size_t wanted)83 size_t	read_bcpl(FILE *in, char *buffer, size_t maxlen, size_t wanted)
84 {
85 	size_t	i;
86 
87 	i = (int)fuget1(in);
88 	if(maxlen && i > maxlen)
89 		i = maxlen;
90 	if(fread(buffer, i, 1, in) != 1)
91 		return -1;
92 	buffer[i] = '\0';
93 	while(wanted-- > i)
94 		(void)fgetc(in);
95 	return i;
96 }
97 
read_alloc_bcpl(FILE * in,size_t maxlen,size_t * size)98 char	*read_alloc_bcpl(FILE *in, size_t maxlen, size_t *size)
99 {
100 	size_t	i;
101 	char	*buffer;
102 
103 	i = (size_t)fuget1(in);
104 	if(maxlen && i > maxlen)
105 		i = maxlen;
106 	buffer = (char *)malloc(i + 1);
107 	if(buffer == NULL)
108 		return NULL;
109 	if(fread(buffer, i, 1, in) != 1) {
110 		free(buffer);
111 		return NULL;
112 	}
113 	buffer[i] = '\0';
114 	if(size) *size = i;
115 	return buffer;
116 }
117 
118 /* buffers */
119 
buff_free(Buffer * buf)120 void	buff_free(Buffer *buf)
121 {
122 	if(buf->data)
123 		mdvi_free(buf->data);
124 	buff_init(buf);
125 }
126 
buff_init(Buffer * buf)127 void	buff_init(Buffer *buf)
128 {
129 	buf->data = NULL;
130 	buf->size = 0;
131 	buf->length = 0;
132 }
133 
buff_add(Buffer * buf,const char * data,size_t len)134 size_t	buff_add(Buffer *buf, const char *data, size_t len)
135 {
136 	if(!len && data)
137 		len = strlen(data);
138 	if(buf->length + len + 1 > buf->size) {
139 		buf->size = buf->length + len + 256;
140 		buf->data = mdvi_realloc(buf->data, buf->size);
141 	}
142 	memcpy(buf->data + buf->length, data, len);
143 	buf->length += len;
144 	return buf->length;
145 }
146 
buff_gets(Buffer * buf,size_t * length)147 char	*buff_gets(Buffer *buf, size_t *length)
148 {
149 	char	*ptr;
150 	char	*ret;
151 	size_t	len;
152 
153 	ptr = strchr(buf->data, '\n');
154 	if(ptr == NULL)
155 		return NULL;
156 	ptr++; /* include newline */
157 	len = ptr - buf->data;
158 	ret = mdvi_malloc(len + 1);
159 	if(len > 0) {
160 		memcpy(ret, buf->data, len);
161 		memmove(buf->data, buf->data + len, buf->length - len);
162 		buf->length -= len;
163 	}
164 	ret[len] = 0;
165 	if(length) *length = len;
166 	return ret;
167 }
168 
169