]> git.lyx.org Git - lyx.git/blobdiff - lib/doc/Customization.lyx
A couple minor changes in the User's Guide.
[lyx.git] / lib / doc / Customization.lyx
index da400c95a0ed2f6e4b4ecf7c4809e1c3eb06931b..35bd469e572c081af77dac1808d75db31a9d1db0 100644 (file)
@@ -1,14 +1,14 @@
-#LyX 1.6.0svn created this file. For more info see http://www.lyx.org/
-\lyxformat 339
+#LyX 2.0.0svn created this file. For more info see http://www.lyx.org/
+\lyxformat 372
 \begin_document
 \begin_header
 \textclass scrbook
 \begin_preamble
 % DO NOT ALTER THIS PREAMBLE!!!
 %
-% This preamble is designed to ensure that the User's Guide prints
+% This preamble is designed to ensure that this document prints
 % out as advertised. If you mess with this preamble,
-% parts of the User's Guide may not print out as expected.  If you
+% parts of this document may not print out as expected.  If you
 % have problems LaTeXing this file, please contact 
 % the documentation team
 % email: lyx-docs@lists.lyx.org
 % redefine the \LyX macro for PDF bookmarks
 \def\LyX{\texorpdfstring{%
   L\kern-.1667em\lower.25em\hbox{Y}\kern-.125emX\@}
-  {LyX }}
+  {LyX}}
 
 % used for multi-column text
 \usepackage{multicol}
 \usepackage{inputenc}
 \end_preamble
 \options fleqn,liststotoc,bibtotoc,idxtotoc,BCOR7.5mm,titlepage,tablecaptionabove
+\use_default_options false
 \begin_modules
 logicalmkup
 \end_modules
@@ -61,16 +62,21 @@ End
 \end_local_layout
 \language english
 \inputencoding auto
+\fontencoding global
 \font_roman default
 \font_sans default
 \font_typewriter default
 \font_default_family default
+\use_xetex false
 \font_sc false
 \font_osf false
 \font_sf_scale 100
 \font_tt_scale 100
 
-\graphics none
+\graphics default
+\default_output_format default
+\bibtex_command default
+\index_command default
 \paperfontsize 12
 \spacing single
 \use_hyperref true
@@ -86,32 +92,37 @@ End
 \pdf_pdfborder false
 \pdf_colorlinks true
 \pdf_backref false
-\pdf_pagebackref false
 \pdf_pdfusetitle false
 \pdf_quoted_options "linkcolor=black, citecolor=black, urlcolor=blue, filecolor=blue,pdfpagelayout=OneColumn, pdfnewwindow=true,pdfstartview=XYZ, plainpages=false, pdfpagelabels"
 \papersize default
 \use_geometry false
 \use_amsmath 0
 \use_esint 0
+\use_mhchem 1
 \cite_engine basic
 \use_bibtopic false
+\use_indices false
 \paperorientation portrait
+\suppress_date false
 \branch OutDated
 \selected 0
+\filename_suffix 0
 \color #f5fae7
 \end_branch
+\index Index
+\shortcut idx
+\color #008000
+\end_index
 \secnumdepth 3
 \tocdepth 3
 \paragraph_separation indent
-\defskip medskip
+\paragraph_indentation default
 \quotes_language english
 \papercolumns 1
 \papersides 2
 \paperpagestyle headings
 \tracking_changes false
 \output_changes false
-\author "" 
-\author "" 
 \end_header
 
 \begin_body
@@ -137,11 +148,29 @@ type "mailto:"
 \end_inset
 
 .
+ Include 
+\begin_inset Quotes eld
+\end_inset
+
+[Customization]
+\begin_inset Quotes erd
+\end_inset
+
+ in the subject header, and please cc the current maintainer of this file,
+ Richard Heck <rgheck@comcast.net>.
 \end_layout
 
 \end_inset
 
+
+\begin_inset Newline newline
+\end_inset
+
+
+\begin_inset Newline newline
+\end_inset
+
+Version 2.0.x 
 \end_layout
 
 \begin_layout Standard
@@ -151,6 +180,22 @@ LatexCommand tableofcontents
 \end_inset
 
 
+\end_layout
+
+\begin_layout Standard
+\begin_inset Note Note
+status open
+
+\begin_layout Plain Layout
+Please use change tracking when modifying this document.
+ This makes it easier for our translators to recognize things that have
+ been changed, and it helps the maintainer keep up-to-date with what's been
+ done.
+\end_layout
+
+\end_inset
+
+
 \end_layout
 
 \begin_layout Chapter
@@ -162,15 +207,15 @@ This manual covers the customization features present in LyX.
  In it, we discuss issues like keyboard shortcuts, screen previewing options,
  printer options, sending commands to LyX via the LyX Server, internationalizati
 on, installing new LaTeX classes and LyX layouts, etc.
- We can't possibly hope to touch on everything you can change---our developers
- add new features faster than we can document them---but we will explain
the most common customizations and hopefully point you in the right direction
+ We can't possibly hope to touch on everything you can changeour developers
+ add new features faster than we can document them—but we will explain the
+ most common customizations and hopefully point you in the right direction
  for some of the more obscure ones.
 \end_layout
 
 \begin_layout Standard
 \begin_inset Branch OutDated
-status collapsed
+status open
 
 \begin_layout Standard
 Information from previous versions of this document that now seems to be
@@ -188,12 +233,6 @@ LyX configuration files
 \end_layout
 
 \begin_layout Standard
-\begin_inset CommandInset label
-LatexCommand label
-name "chap:config"
-
-\end_inset
-
 This chapter aims to help you to find your way through the LyX configuration
  files.
  Before continuing to read this chapter, you should find out where your
@@ -202,18 +241,12 @@ This chapter aims to help you to find your way through the LyX configuration
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp\SpecialChar \menuseparator
+Help\SpecialChar \menuseparator
 About
 \begin_inset space ~
 \end_inset
 
-Ly
-\bar under
-X
+LyX
 \end_layout
 
 \end_inset
@@ -270,22 +303,14 @@ LyXDir
 \end_inset
 
  and its sub-directories contain a number of files and that can be used
- to customise LyX's behaviour.
+ to customize LyX's behavior.
  You can change many of these files from within LyX itself through the 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-references
+Tools\SpecialChar \menuseparator
+Preferences
 \end_layout
 
 \end_inset
@@ -362,16 +387,8 @@ packages.lst
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp\SpecialChar \menuseparator
-L
-\bar under
-a
-\bar default
-TeX
+Help\SpecialChar \menuseparator
+LaTeX
 \begin_inset space ~
 \end_inset
 
@@ -531,18 +548,7 @@ status collapsed
 
 \end_inset
 
- that define the keybindings used in LyX (see section
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:bindings"
-
-\end_inset
-
-).
+ that define the keybindings used in LyX.
  If there exists an internationalized version of the bind file named 
 \begin_inset Flex CharStyle:Code
 status collapsed
@@ -554,25 +560,6 @@ $LANG_xxx.bind
 \end_inset
 
 , that will be used first.
- See Chapter
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "chap:i18n"
-
-\end_inset
-
-, and section 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:bindings"
-
-\end_inset
-
-for details.
 \end_layout
 
 \begin_layout Labeling
@@ -613,26 +600,33 @@ LaTeXConfig.lyx
 \end_inset
 
  deserves special attention, as noted above.
- If there exists an internationalized version of the help-document with
+ The internationalized help docs are in subdirectories 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$LANG_
+doc/xx
 \end_layout
 
 \end_inset
 
- prepended to the name, that will be used first.
- See Chapter
+ where 
+\begin_inset Quotes eld
+\end_inset
+
+xx
+\begin_inset Quotes erd
+\end_inset
+
+ is the ISO language code.
+ See chapter
 \begin_inset space ~
 \end_inset
 
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "chap:i18n"
+reference "cha:Internationalizing-LyX"
 
 \end_inset
 
@@ -709,7 +703,7 @@ kbd/
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:keymap"
+reference "sec:International-Keymap-Stuff"
 
 \end_inset
 
@@ -734,7 +728,7 @@ layouts/
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "chap:textclass"
+reference "cha:Installing-New-Document"
 
 \end_inset
 
@@ -814,7 +808,7 @@ templates/
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:templates"
+reference "sec:Creating-Templates"
 
 \end_inset
 
@@ -845,14 +839,6 @@ status collapsed
  that define the user interface to LyX.
  That is, the files define which items appear in which menus and the items
  appearing on the toolbar.
- See 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:ui"
-
-\end_inset
-
- for details.
 \end_layout
 
 \begin_layout Subsection
@@ -881,11 +867,7 @@ CREDITS
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp\SpecialChar \menuseparator
+Help\SpecialChar \menuseparator
 About
 \begin_inset space ~
 \end_inset
@@ -944,7 +926,7 @@ encodings
 \end_inset
 
  this contains tables describing how different character encodings can be
- mapped to unicode
+ mapped to Unicode
 \end_layout
 
 \begin_layout Labeling
@@ -1020,11 +1002,7 @@ user directory
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp\SpecialChar \menuseparator
+Help\SpecialChar \menuseparator
 About
 \begin_inset space ~
 \end_inset
@@ -1081,16 +1059,8 @@ The preferences set in the
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-references
+Tools\SpecialChar \menuseparator
+Preferences
 \end_layout
 
 \end_inset
@@ -1124,16 +1094,8 @@ When you reconfigure using
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-R
-\bar default
-econfigure
+Tools\SpecialChar \menuseparator
+Reconfigure
 \end_layout
 
 \end_inset
@@ -1166,16 +1128,8 @@ UserDir/layouts
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
@@ -1201,11 +1155,7 @@ UserDir/doc/
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp
+Help
 \end_layout
 
 \end_inset
@@ -1264,7 +1214,7 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-LYX_USERDIR_16x
+LYX_USERDIR_VER
 \end_layout
 
 \end_inset
@@ -1301,22 +1251,14 @@ doc/
 
 \end_inset
 
