Emacs Part 54at UNIX
Emacs Part 54 - 暇つぶし2ch827:名無しさん@お腹いっぱい。
25/10/04 09:17:59.44 .net
それから、この辺も

TreesitterとEglotを使ってPython用Emacsを設定する
gist.github.com/habamax/290cda0e0cdc6118eb9a06121b9bc0d7

GNU Emacs で VS Code 相当のコード・デバッグ支援機能を設定する
a-perpetual-novice.HATENABLOG.com/entry/2024/10/30/005400
a-perpetual-novice.HATENABLOG.com/entry/2024/11/01/013058

828:名無しさん@お腹いっぱい。
25/10/04 14:30:22.02 .net
まあ5年遅いな

829:名無しさん@お腹いっぱい。
25/10/04 15:27:40.44 .net
>>828
進化しろよ

830:名無しさん@お腹いっぱい。
25/10/04 15:58:24.20 .net
treesitterもLSPもEmacsとは関係がない
もはやテキストエディターはモジュールを組み合わせる為の土台でしかなくなった
これからは本体をシンプルにしてモジュールを組み合わせる柔軟性が求められる
kitchen-sinkの時代は終わった

831:名無しさん@お腹いっぱい。
25/10/04 17:05:07.59 .net
>>830
じゃあVImが良いってなるやん
emacsならlispで、vscodeならnodejsで拡張できるっていう良さがあるからエディタ選んで楽しむ余地はまだまだあるっしょ

832:名無しさん@お腹いっぱい。
25/10/04 23:41:11.40 .net
>>831
Vimは大量の酷いCコードを整理する必要があるけど、もはや限界がある
VimScriptもお世辞にも使いやすいとは言えない
なのでEmacsの方がマシなのは間違いないけど、Emacsである必要性も薄らいで来てるのもまた事実w
でもorg-modeみたいなキラーモジュールがあるからEmacsを離れられない人がほとんどなのも現実だろう

833:名無しさん@お腹いっぱい。
25/10/05 00:43:52.21 .net
lsp作ったのもmsだしpythonで一番人気のls作ってるのもmsとゆう事実
ゴミみたいなソフトばっか作ってる印象だけど地味にossに貢献しとる
vimはneovimでvimscriptの1000倍速いluaで設定書けるからそれでええやん

834:名無しさん@お腹いっぱい。
25/10/05 00:46:29.22 .net
emacsはなぜか若いナオンに人気
URLリンク(m.youtube.com)

835:名無しさん@お腹いっぱい。
25/10/05 01:00:03.42 .net
てか最近emacs触り始めたけどなんでも()つけないといけないlispてキチゲエみたいな言語やな
プログラム向けとか神の言語とかゆわれてるけどそれならrubyとかputhonのほうが近いやんておもた

836:名無しさん@お腹いっぱい。
25/10/05 05:26:54.44 .net
emacs 30 シリーズも30.2 が出たので、29.x からそれにしたらいきなり egg 関連のパッケージがエラーおこしたが、それは割とすぐに対処できた。
obarray を作るには make-vector の最後の値を nil から0にせよということだ。あるいは obarray-make を使えと。
たとえば:
URLリンク(www.agt.ne.jp)

で、実は手元でローカルにいろいろパッチを当てていた egg 関連の emacs-lisp を emacs 30.2 で compile しようとしたらどうも macroexpand が うまくいかないようでエラーを起こす。
多分どこかでマクロの引数が足りないところなどがあるんだろうけど古いemacsのコンパイラではmacro の展開が緩かったりで発見されていなかった問題かも。

それはともかくその過程で次のパッケージとウェブサイトを知った。
egg-tart (tamago-tsunagi と 追加の説明など) URLリンク(github.com)
やっぱりWnnが好き! URLリンク(wnn.jp)
FreeBSD における Wnn8 URLリンク(maikaze.cafe.coocan.jp)

最後のは自分で .el 書き換えたりしてない人には詳しすぎるかも。
egg.el関連のソースはやはり漸次でもよいから直していかないと emacs 30.x (x > 2), 31.y で使えなくなりそうだけども、そういう観点から更新をしている人は世の中にいるのだろうか?
長く使っている入力方法は簡単に捨てられないので、そういうところがあれば情報を共有したいと思ってるのでした。

837:名無しさん@お腹いっぱい。
25/10/05 06:34:58.15 .net
>>835
いま手元に実物が無いからうろ覚えだけど
A君「LISPは機械を優先して、人にとっての使いやすさを無視した言語なんですか?」
K先生「それはある意味当たっておる。しかし機械が扱いやすいということは、回り回ってその機械を作ったり制御したりする人が楽をできるということでもある。まあ人と機械が歩み寄ったと思えば美談じゃ」
みたいな会話を読んで目から鱗が落ちたことがある
URLリンク(www.shoeisha.co.jp)

838:名無しさん@お腹いっぱい。
25/10/05 09:16:32.78 .net
28以降はクソ

