Sophie

Sophie

distrib > Mageia > 1 > i586 > by-pkgid > 465db973f257b5c088eeb6a276b5cbfa > files > 12

kdiff3-0.9.95-4.mga1.i586.rpm

<?xml version="1.0" ?>
<!DOCTYPE book PUBLIC "-//KDE//DTD DocBook XML V4.2-Based Variant V1.1//EN" "dtd/kdex.dtd" [
  <!ENTITY kdiff3 "<application
>KDiff3</application
>">
  <!ENTITY kappname "&kdiff3;">
  <!ENTITY package "extragear-utils">
  <!ENTITY % addindex "IGNORE">
  <!ENTITY % Estonian  "INCLUDE">
]>

<book lang="&language;">

<!-- This header contains all of the meta-information for the document such
as Authors, publish date, the abstract, and Keywords -->

<bookinfo>
<title
>&kdiff3; käsiraamat</title>

<authorgroup>
<author
><firstname
>Joachim</firstname
> <surname
>Eibl</surname
> <affiliation
><address
> <email
>joachim.eibl at gmx.de</email>
</address
></affiliation>
</author>
<othercredit role="translator"
><firstname
>Marek</firstname
> <surname
>Laane</surname
> <affiliation
><address
><email
>bald@starman.ee</email
></address
></affiliation
><contrib
>Tõlge eesti keelde</contrib
></othercredit
> 
</authorgroup>

<copyright>
<year
>2002-2007</year>
<holder
>Joachim Eibl</holder>
</copyright>
<!-- Translators: put here the copyright notice of the translation -->
<!-- Put here the FDL notice.  Read the explanation in fdl-notice.docbook
     and in the FDL itself on how to use it. -->
<legalnotice
>&FDLNotice;</legalnotice>

<!-- Date and version information of the documentation
Don't forget to include this last date and this last revision number, we
need them for translation coordination !
Please respect the format of the date (YYYY-MM-DD) and of the version
(V.MM.LL), it could be used by automation scripts.
Do NOT change these in the translation. -->

<date
>2007-31-03</date>
<releaseinfo
>0.9.92</releaseinfo>


<abstract>
<para
>&kdiff3; on failide ja kataloogide võrdlemise ja ühendamise vahend, mis <itemizedlist>
<listitem
><para
>võrdleb ja ühendab kaks või kolm sisendfaili või -kataloogi,</para
></listitem>
<listitem
><para
>näitab erinevusi rida realt ja sümbol sümbolilt (!),</para
></listitem>
<listitem
><para
>pakub automaatse ühendamise võimalust,</para
></listitem>
<listitem
><para
>võimaldab kasutada hõlpsasti ühendamiskonflikte lahendada suutvat redaktorit</para
></listitem>
<listitem
><para
>pakub tänu KIO moodulitele võrguläbipaistvust</para
></listitem>
<listitem
><para
>võimaldab esile tõsta või peita tühikute või kommentaaride erinevusi</para
></listitem>
<listitem
><para
>toetab Unicode'i, UTF-8 ja muid kodeeringuid.</para
></listitem>
<listitem
><para
>näitab erinevusi,</para
></listitem>
<listitem
><para
>toetab versioonikontrolli võtmesõnade ja ajaloo ühendamist.</para
></listitem>
</itemizedlist>
</para
><para
>Käesolev käsiraamat kirjeldab &kdiff3; versiooni 0.9.92. </para>
</abstract>

<!-- This is a set of Keywords for indexing by search engines.
Please at least include KDE, the KDE package it is in, the name
 of your application, and a few relevant keywords. -->

<keywordset>
<keyword
>KDE</keyword>
<keyword
>kdeextragear</keyword>
<keyword
>kdiff3</keyword>
<keyword
>diff</keyword>
<keyword
>ühendamine</keyword>
<keyword
>CVS</keyword>
<keyword
>kolmikvõrdlus</keyword>
<keyword
>võrdlemine</keyword>
<keyword
>failid</keyword>
<keyword
>kataloogid</keyword>
<keyword
>versioonide kontroll</keyword>
<keyword
>kolmikühendamine</keyword>
<keyword
>reaerinevused</keyword>
<keyword
>sünkroniseerimine</keyword>
<keyword
>kpart</keyword>
<keyword
>kio</keyword>
<keyword
>võrguläbipaistvus</keyword>
<keyword
>redaktor</keyword>
<keyword
>tühimärgid</keyword>
<keyword
>kommentaarid</keyword>
</keywordset>

</bookinfo>

<chapter id="introduction"
><title
>Sissejuhatus</title>
<sect1 id="why"
><title
>Veel üks võrdlemisrakendus?</title>
<para
>Teatavasti on olemas üsna mitu graafilist võrdlusrakendust. Miks siis veel &kdiff3;? Siin ma selgitan veidi selle loomise tagamaid. </para
><para
>&kdiff3; nägi ilmavalgust sellepärast, et mul oli raskusi ühendamisega. Ühendamine on hädavajalik, kui mingi projekti failide kallal töötab korraga mitu inimest. Ühendamine peab olema mingil määral automatiseeritud, kui arvestada seda, et ühendamisvahend tegeleb nii uute, muudetud failidega (niinimetatud harudega) kui ka algse failiga (niinimetatud baas). Ühendamisvahend valib automaatselt muudatuse, mis mingis harus on tehtud. Kui mitu arendajat on muutnud üht ja sama rida, tuvastab ühendamisvahend konflikti, mis tuleb lahendada käsitsi. </para
><para
>Ühendamine oli sellisel juhul keeruline, sest üks arendaja muutis hulk asju ja lisaks sellele parandas veel paljudes kohtades näiteks taanet. Samal ajal muutis teine arendaja samuti üsna palju samas failis ja nii tekkiski korraga mitu ühendamiskonflikti. </para
><para
>Vahendid, mida ma toona kasutasin, näitasid ainult muudetud ridu, aga mitte seda, mida neis ridades on muudetud. Ning miski ei viidanud ka sellele, et muudetud on ainult taanet. See muutis ühendamise väikest viisi luupainajaks. </para
><para
>Minu jaoks oli see alguspunkt. Esimene versioon oskas näidata erinevusi rea sees ning erinevusi tühimärkides. Hiljem lisandus veel hulk võimalusi, mis ainult suurendasid rakenduse kasulikkust. </para
><para
>Nii on näiteks võimalik teksti kiireks võrdlemiseks kopeerida see lõikepuhvrisse ja asetada siis mis tahes võrdlusaknasse. </para
><para
>Päris suurt pingutust nõudvaks võimaluseks osutus kataloogide võrdlemine ja ühendamine, mille tulemusena sündis peaaegu juba brauseri mõõtu lisandus. </para
><para
>Ma loodan, et &kdiff3; rahuldab ka sinu vajadused. Edu sulle! </para
><para
>Joachim Eibl (2003) </para>
</sect1>

<sect1 id="screenshots"
><title
>Pildid ja võimalused</title>
<para
>See pilt näitab erinevust kahe tekstifaili vahel</para>
<para
>(&kdiff3; üks varasemaid versioone):</para>
<screenshot
><mediaobject>
   <imageobject
><imagedata fileref="screenshot_diff.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>

<para
>Kolmikühendamine on täielikult toetatud. See on abiks juhul, kui kaks inimest on koodi teineteisest sõltumatult muutnud. Algne fail (baas) võimaldab &kdiff3; automaatselt valida korrektsed muudatused. Võrdlusakende all asuv ühendamisredaktor lubab konflikte lahendada ja näitab, milline on sellisel juhul tulemus. Isegi seda tulemust saab kohe edasi redigeerida. See pilt näitab kolme sisendfaili ühendamist: </para
><para>
<screenshot
><mediaobject>
   <imageobject
><imagedata fileref="screenshot_merge.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</para>

<para id="dirmergebigscreenshot"
>&kdiff3; aitab ka võrrelda ja ühendada terveid katalooge. See pilt näitabki &kdiff3; kataloogide ühendamisel: </para
><para>
<screenshot
><mediaobject>
   <imageobject
><imagedata fileref="dirmergebig.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</para>
</sect1>

<sect1 id="features"
><title
>Veel võimalusi</title>
<sect2
><title
>Võrdlemine rida realt ja märk märgilt</title>
<para
>Graafiliselt, värvidega näitab &kdiff3; täpselt, milles peituvad erinevused. Kui tegeled palju koodi (ümber)kirjutamisega, on see kindlasti abiks. </para>
<screenshot
><mediaobject>
   <imageobject
><imagedata fileref="letter_by_letter.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</sect2>

<sect2
><title
>Tühimärkide erinevuste näitamine</title>
<para
>Tühikute ja tabeldusmärkide erinevused näidatakse otseselt ära. Kui read erinevad ainult tühimärkide arvu poolest, võib seda üheainsa pilguga näha vasakul asuval kokkuvõttetulbal (mis tähendab, et ei pruugi enam pead murda, kui muudetud on kõigest taanet). </para>
<screenshot
><mediaobject>
   <imageobject
><imagedata fileref="white_space.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</sect2>

<sect2
><title
>Kolmikvõrdlus</title>
<para
>Kolme faili analüüs ja nende erinevuste näitamine. </para
><para
>Vasakpoolne, keskmine ja parempoolne aken kannavad vastavalt nimesid A, B ja C ning neid eristab ka värv (sinine, roheline, magenta). </para
><para
>Kui ühes failis on rida sama, teises aga erinev, näitab värv, milline fail on erinev. Punane värv tähendab, et mõlemad ülejäänud failid on erinevustega. </para>
<screenshot
><mediaobject>
   <imageobject
><imagedata fileref="triple_diff.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
</sect2>

<sect2
><title
>Kahe või kolme sisendfaili hõlpus ühendamine</title>
<para
>&kdiff3; võib ühendada kaks või kolm sisendfaili, sealjuures võimalikult palju juba automaatselt. Tulemust näidatakse redigeeritavas aknas, kus enamiku konflikte saab lahendada üheainsa hiireklõpsuga: vali nupuribalt A, B või C määramaks, millist allikat kasutada. Valida võib ka enam kui ühe allika. Kuna väljundiaken on samal ajal redaktor, siis saab isegi selliseid konflikte, mille puhul tuleb midagi täiendavalt teha, lahendada ilma mingit muud abivahendit kasutamata. </para>
</sect2>

<sect2
><title
>Ja veel...</title>
<itemizedlist>
   <listitem
><para
>Kiire liikumine nuppude abil.</para
></listitem>
   <listitem
><para
>Hiireklõps kokkuvõttetulbal sünkroniseerib kõik aknad ühele positsioonile.</para
></listitem>
   <listitem
><para
>Valimine ja kopeerimine mis tahes aknast ning asetamine ühendamisaknasse.</para
></listitem>
   <listitem
><para
>Ülevaatetulp, mis näitab, kus esineb muudatusi ja konflikte.</para
></listitem>
   <listitem
><para
>Värve saab kohandada just kasutaja maitsele.</para
></listitem>
   <listitem
><para
>Kohandatav tabeldusmärgi suurus.</para
></listitem>
   <listitem
><para
>Võimalus lisada tabeldusmärkide asemel tühikud.</para
></listitem>
   <listitem
><para
>Failide hõlpus avamine dialoogiga või võimalus määrata faile käsureal.</para
></listitem>
   <listitem
><para
>Stringide otsimine kõigis tekstiakendes (Otsi ehk CTRL+F ja Otsi järgmine ehk F3).</para
></listitem>
   <listitem
><para
>Iga rea reanumbri näitamine. </para
></listitem>
   <listitem
><para
>Lõikepuhvri sisu asetamine või teksti lohistamine võrdlemise sisendaknasse.</para
></listitem>
   <listitem
><para
>Võrguläbipaistvus KIO-moodulite vahendusel.</para
></listitem>
   <listitem
><para
>Võimalus kasutada KDevelop3 erinevuste näitajana.</para
></listitem>
   <listitem
><para
>Pikkade ridade murdmine.</para
></listitem>
   <listitem
><para
>Unicode'i, UTF-8 ja muude kodeeringute toetus.</para
></listitem>
   <listitem
><para
>Paremalt vasakule kirjutatavate keelte toetus.</para
></listitem>
   <listitem
><para
>...</para
></listitem>
</itemizedlist>
</sect2>
</sect1>
</chapter>

<chapter id="documentation"
><title
>Failide võrdlemine ja ühendamine</title>

<sect1 id="commandline"
><title
>Käsurea võimalused</title>

<sect2
><title
>Kahe faili võrdlemine: </title>
<screen
><command
>kdiff3</command
> <replaceable
>fail1 fail2</replaceable
>
</screen>
</sect2>

<sect2
><title
>Kahe faili ühendamine: </title>
<screen
><command
>kdiff3</command
> <replaceable
>fail1 fail2</replaceable
> -m
   <command
>kdiff3</command
> <replaceable
>fail1 fail2</replaceable
> -o <replaceable
>väljundfail</replaceable
>
</screen>
</sect2>

<sect2
><title
>Kolme faili võrdlemine: </title>
<screen
><command
>kdiff3</command
> <replaceable
>fail1 fail2 fail3</replaceable
>
</screen>
</sect2>

<sect2
><title
>Kolme faili ühendamine: </title>
<screen
><command
>kdiff3</command
> <replaceable
>fail1 fail2 fail3</replaceable
> -m
   <command
>kdiff3</command
> <replaceable
>fail1 fail2 fail3</replaceable
> -o <replaceable
>väljundfail</replaceable
>
</screen>
<para
>Pane tähele, et <replaceable
>fail1</replaceable
> kujutab endast baasi <replaceable
>fail2</replaceable
> ja <replaceable
>fail3</replaceable
> jaoks. </para>
</sect2>

<sect2
><title
>Erijuhtum: ühenimelised failid </title>
<para
>Kui kõigil failidel on sama nimi, aga nad asuvad erinevates kataloogides, võib kirjutamisvaeva vähendada, andes ainult esimese faili nime. Näiteks: </para>
<screen
><command
>kdiff3</command
> <replaceable
>kataloog1/failinimi kataloog2 kataloog3</replaceable
>
</screen>
</sect2>

<sect2
><title
>Kataloogide võrdlemine või ühendamine käsureal: </title>
<para
>See käib samamoodi, ainult et tegu on kataloogidega.</para>
<screen
><command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2</replaceable>
   <command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2</replaceable
> -o <replaceable
>sihtkataloog</replaceable>
   <command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2 kataloog3</replaceable>
   <command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2 kataloog3</replaceable
> -o <replaceable
>sihtkataloog</replaceable
>
</screen>
<para
>Kataloogide võrdlemisest ja ühendamisest saab täpsemalt lugeda <link linkend="dirmerge"
>siit</link
>.</para>
</sect2>

<sect2
><title
>Muud käsurea võtmed</title>
<para
>Kõiki käsurea võtmeid näitab käsk</para>
<screen
><command
>kdiff3</command
> --help
</screen>
<para
>Näidisväljund:</para>
<screen
>Võtmed:
  -m, --merge               Sisendi liitmine.
  -b, --base fail           Baasfail. Ühilduvuseks teatud tööriistadega.
  -o, --output fail         Väljundfail. Eelduseks -m. Nt.: -o newfile.txt
  --out fail                Taas väljundfail. (Ühilduvuseks teatud tööriistadega.)
  --auto                    GUI puudub, kui kõik konfliktid on automaatselt lahenevad. (Vajalik on -o file)
  --qall                    Konflikte ei lahendata automaatselt. (Ühilduvuseks...)
  --L1 alias1               Sisendfaili 1 (baas) näidatava nime asendus.
  --L2 alias2               Sisendfaili 2 näidatava nime asendus.
  --L3 alias3               Sisendfaili 3 näidatava nime asendus.
  -L, --fname alias         Alternatiivne näidatava nime asendus. Tuleb anda kord iga sisendi kohta.
  --cs string               Tühistab seadistuse. Tuleb anda eraldi iga seadistuse kohta. Näide: --cs "AutoAdvance=1"
  --confighelp              Näitab seadistusi ja nende kehtivaid väärtusi.
  --config fail             Mõne muu seadistustefaili kasutamine.
