【普通のやつらの】 Arc Language 0 【上を行け】

■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
垢版 |
2008/02/04(月) 13:22:29
プログラミング言語Arc

あのPaul Grahamが長年考案しつつもベーパーウェアだったArcがとうとう発表された。
これを使えば今日から君もスーパーハッカーだ(*注: Arcは現在のところASCII以外の
文字を適切に扱えません)。

公式サイト
http://www.arclanguage.org/
インストール
http://www.arclanguage.org/install
チュートリアル
http://ycombinator.com/arc/tut.txt
非公式リファレンス
http://practical-scheme.net/wiliki/arcxref

* なぜArcはとりたててオブジェクト指向でないのか
http://practical-scheme.net/trans/noop-j.html
2008/02/05(火) 23:32:51
スレ違いです
2008/02/05(火) 23:33:02
&restが要らなくなったー
2008/02/05(火) 23:33:30
>>48
ストールマンは何で実装されてるの?
2008/02/05(火) 23:40:00
TECO
2008/02/05(火) 23:40:22
三角関数がないのは(xdef 'sin sin)をac.scmに追加すれはOK。
で、xdefで関数名に _ を追加して名前空間にセットしているらしい。

(sin 3.14)がコンパイルされると
(ar-funcall1 _sin 3.14)

1000行くらいなら読めるしPaul Grahamが残したらしいコメントから
彼の思考過程を探ることもできそうだ。こりゃ、面白いぜ。
2008/02/06(水) 00:11:16
これ、なんでシンボルを| fact|とかにしてるの?
2008/02/06(水) 00:18:17
> '(1 . 2 . 3)
(2 1 3)

なにこれ
2008/02/06(水) 07:27:58
>>38
IronScheme
2008/02/06(水) 19:15:19
ラムダ計算プログラムを書いてみた

http://natal.web.fc2.com/lambda.arc.txt
2008/02/06(水) 19:53:26
>>57

あなた、すごい人だね。
解説、頼みます。

2008/02/06(水) 21:37:26
やっぱりrubyには敵わないな
2008/02/06(水) 22:17:19
そうだな。RubyはLispの方言としてはずば抜けてるからな。
2008/02/06(水) 22:34:06
S式に囚われている限りRubyには勝てないね
2008/02/06(水) 22:42:45
逆。S式に(逆向きに)囚われてるのはMatzなんだから
> S式に囚われている限りRubyは勝てないね
だよ。
2008/02/06(水) 22:43:38
俺のarcスレで関係ない言語の話すんなよ
2008/02/06(水) 22:45:10
arcってschemeと何が違うんだよ。

単なるschemeの別バージョンならschemeスレでやれってこと。
糞スレ立てるなってこと。
2008/02/06(水) 22:47:27
すまん。おまえのスレで。
2008/02/06(水) 22:48:10
>>64
SchemeよりはむしろLispに近いと思うが
2008/02/06(水) 23:29:34
57の人には感心してしまった。

(ac s env) のssyntax? って何だろう?と首をひねっていた。
car:cdr は〜、なるほど。

cccの使い方ってそれはバックトラック?

忙しいのかね〜。出てきて教えて欲しいね〜。
2008/02/07(木) 00:10:35
Lisp-2 + パッケージシステム + legacy macro = CL
Lisp-1 + hygienic macro = Scheme
Lisp-1 + legacy macro - パッケージシステム = Arc

らしい。ここの shiro さんのコメントより。
ttp://d.hatena.ne.jp/archacker/20080203/1201988205#c
2008/02/07(木) 00:18:28
>>67
57じゃないけど、このcccの使い方はいわゆる大域脱出ってやつかな。

Common Lispだとblock/return-from、他の言語だとtry/catch/throw等の
例外機構を使う。
7067
垢版 |
2008/02/07(木) 00:22:36
>>69
なるほど〜。

2008/02/07(木) 00:34:46
>>68
マクロは竹内先生の本で覚えたのでlegacy macroの方が
自分にとってはわかりやすい。

Arcの方がなんとなくLispっぽいし気楽な感じでいいかも。
2008/02/07(木) 00:38:36
>>68
「- パッケージシステム」は必要ない希ガス
2008/02/07(木) 00:43:16
つまり Arc + パッケージシステム を作れば無敵w
2008/02/07(木) 00:54:04
>>72
あーそうだね、そのまま引用しちゃったから気がつかなかった。

ちょっと補足。
関数と変数の名前空間に区別がないのがLisp-1で、区別があるのがLisp-2。
2008/02/07(木) 01:18:07
黒田涙目w
2008/02/07(木) 01:46:35
arc> (頭良くなれー頭良くなれー 俺)
2008/02/07(木) 11:22:18
>>75
いやー、あの人は現状のArcの出来だったらボロクソに言うと思うけどww

今後Arcは開発コミュニティによってどう育って行くのか楽しみだね。
2008/02/07(木) 13:46:02
黒田さんじゃなくても現状のArcは出来はアレだと思うだろ
バージョン0のものを叩くってのは空気の読めないアホだけだよ
2008/02/07(木) 21:39:43
trace untrace って無いみたいなのでしょうがなく
こんなことをやってみた。
arc> :a
done
> (require (lib "trace.ss"))
> (trace _fact)
(_fact)
> (tl)
Use (quit) to quit, (tl) to return here after an interrupt.
arc> (fact 10)
|(_fact 10)
| (_fact 9)
| |(_fact 8)
| | (_fact 7)
| | |(_fact 6)
| | | (_fact 5)
| | | |(_fact 4)
| | | | (_fact 3)
| | | | |(_fact 2)
| | | | | (_fact 1)
| | | |[10](_fact 0)
| | | |[10]1
省略
|3628800
3628800
arc>
もっとスマートは方法はないかな? (ar-funcall(n) ... )をいじればいいのかな。
2008/02/08(金) 06:42:25
Arc Forumでジョークなのか$かsevalでScheme関数を呼び出すってのがあるなんてやってた。
そんなの無かったので追加してみた。
(ac s env)に加える。
((eq? (xcar s) '$) (ac-seval (cadr s)))
そして
(define (ac-seval x)
`(eval ,x))

arc> (= x "hello")
"hello"
arc> (($ string-fill!) x #\a)
#<void>
arc> x
"aaaaa"
2008/02/09(土) 03:43:45
[ ... ]っていいね。かなり記述量減らせる。
明示的に変数名も入れられるとベターなんだけど。
[< a b c > ...]みたいな
2008/02/09(土) 08:05:39
記述量減らせるけど、カッコ以外の記号覚えるの嫌だ>[]
2008/02/09(土) 08:21:22
あれあれ、'とか.とか:とか#とか`とか,とか,@とか&とかいっぱいありますよ?
[]は元々違う意味ですよ?(superbrace)
2008/02/09(土) 08:50:36
おれは#L()の方がいいよ
2008/02/09(土) 09:55:53
覚えるのが嫌だとは思わないが、カスタマイズできない構文が増えると嫌だな
しかし fn や if の定義は変更できないほうがいい
2008/02/09(土) 10:07:42
shiro氏公開のポールエッセイに数学的だから長生きだ、
みたいな事書いてたけど、[]は数学的根拠はないよね。
if辺りの拡張も俺言語オナニーと発想レベルは同じ。
長生きしないでしょう。
2008/02/09(土) 11:58:02
根拠がないなら作ればいい
たとえば、関数適用とラムダ抽象は全然違うんだから全然違うカッコを使うべきだとか
2008/02/09(土) 15:15:45
昔は ' も無かったんだし、単なるsyntax sugarでしょ。目くじら立てるようなもんじゃない。
まあ定着するかどうかは微妙だと思うけど。
2008/02/09(土) 22:04:44
>>86
長生きさせる気無いんじゃない?
というか最近、彼の一流の技術者的なジョークなんじゃないかという疑いを持つようになった。
あーだこーだ言ってる俺を見てほくそ笑んでるんでは無いかと。
Ctrl-Cの人はそれに気付いてジョークで返したんでは無いかと。
そうやっていつもアイツらは俺を笑ってるんだ。クソ!
2008/02/09(土) 22:24:53
>>89
Paranoid schizophreniaの可能性がありますので医師に御相談ください
2008/02/09(土) 22:29:35
100%ジョークってことはないが
Arcのソースにdefine-syntaxが一度たりとも出てこないのはわざとだろうなぁ
2008/02/10(日) 10:16:44
>>83
>[]は元々違う意味ですよ?(superbrace)
いつの時代の話してんの?w
その処理系つかったことあるの?w
2008/02/10(日) 11:12:31
>>92
なめんな。お前みたいな俄かLisperとは違うわ。
大した手間でもないから、わざわざ自分の
処理系には必ず入れていたぐらい精通してるよ。
後でマイナーな存在だと知ったけどな。
結局、閉じ括弧が減った程度じゃ、
一般人にLispは受け入れられないと悟った。
俺も色々変態構文は作ってきた方だが、
arcの[]みたいな使い方は思いつかなかった。
#fn <args> <expr> => (lambda <args> <expr>)
みたいな物ならいくつもあるが。
2008/02/10(日) 11:22:21
ニヤニヤ
2008/02/10(日) 12:31:02
>> 93
わりと論旨がとっちらかってて、なにが言いたいのか分からないんだけど、
でも、なんだか凄い人なのは理解できたかも!!!!!
Arcに超カッコが取り入れられる日も近い!
一般人への啓蒙のためにも[]は超カッコで、#L()を採用するべきだわ。
それか、gooみたいに(op _)とかね!まあ、cutでも良いか!

ちなみに#fn <args> <expr>って俄Lisperの漏れには
一見全然便利そうに見えないんですけど、どういうところで、
便利なんですか?!!! 
どこまでが後悔関数の引数なのか分かんなくなって混乱しちゃいそうです!!
2008/02/10(日) 13:46:05
ニヤニヤ
2008/02/10(日) 14:07:14
パンチカードを使ってた頃は便利だったなあ>超カッコ
まともなエディタがあれば要らないね。w
あと [ ] を vector と解釈する処理系も無かったっけ。Interlispだっけか。
2008/02/10(日) 14:22:41
Emacs Lisp も (vector 'a 'b 'c) => [a b c]
2008/02/10(日) 15:35:48
Taoではprintで[]を再現出来るんじゃなかったっけ?
2008/02/10(日) 16:01:42
>>95
「わりとなんだか凄い人」なのは判ってくれたようだが、
分からないのは理解しようと努力してないからだ。
>ちなみに#fn <args> <expr>って俄Lisperの漏れには
さて、この変態構文の例を>>7のコードで示せばこうなる。
(trues #fn (_) (if (odd _) (+ _ 10)) '(1 2 3 4 5))
何が便利かはこれで判るだろ。
少なくともarcの[]の様なナンセンスな仕組みよりも、
何を意図するものか判り易い。
付け足すなら、短く書きたいという願望は判るが、
arcの[]は引数が'_'限定では述語ぐらいにしか使えないし、
'_'という名前が名前だけに、読み手に意図も伝えられない。
実際に[]が入っているコードを見たら、頭を1回転させないと
判らない難解さを感じた。
いくら短く書けてもぱっと見で意味不明なのは問題だろうよ。
lambdaをfnに変えたぐらいのセンスで、もうひと捻り欲しい。
2008/02/10(日) 16:20:44
かえって分かりづらいね。
センスが悪いと生きるのも大変だろうね。
2008/02/10(日) 16:28:41
_決め打ちだとネストできないのは困るな
2008/02/10(日) 16:30:22
こういう目新しい構文って、それなりに使ってみないとまともに評価できないよな
単に慣れないから不自然に見えるだけなのか、根本的に使いにくい構文なのかが一見では区別できない
2008/02/10(日) 16:36:49
>>100
自分の中に入りすぎていて論旨がわかりにくい。
もうちょっと行数を減らしてくれないと読むのが苦痛だ。
2008/02/10(日) 16:42:35
>>104
日記です。
2008/02/10(日) 17:59:59
面倒だから全レスしてやるよ。
>>101 このレベルじゃ常人に理解されなくても困らないんだぜ。
>>102 ネストなんて意図を汲み取れば考慮の外だろ。
>>103 俺なら経験とカンである程度判断できる。
>>104 苦痛でも無理して読むといいよ。
>>105 いい目をしているな、それに度胸もいい。
あえて言うなら[]があればその中で'_'が使われている可能性アリ、
という対の関係を脊髄反射的に印象付けられる、変数ではなく
記号的な識別を行えるという目論見はあるだろうな。
2008/02/10(日) 18:04:51
可哀想
2008/02/10(日) 18:09:19
さすが、普通のやつらの上を行ってるやつらの言う事は違うな
2008/02/10(日) 18:52:51
上様御乱心
2008/02/10(日) 19:07:53
>>106
日本だと成功しないよあんた
2008/02/10(日) 22:38:58
まるで外国なら成功するみた(ry
2008/02/10(日) 23:05:25
そりゃ成功するでしょ
2008/02/10(日) 23:16:16
じゃあ、さっさと(ry
2008/02/10(日) 23:56:32
>>112
アフガニスタンとかか?
2008/02/11(月) 07:12:51
Arc の [] は、極端に単純な関数を極端に簡単に書くためだけの仕組みでしょ。
ちょっとでも複雑なコードが書きたいなら、普通に fn で書けばいいんだよ。
変数名とかがなくても一目でわかるくらいのコードに限定して、便利に使えればそれでいい。
別に fn を置き換えるようなものじゃないんだから。
2008/02/11(月) 09:08:01
C++の_1とか好きだけどな。
2008/02/11(月) 09:28:42
de Bruijn indexというのがあってだな
現在のスコープで最も内側で束縛された変数を 1 とする
2008/02/11(月) 09:43:22
de Buijn indexはlambda抽象を明示しないと成り立たないし、Boostの_1とは別物だろ
2008/02/11(月) 09:51:32
>> 115
そうだよね、letとwithの関係みたいなね。
引数が一つだけのlambdaが多用されるから便利に、ってことなんじゃないのかしら。
2008/02/11(月) 09:57:17
>>118
BoostはおいといてArcの[]を一般化しようという妄想だから

>>115
その「限定された範囲で便利に使える」機能は
普遍的な機能 (マクロなど) から導き出せるはずだっていう思想があるから
fnを置き換えるほど普遍的な機能だ
ということにすれば受け入れられやすいのではないか
2008/02/11(月) 18:42:15
>>117
0じゃね? まどっちでもいいんだが
2008/02/13(水) 20:10:50
あら、もう新しいarc1.tarが出たみたい。
x.yとか、x!yとか新しい構文が…。
2008/02/13(水) 22:56:21
arc> :a
> (expand-ssyntax 'x.y)
(x y)
> (expand-ssyntax 'x!y)
(x (quote y))
2008/02/13(水) 23:36:09
下らない小手先の構文糖衣ばっかりだなあ
2008/02/13(水) 23:59:48
くだらなくない糖衣構文キボンヌ
2008/02/14(木) 00:03:53
type genericとか
ここらで一気に強い型な言語になろうぜ
2008/02/14(木) 00:25:28
(= x (table))
(= x!key 'val)

将来的には「applyメソッドをoverride」したり中置記法のマクロを書けるようになるのか?
2008/02/14(木) 00:27:17
うーむ。意外な方向に発展する言語だなあ。
2008/02/14(木) 07:30:08
なんか予想外だよね。こまいところだけ手が入ってる感じ。
2008/02/14(木) 14:31:03
なんかarc1の説明にcutが沢山でてくると思ったらsubseqから名前変わったのね。
他にも変更になったのあるのかしらん。
2008/02/21(木) 01:23:29
保守
2008/02/25(月) 17:37:51
・ポール・グレアム「新しいものを作る6つの原則」 - らいおんの隠れ家
http://d.hatena.ne.jp/lionfan/20080224

・Arcをリリースした - 武蔵の日記
http://d.hatena.ne.jp/sirocco634/20080130/

・ポール・グレアム「Arc公開」を翻訳しかけたのですが - らいおんの隠れ家
http://d.hatena.ne.jp/lionfan/20080225
2008/03/01(土) 00:38:24
てめぇらの意見が聞きたい

型やマクロに制約のある言語を使ってると
その制約と相性の悪い新機能を使うために新しい言語に移行するパターンが多くないか?

制約のある言語はいつか破綻するものと割り切って使うしかないのか?
2008/03/01(土) 02:02:36
なんか抽象的な質問だなあ
2008/03/01(土) 03:54:09
そうかもしれん

ポールグレアムは「高級言語はプログラムを短くするためにある」と言った
でも普通のやつらは新しい機能を使うために新しい言語を使うんじゃないか
そこには、新しい機能を古い言語で実現できないという前提がある

Arcが期待はずれだった人も、
プログラムを短くすることではなく、新しい機能を期待していたのだと思う

だがポールグレアム的には、古い言語で実現できない新しい機能など存在しない
できないのは言語に色んな制約をつけた奴が悪い

で、静的型やhygienic macroのある言語って何なの?って話
2008/03/01(土) 04:00:17
Cを始めてみた時、ここまで記号羅列で表記する意味はあるのか、
いやないんじゃないかと思った。今では慣れた。endすらうざい。
2008/03/01(土) 04:02:05
Cにendなんてないわけだけど。
Rubyのことを言ってるならあれはEmacsから一発でインデントと共に
入れるもの。
2008/03/01(土) 08:04:09
括弧が記号じゃないとエディタで対応とらせるのに不便よね。
インデントだけじゃなくて移動とか。
PostScriptみたいに[,]が実はオペレータってのも勘弁だが。
2008/03/01(土) 08:21:11
,はunquoteじゃないの?
2008/03/01(土) 10:20:11
>>137
inputが面倒という以外に、視覚的に鬱陶しいというのもあるのでは?
2008/03/01(土) 23:27:59
>>140
Lispの括弧と同じで慣れれば見えなくなるけどね
142デフォルトの名無しさん
垢版 |
2008/03/02(日) 14:13:23
レンタルサーバ上で Arc によってウェブアプリを書いている人いますか?


Arcで書かれたポールグレアムの News.YC がオープンソース化
http://d.hatena.ne.jp/higepon/20080225/1203913944
143デフォルトの名無しさん
垢版 |
2008/03/02(日) 14:15:13
Arcからの挑戦
http://practical-scheme.net/wiliki/wiliki.cgi?Arc%E3%81%8B%E3%82%89%E3%81%AE%E6%8C%91%E6%88%A6
144デフォルトの名無しさん
垢版 |
2008/03/02(日) 14:17:36
Arcからの挑戦
http://practical-scheme.net/wiliki/wiliki.cgi?Arc%E3%81%8B%E3%82%89%E3%81%AE%E6%8C%91%E6%88%A6

単純な問題を、挑戦として示すことにしよう。
そして、ポピュラーな言語での解答を集めて、その長さを比べてみるつもりだ。

次のようなプログラムを書け。
URL said (例えば http://localhost:port/said )は、入力フィールドひとつと、送信ボタンひとつのページを生成する。
送信ボタンが押されたら、2番めのページとして、"click here." と書かれたリンクひとつのページを生成する。
それがクリックされたら、3番めのページとして、"you said: ..." と書かれたページにいく。
ここで ... は、さっきの入力フィールドにユーザがタイプしたものだ。
ただし、3番めのページは、ユーザが実際にタイプしたものだけを表示すること。
つまり、入力フィールドの値を URL で渡してはいけない。そうしないと、最後のページの動作をURLで変えるようなことができてしまう。

単純だし、このようなテストに求められるように、これは例として不自然ではない。
Webアプリは、このようなことをいつもやっているのだ。あるいは、何か難解なライブラリ(Arcにあって他の言語にはないような)に頼るわけでもない。Webアプリを書くのに使われる言語なら当然もっているものだけでいい。

これが Arc の答えだ:

(defop said req
 (aform [w/link (pr "you said: " (arg _ "foo"))
      (pr "click here")]
 (input "foo")
 (submit)))

もし Arc になじみがなければ、私のいうことを信じてもらうほかないが、これはコード上のトリックで圧縮したわけではない。
これが Arc で書くには標準的な書きかたなのだ。
2008/03/02(日) 15:51:22
Arcで書かれたポールグレアムとlispで書かれたポールグレアムはどっちが強いんだろう
2008/03/02(日) 16:20:28
詠唱速度というのがあってだな
2008/03/02(日) 19:14:13
>>144
http://practical-scheme.net/wiliki/wiliki.cgi?cut-sea#H-1119bvv

>(define-page (said)
> (self-chain "self"
>  (form/cont/ (entry-lambda (:keyword say)
>      (a/cont/ (cut p/ "You say:" say) "click here"))
>   (readln/ say)
>   (submit/))))

>Arc: 23ノード:15の葉/字句 + 8内部ノード
>Kahua: 27ノード:17の葉/字句 + 10内部ノード
2008/03/06(木) 17:09:30
野良犬日記 2.1 ? Going to the Mutts
- Paul Graham のエッセイは翻訳が許可されている
http://tamo.tdiary.net/20080304.html#p01

> たとえば cond マクロ。こいつには Lisp 1 からこのかた余計な括弧がびっ
> しり付いてきて、それを誰も何ともしてこなかった。 if と cond を押しつ
> ぶしてひとつのオペレータにする Arc の技も、誰かがとっくに見つけてい
> たっておかしくなかったのだが、 間違いなくそんな周知の事実はない。こ
> んなことができると気づいたときは嬉しかったなあ。

これって何の話?誰か教えてプリーズ。
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況