tmj 2019-06-28
原文地址:Golang Gin实践 番外 请入门 Makefile
含一定复杂度的软件工程,基本上都是先编译 A,再依赖 B,再编译 C...,最后才执行构建
如果每次都人为编排,又或是每新来一个同事就问你项目 D 怎么构建、重新构建需要注意什么...等等情况,岂不是要崩溃?
我们常常会在开源项目中发现 Makefile,你是否有过疑问?
本章节会简单介绍 Makefile 的使用方式,最后建议深入学习
对于构建编排,Docker 有 Dockerfile ,在 Unix 中有神器 Make ....
Make 是一个构建自动化工具,会在当前目录下寻找 Makefile 或 makefile 文件。如果存在,会依据 Makefile 的构建规则去完成构建
当然了,实际上 Makefile 内都是你根据 make 语法规则,自己编写的特定 Shell 命令等
它是一个工具,规则也很简单。在支持的范围内,编译 A, 依赖 B,再编译 C,完全没问题
Makefile 由多条规则组成,每条规则都以一个 target(目标)开头,后跟一个 : 冒号,冒号后是这一个目标的 prerequisites(前置条件)
紧接着新的一行,必须以一个 tab 作为开头,后面跟随 command(命令),也就是你希望这一个 target 所执行的构建命令
[target] ... : [prerequisites] ... <tab>[command] ... ...
本文将以 go-gin-example 去编写 Makefile 文件,请跨入 make 的大门
在编写 Makefile 前,需要先分析构建先后顺序、依赖项,需要解决的问题等
.PHONY: build clean tool lint help all: build build: go build -v . tool: go tool vet . |& grep -v vendor; true gofmt -w . lint: golint ./... clean: rm -rf go-gin-example go clean -i . help: @echo "make: compile packages and dependencies" @echo "make tool: run specified go tool" @echo "make lint: golint ./..." @echo "make clean: remove object files and cached files"
1、在上述文件中,使用了 .PHONY
,其作用是声明 build / clean / tool / lint / help 为伪目标,声明为伪目标会怎么样呢?
2、这块比较简单,在命令行执行即可看见效果,实现了以下功能:
如果你实际操作过,可能会有疑问。明明只是执行命令,为什么会打印到标准输出上了?
make 默认会打印每条命令,再执行。这个行为被定义为回声
可以在对应命令前加上 @,可指定该命令不被打印到标准输出上
build: @go build -v .
那么还有其他的特殊符号吗?有的,请课后去了解下 +、- 的用途