- subirectory, however, since it contains a file written by the configuration
+ subdirectory, however, since it contains a file written by the configuration
  script (also accessible through 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-R
-\bar default
-econfigure
+Tools\SpecialChar \menuseparator
+Reconfigure
 \end_layout
 
 \end_inset
@@ -1328,1132 +1270,997 @@ econfigure
 The Preferences dialog
 \end_layout
 
+\begin_layout Standard
+All options of the preferences dialog are described in the Appendix 
+\emph on
+The Preferences Dialog
+\emph default
+ in the 
+\emph on
+User's Guide
+\emph default
+.
+ For some options you might find here more details.
+\end_layout
+
 \begin_layout Section
-Using the dialog for the first time
+Formats
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:Formats"
+
+\end_inset
+
+
 \end_layout
 
 \begin_layout Standard
-The 
-\begin_inset Flex CharStyle:Code
+The first step is to define your file formats if they are not already defined.
+ To do so, open the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/preferences
+Tools\SpecialChar \menuseparator
+Preferences
 \end_layout
 
 \end_inset
 
- file will contain only changes that you have made to the default behaviour,
- some of which is hard-coded into LyX and some of which is contained in
- the system file 
-\begin_inset Flex CharStyle:Code
+ dialog.
+ Under 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/lyxrc.defaults
+File Handling\SpecialChar \menuseparator
+File formats
 \end_layout
 
 \end_inset
 
-.
- Note that in both files lines beginning with a 
-\begin_inset Quotes eld
+ press the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+New\SpecialChar \ldots{}
+
+\end_layout
+
 \end_inset
 
-#
-\begin_inset Quotes erd
+ button to define your new format.
+ The 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Format
+\end_layout
+
 \end_inset
 
are just comments and are not interpreted.
- However, only system administrators should edit 
-\begin_inset Flex CharStyle:Code
field contains the name used to identify the format in the GUI.
+ The 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/lyxrc.defaults
+Short Name
 \end_layout
 
 \end_inset
 
-.
- Users should use the 
+ is used to identify the format internally.
+ You will also need to enter a file extension.
+ These are all required.
+ The optional 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
+Shortcut
+\end_layout
 
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-P
-\bar default
-references
+ field is used to provide a keyboard shortcut on the menus.
+ (For example, pressing 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Alt-V D
 \end_layout
 
 \end_inset
 
- dialog to create and modify their own 
-\begin_inset Flex CharStyle:Code
+ will 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/preferences
+View\SpecialChar \menuseparator
+DVI
 \end_layout
 
 \end_inset
 
- file.
+.) 
 \end_layout
 
 \begin_layout Standard
-We hope that the 
+A Format can have a 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-references
+Viewer
 \end_layout
 
 \end_inset
 
- dialog will be largely self-explanatory.
- Most things in the dialog have associated `tool tips': hover your mouse
- pointer over something for more information.
- Before we highlight a few of the more important commands below, however,
- a word of warning: 
+ and an 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Apply
+Editor
 \end_layout
 
 \end_inset
 
-ing some of your changes (e.g., screen fonts) will have an instant effect.
- Others (e.g.
- changing the bind file) will not.
- If nothing appears to have changed, just 
+ associated with it.
+ For example, you might want to use 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Save
+Ghostview
 \end_layout
 
 \end_inset
 
- the changes and restart LyX.
-\end_layout
+ to view PostScript files.
+ You can enter the command needed to start the program in the corresponding
+ fields.
+ In defining this command, you can use the four variables listed in the
+ next section.
+ The viewer is launched when you view an image in LyX or use the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_layout Section
-Look and Feel
+\begin_layout Plain Layout
+View
 \end_layout
 
-\begin_layout Subsection
-Screen fonts
-\end_layout
+\end_inset
 
-\begin_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.
- Therefore it is important that the font be as readable and good-looking
- as possible.
- The LyX team tried to provide the best possible default font for you, but
- since systems can be so different, it's quite possible that the default
- fonts will be sub-optimal on your system.
- Fortunately, you can do something about this.
- Before we explain how, you should learn a bit more about fonts so that
- you are better prepared for choosing your fonts.
- There are trade-offs that are specific to your preferences and the capabilities
- of your system.
-\end_layout
+ menu.
+ The editor is for example launched when you right-click on an image and
+ choose 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_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.
+\begin_layout Plain Layout
+Edit externally
 \end_layout
 
-\begin_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 in 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.
-\end_layout
+\end_inset
 
-\begin_layout Standard
-The scalable fonts are built 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
- (or symbol) the programmer requests.
- This means that scalable fonts will look pretty good in most 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
- computed 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, tradeoffs have to be
- made, and the result is that scalable fonts can be difficult to read at
- small sizes.
+ in the appearing context menu.
 \end_layout
 
 \begin_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 an
- image 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.
-\end_layout
+The 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_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.
+\begin_layout Plain Layout
+Document format
 \end_layout
 
-\begin_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.
-\end_layout
+\end_inset
 
-\begin_layout Subsubsection
-DPI setting and Font Zoom
-\end_layout
+ option tells LyX that a format is suitable for document export.
+ If this is set and if a suitable conversion route exists (see sec.
+\begin_inset space \thinspace{}
+\end_inset
 
-\begin_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.
-\end_layout
 
-\begin_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 information
- provided by your system.
- You can check what LyX autodetects the DPI setting to, by running LyX as
-\begin_inset Flex CharStyle:Code
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sec:Converters"
+
+\end_inset
+
+), the format will appear in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-lyx -dbg 2
+File\SpecialChar \menuseparator
+Export
 \end_layout
 
 \end_inset
 
-.
+ menu.
+ The format will also appear in the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+View
 \end_layout
 
-\begin_layout Standard
-On many systems, this will not be correct, so you should check that it is
- correct by hand.
- On X11 systems, you can run 
-\begin_inset Quotes eld
 \end_inset
 
-
+ menu if a viewer is specified for the format.
+ Pure image formats, such as 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xdpyinfo | more
+png
 \end_layout
 
 \end_inset
 
+, should not use this option.
+ Formats that can both represent vector graphics and documents like 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\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
+\begin_layout Plain Layout
+pdf
+\end_layout
 
-dimensions
-\begin_inset Quotes erd
 \end_inset
 
-).
-\end_layout
-
-\begin_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 dividing
- by 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 your system setup, or at least tell LyX that the DPI is different
- than the detected value.
+ should use it.
 \end_layout
 
 \begin_layout Standard
-If you can't fix system setup (which of course is best since other programs
- than LyX will benefit from this as well), you can tell LyX the correct
- DPI using the 
+The option 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Preferences
+Vector graphics format
 \end_layout
 
 \end_inset
 
- dialog.
-\end_layout
-
-\begin_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.
- Since LyX is a WYSIWYM system anyways, this limitation isn't much of an
- issue.
-\end_layout
-
-\begin_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
+ tells LyX that a format can contain vector graphics.
+ This information is used to determine the target format of included graphics
+ for 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Font
-\begin_inset space ~
+pdflatex
+\end_layout
+
 \end_inset
 
+ export.
+ Included graphics may need to be converted to either 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\bar under
-Z
-\bar default
-oom
+\begin_layout Plain Layout
+pdf
 \end_layout
 
 \end_inset
 
- setting in the 
+, 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Preferences
+png
 \end_layout
 
 \end_inset
 
- dialog to find a size that you like.
- When you've found a setting that seems to work nicely for you (tip: use
- the 
+, or 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-A
-\bar default
-pply
+jpg
 \end_layout
 
 \end_inset
 
- button to keep the dialog open while you experiment), you can make this
- setting the default by using the 
+, since 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-S
-\bar default
-ave
+pdflatex
 \end_layout
 
 \end_inset
 
- button.
-\end_layout
+ cannot handle other image formats.
+ If an included graphic is not already in 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_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.
+\begin_layout Plain Layout
+pdf
 \end_layout
 
-\begin_layout Subsubsection
-Font definition commands
-\end_layout
+\end_inset
 
-\begin_layout Standard
-You can change LyX's screen fonts from within the 
+, 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Preferences
+png
 \end_layout
 
 \end_inset
 
- dialog.
- The number of fonts that are available on different systems vary.
-\end_layout
+, or 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_layout Standard
-Before you go about scrapping a bitmap font because the larger sizes look
-\begin_inset Quotes eld
-\end_inset
+\begin_layout Plain Layout
+jpg
+\end_layout
 
-blocky
-\begin_inset Quotes erd
 \end_inset
 
-, you should toggle the 
-\begin_inset Flex CharStyle:Code
+ format, it is converted to 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Use scalable fonts
+pdf
 \end_layout
 
 \end_inset
 
- button.
- 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 good.
- However, the downside is that there will be a greater difference between
- the size of the fonts on screen and the size of fonts on paper 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 
+ if the vector format option is set, and otherwise to 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Large
+png
 \end_layout
 
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:MenuItem
+.
+\end_layout
+
+\begin_layout Section
+Copiers
+\end_layout
+
+\begin_layout Standard
+Since all conversions from one format to another take place in LyX's temporary
+ directory, it is sometimes necessary to modify a file before copying it
+ to the temporary directory in order that the conversion may be performed.
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-Larger
+For example, the file may refer to other files—images, for example—using
+ relative file names, and these may become invalid when the file is copied
+ to the temporary directory.
 \end_layout
 
 \end_inset
 
-, will be mapped to the same screen font, making it hard for you to see
- the difference on screen.
+ This is done by a Copier: It copies a file to (or from) the temporary directory
+ and may modify it in the process.
 \end_layout
 
 \begin_layout Standard
-One final note regarding the 
+The definitions of the copiers may use four variables:
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Use scalable fonts
+$$s
 \end_layout
 
 \end_inset
 
- 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
+ The LyX system directory (e.
+\begin_inset space \thinspace{}
 \end_inset
 
-Utopia
-\begin_inset Quotes erd
+g.
+\begin_inset space \space{}
 \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
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-.
- And you can safely select the 
-\begin_inset Quotes eld
-\end_inset
+\begin_layout Plain Layout
+/usr/share/lyx
+\end_layout
 
-Use scalable fonts
-\begin_inset Quotes erd
 \end_inset
 
- button without worries: It will only apply to the Helvetica font.
+).
 \end_layout
 
-\begin_layout Standard
-Sometimes the artifacts introduced by use of the flag can be relieved by
- using the fine-detail screen font sizes which defines which point sizes
- the different logical font sizes correspond to.
- Run LyX as 
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyx -dbg 513
+$$i
 \end_layout
 
 \end_inset
 
- to see exactly what concrete fonts the logical sizes map to, and try adjusting
- the corresponding entries in the 
-\begin_inset Flex CharStyle:MenuItem
+ The input file
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Preferences
+$$o
 \end_layout
 
 \end_inset
 
- dialog 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.
-\end_layout
-
-\begin_layout Standard
-\begin_inset Branch OutDated
-status collapsed
-
-\begin_layout Subsubsection
-Font encoding
+ The output file
 \end_layout
 
-\begin_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 encoding setting.
- This requires you to have special fonts installed.
- You can use 
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xfontsel
+$$l
 \end_layout
 
 \end_inset
 
- to see whether this is the case: check the 
-\begin_inset Quotes eld
-\end_inset
+ The `LaTeX name'
+\end_layout
 
-rgstry
-\begin_inset Quotes erd
-\end_inset
-
- and 
-\begin_inset Quotes eld
-\end_inset
-
-encdng
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Standard
+The latter should be the filename as it would be used in a LaTeX's 
+\series bold
 
- 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, enter this encoding in the dialog.
If not, go searching the Web for appropriate fonts.
For the Qt frontend, it's recommended you use an iso646 font set.
+\backslash
+include
+\series default
command.
It is relevant only when exporting files suitable for such inclusion.
 \end_layout
 
 \begin_layout Standard
-When you've set LyX up to use a different font encoding, you should also
- consider changing the font used by dialog windows in LyX.
- For instance, the 
-\begin_inset Flex CharStyle:MenuItem
+Copiers can be used to do almost anything with output files.
+ For example, suppose you want generated pdf files to be copied to a special
+ directory, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Table
-\begin_inset space ~
-\end_inset
+/home/you/pdf/
+\end_layout
 
-of
-\begin_inset space ~
 \end_inset
 
-Contents
+.
+ Then you could write a shell script such as this one:
 \end_layout
 
-\end_inset
-
- dialog will not be understandable unless you tell LyX to use a different
- font for this.
- By default the menu font is set to 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Standard
+\begin_inset listings
+inline false
+status open
 
 \begin_layout Plain Layout
--*-helvetica-medium-r
+
+#!/bin/bash
 \end_layout
 
-\end_inset
+\begin_layout Plain Layout
 
-, but often Helvetica is not available in the font encoding you need, so
- the dialog allows this to be changed.
+FROMFILE=$1
 \end_layout
 
-\begin_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 using
- fonts that have to look good both on paper and on screen, LyX gives you
- the possibility of using fonts that are designed to look good on the screen
- while using a different set of fonts to look good on paper.
-\end_layout
+\begin_layout Plain Layout
 
-\end_inset
+TOFILE=`basename $2`
+\end_layout
 
+\begin_layout Plain Layout
 
+cp $FROMFILE /home/you/pdf/$TOFILE
 \end_layout
 
-\begin_layout Subsection
-User Interface
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:ui"
-
 \end_inset
 
-
-\end_layout
-
-\begin_layout Standard
-The appearance of both the menu and toolbar may both be changed using the
-\begin_inset Flex CharStyle:MenuItem
+Save it in your local LyX directory—say, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Preferences
+/home/you/.lyx/scripts/pdfcopier.sh
 \end_layout
 
 \end_inset
 
- dialog.
- Simply select a different 
-\begin_inset Flex CharStyle:Code
+—and make it executable, if you need to do so on your platform.
+ Then, in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-.ui
+Tools\SpecialChar \menuseparator
+Preferences
 \end_layout
 
 \end_inset
 
- file in the 
+ dialog, select under 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Look & Feel\SpecialChar \menuseparator
-User Interface
+File Handling\SpecialChar \menuseparator
+File formats
 \end_layout
 
 \end_inset
 
- section.
- You can customize the interface by copying one of the 
-\begin_inset Flex CharStyle:Code
+ the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-.ui
+PDF(pdflatex)
 \end_layout
 
 \end_inset
 
- files from 
+ format—or one of the other pdf formats—and enter 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/ui/
+pdfcopier.sh $$i $$o
 \end_layout
 
 \end_inset
 
- to 
-\begin_inset Flex CharStyle:Code
+ into the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/ui/
+Copier
 \end_layout
 
 \end_inset
 
-.
- You may have to restart LyX for these changes to take effect.
+ field.
 \end_layout
 
 \begin_layout Standard
-The syntax of the 
-\begin_inset Flex CharStyle:Code
+Copiers are used by LyX in various of its own conversions.
+ For example, if appropriate programs are found, LyX will automatically
+ install copiers for the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-.ui
+HTML
 \end_layout
 
 \end_inset
 
- files is straightforward: have a look at 
-\begin_inset Flex CharStyle:Code
+ and 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-default.ui
+HTML
+\begin_inset space ~
+\end_inset
+
+(MS Word)
 \end_layout
 
 \end_inset
 
-.
- The 
-\begin_inset Flex CharStyle:Code
+ formats.
+ When these formats are exported, the copier sees that not just the main
+ HTML file but various associated files (style files, images, etc.) are also
+ copied.
+ All these files are written to a subdirectory of the directory in which
+ the original LyX file was found.
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-Menubar
-\end_layout
+This copier can be customized.
+ The optional 
+\begin_inset Quotes eld
+\end_inset
 
+-e
+\begin_inset Quotes erd
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:Code
+ argument takes a comma-separated list of extensions to be copied; if it
+ is omitted, all files will be copied.
+ The 
+\begin_inset Quotes eld
+\end_inset
+
+-t
+\begin_inset Quotes erd
+\end_inset
+
+ argument determines the extension added to the generated directory.
+ By default, it is 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Menu
+LyXconv
 \end_layout
 
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:Code
+
+\begin_inset Quotes erd
+\end_inset
+
+, so HTML generated from 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Toolbar
+/path/to/filename.lyx
 \end_layout
 
 \end_inset
 
- entries must be ended with an explicit 
-\begin_inset Flex CharStyle:Code
+ will end up in 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-End
+/path/to/filename.html.LyXconv
 \end_layout
 
 \end_inset
 
 .
- They may contain 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-Submenu
 \end_layout
 
 \end_inset
 
-s, 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-Item
 \end_layout
 
+\begin_layout Section
+Converters
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:Converters"
+
 \end_inset
 
-s, 
-\begin_inset Flex CharStyle:Code
+
+\end_layout
+
+\begin_layout Standard
+You can define your own Converters to convert files between different formats.
+ This is done in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-OptItem
+Tools\SpecialChar \menuseparator
+Preferences\SpecialChar \menuseparator
+File Handling\SpecialChar \menuseparator
+Converters
 \end_layout
 
 \end_inset
 
-s, 
-\begin_inset Flex CharStyle:Code
+ dialog.
+\end_layout
+
+\begin_layout Standard
+To define a new converter, select the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Separator
+From
+\begin_inset space ~
+\end_inset
+
+format
 \end_layout
 
 \end_inset
 
-s, 
-\begin_inset Flex CharStyle:Code
+ and 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Icon
-\end_layout
-
+To
+\begin_inset space ~
 \end_inset
 
-s and in the case of the 
-\begin_inset Quotes eld
-\end_inset
+format
+\end_layout
 
-file
-\begin_inset Quotes erd
 \end_inset
 
- menus, a 
-\begin_inset Flex CharStyle:Code
+ from the drop-down lists, enter the command needed for the conversion,
+ and then press the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Lastfiles
+Add
 \end_layout
 
 \end_inset
 
- entry.
- One small word of warning.
+ button.
+ Several variables can be used in the definition of converters:
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Submenu
+$$s
 \end_layout
 
 \end_inset
 
-s may be inserted in a 
+ The LyX system directory
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Menubar
+$$i
 \end_layout
 
 \end_inset
 
- or 
+ The input file
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Menu
+$$o
 \end_layout
 
 \end_inset
 
-, but they are defined as 
+ The output file
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Menu
+$$b
 \end_layout
 
 \end_inset
 
-s, not as 
+ The base filename of the input file (i.
+\begin_inset space \thinspace{}
+\end_inset
+
+g., without the extension)
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Submenu
+$$p
 \end_layout
 
 \end_inset
 
-s.
- A 
+ The path to the input file
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Submenu
+$$r
 \end_layout
 
 \end_inset
 
- tag is used to insert context-dependent information that is generated by
- LyX itself.
- Unfortunately, the available tags are not documented outside the source
- code.
+ The path to the original input file (this is different from $$p when a
+ chain of converters is called).
 \end_layout
 
 \begin_layout Standard
-Note that, as of LyX 1.6, there are extensive context menus, normally accessed
- via a right click.
- These are defined in the 
-\begin_inset Flex CharStyle:Code
+In the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-.ui
+Extra
+\begin_inset space ~
+\end_inset
+
+Flag
 \end_layout
 
 \end_inset
 
- files.
+ field you can enter the following flags, separated by commas:
 \end_layout
 
-\begin_layout Section
-Editing
-\end_layout
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-The settings in this section are used to customise the behavior of the LyX
- editor.
+\begin_layout Plain Layout
+latex
 \end_layout
 
-\begin_layout Subsection
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:bindings"
-
 \end_inset
 
-Shortcuts
+ This converter runs some form of LaTeX.
+ This will make LyX's LaTeX error logs available.
 \end_layout
 
-\begin_layout Standard
-Bindings are used to associate a LyX function to a key.
- Several prepackaged binding files are available: a CUA set of bindings
- (familiar as the typical set of PC and CDE set of keyboard shortcuts),
- an Emacs set of bindings, for those of us who follow the One True Way and
- refuse to lower our standards,
-\begin_inset Foot
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-I'm kidding here, of course!
+needaux
 \end_layout
 
 \end_inset
 
- as well as specialty bindings (broadway and hollywood) and bindings for
- languages other than English.
- You can select your binding in the 
+ Needs the LaTeX 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Editing\SpecialChar \menuseparator
-Shortcuts
+.aux
 \end_layout
 
 \end_inset
 
- section of the 
-\bar under
+ file for the conversion.
+\end_layout
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-references
+xml
 \end_layout
 
 \end_inset
 
-
-\bar default
- dialog.
+ Output is XML.
 \end_layout
 
 \begin_layout Standard
-If, however, you'd like to customise the bindings to your own exacting tastes,
- then there are two ways to proceed.
- The first, and older method, is to copy a file from 
-\begin_inset Flex CharStyle:Code
+The following three flags are not really flags at all because they take
+ an argument in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/bind/
+key
+\begin_inset space ~
+\end_inset
+
+=
+\begin_inset space ~
+\end_inset
+
+value
 \end_layout
 
 \end_inset
 
- to your own 
+ format:
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/bind/
+parselog
 \end_layout
 
 \end_inset
 
- and modify that in a text editor.
- Don't forget to select this file in 
-\begin_inset Flex CharStyle:MenuItem
+ If set, the converter's standard error will be redirected to a file 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Editing\SpecialChar \menuseparator
-Shortcuts
+infile.out
 \end_layout
 
 \end_inset
 
-.
- The second method is to use the shortcut editor, which you will also find
- at 
-\begin_inset Flex CharStyle:MenuItem
+, and the script given as argument will be run as: 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Editing\SpecialChar \menuseparator
-Shortcuts
+script < infile.out > infile.log
 \end_layout
 
 \end_inset
 
 .
- The changes you make here will be stored at 
+ The argument may contain 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/bind/user.bind
+$$s
 \end_layout
 
 \end_inset
@@ -2461,449 +2268,459 @@ UserDir/bind/user.bind
 .
 \end_layout
 
-\begin_layout Standard
-LyX supports internationalization of the user interface (see Chapter
-\begin_inset space ~
-\end_inset
-
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "chap:i18n"
+\begin_layout Plain Layout
+resultdir
+\end_layout
 
 \end_inset
 
-).
- If your 
-\emph on
-locale
-\emph default
- is set, LyX will try to use bindfiles by prepending the standard language
- code to their name.
- For example, you can put a translated copy of some standard bind file in
- your personal 
+ The name of the directory in which the converter will dump the generated
+ files.
+ LyX will not create this directory, and it does not copy anything into
+ it, though it will copy this directory to the destination.
+ The argument may contain 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-bind/
+$$b
 \end_layout
 
 \end_inset
 
- directory, and LyX will use it automatically.
+, which will be replaced by the base name of the input and output files,
+ respectively, when the directory is copied.
+\begin_inset Newline newline
+\end_inset
+
+Note that resultdir and usetempdir make no sense together.
+ The latter will be ignored if the former is given.
 \end_layout
 
-\begin_layout Standard
-The syntax of the 
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.bind
-\end_layout
-
-\end_inset
-
- files is straightforward:
+resultfile
 \end_layout
 
-\begin_layout LyX-Code
-
-\backslash
-bind ``<key combination>'' ``<lyx-function>
-\begin_inset Quotes erd
 \end_inset
 
+ Determines the output file name and may, contain 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
+\begin_layout Plain Layout
+$$b
 \end_layout
 
-\begin_layout Standard
-Both key combination and lyx-function (including any arguments) must be
- enclosed in "double quotes".
- The LyX functions are partially documented on listed on the 
-\begin_inset CommandInset href
-LatexCommand href
-name "LyXWiki"
-target "http://wiki.lyx.org/LyX/LyxFunctions"
-
 \end_inset
 
 .
- A major effort is presently underway to improve this documentation.
-\end_layout
-
-\begin_layout Section
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:converters-etc"
-
-\end_inset
-
-File Handling
+ Sensible only with resultdir and optional even then; if not given, it defaults
+ to `index'.
 \end_layout
 
 \begin_layout Standard
-LyX has a powerful mechanism to convert to and from any file format using
external programs.
+None of these last three are presently used in any of the converters that
are installed with LyX.
  
 \end_layout
 
-\begin_layout Subsection
-\begin_inset CommandInset label
-LatexCommand label
-name "sub:Formats"
-
-\end_inset
-
-Formats
-\end_layout
-
 \begin_layout Standard
-The first step is to define your file formats if they are not already defined.
- To do so, open the 
+You do not have to define converters for all formats between which you want
+ to convert.
+ For example, you will note that there is no `LyX to PostScript' converter,
+ but LyX will export PostScript.
+ It does so by first creating a LaTeX file (no converter needs to be defined
+ for this) which is then converted to DVI using the `LaTeX to DVI' converter,
+ and finally converting the resulting DVI file to PostScript.
+ LyX finds such `chains' of converters automatically, and it will always
+ choose the shortest possible chain.
+ You can, though, still define multiple conversion methods between file
+ formats.
+ For example, the standard LyX configuration provides three ways to convert
+ LaTeX to PDF: Directly, using 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Tools\SpecialChar \menuseparator
-Preferences\SpecialChar \menuseparator
-File Handling\SpecialChar \menuseparator
-File Formats
+pdflatex
 \end_layout
 
 \end_inset
 
- dialog.
- Press the 
+; via (DVI and) PostScript, using 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-New\SpecialChar \ldots{}
-
+ps2pdf
 \end_layout
 
 \end_inset
 
- button to define your new format.
- The 
+; or via DVI, using 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Format
+dvipdfm
 \end_layout
 
 \end_inset
 
- field contains the named used to identify the format in the GUI.
- The 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-Short Name
-\end_layout
+.
+ To define such alternate chains, you must define multiple target `file
+ formats', as described in section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sec:Formats"
 
 \end_inset
 
- is used to identify the format interally.
- You will also need to enter a file extension.
- These are all required.
- The optional 
+.
+ For example, in the standard configuration, the formats named 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Shortcut
+pdf
 \end_layout
 
 \end_inset
 
- field is used to provide a keyboard shortcut on the menus.
- (For example, pressing 
+, 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Alt-V D
+pdf2
 \end_layout
 
 \end_inset
 
- will 
+, and 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-View\SpecialChar \menuseparator
-DVI
+pdf3
 \end_layout
 
 \end_inset
 
-.) 
-\end_layout
-
-\begin_layout Standard
-A Format can have a 
+ are defined, all of which share the extension 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Viewer
+.pdf
 \end_layout
 
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-Editor
+, and which correspond to the conversion methods just mentioned.
 \end_layout
 
+\begin_layout Chapter
+Internationalizing LyX
+\begin_inset CommandInset label
+LatexCommand label
+name "cha:Internationalizing-LyX"
+
 \end_inset
 
- associated with it.
- For example, you might want to use 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
 
-\begin_layout Plain Layout
-Ghostview
 \end_layout
 
-\end_inset
-
- to view PostScript files.
- You can enter the command needed to start the program in the corresponding
- fields.
- In defining this command, you can use the four variables listed in the
- next section.
- The viewer is launched when you view an image in LyX or use the 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Standard
+LyX supports using a translated interface.
+ Last time we checked, LyX provided text in thirty languages.
+ 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 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-View
+locale(5)
 \end_layout
 
 \end_inset
 
- menu.
- The editor is for example launched when you press the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-Edit
+ could be a good place to start).
 \end_layout
 
-\end_inset
-
- button in the 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Standard
+Notice that these translations will work, but do contain a few flaws.
+ In particular, all dialogs 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 shortcut
+ 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.
+ Our localization team, which you may wish to join,
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-Graphics
+If you are a fluent speaker of a language other than English, joining these
+ teams is a great way to give back to the LyX community!
 \end_layout
 
 \end_inset
 
- or the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-External material
+ will of course try to fix these shortcomings in future versions of LyX.
 \end_layout
 
-\end_inset
+\begin_layout Section
+Translating LyX
+\end_layout
 
- dialog.
+\begin_layout Subsection
+Translating the graphical user interface (text messages).
 \end_layout
 
 \begin_layout Standard
-The 
-\begin_inset Flex CharStyle:MenuItem
+LyX uses the GNU 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Document format
+gettext
 \end_layout
 
 \end_inset
 
- option tells LyX that a format is suitable for document export.
- If this is is set and if a suitable conversion route exists (see 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sub:Converters"
-
-\end_inset
-
-), the format will appear in the 
-\begin_inset Flex CharStyle:MenuItem
+ library to handle the internationalization of the interface.
+ To have LyX speak your favorite language in all menus and dialogs, you
+ need a 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-File\SpecialChar \menuseparator
-Export
+po
 \end_layout
 
 \end_inset
 
- menu.
- The format will also appear in the 
-\begin_inset Flex CharStyle:MenuItem
+-file for that language.
+ When this is available, you'll have to generate a 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-View
+mo
 \end_layout
 
 \end_inset
 
- menu if a viewer is specified for the format.
- Pure image formats, such as 
+-file from it and install the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-png
+mo
 \end_layout
 
 \end_inset
 
-, should not use this option.
- Formats that can both represent vector graphics and documents like 
+-file.
+ The process of doing all of this is explained in the documentation for
+ GNU 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdf
+gettext
 \end_layout
 
 \end_inset
 
- should use it.
+.
+ It is possible to do this just for yourself, but if you're going to do
+ it, you might as well share the results of your labors with the rest of
+ the LyX community.
+ Send a message to the LyX developers' list for more information about how
+ to proceed.
 \end_layout
 
 \begin_layout Standard
-The option 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-Vector graphics format
+In short, this is what you should do (xx denotes the language code):
 \end_layout
 
+\begin_layout Itemize
+Check out the LyX source code.
+ (See the 
+\begin_inset CommandInset href
+LatexCommand href
+name "information on the web"
+target "http://www.lyx.org/devel/cvs.php"
+
 \end_inset
 
- tells LyX that a format can contain vector graphics.
- This information is used to determine the target format of included graphics
- for 
-\begin_inset Flex CharStyle:MenuItem
+.)
+\end_layout
+
+\begin_layout Itemize
+Copy the file 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdflatex
+lyx.pot
 \end_layout
 
 \end_inset
 
- export.
- Included graphics may need to be converted to either 
-\begin_inset Flex CharStyle:MenuItem
+ to the folder of the 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdf
+**.po
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
+ files.
+ Then rename it to 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-png
+xx.po
 \end_layout
 
 \end_inset
 
-, or 
-\begin_inset Flex CharStyle:MenuItem
+.
+ (If 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-jpg
+lyx.pot
 \end_layout
 
 \end_inset
 
-, since 
-\begin_inset Flex CharStyle:MenuItem
+ doesn't exist anywhere, it can be remade with the console command 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdflatex
+make lyx.pot
 \end_layout
 
 \end_inset
 
- cannot handle other image formats.
- If an included graphic is not already in 
-\begin_inset Flex CharStyle:MenuItem
+ in that directory, or you can use an existing po-file for some other language
+ as a template).
+\end_layout
+
+\begin_layout Itemize
+Edit 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdf
+xx.po
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
+.
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-png
+This is just a text file, so it can be edited in any text editor.
+ But there are also specialized programs that support such editing, such
+ as 
+\family typewriter
+Poedit
+\family default
+ (for all platforms) or 
+\family typewriter
+KBabel
+\family default
+ (for KDE).
+\family typewriter
+Emacs
+\family default
+ contains a `mode' for editing 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+po
 \end_layout
 
 \end_inset
 
-, or 
-\begin_inset Flex CharStyle:MenuItem
+ files, as well.
+\end_layout
+
+\end_inset
+
+ For some menu- and widget-labels, there are also shortcut keys that should
+ be translated.
+ Those keys are marked after a `|', and should be translated according to
+ the words and phrases of the language.
+ You should also fill also out the information at the beginning of the new
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-jpg
+po
 \end_layout
 
 \end_inset
 
- format, it is converted to 
-\begin_inset Flex CharStyle:MenuItem
+-file with your email-address, etc., so people know where to reach you with
+ suggestions and entertaining flames.
+\end_layout
+
+\begin_layout Standard
+If you are just doing this on your own, then:
+\end_layout
+
+\begin_layout Itemize
+Generate 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdf
+xx.mo
 \end_layout
 
 \end_inset
 
- if the vector format option is set, and otherwise to 
-\begin_inset Flex CharStyle:MenuItem
+.
+ This can be done with 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-png
+msgfmt -o xx.mo < xx.po
 \end_layout
 
 \end_inset
 .
 \end_layout
 
-\begin_layout Subsection
-Copiers
-\end_layout
-
-\begin_layout Standard
-Since all conversions from one format to another take place in LyX's temporary
- directory, it is sometimes necessary to modify a file before copying it
- to the temporary directory in order that the conversion may be performed.
-\begin_inset Foot
+\begin_layout Itemize
+Copy the 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-For example, the file may refer to other files---images, for example---using
- relative filenames, and these may become invalid when the file is copied
- to the temporary directory.
+mo
 \end_layout
 
 \end_inset
 
- This is done by a Copier: It copies a file to (or from) the temporary directory
- and may modify it in the process.
-\end_layout
-
-\begin_layout Standard
-The definitions of the copiers may use four variables:
-\end_layout
-
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+-file to your locale-tree, at the correct directory for application messages
+ for the language
+\series bold
+\series default
+xx, and under the name 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$s
+lyx.mo
 \end_layout
 
 \end_inset
 
The LyX system directory (e.
+ (e.
 \begin_inset space \thinspace{}
 \end_inset
 
 g.
-\begin_inset space ~
+\begin_inset space \space{}
 \end_inset
 
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-/usr/share/lyx
+/usr/local/share/locale/xx/LC_MESSAGES/lyx.mo
 \end_layout
 
 \end_inset
 
-).
+
+\series bold
+.
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\begin_layout Standard
+As said, however, it would be best if the new 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$i
+po
 \end_layout
 
 \end_inset
 
- The input file
-\end_layout
-
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-$$o
+-file could be added to the LyX distribution, so others can use it.
+ Adding it involves making additional changes to LyX.
+ So send an email to the developers' mailing list if you're interested in
+ doing that.
 \end_layout
 
-\end_inset
-
- The output file
+\begin_layout Subsubsection
+Ambiguous messages
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\begin_layout Standard
+Sometimes it turns out that one English message needs to be translated into
+ different messages in the target language.
+ One example is the message 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$l
+To
 \end_layout
 
 \end_inset
 
- The `LaTeX name'
-\end_layout
-
-\begin_layout Standard
-The latter is to be given in a form suitable for inclusion in a LaTeX's
-\series bold
+ which has the German translation 
+\lang german
+Nach
+\lang english
+ or 
+\lang german
+Bis
+\lang english
+, depending upon exactly what the English 
+\begin_inset Quotes eld
+\end_inset
 
-\backslash
-include
-\series default
- command and is relevant only when exporting files suitable for such inclusion.
-\end_layout
+to
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Standard
-Copiers can be used to do almost anything with output files.
- For example, suppose you want generated pdf files to be copied to a special
- directory, 
+ means.
+ GNU 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-/home/you/pdf/
+gettext
 \end_layout
 
 \end_inset
 
-.
- Then you could write a shell script such as this one:
-\end_layout
-
-\begin_layout Standard
-\begin_inset listings
-inline false
-status open
-
-\begin_layout Plain Layout
-
-#!/bin/bash
-\end_layout
-
-\begin_layout Plain Layout
-
-FROMFILE=$1
-\end_layout
-
-\begin_layout Plain Layout
-
-TOFILE=`basename $2`
-\end_layout
+ does not handle such ambiguous translations.
+ Therefore you have to add some context information to the message: Instead
+ of 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
 \begin_layout Plain Layout
-
-cp $FROMFILE /home/you/pdf/$TOFILE
+To
 \end_layout
 
 \end_inset
 
-Save that in your local LyX directory---say, 
+ it becomes 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-/home/you/.lyx/scripts/pdfcopier.sh
+To[[as in 'From format x to format y']]
 \end_layout
 
 \end_inset
 
----and make it executable, if you need to do so on your platform.
- Then, in the 
-\begin_inset Flex CharStyle:MenuItem
+ and 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Tools\SpecialChar \menuseparator
-Preferences:Copiers
+To[[as in 'From page x to page y']].
 \end_layout
 
 \end_inset
 
- dialog, select the 
-\begin_inset Flex CharStyle:MenuItem
+ Now the two occurrences of 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-PDF(pdflatex)
+To
 \end_layout
 
 \end_inset
 
format---or one of the other pdf formats---and ente
are different fo
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdfcopier.sh $$i $$o
+gettext
 \end_layout
 
 \end_inset
 
- into the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-Copier
+ and can be translated correctly to 
+\lang german
+Nach
+\lang english
+ and 
+\lang german
+Bis
+\lang english
+, respectively.
 \end_layout
 
-\end_inset
+\begin_layout Standard
+Of course the context information needs to be stripped off the original
+ message when no translation is used.
+ Therefore you have to put it in double square brackets at the end of the
+ message (see the example above).
+ The translation mechanism of LyX ensures that everything in double square
+ brackets at the end of messages is removed before displaying the message.
+\end_layout
 
- field.
+\begin_layout Subsection
+Translating the documentation.
 \end_layout
 
 \begin_layout Standard
-Copiers are used by LyX in various of its own conversions.
- For example, if appropriate programs are found, LyX will automatically
- install copiers for the 
+The online documentation (in the 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-HTML
+Help
 \end_layout
 
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:MenuItem
+-menu) can (and should!) be translated.
+ If there are translated versions of the documentation available
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-HTML
-\begin_inset space ~
-\end_inset
-
-(MS Word)
+As of March 2008, at least some of the documents have been translated into
+ fourteen languages, with the Tutorial available in a few more.
 \end_layout
 
 \end_inset
 
- formats.
- When these formats are exported, the copier sees that not just the main
- HTML file but various associated files (style files, images, etc.) are also
- copied.
- All these files are written to a subdirectory of the directory in which
- the original LyX file was found.
-\begin_inset Foot
+ and the locale is set accordingly, these will be used automagically by
+ LyX.
+ LyX looks for translated versions as 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-This copier can be customized.
- The optional 
-\begin_inset Quotes eld
-\end_inset
+LyXDir/doc/xx/DocName.lyx
+\end_layout
 
--e
-\begin_inset Quotes erd
 \end_inset
 
- argument takes a comma-separated list of extensions to be copied; if it
- is omitted, all files will be copied.
- The 
-\begin_inset Quotes eld
-\end_inset
+, where 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
--t
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Plain Layout
+xx
+\end_layout
 
- argument determines the extension added to the generated directory.
- By default, it is 
-\begin_inset Quotes eld
 \end_inset
 
-
-\begin_inset Flex CharStyle:MenuItem
+ is the code for the language currently in use.
+ If there are no translated documents, the default English versions will
+ be displayed.
+ Note that the translated versions must have the same filenames (
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXconv
+DocName
 \end_layout
 
 \end_inset
 
+ above) as the original.
+ If you feel up to translating the documentation (an excellent way to proof-read
+ the original documentation by the way!), there are a few things you should
+ do right away:
+\end_layout
+
+\begin_layout Itemize
+Check out the documentation translation web page at 
+\begin_inset CommandInset href
+LatexCommand href
+name "http://www.lyx.org/Translation"
+target "http://www.lyx.org/Translation"
 
-\begin_inset Quotes erd
 \end_inset
 
-, so HTML generated from 
-\begin_inset Flex CharStyle:MenuItem
+.
+ That way, you can find out which (if any) documents have already been translate
+d into your language.
+ You can also find out who (if anyone) is organizing the effort to translate
+ the documentation into your language.
+ If no one is organizing the effort, please let us know that you're interested.
+\end_layout
+
+\begin_layout Standard
+Once you get to actually translating, here's a few hints for you that may
+ save you trouble:
+\end_layout
+
+\begin_layout Itemize
+Join the documentation team! There is information on how to do that in 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-/path/to/filename.lyx
+Intro.lyx
 \end_layout
 
 \end_inset
 
- will end up in 
+ (
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-/path/to/filename.html.LyXconv
+Help\SpecialChar \menuseparator
+Introduction
 \end_layout
 
 \end_inset
 
-.
+), which by the way is the first document you should translate.
 \end_layout
 
-\end_inset
+\begin_layout Itemize
+Learn the typographic conventions for the language you are translating to.
+ Typography is an ancient art and over the centuries, a great variety of
+ conventions have 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 addictive!)
+\end_layout
 
+\begin_layout Itemize
+Make a copy of the document.
+ This will be your working copy.
+ You can use this as your personal translated help-file by placing it in
+ your 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
+\begin_layout Plain Layout
+UserDir/doc/xx/
 \end_layout
 
-\begin_layout Subsection
-\begin_inset CommandInset label
-LatexCommand label
-name "sub:Converters"
-
 \end_inset
 
-Converters
+ directory.
 \end_layout
 
-\begin_layout Standard
-You can define your own Converters to, uhh, convert files between different
- formats.
- This is done in the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-Tools\SpecialChar \menuseparator
-Preferences\SpecialChar \menuseparator
-File Handling\SpecialChar \menuseparator
-Converters
-\end_layout
+\begin_layout Itemize
+Sometimes the original document (from the LyX-team) will be updated.
+ Use the source viewer at 
+\begin_inset CommandInset href
+LatexCommand href
+name "http://www.lyx.org/trac/timeline"
+target "http://www.lyx.org/trac/timeline"
 
 \end_inset
 
- dialog.
+ to see what has been changed.
+ That way you can easily see which parts of the translated document need
+ to be updated.
 \end_layout
 
 \begin_layout Standard
-To define a new converter, select the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-From
-\begin_inset space ~
-\end_inset
-
-format
+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?)
 \end_layout
 
-\end_inset
-
- and
-\begin_inset space \thinspace{}
-\end_inset
-
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Standard
+\begin_inset Branch OutDated
 status collapsed
 
-\begin_layout Plain Layout
-To
-\begin_inset space ~
-\end_inset
-
-format
+\begin_layout Section
+International Keyboard Support
 \end_layout
 
-\end_inset
-
- from the drop-down lists, enter the command needed for the conversion,
- and then press the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+\begin_layout Standard
 
-\begin_layout Plain Layout
-Add
+\emph on
+[Editor's Note: The following section is by
+\emph default
+\shape smallcaps
+\emph on
+Ivan Schreter
+\shape default
+.
+ 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
+ It may also be badly out of date.-rh (2008)]
 \end_layout
 
-\end_inset
+\begin_layout Subsection
+Defining Own Keymaps: Keymap File Format
+\end_layout
 
- button.
- Several variables can be used in the definition of converters:
+\begin_layout Standard
+Let's look at a keyboard definition file a little closer.
+ It is a plain text file defining
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Itemize
+key-to-key or key-to-string translations
+\end_layout
 
-\begin_layout Plain Layout
-$$s
+\begin_layout Itemize
+dead keys
 \end_layout
 
-\end_inset
+\begin_layout Itemize
+dead keys exceptions
+\end_layout
 
- The LyX system directory
+\begin_layout Standard
+To define key-to-key or key-to-string translation, use this command:
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\begin_layout Quotation
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$i
+
+\backslash
+kmap
 \end_layout
 
 \end_inset
 
- The input file
-\end_layout
-
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$o
+key
 \end_layout
 
 \end_inset
 
- The output file
+ outstring 
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\begin_layout Standard
+where 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$b
+key
 \end_layout
 
 \end_inset
 
- The base filename of the input file (i.e., without the extension)
-\end_layout
-
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+ is the key to be translated and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$p
+outstring
 \end_layout
 
 \end_inset
 
- The path to the input file
+ is the string to be inserted into the document.
+ To define dead keys, use:
 \end_layout
 
-\begin_layout Standard
-In the 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Quotation
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Extra
-\begin_inset space ~
-\end_inset
 
-Flag
+\backslash
+kmod
 \end_layout
 
 \end_inset
 
- field you can enter the following flags, separated by commas:
-\end_layout
-
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-latex
+key
 \end_layout
 
 \end_inset
 
- This converter runs some form of LaTeX.
- This will make LyX's LaTeX error logs available.
+ deadkey
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\begin_layout Standard
+where 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-needaux
+key
 \end_layout
 
 \end_inset
 
- Needs the LaTeX 
-\begin_inset Flex CharStyle:MenuItem
+ is a keyboard key and 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.aux
+deadkey
 \end_layout
 
 \end_inset
 
- file for the conversion.
+ is dead key name.
+ The following dead keys are supported (shortcut name is in parentheses):
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-xml
-\end_layout
+\begin_layout Quotation
 
+\emph on
+Name
+\begin_inset space \hfill{}
 \end_inset
 
- Output is XML.
+Example
 \end_layout
 
-\begin_layout Standard
-The following three flags are not really flags at all because they take
- an argument in the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-key
-\begin_inset space ~
+\begin_layout Quotation
+acute (acu)
+\begin_inset space \hfill{}
 \end_inset
 
-=
-\begin_inset space ~
+áéíóú
+\end_layout
+
+\begin_layout Quotation
+grave (gra)
+\begin_inset space \hfill{}
 \end_inset
 
-value
+àèìòù
 \end_layout
 
+\begin_layout Quotation
+macron (mac)
+\begin_inset space \hfill{}
 \end_inset
 
- format:
+ ō
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Quotation
+tilde (til)
+\begin_inset space \hfill{}
+\end_inset
 
-\begin_layout Plain Layout
-parselog
+ñÑ
 \end_layout
 
+\begin_layout Quotation
+underbar (underb)
+\begin_inset space \hfill{}
 \end_inset
 
- If set, the converter's standard error will be redirected to a file 
-\begin_inset Flex CharStyle:Code
-status collapsed
+
+\begin_inset ERT
+status open
 
 \begin_layout Plain Layout
-infile.out
+
+
+\backslash
+b o
 \end_layout
 
 \end_inset
 
-, and the script given as argument will be run as: 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-script <infile.out >infile.log
 \end_layout
 
+\begin_layout Quotation
+cedilla (ced)
+\begin_inset space \hfill{}
 \end_inset
 
-.
- The argument may contain 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-$$s
+çÇ
 \end_layout
 
+\begin_layout Quotation
+underdot (underd)
+\begin_inset space \hfill{}
 \end_inset
 
-.
-\end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_inset ERT
+status open
 
 \begin_layout Plain Layout
-resultdir
+
+
+\backslash
+d o
 \end_layout
 
 \end_inset
 
- The name of the directory in which the converter will dump the generated
- files.
- LyX will not create this directory, and it does not copy anything into
- it, though it will copy this directory to the destination.
- The argument may contain 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-$$b
 \end_layout
 
+\begin_layout Quotation
+circumflex (circu)
+\begin_inset space \hfill{}
 \end_inset
 
