<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/71387>71387</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
17.0.4: `clang` python module tries to find libclang in wrong location
</td>
</tr>
<tr>
<th>Labels</th>
<td>
clang
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
kloczek
</td>
</tr>
</table>
<pre>
First of all `clang` python module tries to find not versioned libclang but `libclang.so` so I've added below quick patch
```patch
--- a/clang/bindings/python/clang/cindex.py
+++ b/clang/bindings/python/clang/cindex.py
@@ -3937,7 +3937,7 @@
elif name == "Windows":
file = "libclang.dll"
else:
- file = "libclang.so"
+ file = "libclang.so.17.0"
if Config.library_path:
file = Config.library_path + "/" + file
```
Unversioned library name is part of the clang devel resources.
Than on use installed `clang` module it tries to find `libclang.so.17.0` in /usr/local/lib.
Below is from building libdicom documentation"
```console
+ /usr/bin/meson compile -C x86_64-redhat-linux-gnu -j 48 --verbose html
ninja: Entering directory `/home/tkloczko/rpmbuild/BUILD/libdicom-1.0.5/x86_64-redhat-linux-gnu'
[1/1] /usr/bin/sphinx-build ../doc/source html
FAILED: html
/usr/bin/sphinx-build ../doc/source html
Running Sphinx v7.1.2
making output directory... done
WARNING: html_static_path entry '_static' does not exist
building [mo]: targets for 0 po files that are out of date
writing output...
building [html]: targets for 7 source files that are out of date
updating environment: [new config] 7 added, 0 changed, 0 removed
reading sources... [ 14%] api
Exception occurred:
File "/usr/lib/python3.8/site-packages/clang/cindex.py", line 3956, in get_cindex_library
raise LibclangError(msg)
clang.cindex.LibclangError: /usr/local/lib/libclang.so.17.0: cannot open shared object file: No such file or directory. To provide a path to libclang use Config.set_library_path() or Config
The full traceback has been saved in /tmp/sphinx-err-s7hvhnue.log, if you want to report the issue to the developers.
Please also report this if it was a user error, so that a better error message can be provided next time.
A bug report can be filed in the tracker at <https://github.com/sphinx-doc/sphinx/issues>. Thanks!
ninja: build stopped: subcommand failed.
INFO: autodetecting backend as ninja
INFO: calculating backend command to run: /usr/bin/ninja -C /home/tkloczko/rpmbuild/BUILD/libdicom-1.0.5/x86_64-redhat-linux-gnu -j 48 -v html
```
At the same time in system is installed
```console
[tkloczko@pers-jacek SPECS]$ ls -1 /usr/lib64/libclang*
/usr/lib64/libclang-cpp.so.17.0
/usr/lib64/libclang.so.17.0
/usr/lib64/libclang.so.17.0.4
```
It would be good to find better way to update LLVM major version number in libclang library name than what is in above JFDI patch
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJysV11v67gR_TX0y0CCTPnzwQ92EhUp0tvF3t3uY0BRY4kxRaokZSf99cVQ8lf29t72ooERm9RwOHPmzCElvFe1Qdyw-Y7NHyeiD411m4O28l94mJS2-tgUyvkAdg9Ca2CLTGpharbIoPsIjTXQ2qrXCMEp9BAs7JWpwNgAR3ReWYMVaFXGVVD2gVycx6m35MhbeGZ8eUQQVYUVlKjtCf7ZK3mATgTZsOyRZVu2yIbPzVySJCAYL4ageFEqUylTe8aLIbybZ1KZCt_T7mN0x3fDB8qfdDDL2CyDJF_nS8YflsD47vo7PhwMAbXagxEtAssfWf4IjPM_lKnsyTPOWb4d7W7_9kpHc7K94FVpTQvOXj1e1iY_XOvtZSkl_WPzdLpMs-ua-xDVHh6s2as61ap0wn28diI011QuPr9hRUDRXowXjPM4IvNPVR6Gv5s7GpGPAUnloRMuEjM0CAO_KjyiBofe9k6iT29D_60RBqyB3iMo44PQGqs7Qo9MVuETme8ZO8CyyEAZYLzovWO80FYKTd-qHDfdRRIrD3tnWyh7pYlXlEOlpG2hsrJv0QQRFJGMf8peWuPtBZOI17hVqYiTLXprQNq2I6CTB3hfLV4Xs8Rh1YiQaGX696Q2PSRvMFtBkhzRldYjNKHVg1ejzJtg-RaeTEBHwVXKoQzWfVDKjBeNbZHxIkQ9OFjGC9e1MRXGi93vzy-PQ8oxo2SaZumc8eI_RML4csxmvpsyXkzZ_PFzVr5rlHlP4haQpowXlZU0H-t5E3uxfX55eqTgr3M_6-vX3hjK_mtcAMdlOk3HcrTiQE9sH7o-XOFJ0xQqa8bq_LH99cvzl7-cg3n1VFM5MB1NIDT5cpxlfAmVRR8FEt-VD4OPCz_YfNdaNo-pBeFqDB721kEGnY1d4iE0IoBwSGER_SsRxkhOToVrvGma_tl5TPvP7pcwwvKjLfquEnEPNEflrCEKkzM23xk8gYzdTpVdDmLO-ANkIBth6vPAYWuPWA3-HIoY2rlj05RcwXTG-JzciE4Nhk_vEjvqFbBS9s5hdaObRVSbqChjP6ryouB5uqKyq4BJJ-RB1Oi_Keq0_AG0Mgj5er6ggTJQY3gdbF5H_bkqoRPKI7yM2vDknHWMr1pfM74erAbRGPe4NyTQviEfw_97scm3IIUhytgODfhGOKzAlm8owyCd-Ra-WPC9bAblte6GrfCbhc7Zo6oQBEReBns9lEkQR5X2GF7v9JyvGF-Tt8HgrKQI-15rCE5ILIU8QCM8lEixiSNWozSGtrv2ITqX-GVzbEyPqbZ1hHcPH7aHkzCBInLYWReinCvve6Q5GkRVtx26s6D_olF4BKH9zSLlyZ8KcBIeBGXlAIeSPNAVY-A0lBjC-Qm06L2okdCFEs8gVWDwPUBQLY4bbqHs6_NWozHhHDOlEAmJAzoQAVj-0ITQeaInHXBFrULTl6m07RWNUYrigPEiputZ_pQCHVMHz_j0k0gPOuaD7bpIffB9KW3bClPBXlAsY6zPX4q_03PRB1thQBnblaqEpgLhYXB5ZyuFlr0Wd5Zn51SY3tzRdRDY6IeOnv_3SXE-s4634n5_LdgONPF0E6A6UR38hw_Y0pF7Od6_e6jOd5dwZxmxK3kTEg_w9Zenh6-kkXwG2kMyhVtZWcxuOpTx7aez57NFIrvu0sffN_0fzdLZN5EZCxvgZHtNd2mora0ud5mR_ifxQVNRzRFeXv7xN2jFm3XnSzuYvi3REawXnbi7fgW6TZ2opSLeIEp7RPhr8fg8XNkn1Sav1vlaTHAzXazXfDmbrrJJs5FlthK8lBzzfMEX2XI1z_OVlJmYl3uxFhO14RnPp9NsMeX5gmfpPJOr_Xy2WM32q9VsWrJZhq1QOtX62KbW1ZPYPpvlNF8tJ1qUqH18oeF8LBKndxu3Ifuk7GvPZplWPvirh6CCxs0IK1H9v3zPuYCjDJycJZSsjFe6Se_05jtCQFuPX0nnLEn5VQh4EZP5dwAAAP__aa1RtA">