]> git.lyx.org Git - lyx.git/blobdiff - lib/doc/Customization.lyx
Typo.
[lyx.git] / lib / doc / Customization.lyx
index ddcd24e5693afb7d533dc6703d6fe257fec25645..baecb3b8f83a2e767d0de8250c23f27eea8589e1 100644 (file)
@@ -1,14 +1,14 @@
-#LyX 1.6.0svn created this file. For more info see http://www.lyx.org/
-\lyxformat 338
+#LyX 2.0.0svn created this file. For more info see http://www.lyx.org/
+\lyxformat 375
 \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,39 @@ 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 "" 
+\html_use_mathml true
+\html_be_strict true
 \end_header
 
 \begin_body
@@ -137,11 +150,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 +182,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 +209,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 +235,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 +243,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 +305,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 +389,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 +550,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 +562,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 +602,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 +705,7 @@ kbd/
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:keymap"
+reference "sec:International-Keymap-Stuff"
 
 \end_inset
 
@@ -734,7 +730,7 @@ layouts/
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "chap:textclass"
+reference "cha:Installing-New-Document"
 
 \end_inset
 
@@ -814,7 +810,7 @@ templates/
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:templates"
+reference "sub:Creating-Templates"
 
 \end_inset
 
@@ -845,14 +841,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 +869,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 +928,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 +1004,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 +1061,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 +1096,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 +1130,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 +1157,7 @@ UserDir/doc/
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp
+Help
 \end_layout
 
 \end_inset
@@ -1264,7 +1216,7 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-LYX_USERDIR_16x
+LYX_USERDIR_VER
 \end_layout
 
 \end_inset
@@ -1301,22 +1253,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 +1272,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
-\end_layout
-
+Extra
+\begin_inset space ~
 \end_inset
 
- files.
+Flag
 \end_layout
 
-\begin_layout Section
-Editing
-\end_layout
+\end_inset
 
-\begin_layout Standard
-The settings in this section are used to customise the behavior of the LyX
- editor.
+ field you can enter the following flags, separated by commas:
 \end_layout
 
-\begin_layout Subsection
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:bindings"
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+latex
+\end_layout
 
 \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 +2270,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
+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 Plain Layout
-From
-\begin_inset space ~
-\end_inset
+\begin_layout Section
+International Keyboard Support
+\end_layout
 
-format
+\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
 
-\end_inset
+\begin_layout Subsection
+Defining Own Keymaps: Keymap File Format
+\end_layout
 
- and
-\begin_inset space \thinspace{}
-\end_inset
+\begin_layout Standard
+Let's look at a keyboard definition file a little closer.
+ It is a plain text file defining
+\end_layout
 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+\begin_layout Itemize
+key-to-key or key-to-string translations
+\end_layout
 
-\begin_layout Plain Layout
-To
-\begin_inset space ~
-\end_inset
+\begin_layout Itemize
+dead keys
+\end_layout
 
-format
+\begin_layout Itemize
+dead keys exceptions
 \end_layout
 
-\end_inset
+\begin_layout Standard
+To define key-to-key or key-to-string translation, use this command:
+\end_layout
 
- from the drop-down lists, enter the command needed for the conversion,
- and then press the 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Quotation
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Add
+
+\backslash
+kmap
 \end_layout
 
 \end_inset
 
- 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
-$$s
+key
 \end_layout
 
 \end_inset
 
- The LyX system directory
+ 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
-$$i
+key
 \end_layout
 
 \end_inset
 
- The input file
-\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
-$$o
+outstring
 \end_layout
 
 \end_inset
 
- The output file
+ is the string to be inserted into the document.
+ To define dead keys, use:
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\begin_layout Quotation
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$b
+
+\backslash
+kmod
 \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
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$$p
+key
 \end_layout
 
 \end_inset
 
- The path to the input file
+ deadkey
 \end_layout
 
 \begin_layout Standard
-In th
-\begin_inset Flex CharStyle:MenuItem
+wher
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Extra
-\begin_inset space ~
-\end_inset
-
-Flag
+key
 \end_layout
 
 \end_inset
 
- field you can enter the following flags, separated by commas:
-\end_layout
-
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+ is a keyboard key and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-latex
+deadkey
 \end_layout
 
 \end_inset
 
This converter runs some form of LaTeX.
- This will make LyX's LaTeX error logs available.
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 Quotation
 
-\begin_layout Plain Layout
-needaux
+\emph on
+Name
+\begin_inset space \hfill{}
+\end_inset
+
+Example
 \end_layout
 
+\begin_layout Quotation
+acute (acu)
+\begin_inset space \hfill{}
 \end_inset
 
- Needs the LaTeX 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-.aux
+áéíóú
 \end_layout
 
+\begin_layout Quotation
+grave (gra)
+\begin_inset space \hfill{}
 \end_inset
 
- file for the conversion.
+àèìòù
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Quotation
+macron (mac)
+\begin_inset space \hfill{}
+\end_inset
 
-\begin_layout Plain Layout
-xml
+ ō
 \end_layout
 
+\begin_layout Quotation
+tilde (til)
+\begin_inset space \hfill{}
 \end_inset
 
- Output is XML.
+ñÑ
 \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 Quotation
+underbar (underb)
+\begin_inset space \hfill{}
+\end_inset
+
+
+\begin_inset ERT
+status open
 
 \begin_layout Plain Layout
-key
-\begin_inset space ~
-\end_inset
 
-=
-\begin_inset space ~
-\end_inset
 
-value
+\backslash
+b o
 \end_layout
 
 \end_inset
 
- format:
+
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Quotation
+cedilla (ced)
+\begin_inset space \hfill{}
+\end_inset
 
-\begin_layout Plain Layout
-parselog
+çÇ
 \end_layout
 
+\begin_layout Quotation
+underdot (underd)
+\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
+d 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
+circumflex (circu)
+\begin_inset space \hfill{}
 \end_inset
 
-.
- The argument may contain 
-\begin_inset Flex CharStyle:Code
-status collapsed
+âêîôû
+\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
-$$s
+
+
+\backslash
+t o
 \end_layout
 
 \end_inset
 
-.
+
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Quotation
+breve (bre)
+\begin_inset space \hfill{}
+\end_inset
+
+\begin_inset ERT
+status open
 
 \begin_layout Plain Layout
-resultdir
+
+
+\backslash
+u 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
+caron (car)
+\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_layout
+
+\begin_layout Quotation
+hungarian umlaut (hug)
+\begin_inset space \hfill{}
 \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
+umlaut (uml)
+\begin_inset space \hfill{}
+\end_inset
 
-\begin_layout Plain Layout
-resultfile
+äöü
 \end_layout
 
+\begin_layout Quotation
+dot (dot)
+\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
+.s
 \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.
+Since in many international keyboards there are exceptions to what some
+ dead keys should do, you can define them using
 \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
+\begin_layout Quotation
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdflatex
+
+\backslash
+kxmod
 \end_layout
 
 \end_inset
 
-; via (DVI and) PostScript®, using 
-\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
-ps2pdf
+
+\backslash
+kxmod
 \end_layout
 
 \end_inset
 
-; or via DVI, using 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+ caron o "
+\backslash
+^o"
+\end_layout
 
-\begin_layout Plain Layout
-dvipdfm
+\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
 
-\end_inset
+\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
 
-.
- 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"
+\begin_layout Plain Layout
+#
+\end_layout
 
 \end_inset
 
-.
- For example, in the standard configuration, the formats named 
-\begin_inset Flex CharStyle:MenuItem
+ have different meaning.
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdf
+#
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
+ 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
-pdf2
+
+\backslash
+"
 \end_layout
 
 \end_inset
 
-, and 
-\begin_inset Flex CharStyle:MenuItem
+, to enter 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-pdf3
+#
 \end_layout
 
 \end_inset
 
- are defined, all of which share the extension 
-\begin_inset Flex CharStyle:MenuItem
+, use 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.pdf
+
+\backslash
+#
 \end_layout
 
 \end_inset
 
-, and which correspond to the conversion methods just mentioned.
+.
 \end_layout
 
-\begin_layout Section
-Output 
+\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
-The settings in this section affect the output LyX produces.
+More keywords will be supported in keymap configuration file in future,
+ like
 \end_layout
 
-\begin_layout Subsection
-Plain text export options
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\backslash
+kinclude filename
 \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
+
+\emph on
+
+\begin_inset space \hfill{}
 \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
+
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Output\SpecialChar \menuseparator
-Plain Text
+include
 \end_layout
 
 \end_inset
 
- dialog if you disagree with its interpretation.
+ another file
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-roff command
+
+\backslash
+kprog program
 \end_layout
 
 \end_inset
 
- This option defines the command used to produce better plain text tables
- with the 
+
+\emph on
+
+\begin_inset space \hfill{}
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-groff/troff/nroff
+define
 \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.
+ an external keymap translation program 
 \end_layout
 
-\begin_layout Description
+\begin_layout Standard
+Also, it should look into 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Output line length
+lyxrc
 \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
+ file for defaults, too (for example, a 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Section
-The rest
+\begin_layout Plain Layout
+
+\backslash
+kinclude
 \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"
-
 \end_inset
 
if you need some more information.
option to include default keyboard).
 \end_layout
 
-\begin_layout Chapter
-Internationalizing LyX
-\begin_inset CommandInset label
-LatexCommand label
-name "chap:i18n"
-
 \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 Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-locale(5)
-\end_layout
+\begin_layout Section
+International Keymap Stuff
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:International-Keymap-Stuff"
 
 \end_inset
 
- could be a good place to start).
+
 \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
-status collapsed
+\begin_inset Note Note
+status open
 
 \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!
+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
 
- will of course try to fix these shortcomings in future versions of LyX.
-\end_layout
-
-\begin_layout Section
-Translating LyX
-\end_layout
 
-\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
-\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 
+The next two sections describe the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-po
-\end_layout
-
-\end_inset
-
--file for that language.
- When this is available, you'll have to generate a 
-\begin_inset Flex CharStyle:Code
-status open
 
-\begin_layout Plain Layout
-mo
+\shape up
+.kmap
 \end_layout
 
 \end_inset
 
--file from it and install the 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-mo
-\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
+\shape up
+.cdef
 \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):
+ 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 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
-
-.)
+\begin_layout Subsection
+The .kmap File
 \end_layout
 
-\begin_layout Itemize
-Copy the file 
+\begin_layout Standard
+A 
+\shape up
+.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyx.pot
+kmap
 \end_layout
 
 \end_inset
 
- to the folder of the 
+ 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.
- Then rename it to 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-xx.po
-\end_layout
 
-\end_inset
+\shape default
+ file keywords 
+\shape up
 
-.
- (If 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyx.pot
-\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
+\shape up
+kmap
 \end_layout
 
 \end_inset
 
- in that directory, or you can use an existing po-file for some other language
- as a template).
-\end_layout
 
-\begin_layout Itemize
-Edit 
+\shape default
+,
+\shape up
+\shape default
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xx.po
+
+\shape up
+kmod
 \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).
+,
+\shape up
  
-\family typewriter
-Emacs
-\family default
- contains a `mode' for editing 
+\shape default
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-po
-\end_layout
 
-\end_inset
-
- files, as well.
+\shape up
+ksmod
 \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
+, and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-po
+
+\shape up
+kcomb
 \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:
+ are described in this section.
 \end_layout
 
-\begin_layout Itemize
-Generate 
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
 \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
+kmap
 \end_layout
 
 \end_inset
 
-.
+ Map a character to a string
 \end_layout
 
-\begin_layout Itemize
-Copy the 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
 
-\begin_layout Plain Layout
-mo
+\backslash
+kmap 
+\family roman
+\emph on
+char
+\family default
+\emph default
+\family roman
+\emph on
+string
+\end_layout
+
+\begin_layout Standard
+This will ma
+\family roman
+p
+\family default
+\family roman
+\emph on
+char
+\family default
+\emph default
+\family roman
+to
+\family default
+\family roman
+\emph on
+string
+\emph default
+.
+ Note that in
+\family default
+\family roman
+\emph on
+string
+\emph default
+,
+\family default
+\family roman
+\shape up
+the double-quote (")
+\family default
+\shape default
+\family roman
+and
+\family default
+\family roman
+\shape up
+the backslash (
+\backslash
+)
+\family default
+\shape default
+\family roman
+must be escaped with a preceding backslash (
+\shape up
+
+\backslash
+
+\shape default
+)
+\family default
+.
+\end_layout
+
+\begin_layout Standard
+An example of a 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+kmap
+\end_layout
+
+\end_inset
+
+ statement to cause the symbol 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+/
+\end_layout
+
+\end_inset
+
+ to be output for the keystroke 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+&
+\end_layout
+
+\end_inset
+
+ is:
+\end_layout
+
+\begin_layout LyX-Code
+
+\backslash
+kmap & /
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+kmod
+\end_layout
+
+\end_inset
+
+ Specify an accent character
+\end_layout
+
+\begin_layout LyX-Code
+
+\backslash
+kmod 
+\family roman
+\emph on
+char accent allowed
+\end_layout
+
+\begin_layout Standard
+This will make the cha
+\family roman
+racter
+\family default
+\family roman
+\emph on
+char
+\family default
+\emph default
+\family roman
+\shape up
+\emph on
+be an accent
+\family default
+\shape default
+\emph default
+\family roman
+\shape up
+on the
+\family default
+\shape default
+\family roman
+\shape up
+\emph on
+allowed
+\family default
+\shape default
+\emph default
+\family roman
+\shape up
+cha
+\family default
+racter(s).
+ This is the dead key
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+The term 
+\family roman
+\emph on
+dead key
+\family default
+\emph default
+ refers to a key that does not produce a character by itself, but when followed
+ with another key, produces the desired accent character.
+ For example, a German characte
+\family roman
+r with an umlaut like
+\family default
+\family roman
+\emph on
+\family default
+\emph default
+\family roman
+can be produced in this manner.
+\end_layout
+
+\end_inset
+
+ mechanism.
+\end_layout
+
+\begin_layout Standard
+If you 
+\family roman
+hit
+\family default
+\family roman
+\emph on
+char
+\family default
+\emph default
+\family roman
+and then another key not in
+\family default
+\family roman
+\emph on
+allowed
+\emph default
+, you will get a
+\family default
+\family roman
+\emph on
+char
+\family default
+\emph default
+\family roman
+followed by the other, not allowed key, as output.
+
+\family default
+ Note that a 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+Backspace
+\end_layout
+
+\end_inset
+
+ cancels a dead key, so if 
+\family roman
+you hit
+\family default
+\family roman
+\emph on
+char
+\family default
+\emph default
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+\emph on
+Backspace
+\end_layout
+
+\end_inset
+
+, the cursor will not go one position backwards but will instead cancel
+ the effect t
+\family roman
+hat
+\family default
+\family roman
+\shape up
+\emph on
+char
+\family default
+\shape default
+\emph default
+\family roman
+\shape up
+might have had on the next keystroke.
+\end_layout
+
+\begin_layout Standard
+The following example specifies that the character ' is to be an acute accent,
+ allowed on the characters a, e, i, o, u, A, E, I, O, and U:
+\end_layout
+
+\begin_layout LyX-Code
+
+\backslash
+kmod ' acute aeiouAEIOU
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+ksmod
+\end_layout
+
+\end_inset
+
+ Specify an exception to the accent character
+\end_layout
+
+\begin_layout LyX-Code
+
+\backslash
+kxmod  
+\family roman
+\emph on
+accent char result
+\end_layout
+
+\begin_layout Standard
+This defines an exce
+\family roman
+ption for
+\family default
+\family roman
+\emph on
+accent
+\family default
+\emph default
+\family roman
+on
+\family default
+\family roman
+\emph on
+char
+\emph default
+.
+ T
+\shape up
+he
+\family default
+\shape default
+\family roman
+\shape up
+\emph on
+accent
+\family default
+\shape default
+\emph default
+\family roman
+\shape up
+must
+\family default
+\shape default
+\shape up
+have been assigned a keystroke with a previous
+\shape default
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+
+\backslash
+kmo
+\shape default
+d
+\end_layout
+
+\end_inset
+
+ declar
+\family roman
+ation and
+\family default
+\family roman
+\emph on
+char
+\family default
+\emph default
+\family roman
+must not belong in the
+\family default
+\family roman
+\emph on
+allowed
+\family default
+\emph default
+\family roman
+set of
+\family default
+\family roman
+\emph on
+accent
+\emph default
+.
+ When
+\family default
+\family roman
+\shape up
+you enter the
+\family default
+\shape default
+\family roman
+\shape up
+\emph on
+accent char
+\family default
+\shape default
+\emph default
+\family roman
+\shape up
+sequence,
+\family default
+\shape default
+\family roman
+\shape up
+\emph on
+result
+\emph default
+ is produced.
+ If such a declaration does not exist in
+\family default
+\shape default
+\shape up
+the
+\shape default
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+.kmap
+\end_layout
+
+\end_inset
+
+ file and yo
+\family roman
+u enter
+\family default
+\family roman
+\emph on
+accent char
+\emph default
+, you get
+\family default
+\family roman
+\emph on
+accent_key char
+\emph default
+ where
+\family default
+\family roman
+\emph on
+accent_key
+\emph default
+ is the first arg
+\family default
+ument of the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+
+\backslash
+kmod
+\end_layout
+
+\end_inset
+
+ declaration.
+\end_layout
+
+\begin_layout Standard
+The following command produces causes äi to be produced when you enter acute-i
+ ('i):
+\end_layout
+
+\begin_layout LyX-Code
+
+\backslash
+kxmod acute i "
+\backslash
+
+\backslash
+'{
+\backslash
+
+\backslash
+i}"
+\end_layout
+
+\begin_layout Labeling
+\labelwidthstring 00.00.0000
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+kcomb
+\end_layout
+
+\end_inset
+
+ Combine two accent characters
+\end_layout
+
+\begin_layout LyX-Code
+
+\backslash
+kcomb 
+\family roman
+\emph on
+accent1 accent2 allowed
+\end_layout
+
+\begin_layout Standard
+This one is getting pretty esoteric.
+ It allows you to combine the effect 
+\family roman
+of
+\family default
+\family roman
+\emph on
+accent1
+\family default
+\emph default
+\family roman
+and
+\family default
+\family roman
+\emph on
+accent2
+\family default
+\emph default
+\family roman
+(in that order!) on
+\family default
+\family roman
+\emph on
+allowed
+\family default
+\emph default
+\family roman
+chars.
+ The keystrokes for
+\family default
+\family roman
+\emph on
+accent1
+\family default
+\emph default
+\family roman
+and
+\family default
+\family roman
+\emph on
+accent2
+\family default
+\emph default
+\family roman
+must have be
+\family default
+en set with a 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+
+\backslash
+kmod
+\end_layout
+
+\end_inset
+
+ command at 
+\family roman
+a
+\family default
+\family roman
+\emph on
+previous
+\family default
+\emph default
+\family roman
+point in the
+\family default
+ file.
+\end_layout
+
+\begin_layout Standard
+Consider this example from the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+greek.kmap
+\end_layout
+
+\end_inset
+
+ file:
+\end_layout
+
+\begin_layout LyX-Code
+
+\backslash
+kmod ; acute aeioyvhAEIOYVH 
+\backslash
+kmod : umlaut iyIY 
+\backslash
+kcomb acute umlaut iyIY
+\end_layout
+
+\begin_layout Standard
+This allows you to press 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+;:i
+\end_layout
+
+\end_inset
+
+ and get the effect of 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+
+\backslash
+'{
+\backslash
+"{i}}
+\end_layout
+
+\end_inset
+
+.
+\family roman
+\shape up
+A backspace
+\family default
+\shape default
+ in this case cancels the last dead key, so if you press 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+;: Backspace i
+\end_layout
+
+\end_inset
+
+ you get 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+
+\backslash
+'{i}
+\end_layout
+
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Subsection
+The .cdef File
+\end_layout
+
+\begin_layout Standard
+After the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+.kmap
+\end_layout
+
+\end_inset
+
+ mapping is performed, a 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+.cde
+\shape default
+f
+\end_layout
+
+\end_inset
+
+ file maps the strings that the symbols generate to characters in the current
+ font.
+ The LyX distribution currently includes at least the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+iso8859-1.cdef
+\end_layout
+
+\end_inset
+
+ and 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+iso8859-2.cdef
+\end_layout
+
+\end_inset
+
+ files.
+\end_layout
+
+\begin_layout Standard
+In general the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+.cdef
+\end_layout
+
+\end_inset
+
+ file is a sequence of declarations of the form
+\end_layout
+
+\begin_layout LyX-Code
+
+\family roman
+\emph on
+char_index_in_set
+\family default
+\emph default
+\family roman
+\emph on
+ string
+\end_layout
+
+\begin_layout Standard
+For example, in order to map 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+
+\shape up
+
+\backslash
+'{e}
+\end_layout
+
+\end_inset
+
+ to the corresponding character in the iso-8859-1 set (233), the following
+ declaration is used
+\end_layout
+
+\begin_layout LyX-Code
+233 "
+\backslash
+
+\backslash
+'{e}"
+\end_layout
+
+\begin_layout Standard
+with 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\backslash
+
+\end_layout
+
+\end_inset
+
+ and 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+"
+\end_layout
+
+\end_inset
+
+ being escap
+\family roman
+ed in
+\family default
+\family roman
+\emph on
+string
+\emph default
+.
+ Note that
+\family default
+ the same character can apply to more than one string.
+ In the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+i
+\shape up
+so-8859-7.cdef
+\end_layout
+
+\end_inset
+
+ file you have
+\end_layout
+
+\begin_layout LyX-Code
+192 "
+\backslash
+
+\backslash
+'{
+\backslash
+
+\backslash
+
+\backslash
+"{i}}"
+\begin_inset Newline newline
+\end_inset
+
+192 "
+\backslash
+
+\backslash
+
+\backslash
+"{
+\backslash
+
+\backslash
+'{i}}"
+\end_layout
+
+\begin_layout Standard
+If LyX cannot find a mapping for the string produced by the keystroke or
+ a deadkey sequence, it will check if it looks like an accented char and
+ try to draw an accent over the character on screen.
+\end_layout
+
+\begin_layout Subsection
+Dead Keys
+\end_layout
+
+\begin_layout Standard
+There is a second way to add support for international characters through
+ so-called dead-keys.
+ A dead-key works in combination with a letter to produce an accented character.
+ Here, we'll explain how to create a really simple dead-key to illustrate
+ how they work.
+\end_layout
+
+\begin_layout Standard
+Suppose you happen to need the circumflex character, 
+\begin_inset Quotes eld
+\end_inset
+
+ ̂
+\begin_inset Quotes erd
+\end_inset
+
+.
+ You could bind the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+^
+\end_layout
+
+\end_inset
+
+-key [a.k.a.
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Shift-6
+\end_layout
+
+\end_inset
+
+] to the LyX command 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+accent-circumflex
+\end_layout
+
+\end_inset
+
+ in your 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+lyxrc
+\end_layout
+
+\end_inset
+
+ file.
+ Now, whenever you type the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+^
+\end_layout
+
+\end_inset
+
+-key followed by a letter, that letter will have a circumflex accent on
+ it.
+ For example, the sequence 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+^e
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+ produces the letter: 
+\begin_inset Quotes eld
+\end_inset
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ If you tried to type 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+^t
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+, however, LyX will complain with a beep, since a 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+t
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+ never takes a circumflex accent.
+ Hitting 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Space
+\end_layout
+
+\end_inset
+
+ after a dead-key produces the bare-accent.
+ Please note this last point! If you bind a key to a dead-key, you'll need
+ to rebind the character on that key to yet another key.
+ Binding the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+,-key
+\end_layout
+
+\end_inset
+
+ to a cedilla is a bad idea, since you'll only get cedillas instead of commas.
+\end_layout
+
+\begin_layout Standard
+One common way to bind dead-keys is to use 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Meta-
+\end_layout
+
+\end_inset
+
+, 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Ctrl-
+\end_layout
+
+\end_inset
+
+, and 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Shift-
+\end_layout
+
+\end_inset
+
+ in combination with an accent, like 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+~
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+ or 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+,
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+ or 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+^
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ Another way involves using 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+xmodmap
+\end_layout
+
+\end_inset
+
+ and 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+xkeycaps
+\end_layout
+
+\end_inset
+
+ to set up the special 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Mode_Switch
+\end_layout
+
+\end_inset
+
+ key.
+ The 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Mode_Switch
+\end_layout
+
+\end_inset
+
+ acts in some ways just like 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Shift
+\end_layout
+
+\end_inset
+
+ and permits you to bind keys to accented characters.
+ You can also turn keys into dead-keys by binding them to something like
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+usldead_cedilla
+\end_layout
+
+\end_inset
+
+ and then binding this symbolic key to the corresponding LyX command.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+Note from 
+\noun on
+John Weiss
+\noun default
+: This is exactly what I do in my 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+~/.lyx/lyxrc
+\end_layout
+
+\end_inset
+
+ and my 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+~/.xmodmap
+\end_layout
+
+\end_inset
+
+ files.
+ I have my 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Scroll
+\begin_inset space ~
+\end_inset
+
+Lock
+\end_layout
+
+\end_inset
+
+ key set up as 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Mode_Shift
+\end_layout
+
+\end_inset
+
+ and a bunch of these 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+usldead_*
+\end_layout
+
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+ symbolic keys bound such things as 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Scroll
+\begin_inset space ~
+\end_inset
+
+Lock-^
+\end_layout
+
+\end_inset
+
+ and 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Scroll
+\begin_inset space ~
+\end_inset
+
+Lock-~
+\end_layout
+
+\end_inset
+
+.
+ This is how I produce my accented characters.
+\end_layout
+
+\end_inset
+
+ You can make just about anything into the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Mode_Switch
+\end_layout
+
+\end_inset
+
+ key: One of the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Ctrl-
+\end_layout
+
+\end_inset
+
+ keys, a spare function key, etc.
+ As for the LyX commands that produce accents, check the entry for 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+accent-acute
+\end_layout
+
+\end_inset
+
+ in the 
+\emph on
+Reference Manual
+\emph default
+.
+ You'll find the complete list there.
+\end_layout
+
+\begin_layout Subsection
+Saving your Language Configuration
+\end_layout
+
+\begin_layout Standard
+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
+Edit\SpecialChar \menuseparator
+Preferences
+\end_layout
+
+\end_inset
+
+ dialog.
+\end_layout
+
+\begin_layout Chapter
+Installing New Document Classes, Layouts, and Templates
+\begin_inset CommandInset label
+LatexCommand label
+name "cha:Installing-New-Document"
+
+\end_inset
+
+
+\begin_inset OptArg
+status collapsed
+
+\begin_layout Plain Layout
+Installing New Document Classes
+\end_layout
+
+\end_inset
+
+
+\end_layout
+
+\begin_layout Standard
+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.
+\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.
+ Similarly, LyX itself does not know much about DocBook or XHTML.
+\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, DocBook, or
+ XHTML 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
+
+ and in various other files it includes.
+ 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 is 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, DocBook, and XHTML
+ commands and tags.
+ 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 the only thing layout files
+ do, though.
+ 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, to use information about how it should display a
+ paragraph on the screen to output information (in the form of CSS) about
+ how the paragraph 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.
+ See 
+\begin_inset CommandInset ref
+LatexCommand prettyref
+reference "sec:Tags-for-XHTML"
+
+\end_inset
+
+ for the details.
+\end_layout
+
+\begin_layout Section
+Installing new LaTeX files
+\end_layout
+
+\begin_layout Standard
+Some installations may not include a LaTeX package or class file that you
+ would like to use within LyX.
+ 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 your LaTeX distribution doesn't provide such a `package manager', or
+ if the file is not available from your distribution, then you can follow
+ these steps to install it manually.
+\end_layout
+
+\begin_layout Enumerate
+Get the package from 
+\begin_inset CommandInset href
+LatexCommand href
+name "CTAN"
+target "http://www.ctan.org/"
+
+\end_inset
+
+ or wherever.
+\end_layout
+
+\begin_layout Enumerate
+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 trees should be created, if they do not already exist, depends
+ upon the details of your system.
+ To find out where they are, look in the file 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+texmf.cnf
+\end_layout
+
+\end_inset
+
+.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+This usually lives in the directory 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$TEXMF/web2c
+\end_layout
+
+\end_inset
+
+, though you can run 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+kpsewhich texmf.cnf
+\end_layout
+
+\end_inset
+
+ to locate it.
+\end_layout
+
+\end_inset
+
+ The location of the `local' TeX tree is defined by the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+TEXMFLOCAL
+\end_layout
+
+\end_inset
+
+ variable; this is usually somewhere like 
+\begin_inset Flex URL
+status collapsed
+
+\begin_layout Plain Layout
+
+/usr/local/share/texmf/
+\end_layout
+
+\end_inset
+
+.
+ The location of the `user' TeX tree is defined by 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+TEXMFHOME
+\end_layout
+
+\end_inset
+
+ and is commonly 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$HOME/texmf/
+\end_layout
+
+\end_inset
+
+.
+ (If these variables are not predefined, you can define them.) You'll probably
+ need root permissions to create or modify the `local' tree, but your `user'
+ tree shouldn't have such limitations.
+\end_layout
+
+\begin_layout Enumerate
+Make sure 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+TEXMF
+\end_layout
+
+\end_inset
+
+ includes the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+TEXMFLOCAL
+\end_layout
+
+\end_inset
+
+ and 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+TEXMFHOME
+\end_layout
+
+\end_inset
+
+ variables; e.
+\begin_inset space \thinspace{}
+\end_inset
+
+g.
+\begin_inset Newline newline
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+TEXMF = {$TEXMFHOME,!!$TEXMFLOCAL,!!$TEXMFMAIN}
 \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 
