微软欲闭源 VS Code 的 C# 扩展惹众怒
6 月 16 日,微软项目经理 Tim Heuer 公布 了 VSCode C# 扩展的路线图更新,新的路线图引入语言服务器协议(LSP) 作为 VSCode C# 扩展的基础通信机制,并计划创建一个新的“LSP Tools Host”组件作为新版 C# 扩展的基础,以引入更多实用功能。但微软在公告中称 “LSP Tools Host”组件 将不开源 ,该决定随即引发了大量批评。
八年前,OmniSharp 团队用当时的 API 和协议开发了 VS Code 中的 C# 扩展。如今语言服务器协议 LSP 已成为现代开发工具(编辑器、IDE 等)相互交流的标准机制,因此微软打算将 C# 扩展切换为完全使用 LSP 进行通信,并计划更新现有的 OmniSharp 组件,使它们也以 LSP 进行通信:
(这里要提一句,创建 C# for VSCode 扩展的 OmniSharp 团队虽然有很多微软的员工,但该团队由社区驱动,并不属于微软,也就是说微软正在收编由社区开发的 C# 扩展,把它的发展路径掌握在自己手中。)
利用 LSP ,将使我们能为 C# for VS Code 扩展带来创新的功能。包括提供高级功能,以及在某些情况下提供 闭源体验 ,例如 IntelliCode。
我们计划创建一个新的“LSP Tools Host”组件,它将 Roslyn 和 Razor 等开源组件 与闭源组件集成在一起 ,提供了更广泛的功能。
“LSP Tools Host” 将成为 C# for VS Code 扩展的 默认体验, 现有用户可以在现有的开源 OmniSharp 驱动系统和新的“LSP Tools Host”之间进行选择,后者将提供一些额外功能(比如闭源功能)的访问权限。
“LSP Tools Host”不会开源,但我们计划在此过程中与社区进行沟通,以帮助指导我们未来的计划。
简而言之,采用 LSP 通信机制之后,这个新的 LSP Tools Host 组件将是新的 C# for VS Code 扩展的默认功能包,会捆绑更多“开箱即用”的功能。也许是因为这个组件引进了一些闭源的功能模块,所以社区用户可以帮忙开发,但它不能开源。
这则公告毫无疑问地被冲了,用户纷纷质疑为什么新的组件不能开源,指责微软“回到过去那个封闭的、利益至上的微软”:
面对众人对闭源的质疑,微软项目经理 Tim Heuer 更新了公告,进一步解释了 “LSP Tools Host” 组件不开源的原因:
Razor 和 C# 的 LSP 实现将保持开源(Roslyn 和 Razor)。VS Code 的 C# 扩展 (ms-dotnettools.csharp) 本身也将保持开源。
这个新的 “LSP Tools Host” 组件只是 开源和闭源功能之间的桥梁 ,让我们可以同时提供这两种功能。
但有一说一,这个说法似乎不太能服众,毕竟路线图写得明明白白: “LSP Tools Host” 将成为 C# for VS Code 扩展的默认体验,现在则称其只是一个“桥梁”......
前车之鉴
其实,在 C# 扩展之前,微软对 VSCode 的语言扩展就有过收编再闭源的操作 。用户 Pradyun Gedam 指出:此前 VSCode 的 Python 扩展在开源解决方案 Jedi 的支持下普及,然后微软将其收编,并 构建了一个基于 LSP 的闭源 Python 扩展 pylance ,承诺提供更好的用户体验。
然后微软就将闭源的 pylance 设为 Python for VS Code 扩展的默认方案(甚至推送提示,让用户切换到该扩展),同时不断地减少对开源部分的资源投入。如今,使用 Pylance 的 Python 扩展比 Jedi 多太多功能,以至于用户只能选择闭源的 pylance 扩展。
用户 Gerard Smit 对此进行了总结:“ 拥抱、延伸和熄灭。 ”这三个词指先拥抱开源,让社区力量为其提供更完善的功能;然后再对该功能进行“延伸、扩展和改善”,随后再闭源并强推“延伸”之后的新功能,“熄灭”原有的由社区驱动的开源功能。
- 为什么 Fedora 一开始允许使用 CC0 许可证 | Linux 中国
- 开源节流!中国移动上半年净利增近19%,员工减少3866人
- What's new in dubbo-go-pixiu 0.5.1
- 负载均衡原理分析与源码解读
- Padloc:一个直观的开源密码管理器 | Linux 中国
- 中国电信成为首个加入 OpenHarmony 开源鸿蒙社区的运营商
- 利用 SonarScanner 静态扫描 Rainbond 上的 Maven 项目
- Gartner:iPaaS、低代码平台销售额将在 2022 实现两位数增长
- Koodo:一款适用于 Linux 的一体化开源电子书阅读器应用 | Linux 中国
- 不删了!遭强烈反对后,GitLab 修改政策
- 分布式链路追踪Jaeger 微服务Pig在Rainbond上的实践分享
- AppFlowy:Notion 的开源替代品 | Linux 中国
- 微软 .NET Core 3.1 年底将结束支持
- GNOME 新功能:安全启动被禁用时警告用户
- Aapache ShenYu 毕业成为 Apache 顶级项目!
- 收藏!0基础开源数据可视化平台FlyFish大屏开发指南
- 从开源的视角,解析SAP经典ERP “三十年不用变”的架构设计 荐 转
- 从码农转型大音乐家,你需要这些音乐制作处理工具
- 时隔 15 年,Glibc 终于引入了用于 Linux 的 arc4random 函数
- 五分钟给你的 gRPC 服务加上 HTTP 接口