polarphp是一个全新的PHP语言的运行时环境,基于目前最新的zend virtual machine进行打造,支持最新的语言规范,同时提供了自己的运行时标准库 (libpdk)。简单来说polarphp之于PHP语言的关系跟NodeJS之于JavaScript语言一样,NodeJS在v8引擎基础之上进行打造,为Javascript提供了一个在服务端运行的环境。
同样polarphp也在zend engine的基础上进行打造,实现了一个除Web开发之外的一个全新的运行环境。
项目官网库:
https://gitee.com/polarphp/polarphp
https://github.com/polarphp/polarphp
欢迎小伙伴们多多star ^ _ ^
为什么发起 polarphp 项目
随着Go和NodeJS的强势崛起,PHP的市场份额逐渐被蚕食,而PHP官方仍然坚守在Web编程领域,有些东西越是想守住就越守不住。polarphp借鉴NodeJS和Go的相关特性对zendVM重新封装,去掉PHP一些古老弃用的特性和强Web属性,通过实现一套新的运行时框架libpdk,将PHP语言打造成为一门真正的通用性脚本语言,赋能PHP,让其拥有异步编程,协程,线程,内置的unicode支持,标准的文件IO等等特性,让PHP程序员不仅仅能做web应用,也能从容面对真正的服务端应用。
polarphp 提供的基础设施
直接面向终端,去掉SAPI从而更好的实现服务端环境。
规范化OPCODE形成规范,从而提供一种类似pyc文件的预编译机制。
提供原生多线程支持,借鉴Java在多线程方面的编程范式。
提供原生异步IO支持。
提供针对字符串的unicode支持。
提供一种全新的包组织方式,内置包依赖管理工具,类似Cargo和npm。
提供内置的API文档生成工具。
polarphp 大致架构
项目主要由三部分构成,主要有如下三个子模块
polarvm
zendAPI
libpdk
这个模块大致的关系如下:
polarvm <=> zendAPI <=> libpdk
polarvm 介绍
现阶段实现对zend engine的封装,实现最基本的PHP执行环境,比如实现:
语言解析,OPCODE的执行。
实现基础运行环境,实现变量操作,数组操作,类加载机制,语言反射等等。
zend engine的初始化,实现语言引擎与终端的链接,实现语言引擎对标准输入输出的直接控制。
实现语言引擎与标准库之间的回调机制。
zendAPI 介绍
做过PHP扩展的朋友应该知道,在我们开发扩展的时候,zend engine的很多接口都是通过宏调用的方式提供的,类型不安全,出错了不好调试,而且有些宏还长的特别像,同时操作数组的时候特别繁琐。zend engine的gc是通过引用计数实现的,同时C语言又没有什么从语言层面帮我们管理计数的机制,从而我们在写扩展的时候管理内存不仅很繁琐而且一不小心就会造成内存泄露。特别是将写时复制和PHP变量之间的引用一起使用的时候,非常让能头痛。
如果我们的标准库如果直接基于原生的zend engine的接口,势必扩展性,可维护性会受到严重影响,特别是目前polarvm是基于zend engine二次开发的可观情况下。所以在语言引擎和标准库之间实现一个屏蔽层,对下实现对zend engine原生接口的封装,对上提供一套相对稳定且简单的面向对象的CPP编程接口。
zendAPI 提供如下的特性:
完全面向对象,对Zend Engine API进行二次定义
使用现代的C++11语法进行开发,便于维护
最大化屏蔽PHP版本对扩展开发的影响,zendAPI将对Zend Engine API不同版本带来的差异屏蔽掉
高覆盖的单元测试,保证代码质量
在封装的时候,尽最大能力保证性能
致力于项目库的二进制兼容
libpdk 介绍polarphp 的开发计划
因为开发资源有限,开发计划暂定如下:
使用cmake对zend VM进行编译,生成polarphp定制版的PHP语言虚拟机。
语言支持项目,语言测试框架,移植LLVM项目的lit测试框架。
实现polarphp驱动程序,实现从命令行执行PHP代码。
对polarphp虚拟机进行回归测试,暂定跑通PHP的语言虚拟机相关回归测试。
实现polarphp的内置函数。
发布核心虚拟机的docker镜像。
整合libpdk运行时框架。
实现人性化安装,尽量以最少的步骤进行polarphp的安装。
实现包管理器。
实现语言配套小工具,比如文档生成工具等等。
polarphp 目前的现状
目前项目处于一个非常前期的阶段,通过docker镜像来实现项目的迭代发布,目前主要是我一个人在业余时间进行开发,欢迎大家一起玩。2019年一个重要的任务就是完善polarphp标准库libpdk,以及实现在主流的Linux操作系统上稳定的运行。
如何参与
目前我们暂时只针对中国的用户,所以采用了微信和QQ群的交流方式,下面是二维码,有兴趣的同学可以扫码加入:
目前有以下工作组
语言核心团队
标准库团队
生态链项目团队
文档团队
官方网站维护团队