英語版
このページの英語版を見る

変更ログ 2.063

前バージョン: - 次のバージョン:

Download D 2.063
2013年5月28日リリース


D 2.063における全てのバグ修正と機能強化のリスト。

言語の変更

  1. 初期化子を持つconstフィールドと不変のフィールドが警告されるようになった:

    最終的には非推奨となり、エラーが発生する。そのようなフィールドは をenumかstaticに変更すべきである。

    将来のリリースでは、このようなフィールドの新しい動作が有効になる予定だ:

    静的でない集約のフィールドは常にアドレス可能である。 つまり、それらはオブジェクト内のスペースを占有することになる:

    struct S
    {
        // 2.062では暗黙的にstaticであったが、現在は警告している。将来のリリースではstaticでなくなる。
        immutable int[] arr = [1, 2];
    
        // 同上
        const int[] arr2 = [1, 2];
    }
    

    これは、このような宣言に参照なしでアクセスしたコードはコンパイルできなくなることを意味する。this にアクセスするコードはコンパイルできなくなる。さらに、このようなフィールドを持つ に依存していたコードも修正しなければならない:

    struct S
    {
        immutable int[] arr = [1, 2];
    }
    
    void main()
    {
        auto x = S.arr;  // 将来のリリースではエラーとなり、'arr'は'this'参照を必要とする。
    
        // 2.062と2.063では、Sはサイズ1である。将来のリリースでは、これは変更され、以下のstatic assertが通るようになる。
        static assert(S.sizeof == size_t.sizeof + size_t.sizeof);  // ptr + length for the array
    }
    

    フィールドを再び静的にするには、単にstaticキーワードを使えばよい。あるいは フィールドをenum にしてマニフェスト定数にする:

    struct S
    {
        static immutable int[] arr = [1, 2];
        enum arr2 = [1, 2];
    }
    

    ただし、配列であるマニフェスト定数は、各使用時に割り当てられることに注意されたい、 の代わりにstatic を使用することを好むかもしれない。

    根拠: マニフェスト定数は配列である:

    const/不変のフィールドかどうか、イニシャライザを持つかどうかに基づいて、フィールドを暗黙的に静的にすることは混乱を招く。static キーワードを使用すると、どのフィールドも明示的に静的にすることができる。

  2. コンストラクタ修飾子は、オブジェクトを構築するときに考慮される:

    修飾されたコンストラクタは、const/immutable/shared 集約オブジェクトがインスタンス化されるときに呼び出される。 がインスタンス化されるときに、修飾されたコンストラクタが呼び出されるようになった:

    import std.stdio;
    
    class C
    {
        this()           { writeln("1"); }
        this() const     { writeln("2"); }
        this() immutable { writeln("3"); }
        this() shared    { writeln("4"); }
    }
    
    void main()
    {
        auto a = new C;           // "1"を書き込む
        auto b = new const C;     // "2"を書き込む
        auto c = new immutable C; // "3"を書き込む
        auto d = new shared C;    // "4"を書き込む
    }
    

    この結果、immutable またはshared コンストラクタ "しか持たない集合体は、変更可能なオブジェクトのインスタンス化に使用できなくなる:

    class C
    {
        this() immutable { }
        this() shared { }
    }
    
    void main()
    {
        auto c1 = new C;           // 不許可
        auto c2 = new immutable C; // OK
        auto c3 = new shared C;    // OK
    }
    

    一方、shared またはimmutable コンストラクタを持たない集合体は、それぞれ または オブジェクトを構築するために使用できなくなる。 を持たない集合体は、それぞれshared またはimmutable オブジェクトを構築するために使用できなくなる:

    class C
    {
        this() { }
    }
    
    void main()
    {
        auto c1 = new C;           // OK
        auto c2 = new immutable C; // 不許可
        auto c3 = new shared C;    // 不許可
    }
    

    しかし、集合体がpure コンストラクタを持つ場合、任意の型コンストラクタでオブジェクトを構築するために使用できる:

    class C
    {
        this() pure { }
    }
    
    void main()
    {
        auto c1 = new C;  // OK
        auto c2 = new immutable C;  // OK
        auto c3 = new shared C;  // OK
    }
    
  3. ビット比較以外の比較を必要とする構造体メンバが適切に比較されるようになった。

    以前のリリースでは、配列のような一部の構造体メンバは比較操作でビット単位で比較されていた。 これが構造体比較に変更された:

    struct S
    {
        char[] data;
    }
    
    void main ()
    {
        auto s1 = S("foo".dup);
        auto s2 = S("foo".dup);
    
        assert(s1.data !is s2.data);  // どちらもユニークなデータである
    
        assert(s1 == s2);   // 2.063では合格
        assert(s1.data == s2.data);  // 上記と同等
    }
    

    opEquals 関数が存在しない場合、コンパイラーは式を書き換える。 s1 == s2s1.tupleof == s2.tupleof に書き換える。.tupleof 式の比較は、2.063リリースのDに追加された機能である。 式の比較も2.063リリースのDに追加された機能である。

  4. 配列のコピー操作では、常にスライス構文を使用する必要がある:

    配列コピー操作の右辺では、スライス構文を使用する必要がある:

    void main()
    {
        int[][2] x;
        int[] y;
        int[] z;
    
        x[] = z;    // z (ポインタ + 長さ)をxに2回コピーする
        y[] = z;    // zの各要素をyにコピーする(コンパイラは警告を出す)
    }
    

    もしユーザーがそのようなコードを書くつもりなら、ソース配列とターゲット配列の両方にスライス構文を使わなければならない:

    void main()
    {
        int[][2] x;
        int[] y;
        int[] z;
    
        y[] = z[];  // zの各要素をyにコピーする(警告は出ない)
    }
    

    根拠:このような理由で、このような決断を下したのである:

    理由:コンパイラは、コピー操作が恣意的に高価であることを警告する。

  5. 型がtypeof 式で引数として機能しなくなった:

    型をその型の値として関数に渡すことができなくなった:

    T[] foo(T)(T t)
    {
        return null;
    }
    
    void main()
    {
        alias int Int;
    
        // 以前は動作していた(エイリアスを使った場合のみ)、現在はコンパイラーエラー
        alias typeof(foo(Int)) IntArray;
    }
    

    ユーザーが特定の型の引数を渡したい場合は、.init " プロパティを使用することができる:

    T[] foo(T)(T t)
    {
        return null;
    }
    
    void main()
    {
        alias typeof(foo(int.init)) IntArray;  // OK
    }
    

    根拠:このような理由で、このような決断を下したのである:

    理由:特殊な文脈で型を "式"として扱うことは混乱を招くだけである。 その代わりに、.init " プロパティをそのような目的に使うことができる。

  6. foreach範囲のインデックス変数は、もはや暗黙の参照ではない:

    foreach範囲のインデックス変数は、デフォルトで値型になった:

    void main()
    {
        size_t count;
        foreach (n; 0 .. 10)
        {
            ++n;
            ++count;
        }
        assert(count == 10);  // 合格
    }
    

    もしユーザーがインデックス変数を変更したい場合は、ref キーワードを使わなければならない:

    void main()
    {
        size_t count;
        foreach (ref n; 0 .. 10)
        {
            ++n;
            ++count;
        }
        assert(count == 5);
    }
    

    根拠:このような理由で、このような決断を下したのである:

    インデックス変数を暗黙的にref にすると、追跡が困難なバグが発生する可能性がある。

  7. 連想配列のエントリは、代入前にデフォルトで初期化されなくなった:

    連想配列のエントリーは、代入される前にデフォルトで初期化されていた:

    void main()
    {
        int[int] aa;
        aa[1] = aa[1] + 1;   // 2.062ではエラーはスローされなかった
        assert(aa[1] == 1);  // 2.062では動作していた
    }
    

    2.063では、存在しないエントリーにアクセスするとRangeErrorがスローされるようになった:

    void main()
    {
        int[int] aa;
        aa[1] = aa[1] + 1;   // 2.063ではRangeErrorがスローされる
    }
    

    根拠:このような理由で、このような決断を下したのである:

    代入時のデフォルト初期化はバグの原因になる。

  8. const属性は、オーバーライドされたメソッドでは継承されなくなった。

    メソッドのオーバーライドで、ベース・メソッドの const 属性が継承されなくなった:

    class A
    {
        void foo() const { }
    }
    
    class B : A
    {
        // 2.062では動作していた、現在はエラー
        override void foo() { }  // 'const'がないことに注意
    }
    

    ユーザーがconstメソッドをオーバーライドしたい場合は、オーバーライドするメソッドをconstとしてマークしなければならない。 メソッドをconstとしてマークしなければならない:

    class A
    {
        void foo() const { }
    }
    
    class B : A
    {
        override void foo() const { }  // OK
    }
    

    この機能により、メソッドの定数に基づいて新しいオーバーロードを導入することができる:

    class A
    {
        void foo() const { }
    }
    
    class B : A
    {
        // 新しいオーバーロードを導入する(オーバーライドではない!)
        void foo() { }
    
        // 上記のオーバーロードが導入された場合、ユーザーは以下のいずれかを行わなければならない:
        // a: 関数のハイジャックを防ぐため、constオーバーロードを再度導入する
        alias super.foo foo;  // これをしないとコンパイラーエラーになる
    
        // もしくはb: 適切に型付けされたオーバーライドを提供する:
        override void foo() const { }
    }
    
  9. typeof(null) は暗黙的にT[]に変換されなくなった:

    以前は次のようなコードが許されていた:

    void f(int[] function() del)
    {
        assert(!del());  // 失敗
    }
    
    typeof(null) g() { return null; }
    
    void main()
    {
        f(&g);
        f(() => null);
    }
    

    しかし、暗黙の変換は間違ったコードを生成してしまう。 これを回避するには、return型が適切に型付けされていることを確認する、 あるいは、ラムダ式の戻り値式で(T[]).init :

    void f(int[] function() del)
    {
        assert(!del());  // 合格
    }
    
    int[] g() { return null; }  // 戻り値の型を修正した
    
    void main()
    {
        f(&g);  // OK
        f(() => (int[]).init);  // OK
    }
    
  10. テンプレート化された "This Parameter"はメンバー関数の修飾子を変更する:

    テンプレートThisパラメータを使うことで、this のメンバ関数の修飾子を推測できるようになった。 関数に推論できるようになった:

    struct S
    {
        void foo(this T)()
        {
        }
    }
    
    void main()
    {
         immutable S s;
         s.foo();  // S.fooを不変にする
    }
    
  11. アレイのスライスがr値になった:

    配列スライスはもはやl値ではない。これは、スライスからアドレスを取ることができなくなったことを意味する。 スライスは関数にrefで渡すことはできない:

    void foo(ref int[] arr) { arr = new int[10]; }
    
    void main()
    {
        int[] arr;
        foo(arr);  // OK
        assert(arr.length == 10);
    
        foo(arr[]);  // 2.063では不許可、スライスはr値である
        auto ptr = &arr[1..2];  // 2.063では不許可、r値のアドレスを取ることができない
    }
    

    これを回避するには、スライスの再割り当てやサイズ変更が必要なく、その内容を読み取ったり変更したりするだけでよい場合は、関数にr値を取らせるようにすればよい。 を取るようにすればよい。 そうでない場合は、l値とr値の両方を受け取る関数にすればよい。 の引数をauto ref :

    void take(int[] arr) { }
    void takeRef(ref int[] arr) { }
    void takeAutoRef(T)(auto ref T[] arr) { }
    
    void main()
    {
        int[] arr = [1, 2, 3, 4];
        take(arr);          // OK
        takeRef(arr);       // OK
        takeAutoRef(arr);   // OK
    
        int[] arr2 = arr[1 .. 2];
        take(arr2);         // OK、arr2は変数である
        takeRef(arr2);      // 同上
        takeAutoRef(arr2);  // 同上
    
        take(arr[1 .. 2]);         // OK
        takeRef(arr[1 .. 2]);      // エラー、r値を参照渡しできない
        takeAutoRef(arr[1 .. 2]);  // OK
    }
    

    根拠:このような理由で、このような決断を下したのである:

    理由:スライスを参照渡しすることは、呼び出し先でそのようなスライスを再割り当てまたはサイズ変更する際に観測可能な効果がなかった。 従って、そのようなスライスはデフォルトでr値にすべきである。 例えば、以下のコードは以前は許可されていたが、現在はコンパイル時のエラーとなる:

    void reAssign(ref int[] arr) { arr = new int[2]; }
    void reSize(ref int[] arr)   { arr.length = 10; }
    
    void main()
    {
        int[] arr = [1, 2, 3, 4];
    
        reAssign(arr[0 .. 4]);  // 再割り当ては、呼び出し元で観測可能な効果をもたらさない
        assert(arr == [1, 2, 3, 4]);
    
        reSize(arr[0 .. 4]);    // サイズ変更は呼び出し元で観測可能な効果を持たない
        assert(arr.length == 4);
    }
    
  12. this 、参照なしで非静的フィールドにアクセスすることは、特定のコンテキストでのみ許される:

    静的でないフィールドへのアクセスは、以前は多くのコンテキストで許可されていたが、現在はいくつかのコンテキストに限定されている:

    - offsetof init その他の組み込みプロパティは許可されている:

    struct S { int field; }
    
    void main()
    {
        auto a = S.field.offsetof;  // OK、statically known
        auto c = S.field.max;       // 同上
        auto d = S.field;           // 不許可、`this`参照はない
    }
    

    - 非静的フィールドの静的メソッドを呼び出す場合:

    struct Foo
    {
        static struct Bar
        {
            static int get() { return 0; }
        }
    
        Bar bar;
    }
    
    void main()
    {
        static assert(Foo.bar.get() == 0);  // OK、`typeof(Foo.bar).get()`と等価である
    }
    

    - を使用して暗黙的に静的フィールドにアクセスする場合は、以下のようになる。 alias this式を使って暗黙的に静的フィールドにアクセスする:

    struct Foo
    {
        static struct Bar
        {
            static int get() { return 0; }
        }
    
        Bar bar;
        alias bar this;
    }
    
    void main()
    {
        static assert(Foo.get() == 0);  // OK、'typeof(Foo.bar).get()'と等価である
    }
    
  13. 配列が暗黙的にポインタに変換されなくなった:

    配列の暗黙のポインタ変換は非推奨の機能だった:

    void foo(int* p) { }
    
    void main()
    {
        int[] arr = [1, 2];
        foo(arr);   // コンパイル時に-dスイッチが使用されていればOK
    }
    

    この機能は現在完全に削除されている。回避策としては .ptr プロパティを使うか、明示的に最初の要素へのポインタを渡すことである:

    void foo(int* p) { }
    
    void main()
    {
        int[] arr = [1, 2];
        foo(arr);      // コンパイルエラー
        foo(arr.ptr);  // OK
        foo(&arr[0]);  // OK
    }
    

