commit d55d731007b7adbe18e2742c1f20518bb06165e0
parent 845c063cf6d0370bc53b0182d234e4f7a32c796f
Author: phoebos <ben@bvnf.space>
Date: Fri, 30 Jun 2023 03:51:06 +0100
blog: new post
Diffstat:
3 files changed, 99 insertions(+), 0 deletions(-)
diff --git a/blog/009-fulldeps.html b/blog/009-fulldeps.html
@@ -0,0 +1,99 @@
+<!DOCTYPE html>
+<html>
+<head>
+ <meta charset="utf-8"/>
+ <meta name="viewport" content="width=device-width, initial-scale=1"/>
+ <title>bliss-fulldepends</title>
+ <link rel="icon" href=""/>
+ <style type="text/css">
+ body {font-family: sans-serif; padding: 2ch; margin: auto; max-width: 50em; color:black; background: #fff;}
+ pre { margin: 0; padding: 1ch;}
+ h1 { font-size: 1.4em;}
+ </style>
+</head>
+<body>
+<h1>bliss-fulldepends</h1>
+
+<p>I've been writing <a href="//git.bvnf.space/bliss/">an implementation of kiss
+ in Lua</a>, called bliss, and I just finished a <code>pkg.order</code>
+function, which performs a topological sort to order packages so that
+dependencies are built first. This function can also be used to get the full,
+recursive dependency list of a package, which I think is sort of interesting, so
+I wrote <a href="http://git.bvnf.space/bliss/file/contrib/bliss-fulldepends.html">a quick script</a>.</p>
+
+<details>
+ <summary>View the code</summary>
+<pre><code>#!/usr/bin/env lua
+-- Display all dependencies of packages (recursively)
+local bliss = require "bliss"
+local dirent = require "posix.dirent"
+
+local function lists(env, arg)
+ if #arg == 0 then
+ for file in dirent.files(env.sys_db) do
+ if string.sub(file, 1, 1) ~= "." then
+ table.insert(arg, {file, #bliss.order(env, {file})})
+ end
+ end
+ table.sort(arg, function (a,b) return a[2]<b[2] end)
+ for _,v in ipairs(arg) do print(v[1],v[2]) end
+ else
+ local deps = bliss.order(env, {arg[1]})
+ for _,v in ipairs(deps) do print(v) end
+ end
+end
+
+if arg[1] == "-h" then
+ print("usage: "..arg[0].." [pkg]")
+ print(" With no args, list installed packages by total number of dependencies")
+ print(" With an arg, list full dependencies of pkg")
+ os.exit()
+end
+
+local env, atexit = bliss.setup()
+table.insert(env.PATH, 1, env.sys_db)
+
+lists(env, arg)</pre></code></details>
+
+<p>Here's what you can do with it.</p>
+
+<ul>
+<li>List all your installed packages by number of total dependencies:
+<pre><code>$ bliss-fulldepends
+scheme-manpages 1
+libogg 1
+...
+zathura-pdf-poppler 91
+firefox 102</pre></code>
+</li>
+
+<li>List the total dependencies for a package (topologically sorted):
+<pre><code>$ bliss-fulldepends kiss
+certs
+zlib
+openssl
+curl
+git
+b3sum
+kiss</pre></code>
+i.e. kiss depends on b3sum and git; git depends on curl, and so on.
+</li>
+</ul>
+
+<p>And no, it's not horribly slow: for my system, the former takes <code>150ms</code> and the latter <code>6ms</code>.
+The listing of all packages could be sped up by caching the dependency lists rather than walking through them all again for each package installed,
+but it's fast enough for me.</p>
+
+<p>Here's a bar chart of number of total dependencies on my system:
+<figure><img src="/media/bar.png" alt="bar chart" height="480px"/></figure>
+And here is a histogram of the same information, showing how many just have 1 "dependency" (themselves).
+<figure><img src="/media/hist.png" alt="histogram of the same data" height="480px"/></figure>
+</p>
+
+<hr />
+<p>written 2023-06-30</p>
+
+<p><a href="../">Home</a></p>
+<p><a href="./">Blog home</a></p>
+</body>
+</html>
diff --git a/media/bar.png b/media/bar.png
Binary files differ.
diff --git a/media/hist.png b/media/hist.png
Binary files differ.