Kapitel 11. Program. 11.3 Att köra program. 11.1 Skript. 11.2 Interpreterande och kompilerande programspråk. 11.4 Att kompilera program

Relevanta dokument
Kapitel 11. Program Skript Att köra program Interpreterande och kompilerande programspråk

Kapitel 11. Program Skript Att köra program Interpreterande och kompilerande programspråk Att kompilera program

Avslutning. Kapitel Komprimering av filer

Program. Kapitel make Program Interpreterande och kompilerande program

Kapitel 12. Mer om program Att rapportera buggar och problem make

Fria upphovsrättslicenser underlättar kunskapsdelning och lärande

Open Source - Eller som vi säger, Fri programvara

Open Source - Eller som vi säger, Fri programvara

Programmering i C++ Kompilering från kommandoraden

Licenser - Jo, tack, men så få som möjligt

Öppen/Fri programvara

Datorer och datoranvändning Föreläsningar 2014/15. Föreläsning 1 Unix. Operativsystem. Unix

Lab 7, 48 steg till ett bättre liv i Unix-labbet

Denna presentation är inte klar, kommentarer mottages tacksamt! CyberRymden

Svenska Linuxföreningen. Fri programvara Mycket mer än gratis 1(36) Copyright 2005, 2006 Marcus Rejås

NetBeans 5.5. Avsikt. Projektfönster

Omkoppling av in- och utmatning. In- och utmatning i Unix. Kommando exempel, ls, pipe forts. Kommando exempel, ls, pipe

Open Source - Program och hur man väljer

Introduktion till datateknik för språkvetare ht 2007

Allmänt om programvaror och filer i Windows.

Övning Installation av Gentoo och/eller Arch Linux

Creative Commons. en guide för lärare. En guide för lärare

Kort-kort om utdelade användarkonton och datormiljön på NADA

Introduktion till Linux. TDDC66 Datorsystem och programmering Föreläsning (i) Peter Dalenius Institutionen för datavetenskap

Introduktion till Linux. TDDC66 Datorsystem och programmering Föreläsning 1 Peter Dalenius Institutionen för datavetenskap

Introduktion till programmering, hösten 2011

Svenska Linuxföreningen. Fri programvara Mycket mer än bara gratis 1(29)

Introduktion till Unix och Linux

Föreläsning 1 Unix. Datorer och datoranvändning Föreläsningar 2018/19. Operativsystem. Unix

Operativsystem och användargränssnitt

Open Source-licenser

Introduktion till Linux. TDDE23 Funktionell och imperativ programmering, del 1 Föreläsning 1 Peter Dalenius Institutionen för datavetenskap

Datorsystem och programmering

UNIX. Laborations-PM Anders Egneus, Henrik Lindgren, 2004, Raphael Corsoski, Erik Eliasson, Christian von Schultz, 2008.

Programvaror - Jo, tack, det vill vi ha...

Open Source-licenser

Eclipse. Avsikt. Nu ska ett fönster liknande figuren till höger synas.

Föreläsning 2. Operativsystem och programmering

CVS-Introduktion. CyberRymden Introduktion till CVS,17 november (27) Marcus Rejås

NetBeans 7. Avsikt. Projektfönster

Föreläsning 3. Programmering, C och programmeringsmiljö

Inledande programmering med C# (1DV402) Introduktion till C#

Övning 1. Datateknik A, Java I, 5 poäng. Att ladda hem och installera Java Att skriva ditt första Javaprogram Att kompilera och exekvera ditt program

UNIX. 2D1339 Programkonstruktion Hösten 2001 Datorintroduktion Laboration 1. Mål. Vad laborationen går ut på. Redovisning

Objektorienterad programmering i Java I

Dedikerad Server Vilket operativsystem ska jag välja? Är ni i startgroparna och ska beställa en dedikerad server eller en virtuell server?

Editering, Kompilering och Exekvering av Javaprogram

Handbok KAppTemplate. Anne-Marie Mahfouf Översättare: Stefan Asserhäll

Laboration 0. Enhetsbokstaven anges med ett kolon efter och man läser ofta ut detta, exempelvis C:(sekolon).

Unix design. Unix är ett operativsystem från mellan 1969 och 1972, beroende på hur man räknar. Unix utvecklas fortfarande.

GitHub for Windows och GitShell

Subversion. Laboration. Höstterminen 2008 r81. Ronny Kuylenstierna

Kort om World Wide Web (webben)

Open Source - Utmaningar och fördelar

TDP005 Projekt: Objektorienterat system

UNIX Introduktion UNIX. Datorerfarenhet. Vad menar man med operativsystem

Handbok Simond. Peter H. Grasch

Tips och tricks. Några bra tips. Lägg till sökvägar

