V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
adoyle
V2EX  ›  分享创造

makefile-utils: 帮助写 Makefile 的小工具

  •  
  •   adoyle ·
    adoyle-h · 2023-02-21 17:49:18 +08:00 · 1343 次点击
    这是一个创建于 670 天前的主题,其中的信息可能已经有所发展或是发生改变。

    分享一个小工具。

    如果你不想在项目中引入 cmake, xmake, mmake, emake 等高级的 make 工具,仅使用系统自带的 make 命令。 makefile-utils 能帮上一点小忙。

    功能

    make help

    make help 能打印 target 列表。

    make semver-*

    make semver-major 能打印下一个 major 版本。还有 make semver-minormake semver-patch

    你可能会想这有啥用?因为可以用它这么玩:批量升级替换文件里的版本号。

    # @target bump-major  bump major version (x)
    # @target bump-minor  bump minor version (y)
    # @target bump-patch  bump patch version (z)
    BUMP_TARGETS := $(addprefix bump-,major minor patch)
    .PHONY: $(BUMP_TARGETS)
    $(BUMP_TARGETS):
    	@$(MAKE) $(subst bump-,semver-,$@) > VERSION
    	@sed -i.bak -E "s/^VERSION=.+/VERSION=v$$(cat VERSION)/" README.md
    	@rm README.md.bak VERSION
    

    make md5

    可以给指定目录里的每个文件生成.md5 文件。

    默认目录是 ./dist。但你可以指定其他目录 make md5 DIST=./dist

    make md5-check

    校验指定目录下的文件的 md5 。

    默认目录是 ./dist。但你可以指定其他目录 make md5-check DIST=./dist

    更多 makefile target...

    后续会补充更多方便的 makefile target 。

    欢迎在 Discussion 中与我讨论需求。

    安装使用

    安装很简单,只要把 makefile-utils 目录拷贝到你的项目。然后在你的 Makefile 里加一行 include ./makefile-utils/*.mk 就可以使用了,按 make help 试试。

    如果你的项目使用 git ,需要在 .gitignore 里加两行来忽略一些文件。

    /makefile-utils/*
    !/makefile-utils/*.mk
    

    如果你想把 make help 作为默认命令就在 Makefile 里加一行 .DEFAULT_GOAL := help


    觉得不错的话,请给项目点给 Star 吧。

    https://github.com/adoyle-h/makefile-utils

    第 1 条附言  ·  2023-03-02 16:17:14 +08:00

    目前更新到 v0.4.1 版本,新增的功能有:

    1. 用户能通过 makefile-utils init . 来初始化项目。
    2. 通过 make CHANGELOG 根据 git message 来生成 changelog。changelog 是我总结的最佳实践,生成结果可以参考 makefile-utils 的 CHANGELOG
    3. 通过 make md-check-links 检查项目文档中是否存在死链。
    1 条回复    2023-02-23 02:09:28 +08:00
    adoyle
        1
    adoyle  
    OP
       2023-02-23 02:09:28 +08:00
    更新到 v0.2.0 。加了一个 make changelog 的功能。能够根据 git log 自动生成 changelog ,比如这样 https://github.com/adoyle-h/makefile-utils/blob/master/CHANGELOG.md
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2648 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 11:14 · PVG 19:14 · LAX 03:14 · JFK 06:14
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.