Anforderungen  |   Konzepte  |   Entwurf  |   Entwicklung  |   Qualitätssicherung  |   Lebenszyklus  |   Steuerung
 
 
 
 


SSL Customization.lyx   Sprache: unbekannt

 
Spracherkennung für: .lyx vermutete Sprache: Unknown {[0] [0] [0]} [Methode: Schwerpunktbildung, einfache Gewichte, sechs Dimensionen]

#This file was created by <mike> Thu Jan 28 23:57:44 1999
#LyX 1.0 (C) 1995-1998 Matthias Ettrich and the LyX Team
\lyxformat 2.15
\textclass book
\begin_preamble
\usepackage{multicol}
\IfFileExists{isolatin.def}
{\usepackage[isolatin]{inputenc}}
{\usepackage[latin1]{inputenc}}
\end_preamble
\language default
\inputencoding default
\fontscheme default
\graphics none
\paperfontsize default
\spacing single 
\papersize letterpaper
\paperpackage a4
\use_geometry 0
\use_amsmath 0
\paperorientation portrait
\secnumdepth 3
\tocdepth 3
\paragraph_separation indent
\defskip medskip
\quotes_language english
\quotes_times 2
\papercolumns 1
\papersides 2
\paperpagestyle headings

\layout Title

Customizing LyX: Features for the Advanced User
\layout Author

by the LyX Team
\layout Standard


\begin_inset LatexCommand \tableofcontents

\end_inset 


\layout Chapter

Introduction
\layout Standard

This manual covers the customization features present in LyX.
 While it is not yet 100% complete, most of the basics and a few advanced
 features are covered.
\layout Chapter

LyX configuration files
\layout Standard


\begin_inset LatexCommand \label{chap:config}

\end_inset 

This chapter aims at helping you to find your way through LyX configuration
 files.
 Before continuing to read this chapter, you should find out where your
 LyX library directory is by using 
\family sans 
\bar under 
H
\bar default 
elp->
\bar under 
V
\bar default 
ersion
\family default 
.
 This directory is the place where LyX places its system-wide configuration
 files, and we will simply name it 
\family typewriter 
LyXDir
\family default 
 in the remainder of this document.
 
\layout Section

What's in 
\family typewriter 
LyXDir
\family default 
?
\layout Standard

Among the files and directories that you will find in a typical LyX installation
, the most interesting one is 
\family typewriter 
\series medium 
lyxrc
\family default 
\series default 
, which is the main configuration file, as described in Chapter
\protected_separator 

\begin_inset LatexCommand \ref{chap:lyxrc}

\end_inset 

.
\layout Standard

Most customization that you might want to do to LyX are available through
 this file.
 However, many other inner aspects of LyX can be customized by modifying
 the other files in 
\family typewriter 
LyXDir
\family default 
.
 They fall in different categories, described in the following subsections.
\layout Subsection

Automatically generated files
\layout Standard

These files are generated when you configure LyX.
 They contain various default values that are guessed by inspection.
 In general, it is not a good idea to modify them, since they might be overwritt
en at any time.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
lyxrc.defaults
\family default 
\series default 
 is read just before 
\family typewriter 
lyxrc
\family default 
.
 It contains defaults for various commands.
 If you don't like some values given there, you can override them in 
\family typewriter 
lyxrc
\family default 
.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
packages.lst
\family default 
\series default 
 contains the list of packages that have been recognized by LyX.
 It is currently unused by the LyX program itself, but the information extracted
, and more, is made available with 
\family sans 
\bar under 
H
\bar default 
elp->L
\bar under 
a
\bar default 
TeX
\protected_separator 
Configuration
\family default 
.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
textclass.lst
\family default 
\series default 
 is the list of textclasses that have been found in your 
\family typewriter 
layout/
\family default 
 directory, along with the associated LaTeX document class and their description.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
doc/LaTeXConfig.lyx
\family default 
 is automatically generated during configuration from the file 
\family typewriter 
LaTeXConfig.lyx.in
\family default 
.
 Each string of the form 
\begin_inset Quotes eld
\end_inset 

@chk_foo@
\begin_inset Quotes erd
\end_inset 

 will be replaced by 
\begin_inset Quotes eld
\end_inset 

yes
\begin_inset Quotes erd
\end_inset 

 or 
\begin_inset Quotes eld
\end_inset 

no
\begin_inset Quotes erd
\end_inset 

 depending on whether the package 
\family typewriter 
foo
\family default 
 has been found.
\layout Subsection

Directories
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
bind/
\family default 
\series default 
 this directory contains files with the extension .bind that define the keybindin
gs used in LyX (see section
\protected_separator 

\begin_inset LatexCommand \ref{sec:bindings}

\end_inset 

).
 If there exists an internationalized version of the bindfile named 
\family typewriter 
$LANG_xxx.bind
\family default 
, that will be used first.
 See Chapter
\protected_separator 

\begin_inset LatexCommand \ref{chap:i18n}

\end_inset 

, and section 
\begin_inset LatexCommand \ref{sec:bindings}

\end_inset 

for details.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
clipart/
\family default 
\series default 
 contains Postscript� pictures that can be included in documents.
 
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
doc/
\family default 
\series default 
 contains LyX documentation files (including the one you are currently reading).
 The file 
\family typewriter 
LaTeXConfig.lyx
\family default 
 deserves special attention, as noted above.
 If there exists an internationalized version of the help-document with
 
\family typewriter 
$LANG_
\family default 
 prepended to the name, that will be used first.
 See Chapter
\protected_separator 

\begin_inset LatexCommand \ref{chap:i18n}

\end_inset 

 for details.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
examples/
\family default 
\series default 
 contains example files that explain how to use some features.
 In the file browser, press the 
\family sans 
Examples
\family default 
 button to get there.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
images/
\family default 
 contains image files that are used by the 
\family sans 
Itemize
\protected_separator 
Bullet
\protected_separator 
Selection
\family default 
 popup.
 It is planned that this directory will be used in future releases to support
 custom icons and banners.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
kbd/
\family default 
\series default 
 contains keyboard keymapping files.
 See Chapter
\protected_separator 

\begin_inset LatexCommand \ref{sec:keymap}

\end_inset 

 for details.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
layouts/
\family default 
\series default 
 contains the textclass files described in Chapter
\protected_separator 

\begin_inset LatexCommand \ref{chap:textclass}

\end_inset 

.
\layout Subsection

Files you don't want to modify
\layout Standard

These files are used internally by LyX and you generally do not need to
 modify them unless you are a developer.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
CREDITS
\family default 
\series default 
 this file contains the list of LyX developers.
 The contents are displayed with the menu entry 
\family sans 
\bar under 
H
\bar default 
elp->Cr
\bar under 
e
\bar default 
dits
\family default 
.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
chkconfig.ltx
\family default 
\series default 
 this is a LaTeX script used during the configuration process.
 Do not run directly.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\series medium 
configure
\family default 
\series default 
 this is the script that is used to re-configure LyX.
 It creates configuration files in the directory it was run from.
\layout Section

Your local configuration directory
\layout Standard

Even if you are using LyX as an unprivileged user, you might want to change
 LyX configuration for your own use.
 One new feature of LyX 0.12 was the introduction of a 
\family typewriter 
UserDir
\family default 
 directory that contains all your personal configuration files.
 This is the directory described as 
\begin_inset Quotes eld
\end_inset 

user directory
\begin_inset Quotes erd
\end_inset 

 in 
\family sans 
\bar under 
H
\bar default 
elp->
\bar under 
V
\bar default 
ersion
\family default 
.
 This directory is used as a mirror of 
\family typewriter 
LyXDir
\family default 
, which means that every file in 
\family typewriter 
UserDir
\family default 
 is a replacement for the corresponding file in 
\family typewriter 
LyXDir
\family default 
.
 Any configuration file described in the above sections can be placed either
 in the system-wide directory, in which case it will affect all users, or
 in your local directory for your own use.
\layout Standard

To make things clearer, let's provide a few examples:
\layout Itemize

when you reconfigure using 
\family sans 
\bar under 
O
\bar default 
ptions->
\bar under 
R
\bar default 
econfigure
\family default 
, LyX runs 
\family typewriter 
configure
\family default 
 and the resulting files are written in your local configuration directory
 (see section
\protected_separator 

\begin_inset LatexCommand \ref{sec:autodetected}

\end_inset 

 to have a list of the 
\family typewriter 
lyxrc
\family default 
 settings affected by this section).
 This means that any additional textclass file that you might have added
 in 
\family typewriter 
UserDir/layouts
\family default 
 will be added to the list of classes in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
D
\bar default 
ocument
\family default 
 popup.
\layout Itemize

Similarly, if you have installed some LaTeX document classes in your home
 directory, that LaTeX can find with your 
\family typewriter 
TEXINPUTS
\family default 
 path, they will show up in your list of text classes.
\begin_float footnote 
\layout Standard

as long as LyX or yourself have a 
\family typewriter 
.layout
\family default 
 file for it, of course.
\end_float 
\layout Itemize

If you get some updated documentation from LyX ftp site and cannot install
 it because you do not have sysadmin rights on your system, you can just
 copy the files in 
\family typewriter 
UserDir/doc/
\family default 
 and the items in the 
\family sans 
\bar under 
H
\bar default 
elp
\family default 
 menu will open them!
\layout Chapter

The 
\family typewriter 
lyxrc
\family default 
 File
\begin_inset LatexCommand \label{chap:lyxrc}

\end_inset 


\layout Section

Customization with the 
\family typewriter 
lyxrc
\family default 
-file
\layout Standard

LyX will read the file 
\family typewriter 
lyxrc
\family default 
, when it is invoked.
 This file include various settings that are described below.
 Note that lines beginning with a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
#
\family default 

\begin_inset Quotes erd
\end_inset 

 are just comments and not interpreted.
\layout Standard

According to the file loading scheme described on page
\protected_separator 

\begin_inset LatexCommand \pageref{chap:config}

\end_inset 

, if
\family typewriter 
 UserDir/lyxrc
\family default 
 doesn't exist, LyX loads the system default file 
\family typewriter 
LyXDir/lyxrc
\family default 
 instead.
 Only system administrators should edit the global 
\family typewriter 
lyxrc
\family default 
 file.
 To design your own, copy 
\family typewriter 
lyxrc
\family default 
 to 
\family typewriter 
UserDir/
\family default 
 and use it as a template.
\layout Section

Bindings
\begin_inset LatexCommand \label{sec:bindings}

\end_inset 


\layout Standard

command: 
\family typewriter 

\backslash 
bind
\family default 

\newline 
format: 
\family typewriter 

\backslash 
bind <key combination> <lyx-function>
\layout Standard


\family typewriter 

\backslash 
bind
\family default 
 is used to, well, bind a function to a key.
 Both key combination and lyx-function (including any arguments) must be
 enclosed in "double quotes".
 Look in the bind files in 
\family typewriter 
(LyXDir/bind/)
\family default 
 for examples on how to use this command.
 All the LyX functions are listed in the 
\emph on 
Reference Guide
\emph default 
.
\layout Standard

LyX supports internationalization of the user interface (se Chapter
\protected_separator 

\begin_inset LatexCommand \ref{chap:i18n}

\end_inset 

).
 If your 
\emph on 
locale
\emph default 
 is set, with the environment variable 
\family typewriter 
$LANG
\family default 
, LyX will try to use bindfiles by prepending 
\family typewriter 
$LANG_
\family default 
 to their name.
 For example, you can put in your personal 
\family typewriter 
bind/
\family default 
 directory a translated copy of some bind file.
\layout Section

Toolbar
\layout Standard

The toolbar is also configurable from 
\family typewriter 
lyxrc
\family default 
.
 This is done inside a 
\emph on 
toolbar section
\emph default 
 surrounded by 
\family typewriter 

\backslash 
begin_toolbar
\family default 
 and 
\family typewriter 

\backslash 
end_toolbar
\family default 
 commands.
 The only legal commands inside this section are 
\family typewriter 

\backslash 
add
\family default 

\family typewriter 

\backslash 
layouts
\family default 
, and 
\family typewriter 

\backslash 
separator
\family default 
.
\layout Standard


\family typewriter 

\backslash 
add
\family default 
 has this format: 
\family typewriter 

\backslash 
add <lyx-function> [<parameters>]
\family default 
 (the parameters are optional) and adds a button for the specified function.
 LyX has icons for a small subset of the functions, but you can bind any
 function.
 If you draw some nice icons, you can submit them to the LyX team, and we'll
 provide support for them in a future release.
 
\layout Standard

The 
\family typewriter 

\backslash 
layouts
\family default 
 command adds the paragraph environment drop-down list.
 The 
\family typewriter 

\backslash 
separator
\family default 
 command is used to add a little space between entries, and should be used
 to organize the toolbar in a logical way.
 Have a look in your 
\family typewriter 
lyxrc
\family default 
 file to see how the standard toolbar could be declared.
\layout Section

On-screen Previewing
\layout Standard

In addition to viewing documents within LyX, you can also preview your document
 in the form in which it will appear on the paper output.
 By default, LyX uses 
\family typewriter 
xdvi
\family default 
 for on-screen previewing of .
\family typewriter 
dvi
\family default 
 files (the output from LaTeX).
\layout Standard

LyX can also use 
\family typewriter 
dvips
\family default 
 to convert 
\family typewriter 
.dvi
\family default 
 files to .
\family typewriter 
ps
\family default 
 files and 
\family typewriter 
ghostview
\family default 
 for previewing.
 A number of options in the 
\family typewriter 
lyxrc
\family default 
 file can be used to customize these settings.
\layout Description


\family typewriter 
\series medium 

\backslash 
view_dvi_command
\family default 
\series default 
 Allows you to replace 
\family typewriter 
xdvi
\family default 
 by some other 
\family typewriter 
.dvi
\family default 
 previewer, or to supply arguments to 
\family typewriter 
xdvi
\family default 
.
\layout Description


\family typewriter 
\series medium 

\backslash 
view_ps_command
\family default 
\series default 
 Allows you to replace 
\family typewriter 
ghostview
\family default 
 with your preferred Post
\latex latex 

\backslash 
-
\latex default 
Script previewer, or to provide arguments to 
\family typewriter 
ghostview
\family default 
.
\layout Description


\family typewriter 
\series medium 

\backslash 
view_pspic_command
\family default 
\series default 
 Defines the program used to do full-screen previews of PostScript figures.
 You can not use this setting to include any options.
\layout Description


\family typewriter 
\series medium 

\backslash 
ps_command
\family default 
\series default 
 Defines the program to use to embed PostScript figures within a LyX document.
 You can not include any options.
 If you define this to the empty string (""), LyX will not render any figures.
 This can be useful if you have a slow machine and work with lots of figures.
\layout Description


\family typewriter 
\series medium 

\backslash 
default_papersize
\family default 
\series default 
 Sets the paper size used by LyX when previewing documents.
 The default value is USletter paper.
 If LaTeX is configured to use a different default size at your site, you
 may wish to change this setting.
\layout Section

Printer
\layout Standard

There are a bunch of commands that help you setup the printer command from
 LyX.
 Normally, you only need to use a few of them, but all are provided for
 completeness.
\layout Description


\family typewriter 
\series medium 

\backslash 
printer
\family default 
\series default 
 This setting defines the default name of your printer.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_command
\family default 
\series default 
 This setting defines which command, LyX should use to print your document.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_evenpage_flag
\family default 
\series default 
 This setting defines which flag to your printer command will trigger printing
 of only the even pages.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_oddpage_flag
\family default 
\series default 
 This setting defines which flag to give your printer command to print only
 the odd pages.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_reverse_flag
\family default 
\series default 
 With this command, you can define what flag that will cause your printing
 command to print the pages in reverse order.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_landscape_flag
\family default 
\series default 
 This command defines what flag is set when you've requested printing of
 your document in landscape.
 No option is passed, if the document is printed in portrait.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_to_printer
\family default 
\series default 
 If you specify an explicit name of a printer, you'll typically have to
 prepend this name with a flag on the printing command line.
 This command defines what flag should appear before the printer name.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_to_file
\family default 
\series default 
 If you want to print to a file, you have to provide a flag before the filename.
 This command allows you to define how this flag looks.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_file_extension
\family default 
\series default 
 When you print to a file, you can define what extension the printed file
 will have with this command.
\layout Description


\family typewriter 
\series medium 

\backslash 
print_extra_options
\family default 
\series default 
 With this command, you can define a series of flags that will be put on
 the printing command after the other flags.
 
\layout Description


\family typewriter 
\series medium 

\backslash 
print_spool_cmd
\family default 
\series default 
 If you specify something in this command, LyX will print in two steps:
 First, the program specified with the 
\family typewriter 

\backslash 
print_command
\family default 
 setting will be executed with the directive to print to a file.
 Then, the command specified with 
\family typewriter 

\backslash 
print_spool_cmd
\family default 
 will be executed with the output file from the previous command on the
 command line, and if specified, the directive (
\family typewriter 

\backslash 
print_to_printer
\family default 
) to send the output to a named printer before the filename.
\layout Standard

