2012/10/16


しばらく zencoding-vim の emmet ブランチで開発し、落ち着いたら master にマージします。

親参照

^ で親へ移動出来る様になってます。
.header>.nav^.logo
これが <div class="header">
    <div class="nav"></div>
</div>
<div class="logo"></div>
こう展開されます。^^ で複数階層登れます。

高度なCSS補完

おそらくこれが emmet の最大の武器と思う。
まず m0.1 margin: 0.1em; に展開される。また m2 margin: 2px; に、m3p margin: 3%; に展開される。本来ならば z-index の様に px 単位で無い物には単位を付けない様にしないといけないけど、この辺は後々やってく。

ベンダープレフィックス

好き嫌いありそうな機能ですが...
通常 bdrs8 border-radius: 8px; にされるが、頭に - を付けると -bdrs8 -webkit-border-radius: 8px;
-moz-border-radius: 8px;
border-radius: 8px;
と変換される。また、lg(top,#fff,#000) から background-image:  -webkit-gradient(top, 0 0, 0 100, from(#fff), to(#000));
background-image:  -webkit-linear-gradient(#fff, #000);
background-image:  -moz-linear-gradient(#fff, #000);
background-image:  -o-linear-gradient(#fff, #000);
background-image:  linear-gradient(#fff, #000);
に変換される。


興味ある人は emmet ブランチで人柱お願いします。
mattn/zencoding-vim ツキ GitHub
https://github.com/mattn/zencoding-vim
Posted at by



2012/10/11


タイトルなげーーーーーーーーーーー!
プロキシ環境下でしか動きませんが、使いたい人は勝手に書き換えて下さい。
boost::bind 使わずラムダだけでやってんの、オレオレルールだから気にした奴は負け。
#define _WIN32_WINNT 0x0501
#include <iostream>
#include <string>
#include <sstream>
#include <system_error>
#include <boost/array.hpp>
#include <boost/bind.hpp>
#include <boost/regex.hpp>
#include <boost/foreach.hpp>
#include <boost/asio.hpp>
#include <boost/system/error_code.hpp>
#include <boost/property_tree/json_parser.hpp>

using namespace boost::asio;
using namespace boost::asio::ip;
using namespace boost::property_tree;
using namespace boost::system;

int
main(int argc, char* argv[]) {
  if (argc == 1) {
    std::cerr << "usage: " << argv[0] << " [words]" << std::endl;
    return -1;
  }

  // リクエストする URL を作る
  std::string get_url =
    "http://ajax.googleapis.com/ajax/services/search/web?v=1.0&q=";

  for (int i = 1; i < argc; i++) {
    std::string arg = argv[i];
    BOOST_FOREACH(auto c, arg) {
      if ((c >= 'A' && c <= 'Z') || (c >= 'a' && c <= 'z') ||
          (c >= '0' && c <= '9') ||
          c == '-' || c == '_' || c == '.' || c == '~') {
        get_url += c;
      } else if (c == ' ') {
        get_url += '+';
      } else {
        std::stringstream ss;
        ss << "%" << std::hex << std::setw(2) <<
          std::setfill('0') << (int) (c & 0xff);
        get_url += ss.str();
      }
    }
  }

  // HTTP_PROXY 環境変数からホスト名とポート番号を得る
  std::string http_proxy = std::getenv("HTTP_PROXY");
  boost::regex pattern("^(?:http://)?([^/]+):([0-9]+)");
  boost::match_results<std::string::const_iterator> it;
  if (!regex_search(http_proxy, it, pattern)) {
    std::cerr << "プロキシを使っていません" << std::endl;
    return -1;
  }

  io_service service;
  tcp::resolver resolver(service);

  // ホスト名から名前解決を行う
  tcp::resolver::query resolver_query(
    std::string(it[1].first, it[1].second), // ホスト名
    std::string(it[2].first, it[2].second)  // ポート番号
  );

  std::string data;
  resolver.async_resolve(
    resolver_query,
    [&](const error_code& ec, tcp::resolver::iterator it) {
      if (ec) {
        std::cerr << ec.message() << std::endl;
      } else {
        // プロキシに接続する
        tcp::socket socket(service);
        socket.async_connect(
          it->endpoint(),
          [&](const error_code& ec) {
            if (ec) {
              std::cerr << ec.message() << std::endl;
            } else {
              // プロキシに GET 命令を送信する
              std::string query = "GET ";
              query += get_url;
              query += " HTTP/1.0\r\n\r\n";

              async_write(
                socket,
                buffer(query.c_str(), query.size()),
                [&](const error_code& ec, std::size_t len) {
                  if (ec) {
                    std::cerr << ec.message() << std::endl;
                  } else {
                    boost::array<char1024> buf;
                    std::stringstream ss;
                    // HTTP/1.0 なので切断までループ
                    while (socket.is_open()) {
                      socket.async_read_some(
                        buffer(buf),
                        [&](const error_code& ec, std::size_t len) {
                          if (ec) {
                            socket.close();
                          } else if (len == 0) {
                            socket.close();
                          } else {
                            ss << std::string(buf.data(), len);
                            buf.assign(0);
                          }
                        });
                      service.run_one();
                    }
                    data = ss.str();
                    // ヘッダを取り除く
                    std::size_t pos = data.find("\r\n\r\n");
                    if (pos != std::string::npos) {
                      data = data.substr(pos + 4);
                    }
                  }
                });
              service.run_one();
            }
          });
        service.run_one();
      }
    });
  service.run_one();

  if (!data.empty()) {
    // 結果で得られた JSON をパースする
    std::stringstream ss(data);
    ptree pt;
    read_json(ss, pt);

    if (pt.get<int>("responseStatus") == 200) {
      // 結果配列でループしながら表示
      ptree& results = pt.get_child("responseData.results");
      BOOST_FOREACH(const ptree::value_type& result, results) {
        std::string url = result.second.get<std::string>("url");
        std::string title = result.second.get<std::string>("titleNoFormatting");
        std::cout << url << std::endl << "  " << title << std::endl;
      }
    }
  }
  return 0;
}
Posted at by




JekyllGitoliteを連携させたら思いのほか便利だったという話。
以下は CentOS6 でやった履歴。まず jekyll をインストールする。これは rvm じゃなくて後で作る git ユーザから実行可能な物でないといけない(まぁパス通してもいいけど)。
$ yum install git gitweb ruby rubygems
$ gem install jekyll
git ユーザを作る。 $ useradd git
$ passwd git
ssh でログイン出来る様にする。 $ vi /etc/sshd/sshd_config
$ /etc/init.d/sshd restart
※AllowUsers に git を足す
gitolite のインストール。 $ su - git
$ cp /tmp/trusted-key.pub foo.pub
$ git clone https://github.com/sitaramc/gitolite.git
$ `pwd`/gitolite/install -ln
$ gitolite setup -pk foo.pub
※foo はメインで使うユーザ名にしておくと良い
リモートから gitolite-admin で blog を作る。 $ git clone git@server:gitolite-admin
$ cd gitolite-admin
$ vi conf/gitolite.conf
repo gitolite-admin
    RW+     =   mattn

#repo testing
#    RW+     =   @all

repo blog
    RW+     = foo
    R       = gitweb
    config gitweb.owner = foo
    config gitweb.description = blog
$ git commit -a
$ git push origin master
ここでサーバ側に仕掛けを入れる。 $ su - git
$ vi ~/repositories/blog.git/hooks/post-receive
#!/bin/sh

GIT_REPO=$HOME/repositories/blog.git
TMP_GIT_CLONE=$HOME/tmp/blog
PUBLIC_WWW=/var/www/blog

git clone $GIT_REPO $TMP_GIT_CLONE
cd $TMP_GIT_CLONE && jekyll --no-auto $TMP_GIT_CLONE $PUBLIC_WWW
cd ~ && rm -rf $TMP_GIT_CLONE

find $PUBLIC_WWW -type f -print0 | xargs -0 chmod 666
find $PUBLIC_WWW -type d -print0 | xargs -0 chmod 777

exit
またapacheでブログが見れる様にする。 $ su -
$ mkdir /var/www/blog
$ chmod 775 /var/www/blog
$ chown git:git /var/www/blog
$ vi /etc/httpd/conf/httpd.conf
DocumentRoot "/var/www/blog" apacheグループから見れる様にする $ usermod -a -G apache git リモートから blog リポジトリをチェックアウト。 $ git clone git@server:blog ここから先は、Jekyllで始める簡単ブログを読んでJekyllを設定して欲しい。
さて、あとは記事を書いてgit addして、コミットそしてプッシュすれば自動的にサーバ側でjekyllが静的コンテンツを生成してくれ、ブログが公開される様になる。

GitHub Pages ぽくなってウマー。
Posted at by