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.compiler
Compiler implementation of the
D programming language.
Authors:
License:
Source compiler.d
Documentation https://dlang.org/phobos/dmd_compiler.html
- Module
entrypoint
; - DMD-generated module __entrypoint where the C main resides
- Module
rootHasMain
; - Module in which the D main is
- struct
Compiler
; - A data structure that describes a back-end compiler and implements compiler-specific actions.
- static void
genCmain
(Scope*sc
); - Generate C main() in response to seeing D main().This function will generate a module called __entrypoint, and set the globals entrypoint and rootHasMain. This used to be in druntime, but contained a reference to Dmain which didn't work when druntime was made into a dll and was linked to a program, such as a C++ program, that didn't have a Dmain.Parameters:
Scope* sc
Scope which triggered the generation of the C main, used to get the module where the D main is. - static Expression
paintAsType
(UnionExp*pue
, Expressione
, Typetype
); - Encode the given expression, which is assumed to be an rvalue literal as another type for use in CTFE. This corresponds roughly to the idiom *(Type *)&e.
- static void
loadModule
(Modulem
); - For the given module, perform any post parsing analysis. Certain compiler backends (ie: GDC) have special placeholder modules whose source are empty, but code gets injected immediately after loading.
- static bool
onImport
(Modulem
); - A callback function that is called once an imported module is parsed. If the callback returns true, then it tells the frontend that the driver intends on compiling the import.
Copyright © 1999-2022 by the D Language Foundation | Page generated by
Ddoc on (no date time)