开放源代码工程组织研究-->

啄木鸟社区工程管理文集-->

开源自由软件项目管理文集

:: ZoomQuiet [2005-02-27 03:19:57]

项目表情

(!) 概念/筹备/设计ing

{o} 编写/开发/组织ing

{*} 试用/推行ing

{OK} 发行/应用ed

|-) 停顿

总述

没有规矩不成方圆,利用前人经验,写出自个儿的漂亮代码!

规范

规范名

链接

主要作者

进展

{o} SVN使用规范

OssSvnRule

ZoomQuiet

30%

{o} 项目文档规范

OssProjDocRule

ZoomQuiet

20%

{*} 工作邮件规范

WkMailRule

ZoomQuiet

100%

编码规范

规范名

链接

主要作者

进展

规范名

链接

主要作者

进展

{*} 编码注释规范

CodeCommentingRule

ZoomQuiet

90%

{o} 通用编码规范

OssGeneralCodingRule

ZoomQuiet

40%

(!) 安全编码规范

OssSecurityCodingRule

-

10%

(!) c/c++语言编码规范

OssCCodingRule

-

5%

(!) Perl语言编码规范

OssPerlCodingRule

-

0%

(!) PHP语言编码规范

OssPhpCodingRule

-

0%

{*} Python语言编码规范

PythonCodingRule

hoxide,xyb,ZoomQuiet

92%

(!) JScript语言编码规范

JscriptCodingRule

-

0%

(!) ActionScript语言编码规范

ActionScriptCodingRule

-

0%

(!) 数据库设计规范

OssDbDesignRule

-

-

文档规范

原则就是条理,充分

日志记要

<< <  2015 / 11 >  >>
Mon Tue Wed Thu Fri Sat Sun
            1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30            

07日志

06日志

体验

如何做开源项目——ABC

谈开源不能不谈免费,现在国内几乎所有的所谓开源软件,根本不具备任何开源特征,对开源领域及计算机业的奉献甚少。比如Discuz一类的论坛什么的。 他们都抓住了人贪婪的本性,一味的将开源同免费划成等号。我们今天就不详细讲述他们的罪过,我们在这里讲讲,假如你想做开源你需要做好什么样的心理和技 术的准备。

心理准备:

  1. 做的时候就要考虑好你的项目要发展10年甚至100年。长期的考虑可以更好的规划你的项目,放下浮躁的心态,认真的做事情。
    • 一个开源项目同一个公司的项目不同。公司的项目是计划式项目,利益为目的,如果公司破产或业务改变那么项目就可能会取消。而开源项目不一定,很多项目都是由爱好者发起维护的,你要准备好即使你离开,这个项目也会继续,一个项目的发展目的不仅仅是为了你个人
    • (当然你出发点可能是为了个人,但是项目能否存活关键一点在于心态)。
  2. 万事怀着感恩的心。宽待别人,善于倾听别人的意见,但同时也要保证自己的设计思路不被打乱。
    • 一定要倾听别人的意见,但是作为项目的执行者,要以自己的理解为准则。不要怕自己做错了,做的不好。记住你有10年的时间来使项目完善。一个项目如果想发展起来一定是有很多人参与的,所以不要做一言堂。
  3. 尊重合约。不是要求别人尊重你的合约,而是尊重他人的。不偷窃他人的代码,尊重微软这类公司,对盗版憎恨。这是做开源的基础,如果做不到,恐怕你还需要学习。建议,如果有时间请先看过圣经,在圣经中你会学习信用是多么重要的。
    • 开源最大的敌人是谁?不是商业软件,不是微软,是盗版。如果你想别人尊重你的劳动成果你现在就应该尊重微软这类公司。我们现在不是土匪时代(英雄时代),盗版不利于我们的科技进步,人人想着不劳而获,贪婪不要占据你全身。尊重合同,可以得到所有人的尊重,因此请注意,如果你要抄袭别人代码。请为他们保留版权说明,别啥都是你做的。你也想搞个小汉芯吗?
  4. 作好心态,不论你是为了盈利你还是为了兴趣,做开源就要做好心态,你要允许别人在没给你任何好处的时候利用你的成果获利。
    • 不论你是为了盈利,还是为了兴趣,只要不违背开源的精神,你对这个行业都有贡献。请不要做的太自私,既然开源的就要让大家共同享受知识带来的好处,不然你开源干吗,还是继续去搞“免费软件”吧。
  5. 不要相信那些说“我愿意参加你的项目,我希望参与工作”的人,真正参与项目的人从来不会表态他只会给你一个patch然后告诉你你代码有什么问题。
    • 根据多年的经验,以及多次项目的失败总结,基本上热火朝天的跟你说这句话的人,根本对你一点帮助也没有。真正愿意参与做事情的人,是不会说这句话的。这不仅仅在国内,在海外也是有这个特点的。

