-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathblog-dx.html
32 lines (32 loc) · 2.31 KB
/
blog-dx.html
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
31
32
<link href="styles.css" rel="stylesheet"/>
<h2>DX (dev experience)</h2>
<hr/>
<p><strong>What is DX?</strong></p>
<p>'DX' means 'dev experience'.</p>
<p><strong>Why coin a neologism?</strong></p>
<p>Developers lack a succinct way to characterize a software library's ease of use. The closest thing I've seen is <a href="https://rubyonrails.org/doctrine/">'programmer happiness'</a>. 'Ergonomics' also works, although 4 syllables makes it unlikely to catch on. </p>
<p><strong>Is this like UX (user experience)?</strong></p>
<p>Yes.</p>
<p><strong>Why should I care about DX?</strong></p>
<p>For the same reasons you care about UX: if your project is unpleasant to use, other developers won't use it.</p>
<p><strong>How to have good DX?</strong></p>
<p>Use 'immediate files'.</p>
<p><strong>What are immediate files?</strong></p>
<blockquote>
<p>If you’re browsing a directory full of source code, it’s useful to see the documentation or build script that “kicks off” the entire project. This is why <a href="https://the.exa.website">exa</a> calls them <a href="https://the.exa.website/features/colours">immediate files</a> — they’re meant to be the first file you read or run. </p>
</blockquote>
<p><strong>What files are immediate files?</strong></p>
<p><a href="https://github.com/ogham/exa/blob/4c73a3353025f09410301af5d7e8c8b738db92a5/src/info/filetype.rs#L22">Examples include</a>:</p>
<ul>
<li><code>README.md</code></li>
<li><code>Makefile</code></li>
<li>language-specific files like <code>build.gradle</code> or <code>Rakefile</code></li>
</ul>
<p><strong>What information should immediate files provide?</strong></p>
<blockquote>
<p><a href="https://news.ycombinator.com/item?id=20910538">Examples. Realistic, complete, useful examples</a> that demonstrate the software being used in the manner it is intended.</p>
<p>Glossary for any special terminology that can't just be googled - especially project specific terminology that may be confusing, and double especially terms or phrases which are used slightly differently to the way everybody else uses them (e.g. 'user' means something slightly different almost everywhere).</p>
<p>Lots of "why" describing why the software behaves in ways that seem surprising at first glance.</p>
</blockquote>
<p><strong>Do immediate files have a tradeoff?</strong></p>
<p>Yes; they have to be maintained.</p>