]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/dyn-string.c
Oops, missed ChangeLog in last checkin...
[thirdparty/gcc.git] / gcc / dyn-string.c
CommitLineData
b170964a 1/* An abstract string datatype.
87e11268 2 Copyright (C) 1998, 1999 Free Software Foundation, Inc.
b170964a
MM
3 Contributed by Mark Mitchell (mark@markmitchell.com).
4
63fdf24a 5This file is part of GNU CC.
b170964a 6
c5c76735
JL
7GNU CC is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
63fdf24a
JL
9the Free Software Foundation; either version 2, or (at your option)
10any later version.
b170964a 11
c5c76735
JL
12GNU CC is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
b170964a 16
63fdf24a 17You should have received a copy of the GNU General Public License
ab97ebb9
JL
18along with GNU CC; see the file COPYING. If not, write to
19the Free Software Foundation, 59 Temple Place - Suite 330,
20Boston, MA 02111-1307, USA. */
b170964a 21
c5c76735 22
b170964a
MM
23#include "config.h"
24#include "system.h"
b170964a
MM
25#include "dyn-string.h"
26
c5c76735
JL
27/* Create a new dynamic string capable of holding at least SPACE characters,
28 including the terminating NUL. If SPACE is 0, it will be silently
29 increased to 1. */
b170964a
MM
30
31dyn_string_t
32dyn_string_new (space)
33 int space;
34{
35 dyn_string_t result = (dyn_string_t) xmalloc (sizeof (struct dyn_string));
36
c5c76735 37 /* We need at least one byte in which to store the terminating NUL. */
b170964a 38 if (space == 0)
b170964a
MM
39 space = 1;
40
41 result->allocated = space;
c5c76735 42 result->s = (char *) xmalloc (space);
b170964a
MM
43 result->length = 0;
44 result->s[0] = '\0';
45
46 return result;
47}
48
49/* Free the memory used by DS. */
50
51void
52dyn_string_delete (ds)
53 dyn_string_t ds;
54{
55 free (ds->s);
56 free (ds);
57}
58
c5c76735 59/* Append the NUL-terminated string S to DS, resizing DS if necessary. */
b170964a
MM
60
61dyn_string_t
62dyn_string_append (ds, s)
63 dyn_string_t ds;
87e11268 64 const char *s;
b170964a
MM
65{
66 int len = strlen (s);
c5c76735
JL
67
68 /* The new length is the old length plus the size of our string, plus
69 one for the null at the end. */
70 dyn_string_resize (ds, ds->length + len + 1);
b170964a
MM
71 strcpy (ds->s + ds->length, s);
72 ds->length += len;
73
74 return ds;
75}
76
c5c76735
JL
77/* Increase the capacity of DS so it can hold at least SPACE characters,
78 including the terminating NUL. This function will not (at present)
79 reduce the capacity of DS. */
b170964a
MM
80
81dyn_string_t
82dyn_string_resize (ds, space)
83 dyn_string_t ds;
84 int space;
85{
86 int new_allocated = ds->allocated;
87
88 while (space > new_allocated)
89 new_allocated *= 2;
90
91 if (new_allocated != ds->allocated)
92 {
93 /* We actually need more space. */
94 ds->allocated = new_allocated;
c5c76735 95 ds->s = (char *) xrealloc (ds->s, ds->allocated);
b170964a
MM
96 }
97
98 return ds;
99}