-, which will be replaced by the basename of the input and output files,
- respectively, when the directory is copied.
-\begin_inset Newline newline
-\end_inset
-
-Note that resultdir and usetempdir make no sense together.
- The latter will be ignored if the former is given.
+âêîôû
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Quotation
+circle (circl)
+\begin_inset space \hfill{}
+\end_inset
 
-\begin_layout Plain Layout
-resultfile
+ÅůŮ
 \end_layout
 
+\begin_layout Quotation
+tie (tie)
+\begin_inset space \hfill{}
 \end_inset
 
- Determines the output filename and may, contain 
-\begin_inset Flex CharStyle:Code
-status collapsed
+
+\begin_inset ERT
+status open
 
 \begin_layout Plain Layout
-$$b
+
+
+\backslash
+t o
 \end_layout
 
 \end_inset
 
-.
- Sensible only with resultdir and optional even then; if not given, it defaults
- to `index'.
-\end_layout
 
-\begin_layout Standard
-None of these last three are presently used in any of the converters that
- are installed with LyX.
 \end_layout
 
-\begin_layout Standard
-You do not have to define converters between all the formats between which
- you want to convert.
- For example, you will note that there is no `LyX to PostScript®' converter,
- but LyX will export PostScript®.
- It does so by first creating a LaTeX file (no converter needs to be defined
- for this) which is then converted to DVI using the `LaTeX to DVI' converter,
- and finally converting the resulting DVI file to PostScript®.
- LyX finds such `chains' of converters automatically, and it will always
- choose the shortest possible chain.
- You can, though, still define multiple conversion methods between file
- formats.
- For example, the standard LyX configuration provides three ways to convert
- LaTeX to PDF: Directly, using 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+\begin_layout Quotation
+breve (bre)
+\begin_inset space \hfill{}
+\end_inset
+
+\begin_inset ERT
+status open
 
 \begin_layout Plain Layout
-pdflatex
+
+
+\backslash
+u o
 \end_layout
 
 \end_inset
 
-; via (DVI and) PostScript®, using 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
 
-\begin_layout Plain Layout
-ps2pdf
 \end_layout
 
+\begin_layout Quotation
+caron (car)
+\begin_inset space \hfill{}
 \end_inset
 
-; or via DVI, using 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+čšž
+\end_layout
 
-\begin_layout Plain Layout
-dvipdfm
+\begin_layout Quotation
+hungarian umlaut (hug)
+\begin_inset space \hfill{}
+\end_inset
+
+őű
 \end_layout
 
+\begin_layout Quotation
+umlaut (uml)
+\begin_inset space \hfill{}
 \end_inset
 
-.
- To define such alternate chains, you must define multiple target `file
- formats', as described in section 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sub:Formats"
+äöü
+\end_layout
 
+\begin_layout Quotation
+dot (dot)
+\begin_inset space \hfill{}
 \end_inset
 
-.
- For example, in the standard configuration, the formats named 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+\begin_inset ERT
+status open
 
 \begin_layout Plain Layout
-pdf
+
+
+\backslash
+.s
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
 
-\begin_layout Plain Layout
-pdf2
 \end_layout
 
-\end_inset
+\begin_layout Standard
+Since in many international keyboards there are exceptions to what some
+ dead keys should do, you can define them using
+\end_layout
 
-, and 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Quotation
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdf3
+
+\backslash
+kxmod
 \end_layout
 
 \end_inset
 
- are defined, all of which share the extension 
-\begin_inset Flex CharStyle:MenuItem
+ deadkey key outstring
+\end_layout
+
+\begin_layout Standard
+For example, on Slovak keyboard, if you enter caron-o, it generates circumflex-o
+, so you put in
+\end_layout
+
+\begin_layout Quotation
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.pdf
+
+\backslash
+kxmod
 \end_layout
 
 \end_inset
 
-, and which correspond to the conversion methods just mentioned.
+ caron o "
+\backslash
+^o"
 \end_layout
 
-\begin_layout Section
-Output 
+\begin_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 haven't had time.
 \end_layout
 
 \begin_layout Standard
-The settings in this section affect the output LyX produces.
-\end_layout
+Oh, and about characters: backslash is escaped, so to enter it, you'll need
+ double backslash.
+ Also, quotes and 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Subsection
-Plain text export options
+\begin_layout Plain Layout
+#
 \end_layout
 
-\begin_layout Standard
-\noindent
-There are a couple of commands that can be used to 
-\begin_inset Quotes eld
-\end_inset
-
-clean up
-\begin_inset Quotes erd
 \end_inset
 
- exported plain text files.
- Note that LyX automatically detects and tries to use the best settings
- for your system at installation time, but you can modify them in the 
-\begin_inset Flex CharStyle:MenuItem
+ have different meaning.
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Output\SpecialChar \menuseparator
-Plain Text
+#
 \end_layout
 
 \end_inset
 
- dialog if you disagree with its interpretation.
-\end_layout
-
-\begin_layout Description
+ marks comments, quotes start and end LaTeX-style commands.
+ To enter quote, you'll need to use 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-roff command
+
+\backslash
+"
 \end_layout
 
 \end_inset
 
- This option defines the command used to produce better plain text tables
- with the 
+, to enter 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-groff/troff/nroff
+#
 \end_layout
 
 \end_inset
 
- UNIX-commands (refer to their manpages for more information about them).
- Setting this as empty tells LyX to use the internal (inferior) formatter.
-\end_layout
-
-\begin_layout Description
+, use 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Output line length
+
+\backslash
+#
 \end_layout
 
 \end_inset
 
- With this command you can set the default line length of the plain text
- output file.
- Setting it to 0 means that no line breaks will be inserted except between
- paragraphs and the like.
+.
 \end_layout
 
-\begin_layout Section
-The rest
+\begin_layout Standard
+If you make a keyboard description file that works for your language, please
+ mail it to me, so I can include it in the next keymap distribution.
 \end_layout
 
 \begin_layout Standard
-There are many other configuration options that can be used to customize
- LyX behavior.
- Most of them are sufficiently self-explanatory that we have not felt it
- necessary to document them here.
- Please ask on the 
-\begin_inset CommandInset href
-LatexCommand href
-name "mailing lists"
-target "http://www.lyx.org/mailing.php"
+More keywords will be supported in keymap configuration file in future,
+ like
+\end_layout
 
-\end_inset
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
+status collapsed
 
- if you need some more information.
-\end_layout
+\begin_layout Plain Layout
 
-\begin_layout Chapter
-Internationalizing LyX
-\begin_inset CommandInset label
-LatexCommand label
-name "chap:i18n"
+\backslash
+kinclude filename
+\end_layout
 
 \end_inset
 
 
-\end_layout
-
-\begin_layout Standard
-LyX supports using a translated interface.
- Last time we checked, LyX provided text in thirty languages.
- 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 
+
+\begin_inset space \hfill{}
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-locale(5)
+include
 \end_layout
 
 \end_inset
 
- could be a good place to start).
+ another file
 \end_layout
 
-\begin_layout Standard
-Notice that these translations will work, but do contain a few flaws.
- In particular, all dialogs 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 shortcut
- 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.
- Our localization team, which you may wish to join,
-\begin_inset Foot
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-If you are a fluent speaker of a language other than English, joining these
- teams is a great way to give back to the LyX community!
+
+\backslash
+kprog program
 \end_layout
 
 \end_inset
 
- will of course try to fix these shortcomings in future versions of LyX.
-\end_layout
 
-\begin_layout Section
-Translating LyX
-\end_layout
+\emph on
+
+\begin_inset space \hfill{}
+\end_inset
 
-\begin_layout Subsection
-Translating the graphical user interface (text messages).
-\end_layout
 
-\begin_layout Standard
-LyX uses the GNU 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-gettext
+define
 \end_layout
 
 \end_inset
 
- library to handle the internationalization of the interface.
- To have LyX speak your favorite language in all menus and dialogs, you
- need a 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-po
+ an external keymap translation program 
 \end_layout
 
-\end_inset
-
--file for that language.
- When this is available, you'll have to generate a 
+\begin_layout Standard
+Also, it should look into 
 \begin_inset Flex CharStyle:Code
-status open
+status collapsed
 
 \begin_layout Plain Layout
-mo
+lyxrc
 \end_layout
 
 \end_inset
 
--file from it and install the 
+ file for defaults, too (for example, a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-mo
+
+\backslash
+kinclude
 \end_layout
 
 \end_inset
 
--file.
- The process of doing all of this is explained in the documentation for
- GNU 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-gettext
+ option to include default keyboard).
 \end_layout
 
 \end_inset
 
-.
- It is possible to do this just for yourself, but if you're going to do
- it, you might as well share the results of your labors with the rest of
- the LyX community.
- Send a message to the LyX developers' list for more information about how
- to proceed.
-\end_layout
 
-\begin_layout Standard
-In short, this is what you should do (xx denotes the language code):
 \end_layout
 
-\begin_layout Itemize
-Check out the LyX source code.
- (See the 
-\begin_inset CommandInset href
-LatexCommand href
-name "information on the web"
-target "http://www.lyx.org/devel/cvs.php"
+\begin_layout Section
+International Keymap Stuff
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:International-Keymap-Stuff"
 
 \end_inset
 
-.)
+
 \end_layout
 
-\begin_layout Itemize
-Copy the file 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Standard
+\begin_inset Note Note
+status open
 
 \begin_layout Plain Layout
-lyx.pot
+In doing the revisions on this document in March 2008, I did not look over
+ this stuff, as I do not understand it.
+ It would be good if someone else could do so.
+ (RH)
 \end_layout
 
 \end_inset
 
- to the folder of the 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-**.po
 \end_layout
 
-\end_inset
-
- files.
- Then rename it to 
+\begin_layout Standard
+The next two sections describe the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xx.po
+
+\shape up
+.kmap
 \end_layout
 
 \end_inset
 
-.
- (If 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyx.pot
+
+\shape up
+.cdef
 \end_layout
 
 \end_inset
 
- doesn't exist anywhere, it can be remade with the console command 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-make lyx.pot
+ file syntax in detail.
+ These sections should help you design your own key map if the ones provided
+ do not meet your needs.
 \end_layout
 
-\end_inset
-
- in that directory, or you can use an existing po-file for some other language
- as a template).
+\begin_layout Subsection
+The .kmap File
 \end_layout
 
-\begin_layout Itemize
-Edit 
+\begin_layout Standard
+A 
+\shape up
+.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xx.po
+kmap
 \end_layout
 
 \end_inset
 
-.
-\begin_inset Foot
-status collapsed
-
-\begin_layout Plain Layout
-This is just a text file, so it can be edited in any text editor.
- But there are also specialized programs that support such editing, such
- as 
-\family typewriter
-Poedit
-\family default
- (for all platforms) or 
-\family typewriter
-KBabel
-\family default
- (for KDE).
-\family typewriter
-Emacs
-\family default
- contains a `mode' for editing 
+ file maps keystrokes to characters or strings.
+ As the name suggests, it sets a keyboard mapping.
+ The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-po
+.kmap
 \end_layout
 
 \end_inset
 
- files, as well.
-\end_layout
 
-\end_inset
+\shape default
+ file keywords 
+\shape up
 
- For some menu- and widget-labels, there are also shortcut keys that should
- be translated.
- Those keys are marked after a `|', and should be translated according to
- the words and phrases of the language.
- You should also fill also out the information at the beginning of the new
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-po
+
+\shape up
+kmap
 \end_layout
 
 \end_inset
 
--file with your email-address, etc., so people know where to reach you with
- suggestions and entertaining flames.
-\end_layout
 
-\begin_layout Standard
-If you are just doing this on your own, then:
-\end_layout
+\shape default
+,
+\shape up
+\shape default
 
-\begin_layout Itemize
-Generate 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xx.mo
-\end_layout
-
-\end_inset
-
-.
- This can be done with 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-msgfmt -o xx.mo < xx.po
+\shape up
+kmod
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+,
+\shape up
+\shape default
 
-\begin_layout Itemize
-Copy the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-mo
+
+\shape up
+ksmod
 \end_layout
 
 \end_inset
 
--file to your locale-tree, at the correct directory for application messages
- for the language
-\series bold
-\series default
-xx, and under the name 
+, and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyx.mo
+
+\shape up
+kcomb
 \end_layout
 
 \end_inset
 
- (e.g.
+ are described in this section.
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-/usr/local/share/locale/xx/LC_MESSAGES/lyx.mo
+
+\shape up
+kmap
 \end_layout
 
 \end_inset
 
-
-\series bold
-.
-\end_layout
-
-\begin_layout Standard
-As said, however, it would be best if the new 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-po
-\end_layout
-
-\end_inset
-
--file could be added to the LyX distribution, so others can use it.
- Adding it involves making additional changes to LyX.
- So send an email to the developers' mailing list if you're interested in
- doing that.
-\end_layout
-
-\begin_layout Subsubsection
-Ambigous messages
-\end_layout
-
-\begin_layout Standard
-Sometimes it turns out that one English message needs to be translated into
- different messages in the target language.
- One example is the message 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-To
-\end_layout
-
-\end_inset
-
- which has the German translation 
-\lang german
-Nach
-\lang english
- or 
-\lang german
-Bis
-\lang english
-, depending upon exactly what the English 
-\begin_inset Quotes eld
-\end_inset
-
-to
-\begin_inset Quotes erd
-\end_inset
-
- means.
- GNU 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-gettext
-\end_layout
-
-\end_inset
-
- does not handle such ambigous translations.
- Therefore you have to add some context information to the message: Instead
- of 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-To
-\end_layout
-
-\end_inset
-
- it becomes 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-To[[as in 'From format x to format y']]
-\end_layout
-
-\end_inset
-
- and 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-To[[as in 'From page x to page y']].
-\end_layout
-
-\end_inset
-
- Now the two occurences of 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-To
-\end_layout
-
-\end_inset
-
- are different for 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-gettext
-\end_layout
-
-\end_inset
-
- and can be translated correctly to 
-\lang german
-Nach
-\lang english
- and 
-\lang german
-Bis
-\lang english
-, respectively.
-\end_layout
-
-\begin_layout Standard
-Of course the context information needs to be stripped off the original
- message when no translation is used.
- Therefore you have to put it in double square brackets at the end of the
- message (see the example above).
- The translation mechanism of LyX ensures that everything in double square
- brackets at the end of messages is removed before displaying the message.
-\end_layout
-
-\begin_layout Subsection
-Translating the documentation.
-\end_layout
-
-\begin_layout Standard
-The online documentation (in the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp
-\end_layout
-
-\end_inset
-
--menu) can (and should!) be translated.
- If there are translated versions of the documentation available
-\begin_inset Foot
-status collapsed
-
-\begin_layout Plain Layout
-As of March 2008, at least some of the documents have been translated into
- fourteen languages, with the Tutorial available in a few more.
-\end_layout
-
-\end_inset
-
- and the locale is set accordingly, these will be used automagically by
- LyX.
- LyX looks for translated versions as 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-LyXDir/doc/xx_DocName.lyx
-\end_layout
-
-\end_inset
-
-, where 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-xx
-\end_layout
-
-\end_inset
-
- is the code for the language currently in use.
- If there are no translated documents, the default English versions will
- be displayed.
- Note that the translated versions must have the same filenames (
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-DocName
-\end_layout
-
-\end_inset
-
- above) as the original.
- If you feel up to translating the documentation (an excellent way to proof-read
- the original documentation by the way!), there are a few things you should
- do right away:
-\end_layout
-
-\begin_layout Itemize
-Read 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-DocStyle.lyx
-\end_layout
-
-\end_inset
-
-, the guide to writing LyX documentation.
- Pay special attention to the translator's section.
-\end_layout
-
-\begin_layout Itemize
-Check out the documentation translation web page at 
-\begin_inset CommandInset href
-LatexCommand href
-name "http://www.devel.lyx.org"
-target "http://www.devel.lyx.org"
-
-\end_inset
-
-.
- That way, you can find out which (if any) documents have already been translate
-d into your language.
- You can also find out who (if anyone) is organizing the effort to translate
- the documentation into your language.
- If no one is organizing the effort, please let us know that you're interested.
-\end_layout
-
-\begin_layout Standard
-Once you get to actually translating, here's a few hints for you that may
- save you trouble:
-\end_layout
-
-\begin_layout Itemize
-Join the documentation team! There is information on how to do that in 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-Intro.lyx
-\end_layout
-
-\end_inset
-
- (
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp\SpecialChar \menuseparator
-
-\bar under
-I
-\bar default
-ntroduction
-\end_layout
-
-\end_inset
-
-), which by the way is the first document you should translate.
-\end_layout
-
-\begin_layout Itemize
-Learn the typographic conventions for the language you are translating to.
- Typography is an ancient art and over the centuries, a great variety of
- conventions have 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 addictive!)
-\end_layout
-
-\begin_layout Itemize
-Make a copy of the document.
- This will be your working copy.
- You can use this as your personal translated help-file by placing it in
- your 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-UserDir/doc/
-\end_layout
-
-\end_inset
-
- directory.
-\end_layout
-
-\begin_layout Itemize
-Sometimes the original document (from the LyX-team) will be updated.
- Use the source viewer at 
-\begin_inset CommandInset href
-LatexCommand href
-name "http://www.lyx.org/trac/timeline"
-target "http://www.lyx.org/trac/timeline"
-
-\end_inset
-
- to see what has been changed.
- That way you can easily see which parts of the translated document need
- to be updated.
-\end_layout
-
-\begin_layout Standard
-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?)
-\end_layout
-
-\begin_layout Standard
-\begin_inset Branch OutDated
-status collapsed
-
-\begin_layout Section
-International Keyboard Support
-\end_layout
-
-\begin_layout Standard
-
-\emph on
-[Editor's Note: The following section is by
-\emph default
-\shape smallcaps
-\emph on
-Ivan Schreter
-\shape default
-.
- 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
- It may also be badly out of date.-rh (2008)]
-\end_layout
-
-\begin_layout Subsection
-Defining Own Keymaps: Keymap File Format
-\end_layout
-
-\begin_layout Standard
-Let's look at a keyboard definition file a little closer.
- It is a plain text file defining
-\end_layout
-
-\begin_layout Itemize
-key-to-key or key-to-string translations
-\end_layout
-
-\begin_layout Itemize
-dead keys
-\end_layout
-
-\begin_layout Itemize
-dead keys exceptions
-\end_layout
-
-\begin_layout Standard
-To define key-to-key or key-to-string translation, use this command:
-\end_layout
-
-\begin_layout Quotation
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-kmap
-\end_layout
-
-\end_inset
-
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-key
-\end_layout
-
-\end_inset
-
- outstring 
-\end_layout
-
-\begin_layout Standard
-where 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-key
-\end_layout
-
-\end_inset
-
- is the key to be translated and 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-outstring
-\end_layout
-
-\end_inset
-
- is the string to be inserted into the document.
- To define dead keys, use:
-\end_layout
-
-\begin_layout Quotation
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-kmod
-\end_layout
-
-\end_inset
-
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-key
-\end_layout
-
-\end_inset
-
- deadkey
-\end_layout
-
-\begin_layout Standard
-where 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-key
-\end_layout
-
-\end_inset
-
- is a keyboard key and 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-deadkey
-\end_layout
-
-\end_inset
-
- is dead key name.
- The following dead keys are supported (shortcut name is in parentheses):
-\end_layout
-
-\begin_layout Quotation
-
-\emph on
-Name
-\begin_inset space \hfill{}
-\end_inset
-
-Example
-\end_layout
-
-\begin_layout Quotation
-acute (acu)
-\begin_inset space \hfill{}
-\end_inset
-
-áéíóú
-\end_layout
-
-\begin_layout Quotation
-grave (gra)
-\begin_inset space \hfill{}
-\end_inset
-
-àèìòù
-\end_layout
-
-\begin_layout Quotation
-macron (mac)
-\begin_inset space \hfill{}
-\end_inset
-
- ō
-\end_layout
-
-\begin_layout Quotation
-tilde (til)
-\begin_inset space \hfill{}
-\end_inset
-
-ñÑ
-\end_layout
-
-\begin_layout Quotation
-underbar (underb)
-\begin_inset space \hfill{}
-\end_inset
-
-
-\begin_inset ERT
-status open
-
-\begin_layout Plain Layout
-
-
-\backslash
-b o
-\end_layout
-
-\end_inset
-
-
-\end_layout
-
-\begin_layout Quotation
-cedilla (ced)
-\begin_inset space \hfill{}
-\end_inset
-
-çÇ
-\end_layout
-
-\begin_layout Quotation
-underdot (underd)
-\begin_inset space \hfill{}
-\end_inset
-
-
-\begin_inset ERT
-status open
-
-\begin_layout Plain Layout
-
-
-\backslash
-d o
-\end_layout
-
-\end_inset
-
-
-\end_layout
-
-\begin_layout Quotation
-circumflex (circu)
-\begin_inset space \hfill{}
-\end_inset
-
-âêîôû
-\end_layout
-
-\begin_layout Quotation
-circle (circl)
-\begin_inset space \hfill{}
-\end_inset
-
-ÅůŮ
-\end_layout
-
-\begin_layout Quotation
-tie (tie)
-\begin_inset space \hfill{}
-\end_inset
-
-
-\begin_inset ERT
-status open
-
-\begin_layout Plain Layout
-
-
-\backslash
-t o
-\end_layout
-
-\end_inset
-
-
-\end_layout
-
-\begin_layout Quotation
-breve (bre)
-\begin_inset space \hfill{}
-\end_inset
-
-\begin_inset ERT
-status open
-
-\begin_layout Plain Layout
-
-
-\backslash
-u o
-\end_layout
-
-\end_inset
-
-
-\end_layout
-
-\begin_layout Quotation
-caron (car)
-\begin_inset space \hfill{}
-\end_inset
-
-čšž
-\end_layout
-
-\begin_layout Quotation
-hungarian umlaut (hug)
-\begin_inset space \hfill{}
-\end_inset
-
-őű
-\end_layout
-
-\begin_layout Quotation
-umlaut (uml)
-\begin_inset space \hfill{}
-\end_inset
-
-äöü
-\end_layout
-
-\begin_layout Quotation
-dot (dot)
-\begin_inset space \hfill{}
-\end_inset
-
-\begin_inset ERT
-status open
-
-\begin_layout Plain Layout
-
-
-\backslash
-.s
-\end_layout
-
-\end_inset
-
-
-\end_layout
-
-\begin_layout Standard
-Since in many international keyboards there are exceptions to what some
- dead keys should do, you can define them using
-\end_layout
-
-\begin_layout Quotation
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-kxmod
-\end_layout
-
-\end_inset
-
- deadkey key outstring
-\end_layout
-
-\begin_layout Standard
-For example, on Slovak keyboard, if you enter caron-o, it generates circumflex-o
-, so you put in
-\end_layout
-
-\begin_layout Quotation
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-kxmod
-\end_layout
-
-\end_inset
-
- caron o "
-\backslash
-^o"
-\end_layout
-
-\begin_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 haven't had time.
-\end_layout
-
-\begin_layout Standard
-Oh, and about characters: backslash is escaped, so to enter it, you'll need
- double backslash.
- Also, quotes and 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-#
-\end_layout
-
-\end_inset
-
- have different meaning.
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-#
-\end_layout
-
-\end_inset
-
- marks comments, quotes start and end LaTeX-style commands.
- To enter quote, you'll need to use 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-"
-\end_layout
-
-\end_inset
-
-, to enter 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-#
-\end_layout
-
-\end_inset
-
-, use 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-#
-\end_layout
-
-\end_inset
-
-.
-\end_layout
-
-\begin_layout Standard
-If you make a keyboard description file that works for your language, please
- mail it to me, so I can include it in the next keymap distribution.
-\end_layout
-
-\begin_layout Standard
-More keywords will be supported in keymap configuration file in future,
- like
-\end_layout
-
-\begin_layout Itemize
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-kinclude filename
-\end_layout
-
-\end_inset
-
-
-\emph on
-
-\begin_inset space \hfill{}
-\end_inset
-
-
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-include
-\end_layout
-
-\end_inset
-
- another file
-\end_layout
-
-\begin_layout Itemize
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-kprog program
-\end_layout
-
-\end_inset
-
-
-\emph on
-
-\begin_inset space \hfill{}
-\end_inset
-
-
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-define
-\end_layout
-
-\end_inset
-
- an external keymap translation program 
-\end_layout
-
-\begin_layout Standard
-Also, it should look into 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-lyxrc
-\end_layout
-
-\end_inset
-
- file for defaults, too (for example, a 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-kinclude
-\end_layout
-
-\end_inset
-
- option to include default keyboard).
-\end_layout
-
-\end_inset
-
-
-\end_layout
-
-\begin_layout Section
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:keymap"
-
-\end_inset
-
-International Keymap Stuff
-\end_layout
-
-\begin_layout Standard
-\begin_inset Note Note
-status open
-
-\begin_layout Plain Layout
-In doing the revisions on this document in March 2008, I did not look over
- this stuff, as I do not understand it.
- It would be good if someone else could do so.
-\end_layout
-
-\end_inset
-
-
-\end_layout
-
-\begin_layout Standard
-The next two sections describe the 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\shape up
-.kmap
-\end_layout
-
-\end_inset
-
- and 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\shape up
-.cdef
-\end_layout
-
-\end_inset
-
- file syntax in detail.
- These sections should help you design your own key map if the ones provided
- do not meet your needs.
-\end_layout
-
-\begin_layout Subsection
-The .kmap File
-\end_layout
-
-\begin_layout Standard
-A 
-\shape up
-.
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-kmap
-\end_layout
-
-\end_inset
-
- file maps keystrokes to characters or strings.
- As the name suggests, it sets a keyboard mapping.
- The 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-.kmap
-\end_layout
-
-\end_inset
-
-
-\shape default
- file keywords 
-\shape up
-
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\shape up
-kmap
-\end_layout
-
-\end_inset
-
-
-\shape default
-,
-\shape up
-\shape default
-
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\shape up
-kmod
-\end_layout
-
-\end_inset
-
-,
-\shape up
-\shape default
-
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\shape up
-ksmod
-\end_layout
-
-\end_inset
-
-, and 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\shape up
-kcomb
-\end_layout
-
-\end_inset
-
- are described in this section.
-\end_layout
-
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\shape up
-kmap
-\end_layout
-
-\end_inset
-
- Map a character to a string
+ Map a character to a string
 \end_layout
 
 \begin_layout LyX-Code
@@ -5412,7 +4050,7 @@ char
 \emph default
  
 \family roman
-followed by the other, unallowed key, as output.
+followed by the other, not allowed key, as output.
 
 \family default
  Note that a 
@@ -5621,12 +4259,7 @@ sequence,
 \shape up
 \emph on
 result
-\family default
-\shape default
 \emph default
-\family roman
-\shape up
  is produced.
  If such a declaration does not exist in
 \family default
@@ -5654,7 +4287,7 @@ u enter
  
 \family roman
 \emph on
-accent  char
+accent char
 \emph default
 , you get
 \family default
@@ -5662,20 +4295,14 @@ accent  char
 \family roman
 \emph on
 accent_key char
-\family default
 \emph default
-\family roman
  where
 \family default
  
 \family roman
 \emph on
 accent_key
-\family default
 \emph default
-\family roman
  is the first arg
 \family default
 ument of the 
@@ -6394,7 +5021,7 @@ xkeycaps
 
 \end_inset
 
 to set up the special 
+ to set up the special 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -6587,28 +5214,14 @@ Saving your Language Configuration
 \end_layout
 
 \begin_layout Standard
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:savlang"
-
-\end_inset
-
 You can edit your preferences so that your desired language environment
  is automatically configured when LyX starts up, via the 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-E
-\bar default
-dit\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-references
+Edit\SpecialChar \menuseparator
+Preferences
 \end_layout
 
 \end_inset
@@ -6617,10 +5230,10 @@ references
 \end_layout
 
 \begin_layout Chapter
-Installing New Document Classes, Layouts, and Templates 
+Installing New Document Classes, Layouts, and Templates
 \begin_inset CommandInset label
 LatexCommand label
-name "chap:textclass"
+name "cha:Installing-New-Document"
 
 \end_inset
 
@@ -6641,7 +5254,190 @@ Installing New Document Classes
 In this chapter, we describe the procedures for creating and installing
  new LyX layout and template files, as well as offer a refresher on correctly
  installing new LaTeX document classes.
- Some definitions: a document class is a LaTeX file (usually ending in 
+\end_layout
+
+\begin_layout Standard
+First, let us a say a few words about how one ought to think about the relation
+ between LyX and LaTeX.
+ The thing to understand is that, in a certain sense, LyX doesn't know anything
+ about LaTeX.
+ Indeed, from LyX's point of view, LaTeX is just one of several 
+\begin_inset Quotes eld
+\end_inset
+
+backend formats
+\begin_inset Quotes erd
+\end_inset
+
+ in which it is capable of producing output.
+ Other such formats are DocBook, plaintext, and XHTML.
+ LaTeX is, of course, a particularly important format, but very little of
+ the information LyX has about LaTeX is actually contained in the program
+ itself.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+Some commands are sufficiently complex that they are 
+\begin_inset Quotes eld
+\end_inset
+
+hardcoded
+\begin_inset Quotes erd
+\end_inset
+
+ into LyX.
+ But the developers generally regard this as a Bad Thing.
+\end_layout
+
+\end_inset
+
+ Rather, that information, even for the standard classes like 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+article.cls
+\end_layout
+
+\end_inset
+
+, is contained in layout files.
+\end_layout
+
+\begin_layout Standard
+You can think of the layout file for a given document class as a translation
+ manual between LyX constructs---paragraphs with their corresponding styles,
+ certain sorts of insets, etc---and the corresponding LaTeX constructs.
+ Almost everything LyX knows about 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+article.cls
+\end_layout
+
+\end_inset
+
+, for example, is contained in the file 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+article.layout
+\end_layout
+
+\end_inset
+
+.
+ For this reason, anyone intending to write layout files should plan to
+ study the existing files.
+ A good place to start is with 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+stdsections.inc
+\end_layout
+
+\end_inset
+
+, which just gets `included' in 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+article.layout
+\end_layout
+
+\end_inset
+
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+book.layout
+\end_layout
+
+\end_inset
+
+, and many of the other layout files for document classes.
+ This file is where sections and the like are defined: 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+stdsections.inc
+\end_layout
+
+\end_inset
+
+ tells LyX how paragraphs that are marked with the Section, Subsection,
+ etc, styles can be translated into corresponding LaTeX commands.
+ The 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+article.layout
+\end_layout
+
+\end_inset
+
+ file basically just includes several of these 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+std*.inc
+\end_layout
+
+\end_inset
+
+ files.
+\end_layout
+
+\begin_layout Standard
+Defining the LyX--LaTeX correspondence is not, however, the only thing layout
+ files do.
+ Their other job is to define how the LyX constructs themselves will appear
+ on-screen.
+ The fact that layout files have these two jobs is often a source of confusion,
+ because they are completely separate.
+ Telling LyX how to translate a certain paragraph style into LaTeX does
+ not tell LyX how to display it; conversely, telling LyX how to display
+ a certain paragraph style does not tell LyX how to translate it into LaTeX,
+ let alone tell LaTeX how to display it.
+ So, in general, when you define a new LyX construct, you must always do
+ two quite separate things: (i)
+\begin_inset space ~
+\end_inset
+
+tell LyX how to translate it into LaTeX, and (ii)
+\begin_inset space ~
+\end_inset
+
+tell LyX how to display it.
+\end_layout
+
+\begin_layout Standard
+Much the same is true, of course, as regards LyX's other backend formats,
+ though XHTML is in some ways different, because in that case LyX 
+\emph on
+is
+\emph default
+ able, to some extent, anyway, to use information about how it should display
+ a paragraph on the screen to output information (in the form of CSS) about
+ how the paragrpah should be displayed in a browser.
+ Even in this case, however, the distinction between what LyX does internally
+ and how things are rendered externally remains in force, and the two can
+ be controlled separately.
+\end_layout
+
+\begin_layout Standard
+Some definitions: a document class is a LaTeX file (usually ending in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -6702,7 +5498,7 @@ text class
  can be used somewhat interchangeably, but it is better to refer to the
  file as the layout, and the thing living in LyX's memory as the text class.
  A template file is simply a LyX document that contains a set of predefined
- entries for a given document class---entries that are generally required
+ entries for a given document classentries that are generally required
  for that class.
  Templates are especially useful for things like journal manuscripts that
  are to be submitted electronically.
@@ -6715,14 +5511,28 @@ Installing a new LaTeX package
 \begin_layout Standard
 Some installations may not include a LaTeX package that you would like to
  use within LyX.
- For example, you might need FoilTeX, a common (and very powerful) package
- for preparing slides or viewgraphs for overhead projectors.
- On some systems, you may have a GUI for installing such packages: MikTeX
- on Windows®, for example.
+ For example, you might need FoilTeX, a package for preparing slides for
+ overhead projectors.
+ Modern LaTeX distributions like TeXLive (2008 or newer) or MiKTeX provide
+ a user interface for installing such packages.
+ For example, with MiKTeX, you start the program 
+\begin_inset Quotes eld
+\end_inset
+
+Browse Packages
+\begin_inset Quotes erd
+\end_inset
+
+ to get a list of available packages.
+ To install one, right click on it or use the toolbar button to install
+ it.
 \end_layout
 
 \begin_layout Standard
-If you don't have such a GUI, then you can follow these steps.
+If your LaTeX distribution doesn't provide such a user interface, or if
+ the file is not available through the package browser, then you can follow
+ these steps.
 \end_layout
 
 \begin_layout Enumerate
@@ -6738,13 +5548,13 @@ target "http://www.ctan.org/"
 \end_layout
 
 \begin_layout Enumerate
-You can install this package in several different places.
+You can install the package in several different places.
  If you want it to be available for all users on your system, then you should
  install it in your `local' TeX tree; if you want (or need) it to be available
  just for you, then you can install it in your own `user' TeX tree.
  Where these should be created, if they do not already exist, depends upon
  the details of your system.
- To find out, look in the file 
+ To find out where they are, look in the file 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -6784,7 +5594,7 @@ kpsewhich texmf.cnf
 
 \end_inset
 
- The location of the `local' TeX tree is defined by 
+ The location of the `local' TeX tree is defined by the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -6794,7 +5604,7 @@ TEXMFLOCAL
 
 \end_inset
 
-; this is usually somewhere like 
+ variable; this is usually somewhere like 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -6862,8 +5672,11 @@ TEXMFHOME
 
 \end_inset
 
- variables; e.g.
+ variables; e.
+\begin_inset space \thinspace{}
+\end_inset
+
+g.
 \begin_inset Newline newline
 \end_inset
 
@@ -6893,40 +5706,38 @@ just work
 \end_layout
 
 \begin_layout Enumerate
-Create your local
-\begin_inset Foot
+Your local and user trees must have the same sort of directory structure
+ as your main existing 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-We'll assume henceforth that you're defining `local' TeX tree.
- If you're defining a user tree, just adjust as necessary.
+texmf
 \end_layout
 
 \end_inset
 
- TeX tree.
- You must follow the directory structure of your existing 
+ directory, which will be found at 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-texmf
+TEXMFMAIN
 \end_layout
 
 \end_inset
 
- directory, which will be found at 
+ (commonly, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TEXMFMAIN
+/usr/share/texmf/
 \end_layout
 
 \end_inset
 
-.
- For example, latex packages should go under 
+.) For example, latex packages should go under 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -6934,14 +5745,25 @@ status collapsed
 $TEXMFLOCAL/tex/latex/
 \end_layout
 
+\end_inset
+
+ or 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$TEXMFHOME/tex/latex/
+\end_layout
+
 \end_inset
 
 .
 \end_layout
 
 \begin_layout Enumerate
-Install the package.
- For example, you would unpack the FoilTeX tarball and copy it to 
+Once your tree is properly set up, you can install the package into an appropria
+te location.
+ For example, you might install the FoilTeX files into 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -6966,105 +5788,107 @@ foiltex
 \end_layout
 
 \begin_layout Enumerate
-Run: 
+Finally, you must update the database TeX uses to find files.
+ On MiKTeX, this is done by pressing the button 
+\family sans
+Refresh
+\begin_inset space ~
+\end_inset
+
+FNDB
+\family default
+ that you find in MiKTeX's 
+\begin_inset Quotes eld
+\end_inset
+
+Settings
+\begin_inset Quotes erd
+\end_inset
+
+ program.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-texhash
+$TEXMFLOCAL/tex/latex/
 \end_layout
 
 \end_inset
 
 .
- This should create 
+ Under TeXLive and the like, you should run 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$TEXMFLOCAL/ls-R
+texhash
 \end_layout
 
 \end_inset
 
- amongst others.
+ from a terminal, with root permissions if necessary.
 \end_layout
 
 \begin_layout Standard
 Your package is now installed and available to LaTeX.
- To make it available to LyX, you need to create a Layout file, if one is
- not already available.
- (See the next section.) Once you have a layout file, you need only reconfigure
- (
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
+ You can verify this from a terminal by typing `
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\bar under
-R
-\bar default
-econfigure
+\begin_layout Plain Layout
+kpsewhich yourfile.ext
 \end_layout
 
 \end_inset
 
-) and then restart LyX.
- You should then see your new package---for example 
+'.
+ To make LyX aware of it, however, you will need to reconfigure (
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-slides (FoilTeX)
+Tools\SpecialChar \menuseparator
+Reconfigure
 \end_layout
 
 \end_inset
 
----under 
+) and then restart LyX.
+ If the new package was a document class, such as FoilTeX again, you will
+ now see it—
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+slides (FoilTeX)
 \end_layout
 
 \end_inset
 