+
+\begin_inset Newline newline
+\end_inset
+
+It probably does.
+\end_layout
+
+\begin_layout Enumerate
+Your local and user trees 
+\emph on
+must
+\emph default
+ have the same sort of directory structure as your main existing 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyx.mo
+texmf
 \end_layout
 
 \end_inset
 
- (e.g.
+ directory, which will be found at 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-/usr/local/share/locale/xx/LC_MESSAGES/lyx.mo
+TEXMFMAIN
 \end_layout
 
 \end_inset
 
+ (commonly, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\series bold
-.
+\begin_layout Plain Layout
+/usr/share/texmf/
 \end_layout
 
-\begin_layout Standard
-As said, however, it would be best if the new 
+\end_inset
+
+.) For example, latex packages should go under 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-po
+$TEXMFLOCAL/tex/latex/
 \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.
+ or 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+$TEXMFHOME/tex/latex/
 \end_layout
 
-\begin_layout Subsubsection
-Ambigous messages
+\end_inset
+
+.
+ If you do not put them here, they probably will not work.
 \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_layout Enumerate
+Once your tree is properly set up, you can install the package into an appropria
+te location.
+ If you are lucky, your package will have been provided as a so-called `TDS'
+ (TeX Directory Structure) zip file.
+ To install it, you want to unzip it from the top of your tree.
+ So, for example, you can copy the file 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-To
+newpkg.zip
 \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 
+ to 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+/home/yourname/texmf/
+\end_layout
+
+\end_inset
+
+ and then, from inside that directory, just run: 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+unzip newpkg.zip
+\end_layout
+
+\end_inset
+
+.
+ This will extract the needed files and copy them where they need to be.
+\begin_inset Newline newline
+\end_inset
+
+If you do not have a TDS file, then you have to do this manually.
+ For example, you might install the FoilTeX files into 
+\begin_inset Flex URL
+status collapsed
+
+\begin_layout Plain Layout
+
+$TEXMFLOCAL/tex/latex/contrib/foiltex
+\end_layout
+
+\end_inset
+
+.
+ Why there? The CTAN download directories are themselves organized much
+ like a TeX tree, and it isn't a bad idea to follow its structure when you
+ install your own files.
+ FoilTeX, as it happens, is found at 
+\begin_inset Flex URL
+status collapsed
+
+\begin_layout Plain Layout
+
+http://ctan.org/texarchive/macros/latex/contrib/foiltex/
+\end_layout
+
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Enumerate
+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
 
-to
+Settings
 \begin_inset Quotes erd
 \end_inset
 
means.
- GNU 
program.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-gettext
+$TEXMFLOCAL/tex/latex/
 \end_layout
 
 \end_inset
 
- does not handle such ambigous translations.
- Therefore you have to add some context information to the message: Instead
- of 
+.
+ Under TeXLive and the like, you should run 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-To
+texhash
 \end_layout
 
 \end_inset
 
- it becomes 
+ from a terminal, with root permissions if necessary.
+\end_layout
+
+\begin_layout Standard
+Your package is now installed and available to LaTeX.
+ You can verify this from a terminal by typing `
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-To[[as in 'From format x to format y']]
+kpsewhich yourfile.ext
+\end_layout
+
+\end_inset
+
+'.
+ To make LyX aware of it, however, you will need to reconfigure (
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Tools\SpecialChar \menuseparator
+Reconfigure
+\end_layout
+
+\end_inset
+
+) and then restart LyX.
+ If the new package was a document class, such as FoilTeX again, you will
+ now see it 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
+
+, in this case as 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+slides (FoilTeX)
+\end_layout
+
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Standard
+What if there isn't a layout file is available for your new document class?
+ Then, unfortunately, LyX will know nothing about it until you create a
+ layout file yourself (or get someone else to do it).
+ That is the topic of the next section.
+\end_layout
+
+\begin_layout Section
+Types of layout files
+\end_layout
+
+\begin_layout Standard
+This section describes the various sorts of LyX files that contain layout
+ information.
+ These files describe various paragraph and character styles, determining
+ how LyX should display them and how they should be translated into LaTeX,
+ DocBook, XHTML, 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 even
+ by just LaTeX 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 layouts distributed with LyX.
+ If you write a LyX layout for a LaTeX document class that might also be
+ used by others, or write a module that might be useful to others, then
+ you should consider posting your layout to the 
+\begin_inset CommandInset href
+LatexCommand href
+name "layout section on the LyX wiki"
+target "http://wiki.lyx.org/Layouts/Layouts"
+
+\end_inset
+
+ 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 Subsection
+Layout modules
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Layout-modules"
+
+\end_inset
+
+
+\end_layout
+
+\begin_layout Standard
+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 information 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 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+endnotes
+\end_layout
+
+\end_inset
+
+ module—specifcally provide support for one 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
 
- and 
+ files—files like 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-To[[as in 'From page x to page y']].
+stdsections.inc
 \end_layout
 
 \end_inset
 
- Now the two occurences of 
+—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
-To
+article.cls
 \end_layout
 
 \end_inset
 
- are different for 
-\begin_inset Flex CharStyle:Code
+ requires editing that file.
+ Modules, by contrast, are selected in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-gettext
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
 
- and can be translated correctly to 
-\lang german
-Nach
-\lang english
- and 
-\lang german
-Bis
-\lang english
-, respectively.
+ dialog.
 \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.
+Building modules is the easiest way to get started with layout editing,
+ 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
 
 \begin_layout Standard
-The online documentation (in the 
-\begin_inset Flex CharStyle:MenuItem
+After creating a new module and copying it to the 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-H
-\bar default
-elp
+layout/
 \end_layout
 
 \end_inset
 
--menu) can (and should!) be translated.
- If there are translated versions of the documentation available
-\begin_inset Foot
+ folder, you will need to reconfigure and then restart LyX for the module
+ to appear in the menu.
+ However, changes you make to the module will be seen immediately, if you
+ open 
+\begin_inset Flex CharStyle:MenuItem
 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.
+Document\SpecialChar \menuseparator
+Settings
 \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
+, highlight something, and then hit 
+\begin_inset Quotes eld
+\end_inset
+
+OK
+\begin_inset Quotes erd
+\end_inset
+
+.
+\emph on
+It is strongly recommended that you save your work before doing this
+\emph default
+.
+ In fact, 
+\emph on
+it is strongly recommended that you not attempt to edit modules while simultaneo
+usly working on actual documents
+\emph default
+.
+ Though of course the developers strive to keep LyX stable in such situations,
+ syntax errors and the like in your module file could cause strange behavior.
+\end_layout
+
+\begin_layout Subsection
+Layout for 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/doc/xx_DocName.lyx
+.sty
 \end_layout
 
 \end_inset
 
-, where 
+ files
+\end_layout
+
+\begin_layout Standard
+There are two situations you are likely to encounter when wanting to support
+ a new LaTeX document class, involving LaTeX2e class (
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xx
+.cls
 \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 (
+) and style (
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-DocName
+.sty
 \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:
+) files.
+ Supporting a style file is usually fairly easy.
+ Supporting a new class file is a bit harder.
+ We'll discuss the former in this section and the latter in the next.
+ Similar remarks apply, of course, if you want to support a new DocBook
+ DTD.
 \end_layout
 
-\begin_layout Itemize
-Read 
-\begin_inset Flex CharStyle:Code
+\begin_layout Standard
+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.
+ For the sake of the example, we'll assume that the style file is called
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-DocStyle.lyx
+myclass.sty
 \end_layout
 
 \end_inset
 
-, the guide to writing LyX documentation.
- Pay special attention to the translator's section.
-\end_layout
+ and that it is meant to be used with 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\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"
+\begin_layout Plain Layout
+report.cls
+\end_layout
 
 \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.
+, which is a standard class.
 \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
+Start by copying the existing class's layout file into your local directory:
+\begin_inset Foot
+status collapsed
 
-\begin_layout Itemize
-Join the documentation team! There is information on how to do that in 
+\begin_layout Plain Layout
+Of course, which directory is your local directory will vary by platform,
+ and LyX allows you to specify your local directory on startup, too, using
+ the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Intro.lyx
+-userdir
 \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
+ option.
 \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!)
+\begin_layout LyX-Code
+cp report.layout ~/.lyx/layouts/myclass.layout
 \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_layout Standard
+Then edit 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/doc/
+myclass.layout
 \end_layout
 
 \end_inset
 
- directory.
+ and change the line: 
 \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
+\begin_layout LyX-Code
 
- to see what has been changed.
- That way you can easily see which parts of the translated document need
- to be updated.
+\backslash
+DeclareLaTeXClass{report}
 \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?)
+to read
 \end_layout
 
-\begin_layout Standard
-\begin_inset Branch OutDated
-status collapsed
+\begin_layout LyX-Code
 
-\begin_layout Section
-International Keyboard Support
+\backslash
+DeclareLaTeXClass[report, myclass.sty]{report (myclass)}
 \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)]
+Then add:
 \end_layout
 
-\begin_layout Subsection
-Defining Own Keymaps: Keymap File Format
+\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
-Let's look at a keyboard definition file a little closer.
- It is a plain text file defining
+near the top of the file.
 \end_layout
 
-\begin_layout Itemize
-key-to-key or key-to-string translations
+\begin_layout Standard
+Start LyX and select 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Tools\SpecialChar \menuseparator
+Reconfigure
 \end_layout
 
-\begin_layout Itemize
-dead keys
+\end_inset
+
+.
+ Then restart LyX and try creating a new document.
+ You should see "
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+report (myclass)
 \end_layout
 
-\begin_layout Itemize
-dead keys exceptions
+\end_inset
+
+" as a document class option in the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
-\begin_layout Standard
-To define key-to-key or key-to-string translation, use this command:
-\end_layout
+\end_inset
 
-\begin_layout Quotation
+ 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—
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-kmap
+report
 \end_layout
 
 \end_inset
 
+ in this example—so you can fiddle around with the settings for the different
+ sections if you wish.
+ The layout information for sections is contained in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-key
+stdsections.inc
 \end_layout
 
 \end_inset
 
- outstring 
-\end_layout
-
-\begin_layout Standard
-where 
+, but you do not need to copy and change this file.
+ Instead, you can simply add your changes to your layout file, after the
+ line 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-key
+Input stdclass.inc
 \end_layout
 
 \end_inset
 
- is the key to be translated and 
+, which itself includes 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-outstring
+stdsections.inc
 \end_layout
 
 \end_inset
 
- is the string to be inserted into the document.
To define dead keys, use:
+.
For example, you might add these lines:
 \end_layout
 
-\begin_layout Quotation
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+Style Chapter
+\end_layout
 
-\begin_layout Plain Layout
+\begin_layout LyX-Code
+    Font
+\end_layout
 
-\backslash
-kmod
+\begin_layout LyX-Code
+        Family Sans
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+    EndFont
+\end_layout
 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+End
+\end_layout
 
-\begin_layout Plain Layout
-key
+\begin_layout Standard
+to change the font for chapter headings to sans-serif.
+ This will override (or, in this case, add to) the existing declaration
+ for the Chapter style.
 \end_layout
 
+\begin_layout Standard
+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
 
- deadkey
+ for information on how to do so.
 \end_layout
 
 \begin_layout Standard
-where 
-\begin_inset Flex CharStyle:Code
+If 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-key
+myclass.sty
 \end_layout
 
 \end_inset
 
- is a keyboard key and 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-deadkey
+ can be used with several different document classes, and even if it cannot,
+ you might find it easiest just to write a module that you can load with
+ the base class.
+ The simplest possible such module would be:
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+#
+\backslash
+DeclareLyXModule{My Package} 
+\end_layout
 
- is dead key name.
- The following dead keys are supported (shortcut name is in parentheses):
+\begin_layout LyX-Code
+#DescriptionBegin 
 \end_layout
 
-\begin_layout Quotation
+\begin_layout LyX-Code
+#Support for mypkg.sty.
+\end_layout
 
-\emph on
-Name
-\begin_inset space \hfill{}
+\begin_layout LyX-Code
+#DescriptionEnd 
+\begin_inset Newline newline
 \end_inset
 
-Example
+
 \end_layout
 
-\begin_layout Quotation
-acute (acu)
-\begin_inset space \hfill{}
+\begin_layout LyX-Code
+Format 20
+\begin_inset Newline newline
 \end_inset
 
-áéíóú
+
 \end_layout
 
-\begin_layout Quotation
-grave (gra)
-\begin_inset space \hfill{}
+\begin_layout LyX-Code
+Preamble
+\begin_inset Newline newline
 \end_inset
 
-àèìòù
+    
+\backslash
+usepackage{mypkg}
+\begin_inset Newline newline
+\end_inset
+
+EndPreamble
 \end_layout
 
-\begin_layout Quotation
-macron (mac)
-\begin_inset space \hfill{}
+\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 Quotation
-tilde (til)
-\begin_inset space \hfill{}
-\end_inset
+\begin_layout Subsection
+Layout for 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-ñÑ
+\begin_layout Plain Layout
+.cls
 \end_layout
 
-\begin_layout Quotation
-underbar (underb)
-\begin_inset space \hfill{}
 \end_inset
 
+ files
+\end_layout
 
-\begin_inset ERT
-status open
+\begin_layout Standard
+There are two possibilities here.
+ One is that the class file is itself based upon an existing document class.
+ For example, many thesis classes are based upon 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
 \begin_layout Plain Layout
+book.cls
+\end_layout
+
+\end_inset
+
+.
+ To see whether yours is, look for a line like
+\end_layout
 
+\begin_layout LyX-Code
 
 \backslash
-b o
+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
 
-\begin_layout Quotation
-cedilla (ced)
-\begin_inset space \hfill{}
 \end_inset
 
-çÇ
+ and it is based upon 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+book
 \end_layout
 
-\begin_layout Quotation
-underdot (underd)
-\begin_inset space \hfill{}
 \end_inset
 
+, then the line should read:
+\begin_inset Foot
+status collapsed
 
-\begin_inset ERT
-status open
+\begin_layout Plain Layout
+And it will be easiest if you save the file to 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
 \begin_layout Plain Layout
+thesis.layout
+\end_layout
 
+\end_inset
 
-\backslash
-d o
+: LyX assumes that the document class has the same name as the layout file.
 \end_layout
 
 \end_inset
@@ -4680,213 +6544,329 @@ d o
 
 \end_layout
 
-\begin_layout Quotation
-circumflex (circu)
-\begin_inset space \hfill{}
-\end_inset
+\begin_layout LyX-Code
 
-âêîôû
+\backslash
+DeclareLaTeXClass[thesis,book]{thesis}
 \end_layout
 
-\begin_layout Quotation
-circle (circl)
-\begin_inset space \hfill{}
+\begin_layout Standard
+If, on the other hand, the new class is not based upon an existing class,
+ you will probably have to 
+\begin_inset Quotes eld
 \end_inset
 
-ÅůŮ
+roll your own
+\begin_inset Quotes erd
+\end_inset
+
+ layout.
+ We strongly suggest copying an existing layout file which uses a similar
+ LaTeX class and then modifying it, if you can do so.
+ At least use an existing file as a starting point so you can find out what
+ items you need to worry about.
+ Again, the specifics are covered below.
 \end_layout
 
-\begin_layout Quotation
-tie (tie)
-\begin_inset space \hfill{}
+\begin_layout Subsection
+Creating templates
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Creating-Templates"
+
 \end_inset
 
 
-\begin_inset ERT
-status open
+\end_layout
+
+\begin_layout Standard
+Once you have written a layout file for a new document class, you might
+ want to consider writing a 
+\emph on
+template
+\emph default
+ for it, too.
+ A template acts as a kind of tutorial for your layout, showing how it might
+ be used, though containing dummy content.
+ You can of course look at the various templates included with LyX for ideas.
+\end_layout
+
+\begin_layout Standard
+Templates are created just like usual documents: using LyX.
+ 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 preferred settings
+ for such parameters.
+ For that reason, the designer of a template should remove the corresponding
+ commands like 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
 \begin_layout Plain Layout
 
+\backslash
+font_roman
+\end_layout
+
+\end_inset
+
+ or 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
 
 \backslash
-t o
+papersize
 \end_layout
 
 \end_inset
 
+ 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 Plain Layout
+vi
 \end_layout
 
-\begin_layout Quotation
-breve (bre)
-\begin_inset space \hfill{}
 \end_inset
 
-\begin_inset ERT
-status open
+ or 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
 \begin_layout Plain Layout
+notepad
+\end_layout
 
+\end_inset
 
-\backslash
-u o
+.
+\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/
 \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/
 \end_layout
 
-\begin_layout Quotation
-caron (car)
-\begin_inset space \hfill{}
 \end_inset
 
-čšž
+ to the same place, and redefine the template path in the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Tools\SpecialChar \menuseparator
+Preferences\SpecialChar \menuseparator
+Paths
 \end_layout
 
-\begin_layout Quotation
-hungarian umlaut (hug)
-\begin_inset space \hfill{}
 \end_inset
 
-őű
+ dialog.
 \end_layout
 
-\begin_layout Quotation
-umlaut (uml)
-\begin_inset space \hfill{}
-\end_inset
+\begin_layout Standard
+Note, by the way, that there is a template which has a particular meaning:
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-äöü
+\begin_layout Plain Layout
+defaults.lyx
 \end_layout
 
-\begin_layout Quotation
-dot (dot)
-\begin_inset space \hfill{}
 \end_inset
 
-\begin_inset ERT
-status open
+.
+ This template is loaded every time you create a new document with 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
 \begin_layout Plain Layout
+File\SpecialChar \menuseparator
+New
+\end_layout
 
+\end_inset
 
-\backslash
-.s
+ 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
+Save as Document Defaults
 \end_layout
 
 \end_inset
 
-
+ button.
 \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
+\begin_layout Subsection
+Upgrading old layout files
 \end_layout
 
-\begin_layout Quotation
+\begin_layout Standard
+The format of layout files changes with each LyX release, so old layout
+ files need to be converted to the new format.
+ This process has been automated since LyX 1.4: If LyX reads a layout file
+ in an older format, it automatically calls the script 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-kxmod
+layout2layout.py
 \end_layout
 
 \end_inset
 
- deadkey key outstring
+ to convert it to a temporary file in current format.
+ The original file is left untouched.
+ If you use the layout file often, then, you may want to convert it permanently,
+ so that LyX does not have to do so itself every time.
+ To do this, you can call the converter manually:
 \end_layout
 
-\begin_layout Standard
-For example, on Slovak keyboard, if you enter caron-o, it generates circumflex-o
-, so you put in
+\begin_layout LyX-Code
+mv myclass.layout myclass.old
 \end_layout
 
-\begin_layout Quotation
+\begin_layout LyX-Code
+python LyXDir/scripts/layout2layout.py myclass.old myclass.layout
+\end_layout
+
+\begin_layout Standard
+You need to replace 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+LyXDir
+\end_layout
 
-\backslash
-kxmod
+\end_inset
+
+ with the name of your LyX system directory, of course.
+\end_layout
+
+\begin_layout Standard
+Note that manual conversion does not affect included files, so these will
+ have to be converted separately.
 \end_layout
 
+\begin_layout Section
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:TextClass"
+
 \end_inset
 
- caron o "
-\backslash
-^o"
+The layout file format
 \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.
+When it's finally time to get your hands dirty and create or edit your own
+ layout file, the following sections describe what you're up against.
+ Our advice is to go slowly, save and test often, listen to soothing music,
+ 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 too much in one sitting.
+ Go have another adult beverage, just for good measure.
 \end_layout
 
 \begin_layout Standard
-Oh, and about characters: backslash is escaped, so to enter it, you'll need
- double backslash.
- Also, quotes and 
+Note that all the tags used in layout files are case-insensitive.
+ This means that 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-#
+Style
 \end_layout
 
 \end_inset
 
- have different meaning.
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-#
+style
 \end_layout
 
 \end_inset
 
- marks comments, quotes start and end LaTeX-style commands.
- To enter quote, you'll need to use 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-"
+StYlE
 \end_layout
 
 \end_inset
 
-, to enter 
+ are really the same tag.
+ The possible values are printed in brackets after the feature's name.
+ The default value if a feature isn't specified inside a text class-description
+ is typeset 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-#
+
+\emph on
+emphasized
 \end_layout
 
 \end_inset
 
-, use 
+.
+ If the argument has a data type like 
+\begin_inset Quotes eld
+\end_inset
+
+string
+\begin_inset Quotes erd
+\end_inset
+
+ or 
+\begin_inset Quotes eld
+\end_inset
+
+float
+\begin_inset Quotes erd
+\end_inset
+
+, the default is shown like this: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-#
+float=
+\emph on
+default
 \end_layout
 
 \end_inset
@@ -4894,1347 +6874,1125 @@ status collapsed
 .
 \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.
+\begin_layout Subsection
+The Document Class Declaration
 \end_layout
 
 \begin_layout Standard
-More keywords will be supported in keymap configuration file in future,
- like
+Lines in a layout file which begin with 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+#
 \end_layout
 
-\begin_layout Itemize
+\end_inset
+
+ are comments.
+ There is one exception to this rule.
+ All 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-kinclude filename
+*.layout
 \end_layout
 
 \end_inset
 
+ files should begin with a line like:
+\end_layout
 
-\emph on
+\begin_layout LyX-Code
 
-\begin_inset space \hfill{}
-\end_inset
+\size small
+#% Do not delete the line below; configure depends on this 
+\end_layout
+
+\begin_layout LyX-Code
 
+\size small
+#  
+\backslash
+DeclareLaTeXClass{article}
+\end_layout
 
+\begin_layout Standard
+The second line is used when you (re)configure LyX.
+ The layout file is read by the LaTeX script 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-include
+chkconfig.ltx
 \end_layout
 
 \end_inset
 
- another file
+, in a special mode where 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+#
 \end_layout
 
-\begin_layout Itemize
+\end_inset
+
+ is ignored.
+ The first line is just a LaTeX comment, and the second one contains the
+ declaration of the text class.
+ If these lines appear in a file named 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+article.layout
+\end_layout
 
-\backslash
-kprog program
+\end_inset
+
+, then they define a text class of name 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+article
 \end_layout
 
 \end_inset
 
+ (the name of the layout file) which uses the LaTeX document class 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+article.cls
+\end_layout
 
-\emph on
+\end_inset
 
-\begin_inset space \hfill{}
+ (the default is to use the same name as the layout).
+ The string 
+\begin_inset Quotes eld
 \end_inset
 
+article
+\begin_inset Quotes erd
+\end_inset
 
-\begin_inset Flex CharStyle:Code
+ that appears above is used as a description of the text class in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-define
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
 
- an external keymap translation program 
+ dialog.
 \end_layout
 
 \begin_layout Standard
-Also, it should look into 
+Let's assume that you wrote your own text class that uses the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyxrc
+article.cls
 \end_layout
 
 \end_inset
 
- file for defaults, too (for example, a 
+ document class, but where you changed the appearance of the section headings.
+ If you put it in a file 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-kinclude
+myarticle.layout
 \end_layout
 
 \end_inset
 
- option to include default keyboard).
+, the header of this file should be:
 \end_layout
 
-\end_inset
-
+\begin_layout LyX-Code
 
+\size small
+#% Do not delete the line below; configure depends on this 
 \end_layout
 
-\begin_layout Section
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:keymap"
-
-\end_inset
+\begin_layout LyX-Code
 
-International Keymap Stuff
+\size small
+#  
+\backslash
+DeclareLaTeXClass[article]{article (with my own headings)}
 \end_layout
 
 \begin_layout Standard
-\begin_inset Note Note
-status open
+This declares a text class 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
 \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.
+myarticle
 \end_layout
 
 \end_inset
 
-
-\end_layout
-
-\begin_layout Standard
-The next two sections describe the 
+, associated with the LaTeX document class 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-.kmap
+article.cls
 \end_layout
 
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:Code
-status collapsed
+ and described as 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Plain Layout
+article (with my own headings)
+\begin_inset Quotes erd
+\end_inset
 
-\shape up
-.cdef
+.
+ If your text class depends on several packages, you can declare it as:
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
 
- file syntax in detail.
- These sections should help you design your own key map if the ones provided
- do not meet your needs.
+\size small
+#% Do not delete the line below; configure depends on this 
 \end_layout
 
-\begin_layout Subsection
-The .kmap File
+\begin_layout LyX-Code
+
+\size small
+#  
+\backslash
+DeclareLaTeXClass[article,foo.sty]{article (with my own headings)}
 \end_layout
 
 \begin_layout Standard
-A 
-\shape up
-.
+This indicates that your text class uses the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-kmap
+foo.sty
 \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
+ package.
+ Finally, it is also possible to declare classes for DocBook code.
+ Typical declarations will look like:
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
 
+\size small
+#% Do not delete the line below; configure depends on this 
+\end_layout
 
-\shape default
- file keywords 
-\shape up
+\begin_layout LyX-Code
 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\size small
+# 
+\backslash
+DeclareDocBookClass[article]{SGML (DocBook article)}
+\end_layout
 
-\begin_layout Plain Layout
+\begin_layout Standard
+Note that these declarations can also be given an optional parameter declaring
+ the name of the document class (but not a list).
+\end_layout
 
-\shape up
-kmap
+\begin_layout Standard
+So, to be as explicit as possible, the form of the layout declaration is:
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
 
+\size small
+#  
+\backslash
+DeclareLaTeXClass[class,package.sty]{layout description}
+\end_layout
 
-\shape default
-,
-\shape up
-\shape default
+\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 class file
+ is not specified, then LyX will simply assume that it is the same as the
+ name of the layout file.
+\end_layout
 
