概述

  Sysroot 是具有特定逻辑布局根目录兼容的目录,一般在文件系统中实现。

  Sysroot 主要用于本机程序的开发环境构建和部署,以后也可能用于交叉构建(cross building) 。

  在利用 Sysroot 开发之前有必要了解开发注意事项:

  Sysroot 使用的文件系统路径满足运行环境对外部文件的路径的约定。

  当前 Sysroot 仅支持 MinGW 和 Linux 环境。

  关于本文档讨论以外的脚本的其它行为,参见脚本的有关说明。

布局

  在满足前述要求的前提下, Sysroot 部署实例使用的文件系统布局原则上和一般类 UNIX 系统使用的布局同构,具体子目录布局如下:

  • .shbuild :使用 SHBuild 构建时的临时目录(可以在部署后手动删除)。
  • 系统前缀字符串指定的作为安装路径前缀的最后一个路径组件的目录文件名(如 usr ):被部署的用户空间目录,其中的内容使用 Linux 等现代 UNIX 变体类似的约定:
    • bin :二进制文件。
    • include :头文件。
    • lib :库文件。
    • share :共享的数据文件。
      • share/NPLA1 :NPLA1 脚本部署位置。
    • var :程序运行时可修改的数据。

  其中,除 var 外,这些目录中的内容在安装或维护部署情形外通常应保持只读。

  对 MinGW32 和 MinGW64 平台,系统前缀字符串指定的路径和 MSYS2 构建系统的 /etc/msystem 脚本指定的 MSYSTEM_PREFIX 的值一致,对应 MSYS2 支持的两个 mingw 子系统路径

  上述 bin 目录可以加入环境变量 PATH 中以便其中的程序被命令行执行。当前若使用 YDE 构建脚本,这是必要的。

安装脚本

  YSLib 项目提供生成可打包的 Sysroot 的安装脚本,位于 Tools/Scripts/install-sysroot.sh 。输出的 Sysroot 的默认位置为版本库根目录下的 sysroot 目录。安装 Sysroot 时构建和部署多个项目,详见以下各节。

基本安装

  使用 SHBuild 构建和部署运行环境,包括库和工具。

建议阅读以下关于选项以及脚本说明后再运行命令。

  可进入 bash 运行以下 GNU bash 脚本:

Tools/install-sysroot.sh

  直接在默认输出位置构建和部署基础环境。

注意 当前构建脚本默认使用 uname 判断目标的体系结构。对于 MSYS2 等环境,结果为基本系统的体系结构而不一定和目标系统相同。若使用 64 位基本系统构建 32 位目标,使用以下命令代替:

SHBuild_Env_Arch=i686 Tools/install-sysroot.sh

  此处自动环境检测的机制同 shell 脚本 Tools/Scripts/SHBuild-common.sh 中的函数 SHBuild_CheckUName ,详见脚本的说明。

构建和部署

  构建过程包括 SHBuild 可用的多阶段构建

  构建时在 Sysroot 输出目录种保存中间输出。当前不清理这些中间输出。

  通过脚本选项,在 stage 2 SHBuild 需要的库时,也可生成其它的 YSLib 库(静态库和调试版本的库)。

  YSLib 库和依赖的外部的第三方库的二进制文件和对应的头文件在构建后被部署到 Sysroot ,并在之后用于构建 stage 2 SHBuild 。

  完成构建 stage 2 SHBuild 后,脚本部署 stage 2 SHBuild 和脚本(参见以下节)到 Sysroot 。

脚本部署

  在 stage 2 SHBuild 构建后,部署 SHBuild 同时安装(复制)版本库中的以下位置的 脚本文件(无视路径前缀)到 Sysroot 的对应安装路径:

  • NPLA1 脚本安装到 share/NPLA1
    • Tools/Script/SHBuild-BuildApp.txt
    • Tools/Script/SHBuild-YSLib-common.txt
  • Shell 脚本安装到 bin
    • Tools/Script/SHBuild-common.sh
    • Tools/Script/SHBuild-common-options.sh
    • Tools/Script/SHBuild-common-toolchain.sh
    • Tools/Script/SHBuild-BuildApp.sh
    • Tools/Script/SHBuild-BuildPkg.sh

可选工具

  通过脚本选项,在部署 stage 2 SHBuild 后,也可安装 Tools 下的其它工具:

构建时的警告

  除引导 stage 1 SHBuild 最后的链接器警告外,因为升级或更换编译器和/或选项,导致预编译头文件( .gch 文件)不能被识别的警告也可被安全忽略。

  • 此时编译器应能自动忽略这些文件。
  • 若需要预编译头文件在后续重复构建时的性能提升,可以清理这些文件,一般在对应项目生成的相同目录;可手动搜索构建目录中所有 .gch 文件并删除后再运行构建脚本,默认包括以下位置:
    • 项目中的 /Tools/SHBuild 用于 stage 1 SHBuild 构建。
    • 项目中的 /build 构建目录。
    • 安装 stage 1 SHBuild 后默认在部署的 /sysroot/.shbuild 继续构建目录。
  • 若不需要使用预编译头文件,可参考脚本说明设置变量。
  • 若仅需避免产生警告,确保编译器命令行使用恰当选项,如添加 -Wno-invalid-pch

注意 预编译头文件不保证对不同的 Windows 系统版本兼容,参见先决条件中 PC(Win32) 平台关于操作系统版本的说明。

Sysroot 开发指令

  使用 Sysroot 开发,首先需安装 Sysroot 环境,参见以上安装脚本的说明。

应用程序构建脚本

  YSLib 应用程序可使用 SHBuild 构建。为简化构建流程,使用应用程序构建脚本包装对 SHBuild 的调用。

  应用程序构建脚本不限制实现使用的语言,但在版本库中提供的脚本应符合公共的约定;此外,具体脚本可能需要指定适当的 PATH 以确保外部的工具可被调用。

  典型地,应用程序构建脚本是 shell 脚本,可依赖 Sysroot 环境已构建的 Sysroot 环境,并调用 NPLA1 脚本。

  YSTest 支持使用脚本 /YSTest/SHBuild-YSTest.sh 构建,可作为例子参考。和其它在安装脚本部署的 stage 2 应用不同,当前默认情况下使用版本库中的 build 目录下的平台目录存放生成的文件(中间文件和生成的可执行程序示例)。

部署

  除安装脚本外,当前不提供直接部署程序。

  参照运行确定二进制依赖项位置和调整运行时的配置。