- in the 
+—available under 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
+Document\SpecialChar \menuseparator
+Settings\SpecialChar \menuseparator
 Document Class
 \end_layout
 
 \end_inset
 
- drop box.
+.
  
 \end_layout
 
-\begin_layout Section
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:Layouts"
-
-\end_inset
+\begin_layout Standard
+Unless, of course, no layout file is available for your new document class.
+ That is the topic of the next section.
+\end_layout
 
+\begin_layout Section
 Layouts
 \end_layout
 
@@ -7080,34 +5904,40 @@ article
 
 \end_inset
 
- text class format as an example.
+ text class as an example.
  The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.layout
+*.layout
 \end_layout
 
 \end_inset
 
  files describe what paragraph and character styles are available for a
- given document class and how LyX should display them.
- We try to provide a thorough description of the process here; however,
- there are so many different types of documents supported by LaTeX classes
- that we can't hope to cover every different possibility or problem you
- might encounter.
- (The LyX users' list is frequented by people with lots of experience with
- layout design who are willing to share what they've learned.)
+ given document class, how LyX should display them, and how they should
+ be translated into LaTeX, DocBook, or whatever output format is being used.
+\end_layout
+
+\begin_layout Standard
+We shall try to provide a thorough description of the process of writing
+ layout files here.
+ However, there are so many different types of documents supported by LaTeX,
+ DocBook, and so forth, that we can't hope to cover every different possibility
+ or problem you might encounter.
+ The LyX users' list is frequented by people with lots of experience with
+ layout design who are willing to share what they've learned, so please
+ feel free to ask questions there.
 \end_layout
 
 \begin_layout Standard
 As you prepare to write a new layout, it is extremely helpful to look at
- the example layouts distributed with LyX.
- If you use a nice LaTeX document class that might be of interest for others,
- too, and have a nice corresponding LyX layout, feel free to contribute
- the stuff to us, so we may put it into the distribution.
- There is also a 
+ the layouts distributed with LyX.
+ If you use a nice LaTeX document class that might also be of interest for
+ others and so write a corresponding LyX layout, you should consider posting
+ your layout to the 
 \begin_inset CommandInset href
 LatexCommand href
 name "section on the LyX wiki"
@@ -7115,12 +5945,23 @@ target "http://wiki.lyx.org/Layouts/Layouts"
 
 \end_inset
 
- for this kind of material.
+ or even to the LyX developers' list, so that it might be included in LyX
+ itself.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+Note that LyX is licensed under the General Public License, so any material
+ that is contribued to LyX must be similarly licensed.
+\end_layout
+
+\end_inset
+
+
 \end_layout
 
 \begin_layout Standard
-All the tags described in this chapter are case-insensitive; this means
- that 
+All the tags described here are case-insensitive; this means that 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -7166,7 +6007,7 @@ emphasized
 \end_inset
 
 .
- If the argument has a datatype like 
+ If the argument has a data type like 
 \begin_inset Quotes eld
 \end_inset
 
@@ -7198,25 +6039,70 @@ default
 \end_layout
 
 \begin_layout Subsection
+Layout modules
 \begin_inset CommandInset label
 LatexCommand label
 name "sub:Layout-modules"
 
 \end_inset
 
-Layout modules
+
 \end_layout
 
 \begin_layout Standard
-Similar to layout files, and new with LyX 1.6, are layout 
+We have spoken to this point about `layout files'.
+ But there are different sorts of files that contain layout information.
+ Layout files, strictly so called, have the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+.layout
+\end_layout
+
+\end_inset
+
+ extension and provide LyX with information about document classes.
+ As of LyX 1.6, however, layout informtion can also be contained in layout
 \emph on
 modules
 \emph default
-.
+, which have the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+.module
+\end_layout
+
+\end_inset
+
+ extension.
  Modules are to LaTeX packages much as layouts are to LaTeX classes, and
- some modules---such as the Endnotes module---provide support for just such
- a package.
- In a sense, layout modules are similar to included files---files like 
+ some modules—such as the endnotes module—specifcally provide support for
+ one such package.
+ In a sense, layout modules are similar to included
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+These can have any extension, but by convention have the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+.inc
+\end_layout
+
+\end_inset
+
+ extension.
+\end_layout
+
+\end_inset
+
+ files—files like 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -7226,25 +6112,26 @@ stdsections.inc
 
 \end_inset
 
----in that modules are not specific to a given document layout but may be
- used with many different layouts.
- The difference is that using a layout module does not require editing the
- layout file.
- Rather, modules are selected in the 
-\begin_inset Flex CharStyle:MenuItem
+—in that modules are not specific to a given document class but may be used
+ with many different classes.
+ The difference is that using an included file with 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+article.cls
+\end_layout
 
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-S
-\bar default
-ettings
+, say, requires editing that file.
+ Modules, by contrast, are selected in the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
@@ -7254,7 +6141,8 @@ ettings
 
 \begin_layout Standard
 Building modules is the easiest way to get started with layout editing,
- since it can be as simple as adding a single new paragraph or flex inset.
+ since it can be as simple as adding a single new paragraph style or flex
+ inset.
  But modules may, in principle, contain anything a layout file can contain.
 \end_layout
 
@@ -7269,9 +6157,7 @@ DeclareLyXModule[endnotes.sty]{Endnotes}
 \end_layout
 
 \begin_layout Standard
-The argument in square brackets is optional: It declares any LaTeX packages
- on which the module depends.
- The mandatory argument, in curly brackets, is the name of the module, as
+The mandatory argument, in curly brackets, is the name of the module, as
  it should appear in 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
@@ -7284,7 +6170,52 @@ Settings
 \end_inset
 
 .
+ The argument in square brackets is optional: It declares any LaTeX packages
+ on which the module depends.
+ Please note that only packages about which LyX knows should be listed in
+ the square brackets.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+The list of such packages is documented only in the source code.
+\end_layout
+
+\end_inset
+
+ LyX will not check for arbitrary packages.
+ It is also possible to use the form 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+from->to
+\end_layout
+
+\end_inset
+
+, which declares that the module can only be used when there exists a conversion
+ chain between the formats `
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+from
+\end_layout
+
+\end_inset
+
+' and `
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+to
+\end_layout
+
+\end_inset
+
+'.
 \end_layout
 
 \begin_layout Standard
@@ -7303,7 +6234,7 @@ The module declaration should then be followed by lines like the following:
 \begin_layout LyX-Code
 #You will need to add  
 \backslash
-theendnotes in ERT where you 
+theendnotes in TeX code where you 
 \end_layout
 
 \begin_layout LyX-Code
@@ -7374,7 +6305,17 @@ no
 \emph on
 filenames
 \emph default
- without the .module extension.
+ without the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+.module
+\end_layout
+
+\end_inset
+
+ extension.
  So 
 \begin_inset Flex CharStyle:Code
 status collapsed
@@ -7430,7 +6371,7 @@ It is strongly recommended that you save your work before doing so
  In fact, 
 \emph on
 it is strongly recommended that you not attempt to edit modules while simultaneo
-usly working on documents
+usly working on actual documents
 \emph default
 .
  Though of course the developers strive to keep LyX stable in such situations,
@@ -7483,9 +6424,11 @@ sty
 \end_layout
 
 \begin_layout Standard
-If your new document class is provided as a style file that is used in conjuncti
-on with an existing, supported document class---for the sake of the example,
- we'll assume that the style file is called 
+The easier case is the one in which your new document class is provided
+ as a style file that is to be used in conjunction with an already supported
+ document class.
+ Gor the sake of the example, we'll assume that the style file is called
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
@@ -7505,8 +6448,12 @@ report.cls
 
 \end_inset
 
-, which is a standard class---start by copying the existing class's layout
- file into your local directory:
+, which is a standard class.
+\end_layout
+
+\begin_layout Standard
+Start by copying the existing class's layout file into your local directory:
 \end_layout
 
 \begin_layout LyX-Code
@@ -7571,16 +6518,8 @@ Start LyX and select
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-R
-\bar default
-econfigure
+Tools\SpecialChar \menuseparator
+Reconfigure
 \end_layout
 
 \end_inset
@@ -7602,23 +6541,15 @@ report (myclass)
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
 
  dialog.
  It is likely that some of the sectioning commands and such in your new
- class will work differently from how they worked in the base class---
+ class will work differently from how they worked in the base class
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -7628,8 +6559,93 @@ report
 
 \end_inset
 
- in this example---so you can fiddle around with the settings for the different
+ in this exampleso you can fiddle around with the settings for the different
  sections if you wish.
+ Your new package may also provide commands or environments not present
+ in the base class.
+ In this case, you will want to add these to the layout file.
+ See 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sec:TextClass"
+
+\end_inset
+
+ for information on how to do so.
+\end_layout
+
+\begin_layout Standard
+If 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+myclass.sty
+\end_layout
+
+\end_inset
+
+ can be used with several different document classes, and even if it cannot,
+ you might find it easiest just to user a module that you can load with
+ the base class.
+ The simplest possible such module would be:
+\end_layout
+
+\begin_layout LyX-Code
+#
+\backslash
+DeclareLyXModule{My Class} 
+\end_layout
+
+\begin_layout LyX-Code
+#DescriptionBegin 
+\end_layout
+
+\begin_layout LyX-Code
+#Support for myclass.sty.
+\end_layout
+
+\begin_layout LyX-Code
+#DescriptionEnd 
+\begin_inset Newline newline
+\end_inset
+
+
+\end_layout
+
+\begin_layout LyX-Code
+Format 11
+\begin_inset Newline newline
+\end_inset
+
+
+\end_layout
+
+\begin_layout LyX-Code
+Preamble
+\begin_inset Newline newline
+\end_inset
+
+    
+\backslash
+usepackage{myclass}
+\begin_inset Newline newline
+\end_inset
+
+EndPreamble
+\end_layout
+
+\begin_layout Standard
+A more complex module might modify the behavior of some existing constructs
+ or define some new ones.
+ Again, see 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sec:TextClass"
+
+\end_inset
+
+ for discussion.
 \end_layout
 
 \begin_layout Subsection
@@ -7665,16 +6681,45 @@ book.cls
 
 \begin_layout LyX-Code
 
-\backslash
-LoadClass{book}
+\backslash
+LoadClass{book}
+\end_layout
+
+\begin_layout Standard
+in the file.
+ If so, then you may proceed largely as in the previous section, though
+ the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+DeclareLaTeXClass
+\end_layout
+
+\end_inset
+
+ line will be different.
+ If your new class is 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+thesis
+\end_layout
+
+\end_inset
+
+, and it is based upon 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+book
 \end_layout
 
-\begin_layout Standard
-in the file.
- If so, then you may proceed largely as in the previous section, though
- the DeclareLaTeXClass line will be different.
- If your new class is thesis, and it is based upon book, then the line should
- read:
+\end_inset
+
+, then the line should read:
 \begin_inset Foot
 status collapsed
 
@@ -7723,6 +6768,12 @@ roll your own
 \end_layout
 
 \begin_layout Section
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:TextClass"
+
+\end_inset
+
 Declaring a new text class
 \end_layout
 
@@ -7733,7 +6784,7 @@ When it's finally time to get your hands dirty and create or edit your own
  and enjoy one or two of your favorite adult beverages; more if you are
  getting particularly stuck.
  It's really not that hard, except that the multitude of options can become
- overwhelming if you try to do to much in one sitting.
+ overwhelming if you try to do too much in one sitting.
  Go have another adult beverage, just for good measure.
 \end_layout
 
@@ -7742,7 +6793,7 @@ Here we go!
 \end_layout
 
 \begin_layout Standard
-Lines in a layout file which begin with 
+Lines in a layout file which begin with 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -7753,8 +6804,18 @@ status collapsed
 \end_inset
 
  are comments.
- There is one exception to this rule: all layouts should begin with lines
- like:
+ There is one exception to this rule.
+ All 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+*.layout
+\end_layout
+
+\end_inset
+
+ files should begin with a line like:
 \end_layout
 
 \begin_layout LyX-Code
@@ -7840,16 +6901,8 @@ article
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
@@ -7944,9 +6997,19 @@ DeclareLaTeXClass[article,foo.sty]{article (with my own headings)}
 \end_layout
 
 \begin_layout Standard
-This indicates that your text class uses the foo.sty package.
+This indicates that your text class uses the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+foo.sty
+\end_layout
+
+\end_inset
+
+ package.
  Finally, it is also possible to declare classes for DocBook code.
- Typical declarations will look like
+ Typical declarations will look like:
 \end_layout
 
 \begin_layout LyX-Code
@@ -7982,7 +7045,7 @@ DeclareLaTeXClass[class,package.sty]{layout description}
 
 \begin_layout Standard
 The class need only be specified if the name of the LaTeX class file and
- the name of the layout file are different; if the name of the classfile
+ the name of the layout file are different; if the name of the class file
  is not specified, then LyX will simply assume that it is the same as the
  name of the layout file.
 \end_layout
@@ -8014,28 +7077,21 @@ UserDir/layouts
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-R
-\bar default
-econfigure
+Tools\SpecialChar \menuseparator
+Reconfigure
 \end_layout
 
 \end_inset
 
-, exit LyX and restart it.
+, exit LyX and restart.
  Then your new text class should be available along with the others.
 \end_layout
 
 \begin_layout Standard
-In versions of LyX prior to 1.6, you had to restart LyX to see any changes
- you made to your layout files.
- As a result, editing layout files could be very time consuming.
+Once the layout file is installed, you can edit it and see your changes
+ without having to reconfigure or to restart LyX.
+ In versions of LyX prior to 1.6, this was not true.
+ As a result, editing layout files was very time consuming.
  Beginning with 1.6, however, you can force a reload of the layout currently
  in use by using the LyX function 
 \begin_inset Flex CharStyle:MenuItem
@@ -8048,18 +7104,14 @@ layout-reload
 \end_inset
 
 .
- There is no default binding for this function---though, of course, you
- can bind it to a key yourself (see section 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:bindings"
+ There is no default binding for this function—though, of course, you can
+ bind it to a key yourself.
+ But you use this function simply by entering it in the mini-buffer.
+\end_layout
 
-\end_inset
+\begin_layout Standard
 
-).
- If you want to use this function, then, you should simply enter it in the
- mini-buffer.
 \emph on
 Warning
 \emph default
@@ -8073,14 +7125,25 @@ strongly
 \emph on
 strongly
 \emph default
- recommended that you not attempt to edit your layout while simultaneously
- working on a document that you care about.
+ recommended that you not attempt to edit layout information while simultaneousl
+y working on a document that you care about.
  Use a test document.
  Syntax errors and the like in your layout file could cause peculiar behavior.
  In particular, such errors could cause LyX to regard the current layout
  as invalid and to attempt to switch to some other layout.
  The LyX team strives to keep LyX stable in such situations, but safe is
  better than sorry.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+And while we're giving advice, make regular backups.
+ And be nice to your mother.
+\end_layout
+
+\end_inset
+
+
 \end_layout
 
 \begin_layout Subsection
@@ -8088,7 +7151,12 @@ File format
 \end_layout
 
 \begin_layout Standard
-The first non-comment line must contain the file format number:
+The first non-comment line of any layout file, included file, or module
+\emph on
+must
+\emph default
+ contain the file format number:
 \end_layout
 
 \begin_layout Description
@@ -8111,9 +7179,26 @@ int
 
 \end_inset
 
-] This tag was introduced with LyX 1.4.0 (layout files of LyX 1.3.x and earlier
- don't have an explicit file format).
- The file format that is documented here is format 7.
+] The format of the layout file.
+\end_layout
+
+\begin_layout Standard
+This tag was introduced with LyX 1.4.0.
+ Layout files from LyX 1.3.x and earlier don't have an explicit file format
+ and are considered to be of format 1.
+ The format for the present version of LyX is format 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+19
+\end_layout
+
+\end_inset
+
+.
+ But LyX is capable of reading earlier formats, too, just as it is capable
+ of reading files produced by earlier versions of LyX.
 \end_layout
 
 \begin_layout Subsection
@@ -8174,7 +7259,7 @@ ClassOptions
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:classoptions"
+reference "sub:ClassOptions"
 
 \end_inset
 
@@ -8232,27 +7317,198 @@ status collapsed
 
 \end_inset
 
-] Whether the class should default to having one or two columns.
+] Whether the class should 
+\emph on
+default
+\emph default
+ to having one or two columns.
  Can be changed in the 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
+Document\SpecialChar \menuseparator
+Settings
+\end_layout
 
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-S
-\bar default
-ettings
+ dialog.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Counter
 \end_layout
 
 \end_inset
 
- dialog.
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
+\end_layout
+
+\end_inset
+
+] This sequence defines the properties for a counter.
+ If the counter does not yet exist, it is created; if it does exist, it
+ is modified.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+End
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+\begin_inset Newline newline
+\end_inset
+
+See Section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
+
+\end_inset
+
+ for details on counters.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+DefaultFont
+\end_layout
+
+\end_inset
+
+ Sets the default font used to display the document.
+ See Section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Font-description"
+
+\end_inset
+
+ for how to declare fonts.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+EndFont
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+DefaultModule
+\end_layout
+
+\end_inset
+
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string]
+\end_layout
+
+\end_inset
+
+ Specifies a module to be included by default with this document class.
+ The module should be specified by filename without the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+.module
+\end_layout
+
+\end_inset
+
+ extension.
+ The user can still remove the module, but it will be active at the outset.
+ (This applies only when new files are created, or when this class is chosen
+ for an existing document.)
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+DefaultStyle
+\end_layout
+
+\end_inset
+
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
+\end_layout
+
+\end_inset
+
+] This is the style that will be assigned to new paragraphs, usually 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Standard
+\end_layout
+
+\end_inset
+
+.
+ This will default to the first defined style if not given, but you are
+ encouraged to use this directive.
 \end_layout
 
 \begin_layout Description
@@ -8260,43 +7516,58 @@ ettings
 status collapsed
 
 \begin_layout Plain Layout
-Counter
+ExcludesModule
+\end_layout
+
+\end_inset
+
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
 \end_layout
 
 \end_inset
 
- This sequence defines a new counter.
- See Section
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:counter"
+] This tag indicates that the module in question—which should be specified
+ by filename without the 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
+.module
+\end_layout
 
- for details.
- Must end with 
-\begin_inset Quotes eld
 \end_inset
 
-
+ extension—cannot be used with this document class.
+ This might be used in a journal-specific layout file to prevent, say, the
+ use of the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-End
+theorems-sec
 \end_layout
 
 \end_inset
 
+ module that numbers theorems by section.
+ This tag may 
+\emph on
+not
+\emph default
+ be used in a module.
+ Modules have their own way of excluding other modules (see 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Layout-modules"
 
-\begin_inset Quotes erd
 \end_inset
 
-.
+).
 \end_layout
 
 \begin_layout Description
@@ -8304,12 +7575,12 @@ End
 status collapsed
 
 \begin_layout Plain Layout
-DefaultFont
+Float
 \end_layout
 
 \end_inset
 
Sets the default font used to display the document.
Defines a new float.
  See Section
 \begin_inset space ~
 \end_inset
