# keil-autopiler
**Repository Path**: zhang_bin_bin/keil-autopiler
## Basic Information
- **Project Name**: keil-autopiler
- **Description**: 一个基于 keil 的自动化编译代码的脚本
- **Primary Language**: C
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 54
- **Created**: 2024-11-09
- **Last Updated**: 2024-11-09
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# Keil-Autopiler v1.2
## 1 需求来源
部分对开发流程有限制的公司是将开发与编译(提交后的代码版本)分开的,要求编译过程尽可能少的人为参与,需在程序上实现代码的自动化编译。基于此需求开发了本脚本。

## 2 介绍
这是一个 `keil` 的自动化编译脚本,可被其他脚本或程序调用,接收参数并按参数编译 `keil` 工程,而不必打开 `keil` 软件,实现程序上的自动化。主要实现了以下功能:
1. 自动搜索脚本所在的目录下所有的 `keil` 工程
- 搜索到多个 keil 工程时, **若未指定工程,则默认选择最后找到的 keil uvproj(x) 工程**
- 指定 keil uvproj(x) 工程时支持 **相对路径** 和 **绝对路径**
2. 可指定 `keil` 版本进行编译
- 可直接输入以指定 `keil` 软件路径,如: `C:\Keil_v5\UV4\UV4.exe`
- 当 `keil` 安装路径以 `X:\Keil_vY` (X: 盘符; Y: 4 或 5)开头时支持模糊输入(模糊输入如: `4` , `K4` , `Keil4` , `Keilv4` , `Keil_4` 等)
- 当 `keil` 的安装路径和本案例中的 `D:\Keil_v5\UV4\UV4.exe` 路径不同时,除非修改代码中的 `keil` 软件路径后重新编译成新的 `.exe` 或在系统环境变量 `Path` 中设置好路径,否则必须指定 keil 软件的所在路径
3. 可选择 `project target`
- **未指定则默认选择 keil 工程中最后一个 `project target`**
- 支持非法字符识别并报错
4. 编译完成后自动将 `.bin` 和 `.hex` 文件拷贝至脚本的同级目录
- 仅拷贝选定的 keil 工程编译出的 `.bin` 和 `.hex` 文件
5. 自动从系统环境变量 `Path` 中搜索 `keil` 的 `UV4.exe` 程序
- v1.2 新增功能
- 不需要此功能忽略以下说明
- `keil` 安装后不会自动设置环境变量,需要手动设置,可参考本文 5.1.3
- 本脚本仅在系统环境变量 `Path` 中搜索
- 参考值: `C:\Program Files (x86)\Keil_v5\UV4` **(必须是目录)**
## 3 有哪些参数
| 序号 | 描述 | 典型值 | 是否必须 | 备注 |
| :---: | --- | --- | :---: | --- |
| 1 | keil 版本 或 keil `UV4.exe` 的绝对路径 | 1. keil 路径与本脚本一致:`4` 或 `5`
2. keil 路径与本脚本不一致: `C:\Keil_v5\UV4\UV4.exe` (示例) | 否 | 1. v1.2 支持自动从系统环境变量 `Path` 中搜索
2. 脚本优先使用指定的 keil 路径 |
| 2 | keil project target | release (示例) | 否 | |
| 3 | 指定 keil 工程的相对路径或绝对路径 | 以 `.\` 或 `..\` 或 `C:\` 开头 | 否 | |
> **说明:** 本脚本的所有参数可不按顺序输入,为空时表示选择默认值,但参数与参数之间需用**空格**隔开
## 4 我想直接用
0. 本脚本仅支持 `windows` 系统且要求已经安装了 keil 软件
1. 在发行版中下载可直接运行的 `.exe`
2. 将 `.exe` 脚本与需要编译的 keil 工程放在同一级目录(下称目录 A )
3. 打开 `powershell` 或 `cmd` 并定位至目录 A
- 若使用 `powershell` ,可在目录 A 空白处按住 `shift` 键同时单击鼠标右键选择打开 `powershell` ,将自动定位到目录 A
4. 执行脚本
- 案例一:
- 只有一个 keil 工程 或 搜索到的最后一个工程就是要编译的工程
- 只有一个 project target 或 keil 工程保存时已选中需编译的 project target
- keil UV4.exe 的路径和本脚本一致 (`D:\Keil_v5\UV4\UV4.exe`)
```
.\Keil-Autopiler.exe
```
- 案例二:
- 指定 keil 版本
```
.\Keil-Autopiler.exe 4
(注:keil UV4.exe 的路径和本脚本一致或系统环境变量已设置才可使用本条指令,否则使用下条指令)
```
或
```
.\Keil-Autopiler.exe C:\Keil_v4\UV4\UV4.exe
```
- 案例三:
- 指定 keil 工程
```
.\Keil-Autopiler.exe .\Code\Project\MDK\template.uvprojx
```
或
```
.\Keil-Autopiler.exe C:\Users\Administrator\Desktop\test\Code\Project\MDK\template.uvprojx
```
- 案例四:
- 指定 project target
```
.\Keil-Autopiler.exe release
```
- 案例五:
- 指定 keil 版本
- 指定 keil 工程
- 指定 project target
```
.\Keil-Autopiler.exe 4 release .\Code\Project\MDK\template.uvprojx
(注:keil UV4.exe 的路径和本脚本一致才可使用本条指令,否则使用下条指令)
```
或
```
.\Keil-Autopiler.exe C:\Keil_v4\UV4\UV4.exe release C:\Users\Administrator\Desktop\test\Code\Project\MDK\template.uvprojx
```
5. 编译时间与编译器版本、编译选项和代码量有关,需耐心等待。(可打开同级目录的 `keilx_compile_log.txt` 查看编译过程日志)
6. `powershell` 或 `cmd` 打印内容出现 `Copy above file(s) SUCCESS` 的字样表示执行成功,并将对应 keil 工程生成的 `.bin` 和 `.hex` 文件拷贝至脚本的同级目录中

## 5 我想自己编译这个脚本
**本代码仅支持 windows 系统**
### 5.1 预备操作
0. 如果你已经安装了 gcc ,请忽略本步骤
1. 下载 gcc 编译器,为了考虑兼容性,这里提供一个 32 位的 mingw 下载链接: [i686-13.1.0-release-posix-dwarf-ucrt-rt_v11-rev1.7z](https://github.com/niXman/mingw-builds-binaries/releases/download/13.1.0-rt_v11-rev1/i686-13.1.0-release-posix-dwarf-ucrt-rt_v11-rev1.7z)
2. 解压后放在任意路径,此处以 `C:\mingw32` 为例
3. 配置好环境变量

4. 打开 `powershell` 或 `cmd` 输入 `gcc -v` ,出现下图内容表示配置成功

### 5.2 编译
1. 打开 `powershell` 或 `cmd` 并定位至代码目录
- 若使用 `powershell` ,可在代码目录空白处按住 `shift` 键同时单击鼠标右键选择打开 `powershell` ,将自动定位到代码目录
2. 执行以下 gcc 命令
```
gcc .\Keil-Autopiler.c -o .\Keil-Autopiler.exe
```
3. 无任何提示信息,编译通过

## 修改记录
| 版本 | 日期 |修改者 |修改内容 |
|:----:|:----------:|--------------|---------------------------------------|
| v1.0 | 2023-08-22 | Dino | 初版发布 |
| v1.1 | 2023-09-14 | Dino | 1. 修复保存 keil uv4.exe 路径数组过小的问题
2. 增加实时打印编译输出内容的功能 |
| v1.2 | 2023-10-20 | Dino | 1. 增加从系统环境变量 Path 中自动查找 keil UV4.exe 的功能 |
## 重要说明
> **1. 本脚本依赖 keil 软件,定位为 keil 的自动化编译脚本。目的是替代手动编译,实现程序自动化,而非替代编译工具,并无附带任何编译器和链接器。由此,无论代码工程是基于 keil C51 亦或是 keil MDK 都可执行。**
>
> **2. 无论是 keil 安装目录、 keil 工程所在目录和 keil 的 project target ,都不要使用中文和空格。否则,不保证使用效果。**
## 参与贡献
1. Fork 本仓库
2. 新建 Feat_xxx 分支
3. 提交代码
4. 新建 Pull Request