<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/97756>97756</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
ms mangler for template values: poor nyi error messages and nyi opte pointer
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
memory-thrasher
</td>
</tr>
</table>
<pre>
## I am reporting this bug for completeness. I am actively working on a patch submission.
The official MSVC mangler lacks support for some c++ that is valid according to the standard, clang, and every decent compiler. Concerning template instance name mangling, specifically, there are presently 6 cases where the function MicrosoftCXXNameMangler::mangleTemplateArgValue gives up mangling and emits the rather unhelpful error:
> cannot mangle this template argument yet
I improved that error message on my local build to tell which of the 6 possible cases I was running into. That case is when the non-type template parameter's value is an l-value point to one-past-the-end of some constexpr array. This case is not possible in c++ code that supports the official MSVC compiler, so consistency with MSVC is both impossible and uneeded. Furthermore, templates are not generally called across an ABI boudnary, but rather, each binary contains its own instances.
I arbitrarily chose a mangling pseudonym to represent this case. I foresee two potential future issues, though both seem to me to be highly unlikely and neither, any worse than failing to compile the code in the first place.
* Compatibility between binaries output by clang using this patch, with binaries produced by some other compiler or future version of clang that might use a different arbitrary pseudonym. I doubt this case will ever happen because for the reasons already declared above; each binary should contain its own template instance with its own mangling rules.
* Collision between two template function instances of the same template function where the template argument for each is the OPTE value for two different arrays, and that is the only difference between the instances, and yet the two instances should have different behavior. I cannot think of a good reason the two functions should have different behavior when handed a pointer that is essentially invalid (does not point to a usable resource). Even a reverse iterator has better solutions.
The patch will include a minimal test case.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJyEls1u67wRhq9G3gxs2HJixwsvknwnQBanLdDgw9mOqJHIhuII_LGruy-GtOQEWXSjRJY4P-88fCkMwfSO6Fw9vlSPf60wRc3-PNDAflpH7TFo8quG2-lc1fuq3sM74ACeRvbRuB6iNgGa1EPHHhQPo6VIjkLYlDdRRXMhO8GV_acsYAcII0alIaRmMCEYdptq-1e1fS7XD03AXWeUQQu___33KwzoekseLKrPACGNkj1nDDwQqKp-qeoXiBojmAAXtKYFVIp9m2tkiJogRHQt-raqX0FZdL38g64FupCfoCVFLuYejCW_gVd2irzLEWgYLUYC4ySKInA4UKnLlEBhJGU6o9DaSe6jJk-AnmD0FMhFO8EBFAYKcM3PpKYuORUNO_htlOfAXXz98-cfONDv0nK1f672z6X_j1sRz77_G20i6M2FAqRxqaN0M5gYcnCPUgQkp8mOXbJA3nMOWdTe_wKFznG8CVyGufSKvk-DSDJR_DqfdzDD6PlCbVE8R4WBQsCeZL7DBJYVWmiSsW2Wn6yFqzZKA3e5tgOMHIJpLN00eYcrBvDJZcGNi7yBDwkvj2WqV00uL3Xs1nEa6V7piB4HiuSr-pjHn_IKdGDX5W5k46JUwo7WI4a4jprW5Fqpp0DELkT67-gBvcdpA_AhaszZRaWlYuMW5hS3VGS4YVmk_87vzFTmhHMqEyI5NcHVRF1ekn3EUYu4cx4ZZ3JELbUbeEtexjmwp8zXrfmQGZPyenLkBT8QCEl2gOeQZXh-eYeGU-vQZzibFG90yB2h0tAYeSi1RTQugEDEV7cQHzbfGUDfmOjRG8mnORDgncMxUGrZTYNI7um2AwpfoqiYQ8fyK0G8MowcyUXRq0sxeVE8JAplH3HqdZEmEOWIA8m1IdCm13aC5Kz5FJMRwRyZuTF02XdCnpCDDo29-cFtInlWeYSmsNUZHyKMFhXN_dbP8MrDiNE0xpo4QUPxSuSKYoYCcIpjitBMxVYghcUZs9FJKXnOy4rRc5sUtbIm08d5p86cAPtZiAt5MUjBtATPrA2m1xFSFr01XUde5J1HMt31F6FbTs0X7eFqrM2eBxrHURohhRJLDDX7BmFgFwCtJ2yzM1r0AlTDF6r2L9-ICZqTbWdwFm5-WmaWYH68oOKTvbOVtbbW5JZnnQWQJdpimAuXs6MEceSf79299qexScO5FVN27T__9fHrZh9Ziyt_U9fjFOYzYz5r8mZ3dlpeVHQvXN-7XxZOFEs1V_7Sw01EjRf6krIhjRfDXqZ4c-qojfuUlhF65vY2qyXi3Pb_i1jcVKNrZazFHskvXVEIZT_aCYwr52lVP7VMsxPe7BQhBRSr8hQ4eUVVfdrArwvJKe8FMrHPSB4jC29BxJFMgW3Khf44-su3QYbUOGVTm53FODOghUihnAibVXvet6f9CVd03h3r7W533O6PK30-HA-HZt-pjnaPp4enU7NDpej0pOip7nbddmXO9bZ-2B63D7un3XF32OyI1ENzqBUd8did2uphSwMau7H2MmzY96tsR-fT8fh4WFlsyIb8xVTXjq7Fq6q6lg8of5Y16yb1oXrYWhNiuEeJJlo6D2H5nsmQzVRm7kK1f4aR2YObzPeTNRR3mwzwGGke2Sp5e9YxjrKyqt-q-q03Uadmo3io6jdJfvuzHj3_h1Ss6rfZXt9KS5dz_b8AAAD___3Mlqg">