<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/77452>77452</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Include cleaner not properly respecting "-nostdinc"
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
FluffyFoxUwU
</td>
</tr>
</table>
<pre>
My environment is my own kernel development and naturally would includes `-nostdinc -isystem <src dir>` in C flags. I have `Diagnostics.MissingInclude = Strict` and also use `-isystem` due my preference to use `<header>` in kernel developments.
I typedef'ed equivalent C's fixed types (like `uint32_t`, `uint64_t`, etc) in different header file name as those C's fixed types doesn't exist in `-nostdinc` mode.
When I opened this `main.c`. Clangd's include cleaner was suggesting to "fix" by including `<stdint.h>` when obviously I already included my own `types.h` and `stdint.h` doesn't exist.
The expectation: Include cleaner to not suggest any fix
The reality: Include cleaner suggest wrong fix when clearly `types.h` provides it and `stdint.h` doesn't exist
Reproducible sample:
types.h
```c
#pragma once
typedef unsigned int uint32_t;
```
main.c
```c
#include <types.h>
// No header providing "uint32_t" is directly included (fix available)
// (clangd missing-includes)
static uint32_t userOfUint32;
```
Clangd Version: 17.0.6
Additional note I found during writing of the sample:
1. When I used `"types.h"` instead `<types.h>`, include cleaner wrongly mark it as unused
2. Also happen if I used identifier from C standard (like `uint32_t`, `fopen`, `fflush`, `errno`, etc) with same "fix" suggestion but from respective header (like `errno` suggests `errno.h` header)
3. It doesn't happen if I use non C standard's identifiers (I have tried use "ffi_call" from libffi's "ffi.h" but no fix was suggested)
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJyMVk1v4zYQ_TX0ZRBBphzZPviQddaAD9sCbbc9LihxKE2XIlWSsqN_X5CyHCXZLgoECfgxM-8N3zxFeE-NQTywx0_s8XklhtBadzjpQanxZF--Xr-uKivHw5cR0FzIWdOhCUAeuhHs1cB3dAY1SLygtn06FEaCEWFwQusRrnbQEsjUepDogZX5g7E-SDI1PJAffcAOWHH0rgZJjhWfWZkDGTiC0qLxGZyhFReMkc8kmhhMtc--kPdkmvOUGFjxDL8HR3WI4RGC0N7C4FPgXCieyQEj-N6hQoemRgj3e6w4tigkLmB8JOgzlj-z_Gn6fYYw9ihRMb5FCfjPQBehYx-OjG89KHpBme54YHyn6XuqNJAJBf8W0TJ-nHfKzX0HQ834PiKQpBLSABM2UKQRjOgQhIfQWo8_qCUtesP4NgC-kA8x0bL3kV1nJb7h8leLBs5gezQxT0vpvTpBJosBGRy1MI1MtW4vCrVGYdDBVXjwQ9OgD2Sa2FPGuaIXxjlU4-16PJnanFCErL01-hor2-pCdvB6hDMI7VDIOQ7lrDdW5olf1s7vzMr8niw-71veb_j90SLgS491EIGsYcUTnN_RCBaMDTMTEGaMXX0Ndyg0hfFHoXPM1VnTxKiJVTx2enyHvHf2QnEgKPwPFksSv2HvrBxqqjSCF12vkRVPyxtzmWmrzKef-rbmRe9E0wmwpsb3YRIVDCaZQhzaAHedFp_e5VuG3iTyXwXpPqTHGVvxeRnP-InxE_xiZ4lP7Uly4fyOgfPoPJIc1kEvtMH4LrZbXARpUWlkfP8mL-O7OikXusk1HmY_ut_0URL1nW40BPer-pqWP-c-zQT8ic7fNLXeZnlWLu88SUlRcUJHdSGcQdnBSJCDixyvjtLQWAWh_fCo6wxugzl4TEphnM995HzyKR9QyNtsLXo8ecmHWY0K1SN0wn1PAvQwmJh8KsgzeIrm2Yq-RwOk5tIk0QRSFD3I2Q6O4IMwUjj5c2tT0VEWS6UH376u0Tlj39relUIb-4ALF5ndxRqohjAhcOjjONMFZ-UsgMx550h_35yG7Gb1swSKDM5hMXnv6IOxZsF4MsF7Q5K5375UwRHK6ZPCuVL0rRZaRwYJsqZKKUrh03F6xUTJ2Mk2Xq0UJeP7lTwUcl_sxQoP622-2eV8vS9X7YFvVV6IncrF47aqNutK7lQtldjvy3K7WfMVHXjON_k63695vn8sM7XFcrfOxb5U9bYot2yTYydIZ1pfusy6ZkXeD3jYbjePfKVFhdqnfw44N3iFdBg19_i8cocY81ANjWebXJMP_jVLoKDx8N4ho7P2zvYY_XB-umnGXz9MnK8Gpw9tCL2PM5BGuKHQDlVW247xU6xy-_PQO_s31oHxU8LmGT8l7P8GAAD__wHa1MM">