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.
ddmd.clone
Compiler implementation of the
D programming language.
Authors:
License:
Source: clone.d
- StorageClass
mergeFuncAttrs
(StorageClasss1
, FuncDeclarationf
); - Merge function attributes pure, nothrow, @safe, @nogc, and @disable
- FuncDeclaration
hasIdentityOpAssign
(AggregateDeclarationad
, Scope*sc
); - Check given aggregate actually has an identity opAssign or not.Parameters:
AggregateDeclaration ad
struct or class Scope* sc
current scope Returns:if found, returns FuncDeclaration of opAssign, otherwisenull
- FuncDeclaration
buildOpAssign
(StructDeclarationsd
, Scope*sc
); - Build opAssign for struct. ref S opAssign(S s) { ... }Note that s will be constructed onto the stack, and probably copy-constructed in caller site. If S has copy copy construction and/or destructor, the body will make bit-wise object swap: S _swap = this; // bit copy this = s; // bit copy _swap.dtor(); Instead of running the destructor on s, run it on tmp instead. Otherwise, the body will make member-wise assignments: Then, the body is: this.field1 = s.field1; this.field2 = s.field2; ...;
- bool
needOpEquals
(StructDeclarationsd
); - We need an opEquals for the struct if any fields has an opEquals. Generate one if a user-specified one does not exist.
- FuncDeclaration
hasIdentityOpEquals
(AggregateDeclarationad
, Scope*sc
); - Check given aggregate actually has an identity opEquals or not.
- FuncDeclaration
buildOpEquals
(StructDeclarationsd
, Scope*sc
); - Build opEquals for struct. const bool opEquals(const S s) { ... }By fixing https://issues.dlang.org/show_bug.cgi?id=3789 opEquals is changed to be never implicitly generated. Now, struct objects comparison s1 == s2 is translated to: s1.tupleof == s2.tupleof to calculate structural equality. See EqualExp.op_overload.
- FuncDeclaration
buildXopEquals
(StructDeclarationsd
, Scope*sc
); - Build __xopEquals for TypeInfo_Struct static bool __xopEquals(ref const S p, ref const S q) { return p == q; }This is called by TypeInfo.equals(p1, p2). If the struct does not support const objects comparison, it will throw "not implemented" Error in runtime.
- FuncDeclaration
buildXopCmp
(StructDeclarationsd
, Scope*sc
); - Build __xopCmp for TypeInfo_Struct static bool __xopCmp(ref const S p, ref const S q) { return p.opCmp(q); }This is called by TypeInfo.compare(p1, p2). If the struct does not support const objects comparison, it will throw "not implemented" Error in runtime.
- FuncDeclaration
buildXtoHash
(StructDeclarationsd
, Scope*sc
); - Build _xtoHash for non-bitwise hashing static hash_t xtoHash(ref const S p) nothrow @trusted;
- FuncDeclaration
buildPostBlit
(StructDeclarationsd
, Scope*sc
); - Create inclusive postblit for struct by aggregating all the postblits in postblits[] with the postblits for all the members. Note the close similarity with AggregateDeclaration::buildDtor(), and the ordering changes (runs forward instead of backwards).
- FuncDeclaration
buildDtor
(AggregateDeclarationad
, Scope*sc
); - Create inclusive destructor for struct/class by aggregating all the destructors in dtors[] with the destructors for all the members. Note the close similarity with StructDeclaration::buildPostBlit(), and the ordering changes (runs backward instead of forwards).
- FuncDeclaration
buildInv
(AggregateDeclarationad
, Scope*sc
); - Create inclusive invariant for struct/class by aggregating all the invariants in invs[]. void __invariant() const [pure nothrow @trusted] { invs[0](), invs[1](), ...; }
Copyright © 1999-2017 by the D Language Foundation | Page generated by
Ddoc on Sat Nov 4 04:02:07 2017