mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-17 00:30:55 +00:00
d866717ef7
counting when exporting to latex. This is done for the code comprised between \begin{document} and \end{document}, while the preamble code still needs manual calls to TexRow::newline() for registering new lines. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@37584 a592a061-630c-0410-9148-cb99ea01b6c8
122 lines
2.7 KiB
C++
122 lines
2.7 KiB
C++
// -*- C++ -*-
|
|
/**
|
|
* \file InsetRef.h
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author José Matos
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#ifndef INSET_REF_H
|
|
#define INSET_REF_H
|
|
|
|
#include "InsetCommand.h"
|
|
|
|
|
|
namespace lyx {
|
|
|
|
/// The reference inset
|
|
class InsetRef : public InsetCommand {
|
|
public:
|
|
struct type_info {
|
|
///
|
|
std::string latex_name;
|
|
///
|
|
std::string gui_name;
|
|
///
|
|
std::string short_gui_name;
|
|
};
|
|
static type_info types[];
|
|
///
|
|
static int getType(std::string const & name);
|
|
///
|
|
static std::string const & getName(int type);
|
|
|
|
///
|
|
InsetRef(Buffer * buffer, InsetCommandParams const &);
|
|
|
|
/// \name Public functions inherited from Inset class
|
|
//@{
|
|
///
|
|
bool isLabeled() const { return true; }
|
|
///
|
|
docstring toolTip(BufferView const &, int, int) const
|
|
{ return tooltip_; }
|
|
///
|
|
bool hasSettings() const { return true; }
|
|
///
|
|
InsetCode lyxCode() const { return REF_CODE; }
|
|
///
|
|
DisplayType display() const { return Inline; }
|
|
///
|
|
void latex(otexstream &, OutputParams const &) const;
|
|
///
|
|
int plaintext(odocstream &, OutputParams const &) const;
|
|
///
|
|
int docbook(odocstream &, OutputParams const &) const;
|
|
///
|
|
docstring xhtml(XHTMLStream &, OutputParams const &) const;
|
|
///
|
|
void toString(odocstream &) const;
|
|
///
|
|
void forToc(docstring &, size_t) const;
|
|
///
|
|
void validate(LaTeXFeatures & features) const;
|
|
///
|
|
void updateBuffer(ParIterator const & it, UpdateType);
|
|
///
|
|
void addToToc(DocIterator const &) const;
|
|
///
|
|
bool forceLTR() const { return true; }
|
|
//@}
|
|
|
|
/// \name Static public methods obligated for InsetCommand derived classes
|
|
//@{
|
|
///
|
|
static ParamInfo const & findInfo(std::string const &);
|
|
///
|
|
static std::string defaultCommand() { return "ref"; }
|
|
///
|
|
static bool isCompatibleCommand(std::string const & s);
|
|
//@}
|
|
|
|
//FIXME: private
|
|
/// \name Private functions inherited from InsetCommand class
|
|
//@{
|
|
///
|
|
docstring screenLabel() const { return screen_label_; }
|
|
//@}
|
|
|
|
protected:
|
|
///
|
|
InsetRef(InsetRef const &);
|
|
|
|
private:
|
|
/// \name Private functions inherited from Inset class
|
|
//@{
|
|
///
|
|
Inset * clone() const { return new InsetRef(*this); }
|
|
//@}
|
|
|
|
/// \return the label with things that need to be escaped escaped
|
|
docstring getEscapedLabel(OutputParams const &) const;
|
|
/// \return the command for a formatted reference to ref
|
|
/// \param label we're cross-referencing
|
|
/// \param argument for reference command
|
|
/// \param prefix of the label (before :)
|
|
docstring getFormattedCmd(docstring const & ref, docstring & label,
|
|
docstring & prefix) const;
|
|
|
|
///
|
|
mutable docstring screen_label_;
|
|
///
|
|
mutable docstring tooltip_;
|
|
};
|
|
|
|
|
|
} // namespace lyx
|
|
|
|
#endif // INSET_REF_H
|