</screen>
<para
>Võti <option
>--cs</option
> võimaldab muuta seadistuse väärtust, mida muidu saab muuta ainult seadistustedialoogi vahendusel. Kuid arvesta, et kui &kdiff3; töö lõpetab, salvestatakse muudetud väärtus. Võtmega <option
>--confighelp</option
> näeb saadaolevate seadistuste nimesid ja nende kehtivaid väärtusi.</para>
<para
>Võtmega <option
>--config</option
> saab määrata mõne muu seadistustefaili kasutamise. Kui kasutad sageli &kdiff3; mitme täiesti erineva seadistusega, lubab see võti variantide vahel hõlpsasti lülituda.</para>
</sect2>
<sect2
><title
>Eiratavad käsurea võtmed</title>
<para
>Paljud soovivad kasutada &kdiff3; mõne versioonikontrollisüsteemiga. Aga kui versioonikontrollisüsteem kutsub &kdiff3; välja käsureaparameetriga, mida &kdiff3; ei tunne, lõpetab &kdiff3; töö veaga. Lõimimisseadistused lubavad määrata kindlaks käsureaparameetrid, mida &kdiff3; peab eirama. Neid näidatakse abiteates umbes nii:</para>
<screen
><replaceable
>miski</replaceable
>                     Eiratakse (kasutaja määratud).
</screen>
<variablelist>
  <varlistentry
><term
><emphasis
>Eiratavad käsureavõtmed:</emphasis
></term
><listitem
><para
>Võtmete nimekiri, eraldajaks semikoolon ';'. Kui käsureal esineb mõni määratud võtmetest, eirab &kdiff3; seda ja töötab edasi veast teatamata. (Vaikimisi "u;query;html;abort").</para
></listitem
></varlistentry>
</variablelist>
<para
>Kui sellest ei piisa, on soovitatav kirjutada shelliskript, mis seab võtmed vastavusse.</para>
</sect2>

</sect1>

<sect1 id="opendialog"
><title
>Avamisdialoog</title>
<para
>Et mitme sisendfaili korral nad lihtsalt peavad olema valitavad, on rakendusel eriline avamisdialoog: </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="open_dialog.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
<para
>Avamisdialoog võimaldab redigeerida failinimesid käsitsi, valida need failidialoogis ("Fail...") või kasutada rippmenüüs olevaid viimati kasutatud faile. Kui avad dialoogi uuesti, on seal kirjas parajasti aktiivsed failinimed. Kolmanda sisendvälja täitmine ei ole kohustuslik. Kui "C" tühjaks jätta, analüüsitakse ainult kahe faili erinevusi. </para
><para
>Nupule "Kataloog..." klõpsates saab valida kataloogi. Kui A jaoks on määratud kataloog, saab alustada kataloogide võrdlemist-ühendamist. Kui A on fail, kuid B, C või väljund kataloogid, kasutab &kdiff3; A failinime määratud kataloogides. </para
><para
>Kui märkida "Ühenda", saab kasutada ka välja "Väljund". Siiski ei ole nõutav väljundfaili nime kohe määrata, selle võib edasi lükata ka salvestamise ajale. </para
><para
>Klõps nupule "Seadista..." avab valikute dialoogi, kus saab enne analüüsi midagi muuta, kui pead seda vajalikuks. </para>
</sect1>

<sect1 id="pasteinput"
><title
>Sisendi asetamine ja lohistamine</title>
<para
>Vahel võib tekkida vajadus võrrelda tekstilõke, mis ei kujuta endast omaette faile. &kdiff3; võimaldab väga lihtsalt asetada teksti lõikepuhvrist parajasti fookuses olevasse võrdlemise sisendaknasse. Võrdlusanalüüs algab kohe seejärel. Avamisdialoogis ei ole sellisel juhul vajalik määrata faile, vaid selle võib kohe sulgeda klõpsuga nupule "Loobu". </para
><para
>Samuti võib kasutada lohistamist: lohista fail failihalduris või valitud tekst redaktorist ning kukuta see võrdlemise sisendaknasse. </para
><para
>Milleks see hea on? Mõnikord võib fail sisaldada kaht sarnast funktsiooni, kuid kontrollimine, kui sarnased nad ikkagi on, võib olla päris tülikas, kui sa pead näiteks kõigepealt looma kaks faili ja siis nad mõlemad avama. Nüüd aga on võimalik vajalikud osad lihtsalt kopeerida, asetada ja võrdlemine võibki alata. </para
><para
>Märkus: praegu ei ole võimalik midagi &kdiff3;-st välja lohistada, toetatud on ainult lohistamine võrdlemise sisendaknasse. </para
><para
>Hoiatus: mõned redaktorid tõlgendavad lohistamist muusse rakendusse mitte kopeerimise, vaid lõikamisena. See tähendab, et sa võid kaotada oma esialgsed andmed. </para>
</sect1>

<sect1 id="interpretinginformation"
><title
>Failide võrdlemine ja info tõlgendamine sisendaknas</title>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="screenshot_diff.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
<sect2
><title
>Inforiba</title
><para
>Iga tekstiakna ülaservas asub "inforiba". Sisendakende inforibal seisab täht "A", "B" või "C", failinimi, sirvimisnupp ning aknas esimesena näha oleva rea number. (Pane tähele, et akent "C" ei pruugi olemas olla.) Iga inforiba on erinevat värvi. </para
><para
>Kui valid sirvides mõne muu faili või lõpetad failinime redigeerimise klahvile Enter vajutades, laaditakse uus fail ja võrreldakse seda juba laaditud faili(de)ga. </para
></sect2
><sect2
><title
>Värvid</title
><para
>Kolmele sisendaknale on omistatud tähed "A", "B" ja "C". "A" värviks on sinine, "B" roheline ja "C" magenta. Need on vaikeväärtused, mida saab muuta seadistustemenüüst. </para
><para
>Erinevuse avastamisel näitab värv, milline sisendfail erineb. Kui erinevad mõlemad sisendfailid, siis väljendab seda vaikimisi punane värv (seadistuste kohaselt "konflikti värv"). Värviskeem tuleb eriti kasuks kolme sisendfaili korral, mida võib näha järgmises osas (<link linkend="merging"
>Ühendamine</link
>). </para
></sect2
><sect2
><title
>Kokkuvõttetulp</title
><para
>Igast tekstist vasakul asub "kokkuvõttetulp". Kui real on erinevusi, näitab kokkuvõttetulp vastavat värvi. Ainult tühimärkide erinevuse korral on kokkuvõttetulbal näha ruuduline muster. See on abiks programmeerimiskeelte korral, kus tühimärkidel ei ole erilist tähendust, võimaldades ühe hetkega tuvastada, kas on ka mingeid olulisi muudatusi (näiteks C/C++ korral on tühimärkidel mingi roll ainult stringides, kommentaarides, preprotsessoris ja veel mõnel äärmiselt esoteerilisel juhtumil). </para
><para
>Kokkuvõttetulpa ja teksti lahutav püstjoon on katkestatud, kui sisendfailis pole selles kohas ühtki rida. Reamurdmise lubamisel on püstjoon murtud ridade juures punkteeritud. </para
></sect2
><sect2
><title
>Ülevaateriba</title
><para
>Paremal on otse kerimisriba kõrval näha "ülevaateriba". See näitab kokkusurutult sisendfaili "A" kokkuvõttetulpa. Nii on kõik erinevused ja konfliktid korraga näha. Kui kasutada ainult kaht sisendakent, on kõik erinevused punased, sest iga erinevus on sellisel juhul ju ka konflikt. Must ristkülik tähistab parajasti aknas näha olevat tekstiosa. Väga pikkade sisendfailide korral, kus sisendi ridade arv on suurem kui ülevaatetulba kõrgus pikslites, mahutatakse ühele ülevaatereale mitu sisendirida. Konflikti näitamist eelistatakse sellisel juhul tavalisele erinevusele ning viimast muutmata olekule, nii ei jää kindlasti nägemata ükski erinevus või konflikt. Ülevaateribale klõpsates näidatakse vastavat kohta tekstis. </para
></sect2
><sect2 id="manualdiffhelp"
><title
>Ridade joondamine käsitsi</title
><para
>Vahel seab algoritm kõrvuti valed read. Võib ka juhtuda, et soovid võrrelda mingit tekstilõiku teises failis täiesti teises kohas asuva lõiguga. Sel juhul saad anda &kdiff3;-le käsitsi korralduse teatud read joondada. Märgi esimeses vaates tekst, mida soovid kasutada (tee seda hiirega, nagu kopeerimise puhul), ning seejärel vali käsk "Lisa käsitsi samasus" menüüst "Võrdlemine" (kiirklahv "Ctrl+Y"). Valitud teksti kõrvale ilmub kokkuvõttetulbas oranž riba. Korda sama tegevust teises ja vajaduse korral kolmandaski vaates. &kdiff3; leiab iga toimingu järel automaatselt erinevused ja joondab valitud read. Loomulikult on sel juhul võimalik, et teatud varasemad sobivused kuskil vahepeal enam ei klapi. </para
><para
>Praegu ei ole ühendamisel toetatud käsitsi erinevuste kasutamine. </para
></sect2
><sect2 id="joinsplitsections"
><title
>Erinevuse osade käsitsi ühendamine ja lahutamine</title
><para
>Mõnel juhul võib tekstis olla &kdiff3; jaoks liiga vähe või liiga palju erinevaid osasid, et neid ühendada. Sel juhul võib olemasolevad osad liita või lahutada. </para
><para
>Uute lõikude lisamiseks vali kõigepealt mõnes sisendaknas read, mis kuuluvad kokku (tee seda samamoodi nagu lõikepuhvrisse kopeerimisel). Seejärel vali käsk "Jaga erinevused valiku juures" menüüst "Ühendamine". Jagatud osad lisatakse valitud teksti esimese rea ette ja viimase rea järele. Kui soovid lisada ainult ühe lõigu, vali tekst mõne muu lõigujagamise alguses. </para
><para
>Lõikude liitmiseks ükspuha kumbas sisendaknas vali read lõikudes, mida soovid liita (ühekorraga võib liita mitu lõiku). Seejärel vali käsk "Ühenda valitud erinevused" menüüst "Ühendamine". </para
></sect2>
</sect1>


<sect1 id="merging"
><title
>Ühendamine ja ühendamisväljundi redigeerimisaken</title>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="screenshot_merge.png" format="PNG"/></imageobject>
</mediaobject
></screenshot>
<para
>Ka ühendamisväljundi redigeerimisaknal (allpool võrdlemise sisendaknaid) on ülaservas inforiba, kus seisab "Väljund:", failinimi ja "[Muudetud]", kui oled midagi muutnud. Tavaliselt leidub seal automaatse ühendamise vahendite pakutav tekst, kuid tihtipeale ka konfliktid. </para
><para
>!!! Salvestamine on võimalik alles siis, kui kõik konfliktid on lahendatud !!! (allesjäänud konfliktide lahendamiseks kasuta nuppe "Liigu eelmisele/järgmisele lahendamata konfliktile") </para
><para
>Kui on ainult kaks sisendfaili, on iga erinevus ühtlasi konflikt, mis tuleb käsitsi lahendada. </para
><para
>Kolme sisendfaili korral käsitletakse esimest baasina, teist ja kolmandat aga potentsiaalseid muudatusi sisaldavate failidena. Kui muudetud on rida ainult sisendis B või C, aga mitte mõlemas, valitakse automaatselt muudetud allikas. Kui aga nii B kui C on (erinevalt) muutnud üht ja sama rida, märgitakse see konfliktina, mis tuleb käsitsi lahendada. Kui B ja C on ühesugused, aga erinevad A-st, valitakse C. </para
><sect2
><title
>Kokkuvõttetulp</title
><para
>Ka ühendamisväljundi redigeerimisaknal on vasakus servas kokkuvõttetulp. See näitab sisendi tähte, millest rida on valitud, või mitte midagi, kui rida on kõigis kolmes allikas võrdne. Konflikti korral on seal küsimärk "?" ning real endal seisab "&lt;Ühendamise konflikt&gt;, kõik ilusasti puust ja punaseks tehtud. Kuna konfliktide lahendamine rida-realt võib võtta päris palju aega, on read rühmitatud gruppidesse, millel on ühesugused erinevuse ja konflikti omadused. Samas on ainult tühimärkide konfliktid eraldatud muudest konfliktidest, et hõlbustada selliste failide ühendamist, kus taanet on muudetud paljudel ridadel. </para
></sect2
><sect2 id="synchronise_views"
><title
>Aktiivse grupi määramine ning ühendamise ja võrdlemise vaadete sünkroniseerimine</title
><para
>Kui klõpsata hiire vasaku nupuga kokkuvõttetulbal mis tahes aknas, siis valitakse selle rea grupp kõigis akendes ning näidatakse antud grupi algust (see võib kaasa tuua automaatse asukohavahetuse akendes, kui grupi algus ei ole parajasti näha). Valitud grupp muutub sellega "aktiivseks grupiks", see tõstetakse esile "praeguse vahemiku tausta värviga" ning tekstist vasakule ilmub must tulbake. </para
></sect2
><sect2
><title
>Sisendi A, B või C valimine aktiivse konflikti ja redigeerimise jaoks</title
><para
>Nupureal menüüriba all on näha kolm sisendi valimise nuppu tähtedega "A", "B" ja "C". Klõpsa ühele neist vastava allika ridade lisamiseks (või eemaldamiseks, kui need on juba lisatud). Mitme sisendi ridade valimiseks klõpsa vajalikele nuppudele vajalikus järjekorras. Kui näiteks soovid, et "B" read oleks väljundis "A" ridadest eespool, klõpsa kõigepealt "B" ja siis "A". </para
><para
>Kui kasutad automaatse edasiliikumise võimalust (<link linkend="autoadvance"
>"Automaatne liikumine järgmisele lahendamata konfliktile pärast allika valimist"</link
>), tuleb see välja lülitada, enne kui valid mitme sisendi read või soovid pärast valikut ridu redigeerida. Vastasel juhul hüppab &kdiff3; pärast esimese sisendi valimist järgmise konflikti juurde. </para
><para
>Sageli on kasulik ühendamise väljundit otseselt redigeerida. Kokkuvõttetulp näitab iga käsitsi muudetud rea juures tähte "m". Kui erinevused paiknevad viisil, et lihtne sisendi valimine ei anna rahuldavat tulemust, võid märkida vajaliku teksti, selle <link linkend="selections"
>kopeerida ja asetada</link
> otse ühendamise väljundisse. </para
><para
>Vahel võib juhtuda, et rida eemaldatakse automaatse liitmisega või redigeerides. Kui gruppi ei ole jäänud enam ühtki rida, ilmub sellele reale tekst &lt;Lähterida puudub&gt;. See on kõigest grupi kohatäitja juhuks, kui muudad meelt ja valid taas mõne allika. Seda teksti ei ole näha ei salvestatud failis ega kopeeritavates/asetatavates valikutes. </para
><para
>Tekst "&lt;Ühendamise konflikt&gt;" seevastu liigub küll lõikepuhvrisse, kui valida ja kopeerida/asetada sellist rida sisaldav tekst. Seepärast tasuks sellise võimalusega ettevaatlik olla. </para
></sect2
><sect2
><title
>Sisendi A, B või C valimine kõigile konfliktidele</title
><para
>Tavaline ühendamine lahendab lihtsad konfliktid automaatselt. Menüü "Ühendamine" pakub lisaks mõningaid toiminguid muude levinumate vajaduste rahuldamiseks. Kui sul tuleb enamasti konfliktide puhul valida üks ja sama baas, võid valida kõikjal "A", "B" või "C" või ainult veel lahendamata konfliktidele või ainult lahendamata tühimärkide konfliktidele. Kui soovid lahendada iga erinevuse ise käsitsi, võid lülitada sisse võimaluse "Määra erinevused konfliktideks". Kui soovid aga taas panna &kdiff3; automaatselt konflikte lahendama, vali "Lahenda automaatselt lihtsad konfliktid". Seejärel alustab &kdiff3; uuesti ühendamist. Kui selle käigus muudetakse midagi, mida oled varem muutnud, küsib &kdiff3; enne jätkamist, mida soovid teha. </para
><para
>Märkus: kui valid lahendamata tühimärkide konfliktide baasi ning võimalus "Numbreid ignoreeritakse" või "C/C++ kommentaare ignoreeritakse" on sisse lülitatud, koheldakse muutusi numbrites või kommentaarides samuti tühimärkidena. </para
></sect2
><sect2 id="vcskeywordsmergesupport"
><title
>Versioonikontrolli võtmesõnade ja ajaloo (logi) automaatne ühendamine</title
><para
>Paljud versioonikontrollisüsteemid toetavad failis spetsiaalsete võtmesõnade kasutamist (nt. "&#36;Date&#36;", "&#36;Header&#36;", "&#36;Author&#36;", "&#36;Log&#36;" jne.). Väljavõtte tegemise ajal muudab versioonikontrollisüsteem neid ridu. Näiteks "&#36;Date&#36;" asemele tuleb "&#36;Date: 2005/03/22 18:45:01 &#36;".  Et selline rida on faili iga versiooni puhul erinev, on ühendamise ajal vajalik käsitsi sekkumine. </para
><para
>&kdiff3; võimaldab neid automaatselt ühendada. Lihtsate ridade puhul, mis sobivad valikuga "Automaatse ühendamise regulaaravaldis" kõigis sisendfailides, valib &kdiff3; rea B-st või, kui see on olemas, C-st. (Lisaks on vajalik, et mainitud read oleks võrdluses kõrvuti ja eelmine rida ei sisaldaks konflikti.) Automaatse ühendamise saab sooritada kohe ühendamise alates (selleks peab olema sisse lülitatud "Regulaaravaldisega automaatne ühendamine ühendamise alustamisel") või hiljem menüükäsuga "Käivita regulaaravaldisega automaatne ühendamine". </para
><para
>Automaatne ühendamine on toetatud ka versioonikontrolli ajaloo ehk logi puhul. Ajaloo automaatse ühendamise võib käivitada ühendamise alustamisel, kui sisse on lülitatud "Versioonikontrolli ajaloo ühendamine ühendamise alustamisel", või hiljem menüükäsuga "Lahenda automaatselt ajalookonfliktid". </para
><para
>Tavaliselt algab versioonikontrolli ajalugu reaga, kus seisab võtmesõna "&#36;Log&#36;". See peab sobima kokku valikuga "Ajaloo alguse regulaaravaldis". &kdiff3; tuvastab seejärel, millised järgnevad read kuuluvad ajalukku, anaküüsides juhtmärke enne võtmesõna "&#36;Log&#36;". Kui samasugused "kommentaari sissejuhatuse" märgid esinevad ka järgnevate ridade alguses, kuuluvad need ajalukku. </para
><para
>Iga väljavõtte ajal kirjutab versioonikontrollisüsteem unikaalse rea, mis määrab ära versiooni, kuupäeva ja kellaaja, sellele järgnevad kasutaja kommentaariga read. Need moodustavadki ühe ajalookirje. Ajaloosektsioon kasvab iga versioonikontrolli toiminguga, kusjuures viimane kirje on alati kõige ees (otse ajaloo algusrea järel). </para
><para
>Paralleelse arendustegevuse ajal võivad kaks või enam arendajat failiga tegelda, millisel juhul ühendamise ajalugu sisaldab mitut kirjet, mis harude ühendamisel satuvad konflikti. Et nende ühendamine võib olla üsna vaevaline, toetab &kdiff3; kaht strateegiat: mõlema/kõigi arendajate ajaloo lisamine etteotsa või ajaloo sorteerimine kasutaja määratud võtme järgi. </para
><para
>Esimene variant on kõige lihtsam. &kdiff3; peab lihtsalt tuvastama, millised read moodustavad ühe ajalookirje. Enamik versioonikontrollisüsteeme lisab iga ajalookirje järele tühja rea. Kui muid tühje ridu pole, piisab sellest &kdiff3;-le. Sel juhul olgu "Ajaloo alguse regulaaravaldis" lihtsalt tühi. Kui tühjast reast ainuüksi ei piisa, võid koostada regulaaravaldise, mis tuvastab ajalookirje alguse. </para
><para
>Pane tähele, et &kdiff3; eemaldab topeltajalookirjed. Kui sisendfailis esineb ajalookirje mitmel korral, siis väljundisse jääb alles ainult üks kirje. </para
><para
>Kui soovid ajalugu sortida, tuleb määrata sorteerimisvõti. Kasuta väljal "Ajaloo alguse regulaaravaldis" sulge regulaaravaldise nende osade rühmitamiseks, mida hiljem kasutada sorteerimisvõtmena. Seejärel määra "ajaloo sortimisvõtmete järjekord", milles komaga (",") eraldatud arvud viitavad grupi positsioonile regulaaravaldises. </para
><para
>See ei pruugi otsekohe õnnestuda, mistõttu tasub regulaaravaldist ja võtme genereerimist testida spetsiaalses dialoogis, mis avaneb klõpsuga nupule "Regulaaravaldiste test". </para
><para
>Näide: oletame, et ajalugu näeb välja nii: <screen>
/**************************************************************************
** HISTORY:    &#36;Log: \toms_merge_main_view\MyApplication\src\complexalgorithm.cpp &#36;
**
**     \main\integration_branch_12   2 Apr 2001 10:45:41   tom
**  Merged branch simon_branch_15.
**
**     \main\henry_bugfix_branch_7\1   30 Mar 2001 19:22:05   henry
**  Improved the speed for subroutine convertToMesh().
**  Fixed crash.
**************************************************************************/
</screen
> Ajaloo algusrida vastab regulaaravaldisele ".*\&#36;Log.*\&#36;.*". Sellele järgnevad ajalookirjed. </para
><para
>Real võtmesõnaga "&#36;Log&#36;" seisab alguses kaks "*", millele järgneb tühik. &kdiff3; hindab esimese mittetühimärgist stringi "kommentaari alguseks" ning eeldab, et ajalugu lõpeb esimesel real, millel kommentaari algust enam ei seisa. Näites lõpeb viimane rida stringiga, mille alguses on samuti kaks "*", kuid tühimärgi asemel järgneb veel rida märke "*". Seetõttu hinnatakse seda ajaloo lõpuks. </para
><para
>Kui ajaloo sortimist pole vaja, siis võib ajalookirje alguse regulaaravaldis näha välja umbes järgmine (rida on jagatud kaheks, sest see ei mahu muidu ära). <screen>
\s*\\main\\\S+\s+[0-9]+ (Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)
 [0-9][0-9][0-9][0-9] [0-9][0-9]:[0-9][0-9]:[0-9][0-9]\s+.*
