Guardはコマンドラインツールで、ファイル変更を監視してコンパイルや結合などのタスクを実行できます。Middlemanでプロトタイプを構築して、既存システム(PHPベース)に移植という段取りだったのですが、Middlemanのディレクトリ構成をそのまま持ち込むことはできません。
Guardを採用した理由としては以下があります。CoffeeScript、concat、uglifyはまた今度に。
- Compass、CoffeeScript、Slimといった様々なライブラリを複合で扱える
- BundlerでGem管理ができる
- Rubyベースなので資産を再利用しやすかった
まず、CompassとFoundationを導入する段取りについて。
Gemfile
Guardプラグイン各種を入れておきます。
# SASS & Compass source ‘http://rubygems.org’ # V8 JavaScript Engine (for Uglifier) gem “therubyracer” gem "sass" gem "compass" gem "zurb-foundation" gem "susy" gem "compass-normalize" # For concatenation/compression gem "uglifier" # Guard and plugins gem "guard" gem "guard-sass" gem "guard-compass" gem "guard-coffeescript" gem "guard-livereload" gem "guard-concat" gem "guard-uglify" gem "rb-fsevent"
Bundlerでインストールします。
bundle install --path vendor/bundler
config.rb
各種Gemをrequireしておきます。
require 'zurb-foundation' require 'susy' require 'compass-normalize'
Sassファイルでは以下のようにインポートしておきます。
@import "normalize"; @import "foundation";
Foundationについては、これですべてのスタイルが読み込まれます。
Guardfile
CompassでSassファイルをコンパイルするタスクを用意します。
正規表現で .scss と .sass 両方をコンパイル対象にしています。
guard :compass do watch(%r{sass/(.+\.s[ac]ss)}) end
Guard実行
bundle exec guard init bundle exec guard
コマンドを実行するとタスクが実行され、さらにファイル変更の監視を始めます。
[1] guard(main)>
[concrete5.6] ローカルで作成したDesigner Content Proのブロックを本番へ移行する
2016年3月24日
cocrete5の強力なプラグイン、Designer Content Proで作成したブロックをローカルから本番環境へ移行するためのポイントを備忘録としてまとめました。
0 Comments1 Minute
[WordPress]寄稿者ユーザーに他者の投稿を表示させない方法
2015年4月9日
寄稿者ユーザーに他者の投稿を表示させない方法について備忘録としてまとめました。フィルターフックとアクションフックを併用して、管理画面の投稿一覧に関する表示制御を行っています。
2 Comments1 Minute
OSX Marvericks にアップデートしたら MAMP PRO が動かなくなった
2013年11月2日
OSX Marverics(以下、Marvericks)になって、便利な機能も増えましたが恒例のごとく「今まで動いていたものが動かない!」というケースも発生したりします。今回は、MAMP PROがそれになったので対処法をメモとして残しておきます。
0 Comments1 Minutes
RubyでYoutube Data APIの認証、動画検索、取得、更新
2013年2月28日
RubyからGoogle Data APIを操作するバッチを書いていたので、おさらいです。APIとのやりとりを直接書いてみると、マッシュアップ系のWebサービスを作るときの基礎練習として良いですね。
0 Comments2 Minutes
HTTPでXMLを送信したら、The Processing Instruction Target Matching “[xX][mM][lL]” is Not Allowed
2013年2月27日
Rubyで次々とXML送信するバッチスクリプトを書いていたところ、Net::HTTP#putの利用時にステータス400。ふたを開けてみると、なんということはない内容でした。
0 Comments1 Minute
Sublime Text 2 + MAMP + Xdebug でPHPデバッグをする方法
2012年12月18日
Sublime Text 2(以下、ST2)がすっかりメインエディタに定着したのですが、デバッグ環境が未整理でした。そういえば・・・と思って探してみると、やはりプラグインがありました。ST2とMAMPによるPHPデバッグ環境の導入方法を解説します。
0 Comments1 Minutes
IE9でprototype.js + Shadowbox.jsを使う場合のメモ
2012年6月5日
IE9なら、モダンブラウザに近づくから面倒なIE対応は減るはず、というのは幻想で余計に手間が増えるケースもあります。今回は限定されたシチュエーションですが、JavaScriptライブラリを使う場合の対応をまとめました。
0 Comments1 Minute
[FuelPHP] taskでRailsライクなseedを作る
2012年2月22日
FuelPHPを使い始めているのですが、良いと評価できる点にコマンドラインから実行できる便利なタスクがあります。Railsではrake, railsというコマンドで各種タスクを実行でき、それを踏襲しています。今回はその中でも初期データ作成に便利なseedという機能をFuelPHP上に作ってみました。
0 Comments1 Minute