Freelineとはなにものか
これはAndroidその2 Advent Calendar 2016の23日目の記事です。
はじめに
昨今Androidのbuildまわりの話は結構盛り上がっているなーと感じます。 Androidのbuildをしてるとマシンリソースをもっていかれて他の作業に支障がでたりすので、自分のマシン以外に誰も使ってないマシンをbuildサーバ的に使ったり、GCPなどのクラウドリソースを使ったりすることで解消する方法が様々出てきています。 それ自体は最高だな!自分も職場では使っていくぞ!という気持ちで実際空いてるiMacを使ってbuildしたりしています。
一方でbuild自体が高速で終わればbuild中に何分間も他のことができない!みたいな状況はないのではないかとも思います。 また個人開発として考えた時に、札束で叩く選択肢はなかなか取りづらいよなーと思ったりもします。 そこでひとつの解決策として良さそうなのが今回紹介するalibaba/freelineです。
Freelineとは
概要
githubのREADEMEの導入部分を引用すると下記のように紹介されています。
Freeline is a fast build and deployment tool for Android. Caching reusable class files and resource indices, it enables incrementally building Android apps, and optionally deploying the update to your device with hot swap.
Developed and used by Ant Fortune (about us) Android Team, Freeline has been significantly saving time in daily work. Inspiring by Buck and Instant Run but faster than ever, Freeline can finish an incremental build in just a few seconds. No more recompile and reinstall again and again before seeing your modifications, Freeline brings life-changing development experience for Android.
要点だけまとめるとこんな感じです。
- ホットスワップを可能にするぜ!
- BuckとInstant Runにインスパイアされているが、それらよりもより早く動作するぜ!
- FreeLineはAndroid開発生活に変革をもたらすぜ!
完全に意訳ですが、ノリとしてはこれぐらいハッピーな感じで書かれてるんじゃないかと勝手に理解しました。
詳細
特徴
また下記の項目の変更に対応しているようです。
Java | drawable, layout, etc. | res/values | native so | |
---|---|---|---|---|
add | √ | √ | √ | √ |
change | √ | √ | √ | √ |
remove | √ | √ | x | - |
他にもたくさんあるようですが、RADEMEに記載されているので興味がある方はご覧ください。
まだまだな点
- 初回だけちょっと遅い
res/values
の削除には対応できていない- 抽象クラスのインクリメンタルビルドはできない
- Kotlinはサポートしていない
最近の国内でのKotlin熱を考えるとサポートしてないのはちょっとつらいかもしれないですね。
Freelineの使い方
githubにsampleプロジェクトがあるので、それを使ってみます。 手順はこれだけ。
git clone git@github.com:alibaba/freeline.git cd freeline/sample ./gradlew initFreeline python freeline.py
実際にコマンドの実行をしているところを動画に収めたのでご覧ください。 (本当はttyrecとttygifを使ってgif化したかったのですが、謎のエラーでttyrecが使えず今回の記事では諦めましたorz)
— futabooo (@futabooo) 2016年12月23日
なんかtaskが並行実行されてる雰囲気がわかっていただければ幸いです。 既存の自分のプロジェクトに導入する場合はbuild.gradleへの記述などありますが、READEMEに書いてあるので簡単に導入可能です。
おわりに
手元にある大きめのプロジェクトはkotlinが入っていたりしてうまく動かなかったので、Freelineでどれだけ早くなるのか比較を書くことができずに終わってしまいました。 この記事をみてFreelineを試した方にぜひ比較結果をコメントもらえたらなーと思っています。
またほとんどFreelineのREADMEを紹介するだけになってしまいましたが、今回本当に紹介したかったのは下記の記事です。 中国語で書かれており、内容の把握に骨が折れますがFreelineがどのように実装されているのか詳細な紹介がされています。 Androidのフレームワークの知識が必要なため僕自身グーグル先生とともに解読中です。
参考
Pokémon GOを一足早くやってみた
野良apkが配布されてたのでやってみました!
アプリ起動後の登録画面
テレビから離れてみてね!的な画面
オーキドじゃない!!
それなりにアバターいじれる
近くにいるらしい。
現実背景をうつすこともできる!
ヒトカゲいた!
ヒトカゲおったぞ! pic.twitter.com/sCxuF00fLJ
— futabooo (@futabooo) 2016年7月15日
野良apkは下記リンクから。DL、インストールは自己責任でおねがいします。 Pokémon GO 0.29.2 APK Download by Niantic, Inc. - APKMirror
Amazon Kindle本のセールのAndroid界隈の本をまとめてみた
はじめに
全部Kindle本です。Androidで検索すればもっといっぱい出てきますが、有名ドコロだけ集めてみました。 半分ぐらい持ってなかったので買っちゃいました。
AndroidのKindle本
Google Androidプログラミング入門 改訂2版 (アスキー書籍)
50 Android Hacks 開発現場ですぐに役立つヒントとコード (アスキー書籍)
良いAndroidアプリを作る139の鉄則
Smashing Android UI レスポンシブUIとデザインパターン
Android Pattern Cookbook マーケットで埋もれないための差別化戦略
Android Security 安全なアプリケーションを作成するために
これはちょっと番外編だけど。 Gradle徹底入門 次世代ビルドツールによる自動化基盤の構築
JIRAのMentionコメントをSlackのDMで通知するスクリプト
追記(2015/05/19)
このまま使うには一度botとDMのやりとりをしておく必要があります。
はじめに
JIRAのコメントの通知がメールでしか来ないと見逃すし、Slackに流れてきたら楽なのにって思ったので作った。
使い方
- JIRAのWebHooksに
[your heroku app url]/hubot/jira-comment-dm
のURLを登録し、issueのupdatedだけチェックを入れておく。 - JIRAのURLを
heroku config:add HUBOT_JIRA_URL=[your jira url]
で環境変数に登録しておく。 - (必要であれば)JIRAのハンドルネームとSlackのハンドルネームが異なる場合はmapに登録しておく。
サンプル
こんな感じでDMが届く。仕事しろって言われてる。
# Description: # hubot monitoring jira comments mention and slack DM # # Dependencies: # None # # Configuration: # HUBOT_JIRA_URL # # Commands: # None # # Author: # futabooo # Use if the user name of jira and slack is different # "jiraName": "slackName" map = module.exports = (robot) -> convertHandleName = (name) -> map[name] || name extractHandleName = (body) -> temp = body.match(/\[~.+?]/g) unless temp is null name = [] for i in temp name.push("#{i}".replace(/[\[~\]]/g, "")) return name robot.router.post '/hubot/jira-comment-dm', (req, res) -> body = req.body if body.webhookEvent == 'jira:issue_updated' && body.comment issue = "#{body.issue.key} #{body.issue.fields.summary}" url = "#{process.env.HUBOT_JIRA_URL}/browse/#{body.issue.key}" handleNameList = extractHandleName(body.comment.body) unless handleNameList is null for i in handleNameList robot.send(room: convertHandleName(i), "*#{issue}* _(#{url})_\n@#{body.comment.author.name}'s comment:\n```#{body.comment.body}```") res.send 'OK'
さいごに
正規表現力が低くて一発で名前を抜けてないけど、動いてるから運用上問題ないと思われる。 人が増えたら超大変だろうなぁと思ってる。
参考
iTerm2でpowerline、カラースキームはsolarizedで!
はじめに
今までずっとbashだったので、そろそろzshにしよう!と思い作業を進めていたら、zshの環境を用意することよりも見た目に拘っていたら、powerlineの見た目を用意することに結構かかったので備忘録です。
最終成果(とりあえず満足!)
zshの導入
導入というのもへんな話ですが、.zshrcとかを用意します。 ここは結局oh-my-zshを使いました。一瞬です。
oh-my-zshのthemeをpowerlineにする
こいつに時間がかかったわけですが、大きく2つハマりました。
- フォントがうまく表示されない
- 色合いが気に食わない
フォントについて
自分でこれじゃなきゃ嫌だ!とかがなければpowerline/fonts · GitHubからパッチが適用済みのフォントが落とせるのでそれでもいいと思います。僕はRictyが使いたかったので、手動でパッチを当てました(終わったあと出てきましたが、Rictyのパッチ済みフォントはbrewで落とせるらしいです。)
ここを参考にRictyにパッチを当てます。
[Mac + tmux + iTerm] ステータスバーをpowerlineでカッコ良くする - Qiita
色について
このテーマをREADMEを見つつ設定します。
KuoE0/oh-my-zsh-solarized-powerline-theme · GitHub
しかし上の設定だけだとiTermのデフォのカラースキームと全く合わないので、iTermのスキームをsolarized-darkに変更しました。iTermのカラースキーム変更は以前書いた下の記事を参考にしてください。 iTerm2のカラースキーマまとめ - WhereToStart
CentOSとDockerとWordpress
タイトルの元ネタを全く思い出せません。
今日はsakuraVPS(CentOS6.5)上にDockerでWordpressが構築できたので備忘録です。
## 構成
NginXをプロキシサーバー、DockerにApacheとMysqlのせてWordpressインストール
と言った感じです。
とりあえず使う場合は下記でいけるかと。
```
$ git clone https://github.com/futabooo/dockerfiles.git
$ cd dockerfiles
$ sudo docker build -t centos:wordpress .
$ sudo docker run -p 49174:80 -d centos:wordpress
```
dockerコマンドでDockerファイルからイメージをビルドする。
ビルドしたイメージからコンテナ作成。
この時コンテナ側の49174ポートにホスト側の80ポートをつなぐ。
Nginxでのvirtual.confはこんな感じ。
```
server {
listen 80;
server_name example.com;
access_log /var/log/nginx/nilab.jp-access_log main;
error_log /var/log/nginx/nilab.jp-eroor_log warn;
location / {
proxy_pass http://127.0.0.1:49174;
}
}
```
server_nameとかは適宜読み替えていただきたく。
これで超ピュアなWordpressが動くようになります。
ただコンテナをkillするとデータが残らないので、ドカドカ作っては壊すときはご注意を。
参考
dockerでImmutable InfrastructureなWordPressを考える
memorycraft: Dockerってなんじゃ?(docker+nginxで複数コンテナにWEBサーバーをたてる)
MarkDown記法に変えたのに全然なってない??
書き方の問題か。。。