All in all, we hope that this will allow you to be able to print your documents
 without fuss.
\layout Section

Screen & Fonts
\layout Standard

The font used to display your documents on the LyX screen is very important,
 since you'll be reading all your documents with this font.
 Therefor it is important that the font is as readable and good-looking
 as possible.
 The LyX team tried to provide the best possible default font for you, but
 since practically all X11 systems are different, it's very likely that
 the default fonts will be sub-optimal on your system.
 Fortunately, you can do something about this.
 Before we explain how to do this, you should learn a bit more about fonts
 so that you are better prepared for choosing your fonts, because it is
 a trade-off that is individual to your preferences and the capabilities
 of your system.
\layout Standard

Notice that this section only deals with the fonts on the 
\emph on 
screen
\emph default 
 inside the LyX window.
 The fonts that appear on the 
\emph on 
paper
\emph default 
 
\emph on 
output
\emph default 
 are independent from these fonts, and are determined by the document class.
 Read the 
\emph on 
User's Guide
\emph default 
 to learn how to change the font of the printed version of your document.
\layout Standard

Basically, screen fonts come in two different kinds: Scalable outline fonts
 and non-scalable bitmap fonts.
 This distinction seems a bit arbitrary, since non-scalable fonts are actually
 scalable in most modern font renderers.
 The difference lies the 
\emph on 
quality
\emph default 
 of the scaling, and the 
\emph on 
speed
\emph default 
 of display.
 The most important decision is thus whether you should use non-scalable
 bitmap fonts or scalable outline fonts.
\layout Standard

The scalable fonts are build from 
\emph on 
outlines
\emph default 
 of the single glyphs (i.e.
 characters) in the font.
 This means that each glyph is defined using mathematical curves that are
 well suited for scaling to any requested size.
 This mathematical definition is interpreted by the font renderer and turned
 into a small picture composed of pixels according to which size and glyph,
 the programmer requests.
 This means that scalable fonts will look pretty good in all sizes.
 Well, almost all sizes.
 Since scalable fonts are defined in an abstract way, it can be hard to
 provide a good rendering at small sizes, where each pixel has to be very
 carefully put to provide a good image.
 Technically it is possible to do this from the mathematical definition,
 but in order to keep the rendering reasonably fast, round-offs have to
 be made, and the result is that scalable fonts can be difficult to read
 at small sizes.
\layout Standard

Bitmap fonts on the other hand, are defined by bitmap graphics from the
 start, so they will look good at all the sizes they are meant for.
 However, they don't scale well, because in order to scale a glyph, each
 pixel is enlarged into several pixels.
 It is the same effect that happens if you try to enlarge a picture in xv
 or any other picture manipulation program.
 In order to relieve this effect, bitmap fonts are typically provided in
 several fixed sizes typically from around 8 pixels high up to 34 pixels
 or so high in steps according to what is believed to be useful.
 The advantage of bitmap fonts is that no complicated computations are necessary
 to display each glyph, so bitmap fonts are thus faster displayed than scalable
 fonts.
 The disadvantage is that sizes that don't exists as fixed versions have
 to be scaled by doubling pixels, and thus look bad.
\layout Standard

The net result of all this, is that bitmap fonts are generally best for
 the small sizes, where they are available, while scalable fonts are generally
 best for large sizes.
 The logical conclusion would thus be to use bitmap fonts for the small
 sizes, and scalable fonts for the large sizes.
 Unfortunately, this is not a good idea, since bitmap fonts and scalable
 fonts are not designed to be used together, so the overall look of such
 a scheme would be bad.
 The best you can do is thus to try both schemes and decide for yourself
 what suits you.
\layout Standard

By default, LyX uses non-scalable bitmap fonts.
 For serif fonts, 
\emph on 
times
\emph default 
 is used, for sans serif fonts, 
\emph on 
helvetica
\emph default 
 is used, while 
\emph on 
courier
\emph default 
 is used as the monospaced/typewriter font.
\layout Standard

In the following, we will describe what to do if the text does not look
 good in LyX.
 We'll start with the most important parameters: DPI and font zoom.
\layout Subsection

DPI setting and Font Zoom
\layout Standard

LyX automatically tries to scale the fonts to look as close as the paper
 output size as possible, except for the so-called font zoom factor.
\layout Standard

In order for this to work on all systems, it relies on the screen DPI (dots
 per inch) setting to be correct.
 The DPI setting for your system is autodetected by LyX using the information
 the X server can provide.
 You can check what LyX autodetects the DPI setting to, by running LyX as
 
\family typewriter 
lyx -dbg 1
\family default 
.
\layout Standard

On many systems, X is not set up correctly, so you should check that it
 is correct by hand.
 Run 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
xdpyinfo | less
\family default 

\begin_inset Quotes erd
\end_inset 

 and write down what the DPI is for the resolution, you use (this will be
 close to the value LyX detects).
 It is the number mentioned as 
\begin_inset Quotes eld
\end_inset 

resolution
\begin_inset Quotes erd
\end_inset 

.
 Also write down the number of pixels you have in the width (the first number
 under 
\begin_inset Quotes eld
\end_inset 

dimensions
\begin_inset Quotes erd
\end_inset 

).
\layout Standard

Then get the good old ruler out of the closet, and measure the width of
 the visible screen-image on your monitor.
 Convert this measurement to inches if you used a centimeter ruler by multiplyin
g with 2.54.
 Now you can determine the correct DPI setting for your screen by dividing
 the number of pixels in the width by the width of the screen-image on the
 monitor.
 If this number is more than, say, 5 DPI from the detected value, you should
 either fix the X setup, or at least tell LyX that the DPI is different
 than the detected value.
\layout Standard

If you can't fix the X setup (which of course is best since other programs
 than LyX will benefit from this as well), you can tell LyX the correct
 DPI setting with the 
\family typewriter 

\backslash 
screen_dpi
\family default 
 command by providing an integer argument, like this:
\layout Standard


\family typewriter 

\backslash 
screen_dpi 90
\layout Standard

When you've got the correct DPI setting, restart LyX and see if the text
 looks good.
 (Notice that the DPI value mentioned when you run LyX as 
\family typewriter 
lyx -dbg 1
\family default 
 is the autodetected value, so don't be worried when the figure does not
 change even though you use the 
\family typewriter 

\backslash 
screen_dpi
\family default 
 command.
 LyX will use it even if it is silent about it.)
\layout Standard

If the text is too small or too big for your taste, you should fiddle with
 the font zoom setting.
 This setting is used to scale the point size of the text.
 If your DPI setting is correct, and the font zoom setting is set to 100,
 this means that LyX will try to display the text exactly the same size
 as it will appear on the paper-output.
 If you set the zoom factor to 200, the text will try to be 2 times as big
 as on paper.
 Of course, this will only happen if LyX can find a font that has the appropriat
e size, which you can't count on.
 But since LyX is a WYSIWYM system anyways, this limitation isn't much of
 an issue.
\layout Standard

The default font zoom setting is 150 since a monitor is typically wider
 than a piece of paper, but you should try to fiddle with it through the
 
\family sans 
Font
\protected_separator 

\bar under 
Z
\bar default 
oom
\family default 
 setting in the 
\family sans 
Options->Screen
\protected_separator 
Options
\family default 
 pop-up to find a size that you like.
 When you've found a setting that seems to work nicely for you (tip: use
 the 
\family sans 
\bar under 
A
\bar default 
pply
\family default 
 button to keep the pop-up open while you experiment), you can make this
 setting the default by using the 
\family typewriter 

\backslash 
screen_zoom
\family default 
 command in your 
\family typewriter 
lyxrc
\family default 
 file.
\layout Standard

While it is often possible to find a suitable size for the text on the screen,
 this doesn't necessarily mean that the fonts are the best ones available
 on your system.
 In order to help you get the most out of your system, you can use the font
 definition commands to fine-tune the look of the text in greater detail
 than merely size.
\layout Subsection

Font definition commands
\layout Standard

As mentioned, LyX uses non-scalable bitmap fonts by default.
 For serif fonts, 
\emph on 
times
\emph default 
 is used, for sans serif fonts, 
\emph on 
helvetica
\emph default 
 is used, while 
\emph on 
courier
\emph default 
 is used as the monospaced/typewriter font.
\layout Standard

You can change this with the following 
\family typewriter 
lyxrc
\family default 
 commands:
\layout Description


\family typewriter 
\series medium 

\backslash 
screen_font_roman
\family default 
 
\series default 
defines the font to use for serif text, like this.
\layout Description


\family typewriter 
\series medium 

\backslash 
screen_font_sans
\family default 
 
\series default 
defines the font to use for sans serif text, 
\family sans 
like this
\family default 
.
\layout Description


\family typewriter 
\series medium 

\backslash 
screen_font_typewriter
\family default 
 
\series default 
defines the font to use for typewriter/monospaced text, 
\family typewriter 
like this
\family default 
.
\layout Standard

The number of fonts that are available on different systems vary, but the
 program 
\family typewriter 
xfontsel
\family default 
 should be available everywhere.
 Use that program to find candidate fonts.
 When you've found a font that you like, try to insert the first two elements
 of the name (called 
\begin_inset Quotes eld
\end_inset 

fndry
\begin_inset Quotes erd
\end_inset 

 and 
\begin_inset Quotes eld
\end_inset 

fmly
\begin_inset Quotes erd
\end_inset 

 in 
\family typewriter 
xfontsel
\family default 
) in the appropriate field in the 
\family sans 
Options->Screen
\protected_separator 
Options
\family default 
 pop-up and press 
\family sans 
\bar under 
A
\bar default 
pply
\family default 
.
 LyX will then reformat your document using the new font, and if you like
 the font, you should put it in your 
\family typewriter 
lyxrc
\family default 
 file.
 One place to start for a new font is to see if the scalable font 
\begin_inset Quotes eld
\end_inset 

utopia
\begin_inset Quotes erd
\end_inset 

 is available.
 Tip: You can see whether a font is a bitmap font or a scalable font by
 checking the 
\begin_inset Quotes eld
\end_inset 

resx
\begin_inset Quotes erd
\end_inset 

 or 
\begin_inset Quotes eld
\end_inset 

resy
\begin_inset Quotes erd
\end_inset 

 fields in 
\family typewriter 
xfontsel
\family default 
.
 If the value 0 is available, the font is scalable.
 If the value 0 isn't available, the font is a bitmap font.
\layout Standard

Before you go about scrapping a bitmap font because the larger sizes look
 
\begin_inset Quotes eld
\end_inset 

blocky
\begin_inset Quotes erd
\end_inset 

, you should try to use the following command to make it better:
\layout Description


\family typewriter 
\series medium 

\backslash 
screen_font_scalable
\family default 
\series default 
 is a boolean that defines whether LyX should scale bitmap fonts or not.
\layout Standard

This is only useful if you use bitmap fonts, because only these don't scale
 well.
 If you define this flag, LyX will only use the fixed font sizes that are
 available, and this guarantees that all bitmap fonts look well.
 (You can see which individual font sizes are available with the 
\family typewriter 
xlsfonts
\family default 
 command.
 Try 
\family typewriter 
man xlsfonts
\family default 
.) However, the prize is that the difference between the size of the fonts
 on screen and the size of fonts on paper will be larger because LyX will
 have to be satisfied with the closest available size, and not try to scale
 a size to fit.
 Also, you can risk that some logically different sizes, such as 
\family sans 
Large
\family default 
 and 
\family sans 
Larger
\family default 
, will be mapped to the same screen font, making it hard for you to see
 the difference on screen.
 We've decided to let this flag be 
\family typewriter 
false
\family default 
 by default because of these artifacts, but since LyX is a WYSIWYM system,
 many people like to use the flag anyways, well-knowing that the font size
 on the screen can't be trusted.
 But remember that this flag only makes a difference when you use bitmap
 fonts.
 Scalable fonts won't be affected for reasons you should understand by now.
\layout Standard

One final note regarding this flag: you should know that there is nothing
 wrong with using bitmap and scalable fonts at the same time for different
 purposes.
 For instance, it's common to use the scalable 
\begin_inset Quotes eld
\end_inset 

Utopia
\begin_inset Quotes erd
\end_inset 

 for the serif text together with a bitmap version of 
\begin_inset Quotes eld
\end_inset 

Helvetica
\begin_inset Quotes erd
\end_inset 

.
 And you can safely set the 
\family typewriter 
\series medium 

\backslash 
screen_font_scalable
\family default 
\series default 
 setting to 
\family typewriter 
true
\family default 
 without worries: It will only apply to the Helvetica font.
\layout Standard

Sometimes the artifacts introduced by use the flag can be relieved by using
 the fine-detail 
\family typewriter 
lyxrc
\family default 
 command 
\family typewriter 

\backslash 
screen_font_sizes
\family default 
 which defines which point sizes the different logical font sizes correspond
 to.
 Run LyX as 
\family typewriter 
lyx -dbg 513
\family default 
 to see exactly what concrete fonts the logical sizes map to, and try adjusting
 the corresponding entry in 
\family typewriter 

\backslash 
screen_font_sizes
\family default 
 in your 
\family typewriter 
lyxrc
\family default 
 file until you've managed to hit the nail and get the fonts you want.
 This can be hard to do, because LyX uses the DPI setting and the font zoom
 settings to calculate which exact screen font size to ask the X server
 for, thus obfuscating the mapping.
 If you can't make it by trial-and-error, you can make the process more
 transparent if you set both the DPI setting and font zoom settings to 100---eve
n when this is known to be wrong.
 This will of course make your scalable fonts look weird, so use with care.
\layout Subsection

Font encoding
\layout Standard

By default, LyX will use fonts meant to write Western European text, including
 all kinds of English.
 This is defined through the so-called 
\emph on 
font
\emph default 
 
\emph on 
encoding
\emph default 
.
 If you want to use LyX to write for instance Eastern European text, Cyrillic
 or any other language not covered by the ISO-8859-1 font encoding, you
 can define a different one with the 
\family typewriter 

\backslash 
screen_font_encoding
\family default 
 setting.
 This requires you to have special fonts installed.
 You can use 
\family typewriter 
xfontsel
\family default 
 to see whether this is the case: check the 
\begin_inset Quotes eld
\end_inset 

rgstry
\begin_inset Quotes erd
\end_inset 

 and 
\begin_inset Quotes eld
\end_inset 

encdng
\begin_inset Quotes erd
\end_inset 

 fields for ISO-8859-X values different from ISO-8859-1, and search for
 one that contains the national characters of your language.
 If you find any, define this value in your 
\family typewriter 
lyxrc
\family default 
 file.
 If not, go searching the Web for appropriate fonts.
\layout Standard

When you've set LyX up to use a different font encoding, you should also
 consider to change the font used by pop-up windows in LyX.
 For instance, the 
\family sans 
Table
\protected_separator 
of
\protected_separator 
Contents
\family default 
 pop-up will not be understandable unless you tell LyX to use a different
 font for this.
 By default the menu font is set to 
\family typewriter 
-*-helvetica-medium-r
\family default 
, but often Helvetica is not available in the font encoding you need.
 Therefor you can change this font with the 
\family typewriter 

\backslash 
screen_font_menu
\family default 
 command.
\layout Standard

As you can see, there are quite a few options that can be used to fine tune
 the look of your fonts.
 This should not scare you from fiddling with the settings, because after
 all, you will hopefully be using LyX for many hours in the future.
 And contrary to real WYSIWYG word processors where you are tied to use
 fonts that have to look good both on paper and on screen, LyX gives you
 the possibility to use fonts that are designed to look on the screen.
 If you are lucky enough to have that.
\layout Standard

In LyX version 1.1, we will try to support the 
\family typewriter 
T1Lib
\family default 
 font renderer, which provides 
\emph on 
anti-aliased
\emph default 
 text.
 This means that each glyph is built from several color shades rather than
 just two colors, in effect giving what appears to be higher resolution.
 This will not only make the text more readable on screen, but will also
 allow LyX to get really close to the font sizes as they appear on paper,
 since it will be possible for LyX to ask for, say, a point 14.4 font instance,
 contrary to now, where this has to be rounded to point 14.
\layout Section

TeX
\layout Standard

Some sites
\begin_float footnote 
\layout Standard


\emph on 
like my office machine --Dave Johnson
\end_float 
 still have the default LaTeX version as 2.09.
 Though I can't imagine why this should be the default any longer, it will
 be necessary to deal with LyX in such an environment.
 Don't even 
\emph on 
think
\emph default 
 about 
\begin_inset Quotes eld
\end_inset 

fixing
\begin_inset Quotes erd
\end_inset 

 LyX to run under LaTeX 2.09.
 Upgrading your LaTeX will be easier, and is the right way to go, anyway.
 Most large systems should, even if they default to 2.09, have a version
 of LaTeX2e available, but perhaps using a different executable name.
 You can change the name of the appropriate LaTeX command, say to the name
 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
latex2e
\family default 

\begin_inset Quotes erd
\end_inset 


\begin_float footnote 
\layout Standard


\emph on 
as it is at my office --Dave Johnson
\end_float 
 by placing the line
\layout LyX-Code


