私は clojurescriptone (きちんとしたプロジェクト) をいじって、clojurescript がどのように機能するかを理解しようとしました。3 つのコンポーネント、ブラウザー、ブラウザー repl、および http サーバーがどのように相互作用するかは明確ではありません。
開発環境にemacsを使用しています
ClojureScript(CS) をよりよく理解するために、clojurescriptone(CS1) を移植して lein2 を使用し、nrepl を repl として使用することにしました。ポートは機能し、CS1 環境を起動してブラウザとやり取りすることができました。私は - 今のところ - 下位の Lisp プロセスを開始して CS repl を操作するのではなく、clojure repl 内で CS repl を実行することを好みます。これの唯一の欠点は、CS repl が stdin から入力を受け取り、emacs が stdin を使用するように促すことです。これを回避するために、CS1 の一部のコードを置き換えて、Chas Emerick によって書かれた piggieback ライブラリから repl を開始しようとしています。
そうすることで、これらのコンポーネントがどのように相互作用するかについての理解の限界に達しました。どうやら私が収集できるものから、ブラウザのreplは、いくつかのポートでリッスンする「サーバー」です。ずっと、HTTP サーバーにリクエストを送信し、結果を評価した後に出力をブラウザーにリダイレクトするのはある種のクライアントだと思っていました (どのように??)。今、私はそれが事実であるかどうか確信が持てません。
これらのコンポーネントはどのように相互作用しますか?
説明が長くなってすみません!!!
シド