Udvidelse af &quantaplus;ChristopherHornbakerchrishornbaker@earthlink.netAndrásMantiaamantia@kde.org
&rune.laursen.role;
Udvidelse af &quantaplus;Dette kapitel beskriver hvordan &quantaplus; kan tilpasses netop dine behov, og hvordan du kan hjælpe til med at gøre &quantaplus; bedre. Dokumenttype-redigeringspakke (&DTEP;)Dokumenttype-redigeringspakken (&DTEP;) bruges i &quantaplus; til at tilføje understøttelse for mærker, scriptsprog og stilskabeloner. De tillader &quantaplus; at levere funktioner såsom automatisk komplettering og knudetræ. Deres enkelhed og fleksibilitet er det der gør &quantaplus; til et hurtig, udviklervenlig integreret udviklingsmiljø for internet-udviklere. De gør &quantaplus; til et letanvendeligt, produktivt miljø. Der findes to varianter af &DTEP;, familie 1, som er opmarkeringer, og familie 2 som er scriptsprog og stilskabeloner. En &DTEP; består af to dele, mærkemappen og værktøjslinjerne. Mærkemapper består af to filtyper, filerne &descriptionrc; og XML-mærker, som har endelsen .tag. Værktøjslinjer er bekvemme, ikonorienterede linjer med knapper (ovenfor redigeringsvinduet), som tilføjer til tekst til et dokument hurtigere end brugeren kan skrive. En &DTEP; kan laves manuelt (se nedenfor), downloades eller laves automatisk ud fra en eksisterende DTD. Se for information om konvertering. Dette dokument beskriver hvordan XML-mærkefiler, filen &descriptionrc; og værktøjslinjer laves. I korthed, en &DTEP;. XML-mærkefiler (.tag) definerer både egenskaber specifikke for et mærke, samt layout og indhold i egenskabsdialogen som &quantaplus; viser for mærket. Filen &descriptionrc; sørger for regler og information om en hel &DTEP;. Værktøjslinjer sørger for en hurtig måde at tilføje mærker til et dokument, uden at behøve bekymre sig om fejlstavninger eller lignende. IndpakningMærkemapper er netop det, mapper. De består kun af filerne &descriptionrc; og XML-mærkefiler. Mærkemapperne bærer mærkesprogets navn og version, hvis der findes en (for eksempel html-4.01-strict). TagXMLTabellen nedenfor har en liste af elementer som defineres i XML-mærkefiler, og angiver om de kræves eller ej. Selv om ikke alle kræves, anbefales du at anvende så mange som du kan, så andre brugere får en bedre oplevelse og mere information at arbejde med. ElementNormal brugSpeciel brugTAGSkrævesaltidtagkrævesaltidlabelvalgfrikræves for at oprette en egenskabsdialogattrvalgfrikræves for at definere en egenskabtooltipvalgfrikræves for at lade egenskabsdialogen vis et værktøjstipswhatsthisvalgfrikræves for at få egenskabsdialogen til at vise Hvad er dettelistvalgfrikræves når en egenskab har typen listitemvalgfrikræves når <list> brugestextlocationvalgfrialtidlocationvalgfrikræves når label brugestextvalgfrikræves når label brugeschildrenvalgfriliste over mærker som kan findes indeni mærket som definereschildkrævesen af indgangene i childrenstoppingtagsvalgfriliste over mærker som fortæller et andet mærke at det har nået slutningenstoppingtagkrævesen af indgangene i stoppingtagsElementbeskrivelser for XML-mærkerFølgende afsnit beskriver hvert element i detalje. Alt fra hvor de kan findes, til hvad som findes i dem præsenteres på en måde som er enkel at følge. TAGSDette er XML-mærkedokumentets rodelement. Det må kun findes en gang i et dokument. Det kan indeholde definitionen af flere mærker. Dette er et typeelement med kun element. OverliggendeUnderliggendeINGENtagtagOmgivelse for mærket som defineres. Dette er et typeelement kun med element. OverliggendeUnderliggendeTAGSlabel, attr, stoppingtagsEgenskabTypeVærdierStandardBrugBeskrivelsenavnstrengkrævesAngiver navnet på mærken som bliver defineret.singlebooleanvalgfriAngiver om mærket kræver et afsluttende mærke </(mærkenavn)>.typestrengxmltagvalgfriAngiver typen af mærket som defineres.xmltagTypen for mærket er XML-baseret (kun familie 1).entitetMærket beskriver en entitet (kun familie 1).egenskabTypen for mærket er &CSS; (kun familie 2).funktionTypen for mærket er en scriptfunktion. Når dette bruges bliver <attr> funktionens argument (kun familie 2).klasseTypen for mærket er en scriptklasse (kun familie 2).methodTypen for mærket er en klassemetode (kun familie 2).returnTypestrengvoid valgfriAngiver returtypen for mærket som defineres (kun familie 2).voidMærketypen returnerer ingenting.intMærketypen returnerar et heltal.floatMærketypen returnerer et decimaltal.longMærketypen returnerer et langt heltal.strengMærketypen returnerer en streng.versionstrengvalgfriAngiver sprogets version som mærket er gyldig forextendsstrengvalgfriKun gyldig hvis typen for mærket er "klasse". Navnet på basisklassen for denne klasse (kun familie 2).klassestrengvalgfriKun gyldig hvis typen er "method". Angiver navnet på klassen som denne metoden tilhører (kun familie 2).commonbooleanvalgfriHvis "yes", angiver mærket en fælles egenskabsgruppe, og egenskaberne inde i mærket kan kobles til et hvilket som helst andet mærke (kun familie 1).commentstrengvalgfrikommentarstrengen vises ved siden af mærke taggnavnet i kompletteringsfeltetlabelPlacér en rubrik i dialogen. Teksten angives af mærket <text>. Dette er et typeelement kun med element. OverliggendeUnderliggendetagtext, locationattrDefinerer en egenskab for mærket. Elementet forekommer en gang for hver egenskab. Det definerer egenskabens navn og type. Det indeholder også yderligere mærker som angiver hvordan egenskaben skal vises, osv. Dette er et typeelement med kun element. OverliggendeUnderliggendetaglocation, list, tooltip, whatsthis, textlocationEgenskabTypeVærdierStandardBrugBeskrivelsenavnstrengkrævesAngiver navnet på egenskaben som er ved at blive defineres.typestrenginputkrævesAngiver typen for egenskaben som er ved at blive defineres.inputFeltet understøtter frie tekstindgange (tekstfelt).checkFeltets værdi er boolesk (afkrydsningsfelt).farveFeltets værdi er en farve.urlFeltets værdi er en &URL; (Lokal fil at henvise til).listFeltets værdi kommer fra en given liste.statusstrengvalgfrikrævesAngiver om argumentet kræves eller ej (Kun familie 2).valgfriArgumentet kræves ikke.krævesArgumentet kræves.underforståetArgumentet er underforstået.sourcestrengvalgfriAngiver kilden som bruges til at udfylde egenskabens indgang i mærkeeditorens dialog og i egenskabstræetselectionDen markerede tekst bruges som kildedcopResultatet af DCOP-metoden bruges som kildeinterfacestrengvalgfriKræver source="dcop". DCOP-grænsefladen inde i &quantaplus; bruges til at hente kildedata.methodstrengvalgfriKræver source="dcop" og et grænsefladenavn. DCOP-metodenavnet inde i &quantaplus; bruges til at hente kildedata.argumentsstrengvalgfriKræver source="dcop", et grænsefladenavn og et metodenavn. Argumenterne sendes til metoden. Den kan være tom eller "%tagname%", hvilket betyder det nuværende mærkes navn.tooltipDefinerer værktøjsvinket for et felt i dialogen. Dette element er kun tekst. For nuværende understøttes kun almindelig tekst (du kan ikke bruge opmarkering). OverliggendeUnderliggendeattrINGENwhatsthisDefinerer 'Hvad er dette'-hjælp for et felt i dialogen. Elementet er kun tekst. For nuværende understøttes kun almindelig tekst (du kan ikke bruge opmarkering). OverliggendeUnderliggendeattrINGENlistEt omgivelsesmærke som grupperer punkterne i en liste sammen. Det kan kun findes én gang for hver beskrivelse af en egenskab. Dette er et typeelement kun med element. OverliggendeUnderliggendeattritemitemDefinerer et objekt i en liste. Elementet er kun tekst. OverliggendeUnderliggendelistINGENtextlocationAngiver positionen for et mærkes egenskabstekst inde i en dialog. Dette mærke kan kun findes én gang for hver egenskab i dialogen (&ie; en gang for hver <attr>-mærke). Dette element er tomt. OverliggendeUnderliggendeattrINGENEgenskabTypeBrugBeskrivelserowpositivt heltalkrævesAngiver linjen i dialogens layout for et felt eller en etiket.colpositivt heltalkrævesAngiver søjlen i dialogens layout for et felt eller en etiket.rowspanpositivt heltalvalgfriAngiver antal linjer som et felt skal optage.colspanpositivt heltalvalgfriAngiver antal søjler som et felt skal optage.locationAngiver position og størrelse på et felt i dialogen. Dette mærke skal findes én gang for hvert felt i dialogen (&ie; én gang for hvert <attr>- og <label>-mærke). Dette element er tomt. OverliggendeUnderliggendelabel, attrINGENEgenskabTypeBrugBeskrivelserowpositivt heltalkrævesAngiver linjen i dialogens layout for et felt eller en etiket.colpositivt heltalkrævesAngiver søjlen i dialogens layout for et felt eller en etiket.rowspanpositivt heltalvalgfriAngiver antal linjer som et felt skal optage.colspanpositivt heltalvalgfriAngiver antal søjler som et felt skal optage.textDefinerer teksten for en etiket eller et afkrydsningsfelt. Dette element er kun tekst. OverliggendeUnderliggendelabel, attrINGENchildrenDefinerer en liste med elementer som kan findes i mærket som angives. Dette er et typeelement kun med element. OverliggendeUnderliggendetagchildchildDefinerer et underliggende mærke. Dette element er tomt. OverliggendeUnderliggendechildrenINGENEgenskabTypeVærdierBrugBeskrivelsenavnstrengkrævesAngiver et mærke som kan findes indeni et vist mærke.usagestrengvalgfriAngiver forholdet til det overliggende objekt.krævesDet overliggende objekt skal have mindst et underliggende objekt med dette navn.stoppingtagsDefinerer en liste med elementer som tvinger et mærke til at slutte. Dette er et typeelement kun med element. OverliggendeUnderliggendetagstoppingtagstoppingtagDefinerer et slutmærke. Dette element er tomt. OverliggendeUnderliggendestoppingtagsINGENEgenskabTypeBrugBeskrivelsenavnstrengkrævesAngiver hvilke mærker som tvinger et andet mærke til at slutte.Brug af XML-mærkerAlle XML-mærkefiler skal begynde med &XML;-deklarationen: <?xml version="1.0" encoding="UTF-8"?> og skal være hierarkisk indlejrede og afsluttede. Mellemrum påvirker ingenting negativt, men pas på med tegnene & og <. Disse skal formodentlig erstattes med henholdsvis & og < i elementer såsom <tooltip>, <whatsthis>, og <text>. Hvis dette ikke gøres forårsager det ikke noget sammenbrud, men du vil få dele af dit arbejde til at forsvinde hvis du ikke gør det. Validering af XML-mærkerFor at validere XML-mærkefiler, klik helt enkelt på dialogen Værktøj længst oppe i &quantaplus; og vælg Validér XML-mærker. En dialog vises, og du behøver kun at følge de enkle anvisninger. Denne funktion findes ikke for øjeblikket. For øjeblikket sker valideringen når XML-mærkefilerne indlæses i &quantaplus;. Eksempel på XML-mærkerFamilie 1Følgende viser dig en korrekt familie 1 XML-mærkefil. Filen beskriver tilfældigvis &W3C; &XML; farvesammensætningselement <schema>. Filnavnet på denne XML-mærkefil ville være schema.tag. Enkelt, ikke sandt?
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE TAGS>
<TAGS>
<tag name="schema">
<label>
<text>id</text>
<location col="0" row="0"/>
</label>
<attr name="id" type="input">
<tooltip>En entydig identifikation for elementet </tooltip>
<whatsthis>En entydig identifikation for elementet </whatsthis>
<location col="1" row="0"/>
</attr>
<label>
<text>version</text>
<location col="0" row="1"/>
</label>
<attr name="version" type="input">
<tooltip>Version for schema.</tooltip>
<whatsthis>Version for schema.</whatsthis>
<location col="1" row="1"/>
</attr>
<label>
<text>targetNamespace</text>
<location col="0" row="2"/>
</label>
<attr name="targetNamespace" type="input">
<tooltip>Internet-adressereference for navnerummet for dette schema.</tooltip>
<whatsthis>Interneta-dressreference for navnerummet for dette schema.</whatsthis>
<location col="1" row="2"/>
</attr>
<label>
<text>xmlns</text>
<location col="0" row="3"/>
</label>
<attr name="xmlns" type="input">
<tooltip>Internet-adressereference for et eller flere navnerum for anvendelse i dette schema.
Hvis intet præfiks bruges, kan komponenterne i navnerummet anvendes uden kvalifikation </tooltip>
<whatsthis>Internet-adressereference for et eller flere navnerum for anvendelse i dette schema.
Hvis intet præfiks bruges, kan komponenterne i navnerummet anvendes uden kvalifikation </whatsthis>
<location col="1" row="3"/>
</attr>
<label>
<text>attributeFormDefault</text>
<location col="0" row="4"/>
</label>
<attr name="attributeFormDefault" type="list">
<items>
<item>qualified</item>
<item>unqualified</item>
</items>
<tooltip>Standardformular for alle egenskaber i schema.</tooltip>
<whatsthis>Standardformular for alle egenskaber i schema.</whatsthis>
<location col="1" row="4"/>
</attr>
<label>
<text>elementFormDefault</text>
<location col="0" row="5"/>
</label>
<attr name="elementFormDefault" type="list">
<items>
<item>qualified</item>
<item>unqualified</item>
</items>
<tooltip>Standardformular for alle elementer i schema.</tooltip>
<whatsthis>Standardformular for alle elementer i schema.</whatsthis>
<location col="1" row="5"/>
</attr>
<label>
<text>blockDefault</text>
<location col="0" row="6"/>
</label>
<attr name="blockDefault" type="input">
<location col="1" row="6"/>
</attr>
<label>
<text>finalDefault</text>
<location col="0" row="7"/>
</label>
<attr name="finalDefault" type="input">
<location col="1" row="7"/>
</attr>
</tag>
</TAGS>
Familie 2Følgende viser dig en korrekt familie 2 XML-mærkefil. Filen beskriver tilfældigvis &PHP;s overbelastningsfunktion. Filnavnet på denne XML-mærkefil ville være overload.tag.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE tags>
<tags>
<tag name="overload" type="function" returnType="void">
<attr name="class_name" type="string" status="optional"/>
</tag>
</tags>
&descriptionrc;Filen &descriptionrc; er også meget enkel, og en editor for den er tilgængelig med DTDRedigér DTD-indstillinger. Det redigerer &descriptionrc; for en &DTEP; som du kan vælge i en liste. For at redigere &descriptionrc; for en nyoprettet &DTEP;, skal du oprette en enkel &descriptionrc; med følgende indgange:
[General]
Version = Anvend 1 for &quantaplus; version <=3.1.2 og 2 for alle senere versioner.
Name = DTD-definitionsstreng. (-//&W3C;//DTD HTML 4.01 Transitional//EN)
NickName = Det forskønade navnet på en DTD. (HTML 4.01 Transitional). Hvis ikke defineret bruges Name
som NickName.
Når du har oprettet den og lagt den ved siden af mærkefilerne, indlæses din nyoprettete &DTEP; med DTDIndlæs DTD-pakke (DTEP). Efter det er indlæst kan du fortsætte med at redigere indstillingerne i din &DTEP;. Tjek indgangenes værktøjsvink og Hvad er dette-tekster i redigeringsdialogen for at forstå betydningen af hver post. Som et alternativ kan du læse quanta/data/dtep/dtd-description.txt i det komprimerede kildekodearkiv, som indeholder en beskrivelse af formatet. Brugerdefinerede handlingerHandlinger er meget hyppige i alle programmer. Du møder dem ofte når du bruger enhver applikation. Et klik på en værktøjslinjeikon, valg af en menuindgang eller brug af en genvejstast udfører normalt en handling. I &quantaplus; er handlinger videreført til næste niveau. Istedet for fastlagte handlinger (som er defineret af forfatteren af programmet på kildekodeniveau), er det muligt for den almindelige bruger at oprette og modificere handlinger og på den måde indføre ny funktionalitet i &quantaplus;. Det er de brugerdefinerede handlinger og mange af standardhandlingerne i &quantaplus; er brugerdefinerede (og mulige at ændre af brugeren) handlinger også. Der er tre slags brugerdefinérbare handlinger: TeksthandlingerMærkehandlingerScripthandlingerAt oprette handlingerDu kan oprette en handling ved at vælge OpsætningIndstil handlinger . Klik på Ny handling og du får en ny dialog at se: TypeAngiver handlingens type (Tekst, Mærke, Script).TekstDen del af handlingens navn som er synlig for brugerenKnappen nær ved Tekst etiketten.Ikonen der tildeles til denne handling. Klik på den for at ændre den aktuelle ikon.VærktøjsvinkKort beskrivelse af hvad handlingen gør.GenvejstastGenvejstasten der tildeles denne handling. Klik på Brugerdefineret eller knappen tæt på Brugerdefineret for at tildele en genvejstst til handlingen. Klik på Ingen for at fjerne den aktuelle tildelte genvejstast.VærktøjslinjebeholdereDe brugerdefinerede værktøjslinjer, hvor handlingen foregår. Se .Detaljerede indstillingerSpecifikke indstillinger for en anden type handlinger. Se herunder Teksthandlinger De simpleste handlinger. Du kan indtaste noget tekst i Detaljerede indstillinger-feltet og så snart handlingen udføres, bliver denne tekst indsat i dit dokument ved den aktuelle markørposition. Se herunder for et eksempel. MærkehandlingerBrugbar til at indsætte XML-mærker, men selvfølgelig kan du også indsætte dem til andre formål. <mærke>Navnet på mærket.</mærke>Hvis afkrydset når handlingen udføres bliver denne tekst indsat som et lukke-mærke. Hvis der er markeret et område i dokumentet før du udfører handlingen, bliver <mærket> indsat før det markerede område og </mærke> efter.Kør "Redigér mærke"-dialogen hvis den er til rådighedHvis afkrydset og der er en mærkeXML-fil til dette mærke, vises der en mærkeredigeringsdialog før mærket indsættes i dokumentet så du kan finjustere mærkeegenskaberne først. <Mærke> og </mærke> bliver indsat som du har skrevet det her. <, > eller /-tegnet bliver ikke automatisk vedhæftet. Scripthandlinger Den mest kraftfulde handlingstype. Ved hjælp af denne handling kan du køre eksterne programmer (normalt scripter, men ikke begrænset til dette), som kan ændre dit dokument eller bruge dit dokument (eller en del af det) som inddata. Eksempler fra &quantaplus; selv er Hurtigstart-dialogen, de forskellige Vis i... handlinger til (X)HTML DTEP'er. Først skal du indtaste navnet på dit script og også fortolkeren. Eksempel: sh /home/minhjemmemappe/mitscript.sh. Selvom du kan bruge fuldstændige stier, er den anbefalede måde at bruge %scriptdir variablen på kommandolinjen således sh %scriptdir/mitScript.sh. På den måde vil &quantaplus; forsøge at lokalisere dit script de følgende steder: global scriptmappe: $TDEDIR/share/apps/quanta/scriptslocal scriptmappe: $TDEHOME/share/apps/quanta/scriptsdin sti: $PATH Der er andre specielle variable du kan bruge på kommandolinjen: %f: erstattes af adressen på det aktuelle dokument. I fald det er lokale dokumenter bilver file:/ fjernet fra dokumentet.%input: bliver erstattet med den valgte inddata. Se herunder.%projectbase:bliver erstattet med adressen på det aktuelle projekt. Er den tom bliver intet projekt indlæst.%pid: bliver erstattet med PID af den kørende &quantaplus;-proces. Hvis &quantaplus; kører i unik-tilstand, mode, the "unique " teksten foranstillet PID-nummeret. Brugbart når du bruger DCOP til at kontrollere &quantaplus; fra det eksterne script.%userarguments: Nyttigt i tilfældet med begivenheder. Indgangen erstattes af begivenhedens egenskaber i følgende rækkefølge: Første argumentScriptets entydige identifikationAndet argumentbegivenhedsnavnetTredje argumentbegivenhedens parameter, oftest det nuværende dokuments filnavn eller søgestien til projektfilen.Udover de ovennævnte metoder, kan scriptet modtage inddata fra &quantaplus; via stdin. I Indata kombinationsfeltet kan du vælge hvad der skal sendes til stdin. Valgene er: Ingen: intet sendes til scriptet.Aktuelt dokument: hele dokumentet sendes til scriptet.Markeret tekst: det markerede tekstområde i dokumentet sendes til scriptet. At bruge %input variablen giver nomalt kun mening når man bruger denne indstilling.I samme stil som Inddata kan du fange uddata fra den udførte applikation. Der er to slags uddata: normal uddata, udskrevet til stdout;fejlmeddelelser, udskrevet til stderr. Du kan specificere hvad der skal ske med teksten udskrevet til stdout. Dette kan gøres ved at ændre værdien i Uddata kombinationsfeltet: Ingen: applikationens uddata ignoreres.Indsæt ved markørposition: uddata indsættes i det aktuelle dokument ved markørpositionen.Erstat markering: det markerede område i dokumentet erstattes med uddata.Erstat markering: det markerede område i dokumentet erstattes med uddata.Opret et nyt dokument: et nyt dokument bliver oprettet og indeholder scriptets uddata.Erstat aktuelt dokument: hele dokumentet erstattes med uddata.Beskedvindue: uddata vises i Beskeder værktøjsvisningen.Valgene for stderr uddata (Fejl) er det samme som for normal uddata.Opret værktøjslinjerDet følgende viser dig hvordan man opretter værktøjslinjer for en &DTEP;. Værktøjslinjer er grafiske elementer, som tildeles handlinger. I &quantaplus; er handlinger grunden til næsten alle udvidelser som &quantaplus; har, og vil få i fremtiden. &quantaplus; tilbyder også automatisk komplettering og mærkedialoger. Grænserne for hvad du kan gøre med handlinger er næsten ubegrænsede. Som eksempel, anvender vi &HTML; Tidy på vore netsider. Fra begyndelsen til en færdig værktøjslinjeTil at begynde med, skal du oprette en brugerværktøjslinje. Vælg Værktøjslinjer Tilføj brugerværktøjslinje. Hvis der findes mange mærker i sproget, anbefales du at opdele mærkerne i logiske grupper. Du skal oprette en ny brugerværktøjslinje for hver gruppe. I dette tilfælde findes der ikke mange, så vi opretter en værktøjslinje og navngiver den efter mærkesproget. Så snart alle værktøjslinjer er oprettet, skal du tilføje og tilrette handlingerne. For at gøre det, vælges OpsætningIndstil handlinger. Delene i vinduet er ganske ligetil. Tryk på knappen Ny handling længst nede i vinduet for at komme til redigeringstilstand. Udfyld i alle nødvendige felter, og tilføj mærkerne i passende værktøjslinjer. Kompletér resten, og hvis mærkeerne har egenskaber som du altid vil anvende, så markér dialogen Kør dialogen for "Redigér mærke" hvis den findes, så du bliver spurgt hver gang handlingen bruges. Du bør nu have noget som ligner følgende: Tryk på knappen Anvend, så ser du at handlingen er blevet tilføjet i de værktøjslinjer du har markeret. Åh nej! Sikke en grim ikon. Hvordan skal du selv og andre huske at den ikon hører sammen med handlingen. Lad os erstatte den inden der opstår problemer. For at oprette en ikon som bedre beskriver handlingen, anvender vi &tdeiconedit;.. Vælg den i &kmenu;, GrafikFlere programmer (eller hvor din distribution end har placeret den). &tdeiconedit; har standardstørrelsen 32 x 32 billedpunkter, men vi har brug for 22 x 22. For at ændre det, vælges RedigérÆndr størrelse. Husk at du laver en ikon som ikke kun skal hjælpe dig selv med at huske hvilken handling som gør hvad, men også andre brugere af denne &DTEP;. Eftersom mærket vi laver ikonen til, hedder start, bestemmer vi os for at oprette et start-tegn. Ved at bruge grøn farve (grønt tolkes ofte som kør, start eller fortsæt) formidler vi, eller burde i det mindste formidle, brugeren informationen om at ved et klik på denne handling placeres mærket <start> i dette dokument. Nu når ikonen er færdigoprettet, gemmer vi den. Når vi er færdige med at laver ikoner, skal ikonerne associeres med handlingen. For at gøre dette, åbnes vinduet OpsætningIndstil handlingerigen (i &quantaplus;) og handlingen som ikonen oprettedes for vælges. Ved siden af feltet Tekst, findes en knap. Klik på den. Vælg Øvrige ikoner og klik derefter på knappen Gennemsøg.... Gå til mappen hvor du gemte ikonen, vælg den og klik på O.k.. Tryk på knappen Anvend, og fortsæt enten med at gøre det samme med de øvrige mærker, eller klikke på O.k. for at afslutte. Antag at vi vil tilføje nogle almindelige &quantaplus; funktioner i værktøjslinjen, eller måske skulle værktøjslinjen være bedre hvis den blev organiseret på et anden måde, med nogen adskillere for at gruppere handlingerne. Åbn dialogen Indstil værktøjslinjer ved at vælge OpsætningIndstil værktøjslinjer. Sørg for at vores værktøjslinje er valgt. Vi vælger adskilleren (længst oppe i venstre søjle) for værktøjslinjen. Når man har valgt objektet som skal tilføjes i værktøjslinjen, trykker man på højrepilen. Dette vil tilføje den til værktøjslinjen. Vi vil have en hurtig måde at komme til Vis med Konqueror. Vælg den og tilføj de i værktøjslinjen. Bemærk hvordan adskilleren hjælper med gruppering. Nogen som ikke har set vor værktøjslinje tidligere, ville kunne have troet at knappen &konqueror; lignede eller det modsatte af start-knappen. Anvend dine ændringer, og tryk på O.k. når du er klar til at afslutte. Kig på den fantastiske nye værktøjslinje! Meget bekvemmere nu. Husk at teste værktøjslinjen, ved at klikke på knapperne, så du véd at udskriften er rigtig. For nu at gemme værktøjslinjen, vælger vi VærktøjslinjerGem værktøjslinjerGem som lokal værktøjslinje. Gem den i den rigtige mappe. Eftersom NeXML ikke findes, lægger vi den kun i topniveaumappen, men værktøjslinjer skal gemmes i den rigtige mappe. Sørg for at du justerer &descriptionrc; så værktøjslinjerne indlæses når en ny fil af denne type laves. Opret din egen dokumentationRobertNickelrobert@artnickel.com
&rune.laursen.role;
Opret din egen dokumentationFormodentlig de mest bemærkelsesværdige tilføjelser til &quantaplus; for den almindelige bruger, tilføjelse af dokumentation for de mærke- eller scriptsprog som er mest populære. Med dette formål, forklarer dette kapitel hvordan jeg laver &PHP;-dokumentationstræet til min egen personlige brug. Inden du begynder på at oprette din egen dokumentation, vil du måske kigge på &quantaplus;s arkiv for at se om nogen allerede har lavet denne opsætning. Der findes to dele i processen. Først skal du skaffe eksisterende dokumentation for mærkesproget, scriptsproget eller et andet sprog som du er ude efter. Derefter skal du oprette docrc-filen. Det første må du klare selv, det andet er hvad vi dækker her. Den almindelige form for docrc-filen er følgende: #KDE konfigurationsfil
[Tree]
Doc dir=søgesti, relativt til denne fil, for dokumentationens HTML-filer t.ex. php42/
#toppniveauelement
Top Element=Din beskrivelse af disse dokumenter t.ex. PHP 4.2 dokumentation
Section 1=Section1.html
Section 2=#Sec2.1,#Sec2.2,#Sec2.3
Sec2.1=Sec2.1.html
Sec2.2=Sec2.2.html
Sec2.3=Sec2.3.html
...
[Context]
ContextList=func1,func2,tag1,tag2,tag3
func1=func1.html
func2=func2.html
tag1=tag1.html
tag2=tag2.html
tag3=tag3.html
Filen docrc er opdelt i to afdelinger: Tree (træ) og Context (Sammenhæng). Afdelingen Tree definerer præsentationsaspekter for dokumentet under dokumentationsfanebladet. Du ser for eksempel at i &PHP;-dokumentationen, har du noget som ligner dette: Med reference til ovenstående, ser min &PHP; docrc sådan her ud: #KDE indstillingsfil
[Tree]
Doc dir=php42/
#toppniveauelement
Top Element=PHP 4.2 dokumentation
PHP 4.2 dokumentation=Indholdsfortegnelse,#Kom i gang,#Sprogreference
Indholdsfortegnelse=index.html
Kom i gang=Indledning, ...
Indledning=introduction.html
...
Sprogreference=Grundlæggende syntaks, ...
Grundlæggende syntaks=language.basic-syntax.html
...
Bemærk # foran Kom i gang og Sprogreference. Det angiver at disse er delindhold i træet og har deres eget indhold. Jeg tror ikke der findes en angiven grænse for dybde (bortset fra det som dikteres af sund fornuft) — brug din egen dømmekraft. For indholdsfortegnelsen, ser du at den direkte refererer til en fil (og som en konsekvens, vises den længst ned i trævisningen, mapper kommer først). Mellemrum påvirker ingenting negativt, men pas på med tegnene & og <. Disse skal formodentlig erstattes med & og < i alle &quantaplus; &XML;-baserede ressourcefiler. Sammenhængsafsnittet er afsnittet i docrc-filen som bruges til at muliggøre sammenhængsafhængig hjælp. Hvis du for eksempel skriver et &PHP;-script og vil se dokumentationen for funktionen mysql_fetch_array, markerer du helt enkelt funktionen og trykker derefter på &Ctrl;H for sammenhængsafhængig hjælp. Dokumentationen om mysql_fetch_array vises umiddelbart. Der findes kun to typer af indgange her: sammenhængslisten og filassociationslinjerne. SammenhængslisteMeget enkel. Dette er kun en liste af sammenhængsindgange adskilte af kommategn, som du vil have tilgængelige (for &PHP; er det funktionerne i &PHP;). FilassociationslinjerDe er på formen sammenhængspunkt = HTML-dokumentside. F.eks. acos=function.acos.html. En renset version af mit docrc sammenhængsafsnit ser ud som følger: #Nøgleord for sammenhængsafhængig hjælp
[Context]
ContextList=abs,acos,acosh,addcslashes,addslashes,...
abs=function.abs.html
acos=function.acos.html
acosh=function.acosh.html
addcslashes=function.addcslashes.html
addslashes=function.addslashes.html
...
Nu skal du blot gemme din docrc-fil. Gem den i $HOME/.trinity/share/apps/quanta/doc eller $TDEDIR/share/apps/quanta/doc for henholdsvis lokal eller global brug. Opret derefter en mappe (den som angives i docrc-filen) i samme mappe som docrc-filen findes, og kopiér &HTML;-dokumentationssiderne derhen. Du skal genstarte &quantaplus;, for at se din dokumentation. decimaltalr sikker på at de er gode, og værd at dele, send så docrc-filen sammen med med en beskrivelse af passende information om hvilket dokument du brugte til &quantaplus;s arkiv til brug for &quantaplus;' brugere. Du bliver ikke rig, men du føler dig godt tilpas ved at vide at du bidraget til det bedste internetudviklingsmiljø som findes. Del ressourcerDu er ikke alene med &quantaplus;. Det er muligt at dele forskellige ressourcer (DTEP-pakker, værktøjslinjer med handlinger, scripter, skabeloner) med andre. Der er to måder at gøre det: Send med e-mailRessourcer kan sendes med e-mail til venner, kolleger eller til hvem du vil. Du ser menupunktet Send med e-mail på forskellige steder, såsom DTDSend DTD-pakke (DTEP) med e-mail, VærktøjslinjerSend værktøjslinje med e-mail, og i den sammenhængsafhængige menu for filer og mapper i træet Skabeloner og Scripter. Overfør til hovedserverenRessourcer kan overføres til vort hovedarkiv, hvor alle andre brugere af &quantaplus; kan hente dem. Bidragene gennemses nøje og gøres kun tilgængelige hvis vores gruppe anser dem for rigtige og nyttige. For at oprette et gyldigt bidrag, foreslår vi at du underskriver ressourcen. Derfor behøver du en GPG/PGP-nøgle. Informationen bruges til at verificere ressourcens oprindelse, både af vor gruppe og af de som henter den.Om hvordan ressourcer hentes fra hovedserveren, se .Når du overfører bliver du bedt om at angive løsen for din hemmelige GPG-nøgle (løsenet opbevares ikke), og i tilfældet med flere hemmelige nøgler, skal du vælge den du vil bruge. Udfyld inddatafelterne i dialogen Del smarte nye ting (URL for forhåndsvisning kan forblive tom) og starte overførslen ved at klikke på O.k..Overførslen kan startes fra DTDOverfør DTD-pakke (DTEP), VærktøjslinjerOverfør værktøjslinje, og i den sammenhængsafhængige menu for filer og mapper i træet Skabeloner og Skripter. Hent ressourcerDet er muligt at opgradere &quantaplus; uden at skaffe en ny version, ved at hente nye ressourcer såsom DTEP-pakker, værktøjslinjer med handlinger, skabeloner, scripter og dokumentation. En mulighed er at du fik ressourcer med e-mail, eller har hentet dem fra en URL. Så skal du oftest installere dem manuelt. Hvis du er heldig får du også et installationsscript når du henter ressourcen. Men &quantaplus; har en dedikeret server som opbevarer ressourcer som enten ikke er med i hoveddistributionen på grund af deres størrelse eller at de sjældent bruges, eller var senere bidrag af brugere. Disse ressourcer installeres automatisk. Hent sådanne ressourcer i de forskellige menupunkter Download. Du finder dem under DTDHent DTD-pakke (DTEP), VærktøjslinjerHent værktøjslinje, og i den sammenhængsafhængige menuen i et tomt område eller topniveauobjekt i træet Skabeloner, Script og Dokumentation. Efter en ressource er hentet ned, men inden den installeres, verificerer &quantaplus; om ressourcen er gyldig ved at kontrollere integriteten og underskriften. I tilfælde af problemer advares du, og kan bestemme om du vil fortsætte eller ej. Læs advarselsdialogerne nøjagtigt. Hvis integriteten er rigtig og ressourcen er rigtigt underskrevet, vises stadigvæk en informationsdialog så at du kan se hvem der oprettete ressourcen. Sørg for at du kun installerer ressourcer fra pålidelige kilder, særligt værktøjslinjer og scripter!Konvertér en DTD til en &DTEP;Det er muligt at arbejde med XML-sprog som for øjeblikket ikke understøttes af &quantaplus; ved at oprette en DTEP-pakke. Men det kan tage tid at oprette den, eftersom du kan behøve at skrive hundredvis af mærkefiler med tagXML-format. Der er naturligvis en behageligere måde at gøre det på, ved automatisk at konvertere en DTD til en DTEP-pakke. Konverteringen kan startes fra menuen DTDHent og konvertér DTD. Vælg .dtd-filen som definerer den DTD du vil bruge, og derefter vises følgende dialog: Indgangene er:Målmappenavn: Den nyoprettede &DTEP; vil få dette navn i mappen $TDEHOME/share/apps/quanta/dtep. Navn: Navnet (definitionsstrengen) på DTD'enAlias: Navnet på en &DTEP; synligt for brugeren!DOCTYPE-definitionsrad: Strengen som skal ses i mærket !DOCTYPE, såsom HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"DTD-webbadress: URL'en som peger på DTD-filenStandardendelse: Filendelsen som oftest bruges for filer som blev skrevet med denne DTDVersalfølsomme mærker og egenskaber: Selvforklarende. Oftest sandt for XML-sprogsvarianterFinjustér DTEP efter konvertering: Hvis markeret, åbner &quantaplus; editoren for &descriptionrc; når konverteringen er klar, så du kan finjustere din nyoprettete &DTEP;. Det anbefales at dette tilvalg er markeret.