/***************************************************************************
texcode.h - description
-------------------
begin : Mit Jul 24 2002
copyright : (C) 2002 by Andr�Simon
email : andre.simon1@gmx.de
***************************************************************************/
/*
This file is part of Highlight.
Highlight is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Highlight is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Highlight. If not, see .
*/
#ifndef TEXGENERATOR_H
#define TEXGENERATOR_H
#include
#include "codegenerator.h"
namespace highlight
{
/**
\brief This class generates TeX.
It contains information about the resulting document structure (document
header and footer), the colour system, white space handling and text
formatting attributes.
* @author Andre Simon
*/
class TexGenerator : public highlight::CodeGenerator
{
public:
TexGenerator();
~TexGenerator();
private:
/** prints document header
*/
string getHeader();
/** Prints document footer*/
string getFooter();
/** Prints document body*/
void printBody();
/** initialize tags in specific format according to colouring information provided in DucumentStyle */
void initOutputTags();
string styleDefinitionCache;
string getStyleDefinition();
/** \return escaped character*/
virtual string maskCharacter ( unsigned char );
/**\return text formatting attributes in RTF format */
string getAttributes ( const string & elemName, const ElementStyle & elem );
/** @param styleID current style ID
@return matching sequence to begin a new element formatting*/
string getKeywordOpenTag ( unsigned int styleID );
/** @param styleID current style ID
@return matching sequence to stop element formatting*/
string getKeywordCloseTag ( unsigned int styleID );
};
}
#endif