# # Patch managed by http://www.holgerschurig.de/patcher.html # Index: qt-2.3.10/src/kernel/qgfxraster_qws.cpp =================================================================== --- qt-2.3.10.orig/src/kernel/qgfxraster_qws.cpp 2005-05-13 22:22:11.000000000 +0200 +++ qt-2.3.10/src/kernel/qgfxraster_qws.cpp 2005-05-13 22:22:13.000000000 +0200 @@ -51,6 +51,11 @@ #include #include +//HAQ bidi patch +#ifdef USE_BIDI +#include "qbidi.h" +#endif +// end HAQ patch extern bool qws_sw_cursor; @@ -1382,6 +1387,53 @@ setAlphaType(BigEndianMask); } +#ifdef USE_BIDI + // HAQ do bidi + QString n; + qApplyBidi(s, n); + + for( loopc=0; loopc < int(n.length()); loopc++ ) { + QGlyph glyph = memorymanager->lockGlyph(myfont, n[loopc]); + int myw=glyph.metrics->width; + srcwidth = myw; + srcheight = glyph.metrics->height; + setAlphaSource(glyph.data,glyph.metrics->linestep); + int myx=x; + int myy=y; + myx+=glyph.metrics->bearingx; + myy-=glyph.metrics->bearingy; + + // HAQ hack to show arabic tashkeel (diacriticals) above + // the previous character (which in reversed arabic, as it is here, is the next character) + + QChar c = n[loopc]; + if (ISTASHKEEL(c.unicode())) { + //printf("glyph %d bearingx %d width %d advance %d\n", + // c.unicode(),glyph.metrics->bearingx, glyph.metrics->width, glyph.metrics->advance); + + if (loopc < int(n.length()-1)) // if there is a following character then place this glyph over it + { + QGlyph nextGlyph = memorymanager->lockGlyph(myfont, n[loopc+1]); + int nextCharWidth = nextGlyph.metrics->width; + myx += nextCharWidth/2 - glyph.metrics->width; + // pre-undo the advance in x so that the next glyph is placed over this one + x -= glyph.metrics->advance; + } + } + + if(glyph.metrics->width<1 || glyph.metrics->height<1 + || glyph.metrics->linestep==0) + { + // non-printing characters + } else { + blt(myx,myy,myw,glyph.metrics->height,0,0); + } + x+=glyph.metrics->advance; + // ... unlock glyph + } + +#else + for( loopc=0; loopc < int(s.length()); loopc++ ) { QGlyph glyph = memorymanager->lockGlyph(myfont, s[loopc]); int myw=glyph.metrics->width; @@ -1402,6 +1454,9 @@ x+=glyph.metrics->advance; // ... unlock glyph } + +#endif + #ifdef DEBUG_LOCKS qDebug("unaccelerated drawText unlock"); #endif Index: qt-2.3.10/src/kernel/qfont_qws.cpp =================================================================== --- qt-2.3.10.orig/src/kernel/qfont_qws.cpp 2005-05-13 22:22:11.000000000 +0200 +++ qt-2.3.10/src/kernel/qfont_qws.cpp 2005-05-13 22:22:13.000000000 +0200 @@ -49,6 +49,12 @@ #include "qfontmanager_qws.h" #include "qmemorymanager_qws.h" +//HAQ +#ifdef USE_BIDI +#include "qbidi.h" +#endif +// end HAQ + // QFont_Private accesses QFont protected functions class QFont_Private : public QFont @@ -385,17 +391,46 @@ int QFontMetrics::width( QChar ch ) const { +#ifdef USE_BIDI + + int advance; + if (ISTASHKEEL(ch.unicode())) { + advance = 0; + } + else + advance = memorymanager->lockGlyphMetrics(((QFontMetrics*)this)->internal()->handle(),ch)->advance; + return advance; + +#else + return memorymanager->lockGlyphMetrics(((QFontMetrics*)this)->internal()->handle(),ch)->advance; + +#endif } int QFontMetrics::width( const QString &str, int len ) const { +#ifdef USE_BIDI + + QString n; + qApplyBidi(str, n); + if (len < 0) len = n.length(); + int ret=0; + for (int i=0; i + +#define ISTASHKEEL(x) ((x >= 0x64B && x<=0x658) || (x>=0x6d6 && x <= 0x6dc) || (x>=0x6df && x <= 0x6e4) || x==0x6e7 || x == 0x6e8 || (x>=0x6ea && x <= 0x6ed) || (x>=0xfe70 && x <= 0xfe7f)) + +void qApplyBidi(const QString& s, QString& news); Index: qt-2.3.10/src/kernel/qbidi.cpp =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 +++ qt-2.3.10/src/kernel/qbidi.cpp 2005-05-13 22:22:13.000000000 +0200 @@ -0,0 +1,45 @@ +#include +#include "qbidi.h" + + +#define BLOCKTYPE unsigned short* +#define CHARTYPE unsigned short + +extern "C" { + +int doShape(BLOCKTYPE line, CHARTYPE* to, int from, int count); +int doBidi(BLOCKTYPE line, int count, int applyShape, int reorderCombining, int removeMarks); + +} + +void qApplyBidi(const QString& s, QString& news) { + //convert to utf16 zero-terminated + //printf(": qs length is %d\n",s.length()); + int loopc; + int slength = sizeof(unsigned short) * (s.length()); + //printf(": slength is %d\n",slength); + unsigned short* sutf16 = (unsigned short*)malloc(slength); + for( loopc=0; loopc < int(s.length()); loopc++ ) { + sutf16[loopc] = s[loopc].unicode(); + //printf(": char %d is %x\n",loopc,sutf16[loopc]); + } + //printf(": mark 0\n"); + ///sutf16[s.length()] = 0; + + unsigned short* sutf16s = (unsigned short*)malloc(slength); + doShape(sutf16,sutf16s,0,s.length()); + //printf(": do bidi\n"); + doBidi(sutf16s, s.length(),0,0,0); + //sutf16s[s.length()] = 0; + + //printf(": back to QString\n"); + news = ""; + for( loopc=0; loopc < s.length(); loopc++ ) { + QChar newChar((short) sutf16s[loopc]); + news = news + newChar; + //printf(": add char %x\n",newChar.unicode()); + } + + free(sutf16); + free(sutf16s); +} Index: qt-2.3.10/src/kernel/minibidi.c =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 +++ qt-2.3.10/src/kernel/minibidi.c 2005-05-13 22:22:13.000000000 +0200 @@ -0,0 +1,2127 @@ +/************************************************************************ + * $Id: minibidi.c,v 1.2 2005/04/08 18:01:45 lynch Exp $ + * + * ------------ + * Description: + * ------------ + * This is an implemention of Unicode's Bidirectional Algorithm + * (known as UAX #9). + * + * http://www.unicode.org/reports/tr9/ + * + * Author: Ahmad Khalifa + * + * ----------------- + * Revision Details: (Updated by Revision Control System) + * ----------------- + * $Date: 2005/04/08 18:01:45 $ + * $Author: lynch $ + * $Revision: 1.2 $ + * $Source: /home/arabeyes/cvs/projects/external/qt_e/minibidi.c,v $ + * + * (www.arabeyes.org - under MIT license) + * + ************************************************************************/ + +#include /* malloc() and free() definition */ + +/* + * Datatype Extension Macros + */ +#define BLOCKTYPE unsigned short* +#define CHARTYPE unsigned short +#define GETCHAR(from,i) from[i] + +#define GetType(x) getType(x) +/*=====TESTING mode===========*/ +//#define GetType(x) getCAPRtl(x) + +#define lenof(x) sizeof(x) / sizeof(x[0]) + +/* character types */ +enum +{ + /* Strong Char Types */ + L, /* Left-to-Right char */ + LRE, /* Left-to-Right Embedding */ + LRO, /* Left-to-Right Override */ + R, /* Right-to-Left char */ + AL, /* Right-to-Left Arabic char */ + RLE, /* Right-to-Left Embedding */ + RLO, /* Right-to-Left Override */ + /* Weak Char Types */ + PDF, /* Pop Directional Format */ + EN, /* European Number */ + ES, /* European Number Separator */ + ET, /* European Number Terminator */ + AN, /* Arabic Number */ + CS, /* Common Number Separator */ + NSM, /* Non Spacing Mark */ + BN, /* Boundary Neutral */ + /* Neutral Char Types */ + B, /* Paragraph Separator */ + S, /* Segment Separator */ + WS, /* Whitespace */ + ON, /* Other Neutrals */ +}; + +/* Shaping Types */ +enum +{ + SL, /* Left-Joining, doesnt exist in U+0600 - U+06FF */ + SR, /* Right-Joining, ie has Isolated, Final */ + SD, /* Dual-Joining, ie has Isolated, Final, Initial, Medial */ + SU, /* Non-Joining */ + SC /* Join-Causing, like U+0640 (TATWEEL) */ +}; + +#define odd(x) (x%2) +/* Returns the first odd/even value greater than x */ +#define leastGreaterOdd(x) odd(x) ? (x+2) : (x+1) +#define leastGreaterEven(x) odd(x) ? (x+1) : (x+2) + +/* Shaping Helpers */ +#define STYPE(xh) ((xh >= SHAPE_FIRST) && (xh <= SHAPE_LAST)) ? \ + shapetypes[xh-SHAPE_FIRST].type : SU +#define SISOLATED(xh) shapetypes[xh-SHAPE_FIRST].form_b +#define SFINAL(xh) xh+1 +#define SINITIAL(xh) xh+2 +#define SMEDIAL(xh) xh+3 + + +/* function declarations */ +int findIndexOfRun(unsigned char* level , int start, int count, int tlevel); +unsigned char getType(CHARTYPE ch); +unsigned char getCAPRtl(CHARTYPE ch); +void doMirror(BLOCKTYPE ch); + +typedef struct{ + unsigned char type; + unsigned short form_b; +} shape_node; + +/* Kept near the actual table, for verification. */ +#define SHAPE_FIRST 0x621 +#define SHAPE_LAST 0x668 +/* very bad Memory alignment for 32-bit machines + * could split it to 2 arrays or promote type to 2 bytes type + */ +shape_node shapetypes[] = { +/* index, Typ, Iso */ +/* 621 */ {SU, 0xFE80}, +/* 622 */ {SR, 0xFE81}, +/* 623 */ {SR, 0xFE83}, +/* 624 */ {SR, 0xFE85}, +/* 625 */ {SR, 0xFE87}, +/* 626 */ {SD, 0xFE89}, +/* 627 */ {SR, 0xFE8D}, +/* 628 */ {SD, 0xFE8F}, +/* 629 */ {SR, 0xFE93}, +/* 62A */ {SD, 0xFE95}, +/* 62B */ {SD, 0xFE99}, +/* 62C */ {SD, 0xFE9D}, +/* 62D */ {SD, 0xFEA1}, +/* 62E */ {SD, 0xFEA5}, +/* 62F */ {SR, 0xFEA9}, +/* 630 */ {SR, 0xFEAB}, +/* 631 */ {SR, 0xFEAD}, +/* 632 */ {SR, 0xFEAF}, +/* 633 */ {SD, 0xFEB1}, +/* 634 */ {SD, 0xFEB5}, +/* 635 */ {SD, 0xFEB9}, +/* 636 */ {SD, 0xFEBD}, +/* 637 */ {SD, 0xFEC1}, +/* 638 */ {SD, 0xFEC5}, +/* 639 */ {SD, 0xFEC9}, +/* 63A */ {SD, 0xFECD}, +/* 63B */ {SU, 0x0}, +/* 63C */ {SU, 0x0}, +/* 63D */ {SU, 0x0}, +/* 63E */ {SU, 0x0}, +/* 63F */ {SU, 0x0}, +/* 640 */ {SC, 0x0}, +/* 641 */ {SD, 0xFED1}, +/* 642 */ {SD, 0xFED5}, +/* 643 */ {SD, 0xFED9}, +/* 644 */ {SD, 0xFEDD}, +/* 645 */ {SD, 0xFEE1}, +/* 646 */ {SD, 0xFEE5}, +/* 647 */ {SD, 0xFEE9}, +/* 648 */ {SR, 0xFEED}, +/* 649 */ {SR, 0xFEEF}, /* SD */ +/* 64A */ {SD, 0xFEF1}, +/* 64B */ {SU, 0xFEF1}, +/* 64C */ {SU, 0xFEF1}, +/* 64D */ {SU, 0xFEF1}, +/* 64E */ {SU, 0xFEF1}, +/* 64F */ {SU, 0xFEF1}, +/* 650 */ {SU,0xFEF1}, +/* 651 */ {SU,0xFEF1}, +/* 652 */ {SU,0xFEF1}, +/* 653 */ {SU, 0xFEF1}, +/* 654 */ {SU, 0xFEF1}, +/* 655 */ {SU, 0xFEF1}, +/* 656 */ {SU, 0xFEF1}, +/* 657 */ {SU, 0xFEF1}, +/* 658 */ {SU, 0xFEF1}, +/* 659 */ {SU, 0xFEF1}, +/* 65a */ {SU, 0xFEF1}, +/* 65b */ {SU, 0xFEF1}, +/* 65c */ {SU, 0xFEF1}, +/* 65d */ {SU, 0xFEF1}, +/* 65e */ {SU, 0xFEF1}, +/* 65f */ {SU, 0xFEF1}, +/* 660 */ {SU, 0xFEF1}, +/* 661 */ {SU, 0xFEF1}, +/* 662 */ {SU, 0xFEF1}, +/* 663 */ {SU, 0xFEF1}, +/* 664 */ {SU, 0xFEF1}, +/* 665 */ {SU, 0xFEF1}, +/* 666 */ {SU, 0xFEF1}, +/* 667 */ {SU, 0xFEF1}, +/* 668 */ {SU, 0xFEF1} +}; + +/* + * Flips the text buffer, according to max level, and + * all higher levels + * + * Input: + * from: text buffer, on which to apply flipping + * level: resolved levels buffer + * max: the maximum level found in this line (should be unsigned char) + * count: line size in wchar_t + */ +void flipThisRun(BLOCKTYPE from, unsigned char* level, int max, int count) +{ + int i, j, rcount, tlevel; + CHARTYPE temp; + + + j = i = 0; + while(i((i-j)/2); rcount--) + { + temp = GETCHAR(from, j+rcount-1); + GETCHAR(from, j+rcount-1) = GETCHAR(from, i-rcount); + GETCHAR(from, i-rcount) = temp; + } + } +} + +/* + * Finds the index of a run with level equals tlevel + */ +int findIndexOfRun(unsigned char* level , int start, int count, int tlevel) +{ + int i; + for(i=start; i 1) { + k = (i + j) / 2; + if (ch < lookup[k].first) + j = k; + else if (ch > lookup[k].last) + i = k; + else + return (unsigned char)lookup[k].type; + } + + /* + * If we reach here, the character was not in any of the + * intervals listed in the lookup table. This means we return + * ON (`Other Neutrals'). This is the appropriate code for any + * character genuinely not listed in the Unicode table, and + * also the table above has deliberately left out any + * characters _explicitly_ listed as ON (to save space!). + */ + return ON; +} + +unsigned char getPreviousLevel(unsigned char* types, unsigned char* level, int from) +{ + int skip = 0; + + while(--from > 0) + { + + switch(types[from]) + { + case LRE: + case LRO: + case RLE: + case RLO: + if(skip>0) + { + skip--; + break; + }else + return level[from-1]; + case PDF: + skip++; + break; + } + } + return 0; /* Compiler Nag-Stopper */ +} + +unsigned char getPreviousOverride(unsigned char* types, unsigned char* level, int from) +{ + int skip = 1; + + from--; + while(from-- > 0) + { + switch(types[from]) + { + case LRE: + case RLE: + skip++; + break; + + case LRO: + if(skip>0) + { + skip--; + break; + }else + return L; + case RLO: + if(skip>0) + { + skip--; + break; + }else + return R; + case PDF: + skip++; + break; + } + } + return ON; +} + + + +/* The Main shaping function, and the only one to be used + * by the outside world. + * + * line: buffer to apply shaping to. this must be passed by doBidi() first + * to: output buffer for the shaped data + * from: start bidi at this index + * count: number of characters in line + */ +int doShape(BLOCKTYPE line, CHARTYPE* to, int from, int count) +{ + int i, j, ligFlag; + unsigned char prevTemp, nextTemp; + CHARTYPE tempChar; + + ligFlag = 0; + prevTemp = SU; + nextTemp = SU; + for(i=from; i= 0) + { + //assert(j levels[i]) + levels[i] = levels[j]; + + + + if((levels[i] % 2) == 0) + { + types[i] = L; + } + else + { + types[i] = R; + } + + } + } + } + + + if(fNSM) + { + if(types[0] == NSM) + types[0] = paragraphLevel; + + for(i=1; i=0 && types[j] == ON); + tempType = types[j]; + j=i; + while(++j= 0) + { + if(types[j] == AL) + { + types[i] = AN; + break; + } + else if(types[j] == R || types[j] == L) + { + break; + } + } + } + } + + /* Rule (W3) + * W3. Change all ALs to R. + * + * Optimization: on Rule Xn, we might set a flag on AL type + * to prevent this loop in L R lines only... + */ + doALtoR(types, count); + + /* Rule (W4) + * W4. A single European separator between two European numbers changes + * to a European number. A single common separator between two numbers + * of the same type changes to that type. + */ + for( i=0; i<(count-1); i++) + { + if(types[i] == ES) + { + if(types[i-1] == EN && types[i+1] == EN) + types[i] = EN; + }else if(types[i] == CS) + { + if(types[i-1] == EN && types[i+1] == EN) + types[i] = EN; + else if(types[i-1] == AN && types[i+1] == AN) + types[i] = AN; + } + } + + /* Rule (W5) + * W5. A sequence of European terminators adjacent to European numbers + * changes to all European numbers. + * + * Optimization: lots here... else ifs need rearrangement + */ + if(fET) + { + for(i=0; i= 0) + { + if(types[j] == L) + { + types[i] = L; + break; + } + else if(types[j] == R || types[j] == AL) + { + break; + } + + } + } + } + + + /* Rule (N1) + * N1. A sequence of neutrals takes the direction of the surrounding + * strong text if the text on both sides has the same direction. European + * and Arabic numbers are treated as though they were R. + */ + tempType = paragraphLevel; + for(i=0; i0 && (GetType(GETCHAR(line, j)) == WS)) + { + j--; + } + if(j < (count-1)) + { + for(j++; j=i ; j--) + { + levels[j] = paragraphLevel; + } + } + }else if(tempType == B || tempType == S) + levels[i] = paragraphLevel; + } + + /* Rule (L4) + * L4. A character that possesses the mirrored property as specified by + * Section 4.7, Mirrored, must be depicted by a mirrored glyph if the + * resolved directionality of that character is R. + */ + /* Note: this is implemented before L2 for efficiency */ + for(i=0; ii; i++, j--) + { + temp = GETCHAR(line, i); + GETCHAR(line, i) = GETCHAR(line, j); + GETCHAR(line, j) = temp; + } + i=it+1; + } + } + } + + /* Shaping + * Shaping is Applied to each run of levels separately.... + */ + + if(applyShape) + { + + for(i=0; i= i ) + { + tempType = levels[j]; + i=j; + while((i++ < count) && (levels[i] == tempType)); + doShape(line, shapeTo, j, i); + j=i; + tempType = levels[j]; + + } + } + j++; + } + for(i=0; i tempType) + { + tempType = levels[i]; + imax=i; + } + i++; + } + /* maximum level in tempType, its index in imax. */ + while(tempType > 0) /* loop from highest level to the least odd, */ + { /* which i assume is 1 */ + flipThisRun(line, levels, tempType, count); + tempType--; + } + + /* The line should be reordered correctly, check for Explicits marks + * and remove them if removeMarks + */ + if(fX && removeMarks) + { + if(!GetParagraphLevel(line, count)) + { + for(i=0, j=0; i=0; i--) + { + tempType = GetType(GETCHAR(line, i)); + if(tempType != RLE && + tempType != LRE && + tempType != RLO && + tempType != LRO && + tempType != PDF) + GETCHAR(line, j--) = GETCHAR(line, i); + } + for(i=j; j>=0; j--) + GETCHAR(line, j) = 0x20; + } + } + + + free(types); + free(levels); + /* if removeMarks is 1 and there were actual marks then return the new size */ + if(fX && removeMarks) return i; + return count; +} + + +/* + * Bad, Horrible function + * takes a pointer to a character that is checked for + * having a mirror glyph. + */ +void doMirror(CHARTYPE* ch) +{ + if ((*ch & 0xFF00) == 0) { + switch (*ch) { + case 0x0028: *ch = 0x0029; break; + case 0x0029: *ch = 0x0028; break; + case 0x003C: *ch = 0x003E; break; + case 0x003E: *ch = 0x003C; break; + case 0x005B: *ch = 0x005D; break; + case 0x005D: *ch = 0x005B; break; + case 0x007B: *ch = 0x007D; break; + case 0x007D: *ch = 0x007B; break; + case 0x00AB: *ch = 0x00BB; break; + case 0x00BB: *ch = 0x00AB; break; + } + } else if ((*ch & 0xFF00) == 0x2000) { + switch (*ch) { + case 0x2039: *ch = 0x203A; break; + case 0x203A: *ch = 0x2039; break; + case 0x2045: *ch = 0x2046; break; + case 0x2046: *ch = 0x2045; break; + case 0x207D: *ch = 0x207E; break; + case 0x207E: *ch = 0x207D; break; + case 0x208D: *ch = 0x208E; break; + case 0x208E: *ch = 0x208D; break; + } + } else if ((*ch & 0xFF00) == 0x2200) { + switch (*ch) { + case 0x2208: *ch = 0x220B; break; + case 0x2209: *ch = 0x220C; break; + case 0x220A: *ch = 0x220D; break; + case 0x220B: *ch = 0x2208; break; + case 0x220C: *ch = 0x2209; break; + case 0x220D: *ch = 0x220A; break; + case 0x2215: *ch = 0x29F5; break; + case 0x223C: *ch = 0x223D; break; + case 0x223D: *ch = 0x223C; break; + case 0x2243: *ch = 0x22CD; break; + case 0x2252: *ch = 0x2253; break; + case 0x2253: *ch = 0x2252; break; + case 0x2254: *ch = 0x2255; break; + case 0x2255: *ch = 0x2254; break; + case 0x2264: *ch = 0x2265; break; + case 0x2265: *ch = 0x2264; break; + case 0x2266: *ch = 0x2267; break; + case 0x2267: *ch = 0x2266; break; + case 0x2268: *ch = 0x2269; break; + case 0x2269: *ch = 0x2268; break; + case 0x226A: *ch = 0x226B; break; + case 0x226B: *ch = 0x226A; break; + case 0x226E: *ch = 0x226F; break; + case 0x226F: *ch = 0x226E; break; + case 0x2270: *ch = 0x2271; break; + case 0x2271: *ch = 0x2270; break; + case 0x2272: *ch = 0x2273; break; + case 0x2273: *ch = 0x2272; break; + case 0x2274: *ch = 0x2275; break; + case 0x2275: *ch = 0x2274; break; + case 0x2276: *ch = 0x2277; break; + case 0x2277: *ch = 0x2276; break; + case 0x2278: *ch = 0x2279; break; + case 0x2279: *ch = 0x2278; break; + case 0x227A: *ch = 0x227B; break; + case 0x227B: *ch = 0x227A; break; + case 0x227C: *ch = 0x227D; break; + case 0x227D: *ch = 0x227C; break; + case 0x227E: *ch = 0x227F; break; + case 0x227F: *ch = 0x227E; break; + case 0x2280: *ch = 0x2281; break; + case 0x2281: *ch = 0x2280; break; + case 0x2282: *ch = 0x2283; break; + case 0x2283: *ch = 0x2282; break; + case 0x2284: *ch = 0x2285; break; + case 0x2285: *ch = 0x2284; break; + case 0x2286: *ch = 0x2287; break; + case 0x2287: *ch = 0x2286; break; + case 0x2288: *ch = 0x2289; break; + case 0x2289: *ch = 0x2288; break; + case 0x228A: *ch = 0x228B; break; + case 0x228B: *ch = 0x228A; break; + case 0x228F: *ch = 0x2290; break; + case 0x2290: *ch = 0x228F; break; + case 0x2291: *ch = 0x2292; break; + case 0x2292: *ch = 0x2291; break; + case 0x2298: *ch = 0x29B8; break; + case 0x22A2: *ch = 0x22A3; break; + case 0x22A3: *ch = 0x22A2; break; + case 0x22A6: *ch = 0x2ADE; break; + case 0x22A8: *ch = 0x2AE4; break; + case 0x22A9: *ch = 0x2AE3; break; + case 0x22AB: *ch = 0x2AE5; break; + case 0x22B0: *ch = 0x22B1; break; + case 0x22B1: *ch = 0x22B0; break; + case 0x22B2: *ch = 0x22B3; break; + case 0x22B3: *ch = 0x22B2; break; + case 0x22B4: *ch = 0x22B5; break; + case 0x22B5: *ch = 0x22B4; break; + case 0x22B6: *ch = 0x22B7; break; + case 0x22B7: *ch = 0x22B6; break; + case 0x22C9: *ch = 0x22CA; break; + case 0x22CA: *ch = 0x22C9; break; + case 0x22CB: *ch = 0x22CC; break; + case 0x22CC: *ch = 0x22CB; break; + case 0x22CD: *ch = 0x2243; break; + case 0x22D0: *ch = 0x22D1; break; + case 0x22D1: *ch = 0x22D0; break; + case 0x22D6: *ch = 0x22D7; break; + case 0x22D7: *ch = 0x22D6; break; + case 0x22D8: *ch = 0x22D9; break; + case 0x22D9: *ch = 0x22D8; break; + case 0x22DA: *ch = 0x22DB; break; + case 0x22DB: *ch = 0x22DA; break; + case 0x22DC: *ch = 0x22DD; break; + case 0x22DD: *ch = 0x22DC; break; + case 0x22DE: *ch = 0x22DF; break; + case 0x22DF: *ch = 0x22DE; break; + case 0x22E0: *ch = 0x22E1; break; + case 0x22E1: *ch = 0x22E0; break; + case 0x22E2: *ch = 0x22E3; break; + case 0x22E3: *ch = 0x22E2; break; + case 0x22E4: *ch = 0x22E5; break; + case 0x22E5: *ch = 0x22E4; break; + case 0x22E6: *ch = 0x22E7; break; + case 0x22E7: *ch = 0x22E6; break; + case 0x22E8: *ch = 0x22E9; break; + case 0x22E9: *ch = 0x22E8; break; + case 0x22EA: *ch = 0x22EB; break; + case 0x22EB: *ch = 0x22EA; break; + case 0x22EC: *ch = 0x22ED; break; + case 0x22ED: *ch = 0x22EC; break; + case 0x22F0: *ch = 0x22F1; break; + case 0x22F1: *ch = 0x22F0; break; + case 0x22F2: *ch = 0x22FA; break; + case 0x22F3: *ch = 0x22FB; break; + case 0x22F4: *ch = 0x22FC; break; + case 0x22F6: *ch = 0x22FD; break; + case 0x22F7: *ch = 0x22FE; break; + case 0x22FA: *ch = 0x22F2; break; + case 0x22FB: *ch = 0x22F3; break; + case 0x22FC: *ch = 0x22F4; break; + case 0x22FD: *ch = 0x22F6; break; + case 0x22FE: *ch = 0x22F7; break; + } + } else if ((*ch & 0xFF00) == 0x2300) { + switch (*ch) { + case 0x2308: *ch = 0x2309; break; + case 0x2309: *ch = 0x2308; break; + case 0x230A: *ch = 0x230B; break; + case 0x230B: *ch = 0x230A; break; + case 0x2329: *ch = 0x232A; break; + case 0x232A: *ch = 0x2329; break; + } + } else if ((*ch & 0xFF00) == 0x2700) { + switch (*ch) { + case 0x2768: *ch = 0x2769; break; + case 0x2769: *ch = 0x2768; break; + case 0x276A: *ch = 0x276B; break; + case 0x276B: *ch = 0x276A; break; + case 0x276C: *ch = 0x276D; break; + case 0x276D: *ch = 0x276C; break; + case 0x276E: *ch = 0x276F; break; + case 0x276F: *ch = 0x276E; break; + case 0x2770: *ch = 0x2771; break; + case 0x2771: *ch = 0x2770; break; + case 0x2772: *ch = 0x2773; break; + case 0x2773: *ch = 0x2772; break; + case 0x2774: *ch = 0x2775; break; + case 0x2775: *ch = 0x2774; break; + case 0x27D5: *ch = 0x27D6; break; + case 0x27D6: *ch = 0x27D5; break; + case 0x27DD: *ch = 0x27DE; break; + case 0x27DE: *ch = 0x27DD; break; + case 0x27E2: *ch = 0x27E3; break; + case 0x27E3: *ch = 0x27E2; break; + case 0x27E4: *ch = 0x27E5; break; + case 0x27E5: *ch = 0x27E4; break; + case 0x27E6: *ch = 0x27E7; break; + case 0x27E7: *ch = 0x27E6; break; + case 0x27E8: *ch = 0x27E9; break; + case 0x27E9: *ch = 0x27E8; break; + case 0x27EA: *ch = 0x27EB; break; + case 0x27EB: *ch = 0x27EA; break; + } + } else if ((*ch & 0xFF00) == 0x2900) { + switch (*ch) { + case 0x2983: *ch = 0x2984; break; + case 0x2984: *ch = 0x2983; break; + case 0x2985: *ch = 0x2986; break; + case 0x2986: *ch = 0x2985; break; + case 0x2987: *ch = 0x2988; break; + case 0x2988: *ch = 0x2987; break; + case 0x2989: *ch = 0x298A; break; + case 0x298A: *ch = 0x2989; break; + case 0x298B: *ch = 0x298C; break; + case 0x298C: *ch = 0x298B; break; + case 0x298D: *ch = 0x2990; break; + case 0x298E: *ch = 0x298F; break; + case 0x298F: *ch = 0x298E; break; + case 0x2990: *ch = 0x298D; break; + case 0x2991: *ch = 0x2992; break; + case 0x2992: *ch = 0x2991; break; + case 0x2993: *ch = 0x2994; break; + case 0x2994: *ch = 0x2993; break; + case 0x2995: *ch = 0x2996; break; + case 0x2996: *ch = 0x2995; break; + case 0x2997: *ch = 0x2998; break; + case 0x2998: *ch = 0x2997; break; + case 0x29B8: *ch = 0x2298; break; + case 0x29C0: *ch = 0x29C1; break; + case 0x29C1: *ch = 0x29C0; break; + case 0x29C4: *ch = 0x29C5; break; + case 0x29C5: *ch = 0x29C4; break; + case 0x29CF: *ch = 0x29D0; break; + case 0x29D0: *ch = 0x29CF; break; + case 0x29D1: *ch = 0x29D2; break; + case 0x29D2: *ch = 0x29D1; break; + case 0x29D4: *ch = 0x29D5; break; + case 0x29D5: *ch = 0x29D4; break; + case 0x29D8: *ch = 0x29D9; break; + case 0x29D9: *ch = 0x29D8; break; + case 0x29DA: *ch = 0x29DB; break; + case 0x29DB: *ch = 0x29DA; break; + case 0x29F5: *ch = 0x2215; break; + case 0x29F8: *ch = 0x29F9; break; + case 0x29F9: *ch = 0x29F8; break; + case 0x29FC: *ch = 0x29FD; break; + case 0x29FD: *ch = 0x29FC; break; + } + } else if ((*ch & 0xFF00) == 0x2A00) { + switch (*ch) { + case 0x2A2B: *ch = 0x2A2C; break; + case 0x2A2C: *ch = 0x2A2B; break; + case 0x2A2D: *ch = 0x2A2C; break; + case 0x2A2E: *ch = 0x2A2D; break; + case 0x2A34: *ch = 0x2A35; break; + case 0x2A35: *ch = 0x2A34; break; + case 0x2A3C: *ch = 0x2A3D; break; + case 0x2A3D: *ch = 0x2A3C; break; + case 0x2A64: *ch = 0x2A65; break; + case 0x2A65: *ch = 0x2A64; break; + case 0x2A79: *ch = 0x2A7A; break; + case 0x2A7A: *ch = 0x2A79; break; + case 0x2A7D: *ch = 0x2A7E; break; + case 0x2A7E: *ch = 0x2A7D; break; + case 0x2A7F: *ch = 0x2A80; break; + case 0x2A80: *ch = 0x2A7F; break; + case 0x2A81: *ch = 0x2A82; break; + case 0x2A82: *ch = 0x2A81; break; + case 0x2A83: *ch = 0x2A84; break; + case 0x2A84: *ch = 0x2A83; break; + case 0x2A8B: *ch = 0x2A8C; break; + case 0x2A8C: *ch = 0x2A8B; break; + case 0x2A91: *ch = 0x2A92; break; + case 0x2A92: *ch = 0x2A91; break; + case 0x2A93: *ch = 0x2A94; break; + case 0x2A94: *ch = 0x2A93; break; + case 0x2A95: *ch = 0x2A96; break; + case 0x2A96: *ch = 0x2A95; break; + case 0x2A97: *ch = 0x2A98; break; + case 0x2A98: *ch = 0x2A97; break; + case 0x2A99: *ch = 0x2A9A; break; + case 0x2A9A: *ch = 0x2A99; break; + case 0x2A9B: *ch = 0x2A9C; break; + case 0x2A9C: *ch = 0x2A9B; break; + case 0x2AA1: *ch = 0x2AA2; break; + case 0x2AA2: *ch = 0x2AA1; break; + case 0x2AA6: *ch = 0x2AA7; break; + case 0x2AA7: *ch = 0x2AA6; break; + case 0x2AA8: *ch = 0x2AA9; break; + case 0x2AA9: *ch = 0x2AA8; break; + case 0x2AAA: *ch = 0x2AAB; break; + case 0x2AAB: *ch = 0x2AAA; break; + case 0x2AAC: *ch = 0x2AAD; break; + case 0x2AAD: *ch = 0x2AAC; break; + case 0x2AAF: *ch = 0x2AB0; break; + case 0x2AB0: *ch = 0x2AAF; break; + case 0x2AB3: *ch = 0x2AB4; break; + case 0x2AB4: *ch = 0x2AB3; break; + case 0x2ABB: *ch = 0x2ABC; break; + case 0x2ABC: *ch = 0x2ABB; break; + case 0x2ABD: *ch = 0x2ABE; break; + case 0x2ABE: *ch = 0x2ABD; break; + case 0x2ABF: *ch = 0x2AC0; break; + case 0x2AC0: *ch = 0x2ABF; break; + case 0x2AC1: *ch = 0x2AC2; break; + case 0x2AC2: *ch = 0x2AC1; break; + case 0x2AC3: *ch = 0x2AC4; break; + case 0x2AC4: *ch = 0x2AC3; break; + case 0x2AC5: *ch = 0x2AC6; break; + case 0x2AC6: *ch = 0x2AC5; break; + case 0x2ACD: *ch = 0x2ACE; break; + case 0x2ACE: *ch = 0x2ACD; break; + case 0x2ACF: *ch = 0x2AD0; break; + case 0x2AD0: *ch = 0x2ACF; break; + case 0x2AD1: *ch = 0x2AD2; break; + case 0x2AD2: *ch = 0x2AD1; break; + case 0x2AD3: *ch = 0x2AD4; break; + case 0x2AD4: *ch = 0x2AD3; break; + case 0x2AD5: *ch = 0x2AD6; break; + case 0x2AD6: *ch = 0x2AD5; break; + case 0x2ADE: *ch = 0x22A6; break; + case 0x2AE3: *ch = 0x22A9; break; + case 0x2AE4: *ch = 0x22A8; break; + case 0x2AE5: *ch = 0x22AB; break; + case 0x2AEC: *ch = 0x2AED; break; + case 0x2AED: *ch = 0x2AEC; break; + case 0x2AF7: *ch = 0x2AF8; break; + case 0x2AF8: *ch = 0x2AF7; break; + case 0x2AF9: *ch = 0x2AFA; break; + case 0x2AFA: *ch = 0x2AF9; break; + } + } else if ((*ch & 0xFF00) == 0x3000) { + switch (*ch) { + case 0x3008: *ch = 0x3009; break; + case 0x3009: *ch = 0x3008; break; + case 0x300A: *ch = 0x300B; break; + case 0x300B: *ch = 0x300A; break; + case 0x300C: *ch = 0x300D; break; + case 0x300D: *ch = 0x300C; break; + case 0x300E: *ch = 0x300F; break; + case 0x300F: *ch = 0x300E; break; + case 0x3010: *ch = 0x3011; break; + case 0x3011: *ch = 0x3010; break; + case 0x3014: *ch = 0x3015; break; + case 0x3015: *ch = 0x3014; break; + case 0x3016: *ch = 0x3017; break; + case 0x3017: *ch = 0x3016; break; + case 0x3018: *ch = 0x3019; break; + case 0x3019: *ch = 0x3018; break; + case 0x301A: *ch = 0x301B; break; + case 0x301B: *ch = 0x301A; break; + } + } else if ((*ch & 0xFF00) == 0xFF00) { + switch (*ch) { + case 0xFF08: *ch = 0xFF09; break; + case 0xFF09: *ch = 0xFF08; break; + case 0xFF1C: *ch = 0xFF1E; break; + case 0xFF1E: *ch = 0xFF1C; break; + case 0xFF3B: *ch = 0xFF3D; break; + case 0xFF3D: *ch = 0xFF3B; break; + case 0xFF5B: *ch = 0xFF5D; break; + case 0xFF5D: *ch = 0xFF5B; break; + case 0xFF5F: *ch = 0xFF60; break; + case 0xFF60: *ch = 0xFF5F; break; + case 0xFF62: *ch = 0xFF63; break; + case 0xFF63: *ch = 0xFF62; break; + } + } +} Index: qt-2.3.10/src/qt.pro =================================================================== --- qt-2.3.10.orig/src/qt.pro 2005-01-23 15:00:39.000000000 +0100 +++ qt-2.3.10/src/qt.pro 2005-05-13 22:22:13.000000000 +0200 @@ -182,6 +182,7 @@ $$KERNEL_H/qasyncimageio.h \ $$KERNEL_H/qasyncio.h \ $$KERNEL_H/qbitmap.h \ + $$KERNEL_H/qbidi.h \ $$KERNEL_H/qbrush.h \ $$KERNEL_H/qclipboard.h \ $$KERNEL_H/qcolor.h \ @@ -527,6 +528,8 @@ kernel/qapplication.cpp \ kernel/qasyncimageio.cpp \ kernel/qasyncio.cpp \ + kernel/qbidi.cpp \ + kernel/minibidi.cpp \ kernel/qbitmap.cpp \ kernel/qclipboard.cpp \ kernel/qcolor.cpp \ Index: qt-2.3.10/src/Makefile.in =================================================================== --- qt-2.3.10.orig/src/Makefile.in 2005-05-13 22:22:11.000000000 +0200 +++ qt-2.3.10/src/Makefile.in 2005-05-13 22:29:52.000000000 +0200 @@ -168,6 +168,8 @@ kernel/qabstractlayout.o \ kernel/qaccel.o \ kernel/qapplication.o \ + kernel/qbidi.o \ + kernel/minibidi.o \ kernel/qasyncimageio.o \ kernel/qasyncio.o \ kernel/qbitmap.o \ @@ -4107,6 +4109,12 @@ kernel/qthread.h \ tools/qvaluestack.h +kernel/qbidi.o: kernel/qbidi.cpp \ + kernel/qbidi.h \ + tools/qstring.h + +kernel/minibidi.o: kernel/minibidi.c + kernel/qasyncimageio.o: kernel/qasyncimageio.cpp \ kernel/qasyncimageio.h \ kernel/qimage.h \