言語の強化

  1. 一意なオブジェクトを返す式は、暗黙的にimmutableにキャストできる:

    オブジェクトや配列に対するnew 、配列に対するdup のような式が、一意であると推測できるようになった。 これにより、コンパイラーはこのような式を暗黙のうちにimmutableに変換することができる:

    class C { }
    
    void main()
    {
        immutable int[] arr1 = new int[](3);   // OK
        immutable int[] arr2 = [1, 2, 3].dup;  // 2.063ではOK
        immutable C[] arr3 = [new C, new C].dup;  // 2.063ではOK
    }
    
  2. voidの静的配列をユーザーが初期化できるようになった。

    void の静的配列はユーザー・コードで初期化できなかった:

    void main()
    {
        void[2] varr1;  // 2.062ではエラー
        void[2] varr2 = (void[2]).init;  // 2.062ではエラー
        void[2] varr3 = void;  // 2.062ではOK
    }
    

    2.063では、明示的なイニシャライザーが使用できる:

    void main()
    {
        void[2] varr1;  // 2.063ではまだエラー
        void[2] varr2 = (void[2]).init;  // 2.063ではOK
        void[2] varr3 = void;  // 2.063ではOK
    }
    

    .init プロパティは、配列を実質的にゼロ初期化する。

    根拠:配列はゼロ初期化される:

    理由:静的ボイド配列に特化することなく、一般的なコードで.init 。 を使用できるようにするためである。

  3. 集約が複数の不変量を含むことができるようになった:

    集約型が複数の不変量を持つ場合、不変量の本体は単一の不変量関数にマージされ、実行される。 にマージされ、順番に実行される。1つのインバリアント内のコードは、コードやインバリアントを参照することはできない。 のコードは、別の不変量のコードやデータを参照できないことに注意すること:

    struct S
    {
        int x;
    
        void foo() { }
    
        invariant()
        {
            int local;
            assert(x != 0);
        }
    
        invariant()
        {
            // local = 1;  // 変異体はもう一方の変異体にアクセスできない
            assert(x % 2 == 0);
        }
    }
    
    void main()
    {
        S s = S(2);
        s.foo();  // パブリック関数を呼び出すと、両方の変数が順番にトリガーされる
    }
    
  4. テンプレート化された集合体のメソッドは、属性を推測できるようになった:

    いくつかの属性を持つ関数がテンプレート化された集約をインスタンス化する場合、そのメンバ関数はそれらの属性を推論する、 ある属性を持つ関数がテンプレート化された集約をインスタンス化する場合、そのメンバ関数はそれらの属性を推論する:

    struct S(T)
    {
        T square(T x)
        {
            return x * x;
        }
    }
    
    void main() pure
    {
        S!int s;  // S!int.squareが純粋になり、main()から呼び出せるようになる
        assert(s.square(2) == 4);  // OK
    }
    
  5. is expression はもはや識別子を必要としない:

    場合によっては is式 が識別子を必要とする場合があった:

    void main()
    {
        alias AA = string[int];
    
        static if (is(AA _ == V[K], V, K))
        {
            pragma(msg, _);  // string[int]を表示
            pragma(msg, K);  // intを表示
            pragma(msg, V);  // stringを表示
        }
    }
    

    識別子はもはや必要ないので、上記は次のように書き換えることができる:

    void main()
    {
        alias AA = string[int];
    
        static if (is(AA == V[K], V, K))
        {
            pragma(msg, AA); // string[int]を表示
            pragma(msg, K);  // intを表示
            pragma(msg, V);  // stringを表示
        }
    }
    
  6. サイズが既知の動的配列は、文脈によっては暗黙的に静的配列にキャストできる:

    あるコンテキストでは、コンパイラーは動的配列や配列のスライスのサイズを知っている。 このような場合、コンパイラは同じサイズの静的配列への暗黙の変換を許可する:

    void foo(int[4] x) { }
    
    void main()
    {
        int[] arr = [1, 2, 3, 4, 5, 6, 7, 8];
        foo(arr[0 .. 4]);  // OK
    }
    

    別の例では、文字列が静的配列への参照に変換される:

    string str = "aaaabbbbccccdddd";
    
    void foo(ref const(char)[16] buf)
    {
        assert(buf.ptr is str.ptr);
    }
    
    void main()
    {
        foo(str[0..16]);  // OK
    }
    

    制限事項がある:

    - この機能は、スライスのサイズを仮定するのが妥当な複雑な式ではまだ使えない。 スライスの大きさを仮定するのが妥当であるような複雑な式ではまだ機能しない:

    void foo(int[4] x) { }
    
    void main()
    {
        int[] arr = [1, 2, 3, 4, 5, 6, 7, 8];
        foreach (i; 0 .. 4)
        {
            foo(arr[i .. i + 4]);  // 未サポート
        }
    }
    
  7. タプルをvoid初期化できるようになった:

    タプル変数をvoid初期化できるようになった:

    template Tuple(T...)
    {
        alias T Tuple;
    }
    
    void main()
    {
        Tuple!(int, int) tup1 = void;  // OK
    }
    

    このような初期化では、タプルの値は未定義である。

  8. テンプレート制約は、継承リストの後に置くことができる:

    以前は、テンプレート制約は継承リストの前にしか置けなかった。 テンプレート制約を継承リストの後に置くことができるようになった:

    class Foo(T1, T2)
        if (is(T1 == int) && is(T2 == string)) : Base
    {
    }
    

    この制限は解除され、書けるようになった:

    class Foo(T1, T2) : Base
        if (is(T1 == int) && is(T2 == string))
    {
    }
    
  9. タプルが等しいかどうかを比較できるようになった:

    例:

    struct Tuple(T...) { T field; alias field this; }
    
    void main()
    {
        auto tup1 = Tuple!(int, int)(1, 2);
        auto tup2 = Tuple!(int, int)(1, 2);
        auto tup3 = Tuple!(int, int)(1, 3);
    
        assert(tup1 == tup2);  // 2.063以降で動作
        assert(tup1 != tup3);  // 2.063以降で動作
    }
    

    これは、std.traitのParameterStorageClassTuple インスタンスを比較できるようになったことも意味する:

    import std.traits;
    
    void func1(ref int x, ref int y) { }
    void func2(ref float x, ref float y) { }
    
    void main()
    {
        alias Storages = ParameterStorageClassTuple;
        assert(Storages!func1 == Storages!func2);
    }
    

    それに加えて、組み込みの.tupleof 式を使えば、集約のフィールドを簡単に比較することができる:

    struct S
    {
        char[] a, b;
    
        // この型の別のインスタンスに対する等値テストを実装する。
        bool opEquals(S rhs) { return this.tupleof == rhs.tupleof; }
    }
    
    void main()
    {
        S s1 = S("a".dup, "b".dup);
        S s2 = S("a".dup, "b".dup);
        assert(s1 == s2);
    }
    

    これにより、別の型のインスタンスに対する構造的な等質性テストを実装することもできる。 を実装することもできる:

    struct S1
    {
        char[] a, b;
    
        // 他の型Tに対する構造的等値テストを実装する
        bool opEquals(T)(T rhs) { return this.tupleof == rhs.tupleof; }
    }
    
    struct S2
    {
        string x, y;
    }
    
    void main()
    {
        auto s1 = S1("123".dup, "456".dup);
        auto s2 = S2("123", "456");
        assert(s1 == s2);
    }
    

    タプルはスライスできるので、この機能を使ってタプルのサブセットを比較することができる:

    struct S
    {
        int a, b, c, d, e;
    
        bool opEquals(S rhs)
        {
            // a, b, d, eを比較する
            return this.tupleof[0..2] == rhs.tupleof[0..2] &&
                   this.tupleof[3..5] == rhs.tupleof[3..5];
        }
    }
    
    void main()
    {
        S s1 = S(1, 2, 0, 3, 4);
        S s2 = S(1, 2, 1, 3, 4);
        assert(s1 == s2);
    }
    
  10. 初期化子を持つフィールドは、constコンストラクタで再初期化できるようになった:

    constコンストラクタでフィールドを初期化できるようになった。 コンストラクタでフィールドを初期化できるようになった:

    struct S
    {
        bool field = true;
    
        this(int v) const
        {
            field = false;  // OK
        }
    }
    
  11. コンテキスト・ポインターを持つ集約と関数の発見のために、isNested 特性を追加した:

    新しいisNested形質によって、以下のことが可能になる。 新しいisNested traitは、集約や関数がコンテキスト・ポインタを含んでいるかどうかを発見することができる:

    void main()
    {
        int x;
    
        struct S1 { void f() { x++; } }
        static struct S2 { }
    
        void f1() { x++; }
        static void f2() { }
    
        static assert(__traits(isNested, S1));
        static assert(__traits(isNested, f1));
        static assert(!__traits(isNested, S2));
        static assert(!__traits(isNested, f2));
    }
    
  12. テンプレート化された関数は、関数の中に入れ子にすることができる:
  13. void test()
    {
        template ArrayOf(T) { alias ArrayOf = T[]; }
        static assert(is(ArrayOf!int == int[]));
    }
    

    関数の内部でtemplateを許可することで、より良いカプセル化が可能になり、モジュール・スコープのシンボル名の汚染を避けることができる。 モジュール・スコープのシンボル名の汚染を避けることができる。

  14. UFCSがスコープ付きローカル・インポートで動作するようになった:

    ローカル・インポートによって利用可能になった関数は、Uniform Function Call Syntaxを使用する際にピックアップされるようになった:

    module foo;
    string concat(string arg1, string arg2) { return arg1 ~ arg2; }
    
    module test;
    void main()
    {
        import foo;
        assert("foo".concat("bar") == "foobar");  // UFCSが動作するようになった
    }
    

    この機能は、アグリゲート内のインポートでも機能する。ローカル・インポートは、モジュール・スコープのインポートよりも優先順位が高いことに注意されたい。 よりも優先される。

  15. __FUNCTION____PRETTY_FUNCTION____MODULE__ を追加した:

    新しい キーワードが追加された。 追加された。__FILE____LINE__ とともに、コードのデバッグに役立つ完全な機能セットを形成している。 を形成している:

    module test;
    import std.stdio;
    
    void test(string file = __FILE__, size_t line = __LINE__, string mod = __MODULE__,
              string func = __FUNCTION__, string pretty = __PRETTY_FUNCTION__)
    {
        writefln("file: '%s', line: '%s', module: '%s',\nfunction: '%s', pretty function: '%s'",
                 file, line, mod, func, pretty);
    }
    
    int main(string[] args)
    {
        test();
        return 0;
    }
    

    上記のように出力される:

    file: 'test.d', line: '13', module: 'test',
    function: 'test.main', pretty function: 'int test.main(string[] args)'
    
  16. DDoc: 非推奨宣言はDEPRECATED マクロでラップされるようになった:
    module test;
    
    /// sum関数
    deprecated int sum(int x, int y) { return x + y; }
    

    デフォルトでは、マクロは引数に展開される。これは、例えばユーザーによってオーバーライドすることができる:

    macros.ddoc:

    DEPRECATED=<del>$0</del>
    

    上記のddocファイルは、ドキュメンテーションを作成するときに使用できる:

    $ dmd -D -o- test.d macros.ddoc
    
  17. 検証可能なコード例生成のためのドキュメント化されたunittest機能を追加した:

    シンボル宣言の後に続くドキュメント化されたunittestは、DDOCドキュメントを生成する際に、シンボルの例セクションを生成するために使用されるようになった。 の例セクションを生成するために使われるようになった。例:」と表示される:

    /// sum関数
    int sum(int x, int y) { return x + y; }
    
    ///
    unittest
    {
        assert(sum(2, 2) == 4);
    }
    

    unittestの本体はsum関数のドキュメントの一部となる。これにより 関数の実装者は、常にその例を最新に保つことができる。

    詳しくは ドキュメントページ を参照のこと。

