Elixir/Phoenixでウェブサービスを作っている19
寝てて更新が遅れた。今日は深夜大寒波で足が寒くてプログラミングやってらんなかったのと、Clojureの勉強の方でVimの設定にハマったので、些少な進捗しか出せなかった。明日は頑張る。
Done:
- ブラウザ
- 開いてないゴールを
display: none
するようにした
- 開いてないゴールを
Todo:
- ブラウザ
- ツリー全体を展開する
- 上下移動
- jk
- 右移動
- h
- 左移動
- l
- new/create
- n: 新規、enterで作成
- edit/update
- e: 編集、enterで更新
- delete
- X: 削除
- copy/cut/paste
- c: 単体コピー
- C: サブツリー全体をコピー
- x: カット
- v: 下にペースト
- V: 上にペースト
- status切り替え
- f: forward
- b: back
- q: close
- タブ
- システムメニュー
- サインイン/サインアウト
- ユーザーメニュー
- アクティビティ
- ユーザー/グループ...
- アクティビティ
- システムメニュー
- オフライン対応
- すごく欲しいがやらない
- 当初想定より簡単にできるかも
- サーバ
- Activity(activities)
- Status(statuses)
- id
- name
- position
- enable
- ユーザー定義
- デフォルト
- 0: todo
- 1: doing
- 2: done
- -1: close
- done/closeは特別にしたいな……
- 面倒くさいなこれ。固定にしよっかな
- デフォルト
- Group(groups)
- 1ユーザー1グループ作る?
- id
- name
- Membership(memberships)
- user_id
- group_id
- pending
- 操作権限チェックを入れる
- ルート操作の防止を入れる
- /goals/:idを/goals/:hash_digestにする
- User.nickにunique属性つける
- check_descendants!でArgumentErrorにしてるところを独自例外に変える
- on_delete: :delete_allと再帰クエリでどっちが速いか調べる
Memo:
- CSS3 flex
- JSONPath
- JavaScript用: s3u/JSONPath
- こっちは多分要る
- Erlang用: GeneStevens/jsonpath
- こっちはいらないと思うが、1つのゴールを返すとき先祖も付けて返す必要ありそう
- JavaScript用: s3u/JSONPath
- jsでスムーススクロールする方法
- jsでマウスホイールイベントを取得する方法
Programming Phoenix: Productive; Reliable; Fast
- 作者: Chris Mccord,Bruce Tate,Jose Valim
- 出版社/メーカー: Pragmatic Bookshelf
- 発売日: 2016/04/11
- メディア: ペーパーバック
- この商品を含むブログを見る
Clojureを勉強している8
- Creating a Web Server with Compojure
- 第7章はウェブアプリを作るということなので楽しみでござる
- おっ、ClojureScriptも書くらしい。
- Compojureというライブラリを使うらしい。
- CompojureはRingというローレベル・ウェブアプリケーション・ライブラリにシンプルなルーティングを提供するものらしい。RingがRubyのSinatra相当なのかな?
- サンプル・アプリケーション名はcheshire-cat。いちいち書かなかったけどこの本のサンプルは全て不思議の国のアリスの筋書きに則っている。
- Clojure+ClojureScriptって綺麗な組み合わせだよなぁ。JavaScriptで全部書ける次に良い。あとこんなに統一できるのはScala+Scala.jsぐらいか?
- プロジェクトのスケルトン作るのに、
lein new compojure cheshire-cat
しろって書かれてるんだけど、compojureいつダウンロードしたの?leiningenに組み込みなの???どゆこと? - Clojure、謎が多くて、前の章ではcore.asyncってライブラリ使ったんだけど、ダウンロードするコマンドなどは一切打った覚えがなく動いていて、便利と同時になんか表示して欲しい感じがする(自動でCLASSPATHを設定するVimプラグインのせいか?)
- 実行したら、Retrieving compojure/lein-template/0.4.3/lein-template-0.4.3.{pom|jar} from clojars、みたいなメッセージ出た。
- 自分で生成したプロジェクトのREADME.mdを読む。ほうほう、lein ring server でサーバが起動するのか。
- lein ring server したらすごい勢いでダウンロードしだしたw apacheとかjettyとか言う文字列が見えてビビる。マジで?
- そしてブラウザが自動で開いた。Omakaseだ。
- Clojure/Ring/Compojureの使うポートは3000で、今Railsプロジェクトやってなくて良かったという思い。いやポート番号ぐらい指定できるだろうけど。(ちなみにPhoenixは4000)
- まぁ例えだから正確じゃないのでどうでもいいんだが、RingがRack、CompojureがSinatra相当っぽい。
- 自動生成されるRing middlewareのsite-defaultsのオプションが見たければ、https://github.com/ring-clojure/ring-defaults を見よとのこと。はい。
- Compojure、ルート追加してもサーバ再起動しなくていいのスゴイな。楽。
- Using JSON with the Cheshire Library and Ring
- サンプルプロジェクト名がcheshire-catなんだけど、この中でCheshireというJSONを扱うライブラリを使うのでややこしい
- lein ring server-headlessするとnot open a new windowだよって書いてあったので実行してみたら、ブラウザのウィンドウが開かないということだった。てっきりターミナルのウィンドウの1つを専有しないって意味かと思ってた。
- leinと打つたびにleiningenさんのゴーストがささやいてツラい
- Cheshireは
generate-string
がClojureデータ構造からJSONにエンコード、parse-string
がデコード。ふむ。 - ただし、
parse-string
の第2引数にtrue
を与えると、キーがキーワードになる、と。 app-routes
ではレスポンスに:status, :headers, :bodyを含んだマップを返すことができると。- Cheshire使ってJSONエンコードしてたのにRing-JSON入れれば自動的にbodyのClojureデータ構造をJSONに変換してくれるから要らない取り換えと言い出したぞ
- Cheshireからring-json&ring.util.responseに替えたらoctet-streamを返すようになって、
(ring.util.response/response res "application/json; charset=utf-8")
する必要があった
この辺で時間切れでギブアップ。というか、tpope/vim-fireplaceがクソ重かったので消したり、kien/rainbow_parentheses.vimがうまく動かなくてluochen1990/rainbowに入れ替えたりしてて時間かかった。
つづく
- Chapter 7 Creating Web Applications with Clojure
- Creating a Web Server with Compojure
- Using JSON with the Cheshire Library and Ring
- 作者: Carin Meier
- 出版社/メーカー: Oreilly & Associates Inc
- 発売日: 2015/04/30
- メディア: ペーパーバック
- この商品を含むブログを見る
Elixir/Phoenixでウェブサービスを作っている18
Done:
- ブラウザ
- jsでスムーススクロールする方法の調査
- jsでマウスホイールイベントを取得する方法の調査
- HTMLの構造をカラムからツリーに変更
Todo:
- ブラウザ
- ツリー全体を展開する
- 上下移動
- jk
- 右移動
- h
- 左移動
- l
- new/create
- n: 新規、enterで作成
- edit/update
- e: 編集、enterで更新
- delete
- X: 削除
- copy/cut/paste
- c: 単体コピー
- C: サブツリー全体をコピー
- x: カット
- v: 下にペースト
- V: 上にペースト
- status切り替え
- f: forward
- b: back
- q: close
- タブ
- システムメニュー
- サインイン/サインアウト
- ユーザーメニュー
- アクティビティ
- ユーザー/グループ...
- アクティビティ
- システムメニュー
- オフライン対応
- すごく欲しいがやらない
- 当初想定より簡単にできるかも
- サーバ
- Activity(activities)
- Status(statuses)
- id
- name
- position
- enable
- ユーザー定義
- デフォルト
- 0: todo
- 1: doing
- 2: done
- -1: close
- done/closeは特別にしたいな……
- 面倒くさいなこれ。固定にしよっかな
- デフォルト
- Group(groups)
- 1ユーザー1グループ作る?
- id
- name
- Membership(memberships)
- user_id
- group_id
- pending
- 操作権限チェックを入れる
- ルート操作の防止を入れる
- /goals/:idを/goals/:hash_digestにする
- User.nickにunique属性つける
- check_descendants!でArgumentErrorにしてるところを独自例外に変える
- on_delete: :delete_allと再帰クエリでどっちが速いか調べる
Memo:
- CSS3 flex
- JSONPath
- JavaScript用: s3u/JSONPath
- こっちは多分要る
- Erlang用: GeneStevens/jsonpath
- こっちはいらないと思うが、1つのゴールを返すとき先祖も付けて返す必要ありそう
- JavaScript用: s3u/JSONPath
Programming Phoenix: Productive; Reliable; Fast
- 作者: Chris Mccord,Bruce Tate,Jose Valim
- 出版社/メーカー: Pragmatic Bookshelf
- 発売日: 2016/04/11
- メディア: ペーパーバック
- この商品を含むブログを見る
Clojureを勉強している7
ns
関数の引数に(gen-class)
を入れないとREPLが立ち上がったときに環境を読んでくれないのでハマった。
- Basics of core.async Channels
- Serving Tea at a core.async Tea Party
Creating a Tea Party to Be Run from the Command Line
- おお、jar作るのか。起動が速くなるのかな?
project.clj
に(:aot project-name.core)
オプションを足すだけ。lein uberjar
で作成!target
ディレクトリにjarが出来上がっている-standalone.jar
はClojureクラスも全部入り。もう一個の方は自分と(この例では)core.async
のみ入っているjar。java -jar project-name-0.1.0-SNAPSHOT-standalone.jar
で実行!- やっぱり立ち上がりが遅かった。
Chapter 6 Communication with core.async
- Basics of core.async Channels
- Serving Tea at a core.async Tea Party
- Creating a Tea Party to Be Run from the Command Line
- 作者: Carin Meier
- 出版社/メーカー: Oreilly & Associates Inc
- 発売日: 2015/04/30
- メディア: ペーパーバック
- この商品を含むブログを見る
Elixir/Phoenixでウェブサービスを作っている17
今日は出だしが遅かったので進捗が少ない(しかし、コミット数は多め)。
Done:
- ブラウザ
- Component分割
- CSS3でリストのツリーをカラム表示に変換できるか調査
- 実験中……
- 先祖を詰めるのが難しい
- 実験中……
- JSONPathが必要?
- JavaScript用: s3u/JSONPath
- こっちは多分要る
- Erlang用: GeneStevens/jsonpath
- こっちはいらないと思うが、1つのゴールを返すとき先祖も付けて返す必要ありそう
- JavaScript用: s3u/JSONPath
Todo:
- ブラウザ
- 兄弟を展開する
- 子を展開する
- 先祖を展開する
- 上下移動
- jk
- 右移動
- h
- 左移動
- l
- new/create
- n: 新規、enterで作成
- edit/update
- e: 編集、enterで更新
- delete
- X: 削除
- copy/cut/paste
- c: 単体コピー
- C: サブツリー全体をコピー
- x: カット
- v: 下にペースト
- V: 上にペースト
- status切り替え
- f: forward
- b: back
- q: close
- タブ
- システムメニュー
- サインイン/サインアウト
- ユーザーメニュー
- アクティビティ
- ユーザー/グループ...
- アクティビティ
- システムメニュー
- オフライン対応
- すごく欲しいがやらない
- サーバ
- Activity(activities)
- Status(statuses)
- id
- name
- position
- enable
- ユーザー定義
- デフォルト
- 0: todo
- 1: doing
- 2: done
- -1: close
- done/closeは特別にしたいな……
- 面倒くさいなこれ。固定にしよっかな
- デフォルト
- Group(groups)
- 1ユーザー1グループ作る?
- id
- name
- Membership(memberships)
- user_id
- group_id
- pending
- 操作権限チェックを入れる
- ルート操作の防止を入れる
- /goals/:idを/goals/:hash_digestにする
- User.nickにunique属性つける
- check_descendants!でArgumentErrorにしてるところを独自例外に変える
- on_delete: :delete_allと再帰クエリでどっちが速いか調べる
Programming Phoenix: Productive; Reliable; Fast
- 作者: Chris Mccord,Bruce Tate,Jose Valim
- 出版社/メーカー: Pragmatic Bookshelf
- 発売日: 2016/04/11
- メディア: ペーパーバック
- この商品を含むブログを見る
Clojureを勉強している6
- Getting Set Up with a Clojure Editor
- やっとファイルに書ける! ずっとREPLでやってきてtypoしたとき不便だった。
- vimなのでvimプラグインを入れる
- guns/vim-clojure-static
- シンタックスハイライト、インデントなど。基本。
- tpope/vim-fireplace
- vimからREPL等呼び出し。
- kien/rainbow_parentheses.vim
- インデントのレベルに応じて括弧の色を変える
- tpope/vim-classpath
- プロジェクト定義から 自動的にクラスパスを設定してくれる
- guns/vim-clojure-static
- Creating Our Project with Leiningen
- なんや知らんがネームスペースをcoreから変えていく。
lein test
でテスト実行
- Dependency Management with Leiningen
- パッケージのリポジトリはデフォルトでは、ClojarsとMaven Centralの2つを見ると。
- snake_case、CamelCaseは知っていたが、kebab-caseと呼ぶのは初めて知った。LISP系はケバブケースが使えるので素敵。
Using Libraries in Your Own Project
project.clj
の:dependencies
に使いたいパッケージ名とバージョンを加える。:require
でモジュールを取り込み。:as
で別名を付けることができる。module-name/->function-name
で関数呼び出し。(defn -main [& args] ... )
でメイン関数を設定しlein run
でモジュール名を書かなくても実行できる
Chapter 5 How to Use Clojure Projects and Libraries
- Getting Set Up with a Clojure Editor
- Creating Our Project with Leiningen
- Dependency Management with Leiningen
- Using Libraries in Your Own Project
- 作者: Carin Meier
- 出版社/メーカー: O'Reilly Media
- 発売日: 2015/04/14
- メディア: Kindle版
- この商品を含むブログを見る
Elixir/Phoenixでウェブサービスを作っている16
Done:
- サーバ
- リファクタリングいろいろ
- Goal.Commands
- copy
- Goal.Queries
- self_and_descendant_ids
- descendant_ids
- POST /goals/:target_id/copy?dest_parent_id=:dest_parent_id&dest_position=:dest_position
Todo:
- サーバ
- Activity(activities)
- Status(statuses)
- id
- name
- position
- enable
- ユーザー定義
- デフォルト
- 0: todo
- 1: doing
- 2: done
- -1: close
- done/closeは特別にしたいな……
- 面倒くさいなこれ。固定にしよっかな
- デフォルト
- Group(groups)
- 1ユーザー1グループ作る?
- id
- name
- Membership(memberships)
- user_id
- group_id
- pending
- 操作権限チェックを入れる
- ルート操作の防止を入れる
- ブラウザ
- 兄弟を展開する
- 子を展開する
- 先祖を展開する
- 上下移動
- jk
- 右移動
- h
- 左移動
- l
- new/create
- n: 新規、enterで作成
- edit/update
- e: 編集、enterで更新
- delete
- X: 削除
- copy/cut/paste
- c: 単体コピー
- C: サブツリー全体をコピー
- x: カット
- v: 下にペースト
- V: 上にペースト
- status切り替え
- f: forward
- b: back
- q: close
- タブ
- システムメニュー
- サインイン/サインアウト
- ユーザーメニュー
- アクティビティ
- ユーザー/グループ...
- アクティビティ
- システムメニュー
- オフライン対応
- すごく欲しいがやらない
- /goals/:idを/goals/:hash_digestにする
- User.nickにunique属性つける
- check_descendants!でArgumentErrorにしてるところを独自例外に変える
- on_delete: :delete_allと再帰クエリでどっちが速いか調べる
- 作者: Bill Karwin,和田卓人,和田省二,児島修
- 出版社/メーカー: オライリージャパン
- 発売日: 2013/01/26
- メディア: 大型本
- 購入: 9人 クリック: 698回
- この商品を含むブログ (41件) を見る
Programming Phoenix: Productive; Reliable; Fast
- 作者: Chris Mccord,Bruce Tate,Jose Valim
- 出版社/メーカー: Pragmatic Bookshelf
- 発売日: 2016/01/25
- メディア: ペーパーバック
- この商品を含むブログを見る