2006年 08月 02日

CSS で変数が欲しい!の……

川o・-・)<2nd life - ファイル保存時に ERb でコンパイルして保存

これの別方向バージョンです。 (最近こんなんばっかだ。パクりマンセー)

CSS 特化でいいかなぁとか思いつつ簡単なスクリプトを通して置換するだけっていうのをやってみることにしました。ERB にせよ、なんにせよ、クライアントサイドでやってる限りは書いてる人の好き放題なのがいいところです。ERB のほうが別の場合も常に使えていいんですが。

#!/usr/bin/ruby
pre = File.read(ARGV[0])
vars = Hash[*pre.scan(/^\s*\*\s+([^\s;]+)\s*=\s*(.+$)/).flatten]
#p vars
ret = pre.gsub(/\#\{([^\s;]+)\}/) do |match|
if vars.key?(Regexp.last_match[1])
vars[Regexp.last_match[1]]
else
match
end
end
File.open(ARGV[1], "wb") {|f| f.puts ret }

第一引数に変換する前のファイル名、第二引数に変換したあとのファイル名を与えます。

vim 側は id:secondlife さんのやつを完全パクりでお送りいたします。指定した実行ファイルに保存時、ファイル名を与えて実行するだけ。~/.vim/plugin/css_pre_compile.vim

if v:version < 700 || (exists('g:loaded_css_pre_compile') && g:loaded_css_pre_compile || &cp)
finish
endif
let g:loaded_css_pre_compile = 1
if !exists('g:css_pre_compile_exec')
let g:css_pre_compile_exec = '/home/cho45/proj/mendoi/compile-css.rb'
endif
if !exists('g:css_pre_compile_name')
let g:css_pre_compile_name = 'pre'
endif
function! s:CssPreCompile()
let filename = expand('%:p')
let compiled_filename = substitute(filename, '\.' . g:css_pre_compile_name . '\.css$', '.css', '')
call system(g:css_pre_compile_exec . ' ' . filename . ' ' . compiled_filename)
endfunction
exe 'autocmd BufWritePost *.' . g:css_pre_compile_name . '.css call <SID>CssPreCompile()'

でもって編集する CSS

/*
* * Colors
* key-color-dark  = #123456
* key-color-light = #234567
*
* * Images
* imgdir = /img/hogehoge
*
* * Other Constants
* content-x-margin = 5%
*/
h1 {
background: #{key-color-dark} url("#{imgdir}/head.jpg") no-repeat top left;
height: 235px;
width: 50px;
}
/* 諸事情で #content に padding が指定できないとか */
#content .section {
margin: 0 #{content-x-margin};
}
#content .h2 {
margin: 0 #{content-x-margin};
}
#footer {
background: #{key-color-dark};
color: #fff;
}
#footer address {
color: #{key-color-dark};
background: #{key-color-light};
}

この場合頭に書いた宣言部分は消えないので、キーカラーを最初に明示しておく、なんてことが自然にできます。そういえば自分はよく色の頭二文字ぐらいを覚えて動的補完カマして入力するんですが、最初の二文字さえ最近覚えるのがダルイです。


ちょっと使ってみよう。が、しかし、すぐに使わなくなる予感が! といっても一回放り込めば使って悪いことはないので使えるかな。わからない。一ファイルで完結していないのがイマイチ。オートリロードとの兼ね合いもあるかも。あれダメダメじゃん。

Ruby 限定にするなら、探し出した変数宣言を module_eval とかで読み込んで、eval("<<EOF\n#{file_content}\nEOF") みたいなことやってもいい? 式が書けるようになるけど、エラーでてもわからなく。移植性が落ちる。


でもやっぱ。ERB のほうがループとかも書けていい気がする。<% が打ちにくいからそれだけなんとかできればいいような気もする。ねむい

jAbasRipT:Sreep[];

ううん

wktk

もっと wkwktktk したことをしたいなぁ。もっと

