我持续推动Rust语言支持Windows XP系统

   2023-02-09 学习力0
核心提示:前言Rust好像长期以来不支持Windows XP系统。有不少用户发帖提议官方支持XP,基本上都被Rust官方开发人员明白的拒绝了。他们的对话大致上是以这种形式開始和结束的(当中乙方代表官方及其拥趸):甲方:Rust应该支持XP呀乙方:微软官方已经放弃维护XP。我们为

前言

Rust好像长期以来不支持Windows XP系统。有不少用户发帖提议官方支持XP,基本上都被Rust官方开发人员明白的拒绝了。他们的对话大致上是以这种形式開始和结束的(当中乙方代表官方及其拥趸):

甲方:Rust应该支持XP呀
乙方:微软官方已经放弃维护XP。我们为什么要支持一个不安全的系统?
甲方:从技术上说Rust支持XP应该也不难
乙方:不是必需为一个老旧的系统付出开发和维护成本
甲方:XP在全世界还有非常多装机量。甚至远超Mac OS系统
乙方:XP是不安全的系统
甲方:我们的客户要求软件支持XP
乙方:XP是不安全的系统
甲方:听说美国国防部还在部署一大批XP,花大价钱专门请来微软提供技术支持
乙方:XP是不安全的系统
甲方:……

基本上,Rust官方对支持XP的态度从来都是消极的,向来都是明白拒绝的。

发帖:Rethink supporting Windows XP