Föreläsning 3. Programmering, C och programmeringsmiljö

Versionshantering. Problem som uppstår i större (samt även mindre) projekt:

Handbok Svarta lådan. Nicolas Roffet Robert Cimrman Philip Rodrigues Lauri Watts Översättare: Stefan Asserhäll

Handbok Dela Skrivbord. Brad Hards Översättare: Stefan Asserhäll

Lathund för webbpublicering av bilder

Laborationer i kursmomentet Datoranvändning E1. Laboration nr 5: Mer om FrameMaker

Grundkurs 1 IKT Filhantering

1 Vad är Versionshantering? 2 Git. 2.1 GitHub

TDP003 Projekt: Egna datormiljön

Kort-kort om utdelade användarkonton och datormiljön på NADA

DRAFT. CVS kurs laboration 1 Checka in, ut och uppdatera. Marcus Rejås. 17 november 2002

Alla filer som bearbetar PHP script ska avslutas med ändelsen.php, exempelvis ska en indexsida till en hemsida heta index.php

Introduktion till git

Konsolfönster i Windows Momentet ingår i kursen PDA DTR1206 Lab 1 DOS Konsolfönstret

Svenska Linuxföreningen. Fri programvara Mer än bara gratis 1(17) Copyright 2006 Marcus Rejås

Policy för Linnéuniversitetets publicering av digitalt undervisningsmaterial

Handbok KsirK. Gael Kleag de Chalendar Nemanja Hirsl Översättare: Stefan Asserhäll

Innehåll. 1 Inledning 5. 2 Förinställning 6. 3 Anpassa användargränssnittet 7. 4 Anpassa interna inställningar 9. 5 Förbereda att bränna en skiva 10

Unix-miljöer i större sammanhang

Flytt av. Vitec Mäklarsystem

Operativsystem. Innehåll. Operativsystemets funktion. Vad är ett OS? Vart hittar men ett OS? OS hanterar processorns resurser

Instruktion för användande av Citrix MetaFrame

Installationsmanual OpenOffice 3.0

Handbok Kanagram. Danny Allen Översättare: Stefan Asserhäll

FrontPage Express. Ämne: Datorkunskap (Internet) Handledare: Thomas Granhäll

Svenska Föreningen för Upphovsrätt 5 november Mikael Pawlo Något om öppen kod, öppen text och öppen musik

Övningar för del I av kursen

Policy för Skånes Ridsportförbunds närvaro i sociala medier

Inledande programmering med C# (1DV402) Ditt första C#-program med Visual Studio

3. Hämta och infoga bilder

DC ++ o allt annat runt om! (en kom-i-gång guide..) Klicka på File Settings. Färdigt med konfigureringen!

kommando -fl argument

Objektorienterad Programmering (TDDC77)

Handbok Kfloppy diskettformaterare

Windows, vs Mac, vs Linux

Handbok Ark. Matt Johnston Översättare: Stefan Asserhäll

Inledande programmering med C# (1DV402) Introduktion till programmering

DDR PC SOFTWARE 2 RELEASENOTES VERSION 2.5. Swerob Service AB Global Robot Parts AB

INSTALLATIONS ANVISNING

Mer om skalet. Kapitel Omdirigering

Vilken version av Dreamweaver använder du?

Den här texten ska förhoppningsvis underlätta en del av anpassningarna. Det kan säkert finnas en del fel och annat tok.

Transkript:

Kapitel 11 Program Ett datorprogram är en samling instruktioner som beskriver något som en dator ska utföra. 11.1 Skript På s. 35 fick ni skapa skalskript textfiler med flera skalkommandon efter varann och köra dem genom att skriva bash filnamn. Genom att ge ett filnamn som argument till skalet (bash) talar man om att det ska hämta kommandon från den filen. Detta är en slags enkla program. 11.2 Interpreterande och kompilerande programspråk De flesta program man kör är dock inte textfiler utan binärfiler. De innehåller då instruktioner i en maskinnära form (maskinkod) som kan utföras (exekveras, köras) direkt av datorn. Med datorprogram kan man avse både en sådan binärfil, och även källkoden, så som programmet skrivits i något programspråk i en eller flera textfiler. I de flesta programspråk skriver man instruktioner som ligger långt ifrån den typen av instruktioner som datorn kan utföra direkt. Det finns olika sätt att då få datorn att utföra instruktionerna i källkoden: kompilering och interpretering. Kompilering är att översätta källkoden till maskinkod. Översättningen sker med en kompilator ett särskilt program. Sen kör man den resulterande koden. (Källkoden behövs inte längre för att kunna köra programmet. Men om man behöver göra ändringar i programmet behöver man källkoden igen och får lov att kompilera om den efteråt.) Interpretering är att tolka källkoden bit för bit istället, så som skalet tolkar kommandon i ett skalskript. Ett särskilt program, en interpretator, läser och utför dessa instruktioner. (Det finns även mellanlägen mellan kompilering och interpretering.) 11.3 Att köra program Programmen är filer de också. Om man t. ex. kör bildbearbetningsprogrammet Gimp så är det filen /usr/bin/gimp man kör. Det skulle gå att skriva den fullständiga sökvägen /usr/bin/gimp för att köra det programmet, men det räcker med bara gimp. Om man skriver bara ett namn utan katalog så letar nämligen skalet efter en sådan fil i vissa kataloger (däribland bland annat /bin och /usr/bin). Där ligger de flesta av de program du använt hittills, som t. ex. cat, grep, ls, sed osv. Om programfilen inte ligger i en av dessa kataloger måste man skriva ett längre filnamn där man tar med katalogen, med en fullständig eller relativ sökväg. Observera att skalet inte söker filen i aktuell katalog i sådana fall, som annars när man skriver ett filnamn utan katalog. 11.4 Att kompilera program För att kompilera ett program så kör man i de enklaste fallen en kompilator med källkodsfilen som argument. Kompilatorn skapar en ny fil som går att köra. Ett större program består normalt en mängd filer som använder sig av varandra på komplicerade sätt, och för att kompilera detta kan det krävas flera steg. I Unix-världen används oftast ett program make för att göra detta. Den kör alla dessa steg i rätt ordning för att tillverka vissa filer. I en fil Makefile har man skrivit regler som talar om för den vad den ska göra. Man kan ge argument till make som talar om vad det är man vill»tillverka«med det, men bara make utan argument duger ofta. 11.5 Att installera program På en GNU-dator som man själv administrerar är det i allmänhet enklast att inte kompilera program man ska använda själv, utan istället installera fär- 99

11. PROGRAM digkompilerade program som färdiga paket med filer som läggs ut på rätt ställen på disken. Program som sköter sådant kallas pakethanterare. Detta förutsätter att någon har gjort ett sådant paket som passar till ens system, men är det ett välanvänt program så är det antagligen så. Ett paketsystem som många system, bl. a. vårt, använder heter RPM. Men som vanlig användare utan administratörsrättigheter så kan du oftast inte använda dig av sådant eftersom du inte har rätt att lägga filerna på de centrala ställen där de då är tänkta att hamna. Då får du oftast lov att installera program någonstans under din hemkatalog genom att kompilera dem själv. (Så kan det också vara för att ingen har gjort nåt behändigt paket av just det programmet.) Programmen distribueras då i allmänhet i form av ett (komprimerat) filarkiv som källkoden finns i. Du börjar med att packa upp detta filarkiv och sen se efter om det bland filerna finns någon fil README med allmänna instruktioner eller kanske en fil INSTALL med instruktioner om hur du ska installera programmet. (Dessa filer heter ofta just så, med versaler.) Ofta säger instruktionerna att du ska använda make på något sätt. 11.5.1 Att installera med make I GNU har det utarbetats en standard för hur installationen går till. Med distributionen av programmet följer det med ett skalskript configure som man börjar med att köra. Det skapar en fil Makefile som är särskilt anpassad för det system man kör på. Efter det kan man kompilera programmet med make och sedan installera det med make install. I det sista steget kopieras filerna ut till olika ställen i filsystemet. Normalt läggs program i /usr/local/bin/, man-sidor i /usr/local/man/ och diverse andra filer i några andra underkataloger till /usr/local. Men där har vanliga användare inte rätt att lägga filer, så det kommer inte att funka om man inte är systemets administratör! Bland uppgifterna för configure hör att anpassa installationen för den variant av operativsystemet som det kör på just nu. Det gör en mängd tester av vad som finns installerat och inte och hur saker fungerar som fungerar lite olika på olika system. I anropet till configure kan man dessutom tala om olika saker om hur detta program ska kompileras och installeras just denna gång i form av långa väljare. En användbar sådan är --prefix katalognamn för att tala om var programmet och alla dess filer ska installeras, så med t. ex. --prefix ~/foo installeras själva programmen i ~/foo/bin/ osv. Istället för en katalog under ens hemkatalog kan man förstås använda hemkatalogen själv: Med --prefix ~ hamnar själva programmen i ~/bin osv. 11.6 Upphovsrätt och licenser Upphovsrätt gäller för program, både för källkod och maskinkod, precis som för litterära och konstnärliga verk. Inga som har skrivit program för moderna datorer har dock varit döda i sjuttio år så att upphovsrätten har gått ut för deras verk, så som skett för t. ex. Strindberg och Lenngren. 1 Trots det finns det en mängd program som det står en fritt att använda, kopiera och sprida, eftersom programmens författare uttryckligen givit en tillstånd till detta. Sådant sker i form av en licens där upphovsrättsinnehavarna talar om vad de tillåter. I synnerhet är hela operativsystemet GNU sådan»fri programvara«, men för att komma till GNU tar vi först en kort Unixhistoria: 11.6.1 Unix Operativsystemet Unix skapades i slutet av 1960- talet på Bell Labs i USA. I mitten av 1970-talet började det spridas utanför Bell Labs. Det såldes rätt billigt (speciellt till universitet) och gick att köra på relativt billiga datorer (vid en tid när datorer var stora och dyra), vilket bidrog till dess popularitet. Dessutom följde källkoden med så att man kunde se precis hur det fungerade och även införa egna ändringar i systemet. Det ökade populariteten ännu mer i den akademiska världen, där en mängd universitet använde Unix i undervisningen i datorvetenskap. Möjligheten att göra ändringar i koden ledde till att det uppstod en stor mängd varianter av Unix. En viktig variant var BSD (Berkeley Software Distribution) från University of California, Berkeley. Berkeley spred sina tillägg och förändringar fritt, och många använde dessa. På 1980-talet tillverkade flera företag olika enanvändardatorer med Unix arbetsstationer. De var mycket kraftfullare och dyrare än den tidens vanliga persondatorer, och innehöll lite olika versioner av Unix. De olika tillverkarna skickade med olika tillägg från BSD och andra håll, och skrev också mycket egna tillägg (som inte spreds fritt), så de olika Unix-systemen skilde sig åt så pass mycket så att det inte alltid gick rakt av att flytta ett program från ett system till ett annat, trots att alla var Unix i grunden. En viktig del var fönstersystemet X som spreds fritt från Massachusetts Institute of Technology (MIT) där det var skrivet. Även till detta lade de olika tillverkarna till olika nya finesser, så på olika datorer körde man lite olika versioner av X. 1 Detta är förstås skälet till att texter av dessa figurerat i flera övningar. 100

