# C API用户指导

## 基础知识
了解C API基础知识,请参考《[Native API入门](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/native-api-intro.md)》。


## 接口开放策略

### 不开放原则

1. 应用生态提供的核心特性只开放ArkTS API,不开发C API。
2. 不开发ArkUI的C API。
3. 不开发硬件底层接口(HDI)C API。
4. 不开放命令行接口C API。
### 开放原则
5. 高性能、密集计算业务场景主动开放C API,例如:需要高性能的IO、CPU密集计算等场景;音视频编解码、图形计算等场景。
6. 应用生态业务依赖的场景,主动开放高阶C API。例如:对标竞品,媒体高阶C API。
7. 应用生态框架以来的场景,按需开放C API。例如:按需开放Unity/electron/CFE框架中依赖的C API。
8. 行业约定或者标准要求的场景按需开放C API。此类C API独立发布,不放入OpenHarmony C API中。例如:金融或者安全行业高密加密算法等,按需独立发布。

### 前向兼容性原则
9. C API的前向兼容性原则与ArkTS API策略保持一致。CI流程中会使用自动化工具进行看护。


## C API接口设计规范
本规范是在《[OpenHarmony API治理章程](https://gitee.com/openharmony/docs/blob/master/zh-cn/design/OpenHarmony-API-governance.md)》《[OpenHarmony API社区规范](https://gitee.com/openharmony/docs/blob/master/zh-cn/design/OpenHarmony-API-quality.md)》的基础上,对C API设计进行的一些补充。在C API接口设计上同时满足此三份规范。

### 设计规则
* 【规则】C API相关的接口文件,包含接口列表文件ndk.json,头文件,编译构建脚本三部分;这些内容必须放置在interface_sdk_c仓中,不能对外产生依赖。三方库接口暴露规则同自研仓,接口是处理过的接口文件,不是三方库原生文件。
* 【规则】接口命名必须符合《[C API接口编码规范](./capi_naming.md)》。
* 【规则】需要发布的接口需要明确在ndk.json文件中声明列出,不允许直接发布镜像中的动态库,都采用stub动态库的方式发布。
  * json文件是一个符号描述数组,举例如下:
  ```
  [
      {
          "name": "__progname",
          "type": "variable"
      },
      {
          "name": "pthread_cond_clockwait"
      }
  ]
  ```
  name表示符号的名字,type表示符号类型,不写type,默认认为是函数;varible表示这个符号是变量。
* 【规则】C API中头文件中不允许包含不发布的接口声明,类型定义;三方库的接口文件,可
以备案保留。
* 【规则】接口必须是C语言接口,不允许出现C++元素,保证引用方是C代码也能使用;提供头文件中的接口需要用C declare声明。
  
  * C declare声明
  ```
  #ifdef __cplusplus
  extern "C" {
  #endif
  ...
  #ifdef __cplusplus
  }
  #endif
  ```
  * __反例__  
  struct/enum声明的类型,如果没有声明typedef类型,在使用时必须加上struct、enum关键字。

  * __例外__  直接提供实现库,嵌入到应用包中的接口可以使用C++元素。

* 【规则】包含C API的实现动态库放到/system/{lib}/ndk目录下。
* 【规则】每个接口都需要与syscap相关联;一个头文件中的接口只能属于一个syscap,不能包含多个syscap能力;多个文件可以关联相同的syscap。
* 【规则】自研接口按照如下文档注释写作规范进行注释,三方库接口有修改的,注释规则按照注释规范进行注释。
* 【规则】对外提供的接口,采用对外封闭,依赖倒置原则;结构体的具体实现不对外暴露,方便后续扩展修改

> 此条是《[OpenHarmony API社区规范](https://gitee.com/openharmony/docs/blob/master/zh-cn/design/OpenHarmony-API-quality.md)》规则16:注意封装:不暴露实现细节的C API补充解释。

### 兼容性规则
* 【规则】不允许进行接口原型变更,可以通过新增接口,废弃老接口的方式进行。
* 【规则】接口语义不允许变更,语义通过xts用例保持兼容性。接口涉及的结构体,枚举值变更也会影响语义,建议在设计的时候保留一些字段供扩展使用。
* 【规则】结构体成员,枚举值可以标明废弃,不建议删除。

## 文档注释写作规范
本章在OpenHarmony API社区规范[API设计概述](https://gitee.com/openharmony/docs/blob/master/zh-cn/design/OpenHarmony-API-quality.md#api设计概述)基础上,对C API的注释流程做了补充。

自研接口注释书写规范步骤:
1. 每个头文件都需要书写注释。
2. 注释书写参考 [Native接口注释规范](https://gitee.com/openharmony/docs/blob/master/zh-cn/contribute/template/native-template.md),注释命令必须按照@开头。
3. 提交注释头文件到 https://gitee.com/openharmony-sig/interface_native_header/tree/master/zh-cn/native_sdk 这个仓。
4. 等待资料审核,合入;同时翻译一份英文注释头文件到en目录。
5. 下载这个头文件,覆盖到对应头文件。