KateParts editorkomponent kan enkelt utökas genom att skriva skript. Skriptspråket är ECMAscript (känt överallt som JavaScript). KatePart stöder två sorters skript: intenterings- och kommandoradskript.
Indenteringsskript, som också kallas indenterare, indenterar automatiskt källkoden medan texten skrivs in. Som ett exempel, efter att ha tryckt på returtangenten ökar ofta indenteringsnivån.
Följande avsnitt beskriver steg för steg hur skelettet för en enkel indenterare skapas. Som ett första steg, skapa en ny *.js-fil, som t.ex. heter javascript.js i den lokala hemkatalogen $. I detta expanderas miljövariabeln XDG_DATA_HOME/katepart5/script/indentationXDG_DATA_DIRS typiskt antingen som ~/.local eller ~/.local/share.
På Windows® är filerna placerade i %USERPROFILE%\AppData\Local\katepart5\script\indentation. %USERPROFILE% expanderas oftast till C:\\Users\\.användare
Huvudet i filen javascript.js är inbäddat som JSON i början av dokumentet enligt följande:
var katescript = {
"name": "JavaScript",
"author": "Exempelnamn <exempel.namn@någon.adress.org>",
"license": "BSD-licens",
"revision": 1,
"kate-version": "5.1",
"required-syntax-style": "javascript",
"indent-languages": ["javascript"],
"priority": 0,
}; // kate-script-header, måste finnas i början av filen utan kommentarer
Varje post förklaras nu i detalj:
name[krävs]: Detta är indenterarens namn som visas i menyn → och i inställningsdialogrutan.author[valfri]: Upphovsmannens namn och kontaktinformation.license[valfri]: Kort form av licensen, såsom BSD-licensen eller LGPLv3.revision[krävs]: Skriptets utgåva. Numret ska ökas så fort skriptet ändras.kate-version[krävs]: Lägsta version av KatePart som krävs.required-syntax-style[valfri]: Syntaxstilen som krävs, som matchar angivenstili syntaxfärgläggningsfiler. Det är viktigt för indenterare som förlitar sig på specifik syntaxfärgläggningsinformation i dokumentet. Om en krävd syntaxstil specificeras, är bara indenteraren tillgänglig när lämplig syntaxfärgläggning är aktiv. Det förhindrar ”odefinierat beteende” orsakat av att använda indenteraren utan den förväntade färgläggningsmetoden. Exempelvis använder sig Ruby-indenteraren sig av det i filenruby.jsochruby.xml.indent-languages[valfri]: JSON-fält av syntaxstilar som indenteraren kan indentera korrekt, t.ex.["c++", "java"].priority[valfri]: Om flera indenterare är lämpliga för en viss färglagd fil, bestämmer prioriteten vilken indenterare som väljes som standardindenterare.
Efter att ha specificerat huvudet, förklarar det här avsnittet hur själva indenteringsskriptet fungerar. Det grundläggande skelettet för implementeringen ser ut så här:
// nödvändiga katepart js bibliotek, t.ex. range.js om Range används
require ("range.js");
triggerCharacters = "{}/:;";
function indent(line, indentWidth, ch)
{
// anropas för varje nyrad (ch == '\n') och alla tecken angivna i
// den globala variabeln triggerCharacters. Vid anrop av →
// är variabeln ch tom, dvs. ch == ''.
//
// se också: Programmeringsgränssnittet för skripthantering
return -2;
}
Funktionen indent() har tre parametrar:
line: raden som ska indenterasindentWidth: indenteringsbredden i antal mellanslagch: antingen ett nyradstecken (ch == '\n'), avtryckartecknet angivet itriggerCharacterseller tom om användaren utförde åtgärden → .
Returvärdet från funktionen indent() anger hur raden kommer att indenteras. Om returvärdet är ett enkelt heltal, tolkas det på följande sätt:
returvärde
-2: gör ingentingreturvärde
-1: behåll indentering (söker efter föregående icke tomma rad)returvärde
0: tal >= 0 anger indenteringsdjupet i mellanslag
Som alternativ kan ett fält med två element returneras.
return [ indent, align ];
I detta fall är det först elementet indenteringsdjupet ovan med samma betydelse för specialvärden. Det andra elementet är dock ett absolutvärde som representerar en kolumn för ”justering”. Om värdet är större än indenteringsvärdet, representerar skillnaden ett antal mellanslag att lägga till efter indentering av den första parametern. Annars ignoreras det andra numret. Att använda tabulator och mellanslag för indentering kallas ofta ”blandat läge”.
Betrakta följande exempel: Antag att tabulator används för indentering, och tabulatorbredden är inställd till 4. Här representerar <tab> en tabulator, och '.' ett mellanslag.
1: <tab><tab>anropa("Hej",
2: <tab><tab>......."allesamman");
Vid indentering av rad 2, returnerar funktionen indent() [8, 15]. Som resultat infogas två tabulatorer för att indentera till kolumn 8, och 7 mellanslag läggs till för att justera den andra parametern under den första, så att den förblir justerad om filen visas med en annan tabulatorbredd.
En standardinstallation av KDE levererar KatePart med flera indenterare. Den motsvarande JavaScript-koden finns i $.XDG_DATA_DIRS/katepart5/script/indentation
På Windows® är filerna placerade i %USERPROFILE%\AppData\Local\katepart5\script\indentation. %USERPROFILE% expanderas oftast till C:\\Users\\. användare
Att utveckla en indenterare kräver att skript läses in igen för att se om ändringar beter sig lämpligt. Istället för att starta om programmet, byt helt enkelt till kommandoraden och utför kommandot reload-scripts.
Om du utvecklar användbara skript, fundera på att bidra med det till KatePart-projektet genom att kontakta e-postlistan.
Eftersom det är svårt att uppfylla allas behov, stöder KatePart små hjälpverktyg för snabb textbehandling via den inbyggda kommandoraden. Exempelvis är kommandot sort implementerat som ett skript. Det här avsnittet förklarar hur man skapar *.js-filer för att utöka KatePart med godtyckliga hjälpskript.
Kommandoradskript är placerade i samma katalog som indenteringsskript. Som ett första steg, skapa alltså en ny *.js-fil som heter mina_verktyg.js i den lokala hemkatalogen $. I detta expanderas miljövariabeln XDG_DATA_HOME/katepart5/script/commandsXDG_DATA_DIRS typiskt antingen som ~/.local eller ~/.local/share.
På Windows® är filerna placerade i %USERPROFILE%\AppData\Local\katepart5\script\commands. %USERPROFILE% expanderas oftast till C:\\Users\\. användare
Huvudet för varje kommandoradskript är inbäddat som JSON i början av skriptet enligt följande:
var katescript = {
"author": "Exempelnamn <exempel.namn@någon.adress.org>",
"license": "LGPLv2+",
"revision": 1,
"kate-version": "5.1",
"functions": ["sort", "moveLinesDown"],
"actions": [
{ "function": "sort",
"name": "Sortera markerad text",
"category": "Editing",
"interactive": "false"
},
{ "function": "moveLinesDown",
"name": "Flytta rader neråt",
"category": "Editing",
"shortcut": "Ctrl+Shift+Down",
"interactive": "false"
}
]
}; // kate-script-header, måste finnas i början av filen utan kommentarer
Varje post förklaras nu i detalj:
author[valfri]: Upphovsmannens namn och kontaktinformation.license[valfri]: Kort form av licensen, såsom BSD-licensen eller LGPLv2.revision[krävs]: Skriptets utgåva. Numret ska ökas så fort skriptet ändras.kate-version[krävs]: Lägsta version av KatePart som krävs.functions[krävs]: JSON-fält av kommandon i skriptet.actions[valfri]: Ett JSON-fält av JSON-objekt som definierar åtgärderna som visas i programmenyn. Detaljerad information tillhandahålls i avsnittet Tilldela genvägar.
Eftersom värdet på functions är ett JSON-fält, kan ett enda skript innehålla godtyckligt antal kommandon för kommandoraden. Varje funktion är tillgänglig via KateParts inbyggda kommandorad.
Alla funktioner specificerade i huvudet måste implementeras i skriptet. Exempelvis måste skriptfilen i exemplet ovan implementera de två funktionerna sort och moveLinesDown. Alla funktioner har följande syntax:
// nödvändiga katepart.js bibliotek, t.ex. range.js om Range används
require ("range.js");
function <namn>(arg1, arg2, ...)
{
// ... implementering, se också: Programmeringsgränssnittet för skripthantering
}
Argument på kommandoraden skickas till funktionen som arg1, arg2, etc. För att ge dokumentation av varje kommando, implementera helt enkelt funktionen 'help' på följande sätt:
function help(cmd)
{
if (cmd == "sort") {
return "Sortera markerad text.";
} else if (cmd == "...") {
// ...
}
}
Att utföra help sort på kommandoraden anropar hjälpfunktionen med argumentet cmd inställd till det givna kommandot, dvs. cmd == "sort". KatePart visar därefter den returnerade texten som dokumentation för användaren. Försäkra dig om att översätta strängarna.
Att utveckla ett kommandoradskript kräver att skript läses in igen för att se om ändringar beter sig lämpligt. Istället för att starta om programmet, byt helt enkelt till kommandoraden och utför kommandot reload-scripts.
För att göra det möjligt att komma åt skripten i programmenyn och tilldela genvägar, måste skriptet tillhandahålla ett lämpligt skripthuvud. I exemplet ovan, visas båda funktionerna sort och moveLinesDown i menyn på grund a följande del av skripthuvudet:
var katescript = {
...
"actions": [
{ "function": "sort",
"name": "Sortera markerad text",
"icon": "",
"category": "Editing",
"interactive": "false"
},
{ "function": "moveLinesDown",
"name": "Flytta rader neråt",
"icon": "",
"category": "Editing",
"shortcut": "Ctrl+Shift+Down",
"interactive": "false"
}
]
};
Fälten för en åtgärd är följande:
function[krävs]: Funktionen som ska visas i menyn → .name[krävs]: Texten visas i skriptmenyn.icon[valfri]: Ikonen visas intill texten i menyn. Alla KDE:s ikonnamn kan användas här.category[valfri]: Om en kategori anges, visas skriptet i en undermeny.shortcut[valfri]: Genvägen som anges här är förvald genväg. Exempel:Ctrl+Alt+t. Se Qt™:s dokumentation för ytterligare detaljinformation.interactive[valfri]: Om skriptet kräver användarinmatning via kommandoraden, ange det här somtrue.
Om du utvecklar användbara skript, fundera på att bidra med det till KatePart-projektet genom att kontakta e-postlistan.
Programmeringsgränssnittet för skripthantering som presenteras här är tillgängligt i alla skript, dvs. indenteringsskript och kommandon för kommandoraden. Klasserna Cursor och Range tillhandahålls av biblioteksfiler i $. Om du vill använda dem i skriptet, vilket behöver använda vissa av funktionerna i XDG_DATA_DIRS/katepart5/librariesDocument eller View , inkludera det nödvändiga biblioteket med:
// nödvändiga katepart.js bibliotek, t.ex. range.js om Range används
require ("range.js");
För att utöka det vanliga skriptprogrammeringsgränssnittet med egna funktioner och prototyper, skapa helt enkelt en ny fil i KDE:s lokala inställningskatalog $ och inkludera den i skriptet med: XDG_DATA_HOME/katepart5/libraries
require ("mitt_skriptnamn.js");
På Windows® är filerna placerade i %USERPROFILE%\AppData\Local\katepart5\libraries. %USERPROFILE% expanderas oftast till C:\\Users\\.användare
För att utöka befintliga prototyper som Cursor eller Range, är det rekommenderade sättet inte att ändra den globala *.js-filen. Ändra istället prototypen för Cursor i JavaScript efter att cursor.js har inkluderats i skriptet via require.
Eftersom KatePart är en texteditor är alla programmeringsgränssnitt baserade på markörer och intervall om det är möjligt. En markör (Cursor) är ett enkelt par (rad, kolumn), som representerar en textposition i dokumentet. Ett intervall (Range) omfattar text från en markörs startposition till en markörs slutposition. Programmeringsgränssnittet förklaras i detalj i följande avsnitt.
Cursor();
Konstruktor. Returnerar en markör på position
(0, 0).Exempel:
var cursor = new Cursor();Cursor(
int,radint);kolumnKonstruktor. Returnerar en markör på position (rad, kolumn).
Exempel:
var cursor = new Cursor(3, 42);Cursor(Cursor);annanKopieringskonstruktor. Returnerar en kopia av markören
annan.Exempel:
var copy = new Cursor(other);Cursor Cursor.clone();
Returnerar en klon av markören.
Exempel:
var clone = cursor.clone();Cursor.setPosition(
int,radint);kolumnStäller in markörens position till
radochkolumn.Sedan: KDE 4.11
bool Cursor.isValid();
Kontrollera om markören är giltig. Markören är ogiltig om rad och/eller kolumn har värdet
-1.Exampel:
var valid = cursor.isValid();Cursor Cursor.invalid();
Returnerar en ny ogiltig markör placerad på
(-1, -1).Exempel:
var invalidCursor = cursor.invalid();int Cursor.compareTo(Cursor);annanJämför den här markören med markören
annan. Returnerar-1, om den här markören är placerad innan markörenannan,0, om båda markörerna är lika, och+1, om den här markören är placerad efter markörenannan.
bool Cursor.equals(Cursor);annanReturnerar
santom den här markören och markörenannanär lika, annarsfalskt.String Cursor.toString();
Returnerar markören som en sträng på formen ”
Cursor(rad, kolumn)”.
Range();
Konstruktor. Att anropa
new Range()returnerar intervallet (0, 0) - (0, 0).Range(
Cursor,startCursor);slutKonstruktor. Att anropa
new Range(returnerar intervallet (start,slut)start,slut).Range(
int,startradint,startkolumnint,slutradint);slutkolumnConstructor. Calling
new Range(returnerar intervallet från (startrad,startkolumn,slutrad,slutkolumn)startrad,startkolumn) to (startrad,slutkolumn).Range(Range);annatKopieringskonstruktor. Returnerar en kopia av intervallet
annat.Range Range.clone();
Returnerar en klon av intervallet.
Exempel:
var clone = range.clone();bool Range.isEmpty();
Returnerar
santom både start- och slutmarkörerna är lika.Exempel:
var empty = range.isEmpty();Sedan: KDE 4.11
bool Range.isValid();
Returnerar
santom både start- och slutmarkörerna är giltiga, annarsfalskt.Exempel:
var valid = range.isValid();Range Range.invalid();
Returnerar intervallet från (-1, -1) till (-1, -1).
bool Range.contains(Cursor);markörReturnerar
trueom intervallet innehåller markörpositionen, annarsfalse.bool Range.contains(Range);annatReturnerar
santom det här intervallet innehåller intervalletannat, annarsfalskt.bool Range.containsColumn(int);kolumnReturnerar
santomkolumnär i det halvöppna intervallet[startkolumn, slutkolumn), annarsfalskt.bool Range.containsLine(int);radReturnerar
santomradär i det halvöppna intervallet[startrad, slutrad), annarsfalskt.bool Range.overlaps(Range);annatReturnerar
santom det här intervallet och intervalletannatdelar ett gemensamt område, annarsfalskt.bool Range.overlapsLine(int);radReturnerar
santomradär i intervallet[startrad, slutrad], annarsfalskt.bool Range.overlapsColumn(int);kolumnReturnerar
santomkolumnär i intervallet[startkolumn, slutkolumn], annarsfalskt.bool Range.onSingleLine();
Returnerar
santom intervallet startar och slutar på samma rad, dvs. omRange.start.line == Range.end.line.Sedan: KDE 4.9
bool Range.equals(Range);annanReturnerar
santom det här intervallet och intervalletannatär lika, annarsfalskt.String Range.toString();
Returnerar intervallet som en sträng på formen ”
Range(Cursor(rad, kolumn), Cursor(rad, kolumn))”.
Det här avsnittet listar alla globala funktioner.
String read(String);filSöker efter angiven
filrelativt i förhållande till katalogenkatepart5/script/filesoch returnerar innehållet som en sträng.
void require(String);filSöker efter angiven
filrelativt i förhållande till katalogenkatepart5/script/librariesoch utvärdera den. Internt skyddasrequirefrån att sammafilinkluderas flera gånger.Sedan: KDE 4.10
void debug(String);textSkriver ut
textpåstandardutmatningeni terminalen som startade programmet.
För att stödja fullständig landsanpassning, finns det flera funktioner för att översätta strängar i skript, närmare bestämt i18n, i18nc, i18np och i18ncp. Funktionerna beter sig exakt likadant som KDE:s översättningsfunktioner.
Översättningsfunktionerna översätter strängarna de omger via KDE:s översättningssystem till det språk som används i programmet. Strängar i skript som utvecklas i KateParts officiella källkod extraheras automatiskt och är översättningsbara. Med andra ord, som utvecklare av KatePart behöver man inte bry dig om att extrahera och översätta meddelanden. Observera dock att översättningen bara fungerar inne i KDE:s infrastruktur, nya strängar i skript från tredjepart som utvecklas utanför KDE, översätts inte. Överväg därför gärna att bidra med dina skript till Kate så att en passande översättning blir möjlig.
void i18n(
String,textarg1, ...);Översätter
texttill språket som används av programmet. Parametrarnaarg1, ... , är valfria och används för att ersätta platsmarkörerna%1,%2, etc.void i18nc(
String,sammanhangString,textarg1, ...);Översätter
texttill språket som används av programmet. Dessutom är strängensammanhangsynlig för översättare, så att de kan tillhandahålla en bättre översättning. Parametrarnaarg1, ... , är valfria och används för att ersätta platsmarkörerna%1,%2, etc.void i18np(
String,singularisString,pluralisint,antalarg1, ...);Översätter antingen
singularisellerpluralistill språket som används av programmet, beroende på angivetantal. Parametrarnaarg1, ... , är valfria och används för att ersätta platsmarkörerna%1,%2, etc.void i18ncp(
String,sammanhangString,singularisString,pluralisint,antalarg1, ...);Översätter antingen
singularisellerpluralistill språket som används av programmet, beroende på angivetantal. Dessutom är strängensammanhangsynlig för översättare, så att de kan tillhandahålla en bättre översättning. Parametrarnaarg1, ... , är valfria och används för att ersätta platsmarkörerna%1,%2, etc.
När ett skript håller på att köras, finns det en global variabel ”view” som representerar den för närvarande aktiva editorvyn. Det följande är en lista med alla tillgängliga funktioner i View.
void view.copy()Kopiera markeringen om det finns någon, annars aktuell rad om alternativet
[ ] Kopiera eller klipp ut nuvarande rad om markering saknasär aktiverat.Sedan: KDE Ramverk 5.79
void view.cut()Klipp ut markeringen om det finns någon, annars aktuell rad om alternativet
[ ] Kopiera eller klipp ut nuvarande rad om markering saknasär aktiverat.Sedan: KDE Ramverk 5.79
void view.paste()Klistra in klippbordets innehåll.
Sedan: KDE Ramverk 5.79
Cursor view.cursorPosition()Returnerar den nuvarande markörpositionen i vyn.
void view.setCursorPosition(
int,radint); void view.setCursorPosition(kolumnCursor);markörStäll in den nuvarande markörpositionen till antingen (rad, kolumn) eller till den givna markören.
Cursor view.virtualCursorPosition();
Returnerar den virtuella markörpositionen, där varje tabulator räknas som motsvarande antal mellanslag, beroende på nuvarande tabulatorbredd.
void view.setVirtualCursorPosition(
int,radint); void view.setVirtualCursorPosition(kolumnCursor);markörStäll in den nuvarande virtuella markörpositionen till (rad, kolumn) eller till den givna markören.
String view.selectedText();
Returnerar den markerade texten. Om ingen text är markerad, är den returnerade strängen tom.
bool view.hasSelection();
Returnerar
trueom vyn har markerad text, annarsfalse.Range view.selection();
Returnerar det markerade textintervallet. Det returnerade intervallet är ogiltigt om det inte finns någon markerad text.
void view.setSelection(Range);intervallStäller in markerad text till angivet intervall.
void view.removeSelectedText();
Tar bort den markerade texten. Om vyn inte har någon markerad text, händer ingenting.
void view.selectAll();
Markerar hela texten i dokumentet.
void view.clearSelection();
Rensar textmarkeringen utan att ta bort texten.
void view.setBlockSelection(bool on);
Sätt på eller stäng av blockmarkering.
bool view.blockSelection();
Returnerar
trueom blockmarkering är på, annarsfalse.void view.align(Range);intervallIndentera rader på ett riktigt sätt igen inom
intervallenligt aktuella indenteringsinställningar.void view.alignOn(
Range,intervallString);mönster= ""Justerar rader i
intervalli kolumnen som anges av det reguljära uttrycketmönster. Med ett tomtmönsterjusteras de normalt på den första tecknet som inte är ett blanktecken. Om mönstret har en platsmarkör indenterar det där markören matchar.Exempel:
view.alignOn(document.documentRange(), '-');infogar mellanslag innan första-på varje rad för att justera alla på samma kolumn.view.alignOn(document.documentRange(), ':\\s+(.)');infogar mellanslag före det första tecknet som inte är ett blanktecken efter ett kolon för att justera alla till samma kolumn.object view.executeCommand(
String,kommandoString,argumentRange);intervallKör kommandoradskommandot
kommandomed de valfria argumentenargumentoch ett valfrittintervall. Returneratobjekthar den Booleska egenskapenobjekt.oksom anger om körning avkommandolyckades. I händelse av fel, innehåller strängenobjekt.statusett felmeddelande.Sedan: KDE Ramverk 5.50
Range view.searchText(
Range,intervallString,mönsterbool);bakåt= falseSök efter den första förekomsten av
mönsteriintervalloch returnerar det matchade intervallet. Sökningen utförs bakåt om den valfria booleska parameternbakåtär inställd tilltrue.Det returnerade intervallet är ogiltigt (se Range.isValid()) om
mönsterinte hittas iintervall.Sedan: KDE Ramverk 5.97
När ett skript håller på att köras, finns det en global variabel ”document” som representerar det för närvarande aktiva dokumentet. Det följande är en lista med alla tillgängliga funktioner i Document.
String document.fileName();
Returnerar dokumentets filnamn eller en tom sträng för osparade textbuffrar.
String document.url();
Returnerar dokumentets fullständiga webbadress eller en tom sträng för osparade textbuffrar.
String document.mimeType();
Returnerar dokumentets Mime-typ eller MIME-typen
application/octet-streamom ingen lämplig MIME-typ kunde hittas.String document.encoding();
Returnerar den nuvarande kodningen använd för att spara filen.
String document.highlightingMode();
Returnerar det allmänna färgläggningsläget som används för hela dokumentet.
String document.highlightingModeAt(Cursor);posReturnerar färgläggningsläget som används på den givna positionen i dokumentet.
Array document.embeddedHighlightingModes();
Returnerar ett fält med färgläggningslägen inbäddade i det här dokumentet.
bool document.isModified();
Returnerar
trueom dokumentet har osparade ändringar (är modifierat), annarsfalse.String document.text();
Returnerar dokumentets hela innehåll i en enda textsträng. Nya rader är markerade med nyradstecknet ”
\n”.String document.text(
int,från_radint,från_kolumnint,till_radint); String document.text(till_kolumnCursor,frånCursor); String document.text(tillRange);intervallReturnerar texten i det angivna intervallet. Det rekommenderas att använda markör- och intervallbaserade versioner för bättre läsbarhet hos källkoden.
String document.line(int);radReturnerar den givna textraden som en sträng. Strängen är tom om den begärda raden är utanför tillgängligt intervall.
String document.wordAt(
int,radint); String document.wordAt(kolumnCursor);markörReturnerar ordet på den angivna markörposition.
-
Range document.wordRangeAt(
int,radint); Range document.wordRangeAt(kolumnCursor);markör Returnerar intervallet för ordet på den givna markörpositionen. Det returnerade intervallet är ogiltigt (se Range.isValid()) om textpositionen är efter ett radslut. Om det inte finns något ord vid den givna markörpositionen returneras ett tomt intervall.
Sedan: KDE 4.9
String document.charAt(
int,radint); String document.charAt(kolumnCursor);markörReturnerar tacknet på den angivna markörpositionen.
String document.firstChar(int);radReturnerar det första tecknet på angiven
radsom inte är ett blanktecken. Det första tecknet finns på kolumn 0. Om raden är tom, eller bara innehåller blanktecken, är den returnerade strängen tom.String document.lastChar(int);radReturnerar det sista tecknet på angiven
radsom inte är ett blanktecken. Om raden är tom, eller bara innehåller blanktecken, är den returnerade strängen tom.bool document.isSpace(
int,radint); bool document.isSpace(kolumnCursor);markörReturnerar
santom tecknet på den givna markörpositionen är ett blanktecken, annarsfalskt.bool document.matchesAt(
int,radint,kolumnString); bool document.matchesAt(textCursor,markörString);textReturnerar
santom giventextmatchar på den motsvarande markörpositionen, annarsfalskt.bool document.startsWith(
int,radString,textbool);hoppa_över_blankteckenReturnerar
santom raden börjar medtext, annarsfalskt. Argumentethoppa_över_blankteckenbestämmer om inledande blanktecken ignoreras.bool document.endsWith(
int,radString,textbool);hoppa_över_blankteckenReturnerar
santom raden slutar medtext, annarsfalskt. Argumentethoppa_över_blankteckenbestämmer om inledande blanktecken ignoreras.bool document.setText(String);textAnger hela dokumentets text.
bool document.clear();
Tar bort hela texten i dokumentet.
bool document.truncate(
int,radint); bool document.truncate(kolumnCursor);markörAvkortar den givna raden på den givna kolumnen eller markörpositionen. Returnerar
santom det lyckas, ellerfalsktom den givna raden inte ingår i dokumentets intervall.bool document.insertText(
int,radint,kolumnString); bool document.insertText(textCursor,markörString);textInfogar
textpå den givna markörpositionen. Returnerarsantom det lyckas, ellerfalsktom dokumentet är skrivskyddat.bool document.removeText(
int,från_radint,från_kolumnint,till_radint); bool document.removeText(till_kolumnCursor,frånCursor); bool document.removeText(tillRange);intervallTar bort text i det givna intervallet. Returnerar
santom det lyckas, ellerfalsktom dokumentet är skrivskyddat.bool document.insertLine(
int,radString);textInfogar text på den givna raden. Returnerar
santom det lyckas, ellerfalsktom dokumentet är skrivskyddat eller raden inte ingår i dokumentets intervall.bool document.removeLine(int);radTar bort den givna textraden. Returnerar
santom det lyckas, ellerfalsktom dokumentet är skrivskyddat eller raden inte ingår i dokumentets intervall.bool document.wrapLine(
int,radint); bool document.wrapLine(kolumnCursor);markörRadbryter raden vid den givna markörpositionen. Returnerar
santom det lyckas, ellerfalskt, t.ex. om rad < 0.Sedan: KDE 4.9
void document.joinLines(
int,startradint);slutradSammanfogar rader från
startradtillslutrad. Två på varandra följande rader åtskiljs alltid med exakt ett mellanslag.int document.lines();
Returnerar antal rader i dokumentet.
bool document.isLineModified(int);radReturnerar
santomradför närvarande innehåller osparad data.Since: KDE 5.0
bool document.isLineSaved(int);radReturnerar
santomradhar ändrats, men dokumentet har sparats. Sålunda innehåller raden för närvarande ingen osparad data.Since: KDE 5.0
bool document.isLineTouched(int);radReturnerar
santomradför närvarande innehåller osparad data eller tidigare har ändrats.Since: KDE 5.0
bool document.findTouchedLine(
int,startradbool);nerSök efter nästa ändrade rad med början på
rad. Sökningen utförs antingen uppåt eller neråt beroende på sökriktningen angiven medner.Since: KDE 5.0
int document.length();
Returnerar antal tecken i dokumentet.
int document.lineLength(int);radReturnerar längden på
rad.void document.editBegin();
Startar en redigeringsgrupp för gruppering av ångra/gör om. Försäkra dig om att alltid anropa
editEnd()lika många gånger som du anropareditBegin(). Att anropaeditBegin()använder en referensräknare internt, dvs. anropet kan nästlas.void document.editEnd();
Avslutar en redigeringsgrupp. Det sista anropet av
editEnd()(dvs. det för det första anropet tilleditBegin()) avslutar redigeringssteget.int document.firstColumn(int);radReturnerar det första tecknet som inte är ett blanktecken på given
rad. Om det bara finns blanktecken på raden, är returvärdet-1.int document.lastColumn(int);radReturnerar det sista tecknet som inte är ett blanktecken på given
rad. Om det bara finns blanktecken på raden, är returvärdet-1.int document.prevNonSpaceColumn(
int,radint); int document.prevNonSpaceColumn(kolumnCursor);markörReturnerar kolumnen med ett tecken som inte är ett blanktecken med början på given markörposition genom att söka bakåt.
int document.nextNonSpaceColumn(
int,radint); int document.nextNonSpaceColumn(kolumnCursor);markörReturnerar kolumnen med ett tecken som inte är ett blanktecken med början på given markörposition genom att söka framåt.
int document.prevNonEmptyLine(int);radReturnerar nästa rad som inte är tom och som innehåller tecken som inte är blanktecken, genom att söka bakåt.
int document.nextNonEmptyLine(int);radReturnerar nästa rad som inte är tom och som innehåller tecken som inte är blanktecken, genom att söka framåt.
bool document.isInWord(
String,teckenint);egenskapReturnerar
sant, om givetteckenmed givenegenskapkan vara en del av ett ord, annarsfalskt.bool document.canBreakAt(
String,teckenint);egenskapReturnerar
sant, om givetteckenmed givenegenskapär lämpat att bryta en rad, annarsfalskt.bool document.canComment(
int,startegenskapint);slutegenskapReturnerar
santom ett intervall som börjar och slutar med den givna egenskapen är lämpat att kommenteras bort, annarsfalskt.String document.commentMarker(int);egenskapReturnerar kommentarmarkören för enraderskommentarar för en given
egenskap.String document.commentStart(int);egenskapReturnerar kommentarmarkören för början av flerraderskommentarer för en given
egenskap.String document.commentEnd(int);egenskapReturnerar kommentarmarkören för slutet av flerraderskommentarer för en given
egenskap.Range document.documentRange();
Returnerar ett intervall som omfattar hela dokumentet.
Cursor documentEnd();
Returnerar en markör placerad på den sista radens sista kolumn i dokumentet.
bool isValidTextPosition(
int,radint); bool isValidTextPosition(kolumnCursor);markörReturnerar
santom den angivna markörpositionen är placerad på en giltig textposition. En textposition är bara giltig om den finns i början av, mitten av eller slutet av en giltig rad. Dessutom är en textposition ogiltig om den är placerad i ett Unicode-surrogat.Since: KDE 5.0
int document.attribute(
int,radint); int document.attribute(kolumnCursor);markörReturnerar egenskapen på den angivna markörpositionen.
bool document.isAttribute(
int,radint,kolumnint); bool document.isAttribute(egenskapCursor,markörint);egenskapReturnerar
santom egenskapen på den givna markörpositionen är lika medegenskap, annarsfalskt.String document.attributeName(
int,radint); String document.attributeName(kolumnCursor);markörReturnerar egenskapsnamnet som läsbar text. Det är lika med namnet
itemDatai syntaxfärgläggningsfilerna.bool document.isAttributeName(
int,radint,kolumnString); bool document.isAttributeName(namnCursor,markörString);namnReturnerar
santom egenskapsnamnet på en viss markörposition motsvara givetnamn, annarsfalskt.String document.variable(String);nyckelReturnerar värdet på den begärda dokumentvariabeln
nyckel. Om dokumentvariabeln inte finns, är returvärdet en tom sträng.void document.setVariable(
String,nyckelString);värdeStäll in värdet på den begärda dokumentvariabeln
nyckel.Se också: Kate-dokumentvariabler
Sedan: KDE 4.8
int document.firstVirtualColumn(int);radReturnerar den virtuella kolumnen för det första tecknet som inte är ett blanktecken på den givna raden, eller
-1om raden är tom eller bara innehåller blanktecken.int document.lastVirtualColumn(int);radReturnerar den virtuella kolumnen för det sista tecknet som inte är ett blanktecken på den givna raden, eller
-1om raden är tom eller bara innehåller blanktecken.int document.toVirtualColumn(
int,radint); int document.toVirtualColumn(kolumnCursor); Cursor document.toVirtualCursor(markörCursor);markörKonverterar den givna ”verkliga” markörpositionen till en virtuell markörposition, och returnerar antingen ett heltal eller ett markörobjekt.
int document.fromVirtualColumn(
int,radint); int document.fromVirtualColumn(virtuell_kolumnCursor); Cursor document.fromVirtualCursor(virtuell_markörCursor);virtuell_markörKonverterar den givna virtuella markörpositionen till en ”verklig” markörposition, och returnerar antingen ett heltal eller ett markörobjekt.
Cursor document.anchor(
int,radint,kolumnChar); Cursor document.anchor(teckenCursor,markörChar);teckenSöker bakåt efter det givna tecknet med början på den givna markören. Om exempelvis '(' anges som tecken, returnerar funktionen positionen på ett inledande '('. Det sker med referensräkning, dvs. andra '(...)' ignoreras.
Cursor document.rfind(
int,radint,kolumnString,textint); Cursor document.rfind(egenskap= -1Cursor,markörString,textint);egenskap= -1Söker bakåt efter den givna texten med lämplig
egenskap. Argumentetegenskapignoreras om det anges som-1. Den returnerade markören är ogiltig om texten inte kunde hittas.int document.defStyleNum(
int,radint); int document.defStyleNum(kolumnCursor);markörReturnerar standardstilen som används på den givna markörpositionen.
bool document.isCode(
int,radint); bool document.isCode(kolumnCursor);markörReturnerar
santom egenskapen på given markörposition inte är lika med någon av följande stilar:dsComment,dsString,dsRegionMarker,dsChar,dsOthers.bool document.isComment(
int,radint); bool document.isComment(kolumnCursor);markörReturnerar
sant, om egenskapen för tecknet på markörpositionen ärdsComment, annarsfalskt.bool document.isString(
int,radint); bool document.isString(kolumnCursor);markörReturnerar
sant, om egenskapen för tecknet på markörpositionen ärdsString, annarsfalskt.bool document.isRegionMarker(
int,radint); bool document.isRegionMarker(kolumnCursor);markörReturnerar
sant, om egenskapen för tecknet på markörpositionen ärdsRegionMarker, annarsfalskt.bool document.isChar(
int,radint); bool document.isChar(kolumnCursor);markörReturnerar
sant, om egenskapen för tecknet på markörpositionen ärdsChar, annarsfalskt.bool document.isOthers(
int,radint); bool document.isOthers(kolumnCursor);markörReturnerar
sant, om egenskapen för tecknet på markörpositionen ärdsOthers, annarsfalskt.void document.indent(
Range,intervallint);ändringIndentera alla rader i
intervallmedändringtabulatortecken ellerändringgångertabulatorstorlekmellanslag beroende på användarens inställningar. Parameternändringkan vara negativ.
Förutom dokumentet och programmeringsgränssnittet för vyn, finns ett generellt programmeringsgränssnitt för editorn som tillhandahåller funktioner för allmän redigeringsskriptfunktionalitet.
String editor.clipboardText();
Returnerar texten som för närvarande finns i det globala klippbordet.
Sedan: KDE Ramverk 5.50
String editor.clipboardHistory();
Editorn har en klippbordshistorik som innehåller upp till tio klippbordsposter. Funktionen returnerar alla poster som för närvarande finns i klippbordshistoriken.
Sedan: KDE Ramverk 5.50
void editor.setClipboardText(String);textStäll in klippbordets innehåll till
text.textläggs till i klippbordshistoriken.Sedan: KDE Ramverk 5.50