Upphovsrätt och licenser 11.6.2 GNU och fri programvara När Unix var nytt hade de flesta av dess användare möjlighet att läsa koden för att lära sig hur den fungerade och även möjlighet att införa egna ändringar för att få delar av systemet att bete sig annorlunda. Med tiden hade det blivit allt ovanligare. De flesta Unix-användare kom att sitta vid arbetsstationer som till stora delar var som svarta lådor som man inte hade insyn i. Det uppfattades av många som frustrerande vid en tid när en stor del av datoranvändarna var programmerare själva. 1983 utannonserade Richard M. Stallman på MIT planer på att skriva ett fritt operativsystem som skulle få namnet GNU. Eftersom Unix redan då hade en så stark ställning så valde han att det skulle vara Unix-kompatibelt, dvs. bete sig som Unix trots att det inte var Unix. GNU stod för»gnu s Not Unix«. Snart startades en särskild stiftelse, Free Software Foundation (FSF), för att hålla i projektet och även i övrigt verka för fria program. En del program som redan fanns och som var fria kunde användas. T. ex. bestämde Stallman tidigt att man inte behövde skriva ett nytt fönstersystem eftersom fönstersystemet X var fritt. En del tillägg till Unix som skrivits på Berkeley och andra ställen var också möjliga att återanvända. Men den största delen av koden fick man skriva själva. 11.6.3 Linux Många delar av GNU kom snabbt till, och användes som separata delar på andra Unix-system, men en viktig del som kom på efterkälken var den mest centrala delen av operativsystemet, kärnan. Utan den var det inte möjligt att sätta ihop ett helt GNU-system. 1991 offentliggjordes Linux av den finlandssvenske studenten Linus Torvalds. Det var ett litet Unixliknande system, framförallt inspirerat av Minix, ett tidigare minimalt Unixliknande system, gjort särskilt för undervisning i operativsystem av Andrew S. Tanenbaum i Holland. Inom kort sattes hela GNU/Linux-system samman som använde Linux som operativsystemskärna istället för HURD som var den fortfarande bara halvfärdiga kärna som skulle användas i GNU. Oftast kallas sådana system bara för Linux-system, efter den kärna som används. Detta gick att köra på vanliga persondatorer, som annars oftast körde MS-DOS från Microsoft. Persondatorerna hade med tiden blivit så pass kraftfulla att de kunde klara ett mer krävande system. 11.6.4 Unix och Unix-liknande system idag En stor del av Unix-liknande system idag är fri programvara. Det finns nu en mängd olika distributioner av GNU/Linux som publiceras av olika företag och organisationer. Dessa skiljer sig åt mer eller mindre mycket beroende på vilka val distributörerna har gjort angående vilka program som ska vara med och inte vara med. Några av de populäraste distributionerna är Debian GNU/Linux, Ubuntu, Red Hat Enterprise Linux, Fedora, Centos, opensuse och Gentoo. Dessutom finns det fria Unix-liknande system som baserar sig på BSD. På Berkeley fortsatte man nämligen att utveckla koden, och så småningom hade man bit för bit ersatt så många delar med nyskriven kod så att det inte fanns mycket kvar av ursprunglig kod från Bell Labs. Då gjorde man en ansträngning att ersätta även de kvarvarande delarna, så i början av 90-talet kunde man släppa ett nästan komplett operativsystem som var fritt. Fria system som bygger på den koden är FreeBSD, OpenBSD och NetBSD. De vanligaste kommersiella Unix-versionerna är idag AIX, HP-UX, MacOS X och Solaris. Apple har sedan MacOS X (version 10) byggt på ett Unix-liknande system från BSD-familjen. Alla dessa system liknar varandra i stora drag i grunden, och man talar om Unix-liknande system även om system som inte verkligen är Unix, 2 utan kanske bara beter sig som Unix, dvs. är Unixkompatibla. De olika Unix-liknande systemen skiljer sig åt på en mängd små sätt. Det har gjorts flera försök att få dem att närma sig varandra för att underlätta flyttandet av program från ett system till ett annat, och bland annat genom standarderna POSIX och Single Unix Specification (och genom att en del kommersiella system slagits ut på marknaden) är dagens Unix-system mycket mer lika varandra än hur det var för ett par decennier sedan. 11.6.5 GNU GPL och»copyleft«många fria program finns det ofria varianter av. Så är det t. ex. med fönstersystemet X från MIT och med de Unix-tillägg som gjordes för BSD. Företag har vidareutvecklat dessa fria program men inte gjort sina nya versioner till fri programvara. Den som har använt dessa versioner har inte t. ex. kunnat läsa eller ändra i programmet de kört, trots att den ursprungliga versionen var fri programvara. De som skrivit dessa program hade inget emot detta, men för GNU ville man inte ha det så. Man ville att alla som använde de program man skrev skulle använda fria versioner av programmen. 2 Dvs. som är licensierade att använda varumärket Unix, som ägs av The Open Group. 101

