<pre style='margin:0'>
Blair Zajac (blair) pushed a commit to branch master
in repository macports-ports.
</pre>
<p><a href="https://github.com/macports/macports-ports/commit/1392aaf376a6663c2f3d300ae2b4d760aab84794">https://github.com/macports/macports-ports/commit/1392aaf376a6663c2f3d300ae2b4d760aab84794</a></p>
<pre style="white-space: pre; background: #F8F8F8">The following commit(s) were added to refs/heads/master by this push:
<span style='display:block; white-space:pre;color:#404040;'> new 1392aaf376a nodejs18: update to 18.20.1
</span>1392aaf376a is described below
<span style='display:block; white-space:pre;color:#808000;'>commit 1392aaf376a6663c2f3d300ae2b4d760aab84794
</span>Author: Blair Zajac <blair@macports.org>
AuthorDate: Fri Apr 5 12:10:34 2024 -0700
<span style='display:block; white-space:pre;color:#404040;'> nodejs18: update to 18.20.1
</span>---
devel/nodejs18/Portfile | 11 +-
devel/nodejs18/files/v8-bitfield-width.diff | 161 ++++++++++++++++++++++++++++
2 files changed, 167 insertions(+), 5 deletions(-)
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/devel/nodejs18/Portfile b/devel/nodejs18/Portfile
</span><span style='display:block; white-space:pre;color:#808080;'>index 5ada4b4f719..e53fbf238b8 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/devel/nodejs18/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/devel/nodejs18/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -11,7 +11,7 @@ configure.cxx_stdlib libc++
</span> compiler.cxx_standard 2014
name nodejs18
<span style='display:block; white-space:pre;background:#ffe0e0;'>-version 18.19.1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+version 18.20.1
</span> revision 0
categories devel net
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -32,9 +32,9 @@ homepage https://nodejs.org/
</span> master_sites ${homepage}dist/v${version}
use_xz yes
<span style='display:block; white-space:pre;background:#ffe0e0;'>-checksums rmd160 22e5122bafe3e84ea588ca45febf7bdf9f40ab6c \
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- sha256 090f96a2ecde080b6b382c6d642bca5d0be4702a78cb555be7bf02b20bd16ded \
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- size 41250068
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+checksums rmd160 ee1cb86b4d5c9ccf8cb9ff72edcc7f43b2a30316 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ sha256 c6d867a9f25e6354810effb8201f8147a15b28000e50790fda00d1ca15f49b8a \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ size 40434200
</span>
distname node-v${version}
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -66,7 +66,8 @@ proc rec_glob {basedir pattern} {
</span>
configure.python ${prefix}/bin/python${py_ver}
<span style='display:block; white-space:pre;background:#ffe0e0;'>-patchfiles patch-common.gypi.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+patchfiles patch-common.gypi.diff \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ v8-bitfield-width.diff
</span>
post-patch {
foreach f [concat ${worksrcpath}/configure \
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/devel/nodejs18/files/v8-bitfield-width.diff b/devel/nodejs18/files/v8-bitfield-width.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..8067bc83ef8
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/devel/nodejs18/files/v8-bitfield-width.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,161 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+This fixes this compile error:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+../deps/v8/src/base/bit-field.h:43:29: error: integer value 31 is outside the valid range of values [0, 15] for this enumeration type [-Wenum-constexpr-conversion]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ static constexpr T kMax = static_cast<T>(kNumValues - 1);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ^
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+1 error generated.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+See:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ https://github.com/nodejs/node/issues/52230
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ https://github.com/nodejs/node/pull/52337
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ https://github.com/nodejs/node/commit/f7a319eb22d956c11c71fd203243c3fb7fa2094e.patch?full_index=1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+The only changes made to this patch was for a/... paths to add .orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+to the end and drop the a/ and for b/... paths to drop the b/.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+From f7a319eb22d956c11c71fd203243c3fb7fa2094e Mon Sep 17 00:00:00 2001
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+From: Bo Anderson <mail@boanderson.me>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+Date: Tue, 2 Apr 2024 22:55:25 +0100
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+Subject: [PATCH] deps: V8: cherry-pick d15d49b09dc7
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+Original commit message:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Make bitfields only as wide as necessary for enums
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ clang now complains when a BitField for an enum is too wide.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ We could suppress this, but it seems kind of useful from an
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ uninformed distance, so I made a few bitfields smaller instead.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ (For AddressingMode, since its size is target-dependent, I added
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ an explicit underlying type to the enum instead, which suppresses
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ the diag on a per-enum basis.)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ This is without any understanding of the code I'm touching.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Especially the change in v8-internal.h feels a bit risky to me.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Bug: chromium:1348574
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Change-Id: I73395de593045036b72dadf4e3147b5f7e13c958
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3794708
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Commit-Queue: Nico Weber <thakis@chromium.org>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Reviewed-by: Leszek Swirski <leszeks@chromium.org>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Reviewed-by: Hannes Payer <hpayer@chromium.org>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Auto-Submit: Nico Weber <thakis@chromium.org>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Cr-Commit-Position: refs/heads/main@{#82109}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+Refs: https://github.com/v8/v8/commit/d15d49b09dc7aef9edcc4cf6a0cb2b77a0db203f
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+---
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ common.gypi | 2 +-
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ deps/v8/src/ast/ast.h | 2 +-
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ deps/v8/src/base/bit-field.h | 5 +++++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ deps/v8/src/compiler/backend/instruction-codes.h | 4 ++--
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ deps/v8/src/compiler/backend/instruction.h | 4 ++--
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ deps/v8/src/maglev/maglev-ir.h | 2 +-
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ deps/v8/src/wasm/wasm-code-manager.h | 2 +-
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ 7 files changed, 13 insertions(+), 8 deletions(-)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git common.gypi.orig common.gypi
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 38471d4639eb5e3ee5c0da4e117f716b7cc06177..ec92c9df4c1ea25eaa85fec1862f55cd04e81a1a 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- common.gypi.orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ common.gypi
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -36,7 +36,7 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # Reset this number to 0 on major V8 upgrades.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # Increment by one for each non-official patch applied to deps/v8.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- 'v8_embedder_string': '-node.36',
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ 'v8_embedder_string': '-node.37',
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ##### V8 defaults for Node.js #####
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git deps/v8/src/ast/ast.h.orig deps/v8/src/ast/ast.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 971a2b0ec1321efc1ca993906dc89ec22da0602a..be1fe09ee438ad0f04ccc62df5b2d7a5b3724184 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- deps/v8/src/ast/ast.h.orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ deps/v8/src/ast/ast.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -999,7 +999,7 @@ class Literal final : public Expression {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ friend class AstNodeFactory;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ friend Zone;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- using TypeField = Expression::NextBitField<Type, 4>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ using TypeField = Expression::NextBitField<Type, 3>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ Literal(int smi, int position) : Expression(position, kLiteral), smi_(smi) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ bit_field_ = TypeField::update(bit_field_, kSmi);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git deps/v8/src/base/bit-field.h.orig deps/v8/src/base/bit-field.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 63142a20fa2c29edce9faaea408cbebeb2ee9315..9605c41c14f8ce60c9b6cd5a45dca8410cf78fbe 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- deps/v8/src/base/bit-field.h.orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ deps/v8/src/base/bit-field.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -40,6 +40,11 @@ class BitField final {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ static constexpr U kNumValues = U{1} << kSize;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // Value for the field with all bits set.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ // If clang complains
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ // "constexpr variable 'kMax' must be initialized by a constant expression"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ // on this line, then you're creating a BitField for an enum with more bits
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ // than needed for the enum values. Either reduce the BitField size,
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ // or give the enum an explicit underlying type.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ static constexpr T kMax = static_cast<T>(kNumValues - 1);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ template <class T2, int size2>
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git deps/v8/src/compiler/backend/instruction-codes.h.orig deps/v8/src/compiler/backend/instruction-codes.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index b06b522287f2d1d109754847a33144cb86b9b536..19cb21d041b8971c0face3b781935808f85d6d3b 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- deps/v8/src/compiler/backend/instruction-codes.h.orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ deps/v8/src/compiler/backend/instruction-codes.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -195,7 +195,7 @@ V8_EXPORT_PRIVATE std::ostream& operator<<(std::ostream& os,
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ V(None) \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ TARGET_ADDRESSING_MODE_LIST(V)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+-enum AddressingMode {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++enum AddressingMode : uint8_t {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #define DECLARE_ADDRESSING_MODE(Name) kMode_##Name,
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ADDRESSING_MODE_LIST(DECLARE_ADDRESSING_MODE)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #undef DECLARE_ADDRESSING_MODE
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -306,7 +306,7 @@ using MiscField = base::BitField<int, 22, 10>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // LaneSizeField and AccessModeField are helper types to encode/decode a lane
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // size, an access mode, or both inside the overlapping MiscField.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ using LaneSizeField = base::BitField<int, 22, 8>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+-using AccessModeField = base::BitField<MemoryAccessMode, 30, 2>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++using AccessModeField = base::BitField<MemoryAccessMode, 30, 1>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // TODO(turbofan): {HasMemoryAccessMode} is currently only used to guard
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // decoding (in CodeGenerator and InstructionScheduler). Encoding (in
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // InstructionSelector) is not yet guarded. There are in fact instructions for
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git deps/v8/src/compiler/backend/instruction.h.orig deps/v8/src/compiler/backend/instruction.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 89394b2c2427d3ea1a2a3e3d83dbb0411bac597a..66a6232c32a8d0a50e174bb352c1274c6ef2b949 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- deps/v8/src/compiler/backend/instruction.h.orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ deps/v8/src/compiler/backend/instruction.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -586,8 +586,8 @@ class LocationOperand : public InstructionOperand {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ STATIC_ASSERT(KindField::kSize == 3);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- using LocationKindField = base::BitField64<LocationKind, 3, 2>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- using RepresentationField = base::BitField64<MachineRepresentation, 5, 8>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ using LocationKindField = base::BitField64<LocationKind, 3, 1>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ using RepresentationField = LocationKindField::Next<MachineRepresentation, 8>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ using IndexField = base::BitField64<int32_t, 35, 29>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ };
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git deps/v8/src/maglev/maglev-ir.h.orig deps/v8/src/maglev/maglev-ir.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 1f7c5471de025db2c1d9d4453bb788cde0828a3c..9ff1a3085790c812cfebc7811ffb46fd838234ef 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- deps/v8/src/maglev/maglev-ir.h.orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ deps/v8/src/maglev/maglev-ir.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -196,7 +196,7 @@ class OpProperties {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ constexpr bool is_pure() const {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- return (bitfield_ | kPureMask) == kPureValue;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ return (bitfield_ & kPureMask) == kPureValue;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ constexpr bool is_required_when_unused() const {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ return can_write() || non_memory_side_effects();
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git deps/v8/src/wasm/wasm-code-manager.h.orig deps/v8/src/wasm/wasm-code-manager.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 137c3074d503f074da2845ab2e8feb25f94a8738..c6e878a1db508e2c86bd86107d01b82a72172aa6 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- deps/v8/src/wasm/wasm-code-manager.h.orig
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ deps/v8/src/wasm/wasm-code-manager.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -474,7 +474,7 @@ class V8_EXPORT_PRIVATE WasmCode final {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ int trap_handler_index_ = -1;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // Bits encoded in {flags_}:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- using KindField = base::BitField8<Kind, 0, 3>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ using KindField = base::BitField8<Kind, 0, 2>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ using ExecutionTierField = KindField::Next<ExecutionTier, 2>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ using ForDebuggingField = ExecutionTierField::Next<ForDebugging, 2>;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span></pre><pre style='margin:0'>
</pre>