X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=lib%2Fchkconfig.ltx;h=eef69b1151da99fdaa5d7b0c2c30f12dd6e78730;hb=81a3abd0cd3ae4c42ac3d987bab67ec58613c47c;hp=19dff8bb67938fb804332976fdd6109386863371;hpb=fc7c77587f85368b5ef86d75fe4c202c1f58a158;p=lyx.git diff --git a/lib/chkconfig.ltx b/lib/chkconfig.ltx index 19dff8bb67..eef69b1151 100644 --- a/lib/chkconfig.ltx +++ b/lib/chkconfig.ltx @@ -1,5 +1,5 @@ % This is chkconfig.ltx, a script which tries to autodetect and -% document your LaTeX configuration. +% document your LaTeX configuration. % Author: Jean-Marc Lasgouttes (Jean-Marc.Lasgouttes@inria.fr) % with minimal changes by Asger Alstrup (alstrup@diku.dk). % @@ -15,10 +15,10 @@ %%% LaTeX code below to help improving chkconfig.ltx :-) %%% %%% If you want to add the new package , all you need most of -%%% the times is a two-steps work: +%%% the times is a two-steps work: %%% 1- Add the command \TestPackage{}. The syntax is: %%% \TestPackage[]{}, which tests whether .sty -%%% (or , if this optional parameter is provided) exists. +%%% (or , if this optional parameter is provided) exists. %%% 2- Add a description for in doc/LyXConfig.lyx.in, %%% containing in particular a line like %%% Found @chk_@ @@ -35,28 +35,20 @@ % we do not want to stop on errors \nonstopmode\makeatletter -% Have we been called from the configure script? -\@ifundefined{srcdir} - {\message{% -**** WARNING: For proper results, you should not run this script directly.^^J% -**** Please use the `configure' script.^^J} - \newcommand\srcdir{.}} - {\def\input@path{{\srcdir/}}} %%% Some useful macros. % Several commands are defined to test for packages: % \AddLayout{} adds an entry for in textclass.lst % \AddVariable{}{} creates a new variable chk_, % and gives it the value . -% \TestDocClass[]{} tests whether .cls (or , -% if it is provided) exists and creates a new entry with -% \AddLayout if this is the case. Note that you will probably not -% need to use this directly, since the configure script generates -% the needed macro calls automatically. +% \TestDocClass{}{} if layout has not already +% been tested for, execute . Note that you will +% probably not need to use this directly, since the configure +% script generates the needed macro calls automatically. % \TestPackage[]{} tests whether .sty (or , -% if it is provided) exists. +% if it is provided) exists. % Both commands call \AddVariable to give value 'yes' or 'no' to -% the variable chk_. +% the variable chk_. %%% \newcommand{\prefix}{+} % the character used by grep to filter 'good' output \newcommand{\AddLayout}[4][\default]{ @@ -95,30 +87,25 @@ \fi} \newcommand{\TestPackage}[2][\default]{ \TestItem[#1]{#2}{package}{sty}{\AddPackage{#2}}{}} -\newcommand{\TestDocClass}[1]{ +\newcommand{\TestDocClass}[2]{ \def\layoutname{#1} % remember the name of the layout file \@ifundefined{layout@#1} - {\bgroup - \catcode`\#=9 % consider # as a space - \input{layouts/#1.layout} % read the layout file - \egroup - \global\@namedef{layout@#1}{}} + {#2 % execute the command + \global\@namedef{layout@#1}{}} {} % we have already tried this one. } \newcommand{\DeclareLaTeXClass}[2][\default]{ \TestItem[#1]{\layoutname}{document class}{cls} {\AddLayout[\firstelement]{\layoutname}{#2}{true}} {\AddLayout[\firstelement]{\layoutname}{#2}{false}} - \expandafter\endinput } \newcommand{\DeclareLinuxDocClass}[2][\default]{ \message{^^J\prefix checking for linuxdoc class \layoutname... } \@ifundefined{haslinuxdoc} - {\message{no^^J} + {\message{no^^J} \AddLayout[#1]{\layoutname}{#2}{false}} {\message{yes^^J} \AddLayout[#1]{\layoutname}{#2}{true}} - \expandafter\endinput } % Only for compatibility. Will be removed later. \let\DeclareSGMLClass=\DeclareDocBookClass @@ -130,7 +117,6 @@ \AddLayout[#1]{\layoutname}{#2}{false}} {\message{yes^^J} \AddLayout[#1]{\layoutname}{#2}{true}} - \expandafter\endinput } % Stolen from article.cls @@ -166,6 +152,25 @@ \message{^^J\prefix checking for LaTeX version... \fmtversion} \AddVariable{fmtversion}{\fmtversion} +%%% And now, the list of available languages +% The trick is to know that \the\everyjob contains something like +% \typeout{LaTeX2e <2001/06/01>} +% \typeout{Babel and hyphenation patterns for american, french, german, ngerman, nohyphenation, loaded.} +% All we have to do is to extract the list from there: +% (1) concatenate all the messages that are displayed everytime the +% format is loaded. The is done by redefining locally \typeout to +% append its argument to the macro \mesg. +\def\mesg{} +{\def\typeout#1{\xdef\mesg{\mesg #1}} + \the\everyjob} +% (2) strip the useless parts from \mesg. This uses the fact that TeX +% allows to define macros with parameters delimited by arbitrary text. +\def\strip#1patterns for #2, loaded.#3\endmark{\def\langs{#2}} +\expandafter\strip\mesg\endmark +% (3) handle the result +\message{^^J\prefix checking for available hyphenation patterns... \langs} +\AddVariable{languages}{\langs} + %%% Check for ec fonts. Most of this code has been shamelessely stolen %%% from the file ltxcheck.tex in the LaTeX distribution. In particular, %%% don't ask me how the macro \ecrm works... @@ -210,25 +215,27 @@ %%% Packages -\TestPackage{a4} -\TestPackage{a4wide} +\TestPackage{algorithm} \TestPackage{array} \TestPackage{babel} +\TestPackage{bibtopic} \TestPackage{color} % this one should be there if graphics.sty is there. +\TestPackage{dvipost} +\TestPackage{fancybox} \TestPackage{fancyhdr} \TestPackage{floatflt} -\TestPackage{setspace} -\TestPackage{subfigure} \TestPackage{geometry} +\TestPackage{jurabib} +\TestPackage{latex8} \TestPackage{longtable} -\TestPackage{algorithm} +\TestPackage{natbib} +\TestPackage{prettyref} +\TestPackage{preview} \TestPackage{rotating} -\TestPackage{latex8} -\TestPackage{url} +\TestPackage{setspace} +\TestPackage{subfigure} \TestPackage{varioref} -\TestPackage{prettyref} -\TestPackage{natbib} -\TestPackage{dvipost} +\TestPackage{url} % The test for the graphics package is slightly more involved... \newcommand\groption{dvips} @@ -246,7 +253,7 @@ % psnfss is in fact the name of a set of style files, among which % times.sty. If times.sty is here, we will assume that everything is -% fine. +% fine. \TestPackage[times.sty]{psnfss} %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%