11. PROGRAM Figur 11.1: Copyleft-tecknet har bildats genom att spegelvända copyright-tecknet. För att de program som skrevs för GNU skulle fortsätta att vara fria för alla som använde dessa program skrev man en ny licens, GNU GPL (General Public License), där en av de viktigaste nyheterna var något som man kallade för copyleft. Det innebär att man inte tillåter att någon sprider modifierade versioner av programmet om inte dessa ändringar också sprids med samma villkor. Den som delar med sig av program enligt GPL till en grupp människor försäkrar sig alltså inte bara om att programmet är fritt för den gruppen, utan även för dem som den gruppen i sin tur sprider vidare programmet till. Ibland använder man ett spegelvänt copyright-tecken (figur 11.1) för detta. Med tiden har det skapats fler licenser för fri programvara med lite olika egenskaper, men GPL är den klart vanligaste inte bara för sådant som skrivits direkt för GNU, utan även för t. ex. kärnan Linux och webbläsaren Firefox. Istället för att formulera dessa villkor själv brukar man i allmänhet använda någon av de licenser som redan har formulerats. Ett skäl är att det underlättar mycket för den som vill använda programmet om en välkänd licens som man redan känner till har använts. Ett annat är att det underlättar återanvändning av delar av programmet tillsammans med delar av andra program som använder samma licens. Licenser för icke-fria program är i allmänhet utformade som avtal eller överenskommelser mellan två parter. För att få komma åt programmet så förbinder man sig till att uppfylla vissa villkor. En licens som GNU GPL fungerar inte så, utan är helt enkelriktad. Det finns ingenting som man behöver gå med på för att använda ett GPL:at program. Allt licensen gör är att ge andra rätt att göra vissa saker som annars inte hade varit tillåtet på grund av upphovsrätten. De som snarare betonar de tekniska fördelarna som att ökad tillgänglighet av källkoden kan leda till förbättrade program genom att fler har möjlighet att hitta fel eller bidra med fixar brukar istället tala om öppen källkod (open source), och ser det som ett medel till att nå bättre resultat snarare än som ett mål i sig, även om vilka program som är fri programvara och vilka som är öppen källkod i praktiken oftast räknas likadant. 11.6.7 Annat än program Programförfattares fria spridande av sina program har varit en inspiration även för fritt spridande av andra upphovsrättsligt skyddade verk, som texter, bilder och musik. Ett exempel är ett stort samarbetsprojekt som encyklopedin Wikipedia. Licenser som GNU GPL som är gjorda för program passar inte alltid så bra in på annat material. Organisationen Creative Commons har gjort en mängd olika licenser som är till för att upphovsrättsinnehavare ska kunna ge en del av sina rättigheter till allmänheten utan att släppa all kontroll. Dessa används rätt ofta vid spridande av texter, musik, bilder osv. och en del av dessa licenser är»fria«i den betydelse som används inom fri programvara. En del har även en copyleft-klausul, som där kallas för Sharealike. I figur 11.2 ses ikoner som ofta används vid beskrivning av de olika CC-licenserna. Creative Commons. BY = Attribution: man måste ange upphovsmakare. NC = Noncommercial: bara icke-kommersiell spridning är tillåten. ND = No Derivate Works: man får inte sprida härledda verk, bara exakta kopior SA = share alike: man får bara sprida det med samma villkor. En CC-licens använder någon kombination av dessa element, t. ex. Attribution + NoDerivates = by-nd = för något som andra får sprida vidare i oförändrat skick, om de anger ursprung, oavsett om det görs kommersiellt eller inte. 11.6.6 Öppen källkod = Open source Figur 11.2: Byggblock i Creative Commons-licenser. 102