+\begin_layout Standard
+When the text class has been modified to your taste, all you have to do
+ is to copy it either to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-kmod
+LyXDir/layouts/
 \end_layout
 
 \end_inset
 
-,
-\shape up
-\shape default
-
+ or to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-ksmod
+UserDir/layouts
 \end_layout
 
 \end_inset
 
-, and 
-\begin_inset Flex CharStyle:Code
+, run 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-kcomb
+Tools\SpecialChar \menuseparator
+Reconfigure
 \end_layout
 
 \end_inset
 
- are described in this section.
+, exit LyX and restart.
+ Then your new text class should be available along with the others.
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
-\begin_inset Flex CharStyle:Code
+\begin_layout Standard
+Once the layout file is installed, you can edit it and see your changes
+ without having to reconfigure or to restart LyX.
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-kmap
+In versions of LyX prior to 1.6, this was not true.
+ As a result, editing layout files was very time consuming, since you had
+ constantly to restart LyX to see changes.
 \end_layout
 
 \end_inset
 
- Map a character to a string
-\end_layout
-
-\begin_layout LyX-Code
-
-\backslash
-kmap 
-\family roman
-\emph on
-char
-\family default
-\emph default
+ You can force a reload of the current layout by using the LyX function
  
-\family roman
-\emph on
-string
-\end_layout
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
 
-\begin_layout Standard
-This will ma
-\family roman
-p
-\family default
-\family roman
-\emph on
-char
-\family default
-\emph default
-\family roman
-to
-\family default
-\family roman
-\emph on
-string
-\emph default
-.
- Note that in
-\family default
-\family roman
-\emph on
-string
-\emph default
-,
-\family default
-\family roman
-\shape up
-the double-quote (")
-\family default
-\shape default
-\family roman
-and
-\family default
-\family roman
-\shape up
-the backslash (
-\backslash
-)
-\family default
-\shape default
-\family roman
-must be escaped with a preceding backslash (
-\shape up
+\begin_layout Plain Layout
+layout-reload
+\end_layout
 
-\backslash
+\end_inset
 
-\shape default
-)
-\family default
 .
+ There is no default binding for this function—though, of course, you can
+ bind it to a key yourself.
+ But you will normally use this function simply by entering it in the mini-buffe
+r.
 \end_layout
 
 \begin_layout Standard
-An example of a 
+
+\emph on
+Warning
+\emph default
+: 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-kmap
+layout-reload
 \end_layout
 
 \end_inset
 
- statement to cause the symbol 
-\begin_inset Flex CharStyle:MenuItem
+ is very much an `advanced feature'.
+ It is 
+\emph on
+strongly
+\emph default
+ recommended that you save your work before using this function.
+ In fact, it is 
+\emph on
+strongly
+\emph default
+ 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.
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
+Really bad syntax errors may even caused LyX to exit.
+ This is because certain sorts of errors may make LyX unable to read 
+\emph on
+any
+\emph default
+ layout information.
+ Please be careful.
+\end_layout
 
-\shape up
-/
+\end_inset
+
+ 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
+While we're giving advice: make regular backups.
+ And be nice to your mother.
 \end_layout
 
 \end_inset
 
- to be output for the keystroke 
+
+\end_layout
+
+\begin_layout Subsection
+The Module Declaration
+\end_layout
+
+\begin_layout Standard
+A module must begin with a line like the following:
+\end_layout
+
+\begin_layout LyX-Code
+#
+\backslash
+DeclareLyXModule[endnotes.sty]{Endnotes} 
+\end_layout
+
+\begin_layout Standard
+The mandatory argument, in curly brackets, is the name of the module, as
+ it should appear in 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-&
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
 
- is:
+.
+ 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
 
-\begin_layout LyX-Code
+\end_inset
 
-\backslash
-kmap & /
+ 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
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\end_inset
+
+ as an optional argument, 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
 
-\shape up
-kmod
+\end_inset
+
+' and `
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+to
 \end_layout
 
 \end_inset
 
- Specify an accent character
+'.
+\end_layout
+
+\begin_layout Standard
+The module declaration should then be followed by lines like the following:
+\end_layout
+
+\begin_layout LyX-Code
+#DescriptionBegin 
 \end_layout
 
 \begin_layout LyX-Code
+#Adds an endnote command, in addition to footnotes.
+\end_layout
 
+\begin_layout LyX-Code
+#You will need to add  
 \backslash
-kmod 
-\family roman
-\emph on
-char accent allowed
+theendnotes in TeX code where you 
 \end_layout
 
-\begin_layout Standard
-This will make the cha
-\family roman
-racter
-\family default
-\family roman
-\emph on
-char
-\family default
-\emph default
-\family roman
-\shape up
-\emph on
-be an accent
-\family default
-\shape default
-\emph default
-\family roman
-\shape up
-on the
-\family default
-\shape default
-\family roman
-\shape up
-\emph on
-allowed
-\family default
-\shape default
-\emph default
+\begin_layout LyX-Code
+#want the endnotes to appear.
  
-\family roman
-\shape up
-cha
-\family default
-racter(s).
- This is the dead key
-\begin_inset Foot
+\end_layout
+
+\begin_layout LyX-Code
+#DescriptionEnd 
+\end_layout
+
+\begin_layout LyX-Code
+#Requires: somemodule | othermodule
+\end_layout
+
+\begin_layout LyX-Code
+#Excludes: badmodule
+\end_layout
+
+\begin_layout Standard
+The description is used in 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-The term 
-\family roman
-\emph on
-dead key
-\family default
-\emph default
- refers to a key that does not produce a character by itself, but when followed
- with another key, produces the desired accent character.
- For example, a German characte
-\family roman
-r with an umlaut like
-\family default
-\family roman
-\emph on
-\family default
-\emph default
-\family roman
-can be produced in this manner.
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
 
- mechanism.
+ to provide the user with information about what the module does.
+ The 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Requires
 \end_layout
 
-\begin_layout Standard
-If you 
-\family roman
-hit
-\family default
-\family roman
-\emph on
-char
-\family default
-\emph default
-\family roman
-and then another key not in
-\family default
-\family roman
+\end_inset
+
+ line is used to identify other modules with which this one must be used;
+ the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Excludes
+\end_layout
+
+\end_inset
+
+ line is used to identify modules with which this one may not be used.
+ Both are optional, and, as shown, multiple modules should be separated
+ with the pipe symbol: |.
+ Note that the required modules are treated disjunctively: 
 \emph on
-allowed
+at least one
 \emph default
-, you will get a
-\family default
-\family roman
+ of the required modules must be used.
+ Similarly, 
 \emph on
-char
-\family default
+no
 \emph default
-\family roman
-followed by the other, unallowed key, as output.
-
-\family default
- Note that a 
-\begin_inset Flex CharStyle:MenuItem
+ excluded module may be used.
+ Note that modules are identified here by their 
+\emph on
+filenames
+\emph default
+ without the 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-Backspace
+.module
 \end_layout
 
 \end_inset
 
- cancels a dead key, so if 
-\family roman
-you hit
-\family default
-\family roman
-\emph on
-char
-\family default
-\emph default
-\begin_inset Flex CharStyle:MenuItem
+ extension.
+ So 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+somemodule
+\end_layout
 
-\shape up
-\emph on
-Backspace
+\end_inset
+
+ is really 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+somemodule.module
 \end_layout
 
 \end_inset
 
-, the cursor will not go one position backwards but will instead cancel
- the effect t
-\family roman
-hat
-\family default
-\family roman
-\shape up
-\emph on
-char
-\family default
-\shape default
-\emph default
-\family roman
-\shape up
-might have had on the next keystroke.
+.
+\end_layout
+
+\begin_layout Subsection
+File format
 \end_layout
 
 \begin_layout Standard
-The following example specifies that the character ' is to be an acute accent,
- allowed on the characters a, e, i, o, u, A, E, I, O, and U:
+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 LyX-Code
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\backslash
-kmod ' acute aeiouAEIOU
+\begin_layout Plain Layout
+Format
 \end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
+\end_inset
+
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ksmod
+int
 \end_layout
 
 \end_inset
 
- Specify an exception to the accent character
+] The format of the layout file.
 \end_layout
 
-\begin_layout LyX-Code
+\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 20.
+ But each version of LyX is capable of reading earlier versions' layout
+ files, just as they are capable of reading files produced by earlier versions
+ of LyX.
+ There is, however, no provision for converting to earlier formats.
+ So LyX 1.6.x will not read layout files in format 20 but only files in format
+ 11 or earlier.
+\end_layout
 
-\backslash
-kxmod  
-\family roman
-\emph on
-accent char result
+\begin_layout Subsection
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:General-text-class"
+
+\end_inset
+
+General text class parameters
 \end_layout
 
 \begin_layout Standard
-This defines an exce
-\family roman
-ption for
-\family default
-\family roman
-\emph on
-accent
-\family default
-\emph default
-\family roman
-on
-\family default
-\family roman
-\emph on
-char
-\emph default
-.
- T
-\shape up
-he
-\family default
-\shape default
-\family roman
-\shape up
+These are general parameters that govern the behavior of an entire document
+ class.
+ (This does 
 \emph on
-accent
-\family default
-\shape default
+not
 \emph default
-\family roman
-\shape up
-must
-\family default
-\shape default
-\shape up
-have been assigned a keystroke with a previous
-\shape default
+ mean that they must appear in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-
-\backslash
-kmo
-\shape default
-d
+.layout
 \end_layout
 
 \end_inset
 
- declar
-\family roman
-ation and
-\family default
-\family roman
-\emph on
-char
-\family default
-\emph default
-\family roman
-must not belong in the
-\family default
-\family roman
-\emph on
-allowed
-\family default
-\emph default
-\family roman
-set of
-\family default
-\family roman
-\emph on
-accent
-\emph default
-.
- When
-\family default
-\family roman
-\shape up
-you enter the
-\family default
-\shape default
-\family roman
-\shape up
-\emph on
-accent char
-\family default
-\shape default
-\emph default
-\family roman
-\shape up
-sequence,
-\family default
-\shape default
-\family roman
-\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
-\shape default
-\shape up
-the
-\shape default
+ files rather than in modules.
+ A module can contain any layout tag.)
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-.kmap
+AddToHTMLPreamble
 \end_layout
 
 \end_inset
 
- file and yo
-\family roman
-u enter
-\family default
-\family roman
-\emph on
-accent  char
-\emph default
-, you get
-\family default
-\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 
+ Adds information that will be output in the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-
-\backslash
-kmod
+<head>
 \end_layout
 
 \end_inset
 
- declaration.
-\end_layout
+ block when this document class is output to XHTML.
+ Typically, this would be used to output CSS style information, but it can
+ be used for anything that can appear in 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-The following command produces causes äi to be produced when you enter acute-i
- ('i):
+\begin_layout Plain Layout
+<head>
 \end_layout
 
-\begin_layout LyX-Code
-
-\backslash
-kxmod acute i "
-\backslash
+\end_inset
 
-\backslash
-'{
-\backslash
+.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
 
-\backslash
-i}"
-\end_layout
 
-\begin_layout Labeling
-\labelwidthstring 00.00.0000
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-kcomb
+EndPreamble
 \end_layout
 
 \end_inset
 
- Combine two accent characters
-\end_layout
 
-\begin_layout LyX-Code
+\begin_inset Quotes erd
+\end_inset
 
-\backslash
-kcomb 
-\family roman
-\emph on
-accent1 accent2 allowed
+.
 \end_layout
 
-\begin_layout Standard
-This one is getting pretty esoteric.
- It allows you to combine the effect 
-\family roman
-of
-\family default
-\family roman
-\emph on
-accent1
-\family default
-\emph default
-\family roman
-and
-\family default
-\family roman
-\emph on
-accent2
-\family default
-\emph default
-\family roman
-(in that order!) on
-\family default
-\family roman
-\emph on
-allowed
-\family default
-\emph default
-\family roman
-chars.
- The keystrokes for
-\family default
-\family roman
-\emph on
-accent1
-\family default
-\emph default
-\family roman
-and
-\family default
-\family roman
-\emph on
-accent2
-\family default
-\emph default
-\family roman
-must have be
-\family default
-en set with a 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-
-\backslash
-kmod
+AddToPreamble
 \end_layout
 
 \end_inset
 
- command at 
-\family roman
-a
-\family default
-\family roman
-\emph on
-previous
-\family default
-\emph default
-\family roman
-point in the
-\family default
- file.
-\end_layout
+ Adds information to the document preamble.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
+
 
-\begin_layout Standard
-Consider this example from the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-greek.kmap
+EndPreamble
 \end_layout
 
 \end_inset
 
- file:
-\end_layout
 
-\begin_layout LyX-Code
+\begin_inset Quotes erd
+\end_inset
 
-\backslash
-kmod ; acute aeioyvhAEIOYVH 
-\backslash
-kmod : umlaut iyIY 
-\backslash
-kcomb acute umlaut iyIY
+.
 \end_layout
 
-\begin_layout Standard
-This allows you to press 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-;:i
+ClassOptions
 \end_layout
 
 \end_inset
 
- and get the effect of 
+ Describes various global options supported by the document class.
+ See Section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:ClassOptions"
+
+\end_inset
+
+ for a description.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+End
+\end_layout
 
-\shape up
+\end_inset
 
-\backslash
-'{
-\backslash
-"{i}}
-\end_layout
 
+\begin_inset Quotes erd
 \end_inset
 
 .
-\family roman
-\shape up
-A backspace
-\family default
-\shape default
- in this case cancels the last dead key, so if you press 
-\begin_inset Flex CharStyle:MenuItem
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-;: Backspace i
+Columns
 \end_layout
 
 \end_inset
 
- you get 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
-\shape up
+\emph on
+1
+\end_layout
 
-\backslash
-'{i}
+\end_inset
+
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+2
 \end_layout
 
 \end_inset
 
-.
+] 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
 
-\begin_layout Subsection
-The .cdef File
+\end_inset
+
+ dialog.
 \end_layout
 
-\begin_layout Standard
-After the 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-.kmap
+Counter
 \end_layout
 
 \end_inset
 
- mapping is performed, a 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-.cde
-\shape default
-f
+string
 \end_layout
 
 \end_inset
 
- file maps the strings that the symbols generate to characters in the current
- font.
- The LyX distribution currently includes at least the 
+] 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
-
-\shape up
-iso8859-1.cdef
+End
 \end_layout
 
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
+\begin_inset Quotes erd
+\end_inset
 
-\shape up
-iso8859-2.cdef
-\end_layout
+.
+\begin_inset Newline newline
+\end_inset
 
+See Section
+\begin_inset space ~
 \end_inset
 
- files.
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
+
+\end_inset
+
+ for details on counters.
 \end_layout
 
-\begin_layout Standard
-In general the 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\shape up
-.cdef
+DefaultFont
 \end_layout
 
 \end_inset
 
- file is a sequence of declarations of the form
-\end_layout
+ Sets the default font used to display the document.
+ See Section
+\begin_inset space ~
+\end_inset
 
-\begin_layout LyX-Code
 
-\family roman
-\emph on
-char_index_in_set
-\family default
-\emph default
-\family roman
-\emph on
- string
-\end_layout
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Font-description"
 
-\begin_layout Standard
-For example, in order to map 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+\end_inset
 
-\begin_layout Plain Layout
+ for how to declare fonts.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
 
-\shape up
 
-\backslash
-'{e}
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+EndFont
 \end_layout
 
 \end_inset
 
- to the corresponding character in the iso-8859-1 set (233), the following
- declaration is used
-\end_layout
 
-\begin_layout LyX-Code
-233 "
-\backslash
+\begin_inset Quotes erd
+\end_inset
 
-\backslash
-'{e}"
+.
 \end_layout
 
-\begin_layout Standard
-with 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-
+DefaultModule
 \end_layout
 
 \end_inset
 
- and 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-"
+string]
 \end_layout
 
 \end_inset
 
- being escap
-\family roman
-ed in
-\family default
-\family roman
-\emph on
-string
-\emph default
-.
- Note that
-\family default
- the same character can apply to more than one string.
- In the 
+ 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
-i
-\shape up
-so-8859-7.cdef
+.module
 \end_layout
 
 \end_inset
 
- file you have
+ 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 LyX-Code
-192 "
-\backslash
-
-\backslash
-'{
-\backslash
-
-\backslash
-
-\backslash
-"{i}}"
-\begin_inset Newline newline
-\end_inset
-
-192 "
-\backslash
-
-\backslash
-
-\backslash
-"{
-\backslash
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\backslash
-'{i}}"
+\begin_layout Plain Layout
+DefaultStyle
 \end_layout
 
-\begin_layout Standard
-If LyX cannot find a mapping for the string produced by the keystroke or
- a deadkey sequence, it will check if it looks like an accented char and
- try to draw an accent over the character on screen.
-\end_layout
+\end_inset
 
-\begin_layout Subsection
-Dead Keys
-\end_layout
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-There is a second way to add support for international characters through
- so-called dead-keys.
- A dead-key works in combination with a letter to produce an accented character.
- Here, we'll explain how to create a really simple dead-key to illustrate
- how they work.
+\begin_layout Plain Layout
+string
 \end_layout
 
-\begin_layout Standard
-Suppose you happen to need the circumflex character, 
-\begin_inset Quotes eld
-\end_inset
-
- ̂
-\begin_inset Quotes erd
 \end_inset
 
-.
- You could bind the 
+] 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
 
--key [a.k.a.
-\begin_inset space ~
-\end_inset
-
+.
+ This will default to the first defined style if not given, but you are
+ encouraged to use this directive.
+\end_layout
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Shift-6
+ExcludesModule
 \end_layout
 
 \end_inset
 
-] to the LyX command 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-accent-circumflex
+string
 \end_layout
 
 \end_inset
 
- in your 
+] This tag indicates that the module in question—which should be specified
+ by filename without the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-lyxrc
+.module
 \end_layout
 
 \end_inset
 
- file.
- Now, whenever you type the 
-\begin_inset Flex CharStyle:MenuItem
+ 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
-^
+theorems-sec
 \end_layout
 
 \end_inset
 
--key followed by a letter, that letter will have a circumflex accent on
- it.
- For example, the sequence 
-\begin_inset Quotes eld
+ 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"
+
 \end_inset
 
+).
+\end_layout
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-^e
+Float
 \end_layout
 
 \end_inset
 
-
-\begin_inset Quotes erd
+ Defines a new float.
+ See Section
+\begin_inset space ~
 \end_inset
 
- produces the letter: 
-\begin_inset Quotes eld
-\end_inset
 
-\begin_inset Quotes erd
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Floats"
+
 \end_inset
 
-.
- If you tried to type 
+ for details.
+ Must end with 
 \begin_inset Quotes eld
 \end_inset
 
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-^t
+End
 \end_layout
 
 \end_inset
@@ -6243,92 +8001,114 @@ status collapsed
 \begin_inset Quotes erd
 \end_inset
 
-, however, LyX will complain with a beep, since a 
-\begin_inset Quotes eld
-\end_inset
+.
+\end_layout
 
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Plain Layout
+HTMLPreamble
+\end_layout
+
+\end_inset
+
+ Sets the information that will be output in the 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-t
+<head>
 \end_layout
 
 \end_inset
 
+ block when this document class is output to XHTML.
+ Note that this will completely override any prior 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+HTMLPreamble
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
- never takes a circumflex accent.
- Hitting 
-\begin_inset Flex CharStyle:MenuItem
+ or 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Space
+AddToHTMLPreamble
 \end_layout
 
 \end_inset
 
- after a dead-key produces the bare-accent.
- Please note this last point! If you bind a key to a dead-key, you'll need
- to rebind the character on that key to yet another key.
- Binding the 
-\begin_inset Flex CharStyle:MenuItem
+ declarations.
+ (Use 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-,-key
+AddToHTMLPreamble
 \end_layout
 
 \end_inset
 
- to a cedilla is a bad idea, since you'll only get cedillas instead of commas.
-\end_layout
+ if you just want to add material to the preamble.) Must end with 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Standard
-One common way to bind dead-keys is to use 
-\begin_inset Flex CharStyle:MenuItem
+
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Meta-
+EndPreamble
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Ctrl-
+IfCounter
 \end_layout
 
 \end_inset
 
-, and 
-\begin_inset Flex CharStyle:MenuItem
+ [
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Shift-
+string
 \end_layout
 
 \end_inset
 
- in combination with an accent, like 
+] 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:MenuItem
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-~
+End
 \end_layout
 
 \end_inset
@@ -6337,34 +8117,56 @@ status collapsed
 \begin_inset Quotes erd
 \end_inset
 
- or 
-\begin_inset Quotes eld
+.
+\begin_inset Newline newline
+\end_inset
+
+See Section
+\begin_inset space ~
 \end_inset
 
 
-\begin_inset Flex CharStyle:MenuItem
+\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
-,
+IfStyle
 \end_layout
 
 \end_inset
 
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
- or 
+] 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
 
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-^
+End
 \end_layout
 
 \end_inset
@@ -6374,241 +8176,260 @@ status collapsed
 \end_inset
 
 .
- Another way involves using 
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xmodmap
+Input
 \end_layout
 
 \end_inset
 
- and 
+ As its name implies, this command allows you to include another layout
+ definition file within yours to avoid duplicating commands.
+ Common examples are the standard layout files, for example, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xkeycaps
+stdclass.inc
 \end_layout
 
 \end_inset
 
-  to set up the special 
+, which contains most of the basic layouts.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Mode_Switch
+InsetLayout
 \end_layout
 
 \end_inset
 
- key.
- The 
+ This section (re-)defines the layout of an inset.
+ It can be applied to an existing inset or to a new, user-defined inset,
+ e.g., a new character style.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Mode_Switch
+End
 \end_layout
 
 \end_inset
 
- acts in some ways just like 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
 
-\begin_layout Plain Layout
-Shift
-\end_layout
+\begin_inset Quotes erd
+\end_inset
 
+.
+\begin_inset Newline newline
 \end_inset
 
- and permits you to bind keys to accented characters.
- You can also turn keys into dead-keys by binding them to something like
-\begin_inset Flex CharStyle:Code
-status collapsed
+See Section
+\begin_inset space ~
+\end_inset
 
-\begin_layout Plain Layout
-usldead_cedilla
-\end_layout
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Flex-insets-and"
 
 \end_inset
 
and then binding this symbolic key to the corresponding LyX command.
-\begin_inset Foot
-status collapsed
for more information.
+\end_layout
 
-\begin_layout Plain Layout
-Note from 
-\noun on
-John Weiss
-\noun default
-: This is exactly what I do in my 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-~/.lyx/lyxrc
+LeftMargin
 \end_layout
 
 \end_inset
 
- and my 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-~/.xmodmap
+string
 \end_layout
 
 \end_inset
 
- files.
- I have my 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+] A string that indicates the width of the left margin on the screen, for
+ example, 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Plain Layout
-Scroll
-\begin_inset space ~
+MMMMM
+\begin_inset Quotes erd
 \end_inset
 
-Lock
-\end_layout
+.
+ (Note that this is not a `length', like 
+\begin_inset Quotes eld
+\end_inset
 
+2ex
+\begin_inset Quotes erd
 \end_inset
 
- key set up as 
+.)
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Mode_Shift
+NoFloat
 \end_layout
 
 \end_inset
 
- and a bunch of these 
-\begin_inset Quotes eld
-\end_inset
-
+ This command deletes an existing float.
+ This is particularly useful when you want to suppress a float that has
+ been defined in an input file.
+\end_layout
 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-usldead_*
+NoStyle
 \end_layout
 
 \end_inset
 
+ This command deletes an existing style.
+ This is particularly useful when you want to suppress a style that has
+ be defined in an input file.
+\end_layout
 
-\begin_inset Quotes erd
-\end_inset
-
- symbolic keys bound such things as 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Scroll
-\begin_inset space ~
+OutputFormat
+\end_layout
+
 \end_inset
 
-Lock-^
+ 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
 
- and 
-\begin_inset Flex CharStyle:MenuItem
+ 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
-Scroll
-\begin_inset space ~
+OutputType
+\end_layout
+
 \end_inset
 
-Lock-~
+ parameter is encountered.
 \end_layout
 
-\end_inset
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-.
- This is how I produce my accented characters.
+\begin_layout Plain Layout
+OutputType
 \end_layout
 
 \end_inset
 
- You can make just about anything into the 
+ 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 collapsed
 
 \begin_layout Plain Layout
-Mode_Switch
+PageStyle
 \end_layout
 
 \end_inset
 
- key: One of the 
-\begin_inset Flex CharStyle:MenuItem
+ [
+\emph on
+
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Ctrl-
+
+\emph on
+plain
 \end_layout
 
 \end_inset
 
- keys, a spare function key, etc.
- As for the LyX commands that produce accents, check the entry for 
+
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-accent-acute
+empty
 \end_layout
 
 \end_inset
 
- in the 
-\emph on
-Reference Manual
-\emph default
-.
- You'll find the complete list there.
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Subsection
-Saving your Language Configuration
+\begin_layout Plain Layout
+headings
 \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 
+] The default pagestyle.
Can be changed in 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
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
@@ -6616,37 +8437,23 @@ references
  dialog.
 \end_layout
 
-\begin_layout Chapter
-Installing New Document Classes, Layouts, and Templates 
-\begin_inset CommandInset label
-LatexCommand label
-name "chap:textclass"
-
-\end_inset
-
-
-\begin_inset OptArg
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Installing New Document Classes
+Preamble
 \end_layout
 
 \end_inset
 
-
-\end_layout
-
-\begin_layout Standard
-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 
+ Sets the preamble for the LaTeX document.
+ Note that this will completely override any prior 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.cls
+Preamble
 \end_layout
 
 \end_inset
@@ -6656,1439 +8463,1320 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-.sty
+AddToPreamble
 \end_layout
 
 \end_inset
 
-) that describes the format of a document such as an article, report, journal
- preprint, etc, and all the commands needed to realize that format.
- A layout file is a LyX file that corresponds to a LaTeX document class
- and that tells LyX how to 
-\begin_inset Quotes eld
-\end_inset
+ declarations.
+ (Use 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+AddToPreamble
+\end_layout
 
-draw
-\begin_inset Quotes erd
 \end_inset
 
- things on the screen to make the display look something like the final
- printed page.
- More precisely, a layout file describes a 
+ if you just want to add material to the preamble.) Must end with 
 \begin_inset Quotes eld
 \end_inset
 
-text class
-\begin_inset Quotes erd
-\end_inset
 
- which is the internal construct LyX uses to render the screen display.
-\begin_inset Quotes eld
-\end_inset
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-Layout
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Plain Layout
+EndPreamble
+\end_layout
 
- and 
-\begin_inset Quotes eld
 \end_inset
 
-text class
+
 \begin_inset Quotes erd
 \end_inset
 
- 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
- for that class.
- Templates are especially useful for things like journal manuscripts that
- are to be submitted electronically.
-\end_layout
-
-\begin_layout Section
-Installing a new LaTeX package
+.
 \end_layout
 
-\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.
-\end_layout
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-If you don't have such a GUI, then you can follow these steps.
+\begin_layout Plain Layout
+Provides
 \end_layout
 
-\begin_layout Enumerate
-Get the package from 
-\begin_inset CommandInset href
-LatexCommand href
-name "CTAN"
-target "http://www.ctan.org/"
-
 \end_inset
 
- or wherever.
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
 \end_layout
 
-\begin_layout Enumerate
-You can install this 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 
+\end_inset
+
+] [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-texmf.cnf
+
+\emph on
+0
 \end_layout
 
 \end_inset
 
-.
-\begin_inset Foot
+, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-This usually lives in the directory 
+1
+\end_layout
+
+\end_inset
+
+] Whether the class already provides the feature 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$TEXMF/web2c
+string
 \end_layout
 
 \end_inset
 
-, though you can run 
+.
+ A feature is in general the name of a package (
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-kpsewhich texmf.cnf
+amsmath
 \end_layout
 
 \end_inset
 
- to locate it.
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+makeidx
 \end_layout
 
 \end_inset
 
- The location of the `local' TeX tree is defined by 
+, \SpecialChar \ldots{}
+) or a macro (
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TEXMFLOCAL
+url
 \end_layout
 
 \end_inset
 
-; this is usually somewhere like 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-/usr/local/share/texmf/
+boldsymbol
 \end_layout
 
 \end_inset
 
-.
- The `user' TeX tree is defined by 
+,\SpecialChar \ldots{}
+); the complete list of supported features is unfortunately not documented
+ outside the LyX source code—but see 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TEXMFHOME
+LaTeXFeatures.cpp
 \end_layout
 
 \end_inset
 
- and is commonly at 
-\begin_inset Flex CharStyle:Code
+ if you're interested.
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-$HOME/texmf/
+Help\SpecialChar \menuseparator
+LaTeX Configuration
 \end_layout
 
 \end_inset
 
-.
- (If these variables are not predefined, you can define them.) You'll probably
- need root permissions to create or modify the `local' tree; but your `user'
- tree shouldn't have such limitations.
+ also gives an overview of the supported packages.
 \end_layout
 
-\begin_layout Enumerate
-Make sure 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TEXMF
+ProvidesModule
 \end_layout
 
 \end_inset
 
- includes the 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TEXMFLOCAL
+string
 \end_layout
 
 \end_inset
 
- and 
+] 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
-TEXMFHOME
+.module
 \end_layout
 
 \end_inset
 