@@ -8317,11 +7588,11 @@ DefaultFont
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:fonts"
+reference "sub:Floats"
 
 \end_inset
 
- for how to declare fonts.
+ for details.
  Must end with 
 \begin_inset Quotes eld
 \end_inset
@@ -8331,7 +7602,7 @@ reference "sec:fonts"
 status collapsed
 
 \begin_layout Plain Layout
-EndFont
+End
 \end_layout
 
 \end_inset
@@ -8348,7 +7619,7 @@ EndFont
 status collapsed
 
 \begin_layout Plain Layout
-DefaultStyle
+IfCounter
 \end_layout
 
 \end_inset
@@ -8363,19 +7634,42 @@ string
 
 \end_inset
 
-] This is the style that will be assigned to new paragraphs, usually 
-\begin_inset Flex CharStyle:MenuItem
+] Modifies the properties of the given counter.
+ If the counter does not exist, the section is ignored.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Standard
+End
 \end_layout
 
 \end_inset
 
+
+\begin_inset Quotes erd
+\end_inset
+
 .
- This will default to the first defined style if not given, but you are
- highly encouraged to use this directive.
+\begin_inset Newline newline
+\end_inset
+
+See Section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
+
+\end_inset
+
+ for details on counters.
 \end_layout
 
 \begin_layout Description
@@ -8383,24 +7677,23 @@ Standard
 status collapsed
 
 \begin_layout Plain Layout
-Float
+IfStyle
 \end_layout
 
 \end_inset
 
- Defines a new float.
- See Section
-\begin_inset space ~
-\end_inset
-
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:floats"
+\begin_layout Plain Layout
+string
+\end_layout
 
 \end_inset
 
- for details.
+] Modifies the properties of the given paragraph style.
+ If the style does not exist, the section is ignored.
  Must end with 
 \begin_inset Quotes eld
 \end_inset
@@ -8458,20 +7751,8 @@ InsetLayout
 \end_inset
 
  This section (re-)defines the layout of an inset.
- It can be applied to an existing inset of to a new, user-defined inset,
+ It can be applied to an existing inset or to a new, user-defined inset,
  e.g., a new character style.
- See Section
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:charstyle"
-
-\end_inset
-
- for more information.
  Must end with 
 \begin_inset Quotes eld
 \end_inset
@@ -8491,6 +7772,22 @@ End
 \end_inset
 
 .
+\begin_inset Newline newline
+\end_inset
+
+See Section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Flex-insets-and"
+
+\end_inset
+
+ for more information.
 \end_layout
 
 \begin_layout Description
@@ -8503,7 +7800,35 @@ LeftMargin
 
 \end_inset
 
- [[FIXME]]
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
+\end_layout
+
+\end_inset
+
+] A string that indicates the width of the left margin on the screen, for
+ example, 
+\begin_inset Quotes eld
+\end_inset
+
+MMMMM
+\begin_inset Quotes erd
+\end_inset
+
+.
+ (Note that this is not a `length', like 
+\begin_inset Quotes eld
+\end_inset
+
+2ex
+\begin_inset Quotes erd
+\end_inset
+
+.)
 \end_layout
 
 \begin_layout Description
@@ -8518,7 +7843,7 @@ NoFloat
 
  This command deletes an existing float.
  This is particularly useful when you want to suppress a float that has
- be defined in an input file.
+ been defined in an input file.
 \end_layout
 
 \begin_layout Description
@@ -8540,13 +7865,37 @@ NoStyle
 \begin_inset Flex CharStyle:Code
 status collapsed
 
+\begin_layout Plain Layout
+OutputFormat
+\end_layout
+
+\end_inset
+
+ A string indicating the file format (as defined in the Preferences dialog)
+ produced by this class.
+ It is mainly useful when 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+OutputType
+\end_layout
+
+\end_inset
+
+ is `literate' and one wants to define a new type of literate document.
+ This string is reset to `docbook', `latex', or `literate' when the correspondin
+g 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
 \begin_layout Plain Layout
 OutputType
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+ parameter is encountered.
 \end_layout
 
 \begin_layout Description
@@ -8554,8 +7903,21 @@ OutputType
 status collapsed
 
 \begin_layout Plain Layout
+OutputType
+\end_layout
 
-\series medium
+\end_inset
+
+ A string indicating what sort of output documents using this class will
+ produce.
+ At present, the options are: `docbook', `latex', and `literate'.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status open
+
+\begin_layout Plain Layout
 PageStyle
 \end_layout
 
@@ -8597,22 +7959,14 @@ headings
 
 \end_inset
 
-] The class default pagestyle.
+] The default pagestyle.
  Can be changed in the 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
@@ -8622,7 +7976,7 @@ ettings
 
 \begin_layout Description
 \begin_inset Flex CharStyle:Code
-status collapsed
+status open
 
 \begin_layout Plain Layout
 Preamble
@@ -8636,7 +7990,7 @@ Preamble
 status collapsed
 
 \begin_layout Plain Layout
-Premable
+Preamble
 \end_layout
 
 \end_inset
@@ -8652,7 +8006,17 @@ AddToPreamble
 \end_inset
 
  declarations.
- Must end with 
+ (Use 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+AddToPreamble
+\end_layout
+
+\end_inset
+
+ if you just want to add material to the preamble.) Must end with 
 \begin_inset Quotes eld
 \end_inset
 
@@ -8683,14 +8047,7 @@ Provides
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:Provides"
-
-\end_inset
-
-[
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -8776,7 +8133,7 @@ boldsymbol
 
 ,\SpecialChar \ldots{}
 ); the complete list of supported features is unfortunately not documented
- outside the LyX source code---but see 
+ outside the LyX source codebut see 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -8792,21 +8149,61 @@ LaTeXFeatures.cpp
 status collapsed
 
 \begin_layout Plain Layout
+Help\SpecialChar \menuseparator
+LaTeX Configuration
+\end_layout
 
-\bar under
-H
-\bar default
-elp\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-L
-\bar default
-aTeX Configuration
+ also gives an overview of the supported packages.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+ProvidesModule
 \end_layout
 
 \end_inset
 
- also gives an overview of the supported packages.
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
+\end_layout
+
+\end_inset
+
+] Indicates that this layout provides the functionality of the module mentioned,
+ which should be specified by the filename without the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+.module
+\end_layout
+
+\end_inset
+
+ extension.
+ This will typically be used if the layout includes the module directly,
+ rather than using the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+DefaultModule
+\end_layout
+
+\end_inset
+
+ tag to indicate that it ought to be used.
+ It could also be used in a module that provided an alternate implementation
+ of the same functionality.
 \end_layout
 
 \begin_layout Description
@@ -8829,12 +8226,12 @@ string
 
 \end_inset
 
-] Whether the class requires the feature
+] Whether the class requires the feature 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
- string
+string
 \end_layout
 
 \end_inset
@@ -8842,6 +8239,17 @@ status collapsed
 .
  Multiple features must be separated by commas.
  Note that you can only request supported features.
+ (Again, see 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LaTeXFeatures.cpp
+\end_layout
+
+\end_inset
+
+ for a list of these.)
 \end_layout
 
 \begin_layout Description
@@ -8854,7 +8262,16 @@ RightMargin
 
 \end_inset
 
- [[FIXME]]
+ A string that indicates the width of the right margin on the screen, for
+ example, 
+\begin_inset Quotes eld
+\end_inset
+
+MMMMM
+\begin_inset Quotes erd
+\end_inset
+
+.
 \end_layout
 
 \begin_layout Description
@@ -8867,7 +8284,18 @@ SecNumDepth
 
 \end_inset
 
- [[FIXME]]
+ Sets which divisions get numbered.
+ Corresponds to the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+secnumdepth
+\end_layout
+
+\end_inset
+
+ counter in LaTeX.
 \end_layout
 
 \begin_layout Description
@@ -8913,16 +8341,8 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
@@ -8940,20 +8360,9 @@ Style
 
 \end_inset
 
- This sequence defines a new paragraph style.
- If the style already exists, it will redefine some of its parameters instead.
- See Section
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:style"
-
-\end_inset
-
- for details.
+ This sequence defines a paragraph style.
+ If the style does not yet exist, it is created; if it does exist, its parameter
+s are modified.
  Must end with 
 \begin_inset Quotes eld
 \end_inset
@@ -8973,6 +8382,21 @@ End
 \end_inset
 
 .
+\begin_inset Newline newline
+\end_inset
+
+See Section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Paragraph-Styles"
+
+\end_inset
+
+ for details on paragraph styles.
 \end_layout
 
 \begin_layout Description
@@ -9131,7 +8555,18 @@ TocDepth
 
 \end_inset
 
- [[FIXME]]
+ Sets which divisions are included in the table of contents.
+ Corresponds to the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+tocdepth
+\end_layout
+
+\end_inset
+
+ counter in LaTeX.
 \end_layout
 
 \begin_layout Subsection
@@ -9145,15 +8580,16 @@ ClassOptions
 \end_inset
 
  section
-\end_layout
-
-\begin_layout Standard
 \begin_inset CommandInset label
 LatexCommand label
-name "sec:classoptions"
+name "sub:ClassOptions"
 
 \end_inset
 
+
+\end_layout
+
+\begin_layout Standard
 The 
 \begin_inset Flex CharStyle:Code
 status collapsed
@@ -9219,7 +8655,20 @@ Header
 
 \end_inset
 
- [[FIXME]]
+ Used to set the DTD line with XML-based output classes.
+ E.
+\begin_inset space \thinspace{}
+\end_inset
+
+g.: PUBLIC 
+\begin_inset Quotes eld
+\end_inset
+
+-//OASIS//DTD DocBook V4.2//EN
+\begin_inset Quotes erd
+\end_inset
+
+.
 \end_layout
 
 \begin_layout Description
@@ -9333,15 +8782,16 @@ End
 
 \begin_layout Subsection
 Paragraph Styles
-\end_layout
-
-\begin_layout Standard
 \begin_inset CommandInset label
 LatexCommand label
-name "sec:style"
+name "sub:Paragraph-Styles"
 
 \end_inset
 
+
+\end_layout
+
+\begin_layout Standard
 A paragraph style description looks like this:
 \begin_inset Foot
 status collapsed
@@ -9435,6 +8885,96 @@ block
 \begin_inset Flex CharStyle:Code
 status collapsed
 
+\begin_layout Plain Layout
+BabelPreamble
+\end_layout
+
+\end_inset
+
+ Language dependent information to be included in the LaTeX preamble when
+ this style is used.
+ Note that this will completely override any prior 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+BabelPreamble
+\end_layout
+
+\end_inset
+
+ declarations.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+EndBabelPreamble
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ The contents of this tag will occur once in the LaTeX preamble for each
+ language used by the document.
+ Each time, the following substitutions are made:
+\end_layout
+
+\begin_deeper
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$$lang
+\end_layout
+
+\end_inset
+
+ is replaced by the language name (as used by the babel package).
+\end_layout
+
+\begin_layout Itemize
+The 
+\begin_inset Quotes eld
+\end_inset
+
+Function
+\begin_inset Quotes erd
+\end_inset
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+_()
+\end_layout
+
+\end_inset
+
+ replaces its argument by the translation of the argument to the current
+ language.
+\end_layout
+
+\begin_layout Standard
+This preamble snippet will only be used if the document contains more than
+ one language and the babel package is used.
+\end_layout
+
+\end_deeper
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
 \begin_layout Plain Layout
 BottomSep
 \end_layout
@@ -9504,7 +9044,8 @@ CommandDepth
 
 \end_inset
 
- [[FIXME]]
+ Depth of XML command.
+ Used only with XML-type formats.
 \end_layout
 
 \begin_layout Description
@@ -9822,16 +9363,8 @@ Vertical space above
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-E
-\bar default
-dit\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-aragraph
+Edit\SpecialChar \menuseparator
+Paragraph
 \begin_inset space ~
 \end_inset
 
@@ -9880,7 +9413,7 @@ and
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:fonts"
+reference "sub:Font-description"
 
 \end_inset
 
@@ -9982,7 +9515,33 @@ InnerTag
 
 \end_inset
 
- [[FIXME]]
+ [[FIXME]] (Used only with XML-type formats.)
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+InPreamble
+\end_layout
+
+\end_inset
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+[1, 0]
+\end_layout
+
+\end_inset
+
+ If 1, marks the layout as to be included in the document preamble rather
+ than in the document body.
+ This is useful for document classes that want such information as the title
+ and author to appear in the preamble.
 \end_layout
 
 \begin_layout Description
@@ -10088,7 +9647,7 @@ ItemTag
 
 \end_inset
 
- [[FIXME]]
+ [[FIXME]] (Used only with XML-type formats.)
 \end_layout
 
 \begin_layout Description
@@ -10200,20 +9759,21 @@ string=""
 \begin_inset Newline newline
 \end_inset
 
-The name of the counter for automatic numbering (see Section 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:counter"
-
+The name of the counter for automatic numbering.
+\begin_inset Newline newline
 \end_inset
 
- for details).
- This must be given if 
+This 
+\emph on
+must
+\emph default
+ be given if 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Labeltype
+LabelType
 \end_layout
 
 \end_inset
@@ -10228,7 +9788,109 @@ Counter
 
 \end_inset
 
-.
+.
+ In that case, the counter will be stepped each time the layout appears.
+\begin_inset Newline newline
+\end_inset
+
+This 
+\emph on
+may
+\emph default
+ also be given if 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LabelType
+\end_layout
+
+\end_inset
+
+ is 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Enumerate
+\end_layout
+
+\end_inset
+
+, though this case is a bit complicated.
+ Suppose you declare 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LabelCounter myenum
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ Then the actual counters used are 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+myenumi
+\end_layout
+
+\end_inset
+
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+myenumii
+\end_layout
+
+\end_inset
+
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+myenumiii
+\end_layout
+
+\end_inset
+
+, and 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+myenumiv
+\end_layout
+
+\end_inset
+
+, much as in LaTeX.
+ These counters must all be declared separately.
+\begin_inset Newline newline
+\end_inset
+
+See Section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
+
+\end_inset
+
+ for details on counters.
 \end_layout
 
 \begin_layout Description
@@ -10249,7 +9911,7 @@ LabelFont
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:fonts"
+reference "sub:Font-description"
 
 \end_inset
 
@@ -10260,6 +9922,19 @@ reference "sec:fonts"
 \begin_inset Flex CharStyle:Code
 status collapsed
 
+\begin_layout Plain Layout
+LabelIndent
+\end_layout
+
+\end_inset
+
+ Text that indicates how far a label should be indented.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
 \begin_layout Plain Layout
 Labelsep
 \end_layout
@@ -10325,7 +10000,7 @@ LabelCounter
  in Section 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:counter"
+reference "sub:Counters"
 
 \end_inset
 
@@ -10375,7 +10050,7 @@ style-name
  Section 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:counter"
+reference "sub:Counters"
 
 \end_inset
 
@@ -10446,7 +10121,20 @@ LabelStringAppendix
 status collapsed
 
 \begin_layout Plain Layout
-Labeltype
+LabelTag
+\end_layout
+
+\end_inset
+
+ [FIXME] (Used only with XML-type formats.)
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LabelType
 \end_layout
 
 \end_inset
@@ -10460,20 +10148,17 @@ status collapsed
 \emph on
 No_Label
 \emph default
-, Manual, Static, Top_Environment, 
-\begin_inset Newline newline
-\end_inset
-
-Centered_Top_Environment, Sensitive, Counter
+, Manual, Static, Top_Environment, Centered_Top_Environment, Counter, Sensitive,
+ Enumerate, Itemize, Bibliography
 \end_layout
 
 \end_inset
 
 ] 
-\begin_inset Newline newline
-\end_inset
-
+\end_layout
 
+\begin_deeper
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10484,16 +10169,15 @@ Manual
 \end_inset
 
  means the label is the very first word (up to the first real blank).
-\begin_inset Foot
-status collapsed
-
-\begin_layout Plain Layout
-Use protected spaces if you want more than one word as the label.
-\end_layout
-
+ Use protected spaces (like
+\begin_inset space ~
 \end_inset
 
+that one) if you want more than one word as the label.
  
+\end_layout
+
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10503,7 +10187,7 @@ Static
 
 \end_inset
 
- means it is defined in the layout (see 
+ means the label is simply whatever 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10513,8 +10197,11 @@ LabelString
 
 \end_inset
 
-).
+ declares it to be.
+ Note that this really is `static'.
+\end_layout
+
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10547,7 +10234,7 @@ Static
 .
  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 
This might be used with the 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
@@ -10557,155 +10244,358 @@ Abstract
 
 \end_inset
 
- layout or the 
-\begin_inset Flex CharStyle:MenuItem
+ layout, for example.
+\end_layout
+
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Bibliography
+Sensitive
 \end_layout
 
 \end_inset
 
- layout.
- This is also the case for 
+ 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
+
+.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Manual
+Sensitive
 \end_layout
 
 \end_inset
 
- labels with latex type 
+ means the (hardcoded) label string depends on the kind of float: It is
+ hardcoded to be `FloatType N', where N is the value of the counter associated
+ with the float.
+\end_layout
+
+\begin_layout Itemize
+The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Environment
+Counter
 \end_layout
 
 \end_inset
 
-, in order to make layouts for theorems work correctly.
+ label type defines automatically numbered labels.
+ The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Sensitive
+LabelString
 \end_layout
 
 \end_inset
 
- is a special case for the caption-labels 
+ will be expanded to resolve any counter references it contains: For example,
+ it might be 
 \begin_inset Quotes eld
 \end_inset
 
-Figure
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Section 
+\backslash
+thechapter.
+\backslash
+thesection
+\end_layout
+
+\end_inset
+
+
 \begin_inset Quotes erd
 \end_inset
 
- and 
+.
+ See Section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
+
+\end_inset
+
+ for more information on counters.
+\end_layout
+
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Enumerate
+\end_layout
+
+\end_inset
+
+ produces the usual sort of enumeration labels.
+ At present, it is hardcoded to use Arabic numerals, lowercase letters,
+ small Roman numerals, and uppercase letters for the four possible depths.
+\end_layout
+
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Itemize
+\end_layout
+
+\end_inset
+
+ produces various bullets at the different levels.
+ It is also hardcoded.
+\end_layout
+
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Bibliography
+\end_layout
+
+\end_inset
+
+ is used internally by LyX and should be used only with 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LatexType BibEnvironment
+\end_layout
+
+\end_inset
+
+.
+\end_layout
+
+\end_deeper
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LangPreamble
+\end_layout
+
+\end_inset
+
+ Like 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+BabelPreamble
+\end_layout
+
+\end_inset
+
+, but this preamble snippet occurs independently from the babel package,
+ and only for the document language.
+ Must end with 
 \begin_inset Quotes eld
 \end_inset
 
-Table
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+EndLangPreamble
+\end_layout
+
+\end_inset
+
+
 \begin_inset Quotes erd
 \end_inset
 
 .
+\end_layout
+
+\begin_deeper
+\begin_layout Standard
+If the style defines text that appears in the typeset document, it may use
  
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Sensitive
+LangPreamble
 \end_layout
 
 \end_inset
 
- means the (hardcoded) label string depends on the kind of float.
- The 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Counter
+BabelPreamble
 \end_layout
 
 \end_inset
 
- label type defines automatically numbered labels.
- See Section 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:counter"
+ to support non-english and even multilanguage documents correctly.
+ The following excerpt (from the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+theorems-ams.inc
+\end_layout
 
 \end_inset
 
-.
+ file) shows how this works:
 \end_layout
 
-\begin_layout Description
+\begin_layout LyX-Code
+Preamble
+\end_layout
+
+\begin_layout LyX-Code
+  
+\backslash
+theoremstyle{remark}
+\end_layout
+
+\begin_layout LyX-Code
+  
+\backslash
+newtheorem{claim}[thm]{
+\backslash
+protect
+\backslash
+claimname}
+\end_layout
+
+\begin_layout LyX-Code
+EndPreamble
+\end_layout
+
+\begin_layout LyX-Code
+LangPreamble
+\end_layout
+
+\begin_layout LyX-Code
+  
+\backslash
+providecommand{
+\backslash
+claimname}{_(Claim)}
+\end_layout
+
+\begin_layout LyX-Code
+
+\end_layout
+
+\begin_layout LyX-Code
+EndLangPreamble
+\end_layout
+
+\begin_layout LyX-Code
+BabelPreamble
+\end_layout
+
+\begin_layout LyX-Code
+    
+\backslash
+addto
+\backslash
+captions$$lang{
+\backslash
+renewcommand{
+\backslash
+claimname}{_(Claim)}}
+\end_layout
+
+\begin_layout LyX-Code
+EndBabelPreamble
+\end_layout
+
+\begin_layout Standard
+The key to correct translation of the user visible text is the definition
+ of the command 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexFooter
+
+\backslash
+claimname
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
+ in the language preamble.
+ This command holds the name of the theorem that will appear in the output.
+ The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexHeader
+BabelPreamble
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
+ then uses the commands offered by the babel package to redefine 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexName
-\end_layout
-
-\end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:LatexName"
+\backslash
+claimname
+\end_layout
 
 \end_inset
 
-The name of the corresponding LaTeX stuff.
- Either the environment or command name.
+ for each used language in multilanguage documents.
 \end_layout
 
+\end_deeper
 \begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexParagraph
+LatexName
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+ The name of the corresponding LaTeX stuff.
+ Either the environment or command name.
 \end_layout
 
 \begin_layout Description
@@ -10718,14 +10608,7 @@ LatexParam
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:LatexParam"
-
-\end_inset
-
-An optional parameter for the corresponding 
+ An optional parameter for the corresponding 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10775,13 +10658,36 @@ Paragraph
 status collapsed
 
 \begin_layout Plain Layout
-List_Environment
+List_Environment, Bib_Environment
 \end_layout
 
 \end_inset
 
 ] How the layout should be translated into LaTeX.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LatexType
+\end_layout
+
+\end_inset
+
+ is perhaps a bit misleading, since these rules apply to SGML classes, too.
+ Visit the SGML class files for specific examples.
+\end_layout
+
+\end_inset
+
+
+\end_layout
+
+\begin_deeper
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10793,6 +10699,9 @@ Paragraph
 
  means nothing special.
  
+\end_layout
+
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10819,7 +10728,10 @@ LatexName
 
 \end_inset
 
- and 
+.
+\end_layout
+
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10854,6 +10766,9 @@ LatexName
 
 .
  
+\end_layout
+
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10873,7 +10788,7 @@ Environment
 
 \end_inset
 
-, except that a 
+, except that an 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10887,6 +10802,9 @@ item
 
  is generated for each paragraph of this environment.
  
+\end_layout
+
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -10948,19 +10866,6 @@ aragraph
 
  dialog.
  
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\emph on
-LatexType
-\end_layout
-
-\end_inset
-
- is perhaps a bit misleading, since these rules apply to SGML classes, too.
- Visit the SGML class files for specific examples.
 \end_layout
 
 \begin_layout Standard
@@ -10988,9 +10893,10 @@ end{latexname}.
 \end_layout
 
 \begin_layout Standard
-depending upon the LaTex type.
+depending upon the LaTeX type.
 \end_layout
 
+\end_deeper
 \begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
@@ -11160,16 +11066,8 @@ Manual
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-E
-\bar default
-dit\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-aragraph
+Edit\SpecialChar \menuseparator
+Paragraph
 \begin_inset space ~
 \end_inset
 
@@ -11262,14 +11160,7 @@ NeedProtect
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:NeedProtect"
-
-\end_inset
-
-[
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -11304,6 +11195,11 @@ protect
 \end_inset
 
 'ed.
+ (Note: This is 
+\emph on
+not
+\emph default
+ whether this command should itself be protected.)
 \end_layout
 
 \begin_layout Description
@@ -11423,7 +11319,8 @@ ObsoletedBy
 
 \end_inset
 
- [[FIXME]]
+ Name of a layout that has replaced this layout.
+ This is used to rename a layout, while keeping backward compatibility.
 \end_layout
 
 \begin_layout Description
@@ -11636,7 +11533,7 @@ PassThru
  
 \begin_inset CommandInset label
 LatexCommand label
-name "des:PassThru"
+name "des:PathThru"
 
 \end_inset
 
@@ -11687,7 +11584,7 @@ name "des:Preamble"
 
 \end_inset
 
-Information to be included in the LaTeX preamable when this style is used.
+Information to be included in the LaTeX preamble when this style is used.
  Used to define macros, load packages, etc., required by this particular
  style.
  Must end with 
@@ -11914,7 +11811,7 @@ TextFont
  See section 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:fonts"
+reference "sub:Font-description"
 
 \end_inset
 
@@ -11965,15 +11862,16 @@ float=0
 
 \begin_layout Subsection
 Floats
-\end_layout
-
-\begin_layout Standard
 \begin_inset CommandInset label
 LatexCommand label
-name "sec:floats"
+name "sub:Floats"
 
 \end_inset
 
+
+\end_layout
+
+\begin_layout Standard
 Since version 1.3.0 of LyX, it is has been both possible and necessary to
  define the floats (
 \begin_inset Flex CharStyle:MenuItem
@@ -12083,6 +11981,7 @@ string
 \end_inset
 
 ] The string that will be used in the menus and also for the caption.
+ This is translated to the current language if babel is used.
 \end_layout
 
 \begin_layout Description
@@ -12180,6 +12079,7 @@ string
 \end_inset
 
 ] The heading used for the list of floats.
+ This is translated to the document language.
 \end_layout
 
 \begin_layout Description
 \end_inset
 
  specifier is special and, because of implementation details, cannot be
- used in non-builtin float types.
+ used in non-built in float types.
  If you do not understand what this means, just use 
 \begin_inset Quotes eld
 \end_inset
@@ -12506,28 +12406,19 @@ type
 \end_layout
 
 \begin_layout Subsection
-Inset layouts and Flex insets
-\end_layout
-
-\begin_layout Standard
+Flex insets and InsetLayout
 \begin_inset CommandInset label
 LatexCommand label
-name "sec:charstyle"
+name "sub:Flex-insets-and"
 
 \end_inset
 
-LyX has supported character styles since version 1.4.0; since version 1.6.0
- these are called Flex insets.
+
 \end_layout
 
 \begin_layout Standard
-Furthermore, it is possible to define the general layout of many different
- types of insets.
- Currently, InsetLayout can be used to customize the  layout parameters
- for footnotes, marginal notes, note insets, ERT insets, branches, listings,
- indexes, boxes, tables, algorithms, URLs, and optional arguments, as well
- as Flex insets.
+LyX has supported character styles since version 1.4.0; as of version 1.6.0,
+ these are called Flex insets.
  
 \end_layout
 
@@ -12585,8 +12476,19 @@ Custom
 
 \end_inset
 
-): These can be used to define custom collapsable insets, similar to ERT,
- footnote, and the like.
+): These can be used to define custom collapsible insets, similar to TeX
+ code, footnote, and the like.
+ An obvious example is an endnote inset, which is defined in the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+endnote
+\end_layout
+
+\end_inset
+
+ module.
 \end_layout
 
 \begin_layout Itemize
@@ -12603,6 +12505,49 @@ Element
 ): For use with DocBook classes.
 \end_layout
 
+\begin_layout Standard
+Flex insets are defined using the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+InsetLayout
+\end_layout
+
+\end_inset
+
+ tag, which shall be explained in a moment.
+\end_layout
+
+\begin_layout Standard
+The 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+InsetLayout
+\end_layout
+
+\end_inset
+
+ tag also serves another function: It can be used to customize the general
+ layout of many different types of insets.
+ Currently, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+InsetLayout
+\end_layout
+
+\end_inset
+
+ can be used to customize the layout parameters for footnotes, marginal
+ notes, note insets, TeX code (ERT) insets, branches, listings, indexes,
+ boxes, tables, algorithms, URLs, and optional arguments, as well as to
+ define Flex insets.
+\end_layout
+
 \begin_layout Standard
 The 
 \begin_inset Flex CharStyle:Code
@@ -12614,15 +12559,15 @@ InsetLayout
 
 \end_inset
 
- definition starting line is of the form
+ definition must begin with a line of the form:
 \end_layout
 
 \begin_layout LyX-Code
-InsetLayout <Type> <Name>
+InsetLayout <Type>
 \end_layout
 
 \begin_layout Standard
