annotate dmd/OutBuffer.d @ 68:ee3a9f34dc48

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