Zephyr OS 1.14(LTS)错误修复大赛

Zephyr项目社区正在准备发布Zephyr OS 1.14,这是迄今为止我们最大的合作项目!我们感谢成员和才华横溢的开发者的所有支持,帮助我们满足这么多技术里程碑。为了表达我们的赞赏,Zephyr项目将向Zephyr OS 1.14修复bug最多的5个贡献者,发送由我们的白金会员NXP提供的i.MX RT1050!该板将高性能与实时功能相结合。i.MX RT系列分频处理器旨在支持下一代物联网应用,具有高水平的集成度和安全性,并以实惠的价格实现MCU级别的可用性。使用i.MX RT1050 EVK,开发者可以通过类似MCU的可用性简化产品设计,并利用当前的工具链,包括MCUXpresso。i.MX RT1050 EVK是一款4层通孔USB供电PCB。i.MX RT1050交叉处理器的核心是NXP先进的Arm® Cortex®-M7内核,运行速度高达600MHz。要获得i.MX RT1050的参赛资格,请将所有已解决的错误和问题列表发送至info@zephyrproject.org。请确保在2019年10月到2019年4月中旬Zephyr OS 1.14版本之间包含你的名称和链接到你负责修复的错误。Zephyr Project TSC成员不符合参加本次竞赛的资格。欢迎并鼓励来自Zephyr项目成员公司的非TSC成员参与。还有时间参与其中!如果你是Zephyr项目的新贡献者,那么开始的好地方就是查看GitHub的“问题”部分。请遵循贡献者指南,确保你的贡献符合我们的编码标准。如有疑问,请联系Thea Aldrich,电子邮件:info@zephyrproject.org。请继续关注Zephyr项目博客,了解NXP和其他Zephyr项目成员赞助的更多竞赛和赠品。Zephyr OS 1.14(LTS)发布一周后,将通知本次比赛的获胜者。要了解更多信息或提出问题,请注册Zephyr Project Slack频道:https://zephyrproject.slack.com/。KubeCon + CloudNativeCon + Open Source Summit大会日期:会议日程通告日期:2019 年 4 月 10 日会议活动举办日期:2019 年 6 月 24 至 26 日KubeCon + CloudNativeCon + Open Source Summit赞助方案KubeCon + CloudNativeCon + Open Source Summit多元化奖学金现正接受申请KubeCon + CloudNativeCon和Open Source Summit即将首次合体落地中国KubeCon + CloudNativeCon + Open Source Summit购票窗口,立即购票!CNCF邀请你加入最终用户社区

March 28, 2019 · 1 min · jiezi

【PHP 扩展开发】Zephir 基础篇

上一篇 《Zephir 简介》 简单介绍了环境搭建,编写了一个的简单示例。这一篇继续介绍 Zephir 基础。基本语法Zephir 中,每个文件都必须有且只有一个类,每个类都必须有一个命名空间,目录结构必须与所使用的类和命名空间的名称相匹配,这一点和 PSR4 的约定一致,但是它是强制的。空间名和类名首字母大写,文件名全部小写。变量Zephir 支持动态类型和静态类型。变量作为函数返回值时,必须声明为动态类型。动态变量与 PHP 中的变量基本完全相同,支持在使用时改变类型。与 PHP 不一样,变量名不需要带$符号,所有变量在使用前都需要先定义,动态类型通过 var 关键字声明。var a = 10,b,c;let b = 20;let c = a + b;与 PHP 不一样,字符串文字只能使用双引号指定,不能用单引号,也不支持变量解析,比如这样是不支持的。var a = “变量解析{$test}“静态变量静态类型一旦被声明,就不能更改。支持如下类型给静态类型变量赋值,会先尝试自动转换,转换失败抛出异常boolean a;let a = 0; // a = falselet a = “string”; // 抛出异常运算符Zephir 的运算符与 PHP 基本一致。比较运算符在运算时考虑变量类型,如果是动态变量与 PHP 一致。不支持太空船操作符、空合并运算符。特殊运算符 - FetchPHPif (isset($myArray[$key])) { $value = $myArray[$key]; echo $value;}Zephirif fetch value, myArray[key] { echo value;}控制结构Zephir 提供了 if/switch/while/loop/for 几种语句,前三种与 PHP 基本一致。Zephir 控制语句中括号是非必选的。loop 可以用来创建无限循环,相当于 while truelet n = 40;loop { let n -= 2; if n % 5 == 0 { break; } echo x, “\n”;}for 和 PHP 一样支持索引 value 和 key => valuefor item in [“a”, “b”, “c”, “d”] { echo item, “\n”;}let items = [“a”: 1, “b”: 2, “c”: 3, “d”: 4];for key, value in items { echo key, " “, value, “\n”;}还非常友好的提供了反方向遍历let items = [1, 2, 3, 4, 5];for value in reverse items { echo value, “\n”;}与 python 等语言一样,遍历一系列整数值,可以这么写:for i in range(1, 10) { echo i, “\n”;}异常处理异常处理与 PHP 类似,在try 语句中抛出异常,在 catch 中捕获。var e;try { throw new \Exception(“This is an exception”);} catch \Exception, e { echo e->getMessage();}与 PHP 不一致,Zephir try 语句可以没有 catch,表示忽略所有异常。即,这是合法的try { throw new \Exception(“This is an exception”);}捕获多个异常也非常方便var e;try { throw new \Exception(“This is an exception”);} catch \RuntimeException|\Exception, e { echo e->getMessage();}附件1官方文档 ...