-where 
+Here 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -12632,7 +12577,23 @@ status collapsed
 
 \end_inset
 
- can be 
+ indicates the inset whose layout is being defined, and here there are two
+ cases.
+\end_layout
+
+\begin_layout Enumerate
+The layout for a pre-existing inset is being modified.
+ In this case, can be 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+<Type>
+\end_layout
+
+\end_inset
+
+ any one of the following: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -12667,7 +12628,7 @@ Box
 status collapsed
 
 \begin_layout Plain Layout
-ERT
+Box:shaded
 \end_layout
 
 \end_inset
@@ -12677,7 +12638,7 @@ ERT
 status collapsed
 
 \begin_layout Plain Layout
-Figure
+ERT
 \end_layout
 
 \end_inset
@@ -12687,7 +12648,7 @@ Figure
 status collapsed
 
 \begin_layout Plain Layout
-Foot
+Figure
 \end_layout
 
 \end_inset
@@ -12697,7 +12658,7 @@ Foot
 status collapsed
 
 \begin_layout Plain Layout
-Index
+Foot
 \end_layout
 
 \end_inset
@@ -12707,7 +12668,7 @@ Index
 status collapsed
 
 \begin_layout Plain Layout
-Listings
+Index
 \end_layout
 
 \end_inset
@@ -12717,7 +12678,7 @@ Listings
 status collapsed
 
 \begin_layout Plain Layout
-Marginal
+Info
 \end_layout
 
 \end_inset
@@ -12727,7 +12688,7 @@ Marginal
 status collapsed
 
 \begin_layout Plain Layout
-Note:Comment
+Info:menu
 \end_layout
 
 \end_inset
@@ -12737,7 +12698,7 @@ Note:Comment
 status collapsed
 
 \begin_layout Plain Layout
-Note:Note
+Info:shortcut
 \end_layout
 
 \end_inset
@@ -12747,7 +12708,7 @@ Note:Note
 status collapsed
 
 \begin_layout Plain Layout
-Note:GreyedOut
+Info:shortcuts
 \end_layout
 
 \end_inset
@@ -12757,7 +12718,7 @@ Note:GreyedOut
 status collapsed
 
 \begin_layout Plain Layout
-OptArg
+Listings
 \end_layout
 
 \end_inset
@@ -12767,7 +12728,7 @@ OptArg
 status collapsed
 
 \begin_layout Plain Layout
-Table
+Marginal
 \end_layout
 
 \end_inset
@@ -12777,128 +12738,150 @@ Table
 status collapsed
 
 \begin_layout Plain Layout
-URL
+Note:Comment
 \end_layout
 
 \end_inset
 
-, or 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Flex
+Note:Note
 \end_layout
 
 \end_inset
 
-.
- If 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-<Type>
+Note:GreyedOut
 \end_layout
 
 \end_inset
 
- is 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Flex
+OptArg
 \end_layout
 
 \end_inset
 
-, then 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-<Name>
+Table
 \end_layout
 
 \end_inset
 
- should have the form 
+, or 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-SubType:StyleName
+URL
 \end_layout
 
 \end_inset
 
-, where 
+.
+\end_layout
+
+\begin_layout Enumerate
+The layout for a Flex inset is being defined.
+ In this case, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-SubType
+<Type>
 \end_layout
 
 \end_inset
 
- is either 
+ can be any valid identifier not used by a pre-existing inset.
+ Note that the definition of a flex inset must
+\emph on
+ als
+\emph default
+o include a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-CharStyle
+LyXType
 \end_layout
 
 \end_inset
 
-, 
+ entry.
+\end_layout
+
+\begin_layout Standard
+The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Custom
+InsetLayout
 \end_layout
 
 \end_inset
 
-, or 
+ definition can contain the following entries:
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Element
+BgColor
 \end_layout
 
 \end_inset
 
-, and 
+ The color for the inset's background.
+ The valid colors are defined in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-StyleName
+src/ColorCode.h
 \end_layout
 
 \end_inset
 
- is any valid identifier.
+.
 \end_layout
 
-\begin_layout Standard
-The following 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-InsetLayout
+CopyStyle
 \end_layout
 
 \end_inset
 
- section can contain the following entries:
+ As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "des:CopyStyle"
+
+\end_inset
+
+).
 \end_layout
 
 \begin_layout Description
@@ -12906,43 +12889,35 @@ InsetLayout
 status collapsed
 
 \begin_layout Plain Layout
-BgColor
+CustomPars
 \end_layout
 
 \end_inset
 
- The color for the inset's background.
- These valid colors are defined in 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-src/ColorCode.h
-\end_layout
-
-\end_inset
 
-.
+\emph on
+0
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-CopyStyle
+1
 \end_layout
 
 \end_inset
 
- As with paragraph styles (see page 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "des:CopyStyle"
-
-\end_inset
-
-).
+] Indicates whether the user may employ the Paragraph Settings dialog to
+ customize the paragraph.
 \end_layout
 
 \begin_layout Description
@@ -12996,7 +12971,7 @@ Classic
 
 \end_inset
 
-; ERT insets generally use 
+, ERT insets generally 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -13006,7 +12981,7 @@ Minimalistic
 
 \end_inset
 
-; and character styles use 
+, and character styles 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -13023,6 +12998,19 @@ Conglomerate
 \begin_inset Flex CharStyle:Code
 status collapsed
 
+\begin_layout Plain Layout
+End
+\end_layout
+
+\end_inset
+
+ Required at the end of the InsetLayout declarations.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
 \begin_layout Plain Layout
 Font
 \end_layout
@@ -13041,7 +13029,7 @@ and
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:fonts"
+reference "sub:Font-description"
 
 \end_inset
 
@@ -13079,97 +13067,24 @@ ForceLTR
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-FreeSpacing
-\end_layout
-
-\end_inset
-
- As with paragraph styles (see page 
-\begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:FreeSpacing"
-
-\end_inset
-
-).
-\end_layout
-
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-KeepEmpty
-\end_layout
-
-\end_inset
-
- As with paragraph styles (see page 
-\begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:KeepEmpty"
-
-\end_inset
-
-).
-\end_layout
-
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-LabelString
-\end_layout
-
-\end_inset
-
- What will be displayed on the button or elsewhere as the inset label.
- Some inset types (ERT and Branch) modify this label on the fly.
-\end_layout
-
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-LabelFont
-\end_layout
-
+ Force the 
+\begin_inset Quotes eld
 \end_inset
 
- The font used for the label.
- See section
-\begin_inset space ~
+latex
+\begin_inset Quotes erd
 \end_inset
 
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:fonts"
-
+ language, leading to Left-to-Right (latin) output, e.
+\begin_inset space \thinspace{}
 \end_inset
 
-.
- Note that this definition can never appear before 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-Font
-\end_layout
-
+g.
+\begin_inset space \space{}
 \end_inset
 
-, lest it be ineffective.
+in TeX code or URL.
+ A kludge.
 \end_layout
 
 \begin_layout Description
@@ -13177,47 +13092,35 @@ Font
 status collapsed
 
 \begin_layout Plain Layout
-LatexName
+ForcePlain
 \end_layout
 
 \end_inset
 
- The name of the corresponding LaTeX stuff.
- Either the environment or command name.
-\end_layout
-
-\begin_layout Description
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexParam
-\end_layout
-
-\end_inset
-
- The optional parameter for the corresponding 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-LatexName
+\emph on
+0
 \end_layout
 
 \end_inset
 
- stuff, including possible bracket pairs like 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-[]
+1
 \end_layout
 
 \end_inset
 
-.
This parameter cannot be changed from within LyX.
+] Indicates whether the PlainLayout should be used or, instead, the user
can change the paragraph style used in the inset.
 \end_layout
 
 \begin_layout Description
@@ -13225,7 +13128,7 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-LatexType
+FreeSpacing
 \end_layout
 
 \end_inset
@@ -13233,7 +13136,7 @@ LatexType
  As with paragraph styles (see page 
 \begin_inset CommandInset ref
 LatexCommand pageref
-reference "des:LatexType"
+reference "des:FreeSpacing"
 
 \end_inset
 
@@ -13245,53 +13148,39 @@ reference "des:LatexType"
 status collapsed
 
 \begin_layout Plain Layout
-LyxType 
-\end_layout
-
-\end_inset
-
- Can be 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-charstyle
+InToc
 \end_layout
 
 \end_inset
 
-, 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-custom
-\end_layout
-
-\end_inset
-
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-element
+\emph on
+0
 \end_layout
 
 \end_inset
 
-, 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-end
+1
 \end_layout
 
 \end_inset
 
- (indicating a dummy definition ending definitions of charstyles etc.).
- This entry is only meaningful for Flex (user definable) insets.
+] Whether to include the contents of this inset in the strings generated
+ for the `Outline' pane.
+ One would not, for example, want the content of a footnote in a section
+ header to be included in the TOC displayed in the outline, but one would
+ normally want the content of a character style displayed.
+ Default is false: not to include.
 \end_layout
 
 \begin_layout Description
@@ -13299,7 +13188,7 @@ end
 status collapsed
 
 \begin_layout Plain Layout
-Preamble
+KeepEmpty
 \end_layout
 
 \end_inset
@@ -13307,7 +13196,7 @@ Preamble
  As with paragraph styles (see page 
 \begin_inset CommandInset ref
 LatexCommand pageref
-reference "des:Preamble"
+reference "des:KeepEmpty"
 
 \end_inset
 
@@ -13319,86 +13208,35 @@ reference "des:Preamble"
 status collapsed
 
 \begin_layout Plain Layout
-Requires 
-\end_layout
-
-\end_inset
-
- [
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-string
-\end_layout
-
-\end_inset
-
-] As with paragraph styles (see page 
-\begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:Requires"
-
-\end_inset
-
-).
-\end_layout
-
-\begin_layout Subsection
-Counters
+LabelFont
 \end_layout
 
-\begin_layout Standard
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:counter"
-
 \end_inset
 
-Since version 1.3.0 of LyX, it is both possible and necessary to define the
- counters (
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-chapter
-\end_layout
-
+ The font used for the label.
+ See section
+\begin_inset space ~
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
 
-\begin_layout Plain Layout
-figure
-\end_layout
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Font-description"
 
 \end_inset
 
-, \SpecialChar \ldots{}
-) in the text class itself.
- The standard counters are defined in the file 
+.
+ Note that this definition can never appear before 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-stdcounters.inc
+Font
 \end_layout
 
 \end_inset
 
-, so you may have to do no more than add
-\end_layout
-
-\begin_layout LyX-Code
-Input stdcounters.inc
-\end_layout
-
-\begin_layout Standard
-to your layout file to get them to work.
- But if you want to define custom counters, then you can do so, using the
- following parameters:
+, lest it be ineffective.
 \end_layout
 
 \begin_layout Description
@@ -13406,263 +13244,230 @@ to your layout file to get them to work.
 status collapsed
 
 \begin_layout Plain Layout
-LabelString [string=""]
-\end_layout
-
-\end_inset
-
- when this is defined, this string defines how the counter is displayed.
- Setting this value sets 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-LabelStringAppendix
+LabelString
 \end_layout
 
 \end_inset
 
to the same value.
- The following special constructs can be used in the string:
What will be displayed on the button or elsewhere as the inset label.
+ Some inset types (TeX code and Branch) modify this label on the fly.
 \end_layout
 
-\begin_deeper
-\begin_layout Itemize
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-thecounter
+LatexName
 \end_layout
 
 \end_inset
 
- will be replaced by the expansion of the 
+ The name of the corresponding LaTeX stuff.
+ Either the environment or command name.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
+LatexParam
 \end_layout
 
 \end_inset
 
- (or 
+ The optional parameter for the corresponding 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelStringAppendix
+LatexName
 \end_layout
 
 \end_inset
 
-) of the counter 
+ stuff, including possible bracket pairs like 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-counter
+[]
 \end_layout
 
 \end_inset
 
 .
+ This parameter cannot be changed from within LyX.
 \end_layout
 
-\begin_layout Itemize
-counter values can be expressed using LaTeX-like macros 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+LatexType
+\end_layout
 
-\backslash
+\end_inset
 
-\emph on
-numbertype
-\emph default
-{
-\emph on
-counter
-\emph default
-}
-\end_layout
+ As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:LatexType"
 
 \end_inset
 
-, where 
+).
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-numbertype
+LyxType 
 \end_layout
 
 \end_inset
 
- can be:
-\begin_inset Foot
+ Can be 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\family roman
-\series medium
-\shape up
-\size normal
-\emph off
-\bar no
-\noun off
-\color none
-Actually, the situation is a bit more complicated: any
-\family default
-\series default
-\shape default
-\emph default
-\bar default
-\size default
-\emph on
-\noun default
-\color inherit
-numbertype
-\family roman
-\series medium
-\shape up
-\size normal
-\emph off
-\bar no
-\noun off
- other than those descibed below will produce arabic numerals.
- It would not be surprising to see this change in the future.
+charstyle
 \end_layout
 
 \end_inset
 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-arabic
+custom
 \end_layout
 
 \end_inset
 
-: 1, 2, 3,\SpecialChar \ldots{}
-; 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-alph
+element
 \end_layout
 
 \end_inset
 
- for lower-case letters: a, b, c, \SpecialChar \ldots{}
-; 
+, or 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Alph
+end
 \end_layout
 
 \end_inset
 
- for upper-case letters: A, B, C, \SpecialChar \ldots{}
-; 
+ (indicating a dummy definition ending definitions of charstyles, etc).
+ This entry is required in and is only meaningful for Flex insets.
+ Among other things, it determines on which menu this inset will appear.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-roman
+MultiPar
 \end_layout
 
 \end_inset
 
- for lower-case roman numerals: i, ii, iii, \SpecialChar \ldots{}
-; 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Roman
+
+\emph on
+0
 \end_layout
 
 \end_inset
 
- for upper-case roman numerals: I, II, III\SpecialChar \ldots{}
-; 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-hebrew
+1
 \end_layout
 
 \end_inset
 
- for hebrew numerals.
+] Whether multiple paragraphs are permitted in this inset.
+ This will also set CustomPars to the same value and ForcePlain to the opposite
+ value.
+ These can be reset to other values, if they are used 
+\emph on
+after
+\emph default
+ MultiPar.
 \end_layout
 
-\end_deeper
-\begin_layout Standard
-If LabelString is not defined, a default value is constructed as follows:
- if the counter has a master counter 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-master
+NeedProtect
 \end_layout
 
 \end_inset
 
- (defined via 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Within
+
+\emph on
+0
 \end_layout
 
 \end_inset
 
-), the string 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-themaster.
-\backslash
-arabic{counter}
+1
 \end_layout
 
 \end_inset
 
- is used; otherwise the string 
+] Whether fragile commands in this layout should be 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
 \backslash
-arabic{counter}
+protect
 \end_layout
 
 \end_inset
 
- is used.
+'ed.
+ (Note: This is 
+\emph on
+not
+\emph default
+ whether the command should itself be protected.)
 \end_layout
 
 \begin_layout Description
@@ -13670,53 +13475,41 @@ arabic{counter}
 status collapsed
 
 \begin_layout Plain Layout
-LabelStringAppendix [string=""]
+PassThru
 \end_layout
 
 \end_inset
 
- Same as 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
-\end_layout
-
-\end_inset
-
-.
-\end_layout
-
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-Name
+\emph on
+0
 \end_layout
 
 \end_inset
 
- [
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+1
 \end_layout
 
 \end_inset
 
-=
-\begin_inset Quotes erd
-\end_inset
-
+] As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "des:PathThru"
 
-\begin_inset Quotes erd
 \end_inset
 
-] The name of the counter.
+).
 \end_layout
 
 \begin_layout Description
@@ -13724,365 +13517,432 @@ string
 status collapsed
 
 \begin_layout Plain Layout
-Within
+Preamble
 \end_layout
 
 \end_inset
 
- [
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-string
-\end_layout
-
-\end_inset
+ As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:Preamble"
 
-=
-\begin_inset Quotes erd
 \end_inset
 
+).
+\end_layout
 
-\begin_inset Quotes erd
-\end_inset
-
-] If this is set to the name of another counter, the present counter will
- be reset everytime the other one is increased.
- For example, 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-subsection
+Requires 
 \end_layout
 
 \end_inset
 
- is numbered inside 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-section
+string
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+] As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:Requires"
 
-\begin_layout Subsection
-Font description
+\end_inset
+
+).
 \end_layout
 
-\begin_layout Standard
+\begin_layout Subsection
+Counters
 \begin_inset CommandInset label
 LatexCommand label
-name "sec:fonts"
+name "sub:Counters"
 
 \end_inset
 
-A font description looks like this:
-\end_layout
 
-\begin_layout LyX-Code
-Font 
-\family roman
-\emph on
-or
-\family default
-\emph default
- LabelFont
 \end_layout
 
-\begin_layout LyX-Code
- ...
-\end_layout
+\begin_layout Standard
+Since version 1.3.0 of LyX, it is both possible and necessary to define the
+ counters (
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_layout LyX-Code
-EndFont
+\begin_layout Plain Layout
+chapter
 \end_layout
 
-\begin_layout Standard
-The following commands are available:
-\end_layout
+\end_inset
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
+, 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Color
+figure
 \end_layout
 
 \end_inset
 
- [
+, \SpecialChar \ldots{}
+) in the text class itself.
+ The standard counters are defined in the file 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-none
+stdcounters.inc
 \end_layout
 
 \end_inset
 
-, 
+, so you may have to do no more than add
+\end_layout
+
+\begin_layout LyX-Code
+Input stdcounters.inc
+\end_layout
+
+\begin_layout Standard
+to your layout file to get them to work.
+ But if you want to define custom counters, then you can do so.
+ The counter declaration must begin with:
+\end_layout
+
+\begin_layout LyX-Code
+Counter CounterName
+\end_layout
+
+\begin_layout Standard
+where of course `
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-black
+CounterName
 \end_layout
 
 \end_inset
 
-, 
+' is replaced by the name of the counter.
+ And it must end with 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-white
+End
 \end_layout
 
 \end_inset
 
-, 
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ The following parameters can also be used:
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-red
+LabelString [string=""]
 \end_layout
 
 \end_inset
 
-, 
+ when this is defined, this string defines how the counter is displayed.
+ Setting this value sets 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-green
+LabelStringAppendix
 \end_layout
 
 \end_inset
 
-, 
+ to the same value.
+ The following special constructs can be used in the string:
+\end_layout
+
+\begin_deeper
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-blue
+
+\backslash
+thecounter
 \end_layout
 
 \end_inset
 
-, 
+ will be replaced by the expansion of the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-cyan
+LabelString
 \end_layout
 
 \end_inset
 
-, 
+ (or 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-magenta
+LabelStringAppendix
 \end_layout
 
 \end_inset
 
-, 
+) of the counter 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-yellow
+counter
 \end_layout
 
 \end_inset
 
-]
+.
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
+counter values can be expressed using LaTeX-like macros 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Family
-\end_layout
 
-\end_inset
+\backslash
 
- [
 \emph on
+numbertype
+\emph default
+{
+\emph on
+counter
+\emph default
+}
+\end_layout
 
+\end_inset
+
+, where 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
 \emph on
-Roman
+numbertype
 \end_layout
 
 \end_inset
 
-
-\emph default
-, 
-\begin_inset Flex CharStyle:Code
+ can be:
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-Sans
+
+\family roman
+\series medium
+\shape up
+\size normal
+\emph off
+\bar no
+\noun off
+\color none
+Actually, the situation is a bit more complicated: any
+\family default
+\series default
+\shape default
+\emph default
+\bar default
+\size default
+\emph on
+\noun default
+\color inherit
+numbertype
+\family roman
+\series medium
+\shape up
+\size normal
+\emph off
+\bar no
+\noun off
+ other than those described below will produce arabic numerals.
+ It would not be surprising to see this change in the future.
 \end_layout
 
 \end_inset
 
-, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Typewriter
+arabic
 \end_layout
 
 \end_inset
 
-] 
-\end_layout
-
-\begin_layout Description
+: 1, 2, 3,\SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Misc
+alph
 \end_layout
 
 \end_inset
 
- [
+ for lower-case letters: a, b, c, \SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+Alph
 \end_layout
 
 \end_inset
 
-] Valid argument sare: 
+ for upper-case letters: A, B, C, \SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-emph
+roman
 \end_layout
 
 \end_inset
 
-, 
+ for lower-case roman numerals: i, ii, iii, \SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-noun
+Roman
 \end_layout
 
 \end_inset
 
-, 
+ for upper-case roman numerals: I, II, III\SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-underbar
+hebrew
 \end_layout
 
 \end_inset
 
-, 
+ for hebrew numerals.
+\end_layout
+
+\end_deeper
+\begin_layout Standard
+If LabelString is not defined, a default value is constructed as follows:
+ if the counter has a master counter 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-no_emph
+master
 \end_layout
 
 \end_inset
 
-, 
+ (defined via 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-no_noun
+Within
 \end_layout
 
 \end_inset
 
- and 
+), the string 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-no_bar
+
+\backslash
+themaster.
+\backslash
+arabic{counter}
 \end_layout
 
 \end_inset
 
-.
- Each of these turns on or off the corresponding attribute.
-\end_layout
-
-\begin_layout Description
+ is used; otherwise the string 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Series
+
+\backslash
+arabic{counter}
 \end_layout
 
 \end_inset
 
- [
-\emph on
+ is used.
+\end_layout
 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-Medium
+LabelStringAppendix [string=""]
 \end_layout
 
 \end_inset
 
-
-\emph default
-, 
+ Same as 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Bold
+LabelString
 \end_layout
 
 \end_inset
 
-] 
+, but for use in the Appendix.
 \end_layout
 
 \begin_layout Description
@@ -14090,58 +13950,89 @@ Bold
 status collapsed
 
 \begin_layout Plain Layout
-Shape
+Within
 \end_layout
 
 \end_inset
 
  [
-\emph on
-
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-Up
+string
 \end_layout
 
 \end_inset
 
+=
+\begin_inset Quotes erd
+\end_inset
 
-\emph default
-, 
+
+\begin_inset Quotes erd
+\end_inset
+
+] If this is set to the name of another counter, the present counter will
+ be reset every time the other one is increased.
+ For example, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Italic
+subsection
 \end_layout
 
 \end_inset
 
-, 
+ is numbered inside 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-SmallCaps
+section
+\end_layout
+
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Subsection
+Font description
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Font-description"
+
+\end_inset
+
+
 \end_layout
 
-\end_inset
+\begin_layout Standard
+A font description looks like this:
+\end_layout
 
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+Font 
+\family roman
+\emph on
+or
+\family default
+\emph default
+ LabelFont
+\end_layout
 
-\begin_layout Plain Layout
-Slanted
+\begin_layout LyX-Code
+ ...
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+EndFont
+\end_layout
 
-] 
+\begin_layout Standard
+The following commands are available:
 \end_layout
 
 \begin_layout Description
@@ -14149,7 +14040,7 @@ Slanted
 status collapsed
 
 \begin_layout Plain Layout
-Size
+Color
 \end_layout
 
 \end_inset
@@ -14159,7 +14050,9 @@ Size
 status collapsed
 
 \begin_layout Plain Layout
-tiny
+
+\emph on
+none
 \end_layout
 
 \end_inset
@@ -14169,7 +14062,7 @@ tiny
 status collapsed
 
 \begin_layout Plain Layout
-small
+black
 \end_layout
 
 \end_inset
@@ -14179,9 +14072,7 @@ small
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-normal
+white
 \end_layout
 
 \end_inset
@@ -14191,7 +14082,7 @@ normal
 status collapsed
 
 \begin_layout Plain Layout
-large
+red
 \end_layout
 
 \end_inset
@@ -14201,7 +14092,7 @@ large
 status collapsed
 
 \begin_layout Plain Layout
-larger
+green
 \end_layout
 
 \end_inset
@@ -14211,7 +14102,7 @@ larger
 status collapsed
 
 \begin_layout Plain Layout
-largest
+blue
 \end_layout
 
 \end_inset
@@ -14221,7 +14112,7 @@ largest
 status collapsed
 
 \begin_layout Plain Layout
-huge
+cyan
 \end_layout
 
 \end_inset
 status collapsed
 
 \begin_layout Plain Layout
-giant
+magenta
 \end_layout
 
 \end_inset
 
-]
-\end_layout
-
-\begin_layout Subsection
-Upgrading old layout files
-\end_layout
-
-\begin_layout Standard
-The file format of layout files changes from time to time, so old layout
- files need to be converted.
- This process has been automated since LyX 1.4.0: If LyX reads an old format
- layout file it will call the conversion tool 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/scripts/layout2layout.py
+yellow
 \end_layout
 
 \end_inset
 
- and convert it to a temporary file in current format.
- The original file is left untouched.
- If you want to convert the layout file permanently, just call the converter
- by hand:
-\end_layout
-
-\begin_layout LyX-Code
-python $LyXDir/scripts/layout2layout.py myclass.layout myclassnew.layout
+]
 \end_layout
 
-\begin_layout Standard
-(You need to replace 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$LyXDir
+Family
 \end_layout
 
 \end_inset
 
- with the name of your LyX system directory, unless you happen to have defined
- such an environment variable.) Then copy 
+ [
+\emph on
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-myclassnew.layout
+
+\emph on
+Roman
 \end_layout
 
 \end_inset
 
- to 
+
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/layouts/
+Sans
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-The automatic conversion only handles syntax changes.
- It cannot handle the case where the contents of included files was changed,
- so these will have to be converted separately.
+\begin_layout Plain Layout
+Typewriter
 \end_layout
 
-\begin_layout Section
-Creating Templates
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:templates"
-
 \end_inset
 
-
+] 
 \end_layout
 
-\begin_layout Standard
-Templates are created just like usual documents.
- The only difference is that usual documents contain all possible settings,
- including the font scheme and the paper size.
- 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 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-fontscheme
+Misc
 \end_layout
 
 \end_inset
 
- or 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-papersize
+string
 \end_layout
 
 \end_inset
 
- from the template LyX file.
- This can be done with any simple text-editor, for example 
+] Valid arguments are: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-vi
+emph
 \end_layout
 
 \end_inset
 
- or 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xedit
+noun
 \end_layout
 
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Standard
-Put the edited template files you create in 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/templates/
+underbar
 \end_layout
 
 \end_inset
 
-, copy the ones you use from the global template directory in 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/templates/
+no_emph
 \end_layout
 
 \end_inset
 
- to the same place, and redefine the template path in the 
-\begin_inset Flex CharStyle:MenuItem
+, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-T
-\family sans
-\bar default
-ools
-\family default
-\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-references\SpecialChar \menuseparator
-Paths
+no_noun
 \end_layout
 
 \end_inset
 
- dialog.
-\end_layout
-
-\begin_layout Standard
-Note that there is a template which has a particular meaning: 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-defaults.lyx
+no_bar
 \end_layout
 
 \end_inset
 
 .
- This template is loaded everytime you create a new document with 
-\begin_inset Flex CharStyle:MenuItem
+ Each of these turns on or off the corresponding attribute.
+ For example, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-F
-\bar default
-ile
+emph
 \end_layout
 
 \end_inset
 
-\SpecialChar \menuseparator
-
-\begin_inset Flex CharStyle:MenuItem
+ turns on emphasis, and 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-N
-\bar default
-ew
+no_emph
 \end_layout
 
 \end_inset
 
- in order to provide useful defaults.
- To create this template from inside LyX, all you have to do is to open
- a document with the correct settings, and use the 
-\begin_inset Flex CharStyle:MenuItem
+ turns it off.
+\begin_inset Newline newline
+\end_inset
+
+If the latter seems puzzling, remember that the font settings for the present
+ context are generally inherited from the surrounding context.
+ So 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Sa
-\bar under
-v
-\bar default
-e as Document Defaults
+no_emph
 \end_layout
 
 \end_inset
 
- button.
-\end_layout
-
-\begin_layout Chapter
-Including External Material
-\end_layout
-
-\begin_layout Standard
-The use of material from sources external to LyX is covered in detail in
- the 
-\emph on
-Embedded Objects
-\emph default
- manual.
- This part of the manual covers what needs to happen behind the scenes for
- new sorts of material to be included.
-\end_layout
-
-\begin_layout Section
-How does it work?
+ would turn off the emphasis that was anyway in effect, say, in a theorem
+ environment.
 \end_layout
 
