だるいですよね、インラインテーブル記述。
name = { first = "Tom", last = "Preston-Werner" }
point = { x = 1, y = 2 }
animal = { type.name = "pug" }
👉 TOML: 日本語 v0.5.0 data:image/s3,"s3://crabby-images/ad321/ad321a39662d1da298b1a9e924dec05ab6ea53fc" alt="hatena-bookmark"
Android Studio でも
Graadle Version Catalog で、最初は、こんな記述でも
[plugins]
android-material = "com.google.android.material:material:1.8.0-alpha02"
やがて、
[plugins]
android-material = { module = "com.google.android.material:material", version = "1.8.0-alpha02" }
となり
[versions]
android-material = "1.8.0-alpha02"
[plugins]
android-material = { module = "com.google.android.material:material", version.ref = "android-material" }
というふうに変わっていきます。
大量にやってるのも地味にだるい。
Live Templete を使って書き換えます。
Preferences
↓
Live Templates
から作っていきます。
ここマクロたちは、思ったより使いづらいものが多い。
data:image/s3,"s3://crabby-images/2597d/2597dd8f4e0718117c38696ee6391ffa76ef382f" alt="live template macro"
👉 intellij-community/platform/lang-impl/src/com/intellij/codeInsight/template/macro at master · JetBrains/intellij-community data:image/s3,"s3://crabby-images/07dc4/07dc4daff8559d15d74c9d10d27d3ed8b18b50d5" alt="hatena-bookmark"
割と使える Groovy のマクロ。
groovyScript(, [arg, ...])
Executes the Groovy script passed as a string.
The first argument is a string with either the text of the script or the path to the file that contains the script. The function passes other optional arguments to the script as values for _1, _2, _3, ..., _n variables. Also, you can access the current editor from inside the script using the _editor variable.
The following example shows a groovyScript() function that splits the selected text into words and displays them as a numbered list:
groovyScript("def result = ''; _1.split().eachWithIndex { item, index -> result = result + index.next() + '. ' + item + System.lineSeparator() }; return result;", SELECTION);
👉 Edit Template Variables dialog | IntelliJ IDEA data:image/s3,"s3://crabby-images/35d1a/35d1ad57e921a2634fbc6495e409c40c8775855c" alt="hatena-bookmark"
以下の感じで設定して4つのテンプレートを記述しました。
data:image/s3,"s3://crabby-images/66820/668204b9ab0d54ba946910a013058ada6aa844b4" alt=""
どれも似たような記述なので、一つだけ貼っておきます。
使い回せます。
data:image/s3,"s3://crabby-images/e2232/e2232f0dc4fc95731a8457dd8b5687f3251f16bf" alt=""
使い方は、該当文字列をコピーしてから、Abbreviation を入力で、テンプレートを吐き出しながらキーなどを編集してください。
結果。
data:image/s3,"s3://crabby-images/80487/804876230c72b5f5e3d9bc0227c75c490ecd956e" alt="toml live template"
キーの編集に連携されて関連記述が編集されるのがいいところでしょうか。
けどまあ、Android Studio 本体の機能更新が待たれるところですが。
🙆 追記
複数行一括のほうがいいので以下の方法を実際は使っています。