コンパイラの機能強化

  1. 空のmain関数を追加する-mainスイッチを追加した:

    -main ・スイッチは、主にライブラリーのunittest時に便利である:

    module test;
    
    int sum(int a, int b) { return a + b; }
    unittest
    {
        assert(sum(2, 2) == 4);
    }
    

    上記のライブラリでは、unittestsを実行するためにmain() 関数が必要になる、 -main :

    $ dmd -unittest -main -run test.d
    
  2. 最小カバレッジ・テスト用に-cov=percentageスイッチを追加した。

    -cov スイッチにオプションのパーセンテージ設定が追加された。 これは、カバレッジが指定された要件を満たさない場合に実行ファイルをエラーにするものである:

    module test;
    
    void test1() { int x = 5; }
    void test2() { int x = 5; }
    void test3() { int x = 5; }
    
    void main()
    {
        test1();
        test2();
    }
    

    カバレッジテストの例:

    $ dmd -cov=90 test.d
    $ test
    Error: test.d is 80% covered, less than required 90%
    
  3. コンパイラのプラグマでシンボルのマングリングを上書きする機能を追加した:

    新しいpragma(mangle, ...) ディレクティブにより、任意のシンボルにカスタム・マングリングを設定できる:

    pragma(mangle, "module") extern(C) void module_();
    

    上記は、通常 "module"という名前のC関数にリンクすることを可能にする。 module "は予約されたDキーワードなので、通常は直接リンクすることはできない。

