<para>Схема каталогов &kde; используется как собственно оболочкой &kde;, так и всеми приложениями &kde;. Дерево каталогов &kde; имеет фиксированную структуру. </para>
<para>Как системный администратор, вы можете создать дополнительные деревья каталогов, которые, например, могут использоваться для разных <link linkend="user-profiles">профилей</link></para>
<listitem><para><filename class="directory">/opt/kde3</filename> (специфика &SuSE; - в других дистрибутивах это может быть <filename class="directory">/usr</filename> или <filename class="directory">/usr/kde3</filename>).</para></listitem>
<para>Если у вас установлена утилита администрирования KIOSK версии 0.7 или более поздней, вы можете узнать, какие деревья каталогов использует KDE, выполнив команду <userinput><command>kiosktool-tdedirs</command> <option>--check</option></userinput></para>
<para>При поиске файлов, сам &kde; и все его приложения просматривают все деревья каталогов &kde; (с учётом приоритета). Если файл находится более чем в одном дереве, берётся последний найденный файл. Обычно последним просматривается дерево из домашнего каталога пользователя, т. к. оно имеет наибольший приоритет. Именно в это дерево пользователь имеет право вносить изменения.</para>
<para>Изменения, внесённые пользователем, будут сохранены в файле <filename class="directory">$<envar>HOME</envar>/.trinity/share/mimelnk/text/plain.desktop</filename></para>
<para>Файлы конфигурации обрабатываются по-другому. Параметры считываются из файлов всех уровней. Если один и тот же параметр встречается в нескольких файлах, то его значение определяется файлом с наивысшим приоритетом.</para>
<seg>Переменные различаются, чтобы суперпользователь не мог случайно перезаписать данные из пользовательского каталога $TDEHOME после выполнения команды <command>su</command>.</seg>
<seg>Добавлено в &kde; 3. Может задавать несколько каталогов (разделяются двоеточиями). Если не установлено, используется значение $<envar>TDEDIR</envar></seg>
<para>В предыдущем примере в каталоге <filename class="directory">/opt/kde_staff</filename> содержались дополнительные параметры и приложения для сотрудников. <quote>Профили пользователей</quote> служат для того, чтобы эти каталоги добавлялись только для некоторых явно заданных пользователей. Добавьте в файл <filename>/etc/tderc</filename> строки:</para>
<para>Будет создан профиль <quote>staff</quote>, для которого добавляется дерево каталогов <filename class="directory">/opt/kde_staff</filename>. Учтите, что в &SuSE; &Linux; используется <filename>/etc/kde3rc</filename>, а не <filename>/etc/tderc</filename>. Теперь профиль с этим именем можно назначать пользователям.</para>
<para>Для этого нужно связать пользователей и профили в файле связи, задаваемом в <filename>/etc/tderc</filename>:</para>
<para>Чтобы связать профиль "staff" со всеми пользователями, входящими в группу пользователей &UNIX; "staff_members", добавьте в файл <filename>/etc/kde-user-profile</filename> следующие строки:</para>
<para>Все деревья каталогов, которые использует &kde;, имеют фиксированную структуру. Однако вы можете не беспокоиться о каталогах, которые не относятся ни к одному дереву, или просто не используются. Например, каталоги, в которых хранятся временные файлы, обычно находятся в <filename class="directory">$<envar>TDEHOME</envar></filename>.</para>
<listitem><para>В этом каталоге хранятся компоненты, подключаемые модули, и другие объекты, используемые приложениями &kde; 3.<replaceable>x</replaceable> во время работы.</para></listitem>
<listitem><para>Файлы настроек. Имя файла обычно состоит из имени приложения и букв <quote>rc</quote>. Настройки из файла <filename>kdeglobals</filename> относятся ко всем приложениям.</para></listitem>
<listitem><para>Этот каталог обычно есть только в дереве <filename class="directory">$<envar>TDEHOME</envar></filename>. Он используется для управления сеансом. В конце сеанса приложения &kde; сохраняют здесь данные о своём состоянии. Имя файла включает имя приложения и число. Программа управления сеансом, <command>kcmserver</command>, при сохранении сеанса записывает эти номера в файл <filename>ksmserverrc</filename>.</para></listitem>
<listitem><para>Каталог содержит документацию приложений &kde;. Документы отсортированы по языкам и приложениям. Конечный по иерархии каталог обычно включает как минимум два файла: <filename>index.docbook</filename> -- xml-файл DocBook, и <filename>index.cache.bz2</filename>, который содержит тот же текст, но в формате &HTML;, сжатый <command>bzip2</command>. Файл &HTML; используется программой &khelpcenter;. Если &khelpcenter; не находит файл &HTML;, он генерируется из DocBook автоматически, но этот процесс требует времени.</para>
<listitem><para>В этом каталоге хранятся файлы <literal role="extension">.desktop</literal>, которые описывают типы &MIME;. &kde; использует типы &MIME;, чтобы определять тип файлов.</para>
<listitem><para>Каталог содержит файлы <literal role="extension">.desktop</literal>, которые описывают службы (сервисы). Службы похожи на приложения, однако они обычно запускаются другими приложениями, а не пользователем. В меню &kde; службы отсутствуют.</para>
<listitem><para>Каталог содержит файлы <literal role="extension">.desktop</literal>, которые описывают типы служб. Тип службы обычно представляет какой-либо интерфейс программирования. Приложения и службы включают в свои файлы <literal role="extension">.desktop</literal> информацию о предоставляемых ими службах.</para> </listitem></varlistentry>
<listitem><para>Содержит шаблоны файлов различных типов. Шаблон состоит из файла <literal role="extension">.desktop</literal>, который описывает файл и включает ссылку на файл в подкаталоге <filename class="directory">.source</filename>. Эти шаблоны доступны через подменю <guimenu>Создать новый</guimenu> меню рабочего стола и менеджера файлов. Когда пользователь выбирает какой-либо пункт меню, соответствующий шаблон копируется в текущий каталог.</para>
<para>Существует три каталога, имена которых зависят от имени узла. Обычно в других деревьях содержатся символические ссылки на них. Если эти каталоги не существуют, их можно создать с помощью утилиты <command>lnusertemp</command>:</para>
<para>Так как право записи в <filename class="directory">/tmp</filename> и <filename class="directory">/var/tmp</filename> имеют все пользователи, возможно, что какой-либо из вышеуказанных каталогов уже существует и принадлежит другому пользователю. В этом случае используйте команду <command>lnusertemp</command>. Она создаст новый каталог с альтернативным именем, который будет использоваться KDE.</para>
<title>Файлы конфигурации</title> <para>Формат файлов конфигурации &kde; - обычный текст. Файлы содержат пары ключ-значение, которые отсортированы по группам. Кодировка файлов конфигурации &kde; -- <acronym>UTF</acronym>-8 (позволяет задавать символы, не входящие в <acronym>ASCII</acronym>).</para>
<para>В начале группы опций находится имя группы, заключённое в квадратные скобки. Концом группы является начало другой группы или конец файла. Записи в начале файла, не отнесённые ни к какой группе, являются настройками по умолчанию.</para>
<informalexample><para>Следующий пример является файлом конфигурации, который состоит из двух групп. Первая группа содержит ключи <varname>LargeCursor</varname> и <varname>SingleClick</varname>, вторая -- <varname>Show hidden files</varname> и <varname>Sort by</varname>:</para>
<para>Каждая запись состоит из ключа и значения, разделённых знаком равенства. Имя ключа может содержать пробелы, последующие опции могут быть заключены в квадратные скобки. Часть после знака равенства -- значение опции. Пробелы, обрамляющие знак равенства, и пробелы, следующие за значением, игнорируются. Короче говоря, формат таков:</para>
<informalexample><para>В следующем примере значение опции <varname>Caption</varname> начинается с двух пробелов, а значение <varname>Description</varname> состоит из трёх строк. (Символы новой строки разделяют строки.)</para>
<para>Пустые строки и строки, начинающиеся со знака диеза (<quote>#</quote>), игнорируются. Знак диеза используется для добавления комментариев. Обратите внимание, что при обновлении конфигурационного файла приложением &kde; комментарии <emphasis>не</emphasis> сохраняются.</para>
<para>В подкаталогах <filename class="directory">share/config</filename> различных деревьев каталогов &kde; могут находиться конфигурационные файлы с одинаковыми именами. В этом случае будут использоваться опции из всех файлов. Если один и тот же ключ определён в разных файлах, будет использовано значение из файла, находящегося в каталоге с наивысшим приоритетом. Файлы каталога <filename class="directory">$<envar>TDEHOME</envar></filename> всегда имеют наивысший приоритет. Если один и тот же ключ определён несколько раз в одном файле, используется значение, указанное последним.</para>
<para>Чтобы пользователи не могли изменять настройки, заданные по умолчанию, их можно пометить как неизменяемые. Вы можете запретить изменение одной настройки, группы или всех настроек файла. Чтобы запретить изменение одного ключа, добавьте после его имени символы <userinput>[$i]</userinput>. Пример: <programlisting>Color[$i]=blue
<para>Чтобы запретить изменение всех настроек, входящих в файл, укажите символы <userinput>[$i]</userinput> на отдельной строке. Пример: <programlisting>[$i]
<para>С помощью так называемых <quote>расширений оболочки</quote> вы можете более гибко задавать настройки по умолчанию. При этом значение ключа может содержать значение переменной окружения и/или вывод команды оболочки. Чтобы включить расширения оболочки для одной записи, добавьте символы <token>[$e]</token> в конец имени ключа. Обычно после первого применения расширенная форма записывается в пользовательский файл конфигурации. Чтобы предотвратить это, рекомендуется использовать символы <token>[$ie]</token>, в этом случае пользователь не сможет изменить настройку.</para>
<para>В следующем примере значение записи <varname>Host</varname> определяется выводом программы <command>hostname</command>. Эта настройка заблокирована.</para>
<para>Значение записи <varname>Email</varname> определяется значениями переменных $<envar>USER</envar> и $<envar>HOST</envar>. Когда пользователь <systemitem class="username">joe</systemitem> находится в системе <systemitem class="systemname">joes_host</systemitem>, запись принимает значение <literal>joe@joes_host</literal>. Эта настройка не заблокирована.</para>
<para>Большей части настроек можно ставить в соответствие код языка. В этом случае предпочтение будет отдаваться настройке, связанной с языком, который выбран пользователем. Если выбран язык по умолчанию (американский английский, American English), или нет записи, соответствующей выбранному языку, то используется запись без индекса языка.</para>
<para>В следующем примере значение записи <varname>Caption</varname> зависит от используемого языка. Если пользователь выбрал русский язык (код <literal>ru</literal>), то запись примет значение <quote>Мой заголовок</quote>. Во всех остальных случаях будет использоваться значение <quote>My Caption</quote>.</para>
<para>В этом примере значение записи <varname>Caption</varname> зависит от используемого языка. Если пользователь выбрал русский язык (код <literal>ru</literal>), то запись примет значение <quote>Мой заголовок</quote>. Во всех остальных случаях будет использоваться значение <quote>My Caption</quote>.</para>
<para>Записи конфигурационных файлов полностью нигде не описаны. Ситуация начала меняться в &kde; 3.2. Файлы <filename class="directory">$<envar>TDEDIR</envar>/share/config.kcfg</filename> дают формальное описание настроек файлов конфигурации. Программа &kde; Configuration Editor использует их при возможности.</para>
<para>Всегда запускается от имени суперпользователя (<systemitem class="username">root</systemitem>)! Использует файлы <filename>$<envar>TDEDIR</envar>/share/config/tdmrc</filename> и <filename>/etc/X11/xdm/Xservers</filename>. Последний содержит записи типа</para>
<para>Запуск &kde; начинается с выполнения сценария <filename>starttde</filename>. Обычно его вызывает менеджер дисплея (&tdm;) после авторизации пользователя. В этом сценарии есть две очень важные строки:</para>
<programlisting>LD_BIND_NOW=true tdeinit +kcminit +knotify и kwrapper ksmserver $TDEWM
<para>Первая строка запускает управляющий процесс <command>tdeinit</command>. <command>tdeinit</command> запускает все остальные процессы &kde;. В выводе команды <command>ps <option>aux</option></command> он отображается как <computeroutput>tdeinit: Running...</computeroutput>. Аргументы <command>tdeinit</command> соответствуют именам запущенных процессов. Символ <token>+</token> означает, что <command>tdeinit</command> будет ожидать завершения процесса. <command>tdeinit</command> запускает <command>dcopserver</command>, <command>tdelauncher</command> и <command>kded</command>.</para>
<para>Вторая строка даёт <command>tdeinit</command> команду запустить процесс управления сеансами <command>ksmserver</command>, который обеспечивает работу сеанса. Когда этот процесс завершается, пользователь выходит из системы.</para>
<para>Все фоновые процессы &kde; зависят от пользователя: в отличие от системных демонов они не являются общесистемными. Они являются уникальными как для каждого пользователя, так и для каждого дисплея Х-сервера. Существуют следующие процессы:</para>
<listitem><para>Запуск программ (это <emphasis>не</emphasis> диалог, вызываемый по <keycombo action="simul">&Alt;<keycap>F2</keycap></keycombo>!)</para>
<para>Для подробностей, см. <xref linkend="tdelauncher"/>.</para>
<para><command>tdeinit</command> запускает другие программы &kde;. <command>tdeinit</command> может запускать как обычные программы (бинарные файлы), так и загружаемые модули <command>tdeinit</command> (<acronym>KLM</acronym>). <acronym>KLM</acronym> работают так же, как обычные программы, но могут быть запущены более эффективно. Они находятся в каталоге <filename class="directory">$<envar>TDEDIR</envar>/lib/kde3</filename>.</para>
<para>В выводе команд <command>top</command> и <command>ps</command> они отображаются как <computeroutput><command>tdeinit</command></computeroutput>. Чтобы узнать действительное имя программы, используйте <command>top <option>-c</option></command> или <command>ps <option>aux</option></command>:</para>
<para>Строка <computeroutput>tdeinit: Running...</computeroutput> соответствует основному процессу <command>tdeinit</command>. Остальные перечисленные выше процессы были запущены как <acronym>KLM</acronym>.</para>
<para>При запуске <command>tdeinit</command> вызывает <command>dcopserver</command>, <command>tdelauncher</command>, <command>kded</command> и программы, указанные в командной строке в сценарии <command>starttde</command>. Обычно это <command>kcminit</command> и <command>knotify</command>.</para>
<para><command>dcopserver</command> -- демон, обеспечивающий взаимодействие между процессами (&DCOP;) приложений &kde;. Вы можете управлять &DCOP;, используя программу <command>dcop</command>. &DCOP; является основой всех приложений &kde;.</para>
<para><command>kcminit</command> запускает службы инициализации во время запуска. Они задаются в файлах .desktop приложений или других служб, в строке <varname>X-TDE-Init</varname>:</para>
<para>Службы инициализации обычно используются для применения пользовательских настроек к оборудованию.</para>
<para>Команда <userinput><command>kcminit <option>--list</option></command></userinput> отображает все службы инициализации, <userinput><command>kcminit <replaceable>имя_сервиса</replaceable></command></userinput> - запускает один сервис. Это может быть полезно при устранении проблем, возникающих при запуске.</para>
<para><command>tdelauncher</command> - демон, запускающий службы в среде &kde;. Он тесно взаимодействует с главным процессом <command>tdeinit</command> (запускает через него новые процессы). Чтобы запустить приложения или службы, программы &kde; связываются с <command>tdelauncher</command> через &DCOP;.</para>
<para>Самое распространённое сообщение об ошибке: <computeroutput><errortext> TDELauncher недоступен через DCOP</errortext></computeroutput>. Это значит, что либо <command>dcopserver</command> неправильно работает, либо <command>tdelauncher</command> ошибочно завершился.</para>
<para>Чтобы перезапустить <command>tdelauncher</command>, перезапустите <command>tdeinit</command> из консоли. Перед этим убедитесь, что значения переменных $<envar>HOME</envar>, $<envar>DISPLAY</envar>, $<envar>TDEDIR</envar> и $<envar>TDEDIRS</envar> указаны верно.</para>
<para>Основная задача <command>knotify</command> - заставлять звуковой сервер выполнять звуковые уведомления. Имеются и другие методы уведомления пользователей о чём-либо.</para>
<para><command>ksmserver</command> - менеджер сеансов &kde;. В начале сеанса он вызывает приложения, настроенные на автозапуск (т. е. в каталоге <filename class="directory">$<envar>TDEDIR</envar>/share/autostart</filename> есть соответствующий файл <literal role="extension">.desktop</literal>), и восстанавливает приложения из предыдущего сеанса. Условия автозапуска приложения определяются значением записи <varname>X-TDE-autostart-condition</varname> в файле <literal role="extension">.desktop</literal>.</para>
<para>Это означает, что в файле <filename>ktiprc</filename>, в секции <varname>[TipOfDay]</varname> указано значение переменной <varname>RunOnStart</varname> - <literal>true</literal>. Это значение является значением по умолчанию, если запись отсутствует, то есть <application>ktip</application> по умолчанию запускается автоматически.</para>
<para><command>kdesktop</command>, в свою очередь, автоматически запускает приложения из <filename class="directory">$<envar>TDEHOME</envar>/Autostart</filename>. <command>kdesktop</command> открывает все файлы из этого каталога, включая документы, двоичные файлы и файлы <literal role="extension">.desktop</literal>.</para>
<para>Менеджер сеансов &kde; может восстанавливать предыдущий сеанс. При этом он восстанавливает те приложения в том состоянии, которое существовало в момент сохранения сеанса. Сеансы сохраняются в конфигурационном файле <filename>ksmserverrc</filename>, который содержит ссылки на файлы с данными о состоянии приложений (находятся в каталоге <filename class="directory">$<envar>TDEHOME</envar>/share/config/session</filename>). Информация о состоянии &twin; содержит данные о расположении окон остальных приложений сеанса. </para>
<listitem><para>Если значение <envar>TDEDIRS</envar> не указано, эта переменная должна указывать на корневой каталог установки &kde;. Позволяет &kde; находить собственные данные, такие как пиктограммы, меню и библиотеки.</para>
<listitem><para>Перекрывает <envar>TDEDIR</envar> и позволяет указать несколько каталогов, в которых &kde; будет искать собственные данные. Может оказаться полезной, если вы установили некоторые программы не в каталог &kde;.</para>
<varlistentry><term><envar>$TDEHOME</envar></term><listitem><para>Если она не задана, &kde; использует по умолчанию каталог <filename class="directory">~/.trinity</filename> для хранения личных данных пользователя.</para>
<varlistentry><term>$<envar>TDEROOTHOME</envar></term><listitem><para>Если значение не указано, &kde; использует <filename class="directory">~root/.trinity</filename> для хранения персональных данных пользователя <systemitem class="username">root</systemitem>. Была введена, чтобы предотвратить случайное затирание данных пользователем после выполнения программы от имени <systemitem class="username">root</systemitem> (<command>su</command>).</para>
<varlistentry><term>$<envar>TDEWM</envar></term><listitem><para>Если значение <envar>TDEWM</envar> указано, то сценарий <command>starttde</command> будет использовать в качестве менеджера окон &kde; не &twin;, а указанный менеджер.</para>
<varlistentry><term>$<envar>TDE_LANG</envar></term><listitem><para>Перекрывает настройки языка в &kde;, например, по команде <userinput>TDE_LANG=fr kprogram &</userinput> программа будет запущена во французском переводе (если установлены необходимые файлы).</para>
<varlistentry><term>$<envar>TDE_MULTIHEAD</envar></term><listitem><para>Установите значение <literal>true</literal>, если &kde; выполняется на многопроцессорной системе.</para>
<listitem><para>(начиная с &kde; 3.2.3) Если переменная установлена, то <acronym>TDEIO</acronym>-slave (подчинённые процессы системы ввода-вывода KDE) порождаются самим вызывающим приложением. По умолчанию <acronym>TDEIO</acronym>-slave запускаются посредством <command>tdelauncher</command>/<command>tdeinit</command>. Эта опция может быть полезной, если <acronym>TDEIO</acronym>-slave должны выполняться в той же среде, что и само приложение. Пример - программа <application>Clearcase</application>.</para>
<varlistentry><term>$<envar>TDE_NO_IPV6</envar></term><listitem><para>(начиная с &kde; 3.2.3) Установите эту переменную, чтобы выключить поддержку <acronym>IPv6</acronym> и работу с <acronym>DNS</acronym> через <acronym>IPv6</acronym>.</para>
<varlistentry><term>$<envar>TDE_IS_PRELINKED</envar></term><listitem><para>(начиная с &kde; 3.2.3) Установите эту переменную, чтобы показать системе, что программы и библиотеки &kde; уже предварительно скомпонованы. <command>tdeinit</command> будет выключен.</para>
<varlistentry><term>$<envar>TDE_UTF8_FILENAMES</envar></term><listitem><para>Если переменная установлена, то &kde; предполагает, что имена файлов хранятся в кодировке <acronym>UTF-8</acronym>.</para>
<varlistentry><term>$<envar>TDE_FULL_SESSION</envar></term><listitem><para>(начиная с &kde; 3.2.3) При запуске среды &kde;, переменной автоматически присваивается значение <literal>true</literal>. Используется, например, программой &konqueror;: если переменная установлена (т.е. программа запущена не из другой графической среды, из &tdesu; и т.п.), то программа остаётся в памяти после закрытия, т. к. вероятность того, что её будут использовать в дальнейшем, выше; если не установлена, то память сразу очищается.</para>
<varlistentry><term>$<envar>TDETMP</envar></term><listitem><para>Позволяет установить каталог для временных файлов, отличный от <filename class="directory">/tmp</filename> (обычно <filename class="directory">/tmp/tde-$<envar>USER</envar>/</filename>).</para>
<varlistentry><term>$<envar>XDG_DATA_HOME</envar></term><listitem><para>(начиная с &kde; 3.2) Каталог, в котором будут храниться пользовательские данные. По умолчанию — <filename class="directory">$<envar>HOME</envar>/.local/share</filename></para>
<varlistentry><term>$<envar>XDG_DATA_DIRS</envar></term><listitem><para>(начиная с &kde; 3.2) Определяет порядок каталогов, в которых система будет искать требуемые файлы (после поиска в <filename class="directory">$<envar>XDG_DATA_HOME</envar></filename>). Значение по умолчанию - <literal>/usr/local/share/:/usr/share/</literal>.</para>
<para>&kde; также добавляет каталоги, указанные в переменной $<envar>TDEDIRS</envar> и в данных профиля. Используется для файлов <literal role="extension">.desktop</literal> и <literal role="extension">.directory</literal> (пункты меню KDE). Файлы <literal role="extension">.desktop</literal> система ищет в <filename class="directory">$<envar>XDG_DATA_DIRS</envar>/applications</filename>, <literal role="extension">.directory</literal> - в $XDG_DATA_DIRS/desktop-directories </para>
<varlistentry><term>$<envar>XDG_CONFIG_HOME</envar></term><listitem><para>(&kde; 3.2) Определяет каталог, в котором хранятся пользовательские файлы конфигурации. Значение по умолчанию - <filename class="directory">$<envar>HOME</envar>/.config</filename>.</para>
<varlistentry><term>$<envar>XDG_CONFIG_DIRS</envar></term><listitem><para>(&kde; 3.2) Определяет порядок каталогов, в которых система ищет пользовательские файлы конфигурации (в дополнение к $<envar>XDG_CONFIG_HOME</envar>). Значение по умолчанию - <filename class="directory">/etc/xdg</filename>. &kde; также добавляет каталоги, перечисленные в $<envar>TDEDIRS</envar> и в данных профиля. Используется файлами <literal role="extension">.menu</literal> из <filename class="directory">$<envar>XDG_CONFIG_DIRS</envar>/menus</filename>. </para>
<para><command>tdeinit</command> запускает другие программы &kde;. <command>tdeinit</command> может запускать как обычные программы (бинарные файлы), так и специальные загружаемые модули <command>tdeinit</command> (<acronym>KLM</acronym>). <acronym>KLM</acronym> работают так же, как обычные программы, но могут быть запущены более эффективно. Они находятся в каталоге <filename class="directory">$<envar>TDEDIR</envar>/lib/kde3</filename>.</para>
<para>В выводе команд <command>top</command> и <command>ps</command> они отображаются как <computeroutput><command>tdeinit</command></computeroutput>. Чтобы узнать действительное имя программы, используйте <command>top <option>-c</option></command> или <command>ps <option>aux</option></command>:</para>
<screen><prompt>%</prompt> <userinput><command>ps aux | grep bastian</command></userinput>
<para>Чтобы создать ссылку на веб-сайт в виде файла <literal role="extension">.desktop</literal>, используйте меню рабочего стола: <menuchoice><guimenu>Создать</guimenu><guimenuitem>Адрес Интернет...</guimenuitem></menuchoice>. Смените значок, используя диалоговое окно <guilabel>Свойства</guilabel>. В результате получится файл <literal role="extension">.desktop</literal> вида: <programlisting>[Desktop Entry]
<para>Чтобы создать ссылку на приложение в виде файла <literal role="extension">.desktop</literal>: Меню рабочего стола - <menuchoice><guimenu>Создать</guimenu><guisubmenu>Файл</guisubmenu><guimenuitem>Ссылка на приложение</guimenuitem></menuchoice>. Укажите детали в появившемся диалоговом окне. Более простой способ - перетащите на рабочий стол пункт меню &kde; и выберите Копировать сюда или Создать ссылку (создаёт символьную ссылку).</para>
<listitem><para>Пиктограмма; если приложению &kde; передаётся опция <option>--icon</option>, то в панели задач оно будет отображать пиктограмму, переданную через переменную <varname>Icon</varname>= .</para>
<listitem><para>Заголовок; если приложению &kde; передаётся опция <option>--caption</option>, то в панели задач оно будет отображать заголовок, переданный через переменную <varname>Name</varname>= .</para>
<para>Чтобы создать ссылку на приложение, используйте файл <literal role="extension">.desktop</literal> или меню рабочего стола Создать -> Устройство </para>
<listitem><para>Зависит от дистрибутива. В SUSE Linux значки темы starttde.theme копируются из <filename class="directory">/opt/kde3/share/config/SuSE/default/</filename></para></listitem>
<para>Стандарт меню для &kde; 3.2 описан в <ulink url="http://freedesktop.org/Standards/menu-spec/">http://freedesktop.org/Standards/menu-spec/</ulink></para>
<para>Файлы <literal role="extension">.menu</literal> описывают структуру меню. Они хранятся в <filename class="directory">$<envar>TDEDIR</envar>/etc/xdg/menus</filename> и <filename class="directory">/etc/xdg/menus</filename> (общесистемное меню) - задаётся $<envar>XDG_CONFIG_DIRS</envar>. В каталоге <filename class="directory">$<envar>HOME</envar>/.config/menus</filename> хранятся пользовательские настройки структуры меню - задаётся $<envar>XDG_CONFIG_HOME</envar>. Дальнейшая информация находится на странице <ulink url="http://www.freedesktop.org/Standards/basedir-spec">http://www.freedesktop.org/Standards/basedir-spec</ulink>.</para>
<para>Файлы <literal role="extension">.desktop</literal> описывают приложения. Они хранятся в <filename class="directory">$<envar>TDEDIR</envar>/share/applications</filename>, <filename class="directory">/usr/share/applications</filename>, <filename class="directory">/usr/local/share/applications</filename>. Они относятся ко всем пользователям. Определяется переменной $<envar>XDG_DATA_DIRS</envar>.</para>
<para>Каталог <filename class="directory">$<envar>HOME</envar>/.local/applications</filename> содержит пользовательские файлы <literal role="extension">.desktop</literal> и пользовательские настройки. Каталоги определяются переменной $<envar>XDG_DATA_HOME</envar>. Дальнейшая информация находится на странице <ulink url="http://www.freedesktop.org/Standards/basedir-spec">http://www.freedesktop.org/Standards/basedir-spec</ulink></para>
<para>Файлы <literal role="extension">.directory</literal> описывают подменю. Они хранятся в каталогах <filename class="directory">$<envar>TDEDIR</envar>/share/desktop-directories</filename>, <filename class="directory">/usr/share/desktop-directories</filename>, <filename class="directory">/usr/local/share/desktop-directories</filename> и относятся ко всем пользователям. Каталоги определяются переменной $<envar>XDG_DATA_DIRS</envar>. Пользовательские настройки хранятся в <filename class="directory">$<envar>HOME</envar>/.local/desktop-directories</filename>. Каталог задаётся переменной $<envar>XDG_DATA_HOME</envar>. Дальнейшая информация находится на странице <ulink url="http://www.freedesktop.org/Standards/basedir-spec">http://www.freedesktop.org/Standards/basedir-spec</ulink></para>
<para><literal>Art</literal> - внутреннее имя меню. Запись <filename>suse-edutainment-art.directory</filename> определяет имя и пиктограмму этого меню. Меню включает все приложения, которые были отнесены к категории <literal>X-SuSE-Art</literal>. Примеры категорий: <programlisting>Categories=Qt;TDE;Education;X-SuSE-Art
</programlisting></para>
<para>Запись <filename>suse-edutainment-art.directory</filename> определяет имя и пиктограмму этого меню: <programlisting>[Desktop Entry]
<para>Приложения, <emphasis>не</emphasis> входящие в меню, <emphasis>не</emphasis> могут быть ассоциированы с файлами и не учитываются другими приложениями. Если вы удаляете приложение из меню, &kde; считает, что вы не хотите его использовать.</para>
<para>Если вы не хотите, чтобы приложение отображалось в меню, поместите его в меню <filename>.hidden</filename> или в отдельное меню с включённой опцией <programlisting>
<para><filename class="directory">$<envar>TDEDIR</envar>/etc/xdg/menus/applications-merged/</filename> содержит файл <filename>kde-essential.menu</filename>. Он включает некоторые важные меню, которые не отображаются в главном меню &kde;: <itemizedlist>
<listitem><para>Центр управления имеет скрытое меню Настройка. Его содержимое определяется файлом <filename>kde-settings.menu</filename>, значок и имя - файлом <filename>kde-settings.directory</filename></para>
<listitem><para>Центр информации имеет скрытое меню Информация. Его содержимое определяется файлом <filename>kde-information.menu</filename>, значок и имя - файлом <filename>kde-information.directory</filename>.</para>
<listitem><para>Хранители экрана имеет скрытое меню Система/Хранители экрана. Его содержимое определяется файлом <filename>kde-screensavers.menu</filename>, значок и имя - файлом <filename>kde-system-screensavers.directory</filename>. <filename>$<envar>TDEDIR</envar>/share/desktop-directories/kde-system-screensavers.directory</filename> содержит: <programlisting>NoDisplay=true
<para>&kde; продолжает поддерживать меню в старом стиле, содержимое которых определяется структурой каталогов <filename class="directory">$<envar>TDEDIR</envar>/share/applnk</filename> (для всех пользователей) и <filename class="directory">$<envar>HOME</envar>/.trinity/share/applnk</filename> (для каждого пользователя в отдельности). Если в файле <literal role="extension">.desktop</literal> указана опция <varname>Categories</varname>= , то просматриваемые каталоги определяются её значением.</para>
<para><application>KSycoca</application> кэширует структуру меню и информацию о всех доступных приложениях. Вы можете создать базу данных заново, выполнив команду <userinput><command>tdebuildsycoca</command></userinput>. База данных находится в <filename class="directory">/var/tmp/tdecache-${<envar>USER</envar>}/tdesycoca</filename>. Она автоматически обновляется <application>KDED</application>, проверяется во время запуска сеанса. В течение сеанса <application>KDED</application> отслеживает изменения.</para>
<para>Чтобы выключить отслеживание изменений (если используется файловая система NFS, оно может приводить к ошибкам), добавьте в файл <filename>kdedrc</filename> следующие строки: <programlisting>[General]
<para>&kmenuedit; изменяет настройки меню для одного пользователя. Изменения в структуре меню сохраняются в файле <filename>~/.config/menus/applications-tdemenuedit.menu</filename>, изменения в наборе приложений - в <filename class="directory">~/.local/share/applications/</filename>, изменения подменю (имена, значки) - в <filename class="directory">~/.local/share/desktop-directories/</filename>. Утилита администратора KIOSK использует &kmenuedit; и копирует внесённые изменения в профиль пользователя или в общесистемные настройки. </para>
<para>По умолчанию панель содержит следующие аплеты: <itemizedlist> <listitem><para>Переключение рабочих столов</para></listitem> <listitem><para>Панель задач</para></listitem> <listitem><para>Системный лоток</para></listitem> <listitem><para>Часы</para></listitem> </itemizedlist> и следующие специальные кнопки: <itemizedlist>
<listitem><para>Меню &kde;</para></listitem>
<listitem><para>Кнопка рабочего стола</para></listitem>
<para>Связи файлов ставят в соответствие типу файлов одно или несколько приложений. Тип файла определяется его типом &MIME;. Типы &MIME;, известные &kde;, хранятся в <filename class="directory">$<envar>TDEDIR</envar>/share/mimelnk</filename>. Файл <literal role="extension">.desktop</literal> каждого приложения содержит список типов &MIME;, которые это приложение поддерживает.</para>
<para>Оба приложения могут открывать файлы типа image/gif. Какое будет использовано для того, чтобы открывать файлы <literal role="extension">.gif</literal>?</para>
<para>Пользователь может изменять связи файлов в Центре управления. Изменения хранятся в <filename>$<envar>HOME</envar>/.trinity/share/config/profilerc</filename>. Чтобы применить настройки к нескольким пользователям, скопируйте этот файл в личные файлы настроек каждого пользователя или в глобальный каталог настроек &kde;.</para>
<para>Запрещая изменение некоторых настроек, администратор может установить настройки системы по умолчанию, которые пользователь не сможет изменить.</para>
<note><para>Не все приложения поддерживают неизменяемые настройки. Даже если пользователь не имеет возможности вносить постоянные изменения в настройки, он может изменить их на время через окно настроек приложения.</para></note>
<para>Приложения &kde; основаны на концепции действий. Действия могут быть запущены несколькими способами, обычно через меню приложения, панель управления или комбинацию клавиш. Пример действия - <action>сохранить документ</action>. Если вы знаете внутреннее имя действия, вы можете запретить его. Пункты, соответствующие запрещённым действиям, не отображаются в меню и панелях инструментов. Внутреннее имя действия <action>сохранить документ</action> - <option>action/file_save</option>. Вы также можете применять более абстрактные запреты, чтобы ограничить функции, которые не соответствуют только одному действию. Например, запрет <option>shell_access</option> отключает все функции, которые предоставляют пользователю доступ к оболочке &UNIX;.</para>
<title>Ограничение доступа пользователей к оболочкам</title>
<para>Чтобы запретить доступ пользователя к оболочке, следует запретить действие <option>shell_access</option>. Добавьте в файл <filename>kdeglobals</filename> следующие строки: </para>
<para>Полная документация по доступным действиям находится на странице <ulink url="http://www.kde.org/areas/sysadmin/">http://www.kde.org/areas/sysadmin/</ulink>.</para>
<para>Правила проверяются в том порядке, в каком они перечислены. Возможность доступа к &URL; определяет последнее правило, которое к нему применимо.</para>
<callout arearefs="url_rule1"><para>Правило <option>rule_1</option> запрещает открывать адреса http и https</para></callout>
<callout arearefs="url_rule2"><para>Правило <option>rule_2</option> позволяет открывать адреса http и https в домене <systemitem class="domainname">.ourcompany.com</systemitem>. Обратите внимание, что шаблон <token>*</token> можно применять только в начале домена.</para></callout>
<para>Следующие правила запрещают пользователю просматривать каталоги локальной файловой системы вне его домашнего каталога ($<envar>HOME</envar>):</para>
<callout arearefs="home_rule1"><para>Правило <option>rule_1</option> запрещает получать список файлов любого локального каталога</para></callout>
<callout arearefs="home_rule2"><para>Правило <option>rule_2</option> позволяет получать список файлов любого подкаталога папки $<envar>HOME</envar>.</para></callout>
<para>Переменные $<envar>HOME</envar> и $<envar>TMP</envar> соответствуют домашнему каталогу пользователя и каталогу временных файлов &kde; для этого пользователя, например, <filename class="directory">/tmp/tde-bastian</filename></para>
<para>Следующие правила запрещают пользователю открывать локальные файлы вне каталога $<envar>HOME</envar>:</para>
<callout arearefs="local_rule1"><para>Правило <option>rule_1</option> запрещает открывать любой локальный файл</para></callout>
<callout arearefs="local_rule2"><para>Правило <option>rule_2</option> разрешает открывать файлы каталога $<envar>HOME</envar>.</para></callout>
<callout arearefs="local_rule3"><para>Правило <option>rule_3</option> позволяет открывать файлы пользовательского каталога временных файлов &kde;. Это необходимо для некоторых приложений &kde;, которые вначале загружают файл в этот каталог, а потом открывают его.</para></callout>
<para>Настройки перенаправления определяют, могут ли документы перенаправлять пользователя, автоматически или через гиперссылку, по другому адресу. Правила по умолчанию обеспечивают некоторую безопасность. Например, документы, расположенные в Интернете, не могут ссылаться на локальные файлы компьютера.</para>
<para>Например, если мы хотим разрешить документам сервера <systemitem class="systemname">www.mycompany.com</systemitem>, расположенного в локальной сети, ссылаться на локальные файлы, мы можем добавить следующее правило:</para>
<para>Информация о протоколах хранится в файлах <literal role="extension">*.protocol</literal>, каталог <filename class="directory">$<envar>TDEDIR</envar>/share/services</filename>.</para>
<para><option>Class</option>= определяет группу, к которой принадлежит протокол, например: <userinput><command>grep</command> <option>Class=</option> <filename>$<envar>TDEDIR</envar>/share/services/*.protocol</filename></userinput></para>
<para>Модули настройки &kde; позволяют настроить различные аспекты окружения &kde;. Модули настройки отображаются в Центре управления и/или в диалоговом окне настройки приложения.</para>
<para>Модуль настройки прокси отображается как в Центре управления, так и в диалоговом окне <guilabel>Настроить Konqueror</guilabel> приложения &konqueror;</para>
<para>Отдельные модули настройки можно запустить, используя команду <command>tdecmshell</command> <replaceable>module</replaceable></para>
<para>Модулям Центра управления обычно соответствуют файлы <literal role="extension">.desktop</literal> из каталога <filename class="directory">$<envar>TDEDIR</envar>/share/applications/kde</filename>. Они отсортированы по категориям в скрытом меню <guimenu>Настройка-Модули</guimenu>, которому соответствует файл <filename>kde-settings.menu</filename> (подключается файлом <filename>kde-essential.menu</filename>)</para>
<para>Модулям, зависящим от приложения, обычно соответствует файл <literal role="extension">.desktop</literal> из каталога <filename>$<envar>TDEDIR</envar>/share/applnk/.hidden</filename>, который соответствует скрытому меню .hidden (подключается в результате <markup><KDELegacyDirs/></markup>)</para>
<listitem><para>В &kde; 3.3 можно редактировать модули Центра управления, используя <application>kcontroledit</application>. <application>kcontroledit</application> работает как <application>kmenuedit</application>, изменения относятся только к одному пользователю. Чтобы внести изменения для всех пользователей, используйте <application>kiosktool</application>.</para></listitem>
<para>Данная функциональность позволяет удалённым пользователям просматривать содержимое вашего экрана и, возможно, управлять вашим компьютером. Для этого необходимо послать пользователю приглашение, возможно защищенное паролем. Это полезно для технической поддержки или для демонстрации какой-либо процедуры.</para>
<para>При отправке приглашения, создаётся единоразовый пароль, по умолчанию действительный только на одно успешное соединение. Его действие также истекает через час после отсутствия попыток (первого) соединения.</para>
<para>Входящие соединения обрабатываются модулем kinetd kded. С помощью команды <userinput><command>dcop</command> kded kinetd services</userinput> можно увидеть, запущен ли он. &krfb; по умолчанию ожидает соединений на порт 5900. При входящем соединении потребуется подтверждение.</para>
<para>Desktop COmmunication Protocol, <acronym>DCOP</acronym> – - это простой механизм взаимодействия процессов. <acronym>DCOP</acronym> служит для взаимодействия с уже работающими программами. В &kde; входят две программы для работы с <acronym>DCOP</acronym>: <application>dcop</application>, утилита командной строки и <application>kdcop</application> - её графический интерфейс. </para>
<para>О работе с командой <command>dcop</command>: </para>
<para>В качестве аргумента для приложения и объекта допускается символ * в качестве шаблона. <screen><prompt>% </prompt><userinput><command>dcop</command><option> kon*</option></userinput>
<para>Сохраняет параметр, определяющий, нужно ли показывать диалог ещё раз, в файле <filename>$<envar>TDEHOME</envar>/share/config/myfile</filename>, дописывая в него следующие строки:</para>
<para>Вместо аргумента <option>--msgbox</option> можно применять <option>--sorry</option> и <option>--error</option>, когда это необходимо. Например, <command>kdialog</command> <option>--sorry 'Сеть недоступна'</option> или <command>kdialog</command> <option>--error 'Не удаётся открыть почтовый ящик'</option>.</para>
<para>Можно также создавать окна сообщений с кнопками Да и Нет.</para>
<screen><command>kdialog</command> <option>--yesno 'Подключиться к Internet?'</option> <command>echo</command> <returnvalue>$?</returnvalue></screen>
<para>Обязательно сохраните результат в переменной, если он вам ещё будет нужен. Следующая команда присвоит значение $?. Здесь также допускается применять <option>--dontagain</option>, чтобы запомнить выбор пользователя и больше не задавать ему этот вопрос.</para>
<para>Результат выводится в stdout. Его можно сохранить в переменной: <userinput>name=$(kdialog --inputbox "Введите имя:" "ваше-имя")</userinput>. Последний аргумент указывать необязательно, он служит как начальное значение в диалоге.</para>
<screen><userinput><varname>city</varname>=$(<command>kdialog</command> <option>--menu "Выберите город" a Москва b Самара c Киев d Рига</option>)</userinput></screen>
<para><varname>$city</varname> вернёт <returnvalue>a</returnvalue>, <returnvalue>b</returnvalue>, <returnvalue>c</returnvalue> или <returnvalue>d</returnvalue>.</para>
<screen><userinput><varname>city</varname>=$(<command>kdialog</command> <option>--checklist "Выберите города" a Москва off b Самара on c Киев on d Рига off</option>)</userinput></screen>
<para>Будут заранее выбраны Самара и Киев. Результат выбора этих городов: <returnvalue>"b"</returnvalue> <returnvalue>"c"</returnvalue>.</para>
<para>С опцией <option>--separate-output</option> <returnvalue>b</returnvalue> и <returnvalue>c</returnvalue> будут выведены с новой строки, при этом обработать результат будет проще.</para>