指定した値をファイルに埋め込むemv
というCLIのツールをGoで作りました。
ビルドツール自体にGitのタグなどを利用してバージョン番号を埋め込むといった方法が提供されているものも多いですが、それだとカバーできないようなパターンをカバーしたくて作っています。
利用方法
emv -c project/emv.json 1.0.2
Usage: emv [-c CONFIG] [-t TARGET] VALUE1 ... Flags -c, --config string Config file path. (default "emv.json") -t, --target string The base directory to search for target files. If not specified, it is the same directory as the config file. -h, --help Help.
設定ファイルに埋め込みのためのルールを記載し、そのルールに従って、CLIでのコマンドライン引数として指定されたものを埋め込みます。
例として下記のような設定を用意します。ファイル名はemv.json
としておきます。
{ "values" : [ { "name" : "version" } ], "targets" : [ { "files" : [ "example.properties" ], "embeddeds" : [ { "pattern" : "version=[0-9\\.]+", "replacement" : "version={{.version}}" } ] } ] }
values
で入力値(emvの引数として指定)の定義を行っています。
name
で入力値に対して名前(上記例だとversion
)を付与しています。この名前を使って、replacement
で入力値を参照することができます。
targets
で対象となるファイルや埋め込み内容を定義しています。
files
はターゲットとなるファイルです。相対パスとして指定した場合、デフォルトでは設定ファイルと同じディレクトリを基準とします。-t
オプションで基準とするディレクトリを変更することができます。
embeddeds
で埋め込むコンテンツを定義します。
pattern
は正規表現になります。pattern
をreplacement
の値で置き換えます。
replacement
には、{{.name}}
のように入力値を埋め込むことができます。Goのtext/templateを利用しています。
files
で指定しているexample.properties
は下記のような内容です。
version=1.1.2
emv.json
とexample.properties
が配置されているフォルダで実行します。
2.0.0
を埋め込みます。
$ emv 2.0.0 Embedded values: version=2.0.0 Files: ([U] Updated, [-] None) [U] example.properties
example.properties
は下記のようになりました。
version=2.0.0
入力値の一部を利用する
入力値はpattern
で正規表現の名前付きキャプチャを利用すると、別の名前として切り出すことができます。
"values" : [ { "name" : "version", "pattern" : "^(?P<major>[0-9]+)\\.(?P<minor>[0-9]+)\\.(?P<revision>[0-9]+)$" } ],
たとえば上記の設定で2.1.2
と入力した場合、下記のような名前と値のペアになります。
version
:1.2.3
major
:1
minor
:2
revision
:3