Laboration 11: Program Redovisning Checka in svar på frågorna i en fil ids11.txt i den versionskontrollerade katalog som heter som ditt användarnamn och som du har sedan tidigare. Gör en incheckning redan första dan du hållit på med detta, och en ny efter nästa gång du arbetat med det, osv. Versionskontroll igen Gå i skalet till katalogen alla-stp11 som du skapat tidigare som kontrolleras av Subversion. Kolla läget här med kommandot svn status som säger något om hur din arbetskatalog skiljer sig från vad som finns i repositoriet. Du borde bland annat få rader som? sagobok.aux? sagobok.pdf och några till eftersom LaTeX skapade de filerna när du TeXade sagobok.tex, men Subversion inte vet något om dessa filer. Det är helt i sin ordning. Dessa filer bör inte checkas in, eftersom de skapas automatiskt från andra. Ett M står för modified, så om du har en rad som Ändra i den genom att att ändra rubriken för din saga från ditt användarnamn till nåt som har med innehållet att göra. TEXa filen tills din titel syns även i innehållsförteckningen och checka sedan in din ändring. Skapa kataloger Du har ändrat i filer och skapat nya filer med svn. En sak som återstår är att lägga till nya kataloger. När du lade till en ny fil så skedde det i två steg. Det är likadant med kataloger, men denna gång får du inte hjälp av Emacs utan får ge svn-kommandon själv. Gå till den svn-katalog som heter som ditt användarnamn och skapa en underkatalog saga där, t. ex. med skalkommandot mkdir saga. Sen talar du om för Subversion att den ska hålla koll på denna katalog med svn add saga. Prova härnäst svn status i den katalogen. Uppgift 11.2 Vad får du för output från detta nu? De ändringar som anges av svn status kan checkas in med $ svn commit -m "ett loggmeddelande" M sagobok.tex betyder det att du har gjort ändringar i den filen som du inte har checkat in. (Gör det i så fall!) Ett A står för added, så om du haft en rad som A groda.png skulle det betytt att du har registrerat den filen i Subversion, men sen inte checkat in den ännu. Uppgift 11.1 Ta bort filen sagobok.tex och ge svn status igen. Att en fil som borde finnas saknas i din arbetskatalog vill Subversion verkligen uppmärksamma dig på. Vad använder den för tecken för att markera sådana filer? Eftersom filen var versionskontrollerad kan du hämta tillbaka den från repositoriet igen. Gör svn update så får du den senaste versionen. (Man måste ha ett loggmeddelande. Om man verkligen vill slippa kan man ge ett tomt sådant som "".) Gör så! Kontrollera efteråt att den incheckade katalogen inte längre nämns i outputten från svn status. Nu är den nya katalogen redo och du kan skapa nya filer i den på samma sätt som du gjorde förra veckan. Lägg din gamla klassiska saga.txt i den katalogen och checka in den från Emacs! Att köra program Gå till svn-katalogen som heter som ditt användarnamn. I föräldrakatalogen, alltså din kurskatalog ligger ett program som du körde från den grafiska miljön i uppgift 1.5 (s. 11). 103