xterm-256color

Linux デスクトップで 256color やろうとするとどうもうまくいかない。xterm を

./configure --enable-wide-chars --enable-256-color --enable-luit

でコンパイルして

xterm -fa Mono -fs 9 -fg white -bg black

とかで起動するといちおうよさげなんだけど、描画が遅すぎて使えない。
putty 使いたいなぁ。

table 要素のレンダリング

Fx だけちょっと違うレンダリングするなぁ。Opera と IE はこの辺かなり似た解釈をしているようだ。
Fx だけボーダーがやたらズレて困る。Fx だけに適用するハックとかしらないしなぁ。

mlterm

mlterm をいれてみる

$ ./configure --enable-anti-alias --enable-optimize-redrawing --enable-scim

で make; sudo make install

がしかし 256colors2.pl 実行すると確実にフリーズする。optimize-redrawing が悪いのかと思い外してみてもだめだった。

上に書くよ

今日のぶんは手動で逆にしたよ!
追記モードっていう隠し機能があるらしい。上上下下左右左右BAを設定画面で押すとチェックボックスが現れるようだ。知らなかった。

vim ZZ

どうも C-z C-z (screen の window スワップ) 押すつもりで ZZ 入力して終了させてしまう。

mlterm

帰宅して ubuntu (バイト先は FC5) の apt で入れてみたけどこっちも 256colors2.pl がフリーズする。諦めよう。

gmail

gmail のほうのソレっぽいアドレスは本名用に使うことにした。

OCN

OCN のカスタマサポートページ重すぎ

2006年 08月 01日

プールサイドガールとそんなリアル・あるいは環境と自分について

こう、やっぱり、夏制服の髪が肩まである女の子が、プールサイドに立ち尽くしてミナソコを見つめているんだよなぁ。ほんとに。その俺が見ている風景の中では、少し遠くに見える木と、彼女の髪とスカートが少し揺れてるわけで、そんな世界に生きているのだから、リアリティ、というものはリアリティでしかなく、本当に、それがリアルであったりしなくてもいい、みたいに感じる。つまり「憧れ」が常になくちゃいけないけれど、それがリアルにないし、ないのは仕方ない。

リアルであれば、俺は高校のとき、何かしら向上的で一体感のある部活に入って何かをしたかった。今もしたい。もちろんその「今もしたい」というのは、今の状態でそれをしたいわけではなく、高校生になって部活動をしたい、という意味。そして正直いって、それ以上の何かはない。だから、このリアルな何かはまず叶わない (時間をとぶことは不可能だからね)。この時点で一つ諦めが必要。しかたないから、それっぽい目標・目標とはいえない目標を「てきとー」に掲げるしかない。死にたいわけじゃないからね、死にたいと思うとき、同時に生きたいと思ってる。よりよく生きたいのに、できないから死にたくなる。

どうでもいい。どっちにしろ、望んだ世界において、俺は俺ではない。ので、そういう意味では、考えることが、本当に意味がないことなんだろうなぁ。俺がそういう情況になるためには、それまでの環境構築 (すなわち自分の構築) の過程で、今の俺のようなことになってはいけない。それは既に俺ではない。環境=自分の反射/自分=環境の反射なのだから、そういう世界のそういう環境にいる俺は、常に俺ではない。

ググレカス

オレッテバ・ス・ゲー

ファイル共有

必要なこと

  • うpが十分で簡単である。
  • だうんこが十分に簡単である。
  • バージョン管理 (必然的にオートコミット)
  • パーミッション

アップロードフォームとかカス。HTTP ダウンロードはまぁいいよ?

だとするとやっぱ dav と svn とかしかない? でも dav もそんなにいい UI があるわけじゃない。いやいいのかなぁあれ。フォームよりはいいけど、うん、うぃんどうずのお話だよ。そうさ。

lftp

なんか唐突に lftp の open が失敗するようになった。