- variables; e.g.
-\begin_inset Newline newline
-\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
-TEXMF = {$TEXMFHOME,!!$TEXMFLOCAL,!!$TEXMFMAIN}
+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_inset Newline newline
-\end_inset
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-But, again, most of this will 
-\begin_inset Quotes eld
-\end_inset
+\begin_layout Plain Layout
+Requires
+\end_layout
 
-just work
-\begin_inset Quotes erd
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Enumerate
-Create your local
-\begin_inset Foot
+ [
+\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.
+string
 \end_layout
 
 \end_inset
 
- TeX tree.
- You must follow the directory structure of your existing 
+] Whether the class requires the feature 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-texmf
+string
 \end_layout
 
 \end_inset
 
- directory, which will be found at 
+.
+ 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
-TEXMFMAIN
+LaTeXFeatures.cpp
 \end_layout
 
 \end_inset
 
-.
- For example, latex packages should go under 
+ for a list of these.)
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$TEXMFLOCAL/tex/latex/
+RightMargin
 \end_layout
 
+\end_inset
+
+ 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 Enumerate
-Install the package.
- For example, you would unpack the FoilTeX tarball and copy it to 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$TEXMFLOCAL/tex/latex/foiltex
+SecNumDepth
 \end_layout
 
 \end_inset
 
-.
The 
+ Sets which divisions get numbered.
Corresponds to the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-foiltex
+secnumdepth
 \end_layout
 
 \end_inset
 
directory contains various files.
counter in LaTeX.
 \end_layout
 
-\begin_layout Enumerate
-Run: 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-texhash
+Sides
 \end_layout
 
 \end_inset
 
-.
- This should create 
+ [
+\emph on
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$TEXMFLOCAL/ls-R
+
+\emph on
+1
 \end_layout
 
 \end_inset
 
- amongst others.
-\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
+\emph default
+, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+2
+\end_layout
 
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-R
-\bar default
-econfigure
+] Whether the class-default should be printing on one or both sides of the
+ paper.
+ Can be changed in the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Document\SpecialChar \menuseparator
+Settings
 \end_layout
 
 \end_inset
 
-) and then restart LyX.
- You should then see your new package---for example 
-\begin_inset Flex CharStyle:MenuItem
+ dialog.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-slides (FoilTeX)
+Style
 \end_layout
 
 \end_inset
 
----under 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
+ 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
 
-\begin_layout Plain Layout
 
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\bar under
-S
-\bar default
-ettings
+\begin_layout Plain Layout
+End
 \end_layout
 
 \end_inset
 
- in the 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
 
-\begin_layout Plain Layout
-Document Class
-\end_layout
+\begin_inset Quotes erd
+\end_inset
 
+.
+\begin_inset Newline newline
 \end_inset
 
- drop box.
-\end_layout
+See Section
+\begin_inset space ~
+\end_inset
 
-\begin_layout Section
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:Layouts"
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Paragraph-Styles"
 
 \end_inset
 
-Layouts
+ for details on paragraph styles.
 \end_layout
 
-\begin_layout Standard
-This section describes how to write and install your own LyX layout files
- and walks through the 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-article
+TitleLatexName
 \end_layout
 
 \end_inset
 
- text class format as an example.
- The 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.layout
+string="maketitle"
 \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.)
-\end_layout
+] The name of the command or environment to be used with 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\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 
-\begin_inset CommandInset href
-LatexCommand href
-name "section on the LyX wiki"
-target "http://wiki.lyx.org/Layouts/Layouts"
+\begin_layout Plain Layout
+TitleLatexType
+\end_layout
 
 \end_inset
 
- for this kind of material.
+.
 \end_layout
 
-\begin_layout Standard
-All the tags described in this chapter are case-insensitive; this means
- that 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Style
+TitleLatexType
 \end_layout
 
 \end_inset
 
-, 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-style
+
+\emph on
+CommandAfter
 \end_layout
 
 \end_inset
 
- and 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-StYlE
+Environment
 \end_layout
 
 \end_inset
 
- are really the same command.
- The possible values are printed in brackets after the feature's name.
- The default value if a feature isn't specified inside a text class-description
- is typeset 
+] Indicates what kind of markup is used to define the title of a document.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-emphasized
+CommandAfter
 \end_layout
 
 \end_inset
 
-.
- If the argument has a datatype like 
-\begin_inset Quotes eld
-\end_inset
+ means that the macro with name 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+TitleLatexName
+\end_layout
 
-string
-\begin_inset Quotes erd
 \end_inset
 
- or 
+ will be inserted after the last layout which has 
 \begin_inset Quotes eld
 \end_inset
 
-float
-\begin_inset Quotes erd
-\end_inset
 
-, the default is shown like this: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-float=
-\emph on
-default
+InTitle 1
 \end_layout
 
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Subsection
-\begin_inset CommandInset label
-LatexCommand label
-name "sub:Layout-modules"
 
+\begin_inset Quotes erd
 \end_inset
 
-Layout modules
-\end_layout
-
-\begin_layout Standard
-Similar to layout files, and new with LyX 1.6, are layout 
-\emph on
-modules
-\emph default
 .
- 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 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-stdsections.inc
+Environment
 \end_layout
 
 \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
+ corresponds to the case where the block of paragraphs which have 
+\begin_inset Quotes eld
+\end_inset
+
+
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+InTitle 1
+\end_layout
 
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-S
-\bar default
-ettings
-\end_layout
 
+\begin_inset Quotes erd
 \end_inset
 
- dialog.
-\end_layout
+ should be enclosed into the 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\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.
- But modules may, in principle, contain anything a layout file can contain.
+\begin_layout Plain Layout
+TitleLatexName
 \end_layout
 
-\begin_layout Standard
-A module must begin with a line like the following:
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-#
-\backslash
-DeclareLyXModule[endnotes.sty]{Endnotes} 
+ environment.
 \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
- it should appear in 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Document\SpecialChar \menuseparator
-Settings
+TocDepth
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+ Sets which divisions are included in the table of contents.
+ Corresponds to the 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-The module declaration should then be followed by lines like the following:
+\begin_layout Plain Layout
+tocdepth
 \end_layout
 
-\begin_layout LyX-Code
-#DescriptionBegin 
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-#Adds an endnote command, in addition to footnotes.
+ counter in LaTeX.
 \end_layout
 
-\begin_layout LyX-Code
-#You will need to add  
-\backslash
-theendnotes in ERT where you 
-\end_layout
+\begin_layout Subsection
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-#want the endnotes to appear.
+\begin_layout Plain Layout
+ClassOptions
 \end_layout
 
-\begin_layout LyX-Code
-#DescriptionEnd 
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-#Requires: somemodule | othermodule
-\end_layout
+ section
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:ClassOptions"
 
-\begin_layout LyX-Code
-#Excludes: badmodule
-\end_layout
+\end_inset
 
-\begin_layout Standard
-The description is used in 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
 
-\begin_layout Plain Layout
-Document\SpecialChar \menuseparator
-Settings
 \end_layout
 
-\end_inset
-
- to provide the user with information about what the module does.
- The 
+\begin_layout Standard
+The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Requires
+ClassOptions
 \end_layout
 
 \end_inset
 
- line is used to identify other modules with which this one must be used;
- the 
+ section can contain the following entries:
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Excludes
+FontSize
 \end_layout
 
 \end_inset
 
- line is used to identify modules with which this one may not be used.
- Both are optional, and, as shown, multiple modules should be separated
- with the pipe symbol: |.
- Note that the required modules are treated disjunctively: 
-\emph on
-at least one
-\emph default
- of the required modules must be used.
- Similarly, 
-\emph on
-no
-\emph default
- excluded module may be used.
- Note that modules are identified here by their 
-\emph on
-filenames
-\emph default
- without the .module extension.
- So 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-somemodule
+string="10|11|12"
 \end_layout
 
 \end_inset
 
- is really 
+] The list of available font sizes for the document's main font, separated
+ by 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-somemodule.module
+|
 \end_layout
 
 \end_inset
 
+
+\begin_inset Quotes erd
+\end_inset
+
 .
 \end_layout
 
-\begin_layout Standard
-After creating a new module, you will need to reconfigure and then restart
- LyX for the module to appear in the menu.
- However, changes you make to the module will be seen immediately, if you
- open 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Document\SpecialChar \menuseparator
-Settings
+Header
 \end_layout
 
 \end_inset
 
-, highlight something, and then hit 
+ 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
 
-OK
+-//OASIS//DTD DocBook V4.2//EN
 \begin_inset Quotes erd
 \end_inset
 
 .
-\emph on
-It is strongly recommended that you save your work before doing so
-\emph default
-.
- In fact, 
-\emph on
-it is strongly recommended that you not attempt to edit modules while simultaneo
-usly working on documents
-\emph default
-.
- Though of course the developers strive to keep LyX stable in such situations,
- syntax errors and the like in your module file could cause strange behavior.
 \end_layout
 
-\begin_layout Subsection
-Supporting new document classes
-\end_layout
-
-\begin_layout Standard
-There are two situations you are likely to encounter when wanting to support
- a new LaTeX document class, involving LaTeX2e class (
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.cls
+PageStyle
 \end_layout
 
 \end_inset
 
-) and style (
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.sty
+string="empty|plain|headings|fancy"
 \end_layout
 
 \end_inset
 
-) files.
- Supporting a style file is usually fairly easy.
- Supporting a new document class is a bit harder.
-\end_layout
+] The list of available page styles, separated by 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Subsection
-A layout for a 
-\begin_inset Flex CharStyle:MenuItem
+
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-sty
+|
 \end_layout
 
 \end_inset
 
- file
+
+\begin_inset Quotes erd
+\end_inset
+
+.
 \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 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-myclass.sty
+Other
 \end_layout
 
 \end_inset
 
- and it is meant to be used with 
-\begin_inset Flex CharStyle:MenuItem
+ [
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-report.cls
+string=""
 \end_layout
 
 \end_inset
 
-, which is a standard class---start by copying the existing class's layout
- file into your local directory:
+] Some document class options, separated by a comma, that will be added
+ to the optional part of the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\backslash
+documentclass
 \end_layout
 
-\begin_layout LyX-Code
-cp report.layout ~/.lyx/layouts/myclass.layout
+\end_inset
+
+ command.
 \end_layout
 
 \begin_layout Standard
-Then edit 
+The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-myclass.layout
+ClassOptions
 \end_layout
 
 \end_inset
 
- and change the line: 
-\end_layout
+ section must end with 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout LyX-Code
 
-\backslash
-DeclareLaTeXClass{report}
-\end_layout
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-to read
+\begin_layout Plain Layout
+End
 \end_layout
 
-\begin_layout LyX-Code
+\end_inset
 
-\backslash
-DeclareLaTeXClass[report, myclass.sty]{report (myclass)}
-\end_layout
 
-\begin_layout Standard
-Then add:
+\begin_inset Quotes erd
+\end_inset
+
+.
 \end_layout
 
-\begin_layout LyX-Code
-Preamble 
-\begin_inset Newline newline
-\end_inset
+\begin_layout Subsection
+Paragraph Styles
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Paragraph-Styles"
 
-    
-\backslash
-usepackage{myclass}
-\begin_inset Newline newline
 \end_inset
 
-EndPreamble
-\end_layout
 
-\begin_layout Standard
-near the top of the file.
 \end_layout
 
 \begin_layout Standard
-Start LyX and select 
-\begin_inset Flex CharStyle:MenuItem
+A paragraph style description looks like this:
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
+Note that this will either define a new layout or modify an existing one.
+\end_layout
+
+\end_inset
 
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
 
-\bar under
-R
-\bar default
-econfigure
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+Style 
+\family roman
+\emph on
+name
+\end_layout
 
-.
- Then restart LyX and try creating a new document.
- You should see "
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout LyX-Code
+ ...
+\end_layout
+
+\begin_layout LyX-Code
+End
+\end_layout
+
+\begin_layout Standard
+where the following commands are allowed:
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-report (myclass)
+Align
 \end_layout
 
 \end_inset
 
-" as a document class option in the 
-\begin_inset Flex CharStyle:MenuItem
+ [
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+\emph on
+block
+\emph default
+, left, right, center
 \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---
+] Paragraph alignment.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-report
+AlignPossible
 \end_layout
 
 \end_inset
 
- in this example---so you can fiddle around with the settings for the different
- sections if you wish.
-\end_layout
-
-\begin_layout Subsection
-Layout for a 
-\begin_inset Flex CharStyle:MenuItem
+ [
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-cls
+
+\emph on
+block
+\emph default
+, left, right, center
 \end_layout
 
 \end_inset
 
- file
+] A comma separated list of permitted alignments.
+ (Some LaTeX styles prohibit certain alignments, since those wouldn't make
+ sense.
+ For example a right-aligned or centered enumeration isn't possible.)
 \end_layout
 
-\begin_layout Standard
-There are two possibilities here.
- One is that the class file is itself based upon an existing document class.
- For example, many thesis classes are based upon 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-book.cls
+BabelPreamble
 \end_layout
 
 \end_inset
 
-.
- To see whether yours is, look for a line like
+ 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
 
-\begin_layout LyX-Code
+\end_inset
 
-\backslash
-LoadClass{book}
-\end_layout
+ declarations.
+ Must end with 
+\begin_inset Quotes eld
+\end_inset
 
-\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:
-\begin_inset Foot
-status collapsed
 
-\begin_layout Plain Layout
-And it will be easiest if you save the file to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-thesis.layout
+EndBabelPreamble
 \end_layout
 
 \end_inset
 
-: LyX assumes that the document class has the same name as the layout file.
-\end_layout
 
+\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
 
-\begin_layout LyX-Code
+\end_inset
 
-\backslash
-DeclareLaTeXClass[thesis,book]{thesis}
+ is replaced by the language name (as used by the babel package).
 \end_layout
 
-\begin_layout Standard
-If, on the other hand, the new class is not based upon an existing class,
- you will probably have to 
+\begin_layout Itemize
+The 
 \begin_inset Quotes eld
 \end_inset
 
-roll your own
+Function
 \begin_inset Quotes erd
 \end_inset
 
- layout.
- We strongly suggest copying an existing layout file which uses a similar
- LaTeX class and then modifying it, if you can do so.
- At least use an existing file as a starting point so you can find out what
- items you need to worry about.
- Again, the specifics are covered below.
-\end_layout
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Section
-Declaring a new text class
+\begin_layout Plain Layout
+_()
 \end_layout
 
-\begin_layout Standard
-When it's finally time to get your hands dirty and create or edit your own
- layout file, the following sections describe what you're up against.
- Our advice is to go slowly, save and test often, listen to soothing music,
- 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.
- Go have another adult beverage, just for good measure.
+\end_inset
+
+ replaces its argument by the translation of the argument to the current
+ language.
 \end_layout
 
 \begin_layout Standard
-Here we go!
+This preamble snippet will only be used if the document contains more than
+ one language and the babel package is used.
 \end_layout
 
-\begin_layout Standard
-Lines in a layout file which begin with a 
+\end_deeper
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-#
+BottomSep
 \end_layout
 
 \end_inset
 
- are comments.
- There is one exception to this rule: all layouts should begin with lines
- like:
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+float=0
 \end_layout
 
-\begin_layout LyX-Code
+\end_inset
 
-\size small
-#% Do not delete the line below; configure depends on this 
+]
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+Note that a `float' here is a real number, such as: 1.5.
 \end_layout
 
-\begin_layout LyX-Code
+\end_inset
 
-\size small
-#  
-\backslash
-DeclareLaTeXClass{article}
+ The vertical space with which the last of a chain of paragraphs with this
+ layout is separated from the following paragraph.
+ If the next paragraph has another layout, the separations are not simply
+ added, but the maximum is taken.
 \end_layout
 
-\begin_layout Standard
-The second line is used when you configure LyX.
- The layout file is read by the LaTeX script 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-chkconfig.ltx
+Category
 \end_layout
 
 \end_inset
 
-, in a special mode where 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-#
+[string]
 \end_layout
 
 \end_inset
 
- is ignored.
- The first line is just a LaTeX comment, and the second one contains the
- declaration of the text class.
- If these lines appear in a file named 
+ The category for this style.
+ This is used to group related styles in the Layout combobox on the toolbar.
+ Any string can be used, but you may want to use existing categories with
+ your own styles.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-article.layout
+CommandDepth
 \end_layout
 
 \end_inset
 
-, then they define a text class of name 
+ Depth of XML command.
+ Used only with XML-type formats.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-article
+CopyStyle
 \end_layout
 
 \end_inset
 
- (the name of the layout file) which uses the LaTeX document class 
+\begin_inset CommandInset label
+LatexCommand label
+name "des:CopyStyle"
+
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-article.cls
+[string]
 \end_layout
 
 \end_inset
 
- (the default is to use the same name as the layout).
- The string 
-\begin_inset Quotes eld
-\end_inset
-
-article
-\begin_inset Quotes erd
-\end_inset
+ Copies all the features of an existing style into the current one.
+\end_layout
 
- that appears above is used as a description of the text class in the 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+DependsOn
+\end_layout
 
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-S
-\bar default
-ettings
+ The name of a style whose preamble should be output 
+\emph on
+before
+\emph default
+ this one.
+ This allows to ensure some ordering of the preamble snippets when macros
+ definitions depend on one another.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+Note that, besides that functionality, there is no way to ensure any ordering
+ of preambles.
+ The ordering that you see in a given version of LyX may change without
+ warning in later versions.
 \end_layout
 
 \end_inset
 
- dialog.
+
 \end_layout
 
-\begin_layout Standard
-Let's assume that you wrote your own text class that uses the 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-article.cls
+EndLabeltype
 \end_layout
 
 \end_inset
 
- document class, but where you changed the appearance of the section headings.
- If you put it in a file 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-myarticle.layout
+
+\emph on
+No_Label
+\emph default
+, Box, Filled_Box, Static
 \end_layout
 
 \end_inset
 
-, the header of this file should be:
+] The type of label that stands at the end of the paragraph (or sequence
+ of paragraphs if 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LatexType
 \end_layout
 
-\begin_layout LyX-Code
+\end_inset
 
-\size small
-#% Do not delete the line below; configure depends on this 
+ is 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Environment
 \end_layout
 
-\begin_layout LyX-Code
+\end_inset
 
-\size small
-#  
-\backslash
-DeclareLaTeXClass[article]{article (with my own headings)}
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Item_Environment
 \end_layout
 
-\begin_layout Standard
-This declares a text class 
+\end_inset
+
+ or 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-myarticle
+List_Environment
 \end_layout
 
 \end_inset
 
-, associated with the LaTeX document class 
+).
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-article.cls
+No_Label
 \end_layout
 
 \end_inset
 
and described a
mean
 \begin_inset Quotes eld
 \end_inset
 
-article (with my own headings)
+nothing
 \begin_inset Quotes erd
 \end_inset
 
-.
- If your text class depends on several packages, you can declare it as:
-\end_layout
-
-\begin_layout LyX-Code
-
-\size small
-#% Do not delete the line below; configure depends on this 
-\end_layout
-
-\begin_layout LyX-Code
-
-\size small
-#  
-\backslash
-DeclareLaTeXClass[article,foo.sty]{article (with my own headings)}
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-This indicates that your text class uses the foo.sty package.
- Finally, it is also possible to declare classes for DocBook code.
- Typical declarations will look like
+\begin_layout Plain Layout
+Box
 \end_layout
 
-\begin_layout LyX-Code
+\end_inset
 
-\size small
-#% Do not delete the line below; configure depends on this 
-\end_layout
+ (resp.
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
+\begin_layout Plain Layout
+\begin_inset space ~
+\end_inset
 
-\size small
-# 
-\backslash
-DeclareDocBookClass[article]{SGML (DocBook article)}
+Filled_Box
 \end_layout
 
-\begin_layout Standard
-Note that these declarations can also be given an optional parameter declaring
- the name of the document class (but not a list).
-\end_layout
+\end_inset
 
-\begin_layout Standard
-So, to be as explicit as possible, the form of the layout declaration is:
-\end_layout
+) is a white (resp.
+\begin_inset space ~
+\end_inset
 
-\begin_layout LyX-Code
+black) square suitable for end of proof markers, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\size small
-#  
-\backslash
-DeclareLaTeXClass[class,package.sty]{layout description}
+\begin_layout Plain Layout
+Static
 \end_layout
 
-\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
- is not specified, then LyX will simply assume that it is the same as the
- name of the layout file.
+\end_inset
+
+ is an explicit text string.
 \end_layout
 
-\begin_layout Standard
-When the text class has been modified to your taste, all you have to do
- is to copy it either to 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/layouts/
+EndLabelString
 \end_layout
 
 \end_inset
 
- or to 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/layouts
+string=""
 \end_layout
 
 \end_inset
 
-, run 
-\begin_inset Flex CharStyle:MenuItem
+] The string used for a label with a 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+Static
+\end_layout
 
-\bar under
-T
-\bar default
-ools\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-R
-\bar default
-econfigure
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+EndLabelType
 \end_layout
 
 \end_inset
 
-, exit LyX and restart it.
- 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.
- 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
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-layout-reload
+Fill_Bottom
 \end_layout
 
 \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"
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
 
-).
- If you want to use this function, then, you should simply enter it in the
- mini-buffer.
-\emph on
-Warning
-\emph default
-: This is very much an `advanced feature'.
- It is 
-\emph on
-strongly
-\emph default
- recommended that you save your work before using this function.
- In fact, it is 
 \emph on
-strongly
+0
 \emph default
- recommended that you not attempt to edit your layout while simultaneously
- 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.
+,1
 \end_layout
 
-\begin_layout Subsection
-File format
+\end_inset
+
+] Similar to 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Fill_Top
 \end_layout
 
-\begin_layout Standard
-The first non-comment line must contain the file format number:
+\end_inset
+
+.
 \end_layout
 
 \begin_layout Description
@@ -8096,7 +9784,7 @@ The first non-comment line must contain the file format number:
 status collapsed
 
 \begin_layout Plain Layout
-Format
+Fill_Top
 \end_layout
 
 \end_inset
@@ -8106,54 +9794,64 @@ Format
 status collapsed
 
 \begin_layout Plain Layout
-int
-\end_layout
-
-\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.
-\end_layout
 
-\begin_layout Subsection
-General text class parameters
+\emph on
+0
+\emph default
+,1
 \end_layout
 
-\begin_layout Standard
-These are the general parameters which describe the form of the entire document:
-\end_layout
+\end_inset
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
+] With this parameter the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-AddToPreamble
+Fill
 \end_layout
 
 \end_inset
 
- Adds information to the document preamble.
- Must end with 
+ value of the 
 \begin_inset Quotes eld
 \end_inset
 
+Vertical space above
+\begin_inset Quotes erd
+\end_inset
 
-\begin_inset Flex CharStyle:Code
+ list of the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-EndPreamble
+Edit\SpecialChar \menuseparator
+Paragraph
+\begin_inset space ~
+\end_inset
+
+Settings
 \end_layout
 
 \end_inset
 
+ dialog can be set when initializing a paragraph with this style.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+
+\emph on
+Note from Jean-Marc:
+\emph default
+ I'm not sure that this setting has much use, and it should probably be
+ removed in later versions.
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-.
 \end_layout
 
 \begin_layout Description
@@ -8161,40 +9859,47 @@ EndPreamble
 status collapsed
 
 \begin_layout Plain Layout
-ClassOptions
+Font
 \end_layout
 
 \end_inset
 
- Describes various global options supported by the document class.
- See Section
+ The font used for both the text body 
+\emph on
+and
+\emph default
+ the label.
+ See section
 \begin_inset space ~
 \end_inset
 
 
 \begin_inset CommandInset ref
 LatexCommand ref
-reference "sec:classoptions"
+reference "sub:Font-description"
 
 \end_inset
 
- for a description.
- Must end with 
-\begin_inset Quotes eld
-\end_inset
-
-
+.
+ Note that defining this font automatically defines the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-End
+LabelFont
 \end_layout
 
 \end_inset
 
+ to the same value.
+ So you should define this one first if you also want to define 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LabelFont
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
 .
@@ -8205,54 +9910,62 @@ End
 status collapsed
 
 \begin_layout Plain Layout
-Columns
+FreeSpacing
 \end_layout
 
 \end_inset
 
- [
+\begin_inset CommandInset label
+LatexCommand label
+name "des:FreeSpacing"
+
+\end_inset
+
+[
+\emph on
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
 \emph on
-1
+0
 \end_layout
 
 \end_inset
 
+
+\emph default
 , 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-2
+1
 \end_layout
 
 \end_inset
 
-] Whether the class should default to having one or two columns.
- Can be changed in the 
-\begin_inset Flex CharStyle:MenuItem
+] Usually LyX doesn't allow you to insert more than one space between words,
+ since a space is considered as the separation between two words, not a
+ character or symbol of its own.
+ This is a very fine thing but sometimes annoying, for example, when typing
+ program code or plain LaTeX code.
+ For this reason, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
-
-\bar under
-S
-\bar default
-ettings
+FreeSpacing
 \end_layout
 
 \end_inset
 
- dialog.
+ can be enabled.
+ Note that LyX will create protected blanks for the additional blanks when
+ in another mode than LaTeX-mode.
 \end_layout
 
 \begin_layout Description
@@ -8260,43 +9973,33 @@ ettings
 status collapsed
 
 \begin_layout Plain Layout
-Counter
+HTML*
 \end_layout
 
 \end_inset
 
- This sequence defines a new counter.
- See Section
-\begin_inset space ~
-\end_inset
-
-
+ These tags are used with XHTML output.
+ See 
 \begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:counter"
-
-\end_inset
+LatexCommand prettyref
+reference "sub:Paragraph-Style-XHTML"
 
- for details.
- Must end with 
-\begin_inset Quotes eld
 \end_inset
 
+.
+\end_layout
 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-End
+InnerTag
 \end_layout
 
 \end_inset
 
-
-\begin_inset Quotes erd
-\end_inset
-
-.
+ [[FIXME]] (Used only with XML-type formats.)
 \end_layout
 
 \begin_layout Description
@@ -8304,78 +10007,68 @@ End
 status collapsed
 
 \begin_layout Plain Layout
