A place to cache linked articles (think custom and personal wayback machine)
Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

index.html 8.4KB

4 anos atrás
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <!doctype html><!-- This is a valid HTML5 document. -->
  2. <!-- Screen readers, SEO, extensions and so on. -->
  3. <html lang="fr">
  4. <!-- Has to be within the first 1024 bytes, hence before the <title>
  5. See: https://www.w3.org/TR/2012/CR-html5-20121217/document-metadata.html#charset -->
  6. <meta charset="utf-8">
  7. <!-- Why no `X-UA-Compatible` meta: https://stackoverflow.com/a/6771584 -->
  8. <!-- The viewport meta is quite crowded and we are responsible for that.
  9. See: https://codepen.io/tigt/post/meta-viewport-for-2015 -->
  10. <meta name="viewport" content="width=device-width,initial-scale=1">
  11. <!-- Required to make a valid HTML5 document. -->
  12. <title>Ned Batchelder: 2500 (archive) — David Larlet</title>
  13. <!-- That good ol' feed, subscribe :). -->
  14. <link rel="alternate" type="application/atom+xml" title="Feed" href="/david/log/">
  15. <!-- Generated from https://realfavicongenerator.net/ such a mess. -->
  16. <link rel="apple-touch-icon" sizes="180x180" href="/static/david/icons2/apple-touch-icon.png">
  17. <link rel="icon" type="image/png" sizes="32x32" href="/static/david/icons2/favicon-32x32.png">
  18. <link rel="icon" type="image/png" sizes="16x16" href="/static/david/icons2/favicon-16x16.png">
  19. <link rel="manifest" href="/static/david/icons2/site.webmanifest">
  20. <link rel="mask-icon" href="/static/david/icons2/safari-pinned-tab.svg" color="#07486c">
  21. <link rel="shortcut icon" href="/static/david/icons2/favicon.ico">
  22. <meta name="msapplication-TileColor" content="#f0f0ea">
  23. <meta name="msapplication-config" content="/static/david/icons2/browserconfig.xml">
  24. <meta name="theme-color" content="#f0f0ea">
  25. <!-- Documented, feel free to shoot an email. -->
  26. <link rel="stylesheet" href="/static/david/css/style_2020-06-19.css">
  27. <!-- See https://www.zachleat.com/web/comprehensive-webfonts/ for the trade-off. -->
  28. <link rel="preload" href="/static/david/css/fonts/triplicate_t4_poly_regular.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)" crossorigin>
  29. <link rel="preload" href="/static/david/css/fonts/triplicate_t4_poly_bold.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)" crossorigin>
  30. <link rel="preload" href="/static/david/css/fonts/triplicate_t4_poly_italic.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)" crossorigin>
  31. <link rel="preload" href="/static/david/css/fonts/triplicate_t3_regular.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: dark)" crossorigin>
  32. <link rel="preload" href="/static/david/css/fonts/triplicate_t3_bold.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: dark)" crossorigin>
  33. <link rel="preload" href="/static/david/css/fonts/triplicate_t3_italic.woff2" as="font" type="font/woff2" media="(prefers-color-scheme: dark)" crossorigin>
  34. <script type="text/javascript">
  35. function toggleTheme(themeName) {
  36. document.documentElement.classList.toggle(
  37. 'forced-dark',
  38. themeName === 'dark'
  39. )
  40. document.documentElement.classList.toggle(
  41. 'forced-light',
  42. themeName === 'light'
  43. )
  44. }
  45. const selectedTheme = localStorage.getItem('theme')
  46. if (selectedTheme !== 'undefined') {
  47. toggleTheme(selectedTheme)
  48. }
  49. </script>
  50. <meta name="robots" content="noindex, nofollow">
  51. <meta content="origin-when-cross-origin" name="referrer">
  52. <!-- Canonical URL for SEO purposes -->
  53. <link rel="canonical" href="https://nedbatchelder.com//blog/202006/2500.html">
  54. <body class="remarkdown h1-underline h2-underline h3-underline hr-center ul-star pre-tick">
  55. <article>
  56. <h1>Ned Batchelder: 2500</h1>
  57. <nav>
  58. <p class="center">
  59. <a href="/david/" title="Aller à l’accueil" tabindex="1">🏠</a>
  60. </p>
  61. </nav>
  62. <hr>
  63. <h2><a href="https://nedbatchelder.com//blog/202006/2500.html">Source originale du contenu</a></h2>
  64. <p>This is the 2500th post on this blog. That&#8217;s a lot of writing. I estimate
  65. this site has about 480,000 words in total, enough for five books.</p>
  66. <p>I&#8217;ve been writing here for more than 18 years. The pace is different than
  67. when I started: last year I wrote <a href="//nedbatchelder.com/blog/archive/year2019.html">33
  68. posts</a>. Compare that to 2003, when I wrote more than ten times as many:
  69. <a href="//nedbatchelder.com/blog/archive/year2003.html">441 posts</a>!
  70. <a href="https://twitter.com/nedbat" rel="external noopener">Twitter</a> has siphoned off some of the
  71. short-post energy, but also interests shift over time.</p>
  72. <p>Writing is a good way to understand things, and to learn things. People
  73. mostly think of writing as a way to teach and explain, and I am glad when my
  74. posts can do that. But I also really value the feedback loop of learning as I
  75. explain, and the deeper understanding I find when I teach.</p>
  76. <p>Here&#8217;s a common piece of advice from people who create things: to make better
  77. things, make more things. Not only does it give you constant practice at making
  78. things, but it gives you more chances at lucking into making a good thing.</p>
  79. <p>These days I set myself a goal of writing two posts a month. I find the goal
  80. helpful. It prods me to dig for topics. Some will be duds, but sometimes an
  81. apparently boring idea will turn out well.</p>
  82. <p>I can&#8217;t promise everything (or anything!) will be interesting or insightful.
  83. But I&#8217;ll keep writing here. Thanks for reading.</p>
  84. </article>
  85. <hr>
  86. <footer>
  87. <p>
  88. <a href="/david/" title="Aller à l’accueil">🏠</a> •
  89. <a href="/david/log/" title="Accès au flux RSS">🤖</a> •
  90. <a href="http://larlet.com" title="Go to my English profile" data-instant>🇨🇦</a> •
  91. <a href="mailto:david%40larlet.fr" title="Envoyer un courriel">📮</a> •
  92. <abbr title="Hébergeur : Alwaysdata, 62 rue Tiquetonne 75002 Paris, +33184162340">🧚</abbr>
  93. </p>
  94. <template id="theme-selector">
  95. <form>
  96. <fieldset>
  97. <legend>Thème</legend>
  98. <label>
  99. <input type="radio" value="auto" name="chosen-color-scheme" checked> Auto
  100. </label>
  101. <label>
  102. <input type="radio" value="dark" name="chosen-color-scheme"> Foncé
  103. </label>
  104. <label>
  105. <input type="radio" value="light" name="chosen-color-scheme"> Clair
  106. </label>
  107. </fieldset>
  108. </form>
  109. </template>
  110. </footer>
  111. <script type="text/javascript">
  112. function loadThemeForm(templateName) {
  113. const themeSelectorTemplate = document.querySelector(templateName)
  114. const form = themeSelectorTemplate.content.firstElementChild
  115. themeSelectorTemplate.replaceWith(form)
  116. form.addEventListener('change', (e) => {
  117. const chosenColorScheme = e.target.value
  118. localStorage.setItem('theme', chosenColorScheme)
  119. toggleTheme(chosenColorScheme)
  120. })
  121. const selectedTheme = localStorage.getItem('theme')
  122. if (selectedTheme && selectedTheme !== 'undefined') {
  123. form.querySelector(`[value="${selectedTheme}"]`).checked = true
  124. }
  125. }
  126. const prefersColorSchemeDark = '(prefers-color-scheme: dark)'
  127. window.addEventListener('load', () => {
  128. let hasDarkRules = false
  129. for (const styleSheet of Array.from(document.styleSheets)) {
  130. let mediaRules = []
  131. for (const cssRule of styleSheet.cssRules) {
  132. if (cssRule.type !== CSSRule.MEDIA_RULE) {
  133. continue
  134. }
  135. // WARNING: Safari does not have/supports `conditionText`.
  136. if (cssRule.conditionText) {
  137. if (cssRule.conditionText !== prefersColorSchemeDark) {
  138. continue
  139. }
  140. } else {
  141. if (cssRule.cssText.startsWith(prefersColorSchemeDark)) {
  142. continue
  143. }
  144. }
  145. mediaRules = mediaRules.concat(Array.from(cssRule.cssRules))
  146. }
  147. // WARNING: do not try to insert a Rule to a styleSheet you are
  148. // currently iterating on, otherwise the browser will be stuck
  149. // in a infinite loop…
  150. for (const mediaRule of mediaRules) {
  151. styleSheet.insertRule(mediaRule.cssText)
  152. hasDarkRules = true
  153. }
  154. }
  155. if (hasDarkRules) {
  156. loadThemeForm('#theme-selector')
  157. }
  158. })
  159. </script>
  160. </body>
  161. </html>