<?xml version="1.0" encoding="utf-8"?>
<rss version="2.0" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" xmlns:content="http://purl.org/rss/1.0/modules/content/">

<channel>
<pubDate>Sun, 07 Dec 2025 14:19:47 GMT</pubDate>
<title>Alexander Gromnitsky&#39;s Blog</title>
<description>Пограмування, ойті, витяги, цитати</description>
<link>https://sigwait.org/~alex/blog</link>
<language>en</language>
<itunes:image href="https://sigwait.org/~alex/blog/itunes.png"/>
<itunes:explicit>false</itunes:explicit>

  <itunes:category text="Drama" />


<itunes:author>ag</itunes:author>



<item>
  <title>Obfuscating Image Links</title>
  <link>https://sigwait.org/~alex/blog/2025/12/07/qYkza8.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/12/07/qYkza8.html</guid>
  <pubDate>Sun, 07 Dec 2025 14:19:47 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>ойті</category>
  
  <description><![CDATA[<p>I noticed this recently, though it started happening about a year ago.
On some websites (archive.org's bookreader), a normal <code>&lt;img&gt;</code> tag
suddenly began to look like some insane MS Internet Explorer extension
from 1998:</p>
<pre><code>&lt;img src="blob:https://example.com/b501e863-fe43-4b63-ae5d-dac14cac097e"&gt;
</code></pre>
<p>The web page that contains it renders the image fine, but when a
fairly naïve user posts that link into a chat, it results in
nothing: the blob referenced by <code>&lt;img&gt;</code> exists only in the memory of a
specific browser instance, &amp; the server will return 404 for
any <code>https://example.com/UUID</code>.</p>
<p>Why do they do this? Every <em>n</em> years some people get scared of
hotlinking (<em>bastards keep stealing our traffic</em>), AI luddites try to
ruin business of evil corporations, &amp; fans of toy-level DRM amuse
themselves with a new scheme.</p>
<p>If you look at the <code>fetch</code>-requests of such a page, you'll see
resources that look like images but actually aren't:</p>
<pre>$ url='<a href="https://ia800206.us.archive.org/BookReader/BookReaderPreview.php?id=parkinsonlaw00park&amp;subPrefix=parkinsonlaw00park&amp;itemPath=/31/items/parkinsonlaw00park&amp;server=ia800206.us.archive.org&amp;page=leaf8&amp;scale=1">https://ia800206.us.archive.org/🙈.jpg</a>'

$ curl -sI "$url" | grep -e type -e length -e obfuscate
content-type: image/jpeg
content-length: 267470
x-obfuscate: 1|uoEV6/PZOWtGhOZdVM898w==

$ curl -s "$url" | head -c25 | file -
/dev/stdin: data
</pre>

<p>Such a .jpg is encrypted. Part of the key is in the <code>X-Obfuscate</code>
header, but neither a random AI scraper nor any social network knows
about this. The cipher is also not disclosed, &amp; every website may use
any scheme it wants: following any recommendations would defeat the
entire purpose of obfuscation.</p>
<p>The image-rendering algorithm then becomes:</p>
<ol>
<li><p>download the encrypted file;</p>
</li>
<li><p>decrypt it using the key from the corresponding header &amp; push the
result into a blob;</p>
</li>
<li><p>create a link to the blob using <code>URL.createObjectURL</code> function;</p>
</li>
<li><p>inject into the DOM an <code>img</code> element whose <em>src</em> attribute is equal
to the newly created link.</p>
</li>
</ol>
<p>We can increase entropy further by <a href="https://sigwait.org/~alex/demo/misc/img-blob/">writing our own custom element</a>:</p>
<pre><code>&lt;img-blob alt="a fluffy cat" src="cat.bin"&gt;&lt;/img-blob&gt;
</code></pre>
<p>that will do all of the above on its own. (I <em>terser</em>'ed the source
code of the example for I absolutely don't want you to use it in
anything serious: the entire approach is extremely user-hostile &amp;
anti-web.)</p>
<p>For efficiency, archive.org AES-CTR-encrypts only the first 1024 bytes
of the image. Browsers know about AES but strictly require a secure
context that can be annoying during testing; hence, for mickey mouse
DRM we can simply use XOR-encryption.</p>
<p>The <code>X-Obfuscate</code> header itself can be obfuscated even more, e.g.:</p>
<pre><code>x-obfuscate: rlW2MKWmnJ9hVwbtZFjtVzgyrFV6VPVkZwZ0AFW9Pt==
</code></pre>
<p>looks like a base64 string, but:</p>
<pre><code>$ echo rlW2MKWmnJ9hVwbtZFjtVzgyrFV6VPVkZwZ0AFW9Pt== | base64 -d | xxd
base64: invalid input
00000000: ae55 b630 a5a6 9c9f 6157 06ed 6458 ed57  .U.0....aW..dX.W
00000010: 3832 ac55 7a54 f564 6706 7400 55bd 3e    82.UzT.dg.t.U.&gt;
</code></pre>
<p>I checked if DeepSeek could figure it out: it spent 9 minutes &amp; left
2 villages in Zhejiang province without water, was several times
very close to the target, but ultimately failed.</p>
<p>The string had been post-processed with rot13:</p>
<pre><code>$ alias rot13="tr 'A-Za-z' 'N-ZA-Mn-za-m'"
$ echo rlW2MKWmnJ9hVwbtZFjtVzgyrFV6VPVkZwZ0AFW9Pt== | rot13 | base64 -d
{"version": 1, "key": "12345"}
</code></pre>
<p>As homework, you can add an equivalent of <code>loading="lazy"</code> to the
custom element using the Intersection Observer API.</p>
]]></description>
  
</item>

<item>
  <title>Offline Math: Converting LaTeX to SVG with MathJax</title>
  <link>https://sigwait.org/~alex/blog/2025/10/07/3t8acq.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/10/07/3t8acq.html</guid>
  <pubDate>Wed, 08 Oct 2025 14:10:31 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>ойті</category>
  
  <description><![CDATA[<p>Pandoc can <em>prepare</em> LaTeX math for MathJax via its eponymous
<code>--mathjax</code> option. It wraps formulas in <code>&lt;span class="math"&gt;</code>
elements and injects a <code>&lt;script&gt;</code> tag that points to
<em>cdn.jsdelivr.net</em>, which means rendering won't work offline or in
case of the 3rd-party server failure. You can mitigate this by
providing your own copy of the MathJax library, but the mechanism
still fails when the target device doesn't support JavaScript (e.g.,
many epub readers).</p>
<p>At the same time, practically all browsers support MathML. Use it
(pandoc's <code>--mathml</code> option), if you care only about the information
superhighway: your formulas will look good on every modern device and
scale delightfully. Otherwise, SVGs are the only truly portable
option.</p>
<p>Now, how can we transform the html produced by</p>
<pre><code>$ echo 'Ohm'\''s law: $I = \frac{V}{R}$.' |
  pandoc -s -f markdown --mathjax
</code></pre>
<p>into a fully standalone document where the formula gets converted into
SVG nodes?</p>
<ol>
<li>Use an html parser like Nokogiri, and replace each <code>&lt;span class="math"&gt;</code> node with an image. There are multiple ways to
convert a TeX-looking string to an SVG: using MathJax itself (which
provides a <a href="https://github.com/mathjax/MathJax-demos-node/blob/master/mjs/simple/tex2svg">corresponding CLI example</a>), or by doing it in a
'classical' fashion with pdflatex. (You can read more about this
method in <a href="https://sigwait.org/~alex/p/pg2e/"><em>A practical guide to EPUB</em></a>, chapters 3.4 and 4.6.)</li>
</ol>
<ol start="2">
<li>Alternatively, load the page into a headless browser, inject
MathJax scripts, and serialise the modified DOM back to html.</li>
</ol>
<p>I tried the 2nd approach in 2016 with the now-defunct phantomjs.  It
worked, but debugging was far from enjoyable due to the strangest bugs
in phantomjs. I can still run the old code, but it depends on an
ancient version of the MathJax library that, for obvious reasons,
isn't easily upgradable within the phantomjs pre-es6 environment.</p>
<p>Nowadays, Puppeteer would certainly do, but for this kind of task
I prefer something more lightweight.</p>
<p>There's also jsdom. Back in 2016, I tried it as well, but it was much
slower than running phantomjs. Recently, I gave jsdom another try and
was pleasantly surprised. I'm not sure what exactly tipped the scales:
computers, v8, or jsdom itself, but it no longer feels slow in
combination with MathJax.</p>
<pre><code>$ wc -l *js *conf.json
  24 loader.js
 105 mathjax-embed.js
  12 mathjax.conf.json
 141 total
</code></pre>
<p>Roughly 50% of the code is nodejs infrastructure junk (including CL
parsing), the rest is a MathJax config and jsdom interactions:</p>
<pre><code>let dom = new JSDOM(html, {
  url: `file://${base}/`,
  runScripts: /* very */ 'dangerously',
  resources: new MyResourceLoader(), // block ext. absolute urls
})

dom.window.my_exit = function() {
  cleanup(dom.window.document) // remove mathjax &lt;script&gt; tags
  console.log(dom.serialize())
}

dom.window.my_mathjax_conf = mathjax_conf // user-provided

let script = new Script(read(`${import.meta.dirname}/loader.js`))
let vmContext = dom.getInternalVMContext()
script.runInContext(vmContext)
</code></pre>
<p>The most annoying step here is setting <code>url</code> property that jsdom uses
to resolve paths to relative resources. <code>my_exit()</code> function is called
by MathJax when its job is supposedly finished. <code>loader.js</code> script is
executed in the context of the loaded html:</p>
<pre><code>window.MathJax = {
  output: { fontPath: '@mathjax/%%FONT%%-font' },
  startup: {
    ready() {
      MathJax.startup.defaultReady()
      MathJax.startup.promise.then(window.my_exit)
    }
  }
}

Object.assign(window.MathJax, window.my_mathjax_conf)

function main() {
  var script = document.createElement('script')
  script.src = 'mathjax/startup.js'
  document.head.appendChild(script)
}

document.addEventListener('DOMContentLoaded', main)
</code></pre>
<p>The full source is on <a href="https://github.com/gromnitsky/mathjax-embed">Github</a>.</p>
<p>Intended use is as follows:</p>
<pre><code>$ echo 'Ohm'\''s law: $I = \frac{V}{R}$.' |
  pandoc -s -f markdown --mathjax |
  mathjax-embed &gt; 1.html
</code></pre>
<p>The resulting html doesn't use JavaScript and doesn't fetch any
external MathJax resources. <code>mathjax-embed</code> script itself always works
offline.</p>
]]></description>
  
</item>

<item>
  <title>The Size of Adobe Reader Installers Through The Years</title>
  <link>https://sigwait.org/~alex/blog/2025/08/25/zw6z4E.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/08/25/zw6z4E.html</guid>
  <pubDate>Tue, 26 Aug 2025 01:33:40 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>ойті</category>
  
  <description><![CDATA[<p>At the time of writing, the most recent Adobe Reader 25.x.y.z 64-bit
installer for Windows 11 weights <strong>687,230,424 bytes</strong>. After
installation, the program includes 'AI' (of course), an auto-updater,
sprinkled ads for <em>Acrobat online services</em> everywhere, and 2 GUIs:
'new' and 'old'.</p>
<p>For comparison, the size of SumatraPDF-3.5.2 installer is 8,246,744
bytes. It has no 'AI', no auto-updater (though it can check for new
versions, which I find unnecessary, for anyone sane would install it
via scoop anyway), and no ads for 'cloud storage'.</p>
<p>The following chart shows how the Adobe Reader installer has grown in
size over the years. When possible, 64-bit versions of installers were
used.</p>
<img style="width: 100%" src="https://sigwait.org/~alex/blog/2025/08/25/adobe_reader-vs-sumatrapdf.svg" alt="adobe reader vs sumatrapdf">

<p><strong>Next Day Update:</strong></p>
<p>Best comment on Hacker News: <em>"Looks like a chart crime scene."</em></p>
<p>Alright, here's your linear graph, along with <a href="https://sigwait.org/~alex/blog/2025/08/25/installers.tar">the
source</a> from which both graphs were generated. All
point labels are version numbers.</p>
<img style="width: 100%" src="https://sigwait.org/~alex/blog/2025/08/25/adobe_reader-vs-sumatrapdf.linear.svg" alt="adobe reader vs sumatrapdf (linear scale)">
]]></description>
  
</item>

<item>
  <title>Not a bug</title>
  <link>https://sigwait.org/~alex/blog/2025/08/15/9pQ3o1.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/08/15/9pQ3o1.html</guid>
  <pubDate>Mon, 25 Aug 2025 08:39:06 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>ойті</category>
  
  <description><![CDATA[<p>Peter Weinberger (the "w" in awk), while working at Bell Labs,
wrote an experimental
implementation of a network file system. Included with Research Unix
v8 (Feb 1985, licensed strictly for educational use), it allowed to
share / (yes) with other machines running v8 by specifying a mapping
between a local uid/gui and the desired view from the LAN.</p>
<p>Weinberger described peculiarities of his <em>netfs</em> as</p>
<blockquote>
<p>"If A mounted B's file system somewhere, and B mounted A's, then the
directory tree was infinite. That's mathematics, not a bug."</p>
</blockquote>
<p>His /usr/src/netfs/TODO contained an existential question:</p>
<blockquote>
<p>'why does it get out of synch?'</p>
</blockquote>
<p>The connection of this <em>netfs</em> and Sun's NFS is murky.</p>
<p>Steve Johnson:</p>
<blockquote>
<p>"I remember Bill Joy visiting Bell Labs and getting a very complete
demo of RFS and being very impressed.  Within a year, Sun announced
NFS."</p>
</blockquote>
<p>Unix System V SVR3, released by AT&amp;T in 1987, included a different
version of <em>netfs</em>, which they officially began calling RFS. Appearing
18 months after Sun announced NFS, it briefly attempted to compete,
but failed on 2 fronts simultaneously: ⓐ big vendors (Dec, IBM, HP)
disliked its licensing terms, and ⓑ the protocol's brittleness
discouraged ports to non-Unix systems. NFS won, becoming widely
used--even by NeXTSTEP.</p>
<p>Lyndon Nerenberg:</p>
<blockquote>
<p>'We ran RFS on a "cluster" of four 3B2s [AT&amp;T microcomputers], and
while it worked, to varying degrees, the statefulness of the
protocol inevitably led to the whole thing locking up, requiring a
reboot of all four machines to recover.'</p>
</blockquote>
]]></description>
  
</item>

<item>
  <title>Batocera 35 and Vontar X3</title>
  <link>https://sigwait.org/~alex/blog/2025/07/06/Gih6An.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/07/06/Gih6An.html</guid>
  <pubDate>Mon, 07 Jul 2025 13:32:04 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>untagged</category>
  
  <description><![CDATA[<p>In the dining room there is an old (2013) 1080p telly with an old (2020)
Android TV box connected to it. The TV box contains an ancient
<a href="https://www.cnx-software.com/2019/04/12/amlogic-s905x3-specifications-block-diagram/">Amlogic S905X3</a> SoC inside. It has just enough power to play
Youtube &amp; 1080p movies from a network drive but not much else.</p>
<p>Some time ago I heard about repurposing this particular model (Vontar
X3) as a retro-gaming console, but anticipating battles similar to
those with openwrt-on-outers--where 2 devices with the exact same name
have slightly different hardware revisions (&amp; as a result, nothing
works as expected)--I've been putting off the adventure.</p>
<p>The easiest Linux gaming distro to deploy is a French one called
Batocera.<a class="footnote" href="#Gih6An-1"><sup>1</sup></a> Its
wiki describes perfomance of a particular device in terms of console
generation support:</p>
<table>
<thead>
<tr>
<th>Gén</th>
<th>Consoles</th>
</tr>
</thead>
<tbody><tr>
<td>3</td>
<td>NES</td>
</tr>
<tr>
<td>4</td>
<td>SNES, Sega Mega Drive</td>
</tr>
<tr>
<td>5</td>
<td>PlayStation (psx), PlayStation Portable (psp)</td>
</tr>
</tbody></table>
<p>(I've skipped the irrelevant generations.)</p>
<p>In my tests, while the modest S905X3 runs most psx &amp; psp games
acceptably, some titles have such a perceived frame drop (that do not
occur on a desktop PC running the same emulator as Batocera) that it
makes them unplayable. The prominent unsuccessful examples are <em>CTR:
Crash Team Racing</em> (psx) and <em>MotorStorm: Arctic Edge</em> (psp).</p>
<p>The last Batocera version for the Vontar X3 is 35 (the OS images for
this device haven't been updated since '22). I dd'ed
<a href="https://mirrors.o2switch.fr/batocera/tvbox-gen3/stable/35/">batocera-s905gen3-tvbox-gen3-35-20220910.img</a> onto a 32GB SD card,
inserted the card into the TV box, pressed its reset button with a
toothpick, plugged in the power cable, &amp; saw this:</p>
<p><video preload="metadata" controls="" src="https://sigwait.org/~alex/blog/2025/07/06/interlaced.mp4"></video></p>
<p>The TV's info popups indicated that the resolution of this shaky image
was 1080i (interlaced?) instead of the expected 1080p. I then tried 2
completely different (albeit much newer) TVs, as well as a capture
card--none of them had any problems negotiating a proper resolution
with Batocera.</p>
<p>After pointlessly suffering with various kernel parameters, I ended up
with the following kludge to disable the interlaced mode:</p>
<ol>
<li><p>Connect the device to your LAN via the ethernet port. Batocera runs
Avahi, hence we can just say</p>
<pre><code> $ ssh root@batocera.local
</code></pre>
<p>(The password is 'linux'.)</p>
</li>
<li><p>Run</p>
<pre><code> # batocera-resolution listModes | head -10
 max-1920x1080:maximum 1920x1080
 max-640x480:maximum 640x480
 0.0.1920x1080.60:HDMIA 1920x1080 60Hz (1920x1080i)
 0.1.1920x1080.60:HDMIA 1920x1080 60Hz (1920x1080)
 0.2.1920x1080.60:HDMIA 1920x1080 60Hz (1920x1080)
 0.3.1920x1080.60:HDMIA 1920x1080 60Hz (1920x1080i)
 0.4.1920x1080.50:HDMIA 1920x1080 50Hz (1920x1080)
 0.5.1920x1080.50:HDMIA 1920x1080 50Hz (1920x1080i)
 0.6.1920x1080.24:HDMIA 1920x1080 24Hz (1920x1080)
 0.7.1920x1080.24:HDMIA 1920x1080 24Hz (1920x1080)
</code></pre>
<p> inside Batocera. Take a note of a mode you'd like to see.</p>
</li>
<li><p>Turn the device off. Extract the SD card out of it &amp; insert it into
a PC. The card has 2 partition: the 1st one is fat32 that has
<code>batocera-boot.conf</code> file. Add a line to it:</p>
<pre><code> es.resolution=0.1.1920x1080.60
</code></pre>
</li>
</ol>
<p>The picture will still incessantly jerk from left to right, but only
during the boot phase:</p>
<p><video preload="metadata" controls="" src="https://sigwait.org/~alex/blog/2025/07/06/fixed.mp4"></video></p>
<pre><code># batocera-info
Disk format: ext4
Temperature: 66°C
Architecture: tvbox-gen3
Model: Shenzhen Haochuangyi Technology Co., Ltd H96 Max
System: Linux 5.10.134
Available memory: 624/932 MB
Cpu model: ARMv8 Processor rev 0 (v8l)
Cpu number: 4
Cpu max frequency: 1908 MHz
</code></pre>
<p>There is little to add here. You copy your .nes/.sfc/.chd/.iso files
to <code>/userdata/roms/{nes,snes,psx,psp}</code> either directly onto the 2nd
partition of the SD card, or via ssh, or even smb, for Batocera runs
Samba.</p>
<hr>

<ol>

<li id="Gih6An-1">I couldn't find any guidance on how to pronouce it:
there is a type of beetles called /bə'tosərə/, but some youtubers say
it as /bαto'sɛrα/.</li>

</ol>
]]></description>
  
</item>

<item>
  <title>Sea-sickness</title>
  <link>https://sigwait.org/~alex/blog/2025/05/19/lzBnKb.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/05/19/lzBnKb.html</guid>
  <pubDate>Mon, 19 May 2025 18:45:46 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>quote</category>
  
    <category>usa</category>
  
  <description><![CDATA[<blockquote>
<p>'[1852] In the regiment there was a Lieutenant Slaughter who was
very liable to sea-sickness. It almost made him sick to see the wave
of a table-cloth when the servants were spreading it.</p>
<p>'Soon after his graduation, Slaughter was ordered to California and
took passage by a sailing vessel going around Cape Horn. The vessel
was seven months making the voyage, and Slaughter was sick every
moment of the time, never more so than while lying at anchor after
reaching his place of destination.</p>
<p>'On landing in California he found orders which had come by the
Isthmus, notifying him of a mistake in his assignment; he should
have been ordered to the northern lakes. He started back by the
Isthmus route and was sick all the way. But when he arrived at the
East he was again ordered to California, this time definitely, and
at this date was making his third trip. He was as sick as ever, and
had been so for more than a month while lying at anchor in the bay.</p>
<p>'I remember him well, seated with his elbows on the table in front
of him, his chin between his hands, and looking the picture of
despair. At last he broke out, "I wish I had taken my father's
advice; he wanted me to go into the navy; if I had done so, I should
not have had to go to sea so much." Poor Slaughter! it was his last
sea voyage. He was killed by Indians in Oregon.'</p>
</blockquote>
<p>(From <em>Personal Memoirs of U.S. Grant</em>, Ch. XIV by Ulysses S. Grant.)</p>
]]></description>
  
</item>

<item>
  <title>Escape sequences in file names</title>
  <link>https://sigwait.org/~alex/blog/2025/03/30/B8povK.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/03/30/B8povK.html</guid>
  <pubDate>Sun, 30 Mar 2025 14:58:10 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>ойті</category>
  
  <description><![CDATA[<p>How to annoy folks who use busybox:</p>
<pre>$ touch `printf "\033[1;33m\033[44mhello"`
$ ls
''$'\033''[1;33m'$'\033''[44mhello'
$ tar cf 1.tar *hello
$ busybox tar tf 1.tar
<b style="background: blue; color: yellow">hello
$ rpm -q busybox
busybox-1.36.1-8.fc41.x86_64
$&nbsp;<span style="background: #ee0000">&nbsp;</span></b>
</pre>

<p>Oopsie-daisy.</p>
<p>A simple <code>ls|cat</code> or <code>ls|less -r</code> produces the same effect.</p>
<p>This won't work with gnu tar &amp; bsdtar, for they both properly escape
escape sequences.</p>
]]></description>
  
</item>

<item>
  <title>Marc Rochkind on managers vs. programmers</title>
  <link>https://sigwait.org/~alex/blog/2025/03/27/Gt8LUg.html</link>
  <guid>https://sigwait.org/~alex/blog/2025/03/27/Gt8LUg.html</guid>
  <pubDate>Thu, 27 Mar 2025 19:06:09 GMT</pubDate>
  
    <author>alexander.gromnitsky@gmail.com (ag)</author>
  
  
    <category>quote</category>
  
  <description><![CDATA[<p>This is the guy who wrote <a href="https://en.wikipedia.org/wiki/Source_Code_Control_System">SCCS</a> while working at Bell Labs.</p>
<pre><code>Date: Wed, 3 Jul 2024 17:29:26 -0600
From: Marc Rochkind &lt;mrochkind@gmail.com&gt;
Newsgroups: gmane.org.unix-heritage.general
Subject: Re: Anyone ever heard of teaching a case study of Initial Unix?
Message-ID: &lt;CAOkr1zXSefHKOqTCaGE7Zb_T09HD-s2pM9QfTW8PuMkLGioDGg@mail.gmail.com&gt;

On Wed, Jul 3, 2024 at 9:27 AM Vincenzo Nicosia wrote:
&gt; The programmers considered as "fungible workforce" by mainstream
&gt; software engineering and project management theories are *paid* to
&gt; to their programming job, and they mostly have to carry that job
&gt; over working on prescribed objectives and timelines which have been
&gt; decided by somebody else, managers who know nothing at all about
&gt; software development. Personal interest in the project, passion,
&gt; motivation, curiosity, creative power, sense of beauty, the joy of
&gt; belonging to a community of likeminded people, are never part of the
&gt; equation, at any point.

What a cynical take on software development! The logical error is to
assume that if something is sometimes true (e.g., "managers who know
nothing at all about software development") then it is always true.

My experience over many decades is quite different. Most often,
managers know software quite well. Where they fail is in their very
poor understanding of how to manage people.

The bias that operates in software development, and perhaps all
organizations, is that when there is a disagreement between management
and non-management (e.g., programmers), the non-managers usually
assume that they are always right and the managers are wrong.

I have never met a programmer or group of programmers who were always
right. Most often, they are ignorant of financing, regulatory
constraints, product schedules, commitments, staffing issues, and
everything else that isn't coding. (There are exceptions, but they are
uncommon.) Management, by definition, is the art and science of using
resources to reach an objective. Programmers generally are concerned
only with themselves as a resource and with their own personal
programming objective. It is unusual to find a programmer who
understands management.
</code></pre>
]]></description>
  
</item>


</channel>
</rss>