</screen
> Täpsemalt kõneleb regulaaravaldistest <ulink url="http://doc.trolltech.com/3.3/qregexp.html#details"
> Trolltechi regulaaravaldiste dokumentatsioon</ulink
>. Pane tähele, et "\s" (väike "s") on suvaline tühik, "\S" (suur "S") iga mittetühik. Meie näites sisaldab ajalookirje algul versiooniteavet vastavalt regulaaravaldisele "\\main\\\S+", kuupäeva päevaga  "[0-9]+", kuuga "(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)" ja aastaga "[0-9][0-9][0-9][0-9]", kellaaega "[0-9][0-9]:[0-9][0-9]:[0-9][0-9]" ning lõpuks ka arendaja kasutajanime ".*". </para
><para
>Pane tähele, et kommentaari alguse märgid (näites  "**") eemaldab &kdiff3; juba enne otsingu alustamist, mistõttu regulaaravaldise alguses seisab nulli või enama tühimärgi vaste "\s*". Et kommentaarimärgid võivad failiti erineda (nt. C/C++ kasutab teistsuguseid kommentaarimärke kui Perli skript), kannab &kdiff3; ise alguses seisvate kommentaarimärkide eest hoolt ja sul pole vaja neid regulaaravaldises määrata. </para
><para
>Kui soovid ajalugu sortida, tuleb arvutada sortimisvõti. Selleks tuleb regulaaravaldise vajalikud osad sulgude abil rühmitada (need sulud võivad avaldisse jääda ka siis, kui ajaloo sortimine välja lülitatakse).<screen>
\s*\\main\\(\S+)\s+([0-9]+) (Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)
 ([0-9][0-9][0-9][0-9]) ([0-9][0-9]:[0-9][0-9]:[0-9][0-9])\s+(.*)
</screen
> Sulgudes on nüüd 1) versiooniteave, 2) kuupäev, 3) kuu, 4) aasta, 5) kellaaeg, 6) nimi. Aga kui me soovime sortida kuupäeva ja kellaaja järgi, tuleb luua võti, milles elemendid on teises järjekoras: esimesena aasta, siis kuu, päev, kellaaaeg, versiooniteave ja nimi. Sestap tuleb sortimisvõtme järjekorraks määrata "4,3,2,5,1,6". </para
><para
>Et kuunimed ei ole sortimiseks kuigi head ("Apr" oleks esimene), tuvastab &kdiff3; kuude järjekorra ja kasutab nende nime asemel hoopis järjekorranumbrit ("Apr"->"04"). Kui leitakse number, teisendatakse see neljakohaliseks, lisades sortimise huvides ette nullid. Lõpuks näeb esimese ajalookirje algusrea sortimisvõti välja järgmine: <screen
>2001 04 0002 10:45:41 integration_branch_12   tom 
</screen>
</para
><para
>Täpsemalt räägib sellest ka osa <link linkend="mergeoptions"
>Ühendamise seadistused</link
>. </para>
</sect2>
</sect1>

<sect1 id="navigation"
><title
>Liikumine ja redigeerimine</title>
<para
>Enamasti saab liikuda kerimisribade ja hiirega, kuid soovi korral on võimalik liikuda ka klahvidega. Kui klõpsata mis tahes aknasse, saab sarnaselt muude rakendustega kasutada noolenuppe, Page Up ja Page Down, Home, End, Ctrl+Home, Ctrl+End. Liikumiseks saab kasutada ka sisendafailide kerimisribast paremal pool asuvat ülevaateriba, mis võimaldab vajalikule kohale liikuda klõpsuga riba vajalikule kohale. </para
><para
>Üles-alla kerimiseks saab kasutada ka hiireratast. </para
><para
>Ühendamisväljundi redigeerimisaknas saab samuti kasutada kõiki tavalisi teksti redigeerimisel kasutatavaid klahve. Klahviga Insert saab lülitada lisamis- ja ülekirjutamisrežiimi (vaikimisi kehtib lisamisrežiim). </para
><para
>Klõps hiire vasaku nupuga mis tahes kokkuvõttetulbal sünkroniseerib kõik aknad, nii et neid näitavad üht ridadegruppi (seda selgitas lähemalt osa <link linkend="synchronise_views"
>Grupi määramine ning ühendamis- ja võrdlemisvaate asukoha sünkroniseerimine</link
>). </para
><para
>Nupureal on üheksa liikumisnuppu, millega saab hüpata aktiivsele/esimesele/viimasele erinevusele, eelmisele/järgmisele erinevusele (Ctrl+Nool üles/Ctrl+Nool alla), eelmisele/järgmisele konfliktile (Ctrl+Page Down/Ctrl+Page Up) või eelmisele/järgmisele lahendamata konfliktile. Pane tähele, et &kdiff3; jaoks jääb "konflikt", mida ei lahendata automaatselt ühendamise alguses, "konfliktiks" ka pärast selle käsitsi lahendamist. Seepärast on ka eristatud "lahendamata konfliktid". </para>
<sect2 id="autoadvance"
><title
>Automaatne edasiliikumine</title>
<para
>Lisaks neile on nupp "Pärast allikavalikut liigutakse automaatselt järgmisele lahendamata konfliktile". Seda sisse lülitades hüppab &kdiff3; allika valimisel automaatsel selles leiduval lahendamata konfliktile. See on abiks, kui soovid tavaliselt valida ainult ühe allika. Kui sul läheb vaja mõlemat allikat või soovid pärast valimist tegelda redigeerimisega, on tõenäoliselt mõttekas see välja lülitada. Enne järgmisele lahendamata konfliktile liikumist näitab &kdiff3; hetkeks langetatud valiku toimet. Kui kaua see näitamine kestab, saab määrata seadistustes: "automaatse edasiliikumise viivitus" on võimalik määrata millisekundites 0 ja 2000 vahel. Vihje: kas oled tüdinud kogu aeg klõpsamast? Kasuta siis pisikest automaatse edasiliikumise viivitust ning kiirklahve Ctrl+1/2/3 A/B/C valimiseks. </para>
</sect2>
</sect1>

<sect1 id="selections"
><title
>Valimine, kopeerimine ja asetamine</title>
<para
>Sisendaknas kursorit ei näidata, seepärast tuleb valimine teha hiirega, klõpsates vasaku nupuga valiku alguses, hoides nuppu all ja liikudes valiku lõppu, pärast mida võib nupu vabastada. Sõna saab valida ka sellel topeltklõpsu tehes. Ühendamisväljundi redigeerimisaknas saab valida ka klaviatuuri abil, hoides all klahvi Shift ja liikudes noolenuppudega. </para
><para
>Kui valik ulatub üle nähtava ala, võib viia hiire üle akna piirde, millisel juhul &kdiff3; kerib hiirekursori suunas. </para
><para
>Väga suure valiku korral võib kasutada ka hiirenuppu all hoides navigeerimisklahve. Näiteks konkreetsesse kohta jõudmiseks võib tarvitada klahve Page Up ja Page down. Õigesse kohta jõudes vabasta hiirenupp. </para
><para
>Aktiivses aknas kõige valimiseks kasuta menüükäsku "Redigeerimine"->"Vali kõik" (Ctrl+A). </para
><para
>Lõikepuhvrisse kopeerimiseks tuleb vajutada nuppu "Kopeeri" (Ctrl+C või Ctrl+Insert). Lisaks sellele on olemas ka võimalus "Valiku automaatne kopeerimine". Selle sisselülitamisel kopeeritakse kõik, mida oled valinud, automaatselt ning sul puudub vajadus anda mis tahes moel kopeerimiskäsku. Kuid ole selle võimalusega ettevaatlik, sest nii võib kogemata üle kirjutada vajaliku lõikepuhvri sisu. </para
><para
>"Lõika" (Ctrl+X või Shift+Delete) kopeerib valiku lõikepuhvrisse ja kustutab selle failist. </para
><para
>"Aseta" (Ctrl+V või Shift+Insert) lisab lõikepuhvris oleva teksti kursori asukohta või asendab lõikepuhvri sisuga parajasti valitud teksti. Kui asetad lõikepuhvri sisu ükspuha millisesse sisendaknasse, näidatakse seda seal otsekohe ja alustatakse aega viitmata uuesti võrdlemist. See on kasulik siis, kui soovid kiiresti kuskilt teksti võtta ja võrrelda seda millegi muuga, ilma et peaksid eelnevalt faili looma hakkama. </para>
</sect1>

<sect1 id="saving"
><title
>Salvestamine</title>
<para
>Salvestamine on võimalik ainult siis, kui kõik konfliktid on lahendatud. Kui fail on juba olemas ning sisse on lülitatud valik "Failidest tehakse varukoopia", antakse olemasolevale failile laiend ".orig". Kui selline peaks juba olemas olema, see kustutatakse. Kui väljud või oled alustanud uud võrdlusanalüüsi ning andmeid ei ole veel salvestatud, pärib &kdiff3; sinu käest, kas soovid salvestada, loobuda või jätkata ilma salvestamata (&kdiff3; ei salvesta andmeid seesmiselt, nii et kui &kdiff3; väljastpoolt "tappa", lähevad andmed kaotsi). </para
><para
>Realõpud salvestatakse vastavalt operatsioonisüsteemi tavale. UNIXi korral lõpetab rea reavahetusmärk "\n", Win32 süsteemides kelgu tagastamise sümbol pluss reavahetusmärk "\r\n". &kdiff3; ei säilita sisendfailide realõppe, mis ühtlasi tähendab, et &kdiff3; kasutamisel binaarfailidega peaks olema erakordselt ettevaatlik. </para>
</sect1>

<sect1 id="find"
><title
>Stringide otsimine</title>
<para
>Stringe saab otsida &kdiff3; kõigis tekstiakendes. Redigeerimismenüü käsk "Otsi..." (Ctrl+F) avab dialoogi, kus saab määrata, mida otsida. Samuti saab valida, millises aknas otsida. Otsimine algab alati teksti algusest. Käsk "Otsi järgmine" (F3) viib otsitava stringi järgmise esinemise juurde (kui seda muidugi on). Kui valid otsimise mitmes aknas, otsitakse esmalt ülalt alla läbi esimene aken, seejärel taas ülalt alla teine aken jne. </para>
</sect1>

<sect1 id="printing"
><title
>Trükkimine</title>
<para
>&kdiff3; toetab tekstifailide erinevuste trükkimist. Menüüs fail leiduv käsk "Trüki..." (Ctrl+P) avab dialoogi, kus saab valida printeri ja muuta teatud valikuid. </para
><para
>Mitmel moel saab kindlaks määrata, millist vahemikku trükkida. Et erinevates operatsioonisüsteemides on trükkimisdialoog erinev, siis on ka trükkimisvahemiku määramises teatud erinevusi. </para>
<variablelist>
   <varlistentry