-DefaultFont
+InPreamble
 \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 "sec:fonts"
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
+[1, 0]
+\end_layout
 
- for how to declare fonts.
- Must end with 
-\begin_inset Quotes eld
 \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
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-EndFont
+InTitle
 \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
-DefaultStyle
+[1, 0]
 \end_layout
 
 \end_inset
 
- [
+ If 1, marks the layout as being part of a title block (see also the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+TitleLatexType
 \end_layout
 
 \end_inset
 
-] This is the style that will be assigned to new paragraphs, usually 
-\begin_inset Flex CharStyle:MenuItem
+ and 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Standard
+TitleLatexName
 \end_layout
 
 \end_inset
 
-.
- This will default to the first defined style if not given, but you are
- highly encouraged to use this directive.
+ global entries).
 \end_layout
 
 \begin_layout Description
@@ -8383,68 +10076,62 @@ Standard
 status collapsed
 
 \begin_layout Plain Layout
-Float
+ItemSep
 \end_layout
 
 \end_inset
 
- Defines a new float.
- See Section
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:floats"
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
+float=0
+\end_layout
 
- for details.
- Must end with 
-\begin_inset Quotes eld
 \end_inset
 
-
+] This provides extra space between paragraphs that have the same layout.
+ If you put other layouts into an environment, each is separated with the
+ environment's 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-End
+Parsep
 \end_layout
 
 \end_inset
 
-
-\begin_inset Quotes erd
-\end_inset
-
 .
-\end_layout
-
-\begin_layout Description
+ But the whole items of the environment are additionally separated with
+ this 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Input
+Itemsep
 \end_layout
 
 \end_inset
 
- As its name implies, this command allows you to include another layout
- definition file within yours to avoid duplicating commands.
- Common examples are the standard layout files, for example, 
+.
+ Note that this is a
+\emph on
+ multiplier.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-stdclass.inc
+ItemTag
 \end_layout
 
 \end_inset
 
-, which contains most of the basic layouts.
+ [[FIXME]] (Used only with XML-type formats.)
 \end_layout
 
 \begin_layout Description
@@ -8452,45 +10139,50 @@ stdclass.inc
 status collapsed
 
 \begin_layout Plain Layout
-InsetLayout
+KeepEmpty
 \end_layout
 
 \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,
- e.g., a new character style.
- See Section
-\begin_inset space ~
+\begin_inset CommandInset label
+LatexCommand label
+name "des:KeepEmpty"
+
 \end_inset
 
+[
+\emph on
 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:charstyle"
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
+
+\emph on
+0
+\end_layout
 
- for more information.
- Must end with 
-\begin_inset Quotes eld
 \end_inset
 
 
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-End
+1
 \end_layout
 
 \end_inset
 
-
-\begin_inset Quotes erd
-\end_inset
-
-.
+] Usually LyX does not allow you to leave a paragraph empty, since it would
+ lead to empty LaTeX output.
+ There are some cases where this could be desirable however: in a letter
+ template, the required fields can be provided as empty fields, so that
+ people do not forget them; in some special classes, a layout can be used
+ as some kind of break, which does not contain actual text.
 \end_layout
 
 \begin_layout Description
@@ -8498,27 +10190,33 @@ End
 status collapsed
 
 \begin_layout Plain Layout
-LeftMargin
+LabelBottomsep
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+ [float=0] The vertical space between the label and the text body.
+ Only used for labels that are above the text body (
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Top_Environment
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-NoFloat
+Centered_Top_Environment
 \end_layout
 
 \end_inset
 
- 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.
+).
 \end_layout
 
 \begin_layout Description
@@ -8526,148 +10224,179 @@ NoFloat
 status collapsed
 
 \begin_layout Plain Layout
-NoStyle
+LabelCounter
 \end_layout
 
 \end_inset
 
- This command deletes an existing style.
- This is particularly useful when you want to suppress a style that has
- be defined in an input file.
-\end_layout
-
-\begin_layout Description
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-OutputType
+string=""
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
+]
+\begin_inset Newline newline
+\end_inset
 
-\begin_layout Description
+The name of the counter for automatic numbering.
+\begin_inset Newline newline
+\end_inset
+
+This 
+\emph on
+must
+\emph default
+ be given if 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\series medium
-PageStyle
+LabelType
 \end_layout
 
 \end_inset
 
- [
-\emph on
-
+ is 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-plain
+Counter
 \end_layout
 
 \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
-empty
+LabelType
 \end_layout
 
 \end_inset
 
-, 
+ is 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-headings
+Enumerate
 \end_layout
 
 \end_inset
 
-] The class default pagestyle.
- Can be changed in the 
-\begin_inset Flex CharStyle:MenuItem
+, 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
 
-\bar under
-D
-\bar default
-ocument\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-S
-\bar default
-ettings
-\end_layout
 
+\begin_inset Quotes erd
 \end_inset
 
- dialog.
+.
+ Then the actual counters used are 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+myenumi
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Preamble
+myenumii
 \end_layout
 
 \end_inset
 
- Sets the preamble for the LaTeX document.
- Note that this will completely override any prior 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Premable
+myenumiii
 \end_layout
 
 \end_inset
 
- or 
+, and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-AddToPreamble
+myenumiv
 \end_layout
 
 \end_inset
 
- declarations.
- Must end with 
-\begin_inset Quotes eld
+, 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
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-EndPreamble
+LabelFont
 \end_layout
 
 \end_inset
 
+ The font used for the label.
+ See section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Font-description"
 
-\begin_inset Quotes erd
 \end_inset
 
 .
@@ -8678,135 +10407,143 @@ EndPreamble
 status collapsed
 
 \begin_layout Plain Layout
-Provides
+LabelIndent
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:Provides"
-
-\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
-string
+Labelsep
 \end_layout
 
 \end_inset
 
-] [
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-0
+string=""
 \end_layout
 
 \end_inset
 
-, 
+] The horizontal space between the label and the text body.
+ Only used for labels that are not above the text body.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-1
+LabelString
 \end_layout
 
 \end_inset
 
-] Whether the class already provides the feature 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+string=""
 \end_layout
 
 \end_inset
 
-.
- A feature is in general the name of a package (
+] The string used for a label with a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-amsmath
+Static
 \end_layout
 
 \end_inset
 
-, 
+ labeltype.
+ When 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-makeidx
+LabelCounter
 \end_layout
 
 \end_inset
 
-, \SpecialChar \ldots{}
-) or a macro (
+ is set, this string can be contain the special formatting commands described
+ in Section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
+
+\end_inset
+
+.
+\begin_inset Foot
+status collapsed
+
+\begin_layout Plain Layout
+For the sake of backwards compatibility, the string 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-url
+@
+\emph on
+style-name
+\emph default
+@
 \end_layout
 
 \end_inset
 
-, 
+ will be replaced by the expanded 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-boldsymbol
+LabelString
 \end_layout
 
 \end_inset
 
-,\SpecialChar \ldots{}
-); the complete list of supported features is unfortunately not documented
- outside the LyX source code---but see 
+ of style 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LaTeXFeatures.cpp
+
+\emph on
+style-name
 \end_layout
 
 \end_inset
 
- if you're interested.
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
+.
+ This feature is now obsolete and should be replaced by the mechanisms of
+ Section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
 
-\bar under
-H
-\bar default
-elp\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-L
-\bar default
-aTeX Configuration
+.
 \end_layout
 
 \end_inset
 
- also gives an overview of the supported packages.
+
 \end_layout
 
 \begin_layout Description
@@ -8814,7 +10551,7 @@ aTeX Configuration
 status collapsed
 
 \begin_layout Plain Layout
-Requires
+LabelStringAppendix
 \end_layout
 
 \end_inset
@@ -8824,37 +10561,43 @@ Requires
 status collapsed
 
 \begin_layout Plain Layout
-string
+string=""
 \end_layout
 
 \end_inset
 
-] Whether the class requires the feature
+] This is used inside the appendix instead of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
- string
+LabelString
 \end_layout
 
 \end_inset
 
 .
- Multiple features must be separated by commas.
- Note that you can only request supported features.
+ Note that every 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LabelString
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+ statement resets 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-RightMargin
+LabelStringAppendix
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+ too.
 \end_layout
 
 \begin_layout Description
@@ -8862,12 +10605,12 @@ RightMargin
 status collapsed
 
 \begin_layout Plain Layout
-SecNumDepth
+LabelTag
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+ [FIXME] (Used only with XML-type formats.)
 \end_layout
 
 \begin_layout Description
@@ -8875,222 +10618,185 @@ SecNumDepth
 status collapsed
 
 \begin_layout Plain Layout
-Sides
+LabelType
 \end_layout
 
 \end_inset
 
  [
-\emph on
-
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
 \emph on
-1
+No_Label
+\emph default
+, Manual, Static, Top_Environment, Centered_Top_Environment, Counter, Sensitive,
+ Enumerate, Itemize, Bibliography
 \end_layout
 
 \end_inset
 
+] 
+\end_layout
 
-\emph default
-, 
+\begin_deeper
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-2
+Manual
 \end_layout
 
 \end_inset
 
-] Whether the class-default should be printing on one or both sides of the
- paper.
- 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
-\end_layout
-
+ means the label is the very first word (up to the first real blank).
+ Use protected spaces (like
+\begin_inset space ~
 \end_inset
 
- dialog.
+that one) if you want more than one word as the label.
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Style
+Static
 \end_layout
 
 \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.
- Must end with 
-\begin_inset Quotes eld
-\end_inset
-
-
+ means the label is simply whatever 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-End
+LabelString
 \end_layout
 
 \end_inset
 
-
-\begin_inset Quotes erd
-\end_inset
-
-.
+ declares it to be.
+ Note that this really is `static'.
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TitleLatexName
+Top_Environment
 \end_layout
 
 \end_inset
 
- [
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string="maketitle"
+Centered_Top_Environment
 \end_layout
 
 \end_inset
 
-] The name of the command or environment to be used with 
+ are special cases of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TitleLatexType
+Static
 \end_layout
 
 \end_inset
 
 .
-\end_layout
-
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
+ 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.
+ This might be used with the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-TitleLatexType
+Abstract
 \end_layout
 
 \end_inset
 
- [
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-
-\emph on
-CommandAfter
+ layout, for example.
 \end_layout
 
-\end_inset
-
-, 
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Environment
+Sensitive
 \end_layout
 
 \end_inset
 
-] Indicates what kind of markup is used to define the title of a document.
-\begin_inset Flex CharStyle:Code
-status collapsed
+ is a special case for the caption-labels 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Plain Layout
-CommandAfter
-\end_layout
+Figure
+\begin_inset Quotes erd
+\end_inset
 
+ and 
+\begin_inset Quotes eld
 \end_inset
 
- means that the macro with name 
+Table
+\begin_inset Quotes erd
+\end_inset
+
+.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TitleLatexName
+Sensitive
 \end_layout
 
 \end_inset
 
- will be inserted after the last layout which has 
-\begin_inset Quotes eld
-\end_inset
-
+ 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
-InTitle 1
+Counter
 \end_layout
 
 \end_inset
 
-
-\begin_inset Quotes erd
-\end_inset
-
-.
+ label type defines automatically numbered labels.
+ The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Environment
+LabelString
 \end_layout
 
 \end_inset
 
- corresponds to the case where the block of paragraphs which have 
+ will be expanded to resolve any counter references it contains: For example,
+ it might be 
 \begin_inset Quotes eld
 \end_inset
 
@@ -9099,7 +10805,11 @@ Environment
 status collapsed
 
 \begin_layout Plain Layout
-InTitle 1
+Section 
+\backslash
+thechapter.
+\backslash
+thesection
 \end_layout
 
 \end_inset
@@ -9108,87 +10818,93 @@ InTitle 1
 \begin_inset Quotes erd
 \end_inset
 
- should be enclosed into the 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-TitleLatexName
-\end_layout
+.
+ See Section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Counters"
 
 \end_inset
 
environment.
for more information on counters.
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TocDepth
+Enumerate
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+ 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 Subsection
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ClassOptions
+Itemize
 \end_layout
 
 \end_inset
 
- section
+ produces various bullets at the different levels.
+ It is also hardcoded.
 \end_layout
 
-\begin_layout Standard
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:classoptions"
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Bibliography
+\end_layout
 
 \end_inset
 
-The 
+ is used internally by LyX and should be used only with 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ClassOptions
+LatexType BibEnvironment
 \end_layout
 
 \end_inset
 
- section can contain the following entries:
+.
 \end_layout
 
+\end_deeper
 \begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-FontSize
+LangPreamble
 \end_layout
 
 \end_inset
 
- [
+ Like 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string="10|11|12"
+BabelPreamble
 \end_layout
 
 \end_inset
 
-] The list of available font sizes for the document's main font, separated
- by 
+, 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
 
@@ -9197,7 +10913,7 @@ string="10|11|12"
 status collapsed
 
 \begin_layout Plain Layout
-|
+EndLangPreamble
 \end_layout
 
 \end_inset
@@ -9209,411 +10925,494 @@ status collapsed
 .
 \end_layout
 
-\begin_layout Description
+\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
-Header
+LangPreamble
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-PageStyle
+BabelPreamble
 \end_layout
 
 \end_inset
 
- [
+ 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
-string="empty|plain|headings|fancy"
+theorems-ams.inc
 \end_layout
 
 \end_inset
 
-] The list of available page styles, separated by 
-\begin_inset Quotes eld
-\end_inset
+ file) shows how this works:
+\end_layout
 
+\begin_layout LyX-Code
+Preamble
+\end_layout
 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+  
+\backslash
+theoremstyle{remark}
+\end_layout
 
-\begin_layout Plain Layout
-|
+\begin_layout LyX-Code
+  
+\backslash
+newtheorem{claim}[thm]{
+\backslash
+protect
+\backslash
+claimname}
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+EndPreamble
+\end_layout
 
+\begin_layout LyX-Code
+LangPreamble
+\end_layout
 
-\begin_inset Quotes erd
-\end_inset
+\begin_layout LyX-Code
+  
+\backslash
+providecommand{
+\backslash
+claimname}{_(Claim)}
+\end_layout
+
+\begin_layout LyX-Code
 
-.
 \end_layout
 
-\begin_layout Description
+\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
-Other
+
+\backslash
+claimname
 \end_layout
 
 \end_inset
 
- [
+ 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
-string=""
+BabelPreamble
 \end_layout
 
 \end_inset
 
-] Some document class options, separated by a comma, that will be added
- to the optional part of the 
+ then uses the commands offered by the babel package to redefine 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
 \backslash
-documentclass
+claimname
 \end_layout
 
 \end_inset
 
command.
for each used language in multilanguage documents.
 \end_layout
 
-\begin_layout Standard
-The 
+\end_deeper
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ClassOptions
+LatexName
 \end_layout
 
 \end_inset
 
- section must end with 
-\begin_inset Quotes eld
-\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
-End
+LatexParam
 \end_layout
 
 \end_inset
 
+ An optional parameter for the corresponding 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LatexName
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-.
+ stuff.
+ This parameter cannot be changed from within LyX.
 \end_layout
 
-\begin_layout Subsection
-Paragraph Styles
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+LatexType
 \end_layout
 
-\begin_layout Standard
+\end_inset
+
 \begin_inset CommandInset label
 LatexCommand label
-name "sec:style"
+name "des:LatexType"
 
 \end_inset
 
-A paragraph style description looks like this:
-\begin_inset Foot
+[
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Note that this will either define a new layout or modify an existing one.
+
+\emph on
+Paragraph
+\emph default
+, Command, Environment, Item_Environment,
 \end_layout
 
 \end_inset
 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
+\begin_layout Plain Layout
+List_Environment, Bib_Environment
 \end_layout
 
-\begin_layout LyX-Code
-Style 
-\family roman
-\emph on
-name
-\end_layout
-
-\begin_layout LyX-Code
- ...
-\end_layout
-
-\begin_layout LyX-Code
-End
-\end_layout
+\end_inset
 
-\begin_layout Standard
-where the following commands are allowed:
-\end_layout
+] How the layout should be translated into LaTeX.
+\begin_inset Foot
+status collapsed
 
-\begin_layout Description
+\begin_layout Plain Layout
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Align
+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
 
 \begin_layout Plain Layout
-
-\emph on
-block
-\emph default
-, left, right, center
+Paragraph
 \end_layout
 
 \end_inset
 
-] Paragraph alignment.
+ means nothing special.
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-AlignPossible
+Command
 \end_layout
 
 \end_inset
 
- [
+ means 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
+\backslash
+
 \emph on
-block
+LatexName
 \emph default
-, left, right, center
+{\SpecialChar \ldots{}
+}
 \end_layout
 
 \end_inset
 
-] A comma separated list of permitted alignments.
- (Some LaTeX styles prohibit certain alignments, since those wouldn't make
- sense.
- For example a right-aligned or centered enumeration isn't possible.)
+.
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-BottomSep
+Environment
 \end_layout
 
 \end_inset
 
- [
+ means 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-float=0
+
+\backslash
+begin{
+\emph on
+LatexName
+\emph default
+}\SpecialChar \ldots{}
+
+\backslash
+end{
+\emph on
+LatexName
+\emph default
+}
 \end_layout
 
 \end_inset
 
-]
-\begin_inset Foot
+.
+\end_layout
+
+\begin_layout Itemize
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Note that a `float' here is a real number, such as: 1.5.
+Item_Environment
 \end_layout
 
 \end_inset
 
- The vertical space with which the last of a chain of paragraphs with this
- layout is separated from the following paragraph.
- If the next paragraph has another layout, the separations are not simply
- added, but the maximum is taken.
-\end_layout
-
-\begin_layout Description
+ is the same as 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Category
+Environment
 \end_layout
 
 \end_inset
 
+, except that an 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-[string]
+
+\backslash
+item
 \end_layout
 
 \end_inset
 
- The category for this style.
- This is used to group related styles in the Layout combobox on the toolbar.
- Any string can be used, but you may want to use existing categories with
- your own styles.
+ is generated for each paragraph of this environment.
  
 \end_layout
 
-\begin_layout Description
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-CommandDepth
+List_Environment
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
+ is the same as 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-CopyStyle
+Item_Environment
 \end_layout
 
 \end_inset
 
+, except that 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-[string]
+LabelWidthString
 \end_layout
 
 \end_inset
 
Copies all the features of an existing style into the current one.
is passed as an argument to the environment.
  
-\end_layout
-
-\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-DependsOn
+LabelWidthString
 \end_layout
 
 \end_inset
 
- The name of a style whose preamble should be output 
-\emph on
-before
-\emph default
- this one.
- This allows to ensure some ordering of the preamble snippets when macros
- definitions depend on one another.
-\begin_inset Foot
+ can be defined in the 
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Note that, besides that functionality, there is no way to ensure any ordering
- of preambles.
- The ordering that you see in a given version of LyX may change without
- warning in later versions.
+
+\bar under
+L
+\bar default
+ayout\SpecialChar \menuseparator
+
+\bar under
+P
+\bar default
+aragraph
 \end_layout
 
 \end_inset
 
+ dialog.
+\end_layout
 
+\begin_layout Standard
+Putting the last few things together, the LaTeX output will be either: 
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
 
-\begin_layout Plain Layout
-EndLabeltype
+\backslash
+latexname[latexparam]{\SpecialChar \ldots{}
+}
 \end_layout
 
-\end_inset
-
- [
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Standard
+or: 
+\end_layout
 
-\begin_layout Plain Layout
+\begin_layout LyX-Code
 
-\emph on
-No_Label
-\emph default
-, Box, Filled_Box, Static
+\backslash
+begin{latexname}[latexparam] \SpecialChar \ldots{}
+\backslash
+end{latexname}.
 \end_layout
 
-\end_inset
+\begin_layout Standard
+depending upon the LaTeX type.
+\end_layout
 
-] The type of label that stands at the end of the paragraph (or sequence
- of paragraphs if 
+\end_deeper
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexType
+LeftMargin
 \end_layout
 
 \end_inset
 
- is 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Environment
+string=""
 \end_layout
 
 \end_inset
 
-, 
+] If you put layouts into environments, the leftmargins are not simply added,
+ but added with a factor 
+\begin_inset Formula $\frac{4}{depth+4}$
+\end_inset
+
+.
+ Note that this parameter is also used when the margin is defined as 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Item_Environment
+Manual
 \end_layout
 
 \end_inset
@@ -9623,68 +11422,77 @@ Item_Environment
 status collapsed
 
 \begin_layout Plain Layout
-List_Environment
+Dynamic
 \end_layout
 
 \end_inset
 
-).
+.
+ Then it is added to the manual or dynamic margin.
  
+\begin_inset Newline newline
+\end_inset
+
+The argument is passed as a string.
+ For example 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-No_Label
+MM
 \end_layout
 
 \end_inset
 
- means 
-\begin_inset Quotes eld
-\end_inset
 
-nothing
 \begin_inset Quotes erd
 \end_inset
 
-, 
+ means that the paragraph is indented with the width of 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Box
+MM
 \end_layout
 
 \end_inset
 
- (resp.
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-\begin_inset space ~
+\begin_inset Quotes erd
 \end_inset
 
-Filled_Box
-\end_layout
-
+ in the normal font.
+ You can get a negative width by prefixing the string with 
+\begin_inset Quotes eld
 \end_inset
 
-) is a white (resp.
-\begin_inset space ~
-\end_inset
 
-black) square suitable for end of proof markers, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Static
+-
 \end_layout
 
 \end_inset
 
- is an explicit text string.
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ This way was chosen so that the look is the same with each used screen
+ font.
 \end_layout
 
 \begin_layout Description
@@ -9692,7 +11500,7 @@ Static
 status collapsed
 
 \begin_layout Plain Layout
-EndLabelString
+Margin
 \end_layout
 
 \end_inset
@@ -9702,12 +11510,21 @@ EndLabelString
 status collapsed
 
 \begin_layout Plain Layout
-string=""
+
+\emph on
+Static
+\emph default
+, Manual, Dynamic, First_Dynamic, Right_Address_Box
 \end_layout
 
 \end_inset
 
-] The string used for a label with a 
+] 
+\begin_inset Newline newline
+\end_inset
+
+The kind of margin that the layout has on the left side.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -9717,55 +11534,104 @@ Static
 
 \end_inset
 
+ just means a fixed margin.
  
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-EndLabelType
+Manual
 \end_layout
 
 \end_inset
 
-.
+ means that the left margin depends on the string entered in the 
+\begin_inset Flex CharStyle:MenuItem
+status collapsed
+
+\begin_layout Plain Layout
+Edit\SpecialChar \menuseparator
+Paragraph
+\begin_inset space ~
+\end_inset
+
+Settings
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+ dialog.
+ This is used to typeset nice lists without tabulators.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Fill_Bottom
+Dynamic
 \end_layout
 
 \end_inset
 
- [
+ means that the margin depends on the size of the label.
+ This is used for automatic enumerated headlines.
+ It is obvious that the headline 
+\begin_inset Quotes eld
+\end_inset
+
+5.4.3.2.1 Very long headline
+\begin_inset Quotes erd
+\end_inset
+
+ must have a wider left margin (as wide as 
+\begin_inset Quotes eld
+\end_inset
+
+5.4.3.2.1
+\begin_inset Quotes erd
+\end_inset
+
+ plus the space) than 
+\begin_inset Quotes eld
+\end_inset
+
+3.2 Very long headline
+\begin_inset Quotes erd
+\end_inset
+
+, even if standard 
+\begin_inset Quotes eld
+\end_inset
+
+word processors
+\begin_inset Quotes erd
+\end_inset
+
+ are not able to do this.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-0
-\emph default
-,1
+First_Dynamic
 \end_layout
 
 \end_inset
 
-] Similar to 
+ is similar, but only the very first row of the paragraph is dynamic, while
+ the others are static; this is used, for example, for descriptions.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Fill_Top
+Right_Address_Box
 \end_layout
 
 \end_inset
 
-.
+ means the margin is chosen in a way that the longest row of this paragraph
+ fits to the right margin.
+ This is used to typeset an address on the right edge of the page.
 \end_layout
 
 \begin_layout Description
@@ -9773,7 +11639,7 @@ Fill_Top
 status collapsed
 
 \begin_layout Plain Layout
-Fill_Top
+NeedProtect
 \end_layout
 
 \end_inset
@@ -9786,69 +11652,38 @@ status collapsed
 
 \emph on
 0
-\emph default
-,1
 \end_layout
 
 \end_inset
 
-] With this parameter the 
-\begin_inset Flex CharStyle:MenuItem
+,
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Fill
+1
 \end_layout
 
 \end_inset
 
- value of the 
-\begin_inset Quotes eld
-\end_inset
-
-Vertical space above
-\begin_inset Quotes erd
-\end_inset
-
- list of the 
-\begin_inset Flex CharStyle:MenuItem
+] Whether fragile commands in this layout should be 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
-\bar under
-E
-\bar default
-dit\SpecialChar \menuseparator
-
-\bar under
-P
-\bar default
-aragraph
-\begin_inset space ~
-\end_inset
-
-Settings
+\backslash
+protect
 \end_layout
 
 \end_inset
 
- dialog can be set when initializing a paragraph with this style.
-\begin_inset Foot
-status collapsed
-
-\begin_layout Plain Layout
-
+'ed.
+ (Note: This is 
 \emph on
-Note from Jean-Marc:
+not
 \emph default
- I'm not sure that this setting has much use, and it should probably be
- removed in later versions.
-\end_layout
-
-\end_inset
-
+ whether this command should itself be protected.)
 \end_layout
 
 \begin_layout Description
@@ -9856,50 +11691,50 @@ Note from Jean-Marc:
 status collapsed
 
 \begin_layout Plain Layout
-Font
+Newline
 \end_layout
 
 \end_inset
 
- The font used for both the text body 
-\emph on
-and
-\emph default
- the label.
- See section
-\begin_inset space ~
-\end_inset
-
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:fonts"
+\begin_layout Plain Layout
+0
+\end_layout
 
 \end_inset
 
-.
- Note that defining this font automatically defines the 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelFont
+
+\emph on
+1
 \end_layout
 
 \end_inset
 
- to the same value.
- So you should define this one first if you also want to define 
+] Whether newlines are translated into LaTeX newlines (
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelFont
+
+\backslash
+
+\backslash
+
 \end_layout
 
 \end_inset
 
-.
+) or not.
+ The translation can be switched off to allow more comfortable LaTeX editing
+ inside LyX.
 \end_layout
 
 \begin_layout Description
@@ -9907,21 +11742,22 @@ LabelFont
 status collapsed
 
 \begin_layout Plain Layout
-FreeSpacing
+NextNoIndent
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:FreeSpacing"
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
+1
+\end_layout
 
-[
-\emph on
+\end_inset
 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -9933,9 +11769,8 @@ status collapsed
 
 \end_inset
 
-
-\emph default
-, 
+] Whether the following Paragraph is allowed to indent its very first row.
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -9945,24 +11780,17 @@ status collapsed
 
 \end_inset
 
-] Usually LyX doesn't allow you to insert more than one space between words,
- since a space is considered as the separation between two words, not a
- character or symbol of its own.
- This is a very fine thing but sometimes annoying, for example, when typing
- program code or plain LaTeX code.
- For this reason, 
+ means that it is not allowed to do so; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-FreeSpacing
+0
 \end_layout
 
 \end_inset
 
- can be enabled.
- Note that LyX will create protected blanks for the additional blanks when
- in another mode than LaTeX-mode.
+ means it could do so if it wants to.
 \end_layout
 
 \begin_layout Description
@@ -9970,12 +11798,13 @@ FreeSpacing
 status collapsed
 
 \begin_layout Plain Layout
-InnerTag
+ObsoletedBy
 \end_layout
 
 \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
