vscode-textlintで日本語の文章校正をしよう【mdx / md / html / txt】
初稿:
- 6 min read -
記事概要
- 先日のBloggerからAstroへ移行した記事の別途詳細
※参考 - Blog移行記事
10年以上の期間お世話になったGoogle Bloggerに別れを告げ、この度AstroでBlogサイトを構築し移行した。Astroは静的サイトを手軽に開発できる軽量フレームワーク。無料のテンプレートをベースにカスタマイズを行った。それなりの作業ボリュームとなったので、詳細は別記事に分け、今回は移行作業全体をまとめる。
目的
- VSCodeの拡張機能「vscode-textlint」をインストールし日本語の文章校正を自動化する
- 校正対象ファイルは4種類
- .mdx
- .md
- .txt
- .html
- mdxは設定が複雑のため詳しい手順をまとめる
- 校正ルールはJTF日本語標準スタイルのルールセットを用いる
作業概要
- textlint、rule、pluginインストール
- vscode-textlintインストール
- vscode-textlintの設定
- .textlintrcを作成
前提
- Node.jsがインストール済みであること
環境
- OS - Ubuntu-22.04LTS on WSL2
- Node.js - v20.14.0
- npm - v10.8.1
- textlint - v14.0.4
- textlint-plugin-markdown - v14.0.4
- textlint-plugin-text - v14.0.4
- VSCode - v1.90.2
- vscode-textlint - v0.11.0
textlint とは
textlint · The pluggable linting tool for text and markdown
The pluggable linting tool for text and markdown
textlintはJavaScriptで書かれたオープンソースのテキスト静的解析ユーティリティです。自然言語のテキストをリントするのは難しいが、私たちはプラガブル(プラグイン可能)なアプローチでこの問題を解決しようとしている。 — textlint公式より引用をDeepLで翻訳
JTF日本語標準スタイルとは
実務翻訳の業界団体である 日本翻訳連盟(JTF)。日本翻訳ジャーナルの発行、JTFほんやく検定、翻訳セミナー(東京・大阪)、翻訳祭、業界調査研究を実施。
『JTF日本語標準スタイルガイド(翻訳用)』は、実務翻訳において和訳時に使用できる日本語表記ガイドラインです。2012年1月30日に初版を公開しました。『JTF日本語標準スタイルガイド』はどなたでも無償で使用できます。日本語の表記のゆらぎを防いで、スムーズに表記を統一するためのガイドラインとして活用してください。著作権および使用条件は文書本体に記載しています。 — JTF 日本翻訳連盟より引用
- 公式github
作業詳細
作業ディレクトリの準備
- VSCodeのプロジェクトディレクトリ作成
textlint、rule、pluginインストール
- textlint本体とJTF日本語標準スタイルのruleをインストール
- グローバルインストールの場合は以下
- .txtと .mdxでtextlintを使用するためのpluginをインストール
vscode-textlintインストール
- VSCodeの拡張機能からvscode-textlint(作者 taichi)を検索しインストール
- または以下マーケットプレイスよりインストール
vscode-textlintの設定
- コマンドパレット(ctrl + shift + p)から「基本設定: ユーザ設定を開く(JSON)」を実行
- settings.json に以下を追加
- VSCodeでtextlintを使用する場合、対象とするファイルをsettings.jsonで指定する必要がある(重要)
- これらの値は、VSCodeのステータスバー「言語モードの選択」に表示される値と一致する必要がある
.textlintrcを作成
- コマンドパレット(ctrl + shift + p)から「textlint: Create ‘.textlintrc’ File」を選択
- プロジェクトディレクトリ直下に、「.textlintrc」が作成される
- .textlintrcに以下のルールとプラグインを記述する
pluginsの設定について
- .mdxと .htmlに対応させている
- markdownとtextファイルはtextlintの標準に含まれるため省略
- インストールしたtext用pluginを .htmlに指定し強引に動作させている
- 他にhtmlでtextlintを走らせる方法が分からない
rulesの設定について
- インストールしたpreset-jtf-styleを有効化している
- 例として特定のルールを1つずつ有効と無効にする設定をした
- 特定のルールを無効化する場合、以下PDFを参照しfalseを指定する
- JTF日本語標準スタイルガイド 第3.0版 - jtf_style_guide.pdf
- ルールの細かい設定はtextlint-rule-preset-JTF-style - ルール一覧を参照
その他追加作業
ファイル内の特定箇所のみignoreする
- textlint-filter-rule-commentsをインストールする
- .textlintrc に以下を追加
- コメントブロックで該当箇所を囲むと校正をスキップできる
- mdxではhtmlコメントでエラーとなるためこう書く
- これはmdxプラグインの効果
まとめ
最後に備忘録として .htmlファイルでtextlintを動かすまでの経緯を残す
- textlint-plugin-html は私の環境ではうまく動作しなかった
- 下記の記事を参考に、 @textlint/textlint-plugin-text を使用し、.htmlを追加する形をとった