Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756390AbcLNPdF (ORCPT ); Wed, 14 Dec 2016 10:33:05 -0500 Received: from mail-io0-f194.google.com ([209.85.223.194]:35253 "EHLO mail-io0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756136AbcLNPcz (ORCPT ); Wed, 14 Dec 2016 10:32:55 -0500 MIME-Version: 1.0 From: Alexey Dobriyan Date: Wed, 14 Dec 2016 18:32:35 +0300 Message-ID: Subject: Moratorium on coding style patches (was Re: [PATCH] include/linux/kernel.h: fixed coding style issues) To: piotrgregor@rsyncme.org Cc: Linus Torvalds , Linux Kernel Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2987 Lines: 69 OK, someone needs to say it. These type of patches are advertised by some people as a good way to enter Linux kernel development. You know, to learn how the process works, how to setup email client pipeline, to get initial feedback. And it is true. What those people aren't saying is that the above is about ~0.01% of what is kernel or any other project development is about. It is the easy part. But the patches also create problems for those who are already in. The very immediate is that "git-blame" stops working. It simply points to the irrelevant commit and developer is forced to either search manually through the history or search the web for "git-blame" options. (maybe there is such an option but that's not the point). And "git-blame" usually happens in important cases: when developer searches for a possible bugfix or wondering who wrote that crap. Au contraire, coding style patch is something unimportant. Whitespace here, whitespace there, who cares. On the grand scale, coding style compliance is important but in my experience Linux kernel CS compliance is top notch for the project of Linux's size. So the tradeoff is not in the patch favour and all you need to follow coding style is basically "indent -kr -i8 -l80" for new code. It is then becomes non problem because editors defaults are doing the job. And they create rejects against other non-coding style patches, again slowing down people who need to fix real problems. Then there is whole big "newbie" angle. My first patches were sent to kernel-janitors@ list which was setup exactly for newbies. Then I agreed to become its maintainer and then (what a shame) silently killed it by doing nothing. But it was not a concious decision. Frankly I do not remember _exactly_ what happened. Then SWsoft hired me to do kernel work (hi, Kirill and Pavel! and Den!) In the first month I learned more about kernel internals than in the previous years of self tinkering. Hey, I didn't know about ctags (or never botherd to find out). More importantly I learned which bugs and problems actually happen to users (or rather customers, commercial Linux doesn't have users, only customers :-) and which exist only in my head. So my advise to Piotr. I can't find your name or email in the changelogs. It looks like this is your first patch, my apologies if it is not. Find and fix a bug. It may be hard to find a bug for a newcomer, there is relaxed version: if your patch doesn't change generated code, then don't send it. Simply don't do it. You'll send them but later when you learn how the kernel works and what is important and what is not. Kernel will not collapse because whitespace is a bit off. But it will collapse if people would only fix coding style. So you need to grow as a kernel developer, and the sooner you start, the sooner you'll be there. ---------------------------------------------------------------------- Said that, I call for a tree wide moratorium on pure coding style changes.