phobosの変更点

  1. std.typecons.scopedの実装が変更され、いくつかのユーザーコードが壊れる可能性がある:

    scoped 呼び出しの型を取得するためにstd.traits.ReturnType トレイトを使っていたユーザーコードは、代わりに 演算子を使うように変更しなければならない。 代わりにtypeof 演算子を使うように変更しなければならない:

    class A
    {
        this() {}
        this(int) {}
    }
    
    class B
    {
        // ReturnType!(scoped!A) a;  // 2.063では許可されていない
        typeof(scoped!A()) a;        // 書き直され、2.063ではコンパイルされる
    
        this()
        {
            a = scoped!A(1);  // 2.062ではコンパイルされなかったが、2.063で使用された構文で動作する。
        }
    }
    

    この変更の理由は、クラスが複数のコンストラクタを持つ場合、ReturnType "トレイト"が間違った型を取得してしまい、フィールドの初期化に失敗してしまうからである。 が複数のコンストラクタを持つ場合、間違った型を取得してしまい、フィールドの初期化に失敗してしまうからである。

    新しい実装のもう1つの利点は、scoped 、ユーザビリティのためにエイリアスを作成できるようになったことである:

    class A
    {
        this(int) { }
    }
    
    void main()
    {
        alias scoped!A scopeA;
        auto a = scopeA(1);
    }
    

フォボスの機能強化

  1. std.process はゼロから再設計され、新しいAPIと機能を導入した:

    新しい std.process新しいモジュールでは、カスタムパイプリダイレクトでプロセスを呼び出す機能が導入されている、 プロセスの終了を待つ機能、プロセスを kill する機能などが導入されている。機能の全リストは は std.processドキュメントにある。

  2. std.getopt ブール値を false に設定できるようになった:

    例:":

    void main(string[] args)
    {
        bool flag = true;
        getopt(args, &flag);
    }
    

    --flag=false 経由で呼び出されると、flagfalse に設定する。

  3. std.concurrency に ownerTid プロパティを追加した:

    子スレッドからオーナー・スレッドにメッセージを送るのが簡単になった。 オーナー・スレッドにメッセージを送るのが簡単になった。ownerTid "プロパティを使って、オーナー・スレッドのTid識別子を取得するだけだ。 スレッドのTid識別子を取得する:

    void fun()
    {
        string res = receiveOnly!string();
        assert(res == "Main calling");
    
        ownerTid.send("Child responding");  // new
    }
    
    void main()
    {
        auto child = spawn(&fun);
        child.send("Main calling");
    
        string res = receiveOnly!string();
        assert(res == "Child responding");
    }
    

    オーナースレッドが終了した場合、子スレッドからownerTidにアクセスすると、。 にアクセスすると、TidMissingException がスローされる。


D 2.063のすべてのバグ修正と機能強化のリスト:

