10个版本 (4个重大更新)
| 0.5.0 | 2022年1月25日 |
|---|---|
| 0.4.0 | 2022年1月14日 |
| 0.3.3 | 2022年1月9日 |
| 0.3.2 | 2021年12月22日 |
| 0.1.1 | 2021年11月24日 |
#539 in 内存管理
每月25次下载
用于 4 个库(3个直接使用)
28KB
527 代码行
关于
NSTD是一个旨在跨平台的库,相当安全(任何可能失败的函数都将返回一个错误代码,指示它是否成功),同时具有许多功能和功能。目标是拥有一个适用于任何平台、任何语言和任何用例的单一API。
平台支持
可以使用 core 模块在 任何地方。它不依赖于 任何 其他库,包括标准库(除了头文件 stddef.h 和 stdint.h)。其他模块将在 大多数 平台上运行,并且已测试过在Windows、macOS、Linux和Redox上构建。
模块概述
nstd- 基于CFFI的跨平台库。alloc- 堆分配。allocator- 自定义内存分配的vtable结构。heap- 与Rust的Box类似。
audio- 音频I/O。def- 常用的音频相关类型。device- 音频I/O设备句柄。host- 平台的音频宿主。player- 音频播放器。queue- 音频流的队列。stream- 音频I/O流。
collections- 集合类型。bit_mask- 具有小型内存占用的可定制位掩码。rc- 通过引用计数共享内存。stack- 可增长和缩小的堆栈数组类型。
core- 包含不需要操作系统的模块。char_types- 特定于字符类型的函数。cstr- C字符串检查。def- 常用typedef。float_types- 特定于浮点类型的函数。int_types- 特定于整型类型的函数。math- 低级数学。platform- 平台识别。pointer- 指针类型。range- 范围类型。slice- 内存视图。str- UTF-8字符串切片类型。
env- 环境特定功能及识别。events- 事件循环。def- 事件系统使用的常用类型。device_id- 用于识别设备的类型。window_id- 用于识别窗口的类型。
fs- 文件系统。file- 文件I/O。
gl- 低级图形库。buffer- GPU VRAM缓冲区。command- 设备命令。buffer- GPU命令缓冲区。encoder- GPU命令编码器。
def- 常用的图形相关类型。device- 用于处理图形设备的模块。handle- 图形设备的句柄。info- 图形设备的信息。
instance-wgpu的实例。render- 渲染。pass- 包含处理渲染通道的函数。pipeline- 渲染管线。
shader- GPU着色器程序。module- 着色器模块。
state- 图形库的状态机。surface- 与显示表面的交互。config- 表面的配置。texture- 表面纹理。
texture- 用于处理纹理的模块。format- 纹理的数据格式。view- 纹理视图。
gui- 图形用户界面库。display- 显示/监视器句柄。window- 窗口和表单。
image- 原始图像数据IO。input- 键盘/鼠标输入。key- 键盘类型。mouse- 鼠标类型。
io- 标准I/O。input_stream- 输入流类型。io_stream- 输入输出都适用的流类型。output_stream- 输出流类型。stderr- 标准错误流。stdin- 标准输入流。stdout- 标准输出流。stream- 基础流类型。
math- 高级数学。net- 网络。tcp- TCP网络。udp- UDP网络。
os- 操作系统特定功能。linux- 对Linux的OS支持。alloc- Linux的底层内存分配。
windows- 对Windows的OS支持。alloc- Windows的底层内存分配。heap- Windows堆管理。
def- 常用Windows类型定义。io- Windows标准I/O。thread- Windows的线程支持。
proc- 进程管理。rand- 随机值生成。string- 动态大小的UTF-8编码字符串。thread- 线程API。time- 获取系统时间的库。vec- 动态大小的数组。
构建方法
cargo build --release --features ""
在“--features”之后,在引号内,您可以使用空格分隔每个模块,并使用“nstd_”作为前缀,尽管nstd_os模块略有不同,并且有自己的功能,如nstd_os_alloc,它可以单独启用,不需要nstd_os。默认情况下构建nstd_core。如果要构建nstd作为C库,还应该使用“clib”功能,以构建适用于C ABI的模块。
示例
cargo build --release --features "clib nstd_alloc nstd_os nstd_os_io nstd_string"
或者您也可以使用
cargo build --release --all-features
来构建所有模块。
依赖项
~0.2–25MB
~321K SLoC