><term
>Kõik:</term
><listitem
><para
>Trükitakse kõik.</para
></listitem
></varlistentry>
   <varlistentry
><term
>Aktiivne:</term
><listitem
><para
>Trükitakse lehekülg alates aknas esimesena näha olevast reast (süsteemides, kus seda valikut pole, saab sama tulemusi, kui määrata trükkimiseks lehkülg 10000).</para
></listitem
></varlistentry>
   <varlistentry
><term
>Valik:</term
><listitem
><para
>Enne trükkimiskäsku tuleb sel juhul valida mõnes sisendaknas hiirega tekst (nagu kopeerimisel), mis paneb paika trükitava valiku algus- ja lõpurea. Kui üheski sisendaknas pole midagi valitud, ei saa seda võimalust kasutada (süsteemides, kus see valik üldse puudub, saab sama tulemuse, kui määrata trükkimiseks lehekülg 9999).</para
></listitem
></varlistentry>
   <varlistentry
><term
>Vahemik:</term
><listitem
><para
>Trükitakse määratud esimesest kuni määratud viimase leheküljeni. </para
></listitem
></varlistentry>
</variablelist>
<para
>Ülejäänud trükkimisvalikud on tavapärasemad: </para
><itemizedlist>
   <listitem
><para
>Font, fondi suurus</para
></listitem>
   <listitem
><para
>Reanumbrite näitamine</para
></listitem>
   <listitem
><para
>Reamurdmine</para
></listitem>
   <listitem
><para
>Värvid</para
></listitem>
   <listitem
><para
>jne.</para
></listitem>
</itemizedlist>
<para
>Trükkida on soovitatav rõhtpaigutusega. </para>
</sect1>

<sect1 id="options"
><title
>Valikud</title>
<para
>Valikud ja viimati avatud failide nimekiri salvestatakse alati, kui rakendusest väljud, ning laaditakse uuesti rakenduse taaskäivitamisel (menüükäsk Seadistused -> &kdiff3; seadistamine...) </para>
<sect2
><title
>Font</title>
<para
>Valib fikseeritud laiusega fondi (mõnes süsteemis pakub dialoog ka muutuva laiusega fonti, kuid seda ei tasuks kasutada). </para>
<variablelist>
   <varlistentry
><term
><emphasis
>Kaldkiri erinevustele:</emphasis
></term
><listitem
><para
>Selle valimisel näidatakse teksti erinevusi valitud fondi kaldkirjas. Kui valitud font kaldkirja ei toeta, ei tee see midagi.</para>
   </listitem
></varlistentry>
</variablelist>
</sect2>

<sect2
><title
>Värvid</title>
<variablelist>
   <varlistentry
><term
><emphasis
>Esiplaani värv:</emphasis
></term
><listitem
><para
>Tavaliselt must. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Tausta värv:</emphasis
></term
><listitem
><para
>Tavaliselt valge. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Erinevuse tausta värv:</emphasis
></term
><listitem
><para
>Tavaliselt helehall. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Värv A:</emphasis
></term
><listitem
><para
>Tavaliselt tumesinine. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Värv B:</emphasis
></term
><listitem
><para
>Tavaliselt tumeroheline. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Värv C:</emphasis
></term
><listitem
><para
>Tavaliselt tume magenta. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Konflikti värv:</emphasis
></term
><listitem
><para
>Tavaliselt punane.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Praeguse vahemiku tausta värv:</emphasis
></term
><listitem
><para
>Tavaliselt helekollane.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Praeguse vahemiku erinevuse tausta värv:</emphasis
></term
><listitem
><para
>Tavaliselt tumekollane.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Käsitsi määratud samasuse vahemiku värv:</emphasis
></term
><listitem
><para
>Tavaliselt oranž.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Uusima faili värv kataloogide võrdlemisel:</emphasis
></term
><listitem
><para
>Tavaliselt roheline.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Vanima faili värv kataloogide võrdlemisel:</emphasis
></term
><listitem
><para
>Tavaliselt punane.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Keskmise vanusega faili värv kataloogide võrdlemisel:</emphasis
></term
><listitem
><para
>Tavaliselt tumekollane.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Puuduvate failide värv kataloogide võrdlemisel:</emphasis
></term
><listitem
><para
>Tavaliselt must.</para
></listitem
></varlistentry>
</variablelist>
<para
>Kataloogide võrdlemise värvide muutmine rakendub alles järgmise kataloogide võrdlemise ajal. </para>
<para
>Ainult 16 või 256 värviga süsteemides ei pruugi mõned värvid puhtal kujul saadaval olla. Sellistes süsteemides valib puhta värvi nupp "Vaikeväärtused". </para>
</sect2>

<sect2
><title
>Redaktori seadistused</title>
<variablelist>
   <varlistentry
><term
><emphasis
>TAB lisab tühikud:</emphasis
></term
><listitem
><para
>Kui see ei ole sees, lisatakse tabeldusklahvile vajutades tabeldusmärk, kui see on sees, vastav kogus tühikuid.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>TABi suurus:</emphasis
></term
><listitem
><para
>Kohandatav oma maitsele. Vaikimisi 8. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Automaatne taandus:</emphasis
></term
><listitem
><para
>Vajutades klahvile Enter, kasutatakse uuel real eelmise rea taandust. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Valiku automaatne kopeerimine:</emphasis
></term
><listitem
><para
>Iga tekstivalik kopeeritakse otsekohe lõikepuhvrisse, ilma et oleks vaja anda spetsiaalset kopeerimiskäsku. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Realõpu stiil:</emphasis
></term
><listitem
><para
>Salvestamisel saab valida, millist realõpu stiili eelistada. Vaikimisi on see valitud operatsioonisüsteemi põhjal. </para
></listitem
></varlistentry>
</variablelist>
</sect2>

<sect2 id="diffoptions"
><title
>Erinevuse seadistused</title>
<para
>Faile võrreldes püüab &kdiff3; kõigepealt seada kokku read, mis on kõigis sisendfailides ühtmoodi. Ainult sel etapil võib ta eirata tühimärke. Teisel etapil võrreldakse iga rida ning nüüd võetakse arvesse ka tühimärgid. Tühimärke ei ignoreerita ka ühendamisel. </para>

<variablelist>
   <varlistentry
><term
><emphasis
>Säilitatakse reavahetus:</emphasis
></term
><listitem
><para
>Mõned redaktorid mõnes süsteemis salvestavad iga rea lõpu kelgu tagastuse märgiga '\r' ning reavahetusmärgiga '\n', teised aga ainult reavahetusmärgiga '\n'. Üldiselt &kdiff3; ignoreerib kelgu tagastuse sümbolit, kuid sellisel juhul võivad tegelikult erineva suurusega failid paista võrdlemisel ühesugustena. Selle valiku sisselülitamisel on kelgutagatusmärgid näha, kuid neid koheldakse tühimärkidena. Ühendamise ajal tuleb see võimalus välja lülitada. Vaikimisi on väljas.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Numbreid ignoreeritakse:</emphasis
></term
><listitem
><para
>Vaikimisi väljas. Numbrilisi sümboleid ('0'-'9', '.', '-') ignoreeritakse analüüsi esimeses, üldvõrdlevas osas. Lõpptulemuses näidatakse siiski erinevusi, aga neid käsitletakse kui tühimärke. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>C/C++ kommentaare ignoreeritakse:</emphasis
></term
><listitem
><para
>Vaikimisi väljas. Muudatusi kommentaarides tõlgendatakse tühimärkide muudatustena. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Tõstu ignoreeritakse:</emphasis
></term
><listitem
><para
>Vaikimisi väljas. Märkide tõstu erinevusi (nt 'A' ja 'a') tõlgendatakse nagu tühimärkide muudatusi. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Eeltöötluse käsk:</emphasis
></term
><listitem
><para
>Vaata <link linkend="preprocessors"
>järgmist osa</link
>. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ridade sobivuse eeltöötluse käsk:</emphasis
></term
><listitem
><para
>Vaata <link linkend="preprocessors"
>järgmist osa</link
>. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Karm uurimine:</emphasis
></term
><listitem
><para
>Püüab tuvastada ka kõige pisemad erinevused. Vaikimisi sees. Ilmselt on sellest rohkem kasu keerulisemate ja suurte failide korral. Aga mõistagi on see väga suurte failide puhul ka väga aeglane. </para
></listitem
></varlistentry>
</variablelist>
</sect2>

<sect2 id="mergeoptions"
><title
>Ühendamise seadistused</title>
<variablelist>
   <varlistentry
><term
><emphasis
>Automaatse edasiliikumise viivitus (ms):</emphasis
></term
><listitem
><para
>Kui automaatne edasiliikumine on sisse lülitatud, määrab see võimalus, kui kaua näidatakse valiku tulemust, enne kui hüpatakse järgmisele lahendamata konfliktile. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Tühimärkide käsitlemine 2/3 faili ühendamisel:</emphasis
></term
><listitem
><para
>Lahendab automaatselt kõik tühimärkide konfliktid määratud faili valides (vaikimisi käsitsivalik). Kasulik, kui tühimärgid pole olulise tähtsusega. Kui seda läheb ainult mõnikord vaja, kasuta parem ühendamismenüü käske "Vali A/B/C kõigi lahendamata tühimärgikonfliktide korral". Pane tähele, et kui sees on "Numbreid ignoreeritakse" või "C/C++ kommentaare ignoreeritakse", rakendub see automaatne valik ka kõigile numbrite või kommentaaride konfliktidele. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Automaatühendamise regulaaravaldis:</emphasis
></term
><listitem
><para
>Regulaaravaldis ridadele, mille puhul &kdiff3; peab automaatselt valima allika. Vt. ka <link linkend="vcskeywordsmergesupport"
>Automaatne ühendamine...</link
> </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Regulaaravaldisega automaatühendamine ühendamise alustamisel:</emphasis
></term
><listitem
><para
>Valimise korral käivitab &kdiff3; ühendamise alustamisel automaatse ühendamise, kasutades selleks "automaatühendamise regulaaravaldist". </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ajaloo alguse regulaaravaldis:</emphasis
></term
><listitem
><para
>REgulaaravaldis ajalookirje alguse tuvastamiseks. Tavaliselt sisaldab see rida võtmesõna "&#36;Log&#36;". Vaikimisi: ".*\&#36;Log.*\&#36;.*" </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ajalookirje alguse regulaaravaldis:</emphasis
></term
><listitem
><para
>Ühendamise ajaloo kirje koosneb mitmest reast. Siin saab koostada regulaaravaldise, mis tuvastab esimese rea (ilma alustavate kommentaarimärkideta). Sulgudega saab rühmitada võtmed, mida soovid kasutada sortimisel. Tühjaksjätmise korral eeldab &kdiff3;, et ajalookirjeid eraldavad tühjad read. Vaata ka <link linkend="vcskeywordsmergesupport"
>Automaatne ühendamine...</link
> </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ajaloo ühendamise sortimine:</emphasis
></term
><listitem
><para
>Versioonikontrolli ajaloo sortimise lubamine. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ajalookirje alguse sortimisvõtmete järjekord:</emphasis
></term
><listitem
><para
>Ajalookirje alguse tuvastamiseks kasutatavas regulaaravaldises võib tarvitada sulge, millega rühmitatakse sortimiseks pruugitavad võtmed. Võtmete järjekorra määramiseks (need kujutavad endast arve alates 1) kirjuta nad komaga eraldatult (nt. "4,5,6,1,2,3,7"). Kui see andmata jätta, ei sordita. Vaata ka <link linkend="vcskeywordsmergesupport"
>Automaatne ühendamine...</link
> </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Versioonikontrolli ajaloo ühendamine ühendamise alustamisel:</emphasis
></term
><listitem
><para
>Sisselülitamisel käivitab &kdiff3; ühendamise alustamisel eelnevalt määratud tingimustel automaatse ajaloo ühendamise. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ajalookirjete maks. arv:</emphasis
></term
><listitem
><para
>&kdiff3; kärbib ajaloo, säilitades ainult määratud hulga kirjeid. Kärpimise vältimiseks määra väärtuseks -1. Vaikimisi: -1. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Regulaaravaldiste test</emphasis
></term
><listitem
><para
>See nupp avab dialoogi, kus saab sisestatud regulaaravaldist testida ja parandada. Kopeeri lihtsalt vajalikud andmed oma failidest siia. "Sobivuse tulemused" näitavad kohe, kas avaldis sobib või mitte. "Sorteerimisvõtme tulemus" näitab ajaloo ühendamise sortimisel kasutatavat võtit. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ebaolulise ühendamise käsk:</emphasis
></term
><listitem
><para
>Siin saab määrata käsu, mis antakse siis, kui &kdiff3; avastab kolme faili ühendamisel, et fail B ei sisalda mingeid olulisi andmeid, mida poleks juba failis C. Käsk kutsutakse välja kolmest failinimest parameetriga. Andmeid, mis sobivad "automaatse ühendamise regulaaravaldisega" või ajalooga, ei peeta oluliseks. </para
></listitem
></varlistentry>
</variablelist>

</sect2>

<sect2
><title
>Kataloogide ühendamine</title>
<para
>Need valikud käivad kataloogide uurimise ja nende ühendamise kohta, millest täpsemalt räägib osa <link linkend="dirmergeoptions"
>Kataloogide võrdlemise ja ühendamise seletused</link
>. </para
><para
>Siiski on üks valik, mis käib ka üksikfailide salvestamise kohta: </para>
<variablelist>
   <varlistentry
><term
><emphasis
>Failidest tehakse varukoopia:</emphasis
></term
><listitem
><para
>Kui faili salvestamisel on sellest olemas vanem versioon, antakse viimasele laiend ".orig". Kui peaks olemas olema ka samanimeline varasem fail laiendiga ".orig", siis see kustutatakse. </para
></listitem
></varlistentry>
</variablelist>
</sect2>

<sect2
><title
>Riigi ja keele valikud</title>
  <variablelist>
    <varlistentry
><term
><emphasis
>Keel:</emphasis
></term
><listitem
><para
>Kasutajaliidese keele määramine. Selle muutmine ei mõjuta töötavat rakendust. Keele muutmiseks tuleb &kdiff3; sulgeda ja uuesti käivitada. (See valik ei ole kasutatav &kdiff3; KDE versioonis, sest seal saab keele määrata KDE üldises seadistuses.) </para
></listitem
></varlistentry>
    <varlistentry
><term
><emphasis
>Kõikjal kasutatakse kodeeringut:</emphasis
></term
><listitem
><para
>Järgnevaid kodeeringuvalikuid saab määrata eraldi, välja arvatud juhul, kui äsjatoodud valik on sisse lülitatud, sest siis võtavad kõik valikud esimese valiku väärtuse. </para
></listitem
></varlistentry>
    <varlistentry
><term
><emphasis
>Kohalik kodeering:</emphasis
></term
><listitem
><para
>Kodeeringu valimise väljade kohal seisab märge, mis annab teada kohaliku kodeeringu (see ei ole muudetav, vaid lihtsalt teadmiseks, kui sa ei peaks oma kodeeringut teadma). </para
></listitem
></varlistentry>
    <varlistentry
><term
><emphasis
>A/B/C kodeering:</emphasis
></term
><listitem
><para
>Sisendfailide kodeeringu kohandamine. See mõjutab inglise tähestikku mittekuuluvate sümbolite esitamist. Kohandada saab iga kodeeringut eraldi, nii et sul on isegi võimalus võrrelda ja ühendada faile, mis on salvestatud erinevas kodeeringus. </para
></listitem
></varlistentry>
    <varlistentry
><term
><emphasis
>Kodeering ühendamisväljundil ja salvestamisel:</emphasis
></term
><listitem
><para
>Kui muudad faili, saad siis määrata, millises kodeeringus salvestatakse see kettale. </para
></listitem
></varlistentry>
    <varlistentry
><term
><emphasis
>Eelprotsessori failide kodeering:</emphasis
></term
><listitem
><para
>Kui oled määranud eelprotsessorid, võib juhtuda, et nad ei suuda sinu kodeeringut töödelda (kui näiteks sinu failid on 16-bitises Unicode''is, eelprotsessor suudab aga töödelda vaid 8-bitist ASCII-d). Siin saad määrata eelprotsessori väljundi kodeeringu. </para
></listitem
></varlistentry>
    <varlistentry
