class LaTeXFont {
public:
/// TeX font
- LaTeXFont() : osfdefault_(false), switchdefault_(false) {}
+ // FIXME Add fontenc tag to classes which is used if no font is specified?
+ LaTeXFont() : osfdefault_(false), switchdefault_(false), moreopts_(false),
+ osffontonly_(false) { fontenc_.push_back("T1"); }
/// The font name
docstring const & name() { return name_; }
/// The name to appear in the document dialog
docstring const & family() { return family_; }
/// The package that provides this font
docstring const & package() { return package_; }
+ /// Does this provide a specific font encoding?
+ bool hasFontenc(std::string const &) const;
+ /// The font encoding(s)
+ std::vector<std::string> const & fontencs() const { return fontenc_; }
/// Alternative font if package() is not available
std::vector<docstring> const & altfonts() { return altfonts_; }
/// A font that provides all families
docstring const & ot1font() { return ot1font_; }
/// A font that provides Old Style Figures for this type face
docstring const & osffont() { return osffont_; }
- /// A package option needed to load this font
- docstring const & packageoption() { return packageoption_; }
/// A package option for Old Style Figures
docstring const & osfoption() { return osfoption_; }
/// A package option for true SmallCaps
docstring const & osfscoption() { return osfscoption_; }
/// A package option for font scaling
docstring const & scaleoption() { return scaleoption_; }
+ /// A macro for font scaling
+ docstring const & scalecmd() { return scalecmd_; }
+ /// Does this provide additional options?
+ bool providesMoreOptions(bool ot1, bool complete, bool nomath);
/// Alternative requirement to test for
- docstring const & requires() { return requires_; }
+ docstring const & required() { return required_; }
/// Does this font provide a given \p feature
bool provides(std::string const & name, bool ot1,
bool complete, bool nomath);
bool switchdefault() const { return switchdefault_; }
/// Does the font provide Old Style Figures as default?
bool osfDefault() const { return osfdefault_; }
+ /// Does OSF font replace (rather than complement) the non-OSF one?
+ bool osfFontOnly() const { return osffontonly_; }
/// Is this font available?
bool available(bool ot1, bool nomath);
- /// Does this font provide an alternative without math?
+ /// Does this font provide an alternative without math?
bool providesNoMath(bool ot1, bool complete);
/// Does this font provide Old Style Figures?
bool providesOSF(bool ot1, bool complete, bool nomath);
/// Does this font provide optional true SmallCaps?
bool providesSC(bool ot1, bool complete, bool nomath);
- /** does this font provide OSF and Small Caps only via
+ /** does this font provide OSF and Small Caps only via
* a single, undifferentiated expert option?
*/
bool hasMonolithicExpertSet(bool ot1, bool complete, bool nomath);
/// Return the LaTeX Code
std::string const getLaTeXCode(bool dryrun, bool ot1, bool complete,
bool sc, bool osf, bool nomath,
+ std::string const & extraopts = std::string(),
int const & scale = 100);
/// Return the actually used font
- docstring const getUsedFont(bool ot1, bool complete, bool nomath);
+ docstring const getUsedFont(bool ot1, bool complete, bool nomath, bool osf);
/// Return the actually used package
docstring const getUsedPackage(bool ot1, bool complete, bool nomath);
///
///
bool readFont(Lexer & lex);
private:
- /// Return the preferred available package
+ /// Return the preferred available package
std::string const getAvailablePackage(bool dryrun);
/// Return the package options
std::string const getPackageOptions(bool ot1,
bool sc,
bool osf,
int scale,
+ std::string const & extraopts,
bool nomath);
/// Return an alternative font
LaTeXFont altFont(docstring const & name);
///
docstring package_;
///
+ std::vector<std::string> fontenc_;
+ ///
std::vector<docstring> altfonts_;
///
docstring completefont_;
///
docstring osffont_;
///
- docstring packageoption_;
+ docstring packageoptions_;
///
docstring osfoption_;
///
///
docstring scaleoption_;
///
+ docstring scalecmd_;
+ ///
std::vector<std::string> provides_;
///
- docstring requires_;
+ docstring required_;
///
docstring preamble_;
///
bool osfdefault_;
///
bool switchdefault_;
+ ///
+ bool moreopts_;
+ ///
+ bool osffontonly_;
};
-
-
+
+
/** The list of available LaTeX fonts
*/
class LaTeXFonts {