【Rails】コードをシンタックスハイライトする『rouge』のカラーテーマ一覧と指定方法

2020年9月8日 8:29

はじめに

Markdownで書いた記事のコード部分をシンタックスハイライトする『rouge』というGemがあります。当ブログでも使っており、導入や使い方については以前記事にしました。

『rouge』にはいくつかのカラーテーマが用意されています。カラーテーマ一覧はこちらで確認できるのですが、実はここに載っていないカラーテーマもあったりします。

また、カラーテーマの指定方法(書き方)がちょっと特殊な場合もあるので、各カラーテーマの指定方法とセットでまとめてみようと思います。

なお、カラーテーマの指定方法はapp/assets/stylesheets/_rouge.scss.erbを作成してそこにコードを貼り付けてください。

カラーテーマ一覧

用意されているカラーテーマは全部で15種類あります。カラーテーマによってはDarkModeLightModeが指定できたりするのですが、見た目に変化はなかったので用途は不明です。

Base16

サンプル

指定方法

# Normal
<%= Rouge::Themes::Base16.render(:scope => '.highlight') %>

# DarkMode
<%= Rouge::Themes::Base16.mode(:dark).render(:scope => '.highlight') %>

# LightMode
<%= Rouge::Themes::Base16.mode(:light).render(:scope => '.highlight') %>

Base16.Monokai

サンプル

指定方法

# Normal
<%= Rouge::Themes::Base16::Monokai.render(:scope => '.highlight') %>

# DarkMode
<%= Rouge::Themes::Base16::Monokai.mode(:dark).render(:scope => '.highlight') %>

# LightMode
<%= Rouge::Themes::Base16::Monokai.mode(:light).render(:scope => '.highlight') %>

Base16.Solarized

サンプル

指定方法

# Normal
<%= Rouge::Themes::Base16::Solarized.render(:scope => '.highlight') %>

# DarkMode
<%= Rouge::Themes::Base16::Solarized.mode(:dark).render(:scope => '.highlight') %>

# LightMode
<%= Rouge::Themes::Base16::Solarized.mode(:light).render(:scope => '.highlight') %>

BlackWhiteTheme

サンプル

指定方法

# Normal
<%= Rouge::Themes::BlackWhiteTheme.render(:scope => '.highlight') %>

Colorful

サンプル

指定方法

# Normal
<%= Rouge::Themes::Colorful.render(:scope => '.highlight') %>

Github

サンプル

指定方法

# Normal
<%= Rouge::Themes::Github.render(:scope => '.highlight') %>

Gruvbox

サンプル

指定方法

# Normal
<%= Rouge::Themes::Gruvbox.render(:scope => '.highlight') %>

IgorPro

サンプル

指定方法

# Normal
<%= Rouge::Themes::IgorPro.render(:scope => '.highlight') %>

Magritte

サンプル

指定方法

# Normal
<%= Rouge::Themes::Magritte.render(:scope => '.highlight') %>

Molokai

サンプル

指定方法

# Normal
<%= Rouge::Themes::Molokai.render(:scope => '.highlight') %>

Monokai

サンプル

指定方法

# Normal
<%= Rouge::Themes::Monokai.render(:scope => '.highlight') %>

MonokaiSublime

サンプル

指定方法

# Normal
<%= Rouge::Themes::MonokaiSublime.render(:scope => '.highlight') %>

Pastie

サンプル

指定方法

# Normal
<%= Rouge::Themes::Pastie.render(:scope => '.highlight') %>

ThankfulEyes

サンプル

指定方法

# Normal
<%= Rouge::Themes::ThankfulEyes.render(:scope => '.highlight') %>

Tulip

サンプル

指定方法

# Normal
<%= Rouge::Themes::Tulip.render(:scope => '.highlight') %>

まとめ

シンタックスハイライトはコードの可読性が格段に向上するので、技術系ブログなどを運営されている方はマストで導入してほしいですね。シンタックスハイライトのないコードだと読む気になりません。

『rouge』のカラーテーマを探していたり、指定方法がわからなくて困っていたという方は参考にしていただければと思います。

関連記事

【Rails】M1チップ搭載MacでRuby on Railsの開発環境構築
# はじめに M1チップ搭載MacにRuby on Railsの開発環境を構築する手順を記載します。 - MacBook Air (M1, 2020) - macOS Monterey 12.3.1 # Homebrew ## [...]
2022年5月5日 11:56
【Rails】Rakeタスクの基本情報と作成・実行方法
# はじめに Railsには標準でRakeというGemが同梱されています。RakeはRubyで実装されたMake(UNIX系のOSで使用できるコマンド)のようなビルド作業を自動化するツールです。Ruby Make、略してRakeというわけですね。 [...]
2022年3月7日 22:12
【Rails】モデルに外部キーを設定する方法とよく起こるエラー内容について
# はじめに Railsでモデルに外部キーを設定する方法について説明します。 # モデルに外部キーを設定する ## リレーションシップ 今回は1つのブログ記事は複数のコメントを持つ1対多のリレーションシップを例に説明します。現在は` [...]
2022年2月10日 14:18
【Rails】Capybaraのfill_inメソッドを実行すると「既存レコードの内容+指定した内容」がセットされる事象の原因と対処【RSpec】
# はじめに RSpec + Capybaraを使用して、Railsアプリの統合テストを実装しています。とあるモデルの編集画面において、入力フォームの内容を書き換えた上で送信し、レコードが更新されることを確認します。 入力フォームの内容を書 [...]
2022年1月27日 21:22
【Rails】GitHubのセキュリティアラートで発見された脆弱性を解消する方法
# はじめに GitHubにはセキュリティアラートという機能があります。セキュリティアラートはリポジトリに含まれるライブラリやパッケージの脆弱性を定期的にチェックし、脆弱性のあるライブラリやパッケージが発見されたらアラートで知らせてくれるという機 [...]
2022年1月16日 10:36