\backslash 
latex_command latex2e
\layout Standard

in your 
\family typewriter 
lyxrc
\family default 
 file.
 At installation time, LyX will try to autodetect whether this setting is
 needed, so normally, you don't need to worry about it.
\layout Section

The autodetected settings
\layout Standard


\begin_inset LatexCommand \label{sec:autodetected}

\end_inset 

There are several items that are detected for you when you run
\latex latex 
 
\family sans 
\bar under 
\latex default 
O
\bar default 
ption->
\bar under 
R
\bar default 
econfigure
\family default 
.
 In this section, we list those which pertain to 
\family typewriter 
lyxrc
\family default 
.
 In what follows, all the 
\family typewriter 
*_command
\family default 
 entries are set to none if no suitable command is found.
 In this case, the corresponding functions are not available.
\layout Description


\family typewriter 
\series medium 

\backslash 
latex_command
\family default 
\series default 
 is set to a valid LaTeX2e processor (programs tested are 
\family typewriter 
latex
\family default 
 and 
\family typewriter 
latex2e
\family default 
);
\layout Description


\family typewriter 
\series medium 

\backslash 
ps_command
\family default 
\series default 
 is set to 
\family typewriter 
gs
\family default 
 if you have Ghostscript installed;
\layout Description


\family typewriter 
\series medium 

\backslash 
view_ps_command
\family default 
\series default 
 is set to 
\family typewriter 
gv
\family default 
 or 
\family typewriter 
ghostview
\family default 
 if they are found (
\family typewriter 

\backslash 
view_pspic_command
\family default 
 is set to use the same program).
\layout Description


\family typewriter 
\series medium 

\backslash 
ascii_roff_command
\family default 
\series default 
 uses either 
\family typewriter 
groff
\family default 
 or 
\family typewriter 
nroff
\family default 
+
\family typewriter 
tbl
\family default 
, depending on what is available.
\layout Description


\family typewriter 
\series medium 

\backslash 
chktex_command
\family default 
\series default 
 is set to 
\family typewriter 
chktex
\family default 
 plus a bunch of options;
\layout Description


\family typewriter 
\series medium 

\backslash 
fax_command
\family default 
\series default 
 is set to 
\family typewriter 
fax
\protected_separator 
send
\family default 
 of 
\family typewriter 
sendfax
\family default 
, depending on what fax package is found.
 The needed command line options are also added;
\layout Description


\family typewriter 
\series medium 

\backslash 
print_spool_command
\family default 
\series default 
 is set to 
\family typewriter 
lp
\family default 
 on systems (so-called System V) who have this command, and 
\family typewriter 
lpr
\family default 
 otherwise (BSD systems);
\layout Description


\family typewriter 
\series medium 

\backslash 
print_spool_printerprefix
\family default 
\series default 
 is set to 
\family typewriter 
-d
\family default 
 or 
\family typewriter 
-P
\family default 
, depending on whether 
\family typewriter 
lp
\family default 
 or 
\family typewriter 
lpr
\family default 
 was found;
\layout Description


\family typewriter 
\series medium 

\backslash 
font_encoding
\family default 
\series default 
 is set to 
\family typewriter 
T1
\family default 
 if the 
\family typewriter 
ec
\family default 
 fonts are found and LaTeX has support for these fonts built-in.
 You can set it manually if you only have the so-called 
\family typewriter 
dc
\family default 
 fonts.
\layout Section

The rest
\layout Standard

There are a bunch of other 
\family typewriter 
lyxrc
\family default 
 commands that can be used to customize LyX behavior.
 We still need to document that here, but for now, the 
\family typewriter 
lyxrc
\family default 
 file is richly commented so walk through that to get an idea of what you
 can customize.
 You can also try your luck in the 
\emph on 
Reference guide,
\emph default 
 but no guarantees.
\layout Chapter

The LyX Server
\layout Section

Introduction
\layout Standard

The LyX server is a method implemented into LyX that will enable other programs
 to talk to LyX, invoke LyX commands and retrieve information about the
 LyX internal state.
 This is only intended for advanced users, but those will find it useful.
\layout Section

Starting the LyX Server
\layout Standard

The LyX server works through the use of a pair of named pipes.
 These are usually located in your home directory and have the names 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
.lyxpipe.in
\family default 

\begin_inset Quotes erd
\end_inset 

 and 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
.lyxpipe.out
\family default 

\begin_inset Quotes erd
\end_inset 

.
 External programs write into 
\family typewriter 
.lyxpipe.in
\family default 
 and read back data from 
\family typewriter 
.lyxpipe.out
\family default 
.
 The stem of the pipe names can be defined in the 
\family typewriter 
lyxrc
\family default 
 file by adding a line like:
\layout LyX-Code


\backslash 
serverpipe "/home/myhome/.lyxpipe"
\layout Standard

LyX will add the '
\family typewriter 
.in
\family default 
' and '
\family typewriter 
.out
\family default 
' to create the pipes.
 The above line also has the effect of activating the LyX server.
 If one of the pipes already exists, LyX will assume that another LyX process
 is already running and will not start the server.
 To have several LyX processes with servers at the same time, you have to
 change the 
\family typewriter 
lyxrc
\family default 
 between the start of the programs.
\layout Standard

If you are developing a client program, you might find it useful to enable
 debugging information from the LyX server.
 Do this by starting LyX as 
\family typewriter 
lyx -dbg 8192.
\layout Standard


\emph on 
Note: if LyX crashes, it may not manage to remove the pipes; in this case
 you should remove them manually.
 If LyX starts and the pipes exist already, it will not start any server.
\layout Standard

Other than this, there are a few points to consider:
\layout Itemize

Both server and clients must run on UNIX or OS/2 machines.
 Communications between LyX on UNIX and clients on OS/2 or vice versa is
 not possible right now.
\layout Itemize

On OS/2, only one client can connect to LyXServer at a time.
\layout Itemize

On OS/2, clients must open inpipe with 
\family typewriter 
O_WRONLY
\family default 
 mode.
\layout Standard

You can find a complete example client written in C in the source distribution
 as 
\family typewriter 
development/server_monitor.c
\family default 
.
\layout Section

Normal communication
\layout Standard

To issue a LyX call, the client writes a line of ASCII text into the input
 pipe.
 This line has the following format:
\layout Quote

LYXCMD:
\emph on 
clientname
\emph default 
:
\emph on 
function
\emph default 
:
\emph on 
argument
\layout Standard

Here 
\emph on 
clientname
\emph default 
 is a name that the client can choose arbitrarily.
 Its only use is that LyX will echo it if it sends an answer - so a client
 can dispatch results from different requesters.
\layout Standard


\emph on 
function
\emph default 
 is the function you want LyX to perform.
 It is the same as the commands you'd use in the minibuffer.
\layout Standard


\emph on 
argument
\emph default 
 is an optional argument which is meaningful only to some functions (for
 instance 
\begin_inset Quotes eld
\end_inset 

self-insert
\begin_inset Quotes erd
\end_inset 

 which will insert the argument as text at the cursor position.)
\layout Standard

The answer from LyX will arrive in the output pipe and be of the form
\layout Quote

INFO:
\emph on 
clientname
\emph default 
:
\emph on 
function
\emph default 
:
\emph on 
data
\layout Standard

where 
\emph on 
clientname
\emph default 
 and 
\emph on 
function
\emph default 
 are just echoed from the command request, while 
\emph on 
data
\emph default 
 is more or less useful information filled according to how the command
 execution worked out.
 Some commands will return information about the internal state of LyX,
 such as 
\begin_inset Quotes eld
\end_inset 

font-state
\begin_inset Quotes erd
\end_inset 

, while other will return an empty data-response.
 This means that the command execution went fine.
\layout Standard

In case of errors, the response from LyX will have this form
\layout Quote

ERROR:
\emph on 
clientname
\emph default 
:
\emph on 
function
\emph default 
:
\emph on 
error message
\layout Standard

where the 
\emph on 
error message
\emph default 
 should contain an explanation of why the command failed.
\layout Standard

Examples:
\layout LyX-Code

echo "LYXCMD:test:beginning-of-buffer:" >~/.lyxpipe.in
\layout LyX-Code

echo "LYXCMD:test:get-xy:" >~/.lyxpipe.in
\newline 
read a <~/.lyxpipe.out
\newline 
echo $a
\layout Section

Notification
\layout Standard

LyX can notify clients of events going on asynchronously.
 Currently it will only do this if the user binds a key sequence with the
 function 
\begin_inset Quotes eld
\end_inset 

notify
\begin_inset Quotes erd
\end_inset 

.
 The format of the string LyX sends is as follows:
\layout Quote


\family typewriter 
NOTIFY:
\family default 
\emph on 
key-sequence
\layout Standard

where 
\emph on 
key-sequence
\emph default 
 is the printed representation of the key sequence that was actually typed
 by the user.
\layout Standard

This mechanism can be used to extend LyX's command set and implement macros:
 bind some key sequence to 
\begin_inset Quotes eld
\end_inset 

notify
\begin_inset Quotes erd
\end_inset 

, start a client that listens on the out pipe, dispatches the command according
 to the sequence and starts a function that may use LyX calls and LyX requests
 to issue a command or a series of commands to LyX.
\layout Section

The simple LyX Server Protocol
\layout Standard

LyX implements a simple protocol that can be used for session management.
 All messages are of the form
\layout Quote

LYXSRV:
\emph on 
clientname
\emph default 
:
\emph on 
protocol message
\layout Standard

where 
\emph on 
protocol message
\emph default 
 can be 
\begin_inset Quotes eld
\end_inset 

hello
\begin_inset Quotes erd
\end_inset 

 or 
\begin_inset Quotes eld
\end_inset 

bye
\begin_inset Quotes erd
\end_inset 

.
 If 
\begin_inset Quotes eld
\end_inset 

hello
\begin_inset Quotes erd
\end_inset 

 is received from a client, LyX will report back to inform the client that
 it's listening to it's messages, while 
\begin_inset Quotes eld
\end_inset 

bye
\begin_inset Quotes erd
\end_inset 

 sent from LyX will inform clients that LyX is closing.
\layout Chapter

Internationalizing LyX
\begin_inset LatexCommand \label{chap:i18n}

\end_inset 


\layout Standard

LyX supports using a translated interface.
 Last time we checked, Norwegian, Danish, Finish, German, Dutch and Swedish
 texts were provided together with the default English text.
 The language of choice is called your 
\emph on 
locale
\emph default 
.
 (For further reading on locale settings, see also the documentation for
 locale that comes with your operating system.
 For Linux, the manual page for locale(5) could be a good place to start).
\layout Standard

Notice that these translations do work not without a few flaws.
 In particular, all pop-ups have been designed with the English text in
 mind, which means that some of the translated text will be too large to
 fit within the space allocated.
 This is only a display problem and will not cause any harm.
 Also, you will find that some of the translations do not define short-cut
 keys for everything.
 Sometimes, there are simply not enough free letters to do it.
 Other times, the translator just hasn't got around to doing it yet.
\layout Standard

We'll try to fix these shortcomings in LyX version 1.1.
\layout Section

Selecting an alternative language for the user interface
\layout Standard

This feature is disabled by default, meaning that the text will be English.
 To enable an alternative language, you have to set an appropriate environment
 variable.
 Use 
\family typewriter 
"setenv LANG xx"
\family default 
 
\family roman 
for csh class shells
\family default 
 or 
\family typewriter 
"export LANG=xx"
\family default 
 
\family roman 
for sh class shells
\family default 
.
 Substitute the 
\family typewriter 
xx
\family default 
 with the two letter code for the language you want.
 For instance, 
\family typewriter 
no
\family default 
 is Norwegian.
\layout Standard

Normally, you'll want to put the appropriate line in 
\family typewriter 
~/.Xsession
\family default 
 or 
\family typewriter 
~/.xinitrc
\family default 
 such that the translation is on per default.
 Remember that if LyX is configured and compiled with 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
--disable-nls
\family default 

\begin_inset Quotes erd
\end_inset 

, this will not work.
\layout Section

Adapting shortcuts for alternative languages
\layout Standard


\latex latex 

\backslash 
begin{sloppypar}
\layout Standard

One main cause for inconsistencies in the translated versions of LyX is
 the fact that all the keyboard shortcuts for the menu functions are based
 on the English version of the text.
 This is, regardless of the entry in the menu, 
\family sans 
M-f t 
\family default 
will open the new-file-from-template popup.
 It is, however, easy to change this, as all the shortcuts for menu operations
 are defined in one file, 
\family typewriter 
LyXDir/bind/menus.bind
\family default 
.
 Every user can have his own copy of that file in his private directory,
 
\family typewriter 
~/.lyx/bind
\family default 
, which will then take precedence over the systemwide file.
 In this private copy, one can easily change the definitions, e.g.
 for the German version change 
\family sans 
M-f t
\family default 
 to 
\family sans 
M-d v
\family default 
 (for 
\family sans 
Datei->Vorlage
\family default 
).
 For some languages, examples for adapted 
\family typewriter 
menus.bind
\family default 
 files can be found in 
\family typewriter 
LyXDir/bind/
\series bold 
xx
\series default 
_menus.bind 
\family default 
(
\series bold 
xx 
\series default 
denotes the language code).
 These will be used automatically by LyX if they exist (and if your locale
 is set with 
\family typewriter 
$LANG=
\series bold 
xx
\family default 
\series default 
).
\layout Standard


\latex latex 

\backslash 
end{sloppypar}
\layout Standard

You will have to take care that the new definitions for shortcuts do not
 collide with other, previous definitions.
 For example the abovementioned binding 
\family sans 
M-d v
\family default 
 would generate an error for those who use 
\family typewriter 
(x)emacs.bind
\family default 
, where 
\family sans 
M-d
\family default 
 is bound to 
\family typewriter 
word-delete-forward
\family default 
.
 
\layout Standard

As of LyX version 1.0, the translated names for the top level menus (translated
 in the po-files) are used by the keybinding mechanism, therefore the 
\emph on 
translated 
\emph default 
menu name must be used in the translated 
\family typewriter 
menus.bind
\family default 
.
\layout Section

Translating LyX
\layout Subsection

Translating the graphical user interface (text messages).
\layout Standard

LyX uses the GNU gettext-library to handle the internationalization of the
 interface.
 To have LyX speak your favorite language in all menus and dialog boxes,
 you need a po-file for that language.
 When this is available, you'll have to generate a mo-file from it and install
 the mo-file.
 The process of doing all of this is explained in the documentation for
 GNU gettext, but in short, this is what you do (
\series bold 
xx 
\series default 
denotes the language code):
\layout Standard


\latex latex 

\backslash 
begin{sloppypar}
\layout Itemize

Copy 
\family typewriter 
LYX-SOURCE-DIR/po/lyx.pot
\family default 
 to 
\series bold 
xx
\family typewriter 
\series default 
.po
\family default 
 (if 
\family typewriter 
lyx.pot
\family default 
 doesn't exist, it can be remade with
\family typewriter 
 make lyx.pot
\family default 
 in that directory, or you can use an existing po-file for some other language
 as a template).
\layout Itemize

Edit 
\family typewriter 
xx.po
\begin_float footnote 
\layout Standard

We recommend that you use Emacs to do this, since the gettext distribution
 includes a nice mode that supports you in doing this.
