KDevelop4/Manual/Sessioner og projekter

From KDE UserBase Wiki
Revision as of 12:22, 20 May 2011 by Claus chr (talk | contribs) (Importing a new version from external source)

Sessioner og projekter: KDevelops grundlag

I dette afsnit vil vi gennemgå noget af terminologien, som KDevelop bruger til at beskrive verden og strukturere sit arbejde. I særdeleshed vil vi introducere begreberne sessioner og projekter og forklare, hvordan du kan opsætte de projekter, som du vil arbejde på i KDevelop.

Terminologi

KDevelop bruger begreberne sessioner og projekter. En session indeholder alle de projekter, som har noget med hinanden at gøre. I de eksempler, der følger antager vi, at du både udvikler et bibliotek og et program, som bruger det. Du kan tænke på en centralt KDE-bibliotek som det første og KDevelop som det andet. Et andet eksempel kunne være en Linux-kerneudvkler, som også arbejder på en enhedsdriver til Linux, som ikke er indføjet i selve kernen endnu.

Tager vi det sidste som eksempel, så ville du have en session i KDevelop, som har to projekter: Linux-kernen og enhedsdriveren. Du vil nok samle dem i en enkelt session (i stedet for at have to sessioner med et projekt i hver), fordi det vil være nyttigt at kunne se kernefunktioner og -datastrukturer i KDevelop, når du skriver kildekode til driveren — så kan du for eksempel få navne på kernefunktioner og -variable automatisk fuldført, og du kan se dokumentation for kernefunktioner mens du arbejder med driveren.

Forestil dig nu, at du også er en KDE-udvikler. Du kan så have endnu en session, som indeholder KDE som et projekt. Du kan i princippet nøjes med én session til det hele, men det er der ingen grund til: når du arbejder med KDE, så har du ikke brug for adgang til kerne- og enhedsdriver-funktioner; og du har ikke brug for automatisk færdiggørelse af KDE-klassenavne, mens du arbejder på Linux-kernen. Endelig er bygning af KDE-biblioteker uafhængig af bygning af Linux-kernen (hvorimod det altid er en god idé at bygge Linux-kernen igen, når du har bygget enhedsdriveren, hvis nogle af kerne-headerne er blevet ændret).

Endelig kan du bruge sessioner, hvis du både arbejder på den aktuelle udviklingsversion af et projekt og på en forgrening: i det tilfælde vil du ikke have, at KDevelop forveksler klasser, som hører til hovedudgaven med nogle, som tilhører forgreningen, så du har to sessioner med det samme sæt af projekter med fra forskellige mapper (svarende til de forskellige udviklingsudgaver).

Opsætning af en session og import af et eksisterende projekt

Lad os holde os til eksemplet med Linux-kernen og enhedsdriveren — du kan erstatte dem med dit egen sæt af biblioteker og projekter. For at lave en ny session, som indeholder to projekter går du til menuen Session -> Start ny session øverst til venstre (eller hvis det er første gang, du bruger KDevelop, så kan du simpelt hen bruge den tomme standardsession, som du får til at begynde med). Gå dernæst til menuen Projekt for at lave et projekt til Linux-kernen i denne session. Følg disse skridt:

  • Gå til menuen Projekter -> Hent projekt... for at importere et projekt
  • Du har nu flere muligheder for at starte et nyt projekt i den aktuelle session afhængigt af, hvor kildefilen kommer fra: Du kan dirigere KDevelop til en eksisterende mappe eller du kan bede KDevelop om at hente kildekoden fra et arkiv. Lad os se på disse forskellige muligheder en ad gangen:
  • Hvis du ønsker at arbejde med et projekt, som allerede findes på din harddisk, så vælg som kilde Hent ikke og vælg den mappe, hvor dit projekt er gemt som Arbejdsmappe. Det kunne være en mappe, hvor du har udpakket en tar-fil, som du har downloadet eller det kunne være mappe, hvortil du har overført en version af projektet ved hjælp af et versionskontrolsystem (fx git eller subversion).
  • Alternativt, hvis du fx ønsker at arbejde med den aktuelle udviklingsversion af deal.II og ikke allerede har overført en version:
    • I dropnedlisten under Vælg kilde vælg Subversion, Git eller en af de andre valgmuligheder
    • Vælg en arbejdsmappe, hvor kildekoden overføres til som destination
    • Vælg en URL for placeringen af arkivet, hvor kildekoden kan hentes
    • Klik på Hent. Dette kan tage ret lang tid afhængigt af, hvor hurtig din forbindelse er og hvor stort projektet er. Desværre viser fremskridtslinjen i KDevelop faktisk ingenting, men du kan følge fremgangen ved periodisk at se på outputtet af kommandoen du -sk /path/to/KDevelop/project for at se, hvor meget data der allerede er blevet downloadet.

Note

Problemet med fremgangslinjen er blevet rapporteret som KDevelop bug 256832.

Note

I denne proces får jeg også fejlmeddelsen Du skal angive en gyldig placering til projektet, som trygt kan ignoreres.
  • Du bliver bedt om at vælge en KDevelop-projektfil i denne mappe. Da du formodentlig ikke har sådan en endnu, så klikker du blot på Næste
  • Klik Næste igen
  • KDevelop vil nu bede dig om at vælge en projektmanager. Hvis projektet bruger almindelige Unix-makefiler, så vælg projektmanageren med hjemmelavet makefil
  • KDevelop vil nu begynde at fortolke hele projektet. Dette kan også tage en del tid at gennemgå alle filer, indeksere klasser osv. Nederst til højre i hovedvinduet er der en fremgangslinje, som viser, hvor langt processen er skredet frem. (Hvis du har mere end en processorkerne, så kan du accelerere denne proces ved at gå til menuen Indstillinger -> Indstil KDevelop..., gå til gruppen Baggrundsfortolker i venstre side og forøge antallet af tråde til baggrundsfortolkning.)

Opsætning af et program som et andet projekt

Det næste, du skal gøre er at opsætte andre projekter i den samme session. I eksemplet ovenfor skal du tilføje enhedsdriveren som et andet projekt, hvilket du kan gøre på præcis samme måde.

Hvis du har flere programmer eller biblioteker, så gentager du simpelt hen processen for hvert projekt, som skal tilføjes til sessionen.

Creating projects from scratch

There is of course also the possibility that you want to start a new project from scratch. This can be done using the Projects -> New from template menu item. The details of what options this offers to you are described elsewhere in this manual.