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
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
てきめん 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
220
ChatGPTを使ってRaspberry Pi Picoの処理系を書いた
youkidearitai
PRO
0
77
PHP Internals わいわい #3 PIEを使ってみよう
youkidearitai
PRO
0
55
grapheme_strrev関数が採択されました(あと雑感)
youkidearitai
PRO
1
310
Limit of code point for grapheme cluster in programming language side.
youkidearitai
PRO
0
81
Unicodeどうしてる? PHPから見たUnicode対応と他言語での対応についてのお伺い
youkidearitai
PRO
2
3.5k
CJK and Unicode From a PHP Committer
youkidearitai
PRO
0
320
PHP Internals わいわい #3 mb_*関数を作ってみよう
youkidearitai
PRO
0
160
Windows版php-srcデバッグ方法
youkidearitai
PRO
1
120
Other Decks in Programming
See All in Programming
TypeSpec で繋ぐ複数プロダクトの型安全
maroon8021
1
420
Why Laravel apps break—Mastering the fundamentals to keep them maintainable
kentaroutakeda
1
340
柔軟なPDFレイアウトエディタを支える型システム設計 — Discriminated UnionとConditional Typeの実践
minako__ph
4
1.4k
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
190
Lessons from Spec-Driven Development
simas
PRO
0
140
セキュリティの専門家じゃなくてもできる。「セキュリティ意識」をアップデートして サプライチェーン攻撃への耐性を高めよう。
tk3fftk
5
650
The Arts and Crafts of Work in the AI Era — Toward Mastery in Software Development
kuranuki
1
730
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
500
コンテキストの使い捨てをやめる — ビジネスルール駆動開発と miko —
ioki
0
140
決定論的オーケストレーションの設計と実装 / Design and Implementation of Deterministic Orchestration
nrslib
3
1.1k
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
17
6.1k
These Five Tricks Can Make Your Apps Greener, Cheaper, & Nicer
hollycummins
0
280
Featured
See All Featured
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
We Have a Design System, Now What?
morganepeng
55
8.2k
Reflections from 52 weeks, 52 projects
jeffersonlam
356
21k
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
230
From π to Pie charts
rasagy
0
200
Are puppies a ranking factor?
jonoalderson
1
3.5k
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
200
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
320
Tell your own story through comics
letsgokoyo
1
950
Visual Storytelling: How to be a Superhuman Communicator
reverentgeek
2
550
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
600
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などで探していき、見つ かったアイデアを公式にいれるべきかを探求したいで
す
おわり