Fw: [心得] 我如何在 GitHub 上拿到四千颗星

楼主: keitheis (无)   2016-07-07 21:18:32
※ [本文转录自 Soft_Job 看板 #1NVZHc9P ]
作者: eliang () 看板: Soft_Job
标题: [心得] 我如何在 GitHub 上拿到四千颗星
时间: Thu Jul 7 18:52:09 2016
两个月前我在 GitHub 发表了一个开源专案,发表后一夕爆红,在一开始的 24 小时内就
得到 1200+ 颗星,目前已累积 4000+ 颗星。这个专案名叫 HTTP Prompt,网址是:
https://github.com/eliangcs/http-prompt
我想在这里分享一下它的开发故事。
这一切要先从 Vertica 讲起。没多久前我的工作几乎每天都会使用 Vertica,Vertica
是一个强大的数据库,但它官方的客户端程式(vsql)一点都不强大。另一个 GUI 的选择
DbVisualizer 也是难用到爆。
我就想起 PostgreSQL 那边有一个叫 pgcli 的好物,我想如果 fork 它,应该不需要太大
功夫就能把它改成 Vertica 版本。最后也如我所想,没花几天就写出了 vcli:
https://github.com/dbcli/vcli
我还联络了 pgcli 的原作者,告诉他“我用你的东西写了另一个专案”,他很高兴的帮我
在他网站上宣传。但 Vertica 实在是小众,所以 vcli 并没有得到很多注意。但至少有了
vcli,我终于能每天快快乐乐的使用 Vertica 了。
vcli、pgcli、mycli(for MySQL)其实都是建于一个叫 prompt-toolkit 的 Python 套件
之上。有了 prompt-toolkit 的加持,任何命令列程式因为有了自动完成和语法高亮,都
会变得超酷炫,去它的首页看看有多少专案使用它就知道了:
https://github.com/jonathanslenders/python-prompt-toolkit
当时有一阵子工作常会需要连接 HTTP/REST API,这应该也是很多人工作的一部分,我相
信大部分人应该都是用 Postman 这类 GUI 工具,但身为一个什么都要尽量用命令列接口
的 hacker,用 GUI 实在有点 low,而且跟 terminal 切换起来也不方便。所以我就选择
使用类似 curl 的 HTTPie。使用 HTTPie 的缺点是常需要打很多重复的字,不像 Postman
会帮你记住之前的状态,我想如果 HTTPie 或 curl 有互动模式就好了。我调查了一下,
原来早在一年前就有人这么想了:
https://github.com/jkbrzt/httpie/issues/343
甚至在五年前就有人写出我心目中理想的工具了:
https://github.com/chrislongo/HttpShell
但 HTTPie 实在设计得太完美让我不想放弃它,而且 HttpShell 似乎也没在更新,所以我
也就不考虑使用 HttpShell。
“任何命令列程式受了 prompt-toolkit 加持,都会变得超酷炫”,那我何不站在巨人肩
膀上,结合 HTTPie 和 prompt-toolkit,写出一个有自动完成和语法高亮的 HTTP client
,不要求使用者放弃完美的 HTTPie,肯定有卖点。
于是我开始着手开发 HTTP Prompt,我还告诉我老婆,我这写完至少会在 GitHub 拿一千
颗星星。我当时不是随便推算的。因为 pgcli 都有四千多颗星了,用 HTTP 的人一定多过
PostgreSQL,所以如果我执行得好,吸引一千颗星星应该不是问题。
一开始卡最久是我想找出一个完美的写法,使得自动完成、语法高亮、指令解析三大模组
能用一个统一的 context-free grammar(CFG)解决,但 prompt-toolkit 的作者告诉我
这个想法不切实际:
https://github.com/jonathanslenders/python-prompt-toolkit/issues/276
所以最终只有指令解析是以 CFG 实做,另两个模组则分别土法炼钢。CFG parser 一开始
也让我有点头痛,幸亏有人写了一个现成的 parser:
https://github.com/erikrose/parsimonious
读过 parsimonious 的程式码,我只能说这套件的作者功力深厚,没有编译器或正规语言
的基础还真写不出这样的东西。
prompt-toolkit 已解决大部分的难题,所以除了 CFG 之外就没什么特别困难的地方了。
我前后大概花了三个礼拜完成基本功能,即发布到 Reddit/programming,没多久就登上热
门第一名:
https://www.reddit.com/r/programming/comments/4k1l2o
Reddit 广告效益真的很强,HTTP Prompt 初期的流量都是靠 Reddit 吸引进来的。之后星
星数愈增愈快,几乎是每一分钟都就多一颗星,也成功登上 GitHub Trending 第一名,老
婆还帮我拍了一张照片做纪念:
http://imgur.com/4zKkv98
Issue 和 pull request 也跟着星星一起来,其中有不少不错的功能建议,我也陆续加入
,在后面几个版本释出。
开发开源专案是很好玩的,当你知道很多人正在使用你写的软件、给你回馈,你会觉得你
在做一件有意义的事。希望这篇文章能鼓励更多人使用 HTTP Prompt,也能帮助到一些想
参与开源专案的人,当然最好是可以贡献到 HTTP Prompt :P。
作者: landlord (91)   2015-07-07 18:55:00
great!
作者: Masakiad (Masaki)   2015-07-07 18:59:00
开源推
作者: lensuper (莫三)   2015-07-07 19:07:00
强者
作者: chiwa (我是青蛙,不是王子^_^)   2015-07-07 19:10:00
高手!!
作者: ntddt (灭顶,降公投罢免门槛)   2015-07-07 19:12:00
强者狂推 让世界看到台湾软实力
作者: crossdunk (推嘘自如)   2015-07-07 19:13:00
4000!!!!!!!!!!!!
作者: SMNOONMS   2015-07-07 19:14:00
推开源
作者: SuM0m0 (Part Time Player)   2015-07-07 19:16:00
赞耶 看起来很不错
作者: rodion (r-kan/reminder)   2015-07-07 19:20:00
感谢分享经验谈:>
作者: mmm951 (白天天气好)   2015-07-07 19:24:00
推分享
作者: hSATAC (cAt Ash)   2015-07-07 19:27:00
作者: feeling543 (ifeelings)   2015-07-07 19:28:00
推!
作者: sdf611097 (犹若洗苦)   2015-07-07 19:29:00
作者: max241 (养生之道)   2015-07-07 19:31:00
GOD
作者: cookie1115 (大饼)   2015-07-07 19:32:00
作者: aa06697 (todo se andarà)   2015-07-07 19:36:00
太神啦
作者: y2468101216 (芸)   2015-07-07 19:37:00
作者: minikai (一肚子拐)   2015-07-07 19:41:00
太神了! 已跪!
作者: MoriUmi (森海)   2015-07-07 19:48:00
推 有空来用用看 感觉很实用 手打指令超容易打错的
作者: jlhc (H)   2015-07-07 19:54:00
推一个!!!
作者: fake01 (假面超人)   2015-07-07 20:02:00
太神辣
作者: Zeusken (Rushken)   2015-07-07 20:04:00
好强
作者: sky75217 (瑞比特)   2015-07-07 20:07:00
作者: TKSHADE (雨怎么下不停)   2015-07-07 20:16:00
强者~~!!
作者: longlyeagle (长鹰宝宝实验室)   2015-07-07 20:21:00
push
作者: Aaronter   2015-07-07 20:26:00
感谢支援
作者: Hevak (Arthow Eshes)   2015-07-07 20:29:00
有在trending看到,原来是台湾人@@! cool
作者: chung928 (chung928)   2015-07-07 20:30:00
推强者!
作者: Yshuan (倚絃)   2015-07-07 20:30:00
朝圣!!
作者: bowin (尽其在我)   2015-07-07 20:33:00
推!Good job!! :-)
作者: bab7171   2015-07-07 20:49:00
作者: FLAMEDDD   2015-07-07 20:53:00
请问“fork它”是什么意思阿 谢谢
作者: SmileJoS ( O.o)   2015-07-07 20:56:00
推推推,好强
作者: wuliou (wuliou)   2015-07-07 20:56:00
太强辣
作者: vi000246 (Vi)   2015-07-07 20:58:00
作者: eliang   2015-07-07 21:00:00
fork意思是拿别人的code改成另一个东西没想到PTT广告效益也很好,又多了好多星星,感谢乡民支持
作者: A4P8T6X9 (残废的名侦探)   2015-07-07 21:06:00
作者: gozule (好冷啊~~)   2015-07-07 21:12:00
open source果然高手如云
作者: javy0521   2015-07-07 21:16:00
推!
作者: uranusjr (←這人是超級笨蛋)   2016-07-08 01:07:00
这真的很猛, MacDown 花了两年才破 4000...
作者: NaiveRed (天真红)   2016-07-08 21:57:00
推 太猛了!
楼主: keitheis (无)   2016-07-14 23:01:00
喔!MacDown 也破 4000!

Links booklink

Contact Us: admin [ a t ] ucptt.com