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.safe
Checks whether member access or array casting is allowed in @
safe
code.
Specification Function Safety
Authors:
License:
Source safe.d
Documentation https://dlang.org/phobos/dmd_safe.html
- bool
checkUnsafeAccess
(Scope*sc
, Expressione
, boolreadonly
, boolprintmsg
); - Check for unsafe access in @safe code:
- read overlapped pointers
- write misaligned pointers
- write overlapped storage classes
Parameters:Scope* sc
scope Expression e
expression to check bool readonly
if access is read-only bool printmsg
print error message if true Returns:true if error - bool
isSafeCast
(Expressione
, Typetfrom
, Typetto
); - Determine if it is @safe to cast e from tfrom to tto.Parameters:
Expression e
expression to be cast Type tfrom
type of e Type tto
type to cast e to Returns:true if @safe - bool
checkUnsafeDotExp
(Scope*sc
, Expressione
, Identifierid
, intflag
); - Check for unsafe use of .ptr or .funcptrParameters:
Scope* sc
context Expression e
expression for error messages Identifier id
ptr or funcptr int flag
DotExpFlag Returns:true if error
Copyright © 1999-2025 by the D Language Foundation | Page generated by
Ddoc on Sat Jan 18 00:12:09 2025