惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

F
Fox-IT International blog
Recent Announcements
Recent Announcements
D
Docker
IT之家
IT之家
B
Blog
Jina AI
Jina AI
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
博客园 - 【当耐特】
Google DeepMind News
Google DeepMind News
F
Fortinet All Blogs
量子位
C
Check Point Blog
Microsoft Azure Blog
Microsoft Azure Blog
罗磊的独立博客
博客园 - 司徒正美
李成银的技术随笔
美团技术团队
Blog — PlanetScale
Blog — PlanetScale
雷峰网
雷峰网
The GitHub Blog
The GitHub Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
J
Java Code Geeks
T
The Blog of Author Tim Ferriss
酷 壳 – CoolShell
酷 壳 – CoolShell
MongoDB | Blog
MongoDB | Blog
P
Proofpoint News Feed
L
LangChain Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
Y
Y Combinator Blog
大猫的无限游戏
大猫的无限游戏
有赞技术团队
有赞技术团队
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
V
Visual Studio Blog
T
Tailwind CSS Blog
H
Help Net Security
Engineering at Meta
Engineering at Meta
小众软件
小众软件
B
Blog RSS Feed
Stack Overflow Blog
Stack Overflow Blog
月光博客
月光博客
M
Microsoft Research Blog - Microsoft Research
宝玉的分享
宝玉的分享
人人都是产品经理
人人都是产品经理
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
GbyAI
GbyAI
H
Hackread – Cybersecurity News, Data Breaches, AI and More
Last Week in AI
Last Week in AI
Martin Fowler
Martin Fowler
Stack Overflow Blog
Stack Overflow Blog

Secret Weblog

Becoming More Xee: A Modern XPath and XSLT Engine in Rust Looking for new challenges! Repeat Yourself, A Bit The Curious Case of Quentell The Humble For Loop in Rust The Humble For Loop in JavaScript Don't Look Down on Print Debugging Question Best Practices I Was a 1980s Teenage Programmer Part 5: Achieving Assembly I Was a 1980s Teenage Programmer Part 4: The Call of Assembly The Tooling Shift I Was a 1980s Teenage Programmer Part 3: MSX-2 JavaScript: when you need two ways to do it! Empowering Programming Languages Bloat and Retrofuturism Refreshing my Blog Again Random Rust Impressions Apilar: An Alife System I Was a 1980s Teenage Programmer Part 2: Olivetti M24 I Was a 1980s Teenage Programmer: the Alphatronic SolidJS fits my brain Is premature optimization the root of all evil? Framework Patterns: JavaScript edition Roll Your Own Frameworks Looking for new challenges Framework Patterns Secret Weblog Highlights Refactoring to Multiple Exit Points mstform: a form library for mobx-state-tree Seven Years: A Very Personal History of the Web Looking for new challenges Morepath 0.16 released! Is Morepath Fast Yet? Introducing Bob Strongpinion Punctuated Equilibrium in Software Morepath 0.15 released! Impressions of React Europe 2016 Morepath 0.14 released! Morepath 0.13 now with Dectate Dectate: advanced configuration for Python code JavaScript Dependencies Revisited: An Example Project The Incredible Drifting Cyber A Brief History of Reselect The Emerging GraphQL Python stack Thoughts about React Europe Build a better batching UI with Morepath and Jinja2 GraphQL and REST Server Templating in Morepath 0.10 10 reasons to check out the Morepath web framework in 2015 A Review of the Web and how Morepath fits in Morepath 0.9 released! Better REST with Morepath 0.8 Morepath 0.7: new inter-app linking They say something I don't like so they must be lying! Life at the Boundaries: Conversion and Validation BowerStatic 0.4 released! Morepath 0.6 released! Morepath 0.5(.1) and friends released! New HTTP 1.1 RFCs versus WSGI Against On Naming In Open Source My visit to EuroPython 2014 Morepath 0.4.1 released (with Python 3 fixes) Morepath 0.4 and breaking changes Announcing BowerStatic Morepath 0.3 released! Morepath 0.2 Morepath Python 3 support The Call of Python 2.8 Morepath 0.1 released! WebOb and Werkzeug compared Morepath: from Werkzeug to WebOb Racing the Morepath: SQLAlchemy Integration The Centre Cannot Hold Breaking Morepath Changes Morepath Update How to do REST with Morepath Morepath Security the Gravity of Python 2 #python2.8 discussion channel on freenode Alex Gaynor on Python 3 Morepath Documentation Starting to Take Shape Back to the Center Morepath App Reuse Implementing Grok Grok: the Idea Why Linux Works for Me On the Morepath Reg, Now With More Generic! The New Zope as a Web Framework Jim Fulton, Zope Architect Renewing Zope Object Publishing The Weirdness of Zope The Rise of Zope My Exit from Zope Reg: Component Architecture Reimagined JSConf EU 2013 impressions Obviel 1.0!
Titus Brown on the importance of communication
Martijn Faassen · 2009-12-19 · via Secret Weblog

