X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetText.h;h=6f509ada4572c470fad3b69b39a9b0c51ae8c640;hb=f61bebd7fb25beabdf0dc761520030f9059499d6;hp=f3c15c490098b55d68cfc3bbc45f52163b04a067;hpb=345d7c00cd85576102a025daad82e6537fcb12d2;p=lyx.git diff --git a/src/insets/InsetText.h b/src/insets/InsetText.h index f3c15c4900..6f509ada45 100644 --- a/src/insets/InsetText.h +++ b/src/insets/InsetText.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author Jürgen Vigna + * \author Jürgen Vigna * * Full author contact details are available in file CREDITS. */ @@ -13,65 +13,75 @@ #define INSETTEXT_H #include "Inset.h" -#include "RowList_fwd.h" -#include "LyXFont.h" -#include "LyXText.h" - -#include "support/types.h" - -#include "frontends/mouse_state.h" +#include "ColorCode.h" +#include "Text.h" namespace lyx { class Buffer; class BufferParams; class BufferView; +class CompletionList; class CursorSlice; class Dimension; -class LColor_color; class ParagraphList; - +class InsetTabular; /** A text inset is like a TeX box to write full text (including styles and other insets) in a given space. */ -class InsetText : public InsetOld { +class InsetText : public Inset { public: + enum UsePlain { + DefaultLayout, + PlainLayout + }; + /// \param buffer + /// \param useplain whether to use the plain layout + /// This is needed because we cannot call the virtual function + /// usePlainLayout() from within the constructor. + explicit InsetText(Buffer const & buffer, UsePlain type = DefaultLayout); + /// + InsetText(InsetText const &); /// - explicit InsetText(BufferParams const &); + void setBuffer(Buffer &); + /// - InsetText(); + Dimension const dimension(BufferView const &) const; /// empty inset to empty par void clear(); /// - void read(Buffer const & buf, LyXLex & lex); + void read(Lexer & lex); /// - void write(Buffer const & buf, std::ostream & os) const; + void write(std::ostream & os) const; /// - bool metrics(MetricsInfo & mi, Dimension & dim) const; + void metrics(MetricsInfo & mi, Dimension & dim) const; /// void draw(PainterInfo & pi, int x, int y) const; - /// draw inset selection - void drawSelection(PainterInfo & pi, int x, int y) const; - /// are we inside the area covered by the inset? - virtual bool covers(BufferView const & bv, int x, int y) const; /// - virtual docstring const editMessage() const; + docstring editMessage() const; /// - EDITABLE editable() const { return HIGHLY_EDITABLE; } + bool editable() const { return true; } /// bool canTrackChanges() const { return true; } /// - InsetText const * asTextInset() const { return this; } + InsetText * asInsetText() { return this; } + /// + InsetText const * asInsetText() const { return this; } + /// + Text & text() { return text_; } + Text const & text() const { return text_; } /// - int latex(Buffer const &, odocstream &, OutputParams const &) const; + int latex(odocstream &, OutputParams const &) const; /// - int plaintext(Buffer const &, odocstream &, OutputParams const &) const; + int plaintext(odocstream &, OutputParams const &) const; /// - int docbook(Buffer const &, odocstream &, OutputParams const &) const; + int docbook(odocstream &, OutputParams const &) const; + /// + int xhtml(odocstream &, OutputParams const &) const; /// void validate(LaTeXFeatures & features) const; @@ -79,9 +89,9 @@ public: void cursorPos(BufferView const & bv, CursorSlice const & sl, bool boundary, int & x, int & y) const; /// - Code lyxCode() const { return TEXT_CODE; } + InsetCode lyxCode() const { return TEXT_CODE; } /// - void setText(docstring const &, LyXFont const &, bool trackChanges); + void setText(docstring const &, Font const &, bool trackChanges); /// void setAutoBreakRows(bool); /// @@ -89,17 +99,17 @@ public: /// void setDrawFrame(bool); /// - LColor_color frameColor() const; + ColorCode frameColor() const; /// - void setFrameColor(LColor_color); + void setFrameColor(ColorCode); /// bool showInsetDialog(BufferView *) const; /// - LyXText * getText(int i) const { - return (i == 0) ? const_cast(&text_) : 0; + Text * getText(int i) const { + return (i == 0) ? const_cast(&text_) : 0; } /// - virtual bool getStatus(LCursor & cur, FuncRequest const & cmd, FuncStatus &) const; + virtual bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const; /// set the change for the entire inset void setChange(Change const & change); @@ -109,15 +119,15 @@ public: void rejectChanges(BufferParams const & bparams); /// append text onto the existing text - void appendParagraphs(Buffer * bp, ParagraphList &); + void appendParagraphs(ParagraphList &); /// void addPreview(graphics::PreviewLoader &) const; /// - void edit(LCursor & cur, bool left); + void edit(Cursor & cur, bool front, EntryDirection entry_from); /// - InsetBase * editXY(LCursor & cur, int x, int y); + Inset * editXY(Cursor & cur, int x, int y); /// number of cells in this inset size_t nargs() const { return 1; } @@ -126,45 +136,59 @@ public: /// ParagraphList const & paragraphs() const; /// - bool insetAllowed(Code) const { return true; } + bool insetAllowed(InsetCode) const { return true; } /// bool allowSpellCheck() const { return true; } - /// should paragraph indendation be ommitted in any case? - bool neverIndent(Buffer const &) const; - /// - InsetText(InsetText const &); /// - virtual bool wide() const { return wide_inset_; } + virtual bool isMacroScope() const { return false; } /// - void setWide(bool wide_inset) { wide_inset_ = wide_inset; } + virtual bool allowMultiPar() const { return true; } -protected: + // Update the counters of this inset and of its contents + void updateLabels(ParIterator const &); + /// + void addToToc(DocIterator const &); /// - virtual void doDispatch(LCursor & cur, FuncRequest & cmd); + Inset * clone() const { return new InsetText(*this); } + /// + bool notifyCursorLeaves(Cursor const & old, Cursor & cur); -private: /// - virtual std::auto_ptr doClone() const; + bool completionSupported(Cursor const &) const; + /// + bool inlineCompletionSupported(Cursor const & cur) const; /// - void init(); + bool automaticInlineCompletion() const; + /// + bool automaticPopupCompletion() const; + /// + bool showCompletionCursor() const; + /// + CompletionList const * createCompletionList(Cursor const & cur) const; + /// + docstring completionPrefix(Cursor const & cur) const; + /// + bool insertCompletion(Cursor & cur, docstring const & s, bool finished); + /// + void completionPosAndDim(Cursor const &, int & x, int & y, Dimension & dim) const; /// - bool drawFrame_; - /** We store the LColor::color value as an int to get LColor.h out - * of the header file. - */ - int frame_color_; + virtual docstring contextMenu(BufferView const & bv, int x, int y) const; /// - mutable pit_type old_pit; + void doDispatch(Cursor & cur, FuncRequest & cmd); +private: /// - bool wide_inset_; -public: + void initParagraphs(UsePlain type); /// - mutable LyXText text_; + void setParagraphOwner(); /// - mutable LyXFont font_; + bool drawFrame_; + /// + ColorCode frame_color_; + /// + mutable pit_type old_pit; /// - static int border_; + mutable Text text_; }; } // namespace lyx