annotate dmd/OutBuffer.d @ 168:ceed63f310fb

stringtable, stringbuffer and freelist moved to Global
author korDen
date Thu, 30 Sep 2010 12:57:13 +0400
parents e28b18c23469
children 94b6033c07f3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.OutBuffer;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
114
e28b18c23469 added a module dmd.common for commonly used stuff
Trass3r
parents: 93
diff changeset
3 import dmd.common;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
4 import std.stdarg;
34
544b922227c7 update to work with dmd 2.048
korDen
parents: 12
diff changeset
5 import std.exception;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
6
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
7 import core.stdc.stdlib;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
8 import core.stdc.string;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
9
4
d706d958e4e8 Step 2 of restoring GC functionality.
korDen
parents: 2
diff changeset
10 import core.memory;
5
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
11 import core.stdc.stdlib;
2
7427ded8caf7 Removed unreferenced modules
korDen
parents: 0
diff changeset
12
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
13 class OutBuffer
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
14 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15 ubyte* data;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 uint offset;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
17 uint size;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
18
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 this()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21 // do nothing
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 final void* extractData()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 void* p = cast(void*)data;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
27
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
28 data = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
29 offset = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 size = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32 return p;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
34
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35 void mark()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
39
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
40 final void reserve(uint nbytes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
41 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
42 //printf("OutBuffer::reserve: size = %d, offset = %d, nbytes = %d\n", size, offset, nbytes);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
43 if (size - offset < nbytes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
44 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
45 size = (offset + nbytes) * 2;
5
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
46 data = cast(ubyte*)realloc(data, size);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
47 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
48 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
49
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
50 final void setsize(uint size)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
51 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
52 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
53 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
54
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
55 final void reset()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
56 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
57 offset = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
58 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
59
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
60 final void write(const(void)* data, uint nbytes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
61 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
62 reserve(nbytes);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
63 memcpy(this.data + offset, data, nbytes);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
64 offset += nbytes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
65 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
66
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
67 final void writebstring(ubyte* string_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
68 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
69 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
70 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
71
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
72 final void writestring(const(char)[] string_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
73 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
74 write(string_.ptr , string_.length);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
75 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
76
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
77 final void writedstring(const(char)* string_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
78 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
79 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
80 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
81
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
82 final void writedstring(const(wchar)* string_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
83 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 final void prependstring(const(char)[] string_)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
88 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
89 uint len = string_.length;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
90 reserve(len);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
91 memmove(data + len, data, offset);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
92 memcpy(data, string_.ptr, len);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
93 offset += len;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
95
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
96 final void writenl() // write newline
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
97 {
114
e28b18c23469 added a module dmd.common for commonly used stuff
Trass3r
parents: 93
diff changeset
98 version (Windows)
93
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
99 {
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
100 version (M_UNICODE)
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
101 {
68
ee3a9f34dc48 final bits of codegen implementation to compile Phobos
korDen
parents: 34
diff changeset
102 write4(0x000A000D); // newline is CR,LF on Microsoft OS's
93
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
103 }
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
104 else
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
105 {
68
ee3a9f34dc48 final bits of codegen implementation to compile Phobos
korDen
parents: 34
diff changeset
106 writeword(0x0A0D); // newline is CR,LF on Microsoft OS's
ee3a9f34dc48 final bits of codegen implementation to compile Phobos
korDen
parents: 34
diff changeset
107 }
93
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
108 }
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
109 else
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
110 {
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
111 version (M_UNICODE)
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
112 {
68
ee3a9f34dc48 final bits of codegen implementation to compile Phobos
korDen
parents: 34
diff changeset
113 writeword('\n');
93
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
114 }
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
115 else
df6d0f967680 implemented a whole bunch of methods to make phobos 2.035 compile
Trass3r
parents: 68
diff changeset
116 {
68
ee3a9f34dc48 final bits of codegen implementation to compile Phobos
korDen
parents: 34
diff changeset
117 writeByte('\n');
ee3a9f34dc48 final bits of codegen implementation to compile Phobos
korDen
parents: 34
diff changeset
118 }
ee3a9f34dc48 final bits of codegen implementation to compile Phobos
korDen
parents: 34
diff changeset
119 }
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
120 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
121
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
122 final void writeByte(uint b)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
123 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
124 reserve(1);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
125 this.data[offset] = cast(ubyte)b;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
126 offset++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
127 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
128
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
129 final void writebyte(uint b) { writeByte(b); }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
130
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
131 final void writeUTF8(uint b)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
132 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
133 reserve(6);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
134 if (b <= 0x7F)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
135 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
136 this.data[offset] = cast(ubyte)b;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
137 offset++;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
138 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
139 else if (b <= 0x7FF)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
140 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
141 this.data[offset + 0] = cast(ubyte)((b >> 6) | 0xC0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
142 this.data[offset + 1] = cast(ubyte)((b & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
143 offset += 2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
144 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
145 else if (b <= 0xFFFF)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
146 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
147 this.data[offset + 0] = cast(ubyte)((b >> 12) | 0xE0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
148 this.data[offset + 1] = cast(ubyte)(((b >> 6) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
149 this.data[offset + 2] = cast(ubyte)((b & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
150 offset += 3;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
151 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
152 else if (b <= 0x1FFFFF)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
153 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
154 this.data[offset + 0] = cast(ubyte)((b >> 18) | 0xF0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
155 this.data[offset + 1] = cast(ubyte)(((b >> 12) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
156 this.data[offset + 2] = cast(ubyte)(((b >> 6) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
157 this.data[offset + 3] = cast(ubyte)((b & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
158 offset += 4;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
159 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
160 else if (b <= 0x3FFFFFF)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
161 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
162 this.data[offset + 0] = cast(ubyte)((b >> 24) | 0xF8);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
163 this.data[offset + 1] = cast(ubyte)(((b >> 18) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
164 this.data[offset + 2] = cast(ubyte)(((b >> 12) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
165 this.data[offset + 3] = cast(ubyte)(((b >> 6) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
166 this.data[offset + 4] = cast(ubyte)((b & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
167 offset += 5;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
168 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
169 else if (b <= 0x7FFFFFFF)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
170 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
171 this.data[offset + 0] = cast(ubyte)((b >> 30) | 0xFC);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
172 this.data[offset + 1] = cast(ubyte)(((b >> 24) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
173 this.data[offset + 2] = cast(ubyte)(((b >> 18) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
174 this.data[offset + 3] = cast(ubyte)(((b >> 12) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
175 this.data[offset + 4] = cast(ubyte)(((b >> 6) & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
176 this.data[offset + 5] = cast(ubyte)((b & 0x3F) | 0x80);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
177 offset += 6;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
178 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
179 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
180 assert(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
181 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
182
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
183 final void writedchar(uint b)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
184 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
185 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
186 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
187
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
188 final void prependbyte(uint b)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
189 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
190 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
191 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
192
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
193 final void writeword(uint w)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
194 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
195 reserve(2);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
196 *cast(ushort*)(this.data + offset) = cast(ushort)w;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
197 offset += 2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
198 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
199
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
200 final void writeUTF16(uint w)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
201 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
202 reserve(4);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
203 if (w <= 0xFFFF)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
204 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
205 *cast(ushort*)(this.data + offset) = cast(ushort)w;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
206 offset += 2;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
207 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
208 else if (w <= 0x10FFFF)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
209 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
210 *cast(ushort*)(this.data + offset) = cast(ushort)((w >> 10) + 0xD7C0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
211 *cast(ushort*)(this.data + offset + 2) = cast(ushort)((w & 0x3FF) | 0xDC00);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
212 offset += 4;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
213 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
214 else
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
215 assert(0);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
216 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
217
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
218 final void write4(uint w)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
219 {
12
832f71e6f96c *Exp and *AssignExp arrayOp implementation added (might be a bit incomplete)
korDen
parents: 5
diff changeset
220 reserve(4);
832f71e6f96c *Exp and *AssignExp arrayOp implementation added (might be a bit incomplete)
korDen
parents: 5
diff changeset
221 *cast(uint*)(this.data + offset) = w;
832f71e6f96c *Exp and *AssignExp arrayOp implementation added (might be a bit incomplete)
korDen
parents: 5
diff changeset
222 offset += 4;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
223 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
224
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
225 final void write(OutBuffer buf)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
226 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
227 if (buf)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
228 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
229 reserve(buf.offset);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
230 memcpy(data + offset, buf.data, buf.offset);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
231 offset += buf.offset;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
232 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
233 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
234
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
235 final void write(Object obj)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
236 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
237 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
238 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
239
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
240 final void fill0(uint nbytes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
241 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
242 reserve(nbytes);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
243 memset(data + offset, 0, nbytes);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
244 offset += nbytes;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
245 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
246
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
247 final void align_(uint size)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
248 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
249 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
250 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
251
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
252 void vprintf(const(char)* format, va_list args)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
253 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
254 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
255 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
256
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
257 void printf(T...)(string format, T t)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
258 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
259 string s = std.string.format(format, t);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
260 writestring(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
261 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
262
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
263 version (M_UNICODE) {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
264 /// void vprintf(const uint short *format, va_list args);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
265 /// void printf(const uint short *format, ...);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
266 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
267 final void bracket(char left, char right)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
268 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
269 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
270 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
271
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
272 final uint bracket(uint i, const(char)* left, uint j, const(char)* right)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
273 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
274 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
275 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
276
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
277 final void spread(uint offset, uint nbytes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
278 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
279 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
280 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
281
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
282 final uint insert(uint offset, const(void)* data, uint nbytes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
283 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
284 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
285 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
286
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
287 final void remove(uint offset, uint nbytes)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
288 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
289 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
290 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
291
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
292 string toChars()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
293 {
5
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
294 char[] s = getString();
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
295 char* copy = cast(char*)malloc(s.length);
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
296 memcpy(copy, s.ptr, s.length);
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
297 return assumeUnique(copy[0..s.length]);
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
298
63623152e82a Fixed memory corruption bug which was introduced when attempting to restore GC functionality
dkoroskin <>
parents: 4
diff changeset
299 //return getString().idup;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
300 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
301
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
302 final string extractString()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
303 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
304 char[] s = getString();
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
305 data = null;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
306 offset = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
307 size = 0;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
308
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
309 return assumeUnique(s);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
310 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
311
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
312 final char[] getString()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
313 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
314 char* s = cast(char*)data;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
315 return s[0..offset];
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
316 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
317 }