I just read an insightful article by Titus Brown about the importance of communication in a team project, in the context of open source projects. It is a very good articulation of a topic I've thought about a lot myself as well.

When helping to manage Zope's participation in the Google Summer of Code I recognized the problems that Titus is talking about. One thing I told students in advance is simply to make noise

I've indeed seen some students, but not all, pop up on various Zope related mailing lists. Others have been more quiet. I'd prefer to hear some noise from you guys. Noise (if at least somewhat on-topic) is good for open source communities.

Noise is also good for you, as if you're noisy, people will get to know you and might actually start listening to some of your ideas. Don't be afraid to make noise. I've made an idiot and a nuisance of myself (on occasion, not all the time I hope!) in the permanent record for years and people still seem to listen to me.

That did have a positive effect. Still, the next year I started to explicitly require all participating students to give regular updates, just like what Titus is planning.

Without regular updates, it's far too easy for time (days, weeks, months) to pass by without obvious progress. Sometimes that is because the progress is hidden. Sometimes that is because the progress itself is in fact lacking: nobody knows you're blocked if you don't tell people about it.

Unfortunately even with those guidelines in place, it turns out to be difficult to make people communicate... Requiring regular reports helped me catch some potential problems early, but even raising my problem didn't always help to make the problem actually go away...

In part that's probably due to shyness or lack of confidence on the part of these people. When you communicate a lot, you may in fact end up saying things that aren't too smart once every while, and people probably worry overly much about that. Feedback can help you learn, and can only get feedback if people know you're there in the first place.

In part it's just due to differences in personality: not everybody communicates in the same way. That's fine - there are many ways to make a positive contribution, as long as you show what you're up to.

Sometimes too there is too much chatter and you just want to hunker down and get work done without distractions. It's just important to remember to resurface once every while.

On the other hand, communication can also be a great way to keep yourself motivated and productive. Sometimes it is quite comfortable to let time go by and slack off, and then it is nice nobody worries about your progress...

I'll just quoting myself again about noise (through Reinout):

I’m a natural noise-maker, and I discovered that while as a result of this I embarrass myself in public on a regular basis, it also means a lot of people know who I am. That’s a good thing.

And this, which I cannot even remember saying (through Michael Hudson):

faassen: anyway, if nothing else flapping your arms running around
will at least give an impression of activity. :)

Since this is a somewhat self-absorbed post anyway, quoting myself and all that, let me finish with a story about my early involvement in the Python community that I think is relevant to this discussion.

The comp.lang.python newsgroup when I joined it sometime in late 1998 was a small and friendly place. Thinking back it seems I spent most of my time posting very silly posts about the Python Secret Underground (PSU), an organization about which, naturally, I cannot say anything more. It was a lot of fun but perhaps not the most constructive contribution to the Python community.

I first went to an international Python conference in in the US in the year 2000. It didn't seem odd to me then, but afterwards I realized that many people there who I had never met before knew who I was. I also knew who many of them were. I think the silly interactions about the PSU that I was involved in on comp.lang.python explain a lot of that. It was completely unintentional, but today I still benefit from the connections I made then.

So, contribute to an open source community! Communicate! Communicate by creating code, writing documentation, or perhaps just by making people chuckle. Communication makes you more engaged in the project, and more motivated to contribute, and more creative and productive as a result. You may also be pleasantly surprised by the feedback.