@@ -9983,105 +11812,105 @@ InnerTag
 status collapsed
 
 \begin_layout Plain Layout
-InTitle
+OptionalArgs
 \end_layout
 
 \end_inset
 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-[1, 0]
+int=0
 \end_layout
 
 \end_inset
 
- If 1, marks the layout as being part of a title block (see also the 
+] The number of optional arguments that can be used with this layout.
+ This is useful for things like section headings, and only makes sense with
+ LaTeX.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TitleLatexType
+ParIndent
 \end_layout
 
 \end_inset
 
- and 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TitleLatexName
+string=""
 \end_layout
 
 \end_inset
 
- global entries).
-\end_layout
-
-\begin_layout Description
+] The indent of the very first line of a paragraph.
+ The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ItemSep
+Parindent
 \end_layout
 
 \end_inset
 
- [
+ will be fixed for a certain layout.
+ The exception is Standard layout, since the indentation of a Standard layout
+ paragraph can be prohibited with 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-float=0
+NextNoIndent
 \end_layout
 
 \end_inset
 
-] This provides extra space between paragraphs that have the same layout.
- If you put other layouts into an environment, each is separated with the
- environment's 
+.
+ Also, Standard layout paragraphs inside environments use the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Parsep
+Parindent
 \end_layout
 
 \end_inset
 
-.
- But the whole items of the environment are additionally separated with
- this 
+ of the environment, not their native one.
+ For example, Standard paragraphs inside an enumeration are not indented.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Itemsep
+Parsep
 \end_layout
 
 \end_inset
 
-.
- Note that this is a
-\emph on
- multiplier.
-\end_layout
-
-\begin_layout Description
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ItemTag
+float=0
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+] The vertical space between two paragraphs of this layout.
 \end_layout
 
 \begin_layout Description
@@ -10089,84 +11918,90 @@ ItemTag
 status collapsed
 
 \begin_layout Plain Layout
-KeepEmpty
+Parskip
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:KeepEmpty"
-
-\end_inset
-
-[
-\emph on
-
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-0
+float=0
 \end_layout
 
 \end_inset
 
+] LyX allows the user to choose either 
+\begin_inset Quotes eld
+\end_inset
 
-\emph default
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
+indent
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-1
-\end_layout
+ or 
+\begin_inset Quotes eld
+\end_inset
 
+skip
+\begin_inset Quotes erd
 \end_inset
 
-] Usually LyX does not allow you to leave a paragraph empty, since it would
- lead to empty LaTeX output.
- There are some cases where this could be desirable however: in a letter
- template, the required fields can be provided as empty fields, so that
- people do not forget them; in some special classes, a layout can be used
- as some kind of break, which does not contain actual text.
-\end_layout
+ to typeset a document.
+ When 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
+indent
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-LabelBottomsep
-\end_layout
+ is chosen, this value is completely ignored.
+ When 
+\begin_inset Quotes eld
+\end_inset
+
+skip
+\begin_inset Quotes erd
+\end_inset
+
+ is chosen, the parindent of a LaTeXtype 
+\begin_inset Quotes eld
+\end_inset
 
+Paragraph
+\begin_inset Quotes erd
 \end_inset
 
[float=0] The vertical space between the label and the text body.
- Only used for labels that are above the text body (
layout is ignored and all paragraphs are separated by this parskip argument.
+ The vertical space is calculated with 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Top_Environment
+value
+\begin_inset space ~
+\end_inset
+
+* DefaultHeight
 \end_layout
 
 \end_inset
 
-, 
+ where 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Centered_Top_Environment
+DefaultHeight
 \end_layout
 
 \end_inset
 
-).
+ is the height of a row with the normal font.
+ This way, the look stays the same with different screen fonts.
 \end_layout
 
 \begin_layout Description
@@ -10174,54 +12009,46 @@ Centered_Top_Environment
 status collapsed
 
 \begin_layout Plain Layout
-LabelCounter
+PassThru
 \end_layout
 
 \end_inset
 
- [
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-string=""
-\end_layout
-
-\end_inset
+\begin_inset CommandInset label
+LatexCommand label
+name "des:PathThru"
 
-]
-\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"
-
-\end_inset
+[
+\emph on
 
- for details).
- This must be given if 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Labeltype
+
+\emph on
+0
 \end_layout
 
 \end_inset
 
- is 
+
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Counter
+1
 \end_layout
 
 \end_inset
 
-.
+] Whether the contents of this paragraph should be output in raw form, meaning
+ without special translations that LaTeX would require.
 \end_layout
 
 \begin_layout Description
@@ -10229,48 +12056,40 @@ Counter
 status collapsed
 
 \begin_layout Plain Layout
-LabelFont
+Preamble
 \end_layout
 
 \end_inset
 
- The font used for the label.
- See section
-\begin_inset space ~
-\end_inset
-
+\begin_inset CommandInset label
+LatexCommand label
+name "des:Preamble"
 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:fonts"
+\end_inset
 
+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 
+\begin_inset Quotes eld
 \end_inset
 
-.
-\end_layout
 
-\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Labelsep
+EndPreamble
 \end_layout
 
 \end_inset
 
- [
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-string=""
-\end_layout
 
+\begin_inset Quotes erd
 \end_inset
 
-] The horizontal space between the label and the text body.
- Only used for labels that are not above the text body.
+.
 \end_layout
 
 \begin_layout Description
@@ -10278,106 +12097,91 @@ string=""
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
+Requires 
 \end_layout
 
 \end_inset
 
- [
+[
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string=""
+string
 \end_layout
 
 \end_inset
 
-] The string used for a label with a 
+] 
+\begin_inset CommandInset label
+LatexCommand label
+name "des:Requires"
+
+\end_inset
+
+Whether the layout requires the feature 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Static
+string
 \end_layout
 
 \end_inset
 
- labeltype.
- When 
+.
+ See the description of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelCounter
+Provides
 \end_layout
 
 \end_inset
 
- is set, this string can be contain the special formatting commands described
- in Section 
+ above (page 
 \begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:counter"
+LatexCommand pageref
+reference "des:FreeSpacing"
 
 \end_inset
 
-.
-\begin_inset Foot
-status collapsed
+) for information on `features'.
+\end_layout
 
-\begin_layout Plain Layout
-For the sake of backwards compatibility, the string 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-@
-\emph on
-style-name
-\emph default
-@
+RightMargin
 \end_layout
 
 \end_inset
 
- will be replaced by the expanded 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
+string=""
 \end_layout
 
 \end_inset
 
- of style 
+] Similar to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-style-name
+LeftMargin
 \end_layout
 
 \end_inset
 
 .
- This feature is now obsolete and should be replaced by the mechanisms of
- Section 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:counter"
-
-\end_inset
-
-.
-\end_layout
-
-\end_inset
-
-
 \end_layout
 
 \begin_layout Description
@@ -10385,7 +12189,7 @@ reference "sec:counter"
 status collapsed
 
 \begin_layout Plain Layout
-LabelStringAppendix
+Spacing
 \end_layout
 
 \end_inset
@@ -10395,250 +12199,287 @@ LabelStringAppendix
 status collapsed
 
 \begin_layout Plain Layout
-string=""
+
+\emph on
+single
+\emph default
+, onehalf, double, other
 \end_layout
 
 \end_inset
 
-] This is used inside the appendix instead of 
+\emph on
+value
+\emph default
+] This defines what the default spacing should be in the layout.
+ The arguments 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
+single
 \end_layout
 
 \end_inset
 
-.
- Note that every 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
+onehalf
 \end_layout
 
 \end_inset
 
- statement resets 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelStringAppendix
+double
 \end_layout
 
 \end_inset
 
- too.
-\end_layout
-
-\begin_layout Description
+ correspond respectively to a multiplier value of 1, 1.25 and 1.667.
+ If you specify the argument 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Labeltype
+other
 \end_layout
 
 \end_inset
 
- [
+, then you should also provide a numerical argument which will be the actual
+ multiplier value.
+ Note that, contrary to other parameters, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+Spacing
+\end_layout
 
-\emph on
-No_Label
-\emph default
-, Manual, Static, Top_Environment, 
-\begin_inset Newline newline
 \end_inset
 
-Centered_Top_Environment, Sensitive, Counter
-\end_layout
+ implies the generation of specific LaTeX code, using the package 
+\family roman
 
-\end_inset
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+setspace.sty
+\end_layout
 
-] 
-\begin_inset Newline newline
 \end_inset
 
+.
+\end_layout
 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Manual
+TextFont
 \end_layout
 
 \end_inset
 
- means the label is the very first word (up to the first real blank).
-\begin_inset Foot
+ The font used for the text body .
+ See section 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Font-description"
+
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Use protected spaces if you want more than one word as the label.
+TocLevel
 \end_layout
 
 \end_inset
 
+
+\series medium
  
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Static
+
+\series medium
+[int]
 \end_layout
 
 \end_inset
 
- means it is defined in the layout (see 
+
+\series default
+ The level of the style in the table of contents.
+ This is used for automatic numbering of section headings.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
+TopSep
 \end_layout
 
 \end_inset
 
-).
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Top_Environment
+float=0
+\end_layout
+
+\end_inset
+
+] The vertical space with which the very first of a chain of paragraphs
+ with this layout is separated from the previous paragraph.
+ If the previous paragraph has another layout, the separations are not simply
+ added, but the maximum is taken.
 \end_layout
 
+\begin_layout Subsection
+Floats
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Floats"
+
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-Centered_Top_Environment
 \end_layout
 
-\end_inset
-
- are special cases of 
-\begin_inset Flex CharStyle:Code
+\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
 status collapsed
 
 \begin_layout Plain Layout
-Static
+figure
 \end_layout
 
 \end_inset
 
-.
- 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 
+, 
 \begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-Abstract
+table
 \end_layout
 
 \end_inset
 
- layout or the 
-\begin_inset Flex CharStyle:MenuItem
+, \SpecialChar \ldots{}
+) in the text class itself.
+ Standard floats are included in the file 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Bibliography
+stdfloats.inc
 \end_layout
 
 \end_inset
 
- layout.
- This is also the case for 
-\begin_inset Flex CharStyle:Code
-status collapsed
+, so you may have to do no more than add
+\end_layout
 
-\begin_layout Plain Layout
-Manual
+\begin_layout LyX-Code
+Input stdfloats.inc
 \end_layout
 
-\end_inset
+\begin_layout Standard
+to your layout file.
+ If you want to implement a text class that proposes some other float types
+ (like the AGU class bundled with LyX), the information below will hopefully
+ help you:
+\end_layout
 
- labels with latex type 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Environment
+Extension
 \end_layout
 
 \end_inset
 
-, in order to make layouts for theorems work correctly.
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Sensitive
+string
 \end_layout
 
 \end_inset
 
- 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
 
-.
+] The file name extension of an auxiliary file for the list of figures (or
+ whatever).
+ LaTeX writes the captions to this file.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Sensitive
+GuiName
 \end_layout
 
 \end_inset
 
- means the (hardcoded) label string depends on the kind of float.
- The 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Counter
+string
 \end_layout
 
 \end_inset
 
- label type defines automatically numbered labels.
- See Section 
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:counter"
+=
+\begin_inset Quotes erd
+\end_inset
 
+
+\begin_inset Quotes erd
 \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
@@ -10646,12 +12487,13 @@ reference "sec:counter"
 status collapsed
 
 \begin_layout Plain Layout
-LatexFooter
+HTML*
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+ These are used for XHTML output.
+ See 
 \end_layout
 
 \begin_layout Description
@@ -10659,329 +12501,273 @@ LatexFooter
 status collapsed
 
 \begin_layout Plain Layout
-LatexHeader
+LaTeXBuiltin
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
+ [
 \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"
+\emph on
+0
+\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
-LatexParagraph
+1
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
+] Set to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexParam
+1
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:LatexParam"
-
-\end_inset
-
-An optional parameter for the corresponding 
+ if the float is already defined by the LaTeX document class.
+ If this is set to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexName
+0
 \end_layout
 
 \end_inset
 
- stuff.
- This parameter cannot be changed from within LyX.
-\end_layout
-
-\begin_layout Description
+, the float will be defined using the LaTeX package 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexType
+float
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:LatexType"
-
-\end_inset
+.
+\end_layout
 
-[
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-Paragraph
-\emph default
-, Command, Environment, Item_Environment,
+ListName
 \end_layout
 
 \end_inset
 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-List_Environment
+string
 \end_layout
 
 \end_inset
 
-] How the layout should be translated into LaTeX.
-\begin_inset Flex CharStyle:Code
-status collapsed
+=
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-Paragraph
-\end_layout
 
+\begin_inset Quotes erd
 \end_inset
 
- means nothing special.
+] The heading used for the list of floats.
+ This is translated to the document language.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Command
+NumberWithin
 \end_layout
 
 \end_inset
 
- means 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-
-\emph on
-LatexName
-\emph default
-{\SpecialChar \ldots{}
-}
+string
 \end_layout
 
 \end_inset
 
- and 
-\begin_inset Flex CharStyle:Code
-status collapsed
+=
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-Environment
-\end_layout
 
+\begin_inset Quotes erd
 \end_inset
 
- means 
+] This (optional) argument determines whether floats of this class will
+ be numbered within some sectional unit of the document.
+ For example, if within is equal to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-begin{
-\emph on
-LatexName
-\emph default
-}\SpecialChar \ldots{}
-
-\backslash
-end{
-\emph on
-LatexName
-\emph default
-}
+chapter
 \end_layout
 
 \end_inset
 
-.
+, the floats will be numbered within chapters.
  
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Item_Environment
+Placement
 \end_layout
 
 \end_inset
 
- is the same as 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Environment
+string
 \end_layout
 
 \end_inset
 
-, except that a 
+=
+\begin_inset Quotes erd
+\end_inset
+
+
+\begin_inset Quotes erd
+\end_inset
+
+] The default placement for the given class of floats.
+ The string should be as in standard LaTeX: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-item
+t
 \end_layout
 
 \end_inset
 
- is generated for each paragraph of this environment.
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-List_Environment
+b
 \end_layout
 
 \end_inset
 
- is the same as 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Item_Environment
+p
 \end_layout
 
 \end_inset
 
-, except that 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelWidthString
+h
 \end_layout
 
 \end_inset
 
- is passed as an argument to the environment.
-\begin_inset Flex CharStyle:Code
+ for top, bottom, page, and here, respectively.
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
-LabelWidthString
+Note that the order of these letters in the string is irrelevant, like in
+ LaTeX.
 \end_layout
 
 \end_inset
 
- can be defined in the 
-\begin_inset Flex CharStyle:MenuItem
+ On top of that there is a new type, 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+H
+\end_layout
 
-\bar under
-L
-\bar default
-ayout\SpecialChar \menuseparator
+\end_inset
 
-\bar under
-P
-\bar default
-aragraph
-\end_layout
+, which does not really correspond to a float, since it means: put it 
+\begin_inset Quotes eld
+\end_inset
 
+here
+\begin_inset Quotes erd
 \end_inset
 
dialog.
and nowhere else.
+ Note however that the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-LatexType
+H
 \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
+ specifier is special and, because of implementation details, cannot be
+ used in non-built in float types.
+ If you do not understand what this means, just use 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Standard
-Putting the last few things together, the LaTeX output will be either: 
-\end_layout
 
-\begin_layout LyX-Code
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\backslash
-latexname[latexparam]{\SpecialChar \ldots{}
-}
+\begin_layout Plain Layout
+tbp
 \end_layout
 
-\begin_layout Standard
-or: 
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
 
-\backslash
-begin{latexname}[latexparam] \SpecialChar \ldots{}
-\backslash
-end{latexname}.
-\end_layout
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Standard
-depending upon the LaTex type.
+.
 \end_layout
 
 \begin_layout Description
@@ -10989,7 +12775,7 @@ depending upon the LaTex type.
 status collapsed
 
 \begin_layout Plain Layout
-LeftMargin
+Style
 \end_layout
 
 \end_inset
@@ -10999,322 +12785,352 @@ LeftMargin
 status collapsed
 
 \begin_layout Plain Layout
-string=""
+string
 \end_layout
 
 \end_inset
 
-] If you put layouts into environments, the leftmargins are not simply added,
- but added with a factor 
-\begin_inset Formula $\frac{4}{depth+4}$
+=
+\begin_inset Quotes erd
 \end_inset
 
-.
- Note that this parameter is also used when the margin is defined as 
+
+\begin_inset Quotes erd
+\end_inset
+
+] The style used when defining the float using 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Manual
+
+\backslash
+newfloat
 \end_layout
 
 \end_inset
 
- or 
+.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Dynamic
+Type
 \end_layout
 
 \end_inset
 
-.
- Then it is added to the manual or dynamic margin.
-\begin_inset Newline newline
-\end_inset
-
-The argument is passed as a string.
- For example 
-\begin_inset Quotes eld
-\end_inset
-
-
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-MM
+string
 \end_layout
 
 \end_inset
 
+=
+\begin_inset Quotes erd
+\end_inset
+
 
 \begin_inset Quotes erd
 \end_inset
 
- means that the paragraph is indented with the width of 
+] The 
 \begin_inset Quotes eld
 \end_inset
 
+type
+\begin_inset Quotes erd
+\end_inset
 
+ of the new class of floats, like program or algorithm.
+ After the appropriate 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-MM
+
+\backslash
+newfloat
 \end_layout
 
 \end_inset
 
+, commands such as 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Plain Layout
 
- in the normal font.
- You can get a negative width by prefixing the string with 
-\begin_inset Quotes eld
-\end_inset
+\backslash
+begin{program}
+\end_layout
 
+\end_inset
 
+ or 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
--
-\end_layout
-
-\end_inset
 
+\backslash
+end{algorithm*}
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-.
- This way was chosen so that the look is the same with each used screen
- font.
+ will be available.
 \end_layout
 
-\begin_layout Description
+\begin_layout Standard
+Note that defining a float with type 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Margin
+
+\emph on
+type
 \end_layout
 
 \end_inset
 
- [
+ automatically defines the corresponding counter with name 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
 \emph on
-Static
-\emph default
-, Manual, Dynamic, First_Dynamic, Right_Address_Box
+type
 \end_layout
 
 \end_inset
 
-] 
-\begin_inset Newline newline
+.
+\end_layout
+
+\begin_layout Subsection
+Flex insets and InsetLayout
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Flex-insets-and"
+
 \end_inset
 
-The kind of margin that the layout has on the left side.
+
+\end_layout
+
+\begin_layout Standard
+LyX has supported character styles since version 1.4.0; as of version 1.6.0,
+ these are called Flex insets.
  
+\end_layout
+
+\begin_layout Standard
+Flex insets come in three different kinds: 
+\end_layout
+
+\begin_layout Itemize
+character style (
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Static
+CharStyle
 \end_layout
 
 \end_inset
 
- just means a fixed margin.
+): These define semantic markup corresponding to such LaTeX commands as
  
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Manual
+
+\backslash
+noun
 \end_layout
 
 \end_inset
 
- means that the left margin depends on the string entered in the 
-\begin_inset Flex CharStyle:MenuItem
+ and 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
-\bar under
-E
-\bar default
-dit\SpecialChar \menuseparator
+\backslash
+code
+\end_layout
 
-\bar under
-P
-\bar default
-aragraph
-\begin_inset space ~
 \end_inset
 
-Settings
+.
+\end_layout
+
+\begin_layout Itemize
+user custom (
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Custom
 \end_layout
 
 \end_inset
 
- dialog.
This is used to typeset nice lists without tabulators.
+): 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
-Dynamic
+endnote
 \end_layout
 
 \end_inset
 
- means that the margin depends on the size of the label.
- This is used for automatic enumerated headlines.
- It is obvious that the headline 
-\begin_inset Quotes eld
-\end_inset
+ module.
+\end_layout
 
-5.4.3.2.1 Very long headline
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Itemize
+XML elements (
+\begin_inset Flex CharStyle:Code
+status collapsed
 
- must have a wider left margin (as wide as 
-\begin_inset Quotes eld
-\end_inset
+\begin_layout Plain Layout
+Element
+\end_layout
 
-5.4.3.2.1
-\begin_inset Quotes erd
 \end_inset
 
- plus the space) than 
-\begin_inset Quotes eld
-\end_inset
+): For use with DocBook classes.
+\end_layout
 
-3.2 Very long headline
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Standard
+Flex insets are defined using the 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+InsetLayout
+\end_layout
 
-, even if standard 
-\begin_inset Quotes eld
 \end_inset
 
-word processors
-\begin_inset Quotes erd
-\end_inset
+ tag, which shall be explained in a moment.
+\end_layout
 
- are not able to do this.
+\begin_layout Standard
+The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-First_Dynamic
+InsetLayout
 \end_layout
 
 \end_inset
 
- is similar, but only the very first row of the paragraph is dynamic, while
the others are static; this is used, for example, for descriptions.
+ 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
-Right_Address_Box
+InsetLayout
 \end_layout
 
 \end_inset
 
- means the margin is chosen in a way that the longest row of this paragraph
- fits to the right margin.
- This is used to typeset an address on the right edge of the page.
+ 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 Description
+\begin_layout Standard
+The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-NeedProtect
+InsetLayout
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:NeedProtect"
+ definition must begin with a line of the form:
+\end_layout
 
-\end_inset
+\begin_layout LyX-Code
+InsetLayout <Type>
+\end_layout
 
-[
+\begin_layout Standard
+Here 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-0
+<Type>
 \end_layout
 
 \end_inset
 
-,
+ 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
-1
+<Type>
 \end_layout
 
 \end_inset
 
-] Whether fragile commands in this layout should be 
+ any one of the following: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-protect
+Algorithm
 \end_layout
 
 \end_inset
 
-'ed.
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Newline
+Branch
 \end_layout
 
 \end_inset
 
- [
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-0
+Box
 \end_layout
 
 \end_inset
@@ -11324,48 +13140,47 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-1
+Box:shaded
 \end_layout
 
 \end_inset
 
-] Whether newlines are translated into LaTeX newlines (
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
+ERT
+\end_layout
 
-\backslash
+\end_inset
 
-\backslash
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
+\begin_layout Plain Layout
+Figure
 \end_layout
 
 \end_inset
 
-) or not.
- The translation can be switched off to allow more comfortable LaTeX editing
- inside LyX.
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-NextNoIndent
+Foot
 \end_layout
 
 \end_inset
 
- [
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-1
+Index
 \end_layout
 
 \end_inset
@@ -11375,245 +13190,227 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-0
+Info
 \end_layout
 
 \end_inset
 
-] Whether the following Paragraph is allowed to indent its very first row.
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-1
+Info:menu
 \end_layout
 
 \end_inset
 
- means that it is not allowed to do so; 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-0
+Info:shortcut
 \end_layout
 
 \end_inset
 
- means it could do so if it wants to.
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ObsoletedBy
+Info:shortcuts
 \end_layout
 
 \end_inset
 
- [[FIXME]]
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-OptionalArgs
+Listings
 \end_layout
 
 \end_inset
 
- [
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-int=0
+Marginal
 \end_layout
 
 \end_inset
 
-] The number of optional arguments that can be used with this layout.
- This is useful for things like section headings, and only makes sense with
- LaTeX.
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Note:Comment
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ParIndent
+Note:Note
 \end_layout
 
 \end_inset
 
- [
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string=""
+Note:GreyedOut
 \end_layout
 
 \end_inset
 
-] The indent of the very first line of a paragraph.
- The 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Parindent
+OptArg
 \end_layout
 
 \end_inset
 
- will be fixed for a certain layout.
- The exception is Standard layout, since the indentation of a Standard layout
- paragraph can be prohibited with 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-NextNoIndent
+Table
 \end_layout
 
 \end_inset
 
-.
- Also, Standard layout paragraphs inside environments use the 
+, or 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Parindent
+URL
 \end_layout
 
 \end_inset
 
- of the environment, not their native one.
- For example, Standard paragraphs inside an enumeration are not indented.
+.
 \end_layout
 
-\begin_layout Description
+\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
-Parsep
+<Type>
 \end_layout
 
 \end_inset
 
- [
+ can be any valid identifier not used by a pre-existing inset.
+ Note that the definition of a flex inset 
+\emph on
+must 
+\emph default
+also include a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-float=0
+LyXType
 \end_layout
 
 \end_inset
 
-] The vertical space between two paragraphs of this layout.
+ entry, declaring which type of inset this is.
 \end_layout
 
-\begin_layout Description
+\begin_layout Standard
+The 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Parskip
+InsetLayout
 \end_layout
 
 \end_inset
 
- [
+ definition can contain the following entries:
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-float=0
+BgColor
 \end_layout
 
 \end_inset
 
-] LyX allows the user to choose either 
-\begin_inset Quotes eld
-\end_inset
-
-indent
-\begin_inset Quotes erd
-\end_inset
-
- or 
-\begin_inset Quotes eld
-\end_inset
-
-skip
-\begin_inset Quotes erd
-\end_inset
+ The color for the inset's background.
+ The valid colors are defined in 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
- to typeset a document.
- When 
-\begin_inset Quotes eld
-\end_inset
+\begin_layout Plain Layout
+src/ColorCode.h
+\end_layout
 
-indent
-\begin_inset Quotes erd
 \end_inset
 
- is chosen, this value is completely ignored.
- When 
-\begin_inset Quotes eld
-\end_inset
+.
+\end_layout
 
-skip
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
- is chosen, the parindent of a LaTeXtype 
-\begin_inset Quotes eld
-\end_inset
+\begin_layout Plain Layout
+ContentAsLabel
+\end_layout
 
-Paragraph
-\begin_inset Quotes erd
 \end_inset
 
- layout is ignored and all paragraphs are separated by this parskip argument.
- The vertical space is calculated with 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-value
-\begin_inset space ~
-\end_inset
 
-* DefaultHeight
+\emph on
+0
 \end_layout
 
 \end_inset
 
- where 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-DefaultHeight
+1
 \end_layout
 
 \end_inset
 
- is the height of a row with the normal font.
- This way, the look stays the same with different screen fonts.
+] Whether to use the content of the inset as the label, when the inset is
+ closed.
+ Default is false.
 \end_layout
 
 \begin_layout Description
@@ -11621,21 +13418,32 @@ DefaultHeight
 status collapsed
 
 \begin_layout Plain Layout
-PassThru
+CopyStyle
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:PassThru"
+ As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "des:CopyStyle"
 
 \end_inset
 
-[
-\emph on
+).
+\end_layout
+
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+CustomPars
+\end_layout
 
+\end_inset
+
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -11647,9 +13455,7 @@ status collapsed
 
 \end_inset
 
-
-\emph default
-, 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -11659,8 +13465,8 @@ status collapsed
 
 \end_inset
 
-] Whether the contents of this paragraph should be output in raw form, meaning
without special translations that LaTeX would require.
+] Indicates whether the user may employ the Paragraph Settings dialog to
customize the paragraph.
 \end_layout
 
 \begin_layout Description
@@ -11668,132 +13474,166 @@ status collapsed
 status collapsed
 
 \begin_layout Plain Layout
-Preamble
+Decoration
 \end_layout
 
 \end_inset
 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:Preamble"
+ can be 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
+Classic
+\end_layout
 
-Information to be included in the LaTeX preamable when this style is used.
- Used to define macros, load packages, etc., required by this particular
- style.
- Must end with 
-\begin_inset Quotes eld
 \end_inset
 
-
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-EndPreamble
+Minimalistic
 \end_layout
 
 \end_inset
 
+, or 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_inset Quotes erd
-\end_inset
-
-.
+\begin_layout Plain Layout
+Conglomerate
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+, describing the rendering style used for the inset's frame and buttons.
+ Footnotes generally use 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Requires 
+Classic
 \end_layout
 
 \end_inset
 
-[
+, ERT insets generally 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+Minimalistic
 \end_layout
 
 \end_inset
 
-] 
-\begin_inset CommandInset label
-LatexCommand label
-name "des:Requires"
+, and character styles 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Conglomerate
+\end_layout
 
 \end_inset
 
-Whether the layout requires the feature 
+.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+End
 \end_layout
 
 \end_inset
 
-.
- See the description of 
+ Required at the end of the InsetLayout declarations.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Provides
+Font
 \end_layout
 
 \end_inset
 
- above (page 
+ The font used for both the text body 
+\emph on
+and
+\emph default
+ the label.
+ See section
+\begin_inset space ~
+\end_inset
+
+
 \begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:FreeSpacing"
+LatexCommand ref
+reference "sub:Font-description"
 
 \end_inset
 
-) for information on `features'.
-\end_layout
-
-\begin_layout Description
+.
+ Note that defining this font automatically defines the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-RightMargin
+LabelFont
 \end_layout
 
 \end_inset
 
