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.dcast
Semantic analysis for cast-expressions.
Authors: 
License: 
Source dcast.d
Documentation https://dlang.org/phobos/dmd_dcast.html
- ExpressionimplicitCastTo(Expressione, Scope*sc, Typet);
- Attempt to implicitly cast the expression into typet.This routine will changee. To check the matching level, use implicitConvTo.Parameters:Expression eExpression that is to be casted Scope* scCurrent scope Type tExpected resulting type Returns:The resulting casted expression (mutatinge), or ErrorExp if such an implicit conversion is not possible.
- MATCHimplicitConvTo(Expressione, Typet);
- Checks whether or not an expression can be implicitly converted to typet.Unlike implicitCastTo, this routine does not perform the actual cast, but only checks up to what MATCH level the conversion would be possible.Parameters:Expression eExpression that is to be casted Type tExpected resulting type Returns:The MATCH level betweene.type andt.
- MATCHimplicitConvTo(Typefrom, Typeto);
- Determine if 'from' can be implicitly converted to type 'to'.Returns:MATCH.nomatch, MATCH.convert, MATCH.constant, MATCH.exact
- MATCHcimplicitConvTo(Expressione, Typet);
- Same as implicitConvTo(); except follow C11 rules, which are quite a bit more permissive than D. C11 6.3 and 6.5.16.1Parameters:Expression eExpression that is to be casted Type tExpected resulting type Returns:The MATCH level betweene.type andt.
- TypetoStaticArrayType(SliceExpe);
- ExpressioncastTo(Expressione, Scope*sc, Typet, Typeatt= null);
- Do an explicit cast. Assume that the expressionedoes not have any indirections. (Parameter 'att' is used to stop 'alias this' recursion)
- ExpressioninferType(Expressione, Typet, intflag= 0);
- Set type inference target t Target type flag 1: don't put an error when inference fails
- ExpressionscaleFactor(BinExpbe, Scope*sc);
- Scale addition/subtraction to/from pointer.
- TypetypeMerge(Scope*sc, EXPop, ref Expressionpe1, ref Expressionpe2);
- Merge types of e1 and e2 into a common subsetParameters e1 and e2 will be rewritten in place as needed.Parameters:Scope* scCurrent scope EXP opOperator such as e1 ope2. In practice, either EXP.question or one of the binary operator.Expression pe1The LHS of the operation, will be rewritten Expression pe2The RHS of the operation, will be rewritten Returns:The resulting type in case of success, null in case of error
- ExpressiontypeCombine(BinExpbe, Scope*sc);
- Bring leaves to common type.Returns:null on success, ErrorExp if error occurs
- ExpressionintegralPromotions(Expressione, Scope*sc);
- Do integral promotions (convertchk). Don't convertto 
- voidfix16997(Scope*sc, UnaExpue);
- This provides a transition from the non-promoting behavior of unary + - ~ to the C-like integral promotion behavior.Parameters:Scope* sccontext UnaExp ueNegExp, UAddExp, or ComExp which is revised per rules 
- boolarrayTypeCompatibleWithoutCasting(Typet1, Typet2);
- See if both types are arrays that can be compared for equality without any casting. Return true if so. This is to enable comparing things like an immutable array with a mutable one.
- @trusted IntRangegetIntRange(Expressione);
- ExpressionspecialNoreturnCast(ExpressiontoBeCasted, Typeto);
- A helper function to "cast" from expressions of type noreturn to any other type - noreturn is implicitly convertible to any other type. However, the dmd backend does not like a naive cast from a noreturn expression (particularly an assert(0)) so this function generates:(assert(0), value) instead of cast(to)(assert(0)). value is currentlyto.init however it cannot be read so could be made simpler.Parameters:Expression toBeCastedExpression of type noreturn to cast Type toType to cast the expression to. Returns:A CommaExp, upon any failure ErrorExp will be returned.
Copyright © 1999-2025 by the D Language Foundation | Page generated by
Ddoc on Mon Mar 31 10:27:49 2025