<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/58066>58066</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Misleading error message "returning ... from a function with incompatible result type ..."
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
Keith-S-Thompson
</td>
</tr>
</table>
<pre>
```
$ clang --version
clang version 15.0.0 (https://github.com/llvm/llvm-project.git 4ba6a9c9f65bbc8bd06e3652cb20fd4dfc846137)
Target: x86_64-unknown-linux-gnu
Thread model: posix
InstalledDir: /o/apps/llvm-15.0.0/bin
```
When I compile this C source file:
```
double bad(void) {
return (void*)0;
}
double good(void) {
return 42;
}
```
I get this error message:
```
c.c:2:12: error: returning 'void *' from a function with incompatible result type 'double'
return (void*)0;
^~~~~~~~
1 error generated.
```
It's true that the `return` statement violates a constraint, and it's true that `void*` and `double` are incompatible types, but type compatibility is not the requirement here. The problem is that there's no implicit conversion from `void*` to `double`.
(clang++ does not have this problem.)
In the `good()` function, types `double` and `int` are also incompatible, but the `return` statement is valid because there is an implicit conversion from `int` to `double`.
The C standard's definition of "compatible types" is quite narrow. See C11 / N1570 6.2.7.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJyVVE1v2zgQ_TXyZWCC-rYOOrRJCwSL3UsD7HFBiSOJuzTpkpST_PsdSnJSp2naGrREcTgz7z3OsLPyqU0qvg1-m_APSVZAr4UZYb8_o_PKmtWwLm5LkJaMMw5JdphCOPkkJ8fPNEYVprljvT3Sh9bny2t_cvZf7AOjDVB0ohJN3wxV2XX9oZO8wrwqs77L-CALOfSHokrzOsmaNfe9cCMGSgKPh-qfqtjP5j9jH8xeKzM_7kczb_smh0LC0UrUcffJevW4mu6MD0JrlLfKRRPhsvQXJwK_QVw50VenNs6vtVmef09o4A6I4klphDApDzfg7ex6hIGWohhvuUs7d-TQCUmyna2iVwNJ_XG1Av0chtkZeDaTqA1P8m1HUt9-i2MLN1r7s3hF9kaMa2x3QAKvXNA56-CI3ovxh1x61pOJ4n5I42N1ipM1paJSSbI6goKFRg2Ds0cQMMymD7GCHqhSQJkoowgqMnHoZ00gnk4YnVd-NPlVfeDll5SfkvqtsWxMN44jGnQioGTvHPddIAgegpvjWYsoEsGr-IqFJkCFFfCIJsBZWU1zTzx7SwXnhDLkfgPCSFCvA5HvhQZFiVvovbGOCw6v9YnC-BitmzeVLkalVXgCOjtjV3wOv87KraAmdMjgnlapBynOMW68MHG4gDIW1PGkVU_dScgvXb6c2TXMYK9Qsm-lonNZbokk-0gDpMUV0STOW59sCNhzZ1-a86LqVs3RTskuxRJJL-xfKbRKFjXe9BLa2yvRnuX68aERrLPQVKgd9mL2uMoSl4V5V5Ut73uKRNVvYi4jhZOL1BIHZdTSAnagUs6-P-EsJqcDDAhGUKU-MPiCFChN47UFf6VlzaFiGavZDtu0qoqirstDvZNtLpu8Ebuggsb2T-U13YexGa-aOmZ96VPG2G82J3lQhN3sdPt7tz99Ku_nyPFzeeBVtZta2Yuc85QTct7XfOiatOe5kEUZaRXVTosOtW-TkooqM_gASwiaJ-XtTrUZzzLeZE16KHNeMz7khzTPyypP87RvMCk4HoXSLOJg1o071y6Qunn0ZNTKB_9iFN6r0SAu6Si-mMNkXfsHErP9l_39RIp4a3YLhnbh8D_JBDma">