\end_float 
.
 For some menu- and widget-labels, there are also shortcut keys that should
 be translated.
 Those keys are marked after a `
\family typewriter 
|
\family default 
', and should be translated according to the words and phrases of the 
\series bold 
xx
\series default 
-language.
 There is a tool named 
\family typewriter 
scgen.pl
\family default 
 written in Prolog in 
\family typewriter 
LYX-SOURCE-DIR/development/tools/
\family default 
 that may be useful to help determine short-cut keys.
 Note that XForms (version 0.86 at least) can't handle anything but 7-bit
 characters as shortcut keys.
 You should also fill also out the information at the beginning of the new
 po-file with your email-address, etc., so people know where to reach you
 with suggestions and entertaining flames.
\layout Itemize

Generate 
\series bold 
xx
\family typewriter 
\series default 
.mo
\family default 
.
 This can be done with
\newline 

\family typewriter 
msgfmt -o 
\family default 
\series bold 
xx
\family typewriter 
\series default 
.mo < 
\family default 
\series bold 
xx
\family typewriter 
\series default 
.po
\layout Itemize

Copy the mo-file to your locale-tree, at the correct directory for application
 messages for the language 
\series bold 
xx
\series default 
, and under the name 
\family typewriter 
lyx.mo
\family default 

\newline 
(e.g.
 
\family typewriter 
/usr/local/share/locale/
\family default 
\series bold 
xx
\family typewriter 
\series default 
/LC_MESSAGES/lyx.mo
\family default 
)
\layout Standard


\latex latex 

\backslash 
end{sloppypar}
\layout Standard

Adding a new po-file to the 
\emph on 
distribution 
\emph default 
of LyX involves altering the configure scripts and more, but the way gettext
 works, you don't actually need the source-code of LyX to translate it---having
 
\family typewriter 
lyx.pot
\family default 
 (or an existing po-file) and the gettext tools suffices.
\layout Standard

If you've written a translation file for a language that LyX does not currently
 support, feel free to submit it for inclusion by sending a patch.
 In this case, we recommend that you read the README provided in the 
\family typewriter 
LYX-SOURCE-DIR/po/
\family default 
 directory for more instructions.
\layout Subsection

Translating the documentation.
\layout Standard

The online documentation (in the 
\family sans 
Help
\family default 
-menu) can be translated.
 If there are translated versions of the documentation available (as of
 this writing, there are hardly none), and the locale is set accordingly,
 these will be used automagically by LyX.
 The translated versions are sought as 
\family typewriter 
LyXDir/doc/
\series bold 
xx
\series default 
_DocName.lyx
\family default 
, where 
\family typewriter 
\series bold 
xx
\family default 
\series default 
 denotes the language as set by the environmental variable 
\family typewriter 
$LANG
\family default 
.
 If there are none, the default English versions will be displayed.
 Note that even the translated versions must have the same filenames as
 the original.
 If you feel up to translating the documentation (an excellent way to proof-read
 the original documentation btw!), here's a few hints for you that may save
 you trouble:
\layout Itemize

Join the documentation team! There is information on how to do that in 
\family typewriter 
Intro.lyx
\family default 
 (
\family sans 
Help->Introduction
\family default 
), which by the way is the first document you should translate.
\layout Itemize

Make a copy of the original document to a safe place.
 You'll need this later (months later perhaps).
\layout Itemize

Learn the typographic conventions for the language you are translating to.
 Typography is an ancient art and during the centuries, a great variety
 of conventions has developed throughout different parts of the world.
 Also study the professional terminology amongst typographers in your country.
 Inventing your own terminology will only confuse the users.
 
\emph on 
(Warning! Typography is addicting!)
\layout Itemize

Make another copy of the same file.
 This will be your working copy.
 You can use this as your personal translated help-file by placing it in
 your 
\family typewriter 
~/.lyx/doc/
\family default 
-directory.
\layout Itemize

Sometimes the original document (from the LyX-team) will be updated, compare
 the new version with your first untouched copy with the 
\noun on 
Unix
\noun default 
-command 
\family typewriter 
diff
\family default 
 for instance.
 That way you can easily see which parts of the translated document that
 needs to be updated.
 Replace the untouched original copy with the new (also untouched) copy.
\layout Itemize

If you ever find an error in the original document, fix it and notify the
 rest of the documentation team of the changes! (You didn't forget to join
 the documentation team did you?) 
\emph on 
As of this writing, not even the original documentation is complete!
\layout Section

International Keyboard Support
\layout Standard


\emph on 
Editor's Note: The following section is by Ivan Schreter.
 It needs to be fixed to conform to the new Documentation Style sheet and
 to make use of the new v1.0 features.
 The whole thing also needs to be merged with the section following it.-jw
\layout Subsection

Defining Own Keymaps: Keymap File Format
\layout Standard

Let's look at a keyboard definition file a little closer.
 It is a plain ASCII file defining
\layout Itemize

key-to-key or key-to-string translations
\layout Itemize

dead keys
\layout Itemize

dead keys exceptions
\layout Standard

To define key-to-key or key-to-string translation, use this command:
\layout Quotation


\family typewriter 

\backslash 
kmap
\family default 
 
\emph on 
key
\emph default 
 
\emph on 
outstring
\layout Standard

where 
\emph on 
key
\emph default 
 is the key to be translated and 
\emph on 
outstring
\emph default 
 is the string to be inserted into the document.
 To define dead keys, use:
\layout Quotation


\family typewriter 

\backslash 
kmod
\family default 
 
\family typewriter 
key
\family default 
 
\family typewriter 
deadkey
\layout Standard

where 
\emph on 
key
\emph default 
 is keyboard key and 
\emph on 
deadkey
\emph default 
 is dead key name.
 The following dead keys are supported (shortcut name is in parentheses):
\layout Quotation


\emph on 
Name
\hfill 
Example
\layout Quotation

acute (acu)
\hfill 
�����
\layout Quotation

grave (gra)
\hfill 
�����
\layout Quotation

macron (mac)
\hfill 
 \i \={o}

\layout Quotation

tilde (til)
\hfill 
��
\layout Quotation

underbar (underb)
\hfill 

\latex latex 

\backslash 
b o
\layout Quotation

cedilla (ced)
\hfill 
��
\layout Quotation

underdot (underd)
\hfill 

\latex latex 

\backslash 
d o
\layout Quotation

circumflex (circu)
\hfill 
�����
\layout Quotation

circle (circl)
\hfill 
�\i \r{u}
\i \r{U}

\layout Quotation

tie (tie)
\hfill 

\latex latex 

\backslash 
t oo
\layout Quotation

breve (bre)
\hfill 
\i \u{a}

\latex latex 

\backslash 
u o
\layout Quotation

caron (car)
\hfill 
\i \v{c}
\i \v{s}
\i \v{z}

\layout Quotation

hungarian umlaut (hug)
\hfill 
\i \H{o}
\i \H{u}

\layout Quotation

umlaut (uml)
\hfill 
���
\layout Quotation

dot (dot)
\hfill 
\i \.{z}

\latex latex 

\backslash 
.s
\layout Standard

Since in many international keyboards there are exceptions to what some
 dead keys should do, you can define them using
\layout Quotation


\family typewriter 

\backslash 
kxmod
\family default 
 
\emph on 
deadkey key outstring
\layout Standard

For example, on Slovak keyboard, if you enter caron-o, it generates circumflex-o
, so you put in
\layout Quotation


\family typewriter 

\backslash 
kxmod
\family default 
 
\family typewriter 
caron o "
\backslash 
^o"
\layout Standard

to make it work correctly.
 Also, you have to define as exceptions dead keys over i and j, to remove
 the dot from them before inserting an accent mark.
 I will change this when the time comes, but so far I didn't have time.
\layout Standard

Oh, and about keys: Backslash is escaped, so to enter it, you'll need double
 backslash.
 Also, quotes and 
\family typewriter 
#
\family default 
 have different meaning.
 
\family typewriter 
#
\family default 
 marks comment, quotes start and end LaTeX-style commands.
 To enter quote, you'll need to use 
\family typewriter 

\backslash 
"
\family default 
, to enter 
\family typewriter 
#
\family default 
, use 
\family typewriter 

\backslash 
#
\family default 
.
\layout Standard

If you make a keyboard description file that works fort your language, please
 mail it to me, so I can include it in the next keymaps distribution.
\layout Standard

More keywords will be supported in keymap configuration file in future,
 like
\layout Itemize


\family typewriter 

\backslash 
kinclude 
\family default 
\emph on 
filename
\hfill 
include
\emph default 
 another file
\layout Itemize


\family typewriter 

\backslash 
kprog
\family default 
 
\emph on 
program
\hfill 
define
\emph default 
 an external keymap translation program 
\layout Standard

Also, it should look into 
\family typewriter 
lyxrc
\family default 
 file for defaults, too (for example, a 
\family typewriter 

\backslash 
kinclude
\family default 
 option to include default keyboard).
\layout Section

International Keymap Stuff
\begin_inset LatexCommand \label{sec:keymap}

\end_inset 


\layout Standard

The next two sections describe the 
\family typewriter 
\shape up 
.kmap
\family default 
\shape default 
 and 
\family typewriter 
\shape up 
.cdef
\family default 
\shape default 
 file syntax in detail.
 These sections should help you design your own key map if the ones provided
 do not meet your needs.
\layout Subsection

The .kmap File
\layout Standard


\family sans 
\shape up 
.
\family typewriter 
kmap
\family default 
\shape default 
 file maps keystrokes to characters or strings.
 As the name suggests it sets a keyboard mapping.
 The 
\family typewriter 
.kmap
\family default 
 file keywords 
\family typewriter 
\shape up 
kmap
\shape default 
,
\shape up 
kmod
\shape default 
,
\shape up 
ksmod
\family default 
\shape default 
, and 
\family typewriter 
\shape up 
kcomb
\family default 
\shape default 
 are described in this section.
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\shape up 
kmap
\family default 
\shape default 
 Map a character to a string
\layout LyX-Code


\backslash 
kmap
\protected_separator 

\family roman 
\emph on 
char
\emph default 

\protected_separator 

\emph on 
string
\layout Standard

This will ma
\family roman 

\emph on 
char 
\emph default 
to 
\emph on 
string
\emph default 
.
 Note that in 
\emph on 
string
\emph default 

\shape up 
the double-quote (")
\shape default 
 and 
\shape up 
the backslash (
\backslash 

\shape default 
must be escaped with a preceding backslash (
\shape up 

\backslash 

\shape default 
)
\family default 
.
\layout Standard

An example of a 
\family sans 
\shape up 
kmap
\family default 
\shape default 
 statement to cause the symbol
\family sans 
\shape up 
 / 
\family default 
\shape default 
to be output for the keystroke
\family sans 
\shape up 
 & 
\family default 
\shape default 
is:
\layout LyX-Code


\backslash 
kmap & /
\layout List
\labelwidthstring 00.00.0000


\family typewriter 
\shape up 
kmod
\family default 
\shape default 
 Specify an accent character
\layout LyX-Code


\backslash 
kmod
\family roman 
 
\emph on 
char accent allowed
\layout Standard

This will make the cha
\family roman 
racter 
\emph on 
char
\shape up 
 be an accent
\emph default 
 on the 
\emph on 
allowed 
\emph default 
cha
\family default 
racter(s).
 This is the dead key
\begin_float footnote 
\layout Standard

The term 
\family roman 
\emph on 
dead key
\family default 
\emph default 
 refers to a key that does not produce a character by itself, but when followed
 with another key, produces the desired accent character.
 For example, a German characte
\family roman 
r with an umlaut like 
\emph on 

\emph default 
 can be produced in this manner.
\end_float 
 mechanism.
 
\layout Standard

If you 
\family roman 
hit 
\emph on 
char 
\emph default 
and then another key not in 
\emph on 
allowed
\emph default 
, you will get a 
\emph on 
char 
\emph default 
followed by the other, unallowed key, as output.
 
\family default 
Note that a 
\family sans 
\shape up 
Backspace
\family default 
\shape default 
 cancels a dead key, so if 
\family roman 
you hit 
\emph on 
char
\family sans 
 
\shape up 
Backspace
\family default 
\emph default 
, the cursor will not go one position backwards but will instead cancel
 the effect t
\family roman 
hat 
\emph on 
char
\emph default 
 might have had on the next keystroke.
 
\layout Standard

The following example specifies that the character ' is to be an acute accent,
 allowed on the characters a, e, i, o, u, A, E, I, O, and U:
\layout LyX-Code


\backslash 
kmod ' acute aeiouAEIOU
\layout List
\labelwidthstring 00.00.0000

ksmod Specify an exception to the accent character
\layout LyX-Code


\backslash 
kxmod 
\family sans 
\emph on 

\protected_separator 

\family roman 
accent char result
\layout Standard

This defines an exce
\family roman 
ption for 
\emph on 
accent 
\emph default 
on 
\emph on 
char
\emph default 
.
 T
\shape up 
he
\emph on 
 accent 
\emph default 
must 
\family default 
have been assigned a keystroke with a previous 
\family typewriter 

\backslash 
kmo
\shape default 
d
\family default 
 declar
\family roman 
ation and 
\emph on 
char 
\emph default 
must not belong in the 
\emph on 
allowed 
\emph default 
set of 
\emph on 
accent
\emph default 
.
 When 
\shape up 
you enter the 
\emph on 
accent char 
\emph default 
sequence, 
\emph on 
result
\emph default 
  is produced.
 If such a declaration does not exist in
\family default 
 the
\family sans 
 
\family typewriter 
.kmap
\family default 
\shape default 
 file and yo
\family roman 
u enter 
\emph on 
accent  char
\emph default 
, you get 
\emph on 
accent_key char 
\emph default 
 where 
\emph on 
accent_key 
\emph default 
 is the first arg
\family default 
ument of the 
\family typewriter 
\shape up 

\backslash 
kmod
\family default 
\shape default 
 declaration.
 
\layout Standard

The following command produces causes �i to be produced when you enter acute-i
 ('i):
\layout LyX-Code


\backslash 
kxmod acute i "
\backslash 

\backslash 
'{
\backslash 

\backslash 
i}"
\layout List
\labelwidthstring 00.00.0000


\family sans 
\shape up 
kcomb
\family default 
\shape default 
 Combine two accent characters
\layout LyX-Code


\backslash 
kcomb 
\family roman 
\emph on 
accent1 accent2 allowed
\layout Standard

This one is getting pretty esoteric.
 It allows you to combine the effect
\family roman 
 of 
\emph on 
accent1
\emph default 
 and 
\emph on 
accent2
\emph default 
 (in that order!) on 
\emph on 
allowed
\emph default 
 chars.
 The keystrokes for 
\emph on 
accent1
\emph default 
 and 
\emph on 
accent2
\emph default 
 must have be
\family default 
en set with a 
\family typewriter 
\shape up 

\backslash 
kmod
\family default 
\shape default 
 command at 
\family roman 

\emph on 
previous
\emph default 
 point in the 
\family default 
file.
 
\layout Standard

Consider this example from the 
\family typewriter 
\shape up 
greek.kmap
\family default 
\shape default 
 file:
\layout LyX-Code


\backslash 
kmod ; acute aeioyvhAEIOYVH 
\backslash 
kmod : umlaut iyIY 
\backslash 
kcomb acute umlaut iyIY
\layout Standard

This allows you to press 
\family sans 
\shape up 
;:i
\family default 
\shape default 
 and get the effect of 
\family typewriter 
\shape up 

\backslash 
'{
\backslash 
"{i}}
\family default 
\shape default 
.
 
\family roman 
\shape up 
A backspace 
\family default 
\shape default 
in this case cancels the last dead key, so if you press
\family sans 
\shape up 
 ;: Backspace i 
\family default 
\shape default 
you get 
\family typewriter 
\shape up 

\backslash 
'{i}
\family default 
\shape default 
.
\layout Subsection

The .cdef File
\layout Standard

After the 
\family typewriter 
\shape up 
.kmap
\family sans 
 
\family default 
\shape default 
mapping is performed, a 
\family typewriter 
\shape up 
.cde
\shape default 
f
\family default 
 file maps the strings that the symbols generate to characters in the current
 font.
 The LyX distribution currently includes at least the 
\family typewriter 
\shape up 
iso8859-1.cdef
\family default 
\shape default 
 and 
\family typewriter 
\shape up 
iso8859-2.cdef
\family default 
\shape default 
 files.
\layout Standard

In general the 
\family typewriter 
\shape up 
.cdef
\family sans 
 
\family default 
\shape default 
file is a sequence of declarations of the form
\layout LyX-Code


\family roman 
\emph on 
char_index_in_set
\emph default 
 
\emph on 

\protected_separator 
string
\layout Standard

For example, in order to map 
\family sans 
\shape up 

\backslash 
'{e}
\family default 
\shape default 
 to the corresponding character in the iso-8859-1 set (233), the following
 declaration is used
\layout LyX-Code

233 "
\backslash 

\backslash 
'{e}"
\layout Standard

with 
\family typewriter 

\backslash 

\family default 
 and 
\family typewriter 
"
\family default 
 being escap
\family roman 
ed in 
\emph on 
string
\emph default 
.
 Note that 
\family default 
the same character can apply to more than one string.
 In the 
\family typewriter 
i
\shape up 
so-8859-7.cdef
\family sans 
 
\family default 
\shape default 
file you have
\layout LyX-Code

192 "
\backslash 

\backslash 
'{
\backslash 

\backslash 

\backslash 
"{i}}"
\newline 
192 "
\backslash 

\backslash 

\backslash 
"{
\backslash 

\backslash 
'{i}}"
\layout Standard

If LyX cannot find a mapping for the string produced by the keystroke or
 a deadkey sequence, it will check if it looks like an accented char and
 try to draw an accent over the character on screen.
\layout Subsection

Dead Keys
\layout Standard

There is a second way to add support for international characters through
 so-called dead-keys.
 A dead-key works in combination with a letter to produce an accented character.
 Here, we'll explain how to create a really simple dead-key to illustrate
 how they work.
\layout Standard

Suppose you happen to need the circumflex character, 
\begin_inset Quotes eld
\end_inset 

\i \^{}

\begin_inset Quotes erd
\end_inset 

.
 You could bind the 
\family sans 
^
\family default 
-key [a.k.a.
\protected_separator 

\family sans 
Shift-6
\family default 
] to the LyX command 
\family typewriter 
accent-circumflex
\family default 
 in your 
\family typewriter 
lyxrc
\family default 
 file.
 Now, whenever you type the 
\family sans 
^
\family default 
-key followed by a letter, that letter will have a circumflex accent on
 it.
 For example, the sequence 
\begin_inset Quotes eld
\end_inset 


\family sans 
^e
\family default 

\begin_inset Quotes erd
\end_inset 

 produces the letter: 
\begin_inset Quotes eld
\end_inset 


\begin_inset Quotes erd
\end_inset 

.
 If you tried to type 
\begin_inset Quotes eld
\end_inset 


\family sans 
^t
\family default 

\begin_inset Quotes erd
\end_inset 

, however, LyX will complain with a beep, since a 
\begin_inset Quotes eld
\end_inset 


\family sans 
t
\family default 

\begin_inset Quotes erd
\end_inset 

 never takes a circumflex accent.
 Hitting 
\family sans 
Space
\family default 
 after a dead-key produces the bare-accent.
 Please note this last point! If you bind a key to a dead-key, you'll need
 to rebind the character on that key to yet another key.
 Binding the 
\family sans 
,-key
\family default 
 to a cedilla is a bad idea, since you'll only get cedillas instead of commas.
\layout Standard

One common way to bind dead-keys is to use 
\family sans 
Meta-
\family default 

\family sans 
Ctrl-
\family default 
, and 
\family sans 
Shift-
\family default 
 in combination with an accent, like 
\begin_inset Quotes eld
\end_inset 


\family sans 
~
\family default 

\begin_inset Quotes erd
\end_inset 

 or 
\begin_inset Quotes eld
\end_inset 


\family sans 
,
\family default 

\begin_inset Quotes erd
\end_inset 

 or 
\begin_inset Quotes eld
\end_inset 


\family sans 
^
\family default 

\begin_inset Quotes erd
\end_inset 

.
 Another way involves using 
\family typewriter 
xmodmap
\family default 
 and 
\family typewriter 
xkeycaps
\family default 
 [remember them from section?] to set up the special 
\family typewriter 
Mode_Switch
\family default 
 key.
 The 
\family typewriter 
Mode_Switch
\family default 
 acts in some ways just like 
\family sans 
Shift
\family default 
 and permits you to bind keys to accented characters.
 You can also turn keys into dead-keys by binding them to something like
 
\family typewriter 
usldead_cedilla
\family default 
 and then binding this symbolic key to the corresponding LyX command.
\begin_float footnote 
\layout Standard

Note from 
\noun on 
John Weiss
\noun default 
: This is exactly what I do in my 
\family typewriter 
~/.lyx/lyxrc
\family default 
 and my 
\family typewriter 
~/.xmodmap
\family default 
 files.
 I have my 
\family sans 
Scroll
\protected_separator 
Lock
\family default 
 key set up as 
\family typewriter 
Mode_Shift
\family default 
 and a bunch of these 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
usldead_*
\family default 

\begin_inset Quotes erd
\end_inset 

 symbolic keys bound such things as 
\family sans 
Scroll
\protected_separator 
Lock-^
\family default 
 and 
\family sans 
Scroll
\protected_separator 
Lock-~
\family default 
.
 This is how I produce my accented characters.
\end_float 
 You can make just about anything into the 
\family typewriter 
Mode_Switch
\family default 
 key: One of the 
\family sans 
Ctrl-
\family default 
 keys, a spare function key, etc.
 As for the LyX commands that produce accents, check the entry for 
\family typewriter 
accent-acute
\family default 
 in the 
\emph on 
Reference Manual
\emph default 
.
 You'll find the complete list there.
\layout Subsection

Saving your Language Configuration
\layout Standard


\begin_inset LatexCommand \label{sec:savlang}

\end_inset 

You can edit your 
\family typewriter 
lyxrc
\family default 
 file so that your desired language environment is automatically configured
 when LyX starts up.
 This section describes 
\family typewriter 
\shape up 
lyxrc
\family default 
\shape default 
 commands to specify:
\layout Itemize

default, primary, and secondary keymaps
\layout Itemize

character set
\layout Standard

Look at your 
\family typewriter 
\shape up 
lyxrc
\family default 
\shape default 
 file for the various examples of how to configure it.
 In particular, you can set a keymap like this:
\layout LyX-Code


\backslash 
bind "american" "keymap-primary"
\layout Standard

a dead-key like this:
\layout LyX-Code


\backslash 
bind "M-,"  "accent-cedilla"
\layout Standard

and a font-mapping (
\family typewriter 
\shape up 
.cdef
\family default 
\shape default 
 file) like this:
\layout LyX-Code

# The norm for the screen fonts.
\layout LyX-Code

# The default is iso8859-1.
\layout LyX-Code


\backslash 
font_norm iso8859-2
\layout Chapter

The LyX-textclass format
\begin_inset LatexCommand \label{chap:textclass}

\end_inset 


\layout Standard

This section describes the LyX textclass format for LyX 1.0.
 Later versions of LyX will possibly support an enhanced format.
\layout Standard

This is not a tutorial, but a short reference.
 When you plan to realize a new textclass, it might be very helpful to look
 at the example textclasses contributed with LyX.
 If you use a nice LaTeX textclass that might be of interest for others,
 too, and have a nice corresponding LyX textclass, feel free to contribute
 the stuff to us, so we may put it into the distribution.
\layout Standard

All the tags described in this chapter are case-insensitive; this means
 that 
\family typewriter 
Style
\family default 

\family typewriter 
style
\family default 
 and 
\family typewriter 
StYlE
\family default 
 are really the same command.
 The possible values are printed in brackets after the feature's name.
 The default value if a feature isn't specified inside a textclass-description
 is typeset 
\family typewriter 
\emph on 
emphasized
\family default 
\emph default 
.
 If the argument has a datatype like 
\begin_inset Quotes eld
\end_inset 

string
\begin_inset Quotes erd
\end_inset 

 or 
\begin_inset Quotes eld
\end_inset 

float
\begin_inset Quotes erd
\end_inset 

, the default is shown like this: 
\family typewriter 
float=
\emph on 
default
\family default 
\emph default 
.
\layout Section

Declaring a textclass
\layout Standard

Lines beginning with a 
\family typewriter 
#
\family default 
 are comments.
 There is one exception to this rule: all textclass files should begin with
 lines like:
\layout LyX-Code


\size small 
#% Do not delete the line below; configure depends on this
\newline 
#
\protected_separator 
 
\backslash 
DeclareLaTeXClass{article}
\layout Standard

As stated the second line is used when you configure LyX.
 The textclass file is read by the LaTeX script 
\family typewriter 
chkconfig.ltx
\family default 
, in a special mode where 
\family typewriter 
#
\family default 
 is ignored.
 The first line is just a LaTeX comment, and the second one contains the
 declaration of the textclass.
 If these lines appear in a file named 
\family typewriter 
article.layout
\family default 
, then they define a textclass of name 
\family typewriter 
article
\family default 
 (the name of the textclass file) which uses the LaTeX documentclass 
\family typewriter 
article.cls
\family default 
 (the default is to use the same name as the textclass).
 The string 
\begin_inset Quotes eld
\end_inset 

article
\begin_inset Quotes erd
\end_inset 

 that appears above is used as a description of the textclass in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
D
\bar default 
ocument
\family default 
 popup.
\layout Standard

Let's assume that you wrote your own textclass that uses the 
\family typewriter 
article.cls
\family default 
 documentclass, but where you changed the appearance of the section headings.
 If you put it in a file 
\family typewriter 
myarticle.layout
\family default 
, the header of this file should be:
\layout LyX-Code


\size small 
#% Do not delete the line below; configure depends on this
\newline 
#
\protected_separator 
 
\backslash 
DeclareLaTeXClass[article]{article (with my own headings)}
\layout Standard

This declares a textclass 
\family typewriter 
myarticle
\family default 
, associated with the LaTeX documentclass 
\family typewriter 
article.cls
\family default 
 and described as 
\begin_inset Quotes eld
\end_inset 

article (with my own headings)
\begin_inset Quotes erd
\end_inset 

.
 If your textclass depends on several packages, you can declare it as:
\layout LyX-Code


\size small 
#% Do not delete the line below; configure depends on this
\newline 
#
\protected_separator 
 
\backslash 
DeclareLaTeXClass[article,foo.sty]{article (with my own headings)}
\layout Standard

This indicates that your textclass uses the foo.sty package.
 Finally, it is also possible to declare classes for SGML code.
 A typical declaration will be like
\layout LyX-Code


\size small 
#% Do not delete the line below; configure depends on this
\newline 

\backslash 
DeclareSGMLClass{SGML (LinuxDoc)}
\layout Standard

Note 
\family typewriter 

\backslash 
DeclareSGMLClass
\family default 
 can also be given an optional parameter declaring the name of the document
 class (but not a list).
\layout Standard

When the textclass has been modified to your taste, all you have to do is
 to copy it either in 
\family typewriter 
LyXDir/layouts/
\family default 
 or in 
\family typewriter 
UserDir/layouts
\family default 
 and run 
\family sans 
\bar under 
O
\bar default 
ptions->
\bar under 
R
\bar default 
econfigure
\family default 
.
 Then your new textclass should be available along with the others.
\layout Section

General textclass parameters
\layout Description


\family typewriter 
\series medium 
Columns
\family default 
\series default 
 [
\family typewriter 
\emph on 
1
\emph default 
, 2
\family default 
] Whether the class-default should have or two columns.
 Can be changed in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
D
\bar default 
ocument
\family default 
\emph on 
 
\emph default 
popup.
\layout Description


\family typewriter 
\series medium 
Sides
\family default 
\series default 
 [
\family typewriter 
\emph on 
1
\emph default 
, 2
\family default 
] Whether the class-default should be printing on one or both sides of the
 paper.
 Can be changed in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
D
\bar default 
ocument
\family default 
\emph on 
 
\emph default 
popup.
\layout Description


\family typewriter 
\series medium 
PageStyle
\series default 
 
\family default 
[
\family typewriter 
\emph on 
plain
\emph default 
, empty, headings
\family default 
] The class default pagestyle.
 Can be changed in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
D
\bar default 
ocument
\family default 
\emph on 
 
\emph default 
popup.
\layout Description


\family typewriter 
\series medium 
MaxCounter
\family default 
\series default 
 [
\family typewriter 
\emph on 
Counter_Chapter
\emph default 
, Counter_Section, Counter_Subsection, 
\newline 
Counter_Subsubsection, Counter_Paragraph, Counter_Subparagraph, Counter_EnumI,
 Counter_EnumII, Counter_EnumIII, Counter_EnumIV
\family default 
] The highest level of automatic enumeration.
 Useful values are 
\family typewriter 
Counter_Chapter
\family default 
 for a book or report and 
\family typewriter 
Counter_Section
\family default 
 for an article.
 If there is no enumeration needed at all, for example inside a letter class,
 
\family typewriter 
MaxCounter
\family default 
 should be set to 
\family typewriter 
Counter_EnumI
\family default 
.
 
\layout Description


\family typewriter 
\series medium 
ClassOptions\SpecialChar \ldots{}
End
\family default 
\series default 
 This section describes various global options supported by the document
 class.
 See Section
\protected_separator 

\begin_inset LatexCommand \ref{sec:classoptions}

\end_inset 

 for a description.
\layout Description


\family typewriter 
\series medium 
DefaultFont
\family default 
\series default 
 This is used to describe the default font of the document.
 See Section
\protected_separator 

\begin_inset LatexCommand \ref{sec:fonts}

\end_inset 

 for a description.
\layout Description


\family typewriter 
\series medium 
Preamble\SpecialChar \ldots{}
EndPreamble
\family default 
\series default 
 A set of macro definitions that will be output at the beginning of the
 LaTeX files.
 Use this for global definitions.
\layout Description


\family typewriter 
\series medium 
Input
\family default 
\series default 
 As its name implies, this command allows one to input another textclass
 definition file to avoid duplicating commands.
 Most standard textclass files, for example, input 
\family typewriter 
stdclass.inc
\family default 
, which contains most of the basic layouts.
\layout Description


\family typewriter 
\series medium 
NoStyle
\family default 
\series default 
 This command deletes an existing style.
 This is particularly useful when you want to suppress a layout that has
 be defined in an input file.
\layout Section


\family typewriter 
ClassOptions
\family default 
 section
\layout Standard


\begin_inset LatexCommand \label{sec:classoptions}

\end_inset 

The 
\family typewriter 
ClassOption
\family default 
 section can contain the following entries:
\layout Description


\family typewriter 
\series medium 
FontSize
\family default 
\series default 
 [
\family typewriter 
string="10|11|12"
\family default 
] The list of available font sizes for the document's main font, separated
 by 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
|
\family default 

\begin_inset Quotes erd
\end_inset 

.
\layout Description


\family typewriter 
\series medium 
PageStyle
\family default 
\series default 
 [
\family typewriter 
string="empty|plain|headings|fancy"
\family default 
] The list of available page styles, separated by 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
|
\family default 

\begin_inset Quotes erd
\end_inset 

.
\layout Description


\family typewriter 
\series medium 
Other
\family default 
\series default 
 [
\family typewriter 
string=""
\family default 
] Some document class options, separated by a comma, that will be added
 to the optional part of the 
\family typewriter 

\backslash 
documentclass
\family default 
 command.
\layout Section

Specific Layouts
\layout Standard

A layout description looks like this
\begin_float footnote 
\layout Standard

Note that this will either define a new layout or modify an existing one.
\end_float 
:
\layout LyX-Code

Style 
\family roman 
\emph on 
name
\layout LyX-Code


\protected_separator 
\SpecialChar \ldots{}

\layout LyX-Code

End
\layout Standard

where the following commands are allowed:
\layout Standard


\latex latex 

\backslash 
begin{sloppypar}
\layout Description


\family typewriter 
\series medium 
CopyStyle
\family default 
\series default 
 This is used to copy all the features of an existing layout into the current
 one.
 
\layout Description


\family typewriter 
\series medium 
Margin
\family default 
\series default 
 [
\family typewriter 
\emph on 
Static
\emph default 
, Manual, Dynamic, First_Dynamic, Right_Address_Box
\family default 

\newline 
The kind of margin that the layout has on the left side.
 
\family typewriter 
Static
\family default 
 means just a static margin.
 
\family typewriter 
Manual
\family default 
 means that the left margin depends on the string entered in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
P
\bar default 
aragraph
\family default 
 popup.
 This is used to typeset nice lists without tabulators.
 
\family typewriter 
Dynamic
\family default 
 means that the margin depends on the size of the label.
 This is used for automatic enumerated headlines.
 It is obvious that the headline 
\begin_inset Quotes eld
\end_inset 

5.4.3.2.1 Very long headline
\begin_inset Quotes erd
\end_inset 

 must have a wider left margin (as wide as 
\begin_inset Quotes eld
\end_inset 

5.4.3.2.1
\begin_inset Quotes erd
\end_inset 

) than 
\begin_inset Quotes eld
\end_inset 

3.2 Very long headline
\begin_inset Quotes erd
\end_inset 

, even if other word processors are not able to do this.
 
\family typewriter 
First_Dynamic
\family default 
 is similar, but only the very first row of the paragraph is dynamic, while
 the others are static.
 Used for example for descriptions.
 
\family typewriter 
Right_Address_Box
\family default 
 means the margin is chosen in a way that the longest row of this paragraph
 fits to the right margin.
 Used to typeset an address on the very right of the page.
\layout Description


\family typewriter 
\series medium 
LatexType
\family default 
\series default 
 [
\family typewriter 
\emph on 
Paragraph
\emph default 
, Command, Environment, Item_Environment,
\family default 
 
\family typewriter 
List_Environment
\family default 
] How the layout should be translated into LaTeX.
 
\family typewriter 
Paragraph
\family default 
 means nothing special.
 
\family typewriter 
Command
\family default 
 means 
\family typewriter 

\backslash 

\emph on 
LatexName
\emph default 
{\SpecialChar \ldots{}
}
\family default 
 and 
\family typewriter 
Environment
\family default 
 means 
\family typewriter 

\backslash 
begin{
\emph on 
LatexName
\emph default 
}\SpecialChar \ldots{}

\backslash 
end{
\emph on 
LatexName
\emph default 
}
\family default 
.
 
\family typewriter 
Item_Environment
\family default 
 is the same as 
\family typewriter 
Environment
\family default 
, except that a 
\family typewriter 

\backslash 
item
\family default 
 is generated for each paragraph of this environment.
 
\family typewriter 
List_Environment
\family default 
 is the same as 
\family typewriter 
Item_Environment
\family default 
, except that 
\family typewriter 
LabelWidthString
\family default 
 is passed as an argument to the environment.
 
\family typewriter 
LabelWidthString
\family default 
 can be defined in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
P
\bar default 
aragraph
\family default 
 popup.
 
\layout Description


\family typewriter 
\series medium 
InTitle
\series default 
 [1, 0] 
\family default 
If 1, marks the layout as needing a 
\family typewriter 

\backslash 
maketitle
\family default 
 afterwards.
 
\layout Description


\family typewriter 
\series medium 
LatexName
\family default 
\series default 
 The name of the corresponding LaTeX stuff.
 Either the environment or command name.
\layout Description


\family typewriter 
\series medium 
LatexParam
\family default 
\series default 
 The optional parameter for the corresponding 
\family typewriter 
\series medium 
LatexName
\family default 
\series default 
 stuff.
 This parameter cannot be changed from within LyX.
\layout Description


\family typewriter 
\series medium 
NextNoIndent
\family default 
\series default 
 [
\family typewriter 
1, 
\emph on 
0
\family default 
\emph default 
] Whether the following Paragraph is allowed to indent its very first row.
 
\family typewriter 
1
\family default 
 means that it is not allowed to do so, 
\family typewriter 
0
\family default 
 means it could do so if it wants to.
\layout Description


\family typewriter 
\series medium 
ParIndent
\family default 
\series default 
 [
\family typewriter 
string=""
\family default 
] The indent of the very first line of a paragraph.
 The argument is passed as a string.
 For example 
\family typewriter 
"MM"
\family default 
 means that the paragraph is indented with the width of 
\family typewriter 
"MM"
\family default 
 in 
\family typewriter 
the
\family default 
 normal font.
 This way was chosen so that the look is the same with each used screen
 font.
 The 
\family typewriter 
Parindent
\family default 
 will be fixed for a certain layout.
 The exception is Standard layout, since the indentation of a Standard layout
 paragraph can be prohibited with 
\family typewriter 
NextNoIndent
\family default 
.
 Also, Standard layout paragraphs inside environments use the 
\family typewriter 
Parindent
\family default 
 of the environment, not their native one.
 For example Standard paragraphs inside an enumeration are not indented.
\layout Description


\family typewriter 
\series medium 
Parskip
\family default 
\series default 
 [
\family typewriter 
float=0
\family default 
] LyX allows to choose either 
\begin_inset Quotes eld
\end_inset 

indent
\begin_inset Quotes erd
\end_inset 

 or 
\begin_inset Quotes eld
\end_inset 

skip
\begin_inset Quotes erd
\end_inset 

 to typeset a document.
 When 
\begin_inset Quotes eld
\end_inset 

indent
\begin_inset Quotes erd
\end_inset 

 is chosen, this value is completely ignored.
 When 
\begin_inset Quotes eld
\end_inset 

skip
\begin_inset Quotes erd
\end_inset 

 is chosen, the parindent of a LaTeXtype 
\begin_inset Quotes eld
\end_inset 

Paragraph
\begin_inset Quotes erd
\end_inset 

 layout is ignored and all paragraphs are additionally separated by this
 parskip argument.
 The vertical space is calculated with 
\family typewriter 
value*DefaultHeight()
\family default 
 where 
\family typewriter 
DefaultHeight()
\family default 
 is the height of a row with the normal font.
 This way, the look stays the same with different screen fonts.
\layout Description


\family typewriter 
\series medium 
TopSep
\family default 
\series default 
 [
\family typewriter 
float=0
\family default 
] The vertical space with which the very first of a chain of paragraphs
 with this layout is separated from the previous paragraph.
 If the previous paragraph has another layout, the separations are not simply
 added, but the maximum is taken.
\layout Description


\family typewriter 
\series medium 
BottomSep
\family default 
\series default 
 [
\family typewriter 
float=0
\family default 
] The same like 
\family typewriter 
TopSep
\family default 
 for the very last paragraph.
\layout Description


\family typewriter 
\series medium 
Parsep
\family default 
\series default 
 [
\family typewriter 
float=0
\family default 
] The vertical space between two paragraphs of this layout.
\layout Description


\family typewriter 
\series medium 
Itemsep
\family default 
\series default 
 [
\family typewriter 
float=0
\family default 
] This is an extra space between the paragraphs of an environment layout.
 If you put other layouts into an environment, each is separated with the
 environment's 
\family typewriter 
Parsep
\family default 
.
 But the whole items of the environment are additionally separated with
 this 
\family typewriter 
Itemsep
\family default 
.
 
\layout Description


\family typewriter 
\series medium 
LeftMargin
\family default 
\series default 
 [
\family typewriter 
string=""
\family default 
] If you put layouts into environments, the leftmargins are not simply added,
 but added with a factor 
\begin_inset Formula \( \frac{4}{depth+4} \)
\end_inset 

.
 Note that this parameter is also used when the border is defined as 
\family typewriter 
Manual
\family default 
 or 
\family typewriter 
Dynamic
\family default 
.
 Then it is added to the manual or dynamic border.
 
\layout Description


\family typewriter 
\series medium 
RightMargin
\family default 
\series default 
 [
\family typewriter 
string=""
\family default 
] Similar to 
\family typewriter 
Left
\family default 
Margin.
\layout Description


\family typewriter 
\series medium 
Labeltype
\family default 
\series default 
 [
\family typewriter 
\emph on 
No_Label
\emph default 
, Manual, Static, Top_Environment, Centered_Top_Environment, Sensitive,
 Counter_Chapter, Counter_Section, Counter_Subsection, Counter_Subsubsection,
 Counter_Paragraph, Counter_Subparagraph, Counter_EnumI, Counter_EnumII,
 Counter_EnumIII, Counter_EnumIV
\family default 

\family typewriter 
Manual
\family default 
 means the label is the very first word (up to the first real blank).
 
\family typewriter 
Static
\family default 
 means it is defined in the layout (see 
\family typewriter 
LabelString
\family default 
).
 
\family typewriter 
Top_Environment
\family default 
 and 
\family typewriter 
Centered_Top_Environment
\family default 
 are special cases of 
\family typewriter 
Static
\family default 
.
 The label will be printed above the paragraph, but only at the top of an
 environment or the top of a chain of paragraphs with this layout.
 Usage is for example the 
\family sans 
Abstract
\family default 
 layout or the 
\family sans 
Bibliography
\family default 
 layout.
 This is also the case for 
\family typewriter 
Manual
\family default 
 labels with latex type 
\family typewriter 
Environment
\family default 
, in order to make layouts for theorems work correctly.
 
\family typewriter 
Sensitive
\family default 
 is a special case for the caption-labels 
\begin_inset Quotes eld
\end_inset 

Figure
\begin_inset Quotes erd
\end_inset 

 and 
\begin_inset Quotes eld
\end_inset 

Table
\begin_inset Quotes erd
\end_inset 

.
 
\family typewriter 
Sensitive
\family default 
 means the (hardcoded) label string depends on the kind of float.
 The 
\family typewriter 
Counter_xxx
\family default 
 label types should be self explanatory.
\layout Description


\family typewriter 
\series medium 
Labelsep
\family default 
\series default 
 [
\family typewriter 
string=""
\family default 
] The horizontal space between the label and the text body.
 Only used for labels that are not above the text body.
\layout Description


\family typewriter 
\series medium 
LabelBottomsep
\family default 
\series default 
 [float=0] The vertical space between the label and the text body.
 Only used for labels that are above the text body (
\family typewriter 
Top_Environment
\family default 

\family typewriter 
Centered_Top_Environment
\family default 
).
\layout Description


\family typewriter 
\series medium 
LabelString
\family default 
\series default 
 [
\family typewriter 
string=""
\family default 
] The string used for a label with a 
\family typewriter 
Static
\family default 
 labeltype.
 When the border is 
\family typewriter 
Manual
\family default 
 this string is also used as a suggestion for the 
\family typewriter 
LabelWidthString
\family default 
 that can be set in the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
P
\bar default 
aragraph
\family default 
 popup.
 When the labeltype is 
\family typewriter 
Counter_
\emph on 
xxx
\family default 
\emph default 
, this string is prepended to the counter.
\layout Description


\family typewriter 
\series medium 
Align
\family default 
\series default 
 [
\family typewriter 
\emph on 
block
\emph default 
, left, right, center
\family default 
] Paragraph alignment.
\layout Description


\family typewriter 
\series medium 
AlignPossible
\family default 
\series default 
 [
\family typewriter 
\emph on 
block
\emph default 
, left, right, center
\family default 
] A comma separated 
\emph on 
list
\emph default 
 of possible aligns.
 Some LaTeX styles prohibit certain alignments, since those wouldn't make
 sense.
 For example a right-aligned or centered enumeration isn't possible.
\layout Description


\family typewriter 
\series medium 
Fill_Top
\family default 
\series default 
 [
\family typewriter 
\emph on 
0
\emph default 
,1
\family default 
] With this parameter the 
\family sans 
Fill
\family default 
 value of the 
\begin_inset Quotes eld
\end_inset 

Vertical space above
\begin_inset Quotes erd
\end_inset 

 list of the 
\family sans 
\bar under 
L
\bar default 
ayout->
\bar under 
P
\bar default 
aragraph
\family default 
 popup can be set when initializing a paragraph with this layout
\begin_float footnote 
\layout Standard


\emph on 
Note from Jean-Marc: 
\emph default 
I'm not sure that this setting has much use, and it should probably be removed
 in later versions.
\end_float 
.
 
\layout Description


\family typewriter 
\series medium 
Fill_Bottom
\family default 
\series default 
 [
\family typewriter 
\emph on 
0
\emph default 
,1
\family default 
] Similar to 
\family typewriter 
Fill_Top
\family default 
.
\layout Description


\family typewriter 
\series medium 
NeedProtect
\family default 
\series default 
 [
\family typewriter 
\emph on 
0
\emph default 
,1
\family default 
] Whether fragile commands in this layout should be 
\family typewriter 

\backslash 
protect
\family default 
'ed.
\layout Description


\family typewriter 
\series medium 
Newline
\family default 
\series default 
 [
\family typewriter 
0, 
\emph on 
1
\family default 
\emph default 
] Whether newlines are translated into LaTeX newlines (
\family typewriter 

\backslash 

\backslash 

\family default 
) or not.
 The translation can be switched off to allow more comfortable LaTeX editing
 inside LyX.
 
\layout Description


\family typewriter 
\series medium 
FreeSpacing
\family default 
\series default 
 [
\family typewriter 
\emph on 
0
\emph default 
, 1
\family default 
] Usually LyX doesn't allow you to insert more than one space between words,
 since a space is considered as the separation between two words, not a
 character or symbol of its own.
 This is a very fine thing but sometimes annoying, for example when typing
 program code or plain LaTeX code.
 For this reason, 
\family typewriter 
FreeSpacing
\family default 
 can be enabled.
 Note that LyX will create protected blanks for the additional blanks when
 in another mode than LaTeX-mode.
\layout Description


\family typewriter 
\series medium 
KeepEmpty
\family default 
\series default 
 [
\family typewriter 
\emph on 
0
\emph default 
, 1
\family default 
] Usually LyX does not allow you to leave a paragraph empty, since it would
 lead to empty LaTeX output.
 There are some cases where this could be desirable however: in a letter
 template, the required fields can be provided as empty fields, so that
 people do not forget them; in some special classes, a layout can be used
 as some kind of break, which does not contain actual text.
\layout Description


\family typewriter 
\series medium 
Spacing
\family default 
\series default 
 [
\family typewriter 
\emph on 
single
\emph default 
, onehalf, double, other 
\family default 
\emph on 
value
\emph default 
] This defines what the default spacing should be in the layout.
 The arguments 
\family typewriter 
single
\family default 

\family typewriter 
onehalf
\family default 
 and 
\family typewriter 
double
\family default 
 correspond respectively to a multiplier value of 1, 1.25 and 1.667.
 If you specify the argument 
\family typewriter 
other
\family default 
, then you should also provide a numerical argument which will be the actual
 multiplier value.
 Note that, contrary to other parameters, 
\family typewriter 
Spacing
\family default 
 implies the generation of specific LaTeX code, using the package 
\family typewriter 
setspace.sty
\family roman 
.
\layout Description


\family typewriter 
\series medium 
Font
\family default 
\series default 
 The font used for both the text body 
\emph on 
and
\emph default 
 the label.
 See section
\protected_separator 

\begin_inset LatexCommand \ref{sec:fonts}

\end_inset 

.
 Note that defining this font automatically defines the 
\family typewriter 
LabelFont
\family default 
 to the same value.
\layout Description


\family typewriter 
\series medium 
TextFont
\family default 
\series default 
 The font used for the text body .
 See section
\protected_separator 

\begin_inset LatexCommand \ref{sec:fonts}

\end_inset 

.
\layout Description


\family typewriter 
\series medium 
LabelFont
\family default 
\series default 
 The font used for the label.
 See section
\protected_separator 

\begin_inset LatexCommand \ref{sec:fonts}

\end_inset 

.
\layout Description


\family typewriter 
\series medium 
Preamble\SpecialChar \ldots{}
EndPreamble
\family default 
\series default 
 A set of macro definitions that will be output at the beginning of the
 LaTeX files when the layout is used.
 Use this to define the macros needed by this particular layout.
\layout Standard


\latex latex 

\backslash 
end{sloppypar}
\layout Section

Font description
\layout Standard


\begin_inset LatexCommand \label{sec:fonts}

\end_inset 

A font description looks like that:
\layout LyX-Code

Font
\family roman 
\emph on 
 or 
\family default 
\emph default 
LabelFont
\layout LyX-Code


\protected_separator 

\emph on 
\SpecialChar \ldots{}

\layout LyX-Code

EndFont
\layout Standard

and the following commands are available:
\layout Description


\family typewriter 
\series medium 
Family
\family default 
\series default 
 [
\family typewriter 
\emph on 
Roman
\emph default 
, Sans, Typewriter
\family default 

\layout Description


\family typewriter 
\series medium 
Series
\family default 
\series default 
 [
\family typewriter 
\emph on 
Medium
\emph default 
, Bold
\family default 

\layout Description


\family typewriter 
\series medium 
Shape
\family default 
\series default 
 [
\family typewriter 
\emph on 
Up
\emph default 
, Italic, SmallCaps
\family default 

\layout Description


\family typewriter 
\series medium 
Size
\family default 
\series default 
 [
\family typewriter 
tiny, small, 
\emph on 
normal
\emph default 
, large, larger, largest, huge, giant
\family default 
]
\layout Description


\family typewriter 
\series medium 
Color
\series default 
 
\series bold 
[
\series default 
\emph on 
none
\emph default 
, black, white, red, green, blue, cyan, magenta, yellow
\series bold 
]
\layout Description


\family typewriter 
\series medium 
Latex
\family default 
\series default 
 [
\family typewriter 
\emph on 
no_latex
\emph default 
, latex
\family default 

\family typewriter 
no_latex
\family default 
 means LyX will translate everything into LaTeX.
 
\family typewriter 
Latex
\family default 
 means a red screenprint and no translation at all.
\layout Section

Creating Templates
\begin_inset LatexCommand \label{sec:templates}

\end_inset 


\layout Standard

Templates are created just like usual documents.
 The only difference is that usual documents contain all possible settings,
 including the fontscheme and the papersize.
 Usually a user doesn't want a template to overwrite his defaults in these
 cases.
 For that reason, the designer of a template should remove the corresponding
 commands like 
\family typewriter 

\backslash 
fontscheme
\family default 
 or 
\family typewriter 

\backslash 
papersize
\family default 
 from the template LyX file.
 This can be done with any simple text-editor, for example 
\family typewriter 
vi
\family default 
 or 
\family typewriter 
xedit
\family default 
.
 
\layout Standard

Put the edited template files you create in 
\family typewriter 
UserDir/templates/
\family default 
, copy the ones you use from the global template directory in 
\family typewriter 
LyXDir/templates/
\family default 
 to the same place, and redefine the template-directory in 
\family typewriter 
lyxrc
\family default 
 using the 
\family typewriter 

\backslash 
template_path
\family default 
 command.
\layout Chapter

A Printer Tutorial
\begin_inset LatexCommand \label{chap:printer}

\end_inset 


\layout Section

Introduction
\layout Standard

This chapter describes how it is possible to setup a printer under a Unix
 system, so that it can be used with LyX.
 
\size normal 
If you have a Linux system, and need to set up your printer, 
\size default 
you might also want to read 
\size normal 
the file 
\family typewriter 
Printing-HOWTO
\family default 
 [often in the directory 
\family typewriter 
/usr/doc/FAQ/HOWTO/
\family default 
 or 
\family typewriter 
/usr/doc/HOWTO/
\family default 
 depending on your system].
 Also, you will need to install the Ghostscript package from your Linux
 CD-ROM, if you never did so.
\layout Standard


\size normal 
Some Linux distributions now come with so-called 
\begin_inset Quotes eld
\end_inset 

magic filters
\begin_inset Quotes erd
\end_inset 

 and automatically set up your system to use them.
 You can use magic filters in place of or in addition to what we describe
 below, but it may be more difficult to take advantage of all of your printer's
 features.
 If your Linux distribution comes with some insta-setup tool for the printer,
 you might just want to use that, then look at the 
\family typewriter 
\size default 
Printing-HOWTO
\family default 
\size normal 
 when you're ready to customize things.
\layout Standard


\size normal 
So if you're feeling adventurous, or have no other choice, read on!
\layout Section

The 
\family typewriter 
/etc/printcap
\family default 
 File
\layout Subsection

Overview
\layout Standard


\size normal 
The 
\family typewriter 
/etc/printcap
\family default 
 file is how you tell Linux about your printer.
 Each entry defines a printer, giving it a name that you and other users
 call it by, and telling Linux how to handle output to it.
 You can actually have multiple 
\begin_inset Quotes eld
\end_inset 

printers
\begin_inset Quotes erd
\end_inset 

 on your system that all access the same physical printer, but use different
 features to do so.
\begin_float footnote 
\layout Standard

Note from 
\noun on 
John Weiss
\noun default 
: I do this with my Epson Stylus Color IIs.
 Since you need to change print heads to use color on the Stylus IIs, I
 set up a separate printer, 
\family typewriter 
color
\family default 
, for printing color documents.
 I also created a 
\family typewriter 
draft
\family default 
 printer that uses lower print resolution and less-accurate printing features.
 So you see, there are lots of things you can do with the printcaps.
\end_float 

\size normal 
 Of course, you will need a printcap entry for each physical printer you
 have.
\layout Standard


\size normal 
Here's a sample 
\family typewriter 
/etc/printcap
\family default 
 file:
\layout LyX-Code


\size normal 
lp|Text on an Epson:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lp=/dev/lp1:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sd=/var/spool/lpd/lp:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/lp/errs:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:mx#0:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sh:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sf:
\newline 

\layout LyX-Code


\size normal 
draft|Postscript on an Epson Stylus Color IIs, 180dpi:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lp=/dev/lp1:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sd=/var/spool/lpd/draft:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/draft/errs:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:if=/var/spool/lpd/draft/draft.filter:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:mx#0:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sh:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sf:
\newline 

\layout LyX-Code


\size normal 
ps|Postscript on an Epson Stylus Color IIs, 360dpi:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lp=/dev/lp1:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sd=/var/spool/lpd/ps:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/ps/errs:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:if=/var/spool/lpd/ps/ps.filter:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:mx#0:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sh:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sf:
\layout Standard


\size normal 
Before we start explaining these heiroglyphs, we have an important message:
\layout Standard
\added_space_top 0.51cm \align center 

\size normal 
WARNING! WARNING! WARNING!
\layout Standard
\align center 

\size normal 
Use only one line between entries!!!
\layout Standard
\added_space_bottom 0.51cm \align center 

\size normal 
Make sure the line between entries is COMPLETELY BLANK!!!
\layout Standard


\size normal 
Even if you leave a space on the blank line between entries, weird things
 can happen, and the system will not parse your 
\family typewriter 
/etc/printcap
\family default 
 correctly.
\layout Standard


\size normal 
Take a look at one of the entries in the above example.
 Each part of the entry is followed by a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 character.
 The 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

 character at the end of each line tells Linux that the entry continues
 on the next line.
 Don't put anything after the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

, not even a space.
 The 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

 should come right after the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 of the last part of the entry on the line you're breaking.
\layout Standard


\size normal 
If you do choose to break up the 
\family typewriter 
printcap
\family default 
 entry into multiple lines, be sure to put a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 at the beginning of the 
\emph on 
text
\emph default 
 of the new line, after any space.
 For example, we could have written the first entry in the previous example
 as:
\layout LyX-Code


\size normal 
lp|Text:lp=/dev/lp1:sd=/var/spool/lpd/lp:lf=/var/spool/lpd/lp/errs:
\layout Standard


\size normal 
Notice that there is only one 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 between each part of the entry.
 If we wanted to break this entry into two lines:
\layout LyX-Code


\size normal 
lp|Text:lp=/dev/lp1:sd=/var/spool/lpd/lp:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/lp/errs:
\layout Standard


\size normal 
We break the line at a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 by adding a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

, starting a new line, adding some space, then adding a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 before continuing.
 It's customary to indent the next line a bit if you break up a 
\family typewriter 
printcap
\family default 
 entry into multiple lines.
\layout Standard


\size normal 
Now we'll explain each part of the 
\family typewriter 
/etc/printcap
\family default 
 entry.
 Note that there are other options you can add to an entry.
 We'll only cover the four basic ones here.
 See the man page for the 
\family typewriter 
printcap
\family default 
 file for additional information.
\layout Subsection

The Printer Name
\layout Standard


\size normal 
The first line of a 
\family typewriter 
printcap
\family default 
 entry is the printer name.
 It contains the printer name, followed by a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
|
\family default 

\begin_inset Quotes erd
\end_inset 

 character, followed by a text description of the printer, and ending, of
 course, with a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 character.
 For example:
\layout LyX-Code


\size normal 
draft|OurPrinter in Draft Mode:
\backslash 

\layout Standard


\size normal 
is a printer called 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
draft
\family default 

\begin_inset Quotes erd
\end_inset 

 with the description 
\begin_inset Quotes eld
\end_inset 

OurPrinter in Draft Mode
\begin_inset Quotes erd
\end_inset 

 [Notice the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

 at the end of the line, indicating that we'll continue the entry on a new
 line.] The name 
\family typewriter 
draft
\family default 
 is what you pass to many printing commands using the 
\family typewriter 
-P
\family default 
 option.
 [The 
\family typewriter 
lpr
\family default 
 program is such a command.]
\layout Standard


\size normal 
It's traditional to name your main PostScript� printer 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 and to call your text printer 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lp
\family default 

\begin_inset Quotes erd
\end_inset 

.
\layout Subsection

The Printer Device
\layout Standard


\size normal 
The next part of our sample 
\family typewriter 
printcap
\family default 
 entries identifies the device to print to.
 In all of the example entries, there is a line:
\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lp=/dev/lp1:
\backslash 

\layout Standard


\size normal 
[Again, notice the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

 at the end of the line, as well as the beginning 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
:
\family default 

\begin_inset Quotes eld
\end_inset 

 after the space we used to indent the text proper.]
\layout Standard


\size normal 
The tag 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lp=
\family default 

\begin_inset Quotes erd
\end_inset 

 takes the name of the printing device.
 In this case, it is 
\family typewriter 
/dev/lp1
\family default 
, the parallel port.
 There are printers that connect to the serial port.
 If you have one, you'd use 
\family typewriter 
/dev/ttyS0
\family default 
 for the first serial port, 
\family typewriter 
/dev/ttyS1
\family default 
 for the second, and so on.
 You'll also want to add other commands the the 
\family typewriter 
printcap
\family default 
 entry, such as the printer's baud rate.
 See the 
\family typewriter 
printcap
\family default 
 man page for more information.
\layout Standard


\size normal 
Most printers, however, use the parallel port.
 In addition, the printer port on 
\emph on 
most
\emph default 
 PC-compatible computers will be 
\family typewriter 
/dev/lp1
\family default 
.
 If you want to know why, look in this footnote.
\begin_float footnote 
\layout Standard

Why is 
\family typewriter 
/dev/lp1
\family default 
 and 
\emph on 
not 
\family typewriter 
/dev/lp0
\family default 
\emph default 
 the first printer port? It turns out that the I/O address of each parallel
 port is hard-coded into the Linux kernel.
 Address 
\family typewriter 
0x3BC
\family default 
 is 
\family typewriter 
/dev/lp0
\family default 
; address 
\family typewriter 
0x378
\family default 
 is 
\family typewriter 
/dev/lp1
\family default 
; and address 
\family typewriter 
0x278
\family default 
 is 
\family typewriter 
/dev/lp2
\family default 
.
 Since most PC-compatible computers assign the first parallel port to the
 I/O address 
\family typewriter 
0x378
\family default 
 by default, 
\family typewriter 
/dev/lp1
\family default 
 will be the parallel port on most systems.
\layout Standard

If you have more than one parallel port, the situation changes.
 Also, if you altered the I/O address of the parallel port for some reason,
 then one of the other 
\family typewriter 
lp
\family default 
 devices will point to your parallel port.
 Other systems may just simply be weird.
 In any case, you can go into DOS and check out which I/O address your parallel
 port has.
 Then you can use that address to figure out whether your parallel port
 is 
\family typewriter 
/dev/lp0
\family default 

\family typewriter 
/dev/lp1
\family default 
, or 
\family typewriter 
/dev/lp2
\family default 
.
\end_float 

\size normal 
 Your system may be different, however, so check to be sure which device
 is the parallel port.
\layout Subsection

The Spool Directory and Log File
\layout Standard


\size normal 
In addition to naming your printer and telling Linux which device it is,
 you'll also need a directory for print spooling.
 The tag 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
sd=
\family default 

\begin_inset Quotes erd
\end_inset 

 identifies the spool directory for the printer.
 It's also a good idea to have a log file for errors.
 The tag 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lf=
\family default 

\begin_inset Quotes erd
\end_inset 

 points to that.
\layout Standard


\size normal 
Most systems put all of the print spools into the directory 
\family typewriter 
/var/spool/lpd
\family default 
; some use only 
\family typewriter 
/var/spool
\family default 
.
 In any case, each printcap entry traditionally has its own spool directory
 named after the printer.
 You'll need to log on a 
\begin_inset Quotes eld
\end_inset 

root
\begin_inset Quotes erd
\end_inset 

 and make these directories yourself.
 You'll also need to change to ownership on these directories, so that their
 group is the 
\family typewriter 
daemon
\family default 
 group.
 You can do this with the command, 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
chgrp daemon 
\family default 
\emph on 
dirname
\emph default 

\begin_inset Quotes erd
\end_inset 

, where 
\emph on 
dirname
\emph default 
 is the name of the spool directory.
\layout Standard


\size normal 
For example, look at the entry for the printer 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 in the example.
 It contains the lines:
\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sd=/var/spool/lpd/ps:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/ps/errs:
\backslash 

\layout Standard


\size normal 
This indicates that the spool directory is 
\family typewriter 
/var/spool/lpd/ps
\family default 
 and that the log file is the file 
\family typewriter 
/var/spool/lpd/ps/errs
\family default 
.
 You should 
\begin_inset Quotes eld
\end_inset 

create
\begin_inset Quotes erd
\end_inset 

 this file using the command 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
touch errs
\family default 

\begin_inset Quotes erd
\end_inset 

 in the spool directory.
\layout Standard


\size normal 
Similarly, the entry for the printer 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lp
\family default 

\begin_inset Quotes erd
\end_inset 

 contains:
\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sd=/var/spool/lpd/lp:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/lp/errs:
\backslash 

\layout Standard


\size normal 
Again, the spool directory is 
\family typewriter 
/var/spool/lpd/lp
\family default 
 and the log file is 
\family typewriter 
/var/spool/lpd/lp/errs
\family default 
.
 
\layout Subsection

The Filter File
\layout Standard


\size normal 
Unlike 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lp
\family default 

\begin_inset Quotes erd
\end_inset 

, which simply passes text to the printer unformatted, the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
draft
\family default 

\begin_inset Quotes erd
\end_inset 

 and 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 printers need a filter [that's why they have an additional tag in them].
 The 
\family typewriter 
printcap
\family default 
 tag for the filter program is 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
if=
\family default 

\begin_inset Quotes erd
\end_inset 

 [stands for 
\family typewriter 
i
\family default 
nput 
\family typewriter 
f
\family default 
ilter, meaning input to the spool].
\layout Standard


\size normal 
There are actually several tags for filter programs, allowing you to specify
 a different filter for different purposes.
 You can also select different filters via options to 
\family typewriter 
lpr
\family default 
, but let's not get into that here.
\layout Standard


\size normal 
Let's look at the entry for the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 printer:
\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:if=/var/spool/lpd/ps/ps.filter:
\backslash 

\layout Standard


\size normal 
The file 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps.filter
\family default 

\begin_inset Quotes erd
\end_inset 

 is actually a shell script that resides in the spool directory for the
 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 printer.
 You could also specify the path and filename of a program; however, calling
 a program via a shell script allows you to specify command line options.
\layout Standard


\size normal 
All filters, whether an actual program or a shell script, should take their
 input from 
\family typewriter 
stdin
\family default 
 [the standard input stream] and send their output to 
\family typewriter 
stdout
\family default 
 [the standard output stream].
\layout Subsection

Additional Tags
\layout Standard


\size normal 
There are three additional things you should put in your 
\family typewriter 
printcap
\family default 
 entries.
 You can see them at the end of all three examples.
 They are:
\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:mx#0:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sh:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sf:
\layout Standard


\size normal 
The 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
mx#0
\family default 

\begin_inset Quotes erd
\end_inset 

 means 
\begin_inset Quotes eld
\end_inset 

don't limit the size of the file we can print.
\begin_inset Quotes erd
\end_inset 

 The 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
sf
\family default 

\begin_inset Quotes erd
\end_inset 

 prevents a form-feed from being sent after the document ends.
 Lastly, the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
sh
\family default 

\begin_inset Quotes erd
\end_inset 

 prevents a header page from being sent at the beginning of each job.
 You'll probably always want to add these to your 
\family typewriter 
printcap
\family default 
 entries.
\layout Section

Creating a Print Filter
\layout Subsection

Printing PostScript� Files Using Ghostscript
\layout Standard


\size normal 
The easiest way to make your printer understand PostScript� is by using
 the Ghostscript program as a print filter.
 There are probably other ways, but this is the most common.
 If, for some reason, you don't want to or can't use Ghostscript, you're
 on your own [see the 
\family typewriter 
Printing-HOWTO
\family default 
 for a start].
\layout Standard


\size normal 
The first thing you should do is install Ghostscript.
 There should be a version in your Linux distribution at the very least.
 If not, you can certainly get one from the Linux FTP archive 
\family typewriter 
sunsite.unc.edu
\family default 
.
 Once you've installed it, execute it using 
\layout LyX-Code


\size normal 
gs -h | more
\layout Standard


\size normal 
from the command line.
 This lists the available output devices and formats.
 Here's a list to help decipher what Ghostscript device name corresponds
 to which printer:
\layout Itemize


\size normal 
Apple Printers:
\begin_deeper 
\layout Description


\size normal 
appledmp Apple dot matrix printers
\layout Description


\size normal 
iwhi Imagewriter in high-res mode
\layout Description


\size normal 
iwlo Imagewriter in low-res mode
\layout Description


\size normal 
iwlq Imagewriter LQ in 
\size default 

\begin_inset Formula \( 320\times 216 \)
\end_inset 


\size normal 
 dpi mode
\end_deeper 
\layout Itemize


\size normal 
Canon Printers:
\begin_deeper 
\layout Description


\size normal 
bj10e BubbleJet BJ-10e
\layout Description


\size normal 
bj200 BubbleJet BJ-200
\layout Description


\size normal 
bjc600 Color BubbleJet BJC-600, BJC-4000 and BJC-70.
\begin_float footnote 
\end_deeper 
\layout Standard

Also good for Apple printers like the StyleWriter 2x00
\end_float 
\begin_deeper 
\layout Description


\size normal 
bjc800 Color BubbleJet BJC-800
\layout Description


\size normal 
lbp8 LBP-II8 laser printer
\layout Description


\size normal 
lips3 LIPS-III laser printer in CaPSL mode
\end_deeper 
\layout Itemize


\size normal 
DEC Printers:
\begin_deeper 
\layout Description


\size normal 
la50 LA50
\layout Description


\size normal 
la70 LA70
\layout Description


\size normal 
la70t LA70 with low-res text enhancement
\layout Description


\size normal 
la75 LA75
\layout Description


\size normal 
la75plus LA75 Plus
\layout Description


\size normal 
ln03 LN03
\layout Description


\size normal 
lj250 LJ250 color printer
\layout Description


\size normal 
declj250 Alternate LJ250 driver0
\end_deeper 
\layout Itemize


\size normal 
Epson Printers:
\begin_deeper 
\layout Description


\size normal 
ap3250 ActionPrinter AP3250 [and any printer using the ESC/P2 printer language]
\layout Description


\size normal 
escp2 All Epson printers using the ESC/P2 command set [thsi driver is possibly
 defunct.
 Use 
\series bold 
ap3250
\series medium 
 instead.]
\layout Description


\size normal 
epson All 9- and 24-pin dot matrix printers [and compatibles]
\layout Description


\size normal 
eps9mid All 9-pin dot matrix printers [and compatibles] in intermediate
 resolution
\layout Description


\size normal 
eps9hi All 9-pin dot matrix printers [and compatibles] in triple resolution
\layout Description


\size normal 
epsonc LQ-2550 color printer [also works for the Fujitsu 1200, 2400, and
 3400 printers
\size default 
]
\layout Description


\size normal 
st800 Stylus 800 inkjet
\layout Description


\size normal 
stcolor the Stylus Color, Stylus Color Pro, Stylus Color II and IIs color
 inkjet printers
\end_deeper 
\layout Itemize


\size normal 
Hewlet Packard [HP] Printers:
\begin_deeper 
\layout Description


\size normal 
lp2563 2563B line printer
\layout Description


\size normal 
cdeskjet DeskJet 500C with 1 bpp color
\layout Description


\size normal 
cdjcolor DeskJet 500C [and 540C] with 24 bpp color and Floyd-Steinberg dithering
\layout Description


\size normal 
cdjmono DeskJet 500C [and 510C, 520C, 540C], monochrome only.
\layout Description


\size normal 
cdj500 same as 
\series bold 
cdjcolor
\layout Description


\size normal 
cdj550 DeskJet 550C and 560C
\layout Description


\size normal 
deskjet DeskJet and DeskJet Plus
\layout Description


\size normal 
djet500 DeskJet 500
\layout Description


\size normal 
djet500c Alternate DeskJet 500C driver [does not work with the 550C or the
 560C]
\layout Description


\size normal 
dnj650c DesignJet 650C
\layout Description


\size normal 
ljet2p LaserJet IId, LaserJet IIp, and LaserJet III* with TIFF compression
\layout Description


\size normal 
ljet3 LaserJet III* with Delta Row compression
\layout Description


\size normal 
ljet3d LaserJet IIID with duplex capability
\layout Description


\size normal 
ljet4 LaserJet 4 [default res=600dpi]
\layout Description


\size normal 
lj4dith LaserJet 4 with Floyd-Steinberg dithering
\layout Description


\size normal 
ljetplus LaserJet Plus
\layout Description


\size normal 
pj PaintJet XL
\layout Description


\size normal 
pjetxl Alternate PaintJet XL driver
\layout Description


\size normal 
pjxl PaintJet XL color
\layout Description


\size normal 
pjxl300 PaintJet XL300 color [and 1200C]
\layout Description


\size normal 
paintjet Alternate PaintJet color driver
\end_deeper 
\layout Itemize


\size normal 
Tektronix Printers:
\begin_deeper 
\layout Description


\size normal 
t4693d2 4693d color printer with 2 bits/RGB component [=6 bpp]
\layout Description


\size normal 
t4693d4 4693d color printer with 4 bits/RGB component [=12 bpp]
\layout Description


\size normal 
t4693d8 4693d color printer with 8 bits/RGB component [=24 bpp]
\layout Description


\size normal 
tek4696 4695 and 4696 inkjet plotters
\end_deeper 
\layout Itemize


\size normal 
Miscellaneous Printers:
\begin_deeper 
\layout Description


\size normal 
cp50 Mitsubishi CP50 color printer
\layout Description


\size normal 
ibmpro IBM 9-pin Proprinter
\layout Description


\size normal 
imagen Imagen ImPress printers
\layout Description


\size normal 
jetp3852 IBM Jetprinter ink-jet color printer (Model #3852)
\layout Description


\size normal 
m8510 C.Itoh M8510 printer
\layout Description


\size normal 
necp6 NEC P6/P6+/P60 printers at 360 dpi 
\layout Description


\size normal 
nwp533 Sony Microsystems NWP533 laser printer [Sony only]
\layout Description


\size normal 
oce9050 OCE 9050 printer
\layout Description


\size normal 
oki182 Okidata MicroLine 182
\layout Description


\size normal 
okiibm Okidata MicroLine IBM-compatible printers
\layout Description


\size normal 
r4081 Ricoh 4081 laser printer
\layout Description


\size normal 
sj48 StarJet 48 inkjet printer
\layout Description


\size normal 
sparc SPARCprinter
\layout Description


\size normal 
xes Xerox XES printers (2700, 3700, 4045, etc.)
\end_deeper 
\layout Standard


\size normal 
If the Ghostscript package that came with your distribution doesn't include
 your printer, you can always hunt down the source code and compile it yourself.
 If your printer isn't 
\emph on 
directly
\emph default 
 supported by Ghostscript at all, try choosing the a printer that's compatible.
\layout Standard


\size normal 
Note that some printers require special command line arguments.
 For example, the 
\family typewriter 
stcolor
\family default 
 driver requires that the file 
\family typewriter 
stcolor.ps
\family default 
 be read before the input file.
 You should read the Ghostscript documentation for more details.
\layout Standard


\size normal 
Next, create the filter.
 We suggest giving it the name 
\begin_inset Quotes eld
\end_inset 


\emph on 
pname
\family typewriter 
\emph default 
.filter
\family default 

\begin_inset Quotes erd
\end_inset 

, where 
\begin_inset Quotes eld
\end_inset 


\emph on 
pname
\emph default 

\begin_inset Quotes erd
\end_inset 

 is the name you gave the printer in its 
\family typewriter 
printcap
\family default 
 entry.
 We also suggest putting the filter script in the printer's spool directory.
 The filter script should contain the following:
\layout LyX-Code


\size normal 
#!/bin/sh
\layout LyX-Code


\size normal 
/usr/bin/gs -q -dSAFER 
\protected_separator 
-dNOPAUSE -sDEVICE=
\family roman 
\emph on 
devname
\family default 
\emph default 

\protected_separator 

\backslash 

\layout LyX-Code


\size normal 

\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
[-r
\family roman 
\emph on 
ResNum
\family default 
\emph default 
 
\family roman 
\emph on 
ExtraOptions
\family default 
\emph default 
]
\protected_separator 
-sOutputFile=- [
\family roman 
\emph on 
precmd
\family default 
\emph default 
.ps] -
\layout Standard


\size normal 
where 
\emph on 
devname
\emph default 
 is the name of the Ghostscript device; 
\emph on 
ResNum 
\emph default 
is the resolution you want to use; 
\emph on 
ExtraOptions
\emph default 
 indicates any additional options to pass to Ghostscript; and 
\begin_inset Quotes eld
\end_inset 


\emph on 
precmd
\emph default 
.
\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 is the name of a file to be read before the input [like the file 
\family typewriter 
stcolor.ps
\family default 
 for the 
\family typewriter 
stcolor
\family default 
 driver].
 The 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

 at the end of the first line is how you break up a command into multiple
 lines in a shell script.
\layout Standard


\size normal 
Note that the above example assumes that 
\family typewriter 
gs
\family default 
 is in the directory 
\family typewriter 
/usr/bin
\family default 
.
 Your system may be different.
\layout Standard


\size normal 
Different Ghostscript drivers treat the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
-r
\family default 

\begin_inset Quotes erd
\end_inset 

 argument differently.
 Some are looking for a single number, for example, 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
-r600
\family default 

\begin_inset Quotes erd
\end_inset 

.
 Others want separate DPI resolutions for the x and y directions, e.g.
 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
-r360x360
\family default 

\begin_inset Quotes erd
\end_inset 

.
 The printer driver may take other options, as well.
 You'll need to consult the Ghostscript documentation for more information.
\layout Standard


\size normal 
After you've created the printer filter, use 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
chmod a+x
\family default 

\begin_inset Quotes erd
\end_inset 

 on the script file to make it executable.
 [You need to be logged in as root to do this].
\layout Standard


\size normal 
Here's an example of a Ghostscript print filter, used by 
\noun on 
John Weiss
\noun default 
 for his Epson Stylus Color IIs:
\layout LyX-Code


\size normal 
#!/bin/sh
\layout LyX-Code


\size normal 
/usr/bin/gs -q -dSAFER -sDEVICE=stcolor 
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
-r360x360 -sDithering=fsmono 
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
 -dNOPAUSE -dnoWeave 
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
-sOutputFile=- stcolor.ps -
\layout Standard


\size normal 
This filter generates 360dpi monochrome output on an Epson Stylus Color
 IIs.
\begin_float footnote 
\layout Standard

Note from 
\noun on 
John Weiss
\noun default 
: This is my 
\family typewriter 
ps
\family default 
 printer.
 I also use a similar filter for my 
\family typewriter 
draft
\family default 
 printer, which has the option 
\family typewriter 
-r180x180
\family default 
 instead of what you see above.
 And for my 
\family typewriter 
color
\family default 
 printer, I use a different value for the 
\family typewriter 
-sDithering
\family default 
 option.
\end_float 
\layout Subsection

If You Already Have a PostScript� Printer\SpecialChar \ldots{}

\layout Standard


\size normal 
Many modern laser printers now come with PostScript� built-in.
 On some laser printers, PostScript� is actually the native printer language.
 If you have such a printer, you won't need a filter and can pass a PostScript�
 file directly to the printer.
 In contrast, if you want to print a text file, you'll need to format it
 in PostScript� somehow.
\layout Standard


\size normal 
We know of three programs that translate plain ASCII text to PostScript�:
 
\family typewriter 
nenscript
\family default 

\family typewriter 
a2ps
\family default 
, and 
\family typewriter 
mpage
\family default 
.
 
\family typewriter 
mpage
\family default 
 can also print multiple pages on a single sheet of paper.
 You should create a filter script using one of these programs for the 
\family typewriter 
lp
\family default 
 printer.
 [The 
\family typewriter 
lp
\family default 
 printer is traditionally the name of the printer that prints ASCII text
 files.] Read the 
\family typewriter 
Printing-HOWTO
\family default 
 for more information.
\layout Section

The Print Spool Daemon, 
\family typewriter 
lpd
\layout Standard


\size normal 
The program that actually does the spooling and printing of files is 
\family typewriter 
lpd
\family default 
.
 It's also the program that reads the 
\family typewriter 
/etc/printcap
\family default 
 file.
 Somewhere in your bootup scripts,
\begin_float footnote 
\layout Standard

Some machines keep their bootup scripts in the 
\family typewriter 
/etc/rc.d
\family default 
 directory.
 Others use 
\family typewriter 
/etc/init.d
\family default 
.
 You'll need to figure this out on your own.
\end_float 

\size normal 
 you'll need to execute 
\family typewriter 
lpd
\family default 
 to begin print spooling every time you boot your machine.
 You can also execute 
\family typewriter 
lpd
\family default 
 as a background job from the command line if you're logged on as root.
 
\layout Standard


\size normal 
Once 
\family typewriter 
lpd
\family default 
 is running on your system, you can control its behavior and that of the
 print spool using the 
\family typewriter 
lpc
\family default 
 command.
 Again, you'll need to log in as root to do this.
\layout Section

Putting It All Together
\layout Standard


\size normal 
We'll conclude this mini-HOWTO with the steps you need to follow to get
 a minimal setup.
 When finished, you'll have two printers, one named 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lp
\family default 

\begin_inset Quotes erd
\end_inset 

 for printing ASCII text, and a second called 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 for printing PostScript� files.
 The filter file for the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 printer [included below] works for any Epson-compatible printer [which
 includes almost all dot-matrix printers these days], using the default
 printing resolution.
\layout Enumerate


\size normal 
Log in as 
\begin_inset Quotes eld
\end_inset 

root
\begin_inset Quotes erd
\end_inset 

 or use 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
su root
\family default 

\begin_inset Quotes erd
\end_inset 

.
 
\layout Enumerate


\size normal 
Execute the following commands:
\begin_deeper 
\layout Enumerate


\family typewriter 
\size normal 
cd /var/spool
\layout Enumerate


\family typewriter 
\size normal 
mkdir lpd
\family default 
 
\begin_deeper 
\layout Standard


\size normal 
[if it doesn't already exist]
\end_deeper 
\layout Enumerate


\family typewriter 
\size normal 
chgrp lp lpd
\begin_deeper 
\layout Standard


\size normal 
[You may need to use 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
daemon
\family default 

\begin_inset Quotes erd
\end_inset 

 instead of 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lp
\family default 

\begin_inset Quotes erd
\end_inset 

]
\end_deeper 
\layout Enumerate


\family typewriter 
\size normal 
cd lpd
\layout Enumerate


\family typewriter 
\size normal 
mkdir lp ps
\begin_deeper 
\layout Standard


\size normal 
[only do this if these directories don't exist yet]
\end_deeper 
\layout Enumerate


\family typewriter 
\size normal 
touch lp/errs ps/errs
\layout Enumerate


\family typewriter 
\size normal 
chgrp daemon lp ps lp/errs ps/errs
\end_deeper 
\layout Enumerate


\size normal 
Now edit the file 
\family typewriter 
/etc/printcap
\begin_deeper 
\layout Enumerate


\size normal 
If this file exists, either
\size default 
\SpecialChar \ldots{}

\begin_deeper 
\layout Enumerate

\SpecialChar \ldots{}

\size normal 
rename the old version to something like 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
/etc/printcap.orig
\family default 

\begin_inset Quotes erd
\end_inset 


\layout Enumerate

\SpecialChar \ldots{}

\size normal 
or, comment out everything in the file by putting a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
#
\family default 

\begin_inset Quotes erd
\end_inset 

 character at the beginning of each line.
\end_deeper 
\layout Enumerate


\size normal 
Put the following into 
\family typewriter 
/etc/printcap
\family default 
:
\begin_deeper 
\layout LyX-Code


\size normal 
lp|Text printer:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lp=/dev/lp1:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sd=/var/spool/lpd/lp:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/lp/errs:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:mx#0:sh:sf:
\newline 

\layout LyX-Code


\size normal 
ps|Postscript printer:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lp=/dev/lp1:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:sd=/var/spool/lpd/ps:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:lf=/var/spool/lpd/ps/errs:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:if=/var/spool/lpd/ps/ps.filter:
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 

\protected_separator 
:mx#0:sh:sf:
\end_deeper 
\layout Enumerate


\size normal 
MAKE SURE THAT:
\begin_deeper 
\layout Enumerate


\size normal 
the blank line between the two entries has nothing in it, not even whitespace
 characters.
\layout Enumerate


\size normal 
nothing follows the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 

\backslash 

\family default 

\begin_inset Quotes erd
\end_inset 

 character at the end of each line.
\end_deeper 
\end_deeper 
\layout Enumerate


\size normal 
Next, create the filter script for the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 printer.
\begin_deeper 
\layout Enumerate


\size normal 
Put the following into the file 
\family typewriter 
/var/spool/lpd/ps/ps.filter
\family default 
:
\begin_deeper 
\layout LyX-Code


\size normal 
#!/bin/sh
\layout LyX-Code


\size normal 
/usr/bin/gs -q -dSAFER -dNOPAUSE 
\backslash 

\layout LyX-Code


\size normal 

\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 
\protected_separator 
 -sDEVICE=epson -sOutputFile=- -
\layout Standard


\size normal 
[If you don't have an Epson-compatible dot-matrix printer, replace the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
epson
\family default 

\begin_inset Quotes erd
\end_inset 

 with the appropriate Ghostscript device name.
 Also, if the program 
\family typewriter 
gs
\family default 
 isn't in 
\family typewriter 
/usr/bin
\family default 
, put in the correct path.]
\end_deeper 
\layout Enumerate


\size normal 
Execute these commands:
\begin_deeper 
\layout Enumerate


\family typewriter 
\size normal 
chmod a+x /var/spool/lpd/ps/ps.filter
\layout Enumerate


\family typewriter 
\size normal 
chgrp daemon /var/spool/lpd/ps/ps.filter
\end_deeper 
\end_deeper 
\layout Enumerate


\size normal 
Lastly, start up the printer daemon, 
\family typewriter 
lpd
\family default 
:
\begin_deeper 
\layout Enumerate


\size normal 
If it's not running already, use 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lpd &
\family default 

\begin_inset Quotes erd
\end_inset 

 to start it.
\layout Enumerate


\size normal 
If it is running already, execute 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lpc
\family default 

\begin_inset Quotes erd
\end_inset 

.
 Then, from within 
\family typewriter 
lpc
\family default 
, do a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
restart all
\family default 

\begin_inset Quotes erd
\end_inset 

 and a 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
up all
\family default 

\begin_inset Quotes erd
\end_inset 

 to activate the new print spools.
 [The command 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
quit
\family default 

\begin_inset Quotes erd
\end_inset 

 leaves 
\family typewriter 
lpc
\family default 
].
\layout Enumerate


\size normal 
Be sure to add the appropriate command to your bootup scripts so that 
\family typewriter 
lpd
\family default 
 is executed every time you boot your system.
\end_deeper 
\layout Enumerate


\size normal 
You may now log out as root and test your new printers to make sure they
 work.
 Issue the command 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lpr -Plp
\family default 

\begin_inset Quotes erd
\end_inset 

 followed by the name of a short ASCII text file to verify that the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lp
\family default 

\begin_inset Quotes erd
\end_inset 

 printer works.
 Then use 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
lpr -Pps
\family default 

\begin_inset Quotes erd
\end_inset 

 followed by the name of a short PostScript� file to test the 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

 printer.
 
\layout Standard


\size normal 
A word of caution: when testing 
\begin_inset Quotes eld
\end_inset 


\family typewriter 
ps
\family default 

\begin_inset Quotes erd
\end_inset 

, if anything goes wrong, the system may end up passing garbage to your
 printer.
 If that happens, shut off your printer and use the 
\family typewriter 
lpq
\family default 
 and 
\family typewriter 
lprm
\family default 
 commands to kill the print job.
 After you kill the print job, you can turn your printer back on.
\layout Standard


\size normal 
If either of these printers doesn't work, check everything again, consult
 the 
\family typewriter 
man
\family default 
 pages for 
\family typewriter 
printcap
\family default 
 and 
\family typewriter 
lpd
\family default 
, and read the 
\family typewriter 
Printing-HOWTO
\family default 
 for help.
\layout Standard


\size normal 
If everything does work, congratulations!
\the_end

[zur Elbe Produktseite wechseln0.403QuellennavigatorsAnalyse erneut starten2026-04-26]

                                                                                                                                                                                                                                                                                                                                                                                                     


Neuigkeiten

     Aktuelles
     Motto des Tages

Software

     Produkte
     Quellcodebibliothek

Aktivitäten

     Artikel über Sicherheit
     Anleitung zur Aktivierung von SSL

Muße

     Gedichte
     Musik
     Bilder

Jenseits des Üblichen ....

Besucherstatistik

Besucherstatistik

Monitoring

Montastic status badge