- [
+ to the same value, so define this first and define 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string=""
+LabelFont
 \end_layout
 
 \end_inset
 
-] Similar to 
+ later if you want them to be different.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LeftMargin
+ForceLTR
 \end_layout
 
 \end_inset
 
-.
+ Force the 
+\begin_inset Quotes eld
+\end_inset
+
+latex
+\begin_inset Quotes erd
+\end_inset
+
+ language, leading to Left-to-Right (latin) output, e.
+\begin_inset space \thinspace{}
+\end_inset
+
+g.
+\begin_inset space \space{}
+\end_inset
+
+in TeX code or URL.
+ A kludge.
 \end_layout
 
 \begin_layout Description
@@ -11801,7 +13641,7 @@ LeftMargin
 status collapsed
 
 \begin_layout Plain Layout
-Spacing
+ForcePlain
 \end_layout
 
 \end_inset
@@ -11813,84 +13653,99 @@ status collapsed
 \begin_layout Plain Layout
 
 \emph on
-single
-\emph default
-, onehalf, double, other
+0
 \end_layout
 
 \end_inset
 
-\emph on
-value
-\emph default
-] This defines what the default spacing should be in the layout.
- The arguments 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-single
+1
 \end_layout
 
 \end_inset
 
-, 
+] Indicates whether the PlainLayout should be used or, instead, the user
+ can change the paragraph style used in the inset.
+ Default is false.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-onehalf
+FreeSpacing
 \end_layout
 
 \end_inset
 
- and 
+ As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:FreeSpacing"
+
+\end_inset
+
+).
+ Default is false.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-double
+HTML*
 \end_layout
 
 \end_inset
 
- correspond respectively to a multiplier value of 1, 1.25 and 1.667.
- If you specify the argument 
+ These tags control XHTML output.
+ See 
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-other
+InToc
 \end_layout
 
 \end_inset
 
-, then you should also provide a numerical argument which will be the actual
- multiplier value.
- Note that, contrary to other parameters, 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Spacing
+
+\emph on
+0
 \end_layout
 
 \end_inset
 
- implies the generation of specific LaTeX code, using the package 
-\family roman
-
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-setspace.sty
+1
 \end_layout
 
 \end_inset
 
-.
+] 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
@@ -11898,20 +13753,20 @@ setspace.sty
 status collapsed
 
 \begin_layout Plain Layout
-TextFont
+KeepEmpty
 \end_layout
 
 \end_inset
 
- The font used for the text body .
- See section 
+ As with paragraph styles (see page 
 \begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:fonts"
+LatexCommand pageref
+reference "des:KeepEmpty"
 
 \end_inset
 
-.
+).
+ Default is false.
 \end_layout
 
 \begin_layout Description
@@ -11919,15 +13774,35 @@ reference "sec:fonts"
 status collapsed
 
 \begin_layout Plain Layout
+LabelFont
+\end_layout
 
-\series medium
-TocLevel [int]
+\end_inset
+
+ The font used for the label.
+ See section
+\begin_inset space ~
+\end_inset
+
+
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Font-description"
+
+\end_inset
+
+.
+ Note that this definition can never appear before 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+Font
 \end_layout
 
 \end_inset
 
- The level of the style in the table of contents.
- This is used for automatic numbering of section headings.
+, lest it be ineffective.
 \end_layout
 
 \begin_layout Description
@@ -11935,83 +13810,81 @@ TocLevel [int]
 status collapsed
 
 \begin_layout Plain Layout
-TopSep
+LabelString
 \end_layout
 
 \end_inset
 
- [
+ 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_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-float=0
+LatexName
 \end_layout
 
 \end_inset
 
-] The vertical space with which the very first of a chain of paragraphs
- with this layout is separated from the previous paragraph.
- If the previous paragraph has another layout, the separations are not simply
- added, but the maximum is taken.
+ The name of the corresponding LaTeX stuff.
+ Either the environment or command name.
 \end_layout
 
-\begin_layout Subsection
-Floats
-\end_layout
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Standard
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:floats"
+\begin_layout Plain Layout
+LatexParam
+\end_layout
 
 \end_inset
 
-Since version 1.3.0 of LyX, it is has been both possible and necessary to
- define the floats (
-\begin_inset Flex CharStyle:MenuItem
+ The optional parameter for the corresponding 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-figure
+LatexName
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
+ stuff, including possible bracket pairs like 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-table
+[]
 \end_layout
 
 \end_inset
 
-, \SpecialChar \ldots{}
-) in the text class itself.
- Standard floats are included in the file 
+.
+ This parameter cannot be changed from within LyX.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-stdfloats.inc
+LatexType
 \end_layout
 
 \end_inset
 
-, so you may have to do no more than add
-\end_layout
+ As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:LatexType"
 
-\begin_layout LyX-Code
-Input stdfloats.inc
-\end_layout
+\end_inset
 
-\begin_layout Standard
-to your layout file.
- If you want to implement a text class that proposes some other float types
- (like the AGU class bundled with LyX), the information below will hopefully
- help you:
+).
 \end_layout
 
 \begin_layout Description
@@ -12019,63 +13892,54 @@ to your layout file.
 status collapsed
 
 \begin_layout Plain Layout
-Extension
+LyxType 
 \end_layout
 
 \end_inset
 
- [
+ Can be 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+charstyle
 \end_layout
 
 \end_inset
 
-=
-\begin_inset Quotes erd
-\end_inset
-
-
-\begin_inset Quotes erd
-\end_inset
-
-] The file name extension of an auxiliary file for the list of figures (or
- whatever).
- LaTeX writes the captions to this file.
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-GuiName
+custom
 \end_layout
 
 \end_inset
 
- [
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+element
 \end_layout
 
 \end_inset
 
-=
-\begin_inset Quotes erd
-\end_inset
+, or 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
+\begin_layout Plain Layout
+end
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-] The string that will be used in the menus and also for the caption.
+ (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
@@ -12083,7 +13947,7 @@ string
 status collapsed
 
 \begin_layout Plain Layout
-LaTeXBuiltin
+MultiPar
 \end_layout
 
 \end_inset
@@ -12100,7 +13964,7 @@ status collapsed
 
 \end_inset
 
-, 
+,
 \begin_inset Flex CharStyle:Code
 status collapsed
 
@@ -12110,38 +13974,44 @@ status collapsed
 
 \end_inset
 
-] Set to 
+] Whether multiple paragraphs are permitted in this inset.
+ This will also set 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-1
+CustomPars
 \end_layout
 
 \end_inset
 
- if the float is already defined by the LaTeX document class.
- If this is set to 
+ to the same value and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-0
+ForcePlain
 \end_layout
 
 \end_inset
 
-, the float will be defined using the LaTeX package 
+ to the opposite value.
+ These can be reset to other values, if they are used 
+\emph on
+after
+\emph default
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-float
+MultiPar
 \end_layout
 
 \end_inset
 
 .
+ Default is true.
 \end_layout
 
 \begin_layout Description
@@ -12149,7 +14019,7 @@ float
 status collapsed
 
 \begin_layout Plain Layout
-ListName
+NeedProtect
 \end_layout
 
 \end_inset
@@ -12159,20 +14029,41 @@ ListName
 status collapsed
 
 \begin_layout Plain Layout
-string
+
+\emph on
+0
 \end_layout
 
 \end_inset
 
-=
-\begin_inset Quotes erd
+,
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+1
+\end_layout
+
 \end_inset
 
+] Whether fragile commands in this layout should be 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+
+\backslash
+protect
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-] The heading used for the list of floats.
+'ed.
+ (Note: This is 
+\emph on
+not
+\emph default
+ whether the command should itself be protected.) Default is false.
 \end_layout
 
 \begin_layout Description
@@ -12180,7 +14071,7 @@ string
 status collapsed
 
 \begin_layout Plain Layout
-NumberWithin
+PassThru
 \end_layout
 
 \end_inset
@@ -12190,33 +14081,52 @@ NumberWithin
 status collapsed
 
 \begin_layout Plain Layout
-string
+
+\emph on
+0
 \end_layout
 
 \end_inset
 
-=
-\begin_inset Quotes erd
+,
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+1
+\end_layout
+
 \end_inset
 
+] As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:PathThru"
 
-\begin_inset Quotes erd
 \end_inset
 
-] This (optional) argument determines whether floats of this class will
- be numbered within some sectional unit of the document.
- For example, if within is equal to 
+).
+ Default is false.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-chapter
+Preamble
 \end_layout
 
 \end_inset
 
-, the floats will be numbered within chapters.
+ As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:Preamble"
+
+\end_inset
+
+).
 \end_layout
 
 \begin_layout Description
@@ -12224,7 +14134,7 @@ chapter
 status collapsed
 
 \begin_layout Plain Layout
-Placement
+Requires 
 \end_layout
 
 \end_inset
@@ -12239,488 +14149,507 @@ string
 
 \end_inset
 
-=
-\begin_inset Quotes erd
+] As with paragraph styles (see page 
+\begin_inset CommandInset ref
+LatexCommand pageref
+reference "des:Requires"
+
 \end_inset
 
+).
+\end_layout
+
+\begin_layout Subsection
+Counters
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Counters"
 
-\begin_inset Quotes erd
 \end_inset
 
-] The default placement for the given class of floats.
- The string should be as in standard LaTeX: 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-t
 \end_layout
 
-\end_inset
-
-, 
-\begin_inset Flex CharStyle:Code
+\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 Plain Layout
-b
+chapter
 \end_layout
 
 \end_inset
 
 , 
-\begin_inset Flex CharStyle:Code
+\begin_inset Flex CharStyle:MenuItem
 status collapsed
 
 \begin_layout Plain Layout
-p
+figure
 \end_layout
 
 \end_inset
 
- and 
+, \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
-h
+stdcounters.inc
 \end_layout
 
 \end_inset
 
- for top, bottom, page, and here, respectively.
-\begin_inset Foot
-status collapsed
+, so you may have to do no more than add
+\end_layout
 
-\begin_layout Plain Layout
-Note that the order of these letters in the string is irrelevant, like in
- LaTeX.
+\begin_layout LyX-Code
+Input stdcounters.inc
 \end_layout
 
-\end_inset
+\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
 
- On top of that there is a new type, 
+\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
-H
+CounterName
 \end_layout
 
 \end_inset
 
-, which does not really correspond to a float, since it means: put it 
+' is replaced by the name of the counter.
+ And it must end with 
 \begin_inset Quotes eld
 \end_inset
 
-here
-\begin_inset Quotes erd
-\end_inset
 
- and nowhere else.
- Note however that the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-H
+End
 \end_layout
 
 \end_inset
 
- specifier is special and, because of implementation details, cannot be
- used in non-builtin float types.
- If you do not understand what this means, just use 
-\begin_inset Quotes eld
+
+\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
-tbp
+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
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-.
+ to the same value.
+ The following special constructs can be used in the string:
 \end_layout
 
-\begin_layout Description
+\begin_deeper
+\begin_layout Itemize
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Style
+
+\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
-string
+LabelString
 \end_layout
 
 \end_inset
 
-=
-\begin_inset Quotes erd
-\end_inset
+ (or 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
+\begin_layout Plain Layout
+LabelStringAppendix
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-] The style used when defining the float using 
+) of the counter 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-newfloat
+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
-Type
+
+\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
-string
-\end_layout
 
-\end_inset
+\emph on
+numbertype
+\end_layout
 
-=
-\begin_inset Quotes erd
 \end_inset
 
+ can be:
+\begin_inset Foot
+status collapsed
 
-\begin_inset Quotes erd
-\end_inset
+\begin_layout Plain Layout
 
-] The 
-\begin_inset Quotes eld
-\end_inset
+\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
 
-type
-\begin_inset Quotes erd
 \end_inset
 
- of the new class of floats, like program or algorithm.
- After the appropriate 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-newfloat
+arabic
 \end_layout
 
 \end_inset
 
-, commands such as 
+: 1, 2, 3,\SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-begin{program}
+alph
 \end_layout
 
 \end_inset
 
- or 
+ for lower-case letters: a, b, c, \SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-end{algorithm*}
+Alph
 \end_layout
 
 \end_inset
 
- will be available.
-\end_layout
-
-\begin_layout Standard
-Note that defining a float with type 
+ for upper-case letters: A, B, C, \SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-type
+roman
 \end_layout
 
 \end_inset
 
- automatically defines the corresponding counter with name 
+ for lower-case roman numerals: i, ii, iii, \SpecialChar \ldots{}
+; 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-type
+Roman
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+ for upper-case roman numerals: I, II, III\SpecialChar \ldots{}
+; 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Subsection
-Inset layouts and Flex insets
+\begin_layout Plain Layout
+hebrew
 \end_layout
 
-\begin_layout Standard
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:charstyle"
-
 \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.
+ for hebrew numerals.
 \end_layout
 
+\end_deeper
 \begin_layout Standard
-Flex insets come in three different kinds: 
-\end_layout
-
-\begin_layout Itemize
-character style (
+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
-CharStyle
+master
 \end_layout
 
 \end_inset
 
-): These define semantic markup corresponding to such LaTeX commands as
+ (defined via 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-noun
+Within
 \end_layout
 
 \end_inset
 
- and 
+), the string 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
 
 \backslash
-code
+themaster.
+\backslash
+arabic{counter}
 \end_layout
 
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Itemize
-user custom (
+ is used; otherwise the string 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Custom
+
+\backslash
+arabic{counter}
 \end_layout
 
 \end_inset
 
-): These can be used to define custom collapsable insets, similar to ERT,
- footnote, and the like.
+ is used.
 \end_layout
 
-\begin_layout Itemize
-XML elements (
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Element
+LabelStringAppendix [string=""]
 \end_layout
 
 \end_inset
 
-): For use with DocBook classes.
-\end_layout
-
-\begin_layout Standard
-The 
+ Same as 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-InsetLayout
+LabelString
 \end_layout
 
 \end_inset
 
- definition starting line is of the form
-\end_layout
-
-\begin_layout LyX-Code
-InsetLayout <Type> <Name>
+, but for use in the Appendix.
 \end_layout
 
-\begin_layout Standard
-where 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-<Type>
+Within
 \end_layout
 
 \end_inset
 
- can be 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Algorithm
+string
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
+=
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-Branch
-\end_layout
 
+\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
-Box
+subsection
 \end_layout
 
 \end_inset
 
-, 
+ is numbered inside 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ERT
+section
 \end_layout
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-Figure
+.
 \end_layout
 
+\begin_layout Subsection
+Font description
+\begin_inset CommandInset label
+LatexCommand label
+name "sub:Font-description"
+
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-Foot
 \end_layout
 
-\end_inset
-
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-Index
+\begin_layout Standard
+A font description looks like this:
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+Font 
+\family roman
+\emph on
+or
+\family default
+\emph default
+ LabelFont
+\end_layout
 
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+ ...
+\end_layout
 
-\begin_layout Plain Layout
-Listings
+\begin_layout LyX-Code
+EndFont
 \end_layout
 
-\end_inset
+\begin_layout Standard
+The following commands are available:
+\end_layout
 
-, 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Marginal
+Color
 \end_layout
 
 \end_inset
 
-, 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Note:Comment
+
+\emph on
+none
 \end_layout
 
 \end_inset
@@ -12730,7 +14659,7 @@ Note:Comment
 status collapsed
 
 \begin_layout Plain Layout
-Note:Note
+black
 \end_layout
 
 \end_inset
@@ -12740,7 +14669,7 @@ Note:Note
 status collapsed
 
 \begin_layout Plain Layout
-Note:GreyedOut
+white
 \end_layout
 
 \end_inset
@@ -12750,7 +14679,7 @@ Note:GreyedOut
 status collapsed
 
 \begin_layout Plain Layout
-OptArg
+red
 \end_layout
 
 \end_inset
@@ -12760,7 +14689,7 @@ OptArg
 status collapsed
 
 \begin_layout Plain Layout
-Table
+green
 \end_layout
 
 \end_inset
@@ -12770,78 +14699,76 @@ Table
 status collapsed
 
 \begin_layout Plain Layout
-URL
+blue
 \end_layout
 
 \end_inset
 
-, or 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Flex
+cyan
 \end_layout
 
 \end_inset
 
-.
- If 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-<Type>
+magenta
 \end_layout
 
 \end_inset
 
- is 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Flex
+yellow
 \end_layout
 
 \end_inset
 
-, then 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-<Name>
+]
 \end_layout
 
-\end_inset
-
- should have the form 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-SubType:StyleName
+Family
 \end_layout
 
 \end_inset
 
-, where 
+ [
+\emph on
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-SubType
+
+\emph on
+Roman
 \end_layout
 
 \end_inset
 
- is either 
+
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-CharStyle
+Sans
 \end_layout
 
 \end_inset
@@ -12851,89 +14778,70 @@ CharStyle
 status collapsed
 
 \begin_layout Plain Layout
-Custom
+Typewriter
 \end_layout
 
 \end_inset
 
-, or 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-Element
+] 
 \end_layout
 
-\end_inset
-
-, and 
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-StyleName
+Misc
 \end_layout
 
 \end_inset
 
- is any valid identifier.
-\end_layout
-
-\begin_layout Standard
-The following 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-InsetLayout
+string
 \end_layout
 
 \end_inset
 
- section can contain the following entries:
-\end_layout
-
-\begin_layout Description
+] Valid arguments are: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-BgColor
+emph
 \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
+noun
 \end_layout
 
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Decoration
+underbar
 \end_layout
 
 \end_inset
 
- can be 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Classic
+no_emph
 \end_layout
 
 \end_inset
@@ -12943,53 +14851,62 @@ Classic
 status collapsed
 
 \begin_layout Plain Layout
-Minimalistic
+no_noun
 \end_layout
 
 \end_inset
 
-, or 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Conglomerate
+no_bar
 \end_layout
 
 \end_inset
 
-, describing the rendering style used for the inset's frame and buttons.
- Footnotes generally use 
+.
+ Each of these turns on or off the corresponding attribute.
+ For example, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Classic
+emph
 \end_layout
 
 \end_inset
 
-; ERT insets generally use 
+ turns on emphasis, and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Minimalistic
+no_emph
 \end_layout
 
 \end_inset
 
-; and character styles use 
+ 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
-Conglomerate
+no_emph
 \end_layout
 
 \end_inset
 
-.
+ would turn off the emphasis that was anyway in effect, say, in a theorem
+ environment.
 \end_layout
 
 \begin_layout Description
@@ -12997,62 +14914,38 @@ Conglomerate
 status collapsed
 
 \begin_layout Plain Layout
-Font
+Series
 \end_layout
 
 \end_inset
 
- The font used for both the text body 
+ [
 \emph on
-and
-\emph default
- the label.
- See section
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:fonts"
-
-\end_inset
 
-.
- Note that defining this font automatically defines the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelFont
-\end_layout
-
-\end_inset
-
- to the same value, so define this first and define 
-\begin_inset Flex CharStyle:Code
-status collapsed
 
-\begin_layout Plain Layout
-LabelFont
+\emph on
+Medium
 \end_layout
 
 \end_inset
 
- later if you want them to be different.
-\end_layout
 
-\begin_layout Description
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-ForceLTR
+Bold
 \end_layout
 
 \end_inset
 
- [[FIXME]]
+] 
 \end_layout
 
 \begin_layout Description
@@ -13060,103 +14953,58 @@ ForceLTR
 status collapsed
 
 \begin_layout Plain Layout
-FreeSpacing
+Shape
 \end_layout
 
 \end_inset
 
- As with paragraph styles (see page 
-\begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:FreeSpacing"
-
-\end_inset
-
-).
-\end_layout
+ [
+\emph on
 
-\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
+\emph on
+Up
 \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
+\emph default
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelFont
+Italic
 \end_layout
 
 \end_inset
 
- The font used for the label.
- See section
-\begin_inset space ~
-\end_inset
-
-
-\begin_inset CommandInset ref
-LatexCommand ref
-reference "sec:fonts"
-
-\end_inset
-
-.
- Note that this definition can never appear before 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Font
+SmallCaps
 \end_layout
 
 \end_inset
 
-, lest it be ineffective.
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexName
+Slanted
 \end_layout
 
 \end_inset
 
- The name of the corresponding LaTeX stuff.
- Either the environment or command name.
+] 
 \end_layout
 
 \begin_layout Description
@@ -13164,71 +15012,59 @@ LatexName
 status collapsed
 
 \begin_layout Plain Layout
-LatexParam
+Size
 \end_layout
 
 \end_inset
 
- The optional parameter for the corresponding 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LatexName
+tiny
 \end_layout
 
 \end_inset
 
- stuff, including possible bracket pairs like 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-[]
+small
 \end_layout
 
 \end_inset
 
-.
- This parameter cannot be changed from within LyX.
-\end_layout
-
-\begin_layout Description
+, 
 \begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-LatexType
-\end_layout
-
-\end_inset
-
- As with paragraph styles (see page 
-\begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:LatexType"
+status collapsed
 
-\end_inset
+\begin_layout Plain Layout
 
-).
+\emph on
+normal
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyxType 
+large
 \end_layout
 
 \end_inset
 
- Can be 
+, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-charstyle
+larger
 \end_layout
 
 \end_inset
@@ -13238,7 +15074,7 @@ charstyle
 status collapsed
 
 \begin_layout Plain Layout
-custom
+largest
 \end_layout
 
 \end_inset
@@ -13248,7 +15084,7 @@ custom
 status collapsed
 
 \begin_layout Plain Layout
-element
+huge
 \end_layout
 
 \end_inset
@@ -13258,384 +15094,371 @@ element
 status collapsed
 
 \begin_layout Plain Layout
-end
+giant
 \end_layout
 
 \end_inset
 
- (indicating a dummy definition ending definitions of charstyles etc.).
- This entry is only meaningful for Flex (user definable) insets.
+]
 \end_layout
 
-\begin_layout Description
+\begin_layout Section
+\begin_inset CommandInset label
+LatexCommand label
+name "sec:Tags-for-XHTML"
+
+\end_inset
+
+Tags for XHTML output
+\end_layout
+
+\begin_layout Standard
+As with LaTeX or DocBook, the format of LyX's XHTML output is also controlled
+ by layout information.
+ In general, LyX provides sensible defaults and, as mentioned earlier, it
+ will even construct default CSS style rules from the other layout tags.
+ For example, LyX will attempt to use the information provided in the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Preamble
+Font
 \end_layout
 
 \end_inset
 
- As with paragraph styles (see page 
-\begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:Preamble"
-
-\end_inset
+ declaration for the Chapter style to write CSS that will appropriately
+ format chapter headings.
+\end_layout
 
-).
+\begin_layout Standard
+In many cases, then, you may not have to do anything at all to get acceptable
+ XHTML output for your own environments, custom insets, and so forth.
+ But in some cases you will, and so LyX provides a number of layout tags
+ that can be used to customize the XHTML and CSS that are generated.
 \end_layout
 
-\begin_layout Description
+\begin_layout Standard
+Note that there are two tags, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Requires 
+HTMLPreamble
 \end_layout
 
 \end_inset
 
- [
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+AddToHTMLPreamble
 \end_layout
 
 \end_inset
 
-] As with paragraph styles (see page 
+ that may appear outside style and inset declarations.
+ See 
 \begin_inset CommandInset ref
-LatexCommand pageref
-reference "des:Requires"
+LatexCommand prettyref
+reference "sub:General-text-class"
 
 \end_inset
 
-).
+ for details on these.
 \end_layout
 
 \begin_layout Subsection
-Counters
-\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
+name "sub:Paragraph-Style-XHTML"
 
 \end_inset
 
-, 
-\begin_inset Flex CharStyle:MenuItem
-status collapsed
-
-\begin_layout Plain Layout
-figure
+Paragraph styles
 \end_layout
 
-\end_inset
-
-, \SpecialChar \ldots{}
-) in the text class itself.
- The standard counters are defined in the file 
+\begin_layout Standard
+The sort of XHTML LyX outputs for a paragraph depends upon whether we are
+ dealing with a normal paragraph, a command, or an environment, where this
+ is itself determined by the contents of the corresponding 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-stdcounters.inc
+LaTeXType
 \end_layout
 
 \end_inset
 
-, so you may have to do no more than add
-\end_layout
-
-\begin_layout LyX-Code
-Input stdcounters.inc
+ tag.
 \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:
+For a command or normal paragraph, the output XHTML has the following form:
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+<tag attr=
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-LabelString [string=""]
+value
+\begin_inset Quotes erd
+\end_inset
+
+>
 \end_layout
 
+\begin_layout LyX-Code
+<labeltag attr=
+\begin_inset Quotes erd
 \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
+value
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-LabelStringAppendix
+>Label</labeltag>
 \end_layout
 
-\end_inset
-
- to the same value.
- The following special constructs can be used in the string:
+\begin_layout LyX-Code
+Contents of the paragraph.
 \end_layout
 
-\begin_deeper
-\begin_layout Itemize
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
+</tag>
+\end_layout
 
-\begin_layout Plain Layout
+\begin_layout Standard
+The label tags are of course omitted if the paragraph does not have a label.
+\end_layout
 
-\backslash
-thecounter
+\begin_layout Standard
+For an environment that is not some sort of list, the XHTML takes this form:
 \end_layout
 
+\begin_layout LyX-Code
+<tag attr=
+\begin_inset Quotes erd
 \end_inset
 
- will be replaced by the expansion of the 
-\begin_inset Flex CharStyle:Code
-status collapsed
+value
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-LabelString
+>
 \end_layout
 
+\begin_layout LyX-Code
+<itemtag attr=
+\begin_inset Quotes erd
 \end_inset
 
- (or 
-\begin_inset Flex CharStyle:Code
-status collapsed
+value
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-LabelStringAppendix
-\end_layout
+><labeltag attr=
+\begin_inset Quotes erd
+\end_inset
 
+value
+\begin_inset Quotes erd
 \end_inset
 
-) of the counter 
-\begin_inset Flex CharStyle:Code
-status collapsed
+>Environment Label</labeltag>First paragraph.</itemtag>
+\end_layout
 
-\begin_layout Plain Layout
-counter
+\begin_layout LyX-Code
+<itemtag>Second paragraph.</itemtag>
 \end_layout
 
-\end_inset
+\begin_layout LyX-Code
+</tag>
+\end_layout
 
-.
+\begin_layout Standard
+Note that the label is output only for the first paragraph, as it should
+ be for a theorem, for example.
  
 \end_layout
 
-\begin_layout Itemize
-counter values can be expressed using LaTeX-like macros 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Standard
+For a list, we have one of these forms:
+\end_layout
 
-\begin_layout Plain Layout
+\begin_layout LyX-Code
+<tag attr=
+\begin_inset Quotes erd
+\end_inset
 