DMDコンパイラのリグレッション

  1. Bugzilla 9130: コンパイル時に構築された構造体のコードジェネが正しくない。
  2. Bugzilla 9258: opAssignが基底クラスで "identity assignment operator overload "エラーを引き起こす。
  3. Bugzilla 9526: unittestsでプロジェクトをコンパイルする際のICE
  4. Bugzilla 9536: staticメンバをconstメンバから呼び出すとIFTIに失敗する
  5. Bugzilla 9538: リグレッション (2.062):静的配列の .ptr で typeid が使えない。
  6. Bugzilla 9539: 配列からポインタへの暗黙の変換が間違っている。
  7. Bugzilla 9545: [REG 2.063a] メンバーテンプレートのインスタンス化でICEが発生する
  8. Bugzilla 9552: DMDが"__traits(getOverloads)"からメンバーデリゲートを取得する際にクラッシュした。
  9. Bugzilla 9566: リグレッション (2.062):struct .init が単一の要素から初期化された静的配列を含む場合に使用できない。
  10. Bugzilla 9568: [64bit] scope(exit)のコードが間違っている。
  11. Bugzilla 9633: オブジェクトのメソッド呼び出しが実際にはコンパイルされない場合でも、コンパイルトレイトが誤って真を返す
  12. Bugzilla 9650: traits(コンパイル) + ミックスイン(ミックスイン)
  13. Bugzilla 9663: [REG2.063a] issue 7444の変更によりICEが発生した。
  14. Bugzilla 9672: 循環インポート内の"ミックスイン"が未定義のプロパティを引き起こす。
  15. Bugzilla 9689: std.typecons.Proxyが"@disable this(this)"で壊れてしまう。
  16. Bugzilla 9694: opEqualsが変更可能なメンバ構造体は奇妙なエラーメッセージを報告する。
  17. Bugzilla 9739: リグレッション(1.077 git-head):DMDがデフォルトの引数を持つctorをデフォルトのctorと見なさない。
  18. Bugzilla 9759: 無効なコードに対する StructLiteral::implicitConvTo(Type*) でコンパイラがセグメンテーションフォールトを起こす。
  19. Bugzilla 9764: Ddoc:Ddocファイル名が正しく強調されていない
  20. Bugzilla 9775: 変数が明示的に型付けされている場合、CTFE で const Date を作成できなくなった。
  21. Bugzilla 9806: struct.c:668 でアサーションに失敗していた。
  22. Bugzilla 9834: ラムダの局所性が正しく検出されない。
  23. Bugzilla 9846: 前方参照の後退
  24. Bugzilla 9858: opAssign が存在する場合、const エイリアスが失敗する。
  25. Bugzilla 9865: 偽のインポート/循環参照でクラッシュする。
  26. Bugzilla 9890: エイリアスthis + エイリアスフィールド
  27. Bugzilla 9903: std.typeconsとetc.c.sqlite3でddocが壊れている
  28. Bugzilla 9919: リグレッション (2.062):public import と mixin でシンボル検索に失敗する。
  29. Bugzilla 9952: 回帰(HEAD):仮想関数の属性推論でサブクラスが壊れる。
  30. Bugzilla 9957: [2.061 -> 2.062] 列挙型float配列のポインタを取るとゴミが出る。
  31. Bugzilla 9974: 不変のコンストラクタが壊れる。
  32. Bugzilla 9984: inout修飾子がコンストラクタの引数でスキップされる(テンプレートコンストラクタのみ)
  33. Bugzilla 9987: 構造体 ModuleInfo の宣言は許可されるべきである。
  34. Bugzilla 10002: 2.062 -> 2.063 の"remove" 呼び出しは不純である。
  35. Bugzilla 10003: void* UFCS回帰
  36. Bugzilla 10016: RefCountedを使ったエラーギャグの不正確さ
  37. Bugzilla 10040: 構造体関連 ICE
  38. Bugzilla 10041: 連想配列の ufcs 書き込み
  39. Bugzilla 10043: traits(compiles)によるICE
  40. Bugzilla 10044: TemplateParameterListによるIsExpの間違ったdi生成
  41. Bugzilla 10047: opDispatchのインスタンス生成の失敗はUFCSのためにギャグにすべきである。
  42. Bugzilla 10049: 範囲集合に対するforeachの内部で "Label already defined "という偽のエラーが発生する
  43. Bugzilla 10050: リグレッション(git-head):RDMDがDMDからエラーメッセージを出さなくなった。
  44. Bugzilla 10053: 構造体メンバが純粋なdtorを持つ場合、宣言されたdtorも純粋でなければならない。
  45. Bugzilla 10055: dtor/postblitビルディングで属性のマージが正しくない。
  46. Bugzilla 10056: テンプレートとstring.formatの奇妙なエラー
  47. Bugzilla 10067: [REG] テンプレートの再帰的インスタンス化
  48. Bugzilla 10073: デフォルトのopEqualsはDMD HEADのクラス宣言順序に依存する。
  49. Bugzilla 10076: expression.c:4310: virtual Expression* TypeExp::semantic(Scope*):アサーション0 に失敗した。
  50. Bugzilla 10089: 指定されたモジュールで奇妙な関数呼び出しエラーメッセージが表示された。
  51. Bugzilla 10091: [HEAD] 構造体メンバ文字列enumを同じサイズの静的ubyte配列にキャストできない。
  52. Bugzilla 10096: リグレッション (git-head):__traits(allMembers)は境界外エラーを引き起こす。
  53. Bugzilla 10101: static if 条件をミックスインテンプレートを使ってグローバルスコープに置くことはできない。
  54. Bugzilla 10106: [ICE] glue.c:1215のIce + 行のない2つのエラーメッセージ
  55. Bugzilla 10134: テンプレートの相互参照エラー
  56. Bugzilla 10142: [REG2.063a] クラスメンバで宣言された "列挙型値"のセマンティックな問題
  57. Bugzilla 10144: finalクラス内部でenumを使用すると奇妙なエラーが発生する
  58. Bugzilla 10148: regression 062=>063: 不当な "safe function cannot call system function"が発生する。
  59. Bugzilla 10151: final: enumの前がエラーになった。
  60. Bugzilla 10160: 行番号がない。"unot modify struct ... with immutable members" 構造体を変更できない。
  61. Bugzilla 10166: XXXはテンプレートではない
  62. Bugzilla 10178: 長さゼロのタプル比較でコンパイラがセグメンテーション・エラーを起こす

