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.
core.runtime
The
runtime module exposes information specific to the D runtime code.
License:
Authors:
Sean Kelly
Source core/runtime.d
- void*
rt_loadLibrary(const char*name); - C interface for Runtime.loadLibrary
- int
rt_unloadLibrary(void*ptr); - C interface for Runtime.unloadLibrary, returns 1/0 instead of bool
- int
rt_init(); - C interface for Runtime.initialize, returns 1/0 instead of bool
- int
rt_term(); - C interface for Runtime.terminate, returns 1/0 instead of bool
- struct
CArgs; - Stores the unprocessed arguments supplied when the process was started.
- int
argc; - The argument count.
- char**
argv; - The arguments as a C array of strings.
- struct
Runtime; - This struct encapsulates all functionality related to the underlying runtime module for the calling context.
- static bool
initialize(); - Initializes the runtime. This call is to be used in instances where the standard program initialization process is not executed. This is most often in shared libraries or in libraries linked to a C program. If the runtime was already successfully initialized this returns
true. Each call toinitializemust be paired by a call to terminate.Returns:trueif initialization succeeded orfalseif initialization failed. - static bool
terminate(); - Terminates the runtime. This call is to be used in instances where the standard program termination process will not be not executed. This is most often in shared libraries or in libraries linked to a C program. If the runtime was not successfully initialized the function returns
false.Returns:trueif termination succeeded orfalseif termination failed. - static @property string[]
args(); - Returns the arguments supplied when the process was started.Returns:The arguments supplied when this process was started.
- static @nogc @property CArgs
cArgs(); - Returns the unprocessed C arguments supplied when the process was started. Use this when you need to supply argc and argv to C libraries.Returns:A CArgs struct with the arguments supplied when this process was started.
Example
import core.runtime; // A C library function requiring char** arguments extern(C) void initLibFoo(int argc, char** argv); void main() { auto args = Runtime.cArgs; initLibFoo(args.argc, args.argv); }
- void*
loadLibrary()(in char[]name); - Locates a dynamic library with the supplied library
nameand dynamically loads it into the caller's address space. If the library contains a D runtime it will be integrated with the current runtime.Parameters:char[] nameThe nameof the dynamic library to load.Returns:A reference to the library ornullon error. - bool
unloadLibrary()(void*p); - Unloads the dynamic library referenced by
p. If this library contains a D runtime then any necessary finalization or cleanup of that runtime will be performed.Parameters:void* pA reference to the library to unload. - static @property void
traceHandler(TraceHandlerh); - Overrides the default trace mechanism with a user-supplied version. A trace represents the context from which an exception was thrown, and the trace handler will be called when this occurs. The pointer supplied to this routine indicates the base address from which tracing should occur. If the supplied pointer is
nullthen the trace routine should determine an appropriate calling context from which to begin the trace.Parameters:TraceHandler hThe new trace handler. Set to nullto use the default handler. - static @property TraceHandler
traceHandler(); - Gets the current trace handler.Returns:The current trace handler or
nullif none has been set. - static @property void
collectHandler(CollectHandlerh); - Overrides the default collect hander with a user-supplied version. This routine will be called for each resource object that is finalized in a non-deterministic manner--typically during a garbage collection cycle. If the supplied routine returns
truethen the object's dtor will called as normal, but if the routine returnsfalsethan the dtor will not be called. The default behavior is for all object dtors to be called.Parameters:CollectHandler hThe new collect handler. Set to nullto use the default handler. - static @property CollectHandler
collectHandler(); - Gets the current collect handler.Returns:The current collect handler or
nullif none has been set. - static @property void
moduleUnitTester(ModuleUnitTesterh); - Overrides the default module unit tester with a user-supplied version. This routine will be called once on program initialization. The return value of this routine indicates to the runtime whether the tests ran without error.Parameters:
ModuleUnitTester hThe new unit tester. Set to nullto use the default unit tester.Example
version (unittest) shared static this() { import core.runtime; Runtime.moduleUnitTester = &customModuleUnitTester; } bool customModuleUnitTester() { import std.stdio; writeln("Using customModuleUnitTester"); // Do the same thing as the default moduleUnitTester: size_t failed = 0; foreach (m; ModuleInfo) { if (m) { auto fp = m.unitTest; if (fp) { try { fp(); } catch (Throwable e) { writeln(e); failed++; } } } } return failed == 0; }
- static @property ModuleUnitTester
moduleUnitTester(); - Gets the current module unit tester.Returns:The current module unit tester handler or
nullif none has been set.
- void
dmd_coverSourcePath(stringpath); - Set source file
pathfor coverage reports.Parameters:string pathThe new pathname.Note This is a dmd specific setting.
- void
dmd_coverDestPath(stringpath); - Set output
pathfor coverage reports.Parameters:string pathThe new pathname.Note This is a dmd specific setting.
- void
dmd_coverSetMerge(boolflag); - Enable merging of coverage reports with existing data.Parameters:
bool flagenable/disable coverage merge mode Note This is a dmd specific setting.
- void
trace_setlogfilename(stringname); - Set the output file
namefor profile reports (-profile switch). An emptynamewill set the output to stdout.Parameters:string namefile nameNote This is a dmd specific setting.
- void
trace_setdeffilename(stringname); - Set the output file
namefor the optimized profile linker DEF file (-profile switch). An emptynamewill set the output to stdout.Parameters:string namefile nameNote This is a dmd specific setting.
- void
profilegc_setlogfilename(stringname); - Set the output file
namefor memory profile reports (-profile=gc switch). An emptynamewill set the output to stdout.Parameters:string namefile nameNote This is a dmd specific setting.
- bool
runModuleUnitTests(); - This routine is called by the runtime to run module unit tests on startup. The user-supplied unit tester will be called if one has been supplied, otherwise all unit tests will be run in sequence.Returns:
trueif execution should continue after testing is complete andfalseif not. Default behavior is to returntrue. - Throwable.TraceInfo
defaultTraceHandler(void*ptr= null);
Copyright © 1999-2017 by the D Language Foundation | Page generated by
Ddoc on (no date time)