<chapter id="fundamentals"> <chapterinfo> <authorgroup> <author><personname><firstname></firstname></personname></author> <!-- TRANS:ROLES_OF_TRANSLATORS --> </authorgroup> </chapterinfo> <title>The Fundamentals</title> <para> If you have ever used a text editor, you will have no problem using &kate;. In the next two sections, <link linkend="starting-kate">Starting &kate; </link> and in <link linkend="working-with-kate">Working with &kate;</link>, we will show you everything you need to get up and running quickly. </para> <sect1 id="starting-kate"> <title>Starting &kate;</title> <para> You can start &kate; from the application launcher or from the command line. </para> <sect2 id="starting-from-the-menu"> <title>From the Menu</title> <para> Open the &kde; program menu by clicking on the application launcher icon on the toolbar at the bottom left of your screen. This will raise a menu. Move your cursor up the menu to the <menuchoice><guimenu>Applications</guimenu><guisubmenu>Utilities</guisubmenu> <guimenuitem>Advanced Text Editor &kate;</guimenuitem></menuchoice> menu item. </para> </sect2> <sect2 id="starting-from-the-command-line"> <title>From the Command Line</title> <para> You can start &kate; by typing its name on the command line. If you give it a file name, as in the example below, it will open or create that file. </para> <informalexample> <screen> <prompt>%</prompt><userinput><command>kate</command> <option><replaceable>myfile.txt</replaceable></option></userinput> </screen> </informalexample> <para> If you have an active connection, and permission, you can take advantage of &kde;'s network transparency to open files on the internet. </para> <informalexample> <screen> <prompt>%</prompt><userinput><command>kate</command> <option><replaceable>ftp://ftp.kde.org/pub/kde/README</replaceable></option></userinput> </screen> </informalexample> <sect3 id="command-line-options"> <title>Command Line Options</title> <para>&kate; accepts following command line options:</para> <variablelist> <varlistentry> <term><userinput><command>kate</command> <option>--help</option></userinput></term> <listitem> <para> This lists the options available at the command line. </para> </listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-s</option> <option>--start</option> <parameter>name</parameter></userinput></term> <listitem> <para> Starts kate with the session <parameter>name</parameter>. The session is created if it does not exist already. If a &kate; instance running the specified session exists, the specified files are loaded in that instance. </para> </listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-p</option> <option>--pid</option> <parameter>PID</parameter></userinput></term> <listitem> <para> Only reuses an instance with the specified PID (Process ID). </para> </listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-e</option> <option>--encoding</option> <parameter>encoding</parameter> <parameter>URL</parameter></userinput></term> <listitem><para>Uses the specified encoding for the document. </para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-l</option> <option>--line</option> <parameter>line</parameter> <parameter>URL</parameter></userinput></term> <listitem><para>Navigates to the specified line after opening the document. </para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-c</option> <option>--column</option> <parameter>column</parameter> <parameter>URL</parameter></userinput></term> <listitem><para>Navigates to the specified column after opening the document. </para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-i</option> <option>--stdin</option></userinput></term> <listitem><para>Reads the document content from STDIN. This is similar to the common option <option>-</option> used in many command line programs, and allows you to pipe command output into &kate;.</para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>--startanon</option></userinput></term> <listitem><para>Start &kate; with a new anonymous session, implies <option>-n</option>.</para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-n</option> <option>--new</option></userinput></term> <listitem><para>Force start of a new &kate; instance (is ignored if <option>start</option> is used and another &kate; instance already has the given session opened), forced if no parameters and no URLs are given at all.</para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-b</option> <option>--block</option></userinput></term> <listitem><para>If using an already running &kate; instance, block until it exits, if URLs given to open.</para> <para> You can use &kate; with this option as editor for typing in commit messages for version control systems like <application>Git</application> or <application>Subversion</application>. These systems expect to block the editor till you have entered your message, because they then open the temporary file, which would be empty if kate immediately returned to the caller. </para> <para>This option is also needed with KIO (&kde; Input/Output), if you open a remote file (which has been downloaded to a temporary) and should be reuploaded, after you saved it. </para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>--tempfile</option></userinput></term> <listitem><para>When used, the specified files are treated as temporary files and deleted (if they are local files and you have sufficient permissions) when closed, unless they were modified since they were opened.</para></listitem> </varlistentry> <!--FIXME usecase? --> <varlistentry> <term><userinput><command>kate</command> <option>--desktopfile</option> <parameter>filename</parameter></userinput></term> <listitem><para>The base file name of the desktop entry for this application.</para></listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>--author</option></userinput></term> <listitem> <para> Lists &kate;'s authors in the terminal window. </para> </listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>-v</option> <option>--version</option></userinput></term> <listitem> <para> Lists version information for &kate;. </para> </listitem> </varlistentry> <varlistentry> <term><userinput><command>kate</command> <option>--license</option></userinput></term> <listitem> <para> Shows license information. </para> </listitem> </varlistentry> </variablelist> </sect3> </sect2> <sect2 id="drag-and-drop"> <title>Drag and Drop</title> <para> &kate; uses the &kde; Drag and Drop protocol. Files may be dragged and dropped onto &kate; from the Desktop, the filemanager &dolphin; or some remote ftp site opened in one of &dolphin;'s windows. </para> </sect2> </sect1> <sect1 id="working-with-kate"> <title>Working with &kate;</title> <para> <link linkend="quick-start">Quick Start</link> will show you how to toggle four simple options that will let you configure some of &kate;'s more powerful features right away. <link linkend="keystroke-commands"> Shortcuts</link> lays out some of the default keystroke shortcuts for those who can't or don't want to use a mouse. </para> <sect2 id="quick-start"> <title>Quick Start</title> <para> This section will describe some of the items on the <guimenu>View</guimenu> menu so that you can quickly configure &kate; to work the way you want it. </para> <para> When you start &kate; for the first time you will see two windows with white backgrounds. Above the two windows is a toolbar with the usual labeled icons. And above that, a menubar. </para> <para> The left-hand window is a side bar. It combines the <guilabel>Documents</guilabel> and <guilabel>Filesystem Browser</guilabel> windows. Switch between the two by clicking on the tabs to the left of the window. </para> <para> If you've started &kate; with a file, the right-hand window will show the file you are editing and the <guilabel>Documents</guilabel> on the side bar will show the name of the file. Use the <guilabel>Filesystem Browser</guilabel> window to open files. </para> <para> You can toggle all sidebar windows on and off in <menuchoice><guimenu>View</guimenu><guisubmenu>Tool Views</guisubmenu></menuchoice> menu or use <keycombo action="simul">&Ctrl;&Alt;&Shift;<keycap>F</keycap></keycombo>. This menu offers you your first glimpse into &kate;'s power and flexibility. </para> <para>In <guisubmenu>Tool Views</guisubmenu> you have a list of all enabled plugins. Click the checkbox in front of each item or click with the &LMB; on the tool buttons in the sidebar to toggle this tool view on and off. </para> </sect2> <sect2 id="keystroke-commands"> <title>Shortcuts</title> <para> Many of &kate;'s keystroke commands (shortcuts) are configurable by way of the <link linkend="settings-help-menu">Settings</link> menu. By default &kate; honors the following key bindings. </para> <!-- Ctrl+T Transpose Characters Meta+Ctrl+V ii input mode --> <informaltable> <tgroup cols="2"> <tbody> <row><entry><para><keycap>Insert</keycap></para></entry> <entry><para> Toggle between Insert and Overwrite mode. When in insert mode the editor will add any typed characters to the text and push any previously typed data to the right of the text cursor. Overwrite mode causes the entry of each character to eliminate the current character.</para></entry> </row> <row> <entry><para><keycombo><keycap>Left Arrow</keycap></keycombo></para></entry> <entry><para>Move the cursor one character to the left </para></entry> </row> <row> <entry><para><keycombo><keycap>Right Arrow</keycap></keycombo></para></entry> <entry><para> Move the cursor one character to the right </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>Up Arrow</keycap></keycombo></para></entry> <entry><para> Move the cursor up one line </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>Down Arrow</keycap></keycombo></para></entry> <entry><para> Move the cursor down one line </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>Page Up</keycap></keycombo></para></entry> <entry><para> Move the cursor up one page </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>Page Down</keycap></keycombo></para></entry> <entry><para>Move the cursor down one page </para></entry> </row> <row> <entry><para><keycombo action="simul">&Backspace;</keycombo></para></entry> <entry><para> Delete the character to the left of the cursor </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>Home</keycap></keycombo></para></entry> <entry><para> Move the cursor to the beginning of the line </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>End</keycap></keycombo></para></entry> <entry><para> Move the cursor to the end of the line </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>Delete</keycap></keycombo></para></entry> <entry><para>Delete the character to the right of the cursor (or any selected text)</para></entry> </row> <row> <entry><para><keycombo action="simul">&Shift;&Enter;</keycombo></para></entry> <entry><para>Insert newline including leading characters of the current line which are not letters or numbers. It is useful ⪚ to write comments in the code: At the end of the line <quote>// some text</quote> press this shortcut and the next line starts already with <quote>// </quote>. So you do not have to enter the comment characters at the beginning of each new line with comments.</para></entry> </row> <row> <entry><para><keycombo action="simul">&Shift;<keycap>Left Arrow</keycap></keycombo></para></entry> <entry><para> Mark text one character to the left </para></entry> </row> <row> <entry><para><keycombo action="simul">&Shift;<keycap>Right Arrow</keycap></keycombo></para></entry> <entry><para> Mark text one character to the right </para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>F1</keycap></keycombo></para></entry> <entry><para> Help</para></entry> </row> <row> <entry><para><keycombo action="simul">&Shift;<keycap>F1</keycap></keycombo></para></entry> <entry><para><link linkend="whats-this">What's this?</link></para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>F</keycap></keycombo></para></entry> <entry><para><link linkend="edit-find"> Find</link></para></entry> </row> <row> <entry><para><keycombo action="simul"><keycap>F3</keycap></keycombo></para></entry> <entry><para><link linkend="edit-find-next"> Find Next</link></para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>B</keycap></keycombo></para></entry> <entry><para>Set a Bookmark</para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>C</keycap></keycombo></para></entry> <entry><para> Copy the marked text to the clipboard </para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>N</keycap></keycombo></para></entry> <entry><para> <link linkend="file-new">New</link> document</para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>P</keycap></keycombo></para></entry> <entry><para><link linkend="file-print">Print</link> </para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>Q</keycap></keycombo></para></entry> <entry><para>Quit - close active copy of editor </para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>R</keycap></keycombo></para></entry> <entry><para><link linkend="edit-replace"> Replace</link></para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>S</keycap></keycombo></para></entry> <entry><para>Save your file</para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>V</keycap></keycombo></para></entry> <entry><para> Paste</para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>X</keycap></keycombo></para></entry> <entry><para>Delete the marked text and copy it to the clipboard </para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;<keycap>Z</keycap></keycombo></para></entry> <entry><para><link linkend="edit-undo">Undo</link></para></entry> </row> <row> <entry><para><keycombo action="simul">&Ctrl;&Shift;<keycap>Z</keycap></keycombo></para></entry> <entry><para><link linkend="edit-redo">Redo</link></para></entry> </row> </tbody> </tgroup> </informaltable> </sect2> </sect1> <sect1 id="kate-mdi"> <title>Working With the &kate; <acronym>MDI</acronym></title> <sect2 id="kate-mdi-overview"> <title>Overview</title> <para>Window, View, Document, Frame, Editor... What are they all in the terminology of &kate;, and how do you get the most out of it? This chapter will explain all of that, and even more.</para> <sect3 id="kate-mdi-overview-mainwindow"> <title>The Main Window</title> <para><indexterm><primary>Main window</primary></indexterm> The &kate; Main Window is a standard &kde; application window, with the addition of side bars containing tool views. It has a menubar with all the common menus, and some more, and a toolbar providing access to commonly used commands.</para> <para>The most important part of the window is the editing area, by default displaying a single text editor component, in which you can work with your documents.</para> <para>The docking capabilities of the window is used for the tool windows of any plugin enabled in the settings dialog.</para> <para>Tool views can be positioned in any sidebar, to move a tool right click its sidebar button and select from the &RMB; menu</para> <para>A tool view can be marked as <emphasis>persistent</emphasis> in the &RMB; menu for its sidebar button. The sidebar can contain more tools at one time so that when a tool is persistent other tools can be shown simultaneously.</para> <para>If a plugin has configuration options you can use the first item in the context menu to open the corresponding page in &kate;'s settings dialog.</para> </sect3> </sect2> <sect2 id="kate-mdi-editor"> <title>The Editor area</title> <para><indexterm><primary>Editing Area</primary></indexterm> &kate; is capable of having more than one document open at the same time, and also of splitting the editing area into any number of frames, similar to how for example &konqueror; or the popular <application>emacs</application> text editor works. This way you can view several documents at the same time, or more instances of the same document, handy for example if your document contains definitions in the top that you want to see often for reference. Or you could view a program source header in one frame, while editing the implementation file in another.</para> <para>When a document is available in more than one editor, changes made in one editor will immediately be reflected in the others as well. This includes changing the text as well as selecting text. Search operations or cursor movement is only reflected in the current editor.</para> <para>It is currently not possible to have more instances of the same document open in the sense that one instance will be edited while the other will not.</para> <para>When splitting an editor into two frames, it is divided into two equally sized frames, both displaying the current document of that editor. The new frame will be at the bottom (in the case of a horizontal split) or at the right (for a vertical split). The new frame gets the focus, which is visualized by the blinking cursor bar in the focused frame.</para> </sect2> </sect1> <sect1 id="fundamentals-using-sessions"> <title>Using Sessions</title> <para>Sessions is how &kate; lets you keep more than one list of files and GUI configuration around. You can have as many named sessions as you want, and you can use unnamed or anonymous sessions for files you want to use only once. Currently &kate; can save the list of open files, and the general window configuration in the session; future versions of &kate; may add more features that can be saved in sessions. With the introduction of sessions, &kate; also allows you to open any number of instances of the application instead of just one as it used to do as the default behavior.</para> <para>Sessions are supported in three areas: <itemizedlist> <listitem><para><link linkend="command-line-options"><emphasis>Command line options</emphasis></link> that lets you select and start sessions when launching kate from the command line.</para> </listitem> <listitem><para><link linkend="sessions-menu"><emphasis>The Sessions menu</emphasis></link> that lets you switch, save, start and manage your sessions.</para></listitem> <listitem><para><link linkend="config-dialog-sessions"><emphasis>Configuration options</emphasis></link> that lets you decide how sessions generally should behave.</para></listitem> </itemizedlist> </para> <para>When starting a new session, the GUI configuration of <guilabel>Default Session</guilabel> is loaded. To save window configuration in the default session, you need to enable saving window configuration in the sessions configuration page of the configuration dialog and then load the default session, set up the window as desired and save the session again.</para> <para>When a named session is loaded, &kate; will display the session name at the start of the window title, which then has the form "<replaceable>Session Name</replaceable>: <replaceable>Document name or &URL;</replaceable> - &kate;"</para> <para>When opening files on the command line with <option>--start <replaceable>name</replaceable></option> or if a session is selected using the session chooser, the specified session is loaded prior to the files specified on the command line. To open files from the command line in a new, unnamed session, configure kate to start a new session as default in the session page of the configuration dialog or use <option>--start</option> with an empty string: <replaceable>''</replaceable>.</para> <!--FIXME still valid for kf5 --> <para>Since &kate; 2.5.1 the <acronym>PID</acronym> of the current instance is exported to the environment variable <envar>KATE_PID</envar>. When opening files from the built in terminal Kate will automatically select the current instance if nothing else is indicated on the command line.</para> </sect1> <sect1 id="fundamentals-getting-help"> <title>Getting Help</title> <sect2> <title>With &kate;</title> <variablelist> <varlistentry> <term>This manual</term> <listitem> <para>Offers detailed documentation on all menu commands, configuration options, tools, dialogs, plugins &etc; as well as descriptions of the &kate; window, the editor and various concepts used in the application.</para> <para>Press <keycap>F1</keycap> or use the <menuchoice><guimenu>Help</guimenu> <guimenuitem>&kate; Handbook</guimenuitem></menuchoice> menu topic to view this manual.</para></listitem> </varlistentry> <varlistentry id="whats-this"> <term>What's This Help</term> <listitem> <para>What's This help offers immediate help with single elements of graphical windows, such as buttons or other window areas.</para> <para>We strive to provide What's This help for any elements for which it makes sense. It is available throughout the configuration dialog, and in many other dialogs as well.</para> <para>To employ What's This help, press <keycombo action="simul">&Shift;<keycap>F1</keycap></keycombo> or use the <menuchoice><guimenu>Help</guimenu><guimenuitem>What's This</guimenuitem></menuchoice> menu item to enable What's This mode. The cursor will turn into an arrow with a question mark, and you can now click any element in the window to read the What's This help for that element, if it is available.</para> </listitem> </varlistentry> <varlistentry> <term>Help Buttons in Dialogs</term> <listitem> <para>Some dialogs have a <guibutton>Help</guibutton> Button. Pressing it will start the &khelpcenter; and open the relevant documentation.</para> </listitem> </varlistentry> </variablelist> </sect2> <sect2> <title>With Your Text Files</title> <para>&kate; does not (yet!) provide any means for reading document related documentation. Depending on the file you are editing, you may find the <link linkend="kate-application-plugin-konsole">Built in Terminal Emulator</link> helpful for viewing related &UNIX; manual pages or info documentation, or you can use &konqueror;.</para> </sect2> <sect2> <title>Articles on &kate;</title> <para>&kate;'s homepage provides some <ulink url="http://kate-editor.org/featured-articles"> Articles and Howtos</ulink> with further information beyond the scope of this handbook.</para> </sect2> </sect1> </chapter>