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: entries from November
2023</title>
7 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"http://www.hungry.com/~pere/blog/style.css" />
8 <link rel=
"stylesheet" type=
"text/css" media=
"screen" href=
"http://www.hungry.com/~pere/blog/vim.css" />
9 <link rel=
"alternate" title=
"RSS Feed" href=
"11.rss" type=
"application/rss+xml" />
15 <a href=
"http://www.hungry.com/~pere/blog/">Petter Reinholdtsen
</a>
22 <h3>Entries from November
2023.
</h3>
26 <a href=
"http://www.hungry.com/~pere/blog/_N_r__p___blir__p_____Et_reservoar_av_tegn_sett_fra_depotet__i_tidsskriftet_Aksess.html">«Når «på» blir «pÃ¥»: Et reservoar av tegn sett fra depotet» i tidsskriftet Aksess
</a>
32 <p>For noen uker siden skrev en kamerat og meg
33 <a href=
"https://www.aksess-tidsskrift.no/fordypning/175530">en
34 artikkel om tegnsett
</a> i
35 <a href=
"https://www.aksess-tidsskrift.no/">arkivtidsskriftet
36 Aksess
</a> både på web og i papirutgave nr.
3 2023. Her er det som
37 nettopp ble publisert.
</p>
41 <p><strong>Når «på» blir «pÃ¥»: Et reservoar av tegn sett fra
44 <p>av Thomas Sødring og Petter Reinholdtsen
</p>
46 <p>De færreste av oss tenker over hva som skjer dypere i datamaskinen
47 mens vi sitter der og skriver noe på tastaturet. Når du trykker på
48 tasten «Å», så vises bokstaven Å. Men noen ganger blir det
49 feil. Hvorfor det – og hva er viktig å være klar over i
52 <p>Dersom bokstaver tolkes forskjellig mellom systemer, blir det fort
53 rot, dette kalles mojibake blant kjennere, etter det japanske
54 uttrykket for tegnomforming. Det er en lang historie her som tidvis
55 har vært preget av rot. Noen husker kanskje tilbake til en tid der
56 bokstavene æ, ø og å ofte var ødelagt i e-poster – et klassisk
57 eksempel på tegnsettproblemstilling.
</p>
59 <p id=
"tegnsett_access_nå_og_før"><strong>«Nå» og «før»
</strong></p>
61 <p>Tid er et skjult problem for depot fordi vi danner dokumentasjon i
62 en kontekst som er preget av å være «nå». Vår forståelse av verden og
63 bruken av teknologi er utgangspunktet for denne konteksten. Tenk selv
64 hvordan verden har utviklet seg de siste
20 årene, hva samfunnet er
65 opptatt av, og hvordan vi bruker teknologi i hverdagen. Tid er et
66 skjult problem fordi når vi trekker dokumentasjon ut av systemer og
67 deponerer for langtidsbevaring, er konteksten til materialet «nå», men
68 verden går videre. Ettersom teknologien og måten vi bruker den på,
69 utvikler seg, blir «nå» til «før», og dokumentasjonen befinner seg
70 snart i en «før»-kontekst.
</p>
72 <p>Dette med «før» og «nå» i forhold til dokumentasjonens kontekst er
73 noe vi er veldig lite bevisste på, men det er en problemstilling
74 depotarkivene eier og forvalter. En av disse utfordringene er hvorfor
75 «Ø» ikke nødvendigvis er det samme som «Ø», og hvorfor det i det hele
76 tatt gir mening å si noe sånt. Vi snakker her om noe som heter
77 tegnsett, som er en avtalt måte å representere bokstaver, tall og
78 andre symboler på slik at vi på en feilfri måte kan utveksle tekst
79 mellom datasystemer.
</p>
81 <p>Tegnsettproblemstillingen er satt sammen av fire fasetter;
82 repertoar, representasjon, koding og uttegning.
</p>
84 <p id=
"tegnsett_access_repertoarer"><strong>Repertoarer
</strong></p>
86 <p>Repertoar er en samling med tegn og symboler som kan
87 representeres. Tenk norsk alfabet eller japanske piktogrammer, men
88 også matematiske og elektroniske symboler. Bokstaven «stor a» kan være
89 en oppføring i et slikt repertoar. For å kunne brukes i en datamaskin
90 trenger hver oppføring i et slikt repertoar en representasjon, hvilket
91 i datamaskinsammenheng betyr at det tilordnes et tall. Tallet kan
92 lagres på ulike vis i en eller flere kodingsformater. For eksempel kan
93 en skrive tallet ti som både
10, X og A, i henholdsvis
94 titallssystemet, romertallssystemet og sekstentallssystemet.
</p>
96 <p>Hvis en skal kunne lese inn filer og vite hvilket tall og hvilken
97 representasjon og instans i et repertoar det er snakk om, så må en
98 vite hvordan tallet er kodet. Sist, men ikke minst, for å kunne bruke
99 symbolet til noe må det kunne være kjent hvordan det skal se ut eller
100 tegnes på ark. Det finnes utallige skrifttyper med norske bokstaver,
101 alle litt forskjellige, og skal en kunne tegne en stor A på skjermen,
102 så må datamaskinen vite hva den skal tegne. Skrifttyper inneholder
103 informasjon om hvordan ulike tall skal tegnes. De inneholder ikke
104 alltid alle symbolene som er brukt i en tekst, hvilket gjør at ikke
105 alle forståtte tegn vil kunne vises på skjerm eller ark.
</p>
107 <p>Hver av disse fasettene må være avklart for å kunne ta vare på og vise
108 frem tekst med en datamaskin. Kombinasjon av repertoar, representasjon
109 og koding er det en kaller et tegnsett. Kombinasjonen av
110 representasjon og uttegning kalles en skrifttype. De fleste
111 skrifttyper har også informasjon om repertoar, men det finnes
112 skrifttyper som kun kobler mellom tallkode og uttegning, uten å
113 fortelle noe om hvordan tallkodene egentlig skal tolkes.
</p>
115 <p id=
"tegnsett_access_fra_ascii_til_iso_8859"><strong>Fra ASCII til ISO-
8859</strong></p>
117 <p>Vi begynner historien med ASCII (American Standard Code for
118 Information Interchange) som har en historie som spores tilbake til
119 1963. Utgangspunktet til ASCII var at det kunne kode opp til
128
120 forskjellige symboler i vanlig bruk i USA. De visuelle symbolene i
121 ASCII er de små og store bokstavene (a til z og A til Z), tall (
0 til
122 9) og tegnsettingssymboler (for eksempel semikolon, komma og
123 punktum). ASCII har også noen usynlige symboler som ble brukt for
124 bl.a. kommunikasjon. Før ASCII var det for eksempel teleks-tegnsett
125 med plass til bare
32 tegn og EBCDIC med plass til
256 tegn, alle med
126 en helt annen rekkefølge på symbolene enn ASCII, men de har vært lite
127 brukt de siste femti årene. Et eksempel på noen utvalgte symboler i
128 repertoaret til ASCII vises i tabell
1.
</p>
130 <table align=
"center" width=
"50%">
132 <caption>Tabell
1. Eksempel på utvalgte symboler hentet fra
133 ASCII-tegnsettet. Kolonnen «Binær» viser symbolets verdi i
134 totallssystemet (
1 og
0 tall), mens kolonnen «Desimal» viser symbolets
135 verdi i titallssystemet.
</caption>
146 <td align=
"right">65</td>
151 <td align=
"right">77</td>
156 <td align=
"right">90</td>
161 <td align=
"right">97</td>
166 <td align=
"right">109</td>
171 <td align=
"right">122</td>
176 <td align=
"right">48</td>
181 <td align=
"right">58</td>
186 <td align=
"right">59</td>
191 <p>Det opprinnelige ASCII-tegnsettet ble også omtalt som ASCII-
7 og
192 brukte
7 bits (
0 og
1) for å representere symboler. Datamaskiner er
193 ofte konfigurert til å jobbe med enheter der bits er gruppert som
4
194 eller
8 bits . Det lå en mulighet i å ta i bruk bit åtte. En slik
195 endring ville gjøre det mulig for datamaskiner å øke antall symboler
196 de kunne representere, noe som ga en økning fra
128 forskjellige
197 symboler til
256 forskjellige symboler. Det ble åpnet for å innlemme
198 de nordiske bokstavene sammen med ASCII, og dette ble etter hvert
199 standardisert som ISO-
8859-
1. Tabell
2 viser deler av ISO-
8859-
1 som
200 støtter de norske bokstavene.
</p>
202 <p>Det sier seg selv at muligheten til å representere inntil
256 symboler
203 ikke holder når vi snakker om en global verden, og det ble gjort et
204 standardiseringsløp som tok utgangspunkt i ASCII-
7 med en utvidelse
205 til å bruke den åttende biten for ulike språkgrupper. Denne standarden
206 heter ISO-
8859 og er inndelt i opptil
16 varianter, altså fra
207 ISO-
8859-
1 til ISO-
8859-
16.
</p>
209 <table align=
"center" width=
"50%">
211 <caption>Tabell
2. Koding av de norske symbolene slik de er definert i
212 ISO-
8859-
1 tegnsettet.
</caption>
223 <td align=
"right">198</td>
228 <td align=
"right">216</td>
233 <td align=
"right">197</td>
238 <td align=
"right">230</td>
243 <td align=
"right">248</td>
248 <td align=
"right">229</td>
253 <p>Norske tegn er definert i ISO-
8859-
1, som også omtales som Latin
1, de
254 fleste samiske tegn er definert i ISO-
8859-
4 (Latin
4) mens tilgang
255 til €-symbolet kom med ISO-
8859-
15 (Latin
9). ISO-
8859-
15 er en
256 revisjon av ISO-
8859-
1 som fjerner noen lite brukte symboler og
257 erstatter bokstaver som er mer brukt, og introduserer €-symbolet. Det
258 er viktig å merke at alle ISO-
8859-variantene har overlapp med
259 ASCII-
7, noe som ga samvirke med de engelskspråklige landene som ikke
260 trengte å gjøre noe. Det innebærer også at de første
128 verdiene i
261 ISO-
8859-variantene representerer de samme symbolene. Det er først når
262 du kommer til tolkningen av de resterende
128 verdiene med nummer
128
263 til
255, at det oppsto tolkningsutfordringer mellom
264 ISO-
8859-variantene.
</p>
266 <p>ISO-
8859-verdenen fungerte godt så lenge tegnsettet som ble brukt når
267 innhold ble skapt, også ble brukt når innhold ble gjengitt og du ikke
268 trengte å kombinere innhold fra forskjellige tegnsett i samme
269 dokument. Utfordringen med bruken av ISO-
8859-variantene ble raskt
270 tydelig i en mer globalisert verden med utveksling av tekst på tvers
271 av landegrenser der tekstlig innhold i dokumenter, e-poster og
272 websider kunne bli skrevet med ett tegnsett og gjengitt med et annet
275 <table align=
"center" width=
"60%">
277 <caption>Tabell
3. Viser tolkning av verdiene som er tilegnet de
278 norske symbolene i ISO-
8859-
1 i de andre ISO
8859-variatene. Merk
279 ISO-
8859-
12 ikke finnes da arbeidet ble avsluttet.
<sup>[
<a id=
"tegnsett_access_footnoteref_1" href=
"#tegnsett_access_footnotedef_1" title=
"View footnote.">1</a>]
</sup></caption>
411 <p>Denne problemstillingen er illustrert i tabell
3, der vi ser verdiene
412 tilegnet de norske symbolene i ISO-
8859-
1 i kolonne «
1». I de øvrige
413 kolonnene ser vi hvilket symbol verdien får i de andre
414 ISO-
8859-variantene. Tar vi utgangspunkt i tabell
3, kan vi se at
415 ordet lærlingspørsmål gjengitt med ISO-
8859-
2 (kolonne
2) blir
416 lćrlingspřrsmĺl, mens det blir lζrlingspψrsmεl med ISO-
8859-
7
417 (kolonne
7). Med ISO-
8859-
2 blir «æ» til «ć», «ø» til «ř» og «å» til
418 «ĺ». I ISO-
8859-
7 blir «æ» til «ζ», «ø» til «ψ», mens «å» blir «ε».
</p>
420 <p>Det er egentlig ingen utfordring med dette så lenge du vet hvilket
421 tegnsett innholdet ditt er representert med, og det ikke har skjedd
422 omforminger som du ikke er klar over. Det er det siste som er
423 problematisk, spesielt de datasystemene som har vært i bruk de siste
424 20 årene, som ikke har noe innebygd funksjonalitet for å forvalte
425 tegnsettproblematikken. Et godt eksempel på dette er
426 Microsoft-tegnsettet Windows-
1252, som ble forvekslet som
100 %
427 kompatibel med ISO-
8859-
1, men hadde byttet ut plassene fra
127 til
428 159. Historisk vil det finnes en del variasjon i hvilket tegnsett som
429 har vært i bruk, og hvor vellykket konvertering mellom tegnsett har
432 <p id=
"tegnsett_access_unicode_som_løsning"><strong>Unicode som løsning
</strong></p>
434 <p>Tegnsettforvirring ble etter hvert et irritasjonsmoment og
435 samvirkeproblem. Ofte fikk man en e-post der æøå var erstattet av rare
436 symboler fordi e-posten hadde vært innom et eller annet datasystem som
437 ikke brukte samme tegnsett.
</p>
439 <p>For å løse dette samvirkeproblemet for tegnsett ble det startet et
440 arbeid og en ny standard så dagens lys etter hvert. Denne standarden
441 fikk navnet Unicode (ISO/ IEC
10646) og skulle resultere i et tegnsett
442 som alle skulle være enige om. Unicode er et repertoar og en
443 representasjon, dvs. navngivning og tilordning av tallverdi til alle
444 symboler i bruk i verden i dag. Oppføringer i Unicode skrives gjerne
445 U+XXXX der XXXX er tallkoden i sekstentallssystemet som oppføringen
446 har i Unicode-katalogen. Her finner vi tegn brukt av både levende og
447 døde språk, konstruerte språk, tekniske symboler, morsomme tegninger
448 (såkalte emojier) og tegn ingen vet hva betyr eller skal brukes
449 til. Et morsomt eksempel er i nettartikkelen: U+
237C ⍼ RIGHT ANGLE
450 WITH DOWNWARDS ZIGZAG ARROW, av Jonathan Chan.
<sup>[
<a id=
"tegnsett_access_footnoteref_2" href=
"#tegnsett_access_footnotedef_2" title=
"View footnote.">2</a>]
</sup></p>
452 <p>Sammen med Unicode kom det tre måter å kode disse tallene på; UTF-
8,
453 UTF-
16 og UTF-
32. Av datatekniske årsaker er UTF-
8 mye brukt, spesielt
454 når det gjelder utveksling av tekst over Internett, mens UTF-
16 er
455 brukt en del til tekstfiler lagret på Windows. En utfordring med
456 Unicode og UTF-variantene er at disse gir flere måter å kode samme
457 symbol på med en kombinasjonsmekanisme. Dette kan gi utfordringer ved
458 søk, hvis en skal søke etter et ord som har ett eller flere symboler
459 som kan skrives på ulikt vis, så er det ikke sikkert at søkesystemet
460 vil finne alle forekomster. For eksempel kan bokstaven U+
00F8 «Latin
461 Small Letter O with Stroke» kodes som den tradisjonelle norske tegnet
462 ø, men også som o kombinert med skråstrek U+
0338. Begge deler er
463 gyldig bruk av Unicode, selv om det er tradisjon for å foretrekke å
464 «normalisere» kombinasjoner som enkelttegn der det er mulig, nettopp
465 for å forenkle søk.
</p>
467 <p id=
"tegnsett_access_bare_unicode_fremover"><strong>Bare Unicode fremover
</strong></p>
469 <p>Forvaltningens bruk av tegnsett er regulert i Forskrift om
470 IT-standarder i offentlig forvaltning
<sup>[
<a id=
"tegnsett_access_footnoteref_3" href=
"#tegnsett_access_footnotedef_3" title=
"View footnote.">3</a>]
</sup>. Her står det: «Ved all
471 utveksling av informasjon mellom forvaltningsorganer og fra
472 forvaltningsorgan til innbyggere og næringsliv skal tegnsettstandarden
473 ISO/IEC
10646 representert ved UTF8 benyttes.» Det er forskjellige
474 bruksområder til UTF-
8, UTF-
16 og UTF-
32, men UTF-
8 er kodingen vi
475 kjenner mest til. Det er flere grunner at UTF-
8 «vant» konkurransen
476 til å bli den utvalgte. Den kanskje viktigste er at UTF-
8 er fullt
477 samvirkende med ASCII-
7, slik at den engelskspråklige delen av verden
478 kunne rulle ut UTF-
8 uten å merke noe forskjell. En tekstfil med kun
479 ASCII-tekst vil være identisk på disken hvis den lagres som UTF-
8 og
480 ASCII. UTF-
16 og UTF-
32 byr på noen optimaliseringer som gjør dem
481 relevant for spesifikke problemområder, men for det meste vil vi aldri
482 oppleve disse standardene på nært hold i hverdagen. Det er uansett kun
483 bruken av UTF-
8 som er lovregulert i Norge.
</p>
485 <p>Det er ikke slik at hele verden bruker ISO/IEC
10646 og UTF-
8. Kina
486 har egne standarder for tegnsett, mye brukt er GB
18030, som er
487 Unicode med en annen koding enn UTF-
8, mens Taiwan og andre asiatiske
488 land gjerne bruker Big5 eller andre tegnsett.
</p>
490 <p>UTF-
8 er dominerende i Norge, men det er tidsperioder der forskjellige
491 datasystemer utvekslet data i henhold til ISO-
8859-
1, ISO-
8859-
15,
492 Windows-
1252, Codepage
865 og ISO-
646-
60 / Codepage
1016 mens
493 overgangen til UTF-
8 pågikk. Det er ikke slik at et datasystem enkelt
494 kan tvinges til å bruke et tegnsett, da det er flere lag i et
495 datasystem som må settes opp til å bruke riktig tegnsett, og
496 tegnsettproblemet fort oppstår når det er et eller annet i
497 datasystemet som bruker feil tegnsett.
</p>
499 <p>Et klassisk eksempel på problemet er en utveksling av tekst mellom to
500 systemer der teksten i utgangspunktet er kodet i UTF-
8, men går
501 gjennom noe som er ISO-
8859-
1 underveis. Dette kan vises med at ordet
502 «på» i et slik scenario ender opp som «pÃ¥». Det er mulig å spore
503 dette tilbake til verdiene symbolene er tilordnet i tegnsettene. «på»
504 blir til «pÃ¥» fordi «å» i UTF-
8 er representert med U+C3AF, og dersom
505 vi ser på hva disse verdiene representerer, ser vi at
506 sekstentallssystemverdien C3 er
1100 0011 i totallssystemet og
507 symbolet med dette tallet i ISO-
8859-
1 er Ã.
</p>
509 <p>Vi ser det samme med sekstentallssystemverdien A5, som er
1010 0101 i
510 totallssystemet, og tilsvarende symbol i ISO-
8859-
1 er ¥. Slik
511 mojibake kan lett skje hvis «på» i utgangspunktet var representert med
512 UTF-
8, men ble behandlet med et system som bruker ISO-
8859-
1. Det er
513 ingen automatikk i å fange opp slike ødeleggelser mens tekstlig
514 innhold utveksles mellom datasystemer.
</p>
516 <p>En utfordring for depotarkivene er at bruken av tegnsett ikke alltid
517 har vært regulert, og at det kan finnes flere dokumentasjonssamlinger
518 som er opprettet med varierende tegnsett før gjeldende forskrift
519 inntraff – uten at det er mulig å avlede fra filene hvilket tegnsett
520 som ble brukt. Et eksempel på dette er €-symbolet, som kom først etter
521 at ISO-
8859-
1 var tatt i bruk. Det kan bli en utfordring for et
522 depotarkiv, men så lenge det er kjent hvilket tegnsett var i bruk, så
523 bør det gå bra. Riksarkivarens
524 forskrift
<sup>[
<a id=
"tegnsett_access_footnoteref_4" href=
"#tegnsett_access_footnotedef_4" title=
"View footnote.">4</a>]
</sup>
525 formaliserer dette ved å kreve følgende:
</p>
528 <p>§
5-
11. Tegnsett i arkivuttrekk
</p>
531 <li>Arkivuttrekk og medfølgende struktur- og innholdsbeskrivelser skal
532 overføres som ren tekst i ukryptert form, og benytte godkjent
535 <li>Godkjente tegnsett er:
537 <li>Unicode UTF-
8<br>
538 (ISO/IEC
10646-
1:
2000 Annex D)
</li>
539 <li>ISO
8859-
1:
1998, Latin
1</li>
540 <li>ISO
8859-
4:
1998, Latin
4 for samiske tegn.
</li>
543 <li>Andre tegnsett aksepteres bare etter avtale med Arkivverket.
</li>
547 <p id=
"tegnsett_access_ditt_ansvar"><strong>Ditt ansvar
</strong></p>
549 <p>På mange måter burde ikke tegnsett være et problem i
2023, men sånn er
550 det nok ikke. Land som har oppgradert til UTF-
8 som primærtegnsett for
551 utveksling av tekstlig innhold, begrenser problematikken betraktelig,
552 men globalt sett så er tegnsettutfordringen ikke løst fordi ikke alle
553 er enige om å bruke samme tegnsett. Det kan være geopolitiske eller
554 kulturelle hensyn som ligger til grunn for dette.
</p>
556 <p>Det er uansett verdt å merke at selv om bruken av UTF-
8 skulle bli
557 100% utbredt, så er det et historisk perspektiv (ASCII-
7,
558 ISO-
8859-variantene, UTF-
8) her som gjør tegnsett til et problemområde
559 arkivarene må forstå og håndtere. Som danningsarkivar har du et
560 ansvar for å vite hvilket tegnsett systemene og databasene dere
561 forvalter, er i samsvar med. Det er noe IT-avdelingen din eller
562 programvareleverandørene enkelt skal kunne svare på, og svaret skal
563 være UTF-
8 for alle nye systemer.
</p>
567 <p id=
"tegnsett_access_footnotedef_1"><a href=
"#tegnsett_access_footnoteref_1">1</a>. Tegnsettkilde
<a href=
"https://en.wikipedia.org/wiki/ISO/IEC_8859">https://en.wikipedia.org/wiki/ISO/IEC_8859
</a></p>
569 <p id=
"tegnsett_access_footnotedef_2"><a href=
"#tegnsett_access_footnoteref_2">2</a>.
<a href=
"https://ionathan.ch/2022/04/09/angzarr.html">https://ionathan.ch/
2022/
04/
09/angzarr.html
</a></p>
571 <p id=
"tegnsett_access_footnotedef_3"><a href=
"#tegnsett_access_footnoteref_3">3</a>.
<a href=
"https://lovdata.no/dokument/SF/forskrift/2013-04-05-959/%C2%A78#%C2%A78">https://lovdata.no/dokument/SF/forskrift/
2013-
04-
05-
959/%C2%A78#%C2%A78
</a></p>
573 <p id=
"tegnsett_access_footnotedef_4"><a href=
"#tegnsett_access_footnoteref_4">4</a>.
<a href=
"https://lovdata.no/forskrift/2017-12-19-2286/§5-11">https://lovdata.no/forskrift/
2017-
12-
19-
2286/§
5-
11</a></p>
577 <p>For øvrig burde varsleren Edward Snowden få politisk asyl i Norge.
</p>
579 <p>Som vanlig, hvis du bruker Bitcoin og ønsker å vise din støtte til
580 det jeg driver med, setter jeg pris på om du sender Bitcoin-donasjoner
582 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>. Merk,
583 betaling med bitcoin er ikke anonymt. :)
</p>
585 <p><b>Oppdatering
2024-
08-
23</b>: Har fått innspill om at det norske
586 ordet for japanske mojibake er tegnsalat.
</p>
592 Tags:
<a href=
"http://www.hungry.com/~pere/blog/tags/noark5">noark5
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/norsk">norsk
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/standard">standard
</a>.
597 <div class=
"padding"></div>
601 <a href=
"http://www.hungry.com/~pere/blog/New_and_improved_sqlcipher_in_Debian_for_accessing_Signal_database.html">New and improved sqlcipher in Debian for accessing Signal database
</a>
607 <p>For a while now I wanted to have direct access to the
608 <a href=
"https://signal.org/">Signal
</a> database of messages and
609 channels of my Desktop edition of Signal. I prefer the enforced end
610 to end encryption of Signal these days for my communication with
611 friends and family, to increase the level of safety and privacy as
612 well as raising the cost of the mass surveillance government and
613 non-government entities practice these days. In August I came across
615 <a href=
"https://www.yoranbrondsema.com/post/the-guide-to-extracting-statistics-from-your-signal-conversations/">recipe
616 on how to use sqlcipher to extract statistics from the Signal
617 database
</a> explaining how to do this. Unfortunately this did not
618 work with the version of sqlcipher in Debian. The
619 <a href=
"http://tracker.debian.org/sqlcipher/">sqlcipher
</a>
620 package is a "fork" of the sqlite package with added support for
621 encrypted databases. Sadly the current Debian maintainer
622 <a href=
"https://bugs.debian.org/961598">announced more than three
623 years ago that he did not have time to maintain sqlcipher
</a>, so it
624 seemed unlikely to be upgraded by the maintainer. I was reluctant to
625 take on the job myself, as I have very limited experience maintaining
626 shared libraries in Debian. After waiting and hoping for a few
627 months, I gave up the last week, and set out to update the package. In
628 the process I orphaned it to make it more obvious for the next person
629 looking at it that the package need proper maintenance.
</p>
631 <p>The version in Debian was around five years old, and quite a lot of
632 changes had taken place upstream into the Debian maintenance git
633 repository. After spending a few days importing the new upstream
634 versions, realising that upstream did not care much for SONAME
635 versioning as I saw library symbols being both added and removed with
636 minor version number changes to the project, I concluded that I had to
637 do a SONAME bump of the library package to avoid surprising the
638 reverse dependencies. I even added a simple
639 autopkgtest script to ensure the package work as intended. Dug deep
640 into the hole of learning shared library maintenance, I set out a few
641 days ago to upload the new version to Debian experimental to see what
642 the quality assurance framework in Debian had to say about the result.
643 The feedback told me the pacakge was not too shabby, and yesterday I
644 uploaded the latest version to Debian unstable. It should enter
645 testing today or tomorrow, perhaps delayed by
646 <a href=
"https://bugs.debian.org/1055812">a small library
649 <p>Armed with a new version of sqlcipher, I can now have a look at the
650 SQL database in ~/.config/Signal/sql/db.sqlite. First, one need to
651 fetch the encryption key from the Signal configuration using this
652 simple JSON extraction command:
</p>
654 <pre>/usr/bin/jq -r '."key"' ~/.config/Signal/config.json
</pre>
656 <p>Assuming the result from that command is 'secretkey', which is a
657 hexadecimal number representing the key used to encrypt the database.
658 Next, one can now connect to the database and inject the encryption
659 key for access via SQL to fetch information from the database. Here
660 is an example dumping the database structure:
</p>
663 % sqlcipher ~/.config/Signal/sql/db.sqlite
664 sqlite
> PRAGMA key = "x'secretkey'";
666 CREATE TABLE sqlite_stat1(tbl,idx,stat);
667 CREATE TABLE conversations(
668 id STRING PRIMARY KEY ASC,
676 , profileFamilyName TEXT, profileFullName TEXT, e164 TEXT, serviceId TEXT, groupId TEXT, profileLastFetchedAt INTEGER);
677 CREATE TABLE identityKeys(
678 id STRING PRIMARY KEY ASC,
682 id STRING PRIMARY KEY ASC,
685 CREATE TABLE sessions(
689 , ourServiceId STRING, serviceId STRING);
690 CREATE TABLE attachment_downloads(
691 id STRING primary key,
696 CREATE TABLE sticker_packs(
701 coverStickerId INTEGER,
703 downloadAttempts INTEGER,
707 stickerCount INTEGER,
709 , attemptedStatus STRING, position INTEGER DEFAULT
0 NOT NULL, storageID STRING, storageVersion INTEGER, storageUnknownFields BLOB, storageNeedsSync
710 INTEGER DEFAULT
0 NOT NULL);
711 CREATE TABLE stickers(
713 packId TEXT NOT NULL,
722 PRIMARY KEY (id, packId),
723 CONSTRAINT stickers_fk
725 REFERENCES sticker_packs(id)
728 CREATE TABLE sticker_references(
731 CONSTRAINT sticker_references_fk
733 REFERENCES sticker_packs(id)
737 shortName TEXT PRIMARY KEY,
740 CREATE TABLE messages(
741 rowid INTEGER PRIMARY KEY ASC,
747 schemaVersion INTEGER,
748 conversationId STRING,
751 hasAttachments INTEGER,
752 hasFileAttachments INTEGER,
753 hasVisualMediaAttachments INTEGER,
755 expirationStartTimestamp INTEGER,
758 messageTimer INTEGER,
759 messageTimerStart INTEGER,
760 messageTimerExpiresAt INTEGER,
763 sourceServiceId TEXT, serverGuid STRING NULL, sourceDevice INTEGER, storyId STRING, isStory INTEGER
764 GENERATED ALWAYS AS (type IS 'story'), isChangeCreatedByUs INTEGER NOT NULL DEFAULT
0, isTimerChangeFromSync INTEGER
765 GENERATED ALWAYS AS (
766 json_extract(json, '$.expirationTimerUpdate.fromSync') IS
1
767 ), seenStatus NUMBER default
0, storyDistributionListId STRING, expiresAt INT
770 expirationStartTimestamp + (expireTimer *
1000),
772 )), shouldAffectActivity INTEGER
773 GENERATED ALWAYS AS (
777 'change-number-notification',
778 'contact-removed-notification',
779 'conversation-merge',
780 'group-v1-migration',
782 'message-history-unsynced',
785 'universal-timer-notification',
788 ), shouldAffectPreview INTEGER
789 GENERATED ALWAYS AS (
793 'change-number-notification',
794 'contact-removed-notification',
795 'conversation-merge',
796 'group-v1-migration',
798 'message-history-unsynced',
801 'universal-timer-notification',
804 ), isUserInitiatedMessage INTEGER
805 GENERATED ALWAYS AS (
809 'change-number-notification',
810 'contact-removed-notification',
811 'conversation-merge',
812 'group-v1-migration',
815 'message-history-unsynced',
818 'universal-timer-notification',
821 ), mentionsMe INTEGER NOT NULL DEFAULT
0, isGroupLeaveEvent INTEGER
822 GENERATED ALWAYS AS (
823 type IS 'group-v2-change' AND
824 json_array_length(json_extract(json, '$.groupV2Change.details')) IS
1 AND
825 json_extract(json, '$.groupV2Change.details[
0].type') IS 'member-remove' AND
826 json_extract(json, '$.groupV2Change.from') IS NOT NULL AND
827 json_extract(json, '$.groupV2Change.from') IS json_extract(json, '$.groupV2Change.details[
0].aci')
828 ), isGroupLeaveEventFromOther INTEGER
829 GENERATED ALWAYS AS (
830 isGroupLeaveEvent IS
1
832 isChangeCreatedByUs IS
0
834 GENERATED ALWAYS AS (
835 json_extract(json, '$.callId')
837 CREATE TABLE sqlite_stat4(tbl,idx,neq,nlt,ndlt,sample);
840 queueType TEXT STRING NOT NULL,
841 timestamp INTEGER NOT NULL,
844 CREATE TABLE reactions(
845 conversationId STRING,
848 messageReceivedAt INTEGER,
849 targetAuthorAci STRING,
850 targetTimestamp INTEGER,
853 CREATE TABLE senderKeys(
854 id TEXT PRIMARY KEY NOT NULL,
855 senderId TEXT NOT NULL,
856 distributionId TEXT NOT NULL,
858 lastUpdatedDate NUMBER NOT NULL
860 CREATE TABLE unprocessed(
861 id STRING PRIMARY KEY ASC,
868 serverTimestamp INTEGER,
869 sourceServiceId STRING
870 , serverGuid STRING NULL, sourceDevice INTEGER, receivedAtCounter INTEGER, urgent INTEGER, story INTEGER);
871 CREATE TABLE sendLogPayloads(
872 id INTEGER PRIMARY KEY ASC,
874 timestamp INTEGER NOT NULL,
875 contentHint INTEGER NOT NULL,
877 , urgent INTEGER, hasPniSignatureMessage INTEGER DEFAULT
0 NOT NULL);
878 CREATE TABLE sendLogRecipients(
879 payloadId INTEGER NOT NULL,
881 recipientServiceId STRING NOT NULL,
882 deviceId INTEGER NOT NULL,
884 PRIMARY KEY (payloadId, recipientServiceId, deviceId),
886 CONSTRAINT sendLogRecipientsForeignKey
887 FOREIGN KEY (payloadId)
888 REFERENCES sendLogPayloads(id)
891 CREATE TABLE sendLogMessageIds(
892 payloadId INTEGER NOT NULL,
894 messageId STRING NOT NULL,
896 PRIMARY KEY (payloadId, messageId),
898 CONSTRAINT sendLogMessageIdsForeignKey
899 FOREIGN KEY (payloadId)
900 REFERENCES sendLogPayloads(id)
903 CREATE TABLE preKeys(
904 id STRING PRIMARY KEY ASC,
906 , ourServiceId NUMBER
907 GENERATED ALWAYS AS (json_extract(json, '$.ourServiceId')));
908 CREATE TABLE signedPreKeys(
909 id STRING PRIMARY KEY ASC,
911 , ourServiceId NUMBER
912 GENERATED ALWAYS AS (json_extract(json, '$.ourServiceId')));
915 category TEXT NOT NULL,
917 descriptionTemplate TEXT NOT NULL
919 CREATE TABLE badgeImageFiles(
920 badgeId TEXT REFERENCES badges(id)
923 'order' INTEGER NOT NULL,
928 CREATE TABLE storyReads (
929 authorId STRING NOT NULL,
930 conversationId STRING NOT NULL,
931 storyId STRING NOT NULL,
932 storyReadDate NUMBER NOT NULL,
934 PRIMARY KEY (authorId, storyId)
936 CREATE TABLE storyDistributions(
937 id STRING PRIMARY KEY NOT NULL,
940 senderKeyInfoJson STRING
941 , deletedAtTimestamp INTEGER, allowsReplies INTEGER, isBlockList INTEGER, storageID STRING, storageVersion INTEGER, storageUnknownFields BLOB, storageNeedsSync INTEGER);
942 CREATE TABLE storyDistributionMembers(
943 listId STRING NOT NULL REFERENCES storyDistributions(id)
946 serviceId STRING NOT NULL,
948 PRIMARY KEY (listId, serviceId)
950 CREATE TABLE uninstalled_sticker_packs (
951 id STRING NOT NULL PRIMARY KEY,
952 uninstalledAt NUMBER NOT NULL,
954 storageVersion NUMBER,
955 storageUnknownFields BLOB,
956 storageNeedsSync INTEGER NOT NULL
958 CREATE TABLE groupCallRingCancellations(
959 ringId INTEGER PRIMARY KEY,
960 createdAt INTEGER NOT NULL
962 CREATE TABLE IF NOT EXISTS 'messages_fts_data'(id INTEGER PRIMARY KEY, block BLOB);
963 CREATE TABLE IF NOT EXISTS 'messages_fts_idx'(segid, term, pgno, PRIMARY KEY(segid, term)) WITHOUT ROWID;
964 CREATE TABLE IF NOT EXISTS 'messages_fts_content'(id INTEGER PRIMARY KEY, c0);
965 CREATE TABLE IF NOT EXISTS 'messages_fts_docsize'(id INTEGER PRIMARY KEY, sz BLOB);
966 CREATE TABLE IF NOT EXISTS 'messages_fts_config'(k PRIMARY KEY, v) WITHOUT ROWID;
967 CREATE TABLE edited_messages(
968 messageId STRING REFERENCES messages(id)
972 , conversationId STRING);
973 CREATE TABLE mentions (
974 messageId REFERENCES messages(id) ON DELETE CASCADE,
979 CREATE TABLE kyberPreKeys(
980 id STRING PRIMARY KEY NOT NULL,
981 json TEXT NOT NULL, ourServiceId NUMBER
982 GENERATED ALWAYS AS (json_extract(json, '$.ourServiceId')));
983 CREATE TABLE callsHistory (
984 callId TEXT PRIMARY KEY,
985 peerId TEXT NOT NULL, -- conversation id (legacy) | uuid | groupId | roomId
986 ringerId TEXT DEFAULT NULL, -- ringer uuid
987 mode TEXT NOT NULL, -- enum "Direct" | "Group"
988 type TEXT NOT NULL, -- enum "Audio" | "Video" | "Group"
989 direction TEXT NOT NULL, -- enum "Incoming" | "Outgoing
990 -- Direct: enum "Pending" | "Missed" | "Accepted" | "Deleted"
991 -- Group: enum "GenericGroupCall" | "OutgoingRing" | "Ringing" | "Joined" | "Missed" | "Declined" | "Accepted" | "Deleted"
992 status TEXT NOT NULL,
993 timestamp INTEGER NOT NULL,
994 UNIQUE (callId, peerId) ON CONFLICT FAIL
996 [ dropped all indexes to save space in this blog post ]
997 CREATE TRIGGER messages_on_view_once_update AFTER UPDATE ON messages
999 new.body IS NOT NULL AND new.isViewOnce =
1
1001 DELETE FROM messages_fts WHERE rowid = old.rowid;
1003 CREATE TRIGGER messages_on_insert AFTER INSERT ON messages
1004 WHEN new.isViewOnce IS NOT
1 AND new.storyId IS NULL
1006 INSERT INTO messages_fts
1009 (new.rowid, new.body);
1011 CREATE TRIGGER messages_on_delete AFTER DELETE ON messages BEGIN
1012 DELETE FROM messages_fts WHERE rowid = old.rowid;
1013 DELETE FROM sendLogPayloads WHERE id IN (
1014 SELECT payloadId FROM sendLogMessageIds
1015 WHERE messageId = old.id
1017 DELETE FROM reactions WHERE rowid IN (
1018 SELECT rowid FROM reactions
1019 WHERE messageId = old.id
1021 DELETE FROM storyReads WHERE storyId = old.storyId;
1023 CREATE VIRTUAL TABLE messages_fts USING fts5(
1025 tokenize = 'signal_tokenizer'
1027 CREATE TRIGGER messages_on_update AFTER UPDATE ON messages
1029 (new.body IS NULL OR old.body IS NOT new.body) AND
1030 new.isViewOnce IS NOT
1 AND new.storyId IS NULL
1032 DELETE FROM messages_fts WHERE rowid = old.rowid;
1033 INSERT INTO messages_fts
1036 (new.rowid, new.body);
1038 CREATE TRIGGER messages_on_insert_insert_mentions AFTER INSERT ON messages
1040 INSERT INTO mentions (messageId, mentionAci, start, length)
1042 SELECT messages.id, bodyRanges.value -
>> 'mentionAci' as mentionAci,
1043 bodyRanges.value -
>> 'start' as start,
1044 bodyRanges.value -
>> 'length' as length
1045 FROM messages, json_each(messages.json -
>> 'bodyRanges') as bodyRanges
1046 WHERE bodyRanges.value -
>> 'mentionAci' IS NOT NULL
1048 AND messages.id = new.id;
1050 CREATE TRIGGER messages_on_update_update_mentions AFTER UPDATE ON messages
1052 DELETE FROM mentions WHERE messageId = new.id;
1053 INSERT INTO mentions (messageId, mentionAci, start, length)
1055 SELECT messages.id, bodyRanges.value -
>> 'mentionAci' as mentionAci,
1056 bodyRanges.value -
>> 'start' as start,
1057 bodyRanges.value -
>> 'length' as length
1058 FROM messages, json_each(messages.json -
>> 'bodyRanges') as bodyRanges
1059 WHERE bodyRanges.value -
>> 'mentionAci' IS NOT NULL
1061 AND messages.id = new.id;
1066 <p>Finally I have the tool needed to inspect and process Signal
1067 messages that I need, without using the vendor provided client. Now
1068 on to transforming it to a more useful format.
</p>
1070 <p>As usual, if you use Bitcoin and want to show your support of my
1071 activities, please send Bitcoin donations to my address
1072 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
1078 Tags:
<a href=
"http://www.hungry.com/~pere/blog/tags/debian">debian
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/english">english
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/sikkerhet">sikkerhet
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/surveillance">surveillance
</a>.
1083 <div class=
"padding"></div>
1087 <a href=
"http://www.hungry.com/~pere/blog/New_chrpath_release_0_17.html">New chrpath release
0.17</a>
1093 <p>The chrpath package provide a simple command line tool to remove or
1094 modify the rpath or runpath of compiled ELF program. It is almost
10
1095 years since I updated the code base, but I stumbled over the tool
1096 today, and decided it was time to move the code base from Subversion
1097 to git and find a new home for it, as the previous one (Debian Alioth)
1098 has been shut down. I decided to go with
1099 <a href=
"https://codeberg.org/">Codeberg
</a> this time, as it is my git
1100 service of choice these days, did a quick and dirty migration to git
1101 and updated the code with a few patches I found in the Debian bug
1102 tracker. These are the release notes:
</p>
1104 <p>New in
0.17 released
2023-
11-
10:
</p>
1107 <li>Moved project to Codeberg, as Alioth is shut down.
</li>
1108 <li>Add Solaris support (use
<sys/byteorder.h
> instead of
<byteswap.h
>).
1109 Patch from Rainer Orth.
</li>
1110 <li>Added missing newline from printf() line. Patch from Frank Dana.
</li>
1111 <li>Corrected handling of multiple ELF sections. Patch from Frank Dana.
</li>
1112 <li>Updated build rules for .deb. Partly based on patch from djcj.
</li>
1115 <p>The latest edition is tagged and available from
1116 <a href=
"https://codeberg.org/pere/chrpath">https://codeberg.org/pere/chrpath
</a>.
1118 <p>As usual, if you use Bitcoin and want to show your support of my
1119 activities, please send Bitcoin donations to my address
1120 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
1126 Tags:
<a href=
"http://www.hungry.com/~pere/blog/tags/chrpath">chrpath
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/debian">debian
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/english">english
</a>.
1131 <div class=
"padding"></div>
1135 <a href=
"http://www.hungry.com/~pere/blog/Test_framework_for_DocBook_processors___formatters.html">Test framework for DocBook processors / formatters
</a>
1141 <p>All the books I have published so far has been using
1142 <a href=
"https://docbook.org/">DocBook
</a> somewhere in the process.
1143 For the first book, the source format was DocBook, while for every
1144 later book it was an intermediate format used as the stepping stone to
1145 be able to present the same manuscript in several formats, on paper,
1146 as ebook in ePub format, as a HTML page and as a PDF file either for
1147 paper production or for Internet consumption. This is made possible
1148 with a wide variety of free software tools with DocBook support in
1149 Debian. The source format of later books have been docx via rst,
1150 Markdown, Filemaker and Asciidoc, and for all of these I was able to
1151 generate a suitable DocBook file for further processing using
1152 <a href=
"https://tracker.debian.org/pkg/pandoc">pandoc
</a>,
1153 <a href=
"https://tracker.debian.org/pkg/asciidoc">a2x
</a> and
1154 <a href=
"https://tracker.debian.org/pkg/asciidoctor">asciidoctor
</a>,
1155 as well as rendering using
1156 <a href=
"https://tracker.debian.org/pkg/xmlto">xmlto
</a>,
1157 <a href=
"https://tracker.debian.org/pkg/dbtoepub">dbtoepub
</a>,
1158 <a href=
"https://tracker.debian.org/pkg/dblatex">dblatex
</a>,
1159 <a href=
"https://tracker.debian.org/pkg/docbook-xsl">docbook-xsl
</a> and
1160 <a href=
"https://tracker.debian.org/pkg/fop">fop
</a>.
</p>
1162 <p>Most of the
<a href=
"http://www.hungry.com/~pere/publisher/">books I
1163 have published
</a> are translated books, with English as the source
1164 language. The use of
1165 <a href=
"https://tracker.debian.org/pkg/po4a">po4a
</a> to
1166 handle translations using the gettext PO format has been a blessing,
1167 but publishing translated books had triggered the need to ensure the
1168 DocBook tools handle relevant languages correctly. For every new
1169 language I have published, I had to submit patches dblatex, dbtoepub
1170 and docbook-xsl fixing incorrect language and country specific issues
1171 in the framework themselves. Typically this has been missing keywords
1172 like 'figure' or sort ordering of index entries. After a while it
1173 became tiresome to only discover issues like this by accident, and I
1174 decided to write a DocBook "test framework" exercising various
1175 features of DocBook and allowing me to see all features exercised for
1176 a given language. It consist of a set of DocBook files, a version
4
1177 book, a version
5 book, a v4 book set, a v4 selection of problematic
1178 tables, one v4 testing sidefloat and finally one v4 testing a book of
1179 articles. The DocBook files are accompanied with a set of build rules
1180 for building PDF using dblatex and docbook-xsl/fop, HTML using xmlto
1181 or docbook-xsl and epub using dbtoepub. The result is a set of files
1182 visualizing footnotes, indexes, table of content list, figures,
1183 formulas and other DocBook features, allowing for a quick review on
1184 the completeness of the given locale settings. To build with a
1185 different language setting, all one need to do is edit the lang= value
1186 in the .xml file to pick a different ISO
639 code value and run
1189 <p>The
<a href=
"https://codeberg.org/pere/docbook-example/">test framework
1190 source code
</a> is available from Codeberg, and a generated set of
1191 presentations of the various examples is available as Codeberg static
1193 <a href=
"https://pere.codeberg.page/docbook-example/">https://pere.codeberg.page/docbook-example/
</a>.
1194 Using this test framework I have been able to discover and report
1195 several bugs and missing features in various tools, and got a lot of
1196 them fixed. For example I got Northern Sami keywords added to both
1197 docbook-xsl and dblatex, fixed several typos in Norwegian bokmål and
1198 Norwegian Nynorsk, support for non-ascii title IDs added to pandoc,
1199 Norwegian index sorting support fixed in xindy and initial Norwegian
1200 Bokmål support added to dblatex. Some issues still remains, though.
1201 Default index sorting rules are still broken in several tools, so the
1202 Norwegian letters æ, ø and å are more often than not sorted properly
1203 in the book index.
</p>
1205 <p>The test framework recently received some more polish, as part of
1206 publishing my latest book. This book contained a lot of fairly
1207 complex tables, which exposed bugs in some of the tools. This made me
1208 add a new test file with various tables, as well as spend some time to
1209 brush up the build rules. My goal is for the test framework to
1210 exercise all DocBook features to make it easier to see which features
1211 work with different processors, and hopefully get them all to support
1212 the full set of DocBook features. Feel free to send patches to extend
1213 the test set, and test it with your favorite DocBook processor.
1214 Please visit these two URLs to learn more:
</p>
1217 <li><a href=
"https://codeberg.org/pere/docbook-example/">https://codeberg.org/pere/docbook-example/
</a></li>
1218 <li><a href=
"https://pere.codeberg.page/docbook-example/">https://pere.codeberg.page/docbook-example/
</a></li>
1221 <p>If you want to learn more on Docbook and translations, I recommend
1222 having a look at the
<a href=
"https://docbook.org/">the DocBook
1224 <a href=
"https://doccookbook.sourceforge.net/html/en/">the DoCookBook
1225 site
<a/> and my earlier blog post on
1226 <a href=
"http://www.hungry.com/~pere/blog/From_English_wiki_to_translated_PDF_and_epub_via_Docbook.html">how
1227 the Skolelinux project process and translate documentation
</a>, a talk I gave earlier this year on
1228 <a href=
"https://www.nuug.no/aktiviteter/20230314-oversetting-og-publisering-av-b%c3%b8ker-med-fri-programvare/">how
1229 to translate and publish books using free software
</a> (Norwegian
1234 https://github.com/docbook/xslt10-stylesheets/issues/205 (docbook-xsl: sme support)
1235 https://bugs.debian.org/968437 (xindy: index sorting rules for nb/nn)
1236 https://bugs.debian.org/856123 (pandoc: markdown to docbook with non-english titles)
1237 https://bugs.debian.org/864813 (dblatex: missing nb words)
1238 https://bugs.debian.org/756386 (dblatex: index sorting rules for nb/nn)
1239 https://bugs.debian.org/796871 (dbtoepub: index sorting rules for nb/nn)
1240 https://bugs.debian.org/792616 (dblatex: PDF metadata)
1241 https://bugs.debian.org/686908 (docbook-xsl: index sorting rules for nb/nn)
1242 https://sourceforge.net/tracker/?func=detail&atid=373747&aid=3556630&group_id=21935 (docbook-xsl: nb/nn support)
1243 https://bugs.debian.org/684391 (dblatex: initial nb support)
1247 <p>As usual, if you use Bitcoin and want to show your support of my
1248 activities, please send Bitcoin donations to my address
1249 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
1255 Tags:
<a href=
"http://www.hungry.com/~pere/blog/tags/debian">debian
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/docbook">docbook
</a>,
<a href=
"http://www.hungry.com/~pere/blog/tags/english">english
</a>.
1260 <div class=
"padding"></div>
1262 <p style=
"text-align: right;"><a href=
"11.rss"><img src=
"http://www.hungry.com/~pere/blog/xml.gif" alt=
"RSS Feed" width=
"36" height=
"14" /></a></p>
1273 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2025/01/">January (
4)
</a></li>
1275 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2025/02/">February (
3)
</a></li>
1282 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/01/">January (
1)
</a></li>
1284 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/02/">February (
1)
</a></li>
1286 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/03/">March (
2)
</a></li>
1288 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/04/">April (
3)
</a></li>
1290 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/05/">May (
1)
</a></li>
1292 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/06/">June (
1)
</a></li>
1294 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/07/">July (
2)
</a></li>
1296 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2024/12/">December (
1)
</a></li>
1303 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/01/">January (
3)
</a></li>
1305 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/02/">February (
1)
</a></li>
1307 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/04/">April (
2)
</a></li>
1309 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/05/">May (
3)
</a></li>
1311 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/06/">June (
1)
</a></li>
1313 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/08/">August (
1)
</a></li>
1315 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/09/">September (
1)
</a></li>
1317 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/10/">October (
1)
</a></li>
1319 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/11/">November (
4)
</a></li>
1321 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2023/12/">December (
1)
</a></li>
1328 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/02/">February (
1)
</a></li>
1330 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/03/">March (
3)
</a></li>
1332 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/04/">April (
2)
</a></li>
1334 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/06/">June (
2)
</a></li>
1336 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/07/">July (
1)
</a></li>
1338 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/09/">September (
1)
</a></li>
1340 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/10/">October (
1)
</a></li>
1342 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2022/12/">December (
1)
</a></li>
1349 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/01/">January (
2)
</a></li>
1351 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/02/">February (
1)
</a></li>
1353 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/05/">May (
1)
</a></li>
1355 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/06/">June (
1)
</a></li>
1357 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/07/">July (
3)
</a></li>
1359 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/08/">August (
1)
</a></li>
1361 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/09/">September (
1)
</a></li>
1363 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/10/">October (
1)
</a></li>
1365 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2021/12/">December (
1)
</a></li>
1372 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/02/">February (
2)
</a></li>
1374 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/03/">March (
2)
</a></li>
1376 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/04/">April (
2)
</a></li>
1378 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/05/">May (
3)
</a></li>
1380 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/06/">June (
2)
</a></li>
1382 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/07/">July (
1)
</a></li>
1384 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/09/">September (
1)
</a></li>
1386 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/10/">October (
1)
</a></li>
1388 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2020/11/">November (
1)
</a></li>
1395 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/01/">January (
4)
</a></li>
1397 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/02/">February (
3)
</a></li>
1399 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/03/">March (
3)
</a></li>
1401 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/05/">May (
2)
</a></li>
1403 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/06/">June (
5)
</a></li>
1405 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/07/">July (
2)
</a></li>
1407 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/08/">August (
1)
</a></li>
1409 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/09/">September (
1)
</a></li>
1411 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/11/">November (
1)
</a></li>
1413 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2019/12/">December (
4)
</a></li>
1420 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/01/">January (
1)
</a></li>
1422 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/02/">February (
5)
</a></li>
1424 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/03/">March (
5)
</a></li>
1426 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/04/">April (
3)
</a></li>
1428 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/06/">June (
2)
</a></li>
1430 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/07/">July (
5)
</a></li>
1432 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/08/">August (
3)
</a></li>
1434 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/09/">September (
3)
</a></li>
1436 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/10/">October (
5)
</a></li>
1438 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/11/">November (
2)
</a></li>
1440 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2018/12/">December (
4)
</a></li>
1447 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/01/">January (
4)
</a></li>
1449 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/02/">February (
3)
</a></li>
1451 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/03/">March (
5)
</a></li>
1453 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/04/">April (
2)
</a></li>
1455 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/06/">June (
5)
</a></li>
1457 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/07/">July (
1)
</a></li>
1459 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/08/">August (
1)
</a></li>
1461 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/09/">September (
3)
</a></li>
1463 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/10/">October (
5)
</a></li>
1465 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/11/">November (
3)
</a></li>
1467 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2017/12/">December (
4)
</a></li>
1474 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/01/">January (
3)
</a></li>
1476 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/02/">February (
2)
</a></li>
1478 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/03/">March (
3)
</a></li>
1480 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/04/">April (
8)
</a></li>
1482 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/05/">May (
8)
</a></li>
1484 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/06/">June (
2)
</a></li>
1486 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/07/">July (
2)
</a></li>
1488 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/08/">August (
5)
</a></li>
1490 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/09/">September (
2)
</a></li>
1492 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/10/">October (
3)
</a></li>
1494 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/11/">November (
8)
</a></li>
1496 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2016/12/">December (
5)
</a></li>
1503 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/01/">January (
7)
</a></li>
1505 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/02/">February (
6)
</a></li>
1507 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/03/">March (
1)
</a></li>
1509 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/04/">April (
4)
</a></li>
1511 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/05/">May (
3)
</a></li>
1513 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/06/">June (
4)
</a></li>
1515 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/07/">July (
6)
</a></li>
1517 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/08/">August (
2)
</a></li>
1519 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/09/">September (
2)
</a></li>
1521 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/10/">October (
9)
</a></li>
1523 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/11/">November (
6)
</a></li>
1525 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2015/12/">December (
3)
</a></li>
1532 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/01/">January (
2)
</a></li>
1534 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/02/">February (
3)
</a></li>
1536 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/03/">March (
8)
</a></li>
1538 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/04/">April (
7)
</a></li>
1540 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/05/">May (
1)
</a></li>
1542 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/06/">June (
2)
</a></li>
1544 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/07/">July (
2)
</a></li>
1546 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/08/">August (
2)
</a></li>
1548 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/09/">September (
5)
</a></li>
1550 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/10/">October (
6)
</a></li>
1552 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/11/">November (
3)
</a></li>
1554 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2014/12/">December (
5)
</a></li>
1561 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/01/">January (
11)
</a></li>
1563 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/02/">February (
9)
</a></li>
1565 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/03/">March (
9)
</a></li>
1567 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/04/">April (
6)
</a></li>
1569 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/05/">May (
9)
</a></li>
1571 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/06/">June (
10)
</a></li>
1573 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/07/">July (
7)
</a></li>
1575 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/08/">August (
3)
</a></li>
1577 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/09/">September (
5)
</a></li>
1579 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/10/">October (
7)
</a></li>
1581 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/11/">November (
9)
</a></li>
1583 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2013/12/">December (
3)
</a></li>
1590 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/01/">January (
7)
</a></li>
1592 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/02/">February (
10)
</a></li>
1594 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/03/">March (
17)
</a></li>
1596 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/04/">April (
12)
</a></li>
1598 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/05/">May (
12)
</a></li>
1600 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/06/">June (
20)
</a></li>
1602 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/07/">July (
17)
</a></li>
1604 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/08/">August (
6)
</a></li>
1606 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/09/">September (
9)
</a></li>
1608 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/10/">October (
17)
</a></li>
1610 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/11/">November (
10)
</a></li>
1612 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2012/12/">December (
7)
</a></li>
1619 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/01/">January (
16)
</a></li>
1621 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/02/">February (
6)
</a></li>
1623 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/03/">March (
6)
</a></li>
1625 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/04/">April (
7)
</a></li>
1627 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/05/">May (
3)
</a></li>
1629 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/06/">June (
2)
</a></li>
1631 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/07/">July (
7)
</a></li>
1633 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/08/">August (
6)
</a></li>
1635 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/09/">September (
4)
</a></li>
1637 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/10/">October (
2)
</a></li>
1639 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/11/">November (
3)
</a></li>
1641 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2011/12/">December (
1)
</a></li>
1648 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/01/">January (
2)
</a></li>
1650 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/02/">February (
1)
</a></li>
1652 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/03/">March (
3)
</a></li>
1654 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/04/">April (
3)
</a></li>
1656 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/05/">May (
9)
</a></li>
1658 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/06/">June (
14)
</a></li>
1660 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/07/">July (
12)
</a></li>
1662 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/08/">August (
13)
</a></li>
1664 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/09/">September (
7)
</a></li>
1666 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/10/">October (
9)
</a></li>
1668 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/11/">November (
13)
</a></li>
1670 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2010/12/">December (
12)
</a></li>
1677 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/01/">January (
8)
</a></li>
1679 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/02/">February (
8)
</a></li>
1681 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/03/">March (
12)
</a></li>
1683 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/04/">April (
10)
</a></li>
1685 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/05/">May (
9)
</a></li>
1687 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/06/">June (
3)
</a></li>
1689 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/07/">July (
4)
</a></li>
1691 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/08/">August (
3)
</a></li>
1693 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/09/">September (
1)
</a></li>
1695 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/10/">October (
2)
</a></li>
1697 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/11/">November (
3)
</a></li>
1699 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2009/12/">December (
3)
</a></li>
1706 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2008/11/">November (
5)
</a></li>
1708 <li><a href=
"http://www.hungry.com/~pere/blog/archive/2008/12/">December (
7)
</a></li>
1719 <li><a href=
"http://www.hungry.com/~pere/blog/tags/3d-printer">3d-printer (
19)
</a></li>
1721 <li><a href=
"http://www.hungry.com/~pere/blog/tags/amiga">amiga (
1)
</a></li>
1723 <li><a href=
"http://www.hungry.com/~pere/blog/tags/aros">aros (
1)
</a></li>
1725 <li><a href=
"http://www.hungry.com/~pere/blog/tags/bankid">bankid (
4)
</a></li>
1727 <li><a href=
"http://www.hungry.com/~pere/blog/tags/betalkontant">betalkontant (
9)
</a></li>
1729 <li><a href=
"http://www.hungry.com/~pere/blog/tags/bitcoin">bitcoin (
13)
</a></li>
1731 <li><a href=
"http://www.hungry.com/~pere/blog/tags/bootsystem">bootsystem (
17)
</a></li>
1733 <li><a href=
"http://www.hungry.com/~pere/blog/tags/bsa">bsa (
2)
</a></li>
1735 <li><a href=
"http://www.hungry.com/~pere/blog/tags/chrpath">chrpath (
3)
</a></li>
1737 <li><a href=
"http://www.hungry.com/~pere/blog/tags/debian">debian (
209)
</a></li>
1739 <li><a href=
"http://www.hungry.com/~pere/blog/tags/debian edu">debian edu (
159)
</a></li>
1741 <li><a href=
"http://www.hungry.com/~pere/blog/tags/debian-handbook">debian-handbook (
9)
</a></li>
1743 <li><a href=
"http://www.hungry.com/~pere/blog/tags/digistan">digistan (
11)
</a></li>
1745 <li><a href=
"http://www.hungry.com/~pere/blog/tags/dld">dld (
18)
</a></li>
1747 <li><a href=
"http://www.hungry.com/~pere/blog/tags/docbook">docbook (
33)
</a></li>
1749 <li><a href=
"http://www.hungry.com/~pere/blog/tags/drivstoffpriser">drivstoffpriser (
4)
</a></li>
1751 <li><a href=
"http://www.hungry.com/~pere/blog/tags/english">english (
471)
</a></li>
1753 <li><a href=
"http://www.hungry.com/~pere/blog/tags/fiksgatami">fiksgatami (
23)
</a></li>
1755 <li><a href=
"http://www.hungry.com/~pere/blog/tags/fildeling">fildeling (
14)
</a></li>
1757 <li><a href=
"http://www.hungry.com/~pere/blog/tags/freeculture">freeculture (
34)
</a></li>
1759 <li><a href=
"http://www.hungry.com/~pere/blog/tags/freedombox">freedombox (
9)
</a></li>
1761 <li><a href=
"http://www.hungry.com/~pere/blog/tags/frikanalen">frikanalen (
20)
</a></li>
1763 <li><a href=
"http://www.hungry.com/~pere/blog/tags/h264">h264 (
20)
</a></li>
1765 <li><a href=
"http://www.hungry.com/~pere/blog/tags/intervju">intervju (
43)
</a></li>
1767 <li><a href=
"http://www.hungry.com/~pere/blog/tags/isenkram">isenkram (
21)
</a></li>
1769 <li><a href=
"http://www.hungry.com/~pere/blog/tags/kart">kart (
23)
</a></li>
1771 <li><a href=
"http://www.hungry.com/~pere/blog/tags/kodi">kodi (
6)
</a></li>
1773 <li><a href=
"http://www.hungry.com/~pere/blog/tags/ldap">ldap (
9)
</a></li>
1775 <li><a href=
"http://www.hungry.com/~pere/blog/tags/lego">lego (
5)
</a></li>
1777 <li><a href=
"http://www.hungry.com/~pere/blog/tags/lenker">lenker (
8)
</a></li>
1779 <li><a href=
"http://www.hungry.com/~pere/blog/tags/linuxcnc">linuxcnc (
8)
</a></li>
1781 <li><a href=
"http://www.hungry.com/~pere/blog/tags/lsdvd">lsdvd (
3)
</a></li>
1783 <li><a href=
"http://www.hungry.com/~pere/blog/tags/ltsp">ltsp (
1)
</a></li>
1785 <li><a href=
"http://www.hungry.com/~pere/blog/tags/madewithcc">madewithcc (
3)
</a></li>
1787 <li><a href=
"http://www.hungry.com/~pere/blog/tags/mesh network">mesh network (
8)
</a></li>
1789 <li><a href=
"http://www.hungry.com/~pere/blog/tags/multimedia">multimedia (
48)
</a></li>
1791 <li><a href=
"http://www.hungry.com/~pere/blog/tags/nice free software">nice free software (
15)
</a></li>
1793 <li><a href=
"http://www.hungry.com/~pere/blog/tags/noark5">noark5 (
27)
</a></li>
1795 <li><a href=
"http://www.hungry.com/~pere/blog/tags/norsk">norsk (
326)
</a></li>
1797 <li><a href=
"http://www.hungry.com/~pere/blog/tags/nuug">nuug (
200)
</a></li>
1799 <li><a href=
"http://www.hungry.com/~pere/blog/tags/offentlig innsyn">offentlig innsyn (
42)
</a></li>
1801 <li><a href=
"http://www.hungry.com/~pere/blog/tags/open311">open311 (
2)
</a></li>
1803 <li><a href=
"http://www.hungry.com/~pere/blog/tags/opensnitch">opensnitch (
4)
</a></li>
1805 <li><a href=
"http://www.hungry.com/~pere/blog/tags/opphavsrett">opphavsrett (
76)
</a></li>
1807 <li><a href=
"http://www.hungry.com/~pere/blog/tags/personvern">personvern (
114)
</a></li>
1809 <li><a href=
"http://www.hungry.com/~pere/blog/tags/raid">raid (
4)
</a></li>
1811 <li><a href=
"http://www.hungry.com/~pere/blog/tags/reactos">reactos (
1)
</a></li>
1813 <li><a href=
"http://www.hungry.com/~pere/blog/tags/reprap">reprap (
11)
</a></li>
1815 <li><a href=
"http://www.hungry.com/~pere/blog/tags/rfid">rfid (
3)
</a></li>
1817 <li><a href=
"http://www.hungry.com/~pere/blog/tags/robot">robot (
17)
</a></li>
1819 <li><a href=
"http://www.hungry.com/~pere/blog/tags/rss">rss (
1)
</a></li>
1821 <li><a href=
"http://www.hungry.com/~pere/blog/tags/ruter">ruter (
7)
</a></li>
1823 <li><a href=
"http://www.hungry.com/~pere/blog/tags/scraperwiki">scraperwiki (
2)
</a></li>
1825 <li><a href=
"http://www.hungry.com/~pere/blog/tags/sikkerhet">sikkerhet (
60)
</a></li>
1827 <li><a href=
"http://www.hungry.com/~pere/blog/tags/sitesummary">sitesummary (
4)
</a></li>
1829 <li><a href=
"http://www.hungry.com/~pere/blog/tags/skepsis">skepsis (
5)
</a></li>
1831 <li><a href=
"http://www.hungry.com/~pere/blog/tags/standard">standard (
80)
</a></li>
1833 <li><a href=
"http://www.hungry.com/~pere/blog/tags/stavekontroll">stavekontroll (
7)
</a></li>
1835 <li><a href=
"http://www.hungry.com/~pere/blog/tags/stortinget">stortinget (
14)
</a></li>
1837 <li><a href=
"http://www.hungry.com/~pere/blog/tags/surveillance">surveillance (
65)
</a></li>
1839 <li><a href=
"http://www.hungry.com/~pere/blog/tags/sysadmin">sysadmin (
6)
</a></li>
1841 <li><a href=
"http://www.hungry.com/~pere/blog/tags/usenix">usenix (
2)
</a></li>
1843 <li><a href=
"http://www.hungry.com/~pere/blog/tags/valg">valg (
9)
</a></li>
1845 <li><a href=
"http://www.hungry.com/~pere/blog/tags/verkidetfri">verkidetfri (
23)
</a></li>
1847 <li><a href=
"http://www.hungry.com/~pere/blog/tags/video">video (
82)
</a></li>
1849 <li><a href=
"http://www.hungry.com/~pere/blog/tags/vitenskap">vitenskap (
4)
</a></li>
1851 <li><a href=
"http://www.hungry.com/~pere/blog/tags/web">web (
42)
</a></li>
1857 <p style=
"text-align: right">
1858 Created by
<a href=
"http://steve.org.uk/Software/chronicle">Chronicle v4.6
</a>