DMDコンパイラのバグ

  1. Bugzilla 1520: TypeInfo_Const.opEqualsが正しくない。
  2. Bugzilla 1804: 配列の繰り返し確保で深刻なGCリークが発生する。
  3. Bugzilla 2356: 配列リテラルを非静的イニシャライザとして使用すると、非効率的なコードが生成される。
  4. Bugzilla 3789: [TDPL] ビット比較でない比較を必要とする構造体メンバが正しく比較されない。
  5. Bugzilla 4094: ICE(expression.c):型推論を伴う再帰構造体テンプレート : [TDPL] ビット毎の比較を必要としない構造体メンバが正しく比較されない : [TDPL] ビット毎の比較を必要としない構造体メンバが正しく比較されない : [TDPL] ビット毎の比較を必要とする構造体メンバが正しく比較されない : ICE(expression.c): 型推論を伴う再帰構造体テンプレート
  6. Bugzilla 4247: コンストラクタが定義されている場合、ヒープ上にデフォルト構造体を作成できない
  7. Bugzilla 4414: ICE(cgcs.c) 関数によって返される静的配列の項目を取る。
  8. Bugzilla 4436: Tuple.initに関する二重バグ
  9. Bugzilla 4479: モジュール Foo が複数のファイルに存在する Foo
  10. Bugzilla 4617: エイリアスのthis'edシンボルはテンプレートに渡せない
  11. Bugzilla 4814: rdmd:ofを使用し、-LリンカーオプションをON/OFFしてもリビルドされない。
  12. Bugzilla 5450: コンストラクタの暗黙の super() 呼び出しにマッチしない。
  13. Bugzilla 5625: std.formatのunittestが無効になった。
  14. Bugzilla 6070: CTFE UFCS 前方参照エラー
  15. Bugzilla 6089: 静的な2D配列でない__gsharedを持つ
  16. Bugzilla 6153: 配列!(配列!T)の中に配列!Tを挿入するとセグメンテーションフォールトが発生する。
  17. Bugzilla 6312: テンプレートのインスタンスは、それを囲むテンプレートの引数を使用できない。
  18. Bugzilla 6431: [RDMD] ライブラリを変更してもリビルドが実行されない
  19. Bugzilla 6535: RDMDが壊れたライブラリファイルを出力する
  20. Bugzilla 6539: テンプレートのインスタンス化に失敗した場合の分かりにくいエラーメッセージ
  21. Bugzilla 6545: [CTFE] ハードコードされた配列操作はまだサポートされていない
  22. Bugzilla 6578: コンストラクタを持つ構造体の const は無視される。
  23. Bugzilla 6795: ICE(cgcs.c):列挙型配列項目のインクリメント
  24. Bugzilla 6852: ParameterStorageClassTuple のインスタンスを比較できない。
  25. Bugzilla 7068: ポインタの配列をコピーする際に -d で memcpy の代わりに memset を呼び出す
  26. Bugzilla 7437: DMDがオーバーロード解決中に無限ループに入る
  27. Bugzilla 7569: タプルの宣言をvoidで初期化できない
  28. Bugzilla 7572: f.fn!(void)はl値ではない
  29. Bugzilla 7719: enumが中括弧内にある場合、enum前方参照エラーが発生する。
  30. Bugzilla 7980: スタックオーバーフロー / 別名のthisを使った再帰的展開
  31. Bugzilla 8041: __gshared/staticの問題
  32. Bugzilla 8081: 生成された "header"ファイルにおける純粋なnothrow unittest問題
  33. Bugzilla 8130: DMDがDLLをコンパイルする際に、*.defファイルがないと仮定してコンパイルするため、メモリが破壊される。_tls_index = 0
  34. Bugzilla 8213: ubyte[]へのポインタと前方へのポインタのエラーメッセージが正しくない。
  35. Bugzilla 8238: テンプレートはゴーストフィールドを生成できる
  36. Bugzilla 8245: UFCSがポインタに対して機能しない
  37. Bugzilla 8294: 64ビットDMDで複雑な呼び出しが壊れる
  38. Bugzilla 8347: declの~this()の後に置かれたconstによるパーサーのバグ
  39. Bugzilla 8366: constメンバ関数をmutableオーバーロードと一緒にオーバーライドすると奇妙なエラーが発生する。
  40. Bugzilla 8589: typeof(null) を返す関数から配列を返す関数への変換が正しくない。
  41. Bugzilla 8609: 静的配列の前方参照エラー
  42. Bugzilla 8668: public selective importは、そうでなければ衝突しない関数を衝突させてしまう。
  43. Bugzilla 8670: エイリアスからIFTIに失敗する
  44. Bugzilla 8697: 無効なエラーメッセージインターフェースの前方参照
  45. Bugzilla 8698: インターフェイスの前方参照エラー
  46. Bugzilla 8827: R12の内容を移動できない。
  47. Bugzilla 8828: 大きな固定サイズの行列に対するdestroy()の長いコンパイル時間
  48. Bugzilla 8833: 式タプルで奇妙なエラーが発生する。
  49. Bugzilla 8902: Xの"共用体初期化の重複"エラー。
  50. Bugzilla 8945: 静的構造体のイニシャライザまたはコンストラクタを、テンプレート化された内部構造体の修飾子なしで呼び出せない。
  51. Bugzilla 8953: パーサーがデストラクタの後の修飾子を拒否する。~this() <qualifier> { }
  52. Bugzilla 8989: cfloat 引数パッシングが壊れた
  53. Bugzilla 8998: "inout pure"はimmutableを返すが、実際にはmutableである。
  54. Bugzilla 9091: テンプレート化された関数で__traits(getMember)を使うとメンバ関数内で失敗する。
  55. Bugzilla 9144: synchronized CRITSECSIZEはターゲット定数であるべきである。
  56. Bugzilla 9199: モジュールレベルの修飾関数は拒否されるべきである。
  57. Bugzilla 9209: ice(symbol.c)でconst structヒープ割り当てを使用する。
  58. Bugzilla 9231: 属性推論でinout関数をオーバーライドすると変なエラーが出る
  59. Bugzilla 9232: テンプレート化されたメソッド呼び出しの解析エラー
  60. Bugzilla 9241: 2.061:プロパティ呼び出しのエラーメッセージが消えた。
  61. Bugzilla 9280: 正規表現における名前付きキャプチャグループの実行時範囲違反
  62. Bugzilla 9311: 共有ライブラリファイルの拡張子が正しく変更されない
  63. Bugzilla 9345: インポートされた文字列列列挙型で std.string.format を使用すると CTFE に失敗する。
  64. Bugzilla 9346: ネストされた構造体呼び出しがポストブリットで無効になった。
  65. Bugzilla 9386: 構造体のデストラクタが誤って呼び出された。
  66. Bugzilla 9393: 部分テンプレート特殊化とテンプレートラムダが機能しない
  67. Bugzilla 9401: デストラクタとnothrow構文
  68. Bugzilla 9413: 契約" 内の不正な変更が正しく検出されない。
  69. Bugzilla 9414: 仮想関数において、契約(contract)内部の不正な変更が検出されない。
  70. Bugzilla 9415: デリゲート推論は関数リテラルを純粋でない関数にすべきである。
  71. Bugzilla 9417: ネストされた構造体で「前方参照用のサイズがまだない」エラーが発生する
  72. Bugzilla 9428: 間違った配列連結
  73. Bugzilla 9441: 構造体コンストラクタが自動/型推論変数定義でミスする
  74. Bugzilla 9445: interpret.c:151:アサーションv->ctfeAdrOnStack >= 0 && v->ctfeAdrOnStack < stackPointer() に失敗した。
  75. Bugzilla 9451: 診断で抽象関数をリストアップする場合、完全なシグネチャを表示すべきである。
  76. Bugzilla 9473: Unittestのドキュメントはそれぞれのセクションにまとめるべき
  77. Bugzilla 9474: Ddocされたunittestはversion(none)を挟んでも正しく動作するようにする。
  78. Bugzilla 9475: ddocのunittestではソースのフォーマットを保持する。
  79. Bugzilla 9480: JSON出力のテンプレート名はテンプレートと関数の引数を含む。
  80. Bugzilla 9494: 無効な連想配列でコンパイラのスタックオーバーフローが発生する
  81. Bugzilla 9495: 最初の引数が8バイトを超える場合のWin64のvarargの問題
  82. Bugzilla 9508: ファイル変更時にRDMDが新しい依存性リストを生成しない。
  83. Bugzilla 9540: デリゲート・コンテキスト・フレームの割り当てでコンパイラがクラッシュする
  84. Bugzilla 9561: std.formatからのエラーメッセージが多い。
  85. Bugzilla 9590: UFCSはvoid lazy式では動作しない。
  86. Bugzilla 9613: 型コンストラクタで.initを使用した場合のパーサバグ
  87. Bugzilla 9617: "ulong.max"が小さい符号付きパラメータで誤って受け取られる。
  88. Bugzilla 9619: 内部関数で構造体フィールドのtypeofに失敗する。
  89. Bugzilla 9622: rdmdの範囲違反
  90. Bugzilla 9649: DMDが有効なPostfixExpression .NewExpression構文。
  91. Bugzilla 9652: __traits(getAttributes)がマニフェスト定数で動作しない。
  92. Bugzilla 9654: テンプレート化された関数はref T[len]で文字列を受け取ることができない。
  93. Bugzilla 9656: 可能であれば、組み込みのdupの結果は一意な配列のように振る舞うべきである。
  94. Bugzilla 9658: 修飾コンストラクタで初期化済みフィールドを設定できるようにする。
  95. Bugzilla 9677: VC 2012 64ビットで配列のlengthプロパティを設定するとクラッシュする。
  96. Bugzilla 9679: 条件付き代入でconst/immutable代入が拒否される
  97. Bugzilla 9692: パッケージのないモジュールで"__traits(allMembers)"に失敗する
  98. Bugzilla 9700: std.typecons.Proxyの無効化とインプレース操作でアクセス違反が発生する
  99. Bugzilla 9712: IFTIは配列リテラル引数からの静的配列型の推測をサポートしていない。
  100. Bugzilla 9713: Ddoc:空の記述は自動生成例を抑制する : Ddoc: 空の記述は自動生成例を抑制する
  101. Bugzilla 9714: Ddoc:Dと-unittestの組み合わせは隠れたunittest関数を明らかにする。
  102. Bugzilla 9720: OSX で -O を使ったコードが間違っている。
  103. Bugzilla 9722: オプティマイザがGOTからEBXへのロードを殺す
  104. Bugzilla 9729: インタフェースサンクがEBXをGOTに設定しない
  105. Bugzilla 9735: デリゲートのvoid*へのキャストは不正であるべきである。
  106. Bugzilla 9736: VS2010のプロジェクトファイルは毎回完全にリビルドされる
  107. Bugzilla 9743: IFTIと多相の文字列リテラルは静的配列型への暗黙の変換をサポートすべきである。
  108. Bugzilla 9744: コンパイル時にスレッドローカル変数のアドレスを取るエラーメッセージが悪い。
  109. Bugzilla 9747: 暗黙的に静的配列に変換されるコミットされた文字列リテラルに対してIFTIの引数推論が失敗する
  110. Bugzilla 9755: JSON出力にテンプレートの保護属性がない。
  111. Bugzilla 9757: Ddoc: dittoの後にドキュメント化されたunittestは機能するはずである。
  112. Bugzilla 9758: Ddoc: 空のddocコメントとunittestブロックは "例"セクションを生成しない。
  113. Bugzilla 9768: 間違ったforeach型の行番号がない
  114. Bugzilla 9773: デフォルト値のrefパラメータはコンパイルすべきでない。
  115. Bugzilla 9774: タプル・メンバーに==を使用した__errorのエラー・メッセージ
  116. Bugzilla 9777: finalインターフェイスメソッドを呼び出すと間違ったコードになる
  117. Bugzilla 9781: -inlineはバックエンドICEの原因になる
  118. Bugzilla 9788: 実行中のプログラムで例外がスローされた場合、-profileは機能しない。
  119. Bugzilla 9790: テンプレート内の無効な変数をコンパイルすると内部エラーが発生する(expression.cとbackendevalu8.c)。
  120. Bugzilla 9791: [ICE] (struct.c line 668) map with a missing tuple import (構造体.c line 668) タプルのインポートが見つからない。
  121. Bugzilla 9818: 静的配列の定数折りたたみが要素による初期化で機能しない
  122. Bugzilla 9829: rdmdがdmdに'--'を渡す
  123. Bugzilla 9837: IFTIは列挙型を考慮すべきである。
  124. Bugzilla 9844: DMD (-m64) int long 初期化のバグ。
  125. Bugzilla 9845: 列挙型はグローバルスコープで前方参照を含むことができるべきである。
  126. Bugzilla 9863: 64ビットでのSAHF命令の生成に誤りがある。
  127. Bugzilla 9873: 内蔵タプルは等価比較をサポートすべきである。
  128. Bugzilla 9874: テンプレート制約における関数呼び出し構文の不統一。
  129. Bugzilla 9880: 冗長なテンプレート・インスタンスがエラー・メッセージに表示される
  130. Bugzilla 9883: プロパティを新しい動的配列サイズとして使用する際のエラー
  131. Bugzilla 9885: IFTIは既知のタプル型を考慮すべきである。
  132. Bugzilla 9892: [ICE]列挙型宣言メンバでの前方参照がコンパイラのセグメンテーションフォールトを引き起こす
  133. Bugzilla 9899: 純粋/非投与デストラクタを持つ構造体を純粋/非投与関数の構造体メンバとして使用できない
  134. Bugzilla 9901: 内部テンプレート化された関数から文字列を返すとエラーが発生する
  135. Bugzilla 9907: デストラクタを持つ構造体リテラルは非参照オーバーロードにマッチすべきである。
  136. Bugzilla 9910: スカラー演算ベクトルが壊れている。
  137. Bugzilla 9928: void* と "関数"リテラルで氷を作る。
  138. Bugzilla 9936: opBinary/opBinaryRightの書き換えが間違っている。
  139. Bugzilla 9939: allMembersトレイトがネストした匿名列挙型のメンバを返さない。
  140. Bugzilla 9940: ICEがgetOverloadsで取得した関数にgetProtectionを適用する。
  141. Bugzilla 9946: 動的配列の割り当てでUFCSが禁止される
  142. Bugzilla 9961: UFCSプロパティを使って実際のエラーを抑制する
  143. Bugzilla 9965: DIL、SILレジスタの間違ったアセンブリ
  144. Bugzilla 9971: 同名関数がl値でない。
  145. Bugzilla 9985: Postblitがローカル構造体のreturnで呼び出されない。
  146. Bugzilla 9990: テンプレート化された関数のエイリアスは前方参照エラーを引き起こす。
  147. Bugzilla 9993: constオブジェクトの生成にはmutableよりconst ctorを優先すべきである。
  148. Bugzilla 9994: 組み込みで生成されるopAssignは代入時にdtorを呼び出すべきである。
  149. Bugzilla 10004: 副作用のあるタプル比較は機能するはずである。
  150. Bugzilla 10005: 構造体変数宣言とconst-correctness:構造体変数宣言とconst-correctnessは正しい。
  151. Bugzilla 10011: クラス参照イニシャライザーのJSON "init" プロパティ出力が正しくない。
  152. Bugzilla 10029: 予約済みバージョン識別子のリストを更新した。
  153. Bugzilla 10058: C++とextern(C++)間の一貫性のないマングリング。
  154. Bugzilla 10059: export が変数宣言に対して機能しない。
  155. Bugzilla 10063: inout+pureの結果、変更可能なデータへの不変の参照を生成することができる。
  156. Bugzilla 10066: テンプレートopEqualsが構造体コンパイルを妨害することがある。
  157. Bugzilla 10102: disableが不完全に実装されている。
  158. Bugzilla 10103: プロパティのオーバーロードを持つ"@property"テンプレートミックスイン
  159. Bugzilla 10105: 列挙型イニシャライザで文字列リテラルをstatic char配列に変換する際のICE
  160. Bugzilla 10115: より多くの@disabledホール。
  161. Bugzilla 10171: 予期せぬエラー "cannot infer type from overloaded function symbol" : "オーバーロードされた関数シンボルから型を推測できない"
  162. Bugzilla 10180: offsetofが関数呼び出しのエイリアスを介して動作しない。

