:: ZoomQuiet [2005-02-27 03:19:57]
项目表情 |
概念/筹备/设计ing |
编写/开发/组织ing |
试用/推行ing |
发行/应用ed |
停顿 |
总述
没有规矩不成方圆,利用前人经验,写出自个儿的漂亮代码!
规范
基础规范 开发规范参考 - WoodpeckerProjs/DevGeneralRule
规范名 |
链接 |
主要作者 |
进展 |
SVN使用规范 |
30% |
||
项目文档规范 |
20% |
||
工作邮件规范 |
100% |
编码规范
规范名 |
链接 |
主要作者 |
进展 |
规范名 |
链接 |
主要作者 |
进展 |
编码注释规范 |
90% |
通用编码规范 |
40% |
||||
安全编码规范 |
- |
10% |
c/c++语言编码规范 |
- |
5% |
||
Perl语言编码规范 |
- |
0% |
PHP语言编码规范 |
- |
0% |
||
Python语言编码规范 |
hoxide,xyb,ZoomQuiet |
92% |
JScript语言编码规范 |
- |
0% |
||
ActionScript语言编码规范 |
- |
0% |
数据库设计规范 |
- |
- |
WebDesignStandard -- Web 开发代码规范建议
文档规范
原则就是条理,充分
OssDocExample -- FreeBSD unionfsの改善提案
日志记要
|
07日志 |
06日志 |
体验
如何做开源项目——ABC
谈开源不能不谈免费,现在国内几乎所有的所谓开源软件,根本不具备任何开源特征,对开源领域及计算机业的奉献甚少。比如Discuz一类的论坛什么的。 他们都抓住了人贪婪的本性,一味的将开源同免费划成等号。我们今天就不详细讲述他们的罪过,我们在这里讲讲,假如你想做开源你需要做好什么样的心理和技 术的准备。
心理准备:
- 做的时候就要考虑好你的项目要发展10年甚至100年。长期的考虑可以更好的规划你的项目,放下浮躁的心态,认真的做事情。
- 一个开源项目同一个公司的项目不同。公司的项目是计划式项目,利益为目的,如果公司破产或业务改变那么项目就可能会取消。而开源项目不一定,很多项目都是由爱好者发起维护的,你要准备好即使你离开,这个项目也会继续,一个项目的发展目的不仅仅是为了你个人
- (当然你出发点可能是为了个人,但是项目能否存活关键一点在于心态)。
- 万事怀着感恩的心。宽待别人,善于倾听别人的意见,但同时也要保证自己的设计思路不被打乱。
- 一定要倾听别人的意见,但是作为项目的执行者,要以自己的理解为准则。不要怕自己做错了,做的不好。记住你有10年的时间来使项目完善。一个项目如果想发展起来一定是有很多人参与的,所以不要做一言堂。
- 尊重合约。不是要求别人尊重你的合约,而是尊重他人的。不偷窃他人的代码,尊重微软这类公司,对盗版憎恨。这是做开源的基础,如果做不到,恐怕你还需要学习。建议,如果有时间请先看过圣经,在圣经中你会学习信用是多么重要的。
- 开源最大的敌人是谁?不是商业软件,不是微软,是盗版。如果你想别人尊重你的劳动成果你现在就应该尊重微软这类公司。我们现在不是土匪时代(英雄时代),盗版不利于我们的科技进步,人人想着不劳而获,贪婪不要占据你全身。尊重合同,可以得到所有人的尊重,因此请注意,如果你要抄袭别人代码。请为他们保留版权说明,别啥都是你做的。你也想搞个小汉芯吗?
- 作好心态,不论你是为了盈利你还是为了兴趣,做开源就要做好心态,你要允许别人在没给你任何好处的时候利用你的成果获利。
- 不论你是为了盈利,还是为了兴趣,只要不违背开源的精神,你对这个行业都有贡献。请不要做的太自私,既然开源的就要让大家共同享受知识带来的好处,不然你开源干吗,还是继续去搞“免费软件”吧。
- 不要相信那些说“我愿意参加你的项目,我希望参与工作”的人,真正参与项目的人从来不会表态他只会给你一个patch然后告诉你你代码有什么问题。
- 根据多年的经验,以及多次项目的失败总结,基本上热火朝天的跟你说这句话的人,根本对你一点帮助也没有。真正愿意参与做事情的人,是不会说这句话的。这不仅仅在国内,在海外也是有这个特点的。
技术准备:
你可以选择sourceforge.net或是你自己弄服务器做开源,不论怎么样。不是简单有个下载,有个web就叫开源的,你需要一些工具来帮助你:
- WIKI
- 你的网站可以采用WIKI这样可以方便参与者编辑修改页面,尤其是编写文档的时候很重要。当然国内的垃圾广告太厉害了,如果你是中文网站,就做上权限吧。我推荐你可以使用dokuwiki来做。
- 作为一个长期发展的项目,你总的做计划吧,你总的允许别人向你报告错误吧。你需要一个缺陷跟踪系统。如果你系统有什么问题或别人对你系统有什么需求,他可以在bug tracker里发出需求。推荐你使用mantis这个代码是php编写的很简单容易使用。
- SVN
- 你需要协同工作,就一定需要一个SVN现在几乎所有的项目都有自己的SVN仓,SVN不仅仅可以协同工作。他还可以对你的代码做历史记录。网上可以下载到svn的中文pdf 你搜索一下看看。
- Maillist或是BBS
- 有这样一个特点,老外是习惯使用Maillist的,而中国人习惯使用BBS。所以根据你自己的需要给项目选择一个沟通方式。
- QQ或IRC
- 如果你项目针对国内,建立一个QQ群是很重要的。当然你也可以建立一个IRC房间,上www.freenode.org上去申请一个,所有的大型项目都在freenode上有实时的讨论组。
- 有了以上,你还需要怎么做?很简单,开始干事情,别记得请别人加入项目。记得你是要发展10年,你的项目只要做的好,做一些简单的宣传,很快就有人找上门来了。
- GPLv2/LGPL/MPL.....想好用什么协议
- 你当然可以自己“开创”一些协议,不过我建议你使用一些标准的协议,这些协议精力了时间的磨练,并且在法律和道德的问题上他们更能经的住考验。协议很多,每个厂家比如SUN都有自己的或APACHE也有自己的。但是目前最流行的还是GPLv2 LGPL MPL等。
- 使用GPLv2是最适合的。相比有些协议过于开放比如Art license而有一些显的非常小气比如MPL。GPLv2的协议能更好的让项目持续发展下去。如果是MPL大部分的项目(我是说那些能做的起来的)做到最后,都成私人产品了。
补充
- QQ 永远是吹水的地方,不是聊技术的地方。放弃它,用邮件列表吧。
- 如果你打算做开源,在项目的初期,请全部用英文,包括网站、文档、svn 修改记录、代码里的注释。
- 不要留私人联系方式,有邮件列表就够了。
- 老外如果用了你的项目,并且他认为确实给他带来了便利,他们会很乐意捐赠给你。国人99%不会。
- 国人会认为他用了你的产品,是给公司带来了便利,所以应该找公司要捐赠、要赞助。
- 他们丝毫不认为你的项目是在帮助他自己 -- 如果他没干好自己分内的事(也就是你的项目做的事), 老板扣的是他的工资。
- 当你告诉他从做测试、做论坛解答开始,他的热情就降了一大半的人,请感谢他。因为他让你少 浪费了一些时间在他身上。
- 从那些实实在在做事、patch、论坛帮忙解答问题的朋友中挑选你认为合适的人选作为团队成员。 做实事,实际就是在做核心团队、开发团队、整个团队做的事情。
反馈
<<PageComment2(commentonly=1)>>