forked from rostgaard/Linuxbog
-
Notifications
You must be signed in to change notification settings - Fork 1
/
README
541 lines (393 loc) · 19.9 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
Dette er README filen til bøgerne "Linux -- Friheden til at vælge".
Indholdet er flyttet over i:
http://www..linuxbog.dk/dokumentation/bog/ftav.html
(dokumentation/ftav.sgml)
Herunder slettes snart (chlor):
-------------------------------------------------------------------------------
* Indhold
1) Hvad er "Linux -- Friheden til at vælge" (FTAV)
2) Bygning af bøgerne fra kildekode
3) Adgang til kildekoden fra CVS
4) Mere om bygning af bøgerne fra CVS
-------------------------------------------------------------------------------
1) Hvad er Linux -- Friheden til at vælge (FTAV)
"Linux -- Friheden til at vælge" er en række bøger om Linux, Unix og
andre relaterede emner, som er skrevet af en gruppe frivillige,
fortrinsvis medlemmer af Linux brugergruppen "Skåne-Sjælland Linux
User Group" (SSLUG; http://www.sslug.dk/).
FTAV udgives med jævne mellemrum på http://www.linuxbog.dk/ . Her kan
du downloade færdige udgaver af bøgerne, i flere forskellige
formater. Nogen formater er velegnet til online brug, f.eks. HTML,
andre egner sig bedre til tryk, f.eks. PDF, ligesom der er formater
til palmpilot, mv. Endeligt er kildeteksten til bøgerne, svarende til
de færdige udgaver også tilgængeligt her.
Udviklingen af bøgerne -- rettelser, opdateringer, mv -- foregår på
http://cvs.linuxbog.dk/ . Her finder du i princippet det samme som på
http://www.linuxbog.dk/, men bøgerne indeholder de sidste rettelser
(og fejl, unøjagtigheder, mv) som forfatterne har tilføjet. Her findes
også information om hvordan du kan komme i kontakt med
forfatterne/udviklerne på bøgerne.
-------------------------------------------------------------------------------
2) Bygning af bøgerne fra kildekode
Der er relativt få grunde til at bygge bøgerne selv fra kildekode. Her
opsummerer vi et par af de årsager der kan være.
- Du ønsker at skrive et afsnit til bøgerne, eller at rette noget der
allerede er skrevet og vil derfor gerne kunne bygge dem selv.
- Du ønsker at bygge bøgerne på en anden måde (f.eks. anden sidebredde
til fast tryk) end de bliver bygget på linuxbog.dk.
Hvis ikke du har et af ovennævnte behov, burde du kunne "nøjes" med de
færdigbyggede bøger på cvs.linuxbog.dk, eller www.linuxbog.dk. Hvis du
vil bygge bøgerne selv, bliver det i det følgende beskrevet hvordan
dette gøres.
For at kunne bygge bøgerne, skal du have en del forskellige programmer
installeret. Det drejer sig om værktøjer der kan oversætte sgml koden
(som bøgerne er skrevet i) til de forskellige formater (html, pdf, ps,
palm pilot, mv) som bøgerne kan oversættes til.
Fremgangsmåden for at bygge bøgerne er lidt forskellig, afhængigt af
hvordan du har fået fat i kildeteksterne. Hvis du har fået CVS adgang
til kildekoden, skal du starte med at læse afsnittet nedenfor kaldet
"Adgang til kildekoden fra CVS". I det følgende beskrives hvordan en
enkelt bog, downloadet som en tar.gz fil, oversættes.
Først skal du udpakke bogen, f.eks. med kommandoen
$tar zxvf linuxbog-applikationer-dist-*.tar.gz
Derefter skal du skifte til kataloget er der blevet oprettet, og
konfigurere bogen:
$cd applikationer
$./configure --help
Ved at skrive --help vil du få en oversigt over de argumenter
configure kan tage. Som udgangspunkt burde det ikke være nødvendigt at
anvende nogen argumenter, men der kan være situationer hvor det er ønskværdigt.
Du kan nu konfigurere bygning af bogen, med f.eks.
$./configure --enable-softlink
Herefter vil configure undersøge dit system for at finde ud af om du
har de nødvendige værktøjer til at bygge bogen med. Hvis configure
finder ud af at du mangler centrale værktøjer, vil den afbryde med en
fejl. Det kan f.eks. være at du mangler programmet "jade" som kan læse
sgml filer, eller programmet "jw" som er en frontend til jade. Disse
programmer er altid krævet for overhovedet at kunne oversætte
bøgerne. For de forskellige formater bøgerne skal oversættes til,
kræves desuden nogle forskellige værktøjer. F.eks. kræves programmet
"db2html" for at kunne lave en udgave af bøgerne i html
format. Configure programmet vil ikke afbryde hvis disse værktøjer
mangler, men blot konfigurere oversættelsen således at disse ikke kan
bygges. Til slut vil configure udskrive en oversigt over hvilke
formater der kan oversættes til. Det kan f.eks. se sådan her ud:
configure: Oversigt over hvilke moduler der kan laves
configure: Kan SGML bygges : ja
configure: Kan PALM bygges : nej
configure: Kan PDF bygges : ja
configure: Kan HTML bygges : ja
configure: Kan PAKHTML bygges : ja
Hvis det format du gerne vil bygge til, ikke understøttes, kan du
kigge i det configure har skrevet for at finde årsagen. Eksempelvis
finder jeg følgende linie:
checking for plucker-build... nej - det er ikke muligt at lave PALM udgaven
og ud fra det kan jeg altså regne ud at jeg skal bruge programmet
"plucker-build" for at kunne bygge bøgerne til palmpilot.
Hvis du mangler nogen værktøjer må du installere dem, og køre
configure igen. Hvis du har vanskeligt ved at finde ud af hvorfor du
ikke kan bygge et bestemt format, kan du kigge i filen "config.log"
hvor configure skriver detaljeret information om hvad det foretager
sig.
Når du har fået support for de formater du gerne vil have, kan du
skrive f.eks.
$make html
for at lave html udgaven. Eller, make pdf for at lave pdf udgaven,
osv. Bemærk at palm formatet hedder palmpilot.
-------------------------------------------------------------------------------
3) Adgang til kildekoden fra CVS
For at få adgang til bøgerne via CVS, skal du vise at du vil være
aktiv og kan arbejde ansvarligt med bøgerne :) Få login på
tyge.sslug.dk ved at skrive til Peter Toft <[email protected]> og gør
dernæst følgende.
Installer OpenSSH på din maskine og følg
vejledningen på
http://cvs.linuxbog.dk/sikkerhed/bog/sikker-net-trafik.html
http://cvs.linuxbog.dk/sikkerhed/bog/opsaetning-af-openssh.html
Gør følgende (Linier med * udføres kun første gang)
* mkdir public_html
* chmod a+rx ~ ~/public_html
cd public_html
* cvs -d /usr/local/CVSROOT checkout linuxbog
cd linuxbog
./configure <<--- NB, se afsnit længere ned om byggesystemet.
cd BOGNAVN
make html
Så kan du køre
Netscape http://cvs.sslug.dk/~DITLOGIN/linuxbog/java/bog
Og teksten kommer på web hver morgen
http://cvs.linuxbog.dk
configure --help fortæller om nogle options, blandt andet
--med-alle, som får make til at generere et arkiv og en
samlet html-version af alle bøgerne.
Du kan også køre ./configure i de enkelt bog-directories.
cd BOGNAVN && ./configure -- men det er kun nødvendigt,
hvis du selv har ændret i bootstrap.subdir.
Hvis du gerne vil have filerne hjem, så kan du sætte
følgende miljø-variabel (environment-variable)
export CVS_RSH=ssh
og skrive
cvs -d [email protected]:/usr/local/CVSROOT checkout linuxbog
hvorefter du bør få bogen checket ud.
Hvis du kun vil have en enkelt bog checket ud, bruger du top-navnet:
cvs -d [email protected]:/usr/local/CVSROOT checkout linuxbog/friheden
Den samlede størrelse af CVS-checkout af alle bøger er ca. 30MB
De enkelte bøger varierer fra < 1.0 MB (dokumentation) til
8.8 MB (applikationer)
Læs http://cvs.linuxbog.dk/program/bog/vaerktoej.html#VAERKTOEJ-CVS
-----------------------------------------
Hvis nogen af jer har lyst til at få email hver gang
der ryger en fil ind i CVS-arkivet (cvs commit), så kan
I tilmelde jer <[email protected]> ved
at skrive til <[email protected]>
I som har konto på tyge kan bruge
$ cd katalog
$ cvs watch add
til at følge de filer I er interesserede i.
Hvordan ser de mails så ud man kan modtage på den nye
liste? De vil indeholde info om hvem som lavede
ændringen (pto), hvilket projekt der er
ændret (linuxbog) og hvilke filer som er ændret (her
kun hjaelpe.html) og man få den log-besked vi skriver
hver gang (kan ses i
http://cvs.linuxbog.dk/cvs2html/ ->
http://cvs.linuxbog.dk/cvs2html/cvs_crono.html)
Man får således ikke selve ændringen at se kun
log-beskeden og hvad der er ændret - og af hvem.
--------------------------------------------
Vejledning i at skrive
Læs http://cvs.linuxbog.dk/dokumentation/bog/docbook.html
Hver bog er organiseret gennem bog.sgml og indhold.sgml
pga. integration med "alle-upgaven" (alle bøgerne
samlet) så er det smart at jeg i bog.sgml anfører
filernes kobling til et SGML-tag - eksempler
<!entity java-indledning SYSTEM "indledning.sgml">
<!entity java-indhold SYSTEM "indhold.sgml">
<!entity java-appendixRevHist SYSTEM "apprevhist.sgml">
<!entity java-forord SYSTEM "forord.sgml">
og at jeg sidst i filen bog.sgml siger at NU kommer
java-indhold - i praksis skriver du &java-indhold;
og dermed kopieres filen indhold.sgml ind (jfr.
ovenstående).
Hvis du så kigger i indhold.sgml så vil jeg i bunden
bruge din indhold.sgml ved at skrive
&java-forord; <---- defineret i bog.sgml
&java-indledning; <---- do.
&java-appendixRevHist; <---- do. versionshistorien.
Dermed kommer de tre filer ind i følgende rækkefølge
forord.sgml
indledning.sgml
apprevhist.sgml
Når I har indført en ny fil VM.sgml og den skal med i
f.eks. java bogen, så skal I indføje en linie i bog.sgml
<!entity java-VM SYSTEM "VM.sgml">
og i indhold.sgml skal I på passende sted referere
&java-VM;
Dernæst skal I tilføje en linie under den rette bog i
linuxbog/alle/bog.sgml - samme som i bog.sgml for den
enkelte bog - men med ../../../ sat foran stien. På den
måde vil alle-bogen også være opdateret.
<!entity java-VM SYSTEM "../../../VM.sgml">
---------------------------------------
Tag id
XML versionen kræver, at alle tags skrives med små bogstaver og
alle tags har formen <tag [attributer]>tagged text</tag>
Afsnit tags, fx. <sect1 id="xx-beskrivende-navn"> bliver brugt
til at give html-filerne navne, så det beskrivende navn vælges
med omhu. Det er vistnok en god ide at bruge en bogstavkode for
selve bogens navn, altså: erstat xx med den identifikation, som
benyttes for den bog, du skriver på.
---------------------------------------
Notation for skrivning
For at bøgerne ligner hinanden mest muligt i de viste
eksempler, skal der anvendes samme brugernavn og
maskinnavn i alle bøger.
Den primære bruger er 'tyge' og hans fulde navn er
'Tyge Brahe'. Denne bruger symbolisere brugeren
selv. Skal der illustreres andre brugere der
kommunikeres med, eller der skal oprettes på et
system, bruges:
otto 'Otto Brahe'
axel 'Axel Brahe'
Valget af 'tyge', 'otto' og 'axel' udemærker sig ved
at de alle har 4 tegn i navnet, og giver overskuelig
liste når de bliver brugt i eksempler.
Den primære maskine som brugeren fysisk sidder ved
hedder 'hven.sslug.dk', hvor normalt brug så blot er
'hven'. Skal der kommunikeres med andre maskiner,
hedder de:
saltholm.sslug.dk
peberholm.sslug.dk
E-mail eksempler:
"Tyge Brahe" <[email protected]>
"Tyge Brahe" <[email protected]>
"Otto Brahe" <[email protected]>
"Axel Brahe" <[email protected]>
En normal-prompt (bash) i homedir bliver så:
[tyge@hven ~]$
Det er ikke på forhånd givet at 'otto' og 'axel'
har login på 'hven.sslug.dk', det skal fremgå af
eksemplet.
Baggrund: Tyge Brahe (latinsk: Tycho) er en kendt
dansk astronom der blev født på Sjælland og voksede
op i Skåne. Sidst bosat på Hven. Otto er hans far
og Axel er hans bror.
Valget af Tyge Brahe som eksempel betyder ikke at
alle medlemmer af LinuxBog-redaktionen anerkender
det Tychoniske-verdensbillede (jorden i midten).
Jvf. afsnittet om tidszoner, tror heller ikke alle
at jorden er flad, det ville dog have gjort det
hele lidt nemmere.
-------------------------------------------------------------------------------
4) Mere om bygning af bøgerne fra CVS
Dette afsnit er til dig der har fået CVS adgang, eller dig der har
haft det igennem et stykke tid, men gerne vil vide hvordan
byggesystemet fungerer (eller forsøger at fungere).
Først beskrives hensigten med det nuværende system, derefter beskrives
hvordan det virker, og hvilke muligheder man har med det.
Når man checker bøgerne ud fra CVS, vil jeg referere til det katalog
der hedder "linuxbog" som "toplevel" og de enkelte bøgers kataloger
(f.eks. applikationer, sikkerhed, mv) som subdir.
* Hensigten med byggesystemet.
Hensigten med det byggesystem vi bruger i CVS og i de enkelte subdirs,
er at
a) Det skal være nemt for folk at bidrage til de enkelte bøger, _uden_
at have skriveadgang til CVS.
b) Alle bøger skal kunne bygges til html, palmpilot, mv, afhængigheder
skal fungere korrekt
c) Alle bogen skal kunne bygges
d) Der skal være install, uninstall, mv, targets
e) På sigt skal man kunne bygge bøgerne under andre platforme end Linux
(f.eks. FreeBSD)
Motivation og uddybning af disse punkter:
a) Tidligere har det været vanskeligt at bidrage til bøgerne af to
hovedårsager: Den eneste måde at få adgang til _alle_ de nødvendige
filer, var ved at få adgang til CVS udgaven af bøgerne & tests for
de nødvendige værktøjer var uigennemskuelig og flettet ind i
makefilerne.
At få adgang via CVS var problematisk af to årsager. For det første
skulle der skriveadgang til, samt login på CVS serveren. For det
andet er det ikke alle der er fortrolige med CVS.
De tests der har været for de forskellige værktøjer var tidligere
dels inkomplette, dels lagt ind i selve makefilerne. Det betød at
det var vanskeligt for brugeren at finde ud af hvorfor
oversættelsen gav problemer. I praksis var det en langvarig
"trial-and-error" proces, indtil man opnåede det ønskede
resultat.
Med autotools udgaven af bøgerne (hvor autotools bruges til at lave
de nødvendige makefiler, mv) forsøges disse problemer
løst. Problemet med tests er løst ved at lade autotools (autoconf)
håndtere nødvendige tests. Det har den fordel at brugeren kan køre
./configure og få en oversigt over hvilke værktøjer der
mangler. Når disse er installeret burde brugeren have en høj grad
af sikkerhed for at testene virke. Test gennemføres kun i subdirs,
da det er disse der skal bygges (som de enkelte bøger). Problemet
med distribution af kildekoden er klaret ved at lave et nyt
toplevel target "dist", der laver distributioner af de enkelte
bøger. De pakker man får ud af dette, er i princippet "stand-alone"
og har ikke nogen afhængigheder til resten af kildekoden.
b) Ikke noget overraskende i dette. Imidlertid vil det nye system (når
det er færdigt) forhåbentligt have mere orthogonale afhængigheder,
og de problemer der pt. er med at f.eks. html og pdf rører ved
"hinandens" filer, vil være fjernet. Der mangler en del her.
c) Det nye i forhold til det eksisterende system vil være at man kan
lave en "personlig" alleudgave af bøgerne, der indeholder præcist
de bøger man er interesseret i. Dette fungerer stort set - dog er
der problemer med ps udgaven i øjeblikket.
d) På sigt skal der implementeres install og uninstall targets, så en
systemadministrator f.eks. kan vælge at installere bøgerne for en
større gruppe af brugere på en struktureret måde.
e) Med udgangspunkt i autotools, skal der findes alternativer til de
platforme der ikke har f.eks. jw i en tilstrækkelig ny
udgave. (pto?)
* Hvordan virker byggesystemet
Byggesystemet er (pt) en blanding af autotools til subdirs, og
håndskrevne scripts til toplevel.
Den ultrakorte udgave af "hvordan man gør", efter udcheck fra CVS for
at bygge bogen "BOGNAVN" som html er som følger:
./configure <options>
cd BOGNAVN
make html
Men, det er langt fra hele historien.
Ideen med configure scriptet i toplevel er at det skal anvendes til at
opsætte hvilke (og eventuelt hvordan) bøger man ønsker bygget på sin
maskine. Dette bestemmes ved at give en række argumenter til
configure. Hvis du kører ./configure --help, vil du se følgende:
----------------------------------
`configure' opsætter hvilke af "Linux - friheden til at vælge bøgerne" der skal
laves på dit system.
Brug: ./configure [OPTIONS] [-- SUBDIROPTIONS]
Hvor OPTIONS kan være een eller flere af
-h, --help Viser denne hjælp og afslutter
-m, --med "BØGER" Bestemmer hvilke bøger der medtages, hvor BØGER
er en liste af bøger. Kombiner:
"itplatform friheden unix kontorbruger applikationer wm signatur admin sikkerhed program web c java dokumentation forsker"
-a, --med-alle Medtag alle (een stor bog) bogen
-u, --bogurl URL Hvilken url bøgerne skal bruge. [cvs.linuxbog.dk]
Hvor SUBDIROPTIONS kan være
--enable-softlink Bruger softlinks for HTML targets
Eksempel: ./configure --med "friheden applikationer" -- --enable-softlink
----------------------------------
I det følgende vil disse argumenter blive uddybet.
--med "BØGER" argumentet, bruges til at fortælle _hvilke_ bøger du
gerne vil have bygget på dit system. ./configure --help vil udskrive
en liste af dem der mulige (se ovenfor). Så, hvis du f.eks. gerne vil
have bygget de bøger der anbefales når du vil lære hvordan man bruger
en Linux maskine til at programmere med, kan du give configure
argumentet --med "friheden unix program c java". Så vil configure
sørge for at opsætte systemet, således at disse bøger vil blive
oversat. Hvis du ikke angiver noget --med argument, vil alle bøger
blive medtaget.
--med-alle argumentet bruges til at angive at man vil have bygget den
særlige "alle" bog. Det er en udgave hvor de forskellige bøger flettes
ind i hinanden. --med argumentet bruges af --med-alle; hvis du har
angivet et --med argument, bruges kun de bøger i dette argument til
--med-alle. Rækkefølgen er også som i --med, hvis det er angivet.
--bogurl bruges fortrinsvist når vi udgiver en bog på nettet - så
bygges bøgerne så interne (explicitte) referencer til &linuxbogurl;
refererer til www.linuxbog.dk - normalt er det cvs.linuxbog.dk.
SUBDIROPTIONS er argumenter der ikke bruges af configure programmet
selv, men gives videre til configure i de forskellige subdirs. Se
afsnittet om at bygge fra kildekode tidligere i denne fil.
Her er en liste af filer der anvendes direkte af byggeprocessen i toplevel.
configure dette script kopierer en række filer til de forskellige
subdirs, og kører "bootstrap", samt "configure" i disse
subdirs.
Makefile.in denne fil laves af configure om til Makefile i
toplevel.
faelles-filer/* disse filer kopieres af configure til de forskellige
subdirs, som subdir/*
bootstrap.subdir denne fil kopieres til de forskellige subdirs, som
subdir/bootstrap
Makefile.subdir denne fil kopieres af configure til de forskellige
subdirs som Makefile.am, som af subdir/bootstrap
laves om til Makefile
configure.ac.subdir kopieres af configure til de forskellige subdirs
som subdir/configure.ac
Endvidere kopieres scriptet "misc/insertimagesize" til subdir/misc/,
samt de forskellige palm relaterede filer fra misc til
subdir/palm-faelles/
Makefile.alle Denne fil kopieres af configure til alle/Makefile.am,
hvis --med-alle argumentet blev angivet.
Når configure er færdig med at kopiere, kører configure
subdir/bootstrap og subdir/configure SUBDIROPTIONS for alle de bøger
der skal opsættes. Bootstrap kører de forskellige autotools værktøjer
der skal til for at opsætte de forskellige subdirs. Bemærk at det
således er nødvendigt at have autotools værktøjerne for at bygge
bøgerne fra CVS, men det er _ikke_ nødvendigt for at bygge
individuelle bøger hentet i *dist* pakker.
Den centrale del af det videre byggeforløb ligger i filerne
"Makefile.subdir" (der via toplevel/configure og subdir/configure
bliver til subdir/Makefile). Denne fil er den centrale at modificere
for at rette de tilbageværende problemer i byggeprocessen.
splitstikord.pl
---------------
Scriptet 'splitstikord.pl' der sørger for at blande alle
stikord.html filerne sammen fra alle bøgerne, og dernæst lave
en fil for hvert bogstav, kræver at perl-pakken HTML::TreeBuilder
er installeret. Det er ikke alle der har den default.
På tyge.sslug.dk der kører Red Hat 9.0 (for tiden), er pakken
http://dag.wieers.com/packages/perl-HTML-Tree/perl-HTML-Tree-3.17-0.dag.rh90.noarch.rpm
blevet installeret. Original-pakken findes på
http://search.cpan.org/dist/HTML-Tree/