DMDコンパイラの機能強化

  1. Bugzilla 3449: constと不変構造体のメンバが仕様通りに動作しない。
  2. Bugzilla 3502: Mac OS X 10.5の不具合を修正した。
  3. Bugzilla 3673: 継承 + if 節 = 失敗
  4. Bugzilla 4528: プライベート抽象メソッドのエラーメッセージを改善
  5. Bugzilla 5140: FUNCTION__、___PRETTY_FUNCTION__、___MODULE__の追加。
  6. Bugzilla 6185: UFCS解決時に非グローバル関数を含める。
  7. Bugzilla 6453: 構造体/クラスごとに複数の不変量を許可する。
  8. Bugzilla 6809: IFTIは、引数にinoutが存在し、戻り値にinoutが存在しない場合、constを意味する。
  9. Bugzilla 7444: 配列のコピーにも[]を要求する
  10. Bugzilla 7511: 属性推論はテンプレート化された関数に対しても機能すべきである。
  11. Bugzilla 8220: 意味解析中に無効な関数呼び出しが検出されない。
  12. Bugzilla 8669: TemplateThisParameterはメンバ関数の修飾子を変更すべきである。
  13. Bugzilla 8819: void static arrayはinit組み込みプロパティを持つべきである。
  14. Bugzilla 8959: IsExpressionは、すべてのケースでIdentifierを持たない構文をサポートすべきである。
  15. Bugzilla 9033: 言語から__threadを削除する
  16. Bugzilla 9136: isNestedを追加する。
  17. Bugzilla 9155: Ddoc: コードセクションは先頭の空白を取り除くべきである
  18. Bugzilla 9170: CTFE: float <-> int のキャストの再解釈を許可する。
  19. Bugzilla 9185: opが有用な場所についての注釈を追加した。
  20. Bugzilla 9574: alias this = that'の古い使い方に対する診断が必要である。
  21. Bugzilla 9627: UFCS使用時のエラーメッセージが不十分な場合がある。
  22. Bugzilla 9635: 静的メソッドから配列フィールドのプロパティへのアクセスに失敗した場合のエラーメッセージを改善した。
  23. Bugzilla 9676: Ddoc:非推奨宣言を(DEPRECATED)マクロで囲む
  24. Bugzilla 9680: dmd -v -o "出力にエントリーポイントの位置を含める
  25. Bugzilla 9723: デフォルトのmain()関数をインジェクトするために-mainスイッチを実装する。
  26. Bugzilla 9726: covテストに必要なカバレッジの最小値を追加した。
  27. Bugzilla 9727: ドキュメント化されたunittestのコメントは "Examples:"セクションの前に表示されるべきである。
  28. Bugzilla 9745: スレッド以外のローカル静的変数のアドレスを CTFE で取得できるようにした。
  29. Bugzilla 9778: RDMD: DMDへのリソースファイルの受け渡しをサポートする。
  30. Bugzilla 9789: エイリアスのDdocは新しい "alias x=y"構文を使用すべきである。
  31. Bugzilla 9866: movsxd はサポートされていない
  32. Bugzilla 9920: [Optimizer] 整数の定数除算にmul/imulを使用する
  33. Bugzilla 9941: [CTFE] "newed"クラスと構造体をデータセグメントに格納できるようにした。
  34. Bugzilla 9943: CTFE から typeid を返せるようにする。
  35. Bugzilla 9963: ブール述語を追加するCodegenの非効率性
  36. Bugzilla 9977: ローカルテンプレート化された関数を許可すべきである。
  37. Bugzilla 10030: ldにデフォルトのライブラリを渡すときに'-l:'スイッチをサポートする。
  38. Bugzilla 10077: シンボルのマングルをオーバーライドするために pragma(mangle, "...") を追加する。
  39. Bugzilla 10109: -transitionコンパイラー・スイッチを追加し、ブレークチェンジに対応できるようにした。
  40. Bugzilla 10150: プレフィックス・メソッドのthis修飾子はいつでも無視されるべきである。
  41. Bugzilla 10179: タプル代入で長さがゼロでも「has no effect」エラーを発生させないようにした。

