Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
PHP 8.5の裏話
Search
てきめん tekimen
PRO
November 26, 2025
Programming
150
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
PHP 8.5の裏話
てきめん tekimen
PRO
November 26, 2025
More Decks by てきめん tekimen
See All by てきめん tekimen
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
260
ChatGPTを使ってRaspberry Pi Picoの処理系を書いた
youkidearitai
PRO
0
81
PHP Internals わいわい #3 PIEを使ってみよう
youkidearitai
PRO
0
57
grapheme_strrev関数が採択されました(あと雑感)
youkidearitai
PRO
1
320
Limit of code point for grapheme cluster in programming language side.
youkidearitai
PRO
0
82
Unicodeどうしてる? PHPから見たUnicode対応と他言語での対応についてのお伺い
youkidearitai
PRO
2
3.5k
CJK and Unicode From a PHP Committer
youkidearitai
PRO
0
330
PHP Internals わいわい #3 mb_*関数を作ってみよう
youkidearitai
PRO
0
160
Windows版php-srcデバッグ方法
youkidearitai
PRO
1
120
Other Decks in Programming
See All in Programming
生成AI時代にこそ効くGo | Why Go Works in the Age of Generative AI
mom0tomo
8
3.2k
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
20
6.5k
並列実装の現場、2ヶ月間実務でAIを使い倒したAIもPCも私も限界が近い
ming_ayami
0
120
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
530
Observability in Practice:Grafana 與 Edge Device SRE 的那些事
blueswen
0
160
AIとASP.NET Coreで雑Webアプリを作った話
mayuki
0
500
Vite+ Unified Toolchain for the Web
naokihaba
0
270
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
5.3k
ECSアプリログをFireLensでコスト削減しようとしたけど諦めた話 in Fargate×Node.js
akihisaikeda
2
4k
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
560
LLM Plugin for Node-REDの利用方法と開発について
404background
0
170
3Dシーンの圧縮
fadis
1
730
Featured
See All Featured
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
28
3.5k
Evolving SEO for Evolving Search Engines
ryanjones
0
210
The Invisible Side of Design
smashingmag
302
52k
How GitHub (no longer) Works
holman
316
150k
AI: The stuff that nobody shows you
jnunemaker
PRO
8
710
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
330
Winning Ecommerce Organic Search in an AI Era - #searchnstuff2025
aleyda
1
2k
Un-Boring Meetings
codingconduct
0
310
Scaling GitHub
holman
464
140k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.3k
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
1
3.6k
Testing 201, or: Great Expectations
jmmastey
46
8.2k
Transcript
PHP 8.5の裏話
自己紹介 てきめん • https://tekitoh-memdhoi.info • @youkidearitai • https://www.youtube.com/use r/tekitohmrp •
https://www.nicovideo.jp/user /2957748 オレ
アジェンダ • ぶっちゃけネガティブめなPHP Internalsの話題 – DmitryさんZend退職だったり • PHP 8.5の開発で感じたこと –
てきめん視点での報告 スライドは急造みがあるのでゆっくり喋ります
PHP 8.5リリース 🎉 • 1年待ったうれしい • 大変だったなあと思いました
Dmitryさん、Zendやめる • https://externals.io/message/126804#126804 • PHPのJITを開発してたDmitryさん、Zendを退職 – 2025-03-17での発表 – これ以降、Zend Engineのレビュー中心になってる印象
Onigurumaの開発終了 • Onigurumaが開発終了 – https://github.com/kkos/oniguruma/ • This project ended on
April 24, 2025. • PHPではmbregex(mb_eregなど)で使っている – OnigurumaはVSCodeなどでユースケースがありなかなか止められない – 膠着状態で板挟み状態 • mbstringのAlexさんはOnigurumaをメンテしてでも維持したい、PHP Internalsは PCREでいいのではないかという意見 • 解決策が見当たらない
mb_levenshtein関数の否決 • mbstringでのレーベンシュタイン距離を求める関数のRFC が全会一致で否決 – https://wiki.php.net/rfc/mb_levenshtein • mbstringではUnicodeコードポイント単位でわかるので、プ ログラマーが欲しい時があると主張したのだけど、 grapheme関数のほうがほしいとのこと
• mbstring関数は時代遅れなのかというとそうでもないのだ けど…なかなか伝わらない
grapheme_levenshtein関数の実装 • 書記素クラスター単位というか、絵文字とかでレー ベンシュタイン距離を測ることができます – 何文字違うのかがわかりますね
grapheme関数にロケールを追加 • grapheme_strpos、grapheme_stripos、grapheme_strrpos、 grapheme_strripos、grapheme_strstr、grapheme_stristr、 grapheme_levenshtein関数にロケールを追加 – grapheme_levenshtein関数の修正RFCでもある • トルコ語のİとiとをマッチさせたり(tr_TR)できます •
ロケールというか、LDMLベースで決められます – ちょっと複雑 https://www.unicode.org/reports/tr35/ – 日本語の異体字でも使えます 邊とか – 複雑にしてすいません感がある
grapheme関数にロケールを追加 • 議論して2週間経って特に誰も何も言わなかったので 投票したらNOを突きつけられる – 加えてなんか色々言ってきた – えーそれは議論のときに言ってよと抗議した – ちょっとなーと思った部分だったかな
– 再投票して可決 • なんだかなあ…
LDMLのサンプル • 邊の異体字を判定するのにLDMLの ‘u-ks-identic’ を使います • ドイツ語のßとssとをマッチさせるのに’u-ks-level1’が使えます • https://www.unicode.org/reports/tr35/tr35-collation.html# Combining_Rules
PHP 8.5の開発で感じたこと • もうmbstring関数は増えないかもしれない – ただ、コードポイント単位のプログラミングをしたいというニーズはまだあるはずなので主張はしていきたいが – Unicodeのネイティブ世代として要求される知識量は増えたと感じている • CJKの事情を伝えるのに遠く感じる
– Onigurumaでも感じたけど簡素化したい感は感じる – Unicodeでいいと思っていそうな割にCJKの事情はわかってなさそうなのでちゃんと伝えないといけないと感じる • CJKだけじゃなくアラビア語などRtoLの言語でもどういう事情なのかとかは知りたいし • Unicodeのプログラミングは複雑である – LDMLをはじめ、ちゃんと勉強しないと文字の処理がうまくいかないことがある – 特に異体字はちゃんとしないと、自分の名前が表示されないというユーザーからの要請に答えられない • これは名前というアイデンティティの問題なので、ちゃんとしてほしい。する土壌は整えている • もっとアジア圏からPHPへの意見を出してほしい感はある
PHP Internalsで思うこと • JITは一段落した感じがします – 特に開発者のDmitryさんがZendを抜けたのは大きい • 色々あったのでしょう • 今は非同期処理がアツい気がします
– ここらへんはノータッチですが
2026年の抱負 • これから、PHPのUnicode実装はどうするべきか、他プ ログラミング言語の参考を勉強したいです • CJKの立場を伝えるために、海外のユーザーのコミュ ニケーションを増やしたいです • PHPのユースケースをGitHubなどで探していき、見つ かったアイデアを公式にいれるべきかを探求したいで
す
おわり