[О блоге] [наверх] [пред] [2020-07-14 11:59:03+03:00] [c5ccb1d06337fd527868c79ab391bf1a0ae3926c]
Темы: [redo][tip]

Научил clangd работе со своим кодом

clangd выполняет роль LSP сервера для C* кода. Никакой настройки не
требуется: он уже будет многое отрабатывать без проблем. Однако, если
есть специфичные пути для include-ов, о которых он ничего не знает, то
он будет выдавать warning-и на неизвестные ему вещи. Я видел что
упоминался compile_commands.json -- в нём задаются все опции компиляции
каждого исходного файла. CMake подобные файлы может делать
самостоятельно, но я его не использую. Делать руками у меня получалось,
но как-то не хочется руками вести redo- (прежде Make) based систему
сборки и ещё этот compile_commands.json. Но никто не запрещает это
автоматизировать конечно же. В https://clang.llvm.org/docs/JSONCompilationDatabase.html
есть упоминание compile_flags.txt в котором просто перечисляются флаги
компиляции общие для всех файлов. Вот такой redo целью в своём C проекте
его создаю:

    % cat compile_flags.txt.do
    redo-ifchange ../cc
    . ../cc
    echo "$PCSC_CFLAGS $TASN1_CFLAGS $CRYPTO_CFLAGS $CFLAGS -I$INCDIR" |
        tr " " "\n" | sed "/^$/d" | sort | uniq

И теперь clangd знает обо всех зависимостях, даже установленных не в
системных директориях. Для моего подобного решения хватает и оно
достаточно простое.

    [оставить комментарий]