我(Liigo)在2014年3月12日发帖,要求Rust又一次考虑支持XP系统:Rethink supporting Windows XP (Issue#12842)

既然我知道Rust官方对待XP的一贯态度。为什么还要再发这类贴子呢?假设说不出什么新意,非常可能被视为来捣乱的,直接Close了事。必须言之有物。

我为什么要求Rust支持XP?无它。自身的需求,客户的需求。

在帖子中,我说自己fork了Rust源码并做了少量的改动,而且真的编译出来一个能够在XP系统下初步工作的Rust(后来我还专门写过一篇如何编译XP下可用的的文档rust-xp)。

以亲身实践说明Rust支持XP在技术上没有难度;就算系统缺少某些API,也能够模拟实现(其它开源项目有非常多先例可供參考)。我还说,XP尽管老旧,但装机量仍比Mac OS、Linux、Unix加起来还要多非常多。我还说,C, C++, Java, C#, Python, Ruby, Scala 等等非常多语言都支持XP。为什么Rust要做一个特殊的另类。

由于帖子是有真材实料的。并不是老生常谈,因而帖子得以保留,讨论得以继续。然而兴许的讨论,事实上跟上一节甲方乙方的对话没有太多差别,拉锯战,持续了一年多都没有实质性的结果。在漫长的时间里,不断地有支持我意见的网友,顶起这个帖子。告诉大家他们的需求:想要Rust支持XP。但是官方人员的态度摆在那里,想说服他们180度转弯没那么easy。我也没有忘记这个帖子,有心地搜集来自各方的相关资料。争取先扭转舆论。再靠舆论扭转官方人员的态度。

契机还是来了。当两个契机来暂时,我抓住机会及时顶贴调动舆论。

第一个契机:Servo in Gecko

Gecko是Mozilla公司以C++开发的的网页渲染引擎。主要应用在Firefox浏览器中。Servo in Gecko项目是一个新的尝试,想把Rust开发的某些Servo相关代码逐步整合/替换到现有的Gecko中,最终形成换了心(Servo)的新的Gecko。这是一个野心勃勃的计划。

2015年1月1日,Mozilla公司内部跨部门沟通会上。考虑Servo in Gecko项目是否支持XP系统,然而并没有什么卵用。由于作为(部分)开发语言的Rust不支持XP。

当时Rust开发组组长Brian Anderson在场,预计承受了一些来自兄弟部门的压力。相关链接:https://github.com/servo/servo/wiki/Mozlandia-Rust-In-Gecko

2015年2月23日。Mozilla公司Servo组的另一次沟通会上,再次考虑了Servo in Gecko支持XP平台的问题。相关链接:https://github.com/servo/servo/wiki/Meeting-2015-02-23

可见,支持XP是严肃认真的需求。要想Gecko支持XP,首先必须Rust支持XP。等于是Rust拖了本公司兄弟项目的后腿。到这个时候,Rust项目组应该已经(被逼)開始考虑支持XP了。(现实,非常多时候就是这样。你能够长期忽视用户的需求,但你敢忽视来自同事甚至自家老板的需求吗?分分钟教你做如何做人。)

第二个契机:Firefox

转机最终来了。

2015年6月16日。Rust语言开发的一个库mp4parser将要被整合进Firefox浏览器源码里1。更早一点,另一个Rust库rust-url parser也打算被整合进Firefox源码里2

Firefox长期支持Windows XP。近些年Firefox在IE、Chrome步步紧逼下过得并不轻松,它在XP平台下的那大约10%的份额是死活也不肯丢的。Mozilla公司短期内绝对不同意Firefox放弃XP平台,也意味着绝对不同意Rust影响Firefox在XP上的部署。Rust必须支持XP,否则就是破坏Mozilla公司的市场战略,甚至动摇Mozilla公司的生存根基!当矛盾上升到这一层次。作为Mozilla公司主导的开源项目,Rust除了老老实实地支持XP之外已经别无选择。

支持XP

事情发展到这一步已经顺风顺水了。仅仅要官方态度发生转变。技术实现上难度不大。

到2015年6月27日,Rust已经初步实现了支持XP系统。动作还是蛮快的。

后语

所谓我(Liigo)“推动”Rust支持XP,仅仅只是是网上发发帖子、顶顶帖子、发几句牢骚、汇集些信息、引导点舆论而已。真正推动Rust支持XP的,是Mozilla公司自己项目的切实需求。Rust官方核心开发人员在此事件中始终持消极被动态度,直至收到来自公司内部的压力才有所改观,在此提出批评。

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • bloom-server 基于 rust 编写的 rest api cache 中间件
    bloom-server 基于 rust 编写的 rest api cache
    bloom-server 基于 rust 编写的 rest api cache 中间件,他位于lb 与api worker 之间,使用redis 作为缓存内容存储, 我们需要做的就是配置proxy,同时他使用基于share 的概念,进行cache 的分布存储,包含了请求端口(proxy,访问数据) 以及cache 控制端口(
    03-08
  • #新闻拍一拍# Oracle 调研如何避免让 Java 开发者投奔 Rust 和 Kotlin | Linux 中国
    #新闻拍一拍# Oracle 调研如何避免让 Java 开发
     导读:• 英特尔对迟迟不被 Linux 主线接受的 SGX Enclave 进行了第 38 次修订 • ARM 支持开源的 Panfrost Gallium3D 驱动本文字数:977,阅读时长大约:1分钟作者:硬核老王Oracle 调研如何避免让 Java 开发者投奔 Rust 和 KotlinOracle 委托分析公司 Omd
    03-08
  • Linux系统下Rust快速安装:国内镜像加速
    Linux系统下Rust快速安装:国内镜像加速
    官方网址和方法Install Rust - Rust Programming Language然而速度慢得让人难以置信。利用国内镜像进行windows的Linux子系统的Rust安装。rust 使用国内镜像,快速安装方法参考:RUST安装慢怎么办,使用镜像方式安装_网络_为中华之崛起而编程-CSDN博客我的操作
    03-08
  • Rust到底值不值得学--Rust对比、特色和理念
    前言其实我一直弄不明白一点,那就是计算机技术的发展,是让这个世界变得简单了,还是变得更复杂了。当然这只是一个玩笑,可别把这个问题当真。然而对于IT从业者来说,这可不是一个玩笑。几乎每一次的技术发展,都让这个生态变得更为复杂。“英年早秃”已经成
    03-08
  • 超33000行新代码,为Linux内核添加Rust支持的补丁已准备就绪
    超33000行新代码,为Linux内核添加Rust支持的补
    https://mp.weixin.qq.com/s/oKw9aBJSdmRoO6-rbLAkNw7 月 4 日,一套修订后的补丁被提交至 Linux 内核的邮件列表中,该补丁为在 Linux 内核中以 Rust 作为辅助编程语言提供了支持,借助 Rust 可以提高 Linux 内核和内存的安全。整套补丁包含 17 个子项,不光
    03-08
  • 【译】Rust 的 Result 类型入门
    【译】Rust 的 Result 类型入门
    A Primer on Rust’s Result Type 译文原文链接:https://medium.com/@JoeKreydt/a-primer-on-rusts-result-type-66363cf18e6a原文作者:Joe Kreydt译文出处:https://github.com/suhanyujie/article-transfer-rs译者:suhanyujietips:水平有限,翻译不当之
    03-08
  • Rust实战系列-基本语法
    Rust实战系列-基本语法
    主要介绍 Rust 的语法、基本类型和数据结构,通过实现一个简单版 grep 命令行工具,来理解 Rust 独有的特性。本文是《Rust in action》学习总结系列的第二部分,更多内容请看已发布文章:一、Rust实战系列-Rust介绍“主要介绍 Rust 的语法、基本类型和数据结
    03-08
  • 全栈程序员的新玩具Rust(三)板条箱
    上次用到了stdout,这次我们来写一个更复杂一点的游戏rust的标准库叫做std,默认就会引入。这次我们要用到一个随机数函数,而随机数比较尴尬的一点是这玩意不在标准库中,我们要额外依赖一个库。很多编程方案都有自己的模块化库系统,rust也不例外,不过rust
    02-10
  • 全栈程序员的新玩具Rust(六)第一个WASM程序
    全栈程序员的新玩具Rust(六)第一个WASM程序
    先上代码https://gitee.com/lightsever/rust_study/tree/master/wasm_hello01webassembly就不用再赘述了,耳朵里面快磨出茧子来了。rustwasm是火狐自家的玩具,让我们来继续做实验,让rust飞起来吧。环境安装安装好rust环境之后仍然需要 一个 wasm 工具包carg
    02-10
  • 【Rust】标准库-Result rust数据库
    环境Rust 1.56.1VSCode 1.61.2概念参考:https://doc.rust-lang.org/stable/rust-by-example/std/result.html示例main.rsmod checked {#[derive(Debug)]pub enum MathError {DivisionByZero,NonPositiveLogarithm,NegativeSquareRoot,}pub type MathResult =
    02-09
点击排行