839:名無しさん@お腹いっぱい。
25/10/05 09:26:00.51 .net
>>835
Emacsの歴史を知るとその疑問が解けるかもしれないよ
GNU EmacsがEmacs Lispを採用したのは2番目のリンクで、どちらも日本語だが英語版より古い

URLリンク(ja.wikipedia.org)
URLリンク(www.gnu.org)

840:名無しさん@お腹いっぱい。
25/10/05 10:14:50.33 .net
ややこしい歴史をたどんなくても
・lisp が完全な高級言語の中で最も小さなインタプリタで実装できたから(当時はメモリとか貴重だった
・rms は MIT の AI研にいて lisp まわりの仕事してて詳しかった
の2点で十分じゃよ

841:名無しさん@お腹いっぱい。
25/10/05 12:16:54.94 .net
>>835
Lispが神の言語なのにはちゃんと理由がある
要約すると、括弧とシンボルと幾つかのオペレーター(例えばcarやatomなど)があれば言語を構築出来ることを「発見」したから
あと、構造化編集で調べれば分かるけど、括弧があるお陰で編集がめちゃやり易くなる
括弧の対応は自動でされる
それとLisperは括弧じゃなくてインデントを見るので括弧が気にならなくなる
もはや欠点が無いw

842:名無しさん@お腹いっぱい。
25/10/05 13:27:59.02 .net
インデントを見るといえばpythonだけど、個人的にはpythonにカッコついてればいいのにと思う

843:名無しさん@お腹いっぱい。
25/10/05 15:09:45.47 .net
>>841
極論を言えばプリミティブは lambda と eval さえあれば後はそれを使って全部実装できるって話はあるからな
入出力とかは全部 eval が担当はインチキだけど

844:名無しさん@お腹いっぱい。
25/10/05 16:38:29.06 .net
doom emcas起動したらcpuが100張り付いたんだけどemacsてこんなに重いん?

845:名無しさん@お腹いっぱい。
25/10/05 16:51:29.98 .net
>>842
HyというLispがあるよ
使ったこと無いけど、Pythonとの親和性を求めるなら良いかもね

846:名無しさん@お腹いっぱい。
25/10/05 16:53:40.92 .net
>>844
裏でネイティブコードのコンパイルが行われてる
一度やれば次起動した時は負荷は上がらないけど、パッケージを更新するとまたコンパイルが走って一時的に負荷が上がる

847:832
25/10/06 02:43:16.18 .net
>> 152

> ChatGPT in Emacs
> URLリンク(youtu.be)

30.2 で tamago のバイトコンパイルどころかロードも失敗するのは、上の emacs に特化した? chatgpt の対話窓口で数時間かけてデバッグしたら解決した。

なかなか参考になる体験。最初の数時間はうまくいったんだけど、最後の1時間半くらい、chatgpt が自分で定義した関数の引数の数と、
テスト用に示してきた関数での利用例での引数の数がマッチしてなくて、それで大混乱して1時間半くらい無駄にした。
こちらの手元の関数定義と向こうが考えてる修正中の定義が微妙にずれていたりするのかもしれない。
あと、なぜか、lisp の対話システムとしては致命的だがときどきカッコのマッチがおかしいのを出力する。シンタックスエラーで分かるからいいんだけど。

そんなわけで、defmacro の問題点は全部解決した. hangul.el は defmacro を修正したら今度は最後関数ボディが巨大になりすぎてコンパイルできないので、
マクロ利用をやめたり。

とりあえず、手元の tamago の .el ファイルはエラーせずに全部コンパイルできるようになった。
それをバイトコンパイルしたもので 30.2 で日本語入力が手元の FreeWnn4 使ってるDebian/Linux でできてる。
第一歩すすんだ。

修正案:
1. 終了: ‘inhibit-point-motion-hooks’ is an obsolete variable (as of 25.1); use ‘cursor-intangible-mode’ or ‘cursor-sensor-mode’ instead
対応。
2.stirng-as-unibyte, string-as-multibyte の置き換え。
対応中。 ただし、これは日本語サーバー使ってる部分しかテストできない。
3. 上の 1 に関連して 'tangible text property の利用をやめる方向でそれを取り除くのも chatgpt と相談しながらできるかもしれないと思い始めたところ。

生成AI でのコーディングは実用になる。結果が正しいかどうかはコンパイラ、インタプリタ―でテストは知らせれば真偽がわかる。
レポートの調査は、「これこれはこのURLに書かれています。」と言われて、本当かと調べたらなかったことが考えられないほどの頻度であるので、そういう使い方には向いてないと思う。

Emacs に特化した窓口を教えてくれた152に感謝。


最新レス表示
レスジャンプ
類似スレ一覧
スレッドの検索
話題のニュース
おまかせリスト
オプション
しおりを挟む
スレッドに書込
スレッドの一覧
暇つぶし2ch