TOC Generator
Read this in other languages: English, 日本語.
これは目次を生成するGitHub Actions
です。
DocToc を実行し変更があればコミットします。
Table of Contents
Details
- [インストール](#%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB) - [スクリーンショット](#%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88) - [オプション](#%E3%82%AA%E3%83%97%E3%82%B7%E3%83%A7%E3%83%B3) - [個別に指定](#%E5%80%8B%E5%88%A5%E3%81%AB%E6%8C%87%E5%AE%9A) - [Action イベント詳細](#action-%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E8%A9%B3%E7%B4%B0) - [対象イベント](#%E5%AF%BE%E8%B1%A1%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88) - [Conditions](#conditions) - [補足](#%E8%A3%9C%E8%B6%B3) - [GITHUB_TOKEN](#github_token) - [プルリクエストの作成](#%E3%83%97%E3%83%AB%E3%83%AA%E3%82%AF%E3%82%A8%E3%82%B9%E3%83%88%E3%81%AE%E4%BD%9C%E6%88%90) - [Context variables](#context-variables) - [Context PR variables](#context-pr-variables) - [設定例](#%E8%A8%AD%E5%AE%9A%E4%BE%8B) - [例1](#%E4%BE%8B%EF%BC%91) - [例2](#%E4%BE%8B%EF%BC%92) - [例3](#%E4%BE%8B%EF%BC%93) - [Author](#author)インストール
- 目次の位置を指定 (option)
<!-- START doctoc --> <!-- END doctoc -->
- workflow を設定
例:.github/workflows/toc.yml
on: push name: TOC Generator jobs: generateTOC: name: TOC Generator runs-on: ubuntu-latest steps: - uses: technote-space/toc-generator@v4
スクリーンショット
オプション
| name | description | default | e.g. |
|:—|:—|:—|:—|
|TARGET_PATHS|対象のファイルパス (カンマ区切り, 詳細)|README*.md
|README*.md,CHANGELOG.md
, .
|
|TOC_TITLE|目次タイトル|**Table of Contents**
|''
|
|MAX_HEADER_LEVEL|Heading最大レベル (詳細)| |3
|
|CUSTOM_MODE|Customモードかどうか(生成例)|false
|true
|
|CUSTOM_TEMPLATE|Customテンプレート(Customモード)|<p align="center">${ITEMS}</p>
| |
|ITEM_TEMPLATE|アイテムテンプレート(Customモード)|<a href="${LINK}">${TEXT}</a>
| |
|SEPARATOR|セパレータ(Customモード)|\|\
| |
|FOLDING|目次を折りたたみ式にするかどうか|false
|true
|
|COMMIT_MESSAGE|コミットメッセージ|chore(docs): update TOC
|docs: update TOC
|
|COMMIT_NAME|コミット時に設定する名前|${github.actor}
| |
|COMMIT_EMAIL|コミット時に設定するメールアドレス|${github.actor}@users.noreply.github.com
| |
|CREATE_PR|プルリクエストを作成するかどうか|false
|true
|
|CHECK_ONLY_DEFAULT_BRANCH|デフォルトのブランチのみをチェックするかどうか|false
|true
|
|PR_BRANCH_PREFIX|プルリクエストのブランチプリフィックス|toc-generator/
| |
|PR_BRANCH_NAME|プルリクエストのブランチ名
Context variables|update-toc-${PR_ID}
|toc-${PR_NUMBER}
|
|PR_TITLE|プルリクエストのタイトル
Context variables|chore(docs): update TOC (${PR_MERGE_REF})
|docs: update TOC
|
|PR_BODY|プルリクエストの本文
Context PR variables|action.yml| |
|PR_COMMENT_BODY|プルリクエストの本文(コメント用)
Context PR variables|action.yml| |
|PR_CLOSE_MESSAGE|プルリクエストを閉じるときのメッセージ|This PR has been closed because it is no longer needed.
| |
|TARGET_BRANCH_PREFIX|ブランチ名のフィルタ| |release/
|
|INCLUDE_LABELS|プルリクエストに付与されているかチェックするラベル| |Label1, Label2
|
|OPENING_COMMENT|開始コメント (DocToc以外のため)|<!-- toc
| |
|CLOSING_COMMENT|終了コメント (DocToc以外のため)|<!-- tocstop
| |
|SKIP_COMMENT|スキップコメントを変更 (default: <!-- DOCTOC SKIP
)| |<!-- toc skip
|
|GITHUB_TOKEN|アクセストークン|$
|$
|
|SIGNOFF| Signed-off-byを付与 | |true
|
個別に指定
doctoc に使用されているオプションはコメントで値を指定することが可能です。
異なる設定で複数の目次を生成したい場合は以下のように個別に値を指定してください。
例:
<!-- START doctoc -->
<!-- param::isNotitle::true:: -->
<!-- param::isCustomMode::true:: -->
<!-- END doctoc -->
...
Action イベント詳細
対象イベント
| eventName: action | condition | |:—|:—| |push: *|condition1| |pull_request: [opened, synchronize, reopened, labeled, unlabeled]|condition2| |pull_request: [closed]|| |schedule, repository_dispatch, workflow_dispatch||
- 次のアクティビティタイプは明示的に指定する必要があります。 (詳細)
labeled
,unlabeled
,closed
Conditions
condition1
- ブランチへのプッシュ (タグのプッシュではない)
- ブランチ名 (
TARGET_BRANCH_PREFIX
)condition2
- ブランチ名 (
- 指定したラベルが付与されているかどうか (
INCLUDE_LABELS
) - ブランチ名 (
TARGET_BRANCH_PREFIX
)
補足
GITHUB_TOKEN
GitHub Actions で提供されるGITHUB_TOKEN
は連続するイベントを作成する権限がありません。
したがって、プッシュによってトリガーされるビルドアクションなどは実行されません。
これはブランチプロテクションを設定していると問題になる場合があります。
もしアクションをトリガーしたい場合は代わりにpersonal access token
を使用してください。
- public_repo または repo の権限で Personal access token を生成
(repo はプライベートリポジトリで必要です) - ACCESS_TOKENとして保存
GITHUB_TOKEN
の代わりにACCESS_TOKEN
を使用するように設定
例:.github/workflows/toc.yml
on: push name: TOC Generator jobs: generateTOC: name: TOC Generator runs-on: ubuntu-latest steps: - uses: technote-space/toc-generator@v4 with: GITHUB_TOKEN: $
プルリクエストの作成
CREATE_PR
に true
を設定した場合は、プルリクエストが作成されます。
on: pull_request
name: TOC Generator
jobs:
generateTOC:
name: TOC Generator
runs-on: ubuntu-latest
steps:
- uses: technote-space/toc-generator@v4
with:
CREATE_PR: true
closed
アクティビティタイプが設定されている場合、このアクションは不要になったプルリクエストを閉じます。
on:
pull_request:
types: [opened, synchronize, reopened, closed]
name: TOC Generator
jobs:
generateTOC:
name: TOC Generator
runs-on: ubuntu-latest
steps:
- uses: technote-space/toc-generator@v4
Context variables
| name | description |
|:—|:—|
| PR_NUMBER | pull_request.number (例:11
) |
| PR_NUMBER_REF | #${pull_request.number}
(例:#11
) |
| PR_ID | pull_request.id (例:21031067
) |
| PR_HEAD_REF | pull_request.head.ref (例:change
) |
| PR_BASE_REF | pull_request.base.ref (例:main
) |
| PR_MERGE_REF | pull_request.base.ref (例:change -> main
) |
| PR_TITLE | pull_request.title (例:update the README with new information.
) |
Context PR variables
name | description |
---|---|
PR_LINK | プルリクエストへのリンク |
COMMANDS_OUTPUT | TOC コマンドの結果 |
FILES_SUMMARY | 例:Changed 2 files |
FILES | 変更されたファイル一覧 |
設定例
例1
ブランチを制限しないでPush時にアクションを実行し直接コミット
on: push
name: TOC Generator
jobs:
generateTOC:
name: TOC Generator
runs-on: ubuntu-latest
steps:
- uses: technote-space/toc-generator@v4
例2
release/
から始まるブランチのみを対象にPull Request更新時に実行しPull Requestを作成または更新
on:
pull_request:
types: [opened, synchronize, reopened, closed]
name: TOC Generator
jobs:
generateTOC:
name: TOC Generator
runs-on: ubuntu-latest
steps:
- uses: technote-space/toc-generator@v4
with:
CREATE_PR: true
TARGET_BRANCH_PREFIX: release/
例3
デフォルトブランチのみを対象にスケジュールでアクションを実行し直接コミット
(他のワークフローの起動のために作成したTokenを使用)
on:
schedule:
- cron: "0 23 * * *"
name: TOC Generator
jobs:
generateTOC:
name: TOC Generator
runs-on: ubuntu-latest
steps:
- uses: technote-space/toc-generator@v4
with:
GITHUB_TOKEN: $
CHECK_ONLY_DEFAULT_BRANCH: true