><term
><emphasis
>Paremalt vasakule keeled:</emphasis
></term
><listitem
><para
>Mõningaid keeli kirjutatakse paremalt vasakule. Selle valiku sisselülitamisel näitab &kdiff3; võrdluse sisendakendes ja ühendamise väljundaknas teksti paremalt vasakule. Pane tähele, et kui käivitad &kdiff3; käsurealt võtmega "--reverse", kasutab kogu rakendus paremalt vasakule paigutust (seda võimaldab Qt). Käesolev käsiraamat on kirjutatud eeldusel, et "Paremalt vasakule keeled" ega võti "reverse" ei ole kasutusel. Sestap tuleb nende kasutamisel mõningaid "vasakul" või "paremal" antud kirjeldusi lugeda lihtsalt selle teadmise valguses vastupidi. </para
></listitem
></varlistentry>

  </variablelist>
</sect2>

<sect2
><title
>Muud</title>
<para
>(neid valikuid ja toiminguid saab kasutada menüü või nupuriba vahendusel)</para>
<variablelist>
  <varlistentry
><term
><emphasis
>Näita reanumbreid:</emphasis
></term
><listitem
><para
>Võimalus valida, kas sisendfailidel näidatakse ridade numbreid.</para
></listitem
></varlistentry>
  <varlistentry
><term
><emphasis
>Näita erinevusi tühiku- ja tabeldusmärkides:</emphasis
></term
><listitem
><para
>Vahel võivad nähtavad tühikud ja tabeldusmärgid tõsiselt häirida, millisel juhul on võimalik nende näitamine välja lülitada.</para
></listitem
></varlistentry>
  <varlistentry
><term
><emphasis
>Näita tühimärke:</emphasis
></term
><listitem
><para
>Selle väljalülitamisel ei tõsteta esile tühimärkide erinevusi tekstis ega ülevaatetulbal. Pane tähele, et et kui sees on "Numbreid ignoreeritakse" või "C/C++ kommentaare ignoreeritakse", rakendub see ka kõigile numbrite või kommentaaride konfliktidele.</para
></listitem
></varlistentry>
  <varlistentry
><term
><emphasis
>Ülevaate valikud:</emphasis
></term
><listitem
><para
>Neid valikuid saab kasutada ainult kolme faili võrdlemisel. Tavarežiimis näidatakse erinevusi ühel värvilisel ülevaatetulbal. Kuid vahel võivad huvi pakkuda kolmest faili ainult kahe erinevused. Valides vastavalt ülevaate "A vs. B", "A vs. C" või "B vs. C", näidatakse tavalise ülevaatetulba kõrval teist vajaliku infoga. </para
></listitem
></varlistentry>
  <varlistentry
><term
><emphasis
>Reamurdmine võrdlusakendes:</emphasis
></term
><listitem
><para
>Read murtakse, kui nende pikkus ületab akna laiust. </para
></listitem
></varlistentry>
  <varlistentry
><term
><emphasis
>Näita akent A/B/C:</emphasis
></term
><listitem
><para
>Vahel võib tekkida tahtmine ekraanil ruumi juurde tekitada, et näha paremini näiteks pikki ridu. Sellisel juhul saab peita aknad, mis ei ole hetkel olulised (menüü Aken).</para
></listitem
></varlistentry>
  <varlistentry
><term
><emphasis
>Lülita poolitamissuund:</emphasis
></term
><listitem
><para
>Lülitab võrdlusakende asetsemist üksteise kõrval (A vasakul pool B ja B vasakul pool C) ning üksteise kohal (A B kohal ja B C kohal). Ka see võib olla abiks pikkade ridade korral (menüü Aken). </para
></listitem
></varlistentry>
  <varlistentry
><term
><emphasis
>Kiirühendamine:</emphasis
></term
><listitem
><para
>Mõnikord võib leida erinevuste vaatamisel, et käes on aeg tegelda ühendamisega. <inlinemediaobject
><imageobject
><imagedata fileref="merge_current.png" format="PNG"/></imageobject
></inlinemediaobject
> "Ühenda praegune fail" menüüs Kataloog toimib ka siis, kui sa võrdled ainult kaht faili. Ühekordne klõps käivitab ühendamise ning kasutab vaikimisi väljundifaili nimena viimase sisendfaili nime (kui seda on kasutatud ühendamise taaskäivitamiseks, väljundfaili nimi säilitatakse).</para
></listitem
></varlistentry>
</variablelist>
</sect2>

<sect2 id="shortcuts"
><title
>Kiirklahvide seadistamine</title>
<para
>Praegu toetab ainult KDE versioon kasutaja võimalust määrata kiirklahve (menüükäsk Seadistused -> Kiirklahvide seadistamine...) </para>
</sect2>
</sect1>

<sect1 id="preprocessors"
><title
>Eeltöötluse käsud:</title>
<para
>&kdiff3; toetab kaht eeltöötluse võimalust. </para
><para>
<variablelist>
   <varlistentry
><term
><emphasis
>Eeltöötluse käsk:</emphasis
></term
><listitem
><para
>Mis tahes faili lugemisel filtreeritakse see läbi siin määratud käsu. Algse faili asemel näeb siis antud käsu väljundit. Sul on võimalik panna kirja oma eeltöötluse käsk, mis rahuldaks just sinu vajadused. Kasuta seda võimalust näiteks faili ülearuste osade kõrvaldamiseks või taande automaatseks korrigeerimiseks vms. </para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ridade sobivuse eeltöötluse käsk:</emphasis
></term
><listitem
><para
>Mis tahes faili lugemisel filtreeritakse see läbi siin määratud käsu. Kui määratud on ka eeltöötluse käsk (vaata eespool), on eeltöötluse käsu väljund ridade sobivuse eeltöötluse käsu sisendiks. Viimase väljundit kasutatakse ainult analüüsi esimeses, reasobivuse faasis. Sul on võimalik panna kirja oma eeltöötluse käsk, mis rahuldaks just sinu vajadused. Igal sisendi real peab olema talle vastav väljundi rida. </para
></listitem
></varlistentry>
</variablelist>
</para>
<para
>Selle mõte on pakkuda kasutajale suuremat paindlikkust võrdlemistulemuse seadistamisel. Kuid see nõuab välist programmi ja mõistagi ei taha enamik sellist ise kirjutama hakata. Õnneks suudab enamasti selliste asjadega toime tulla <command
>sed</command
> või <command
>perl</command
>. </para>
<para
>Näide: lihtne testnäide: Võtame faili a.txt (6 rida): <screen>
      aa
      ba
      ca
      da
      ea
      fa
</screen
> Ja faili b.txt (3 rida): <screen>
      cg
      dg
      eg
</screen
> Ilma eeltöötluseta seatakse vastavusse järgmised read: <screen>
      aa - cg
      ba - dg
      ca - eg
      da
      ea
      fa
</screen
> Tõenäoliselt ei ole see sugugi see, mida sa soovisid, sest oluliseks infokandjaks on just esimesed tähed. Et sobivusalgoritn jätaks arvesse võtmata teise tähe, kasutame reasobivuse eeltöötluse käsku, mis asendab 'g' 'a'-ga: <screen>
   <command
>sed</command
> 's/g/a/'
</screen
> Selle käsu korral on võrdlemise tulemus järgmine: <screen>
      aa
      ba
      ca - cg
      da - dg
      ea - eg
      fa
</screen
> Seesmisel näeb sobivusalgoritm faile juba pärast reasobivuse eeltöötluse rakendamist, kuid ekraanil jääb fail muutmata. (Tavaline eeltöötlus muudaks andmeid ka ekraanil.) </para>

