These general principles apply to all platforms, all programming languages and all data formats, unless explicitly stated otherwise. (Rationale for some decisions is in parenthesis, like this.)
UNIX-style, ie ASCII LF (0x0A).
A newline must be the last things to appear in a text file. (By definition, a text file ends with a line. And by definition, a line ends with a newline. Possible exception: empty files.)
/, \ and other OS-sensitive characters.like-in-this-example.all-DNS-servers.cfg, David-expenses-2014/..jpeg instead of .jpg, .tar.bz2 instead of .tbz2.canvas-controller.OLD.js is a deprecated version of that JS controller.portrait-thumbnail.BACKUP.jpeg is a temporary backup of an image..htaccess.DISABLED is a file that we don’t want the system to use right now.Using spaces. 4 spaces.
Avoid \t altogether (it messes up with indentation if the length of tab isn’t predictable, eg when printing on a terminal).
Align stuff vertically in columns when it improves readability and gives structure to the content, as long as it doesn’t look awkward.
Maximum line length: 160 visible characters. (It’s exactly double of what we used to have on old, physical consoles. It’s an even number. It’s divisible by 5, and by 10. In fact, it’s divisible by 32, which is a nice power of 2. That makes it convenient to divide the width of lines in equal columns. It also seems a reasonable compromise for the IT infrastructure we use nowadays.)
Insert a blank line wherever it make sense to separate logical blocks.
Although I’d prefer to have a blank line at the beginning and end of files for clarity also, I have found this to be one of most contingent aspects in coding
style.
My blank lines at the beginning and at the end of files have been “corrected” or at least questioned multiple times in different projects.
So to avoid discussions about that in the future, I’m not doing that any more (those lines are useful to signal boundaries when multiple files are being
catted on a console, for example).
Avoid two or more consecutive blank lines. (They don’t add information, much in the same way than two or more spaces between words don’t add more meaning to that word separation. If “two blank lines” is intended to mean something different from “only one blank line”, that difference should be clear; often it’s not. Consecutive blank lines are too verbose; waste screen real estate. Consecutive blank lines are difficult to spot, and difficult to count, for the naked eye.)
When possible, use Markdown. When using Markdown, opt for CommonMark.
When writing natural language in a context where newlines don’t matter, eg Markdown, break the line every time a new sentence begins. (It improves readability of the source code; ideas are clearly separated in different lines. It also has the added benefit that sentences that are maybe too long stick out from the rest.)
Exploit the richness of Unicode: don’t settle for 3x4... 12 OK when you can do 3×4… 12 ✓.
When writing natural language (a Markdown document, a comment in a source file), always end sentences with a full stop. Exceptions are: headings; and chunks of code were a colon at the end might induce confusion or constitute a syntax error. (Full stops help detect broken lines or missing copy that might have been removed inadvertently; they also make sentences easier to parse automatically.)