-\begin_layout Standard
-The external material feature is based on the concept of a 
-\emph on
-template
-\emph default
-.
- A template is a specification of how LyX should interface with a certain
- kind of material.
- As bundled, LyX comes with predefined templates for Xfig figures, various
- raster format images, chess diagrams, and LilyPond music notation.
- You can check the actual list by using the menu 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Insert\SpecialChar \menuseparator
-File\SpecialChar \menuseparator
-External Material
+Series
 \end_layout
 
 \end_inset
 
-.
- Furthermore, it is possible to roll your own template to support a specific
- kind of material.
- Later we'll describe in more detail what is involved, and hopefully you
- will submit all the templates you create so we can include them in a later
- LyX version.
-\end_layout
+ [
+\emph on
 
-\begin_layout Standard
-Another basic idea of the external material feature is to distinguish between
- the original file that serves as a base for final material and the produced
- file that is included in your exported or printed document.
- For example, consider the case of a figure produced with 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Xfig
+
+\emph on
+Medium
 \end_layout
 
 \end_inset
 
-.
- The Xfig application itself works on an original file with the 
+
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.fig
+Bold
 \end_layout
 
 \end_inset
 
- extension.
- Within XFig, you create and change your figure, and when you are done,
- you save the 
+] 
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-fig
+Shape
 \end_layout
 
 \end_inset
 
--file.
- When you want to include the figure in your document, you invoke 
+ [
+\emph on
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-transfig
+
+\emph on
+Up
 \end_layout
 
 \end_inset
 
- in order to create a PostScript file that can readily be included in your
- LaTeX file.
- In this case, the 
+
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.fig
+Italic
 \end_layout
 
 \end_inset
 
- file is the original file, and the PostScript file is the produced file.
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-This distinction is important in order to allow updating of the material
- while you are in the process of writing the document.
- Furthermore, it provides us with the flexibility that is needed to support
- multiple export formats.
- For instance, in the case of a plain text file, it is not exactly an award-winn
-ing idea to include the figure as raw PostScript®.
- Instead, you'd either prefer to just include a reference to the figure
- or try to invoke some graphics to Ascii converter to make the final result
- look similar to the real graphics.
- The external material management allows you to do this, because it is parameter
-ized on the different export formats that LyX supports.
+\begin_layout Plain Layout
+SmallCaps
 \end_layout
 
-\begin_layout Standard
-Besides supporting the production of different products according to the
- exported format, it supports tight integration with editing and viewing
- applications.
- In the case of an XFig figure, you are able to invoke Xfig on the original
- file with a single click from within the external material dialog in LyX,
- and also preview the produced PostScript file with ghostview with another
- click.
- No more fiddling around with the command line and/or file browsers to locate
- and manipulate the original or produced files.
- In this way, you are finally able to take full advantage of the many different
- applications that are relevant to use when you write your documents, and
- ultimately be more productive.
-\end_layout
+\end_inset
 
-\begin_layout Section
-The external template configuration file
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-It is relatively easy to add custom external template definitions to LyX.
- However, be aware that doing this in an careless manner most probably 
-\emph on
-will
-\emph default
- introduce an easily exploitable security hole.
- So before you do this, please read the discussion about security in section
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:Security-discussion"
+\begin_layout Plain Layout
+Slanted
+\end_layout
 
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Standard
-Having said that, we encourage you to submit any interesting templates that
- you create.
+] 
 \end_layout
 
-\begin_layout Standard
-The external templates are defined in the 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/lib/external_templates
+Size
 \end_layout
 
 \end_inset
 
- file.
- You can place your own version in 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/external_templates
+tiny
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-A typical template looks like this:
+\begin_layout Plain Layout
+small
 \end_layout
 
-\begin_layout LyX-Code
-Template XFig
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-GuiName "XFig: $$AbsOrRelPathParent$$Basename"
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-HelpText
-\end_layout
+\begin_layout Plain Layout
 
-\begin_layout LyX-Code
-An XFig figure.
+\emph on
+normal
 \end_layout
 
-\begin_layout LyX-Code
-HelpTextEnd
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-InputFormat fig
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-FileFilter "*.fig"
+\begin_layout Plain Layout
+large
 \end_layout
 
-\begin_layout LyX-Code
-AutomaticProduction true
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-Transform Rotate
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Transform Resize
+\begin_layout Plain Layout
+larger
 \end_layout
 
-\begin_layout LyX-Code
-Format LaTeX
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-TransformCommand Rotate RotationLatexCommand
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-TransformCommand Resize ResizeLatexCommand
+\begin_layout Plain Layout
+largest
 \end_layout
 
-\begin_layout LyX-Code
-Product "$$RotateFront$$ResizeFront
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-         
-\backslash
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\backslash
-input{$$AbsOrRelPathMaster$$Basename.pstex_t}
+\begin_layout Plain Layout
+huge
 \end_layout
 
-\begin_layout LyX-Code
-         $$ResizeBack$$RotateBack"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-UpdateFormat pstex
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.pstex_t"
+\begin_layout Plain Layout
+giant
 \end_layout
 
-\begin_layout LyX-Code
-Requirement "graphicx"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pstex_t"
+]
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsPath$$Basename.eps"
+\begin_layout Subsection
+Upgrading old layout files
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile dvi "$$AbsPath$$Basename.eps"
-\end_layout
+\begin_layout Standard
+The file format of layout files changes from time to time, so old layout
+ files need to be converted.
+ This process has been automated since LyX 1.4.0: If LyX reads an old format
+ layout file it will call the conversion tool 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-FormatEnd
+\begin_layout Plain Layout
+LyXDir/scripts/layout2layout.py
 \end_layout
 
-\begin_layout LyX-Code
-Format PDFLaTeX
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-TransformCommand Rotate RotationLatexCommand
+ and convert it to a temporary file in current format.
+ The original file is left untouched.
+ If you want to convert the layout file permanently, just call the converter
+ by hand:
 \end_layout
 
 \begin_layout LyX-Code
-TransformCommand Resize ResizeLatexCommand
+python $LyXDir/scripts/layout2layout.py myclass.layout myclassnew.layout
 \end_layout
 
-\begin_layout LyX-Code
-Product "$$RotateFront$$ResizeFront
+\begin_layout Standard
+(You need to replace 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$LyXDir
 \end_layout
 
-\begin_layout LyX-Code
-         
-\backslash
+\end_inset
 
-\backslash
-input{$$AbsOrRelPathMaster$$Basename.pdftex_t}
-\end_layout
+ with the name of your LyX system directory, unless you happen to have defined
+ such an environment variable.) Then copy 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-         $$ResizeBack$$RotateBack"
+\begin_layout Plain Layout
+myclassnew.layout
 \end_layout
 
-\begin_layout LyX-Code
-UpdateFormat pdftex
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.pdftex_t"
-\end_layout
+ to 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Requirement "graphicx"
+\begin_layout Plain Layout
+UserDir/layouts/
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pdftex_t"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsPath$$Basename.pdf"
+.
 \end_layout
 
-\begin_layout LyX-Code
-FormatEnd
+\begin_layout Standard
+The automatic conversion only handles syntax changes.
+ It cannot handle the case where the contents of included files was changed,
+ so these will have to be converted separately.
 \end_layout
 
-\begin_layout LyX-Code
-Format Ascii
-\end_layout
+\begin_layout Section
+Creating Templates
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:Creating-Templates"
 
-\begin_layout LyX-Code
-Product "$$Contents(
-\backslash
-"$$AbsPath$$Basename.asc
-\backslash
-")"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-UpdateFormat asciixfig
-\end_layout
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.asc"
 \end_layout
 
-\begin_layout LyX-Code
-FormatEnd
-\end_layout
+\begin_layout Standard
+Templates are created just like usual documents.
+ The only difference is that usual documents contain all possible settings,
+ including the font scheme and the paper size.
+ 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 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Format DocBook
-\end_layout
+\begin_layout Plain Layout
 
-\begin_layout LyX-Code
-Product "<graphic fileref=
-\backslash
-"$$AbsOrRelPathMaster$$Basename.eps
 \backslash
-">
+fontscheme
 \end_layout
 
-\begin_layout LyX-Code
-         </graphic>"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-UpdateFormat eps
-\end_layout
+ or 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.eps"
-\end_layout
+\begin_layout Plain Layout
 
-\begin_layout LyX-Code
-ReferencedFile docbook "$$AbsPath$$Basename.eps"
+\backslash
+papersize
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile docbook-xml "$$AbsPath$$Basename.eps"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-FormatEnd
-\end_layout
+ from the template LyX file.
+ This can be done with any simple text-editor, for example 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Product "[XFig: $$FName]"
+\begin_layout Plain Layout
+vi
 \end_layout
 
-\begin_layout LyX-Code
-FormatEnd
+\end_inset
+
+ or 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+xedit
 \end_layout
 
-\begin_layout LyX-Code
-TemplateEnd
+\end_inset
+
+.
 \end_layout
 
 \begin_layout Standard
-As you can see, the template is enclosed in 
+Put the edited template files you create in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Template
+UserDir/templates/
 \end_layout
 
 \end_inset
 
- \SpecialChar \ldots{}
+, copy the ones you use from the global template directory in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TemplateEnd
+LyXDir/templates/
 \end_layout
 
 \end_inset
 
-.
- It contains a header specifying some general settings and, for each supported
- primary document file format, a section 
-\begin_inset Flex CharStyle:Code
+ to the same place, and redefine the template path in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Format
+Tools\SpecialChar \menuseparator
+Preferences\SpecialChar \menuseparator
+Paths
 \end_layout
 
 \end_inset
 
- \SpecialChar \ldots{}
+ dialog.
+\end_layout
+
+\begin_layout Standard
+Note that there is a template which has a particular meaning: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-FormatEnd
+defaults.lyx
 \end_layout
 
 \end_inset
 
 .
-\end_layout
+ This template is loaded every time you create a new document with 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_layout Subsection
-The template header
+\begin_layout Plain Layout
+File\SpecialChar \menuseparator
+New
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
+\end_inset
+
+ in order to provide useful defaults.
+ To create this template from inside LyX, all you have to do is to open
+ a document with the correct settings, and use the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-AutomaticProduction
-\begin_inset space ~
+Save as Document Defaults
+\end_layout
+
 \end_inset
 
-true|false
+ button.
+\end_layout
+
+\begin_layout Chapter
+Including External Material
+\end_layout
+
+\begin_layout Standard
+\begin_inset Box Shadowbox
+position "t"
+hor_pos "c"
+has_inner_box 1
+inner_pos "t"
+use_parbox 0
+width "100col%"
+special "none"
+height "1in"
+height_special "totalheight"
+status open
+
+\begin_layout Plain Layout
+WARNING: This portion of the documentation has not been updated for some
+ time.
+ We certainly hope that it is still accurate, but there are no guarantees.
 \end_layout
 
 \end_inset
 
- Whether the file represented by the template must be generated by LyX.
- This command must occur exactly once.
+
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
+\begin_layout Standard
+The use of material from sources external to LyX is covered in detail in
+ the 
+\emph on
+Embedded Objects
+\emph default
+ manual.
+ This part of the manual covers what needs to happen behind the scenes for
+ new sorts of material to be included.
+\end_layout
+
+\begin_layout Section
+How does it work?
+\end_layout
+
+\begin_layout Standard
+The external material feature is based on the concept of a 
+\emph on
+template
+\emph default
+.
+ A template is a specification of how LyX should interface with a certain
+ kind of material.
+ As bundled, LyX comes with predefined templates for Xfig figures, various
+ raster format images, chess diagrams, and LilyPond music notation.
+ You can check the actual list by using the menu 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-FileFilter
-\begin_inset space ~
-\end_inset
-
-<pattern>
+Insert\SpecialChar \menuseparator
+File\SpecialChar \menuseparator
+External Material
 \end_layout
 
 \end_inset
 
- A glob pattern that is used in the file dialog to filter out the desired
- files.
- If there is more than one possible file extension (e.g.
-\begin_inset space ~
-\end_inset
+.
+ Furthermore, it is possible to roll your own template to support a specific
+ kind of material.
+ Later we'll describe in more detail what is involved, and hopefully you
+ will submit all the templates you create so we can include them in a later
+ LyX version.
+\end_layout
 
-tgif has 
+\begin_layout Standard
+Another basic idea of the external material feature is to distinguish between
+ the original file that serves as a base for final material and the produced
+ file that is included in your exported or printed document.
+ For example, consider the case of a figure produced with 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.obj
+Xfig
 \end_layout
 
 \end_inset
 
- and 
+.
+ The Xfig application itself works on an original file with the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.tgo
+.fig
 \end_layout
 
 \end_inset
 
-), use something like 
+ extension.
+ Within Xfig, you create and change your figure, and when you are done,
+ you save the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-"*.{obj,tgo}"
+fig
 \end_layout
 
 \end_inset
 
-.
- This command must occur exactly once.
-\end_layout
-
-\begin_layout Description
+-file.
+ When you want to include the figure in your document, you invoke 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-GuiName
-\begin_inset space ~
-\end_inset
-
-<guiname>
+transfig
 \end_layout
 
 \end_inset
 
- The text that is displayed on the button.
- This command must occur exactly once.
-\end_layout
-
-\begin_layout Description
+ in order to create a PostScript file that can readily be included in your
+ LaTeX file.
+ In this case, the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-HelpText
-\begin_inset space ~
-\end_inset
-
-<text>
-\begin_inset space ~
-\end_inset
-
-HelpTextEnd
+.fig
 \end_layout
 
 \end_inset
 
- The help text that is used in the External dialog.
- Provide enough information to explain to the user just what the template
- can provide him with.
- This command must occur exactly once.
+ file is the original file, and the PostScript file is the produced file.
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-InputFormat
-\begin_inset space ~
-\end_inset
+\begin_layout Standard
+This distinction is important in order to allow updating of the material
+ while you are in the process of writing the document.
+ Furthermore, it provides us with the flexibility that is needed to support
+ multiple export formats.
+ For instance, in the case of a plain text file, it is not exactly an award-winn
+ing idea to include the figure as raw PostScript.
+ Instead, you'd either prefer to just include a reference to the figure
+ or try to invoke some graphics to ASCII converter to make the final result
+ look similar to the real graphics.
+ The external material management allows you to do this, because it is parametri
+zed on the different export formats that LyX supports.
+\end_layout
 
-<format>
+\begin_layout Standard
+Besides supporting the production of different products according to the
+ exported format, it supports tight integration with editing and viewing
+ applications.
+ In the case of an Xfig figure, you are able to invoke Xfig on the original
+ file with a single click from within the external material dialog in LyX,
+ and also preview the produced PostScript file with Ghostview with another
+ click.
+ No more fiddling around with the command line and/or file browsers to locate
+ and manipulate the original or produced files.
+ In this way, you are finally able to take full advantage of the many different
+ applications that are relevant to use when you write your documents, and
+ ultimately be more productive.
 \end_layout
 
-\end_inset
+\begin_layout Section
+The external template configuration file
+\end_layout
 
- The file format of the original file.
- This must be the name of a format that is known to LyX (see section 
+\begin_layout Standard
+It is relatively easy to add custom external template definitions to LyX.
+ However, be aware that doing this in an careless manner most probably 
+\emph on
+will
+\emph default
+ introduce an easily exploitable security hole.
+ So before you do this, please read the discussion about security in section
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sub:Formats"
+reference "sec:Security-discussion"
 
 \end_inset
 
-).
- Use 
-\begin_inset Quotes eld
-\end_inset
+.
+\end_layout
 
+\begin_layout Standard
+Having said that, we encourage you to submit any interesting templates that
+ you create.
+\end_layout
 
+\begin_layout Standard
+The external templates are defined in the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-*
+LyXDir/lib/external_templates
 \end_layout
 
 \end_inset
 
-
-\begin_inset Quotes erd
-\end_inset
-
- if the template can handle original files of more than one format.
- LyX will attempt to interrogate the file itself in order to deduce its
- format in this case.
- This command must occur exactly once.
-\end_layout
-
-\begin_layout Description
+ file.
+ You can place your own version in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Template
-\begin_inset space ~
+UserDir/external_templates
+\end_layout
+
 \end_inset
 
-<id>
+.
 \end_layout
 
-\end_inset
+\begin_layout Standard
+A typical template looks like this:
+\end_layout
 
- A unique name for the template.
- It must not contain substitution macros (see below).
+\begin_layout LyX-Code
+Template XFig
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+GuiName "XFig: $$AbsOrRelPathParent$$Basename"
+\end_layout
 
-\begin_layout Plain Layout
-Transform
-\begin_inset space ~
-\end_inset
+\begin_layout LyX-Code
+HelpText
+\end_layout
 
-Rotate|Resize|Clip|Extra
+\begin_layout LyX-Code
+An XFig figure.
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+HelpTextEnd
+\end_layout
 
- This command specifies which transformations are supported by this template.
- It may occur zero or more times.
- This command enables the corresponding tabs in the external dialog.
- Each 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+InputFormat fig
+\end_layout
 
-\begin_layout Plain Layout
-Transform
+\begin_layout LyX-Code
+FileFilter "*.fig"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+AutomaticProduction true
+\end_layout
 
- command must have either a corresponding 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+Transform Rotate
+\end_layout
 
-\begin_layout Plain Layout
-TransformCommand
+\begin_layout LyX-Code
+Transform Resize
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+Format LaTeX
+\end_layout
 
- or a 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+TransformCommand Rotate RotationLatexCommand
+\end_layout
 
-\begin_layout Plain Layout
-TransformOption
+\begin_layout LyX-Code
+TransformCommand Resize ResizeLatexCommand
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+Product "$$RotateFront$$ResizeFront
+\end_layout
 
- command in the 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+         
+\backslash
 
-\begin_layout Plain Layout
-Format
+\backslash
+input{$$AbsOrRelPathMaster$$Basename.pstex_t}
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+         $$ResizeBack$$RotateBack"
+\end_layout
 
- section.
- Otherwise the transformation will not be supported by that format.
+\begin_layout LyX-Code
+UpdateFormat pstex
 \end_layout
 
-\begin_layout Subsection
-The Format section
+\begin_layout LyX-Code
+UpdateResult "$$AbsPath$$Basename.pstex_t"
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+Requirement "graphicx"
+\end_layout
 
-\begin_layout Plain Layout
-Format
-\begin_inset space ~
-\end_inset
+\begin_layout LyX-Code
+ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pstex_t"
+\end_layout
 
-LaTeX|PDFLaTeX|PlainText|DocBook
+\begin_layout LyX-Code
+ReferencedFile latex "$$AbsPath$$Basename.eps"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+ReferencedFile dvi "$$AbsPath$$Basename.eps"
+\end_layout
 
- The primary document file format that this format definition is for.
- Not every template has a sensible representation in all document file formats.
- Please define nevertheless a 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+FormatEnd
+\end_layout
 
-\begin_layout Plain Layout
-Format
+\begin_layout LyX-Code
+Format PDFLaTeX
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+TransformCommand Rotate RotationLatexCommand
+\end_layout
 
- section for all formats.
- Use a dummy text when no representation is available.
- Then you can at least see a reference to the external material in the exported
- document.
+\begin_layout LyX-Code
+TransformCommand Resize ResizeLatexCommand
+\end_layout
+
+\begin_layout LyX-Code
+Product "$$RotateFront$$ResizeFront
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+         
+\backslash
+
+\backslash
+input{$$AbsOrRelPathMaster$$Basename.pdftex_t}
+\end_layout
 
-\begin_layout Plain Layout
-Option
-\begin_inset space ~
-\end_inset
+\begin_layout LyX-Code
+         $$ResizeBack$$RotateBack"
+\end_layout
 
-<name>
-\begin_inset space ~
-\end_inset
+\begin_layout LyX-Code
+UpdateFormat pdftex
+\end_layout
 
-<value>
+\begin_layout LyX-Code
+UpdateResult "$$AbsPath$$Basename.pdftex_t"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+Requirement "graphicx"
+\end_layout
 
- This command defines an additional macro 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pdftex_t"
+\end_layout
 
-\begin_layout Plain Layout
-$$<name>
+\begin_layout LyX-Code
+ReferencedFile latex "$$AbsPath$$Basename.pdf"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+FormatEnd
+\end_layout
 
- for substitution in 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+Format Ascii
+\end_layout
 
-\begin_layout Plain Layout
-Product
+\begin_layout LyX-Code
+Product "$$Contents(
+\backslash
+"$$AbsPath$$Basename.asc
+\backslash
+")"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+UpdateFormat asciixfig
+\end_layout
 
-.
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+UpdateResult "$$AbsPath$$Basename.asc"
+\end_layout
 
-\begin_layout Plain Layout
-<value>
+\begin_layout LyX-Code
+FormatEnd
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+Format DocBook
+\end_layout
 
- itself may contain substitution macros.
- The advantage over using 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+Product "<graphic fileref=
+\backslash
+"$$AbsOrRelPathMaster$$Basename.eps
+\backslash
+">
+\end_layout
 
-\begin_layout Plain Layout
-<value>
+\begin_layout LyX-Code
+         </graphic>"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+UpdateFormat eps
+\end_layout
 
- directly in 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+UpdateResult "$$AbsPath$$Basename.eps"
+\end_layout
 
-\begin_layout Plain Layout
-Product
+\begin_layout LyX-Code
+ReferencedFile docbook "$$AbsPath$$Basename.eps"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+ReferencedFile docbook-xml "$$AbsPath$$Basename.eps"
+\end_layout
 
- is that the substituted value of 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+FormatEnd
+\end_layout
 
-\begin_layout Plain Layout
-$$<name>
+\begin_layout LyX-Code
+Product "[XFig: $$FName]"
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+FormatEnd
+\end_layout
 
- is sanitized so that it is a valid optional argument in the document format.
- This command may occur zero or more times.
+\begin_layout LyX-Code
+TemplateEnd
 \end_layout
 
-\begin_layout Description
+\begin_layout Standard
+As you can see, the template is enclosed in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Product
-\begin_inset space ~
-\end_inset
-
-<text>
+Template
 \end_layout
 
 \end_inset
 
- The text that is inserted in the exported document.
- This is actually the most important command and can be quite complex.
- This command must occur exactly once.
-\end_layout
-
-\begin_layout Description
+ \SpecialChar \ldots{}
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Preamble
-\begin_inset space ~
-\end_inset
-
-<name>
+TemplateEnd
 \end_layout
 
 \end_inset
 
- This command specifies a preamble snippet that will be included in the
- LaTeX preamble.
- It has to be defined using 
+.
+ It contains a header specifying some general settings and, for each supported
+ primary document file format, a section 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-PreambleDef
+Format
 \end_layout
 
 \end_inset
@@ -15363,13 +15197,16 @@ PreambleDef
 status collapsed
 
 \begin_layout Plain Layout
-PreambleDefEnd
+FormatEnd
 \end_layout
 
 \end_inset
 
 .
- This command may occur zero or more times.
+\end_layout
+
+\begin_layout Subsection
+The template header
 \end_layout
 
 \begin_layout Description
@@ -15377,23 +15214,17 @@ PreambleDefEnd
 status collapsed
 
 \begin_layout Plain Layout
-ReferencedFile
-\begin_inset space ~
-\end_inset
-
-<format>
+AutomaticProduction
 \begin_inset space ~
 \end_inset
 
-<filename>
+true|false
 \end_layout
 
 \end_inset
 
- This command denotes files that are created by the conversion process and
- are needed for a particular export format.
- If the filename is relative, it is interpreted relative to the master document.
- This command may be given zero or more times.
+ Whether the file represented by the template must be generated by LyX.
+ This command must occur exactly once.
 \end_layout
 
 \begin_layout Description
@@ -15401,120 +15232,75 @@ ReferencedFile
 status collapsed
 
 \begin_layout Plain Layout
-Requirement
+FileFilter
 \begin_inset space ~
 \end_inset
 
-<package>
+<pattern>
 \end_layout
 
 \end_inset
 
- The name of a required LaTeX package.
- The package is included via 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\backslash
-usepackage{}
-\end_layout
-
+ A glob pattern that is used in the file dialog to filter out the desired
+ files.
+ If there is more than one possible file extension (e.
+\begin_inset space \thinspace{}
 \end_inset
 
- in the LaTeX preamble.
- This command may occur zero or more times.
-\end_layout
+g.
+\begin_inset space \space{}
+\end_inset
 
-\begin_layout Description
+tgif has 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TransformCommand
-\begin_inset space ~
-\end_inset
-
-Rotate
-\begin_inset space ~
-\end_inset
-
-RotationLatexCommand
+.obj
 \end_layout
 
 \end_inset
 
- This command specifies that the built in LaTeX command should be used for
- rotation.
- This command may occur once or not at all.
-\end_layout
-
-\begin_layout Description
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TransformCommand
-\begin_inset space ~
-\end_inset
-
-Resize
-\begin_inset space ~
-\end_inset
-
-ResizeLatexCommand
+.tgo
 \end_layout
 
 \end_inset
 
- This command specifies that the built in LaTeX command should be used for
- resizing.
- This command may occur once or not at all.
-\end_layout
-
-\begin_layout Description
+), use something like 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TransformOption
-\begin_inset space ~
-\end_inset
-
-Rotate
-\begin_inset space ~
-\end_inset
-
-RotationLatexOption
+"*.{obj,tgo}"
 \end_layout
 
 \end_inset
 
- This command specifies that rotation is done via an optional argument.
- This command may occur once or not at all.
+.
+ This command must occur exactly once.
 \end_layout
 
 \begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
-\begin_layout Plain Layout
-TransformOption
-\begin_inset space ~
-\end_inset
-
-Resize
+\begin_layout Plain Layout
+GuiName
 \begin_inset space ~
 \end_inset
 
-ResizeLatexOption
+<guiname>
 \end_layout
 
 \end_inset
 
- This command specifies that resizing is done via an optional argument.
- This command may occur once or not at all.
+ The text that is displayed on the button.
+ This command must occur exactly once.
 \end_layout
 
 \begin_layout Description
@@ -15522,21 +15308,23 @@ ResizeLatexOption
 status collapsed
 
 \begin_layout Plain Layout
-TransformOption
+HelpText
 \begin_inset space ~
 \end_inset
 
-Clip
+<text>
 \begin_inset space ~
 \end_inset
 
-ClipLatexOption
+HelpTextEnd
 \end_layout
 
 \end_inset
 
- This command specifies that clipping is done via an optional argument.
- This command may occur once or not at all.
+ The help text that is used in the External dialog.
+ Provide enough information to explain to the user just what the template
+ can provide him with.
+ This command must occur exactly once.
 \end_layout
 
 \begin_layout Description
@@ -15544,59 +15332,64 @@ ClipLatexOption
 status collapsed
 
 \begin_layout Plain Layout
-TransformOption
+InputFormat
 \begin_inset space ~
 \end_inset
 
-Extra
-\begin_inset space ~
+<format>
+\end_layout
+
 \end_inset
 
-ExtraLatexOption
-\end_layout
+ The file format of the original file.
+ This must be the name of a format that is known to LyX (see section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sec:Formats"
 
 \end_inset
 
- This command specifies that an extra optional argument is used.
- This command may occur once or not at all.
-\end_layout
+).
+ Use 
+\begin_inset Quotes eld
+\end_inset
+
 
-\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UpdateFormat
-\begin_inset space ~
+*
+\end_layout
+
 \end_inset
 
-<format>
-\end_layout
 
+\begin_inset Quotes erd
 \end_inset
 
- The file format of the converted file.
- This must be the name of a format that is known to LyX (see the 
-\begin_inset Flex CharStyle:MenuItem
+ if the template can handle original files of more than one format.
+ LyX will attempt to interrogate the file itself in order to deduce its
+ format in this case.
+ This command must occur exactly once.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+Template
+\begin_inset space ~
+\end_inset
 
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-references:Conversion
+<id>
 \end_layout
 
 \end_inset
 
dialog).
This command must occur exactly once.
A unique name for the template.
It must not contain substitution macros (see below).
 \end_layout
 
 \begin_layout Description
@@ -15604,49 +15397,49 @@ references:Conversion
 status collapsed
 
 \begin_layout Plain Layout
-UpdateResult
+Transform
 \begin_inset space ~
 \end_inset
 