<sect2 id="sedbasics"
><title
><command
>sed</command
>'i põhitõed</title>
<para
>Selles osas tutvustame ainult programmi <command
>sed</command
> üksikuid põhimõttelisi omadusi. Rohkem infot leiab käsuga <ulink url="info:/sed"
>info:/sed</ulink
> või aadressilt <ulink url="http://www.gnu.org/software/sed/manual/html_mono/sed.html"
> http://www.gnu.org/software/sed/manual/html_mono/sed.html</ulink
>. Windowsi eelkompileeritud versioon asub aadressil <ulink url="http://unxutils.sourceforge.net"
> http://unxutils.sourceforge.net</ulink
>. Pane tähele, et järgmistes näidetes eeldame, et käsk <command
>sed</command
> asub mõnes keskkonnamuutujaga PATH määratud kataloogis. Kui see nii ei ole, tuleb sul määrata käsu täielik asukoht. </para>
<note
><para
>Pane tähele ka seda, et järgnevates näidetes on kasutatud ühekordset jutumärki ('), mis Windowsis ei toimi - seal tuleb kasutada topeltjutumärke (").</para
></note>
<para
>Antud kontekstis kasutatakse ainult <command
>sed</command
>'i 'asenduskäsku: <screen>
   <command
>sed</command
> 's/<replaceable
>REGULAARAVALDIS</replaceable
>/<replaceable
>ASENDUS</replaceable
>/<replaceable
>LIPUD</replaceable
>'
</screen
> Enne uue käsu kasutamist &kdiff3;-ga võiks seda esmalt testida konsoolil. Siin tuleb kasuks käsk <command
>echo</command
>. Näide: <screen>
   <command
>echo</command
> abrakadabra | <command
>sed</command
> 's/a/o/'
   -> obrakadabra
</screen
> Toodud näites on tegemist äärmiselt lihtsa sed-käsuga, kus asendatakse esimene "a" "o"-ga. Kui soovid asendada kõik esinemiskorrad, tuleb kasutada lippu "g": <screen>
   <command
>echo</command
> abrakadabra | <command
>sed</command
> 's/a/o/g'
   -> obrokodobro
</screen
> Sümbol "|" on torukäsk, mis edastab eelmise käsu väljundi järgmise käsu sisendile. Kui soovid testida pikema failiga, võid kasutada käsku <command
>cat</command
>, kui tegemist on UNIX-i süsteemiga, või <command
>type</command
>, kui tegu on Windowsiga. <command
>sed</command
> sooritab asenduse igal real. <screen
><command
>cat</command
> <replaceable
>failinimi</replaceable
> | <command
>sed</command
> <replaceable
>võtmed</replaceable
>
</screen>
</para>
</sect2>
<sect2 id="sedforkdiff3"
><title
>Näited <command
>sed</command
>'i kasutamise kohta &kdiff3;-ga</title>
<sect3
><title
>Muud tüüpi kommentaaride ignoreerimine</title>
<para
>Praegu mõistab &kdiff3; ainult C/C++ kommentaare. Reasobivuse eeltöötluse käsuga saab aga ignoreerida ka muud tüüpi kommentaare, teisendades need C/C++ kommentaarideks. Näide: kui soovid ignoreerida kommentaare, mille alguses on "#", tuleks need teisendada nii, et alguses oleks "//". Pane tähele, et seejuureks peaks olema võimalus "C/C++ kommentaare ignoreeritakse" sisse lülitatud, muidu pole asjal mõtet. Vastav reasobivuse eeltöötluse käsk näeb välja selline: <screen>
   <command
>sed</command
> 's/#/\/\//'
</screen
> Kuna <command
>sed</command
> omistab sümbolile "/" eritähenduse, on oluline asetada asendusstringis iga "/" ette sümbol "\". Mõnikord on "\" vajalik teatud ertähendusega sümbolite lisamiseks või eemaldamiseks. Nüüd on olulised üksikjutumärgid (') enne ja pärast asenduskäsku, sest vastasel juhul püüab shell mõningaid erisümboleid, näiteks '#', '$' või '\' tõlgendada juba enne nende edastamist käsule <command
>sed</command
>. <emphasis
>Pane tähele, et Windowsis tuleb anda topeltjutumärgid ("). Windows asendab ka muid sümboleid, näiteks '%', nii et siin võib olla vajalik veidi eksperimenteerida.</emphasis
> </para>
</sect3>
<sect3
><title
>Tõstutundetu võrdlus</title>
<para
>Järgmise reasobivuse eeltöötluse käsuga saab kogu sisendi muuta suurtäheliseks: <screen>
   <command
>sed</command
> 's/\(.*\)/\U\1/'
</screen
> Siin on ".*" regulaaravaldis, mis sobib iga stringiga, antud kontekstis siis iga real asuva sümboliga. "\1" asendusstringis tähistab sobivat teksti esimeses "\(" and "\)" paaris. "\U" teisendab sisestatud teksti suurtäheliseks. </para>
</sect3>

<sect3
><title
>Versioonikontrolli võtmesõnade ignoreerimine</title>
<para
>CVS ja muud versioonikontrollisüsteemid kasutavad mitmeid võtmesõnu automaatselt genereeritavate stringide lisamiseks (<ulink url="info:/cvs/Keyword substitution"
>info:/cvs/Keyword substitution</ulink
>). Kõik need järgivad mustrit "$VÕTMESÕNA genereeritud tekst$". Nüüd läheb meil vaja reasobivuse eeltöötluse käsku, mis eemaldaks ainult genereeritud teksti: <screen>
   <command
>sed</command
> 's/\$\(Revision\|Author\|Log\|Header\|Date\).*\$/\$\1\$/'
</screen
> Võimalikke võtmesõnu eraldab "\|". Seda loendit võid mõistagi vastavalt oma vajadustele muuta. Enne "$" on kindlasti vajalik "\", sest muidu on "$" sobivuseks rea lõpp. </para>
<para
>Kui katsetad <command
>sed</command
>'iga, hakkad arvatavasti veidi aduma regulaaravaldiste mõtet ja võib-olla isegi neid armastama. Iseenesest on regulaaravaldised väga kasulikud, sest päris paljud programmid toetavad sarnast võimalust. </para>
</sect3>

<sect3
><title
>Numbrite ignoreerimine</title>
<para
>Numbrite ignoreerimine on tegelikult juba sisseehitatud võimalus. Kuid näitame siinkohal, kuidas see näeks välja reasobivuse eeltöötluse käsuna: <screen>
   <command
>sed</command
> 's/[0123456789.-]//g'
</screen
> Sobivad kõik sümbolid '[' ja ']' vahel ning neid ei asendatagi, vaid lihtsalt kõrvaldatakse. </para>
</sect3>

<sect3
><title
>Teatud veergude ignoreerimine</title>
<para
>Tekst võib olla rangelt vormindatud ning sisaldada näiteks veergu, mida soovid alati ignoreerida, samas aga muid veerge analüüsiks kasutada. Järgnevas näites ignoreeritakse viit esimest veergu (sümbolit), järgmised kümme säilitatakse, siis ignoreeritakse taas viit veergu ning ülejäänud rida säilitatakse. <screen>
   <command
>sed</command
> 's/.....\(..........\).....\(.*\)/\1\2/'
</screen
> Iga punkt '.' vastab ühele sümbolile. "\1" ja "\2" asendusstringis tähistavad sobivat teksti esimeses ja teises "\(" ja "\)" paaris, märkides säilitatavat teksti. </para>
</sect3>

<sect3
><title
>Mitme asenduse kombineerimine</title>
<para
>Vahel võib tekkida tahtmine teha mitu asendust korraga. Selleks tuleb nende eraldamiseks kasutada semikoolonit ';'. Näide: <screen
><command
>echo</command
> abrakadabra | <command
>sed</command
> 's/a/o/g;s/\(.*\)/\U\1/'
   -> OBROKODOBRO
</screen>
</para>
</sect3>

<sect3
><title
><command
>perl</command
>i kasutamine <command
>sed</command
>'i asemel</title>
<para
><command
>sed</command
>'i asemel võib kasutada ka midagi muud, näiteks <command
>perl</command
>. <screen>
   <command
>perl</command
> -p -e 's/<replaceable
>REGULAARAVALDIS</replaceable
>/<replaceable
>ASENDUS</replaceable
>/<replaceable
>LIPUD</replaceable
>'
</screen
> Kuid <command
>perl</command
> on mõnevõrra erinev. Pane tähele, et kui <command
>sed</command
>-ile oli vaja "\(" ja "\)", siis <command
>perl</command
>-ile on vaja lihtsalt "(" ja ")" ilma eelneva '\'. Näide: <screen
><command
>sed</command
> 's/\(.*\)/\U\1/'
   <command
>perl</command
> -p -e 's/(.*)/\U\1/'
</screen>
</para>
</sect3>
</sect2>

<sect2
><title
>Eeltöötluse sooritamise järjekord</title>
<para
>Andmed suunatakse läbi sisemiste ja väliste eeltöötluse käskude järgmises järjekorras </para>
<itemizedlist>
<listitem
><para
>Tavaline eeltöötlus,</para
></listitem>
<listitem
><para
>Reasobivuse eeltöötlus,</para
></listitem>
<listitem
><para
>Tõstu ignoreerimine (teisendamine suurtäheliseks),</para
></listitem>
<listitem
><para
>C/C++ kommentaaride tuvastamine,</para
></listitem>
<listitem
><para
>Numbrite ignoreerimine,</para
></listitem>
<listitem
><para
>Tühimärkide ignoreerimine</para
></listitem>
</itemizedlist>
<para
>Tavalise eeltöötluse tulemusandmed säilitatakse näitamiseks ja ühendamiseks. Muud operatsioonid muudavad ainult andmeid, mida näeb reasobivuse võrdlusalgoritm. </para
><para
>Neil harvadel juhtudel, kui kasutad tavalist eeltöötluse käsku, arvesta, et reasobivuse eeltöötluse käsk peab tavalise eeltöötluse käsu väljundit oma sisendiks. </para>
</sect2>

<sect2
><title
>Hoiatus</title>
<para
>Eeltöötluse käsud on sageli vägagi kasulikud, aga nagu ikka võimalustega, mis muudavad sinu teksti või peidavad automaatselt teatud erinevused, võib sel moel kogemata mõningad erinevused kahe silma vahele jätta või eriti halval juhul isegi olulised andmed hävitada. </para
><para
>Seetõttu teatab &kdiff3; ühendamisel sellest, et kasutatakse tavalist eeltöötluse käsku, ning pärib, kas seda lubada või mitte. Kuid sind ei hoiatata, kas reasobivuse eeltöötluse on aktiivne või mitte. Ühendamine on valmis alles siis, kui kõik konfliktid on lahendatud. Kui lülitad välja võimaluse "Tühimärkide näitamine", siis on nähtamatud ka erinevused, mis eemaldati reasobivuse eeltöötluse käsuga. Kui ühendamisel ei saa kasutada nuppu 'Salvesta' (sest failis on veel konflikte), lülita "tühimärkide näitamine" sisse. Kui sa ei soovi neid enamasti vähese tähtsusega erinevusi käsitsi ühendada, vali ühendamismenüüst käsk "Vali [A|B|C] kõigi lahendamata tühimärgikonfliktide korral". </para>
</sect2>
</sect1>
</chapter>


<chapter id="dirmerge"
><title
>Kataloogide võrdlemine ja ühendamine &kdiff3;-s</title>
<sect1 id="dirmergeintro"
><title
>Kataloogide võrdlemise ja ühendamise sissejuhatus</title>
<para
>Programmeerijad peavad sageli oma eesmärgi saavutamiseks muutma kataloogis paljusid faile. Selle ülesande kergendamiseks võimaldab &kdiff3; võrrelda ja ühendada ka terveid katalooge koos nende alamkataloogidega! </para
><para
>Kuigi kataloogide võrdlemine ja ühendamine tundub olevat üsna lihtne ja selge, tuleks siin siiski arvestada mitme asjaga. Kõige olulisem on kahtlemata see, et sellisel juhul puudutab iga operatsioon paljusid faile korraga. Kui sa ei ole esialgsetest andmetest varukoopiat teinud, võib algoleku taastamine olla väga raske või isegi võimatu. Seepärast kontrolli enne ühendamise alustamist alati, et andmed on turvaliselt varundatud ja et sul on alati võimalus tagasi minna. Kas kasutada arhiveerimist või mõnda versioonikontrollisüsteemi, on sinu enda otsustada, kuid pea silmas, et ka ülikogenud programmeerijad vajavad aeg-ajalt vanu alliktekste. Ning ühtlasi arvesta sedagi, et kuigi mina (see tähendab, &kdiff3; autor) olen püüdnud anda endast parima, ei saa ma täie kindlusega öelda, et rakendus on ideaalne ja täiesti veatu. Nagu ütleb GNU Üldine Avalik Litsents, ei ole sellel rakendusel MITTE MINGIT garantiid. Seepärast pea alati meeles, et </para>
<blockquote
><para>
   <emphasis
>Eksimine on inimlik, aga tõelise segaduse korraldamiseks läheb vaja arvutit.</emphasis>
</para
></blockquote>
<para
>Vaatame siis, mida meie rakendus suudab teha. &kdiff3;... </para>
<itemizedlist>
     <listitem
><para
>... loeb ja võrdleb kaht või kolme kataloogi koos alamkataloogidega</para
></listitem>
     <listitem
><para
>... peab spetsiaalselt silmas nimeviitu</para
></listitem>
     <listitem
><para
>... võimaldab faile vaadelda hiire topeltklõpsuga</para
></listitem>
     <listitem
><para
>... iga elemendi korral pakub välja ühendamisoperatsiooni, mida sul on voli muuta enne tegeliku kataloogide ühendamise alustamist</para
></listitem>
     <listitem
><para
>... võimaldab ühendamist simuleerida, näidates ära toimingud, mis ette võetakse, ilma neid tegelikult veel tegemata</para
></listitem>
     <listitem
><para
>... võimaldab mõistagi ka tegelikku ühendamist ning pakub sulle sekkumise võimalust kõikjal, kus selleks vajadus tekib</para
></listitem>
     <listitem
><para
>... võimaldab käivitada valitud toimingu kõigi elementidega (klahv F7) või ainult valitud elemendiga (klahv F6)</para
></listitem>
     <listitem
><para
>... lubab jätkata pärast sekkumist ühendamist klahvile F7 vajutades</para
></listitem>
     <listitem
><para
>... lisavõimalusena loob varukoopiad laiendiga ".orig"</para
></listitem>
     <listitem
><para
>...</para
></listitem>
</itemizedlist>
</sect1>

<sect1 id="startingdirmerge"
><title
>Kataloogide võrdlemise või ühendamise alustamine</title>
<para
>See on väga sarnane failide ühendamisele ja võrdlemisele. Sul tuleb lihtsalt valida kataloogid käsureal või avamisdialoogis. </para>
<sect2
><title
>Kahe kataloogi võrdlemine/ühendamine: </title>
<screen
><command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2</replaceable>
   <command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2</replaceable
> -o <replaceable
>sihtkataloog</replaceable
>
</screen>
<para
>Kui sihtkataloogi ei määrata, kasutab &kdiff3; sellena kataloogi <replaceable
>kataloog2</replaceable
>. </para>
</sect2>

<sect2
><title
>Kolme kataloogi võrdlemine/ühendamine: </title>
<screen
><command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2 kataloog3</replaceable>
   <command
>kdiff3</command
> <replaceable
>kataloog1 kataloog2 kataloog3</replaceable
> -o <replaceable
>sihtkataloog</replaceable
>
</screen>
<para
>Kolme kataloogi ühendamisel võetakse <replaceable
>kataloog1</replaceable
> ühendamise baasiks. Kui sihtkataloogi ei ole määratud, on selleks &kdiff3; silmis <replaceable
>kataloog3</replaceable
>. </para>

<para
>Pane tähele, et automaatselt algab ainult võrdlemine, mitte aga ühendamine. Viimase jaoks tuleb kasutada vastavat menüükäsku või klahvi F7 (sellest räägime pikemalt veidi hiljem). </para>
</sect2>
</sect1>

<sect1 id="dirmergevisible"
><title
>Kataloogide ühendamise nähtav info</title>
<para
>Kataloogide lugemisel ilmub teatekast, mis näitab edenemise käiku. Kui katkestad kataloogi läbiuurimise, näidatakse ainult neid faile, mida selle hetkeni jõuti võrrelda. </para
><para
>Kui kataloogide skaneerimine on lõpule jõudnud, näitab &kdiff3; nimekirjakasti, kus vasakul on tulemused... </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="dirbrowser.png" format="PNG"/></imageobject
> <!--alt="Image of the directory browser."-->
</mediaobject
></screenshot>
<para
>... ja paremal üksikasjad parajasti valitud elemendi kohta: </para>
<screenshot
><mediaobject>
<imageobject
><imagedata fileref="iteminfo.png" format="PNG"/></imageobject>
   <!--alt="Image with information about the selected item."-->
</mediaobject
></screenshot>

<sect2 id="name"
><title
>Nimeveerg</title>
<para
>Kõiki skaneerimisel leitud faile ja katalooge näidatakse puus. Vajaliku elemendi saab valida sellel hiirega klõpsates. </para
><para
>Vaikimisi on kataloogid suletud. Neid saab avada või sulgeda klõpsuga nende ees seisvale "+"/"-" või topeltklõpsuga kirjel või klahvidega Nool vasakule/paremale. Menüüs "Kataloog" on käsud "Ava kõik alamkataloogid" ja "Sule kõik alamkataloogid", mis lubavad korraga avada/sulgeda kõik alamkataloogid. </para
><para
>Failil topeltklõpsu tehes alustatakse võrdlemist ning ilmub failide võrdlemise aken. </para>
<para
>Pilt nimeveerus kajastab faili tüüpi esimeses kataloogis ("A"). See võib olla üks järgmistest: </para>
<itemizedlist>
     <listitem
><para
>Tavaline fail</para
></listitem>
     <listitem
><para
>Tavaline kataloog (kaustakujuline pilt)</para
></listitem>
     <listitem
><para
>Viit failile (failipilt viidanoolega)</para
></listitem>
     <listitem
><para
>Viit kataloogile (kaustakujuline pilt viidanoolega)</para
></listitem>
</itemizedlist>
<para
>Kui failitüüp on erinevates kataloogides erinev, on see näha veergudes A/B/C ning aknas, mis näitab valitud elemendi üksikasju. Pane tähele, et sellisel juhul ei ole võimalik automaatselt käivitada ühendamist. Kui seda siiski tehakse, antakse kasutajale teada, miks see ei ole võimalik. </para>
</sect2>

<sect2 id="coloring"
><title
>Veerud A/B/C ja värviskeem</title>
<para
>Nagu ülal näha, kasutatakse veergudes A/B/C punast, rohelist, kollast ja musta värvi. </para>
<itemizedlist>
     <listitem
><para
>Must: selles kataloogis sellist elementi ei ole.</para
></listitem>
     <listitem
><para
>Roheline: uusim element.</para
></listitem>
     <listitem
><para
>Kollane: vanem kui roheline, uuem kui punane.</para
></listitem>
     <listitem
><para
>Punane: vanime element.</para
></listitem>
</itemizedlist>
<para
>Võrdlemisel ühesuguseks osutunud elementide värv on siiski samuti ühesugune ka siis, kui nad on erineva vanusega. </para
><para
>Katalooge peetakse võrdseks, kui kõik nendes olevad elemendid on samasugused. Siis võib neil olla ka ühesugune värv. Ka kataloogide korral ei mõjuta värvi vanus. </para
><para
>Selle värviskeemi mõtte andis mulle <ulink url="http://samba.org/cgi-bin/cvsweb/dirdiff"
>dirdiff</ulink
>. Need värvid meenutavad mõneti puulehte, mis värskena on roheline, muutub hiljem kollaseks ja lõpuks punaseks. </para>

</sect2
><sect2 id="operation"
><title
>Operatsiooniveerg</title>
<para
>Pärast kataloogide võrdlemist hindab &kdiff3; ühendamise võimalusi. Seda näitab veerg "Operatsioon". Operatsiooni on võimalik muuta, kui klõpsata sellel operatsioonil, mida soovid muuta. Ilmub väike hüpikmenüü, mis lubab valida antud elemendile vajaliku operatsiooni. (Kõige vajalikumad operatsioonid saab valida ka klaviatuurilt, näiteks Ctrl+1/2/3/4/Del valib vastavalt võimalusele A/B/C/Ühenda/Kustuta.) Valitud operatsioon tehakse teoks ühendamise käigus. Valikud sõltuvad elemendist ning ühendamisrežiimist. Viimaseks võib olla üks järgmistest: </para>
<itemizedlist>
     <listitem
><para
>Kolme kataloogi ühendamine ("A" on sellisel juhul teistele baasiks).</para
></listitem>
     <listitem
><para
>Kahe kataloogi ühendamine.</para
></listitem>
     <listitem
><para
>Kahe kataloogi sünkroniseerimine (selle saab aktiveerida valikuga "Kataloogide sünkroniseerimine").</para
></listitem>
</itemizedlist>
<para
>Kolme kataloogi ühendamisel on operatsioonide valikuks juhul, kui... </para>
<itemizedlist>
     <listitem
><para
>... kõik kolm kataloogi on võrdsed: kopeeri C-st</para
></listitem>
     <listitem
><para
>... A ja C on võrdsed, aga B mitte: kopeeri B-st (või kui B-d ei ole, siis kustuta sihtmärk, kui see on olemas)</para
></listitem>
     <listitem
><para
>... A ja B on võrdsed, aga C mitte: kopeeri C-st (või kui C-d ei ole, siis kustuta sihtmärk, kui see on olemas)</para
></listitem>
     <listitem
><para
>... B ja C on võrdsed, aga A mitte: kopeeri C-st (või kui C-d ei ole, siis kustuta sihtmärk, kui see on olemas)</para
></listitem>
     <listitem
><para
>... ainult A on olemas: kustuta sihtmärk (kui on olemas)</para
></listitem>
     <listitem
><para
>... ainult B on olemas: kopeeri B-st</para
></listitem>
     <listitem
><para
>... ainult C on olemas: kopeeri C-st</para
></listitem>
     <listitem
><para
>... A, B ja C ei ole võrdsed: ühenda</para
></listitem>
     <listitem
><para
>... A, B ja C ei ole sama tüüpi (nt. A on kataloog, B fail): "Viga: failitüüpide konflikt". Kui elemendid on sellised, ei saa kataloogide ühendamist alustada.</para
></listitem>
</itemizedlist>
<para
>Kahe kataloogi ühendamisel on operatsioonide valikuks juhul, kui... </para>
<itemizedlist>
     <listitem
><para
>... mõlemad kataloogid on võrdsed: kopeeri B-st</para
></listitem>
     <listitem
><para
>... A on olemas, aga mitte B: kopeeri A-st</para
></listitem>
     <listitem
><para
>... B on olemas, aga mitte A: kopeeri B-st</para
></listitem>
     <listitem
><para
>... nii A kui B on olemas, aga mitte võrdsed: ühenda</para
></listitem>
     <listitem
><para
>... A ja B ei ole sama tüüpi (nt. A on kataloog, B fail): "Viga: failitüüpide konflikt". Kui elemendid on sellised, ei saa kataloogide ühendamist alustada.</para
></listitem>
</itemizedlist>
<para
>Sünkroniseerimisrežiimi saab kasutada ainult siis, kui tegemist on kahe kataloogiga, märgitud ei ole konkreetset sihtmärki ning sisse on lülitatud valik "Kataloogide sünkroniseerimine". &kdiff3; valib sel juhul vaikeoperatsiooni, et muuta mõlemad kataloogid võrdseks. Juhul kui... </para>
<itemizedlist>
     <listitem
><para
>... mõlemad kataloogid on võrdsed: midagi ei tehta.</para
></listitem>
     <listitem
><para
>... A on olemas, aga mitte B: kopeeri A -> B</para
></listitem>
     <listitem
><para
>... B on olemas, aga mitte A: kopeeri B -> A</para
></listitem>
     <listitem
><para
>... A ja B on mõlemad olemas, aga mitte võrdsed: ühenda ja salvesta tulemus mõlemas kataloogis (kasutaja näeb B salvestamist, kuid &kdiff3; kopeerib ka B-st A-sse).</para
></listitem>
     <listitem
><para
>... A ja B ei ole sama tüüpi (nt. A on kataloog, B fail): "Viga: failitüüpide konflikt". Kui elemendid on sellised, ei saa kataloogide ühendamist alustada.</para
></listitem>
</itemizedlist>
<para
>Kui kahe kataloogi ühendamisel on sisse lülitatud valik "Ühendamise asemel kopeeritakse uuem", uurib &kdiff3; kuupäevi ning pakub välja uuema faili valimise. Kui failid ei ole võrdsed, ent on sama kuupäevaga, näitab operatsiooniveerg teadet "Viga: kuupäevad on samad, aga mitte failid." Kui kataloogis on selliseid elemente, ei ole võimalik ühendamist alustada. </para>
</sect2>

<sect2 id="status"
><title
>Staatuseveerg</title>
<para
>Ühendamisel võetakse ette üks fail teise järel. Staatuseveerg näitab kirjet "Tehtud" elementide puhul, mille ühendamist saatis edu, ning midagi muud, kui ühendamise käigus tuli ette midagi ootamatut. Kui ühendamine on lõpule jõudnud, võiksid üle kontrollida ka staatuseveeru, et näha, kas kõik seal ikka rahuldab sind. </para>
</sect2>

<sect2 id="statisticscolulmns"
><title
>Statistikaveerg</title>
<para
>Kui seadistustes on sisse lülitatud failide võrdlemise režiim "Täielik analüüs", näitab &kdiff3; lisatulpasid, kus on kirjas lahendamata, lahendatud, tühimärkide ja mitte-tühimärkide konfliktide arv. (Lahendatud konflitkide arvuga tulpa näidatakse ainult kolme kataloogi võrdlemisel või ühendamisel.) </para>
</sect2>

<sect2 id="selectingvisiblefiles"
><title
>Nimekirja failide valimine</title>
<para
>Seda, millised failid nimekirjas asuvad, saab mitmeti mõjutada. Mõningad valikud leiab <link linkend="dirmergeoptions"
>seadistustedialoogist</link
>. Menüü 'Kataloog' sisaldab järgmisi kirjeid: </para
><para
><itemizedlist>
     <listitem
><para
>"Näita identseid faile": failid, mis on võrdsed kõigis sisendkataloogides.</para
></listitem>
     <listitem
><para
>"Näita erinevaid faile": failid, mis on kahes või enamas kataloogis, aga pole võrdsed.</para
></listitem>
     <listitem
><para
>"Näita ainult A faile": failid, mis on ainult A-s, aga mitte B-s ega C-s.</para
></listitem>
     <listitem
><para
>"Näita ainult B faile": failid, mis on ainult B-s, aga mitte A-s ega C-s.</para
></listitem>
     <listitem
><para
>"Näita ainult C faile": failid, mis on ainult C-s, aga mitte A-s ega B-s.</para
></listitem>
</itemizedlist
></para>
<para
>Aktiveeri ainult need näitamiskäsud, milliseid elemente soovid näha. Kui tahad näiteks, et nimekirjas oleks kõik elemendid, mis on kas A-s või B-s, aga mitte mõlemas korraga, vali "Näita ainult A faile" ja "Näita ainult B faile" ning lülita välja kõik ülejäänud ("Näita identseid faile", "Näita erinevaid faile", "Näita ainult C faile"). Nimekiri kajastab otsekohe muudatusi. </para
><para
>Need käsud rakenduvad ka kataloogidele, kuid ühe erandiga: "Näita erinevaid faile " ei peida ühtegi faile sisaldavat kataloogi. See käib ainult nende sees paiknevate failide kohta. </para
><para
>Pane tähele, et ainult käsk "Näita identseid faile" jätab oma oleku meelde, teised on &kdiff3; käivitumisel sisse lülitatud. </para>
</sect2>

</sect1>


<sect1 id="dothemerge"
><title
>Kataloogide ühendamine</title>
<para
>Ühendada on võimalik parajasti valitud element (fail või kataloog) või kõik elemendid. Kui oled langetanud kõik operatsioonivalikud (ka alamkataloogides), võid alustada tegelikku ühendamist. </para
><para
>Pane tähele, et kui sa ei määranud sihtkataloogi, peetakse kolme kataloogi ühendamisel selleks "C", kahe kataloogi ühendamisel "B" ning sünkroniseerimisel "A" ja/või "B". </para
><para
>Kui oled sihtkataloogi määranud, kontrolli, et kõik elemendid, mis peaksid olema väljundis, oleksid olemas ka puus. Kasutada saab mõningaid valikuid, mis jätavad teatud elemendid kataloogide võrdlemisel ja ühendamisel arvesse võtmata. Vaata need valikud üle, et vältida ebameeldivaid üllatusi: </para>
<itemizedlist>
     <listitem
><para
>"Rekursiivsed kataloogid": kui see on väljas, ei kaasata elemente alamkataloogides.</para
></listitem>
     <listitem
><para
>"Failimuster"/"Anti-failimuster": kaasatakse/jäetakse välja mustriga sobivad elemendid</para
></listitem>
     <listitem
><para
>"Peidetud failid jäetakse välja"</para
></listitem>
     <listitem
><para
><link linkend="selectingvisiblefiles"
>Näitamisvalikud</link
> (Näita identseid/erinevaid faile, ainult A/B/C faile)</para
></listitem>
</itemizedlist>
<para
>Kui muudad seadistusi, et nimekirjas oleks rohkem faile, pead need uuesti läbi uurima menüükäsuga "Kataloog"->"Uuri uuesti" (põhjus seisab selles, et võrdlemiskiiruse tõstmise nimel jätab &kdiff3; vahele nende kriteeriumidega nähtamatuks muudetud failide võrdlemise). Kui muudad faili- ja kataloogimustrit failide väljajätmiseks, uuendatakse failinimekirja otsekohe pärast valikute dialoogi sulgemist. </para
><para
>Pane tähele, et kui kirjutad täiesti uude kataloogi, on tavaliselt mõttekas kopeerida ka identsed failid. Selleks tuleb sisse lülitada valik "Näita identseid faile". Kui sihtkataloogiks on mõni sisendkataloogidest, siis ei ole seda vaja, sest fail on ju juba seal olemas. </para
><para
>Kui kõik on korras, siis ülejäänud on juba lihtne. </para
><para
>Kõigi elementide ühendamine: vali menüüst "Kataloog" käsk "Alusta/jätka kataloogi ühendamist" või kasuta kiirklahvi F7. Ainult aktiivse elemendi ühendamine: vali "Käivita operatsioon käesoleva elemendiga" või vajuta F6. </para
><para
>Kui failitüüpide konflikti tõttu esineb veel mõningaid sobimatute operatsioonidega elemente, ilmub teatekast, mis osutab sellistele elementidele, nii et sa saad valida neile vajalikud operatsioonid. </para
><para
>Kui ühendad kõik elemendid, ilmub dialoog, kus valikuvõimalusteks on "Tee ära", "Simuleeri" ja "Loobu". </para>
<itemizedlist>
     <listitem
><para
>Vali "Simuleeri", kui soovid näha, mida ette võetakse, ilma et seda tegelikult ette võetaks. Näidatakse põhjalikku ülevaadet, milliseid aktsioone sinu tegevus endaga kaasa tooks.</para
></listitem>
     <listitem
><para
>Ühendamise tegelikuks alustamiseks vali "Tee ära".</para
></listitem>
</itemizedlist>
<para
>Seejärel asub &kdiff3; kõigi elementidega läbi viima neile määratud operatsioone. Kui vaja läheb käsitsi sekkumist (konkreetse faili ühendamisel), ilmub ühendamisaken (<link linkend="dirmergebigscreenshot"
>vaata suurt pilti</link
>). </para
><para
>Kui oled faili kallal kõik vajaliku ära teinud, vali uuesti menüükäsk "Alusta/jätka kataloogi ühendamist" või vajuta klahvi F7. Kui sa ei ole veel salvestanud, ilmub dialoog, mis teeb sulle vastava ettepaneku. Seejärel võtab &kdiff3; ette järgmise elemendi. </para
><para
>Kui &kdiff3; satub silmitsi veaga, annab ta sellest sulle teada ning näitab ka põhjalikku infot vea kohta, mis võib aidata kaasa arusaamisele, mis viga põhjustas. Kui valid ühendamise jätkamise (klahv F7), võimaldab &kdiff3; sul antud elemendi ühendamist uuesti proovida või see vahele jätta. See tähendab, et sa saad enne jätkamist valida mõne muu operatsiooni või jätta hetkel asi nii nagu on, et leida lahendus hiljem. </para
><para
>Kui ühendamine on lõpule jõudnud, annab &kdiff3; sellest teatekastiga sulle märku. </para
><para
>Kui mõned elemendi on ühendatud individuaalselt, jätab &kdiff3; selle (antud ühendamisseansi ajal) meelde ega hakka neid enam ühendama, kui valid hiljem kõigi elementide ühendamise. Isegi juhul, kui ühendamine jäeti tegelikult vahele või midagi ei salvestatud, peetakse neid elemente ühendatuks, nii et nendega saab hakata uuesti tegelema alles siis, kui oled vahetanud ühendamisoperatsiooni. </para>
</sect1>

<sect1 id="dirmergeoptions"
><title
>Kataloogide võrdlemise ja ühendamise valikud</title>
<para
>&kdiff3; seadistustes (menüükäsk "Seadistused"-&gt;"&kdiff3; seadistamine") on sektsioon "Kataloogide ühendamine" järgmiste valikutega: </para>

<variablelist>
   <varlistentry
><term
><emphasis
>Rekursiivsed kataloogid:</emphasis
></term
><listitem
><para
>Võimalus valida, kas kataloogid otsitakse läbi rekursiivselt, see tähendab, koos alamkataloogidega.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Failimustrid:</emphasis
></term
><listitem
><para
>Puus näidatakse ainult faile, mis vastavad siin määratud mustrile. Rohkem kui ühe mustri saab valida, kui kasutada eraldajana semikoolonit ";". Kasutada tohib metamärke '*' ja '?' (nt. "*.cpp;*.h"). Vaikimisi on muster "*". Kataloogid mustrit ei vaja.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Anti-failimustrid:</emphasis
></term
><listitem
><para
>Selle mustriga sobivad failid ja kataloogid jäetakse puust välja. Rohkem kui ühe mustri saab valida, kui kasutada eraldajana semikoolonit ";". Kasutada tohib metamärke '*' ja '?'. Vaikimisi on muster "*.orig;*.o;*.obj".</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Kataloogide anti-failimustrid:</emphasis
></term
><listitem
><para
>Selle mustriga sobivad failid ja kataloogid jäetakse puust välja. Rohkem kui ühe mustri saab valida, kui kasutada eraldajana semikoolonit ";". Kasutada tohib metamärke '*' ja '?'. Vaikimisi on muster "CVS;deps;.svn".</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>.cvsignore kasutamine:</emphasis
></term
><listitem
><para
>Ignoreeritakse faile ja katalooge, mida ignoreerib ka CVS. CVS eirab paljusid automaatselt genereeritud faile. Selle suureks eeliseks on see, et see võib olla kataloogipõhine kohaliku ".cvsignore" faili vahendusel (vaata <ulink url="info:/cvs/cvsignore"
>info:/cvs/cvsignore</ulink
>).</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Peidetud failide ja kataloogide otsimine:</emphasis
></term
><listitem
><para
>Mõnes failisüsteemis on failidel atribuut "peidetud", teistes süsteemides peidab failid nende nime ees seisev punkt ("."). See valik lubab sul määrata, kas sellised failid kaasatakse puusse või mitte. Vaikimisi sees.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Failiviitade järgimine:</emphasis
></term
><listitem
><para
>Kui on väljas, võrreldakse nimeviitu, kui sees, siis faile, millele viidatakse. Vaikimisi väljas.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Kataloogiviitade järgimine:</emphasis
></term
><listitem
><para
>Kui on väljas, võrreldakse nimeviitu, kui sees, peetakse viitu kataloogideks ning neid skaneeritakse rekursiivselt. (Pane tähele, et programm ei kontrolli, kas viit on "rekursiivne", nii et kui viita kataloogile sisaldav kataloog tekitab lõputu silmuse, siis mõne aja pärast, kui pinu on ületäidetud või mälu otsa saab, elab programm üle krahhi.) Vaikimisi väljas.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Tõstutundlik failinimede võrdlemine:</emphasis
></term
><listitem
><para
>Vaikimisi väär Windowsi ja tõene teiste operatsioonosüsteemide korral.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Failide võrdlemise režiim:</emphasis
></term
><listitem
><para>
<variablelist
>            
   <varlistentry
><term
><emphasis
>Binaarne võrdlemine:</emphasis
></term
><listitem
><para
>See on vaikimisi failide võrdlemise režiim. </para
></listitem
></varlistentry
>         
   <varlistentry
><term
><emphasis
>Täielik analüüs:</emphasis
></term
><listitem
><para
>Sooritab iga faili täieliku analüüsi ja näitab statistikatulpi (lahendatud, lahendamata, tühimärkide ja mitte-tühimärkide konfliktide arv). Täielik analüüs on aeglasem kui tavaline binaarne analüüs ning palju aeglasem, kui tegemist on failidega, mis ei sisalda teksti. (Määra sobivad anti-failimustrid.) </para
></listitem
></varlistentry
>         
   <varlistentry
><term
><emphasis
>Muutmiskuupäeva usaldamine:</emphasis
></term
><listitem
><para
>Suurte kataloogide võrdlemisel üle aeglase võrgu on usutavasti kiirem võimalus võrrelda ainult muutmiskuupäevi ja failide suurust. Kuid kui see ka suurendab kiirust, võib see ometi kaasa tuua eksimusi. Seepärast tasuks selle kasutamisse ettevaatlikult suhtuda. Vaikimisi väljas.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Suuruse usaldamine:</emphasis
></term
><listitem
><para
>Sarnane muutmiskuupäeva usaldamisele. Tegelikku võrdlemist ei teostata. Kaht faili peetakse võrdseks, kui nende failisuurus on võrdne. See on abiks, kui failide kopeerimisel ei säilunud muutmise aeg. Kasuta seda siiski ettevaatlikult. Vaikimisi väljas.</para
></listitem
></varlistentry>
</variablelist
></para
></listitem
></varlistentry>
         
   <varlistentry
><term
><emphasis
>Kataloogide sünkroniseerimine:</emphasis
></term
><listitem
><para
>Aktiveerib "sünkroniseerimisrežiimi", mille puhul võrreldakse kaht kataloogi ilma konkreetset sihtkataloogi määramata. Selles režiimis valitakse operatsioonid nii, et lõpptulemusena oleks kaks kataloogi võrdsed. Ka ühendamise tulemused kirjutatakse mõlemasse kataloogi. Vaikimisi väljas.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Ühendamise asemel kopeeritakse uuem:</emphasis
></term
><listitem
><para
>Ühendamise asemel pakutakse operatsiooniks uuema allika kopeerimine. Seda võimalust peetakse ebaturvaliseks, sest see eeldab, et teist faili ei ole redigeeritud. Seda aga tasuks igal juhul konkreetselt kontrollida. Vaikimisi väljas.</para
></listitem
></varlistentry>
   <varlistentry
><term
><emphasis
>Failidest tehakse varukoopia:</emphasis
></term
><listitem
><para
>Kui fail või terve kataloog asendatakse teisega või kustutatakse, säilitatakse algne versioon, andes sellele laiendi ".orig". Kui on juba olemas varasem varukoopia laiendiga ".orig", siis see kustutatakse. See toimib nii kataloogide kui failide liitmisel. Vaikimisi sees.</para
></listitem
></varlistentry>
</variablelist>
</sect1>

<sect1 id="other"
><title
>Muud funktsioonid kataloogide ühendamise aknas</title>
<sect2
><title
>Ekraani poolitamine ja täisekraanirežiim</title>
<para
>Tavaliselt jääb faili võrdlemisel või ühendamisel kataloogi ühendamise nimekiri nähtavale. Hiirega võid aga liigutada failide nimekirja võrdlusaknast eraldavat riba. Kui sa seda ei soovi, võid menüüst "Kataloog" võmaluse "Poolitamisvaade" välja lülitada. Seejärel võid kasutada menüüs "Kataloog" olevat võimalust "Lülita vaadet", et vahetada kogu ekraani täitvat failinimekirja või võrdlusakna vaadet. </para>
</sect2>
<sect2
><title
>Ühe faili võrdlemine või ühendamine</title>
<para
>Võib juhtuda, et eelistad võrdlemiseks kasutada lihtsalt klõpsu failil. Samasugune käsk on siiski olemas ka menüüs "Kataloog". Samuti saab vahetult ühendada konkreetse faili ilma kataloogide ühendamist käivitamata, kui valida menüüst "Kataloog" käsk "Ühenda üks fail". Tulemuse salvestamisel märgitakse selles staatuseks "Tehtud" ning kui seejärel käivitada kataloogide ühendamine, seda faili enam ei kaasata. </para
><para
>Kuid pane tähele, et see staatus läheb kaduma, kui käivitad uuesti kataloogi skaneerimise (menüü "Kataloog", käsk "Uuri uuesti läbi") </para>
</sect2>
<sect2
><title
>Erineva nimeta failide võrdlemine või ühendamine</title>
<para
>Mõnikord on vaja võrrelda või ühendada erineva nimega faile (nt. aktiivne fail ja sellesama faili varukoopia samas kataloogis). </para
><para
>Vali vajalik fail veerus A, B või C ikoonile klõpsates. Esimene nii valitud fail märgitakse A-na, teine ja kolmas B ja C-na sõltumata sellest, millises veerus nad paiknevad. Nii saab valida ainult kuni kolm faili. </para
><para
>Jätkamiseks vali menüüst "Kataloog" käsk "Võrdle valitud faile" või "Ühenda valitud failid". Samu käske saab valida ka kontekstimenüüst, kui klõpsata valitud failile hiire parema nupuga. </para
><para
>Faili võrdlemine või ühendamine toimub samas aknas. Kataloogide korral avatakse uus aken. </para
></sect2>
</sect1>
</chapter>

<chapter id="misc">
<title
>Mitmesugused teemad</title>
<sect1 id="networktransparency">
<title
>Võrguläbipaistvus KIO-moodulite vahendusel</title>
<sect2
><title
>KIO moodulid</title>
<para
>KDE toetab võrguläbipaistvust oma KIO-moodulite abil. &kdiff3; kasutab neid sisendfailide lugemiseks ja kataloogide läbiuurimiseks. See tähendab, et võid faile ja katalooge määrata URL-e kasutades nii kohalikul kui võrgumasinal. </para
><para
>Näide: </para
><para>
<screen
><command
>kdiff3</command
> test.cpp  ftp://ftp.faraway.org/test.cpp
   <command
>kdiff3</command
> tar:/home/hacker/archive.tar.gz/dir ./dir
</screen>
</para>
<para
>Esimene rida võrdleb kohalikku faili failiga FTP-serveris. Teine rida võrdleb kataloogi arhiivifailis kohaliku kataloogiga. </para
><para
>Muud huvipakkuvad KIO-moodulid: </para>
<itemizedlist>
<listitem
><para
>WWW-failid (http:)</para
></listitem>
<listitem
><para
>FTP-failid (ftp:)</para
></listitem>
<listitem
><para
>Krüptitud failiedastused (fish:, sftp:)</para
></listitem>
<listitem
><para
>Windowsi ressursid (smb:)</para
></listitem>
<listitem
><para
>Kohalikud failid (file:)</para
></listitem>
</itemizedlist>
<para
>Muud asjad, mis on võimalikud, aga arvatavasti vähekasutatavad: </para>
<itemizedlist>
<listitem
><para
>Man-leheküljed (man:)</para
></listitem>
<listitem
><para
>Info-leheküljed (info:)</para
></listitem>
</itemizedlist>
</sect2>

<sect2
><title
>Kuidas kirjutada URL-e</title>
<para
>Võrreldes kohalike failide ja kataloogide asukohaga on URL-il teistsugune süntaks. Silmas tuleks pidada järgmisi asju: </para>
<itemizedlist>
<listitem
><para
>Asukoht võib olla suhteline ja sisaldada märke "." või "..". See ei ole võimalik URL-ide puhul, mis on alati absoluutsed. </para
></listitem
><listitem
><para
>Erisümbolid tuleb alati "päästa" ehk varjestada ("#" -> "%23", tühik -> "%20" jne.). Näiteks failil nimega "/#foo#" on URL "file:/%23foo%23". </para
></listitem
><listitem
><para
>Kui URL ei toimi oodatult, proovi see avada Konqueroris. </para
></listitem>
</itemizedlist>

</sect2>

<sect2
><title
>KIO-moodulite võimalused</title>
<para
>Võrguläbipaistvusel on üks puudus: mitte kõik ressursid ei paku ühesuguseid võimalusi. </para
><para
>Vahel sõltub see serveri failisüsteemist, vahel protokollist. Toome siin ära lühikese piirangute loetelu: </para>
<itemizedlist>
<listitem
><para
>Vahel ei ole viidad toetatud. </para
></listitem
><listitem
><para
>Vahel aga ei ole võimalik eristada, kas viit osutab failile või kataloogile: Sellisel juhul eeldatakse alati faili (ftp:, sftp:). </para
></listitem
><listitem
><para
>Alati pole võimalik määrata failisuurust. </para
></listitem
><listitem
><para
>Piiratud õiguste toetus. </para
></listitem
><listitem
><para
>Puudub võimalus muuta õigusi või muutmisaega, mistõttu koopia õigused või aeg erinevad originaalist - vaata ka võimalust "Suuruse usaldamine". (See on võimalik ainult kohalike failidega.) </para
></listitem>
</itemizedlist>
</sect2>
</sect1>

<sect1 id="kpart">
<title
>&kdiff3; kui KPart</title>
<para
>&kdiff3; on KPart. Hetkel on teostatud liides KParts::ReadOnlyPart. </para
><para
>Selle peamine kasutusala on erinevuste vaatamine KDevelopis. KDevelop käivitab alati esmalt oma seesmise erinevuste näitaja. &kdiff3; väljakutsumiseks klõpsa hiire parema nupuga erinevuste näitaja aknal ja vali kontekstimenüüst "Näita KDiff3-s". </para
><para
>&kdiff3; vajab tavaliselt sisendiks kaht faili. Komponendina kasutades eeldab &kdiff3;, et sisendfail on paigafail unifitseeritud vormingus. Seejärel hangib &kdiff3; paigafailist algupärased failinimed. Vähemalt üks kahest failist peab olema kättesaadav. Seejärel kutsub &kdiff3; välja käsu <command
>patch</command
> teise faili taasloomiseks. </para
><para
>Konqueroris võib valida paigafaili ning seejärel kontekstimenüüst "Eelvaatlus KDiff3-s". Arvesta, et see ei toimi, kui ühtegi algupärast faili ei ole saadaval, ning see ei ole eriti usaldusväärne, kui algfaili või ka mõlemat algfaili on muudetud pärast paigafaili loomist. </para
><para
>Komponendina käivitades pakub &kdiff3; ainult kahe faili võrdlemist, väga pisikest tööriistariba ja menüüd. Ühendamine ega kataloogide võrdlemine ei ole praegu toetatud. </para>
</sect1>
</chapter>

<chapter id="faq">
<title
>Küsimused ja vastused</title>
&reporting.bugs; &updating.documentation; <qandaset id="faqlist">

<qandaentry
><question
><para
>Miks on selle nimi "&kdiff3;"? </para
></question
><answer
><para
>Sellised vahendid, nagu "KDiff" ja "KDiff2" (nüüd nimega "Kompare") olid juba olemas. Samuti laseb "KDiff3" oletada, et see tuleb toime ühendamisega samamoodi nagu "diff3" vahend Diff-Tool paketis. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Miks on selle litsents GPL? </para
></question
><answer
><para
>Ma olen GPL programme kasutanud juba väga pikka aega ning väga palju õppinud arvukaid lähtekoode uurides. Seepärast kuulub ka minu siiras tänu kõigile, kes on nii talitanud, talitavad või alles kavatsevad talitada. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Mõned nupud ja funktsioonid on puudu. Mis lahti? </para
></question
><answer
><para
>Kompileerisid ilmselt rakenduse lähtekoodist, kuid jätsid konfigureerimisel korrektse KDE prefiksi määramata. Vaikimisi igatseb .configure paigalduse ette võtta kataloogis /usr/local, kuid sellisel juhul ei leia KDE kasutajaliides ressursifaili (s.t kdiff3ui.rc). Korrektsest prefiksist räägib pikemalt fail README. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Enamasti on sarnased, aga mitte samased read teineteise kõrval, aga mitte alati. Miks? </para
></question
><answer
><para
>Ridu, mis erinevad ainult tühimärkide arvu poolest, peetakse algul "võrdseks", samas muudab ka üksainus teistsugune tühimärk failid "erinevaks". Kui sarnased read satuvad teineteise kõrvale, on see tegelikult kokkusattumus, aga õnneks esineb seda päris sageli. Vaata ka <link linkend="manualdiffhelp"
>Käsitsi erinevused</link
>. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Miks peavad enne salvestamist olema lahendatud kõik konfliktid? </para
></question
><answer
><para
>Iga võrdse või erineva sektsiooni korral jätab redaktor ühendamise tulemuse aknas meelde, kus see algab või lõpeb. Seda on vaja selleks, et konflikte oleks võimalik käsitsi lahendada lihtsalt allikanuppu (A, B või C) valides. See info läheb kaotsi, kui tekst salvestada ning sellise spetsiaalse failivormingu loomine, mis toetaks kogu vajaliku info salvestamist ja taastamist, oleks liiga keeruline ning raske. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Kuidas sünkroniseerida erinevuse ja ühendamise vaated, et kõik vaated näitaksid teksti sama asukohta? </para
></question
><answer
><para
>Klõpsa kokkuvõtetulbal tekstist vasakul (<link linkend="synchronise_views"
>vaata ka siit</link
>). </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Miks puudub redaktoril ühendamise tulemuste aknas "tagasivõtmise" funktsioon? </para
></question
><answer
><para
>Ka see nõuaks asjade praeguse seisu juures liiga palju tööd ja vaeva. Vajalik versioon on võimalik alati taastada konkreetse allika (A, B või C) põhjal lihtsalt vastavat nuppu klõpsates. Suurema redigeerimise korral on nagunii soovitatav kasutada mõnda muud redaktorit. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Eemaldasin veidi teksti ja järsku ilmus "&lt;Lähterida puudub&gt;", mida ei saa kuidagi kõrvaldada. Mida see tähendab ja kuidas sellest lahti saada? </para
></question
><answer
><para
>Iga võrdse või erineva sektsiooni korral jätab redaktor ühendamise tulemuse aknas meelde, kus see algab või lõpeb. "&lt;Lähterida puudub&gt;" tähendab, et sektsiooni ei ole enam midagi jäänud, isegi mitte reavahetusmärki. See võib juhtuda automaatsel ühendamisel või redigeerimise ajal. Tegelikult ei ole see üldse mingi probleem, sest salvestatud failis seda viidet enam ei ole. Kui soovid algvarianti tagasi, vali lihtsalt sektsioon (klõpsuga vasakul asuval kokkuvõttetulbal) ning seejärel klõpsa vajaliku sisuga allkfaili nuppu (A/B või C). </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Miks &kdiff3; ei toeta süntaksi esiletõstu? </para
></question
><answer
><para
>&kdiff3; kasutab niigi palju värve erinevuste esiletõstmiseks. Veelgi rohkem värve ajaks asja ainult arusaamatult kirjuks. Kui sa siiski soovid süntaksi esiletõstu, tuleb sul leppida mõne muu redaktoriga. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Kas &kdiff3; võib võrrelda OpenOffice.Org-i, Wordi, Exceli, PDF-faile &etc;? </para
></question
><answer
><para
>Kuigi &kdiff3; võib analüüsida mis tahes faile, ei ole selle tulemus arvatavasti päris rahuldav. </para
><para
>&kdiff3; on mõeldud puhaste tekstifailide võrdlemiseks. OpenOffice, Word, Excel jne. salvestavad oma failidesse märksa rohkem teavet (fontide, piltide, lehekülgede, värvide jms. kohta), millest &kdiff3; ei tea midagi. Seepärast näitab &kdiff3; nende failide sisu puhtalt tekstina tõlgendades, aga see võib osutuda loetamatuks või vähemalt paista üsna veidrana. </para
><para
>Et enamik rakendusi salvestab tänapäeval oma failid XML-vormingus, võib seda lugeda ka klaartekstina. Sel juhul võib &kdiff3;-st väikeste erinevuste korral ka abi olla. </para
><para
>Kui soovid võrrelda ainult teksti (ilma põimitud objektide, näiteks piltideta), on kõige mõistlikum valida oma rakenduses "Vali kõik" ja "Kopeeri", et kopeerida huvipakkuv tekst lõikepuhvrisse, kust &kdiff3; saab selle asetada mõnda sisendaknasse (vaata ka <link linkend="selections"
>Valimine, kopeerimine ja asetamine</link
>). </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Kuhu on kadunud kataloogide valik "Näita ainult erinevusi"? </para
></question
><answer
><para
>Kataloogimenüüs on nüüd mitu <link linkend="selectingvisiblefiles"
>näitamiskäsku</link
>. Kui eemaldada märge käsu "Näita identseid faile", on tulemus samasugune nagu varem "Näita ainult erinevusi" korral. </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Kuidas valida erinevuse sisendaknas suur hulk teksti - kerimine on nii aeglane? </para
></question
><answer
><para
>Alusta valimist tavapäraselt (klõpsa ja hoia hiire vasakut nuppu all). Seejärel kasutada vasakut nuppu jätkuvalt all hoides liikumisklahve (nt. Page Up, Page Down). (Vaata ka <link linkend="selections"
>Valimine, kopeerimine ja asetamine</link
>.) </para
></answer
></qandaentry>

<qandaentry
><question
><para
>Siin on küll palju infot, aga mitte vastust minu küsimusele! </para
></question
><answer
><para
>Palun saada oma küsimus mulle. Ma olen väga rõõmus igasuguse tagasiside üle. </para
></answer
></qandaentry>

</qandaset>
</chapter>

<chapter id="credits">

<title
>Autorid ja litsents</title>

<para
>&kdiff3; - failide ja kataloogide võrdlemise ja ühendamise vahend </para>
<para
>Rakenduse autoriõigus 2002-2007: Joachim Eibl <email
>joachim.eibl at gmx.de</email
> </para>
<para
>Mitmed lahedad ideed ja vearaportid on pärit minu kolleegidelt ning paljudelt metsiku veebi asukatelt. Tänud teile kõigile! </para>

<para
>Dokumentatsiooni autoriõigus &copy; 2002-2007: Joachim Eibl <email
>joachim.eibl at gmx.de</email
> </para>

<para
>Tõlge eesti keelde: Marek Laane <email
>bald@starman.ee</email
></para
> 
&underFDL; &underGPL; </chapter>

<appendix id="installation">
<title
>Paigaldamine</title>

<sect1 id="getting-kdiff3">
<title
>&kdiff3; hankimine</title>

<para
>&kdiff3; uusima versiooni saab alla laadida selle koduleheküljelt <ulink url="http://kdiff3.sourceforge.net"
>http://kdiff3.sourceforge.net</ulink
>. </para
><para
>&kdiff3; on saadaval ka muudele platvormidele. Vaata lähemalt koduleheküljelt. </para>


</sect1>

<sect1 id="requirements">
<title
>Nõuded</title>

<para
>&kdiff3; kõigi omaduste edukaks kasutamiseks on vajalik &kde; 
>3.1. </para
><para
>Infot selle kohta, kuidas panna &kdiff3; tööle muudel platvormidel ilma KDE-ta, vaata palun <ulink url="http://kdiff3.sourceforge.net"
>koduleheküljelt</ulink
>. </para
><para
>Muudatuste nimekirka leiab internetist <ulink url="http://kdiff3.sourceforge.net/ChangeLog"
>http://kdiff3.sourceforge.net/ChangeLog</ulink
> või lähtepaketist failis "ChangeLog". </para>
</sect1>

<sect1 id="compilation">
<title
>Kompileerimine ja paigaldamine</title>

<para
>&kdiff3; kompileerimiseks ja paigaldamiseks KDE-d kasutavas süsteemis anna &kdiff3; paketi baaskataloogis viibides käsureal korraldused:</para>

<screen
><prompt
>%</prompt
> <userinput
><command
>./configure --prefix=<replaceable
>kde-kataloog</replaceable
></command
></userinput>
<prompt
>%</prompt
> <userinput
><command
>make</command
></userinput>
<prompt
>%</prompt
> <userinput
><command
>make</command
> install</userinput
>
</screen>
<para
><replaceable
>kde-kataloog</replaceable
> määrab kataloogi süsteemis, kuhu on paigaldatud KDE. Kui sa ei ole selles kindel, loe faili README. </para>
<para
>Kui sa ei kasuta KDE-d, ära kasuta ka skripti <command
>configure</command
>, vaid järgi failis README toodud juhiseid ainult Qt-ga süsteemidele.</para>
<para
>Kuna &kdiff3; kasutab programme <command
>autoconf</command
> ja <command
>automake</command
>, ei tohiks kompileerimisel probleeme esineda. Kui neid siiski tekib, anna neist palun teada &kde; meililistides.</para>

</sect1>

</appendix>

&documentation.index;
</book>

<!--
Local Variables:
mode: sgml
sgml-minimize-attributes:nil
sgml-general-insert-case:lower
sgml-indent-step:0
sgml-indent-data:nil
End:

vim:tabstop=2:shiftwidth=2:expandtab
-->