1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-01-26 15:30:04 +08:00
SpaceVim/docs/cn/layers/lang/c.md

84 lines
1.7 KiB
Markdown

---
title: "SpaceVim lang#c 模块"
description: "这一模块为 SpaceVim 提供了 C/C++/Object-C 的开发支持,包括代码补全、语法检查等特性。"
lang: cn
---
# [可用模块](../../) >> lang#c
<!-- vim-markdown-toc GFM -->
- [模块简介](#模块简介)
- [启用模块](#启用模块)
- [功能特性](#功能特性)
- [模块配置](#模块配置)
- [快捷键](#快捷键)
<!-- vim-markdown-toc -->
## 模块简介
这一模块为 SpaceVim 提供了 C/C++/Object-C 的开发支持,包括代码补全、语法检查等特性。
## 启用模块
可通过在配置文件内加入如下配置来启用该模块:
```toml
[[layers]]
name = "lang#c"
```
## 功能特性
- 代码补全
- 语法检查
- 代码格式化
## 模块配置
- `clang_executable`(字符串)
设置可执行程序 clang 的路径。
- `libclang_path`(字符串)
设置 libclang 的路径,默认情况下该选项值为空。
- `clang_std`(字典)
该字典存储编辑不同 C 家族文件类型时所使用的标准库。默认值为:
```json
{
"c": "c11",
"cpp": "c++1z",
"objc": "c11",
"objcpp": "c++1z",
}
```
- `clang_flag`
通常,在项目根目录新建一个 `.clang` 文件,可以将编译参数逐行写入。也可以使用一 List 值来初始化该选项。
例如:`clang_flag = ["-Iwhatever"]`
以下为一个完整的 `lang#c` 模块载入示例:
```toml
[[layers]]
name = "lang#c"
clang_executable = "/usr/bin/clang"
[layer.clang_std]
c = "c11"
cpp = "c++1z"
objc = "c11"
objcpp = "c++1z"
```
## 快捷键
| 按键 | 描述 |
| --------- | ------------------ |
| `SPC l r` | 编译并执行当前文件 |