March 1, 2019 · 1 min · jiezi

Zephir 简介

什么是 ZephirZephir 是一种中间语言,以接近 PHP 的语法来编写代码,然后转换成 PHP 扩展。安装要构建PHP扩展并使用Zephir,您需要满足以下要求 (以centos7 + php7.2 为例)编译环境官方示例以ubuntu,需要安装如下扩展sudo apt-get install git gcc make re2c php php-json php-dev libpcre3-dev build-essentialcentos yum安装yum install -y git gcc make re2c autoconf automake libtool pcre pcre-develyum groupinstall -y “Development Tools"某些库可能某些源没有,可以更换源或者下载源码安装php 扩展Zephir parser >= 1.1.0wget https://github.com/phalcon/php-zephir-parser/archive/v1.2.0.tar.gzmv v1.2.0.tar.gz php-zephir-parser-v1.2.0.tar.gztar -xvzf php-zephir-parser-v1.2.0.tar.gzcd php-zephir-parser-1.2.0//usr/local/php7/bin/phpize./configure –with-php-config=/usr/local/php7/bin/php-configmake && make installgmp (php源码中包含该扩展,默认情况下不安装)扩展安装方法大同小异,不另说明以源码编译的方式追加安装这两扩展,并配置ini文件extension=gmp.soextension=zephir_parser.so安装 Zephir下载最新版本,我们使用phar包cd /usr/local/binwget https://github.com/phalcon/zephir/releases/download/0.11.10/zephir.pharchmod 777 zephir.pharln -s /usr/local/bin/zephir.phar zephir检查是否安装成功zephir help安装成装显示如下图创建扩展初始化一个应用zephir init first生成如下两个目录和一个文件编写代码注意:在 Zephir中, 每个文件都必须包含一个类 (并且只有一个类)。 每个类都必须有一个命名空间, 并且目录结构必须与所使用的类和命名空间的名称相匹配。使用 phpstorm 作为IDE,安装 Zephir 插件。firstfirsthello.zepnamespace First;class Hello{ public function world() { echo “Hello world!”; } public function zephir() { echo “Hello Zephir!”; }}编译zephir build第一次执行,运气不好的话会失败。详细日志见 compile-errors.log 文件的内容。如果build成功,会自动生成 first.so 文件到 extension 目录 ,你需要编辑 php.ini 填加扩展测试一下<?phpecho First\Hello::world(), “\n”;就这样,你也会 PHP 扩展开发了附1:Available commands: init Initializes a Zephir extension builddev Generates/Builds/Installs a Zephir extension in development mode api Generates a HTML API based on the classes exposed in the extension clean Cleans any object files created by the extension generate Generates C code from the Zephir code without compiling it build Generates/Builds/Installs a Zephir extension stubs Generates stubs that can be used in a PHP IDE help Displays this help and exit fullclean Cleans any object files created by the extension (including files generated by phpize) compile Compile a Zephir extension install Installs the extension in the extension directory (may require root password) version Shows the Zephir version ...

February 25, 2019 · 1 min · jiezi