LABORATION 11: PROGRAM Om du istället ska köra samma program från skalet kan du använda en relativ sökväg för föräldrakatalogen. Prova! Uppgift 11.3 Hur skrev du då? Gå upp till föräldrakatalogen så att du står i samma katalog som programmet. För att köra programmet härifrån är det enklaste att använda en relativ sökväg som betyder»samma katalog«. Prova! Uppgift 11.4 Att kompilera Hur skrev du då? Gör svn update i svn-katalogen som heter som ditt användarnamn. Det visar sig att en ny fil dyker upp trappa.c. Det är ett litet program i programspråket C. Kompilera programmet med cc trappa.c. (cc är C-kompilatorn.) Det skapas då en ny fil med det körbara programmet. Uppgift 11.5 Vad heter den fil som då skapas? Kör detta program med /local/texts/ jabberwocky som input. (Programmet accepterar inga argument, så du får lov att använda omdirigering.) Uppgift 11.6 Hur skrev du kommandot för att göra detta och hur löd resultatet? Normalt skulle man vilja att detta program vars källkod ligger i trappa.c skulle heta trappa istället. Det finns väljare till cc för att göra så istället, men tillverka istället en sådan fil trappa med hjälp av kommandot make. Kör alltså make trappa. Det skriver ut vilket kommando det i sin tur utför. Uppgift 11.7 Vilken väljare till cc använde make för att tala om vad det kompilerade programmet skulle heta? Uppgift 11.8 Om du gör make trappa igen vad får du du för meddelande från make? Såg du vad programmet gjorde med textfilen? Antagligen kan du inte C, men öppna ändå källkoden med Emacs och se om du kan gissa en del av hur programmet fungerar. Indent betyder indrag. Uppgift 11.9 Vissa delar av programmet är kommentarer de har ingen effekt på vad programmet gör, utan finns där för att underlätta läsningen och förståelsen av programmet. Vad skriver man tydligen före respektive efter kommentarer i C? Ändra i trappa.c så att den gör indrag med mellanrum istället för med understreck. Skriv make trappa för att kompilera om programmet och provkör det för att se att det stämmer, och checka sedan in den ändring du har gjort, med ett loggmeddelande som talar om vad du har ändrat. Link Grammar Uppgift 11.10 I FSF och friprogramvaruvärlden talar man om fyra friheter som ska vara uppfyllda för att program ska räknas som fri programvara. Vilka är dessa fyra? (Sök på nätet.) Du har fått nys om ett program»link Grammar«som du tänker att du skulle behöva använda här. Du skulle kunna be systemadministratören, men du har en känsla av att han är så upptagen med undervisning så det är nog bäst att installera det själv istället. Sök upp den aktuella versionen av det programmet på nätet. Den senaste versionen kom i år, så gäller inte detta den version du har hittat så är det en för gammal version. Uppgift 11.11 Hämta det filarkiv som den aktuella versionen av programmet distribueras i. Vad heter den filen? Lägg filen i din kurskatalog och cd:a dit i skalet. Uppgift 11.12 Ge ett kommando för att packa upp detta filarkiv. Hur lyder ditt kommando? Uppgift 11.13 I en fil där ges licensen enligt vilket programmet skrivs. Vad heter den filen? Uppgift 11.14 Vilka av de fyra friheterna i uppgift 11.10 har man som användare av detta program? Så är det»fri programvara«? Uppgift 11.15 I filen INSTALL står hur man kan installera programmet. Vad används för sökväg till det första steget configure där? (Är det likadant som du gjorde i uppgift???) Läs instruktionerna för hur man ska installera det programmet, och gör så. När configure ska köras, så gör det med --prefix ~/introduktion-till-datateknik för att lägga filerna under din kurskatalog. Nu ska du kunna köra programmet som bin/ link-parser. När man kör igång det får man en prompt linkparser> till vilken man dels kan ge särskilda kommandon, men också skriva engelska meningar för att få dem analyserade av programmet. Uppgift 11.16 Hur ser den första analys ut som programmet ger av meningen»your logic does not resemble our Earth logic.«? 104