-\backslash
+value
+\begin_inset Quotes erd
+\end_inset
 
-\emph on
-numbertype
-\emph default
-{
-\emph on
-counter
-\emph default
-}
+>
 \end_layout
 
+\begin_layout LyX-Code
+<itemtag attr=
+\begin_inset Quotes erd
 \end_inset
 
-, where 
-\begin_inset Flex CharStyle:Code
-status collapsed
+value
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
+><labeltag attr=
+\begin_inset Quotes erd
+\end_inset
 
-\emph on
-numbertype
+value
+\begin_inset Quotes erd
+\end_inset
+
+>List Label</labeltag>First item.</itemtag>
 \end_layout
 
+\begin_layout LyX-Code
+<itemtag attr=
+\begin_inset Quotes erd
 \end_inset
 
- can be:
-\begin_inset Foot
-status collapsed
-
-\begin_layout Plain Layout
+value
+\begin_inset Quotes erd
+\end_inset
 
-\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.
-\end_layout
+><labeltag attr=
+\begin_inset Quotes erd
+\end_inset
 
+value
+\begin_inset Quotes erd
 \end_inset
 
-\begin_inset Flex CharStyle:Code
-status collapsed
+>List Label</labeltag>Second item.</itemtag>
+\end_layout
 
-\begin_layout Plain Layout
-arabic
+\begin_layout LyX-Code
+</tag>
 \end_layout
 
-\end_inset
-
-: 1, 2, 3,\SpecialChar \ldots{}
-; 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout LyX-Code
 
-\begin_layout Plain Layout
-alph
 \end_layout
 
+\begin_layout LyX-Code
+<tag attr=
+\begin_inset Quotes erd
 \end_inset
 
- for lower-case letters: a, b, c, \SpecialChar \ldots{}
-; 
-\begin_inset Flex CharStyle:Code
-status collapsed
+value
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-Alph
+>
 \end_layout
 
+\begin_layout LyX-Code
+<labeltag attr=
+\begin_inset Quotes erd
 \end_inset
 
- for upper-case letters: A, B, C, \SpecialChar \ldots{}
-; 
-\begin_inset Flex CharStyle:Code
-status collapsed
-
-\begin_layout Plain Layout
-roman
-\end_layout
+value
+\begin_inset Quotes erd
+\end_inset
 
+>List Label</labeltag><itemtag attr=
+\begin_inset Quotes erd
 \end_inset
 
- for lower-case roman numerals: i, ii, iii, \SpecialChar \ldots{}
-; 
-\begin_inset Flex CharStyle:Code
-status collapsed
+value
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-Roman
+>First item.</itemtag>
 \end_layout
 
+\begin_layout LyX-Code
+<labeltag attr=
+\begin_inset Quotes erd
 \end_inset
 
- for upper-case roman numerals: I, II, III\SpecialChar \ldots{}
-; 
-\begin_inset Flex CharStyle:Code
-status collapsed
+value
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout Plain Layout
-hebrew
-\end_layout
+>List Label</labeltag><itemtag attr=
+\begin_inset Quotes erd
+\end_inset
 
+value
+\begin_inset Quotes erd
 \end_inset
 
- for hebrew numerals.
+>Second item.</itemtag>
+\end_layout
+
+\begin_layout LyX-Code
+</tag>
 \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 
+Note the different orders of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-master
+labeltag
 \end_layout
 
 \end_inset
 
- (defined via 
+ and 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Within
+itemtag
 \end_layout
 
 \end_inset
 
-), the string 
+.
+ Which order we get depends upon the setting of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-themaster.
-\backslash
-arabic{counter}
+HTMLLabelFirst
 \end_layout
 
 \end_inset
 
- is used; otherwise the string 
+: If 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-arabic{counter}
+HTMLLabelFirst
 \end_layout
 
 \end_inset
 
- is used.
+ is false (the default), you get the first of these, with the label within
+ the item; if true, you get the second, with the label outside the item.
+\end_layout
+
+\begin_layout Standard
+The specific tags and attributes output for each paragraph type can be controlle
+d by means of the layout tags we are about to describe.
+ As mentioned earlier, however, LyX uses sensible defaults for many of these,
+ so you often may not need to do very much to get good XHTML output.
+ Think of the available tags as there so you can tweak things to your liking.
 \end_layout
 
 \begin_layout Description
@@ -13643,53 +15466,70 @@ arabic{counter}
 status collapsed
 
 \begin_layout Plain Layout
-LabelStringAppendix [string=""]
+HTMLAttr
 \end_layout
 
 \end_inset
 
- Same as 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LabelString
+string
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+] Specifies attribute information to be output with the main tag.
+ For example, 
+\begin_inset Quotes eld
+\end_inset
+
 
-\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Name
+class=`mydiv'
 \end_layout
 
 \end_inset
 
- [
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ By default, LyX will output 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+class=`layoutname'
 \end_layout
 
 \end_inset
 
-=
+
 \begin_inset Quotes erd
 \end_inset
 
+, where 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+layoutname
+\end_layout
 
-\begin_inset Quotes erd
 \end_inset
 
-] The name of the counter.
+ is the LyX name of the layout, made lowercase, for example: chapter.
 \end_layout
 
 \begin_layout Description
@@ -13697,7 +15537,7 @@ string
 status collapsed
 
 \begin_layout Plain Layout
-Within
+HTMLForceCSS
 \end_layout
 
 \end_inset
@@ -13707,183 +15547,177 @@ Within
 status collapsed
 
 \begin_layout Plain Layout
-string
+0,1
 \end_layout
 
 \end_inset
 
-=
-\begin_inset Quotes erd
-\end_inset
-
-
-\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, 
+] Whether to output the default CSS information LyX generates for this layout,
+ even if additional information is explicitly provided via 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-subsection
+HTMLStyle
 \end_layout
 
 \end_inset
 
- is numbered inside 
+.
+ Setting this to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-section
+1
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+ allows you to alter or augment the generated CSS, rather than to override
+ it completely.
+ Default is 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout Subsection
-Font description
+\begin_layout Plain Layout
+0
 \end_layout
 
-\begin_layout Standard
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:fonts"
-
 \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 Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-EndFont
+\begin_layout Plain Layout
+HTMLItem
 \end_layout
 
-\begin_layout Standard
-The following commands are available:
-\end_layout
+\end_inset
 
-\begin_layout Description
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Color
+string
 \end_layout
 
 \end_inset
 
- [
+] The tag to be used for individual paragraphs of environments, replacing
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-none
+itemtag
 \end_layout
 
 \end_inset
 
-, 
+ in the examples above.
+ Defaults to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-black
+div
 \end_layout
 
 \end_inset
 
-, 
+.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-white
+HTMLItemAttr
 \end_layout
 
 \end_inset
 
-, 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-red
+string
 \end_layout
 
 \end_inset
 
-, 
+] Attributes for the item tag.
+ Defaults to 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-green
+class=`layoutname_item'
 \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
-blue
+HTMLLabel
 \end_layout
 
 \end_inset
 
-, 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-cyan
+string
 \end_layout
 
 \end_inset
 
-, 
+] The tag to be used for paragraph and item labels, replacing 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-magenta
+labeltag
 \end_layout
 
 \end_inset
 
-, 
+ in the examples above.
+ Defaults to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-yellow
+span
 \end_layout
 
 \end_inset
 
-]
+.
 \end_layout
 
 \begin_layout Description
@@ -13891,132 +15725,158 @@ yellow
 status collapsed
 
 \begin_layout Plain Layout
-Family
+HTMLLabelAttr
 \end_layout
 
 \end_inset
 
  [
-\emph on
-
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-Roman
+string
 \end_layout
 
 \end_inset
 
+] Attributes for the label tag.
+ Defaults to 
+\begin_inset Quotes eld
+\end_inset
+
 
-\emph default
-, 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Sans
+class=`layoutname_label'
 \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
-Typewriter
+HTMLLabelFirst
 \end_layout
 
 \end_inset
 
-] 
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+0,1
 \end_layout
 
-\begin_layout Description
+\end_inset
+
+] Meaningful only for list-like environments, this tag controls whether
+ the label tag is output before or inside the item tag.
+ This is used, for example, in the description environment, where we want
+ `
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Misc
+<dt>\SpecialChar \ldots{}
+</dt><dd>\SpecialChar \ldots{}
+</dd>
 \end_layout
 
 \end_inset
 
- [
+.
+ Default is 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-string
+0
 \end_layout
 
 \end_inset
 
-] Valid argument sare: 
+: The label tag is output inside the item tag.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-emph
+HTMLPreamble
 \end_layout
 
 \end_inset
 
-, 
+ Information to be output in the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-noun
+<head>
 \end_layout
 
 \end_inset
 
-, 
+ section when this style is used.
+ This might, for example, be used to include a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-underbar
+<script>
 \end_layout
 
 \end_inset
 
-, 
+ block defining an 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-no_emph
+onclick
 \end_layout
 
 \end_inset
 
-, 
+ handler.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-no_noun
+HTMLStyle
 \end_layout
 
 \end_inset
 
- and 
+ CSS style information to be included when this style is used.
+ Note that this will automatically be wrapped in a layout-generated 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-no_bar
+<style>
 \end_layout
 
 \end_inset
 
-.
- Each of these turns on or off the corresponding attribute.
+ block, so only the CSS itself need be included.
 \end_layout
 
 \begin_layout Description
@@ -14024,97 +15884,150 @@ no_bar
 status collapsed
 
 \begin_layout Plain Layout
-Series
+HTMLTag
 \end_layout
 
 \end_inset
 
  [
-\emph on
-
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-Medium
+string
 \end_layout
 
 \end_inset
 
-
-\emph default
-, 
+] The tag to be used for the main label, replacing 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Bold
+tag
 \end_layout
 
 \end_inset
 
-] 
-\end_layout
-
-\begin_layout Description
+ in the examples above.
+ Defaults to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Shape
+div
 \end_layout
 
 \end_inset
 
- [
-\emph on
+.
+\end_layout
 
-\begin_inset Flex CharStyle:Code
+\begin_layout Subsection
+InsetLayout XHTML
+\end_layout
+
+\begin_layout Standard
+The XHTML output of insets can also be controlled by information in layout
+ files.
+\begin_inset Foot
 status collapsed
 
 \begin_layout Plain Layout
+At present, this is true only for 
+\begin_inset Quotes eld
+\end_inset
 
-\emph on
-Up
+text
+\begin_inset Quotes erd
+\end_inset
+
+ insets (insets you can type into) and is not true for 
+\begin_inset Quotes eld
+\end_inset
+
+command
+\begin_inset Quotes erd
+\end_inset
+
+ insets (insets that are associated with dialog boxes).
 \end_layout
 
 \end_inset
 
+ Here, too, LyX tries to provide sensible defaults, and it constructs default
+ CSS style rules.
+ But everything can be customized.
+\end_layout
 
-\emph default
-, 
-\begin_inset Flex CharStyle:Code
-status collapsed
+\begin_layout Standard
+The XHTML LyX outputs for an inset has the following form:
+\end_layout
 
-\begin_layout Plain Layout
-Italic
+\begin_layout LyX-Code
+<tag attr=
+\begin_inset Quotes erd
+\end_inset
+
+value
+\begin_inset Quotes erd
+\end_inset
+
+>
 \end_layout
 
+\begin_layout LyX-Code
+<labeltag>Label</labeltag>
+\end_layout
+
+\begin_layout LyX-Code
+<innertag attr=
+\begin_inset Quotes erd
+\end_inset
+
+value
+\begin_inset Quotes erd
 \end_inset
 
-, 
+>Contents of the inset.</innertag>
+\end_layout
+
+\begin_layout LyX-Code
+</tag>
+\end_layout
+
+\begin_layout Standard
+If the inset permits multiple paragraphs---that is, if 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-SmallCaps
+MultiPar
 \end_layout
 
 \end_inset
 
-, 
+ is true---then the contents of the inset will itself be output as paragraphs
+ formatted according to the styles used for those paragraphs (standard,
+ quote, and the like).
+ The label tag is of course omitted if the paragraph does not have a label
+ and, at present, is always 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Slanted
+span
 \end_layout
 
 \end_inset
 
-] 
+.
+ The inner tag is optional and, by default, does not appear.
+\end_layout
+
+\begin_layout Standard
+The specific tags and attributes output for each inset can be controlled
+ by means of the following layout tags.
 \end_layout
 
 \begin_layout Description
@@ -14122,7 +16035,7 @@ Slanted
 status collapsed
 
 \begin_layout Plain Layout
-Size
+HTMLAttr
 \end_layout
 
 \end_inset
 status collapsed
 
 \begin_layout Plain Layout
-tiny
+string
 \end_layout
 
 \end_inset
 
-, 
+] Specifies attribute information to be output with the main tag.
+ For example, 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-small
+class=`myinset' onclick=`\SpecialChar \ldots{}
+'
 \end_layout
 
 \end_inset
 
-, 
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+ By default, LyX will output 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\emph on
-normal
+class=`insetname'
 \end_layout
 
 \end_inset
 
-, 
+
+\begin_inset Quotes erd
+\end_inset
+
+, where 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-large
+insetname
 \end_layout
 
 \end_inset
 
-, 
+ is the LyX name of the inset, made lowercase and with non-alphanumeric
+ characters converted to underscores, for example: footnote.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-larger
+HTMLForceCSS
 \end_layout
 
 \end_inset
 
-, 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-largest
+
+\emph on
+0
+\emph default
+,1
 \end_layout
 
 \end_inset
 
-, 
+] Whether to output the default CSS information LyX generates for this layout,
+ even if additional information is explicitly provided via 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-huge
+HTMLStyle
 \end_layout
 
 \end_inset
 
-, 
+.
+ Setting this to 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-giant
+1
 \end_layout
 
 \end_inset
 
-]
+ allows you to alter or augment the generated CSS, rather than to override
+ it completely.
+ Default is 0.
 \end_layout
 
-\begin_layout Subsection
-Upgrading old layout files
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+HTMLInnerAttr
 \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 
+\end_inset
+
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/scripts/layout2layout.py
+string
 \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
+] Attributes for the inner tag.
+ Defaults to 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout LyX-Code
-python $LyXDir/scripts/layout2layout.py myclass.layout myclassnew.layout
-\end_layout
 
-\begin_layout Standard
-(You need to replace 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-$LyXDir
+class=`insetname_inner'
 \end_layout
 
 \end_inset
 
- with the name of your LyX system directory, unless you happen to have defined
- such an environment variable.) Then copy 
+
+\begin_inset Quotes erd
+\end_inset
+
+.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-myclassnew.layout
+HTMLInnerTag
 \end_layout
 
 \end_inset
 
- to 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/layouts/
+string
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+] The inner tag, replacing 
+\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
+innertag
 \end_layout
 
-\begin_layout Section
-Creating Templates
-\begin_inset CommandInset label
-LatexCommand label
-name "sec:templates"
-
 \end_inset
 
-
+ in the examples above.
+ By default, there is none.
 \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
+HTMLIsBlock
 \end_layout
 
 \end_inset
 
- or 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\backslash
-papersize
+0,
+\emph on
+1
 \end_layout
 
 \end_inset
 
- from the template LyX file.
- This can be done with any simple text-editor, for example 
+] Whether this inset represents a standalone block of text (such as a footnote)
+ or instead represents material that is included in the surrounding text
+ (such as a branch).
+ Defaults to 1.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-vi
+HTMLLabel
 \end_layout
 
 \end_inset
 
- or 
+ [
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-xedit
+string
 \end_layout
 
 \end_inset
 
-.
-\end_layout
-
-\begin_layout Standard
-Put the edited template files you create in 
+] A label for this inset, possibly including a reference to a counter.
+ For example, for footnote, it might be: 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-UserDir/templates/
+
+\backslash
+arabic{footnote}
 \end_layout
 
 \end_inset
 
-, copy the ones you use from the global template directory in 
+.
+ This is optional, and there is no default.
+\end_layout
+
+\begin_layout Description
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-LyXDir/templates/
+HTMLPreamble
 \end_layout
 
 \end_inset
 
to the same place, and redefine the template path in the 
-\begin_inset Flex CharStyle:MenuItem
Information to be output in the 
+\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
+<head>
 \end_layout
 
 \end_inset
 
- dialog.
-\end_layout
-
-\begin_layout Standard
-Note that there is a template which has a particular meaning: 
+ section when this style is used.
+ This might, for example, be used to include a 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-defaults.lyx
+<script>
 \end_layout
 
 \end_inset
 
-.
- This template is loaded everytime you create a new document with 
-\begin_inset Flex CharStyle:MenuItem
+ block defining an 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-F
-\bar default
-ile
+onclick
 \end_layout
 
 \end_inset
 
-\SpecialChar \menuseparator
+ handler.
+\end_layout
 
-\begin_inset Flex CharStyle:MenuItem
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-
-\bar under
-N
-\bar default
-ew
+HTMLStyle
 \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
+ CSS style information to be included when this style is used.
+ Note that this will automatically be wrapped in a layout-generated 
+\begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Sa
-\bar under
-v
-\bar default
-e as Document Defaults
+<style>
 \end_layout
 
 \end_inset
 
- button.
+ block, so only the CSS itself need be included.
 \end_layout
 
-\begin_layout Chapter
-Including External Material
-\end_layout
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\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.
+\begin_layout Plain Layout
+HTMLTag
 \end_layout
 
-\begin_layout Section
-How does it work?
-\end_layout
+\end_inset
 
-\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_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Insert\SpecialChar \menuseparator
-File\SpecialChar \menuseparator
-External Material
+string
 \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
-
-\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 
+] The tag to be used for the main label, replacing 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Xfig
+tag
 \end_layout
 
 \end_inset
 
-.
- The Xfig application itself works on an original file with the 
+ in the examples above.
+ The default depends upon the setting of 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.fig
+MultiPar
 \end_layout
 
 \end_inset
 
- extension.
- Within XFig, you create and change your figure, and when you are done,
- you save the 
+: If 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-fig
+MultiPar
 \end_layout
 
 \end_inset
 
--file.
- When you want to include the figure in your document, you invoke 
+ is true, the default is 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-transfig
+div
 \end_layout
 
 \end_inset
 
- in order to create a PostScript file that can readily be included in your
- LaTeX file.
- In this case, the 
+; if it is false, the default is 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-.fig
+span
 \end_layout
 
 \end_inset
 
- file is the original file, and the PostScript file is the produced file.
+.
 \end_layout
 
-\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 Subsection
+Float XHTML
 \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
-
-\begin_layout Section
-The external template configuration file
+The XHTML output for floats too can be controlled by layout information.
+ The output has the following form:
 \end_layout
 
-\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 LyX-Code
+<tag attr=
+\begin_inset Quotes erd
+\end_inset
 
+value
+\begin_inset Quotes erd
 \end_inset
 
-.
+>
+\end_layout
+
+\begin_layout LyX-Code
+Contents of the float.
+\end_layout
+
+\begin_layout LyX-Code
+</tag>
 \end_layout
 
 \begin_layout Standard
-Having said that, we encourage you to submit any interesting templates that
- you create.
+The caption, if there is one, is a separate inset and will be output as
+ such.
+ Its appearance can be controlled via the InsetLayout for caption insets.
  
 \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
+HTMLAttr
 \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
+string
 \end_layout
 
 \end_inset
 
-.
-\end_layout
+] Specifies attribute information to be output with the main tag.
+ For example, 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout Standard
-A typical template looks like this:
-\end_layout
 
-\begin_layout LyX-Code
-Template XFig
-\end_layout
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-GuiName "XFig: $$AbsOrRelPathParent$$Basename"
+\begin_layout Plain Layout
+class=`myfloat' onclick=`\SpecialChar \ldots{}
+'
 \end_layout
 
-\begin_layout LyX-Code
-HelpText
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-An XFig figure.
-\end_layout
 
-\begin_layout LyX-Code
-HelpTextEnd
-\end_layout
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout LyX-Code
-InputFormat fig
-\end_layout
+.
+ By default, LyX will output 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout LyX-Code
-FileFilter "*.fig"
-\end_layout
 
-\begin_layout LyX-Code
-AutomaticProduction true
-\end_layout
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Transform Rotate
+\begin_layout Plain Layout
+class=`float float-floattype'
 \end_layout
 
-\begin_layout LyX-Code
-Transform Resize
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-Format LaTeX
-\end_layout
 
-\begin_layout LyX-Code
-TransformCommand Rotate RotationLatexCommand
-\end_layout
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout LyX-Code
-TransformCommand Resize ResizeLatexCommand
-\end_layout
+, where 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Product "$$RotateFront$$ResizeFront
+\begin_layout Plain Layout
+floattype
 \end_layout
 
-\begin_layout LyX-Code
-         
-\backslash
+\end_inset
 
-\backslash
-input{$$AbsOrRelPathMaster$$Basename.pstex_t}
-\end_layout
+ is LyX's name for this type of float, as determined by the float delcaration
+ (see 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Floats"
 
-\begin_layout LyX-Code
-         $$ResizeBack$$RotateBack"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-UpdateFormat pstex
+), though made lowercase and with non-alphanumeric characters converted
+ to underscores, for example: float-table.
 \end_layout
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.pstex_t"
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+HTMLStyle
 \end_layout
 
-\begin_layout LyX-Code
-Requirement "graphicx"
+\end_inset
+
+ CSS style information to be included when this float is used.
+ Note that this will automatically be wrapped in a layout-generated 
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+<style>
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pstex_t"
+\end_inset
+
+ block, so only the CSS itself need be included.
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsPath$$Basename.eps"
+\begin_layout Description
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+HTMLTag
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile dvi "$$AbsPath$$Basename.eps"
+\end_inset
+
+ [
+\begin_inset Flex CharStyle:Code
+status collapsed
+
+\begin_layout Plain Layout
+string
 \end_layout
 
-\begin_layout LyX-Code
-FormatEnd
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-Format PDFLaTeX
-\end_layout
+] The tag to be used for this float, replacing 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout LyX-Code
-TransformCommand Rotate RotationLatexCommand
-\end_layout
 
-\begin_layout LyX-Code
-TransformCommand Resize ResizeLatexCommand
-\end_layout
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Product "$$RotateFront$$ResizeFront
+\begin_layout Plain Layout
+tag
 \end_layout
 
-\begin_layout LyX-Code
-         
-\backslash
+\end_inset
 
-\backslash
-input{$$AbsOrRelPathMaster$$Basename.pdftex_t}
-\end_layout
 
-\begin_layout LyX-Code
-         $$ResizeBack$$RotateBack"
-\end_layout
+\begin_inset Quotes erd
+\end_inset
 
-\begin_layout LyX-Code
-UpdateFormat pdftex
-\end_layout
+ in the example above.
+ The default is 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.pdftex_t"
+\begin_layout Plain Layout
+div
 \end_layout
 
-\begin_layout LyX-Code
-Requirement "graphicx"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsOrRelPathMaster$$Basename.pdftex_t"
+ and will rarely need changing.
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile latex "$$AbsPath$$Basename.pdf"
+\begin_layout Subsection
+LyX-generated CSS
 \end_layout
 
-\begin_layout LyX-Code
-FormatEnd
+\begin_layout Standard
+We have several times mentioned that LyX will generate default CSS style
+ rules for both insets and paragraph styles, based upon the other layout
+ information that is provided.
+ In this section, we shall say a word about which layout information LyX
+ uses and how.
 \end_layout
 
-\begin_layout LyX-Code
-Format Ascii
-\end_layout
+\begin_layout Standard
+At present, LyX auto-generates CSS only for font information, making use
+ of the 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Product "$$Contents(
-\backslash
-"$$AbsPath$$Basename.asc
-\backslash
-")"
+\begin_layout Plain Layout
+Family
 \end_layout
 
-\begin_layout LyX-Code
-UpdateFormat asciixfig
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.asc"
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-FormatEnd
+\begin_layout Plain Layout
+Series
 \end_layout
 
-\begin_layout LyX-Code
-Format DocBook
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-Product "<graphic fileref=
-\backslash
-"$$AbsOrRelPathMaster$$Basename.eps
-\backslash
-">
-\end_layout
+, 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-         </graphic>"
+\begin_layout Plain Layout
+Shape
 \end_layout
 
-\begin_layout LyX-Code
-UpdateFormat eps
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-UpdateResult "$$AbsPath$$Basename.eps"
-\end_layout
+, and 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-ReferencedFile docbook "$$AbsPath$$Basename.eps"
+\begin_layout Plain Layout
+Size
 \end_layout
 
-\begin_layout LyX-Code
-ReferencedFile docbook-xml "$$AbsPath$$Basename.eps"
-\end_layout
+\end_inset
 
-\begin_layout LyX-Code
-FormatEnd
-\end_layout
+ specified in the 
+\begin_inset Flex CharStyle:Code
+status collapsed
 
-\begin_layout LyX-Code
-Product "[XFig: $$FName]"
+\begin_layout Plain Layout
+Font
 \end_layout
 
-\begin_layout LyX-Code
-FormatEnd
-\end_layout
+\end_inset
+
+ declaration.
+ (See 
+\begin_inset CommandInset ref
+LatexCommand ref
+reference "sub:Font-description"
+
+\end_inset
+
+.) The translation is mostly straightforward and obvious.
+ For example, 
+\begin_inset Quotes eld
+\end_inset
 
-\begin_layout LyX-Code
-TemplateEnd
-\end_layout
 
-\begin_layout Standard
-As you can see, the template is enclosed in 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Template
+Family Sans
 \end_layout
 
 \end_inset
 
- \SpecialChar \ldots{}
+
+\begin_inset Quotes erd
+\end_inset
+
+ becomes 
+\begin_inset Quotes eld
+\end_inset
+
+
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-TemplateEnd
+font-family: sans-serif;
 \end_layout
 
 \end_inset
 
+
+\begin_inset Quotes erd
+\end_inset
+
 .
- It contains a header specifying some general settings and, for each supported
- primary document file format, a section 
+ The correspondence of LyX sizes and CSS sizes is a little less obvious
+ but nonetheless intuitive.
+ See the 
 \begin_inset Flex CharStyle:Code
 status collapsed
 
 \begin_layout Plain Layout
-Format
+getSizeCSS()
 \end_layout
 
 \end_inset
 
- \SpecialChar \ldots{}
-\begin_inset Flex CharStyle:Code
+ function in 
+\begin_inset Flex URL
 status collapsed
 
 \begin_layout Plain Layout
-FormatEnd
+
+src/FontInfo.cpp
 \end_layout
 
 \end_inset
 
-.
+ for the details.
 \end_layout
 
-\begin_layout Subsection
-The template header
+\begin_layout Chapter
+Including External Material
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
-status collapsed
+\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
-AutomaticProduction
-\begin_inset space ~
+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
 
-true|false
+
 \end_layout
 
-\end_inset
+\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
 
- Whether the file represented by the template must be generated by LyX.
- This command must occur exactly once.
+\begin_layout Section
+How does it work?
 \end_layout
 
-\begin_layout Description
-\begin_inset Flex CharStyle:Code
+\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
@@ -15336,13 +17249,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
@@ -15350,23 +17266,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
@@ -15374,120 +17284,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
@@ -15495,21 +17360,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
@@ -15517,59 +17384,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
@@ -15577,49 +17449,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
 
@@ -15630,40 +17502,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
@@ -15671,69 +17546,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
@@ -15741,12 +17630,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
@@ -15754,36 +17649,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
@@ -15791,25 +17714,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
@@ -15817,14 +17745,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
@@ -15832,66 +17768,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
@@ -15899,12 +17857,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
@@ -15912,25 +17879,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
@@ -15938,73 +17917,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
@@ -16012,12 +17998,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
@@ -16025,49 +18011,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
 
@@ -16077,713 +18029,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