$ lftp
lftp :~> open s63.xrea.com
open: ftp: no such tcp service 

lowreal.net の日記がさらに書きにくくくく。XML 書くだけで最近ダルイのに。もう Trac Wiki 記法で殆ど書きたい。マークアップとか無駄無駄。でも ill-wormed はやめて! パースできないから!
RDF でなんでもやりたいよなぁ。ホントに。

lftp

cygwin の setup.exe を実行したらなおった。っぽい。他でえらーでてたのが気になるけど。

CSS に変数使いたいなぁ

PHP 使えっていう声が聞こえる。

vim マーク

マークの使いかたわからなくて、使わないようにしてたけど、耐えられないので覚える。

  • mx x にマーク なんの表示もでない><
  • `x (マーク x に戻る)

これだけでいいや

vim ``

バッククオートふたつが便利だなぁ。前いたところに戻る。

vim :s

:s が楽しい。V で選択して範囲内いっかつ置き換えが楽しい。どばーんって。xyzzy だと C-SPC C-n C-r TAB TAB Alt-R C-w とか長い手順ふむもんなぁ。

CSS で変数

http://subtech.g.hatena.ne.jp/secondlife/20060801/1154406385
wktk

コメントで変数宣言してそれはそのまま残しておくと、色とかを頭に書くとかも自然に同時にできる。ERB だとめんどいので軽いパーサ書いてあげるのがよさそう。

/*
 * key-color1 = #708f96
 * key-color2 = #123456;
 */

h1 {
    background: $key-color1;
}

#footer {
    background: $key-color1;
    color: #fff;
}

#footer address {
    color: $key-color1;
    background: $key-color2;
}

$ って使われたっけ

CSS 変数

#!ruby
pre = ARGF.read
vars = Hash[*pre.scan(/^\s*\*\s+(\$[^\s;]+) = (.+$)/).flatten]
ret = pre.gsub(/\$[^\s;]+/) do |match|
    if vars.key?(match)
        vars[match]  
    else
        match
    end
end

puts ret

ハイパー簡略化、が、これだと変数宣言も置換される!

スクリプトは簡単なままにする

やっぱ結構めんどいなぁ。ディレクトリを変数にしたい! とかだとこれでは無理だ? #{var-name} で展開にしたらいいのかな

/*
 * [key-color1] = #123456
 * [key-color2] = #234567
 */

h1 {
        background: $key-color1;
}

#footer {
        background: $key-color1;
        color: #fff;
}

#footer address {
        color: $key-color1;
        background: $key-color2;
}
#!ruby

pre = ARGF.read
vars = Hash[*pre.scan(/^\s*\*\s+\[([^\s;]+)\] = (.+$)/).flatten]
ret = pre.gsub(/\$[^\s;]+/) do |match|
        name = match.sub("$", "")
        if vars.key?(name)
                vars[name]
        else
                match
        end
end

puts ret

#{}に

#!ruby
pre = ARGF.read
vars = Hash[*pre.scan(/^\s*\*\s+\[([^\s;]+)\] = (.+$)/).flatten]
#p vars
ret = pre.gsub(/\#\{([^\s;]+)\}/) do |match|
        if vars.key?(Regexp.last_match[1])
                vars[Regexp.last_match[1]]
        else
                match
        end
end

puts ret

ううーん?

自動リロードで複数ブラウザ常に確認

とかやってると、なんか変な CSS 書かなくなるなぁ。すぐにダメな書き方がわかるのはいい感じだ。ダメな書き方って変な話だけど。

Perl で書いてみる @compile-css

#!perl

use strict;
use warnings;

my $pre = join "",  <ARGV>;
my %vars = ($pre =~ /\* \[([^\s;]+)\] = (.+)$/gm);

$pre =~ s[#\{(.+?)\}]{$vars{$1} ? $vars{$1} : $&}ge;

print $pre;

これだけ書くのに30分ぐらいかかった!! むずい。

vim script

:debug command

が表向きだよ。でも

:set verbose=9
:so %

まくり! って id:secondlife さんがいってた。ので、いくつか試してみよう。

2006年 07月 31日

自動リロードで開発をアジャイルにするたった一つの方法!

vim の保存と同時にIE/Opera on Windows をリロードするデモ

遠隔オートリロード
動画と説明
reload.rb
本体
reload-config.yaml
設定

みたいなのの変化版。下地をバイト先をちまちま作って、使いにくかったのでスクラッチから結局書き直した。同じように HTTP 鯖を webrick で立てるやつです。

dl で win32api を読んでる。使うのは PostMessage。でもなんか、SetForegroundWindow がないとだめだったり、あるとでしゃばってきたり、なくても普通に動いたりと怪しいのでウゴカネーってときはそのへんみたらいいかも。あと mswin32 版じゃないと SEGV する。

EnumWindows で列挙して、タイトルがソレっぽいやつに対して F5 を送るだけ。Fx はこの方法だとリロードされない。残念。

設定の chain でリクエストあったときにさらにリクエストを出すことができるので、こいつのトリガひくだけで、ma.la さんの Safari のスクリプトも同時にひけます。


vim 側

command! AutoReloadOFF let b:autoReload_disable = 1
command! AutoReloadON let b:autoReload_disable = 0
augroup AutoReload
au!
autocmd BufUnload,FileWritePost,BufWritePost * call <SID>AutoReload()
augroup END
function! s:AutoReload(...)
" Check enable
if exists('b:autoReload_disable') && b:autoReload_disable != 0
return
endif
silent exe "!GET 'http://nina:4321/reload' > /dev/null"
endfunction

タイトル

ブクマされても消されない程度に長く、かつキモイのがいい。

投げ銭

初投げ銭 ktkr

iolanguage

久しぶりに Io でもやってみようか、と思いきや、本家のブログのパーマリンクがエラー吐いてて萎える。

バイナリ

バイナリがいつのリリースだかわからない罠だなぁ。ソースからコンパイルしてみよう。

ソースから

えらーでた。あきらめた。バイナリは 20060214 だった。古
ダイナミックロードってできないのかな。なんか必要なのを全部まとめてビルドしてリンクしてるみたいだけど、やたら make に時間かかる。

IoVM

Full じゃないほうはいけた。っていうか普通にコアじゃない部分でエラーなんだよね。それでバイナリが生成されないのはなんともかんとも。Makefile 修正していらないのオフにしたりないといけないな。

IoServer

コアだけだと Regex が使えなくて役に立たないのでやっぱりちゃんと原因さぐる。エラーでてるのは OpenGL なので binding/OpenGL を rm -r して make。一応バイナリはできた。

うーん

仕組みとかは面白いんだけどなぁ。いまいち LL じゃないよなぁ。オレッテバスゲーができない。っていうか正規表現!!必須ですから!!

ぎがじん

そのうち TM とかサークルRとかついたりするんだろうか。

Title

  1. (なんだか忘れたけど一回公開/40秒ぐらい)
  2. vim の保存と同時にIE/Opera on Windows をリロードするデモ (5)
  3. 自動リロードで開発をアジャイルにするたった一つの方法!

hatebu: [http://b.hatena.ne.jp/entry/http://b.hatena.ne.jp/entry/http://lowreal.net/logs/2006/07/31/1:title=GIGAZINE: IE/Opera をお好みのエディタでリロードする10の秘訣!]


たった一つの方法 って意味がわかりません。

バイト

明日から、で、[[gerry]].

Title を Turtle

Title を Turtle に誤読する。Turtle といえば Logo、あるいはピザ。ピザでも食ってろミケランジェロ。

インターネット怖い

「ピザでも食ってろミケランジェロ」でぐぐったら既にあった……