-<filename>
+Rotate|Resize|Clip|Extra
 \end_layout
 
 \end_inset
 
- The file name of the converted file.
- The file name must be absolute.
- This command must occur exactly once.
-\end_layout
+ This command specifies which transformations are supported by this template.
+ It may occur zero or more times.
+ This command enables the corresponding tabs in the external dialog.
+ Each 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Subsection
-Preamble definitions
+\begin_layout Plain Layout
+Transform
 \end_layout
 
-\begin_layout Standard
-The external template configuration file may contain additional preamble
- definitions enclosed by 
+\end_inset
+
+ command must have either a corresponding 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-PreambleDef
+TransformCommand
 \end_layout
 
 \end_inset
 
- \SpecialChar \ldots{}
+ or a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-PreambleDefEnd
+TransformOption
 \end_layout
 
 \end_inset
 
-.
- They can be used by the templates in the 
+ command in the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -15657,40 +15450,43 @@ Format
 \end_inset
 
  section.
+ Otherwise the transformation will not be supported by that format.
 \end_layout
 
-\begin_layout Section
-The substitution mechanism
+\begin_layout Subsection
+The Format section
 \end_layout
 
-\begin_layout Standard
-When the external material facility invokes an external program, it is done
- on the basis of a command defined in the template configuration file.
- These commands can contain various macros that are expanded before execution.
- Execution always take place in the directory of the containing document.
-\end_layout
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-Also, whenever external material is to be displayed, the name will be produced
- by the substitution mechanism, and most other commands in the template
- definition support substitution as well.
-\end_layout
+\begin_layout Plain Layout
+Format
+\begin_inset space ~
+\end_inset
 
-\begin_layout Standard
-The available macros are the following:
+LaTeX|PDFLaTeX|PlainText|DocBook
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+ The primary document file format that this format definition is for.
+ Not every template has a sensible representation in all document file formats.
+ Please define nevertheless a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$AbsOrRelPathMaster
+Format
 \end_layout
 
 \end_inset
 
- The file path, absolute or relative to the master LyX document.
+ section for all formats.
+ Use a dummy text when no representation is available.
+ Then you can at least see a reference to the external material in the exported
+ document.
 \end_layout
 
 \begin_layout Description
@@ -15698,69 +15494,83 @@ $$AbsOrRelPathMaster
 status collapsed
 
 \begin_layout Plain Layout
-$$AbsOrRelPathParent
-\end_layout
+Option
+\begin_inset space ~
+\end_inset
 
+<name>
+\begin_inset space ~
 \end_inset
 
- The file path, absolute or relative to the LyX document.
+<value>
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+ This command defines an additional macro 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$AbsPath
+$$<name>
 \end_layout
 
 \end_inset
 
- The absolute file path.
-\end_layout
-
-\begin_layout Description
+ for substitution in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$Basename
+Product
 \end_layout
 
 \end_inset
 
- The filename without path and without the extension.
+.
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+<value>
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+ itself may contain substitution macros.
+ The advantage over using 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$Contents(
-\begin_inset Quotes eld
-\end_inset
+<value>
+\end_layout
 
-filename.ext
-\begin_inset Quotes erd
 \end_inset
 
-)
+ directly in 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Product
 \end_layout
 
 \end_inset
 
- This macro will expand to the contents of the file with the name 
+ is that the substituted value of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-filename.ext
+$$<name>
 \end_layout
 
 \end_inset
 
-.
+ is sanitized so that it is a valid optional argument in the document format.
+ This command may occur zero or more times.
 \end_layout
 
 \begin_layout Description
@@ -15768,12 +15578,18 @@ filename.ext
 status collapsed
 
 \begin_layout Plain Layout
-$$Extension
+Product
+\begin_inset space ~
+\end_inset
+
+<text>
 \end_layout
 
 \end_inset
 
- The file extension (including the dot).
+ The text that is inserted in the exported document.
+ This is actually the most important command and can be quite complex.
+ This command must occur exactly once.
 \end_layout
 
 \begin_layout Description
@@ -15781,36 +15597,64 @@ $$Extension
 status collapsed
 
 \begin_layout Plain Layout
-$$FName
+Preamble
+\begin_inset space ~
+\end_inset
+
+<name>
 \end_layout
 
 \end_inset
 
- The filename of the file specified in the external material dialog.
- This is either an absolute name, or it is relative to the LyX document.
+ This command specifies a preamble snippet that will be included in the
+ LaTeX preamble.
+ It has to be defined using 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+PreambleDef
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+ \SpecialChar \ldots{}
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$FPath
+PreambleDefEnd
 \end_layout
 
 \end_inset
 
- The path part of 
+.
+ This command may occur zero or more times.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$FName
+ReferencedFile
+\begin_inset space ~
+\end_inset
+
+<format>
+\begin_inset space ~
+\end_inset
+
+<filename>
 \end_layout
 
 \end_inset
 
- (absolute name or relative to the LyX document).
+ This command denotes files that are created by the conversion process and
+ are needed for a particular export format.
+ If the filename is relative, it is interpreted relative to the master document.
+ This command may be given zero or more times.
 \end_layout
 
 \begin_layout Description
@@ -15818,25 +15662,30 @@ $$FName
 status collapsed
 
 \begin_layout Plain Layout
-$$RelPathMaster
-\end_layout
-
+Requirement
+\begin_inset space ~
 \end_inset
 
- The file path, relative to the master LyX document.
+<package>
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+ The name of a required LaTeX package.
+ The package is included via 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$RelPathParent
+
+\backslash
+usepackage{}
 \end_layout
 
 \end_inset
 
- The file path, relative to the LyX document.
+ in the LaTeX preamble.
+ This command may occur zero or more times.
 \end_layout
 
 \begin_layout Description
@@ -15844,14 +15693,22 @@ $$RelPathParent
 status collapsed
 
 \begin_layout Plain Layout
-$$Sysdir
+TransformCommand
+\begin_inset space ~
+\end_inset
+
+Rotate
+\begin_inset space ~
+\end_inset
+
+RotationLatexCommand
 \end_layout
 
 \end_inset
 
- This macro will expand to the absolute path of the system directory.
- This is typically used to point to the various helper scripts that are
bundled with LyX.
+ This command specifies that the built in LaTeX command should be used for
+ rotation.
This command may occur once or not at all.
 \end_layout
 
 \begin_layout Description
@@ -15859,66 +15716,88 @@ $$Sysdir
 status collapsed
 
 \begin_layout Plain Layout
-$$Tempname
+TransformCommand
+\begin_inset space ~
+\end_inset
+
+Resize
+\begin_inset space ~
+\end_inset
+
+ResizeLatexCommand
 \end_layout
 
 \end_inset
 
- A name and full path to a temporary file which will be automatically deleted
- whenever the containing document is closed, or the external material insertion
deleted.
+ This command specifies that the built in LaTeX command should be used for
+ resizing.
This command may occur once or not at all.
 \end_layout
 
-\begin_layout Standard
-All path macros contain a trailing directory separator, so you can construct
- e.g.
- the absolute filename with 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$AbsPath$$Basename$$Extension
+TransformOption
+\begin_inset space ~
+\end_inset
+
+Rotate
+\begin_inset space ~
+\end_inset
+
+RotationLatexOption
 \end_layout
 
 \end_inset
 
-.
+ This command specifies that rotation is done via an optional argument.
+ This command may occur once or not at all.
 \end_layout
 
-\begin_layout Standard
-The macros above are substituted in all commands unless otherwise noted.
- The command 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Product
-\end_layout
-
+TransformOption
+\begin_inset space ~
 \end_inset
 
- supports additionally the following substitutions if they are enabled by
- the 
-\begin_inset Flex CharStyle:Code
-status collapsed
+Resize
+\begin_inset space ~
+\end_inset
 
-\begin_layout Plain Layout
-Transform
+ResizeLatexOption
 \end_layout
 
 \end_inset
 
- and 
+ This command specifies that resizing is done via an optional argument.
+ This command may occur once or not at all.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TransformCommand
+TransformOption
+\begin_inset space ~
+\end_inset
+
+Clip
+\begin_inset space ~
+\end_inset
+
+ClipLatexOption
 \end_layout
 
 \end_inset
 
- commands:
+ This command specifies that clipping is done via an optional argument.
+ This command may occur once or not at all.
 \end_layout
 
 \begin_layout Description
@@ -15926,12 +15805,21 @@ TransformCommand
 status collapsed
 
 \begin_layout Plain Layout
-$$ResizeFront
+TransformOption
+\begin_inset space ~
+\end_inset
+
+Extra
+\begin_inset space ~
+\end_inset
+
+ExtraLatexOption
 \end_layout
 
 \end_inset
 
- The front part of the resize command.
+ This command specifies that an extra optional argument is used.
+ This command may occur once or not at all.
 \end_layout
 
 \begin_layout Description
@@ -15939,25 +15827,37 @@ $$ResizeFront
 status collapsed
 
 \begin_layout Plain Layout
-$$ResizeBack
-\end_layout
-
+UpdateFormat
+\begin_inset space ~
 \end_inset
 
- The back part of the resize command.
+<format>
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
+\end_inset
+
+ The file format of the converted file.
+ This must be the name of a format that is known to LyX (see the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-$$RotateFront
+
+\bar under
+T
+\bar default
+ools\SpecialChar \menuseparator
+
+\bar under
+P
+\bar default
+references:Conversion
 \end_layout
 
 \end_inset
 
- The front part of the rotation command.
+ dialog).
+ This command must occur exactly once.
 \end_layout
 
 \begin_layout Description
@@ -15965,73 +15865,80 @@ $$RotateFront
 status collapsed
 
 \begin_layout Plain Layout
-$$RotateBack
+UpdateResult
+\begin_inset space ~
+\end_inset
+
+<filename>
 \end_layout
 
 \end_inset
 
- The back part of the rotation command.
+ The file name of the converted file.
+ The file name must be absolute.
+ This command must occur exactly once.
+\end_layout
+
+\begin_layout Subsection
+Preamble definitions
 \end_layout
 
 \begin_layout Standard
-The value string of the 
+The external template configuration file may contain additional preamble
+ definitions enclosed by 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Option
+PreambleDef
 \end_layout
 
 \end_inset
 
- command supports additionally the following substitutions if they are enabled
- by the 
+ \SpecialChar \ldots{}
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Transform
+PreambleDefEnd
 \end_layout
 
 \end_inset
 
- and 
+.
+ They can be used by the templates in the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TransformOption
+Format
 \end_layout
 
 \end_inset
 
- commands:
+ section.
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-$$Clip
+\begin_layout Section
+The substitution mechanism
 \end_layout
 
-\end_inset
-
- The clip option.
+\begin_layout Standard
+When the external material facility invokes an external program, it is done
+ on the basis of a command defined in the template configuration file.
+ These commands can contain various macros that are expanded before execution.
+ Execution always take place in the directory of the containing document.
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-$$Extra
+\begin_layout Standard
+Also, whenever external material is to be displayed, the name will be produced
+ by the substitution mechanism, and most other commands in the template
+ definition support substitution as well.
 \end_layout
 
-\end_inset
-
- The extra option.
+\begin_layout Standard
+The available macros are the following:
 \end_layout
 
 \begin_layout Description
@@ -16039,12 +15946,12 @@ $$Extra
 status collapsed
 
 \begin_layout Plain Layout
-$$Resize
+$$AbsOrRelPathMaster
 \end_layout
 
 \end_inset
 
- The resize option.
+ The file path, absolute or relative to the master LyX document.
 \end_layout
 
 \begin_layout Description
@@ -16052,49 +15959,15 @@ $$Resize
 status collapsed
 
 \begin_layout Plain Layout
-$$Rotate
-\end_layout
-
-\end_inset
-
- The rotation option.
-\end_layout
-
-\begin_layout Standard
-You may ask why there are so many path macros.
- There are mainly two reasons:
-\end_layout
-
-\begin_layout Enumerate
-Relative and absolute file names should remain relative or absolute, respectivel
-y.
- Users may have reasons to prefer either form.
- Relative names are useful for portable documents that should work on different
- machines, for example.
- Absolute names may be required by some programs.
-\end_layout
-
-\begin_layout Enumerate
-LaTeX treats relative file names differently than LyX and other programs
- in nested included files.
- For LyX, a relative file name is always relative to the document that contains
- the file name.
- For LaTeX, it is always relative to the master document.
- These two definitions are identical if you have only one document, but
- differ if you have a master document that includes part documents.
- That means that relative filenames must be transformed when presented to
- LaTeX.
- Fortunately LyX does this automatically for you if you choose the right
- macros.
+$$AbsOrRelPathParent
 \end_layout
 
-\begin_layout Standard
-So which path macro should be used in new template definitions? The rule
- is not difficult:
+\end_inset
+
+ The file path, absolute or relative to the LyX document.
 \end_layout
 
-\begin_layout Itemize
-Use 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -16104,713 +15977,565 @@ $$AbsPath
 
 \end_inset
 
if an absolute path is required.
The absolute file path.
 \end_layout
 
-\begin_layout Itemize
-Use 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$AbsOrRelPathMaster
+$$Basename
 \end_layout
 
 \end_inset
 
if the substituted string is some kind of LaTeX input.
The filename without path and without the extension.
 \end_layout
 
-\begin_layout Itemize
-Else use 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$AbsOrRelPathParent
-\end_layout
+$$Contents(
+\begin_inset Quotes eld
+\end_inset
 
+filename.ext
+\begin_inset Quotes erd
 \end_inset
 
- in order to preserve the user's choice.
+)
 \end_layout
 
-\begin_layout Standard
-There are special cases where this rule does not work and e.g.
-\begin_inset space ~
 \end_inset
 
-relative names are needed, but normally it will work just fine.
- One example for such a case is the command 
+ This macro will expand to the contents of the file with the name 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pstex_t"
+filename.ext
 \end_layout
 
 \end_inset
 
- in the XFig template above: We can't use the absolute name because the
- copier for 
+.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.pstex_t
-\end_layout
-
-\end_inset
-
- files needs the relative name in order to rewrite the file content.
+$$Extension
 \end_layout
 
-\begin_layout Section
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:Security-discussion"
-
 \end_inset
 
-Security discussion
+ The file extension (including the dot).
 \end_layout
 
-\begin_layout Standard
-\begin_inset Note Note
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-This section is outdated
+$$FName
 \end_layout
 
 \end_inset
 
-The external material feature interfaces with a lot of external programs
- and does so automatically, so we have to consider the security implications
- of this.
- In particular, since you have the option of including your own filenames
- and/or parameter strings and those are expanded into a command, it seems
- that it would be possible to create a malicious document which executes
- arbitrary commands when a user views or prints the document.
- This is something we definately want to avoid.
+ The filename of the file specified in the external material dialog.
+ This is either an absolute name, or it is relative to the LyX document.
 \end_layout
 
-\begin_layout Standard
-However, since the external program commands are specified in the template
- configuration file only, there are no security issues if LyX is properly
- configured with safe templates only.
- This is so because the external programs are invoked with the 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-execvp
+$$FPath
 \end_layout
 
 \end_inset
 
--system call rather than the 
+ The path part of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-system
+$$FName
 \end_layout
 
 \end_inset
 
- system-call, so it's not possible to execute arbitrary commands from the
- filename or parameter section via the shell.
+ (absolute name or relative to the LyX document).
 \end_layout
 
-\begin_layout Standard
-This also implies that you are restricted in what command strings you can
- use in the external material templates.
- In particular, pipes and redirection are not readily available.
- This has to be so if LyX should remain safe.
- If you want to use some of the shell features, you should write a safe
- script to do this in a controlled manner, and then invoke the script from
- the command string.
- In the 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lib/scripts
+$$RelPathMaster
 \end_layout
 
 \end_inset
 
- directory of the LyX installation, you can find a safe wrapper script 
+ The file path, relative to the master LyX document.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-general_command_wrapper.py
+$$RelPathParent
 \end_layout
 
 \end_inset
 
- that supports redirection of input and output.
- That can serve as an example for how to write safe template scripts.
- For a more advanced example that uses 
+ The file path, relative to the LyX document.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-fork
+$$Sysdir
 \end_layout
 
 \end_inset
 
- and friends, take a look at the 
+ This macro will expand to the absolute path of the system directory.
+ This is typically used to point to the various helper scripts that are
+ bundled with LyX.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pic2ascii.py
+$$Tempname
 \end_layout
 
 \end_inset
 
- converter script.
+ A name and full path to a temporary file which will be automatically deleted
+ whenever the containing document is closed, or the external material insertion
+ deleted.
 \end_layout
 
 \begin_layout Standard
-It is possible to design a template that interacts directly with the shell,
- but since this would allow a malicious user to execute arbitrary commands
- by writing clever filenames and/or parameters, we generally recommend that
- you only use safe scripts that work with the 
+All path macros contain a trailing directory separator, so you can construct
+ e.
+\begin_inset space \thinspace{}
+\end_inset
+
+g.
+\begin_inset space \space{}
+\end_inset
+
+the absolute filename with 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-execvp
+$$AbsPath$$Basename$$Extension
 \end_layout
 
 \end_inset
 
- system call in a controlled manner.
- Of course, for use in a controlled environment, it can be tempting to just
- fall back to use ordinary shell scripts.
- If you do so, be aware that you 
-\emph on
-will
-\emph default
- provide an easily exploitable security hole in your system.
- Of course it stands to reason that such unsafe templates will never be
- included in the standard LyX distribution, although we do encourage people
- to submit new templates in the open source tradition.
- But LyX as shipped from the official distribution channels will never have
- unsafe templates.
+.
 \end_layout
 
 \begin_layout Standard
-Including external material provides a lot of power, and you have to be
- careful not to introduce security hazards with this power.
- A subtle error in a single line in an innocent looking script can open
- the door to huge security problems.
- So if you do not fully understand the issues, we recommend that you consult
- a knowledgable security professional or the LyX development team if you
- have any questions about whether a given template is safe or not.
- And do this before you use it in an uncontrolled environment.
-\end_layout
+The macros above are substituted in all commands unless otherwise noted.
+ The command 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Chapter
-The LyX Server
+\begin_layout Plain Layout
+Product
 \end_layout
 
-\begin_layout Section
-Introduction
-\end_layout
+\end_inset
 
-\begin_layout Standard
-The LyX server is a method implemented in 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 they should find it useful.
- Please note that, at present, 
-\emph on
-the server does not work on Windows
-\emph default
-.
-\begin_inset Foot
+ supports additionally the following substitutions if they are enabled by
+ the 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-There is no principled reason it cannot do so.
- But none of the developers on Windows® have yet implemented this functionality
- there.
+Transform
 \end_layout
 
 \end_inset
 
+ and 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
+\begin_layout Plain Layout
+TransformCommand
 \end_layout
 
-\begin_layout Section
-Starting the LyX Server
+\end_inset
+
+ commands:
 \end_layout
 
-\begin_layout Standard
-The LyX server works through the use of a pair of named pipes.
- These are usually located in 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir
+$$ResizeFront
 \end_layout
 
 \end_inset
 
- and have the names 
-\begin_inset Quotes eld
-\end_inset
-
+ The front part of the resize command.
+\end_layout
 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.lyxpipe.in
+$$ResizeBack
 \end_layout
 
 \end_inset
 
+ The back part of the resize command.
+\end_layout
 
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$$RotateFront
+\end_layout
 
- and 
-\begin_inset Quotes eld
 \end_inset
 
+ The front part of the rotation command.
+\end_layout
 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.lyxpipe.out
+$$RotateBack
 \end_layout
 
 \end_inset
 
+ The back part of the rotation command.
+\end_layout
 
-\begin_inset Quotes erd
-\end_inset
-
-.
- External programs write into 
+\begin_layout Standard
+The value string of the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.lyxpipe.in
+Option
 \end_layout
 
 \end_inset
 
- and read back data from 
+ command supports additionally the following substitutions if they are enabled
+ by the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.lyxpipe.out
+Transform
 \end_layout
 
 \end_inset
 
-.
- The stem of the pipe names can be defined in the 
-\begin_inset Flex CharStyle:MenuItem
+ and 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+TransformOption
+\end_layout
 
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-P
-\bar default
-references
+ commands:
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$$Clip
 \end_layout
 
 \end_inset
 
- dialog, for example 
+ The clip option.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-"/home/myhome/.lyxpipe"
+$$Extra
 \end_layout
 
 \end_inset
 
-.
+ The extra option.
 \end_layout
 
-\begin_layout Standard
-LyX will add the '
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.in
+$$Resize
+\end_layout
+
+\end_inset
+
+ The resize option.
 \end_layout
 
-\end_inset
-
-' and '
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.out
+$$Rotate
 \end_layout
 
 \end_inset
 
-' to create the pipes.
- The above setting 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 configuration between the start of the programs.
-\end_layout
-
-\begin_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 lyx -dbg lyxserver.
+ The rotation option.
 \end_layout
 
 \begin_layout Standard
-Warning: if LyX crashes, it may not manage to remove the pipes; in this
- case you must remove them manually.
- If LyX starts and the pipes exist already, it will not start any server.
+You may ask why there are so many path macros.
+ There are mainly two reasons:
 \end_layout
 
-\begin_layout Standard
-Other than this, there are a few points to consider:
+\begin_layout Enumerate
+Relative and absolute file names should remain relative or absolute, respectivel
+y.
+ Users may have reasons to prefer either form.
+ Relative names are useful for portable documents that should work on different
+ machines, for example.
+ Absolute names may be required by some programs.
 \end_layout
 
-\begin_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.
+\begin_layout Enumerate
+LaTeX treats relative file names differently than LyX and other programs
+ in nested included files.
+ For LyX, a relative file name is always relative to the document that contains
+ the file name.
+ For LaTeX, it is always relative to the master document.
+ These two definitions are identical if you have only one document, but
+ differ if you have a master document that includes part documents.
+ That means that relative filenames must be transformed when presented to
+ LaTeX.
+ Fortunately LyX does this automatically for you if you choose the right
+ macros.
 \end_layout
 
-\begin_layout Itemize
-On OS/2, only one client can connect to LyXServer at a time.
+\begin_layout Standard
+So which path macro should be used in new template definitions? The rule
+ is not difficult:
 \end_layout
 
 \begin_layout Itemize
-On OS/2, clients must open inpipe with 
+Use 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-O_WRONLY
+$$AbsPath
 \end_layout
 
 \end_inset
 
-
-\end_layout
-
-\begin_layout Standard
-mode.
+ if an absolute path is required.
 \end_layout
 
-\begin_layout Standard
-You can find a complete example client written in C in the source distribution
- as 
+\begin_layout Itemize
+Use 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-development/lyxserver/server_monitor.c
+$$AbsOrRelPathMaster
 \end_layout
 
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Section
-Normal communication
-\end_layout
-
-\begin_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:
-\end_layout
-
-\begin_layout Quote
-LYXCMD:
-\emph on
-clientname
-\emph default
-:
-\emph on
-function
-\emph default
-:
-\emph on
-argument
+ if the substituted string is some kind of LaTeX input.
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
+Else use 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\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.
+\begin_layout Plain Layout
+$$AbsOrRelPathParent
 \end_layout
 
-\begin_layout Description
+\end_inset
 
-\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.
+ in order to preserve the user's choice.
 \end_layout
 
-\begin_layout Description
-
-\emph on
-argument
-\emph default
- is an optional argument which is meaningful only to some functions (for
- instance 
-\begin_inset Quotes eld
+\begin_layout Standard
+There are special cases where this rule does not work and e.
+\begin_inset space \thinspace{}
 \end_inset
 
-self-insert
-\begin_inset Quotes erd
+g.
+\begin_inset space \space{}
 \end_inset
 
- which will insert the argument as text at the cursor position.)
-\end_layout
-
-\begin_layout Standard
-The answer from LyX will arrive in the output pipe and be of the form
-\end_layout
+relative names are needed, but normally it will work just fine.
+ One example for such a case is the command 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Quote
-INFO:
-\emph on
-clientname
-\emph default
-:
-\emph on
-function
-\emph default
-:
-\emph on
-data
+\begin_layout Plain Layout
+ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pstex_t"
 \end_layout
 
-\begin_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.
-\end_layout
-
-\begin_layout Standard
-In case of errors, the response from LyX will have this form
-\end_layout
+ in the XFig template above: We can't use the absolute name because the
+ copier for 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Quote
-ERROR:
-\emph on
-clientname
-\emph default
-:
-\emph on
-function
-\emph default
-:
-\emph on
-error message
+\begin_layout Plain Layout
+.pstex_t
 \end_layout
 
-\begin_layout Standard
-where the 
-\emph on
-error message
-\emph default
- should contain an explanation of why the command failed.
-\end_layout
+\end_inset
 
-\begin_layout Standard
-Examples:
+ files needs the relative name in order to rewrite the file content.
 \end_layout
 
-\begin_layout LyX-Code
-echo "LYXCMD:test:beginning-of-buffer:" >~/.lyxpipe.in
-\end_layout
+\begin_layout Section
+Security discussion
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:Security-discussion"
 
-\begin_layout LyX-Code
-echo "LYXCMD:test:get-xy:" >~/.lyxpipe.in
-\begin_inset Newline newline
 \end_inset
 
-read a <~/.lyxpipe.out
-\begin_inset Newline newline
-\end_inset
 
-echo $a
 \end_layout
 
-\begin_layout Section
-Notification
+\begin_layout Standard
+The external material feature interfaces with a lot of external programs
+ and does so automatically, so we have to consider the security implications
+ of this.
+ In particular, since you have the option of including your own filenames
+ and/or parameter strings and those are expanded into a command, it seems
+ that it would be possible to create a malicious document which executes
+ arbitrary commands when a user views or prints the document.
+ This is something we definitely want to avoid.
 \end_layout
 
 \begin_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
+However, since the external program commands are specified in the template
+ configuration file only, there are no security issues if LyX is properly
+ configured with safe templates only.
+ This is so because the external programs are invoked with the 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-.
- The format of the string LyX sends is as follows:
+\begin_layout Plain Layout
+execvp
 \end_layout
 
-\begin_layout Quote
+\end_inset
+
+-system call rather than the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-NOTIFY:
+system
 \end_layout
 
 \end_inset
 
-
-\emph on
-key-sequence
+ system-call, so it's not possible to execute arbitrary commands from the
+ filename or parameter section via the shell.
 \end_layout
 
 \begin_layout Standard
-where 
-\emph on
-key-sequence
-\emph default
- is the printed representation of the key sequence that was actually typed
- by the user.
+This also implies that you are restricted in what command strings you can
+ use in the external material templates.
+ In particular, pipes and redirection are not readily available.
+ This has to be so if LyX should remain safe.
+ If you want to use some of the shell features, you should write a safe
+ script to do this in a controlled manner, and then invoke the script from
+ the command string.
 \end_layout
 
 \begin_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.
-\end_layout
+It is possible to design a template that interacts directly with the shell,
+ but since this would allow a malicious user to execute arbitrary commands
+ by writing clever filenames and/or parameters, we generally recommend that
+ you only use safe scripts that work with the 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Section
-The simple LyX Server Protocol
+\begin_layout Plain Layout
+execvp
 \end_layout
 
-\begin_layout Standard
-LyX implements a simple protocol that can be used for session management.
- All messages are of the form
-\end_layout
+\end_inset
 
-\begin_layout Quote
-LYXSRV:
+ system call in a controlled manner.
+ Of course, for use in a controlled environment, it can be tempting to just
+ fall back to use ordinary shell scripts.
+ If you do so, be aware that you 
 \emph on
-clientname
+will
 \emph default
-:
-\emph on
-protocol message
+ provide an easily exploitable security hole in your system.
+ Of course it stands to reason that such unsafe templates will never be
+ included in the standard LyX distribution, although we do encourage people
+ to submit new templates in the open source tradition.
+ But LyX as shipped from the official distribution channels will never have
+ unsafe templates.
 \end_layout
 
 \begin_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.
+Including external material provides a lot of power, and you have to be
+ careful not to introduce security hazards with this power.
+ A subtle error in a single line in an innocent looking script can open
+ the door to huge security problems.
+ So if you do not fully understand the issues, we recommend that you consult
+ a knowledgeable security professional or the LyX development team if you
+ have any questions about whether a given template is safe or not.
+ And do this before you use it in an uncontrolled environment.
 \end_layout
 
 \end_body