phobosのリグレッション

  1. Bugzilla 9122: std.concurrency send()が複数の配列で失敗する
  2. Bugzilla 9742: std.math.floorはx > -1かつx < 0の値に対して0を返す
  3. Bugzilla 10122: Appender が無効化されたデフォルトの構築では動作しない。

phobosのバグ

  1. Bugzilla 3795: phobosのstd.variantの問題
  2. Bugzilla 4729: std.algorithm: iotaの奇妙な挙動
  3. Bugzilla 4798: std.algorithm.mapはconst要素のある範囲では使えない
  4. Bugzilla 4955: struct dirent.d_typeがマスクではない
  5. Bugzilla 5032: std.file.renameがWindowsとLinuxで異なる動作をする。
  6. Bugzilla 5201: std.string.indexOfとstd.algorithm.indexOfは狭い文字列に対して異なるものを返す
  7. Bugzilla 5310: Variant == const(Variant)はコンパイルできない。
  8. Bugzilla 5359: std.trait.isDelegateは "型"と "式"に対して機能すべきである。
  9. Bugzilla 5360: 別のフォルダからrdmdを呼び出す
  10. Bugzilla 5514: ドキュメントに誤りがある。
  11. Bugzilla 5658: std.typecons.Tupleに文書化されていないフィールドがある。
  12. Bugzilla 5924: Tuple!(char)[]のschwartzSort
  13. Bugzilla 8321: std.range.putはRefCounted出力範囲では動作しない
  14. Bugzilla 8613: std.typecons.Proxyは演算子'in'で動作しない
  15. Bugzilla 8655: bitfieldsとTypedefは混ざらない
  16. Bugzilla 9164: Nullableを別のNullableに簡単に代入できない
  17. Bugzilla 9431: 配列の配列でのタプル生成の問題
  18. Bugzilla 9456: decodeFrontが範囲外の要素をポップするかどうかで一貫性がない
  19. Bugzilla 9512: std.regex: 大文字から構成される16進数のパースが正しくない。
  20. Bugzilla 9553: SOCKETはWin64では64ビット幅であるべきである。
  21. Bugzilla 9583: std.getopt.getoptがargsリストからオプションのターミネーター"--"を消費しない。
  22. Bugzilla 9612: std.range.Cycle.opSliceの境界テストが抜けている。
  23. Bugzilla 9624: 関数のfullyQualifiedNameが失敗する。
  24. Bugzilla 9648: std.algorithm.topNにstd.randomのインポートがない。
  25. Bugzilla 9753: std.string.translateの前提条件がアサートされる
  26. Bugzilla 9794: std.jsonはdelete文字を扱えない
  27. Bugzilla 9804: std.math.FloatingPointControl が浮動小数点の状態を破損する
  28. Bugzilla 9812: std.conv.parse stringが特定のエスケープ文字で失敗する。
  29. Bugzilla 9836: std.array.popFrontがエイリアスのthisで動作しない。
  30. Bugzilla 9950: std.jsonは空の入力に対してnullではなく空の文字列/配列を返すべきである。
  31. Bugzilla 9956: hasElaborateAssignトレイトが静的配列で動作しない。
  32. Bugzilla 9979: を使用した正規表現のバグが修正された。
  33. Bugzilla 10116: stdio.File.byLineが最後の行を永遠に繰り返す、readln(ref C[],R)が不正なデータを返す
  34. Bugzilla 10167: std.format.d(181)の間違ったドキュメントコメント
  35. Bugzilla 10182: std.bitmanip ユニットテストには無意味な foreach ループがある

phobosの機能強化

  1. Bugzilla 4787: 標準アルゴリズム.bisectRight()
  2. Bugzilla 4921: std.variantドキュメントのシノプシスコードがアサーションエラーを投げる。
  3. Bugzilla 5013: std.typecons.Tupleは静的配列のコンストラクタを持つべきである。
  4. Bugzilla 5106: makeIndex は SortedRange を返すべきである
  5. Bugzilla 5226: indexOf()はpredを取るがneedleを取らない
  6. Bugzilla 5401: std.socketの更新とboostライセンス
  7. Bugzilla 5507: countUntilはR2の代わりにRanges...を取るべきである。
  8. Bugzilla 6224: std.concurrencyにownerTidプロパティを追加した。
  9. Bugzilla 6486: std.math.abs(BigInt)を追加した。
  10. Bugzilla 7405: std.algorithm.schwartzSort.releaseを追加した。
  11. Bugzilla 9260: getoptはブール値をfalseに設定できるようにすべきである。
  12. Bugzilla 9265: Null可能な固定サイズ配列のラッパー
  13. Bugzilla 9625: assertNotThrownはmsgが提供されない場合は例外msgを表示する必要がある
  14. Bugzilla 9802: std.traits.{isNested,hasNested} を追加する。
  15. Bugzilla 9814: std.trait.isNestedFunctionを追加する。
  16. Bugzilla 9839: std.trait.Selectでシンボルを選択できるようにする。
  17. Bugzilla 9888: 列挙型に対してstd.random.uniformにジェネレータを渡せるようにする

Druntimeのバグ

  1. Bugzilla 4307: spawn()されたスレッドが終了しない
  2. Bugzilla 6024: Windows 2000 SP4がサポートされなくなったドキュメント
  3. Bugzilla 10057: [2.063 beta] 共有phobosでモジュール情報が上書きされる。
  4. Bugzilla 10081: 間違った文字配列の比較

Optlinkのバグ

  1. Bugzilla 6144: EIP=00428DA3での予期せぬOPTLINK終了

インストーラーのバグ

  1. Bugzilla 9343: Fedora 18 での dmd-2.061-0.fedora.x86_64.rpm のインストールに問題がある

ウェブサイトのバグ

  1. Bugzilla 4847: std.algorithm.topN ドキュメント
  2. Bugzilla 9544: Dロゴの画像がルートレベルでないページで壊れている
  3. Bugzilla 9609: std.string.icmpのDdocタグがおかしい。
  4. Bugzilla 10036: dlang.orgにcore.atomicのドキュメントがない。
前のバージョン: - 次のバージョン: