Skip to content

Commit

Permalink
deploy: 943821b
Browse files Browse the repository at this point in the history
  • Loading branch information
QubitPi committed Jul 17, 2024
1 parent d70f27d commit 0695b60
Show file tree
Hide file tree
Showing 44 changed files with 119 additions and 27 deletions.
Binary file added _astro/cover.Db2-k7rf_1AKSQx.webp
Binary file not shown.
2 changes: 1 addition & 1 deletion about/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/category/Examples/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/category/Guides/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/category/Leadership/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/category/Management/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/category/uncategorized/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Blogging/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Customization/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Demo/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Employees/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Example/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Fuwari/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Leadership/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Management/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Markdown/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Technologies/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion archive/tag/Video/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion index.html

Large diffs are not rendered by default.

Binary file added pagefind/fragment/en_24c8cd8.pf_fragment
Binary file not shown.
Binary file not shown.
Binary file removed pagefind/fragment/en_6130c35.pf_fragment
Binary file not shown.
Binary file added pagefind/fragment/en_6bb533e.pf_fragment
Binary file not shown.
Binary file removed pagefind/fragment/en_729897c.pf_fragment
Binary file not shown.
Binary file removed pagefind/fragment/en_814f186.pf_fragment
Binary file not shown.
Binary file added pagefind/fragment/en_a22ecd3.pf_fragment
Binary file not shown.
Binary file added pagefind/fragment/en_dbcf116.pf_fragment
Binary file not shown.
Binary file added pagefind/fragment/en_dc581f5.pf_fragment
Binary file not shown.
Binary file removed pagefind/fragment/en_e88bace.pf_fragment
Binary file not shown.
Binary file removed pagefind/index/en_6e53113.pf_index
Binary file not shown.
Binary file added pagefind/index/en_794ae1d.pf_index
Binary file not shown.
2 changes: 1 addition & 1 deletion pagefind/pagefind-entry.json
Original file line number Diff line number Diff line change
@@ -1 +1 @@
{"version":"1.1.0","languages":{"en":{"hash":"en_2ccda49ca0","wasm":"en","page_count":7}}}
{"version":"1.1.0","languages":{"en":{"hash":"en_d6cb97a599","wasm":"en","page_count":8}}}
Binary file removed pagefind/pagefind.en_2ccda49ca0.pf_meta
Binary file not shown.
Binary file added pagefind/pagefind.en_d6cb97a599.pf_meta
Binary file not shown.
2 changes: 1 addition & 1 deletion posts/develop-and-retain-high-performers/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion posts/guide/index.html

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions posts/managing-tech-assets-common-lib-or-not/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion posts/markdown-extended/index.html

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion posts/markdown/index.html

Large diffs are not rendered by default.

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion posts/video/index.html

Large diffs are not rendered by default.

91 changes: 91 additions & 0 deletions rss.xml
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,97 @@ draft: false
├── cover.png
└── index.md
</code></pre>
</content:encoded></item><item><title>Managing Tech Assets - Is a Common Library a Good Idea? No</title><link>https://leadership.qubitpi.org/posts/managing-tech-assets-common-lib-or-not/</link><guid isPermaLink="true">https://leadership.qubitpi.org/posts/managing-tech-assets-common-lib-or-not/</guid><description>Managing Tech Assets - Is a Common Library a Good Idea? No</description><pubDate>Wed, 17 Jul 2024 00:00:00 GMT</pubDate><content:encoded>&lt;h2&gt;A Story - A Person Created a Common Library and Then...&lt;/h2&gt;
&lt;p&gt;&quot;Embarrassingly I introduced a &quot;common&quot; library, named as such, in a team environment a couple of decades back.
I didn&apos;t really understand the dynamics back then of what could happen in a loosely-coordinated team setting in just a
matter of months.&lt;/p&gt;
&lt;p&gt;When I introduced it I thought I made it clear and also documented that it&apos;s for things we&apos;d all agree we find useful on
a daily basis, that it&apos;s intended to be a minimalist library, and that the library should depend on nothing else besides
the standard library so that it&apos;s as easy to deploy as possible in new projects. My thinking at the time was that it was
our own little extension to the standard library for things that, in our particular domain, we found useful on a daily
basis.&lt;/p&gt;
&lt;p&gt;And it started off well enough. We started off with a math library (&lt;code&gt;common/math*&lt;/code&gt;) of routines which we all used on a
daily basis, since we were working on computer graphics which was often heavy on the linear algebra. And since we were
often interoping with C code, we agreed on some useful utility functions like find_index which, unlike std::find in C++,
would return an index to an element found in a sequence instead of an iterator which mimicked how our C functions worked
-- things of this sort -- a little bit eclectic but minimalist and widely used enough to remain familiar and practical
to everyone, and instant familiarity is an extremely important criteria as I see it in trying to make anything that is
&quot;common&quot; or &quot;standard&quot; since if it truly is &quot;common&quot;, it should have that familiar quality about it as a result of its
wide adoption and daily usage.&lt;/p&gt;
&lt;p&gt;But over time the design intentions of the library slipped out of my fingers as people started to add things they used
personally that they merely thought might be of use to someone else, only to find no one else using it. And later
someone started adding functions that depended on OpenGL for common GL-related routines. Further on we adopted Qt and
people started adding code that depended on Qt, so already the common library was dependent on two external libraries.
At some point someone added common shader routines which was dependent on our application-specific shader library, and
at that point you couldn&apos;t even deploy it in a new project without bringing in Qt, OGL, and our application-specific
shader library and writing a non-trivial build script for your project. So it turned into this eclectic, interdependent
mess. Later on people even added GUI-dependent code to it.&lt;/p&gt;
&lt;p&gt;But I&apos;ve also found by debating what should and shouldn&apos;t go into this library that what is considered &quot;common&quot; can
easily turn into a very subjective idea if you don&apos;t set a very hard line rule that what&apos;s &quot;common&quot; is what everyone
tends to find useful on a daily basis. Any loosening of the standards and it quickly degrades from things everyone finds
useful on a daily basis to something a single developer finds useful that might have the possibility of being beneficial
to someone else, and at that point the library degrades into an eclectic mess really fast.&lt;/p&gt;
&lt;p&gt;But furthermore when you reach that point, some developers can start adding things for the simple reason that they don&apos;t
like the programming language. They might not like the syntax of a for loop or a function call, at which point the
library is starting to get filled with things that&apos;s just fighting the fundamental syntax of the language, replacing a
couple of lines of straightforward code which isn&apos;t really duplicating any logic down to a single terse line of exotic
code only familiar to the developer who introduced such a shorthand. Then such a developer might start adding more
functionality to the common library implemented using such shorthands, at which point significant sections of the common
library become interwoven with these exotic shorthands which might seem beautiful and intuitive to the developer who
introduced it but ugly and foreign and hard to understand for everyone else. And at that point I think you know that any
hope of making something truly &quot;common&quot; is lost, since &quot;common&quot; and &quot;unfamiliar&quot; are polar opposite ideas.&lt;/p&gt;
&lt;p&gt;So there&apos;s all kinds of cans of worms there, at least in a loosely-coordinated team environment, with a library with
ambitions as broad and as generalized as just &quot;commonly-used stuff&quot;. And while the underlying problem might have been
the loose coordination above all else, at least multiple libraries intended to serve a more singular purpose, like a
library intended to provide math routines and nothing else, probably wouldn&apos;t degrade as significantly in terms of its
design purity and dependencies as a &quot;common&quot; library. So in retrospect I think it would be much better to err on the
side of libraries which have much more clear design intentions. I&apos;ve also found over the years that narrow in purpose
and narrow in applicability are radically different ideas. Often the most widely applicable things are the narrowest and
most singular in purpose, since you can then say, &quot;aha, this is exactly what I need&quot;, as opposed to wading through an
eclectic library of disparate functionality trying to see if it has something you need.&lt;/p&gt;
&lt;p&gt;Also I&apos;m admittedly at least a little bit impractical and care maybe a bit too much about aesthetics, but the way I tend
to perceive my idea of a library&apos;s quality (and maybe even &quot;beauty&quot;) is judged more by its weakest link than its
strongest, in a similar way that if you presented me the most appetitizing food in the world but, on the same plate, put
something rotting on there that smells really bad, I tend to want to reject the entire plate. And if you&apos;re like me in
that regard and make something that invites all sorts of additions as something called &quot;common&quot;, you might find yourself
looking at that analogical plate with something rotting on the side. So likewise I think it&apos;s good if a library is
organized and named and documented in a way such that it doesn&apos;t invite more and more and more additions over time. And
that can even apply to your personal creations, since I&apos;ve certainly created some rotten stuff here and there, and it
&quot;taints&quot; a lot less if it&apos;s not being added to the biggest plate. Separating things out into small, very singular
libraries has a tendency to better decouple code as well, if only by the sheer virtue that it becomes far less
convenient to start coupling everything.&lt;/p&gt;
&lt;p&gt;:::tip
Code deduplication has been hammered into me over the years but I feel like I should try it this time around.
:::&lt;/p&gt;
&lt;p&gt;What I might suggest in your case is to start to take it easy on code deduplication. I&apos;m not saying to copy and paste
big snippets of poorly-tested, error-prone code around or anything of this sort, or duplicating huge amounts of
non-trivial code that has a decent probability of requiring changes in the future.&lt;/p&gt;
&lt;p&gt;But especially if you are of the mindset to create a &quot;common&quot; library, for which I assume your desire is to create
something widely-applicable, highly reusable, and perhaps ideally something you find just as useful today as you do a
decade from now, then sometimes you might even need or want some duplication to achieve this elusive quality. Because
the duplication might actually serve as a decoupling mechanism. It&apos;s like if you want to separate a video player from an
MP3 player, then you at least have to duplicate some things like batteries and hard drives. They can&apos;t share these
things or else they&apos;re indivisibly coupled and cannot be used independently of each other, and at that point people
might not be interested in the device anymore if all they want to do is play MP3s. But some time after you split these
two devices apart, you might find that the MP3 player can benefit from a different battery design or smaller hard drive
than the video player, at which point you&apos;re no longer duplicating anything; what initially started out as duplication
to allow this interdependent device to split into two separate, independent devices might later turn out to yield
designs and implementations that are no longer redundant at all.&lt;/p&gt;
&lt;p&gt;It&apos;s worth considering things from the perspective of the one using a library. Would you actually want to use a library
that minimizes code duplication? Chances are that you won&apos;t because one that does will naturally depend on other
libraries. And those other libraries might depend on other libraries to avoid duplicating their code, and so on, until
you might need to import/link 50 different libraries to just to get some basic functionality like loading and playing an
audio file, and that becomes very unwieldy. Meanwhile if such an audio library deliberately chose to duplicate some
things here and there to achieve its independence, it becomes so much easier to use in new projects, and chances are
that it won&apos;t need to be updated nearly as often since it won&apos;t need to change as a result of one its dependent external
libraries changing which might be trying to fulfill a much more generalized purpose than what the audio library needs.&lt;/p&gt;
&lt;p&gt;So sometimes it&apos;s worth deliberately choosing to duplicate a little bit (consciously, never out of laziness -- actually
out of diligence) in order to decouple a library and make it independent because, through that independence, it achieves
a wider range of practical applicability and even stability (no more afferent couplings). If you want to design the most
reusable libraries possible that will last you from one project to the next and over the years, then on top of narrowing
its scope to the minimum, I would actually suggest considering duplicating a little bit here. And naturally write unit
tests and make sure it&apos;s really thoroughly tested and reliable at what it&apos;s doing. This is only for the libraries that
you really want to take the time to generalize to a point that goes far beyond a single project.&quot;&lt;/p&gt;
</content:encoded></item><item><title>Markdown Extended Features</title><link>https://leadership.qubitpi.org/posts/markdown-extended/</link><guid isPermaLink="true">https://leadership.qubitpi.org/posts/markdown-extended/</guid><description>Read more about Markdown features in Fuwari</description><pubDate>Wed, 01 May 2024 00:00:00 GMT</pubDate><content:encoded>&lt;h2&gt;GitHub repository cards&lt;/h2&gt;
&lt;p&gt;You can add dynamic cards that link to GitHub repositories, on page load, the repository information is pulled from the GitHub API.&lt;/p&gt;
&lt;p&gt;::github{repo=&quot;Fabrizz/MMM-OnSpotify&quot;}&lt;/p&gt;
Expand Down
2 changes: 1 addition & 1 deletion sitemap-0.xml
Original file line number Diff line number Diff line change
@@ -1 +1 @@
<?xml version="1.0" encoding="UTF-8"?><urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:news="http://www.google.com/schemas/sitemap-news/0.9" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:image="http://www.google.com/schemas/sitemap-image/1.1" xmlns:video="http://www.google.com/schemas/sitemap-video/1.1"><url><loc>https://leadership.qubitpi.org/</loc></url><url><loc>https://leadership.qubitpi.org/about/</loc></url><url><loc>https://leadership.qubitpi.org/archive/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Examples/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Guides/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Leadership/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Management/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/uncategorized/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Blogging/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Customization/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Demo/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Employees/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Example/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Fuwari/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Leadership/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Management/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Markdown/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Technologies/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Video/</loc></url><url><loc>https://leadership.qubitpi.org/posts/develop-and-retain-high-performers/</loc></url><url><loc>https://leadership.qubitpi.org/posts/guide/</loc></url><url><loc>https://leadership.qubitpi.org/posts/markdown-extended/</loc></url><url><loc>https://leadership.qubitpi.org/posts/markdown/</loc></url><url><loc>https://leadership.qubitpi.org/posts/strategies-to-help-employees-adapt-to-new-technology/</loc></url><url><loc>https://leadership.qubitpi.org/posts/video/</loc></url></urlset>
<?xml version="1.0" encoding="UTF-8"?><urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:news="http://www.google.com/schemas/sitemap-news/0.9" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:image="http://www.google.com/schemas/sitemap-image/1.1" xmlns:video="http://www.google.com/schemas/sitemap-video/1.1"><url><loc>https://leadership.qubitpi.org/</loc></url><url><loc>https://leadership.qubitpi.org/about/</loc></url><url><loc>https://leadership.qubitpi.org/archive/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Examples/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Guides/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Leadership/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/Management/</loc></url><url><loc>https://leadership.qubitpi.org/archive/category/uncategorized/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Blogging/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Customization/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Demo/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Employees/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Example/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Fuwari/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Leadership/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Management/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Markdown/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Technologies/</loc></url><url><loc>https://leadership.qubitpi.org/archive/tag/Video/</loc></url><url><loc>https://leadership.qubitpi.org/posts/develop-and-retain-high-performers/</loc></url><url><loc>https://leadership.qubitpi.org/posts/guide/</loc></url><url><loc>https://leadership.qubitpi.org/posts/managing-tech-assets-common-lib-or-not/</loc></url><url><loc>https://leadership.qubitpi.org/posts/markdown-extended/</loc></url><url><loc>https://leadership.qubitpi.org/posts/markdown/</loc></url><url><loc>https://leadership.qubitpi.org/posts/strategies-to-help-employees-adapt-to-new-technology/</loc></url><url><loc>https://leadership.qubitpi.org/posts/video/</loc></url></urlset>

0 comments on commit 0695b60

Please sign in to comment.