diff options
Diffstat (limited to 'lib/kotext/KoRichText.h')
-rw-r--r-- | lib/kotext/KoRichText.h | 851 |
1 files changed, 851 insertions, 0 deletions
diff --git a/lib/kotext/KoRichText.h b/lib/kotext/KoRichText.h new file mode 100644 index 00000000..94954b93 --- /dev/null +++ b/lib/kotext/KoRichText.h @@ -0,0 +1,851 @@ +/**************************************************************************** +** +** Definition of internal rich text classes +** +** Created : 990124 +** +** Copyright (C) 1999-2000 Trolltech AS. All rights reserved. +** +** This file is part of the kernel module of the Qt GUI Toolkit. +** +** This file may be distributed under the terms of the Q Public License +** as defined by Trolltech AS of Norway and appearing in the file +** LICENSE.QPL included in the packaging of this file. +** +** This file may be distributed and/or modified under the terms of the +** GNU General Public License version 2 as publish by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. +** +** Licensees holding valid Qt Enterprise Edition or Qt Professional Edition +** licenses may use this file in accordance with the Qt Commercial License +** Agreement provided with the Software. +** +** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE +** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. +** +** See http://www.trolltech.com/pricing.html or email [email protected] for +** information about Qt Commercial License Agreements. +** See http://www.trolltech.com/qpl/ for QPL licensing information. +** See http://www.trolltech.com/gpl/ for GPL licensing information. +** +** Contact [email protected] if any conditions of this licensing are +** not clear to you. +** +**********************************************************************/ + +#ifndef KORICHTEXT_H +#define KORICHTEXT_H + +#include <qptrlist.h> +#include <qrect.h> +#include <qmap.h> +#include <qstringlist.h> +#include <qcolor.h> +#include <qsize.h> +#include <qvaluelist.h> +#include <qobject.h> +#include <qstylesheet.h> +#include <qpainter.h> +#include "KoComplexText.h" + +#include <koffice_export.h> +class KoXmlWriter; +class KoGenStyles; +class KoTextParag; +class KoTextString; +class KoTextCursor; +class KoTextCustomItem; +class KoTextFlow; +class KoTextDocument; +//class KoTextPreProcessor; +class KoTextFormatterBase; +class KoTextFormat; +class KoTextFormatCollection; +struct KoBidiContext; + +//// kotext additions (needed by the #included headers) +class KCommand; +class QDomElement; +class KoTextZoomHandler; +class KoTextFormatter; +class KoParagVisitor; +class KoTextDocCommand; +class KoXmlWriter; +class KoSavingContext; + +#include <qmemarray.h> +#include "KoParagLayout.h" +//// + +// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +class KOTEXT_EXPORT KoTextStringChar +{ + friend class KoTextString; + +public: + // this is never called, initialize variables in KoTextString::insert()!!! + KoTextStringChar() : lineStart( 0 ), type( Regular ), startOfRun( 0 ) {d.format=0; } + ~KoTextStringChar(); + + QChar c; + + // this is the same struct as in qtextengine_p.h. Don't change! + uchar softBreak :1; // Potential linebreak point + uchar whiteSpace :1; // A unicode whitespace character, except NBSP, ZWNBSP + uchar charStop :1; // Valid cursor position (for left/right arrow) + uchar wordStop :1; // Valid cursor position (for ctrl + left/right arrow) (TODO: use) + //uchar nobreak :1; + + enum Type { Regular, Custom }; + uint lineStart : 1; + Type type : 1; + uint startOfRun : 1; + uint rightToLeft : 1; + + // --- added for WYSIWYG --- + Q_INT8 pixelxadj; // adjustment to apply to lu2pixel(x) + short int pixelwidth; // width in pixels + short int width; // width in LU + + int x; + int height() const; + int ascent() const; + int descent() const; + bool isCustom() const { return type == Custom; } + KoTextFormat *format() const; + KoTextCustomItem *customItem() const; + void setFormat( KoTextFormat *f,bool setFormatAgain=TRUE ); + void setCustomItem( KoTextCustomItem *i ); + void loseCustomItem(); + struct CustomData + { + KoTextFormat *format; + KoTextCustomItem *custom; + }; + + union { + KoTextFormat* format; + CustomData* custom; + } d; + +private: + KoTextStringChar &operator=( const KoTextStringChar & ) { + //abort(); + return *this; + } + KoTextStringChar( const KoTextStringChar & ); // copy-constructor, forbidden + friend class KoComplexText; + friend class KoTextParag; +}; + +#if defined(Q_TEMPLATEDLL) +// MOC_SKIP_BEGIN +template class QMemArray<KoTextStringChar>; +// MOC_SKIP_END +#endif + +class KOTEXT_EXPORT KoTextString +{ +public: + + KoTextString(); + KoTextString( const KoTextString &s ); + virtual ~KoTextString(); + + QString toString() const; + static QString toString( const QMemArray<KoTextStringChar> &data ); + QString toReverseString() const; + + QString stringToSpellCheck(); + + KoTextStringChar &at( int i ) const; + int length() const; + + //int width( int idx ) const; // moved to KoTextFormat + + void insert( int index, const QString &s, KoTextFormat *f ); + void insert( int index, KoTextStringChar *c ); + void truncate( int index ); + void remove( int index, int len ); + void clear(); + + void setFormat( int index, KoTextFormat *f, bool useCollection, bool setFormatAgain = FALSE ); + + void setBidi( bool b ) { bidi = b; } + bool isBidi() const; + bool isRightToLeft() const; + QChar::Direction direction() const; + void setDirection( QChar::Direction d ) { dir = d; bidiDirty = TRUE; } + + /** Set dirty flag for background spell-checking */ + void setNeedsSpellCheck( bool b ) { bNeedsSpellCheck = b; } + bool needsSpellCheck() const { return bNeedsSpellCheck; } + + QMemArray<KoTextStringChar> subString( int start = 0, int len = 0xFFFFFF ) const; + QString mid( int start = 0, int len = 0xFFFFFF ) const; // kotext addition + QMemArray<KoTextStringChar> rawData() const { return data.copy(); } + + void operator=( const QString &s ) { clear(); insert( 0, s, 0 ); } + void operator+=( const QString &s ); + void prepend( const QString &s ) { insert( 0, s, 0 ); } + + // return next and previous valid cursor positions. + bool validCursorPosition( int idx ); + int nextCursorPosition( int idx ); + int previousCursorPosition( int idx ); + +private: + void checkBidi() const; + + QMemArray<KoTextStringChar> data; + uint bidiDirty : 1; + uint bidi : 1; // true when the paragraph has right to left characters + uint rightToLeft : 1; + uint dir : 5; + uint bNeedsSpellCheck : 1; +}; + +inline bool KoTextString::isBidi() const +{ + if ( bidiDirty ) + checkBidi(); + return bidi; +} + +inline bool KoTextString::isRightToLeft() const +{ + if ( bidiDirty ) + checkBidi(); + return rightToLeft; +} + +inline QChar::Direction KoTextString::direction() const +{ + return (QChar::Direction) dir; +} + +// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +class KOTEXT_EXPORT KoTextCursor +{ +public: + KoTextCursor( KoTextDocument *d ); + KoTextCursor(); + KoTextCursor( const KoTextCursor &c ); + KoTextCursor &operator=( const KoTextCursor &c ); + virtual ~KoTextCursor() {} + + bool operator==( const KoTextCursor &c ) const; + bool operator!=( const KoTextCursor &c ) const { return !(*this == c); } + + KoTextDocument *document() const { return doc; } + void setDocument( KoTextDocument *d ); + + KoTextParag *parag() const; + int index() const; + void setParag( KoTextParag *s, bool restore = TRUE ); + + void gotoLeft(); + void gotoRight(); + void gotoNextLetter(); + void gotoPreviousLetter(); + void gotoUp(); + void gotoDown(); + void gotoLineEnd(); + void gotoLineStart(); + void gotoHome(); + void gotoEnd(); + void gotoPageUp( int visibleHeight ); + void gotoPageDown( int visibleHeight ); + void gotoNextWord(); + void gotoPreviousWord(); + void gotoWordLeft(); + void gotoWordRight(); + + void insert( const QString &s, bool checkNewLine, QMemArray<KoTextStringChar> *formatting = 0 ); + void splitAndInsertEmptyParag( bool ind = TRUE, bool updateIds = TRUE ); + bool remove(); + bool removePreviousChar(); + void killLine(); + //void indent(); + + bool atParagStart() const; + bool atParagEnd() const; + + void setIndex( int i, bool restore = TRUE ); + + //void checkIndex(); + + //int offsetX() const { return ox; } + //int offsetY() const { return oy; } + + bool place( const QPoint &pos, KoTextParag *s, bool link = false, int *customItemIndex = 0 ); + + int x() const; + int y() const; + void fixCursorPosition(); + +private: + KoTextParag *string; + KoTextDocument *doc; + int idx, tmpIndex; + //int ox, oy; +}; + +// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +class KoTextDocCommand +{ +public: + enum Commands { Invalid, Insert, Delete, Format, Alignment, ParagType }; + + KoTextDocCommand( KoTextDocument *d ) : doc( d ), cursor( d ) {} + virtual ~KoTextDocCommand() {} + virtual Commands type() const { return Invalid; }; + + virtual KoTextCursor *execute( KoTextCursor *c ) = 0; + virtual KoTextCursor *unexecute( KoTextCursor *c ) = 0; + +protected: + KoTextDocument *doc; + KoTextCursor cursor; + +}; + +#if defined(Q_TEMPLATEDLL) +// MOC_SKIP_BEGIN +template class QPtrList<KoTextDocCommand>; +// MOC_SKIP_END +#endif + +class KoTextDocCommandHistory +{ +public: + KoTextDocCommandHistory( int s ) : current( -1 ), steps( s ) { history.setAutoDelete( TRUE ); } + virtual ~KoTextDocCommandHistory() { clear(); } + + void clear() { history.clear(); current = -1; } + + void addCommand( KoTextDocCommand *cmd ); + KoTextCursor *undo( KoTextCursor *c ); + KoTextCursor *redo( KoTextCursor *c ); + + bool isUndoAvailable(); + bool isRedoAvailable(); + + void setUndoDepth( int d ) { steps = d; } + int undoDepth() const { return steps; } + + int historySize() const { return history.count(); } + int currentPosition() const { return current; } + +private: + QPtrList<KoTextDocCommand> history; + int current, steps; + +}; + +// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +#include "KoTextCustomItem.h" + +#if defined(Q_TEMPLATEDLL) +// MOC_SKIP_BEGIN +template class QMap<QString, QString>; +// MOC_SKIP_END +#endif + +#if 0 +class KoTextImage : public KoTextCustomItem +{ +public: + KoTextImage( KoTextDocument *p, const QMap<QString, QString> &attr, const QString& context, + QMimeSourceFactory &factory ); + virtual ~KoTextImage(); + + Placement placement() const { return place; } + //void setPainter( QPainter*, bool ); + int widthHint() const { return width; } + int minimumWidth() const { return width; } + + QString richText() const; + + void draw( QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ); + +private: + QRegion* reg; + QPixmap pm; + Placement place; + int tmpwidth, tmpheight; + QMap<QString, QString> attributes; + QString imgId; + +}; +#endif + +class KoTextHorizontalLine : public KoTextCustomItem +{ +public: + KoTextHorizontalLine( KoTextDocument *p, const QMap<QString, QString> &attr, const QString& context, + QMimeSourceFactory &factory ); + virtual ~KoTextHorizontalLine(); + + //void setPainter( QPainter*, bool ); + void draw(QPainter* p, int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ); + QString richText() const; + + bool ownLine() const { return TRUE; } + +private: + int tmpheight; + QColor color; + +}; + +#if defined(Q_TEMPLATEDLL) +// MOC_SKIP_BEGIN +template class QPtrList<KoTextCustomItem>; +// MOC_SKIP_END +#endif + +class KOTEXT_EXPORT KoTextFlow +{ + friend class KoTextDocument; + friend class KoTextTableCell; + +public: + KoTextFlow(); + virtual ~KoTextFlow(); + + // Called by KoTextDocument::setWidth() + virtual void setWidth( int width ); + + // This is the value returned by KoTextDocument::width() + int width() const { return w; } + + //virtual void setPageSize( int ps ); + //int pageSize() const { return pagesize; } + + /** + * Called by the formatter to find out the left and right margin for a paragraph at ( yp, yp+h ) + * @param leftMargin returns the left margin + * @param rightMargin returns the right margin (from the page width) + * @param pageWidth returns the page width at that point + * This method merges QRichText's adjustLMargin and adjustRMargin for efficiency reasons + */ + virtual void adjustMargins( int yp, int h, int reqMinWidth, int& leftMargin, int& rightMargin, int& pageWidth, KoTextParag* parag ); + + virtual void registerFloatingItem( KoTextCustomItem* item ); + virtual void unregisterFloatingItem( KoTextCustomItem* item ); + //virtual QRect boundingRect() const; + + /// kotext addition. Allows the textformatter to stop when it goes too far. + virtual int availableHeight() const; + virtual void drawFloatingItems(QPainter* p, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ); + + virtual int adjustFlow( int y, int w, int h ); // adjusts y according to the defined pagesize. Returns the shift. + + virtual bool isEmpty(); + + void clear(); + +private: + int w; + //int pagesize; + + QPtrList<KoTextCustomItem> leftItems; + QPtrList<KoTextCustomItem> rightItems; + +}; + +#ifdef QTEXTTABLE_AVAILABLE +class KoTextTable; + +class KoTextTableCell : public QLayoutItem +{ + friend class KoTextTable; + +public: + KoTextTableCell( KoTextTable* table, + int row, int column, + const QMap<QString, QString> &attr, + const QStyleSheetItem* style, + const KoTextFormat& fmt, const QString& context, + QMimeSourceFactory &factory, QStyleSheet *sheet, const QString& doc ); + KoTextTableCell( KoTextTable* table, int row, int column ); + virtual ~KoTextTableCell(); + + QSize sizeHint() const ; + QSize minimumSize() const ; + QSize maximumSize() const ; + QSizePolicy::ExpandData expanding() const; + bool isEmpty() const; + void setGeometry( const QRect& ) ; + QRect geometry() const; + + bool hasHeightForWidth() const; + int heightForWidth( int ) const; + + void setPainter( QPainter*, bool ); + + int row() const { return row_; } + int column() const { return col_; } + int rowspan() const { return rowspan_; } + int colspan() const { return colspan_; } + int stretch() const { return stretch_; } + + KoTextDocument* richText() const { return richtext; } + KoTextTable* table() const { return parent; } + + void draw( int x, int y, int cx, int cy, int cw, int ch, const QColorGroup& cg, bool selected ); + + QBrush *backGround() const { return background; } + virtual void invalidate(); + + int verticalAlignmentOffset() const; + int horizontalAlignmentOffset() const; + +private: + QPainter* painter() const; + QRect geom; + KoTextTable* parent; + KoTextDocument* richtext; + int row_; + int col_; + int rowspan_; + int colspan_; + int stretch_; + int maxw; + int minw; + bool hasFixedWidth; + QBrush *background; + int cached_width; + int cached_sizehint; + QMap<QString, QString> attributes; + int align; +}; + +#if defined(Q_TEMPLATEDLL) +// MOC_SKIP_BEGIN +template class QPtrList<KoTextTableCell>; +template class QMap<KoTextCursor*, int>; +// MOC_SKIP_END +#endif + +class KoTextTable: public KoTextCustomItem +{ + friend class KoTextTableCell; + +public: + KoTextTable( KoTextDocument *p, const QMap<QString, QString> &attr ); + virtual ~KoTextTable(); + + void setPainter( QPainter *p, bool adjust ); + void pageBreak( int y, KoTextFlow* flow ); + void draw( QPainter* p, int x, int y, int cx, int cy, int cw, int ch, + const QColorGroup& cg, bool selected ); + + bool noErase() const { return TRUE; } + bool ownLine() const { return TRUE; } + Placement placement() const { return place; } + bool isNested() const { return TRUE; } + void resize( int nwidth ); + virtual void invalidate(); + /// ## QString anchorAt( QPainter* p, int x, int y ); + + virtual bool enter( KoTextCursor *c, KoTextDocument *&doc, KoTextParag *¶g, int &idx, int &ox, int &oy, bool atEnd = FALSE ); + virtual bool enterAt( KoTextCursor *c, KoTextDocument *&doc, KoTextParag *¶g, int &idx, int &ox, int &oy, const QPoint &pos ); + virtual bool next( KoTextCursor *c, KoTextDocument *&doc, KoTextParag *¶g, int &idx, int &ox, int &oy ); + virtual bool prev( KoTextCursor *c, KoTextDocument *&doc, KoTextParag *¶g, int &idx, int &ox, int &oy ); + virtual bool down( KoTextCursor *c, KoTextDocument *&doc, KoTextParag *¶g, int &idx, int &ox, int &oy ); + virtual bool up( KoTextCursor *c, KoTextDocument *&doc, KoTextParag *¶g, int &idx, int &ox, int &oy ); + + QString richText() const; + + int minimumWidth() const { return layout ? layout->minimumSize().width() : 0; } + int widthHint() const { return ( layout ? layout->sizeHint().width() : 0 ) + 2 * outerborder; } + + QPtrList<KoTextTableCell> tableCells() const { return cells; } + + QRect geometry() const { return layout ? layout->geometry() : QRect(); } + bool isStretching() const { return stretch; } + +private: + void format( int &w ); + void addCell( KoTextTableCell* cell ); + +private: + QGridLayout* layout; + QPtrList<KoTextTableCell> cells; + QPainter* painter; + int cachewidth; + int fixwidth; + int cellpadding; + int cellspacing; + int border; + int outerborder; + int stretch; + int innerborder; + int us_cp, us_ib, us_b, us_ob, us_cs; + QMap<QString, QString> attributes; + QMap<KoTextCursor*, int> currCell; + Placement place; + void adjustCells( int y , int shift ); + int pageBreakFor; +}; +#endif // QTEXTTABLE_AVAILABLE + +// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +class KoTextTableCell; + +struct KoTextDocumentSelection +{ + KoTextCursor startCursor, endCursor; + bool swapped; +}; + +// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + + +class KOTEXT_EXPORT KoTextDocDeleteCommand : public KoTextDocCommand +{ +public: + KoTextDocDeleteCommand( KoTextDocument *d, int i, int idx, const QMemArray<KoTextStringChar> &str ); + //KoTextDocDeleteCommand( KoTextParag *p, int idx, const QMemArray<KoTextStringChar> &str ); + virtual ~KoTextDocDeleteCommand(); + + Commands type() const { return Delete; } + KoTextCursor *execute( KoTextCursor *c ); + KoTextCursor *unexecute( KoTextCursor *c ); + +protected: + int id, index; + KoTextParag *parag; + QMemArray<KoTextStringChar> text; + +}; + +#if 0 +class KoTextDocInsertCommand : public KoTextDocDeleteCommand +{ +public: + KoTextDocInsertCommand( KoTextDocument *d, int i, int idx, const QMemArray<KoTextStringChar> &str ) + : KoTextDocDeleteCommand( d, i, idx, str ) {} + KoTextDocInsertCommand( KoTextParag *p, int idx, const QMemArray<KoTextStringChar> &str ) + : KoTextDocDeleteCommand( p, idx, str ) {} + virtual ~KoTextDocInsertCommand() {} + + Commands type() const { return Insert; } + KoTextCursor *execute( KoTextCursor *c ) { return KoTextDocDeleteCommand::unexecute( c ); } + KoTextCursor *unexecute( KoTextCursor *c ) { return KoTextDocDeleteCommand::execute( c ); } + +}; +#endif + +class KoTextDocFormatCommand : public KoTextDocCommand +{ +public: + KoTextDocFormatCommand( KoTextDocument *d, int sid, int sidx, int eid, int eidx, const QMemArray<KoTextStringChar> &old, const KoTextFormat *f, int fl ); + virtual ~KoTextDocFormatCommand(); + + Commands type() const { return Format; } + KoTextCursor *execute( KoTextCursor *c ); + KoTextCursor *unexecute( KoTextCursor *c ); + +protected: + int startId, startIndex, endId, endIndex; + KoTextFormat *format; + QMemArray<KoTextStringChar> oldFormats; + int flags; + +}; + +class KoTextAlignmentCommand : public KoTextDocCommand +{ +public: + KoTextAlignmentCommand( KoTextDocument *d, int fParag, int lParag, int na, const QMemArray<int> &oa ); + virtual ~KoTextAlignmentCommand() {} + + Commands type() const { return Alignment; } + KoTextCursor *execute( KoTextCursor *c ); + KoTextCursor *unexecute( KoTextCursor *c ); + +private: + int firstParag, lastParag; + int newAlign; + QMemArray<int> oldAligns; + +}; + +// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +struct KoTextParagLineStart +{ + KoTextParagLineStart() : y( 0 ), baseLine( 0 ), h( 0 ), lineSpacing( 0 ), hyphenated( false ) +#ifndef QT_NO_COMPLEXTEXT + , bidicontext( 0 ) +#endif + { } + KoTextParagLineStart( ushort y_, ushort bl, ushort h_ ) : y( y_ ), baseLine( bl ), h( h_ ), + lineSpacing( 0 ), hyphenated( false ), + w( 0 ) +#ifndef QT_NO_COMPLEXTEXT + , bidicontext( 0 ) +#endif + { } +#ifndef QT_NO_COMPLEXTEXT + KoTextParagLineStart( KoBidiContext *c, KoBidiStatus s ) : y(0), baseLine(0), h(0), + lineSpacing( 0 ), hyphenated( false ), + status( s ), bidicontext( c ) { if ( bidicontext ) bidicontext->ref(); } +#endif + + virtual ~KoTextParagLineStart() + { +#ifndef QT_NO_COMPLEXTEXT + if ( bidicontext && bidicontext->deref() ) + delete bidicontext; +#endif + } + +#ifndef QT_NO_COMPLEXTEXT + void setContext( KoBidiContext *c ) { + if ( c == bidicontext ) + return; + if ( bidicontext && bidicontext->deref() ) + delete bidicontext; + bidicontext = c; + if ( bidicontext ) + bidicontext->ref(); + } + KoBidiContext *context() const { return bidicontext; } +#endif + +public: + ushort y, baseLine, h; + short lineSpacing; + bool hyphenated; +#ifndef QT_NO_COMPLEXTEXT + KoBidiStatus status; +#endif + int w; + +private: +#ifndef QT_NO_COMPLEXTEXT + KoBidiContext *bidicontext; +#endif +}; + +// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +class KOTEXT_EXPORT KoTextFormatterBase +{ +public: + KoTextFormatterBase(); + virtual ~KoTextFormatterBase() {} + virtual bool format( KoTextDocument *doc, KoTextParag *parag, int start, const QMap<int, KoTextParagLineStart*> &oldLineStarts, int& y, int& widthUsed ) = 0; + virtual int formatVertically( KoTextDocument* doc, KoTextParag* parag ); + + // Called after formatting a paragraph + virtual void postFormat( KoTextParag* parag ) = 0; + + int wrapAtColumn() const { return wrapColumn;} + //virtual void setWrapEnabled( bool b ) { wrapEnabled = b; } + virtual void setWrapAtColumn( int c ) { wrapColumn = c; } + virtual void setAllowBreakInWords( bool b ) { biw = b; } + bool allowBreakInWords() const { return biw; } + + // This setting is passed to KoTextParag::fixParagWidth by postFormat() + void setViewFormattingChars( bool b ) { m_bViewFormattingChars = b; } + bool viewFormattingChars() const { return m_bViewFormattingChars; } + + /*virtual*/ bool isBreakable( KoTextString *string, int pos ) const; + /*virtual*/ bool isStretchable( KoTextString *string, int pos ) const; + +protected: + //virtual KoTextParagLineStart *formatLine( KoTextParag *parag, KoTextString *string, KoTextParagLineStart *line, KoTextStringChar *start, + // KoTextStringChar *last, int align = AlignAuto, int space = 0 ); + //KoTextStringChar + +#ifndef QT_NO_COMPLEXTEXT + virtual KoTextParagLineStart *bidiReorderLine( KoTextParag *parag, KoTextString *string, KoTextParagLineStart *line, KoTextStringChar *start, + KoTextStringChar *last, int align, int space ); +#endif + +private: + int wrapColumn; + //bool wrapEnabled; + bool m_bViewFormattingChars; + bool biw; + bool unused; // for future extensions + +#ifdef HAVE_THAI_BREAKS + static QCString *thaiCache; + static KoTextString *cachedString; + static ThBreakIterator *thaiIt; +#endif +}; + + +// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +inline int KoTextString::length() const +{ + return data.size(); +} + +inline void KoTextString::operator+=( const QString &s ) +{ + insert( length(), s, 0 ); +} + +inline KoTextParag *KoTextCursor::parag() const +{ + return string; +} + +inline int KoTextCursor::index() const +{ + return idx; +} + +inline void KoTextCursor::setParag( KoTextParag *s, bool /*restore*/ ) +{ + idx = 0; + string = s; + tmpIndex = -1; +} + +//inline void KoTextCursor::checkIndex() +//{ +// if ( idx >= string->length() ) +// idx = string->length() - 1; +//} + +// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +inline KoTextStringChar &KoTextString::at( int i ) const +{ + return data[ i ]; +} + +inline QString KoTextString::toString() const +{ + return toString( data ); +} + +// +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ + +inline KoTextFormat *KoTextStringChar::format() const +{ + return (type == Regular) ? d.format : d.custom->format; +} + +inline KoTextCustomItem *KoTextStringChar::customItem() const +{ + return isCustom() ? d.custom->custom : 0; +} + +#endif |