1 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns=
"http://www.w3.org/1999/xhtml" dir=
"ltr">
5 <meta http-equiv=
"Content-Type" content=
"text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen
</title>
7 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"https://people.skolelinux.org/pere/blog/style.css" />
8 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"https://people.skolelinux.org/pere/blog/vim.css" />
9 <link rel=
"alternate" title=
"RSS Feed" href=
"https://people.skolelinux.org/pere/blog/index.rss" type=
"application/rss+xml" />
14 <a href=
"https://people.skolelinux.org/pere/blog/">Petter Reinholdtsen
</a>
23 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/Test_framework_for_DocBook_processors___formatters.html">Test framework for DocBook processors / formatters
</a></div>
24 <div class=
"date"> 5th November
2023</div>
25 <div class=
"body"><p>All the books I have published so far has been using
26 <a href=
"https://docbook.org/">DocBook
</a> somewhere in the process.
27 For the first book, the source format was DocBook, while for every
28 later book it was an intermediate format used as the stepping stone to
29 be able to present the same manuscript in several formats, on paper,
30 as ebook in ePub format, as a HTML page and as a PDF file either for
31 paper production or for Internet consumption. This is made possible
32 with a wide variety of free software tools with DocBook support in
33 Debian. The source format of later books have been docx via rst,
34 Markdown, Filemaker and Asciidoc, and for all of these I was able to
35 generate a suitable DocBook file for further processing using pandoc,
36 a2x and asciidoctor, as well as rendering using
37 <a href=
"https://tracker.debian.org/pkg/xmlto">xmlto
</a>,
38 <a href=
"https://tracker.debian.org/pkg/dbtoepub">dbtoepub
</a>,
39 <a href=
"https://tracker.debian.org/pkg/dblatex">dblatex
</a>,
40 <a href=
"https://tracker.debian.org/pkg/dblatex">docbook-xsl
</a> and
41 <a href=
"https://tracker.debian.org/pkg/fop">fop
</a>.
</p>
43 <p>Most of the books I have published are translated books, with
44 English as the source language. The use of
45 <a href=
"https://tracker.debian.org/pkg/po4a">po4a
</a> to
46 handle translations using the gettext PO format has been a blessing,
47 but publishing translated books had triggered the need to ensure the
48 DocBook tools handle relevant languages correctly. For every new
49 language I have published, I had to submit patches dblatex, dbtoepub
50 and docbook-xsl fixing incorrect language and country specific issues
51 in the framework themselves. Typically this has been missing keywords
52 like 'figure' or sort ordering of index entries. After a while it
53 became tiresome to only discover issues like this by accident, and I
54 decided to write a DocBook "test framework" exercising various
55 features of DocBook and allowing me to see all features exercised for
56 a given language. It consist of a set of DocBook files, a version
4
57 book, a version
5 book, a v4 book set, a v4 selection of problematic
58 tables, one v4 testing sidefloat and finally one v4 testing a book of
59 articles. The DocBook files are accompanied with a set of build rules
60 for building PDF using dblatex and docbook-xsl/fop, HTML using xmlto
61 or docbook-xsl and epub using dbtoepub. The result is a set of files
62 visualizing footnotes, indexes, table of content list, figures,
63 formulas and other DocBook features, allowing for a quick review on
64 the completeness of the given locale settings. To build with a
65 different language setting, all one need to do is edit the lang= value
66 in the .xml file to pick a different ISO
639 code value and run
69 <p>The
<a href=
"https://codeberg.org/pere/docbook-example/">test framework
70 source code
</a> is available from Codeberg, and a generated set of
71 presentations of the various examples is available as Codeberg static
73 <a href=
"https://pere.codeberg.page/docbook-example/">https://pere.codeberg.page/docbook-example/
</a>.
74 Using this test framework I have been able to discover and report
75 several bugs and missing features in various tools, and got a lot of
76 them fixed. For example I got Northern Sami keywoards added to both
77 docbook-xsl and dblatex, fixed several typos in Norwegian bokmål and
78 Norwegian Nynorsk, support for non-ascii title IDs added to pandoc,
79 Norwegian index sorting support fixed in xindy and initial Norwegian
80 Bokmål support added to dblatex. Some issues still remains, though.
81 Default index sorting rules are still broken in several tools, so the
82 Norwegian letters æ, ø and å are more often than not sorted properly
83 in the book index.
</p>
85 <p>The test framework recently received some more polish, as part of
86 publishing my latest book. This book contained a lot of fairly
87 complex tables, which exposed bugs in some of the tools. This made me
88 add a new test file with various tables, as well as spend some time to
89 brush up the build rules. My goal is for the test framework to
90 exercise all DocBook features to make it easier to see which features
91 work with different processors, and hopefully get them all to support
92 the full set of DocBook features. Feel free to send patches to extend
93 the test set, and test it with your favorite DocBook processor.
94 Please visit these two URLs to learn more:
</p>
97 <li><a href=
"https://codeberg.org/pere/docbook-example/">https://codeberg.org/pere/docbook-example/
</a></li>
98 <li><a href=
"https://pere.codeberg.page/docbook-example/">https://pere.codeberg.page/docbook-example/
</a></li>
101 <p>If you want to learn more on Docbook and translations, I recommend
102 having a look at the
<a href=
"https://docbook.org/">the DocBook
104 <a href=
"https://doccookbook.sourceforge.net/html/en/">the DoCookBook
105 site
<a/> and my earlier blog post on
106 <a href=
"https://people.skolelinux.org/pere/blog/From_English_wiki_to_translated_PDF_and_epub_via_Docbook.html">how
107 the Skolelinux project process and translate documentation
</a>.
</p>
111 https://github.com/docbook/xslt10-stylesheets/issues/205 (docbook-xsl: sme support)
112 https://bugs.debian.org/968437 (xindy: index sorting rules for nb/nn)
113 https://bugs.debian.org/856123 (pandoc: markdown to docbook with non-english titles)
114 https://bugs.debian.org/864813 (dblatex: missing nb words)
115 https://bugs.debian.org/756386 (dblatex: index sorting rules for nb/nn)
116 https://bugs.debian.org/796871 (dbtoepub: index sorting rules for nb/nn)
117 https://bugs.debian.org/792616 (dblatex: PDF metadata)
118 https://bugs.debian.org/686908 (docbook-xsl: index sorting rules for nb/nn)
119 https://sourceforge.net/tracker/?func=detail&atid=373747&aid=3556630&group_id=21935 (docbook-xsl: nb/nn support)
120 https://bugs.debian.org/684391 (dblatex: initial nb support)
124 <p>As usual, if you use Bitcoin and want to show your support of my
125 activities, please send Bitcoin donations to my address
126 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
131 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/docbook">docbook
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>.
136 <div class=
"padding"></div>
139 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/_Virkninger_av_angrefristloven___hovedfagsoppgaven_som_fikk_endret_en_lov.html">«Virkninger av angrefristloven», hovedfagsoppgaven som fikk endret en lov
</a></div>
140 <div class=
"date">29th October
2023</div>
141 <div class=
"body"><img src=
"http://people.skolelinux.org/pere/blog/images/2023-10-29-bok-angrefrist.svg" width=
"20%" align=
"center"></a>
143 <p>I
1979 leverte Ole-Erik Yrvin en hovedfagsoppgave for Cand. Scient.
144 ved Institutt for sosiologi på Universitetet i Oslo på oppdrag fra
145 Forbruker- og administrasjonsdepartementet. Oppgaven evaluerte
146 Angrefristloven fra
1972, og det han oppdaget førte til at loven ble
147 endret fire år senere.
</p>
149 <p>Jeg har kjent Ole-Erik en stund, og synes det var trist at hans
150 oppgave ikke lenger er tilgjengelig, hverken fra oppdragsgiver
151 eller fra universitetet. Hans forsøk på å få den avbildet og lagt
152 ut på Internett har vist seg fånyttes, så derfor tilbød jeg meg for
153 en stund tilbake å publisere den og gjøre den tilgjengelig med
154 fribruksvilkår på Internett. Det er nå klart, og hovedfagsoppgaven
155 er tilgjengelig blant annet via
<a
156 href=
"http://www.hungry.com/~pere/publisher/">min liste over
157 publiserte bøker
</a>, både som nettside,
158 <a href=
"https://www.lulu.com/search?contributor=Ole-Erik+Yrvin">digital
159 bok i ePub-format og på papir fra lulu.com
</a>. Jeg regner med at
160 den også vil dukke opp på nettbokhandlere i løpet av en måned eller
163 <p>Alle tabeller og figurer er gjenskapt for bedre lesbarhet, noen
164 skrivefeil rettet opp og mange referanser har fått flere detaljer
165 som ISBN-nummer og DOI-referanse. Selv om jeg ikke regner med at
166 dette blir en kioskvelter, så håper jeg denne nye utgaven kan komme
167 fremtiden til glede.
</p>
169 <p>Som vanlig, hvis du bruker Bitcoin og ønsker å vise din støtte til
170 det jeg driver med, setter jeg pris på om du sender Bitcoin-donasjoner
172 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>. Merk,
173 betaling med bitcoin er ikke anonymt. :)
</p>
178 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/docbook">docbook
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/norsk">norsk
</a>.
183 <div class=
"padding"></div>
186 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/_underordnet_tjenestemann_blir_inhabil_fordi_en_overordnet_er_inhabil__.html">«underordnet tjenestemann blir inhabil fordi en overordnet er inhabil».
</a></div>
187 <div class=
"date"> 7th September
2023</div>
188 <div class=
"body"><p>Medlemmene av Norges regjering har demonstert de siste månedene at
189 habilitetsvureringer ikke er deres sterke side og det gjelder både
190 Arbeiderpartiets og Senterpartiers representater. Det er heldigvis
191 enklere i det private, da inhabilitetsreglene kun gjelder de som
192 jobber for folket, ikke seg selv. Sist ut er utenriksminister
193 Huitfeldt. I går kom nyheten om at
194 <a href=
"https://www.nrk.no/nyheter/riksadvokaten_-okokrim-nestsjef-kan-behandle-huitfeldt-saken-1.16545162">Riksadvokaten
195 har konkludert med at nestsjefen i Økokrim kan behandle sak om
196 habilitet og innsidekunnskap
</a> for Huitfeldt, på tross av at hans
197 overordnede, sjefen for Økokrim, har meldt seg inhabil i saken. Dette
198 er litt rart. I veilednigen
199 «
<a href=
"https://www.regjeringen.no/globalassets/upload/krd/vedlegg/komm/veiledere/habilitet_i_kommuner_og_fylkeskommuner.pdf">Habilitet
200 i kommuner og fylkeskommuner
</a>» av Kommunal- og regionaldepartementet
201 forteller de hva som gjelder, riktig nok gjelder veiledningen ikke for
202 Økokrim som jo ikke er kommune eller fylkeskommune, men jeg får ikke
203 inntrykk av at dette er regler som kun gjelder for kommune og
207 <p>«
<strong>2.1 Oversikt over inhabilitetsgrunnlagene
</strong>
209 <p>De alminnelige reglene om inhabilitet for den offentlige
210 forvaltningen er gitt i
211 <a href=
"https://lovdata.no/dokument/NL/lov/1967-02-10/KAPITTEL_2#KAPITTEL_2">forvaltningsloven
212 §§
6 til
10</a>. Forvaltningslovens hovedregel om inhabilitet framgår
213 av §
6. Her er det gitt tre ulike grunnlag som kan føre til at en
214 tjenestemann eller folkevalgt blir inhabil. I §
6 første ledd
215 bokstavene a til e er det oppstilt konkrete tilknytningsforhold mellom
216 tjenestemannen og saken eller sakens parter som automatisk fører til
217 inhabilitet. Annet ledd oppstiller en skjønnsmessig regel om at
218 tjenestemannen også kan bli inhabil etter en konkret vurdering av
219 inhabilitetsspørsmålet, der en lang rekke momenter kan være
220 relevante. I tredje ledd er det regler om såkalt avledet
221 inhabilitet. Det vil si at en underordnet tjenestemann blir inhabil
222 fordi en overordnet er inhabil.»
</p>
225 <p>Loven sier ganske enkelt «Er den overordnede tjenestemann ugild,
226 kan avgjørelse i saken heller ikke treffes av en direkte underordnet
227 tjenestemann i samme forvaltningsorgan.» Jeg antar tanken er at en
228 underordnet vil stå i fare for å tilpasse sine konklusjoner til det
229 overordnet vil ha fordel av, for å fortsatt ha et godt forhold til sin
230 overordnede. Men jeg er ikke jurist og forstår nok ikke kompliserte
231 juridiske vurderinger. For å sitere «Kamerat Napoleon» av George
232 Orwell: «Alle dyr er like, men noen dyr er likere enn andre».
237 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/norsk">norsk
</a>.
242 <div class=
"padding"></div>
245 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/Invidious_add_on_for_Kodi_20.html">Invidious add-on for Kodi
20</a></div>
246 <div class=
"date">10th August
2023</div>
247 <div class=
"body"><p>I still enjoy
<a href=
"https://kodi.tv/">Kodi
</a> and
248 <a href=
"https://libreelec.tv/">LibreELEC
</a> as my multimedia center
249 at home. Sadly two of the services I really would like to use from
250 within Kodi are not easily available. The most wanted add-on would be
251 one making
<a href=
"https://archive.org/">The Internet Archive
</a>
252 available, and it has
253 <a href=
"https://kodi.wiki/view/Add-on:Internet_Archive">not been
254 working
</a> for many years. The second most wanted add-on is one
255 using
<a href=
"https://invidious.io/">the Invidious privacy enhanced
256 Youtube frontent
</a>. A plugin for this has been partly working, but
257 not been kept up to date in the Kodi add-on repository, and its
258 upstream seem to have given it up in April this year, when the git
259 repository was closed. A few days ago I got tired of this sad state
260 of affairs and decided to
261 <a href=
"https://github.com/petterreinholdtsen/kodi-invidious-plugin">have
262 a go at improving the Invidious add-on
</a>. As
263 <a href=
"https://github.com/iv-org/invidious/issues/3872">Google has
264 already attacked
</a> the Invidious concept, so it need all the support
265 if can get. My small contribution here is to improve the service
268 <p>I added support to the Invidious add-on for automatically picking a
269 working Invidious instance, instead of requiring the user to specify
270 the URL to a specific instance after installation. I also had a look
271 at the set of patches floating around in the various forks on github,
272 and decided to clean up at least some of the features I liked and
273 integrate them into my new release branch. Now the plugin can handle
274 channel and short video items in search results. Earlier it could
275 only handle single video instances in the search response. I also
276 brushed up the set of metadata displayed a bit, but hope I can figure
277 out how to get more relevant metadata displayed.
</p>
279 <p>Because I only use Kodi
20 myself, I only test on version
20 and am
280 only motivated to ensure version
20 is working. Because of API changes
281 between version
19 and
20, I suspect it will fail with earlier Kodi
285 <a href=
"https://github.com/xbmc/repo-plugins/pull/4363">asked to have
286 the add-on added
</a> to the official Kodi
20 repository, and is
287 waiting to heard back from the repo maintainers.
</p>
289 <p>As usual, if you use Bitcoin and want to show your support of my
290 activities, please send Bitcoin donations to my address
291 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
296 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/kodi">kodi
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/multimedia">multimedia
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/video">video
</a>.
301 <div class=
"padding"></div>
304 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/What_did_I_learn_from_OpenSnitch_this_summer_.html">What did I learn from OpenSnitch this summer?
</a></div>
305 <div class=
"date">11th June
2023</div>
306 <div class=
"body"><p>With yesterdays
307 <a href=
"https://www.debian.org/News/2023/20230610">release of Debian
308 12 Bookworm
</a>, I am happy to know the
309 <a href=
"https://tracker.debian.org/pkg/opensnitch">the interactive
310 application firewall OpenSnitch
</a> is available for a wider audience.
311 I have been running it for a few weeks now, and have been surprised
312 about some of the programs connecting to the Internet. Some programs
313 are obviously calling out from my machine, like the NTP network based
314 clock adjusting system and Tor to reach other Tor clients, but others
315 were more dubious. For example, the KDE Window manager try to look up
316 the host name in DNS, for no apparent reason, but if this lookup is
317 blocked the KDE desktop get periodically stuck when I use it. Another
318 surprise was how much Firefox call home directly to mozilla.com,
319 mozilla.net and googleapis.com, to mention a few, when I visit other
320 web pages. This direct connection happen even if I told Firefox to
321 always use a proxy, and the proxy setting is ignored for this traffic.
322 Other surprising connections come from audacity and dirmngr (I do not
323 use Gnome). It took some trial and error to get a good default set of
324 permissions. Without it, I would get popups asking for permissions at
325 any time, also the most inconvenient ones where I am in the middle of
326 a time sensitive gaming session.
</p>
328 <p>I suspect some application developers should rethink when then need
329 to use network connections or DNS lookups, and recommend testing
330 OpenSnitch (only
<tt>apt install opensnitch
</tt> away in Debian
331 Bookworm) to locate and report any surprising Internet connections on
332 your desktop machine.
</p>
334 <p>At the moment the upstream developer and Debian package maintainer
335 is working on making the system more reliable in Debian, by enabling
336 the eBPF kernel module to track processes and connections instead of
337 depending in content in /proc/. This should enter unstable fairly
340 <p>As usual, if you use Bitcoin and want to show your support of my
341 activities, please send Bitcoin donations to my address
342 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
344 <p><strong>Update
2023-
06-
12</strong>: I got a tip about
345 <a href=
"https://wiki.debian.org/PrivacyIssues">a list of privacy
346 issues in Free Software
</a> and the
347 <a href=
"irc://irc.debian.org/%23debian-privacy">#debian-privacy IRC
348 channel
</a> discussing these topics.
</p>
354 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/opensnitch">opensnitch
</a>.
359 <div class=
"padding"></div>
362 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/wmbusmeters__parse_data_from_your_utility_meter___nice_free_software.html">wmbusmeters, parse data from your utility meter - nice free software
</a></div>
363 <div class=
"date">19th May
2023</div>
364 <div class=
"body"><p>There is a European standard for reading utility meters like water,
365 gas, electricity or heat distribution meters. The
366 <a href=
"https://en.wikipedia.org/wiki/Meter-Bus">Meter-Bus standard
367 (EN
13757-
2, EN
13757-
3 and EN
13757–
4)
</a> provide a cross vendor way
368 to talk to and collect meter data. I ran into this standard when I
369 wanted to monitor some heat distribution meters, and managed to find
370 free software that could do the job. The meters in question broadcast
371 encrypted messages with meter information via radio, and the hardest
372 part was to track down the encryption keys from the vendor. With this
373 in place I could set up a MQTT gateway to submit the meter data for
376 <p>The free software systems in question,
377 <a href=
"https://tracker.debian.org/pkg/rtl-wmbus">rtl-wmbus
</a> to
378 read the messages from a software defined radio, and
379 <a href=
"https://tracker.debian.org/pkg/wmbusmeters">wmbusmeters
</a> to
380 decrypt and decode the content of the messages, is working very well
381 and allowe me to get frequent updates from my meters. I got in touch
382 with upstream last year to see if there was any interest in publishing
383 the packages via Debian. I was very happy to learn that Fredrik
384 Öhrström volunteered to maintain the packages, and I have since
385 assisted him in getting Debian package build rules in place as well as
386 sponsoring the packages into the Debian archive. Sadly we completed
387 it too late for them to become part of the next stable Debian release
388 (Bookworm). The wmbusmeters package just cleared the NEW queue. It
389 will need some work to fix a built problem, but I expect Fredrik will
390 find a solution soon.
</p>
392 <p>If you got a infrastructure meter supporting the Meter Bus
393 standard, I strongly recommend having a look at these nice
396 <p>As usual, if you use Bitcoin and want to show your support of my
397 activities, please send Bitcoin donations to my address
398 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
403 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/nice free software">nice free software
</a>.
408 <div class=
"padding"></div>
411 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/The_2023_LinuxCNC_Norwegian_developer_gathering.html">The
2023 LinuxCNC Norwegian developer gathering
</a></div>
412 <div class=
"date">14th May
2023</div>
413 <div class=
"body"><p>The LinuxCNC project is making headway these days. A lot of
414 patches and issues have seen activity on
415 <a href=
"https://github.com/LinuxCNC/linuxcnc/">the project github
416 pages
</a> recently. A few weeks ago there was a developer gathering
417 over at the
<a href=
"https://tormach.com/">Tormach
</a> headquarter in
418 Wisconsin, and now we are planning a new gathering in Norway. If you
419 wonder what LinuxCNC is, lets quote Wikipedia:
</p>
422 "LinuxCNC is a software system for numerical control of
423 machines such as milling machines, lathes, plasma cutters, routers,
424 cutting machines, robots and hexapods. It can control up to
9 axes or
425 joints of a CNC machine using G-code (RS-
274NGC) as input. It has
426 several GUIs suited to specific kinds of usage (touch screen,
427 interactive development)."
430 <p>The Norwegian developer gathering take place the weekend June
16th
431 to
18th this year, and is open for everyone interested in contributing
432 to LinuxCNC. Up to date information about the gathering can be found
434 <a href=
"https://sourceforge.net/p/emc/mailman/emc-developers/thread/sa64jp06nob.fsf%40hjemme.reinholdtsen.name/#msg37837251">the
435 developer mailing list thread
</a> where the gathering was announced.
436 Thanks to the good people at
437 <a href=
"https://www.debian.org/">Debian
</a>,
438 <a href=
"https://www.redpill-linpro.com/">Redpill-Linpro
</a> and
439 <a href=
"https://www.nuugfoundation.no/no/">NUUG Foundation
</a>, we
440 have enough sponsor funds to pay for food, and shelter for the people
441 traveling from afar to join us. If you would like to join the
442 gathering, get in touch.
</p>
444 <p>As usual, if you use Bitcoin and want to show your support of my
445 activities, please send Bitcoin donations to my address
446 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
451 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/linuxcnc">linuxcnc
</a>.
456 <div class=
"padding"></div>
459 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/OpenSnitch_in_Debian_ready_for_prime_time.html">OpenSnitch in Debian ready for prime time
</a></div>
460 <div class=
"date">13th May
2023</div>
461 <div class=
"body"><p>A bit delayed,
462 <a href=
"https://tracker.debian.org/pkg/opensnitch">the interactive
463 application firewall OpenSnitch
</a> package in Debian now got the
464 latest fixes ready for Debian Bookworm. Because it depend on a
465 package missing on some architectures, the autopkgtest check of the
466 testing migration script did not understand that the tests were
467 actually working, so the migration was delayed. A bug in the package
468 dependencies is also fixed, so those installing the firewall package
469 (opensnitch) now also get the GUI admin tool (python3-opensnitch-ui)
470 installed by default. I am very grateful to Gustavo Iñiguez Goya for
471 his work on getting the package ready for Debian Bookworm.
</p>
473 <p>Armed with this package I have discovered some surprising
474 connections from programs I believed were able to work completly
475 offline, and it has already proven its worth, at least to me. If you
476 too want to get more familiar with the kind of programs using
477 Internett connections on your machine, I recommend testing
<tt>apt
478 install opensnitch
</tt> in Bookworm and see what you think.
</p>
480 <p>The package is still not able to build its eBPF module within
481 Debian. Not sure how much work it would be to get it working, but
482 suspect some kernel related packages need to be extended with more
483 header files to get it working.
</p>
485 <p>As usual, if you use Bitcoin and want to show your support of my
486 activities, please send Bitcoin donations to my address
487 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
492 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/opensnitch">opensnitch
</a>.
497 <div class=
"padding"></div>
500 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/Speech_to_text__she_APTly_whispered__how_hard_can_it_be_.html">Speech to text, she APTly whispered, how hard can it be?
</a></div>
501 <div class=
"date">23rd April
2023</div>
502 <div class=
"body"><p>While visiting a convention during Easter, it occurred to me that
503 it would be great if I could have a digital Dictaphone with
504 transcribing capabilities, providing me with texts to cut-n-paste into
505 stuff I need to write. The background is that long drives often bring
506 up the urge to write on texts I am working on, which of course is out
507 of the question while driving. With the release of
508 <a href=
"https://github.com/openai/whisper/">OpenAI Whisper
</a>, this
509 seem to be within reach with Free Software, so I decided to give it a
510 go. OpenAI Whisper is a Linux based neural network system to read in
511 audio files and provide text representation of the speech in that
512 audio recording. It handle multiple languages and according to its
513 creators even can translate into a different language than the spoken
514 one. I have not tested the latter feature. It can either use the CPU
515 or a GPU with CUDA support. As far as I can tell, CUDA in practice
516 limit that feature to NVidia graphics cards. I have few of those, as
517 they do not work great with free software drivers, and have not tested
518 the GPU option. While looking into the matter, I did discover some
519 work to provide CUDA support on non-NVidia GPUs, and some work with
520 the library used by Whisper to port it to other GPUs, but have not
521 spent much time looking into GPU support yet. I've so far used an old
522 X220 laptop as my test machine, and only transcribed using its
525 <p>As it from a privacy standpoint is unthinkable to use computers
526 under control of someone else (aka a "cloud" service) to transcribe
527 ones thoughts and personal notes, I want to run the transcribing
528 system locally on my own computers. The only sensible approach to me
529 is to make the effort I put into this available for any Linux user and
530 to upload the needed packages into Debian. Looking at Debian Bookworm, I
531 discovered that only three packages were missing,
532 <a href=
"https://bugs.debian.org/1034307">tiktoken
</a>,
533 <a href=
"https://bugs.debian.org/1034144">triton
</a>, and
534 <a href=
"https://bugs.debian.org/1034091">openai-whisper
</a>. For a while
536 <a href=
"https://bugs.debian.org/1034286">ffmpeg-python
</a> was
538 <a href=
"https://github.com/kkroening/ffmpeg-python/issues/760">upstream
539 seem to have vanished
</a> I found it safer
540 <a href=
"https://github.com/openai/whisper/pull/1242">to rewrite
541 whisper
</a> to stop depending on in than to introduce ffmpeg-python
542 into Debian. I decided to place these packages under the umbrella of
543 <a href=
"https://salsa.debian.org/deeplearning-team">the Debian Deep
544 Learning Team
</a>, which seem like the best team to look after such
545 packages. Discussing the topic within the group also made me aware
546 that the triton package was already a future dependency of newer
547 versions of the torch package being planned, and would be needed after
548 Bookworm is released.
</p>
550 <p>All required code packages have been now waiting in
551 <a href=
"https://ftp-master.debian.org/new.html">the Debian NEW
552 queue
</a> since Wednesday, heading for Debian Experimental until
553 Bookworm is released. An unsolved issue is how to handle the neural
554 network models used by Whisper. The default behaviour of Whisper is
555 to require Internet connectivity and download the model requested to
556 <tt>~/.cache/whisper/
</tt> on first invocation. This obviously would
557 fail
<a href=
"https://people.debian.org/~bap/dfsg-faq.html">the
558 deserted island test of free software
</a> as the Debian packages would
559 be unusable for someone stranded with only the Debian archive and solar
560 powered computer on a deserted island.
</p>
562 <p>Because of this, I would love to include the models in the Debian
563 mirror system. This is problematic, as the models are very large
564 files, which would put a heavy strain on the Debian mirror
565 infrastructure around the globe. The strain would be even higher if
566 the models change often, which luckily as far as I can tell they do
567 not. The small model, which according to its creator is most useful
568 for English and in my experience is not doing a great job there
569 either, is
462 MiB (deb is
414 MiB). The medium model, which to me
570 seem to handle English speech fairly well is
1.5 GiB (deb is
1.3 GiB)
571 and the large model is
2.9 GiB (deb is
2.6 GiB). I would assume
572 everyone with enough resources would prefer to use the large model for
573 highest quality. I believe the models themselves would have to go
574 into the non-free part of the Debian archive, as they are not really
575 including any useful source code for updating the models. The
576 "source", aka the model training set, according to the creators
577 consist of "
680,
000 hours of multilingual and multitask supervised
578 data collected from the web", which to me reads material with both
579 unknown copyright terms, unavailable to the general public. In other
580 words, the source is not available according to the Debian Free
581 Software Guidelines and the model should be considered non-free.
</p>
583 <p>I asked the Debian FTP masters for advice regarding uploading a
584 model package on their IRC channel, and based on the feedback there it
585 is still unclear to me if such package would be accepted into the
586 archive. In any case I wrote build rules for a
587 <a href=
"https://salsa.debian.org/deeplearning-team/openai-whisper-model">OpenAI
588 Whisper model package
</a> and
589 <a href=
"https://github.com/openai/whisper/pull/1257">modified the
590 Whisper code base
</a> to prefer shared files under
<tt>/usr/
</tt> and
591 <tt>/var/
</tt> over user specific files in
<tt>~/.cache/whisper/
</tt>
592 to be able to use these model packages, to prepare for such
593 possibility. One solution might be to include only one of the models
594 (small or medium, I guess) in the Debian archive, and ask people to
595 download the others from the Internet. Not quite sure what to do
596 here, and advice is most welcome (use the debian-ai mailing list).
</p>
598 <p>To make it easier to test the new packages while I wait for them to
599 clear the NEW queue, I created an APT source targeting bookworm. I
600 selected Bookworm instead of Bullseye, even though I know the latter
601 would reach more users, is that some of the required dependencies are
602 missing from Bullseye and I during this phase of testing did not want
603 to backport a lot of packages just to get up and running.
</p>
605 <p>Here is a recipe to run as user root if you want to test OpenAI
606 Whisper using Debian packages on your Debian Bookworm installation,
607 first adding the APT repository GPG key to the list of trusted keys,
608 then setting up the APT repository and finally installing the packages
609 and one of the models:
</p>
612 curl https://geekbay.nuug.no/~pere/openai-whisper/D78F5C4796F353D211B119E28200D9B589641240.asc \
613 -o /etc/apt/trusted.gpg.d/pere-whisper.asc
614 mkdir -p /etc/apt/sources.list.d
615 cat
> /etc/apt/sources.list.d/pere-whisper.list
<<EOF
616 deb https://geekbay.nuug.no/~pere/openai-whisper/ bookworm main
617 deb-src https://geekbay.nuug.no/~pere/openai-whisper/ bookworm main
620 apt install openai-whisper
623 <p>The package work for me, but have not yet been tested on any other
624 computer than my own. With it, I have been able to (badly) transcribe
625 a
2 minute
40 second Norwegian audio clip to test using the small
626 model. This took
11 minutes and around
2.2 GiB of RAM. Transcribing
627 the same file with the medium model gave a accurate text in
77 minutes
628 using around
5.2 GiB of RAM. My test machine had too little memory to
629 test the large model, which I believe require
11 GiB of RAM. In
630 short, this now work for me using Debian packages, and I hope it will
631 for you and everyone else once the packages enter Debian.
</p>
633 <p>Now I can start on the audio recording part of this project.
</p>
635 <p>As usual, if you use Bitcoin and want to show your support of my
636 activities, please send Bitcoin donations to my address
637 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
642 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/multimedia">multimedia
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/video">video
</a>.
647 <div class=
"padding"></div>
650 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/rtlsdr_scanner__software_defined_radio_frequency_scanner_for_Linux____nice_free_software.html">rtlsdr-scanner, software defined radio frequency scanner for Linux - nice free software
</a></div>
651 <div class=
"date"> 7th April
2023</div>
652 <div class=
"body"><p>Today I finally found time to track down a useful radio frequency
653 scanner for my software defined radio. Just for fun I tried to locate
654 the radios used in the areas, and a good start would be to scan all
655 the frequencies to see what is in use. I've tried to find a useful
656 program earlier, but ran out of time before I managed to find a useful
657 tool. This time I was more successful, and after a few false leads I
658 found a description of
659 <a href=
"https://www.kali.org/tools/rtlsdr-scanner/">rtlsdr-scanner
660 over at the Kali site
</a>, and was able to track down
661 <a href=
"https://gitlab.com/kalilinux/packages/rtlsdr-scanner.git">the
662 Kali package git repository
</a> to build a deb package for the
663 scanner. Sadly the package is missing from the Debian project itself,
664 at least in Debian Bullseye. Two runtime dependencies,
665 <a href=
"https://gitlab.com/kalilinux/packages/python-visvis.git">python-visvis
</a>
667 <a href=
"https://gitlab.com/kalilinux/packages/python-rtlsdr.git">python-rtlsdr
</a>
668 had to be built and installed separately. Luckily '
<tt>gbp
669 buildpackage
</tt>' handled them just fine and no further packages had
670 to be manually built. The end result worked out of the box after
673 <p>My initial scans for FM channels worked just fine, so I knew the
674 scanner was functioning. But when I tried to scan every frequency
675 from
100 to
1000 MHz, the program stopped unexpectedly near the
676 completion. After some debugging I discovered USB software radio I
677 used rejected frequencies above
948 MHz, triggering a unreported
678 exception breaking the scan. Changing the scan to end at
957 worked
679 better. I similarly found the lower limit to be around
15, and ended
680 up with the following full scan:
</p>
682 <p><a href=
"https://people.skolelinux.org/pere/blog/images/2023-04-07-radio-freq-scanning.png"><img src=
"https://people.skolelinux.org/pere/blog/images/2023-04-07-radio-freq-scanning.png" width=
"100%"></a></p>
684 <p>Saving the scan did not work, but exporting it as a CSV file worked
685 just fine. I ended up with around
477k CVS lines with dB level for
686 the given frequency.
</p>
688 <p>The save failure seem to be a missing UTF-
8 encoding issue in the
689 python code. Will see if I can find time to send a patch
690 <a href=
"https://github.com/CdeMills/RTLSDR-Scanner/">upstream
</a>
691 later to fix this exception:
</p>
694 Traceback (most recent call last):
695 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/main_window.py", line
485, in __on_save
696 save_plot(fullName, self.scanInfo, self.spectrum, self.locations)
697 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/file.py", line
408, in save_plot
698 handle.write(json.dumps(data, indent=
4))
699 TypeError: a bytes-like object is required, not 'str'
700 Traceback (most recent call last):
701 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/main_window.py", line
485, in __on_save
702 save_plot(fullName, self.scanInfo, self.spectrum, self.locations)
703 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/file.py", line
408, in save_plot
704 handle.write(json.dumps(data, indent=
4))
705 TypeError: a bytes-like object is required, not 'str'
708 <p>As usual, if you use Bitcoin and want to show your support of my
709 activities, please send Bitcoin donations to my address
710 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
715 Tags:
<a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/english">english
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/nice free software">nice free software
</a>.
720 <div class=
"padding"></div>
722 <p style=
"text-align: right;"><a href=
"index.rss"><img src=
"https://people.skolelinux.org/pere/blog/xml.gif" alt=
"RSS feed" width=
"36" height=
"14" /></a></p>
733 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/01/">January (
3)
</a></li>
735 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/02/">February (
1)
</a></li>
737 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/04/">April (
2)
</a></li>
739 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/05/">May (
3)
</a></li>
741 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/06/">June (
1)
</a></li>
743 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/08/">August (
1)
</a></li>
745 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/09/">September (
1)
</a></li>
747 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/10/">October (
1)
</a></li>
749 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/11/">November (
1)
</a></li>
756 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/02/">February (
1)
</a></li>
758 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/03/">March (
3)
</a></li>
760 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/04/">April (
2)
</a></li>
762 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/06/">June (
2)
</a></li>
764 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/07/">July (
1)
</a></li>
766 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/09/">September (
1)
</a></li>
768 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/10/">October (
1)
</a></li>
770 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/12/">December (
1)
</a></li>
777 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/01/">January (
2)
</a></li>
779 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/02/">February (
1)
</a></li>
781 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/05/">May (
1)
</a></li>
783 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/06/">June (
1)
</a></li>
785 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/07/">July (
3)
</a></li>
787 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/08/">August (
1)
</a></li>
789 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/09/">September (
1)
</a></li>
791 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/10/">October (
1)
</a></li>
793 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/12/">December (
1)
</a></li>
800 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/02/">February (
2)
</a></li>
802 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/03/">March (
2)
</a></li>
804 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/04/">April (
2)
</a></li>
806 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/05/">May (
3)
</a></li>
808 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/06/">June (
2)
</a></li>
810 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/07/">July (
1)
</a></li>
812 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/09/">September (
1)
</a></li>
814 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/10/">October (
1)
</a></li>
816 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/11/">November (
1)
</a></li>
823 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/01/">January (
4)
</a></li>
825 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/02/">February (
3)
</a></li>
827 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/03/">March (
3)
</a></li>
829 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/05/">May (
2)
</a></li>
831 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/06/">June (
5)
</a></li>
833 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/07/">July (
2)
</a></li>
835 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/08/">August (
1)
</a></li>
837 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/09/">September (
1)
</a></li>
839 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/11/">November (
1)
</a></li>
841 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/12/">December (
4)
</a></li>
848 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/01/">January (
1)
</a></li>
850 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/02/">February (
5)
</a></li>
852 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/03/">March (
5)
</a></li>
854 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/04/">April (
3)
</a></li>
856 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/06/">June (
2)
</a></li>
858 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/07/">July (
5)
</a></li>
860 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/08/">August (
3)
</a></li>
862 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/09/">September (
3)
</a></li>
864 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/10/">October (
5)
</a></li>
866 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/11/">November (
2)
</a></li>
868 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/12/">December (
4)
</a></li>
875 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/01/">January (
4)
</a></li>
877 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/02/">February (
3)
</a></li>
879 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/03/">March (
5)
</a></li>
881 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/04/">April (
2)
</a></li>
883 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/06/">June (
5)
</a></li>
885 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/07/">July (
1)
</a></li>
887 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/08/">August (
1)
</a></li>
889 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/09/">September (
3)
</a></li>
891 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/10/">October (
5)
</a></li>
893 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/11/">November (
3)
</a></li>
895 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/12/">December (
4)
</a></li>
902 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/01/">January (
3)
</a></li>
904 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/02/">February (
2)
</a></li>
906 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/03/">March (
3)
</a></li>
908 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/04/">April (
8)
</a></li>
910 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/05/">May (
8)
</a></li>
912 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/06/">June (
2)
</a></li>
914 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/07/">July (
2)
</a></li>
916 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/08/">August (
5)
</a></li>
918 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/09/">September (
2)
</a></li>
920 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/10/">October (
3)
</a></li>
922 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/11/">November (
8)
</a></li>
924 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/12/">December (
5)
</a></li>
931 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/01/">January (
7)
</a></li>
933 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/02/">February (
6)
</a></li>
935 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/03/">March (
1)
</a></li>
937 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/04/">April (
4)
</a></li>
939 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/05/">May (
3)
</a></li>
941 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/06/">June (
4)
</a></li>
943 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/07/">July (
6)
</a></li>
945 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/08/">August (
2)
</a></li>
947 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/09/">September (
2)
</a></li>
949 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/10/">October (
9)
</a></li>
951 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/11/">November (
6)
</a></li>
953 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/12/">December (
3)
</a></li>
960 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/01/">January (
2)
</a></li>
962 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/02/">February (
3)
</a></li>
964 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/03/">March (
8)
</a></li>
966 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/04/">April (
7)
</a></li>
968 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/05/">May (
1)
</a></li>
970 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/06/">June (
2)
</a></li>
972 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/07/">July (
2)
</a></li>
974 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/08/">August (
2)
</a></li>
976 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/09/">September (
5)
</a></li>
978 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/10/">October (
6)
</a></li>
980 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/11/">November (
3)
</a></li>
982 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/12/">December (
5)
</a></li>
989 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/01/">January (
11)
</a></li>
991 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/02/">February (
9)
</a></li>
993 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/03/">March (
9)
</a></li>
995 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/04/">April (
6)
</a></li>
997 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/05/">May (
9)
</a></li>
999 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/06/">June (
10)
</a></li>
1001 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/07/">July (
7)
</a></li>
1003 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/08/">August (
3)
</a></li>
1005 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/09/">September (
5)
</a></li>
1007 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/10/">October (
7)
</a></li>
1009 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/11/">November (
9)
</a></li>
1011 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/12/">December (
3)
</a></li>
1018 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/01/">January (
7)
</a></li>
1020 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/02/">February (
10)
</a></li>
1022 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/03/">March (
17)
</a></li>
1024 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/04/">April (
12)
</a></li>
1026 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/05/">May (
12)
</a></li>
1028 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/06/">June (
20)
</a></li>
1030 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/07/">July (
17)
</a></li>
1032 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/08/">August (
6)
</a></li>
1034 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/09/">September (
9)
</a></li>
1036 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/10/">October (
17)
</a></li>
1038 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/11/">November (
10)
</a></li>
1040 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/12/">December (
7)
</a></li>
1047 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/01/">January (
16)
</a></li>
1049 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/02/">February (
6)
</a></li>
1051 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/03/">March (
6)
</a></li>
1053 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/04/">April (
7)
</a></li>
1055 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/05/">May (
3)
</a></li>
1057 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/06/">June (
2)
</a></li>
1059 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/07/">July (
7)
</a></li>
1061 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/08/">August (
6)
</a></li>
1063 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/09/">September (
4)
</a></li>
1065 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/10/">October (
2)
</a></li>
1067 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/11/">November (
3)
</a></li>
1069 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/12/">December (
1)
</a></li>
1076 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/01/">January (
2)
</a></li>
1078 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/02/">February (
1)
</a></li>
1080 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/03/">March (
3)
</a></li>
1082 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/04/">April (
3)
</a></li>
1084 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/05/">May (
9)
</a></li>
1086 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/06/">June (
14)
</a></li>
1088 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/07/">July (
12)
</a></li>
1090 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/08/">August (
13)
</a></li>
1092 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/09/">September (
7)
</a></li>
1094 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/10/">October (
9)
</a></li>
1096 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/11/">November (
13)
</a></li>
1098 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/12/">December (
12)
</a></li>
1105 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/01/">January (
8)
</a></li>
1107 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/02/">February (
8)
</a></li>
1109 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/03/">March (
12)
</a></li>
1111 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/04/">April (
10)
</a></li>
1113 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/05/">May (
9)
</a></li>
1115 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/06/">June (
3)
</a></li>
1117 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/07/">July (
4)
</a></li>
1119 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/08/">August (
3)
</a></li>
1121 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/09/">September (
1)
</a></li>
1123 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/10/">October (
2)
</a></li>
1125 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/11/">November (
3)
</a></li>
1127 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/12/">December (
3)
</a></li>
1134 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2008/11/">November (
5)
</a></li>
1136 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2008/12/">December (
7)
</a></li>
1147 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (
19)
</a></li>
1149 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/amiga">amiga (
1)
</a></li>
1151 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/aros">aros (
1)
</a></li>
1153 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bankid">bankid (
4)
</a></li>
1155 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/betalkontant">betalkontant (
9)
</a></li>
1157 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (
12)
</a></li>
1159 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (
17)
</a></li>
1161 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bsa">bsa (
2)
</a></li>
1163 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/chrpath">chrpath (
2)
</a></li>
1165 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian (
195)
</a></li>
1167 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (
159)
</a></li>
1169 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/debian-handbook">debian-handbook (
9)
</a></li>
1171 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/digistan">digistan (
11)
</a></li>
1173 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/dld">dld (
18)
</a></li>
1175 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/docbook">docbook (
32)
</a></li>
1177 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (
4)
</a></li>
1179 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/english">english (
452)
</a></li>
1181 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (
23)
</a></li>
1183 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (
14)
</a></li>
1185 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (
34)
</a></li>
1187 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (
9)
</a></li>
1189 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (
20)
</a></li>
1191 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/h264">h264 (
20)
</a></li>
1193 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/intervju">intervju (
43)
</a></li>
1195 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (
16)
</a></li>
1197 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/kart">kart (
23)
</a></li>
1199 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/kodi">kodi (
6)
</a></li>
1201 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/ldap">ldap (
9)
</a></li>
1203 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/lego">lego (
5)
</a></li>
1205 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/lenker">lenker (
8)
</a></li>
1207 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/linuxcnc">linuxcnc (
5)
</a></li>
1209 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/lsdvd">lsdvd (
2)
</a></li>
1211 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (
1)
</a></li>
1213 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/madewithcc">madewithcc (
3)
</a></li>
1215 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (
8)
</a></li>
1217 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (
46)
</a></li>
1219 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/nice free software">nice free software (
15)
</a></li>
1221 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/noark5">noark5 (
23)
</a></li>
1223 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/norsk">norsk (
322)
</a></li>
1225 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/nuug">nuug (
198)
</a></li>
1227 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (
40)
</a></li>
1229 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/open311">open311 (
2)
</a></li>
1231 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/opensnitch">opensnitch (
4)
</a></li>
1233 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (
75)
</a></li>
1235 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/personvern">personvern (
114)
</a></li>
1237 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/raid">raid (
2)
</a></li>
1239 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/reactos">reactos (
1)
</a></li>
1241 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/reprap">reprap (
11)
</a></li>
1243 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/rfid">rfid (
3)
</a></li>
1245 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/robot">robot (
17)
</a></li>
1247 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/rss">rss (
1)
</a></li>
1249 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/ruter">ruter (
7)
</a></li>
1251 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (
2)
</a></li>
1253 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (
59)
</a></li>
1255 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (
4)
</a></li>
1257 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (
5)
</a></li>
1259 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/standard">standard (
74)
</a></li>
1261 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (
7)
</a></li>
1263 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (
14)
</a></li>
1265 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (
64)
</a></li>
1267 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (
5)
</a></li>
1269 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/usenix">usenix (
2)
</a></li>
1271 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/valg">valg (
9)
</a></li>
1273 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/verkidetfri">verkidetfri (
20)
</a></li>
1275 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/video">video (
79)
</a></li>
1277 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (
4)
</a></li>
1279 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/web">web (
42)
</a></li>
1285 <p style=
"text-align: right">
1286 Created by
<a href=
"http://steve.org.uk/Software/chronicle">Chronicle v4.6
</a>