-rw-r--r-- | noncore/apps/opie-write/qrichtext.cpp | 72 |
1 files changed, 23 insertions, 49 deletions
diff --git a/noncore/apps/opie-write/qrichtext.cpp b/noncore/apps/opie-write/qrichtext.cpp index 768da44..b457cd6 100644 --- a/noncore/apps/opie-write/qrichtext.cpp +++ b/noncore/apps/opie-write/qrichtext.cpp | |||
@@ -160,117 +160,108 @@ bool QTextCommandHistory::isRedoAvailable() | |||
160 | 160 | ||
161 | QTextDeleteCommand::QTextDeleteCommand( QTextDocument *d, int i, int idx, const QMemArray<QTextStringChar> &str, | 161 | QTextDeleteCommand::QTextDeleteCommand( QTextDocument *d, int i, int idx, const QMemArray<QTextStringChar> &str, |
162 | const QByteArray& oldStyleInfo ) | 162 | const QByteArray& oldStyleInfo ) |
163 | : QTextCommand( d ), id( i ), index( idx ), parag( 0 ), text( str ), styleInformation( oldStyleInfo ) | 163 | : QTextCommand( d ), id( i ), index( idx ), parag( 0 ), text( str ), styleInformation( oldStyleInfo ) |
164 | { | 164 | { |
165 | for ( int j = 0; j < (int)text.size(); ++j ) { | 165 | for ( int j = 0; j < (int)text.size(); ++j ) { |
166 | if ( text[ j ].format() ) | 166 | if ( text[ j ].format() ) |
167 | text[ j ].format()->addRef(); | 167 | text[ j ].format()->addRef(); |
168 | } | 168 | } |
169 | } | 169 | } |
170 | 170 | ||
171 | QTextDeleteCommand::QTextDeleteCommand( QTextParagraph *p, int idx, const QMemArray<QTextStringChar> &str ) | 171 | QTextDeleteCommand::QTextDeleteCommand( QTextParagraph *p, int idx, const QMemArray<QTextStringChar> &str ) |
172 | : QTextCommand( 0 ), id( -1 ), index( idx ), parag( p ), text( str ) | 172 | : QTextCommand( 0 ), id( -1 ), index( idx ), parag( p ), text( str ) |
173 | { | 173 | { |
174 | for ( int i = 0; i < (int)text.size(); ++i ) { | 174 | for ( int i = 0; i < (int)text.size(); ++i ) { |
175 | if ( text[ i ].format() ) | 175 | if ( text[ i ].format() ) |
176 | text[ i ].format()->addRef(); | 176 | text[ i ].format()->addRef(); |
177 | } | 177 | } |
178 | } | 178 | } |
179 | 179 | ||
180 | QTextDeleteCommand::~QTextDeleteCommand() | 180 | QTextDeleteCommand::~QTextDeleteCommand() |
181 | { | 181 | { |
182 | for ( int i = 0; i < (int)text.size(); ++i ) { | 182 | for ( int i = 0; i < (int)text.size(); ++i ) { |
183 | if ( text[ i ].format() ) | 183 | if ( text[ i ].format() ) |
184 | text[ i ].format()->removeRef(); | 184 | text[ i ].format()->removeRef(); |
185 | } | 185 | } |
186 | text.resize( 0 ); | 186 | text.resize( 0 ); |
187 | } | 187 | } |
188 | 188 | ||
189 | QTextCursor *QTextDeleteCommand::execute( QTextCursor *c ) | 189 | QTextCursor *QTextDeleteCommand::execute( QTextCursor *c ) |
190 | { | 190 | { |
191 | QTextParagraph *s = doc ? doc->paragAt( id ) : parag; | 191 | QTextParagraph *s = doc ? doc->paragAt( id ) : parag; |
192 | if ( !s && doc ) { | 192 | if ( !s ) { |
193 | owarn << "can't locate parag at " << id << ", last parag: " << doc->lastParagraph()->paragId() << "" << oendl; | 193 | owarn << "can't locate parag at " << id << ", last parag: " << doc->lastParagraph()->paragId() << "" << oendl; |
194 | return 0; | 194 | return 0; |
195 | } else if ( !doc ) { | ||
196 | owarn << "No valid doc" << oendl; | ||
197 | return 0; | ||
198 | } | 195 | } |
199 | 196 | ||
200 | cursor.setParagraph( s ); | 197 | cursor.setParagraph( s ); |
201 | cursor.setIndex( index ); | 198 | cursor.setIndex( index ); |
202 | int len = text.size(); | 199 | int len = text.size(); |
203 | if ( c ) | 200 | if ( c ) |
204 | *c = cursor; | 201 | *c = cursor; |
205 | if ( doc ) { | 202 | if ( doc ) { |
206 | doc->setSelectionStart( QTextDocument::Temp, cursor ); | 203 | doc->setSelectionStart( QTextDocument::Temp, cursor ); |
207 | for ( int i = 0; i < len; ++i ) | 204 | for ( int i = 0; i < len; ++i ) |
208 | cursor.gotoNextLetter(); | 205 | cursor.gotoNextLetter(); |
209 | doc->setSelectionEnd( QTextDocument::Temp, cursor ); | 206 | doc->setSelectionEnd( QTextDocument::Temp, cursor ); |
210 | doc->removeSelectedText( QTextDocument::Temp, &cursor ); | 207 | doc->removeSelectedText( QTextDocument::Temp, &cursor ); |
211 | if ( c ) | 208 | if ( c ) |
212 | *c = cursor; | 209 | *c = cursor; |
213 | } else { | 210 | } else { |
214 | s->remove( index, len ); | 211 | s->remove( index, len ); |
215 | } | 212 | } |
216 | 213 | ||
217 | return c; | 214 | return c; |
218 | } | 215 | } |
219 | 216 | ||
220 | QTextCursor *QTextDeleteCommand::unexecute( QTextCursor *c ) | 217 | QTextCursor *QTextDeleteCommand::unexecute( QTextCursor *c ) |
221 | { | 218 | { |
222 | QTextParagraph *s = doc ? doc->paragAt( id ) : parag; | 219 | QTextParagraph *s = doc ? doc->paragAt( id ) : parag; |
223 | if ( !s && doc ) { | 220 | if ( !s ) { |
224 | owarn << "can't locate parag at " << id << ", last parag: " << doc->lastParagraph()->paragId() << "" << oendl; | 221 | owarn << "can't locate parag at " << id << ", last parag: " << doc->lastParagraph()->paragId() << "" << oendl; |
225 | return 0; | 222 | return 0; |
226 | } else if ( !doc ) { | ||
227 | owarn << "No valid doc" << oendl; | ||
228 | return 0; | ||
229 | } | 223 | } |
230 | 224 | ||
231 | cursor.setParagraph( s ); | 225 | cursor.setParagraph( s ); |
232 | cursor.setIndex( index ); | 226 | cursor.setIndex( index ); |
233 | QString str = QTextString::toString( text ); | 227 | QString str = QTextString::toString( text ); |
234 | cursor.insert( str, TRUE, &text ); | 228 | cursor.insert( str, TRUE, &text ); |
235 | cursor.setParagraph( s ); | 229 | cursor.setParagraph( s ); |
236 | cursor.setIndex( index ); | 230 | cursor.setIndex( index ); |
237 | if ( c ) { | 231 | if ( c ) { |
238 | c->setParagraph( s ); | 232 | c->setParagraph( s ); |
239 | c->setIndex( index ); | 233 | c->setIndex( index ); |
240 | for ( int i = 0; i < (int)text.size(); ++i ) | 234 | for ( int i = 0; i < (int)text.size(); ++i ) |
241 | c->gotoNextLetter(); | 235 | c->gotoNextLetter(); |
242 | } else { | ||
243 | owarn << "No valid cursor" << oendl; | ||
244 | return 0; | ||
245 | } | 236 | } |
246 | 237 | ||
247 | if ( !styleInformation.isEmpty() ) { | 238 | if ( !styleInformation.isEmpty() ) { |
248 | QDataStream styleStream( styleInformation, IO_ReadOnly ); | 239 | QDataStream styleStream( styleInformation, IO_ReadOnly ); |
249 | int num; | 240 | int num; |
250 | styleStream >> num; | 241 | styleStream >> num; |
251 | QTextParagraph *p = s; | 242 | QTextParagraph *p = s; |
252 | while ( num-- && p ) { | 243 | while ( num-- && p ) { |
253 | p->readStyleInformation( styleStream ); | 244 | p->readStyleInformation( styleStream ); |
254 | p = p->next(); | 245 | p = p->next(); |
255 | } | 246 | } |
256 | } | 247 | } |
257 | s = cursor.paragraph(); | 248 | s = cursor.paragraph(); |
258 | while ( s ) { | 249 | while ( s ) { |
259 | s->format(); | 250 | s->format(); |
260 | s->setChanged( TRUE ); | 251 | s->setChanged( TRUE ); |
261 | if ( s == c->paragraph() ) | 252 | if ( s == c->paragraph() ) |
262 | break; | 253 | break; |
263 | s = s->next(); | 254 | s = s->next(); |
264 | } | 255 | } |
265 | 256 | ||
266 | return &cursor; | 257 | return &cursor; |
267 | } | 258 | } |
268 | 259 | ||
269 | QTextFormatCommand::QTextFormatCommand( QTextDocument *d, int sid, int sidx, int eid, int eidx, | 260 | QTextFormatCommand::QTextFormatCommand( QTextDocument *d, int sid, int sidx, int eid, int eidx, |
270 | const QMemArray<QTextStringChar> &old, QTextFormat *f, int fl ) | 261 | const QMemArray<QTextStringChar> &old, QTextFormat *f, int fl ) |
271 | : QTextCommand( d ), startId( sid ), startIndex( sidx ), endId( eid ), endIndex( eidx ), format( f ), oldFormats( old ), flags( fl ) | 262 | : QTextCommand( d ), startId( sid ), startIndex( sidx ), endId( eid ), endIndex( eidx ), format( f ), oldFormats( old ), flags( fl ) |
272 | { | 263 | { |
273 | format = d->formatCollection()->format( f ); | 264 | format = d->formatCollection()->format( f ); |
274 | for ( int j = 0; j < (int)oldFormats.size(); ++j ) { | 265 | for ( int j = 0; j < (int)oldFormats.size(); ++j ) { |
275 | if ( oldFormats[ j ].format() ) | 266 | if ( oldFormats[ j ].format() ) |
276 | oldFormats[ j ].format()->addRef(); | 267 | oldFormats[ j ].format()->addRef(); |
@@ -1372,93 +1363,82 @@ struct Q_EXPORT QTextDocumentTag { | |||
1372 | int alignment : 16; | 1363 | int alignment : 16; |
1373 | int direction : 5; | 1364 | int direction : 5; |
1374 | QStyleSheetItem::ListStyle liststyle; | 1365 | QStyleSheetItem::ListStyle liststyle; |
1375 | 1366 | ||
1376 | QTextDocumentTag( const QTextDocumentTag& t ) { | 1367 | QTextDocumentTag( const QTextDocumentTag& t ) { |
1377 | name = t.name; | 1368 | name = t.name; |
1378 | style = t.style; | 1369 | style = t.style; |
1379 | anchorHref = t.anchorHref; | 1370 | anchorHref = t.anchorHref; |
1380 | wsm = t.wsm; | 1371 | wsm = t.wsm; |
1381 | format = t.format; | 1372 | format = t.format; |
1382 | alignment = t.alignment; | 1373 | alignment = t.alignment; |
1383 | direction = t.direction; | 1374 | direction = t.direction; |
1384 | liststyle = t.liststyle; | 1375 | liststyle = t.liststyle; |
1385 | } | 1376 | } |
1386 | QTextDocumentTag& operator=(const QTextDocumentTag& t) { | 1377 | QTextDocumentTag& operator=(const QTextDocumentTag& t) { |
1387 | name = t.name; | 1378 | name = t.name; |
1388 | style = t.style; | 1379 | style = t.style; |
1389 | anchorHref = t.anchorHref; | 1380 | anchorHref = t.anchorHref; |
1390 | wsm = t.wsm; | 1381 | wsm = t.wsm; |
1391 | format = t.format; | 1382 | format = t.format; |
1392 | alignment = t.alignment; | 1383 | alignment = t.alignment; |
1393 | direction = t.direction; | 1384 | direction = t.direction; |
1394 | liststyle = t.liststyle; | 1385 | liststyle = t.liststyle; |
1395 | return *this; | 1386 | return *this; |
1396 | } | 1387 | } |
1397 | 1388 | ||
1398 | #if defined(Q_FULL_TEMPLATE_INSTANTIATION) | 1389 | #if defined(Q_FULL_TEMPLATE_INSTANTIATION) |
1399 | bool operator==( const QTextDocumentTag& ) const { return FALSE; } | 1390 | bool operator==( const QTextDocumentTag& ) const { return FALSE; } |
1400 | #endif | 1391 | #endif |
1401 | }; | 1392 | }; |
1402 | 1393 | ||
1403 | 1394 | ||
1404 | #define NEWPAR do { \ | 1395 | #define NEWPAR do{ if ( !hasNewPar) { \ |
1405 | if ( !hasNewPar) { \ | 1396 | if ( !textEditMode && curpar && curpar->length()>1 && curpar->at( curpar->length()-2)->c == QChar_linesep ) \ |
1406 | if ( !curpar ) { \ | 1397 | curpar->remove( curpar->length()-2, 1 ); \ |
1407 | owarn << "no current paragraph" << oendl; \ | 1398 | curpar = createParagraph( this, curpar, curpar->next() ); styles.append( vec ); vec = 0;} \ |
1408 | return; \ | 1399 | hasNewPar = TRUE; \ |
1409 | } \ | 1400 | curpar->rtext = TRUE; \ |
1410 | if ( !textEditMode && curpar && curpar->length()>1 && curpar->at( curpar->length()-2)->c == QChar_linesep ) \ | 1401 | curpar->align = curtag.alignment; \ |
1411 | curpar->remove( curpar->length()-2, 1 ); \ | 1402 | curpar->lstyle = curtag.liststyle; \ |
1412 | curpar = createParagraph( this, curpar, curpar->next() ); styles.append( vec ); \ | 1403 | curpar->litem = ( curtag.style->displayMode() == QStyleSheetItem::DisplayListItem ); \ |
1413 | if ( !curpar ) { \ | 1404 | curpar->str->setDirection( (QChar::Direction)curtag.direction ); \ |
1414 | owarn << "failed in creating a new paragraph" << oendl; \ | 1405 | space = TRUE; \ |
1415 | return; \ | 1406 | delete vec; vec = new QPtrVector<QStyleSheetItem>( (uint)tags.count() + 1); \ |
1416 | } \ | 1407 | int i = 0; \ |
1417 | vec = 0; \ | 1408 | for ( QValueStack<QTextDocumentTag>::Iterator it = tags.begin(); it != tags.end(); ++it ) \ |
1418 | } \ | 1409 | vec->insert( i++, (*it).style ); \ |
1419 | hasNewPar = TRUE; \ | 1410 | vec->insert( i, curtag.style ); \ |
1420 | curpar->rtext = TRUE; \ | 1411 | }while(FALSE) |
1421 | curpar->align = curtag.alignment; \ | 1412 | |
1422 | curpar->lstyle = curtag.liststyle; \ | ||
1423 | curpar->litem = ( curtag.style->displayMode() == QStyleSheetItem::DisplayListItem ); \ | ||
1424 | curpar->str->setDirection( (QChar::Direction)curtag.direction ); \ | ||
1425 | space = TRUE; \ | ||
1426 | delete vec; \ | ||
1427 | vec = new QPtrVector<QStyleSheetItem>( (uint)tags.count() + 1); \ | ||
1428 | int i = 0; \ | ||
1429 | for ( QValueStack<QTextDocumentTag>::Iterator it = tags.begin(); it != tags.end(); ++it ) \ | ||
1430 | vec->insert( i++, (*it).style ); \ | ||
1431 | vec->insert( i, curtag.style ); \ | ||
1432 | } while ( FALSE ) | ||
1433 | 1413 | ||
1434 | void QTextDocument::setRichText( const QString &text, const QString &context ) | 1414 | void QTextDocument::setRichText( const QString &text, const QString &context ) |
1435 | { | 1415 | { |
1436 | if ( !context.isEmpty() ) | 1416 | if ( !context.isEmpty() ) |
1437 | setContext( context ); | 1417 | setContext( context ); |
1438 | clear(); | 1418 | clear(); |
1439 | fParag = lParag = createParagraph( this ); | 1419 | fParag = lParag = createParagraph( this ); |
1440 | oTextValid = TRUE; | 1420 | oTextValid = TRUE; |
1441 | oText = text; | 1421 | oText = text; |
1442 | setRichTextInternal( text ); | 1422 | setRichTextInternal( text ); |
1443 | fParag->rtext = TRUE; | 1423 | fParag->rtext = TRUE; |
1444 | } | 1424 | } |
1445 | 1425 | ||
1446 | void QTextDocument::setRichTextInternal( const QString &text, QTextCursor* cursor ) | 1426 | void QTextDocument::setRichTextInternal( const QString &text, QTextCursor* cursor ) |
1447 | { | 1427 | { |
1448 | QTextParagraph* curpar = lParag; | 1428 | QTextParagraph* curpar = lParag; |
1449 | int pos = 0; | 1429 | int pos = 0; |
1450 | QValueStack<QTextDocumentTag> tags; | 1430 | QValueStack<QTextDocumentTag> tags; |
1451 | QTextDocumentTag initag( "", sheet_->item(""), *formatCollection()->defaultFormat() ); | 1431 | QTextDocumentTag initag( "", sheet_->item(""), *formatCollection()->defaultFormat() ); |
1452 | QTextDocumentTag curtag = initag; | 1432 | QTextDocumentTag curtag = initag; |
1453 | bool space = TRUE; | 1433 | bool space = TRUE; |
1454 | bool canMergeLi = FALSE; | 1434 | bool canMergeLi = FALSE; |
1455 | 1435 | ||
1456 | bool textEditMode = FALSE; | 1436 | bool textEditMode = FALSE; |
1457 | 1437 | ||
1458 | const QChar* doc = text.unicode(); | 1438 | const QChar* doc = text.unicode(); |
1459 | int length = text.length(); | 1439 | int length = text.length(); |
1460 | bool hasNewPar = curpar->length() <= 1; | 1440 | bool hasNewPar = curpar->length() <= 1; |
1461 | QString anchorName; | 1441 | QString anchorName; |
1462 | 1442 | ||
1463 | // style sheet handling for margin and line spacing calculation below | 1443 | // style sheet handling for margin and line spacing calculation below |
1464 | QTextParagraph* stylesPar = curpar; | 1444 | QTextParagraph* stylesPar = curpar; |
@@ -1886,69 +1866,66 @@ void QTextDocument::setRichTextInternal( const QString &text, QTextCursor* curso | |||
1886 | } | 1866 | } |
1887 | if ( !anchorName.isEmpty() ) { | 1867 | if ( !anchorName.isEmpty() ) { |
1888 | curpar->at(curpar->length() - 1)->setAnchor( anchorName, curpar->at( curpar->length() - 1 )->anchorHref() ); | 1868 | curpar->at(curpar->length() - 1)->setAnchor( anchorName, curpar->at( curpar->length() - 1 )->anchorHref() ); |
1889 | anchorName = QString::null; | 1869 | anchorName = QString::null; |
1890 | } | 1870 | } |
1891 | 1871 | ||
1892 | 1872 | ||
1893 | setRichTextMarginsInternal( styles, stylesPar ); | 1873 | setRichTextMarginsInternal( styles, stylesPar ); |
1894 | 1874 | ||
1895 | if ( cursor ) { | 1875 | if ( cursor ) { |
1896 | cursor->gotoPreviousLetter(); | 1876 | cursor->gotoPreviousLetter(); |
1897 | cursor->remove(); | 1877 | cursor->remove(); |
1898 | } | 1878 | } |
1899 | 1879 | ||
1900 | } | 1880 | } |
1901 | 1881 | ||
1902 | void QTextDocument::setRichTextMarginsInternal( QPtrList< QPtrVector<QStyleSheetItem> >& styles, QTextParagraph* stylesPar ) | 1882 | void QTextDocument::setRichTextMarginsInternal( QPtrList< QPtrVector<QStyleSheetItem> >& styles, QTextParagraph* stylesPar ) |
1903 | { | 1883 | { |
1904 | // margin and line spacing calculation | 1884 | // margin and line spacing calculation |
1905 | QPtrVector<QStyleSheetItem>* prevStyle = 0; | 1885 | QPtrVector<QStyleSheetItem>* prevStyle = 0; |
1906 | QPtrVector<QStyleSheetItem>* curStyle = styles.first(); | 1886 | QPtrVector<QStyleSheetItem>* curStyle = styles.first(); |
1907 | QPtrVector<QStyleSheetItem>* nextStyle = styles.next(); | 1887 | QPtrVector<QStyleSheetItem>* nextStyle = styles.next(); |
1908 | while ( stylesPar ) { | 1888 | while ( stylesPar ) { |
1909 | if ( !curStyle ) { | 1889 | if ( !curStyle ) { |
1910 | stylesPar = stylesPar->next(); | 1890 | stylesPar = stylesPar->next(); |
1911 | prevStyle = curStyle; | 1891 | prevStyle = curStyle; |
1912 | curStyle = nextStyle; | 1892 | curStyle = nextStyle; |
1913 | nextStyle = styles.next(); | 1893 | nextStyle = styles.next(); |
1914 | continue; | 1894 | continue; |
1915 | } | 1895 | } |
1916 | 1896 | ||
1917 | int i, mar; | 1897 | int i, mar; |
1918 | QStyleSheetItem* mainStyle = (*curStyle)[curStyle->size()-1]; | 1898 | QStyleSheetItem* mainStyle = curStyle->size() ? (*curStyle)[curStyle->size()-1] : 0; |
1919 | if ( !mainStyle ) | 1899 | if ( mainStyle && mainStyle->displayMode() == QStyleSheetItem::DisplayListItem ) |
1920 | return; | ||
1921 | |||
1922 | if ( mainStyle->displayMode() == QStyleSheetItem::DisplayListItem ) | ||
1923 | stylesPar->setListItem( TRUE ); | 1900 | stylesPar->setListItem( TRUE ); |
1924 | int numLists = 0; | 1901 | int numLists = 0; |
1925 | for ( i = 0; i < (int)curStyle->size(); ++i ) { | 1902 | for ( i = 0; i < (int)curStyle->size(); ++i ) { |
1926 | if ( (*curStyle)[ i ]->displayMode() == QStyleSheetItem::DisplayBlock | 1903 | if ( (*curStyle)[ i ]->displayMode() == QStyleSheetItem::DisplayBlock |
1927 | && int((*curStyle)[ i ]->listStyle()) != QStyleSheetItem::Undefined ) | 1904 | && int((*curStyle)[ i ]->listStyle()) != QStyleSheetItem::Undefined ) |
1928 | numLists++; | 1905 | numLists++; |
1929 | } | 1906 | } |
1930 | stylesPar->ldepth = numLists; | 1907 | stylesPar->ldepth = numLists; |
1931 | if ( stylesPar->next() && nextStyle ) { | 1908 | if ( stylesPar->next() && nextStyle ) { |
1932 | // also set the depth of the next paragraph, required for the margin calculation | 1909 | // also set the depth of the next paragraph, required for the margin calculation |
1933 | numLists = 0; | 1910 | numLists = 0; |
1934 | for ( i = 0; i < (int)nextStyle->size(); ++i ) { | 1911 | for ( i = 0; i < (int)nextStyle->size(); ++i ) { |
1935 | if ( (*nextStyle)[ i ]->displayMode() == QStyleSheetItem::DisplayBlock | 1912 | if ( (*nextStyle)[ i ]->displayMode() == QStyleSheetItem::DisplayBlock |
1936 | && int((*nextStyle)[ i ]->listStyle()) != QStyleSheetItem::Undefined ) | 1913 | && int((*nextStyle)[ i ]->listStyle()) != QStyleSheetItem::Undefined ) |
1937 | numLists++; | 1914 | numLists++; |
1938 | } | 1915 | } |
1939 | stylesPar->next()->ldepth = numLists; | 1916 | stylesPar->next()->ldepth = numLists; |
1940 | } | 1917 | } |
1941 | 1918 | ||
1942 | // do the top margin | 1919 | // do the top margin |
1943 | QStyleSheetItem* item = mainStyle; | 1920 | QStyleSheetItem* item = mainStyle; |
1944 | int m; | 1921 | int m; |
1945 | if (stylesPar->utm > 0 ) { | 1922 | if (stylesPar->utm > 0 ) { |
1946 | m = stylesPar->utm-1; | 1923 | m = stylesPar->utm-1; |
1947 | stylesPar->utm = 0; | 1924 | stylesPar->utm = 0; |
1948 | } else { | 1925 | } else { |
1949 | m = QMAX(0, item->margin( QStyleSheetItem::MarginTop ) ); | 1926 | m = QMAX(0, item->margin( QStyleSheetItem::MarginTop ) ); |
1950 | if ( item->displayMode() == QStyleSheetItem::DisplayListItem | 1927 | if ( item->displayMode() == QStyleSheetItem::DisplayListItem |
1951 | && stylesPar->ldepth ) | 1928 | && stylesPar->ldepth ) |
1952 | m /= stylesPar->ldepth; | 1929 | m /= stylesPar->ldepth; |
1953 | } | 1930 | } |
1954 | for ( i = (int)curStyle->size() - 2 ; i >= 0; --i ) { | 1931 | for ( i = (int)curStyle->size() - 2 ; i >= 0; --i ) { |
@@ -3041,73 +3018,70 @@ void QTextDocument::drawParagraph( QPainter *p, QTextParagraph *parag, int cx, i | |||
3041 | } | 3018 | } |
3042 | 3019 | ||
3043 | parag->document()->nextDoubleBuffered = FALSE; | 3020 | parag->document()->nextDoubleBuffered = FALSE; |
3044 | } | 3021 | } |
3045 | 3022 | ||
3046 | QTextParagraph *QTextDocument::draw( QPainter *p, int cx, int cy, int cw, int ch, const QColorGroup &cg, | 3023 | QTextParagraph *QTextDocument::draw( QPainter *p, int cx, int cy, int cw, int ch, const QColorGroup &cg, |
3047 | bool onlyChanged, bool drawCursor, QTextCursor *cursor, bool resetChanged ) | 3024 | bool onlyChanged, bool drawCursor, QTextCursor *cursor, bool resetChanged ) |
3048 | { | 3025 | { |
3049 | if ( withoutDoubleBuffer || par && par->withoutDoubleBuffer ) { | 3026 | if ( withoutDoubleBuffer || par && par->withoutDoubleBuffer ) { |
3050 | withoutDoubleBuffer = TRUE; | 3027 | withoutDoubleBuffer = TRUE; |
3051 | QRect r; | 3028 | QRect r; |
3052 | draw( p, r, cg ); | 3029 | draw( p, r, cg ); |
3053 | return 0; | 3030 | return 0; |
3054 | } | 3031 | } |
3055 | withoutDoubleBuffer = FALSE; | 3032 | withoutDoubleBuffer = FALSE; |
3056 | 3033 | ||
3057 | if ( !firstParagraph() ) | 3034 | if ( !firstParagraph() ) |
3058 | return 0; | 3035 | return 0; |
3059 | 3036 | ||
3060 | if ( cx < 0 && cy < 0 ) { | 3037 | if ( cx < 0 && cy < 0 ) { |
3061 | cx = 0; | 3038 | cx = 0; |
3062 | cy = 0; | 3039 | cy = 0; |
3063 | cw = width(); | 3040 | cw = width(); |
3064 | ch = height(); | 3041 | ch = height(); |
3065 | } | 3042 | } |
3066 | 3043 | ||
3067 | QTextParagraph *lastFormatted = 0; | 3044 | QTextParagraph *lastFormatted = 0; |
3068 | QTextParagraph *parag = firstParagraph(); | 3045 | QTextParagraph *parag = firstParagraph(); |
3069 | 3046 | ||
3070 | QPixmap *doubleBuffer = 0; | 3047 | QPixmap *doubleBuffer = 0; |
3071 | QPainter painter; | 3048 | QPainter painter; |
3072 | 3049 | ||
3073 | bool fullWidthSelection = FALSE; | ||
3074 | while ( parag ) { | 3050 | while ( parag ) { |
3075 | lastFormatted = parag; | 3051 | lastFormatted = parag; |
3076 | if ( !parag->isValid() ) | 3052 | if ( !parag->isValid() ) |
3077 | parag->format(); | 3053 | parag->format(); |
3078 | 3054 | ||
3079 | QRect pr = parag->rect(); | 3055 | QRect pr = parag->rect(); |
3080 | if ( fullWidthSelection ) | ||
3081 | pr.setWidth( parag->document()->width() ); | ||
3082 | if ( pr.y() > cy + ch ) | 3056 | if ( pr.y() > cy + ch ) |
3083 | goto floating; | 3057 | goto floating; |
3084 | if ( !pr.intersects( QRect( cx, cy, cw, ch ) ) || ( onlyChanged && !parag->hasChanged() ) ) { | 3058 | if ( !pr.intersects( QRect( cx, cy, cw, ch ) ) || ( onlyChanged && !parag->hasChanged() ) ) { |
3085 | parag = parag->next(); | 3059 | parag = parag->next(); |
3086 | continue; | 3060 | continue; |
3087 | } | 3061 | } |
3088 | 3062 | ||
3089 | drawParagraph( p, parag, cx, cy, cw, ch, doubleBuffer, cg, drawCursor, cursor, resetChanged ); | 3063 | drawParagraph( p, parag, cx, cy, cw, ch, doubleBuffer, cg, drawCursor, cursor, resetChanged ); |
3090 | parag = parag->next(); | 3064 | parag = parag->next(); |
3091 | } | 3065 | } |
3092 | 3066 | ||
3093 | parag = lastParagraph(); | 3067 | parag = lastParagraph(); |
3094 | 3068 | ||
3095 | floating: | 3069 | floating: |
3096 | if ( parag->rect().y() + parag->rect().height() < parag->document()->height() ) { | 3070 | if ( parag->rect().y() + parag->rect().height() < parag->document()->height() ) { |
3097 | if ( !parag->document()->parent() ) { | 3071 | if ( !parag->document()->parent() ) { |
3098 | p->fillRect( 0, parag->rect().y() + parag->rect().height(), parag->document()->width(), | 3072 | p->fillRect( 0, parag->rect().y() + parag->rect().height(), parag->document()->width(), |
3099 | parag->document()->height() - ( parag->rect().y() + parag->rect().height() ), | 3073 | parag->document()->height() - ( parag->rect().y() + parag->rect().height() ), |
3100 | cg.brush( QColorGroup::Base ) ); | 3074 | cg.brush( QColorGroup::Base ) ); |
3101 | } | 3075 | } |
3102 | if ( !flow()->isEmpty() ) { | 3076 | if ( !flow()->isEmpty() ) { |
3103 | QRect cr( cx, cy, cw, ch ); | 3077 | QRect cr( cx, cy, cw, ch ); |
3104 | flow()->drawFloatingItems( p, cr.x(), cr.y(), cr.width(), cr.height(), cg, FALSE ); | 3078 | flow()->drawFloatingItems( p, cr.x(), cr.y(), cr.width(), cr.height(), cg, FALSE ); |
3105 | } | 3079 | } |
3106 | } | 3080 | } |
3107 | 3081 | ||
3108 | if ( buf_pixmap && buf_pixmap->height() > 300 ) { | 3082 | if ( buf_pixmap && buf_pixmap->height() > 300 ) { |
3109 | delete buf_pixmap; | 3083 | delete buf_pixmap; |
3110 | buf_pixmap = 0; | 3084 | buf_pixmap = 0; |
3111 | } | 3085 | } |
3112 | 3086 | ||
3113 | return lastFormatted; | 3087 | return lastFormatted; |
@@ -5335,65 +5309,65 @@ int QTextFormatterBreakWords::format( QTextDocument *doc, QTextParagraph *parag, | |||
5335 | int marg = left + rdiff; | 5309 | int marg = left + rdiff; |
5336 | int minw = 0; | 5310 | int minw = 0; |
5337 | int wused = 0; | 5311 | int wused = 0; |
5338 | int tminw = marg; | 5312 | int tminw = marg; |
5339 | int linespacing = doc ? parag->lineSpacing() : 0; | 5313 | int linespacing = doc ? parag->lineSpacing() : 0; |
5340 | bool wrapEnabled = isWrapEnabled( parag ); | 5314 | bool wrapEnabled = isWrapEnabled( parag ); |
5341 | 5315 | ||
5342 | start = 0; | 5316 | start = 0; |
5343 | if ( start == 0 ) | 5317 | if ( start == 0 ) |
5344 | c = ¶g->string()->at( 0 ); | 5318 | c = ¶g->string()->at( 0 ); |
5345 | 5319 | ||
5346 | int i = start; | 5320 | int i = start; |
5347 | QTextLineStart *lineStart = new QTextLineStart( y, y, 0 ); | 5321 | QTextLineStart *lineStart = new QTextLineStart( y, y, 0 ); |
5348 | insertLineStart( parag, 0, lineStart ); | 5322 | insertLineStart( parag, 0, lineStart ); |
5349 | int lastBreak = -1; | 5323 | int lastBreak = -1; |
5350 | int tmpBaseLine = 0, tmph = 0; | 5324 | int tmpBaseLine = 0, tmph = 0; |
5351 | bool lastWasNonInlineCustom = FALSE; | 5325 | bool lastWasNonInlineCustom = FALSE; |
5352 | 5326 | ||
5353 | int align = parag->alignment(); | 5327 | int align = parag->alignment(); |
5354 | if ( align == Qt3::AlignAuto && doc && doc->alignment() != Qt3::AlignAuto ) | 5328 | if ( align == Qt3::AlignAuto && doc && doc->alignment() != Qt3::AlignAuto ) |
5355 | align = doc->alignment(); | 5329 | align = doc->alignment(); |
5356 | 5330 | ||
5357 | align &= Qt3::AlignHorizontal_Mask; | 5331 | align &= Qt3::AlignHorizontal_Mask; |
5358 | 5332 | ||
5359 | QPainter *painter = QTextFormat::painter(); | 5333 | QPainter *painter = QTextFormat::painter(); |
5360 | int col = 0; | 5334 | int col = 0; |
5361 | int ww = 0; | 5335 | int ww = 0; |
5362 | QChar lastChr; | 5336 | QChar lastChr; |
5363 | for ( ; i < len; ++i, ++col ) { | 5337 | for ( ; i < len; ++i, ++col ) { |
5364 | if ( c ) | 5338 | if ( c ) |
5365 | lastChr = c->c; | 5339 | lastChr = c->c; |
5366 | // ### next line should not be needed | 5340 | // ### next line should not be needed |
5367 | if ( c && painter ) | 5341 | if ( painter ) |
5368 | c->format()->setPainter( painter ); | 5342 | c->format()->setPainter( painter ); |
5369 | c = &string->at( i ); | 5343 | c = &string->at( i ); |
5370 | c->rightToLeft = FALSE; | 5344 | c->rightToLeft = FALSE; |
5371 | if ( i > 0 && (x > curLeft || ww == 0) || lastWasNonInlineCustom ) { | 5345 | if ( i > 0 && (x > curLeft || ww == 0) || lastWasNonInlineCustom ) { |
5372 | c->lineStart = 0; | 5346 | c->lineStart = 0; |
5373 | } else { | 5347 | } else { |
5374 | c->lineStart = 1; | 5348 | c->lineStart = 1; |
5375 | firstChar = c; | 5349 | firstChar = c; |
5376 | } | 5350 | } |
5377 | 5351 | ||
5378 | if ( c->isCustom() && c->customItem()->placement() != QTextCustomItem::PlaceInline ) | 5352 | if ( c->isCustom() && c->customItem()->placement() != QTextCustomItem::PlaceInline ) |
5379 | lastWasNonInlineCustom = TRUE; | 5353 | lastWasNonInlineCustom = TRUE; |
5380 | else | 5354 | else |
5381 | lastWasNonInlineCustom = FALSE; | 5355 | lastWasNonInlineCustom = FALSE; |
5382 | 5356 | ||
5383 | if ( c->c.unicode() >= 32 || c->isCustom() ) { | 5357 | if ( c->c.unicode() >= 32 || c->isCustom() ) { |
5384 | ww = string->width( i ); | 5358 | ww = string->width( i ); |
5385 | } else if ( c->c == '\t' ) { | 5359 | } else if ( c->c == '\t' ) { |
5386 | int nx = parag->nextTab( i, x - left ) + left; | 5360 | int nx = parag->nextTab( i, x - left ) + left; |
5387 | if ( nx < x ) | 5361 | if ( nx < x ) |
5388 | ww = w - x; | 5362 | ww = w - x; |
5389 | else | 5363 | else |
5390 | ww = nx - x; | 5364 | ww = nx - x; |
5391 | } else { | 5365 | } else { |
5392 | ww = c->format()->width( ' ' ); | 5366 | ww = c->format()->width( ' ' ); |
5393 | } | 5367 | } |
5394 | 5368 | ||
5395 | // last character ("invisible" space) has no width | 5369 | // last character ("invisible" space) has no width |
5396 | if ( i == len - 1 ) | 5370 | if ( i == len - 1 ) |
5397 | ww = 0; | 5371 | ww = 0; |
5398 | 5372 | ||
5399 | QTextCustomItem* ci = c->customItem(); | 5373 | QTextCustomItem* ci = c->customItem(); |