/css/main.css にアクセスがあったら less に送る Rack ミドルウェア

しょーもないメモメモ。

module Rack
  class LessCss
    def initialize(app)
      @app = app
    end

    def call(env)
      status, headers, body = @app.call(env)
      req = Rack::Request.new(env)

      if req.fullpath == '/css/main.css' then
        lessfile = 'less_template/main.less' # less file
        if ::File.exists?(lessfile) then
          cssstr = Less::Engine.new(::File.new(lessfile)).to_css
          body = [cssstr]
          headers['Content-Type'] = 'text/css'
          headers.delete('Content-Length')  # Rack::ContentLength に任せる
          status = 200
        end
      end

      [status, headers, body]
    end
  end
end

PATHが、ウルトラハードコーディングだけど今は気にしない(汗。

んで、main.less には、以下のように import を書いています。

@import 'html5-reset-1.4.css';
@import 'core.less';
@import 'header.less';
@import 'footer.less';
.
.
.

書くときは分割して、読み込むときは1つのファイルですむと。
キャッシュなどは全く考えてないので、制作のためのものです。
# 実際 main.css にまとめて css にしてから上げてるし。

久々に Ruby on Rails

ぼちぼち Rails を触りだしています。Rails 以前に、データベースからお勉強せんといかんので、ほんとにはじめたばっかりです。

colinux に Debian (etch) 入れて、Windows のフォルダを smb でマウントし、そんなかで rails hogehoge やってます。ファイルの編集は Windows 上の Eclipse で。素直に Windows 上に Rails 入れりゃいいんですが、多少 linux のリハビリもしたいなぁってんで、なんとなく。 これからどういう作業環境でいくか、OSも含めて迷ってるので、いろいろやってみよかなと。

インストール後、2つばかしチュートリアルっぽいのを作ってみた。『Rails によるアジャイルWebアプリケーション開発』本の最初のやつと、るびまのやつと、Think IT のやつ。そのまんまじゃ動かないとこがいくつかあったけど、そこは google 先生に聞いて突破。まぁ、バージョンなんかも関係あるかもしれないし・・・。

まずは、数こなしてパターン覚えるかな。目標としては、AIRと組み合わせて遊ぶこと。