Report a bug
If you spot a problem with this page, click here to create a Bugzilla issue.
Improve this page
Quickly fork, edit online, and submit a pull request for this page.
Requires a signed-in GitHub account. This works well for small changes.
If you'd like to make larger changes you may want to consider using
a local clone.
dmd.common.outbuffer
An expandable buffer in which you can write text or binary data.
Authors:
Walter Bright, https://www.digitalmars.com
License:
Source root/outbuffer.d
Documentation https://dlang.org/phobos/dmd_root_outbuffer.html
- struct
OutBuffer
; OutBuffer
is a write-only output stream of untyped data. It is backed up by a contiguous array or a memory-mapped file.- bool
doindent
; - Whether to indent
- bool
spaces
; - Whether to indent by 4 spaces or by tabs;
- int
level
; - Current indent level
- nothrow @safe this(size_t
initialSize
); - Construct given size.
- nothrow @trusted this(const(char)*
filename
); - Construct from filename. Will map the file into memory (or create it anew if necessary) and start writing at the beginning of it.Parameters:
const(char)* filename
zero-terminated name of file to map into memory - pure nothrow @trusted void
dtor
(); - Frees resources associated.
- nothrow @system ubyte*
buf
(); - For porting with ease from dmd.backend.outbuf.Outbuffer
- nothrow @system ubyte**
bufptr
(); - For porting with ease from dmd.backend.outbuf.Outbuffer
- pure nothrow @nogc @trusted char*
extractData
(); - Transfer ownership of the allocated data to the caller.Returns:pointer to the allocated data
- pure nothrow void
destroy
(); - Releases all resources associated with this and resets it as an empty memory buffer. The config variables notlinehead, doindent etc. are not changed.
- pure nothrow @trusted void
reserve
(size_tnbytes
); - Reserves
nbytes
bytes of additional memory (or file space) in advance. The resulting capacity is at least the previous length plusnbytes
.Parameters:size_t nbytes
the number of additional bytes to reserve - pure nothrow @nogc @safe void
setsize
(size_tsize
); - Shrink the size of the data to
size
.Parameters:size_t size
new size of data, must be <= .length - nothrow void
write16n
(intv
); - Writes a 16 bit value, no reserve check.
- nothrow void
write16
(intv
); - Writes a 16 bit value.
- nothrow @trusted void
write32
(intv
); - Writes a 32 bit int.
- nothrow @trusted void
write64
(longv
); - Writes a 64 bit int.
- pure nothrow @system void
writestring
(const(char)*s
);
pure nothrow @safe voidwritestring
(scope const(char)[]s
);
pure nothrow @safe voidwritestring
(scope strings
); - Buffer will NOT be zero-terminated
- pure nothrow @safe void
writestringln
(const(char)[]s
); - Buffer will NOT be zero-terminated, followed by newline
- pure nothrow @system void
writeStringz
(const(char)*s
);
pure nothrow @safe voidwriteStringz
(const(char)[]s
);
pure nothrow @safe voidwriteStringz
(strings
); - Write C string AND null byte
- pure nothrow @safe void
writenl
(); - strip trailing tabs or spaces, write newline
- nothrow @safe void
writeByten
(intb
); - Writes an 8 bit byte, no reserve check.
- pure nothrow @safe char[]
allocate
(size_tnbytes
); - Allocate space, but leave it uninitialized.Parameters:
size_t nbytes
amount to allocate Returns:slice of the allocated space to be filled in - pure nothrow @safe void
print
(ulongu
); - Convert
u
to a string and append it to the buffer.Parameters:ulong u
integral value to append - pure nothrow @system size_t
bracket
(size_ti
, const(char)*left
, size_tj
, const(char)*right
); - Insert left at i, and right at j. Return index just past right.
- pure nothrow @system size_t
insert
(size_toffset
, const(void)*p
, size_tnbytes
); - Returns:offset + nbytes
- const pure nothrow @nogc @safe const(char)[]
opSlice
(); - Returns:a non-owning const slice of the buffer contents
- pure nothrow char[]
extractSlice
(boolnullTerminate
= false); - Extract the data as a slice and take ownership of it.When true is passed as an argument, this function behaves like dmd.utils.toDString(thisbuffer.extractChars()).Parameters:
bool nullTerminate
When true, the data will be null terminated. This is useful to call C functions or store the result in Strings. Defaults to false. - pure nothrow @safe void
writeHexString
(scope const(ubyte)[]data
, boolupperCase
); - Write an array as a string of hexadecimal digitsParameters:
const(ubyte)[] data
bytes to write bool upperCase
whether to upper case hex digits A-F - nothrow @system bool
moveToFile
(const char*filename
); - Destructively saves the contents of this to
filename
. As an optimization, if the file already has identical contents with the buffer, no copying is done. This is because on SSD drives reading is often much faster than writing and because there's a high likelihood an identical file is written during the build process.Parameters:char* filename
the name of the file to receive the contents Returns:true iff the operation succeeded.
Copyright © 1999-2025 by the D Language Foundation | Page generated by
Ddoc on Sat Jan 18 00:11:50 2025