Skalskript När du kompilerade programmet så skapades en massa filer som inte längre behövs. En del var bara mellanresultat, och de som var det resultat som du var ute efter har kopierats till en annan katalog när du installerade. Uppgift 11.17 Läs i INSTALL för att se vad du kan ge för make-kommando för att rensa bort de filer där som inte längre behövs och ge det kommandot. Vad var det? På webbsidan om programmet står även hur man kan checka ut den aktuella utvecklingsversionen av programmet. Gör så i din kurskatalog! Uppgift 11.18 göra det? Vad gav du för kommando för att Uppgift 11.19 Filen data/en/4.0.dict där innehåller huvuddelen av det engelska lexikon som systemet använder. I versionskontrolloggen för filen finns en post som innehåller»green«. Hur lyder den? NR-grep Du har fått nys om ett program NR-grep som är ett grep-liknande program, men som bland annat skiljer sig genom en väljare -k med vilken man kan hitta ungefärliga träffar, som kan skilja sig lite från det man letar efter. I exemplet nedan söker jag efter felstavningen»aprksimativ«i en ordlista. Först tillåter jag två skillnader, men hittar ändå inget. När jag tillåter tre skillnader hittar jag ordet. Om jag tillåter hela fyra skillnader finns det flera möjligheter. $ nrgrep -k2 '^aprksimativ$' dsso-list.txt $ nrgrep -k3 '^aprksimativ$' dsso-list.txt approximativ $ nrgrep -k4 '^aprksimativ$' dsso-list.txt approximativ approximativa approximativt predikativ presumtiv primitiv Sök upp detta program på nätet och hämta källkoden (till den senaste versionen). Flytta den till din kurskatalog och packa upp den där. Uppgift 11.20 Vad heter filen du hämtade? Uppgift 11.21 Vad gav du för kommando för att packa upp den? I katalogen du får då hittar du information om hur programmet kan installeras. Gå till den nyskapade underkatalogen och gör så. (Det kommer upp en drös varningar när programmet kompileras, men det är inget du behöver bry dig om. Ifall du vore programmets författare borde du bry dig om dem.) Uppgift 11.22 Ge ett kommando som plockar ut alla ord i dsso-list.txt som ligger högst ett steg ifrån»hund«, samt det resultat du får av detta. När man kör nrgrep -H säger den att det är free software och att man ska se»the GNU General Public License for details«, men här finns motstridig information, för det följer med en fil med programmet som innehåller upphovsrättsinformation som inte är GNU GPL utan en egen text. Uppgift 11.23 Vad heter den filen? Uppgift 11.24 Enligt vad som står om rättigheterna där, vilka av de fyra friheterna i uppgift 11.10 har man som användare av detta program? Så är det»fri programvara«? Skalskript Öppna en ny fil dosaga.sh i katalogen saga som du skapade tidigare i denna labb och skriv där in kommandon som utför alla dessa uppgifter (varav du redan löst de flesta tidigare): Skapa saga-i.txt som innehåller sagan på i- sprikit. Skapa saga-stor.txt som innehåller SA- GAN MED ENBART VERSALER. Skapa saga-robber.txt som innehåller sagan på rövarspråket. (Bryt om resultatet med fmt så att det inte blir väldigt långa rader bara för att orden har blivit längre.) Skapa saga-ord.txt som innehåller en lista över alla ordformer i sagan som förekommer minst två gånger, med frekvenser, i frekvensordning, med det vanligaste ordet först. Genom att du skriver bash dosaga.sh ska nu allt detta utföras. Checka in denna fil dosaga.sh! (Men inte de filer som den skapar.) DSSO I tidigare uppgifter har ni använt Den stora svenska ordlistan, men inte i den form som den distribueras. Gå till http://www.dsso.se/ på webben och hämta den senaste versionen av denna. Det är förmodligen dsso-1.48.txt, för det är det när jag skriver detta i alla fall. Det finns även versioner av ordlistan som är anpassade för att användas av vissa särskilda program, men hämta själva textfilen bara. 105

LABORATION 11: PROGRAM Uppgift 11.25 Vilken licens sprids den ordlistan med och vilken teckenkodning använder den filen? Filen du har hämtat innehåller ordlistans information på ett särskilt textformat. Du kan se efter själv hur innehållet i filen är upplagt, eller läsa den beskrivning som också finns på webbsidorna. En sak att märka är att det bara är rader med < och > som innehåller ordformer. Lägg filen i din svn-arbetskatalog som heter som ditt användarnamn och skapa en fil dsso.sh i samma katalog. Checka in den, fast den är tom, så att jag ser att du kommit igång med denna uppgift. Här ska du skriva ett skalskript så att om du ger kommandot bash dsso.sh skapas en fil ordformer.txt som innehåller en UTF8-fil med en ordform per rad. Hoppa över flerordsuttryck från filen som»au pair«och»science fiction«. Använd gärna flera skalkommandon i rad och lagra mellanresultat i filer som du tar bort i slutet av skalskriptet. Det första skulle t. ex. kunna vara ett kommando som skapar en fil dsso-u8.txt som är likadan som originalet, men omvandlad till UTF8. Senare i skalskriptet skulle du i så fall göra rm dsso-u8.txt för att rensa upp efter dig. * * * Tips: Fokusera inte på att det ska bli ett skalskript till att börja med, utan försök bara hitta kommandon för att lösa uppgiften. Sen kan du stoppa in dem i ett skript. I skalskript kan man skriva kommentarrader som börjar med»#«. Använd det för att förklara vad som händer, t. ex. med en kommentarsrad # Omvandla till UTF8 före första kommandot. 106