The runtime module exposes information specific to the D runtime code.
C interface for Runtime.loadLibrary
C interface for Runtime.unloadLibrary, returns 1/0 instead of bool
C interface for Runtime.initialize, returns 1/0 instead of bool
C interface for Runtime.terminate, returns 1/0 instead of bool
This type is returned by the module unit test handler to indicate testing results.
Number of modules which were tested
Number of modules passed the unittests
Should the main function be run or not? This is ignored if any tests failed.
Should we print a summary of the results?
Simple check for whether execution should continue after unit tests have been run. Works with legacy code that expected a bool return.
Simple return code that says unit tests pass, and main should be run
Simple return code that says unit tests failed.
Legacy module unit test handler
Module unit test handler
Stores the unprocessed arguments supplied when the process was started.
The argument count.
The arguments as a C array of strings.
This struct encapsulates all functionality related to the underlying runtime module for the calling context.
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 to initialize must be paired by a call to 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 the arguments supplied when the process was started.
Returns the unprocessed C arguments supplied when the process was started. Use this when you need to supply argc and argv to C libraries.
CArgs
struct with the arguments supplied when this process was started. 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); }
Locates a dynamic library with the supplied library name and dynamically loads it into the caller's address space. If the library contains a D runtime it will be integrated with the current runtime.
char[] name
| The name of the dynamic library to load. |
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.
void* p
| A reference to the library to unload. |
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 null then the trace routine should determine an appropriate calling context from which to begin the trace.
TraceHandler h
| The new trace handler. Set to null to use the default handler. |
Gets the current trace handler.
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 true then the object's dtor will called as normal, but if the routine returns false than the dtor will not be called. The default behavior is for all object dtors to be called.
CollectHandler h
| The new collect handler. Set to null to use the default handler. |
Gets the current collect handler.
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.
There are two options for handlers. The bool
version is deprecated but will be kept for legacy support. Returning true
from the handler is equivalent to returning UnitTestResult.pass
from the extended version. Returning false
from the handler is equivalent to returning UnitTestResult.fail
from the extended version.
See the documentation for UnitTestResult
to see how you should set up the return structure.
See the documentation for runModuleUnitTests
for how the default algorithm works, or read the example below.
ExtendedModuleUnitTester h
| The new unit tester. Set both to null to use the default unit tester. |
shared static this() { import core.runtime; Runtime.extendedModuleUnitTester = &customModuleUnitTester; } UnitTestResult customModuleUnitTester() { import std.stdio; writeln("Using customModuleUnitTester"); // Do the same thing as the default moduleUnitTester: UnitTestResult result; foreach (m; ModuleInfo) { if (m) { auto fp = m.unitTest; if (fp) { ++result.executed; try { fp(); ++result.passed; } catch (Throwable e) { writeln(e); } } } } if (result.executed != result.passed) { result.runMain = false; // don't run main result.summarize = true; // print failure } else { result.runMain = true; // all UT passed result.summarize = false; // be quiet about it. } return result; }
Gets the current legacy module unit tester.
This property should not be used, but is supported for legacy purposes.
Note that if the extended unit test handler is set, this handler will be ignored.
Gets the current module unit tester.
This handler overrides any legacy module unit tester set by the moduleUnitTester property.
Set source file path for coverage reports.
string path
| The new path name. |
Set output path for coverage reports.
string path
| The new path name. |
Enable merging of coverage reports with existing data.
bool flag
| enable/disable coverage merge mode |
Set the output file name for profile reports (-profile switch). An empty name will set the output to stdout.
string name
| file name |
Set the output file name for the optimized profile linker DEF file (-profile switch). An empty name will set the output to stdout.
string name
| file name |
Set the output file name for memory profile reports (-profile=gc switch). An empty name will set the output to stdout.
string name
| file name |
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 set, otherwise all unit tests will be run in sequence.
If the extended unittest handler is registered, this function returns the result from that handler directly.
If a legacy boolean returning custom handler is used, false
maps to UnitTestResult.fail
, and true
maps to UnitTestResult.pass
. This was the original behavior of the unit testing system.
If no unittest custom handlers are registered, the following algorithm is executed (the behavior can be affected by the --DRT-testmode
switch below): 1. Run all unit tests, tracking tests executed and passes. For each that fails, print the stack trace, and continue. 2. If there are no failures, set the summarize flag to false, and the runMain flag to true. 3. If there are failures, set the summarize flag to true, and the runMain flag to false.
See the documentation for UnitTestResult
for details on how the runtime treats the return value from this function.
If the switch --DRT-testmode
is passed to the executable, it can have one of 3 values: 1. "run-main": even if unit tests are run (and all pass), main is still run. This is currently the default. 2. "test-or-main": any unit tests present will cause the program to summarize the results and exit regardless of the result. This will be the default in 2.080. 3. "test-only", the runtime will always summarize and never run main, even if no tests are present.
This command-line parameter does not affect custom unit test handlers.
UnitTestResult
struct indicating the result of running unit tests.
© 1999–2018 The D Language Foundation
Licensed under the Boost License 1.0.
https://dlang.org/phobos/core_runtime.html