AICon全球人工智能与机器学习技术大会9折特惠中,点击立减¥480! 了解详情
写点什么

Atom 简史:差点被 GitHub 创始人放弃

2015 年 7 月 01 日

作为 GitHub 专门为开发者推出的跨平台文本编辑器, Atom 预览版之前共经历了 155 次更新,在性能、稳定性以及模块化等方面进行了多项改进。近日,GitHub 正式发布Atom 1.0 版本。接下来,本文从Atom 的历史开始讲起,对其进行简要介绍。

Atom 作为 GitHub 创建者 Chris Wanstrath( @defunkt )的编外项目,起源于 2008 年中期。当时,Chris 称之为 Atomicity,其初衷是利用 web 技术来设计一个像 Emacs 一样可定制化的软件,为新一代的开发者提供一个具有完全控制权的编辑器。但是,与很多其他编外项目的命运相同,Chris 在看到 GitHub 成功的希望之后,就搁浅了 Atomicity。

之后,基于 Node.JS 构建的 JavaScript 程序开发 Web IDE——Cloud9 出现,为 JS、HTML、CSS 等混合代码提供了着色显示的文本编辑器,再次影响了 Atomicity 的进度。到 2011 年 8 月,GitHub 把 Ace 加入到 github.com 中用于文件的编辑工作,再次激发了 Chris 对于 Atomicity 的兴趣。三天后,Chris 用 Ace 编写了一个运行在原生 WebView 空间内的 OS X 应用。由此,Atom 项目的代码编写工作正式启动。

在之后的 3 个月内, @defunkt @probablycorey 开始在闲暇时间一起致力于 Atomicity 的工作。到 11 月份,Atomicity 正式更名为 Atom,并升级为了官方的 GitHub 项目。12 月份, treetop 的作者 @nathansobo 加入了 GitHub,全职进行 Atom 的开发。之后,Atom 就开始沿着正规的开发流行进行不断更新,更多的细节可参考 atom/atom git history contributor graphs

在过去的 18 个月中,Atom 预览版的下载量超过了 130 万,每个月服务超过 35 万活动用户。目前,Atom 社区共创建了 660 个主题和 2090 个包,其中 linter、autocomplete-plus 以及 minimap 等包已经拥有了自己的子社区。通过稳定的 API、内置 ES6 支持、支持包与包的通信、扩展编辑器核以及自适应 UI 等,Atom 变得越来越模块化,也能够更好的支持用户的二次开发。Atom 编辑器的最大特点就是采用 Web 技术了来构建应用程序。基于 Chromium 核心和 Node.js,Atom 就是一个 Web 页面,具有通过 Node.js 访问本地文件系统、执行第三方进程等功能。其开源的组件包括了核心(Core)、包管理器 APM(Atom Package Manager)以及 Atom Shell 三个部分。在不断的更新过程中,为了能够支持社区设计的 autocomplete-plus 等包,Atom 团队对这三个部分进行了不断调整。目前,Atom 具有支持 CSS、HTML、JavaScript 等网页编程语言、支持宏、能够自动完成分屏功能、集成文件管理器等特点。而且,Atom 为 OS X 10.8 及以后的系统、Windows 7&8 以及 Ubuntu 等操作系统都提供了源代码及安装包。Atom 团队还提供了扩展的 API 文档、使用手册以及针对初学者的教学视频等。

Atom 1.0 版本实现了 @defunkt 的初衷——开发者拥有编辑器完全的控制权,成为未来很多工作的基础。但是,完全实现 Atom 项目所预想的目标很有很长的路要走。GitHub 的工程师 Ben Ogle 表示,Atom 团队未来会考虑进行改善用户体验、提升编辑器性能和稳定性、增加更多语言支持等方面的工作。


感谢徐川对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群)。

2015 年 7 月 01 日 09:484937
用户头像

发布了 268 篇内容, 共 103.3 次阅读, 收获喜欢 19 次。

关注

评论

发布
暂无评论
发现更多内容

架构师训练营Week7作业

Frank Zeng

动手实现一下 JavaScript 中的 call, apply 和 bind

卧龙小明

Java 前端

iframe 隐藏滚动条、高度自适应及父子页面通信

卧龙小明

CSS Java html 前端

第七周作业

赵龙

搭建Hadoop开发环境并编写运行测试类

大数据学徒

Java hadoop IDEA

性能测试与优化学习总结

qihuajun

week07总结 性能测试&操作系统

Z冰红茶

Docker基础修炼5--容器数据共享和持久化实战

黑马腾云

Docker Linux 运维 虚拟化 容器化

架构师训练营 - 第七周 - 学习总结

stardust20

简约而不简单的分布式通信基石

架构师修行之路

分布式 socket udp TCP/IP 通信协议

架构师训练营Week7学习总结

Frank Zeng

性能优化(一)

olderwei

架构师训练营 - 第七周 - 作业

韩挺

修改 Docker 数据根目录的 3 种方式

FeiLong

Docker

Docker基础修炼4--Docker仓库及相关命令

黑马腾云

Docker Linux 运维 容器技术 虚拟化

JavaScript 类型判断

卧龙小明

Java 前端

架构师0期07周作业

我在终点等你

阿朱的决定

一直AC一直爽

随笔杂谈 观后感

Docker基础修炼6--网络初探及单机容器间通信

黑马腾云

Docker Linux 运维 虚拟化 容器化

Docker网络学习第三篇-路由

Lazy

Docker Linux 网络

总结

chenzt

LeetCode题解:283. 移动零,JavaScript,一次遍历,详细注释

Lee Chen

LeetCode 前端进阶训练营

关注系统压力测试

麻辣

JavaScript 中 new 一个对象的过程中发生了什么

卧龙小明

Java 前端

优秀的求职者,是如何巧妙应对面试提问呢?

xcbeyond

面试 加班 职业规划 薪资 自我介绍

js基础作业总结

Geek_896619

第七周学习总结

赵龙

性能优化作业

qihuajun

antd vue upload组件使用customRequest上传文件显示文件上传进度

Seven_xw1213

前端 antd vue upload customRequest 进度条

解决 transition 在 display 属性上不生效的问题

卧龙小明

css3

如何找一碗正宗的热干面

zhoo299

美食

新晋管理者都会遇到的6个问题

新晋管理者都会遇到的6个问题

Atom简史:差点被GitHub创始人放弃-InfoQ