diff --git a/CHANGELOG.md b/CHANGELOG.md index 1b9a4220a39..5f6b98cc34c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,11 +1,16 @@ # LDC master #### Big news -- Frontend, druntime and Phobos are at version [2.105.1+](https://dlang.org/changelog/2.105.0.html). (#4476) +- Frontend, druntime and Phobos are at version [2.105.2](https://dlang.org/changelog/2.105.0.html). (#4476, #4498) +- The Windows installer now supports non-admin installs *without* an explicit `/CURRENTUSER` switch. (#4495) #### Platform support #### Bug fixes +- ImportC: + - Fix `static` linkage. (#4484, 4487) + - Make gcc builtins available. (#4483) + - Apple: Support weird `asm("_" "")` mangling stuff. (#4485, #4486) # LDC 1.34.0 (2023-08-26) diff --git a/CMakeLists.txt b/CMakeLists.txt index 4866d43a54a..5c86891277d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -120,7 +120,7 @@ include(GetLinuxDistribution) set(LDC_VERSION "1.35.0") # May be overridden by git hash tag set(DMDFE_MAJOR_VERSION 2) set(DMDFE_MINOR_VERSION 105) -set(DMDFE_PATCH_VERSION 1) +set(DMDFE_PATCH_VERSION 2) set(DMD_VERSION ${DMDFE_MAJOR_VERSION}.${DMDFE_MINOR_VERSION}.${DMDFE_PATCH_VERSION}) diff --git a/dmd/expressionsem.d b/dmd/expressionsem.d index 0d0d79869db..7cfe6146a82 100644 --- a/dmd/expressionsem.d +++ b/dmd/expressionsem.d @@ -11029,7 +11029,9 @@ version (IN_LLVM) (exp.e2.isStringExp() && (exp.e1.isIntegerExp() || exp.e1.isStringExp()))) return exp; - Identifier hook = global.params.tracegc ? Id._d_arraycatnTXTrace : Id._d_arraycatnTX; + bool useTraceGCHook = global.params.tracegc && sc.needsCodegen(); + + Identifier hook = useTraceGCHook ? Id._d_arraycatnTXTrace : Id._d_arraycatnTX; if (!verifyHookExist(exp.loc, *sc, hook, "concatenating arrays")) { setError(); @@ -11058,7 +11060,7 @@ version (IN_LLVM) } auto arguments = new Expressions(); - if (global.params.tracegc) + if (useTraceGCHook) { auto funcname = (sc.callsc && sc.callsc.func) ? sc.callsc.func.toPrettyChars() : sc.func.toPrettyChars(); @@ -11085,7 +11087,7 @@ version (IN_LLVM) /* `_d_arraycatnTX` canot be used with `-betterC`, but `CatExp`s may be * used with `-betterC`, but only during CTFE. */ - if (global.params.betterC || !sc.needsCodegen()) + if (global.params.betterC) return; if (auto ce = exp.isCatExp()) diff --git a/dmd/frontend.h b/dmd/frontend.h index 7273739898d..4065afabce8 100644 --- a/dmd/frontend.h +++ b/dmd/frontend.h @@ -379,8 +379,8 @@ struct Loc final { private: uint32_t _linnum; - uint16_t _charnum; - uint16_t fileIndex; + uint32_t _charnum; + uint32_t fileIndex; public: static bool showColumns; static MessageStyle messageStyle; @@ -7019,9 +7019,9 @@ struct UnionExp final private: union __AnonStruct__u { - char exp[25LLU]; + char exp[29LLU]; char integerexp[40LLU]; - char errorexp[25LLU]; + char errorexp[29LLU]; char realexp[48LLU]; char complexexp[64LLU]; char symoffexp[64LLU]; @@ -7030,7 +7030,7 @@ struct UnionExp final char assocarrayliteralexp[48LLU]; char structliteralexp[76LLU]; char compoundliteralexp[40LLU]; - char nullexp[25LLU]; + char nullexp[29LLU]; char dotvarexp[49LLU]; char addrexp[40LLU]; char indexexp[74LLU]; diff --git a/dmd/globals.h b/dmd/globals.h index eb4bcd8c386..6d225dc3bd2 100644 --- a/dmd/globals.h +++ b/dmd/globals.h @@ -440,8 +440,8 @@ struct Loc { private: unsigned _linnum; - unsigned short _charnum; - unsigned short fileIndex; + unsigned _charnum; + unsigned fileIndex; public: static void set(bool showColumns, MessageStyle messageStyle); diff --git a/dmd/location.d b/dmd/location.d index b2b366130ca..6e69cc33933 100644 --- a/dmd/location.d +++ b/dmd/location.d @@ -38,8 +38,8 @@ debug info etc. struct Loc { private uint _linnum; - private ushort _charnum; - private ushort fileIndex; // index into filenames[], starting from 1 (0 means no filename) + private uint _charnum; + private uint fileIndex; // index into filenames[], starting from 1 (0 means no filename) version (LocOffset) uint fileOffset; /// utf8 code unit index relative to start of file, starting from 0 @@ -67,7 +67,7 @@ nothrow: extern (D) this(const(char)* filename, uint linnum, uint charnum) { this._linnum = linnum; - this._charnum = cast(ushort) charnum; + this._charnum = charnum; this.filename = filename; } @@ -80,7 +80,7 @@ nothrow: /// ditto extern (C++) uint charnum(uint num) @nogc @safe { - return _charnum = cast(ushort) num; + return _charnum = num; } /// line number, starting from 1 @@ -114,8 +114,16 @@ nothrow: { //printf("setting %s\n", name); filenames.push(name); - fileIndex = cast(ushort)filenames.length; - assert(fileIndex); // no overflow + fileIndex = cast(uint)filenames.length; + if (!fileIndex) + { + import dmd.globals : global; + import dmd.errors : error, fatal; + + global.gag = 0; // ensure error message gets printed + error(Loc.initial, "internal compiler error: file name index overflow!"); + fatal(); + } } else fileIndex = 0; diff --git a/packaging/dlang-tools_version b/packaging/dlang-tools_version index 1f9b2b47b5f..d7b23d710b0 100644 --- a/packaging/dlang-tools_version +++ b/packaging/dlang-tools_version @@ -1 +1 @@ -v2.105.1 \ No newline at end of file +v2.105.2 \ No newline at end of file diff --git a/runtime/phobos b/runtime/phobos index d7f31b03664..a4d814cf4de 160000 --- a/runtime/phobos +++ b/runtime/phobos @@ -1 +1 @@ -Subproject commit d7f31b036640670fc9f8364ad9a21d8be302f132 +Subproject commit a4d814cf4de1420fd4a976810c8ec15caf065498 diff --git a/tests/dmd/compilable/test24118.d b/tests/dmd/compilable/test24118.d new file mode 100644 index 00000000000..25376b73b18 --- /dev/null +++ b/tests/dmd/compilable/test24118.d @@ -0,0 +1,15 @@ +// https://issues.dlang.org/show_bug.cgi?id=24118 + +void map(alias fun, T)(T[] arr) +{ + fun(arr); +} + + +void foo() +{ + if( __ctfe ) + { + ["a", "b", "c"].map!( a => " " ~ a[0] ); + } +}