技术准备:

你可以选择sourceforge.net或是你自己弄服务器做开源,不论怎么样。不是简单有个下载,有个web就叫开源的,你需要一些工具来帮助你:

  1. WIKI
    • 你的网站可以采用WIKI这样可以方便参与者编辑修改页面,尤其是编写文档的时候很重要。当然国内的垃圾广告太厉害了,如果你是中文网站,就做上权限吧。我推荐你可以使用dokuwiki来做。
  2. BugTracker

    • 作为一个长期发展的项目,你总的做计划吧,你总的允许别人向你报告错误吧。你需要一个缺陷跟踪系统。如果你系统有什么问题或别人对你系统有什么需求,他可以在bug tracker里发出需求。推荐你使用mantis这个代码是php编写的很简单容易使用。
  3. SVN
    • 你需要协同工作,就一定需要一个SVN现在几乎所有的项目都有自己的SVN仓,SVN不仅仅可以协同工作。他还可以对你的代码做历史记录。网上可以下载到svn的中文pdf 你搜索一下看看。
  4. Maillist或是BBS
    • 有这样一个特点,老外是习惯使用Maillist的,而中国人习惯使用BBS。所以根据你自己的需要给项目选择一个沟通方式。
  5. QQ或IRC
    • 如果你项目针对国内,建立一个QQ群是很重要的。当然你也可以建立一个IRC房间,上www.freenode.org上去申请一个,所有的大型项目都在freenode上有实时的讨论组。
    • 有了以上,你还需要怎么做?很简单,开始干事情,别记得请别人加入项目。记得你是要发展10年,你的项目只要做的好,做一些简单的宣传,很快就有人找上门来了。
  6. GPLv2/LGPL/MPL.....想好用什么协议
    • 你当然可以自己“开创”一些协议,不过我建议你使用一些标准的协议,这些协议精力了时间的磨练,并且在法律和道德的问题上他们更能经的住考验。协议很多,每个厂家比如SUN都有自己的或APACHE也有自己的。但是目前最流行的还是GPLv2 LGPL MPL等。
    • 使用GPLv2是最适合的。相比有些协议过于开放比如Art license而有一些显的非常小气比如MPL。GPLv2的协议能更好的让项目持续发展下去。如果是MPL大部分的项目(我是说那些能做的起来的)做到最后,都成私人产品了。

补充

  • QQ 永远是吹水的地方,不是聊技术的地方。放弃它,用邮件列表吧。
  • 如果你打算做开源,在项目的初期,请全部用英文,包括网站、文档、svn 修改记录、代码里的注释。
  • 不要留私人联系方式,有邮件列表就够了。
  • 老外如果用了你的项目,并且他认为确实给他带来了便利,他们会很乐意捐赠给你。国人99%不会。
    • 国人会认为他用了你的产品,是给公司带来了便利,所以应该找公司要捐赠、要赞助。
    • 他们丝毫不认为你的项目是在帮助他自己 -- 如果他没干好自己分内的事(也就是你的项目做的事), 老板扣的是他的工资。
  • 当你告诉他从做测试、做论坛解答开始,他的热情就降了一大半的人,请感谢他。因为他让你少 浪费了一些时间在他身上。
  • 从那些实实在在做事、patch、论坛帮忙解答问题的朋友中挑选你认为合适的人选作为团队成员。 做实事,实际就是在做核心团队、开发团队、整个团队做的事情。

反馈

<<PageComment2(commentonly=1)>>

OpenSourceProjectManage (last edited 2009-12-25 07:12:49 by localhost)