X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FLaTeXFeatures.h;h=92279ebfc0963767bb2896f86c5407151c5e11aa;hb=98c966c64594611e469313314abd1e59524adb4a;hp=2825c2bf2289ecc8774208184cc6acb87eaec77d;hpb=74b224fcba406f4ea4d1f1fa91a63aea39ca2712;p=lyx.git diff --git a/src/LaTeXFeatures.h b/src/LaTeXFeatures.h index 2825c2bf22..92279ebfc0 100644 --- a/src/LaTeXFeatures.h +++ b/src/LaTeXFeatures.h @@ -1,11 +1,11 @@ // -*- C++ -*- /* This file is part of -* ====================================================== -* +* ====================================================== +* * LyX, The Document Processor -* +* * Copyright 1995 Matthias Ettrich -* Copyright 1995-2000 the LyX Team. +* Copyright 1995-2001 the LyX Team. * * ====================================================== */ @@ -17,118 +17,84 @@ #pragma interface #endif -#include -#include +#include "support/types.h" #include "LString.h" -#include "layout.h" -class BufferParams; +#include +#include +#include +#include + +class BufferParams; struct Language; -/** The packages and commands that a buffer needs. This struct - contains an entry for each of the latex packages and - commands that a buffer might need. This struct is supposed to be - extended as the need arises. Remember to update the validate function - in buffer.C and paragraph.C when you do so. +/** The packages and commands that a buffer needs. This class + contains a list. Each of the LaTeX packages that a buffer needs + should be added with void require(string const & name). + + i.e require("amssymb") + + To add support you should only need to require() the package name as + packages which don't have special requirements are handled automatically. + If your new package does need special consideration you'll need to alter + string const getPackages() const; + Remember to update the validate function in buffer.C and paragraph.C + when you do so. */ -struct LaTeXFeatures { +class LaTeXFeatures { +public: /// - LaTeXFeatures(BufferParams const &, LyXTextClass::size_type n) ; - /// The packaes needed by the document - string const getPackages(); + LaTeXFeatures(BufferParams const &); + /// The packages needed by the document + string const getPackages() const; /// The macros definitions needed by the document - string const getMacros(); + string const getMacros() const; /// The definitions needed by the document's textclass - string const getTClassPreamble(); - /// - string const getIncludedFiles(string const fname) const; - - /// - void showStruct(); - + string const getTClassPreamble() const; + /// The sgml definitions needed by the document (dobook/linuxdoc) + string const getLyXSGMLEntities() const; + /// The SGML Required to include the files added with includeFile(); + string const getIncludedFiles(string const & fname) const; + /// Include a file for use with the SGML entities + void includeFile(string const & key, string const & name); + /// The float definitions. + void getFloatDefinitions(std::ostream & os) const; + /// Print requirements to lyxerr + void showStruct() const; + /// + void addExternalPreamble(string const &); /// Provide a string name-space to the requirements void require(string const & name); - - /// Static preamble bits from the external material insets - string externalPreambles; - - /// - bool array; - /// - bool color; // color.sty - /// - bool graphicx; // graphicx.sty - /// - bool graphics; // graphics.sty - /// - bool setspace; // setspace.sty - /// - bool makeidx; // makeind.sty - /// - bool verbatim; // verbatim.sty + /// Is the package required? + bool isRequired(string const & name) const; /// - bool longtable; // longtable.sty + void useFloat(string const & name); /// - bool algorithm; // algorithm.sty + void useLanguage(Language const *); /// - bool rotating; // rotating.sty + bool hasLanguages(); /// - bool amssymb; // amssymb.sty + string getLanguages() const; /// - bool latexsym; // latexsym.sty + std::set getEncodingSet(string const & doc_encoding); /// - bool pifont; // pifont.sty + void useLayout(string const & lyt); /// - bool subfigure; // subfigure.sty - /// - bool floatflt; // floatflt.sty - /// - bool url; // url.sty - /// - bool varioref; // varioref.sty - /// - bool prettyref; // prettyref.sty + BufferParams const & bufferParams() const; /// - bool chess; // chess.sty - /// - bool lyx; - /// - bool lyxline; - /// \noun - bool noun; - /// \lyxarrow - bool lyxarrow; +private: + string externalPreambles; - /// - bool quotesinglbase; - /// - bool quotedblbase; - /// - bool guilsinglleft; - /// - bool guilsinglright; - /// - bool guillemotleft; - /// - bool guillemotright; + std::set layout; - /// - bool amsstyle; - /// - bool boldsymbol; - /// - bool binom; - - std::vector layout; + /// Static preamble bits from the external material insets + + typedef std::list FeaturesList; /// - bool LyXParagraphIndent; - /// - bool NeedLyXFootnoteCode; - /// - bool NeedLyXMinipageIndent; + FeaturesList features; /// typedef std::set LanguageList; /// @@ -142,8 +108,6 @@ struct LaTeXFeatures { /// FileMap IncludedFiles; /// - BufferParams const & bufferParams() const; -private: /// BufferParams const & params; };