<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/77308>77308</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[clang-format] Incorrect short statement formatting with Allman (17.06)
</td>
</tr>
<tr>
<th>Labels</th>
<td>
clang-format
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
dertarr
</td>
</tr>
</table>
<pre>
Hello. Started using `clang-format` version `17.06` and noticed several strange issues. Here is one of them:
Clang formatter handles short statements inappropriately. I merged all issues with short statements in a single bug report. Here is my config:
```
---
Language: Cpp
BasedOnStyle: Google
AlignConsecutiveShortCaseStatements:
Enabled: true
AcrossComments: true
AcrossEmptyLines: true
AllowShortBlocksOnASingleLine: Always
AllowShortCaseLabelsOnASingleLine: true
AllowShortIfStatementsOnASingleLine: WithoutElse
AllowShortLoopsOnASingleLine: true
BreakBeforeBraces: Allman
InsertBraces: true
...
```
Here is the list of related issues I see:
1. Formatter treats `Allow` word in a misleading way, more like `Enforce`. I would assume that this config *allows* me to keep one-liner short statements where I want to, without complaining about also having short statements on multiple lines. Maybe it makes sense to rename the `AllowShortXxxx` options or to add value `Leave` to `AllowShortBlocksOnASingleLine` option.
2. The `if-else` expression was also shrunk to two lines despite `AllowShortIfStatementsOnASingleLine: WithoutElse` setting.
3. The opening brace for `do {` statement was attached despite `BreakBeforeBraces: Allman` setting.
4. A short one-liner version of `do-while` loop was expanded to multiple lines despite `AllowShortLoopsOnASingleLine: true` setting.
Here is a sample file (on the left) and the formatted file (on the right)
<table>
<tr><th> Sample file </th><th> Formatted output </th></tr>
<tr><td valign="top">
```
void MODULE_ShowShortBlocks(void)
{
// Short loops on several lines
while (true)
{
continue;
}
// Short loops on a single line
while (true) { continue; }
// Short case statements on several lines
switch (a)
{
case 1:
x = 1;
break;
case 2:
return;
}
// Short case statements merged
switch (a)
{
case 1: x = 1; break;
case 2: return;
}
// Short 'if' without 'else' block
if (a == 0) { return; }
// Short 'if' with 'else' block
if (z == 7)
{
return;
}
else
{
LogError();
}
// A "do" example on a multiple lines
do
{
PutItems(items, 1);
} while (false);
// A "do" example on a single line
do { PutItems(items, 1); } while (false);
}
```
</td><td valign="top">
```
void MODULE_ShowShortBlocks(void)
{
// Short loops on several lines
while (true) { continue; }
// Short loops on a single line
while (true) { continue; }
// Short case statements on several lines
switch (a)
{
case 1: x = 1; break;
case 2: return;
}
// Short case statements merged
switch (a)
{
case 1: x = 1; break;
case 2: return;
}
// Short 'if' without 'else' block
if (a == 0) { return; }
// Short 'if' with 'else' block
if (z == 7) { return; }
else { LogError(); }
// A "do" example on a multiple lines
do {
PutItems(items, 1);
} while (false);
// A "do" example on a single line
do {
PutItems(items, 1);
} while (false);
}
```
</td></tr></table>
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzsWNtu47wRfhr6ZmBDphzLufCFj90AWWyBtGjvCloaSWwoUiApO-7TF0NZPifZLBY9AH8Q2BY5M983R4kSzslCI07Zw5w9LHui8aWx0wytF9b2NibbT7-hUmYAL15Yjxk0TuoC2DhKldBFPze2Ep6NI9iiddJo2homg2hMa0JnoI2XKWbgcItWKHDeCl0gSOcadAP4hpYuwGgEk4MvsWLxjEVLFh0-F4QELZJHC6XQmUIHrjTWg_PCY4XaO5Ba1LU1tZXCo9oP4AkqtAVmIJQ6AMJO-vKeKggg1xTCpinAYm2sP7Gr9pAancvixG0cHf7DZb_fb388C100okAWz2BR1-3iXDjMfugXv1dh40_GFArbvZmShV4Y7TBtvNziC3FbCIcvR3pHUICVFhuFGRnxtsFueZZa49zCVJ08wJ39VVX7_bPU6C71Z0qZXcCdK5O-uh969hJiQbIkOlM7sXfXwkTyWWxQ3Srcs_2Unzy6Ufib9KVp_Eq5G71nY-qPEOYWxescc2NxbkXaOjdTqhK6FXjSDq0_7Z1UB4PB3Wy2n13yfYmgpPNUnxaVoD44VNMTOMSreh0OYH0sVm9ReEddERyirtgZm7UFV0mnUGTUUTuxZ3wBlbGE9YqksdK5sSmycUSlvDONykA411QIvhQefCndoSyB8ZkgAMf4DEjAwCtiTW3VV1Kjva35XUn-PcFOaA_eEPyuzQKkpqqVkJqYiQ2tCOUMlGJLKzeWjIaqUV7WishrauvvYr9BkB4q8Uq9itoFUha1CPzxGJOQ5L-_vb1RcEztpdEOjCVpkWWwFaoJws8othQM2rjQvVe0R1OHBPMB_KXFlHkfqcrGEeBbbdGFsbUTrvXRlbbRr4Thd6b1BjJ0tfRXjH-6nMcROPRe6uLAJW65mBpDgDdUmDTfyH5mgCXzoNNZb7l5L9ISs3MuHxX-DehoALND5k410Q1tk7fY_V0pVWCsjKkDML7VQmeYUUQuk3w_LB906w2nyzYT4ERF1nOpEBifGN22Huae8cdwN6Hr7k6QXQtaWZQkeTAeLzzNShavTguWruKFL1m8gpdzuHjB-DqsH_fXRyDT-LrxV0L00961HopWFprFS8a5NzXj_CR4b-Bsjczg-4_lX59X_3gpL-qa8QntnvxK5t1UZ3zN-BqCcMhYaMXuThuS1ImGxFKsQiY6WwBn1oBmiZe6QRZ3iyxZnrN-D_J47yTM9yAJ6xziE-OpcHg1ZO565nbSpyXhiJNfl26RpeHZTZT-3oDFS1qdn69uqKUu1oIyPylb9I3VZyJf86J9IPkF7meEP2L5VX6MJzJnPDmOfsaTMB55Ahuqv05L5oEmkSAeUZfQI95XgD5B-VeHkrxXqddeHrEB8PgIcaXzbIqVtcYyPiGzn0doBozzzDDOAd_aWRFq_XIMdkqZuYsKf278k8eK-li23wsY3hA4dUsuQmBO-z_J6k4HtjeTjxh8Bn2MzL3no8MMzP5_pt4XR9D_7nz7zw6JXxhif0yxyyn2Hko7r8LuzXz6bYPpMhn_9YH0O6l8YUAdn9fan4dnw142jbPH-FH0cDpMolHC-UMc98ppPBzn2UM6iTFOhqM8ytPxKMqj4ZA_IJ8k456c8oiPomE0GY4iPuSDGLNsk_DxOB-KfDJGNoqwElINlNpWA2OLXjg1TpMkjiY9FU7O4dUL5xdvUzhnD8uenZJaf9MUjo0iOn-6kyEvvQqvbS4UH5bwpFNjLab--pTWPTaHwyYVb3tQoKi272v4Y6-xalp6X4cXDiG5hfRlsxmkpmJ8TeiHr35tzT8x9Yyv25Mw4-vg1r8DAAD__10EbxY">