2
0

cldrtest.pas 202 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504
  1. { CLDR collation Algorithm test routines.
  2. Copyright (c) 2013-2015 by Inoussa OUEDRAOGO
  3. The source code is distributed under the Library GNU
  4. General Public License with the following modification:
  5. - object files and libraries linked into an application may be
  6. distributed without source code.
  7. If you didn't receive a copy of the file COPYING, contact:
  8. Free Software Foundation
  9. 675 Mass Ave
  10. Cambridge, MA 02139
  11. USA
  12. This program is distributed in the hope that it will be useful,
  13. but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  15. }
  16. unit cldrtest;
  17. {$mode objfpc}{$H+}
  18. {$typedaddress on}
  19. {$warn 4056 off} //Conversion between ordinals and pointers is not portable
  20. interface
  21. uses
  22. Classes, SysUtils,
  23. unicodeset, helper, cldrhelper, unicodedata, cldrtxt, cldrxml;
  24. function ToAnsiChars(const AValue : array of TUnicodeCodePoint) : string;
  25. function DumpSequenceAnsi(const ASequence : TOrderedCharacters) : string;
  26. function DumpWeigth(const AItem : TUCA_WeightRec) : string;overload;
  27. function DumpWeigth(const AItems : array of TUCA_WeightRec) : string;overload;
  28. function DumpLine(ALine : TUCA_LineRec) : string;
  29. function DumpLines(ALines : TUCA_LineRecArray) : string;
  30. function CodePointToArray(const ACodePoint : TUnicodeCodePoint) : TUnicodeCodePointArray;overload;
  31. function CodePointToArray(const ACodePoints : array of TUnicodeCodePoint) : TUnicodeCodePointArray;overload;
  32. function ToWeight(const APrimary, ASecondary, ATertiary : Cardinal) : TUCA_WeightRecArray;overload;
  33. function ToWeight(const AWeigths : array of Cardinal) : TUCA_WeightRecArray;overload;
  34. procedure exec_tests(const APropagateException : Boolean = True);
  35. procedure test1();
  36. procedure test2();
  37. procedure test3();
  38. procedure test4();
  39. procedure test5();
  40. procedure test6();
  41. procedure test7();
  42. procedure test8();
  43. procedure test9();
  44. procedure test10();
  45. procedure test11();
  46. procedure test12();
  47. procedure test13();
  48. procedure test14();
  49. procedure test15();
  50. procedure test16a();
  51. procedure test16b();
  52. procedure test16c();
  53. procedure test16d();
  54. procedure test16e();
  55. procedure test_parser_1();
  56. procedure test_parser_2();
  57. procedure test_parser_3();
  58. procedure test_parser_4();
  59. procedure test_parser_5();
  60. procedure test_parser_6();
  61. procedure test_parser_7();
  62. procedure test_parser_8();
  63. procedure test_parser_9();
  64. procedure test_parser_abreviating_1();
  65. procedure test_parser_abreviating_2();
  66. procedure test_parser_abreviating_3();
  67. procedure test_parser_abreviating_4();
  68. procedure test_parser_abreviating_5();
  69. procedure test_parser_abreviating_6();
  70. procedure test_parser_abreviating_7();
  71. procedure test_parser_abreviating_8();
  72. procedure test_parser_abreviating_9();
  73. procedure test_parser_abreviating_10();
  74. procedure test_parser_contraction_1();
  75. procedure test_parser_contraction_2();
  76. procedure test_parser_expansion_1();
  77. procedure test_parser_special_char_1();
  78. procedure test_parser_special_char_2();
  79. procedure test_parser_special_char_3();
  80. procedure test_parser_special_char_4();
  81. procedure test_parser_special_char_5();
  82. procedure test_parser_special_char_6();
  83. procedure test_parser_special_char_7();
  84. procedure test_parser_skip_comment_1();
  85. procedure test_parser_skip_comment_2();
  86. procedure test_parser_skip_comment_3();
  87. procedure test_parser_quoted_string_1();
  88. procedure test_parser_quoted_string_2();
  89. procedure test_parser_quoted_string_3();
  90. procedure test_parser_quoted_string_4();
  91. procedure test_parser_quoted_string_5();
  92. procedure test_parser_quoted_string_6();
  93. procedure test_parser_quoted_string_7();
  94. procedure test_parser_quoted_string_8();
  95. procedure test_parser_contexte_before_1();
  96. procedure test_parser_contexte_before_2();
  97. procedure test_parser_contexte_before_3();
  98. procedure test_parser_contexte_before_4();
  99. procedure test_parser_placement_before_1();
  100. procedure test_parser_placement_before_2();
  101. procedure test_parser_placement_before_3();
  102. procedure test_parser_multi_unit_statement_line_1();
  103. procedure test_parser_multi_unit_statement_line_2();
  104. procedure test_parser_multi_unit_statement_line_3();
  105. procedure test_parser_multi_statement_line_1();
  106. procedure test_parser_multi_statement_line_2();
  107. procedure test_parser_multi_statement_line_3();
  108. procedure test_parser_multi_statement_line_4();
  109. procedure test_parser_multi_line_statements_1();
  110. procedure test_collation_parser_HeaderParsing();
  111. procedure test_collation_parser_HeaderParsing_2();
  112. procedure test_collation_parser_FullParsing();
  113. procedure test_collation_parser_FullParsing_2();
  114. procedure test_collation_parser_complete_rules();
  115. procedure test_collation_parser_complete_rules_2();
  116. procedure test_unicode_set_1();
  117. procedure test_unicode_set_2();
  118. procedure test_unicode_set_3();
  119. implementation
  120. uses
  121. typinfo;
  122. procedure do_exec_test(ATest : TProcedure; const APropagateException : Boolean);
  123. begin
  124. if APropagateException then begin
  125. ATest();
  126. end else begin
  127. try
  128. ATest();
  129. except
  130. on e : Exception do begin
  131. writeln(e.Message);
  132. end;
  133. end;
  134. end;
  135. end;
  136. procedure exec_utils_tests(const APropagateException : Boolean);
  137. begin
  138. WriteLn;WriteLn;WriteLn;WriteLn;
  139. WriteLn('UTILITIES TESTS - START');
  140. WriteLn('***************************** TEST UNICODESET 1 ******************');
  141. do_exec_test(@test_unicode_set_1,APropagateException);
  142. WriteLn;
  143. WriteLn('***************************** TEST UNICODESET 2 ******************');
  144. do_exec_test(@test_unicode_set_2,APropagateException);
  145. WriteLn;
  146. WriteLn('***************************** TEST UNICODESET 3 ******************');
  147. do_exec_test(@test_unicode_set_3,APropagateException);
  148. WriteLn;
  149. WriteLn('UTILITIES TESTS - START');
  150. WriteLn;
  151. WriteLn;
  152. end;
  153. procedure exec_parser_tests(const APropagateException : Boolean);
  154. begin
  155. WriteLn;WriteLn;WriteLn;WriteLn;
  156. WriteLn('PARSER TESTS');
  157. WriteLn('***************************** TEST PARSER 1 ******************');
  158. do_exec_test(@test_parser_1,APropagateException);
  159. WriteLn;
  160. WriteLn('***************************** TEST PARSER 2 ******************');
  161. do_exec_test(@test_parser_2,APropagateException);
  162. WriteLn;
  163. WriteLn('***************************** TEST PARSER 3 ******************');
  164. do_exec_test(@test_parser_3,APropagateException);
  165. WriteLn;
  166. WriteLn('***************************** TEST PARSER 4 ******************');
  167. do_exec_test(@test_parser_4,APropagateException);
  168. WriteLn;
  169. WriteLn('***************************** TEST PARSER 5 ******************');
  170. do_exec_test(@test_parser_5,APropagateException);
  171. WriteLn;
  172. WriteLn('***************************** TEST PARSER 6 ******************');
  173. do_exec_test(@test_parser_6,APropagateException);
  174. WriteLn;
  175. WriteLn('***************************** TEST PARSER 7 ******************');
  176. do_exec_test(@test_parser_7,APropagateException);
  177. WriteLn;
  178. WriteLn('***************************** TEST PARSER 8 ******************');
  179. do_exec_test(@test_parser_7,APropagateException);
  180. WriteLn;
  181. WriteLn('***************************** TEST PARSER 9 ******************');
  182. do_exec_test(@test_parser_9,APropagateException);
  183. WriteLn;
  184. WriteLn;
  185. WriteLn('***************************** TEST ABREVIATING 1 ******************');
  186. do_exec_test(@test_parser_abreviating_1,APropagateException);
  187. WriteLn;
  188. WriteLn('***************************** TEST ABREVIATING 2 ******************');
  189. do_exec_test(@test_parser_abreviating_2,APropagateException);
  190. WriteLn;
  191. WriteLn('***************************** TEST ABREVIATING 3 ******************');
  192. do_exec_test(@test_parser_abreviating_3,APropagateException);
  193. WriteLn;
  194. WriteLn('***************************** TEST ABREVIATING 4 ******************');
  195. do_exec_test(@test_parser_abreviating_4,APropagateException);
  196. WriteLn;
  197. WriteLn('***************************** TEST ABREVIATING 5 ******************');
  198. do_exec_test(@test_parser_abreviating_5,APropagateException);
  199. WriteLn;
  200. WriteLn('***************************** TEST ABREVIATING 6 ******************');
  201. do_exec_test(@test_parser_abreviating_6,APropagateException);
  202. WriteLn;
  203. WriteLn('***************************** TEST ABREVIATING 7 ******************');
  204. do_exec_test(@test_parser_abreviating_7,APropagateException);
  205. WriteLn;
  206. WriteLn('***************************** TEST ABREVIATING 8 ******************');
  207. do_exec_test(@test_parser_abreviating_8,APropagateException);
  208. WriteLn;
  209. WriteLn('***************************** TEST ABREVIATING 9 ******************');
  210. do_exec_test(@test_parser_abreviating_9,APropagateException);
  211. WriteLn;
  212. WriteLn;
  213. WriteLn('***************************** TEST ABREVIATING 10 ******************');
  214. do_exec_test(@test_parser_abreviating_10,APropagateException);
  215. WriteLn;
  216. WriteLn('***************************** TEST CONTRACTION 1 ******************');
  217. do_exec_test(@test_parser_contraction_1,APropagateException);
  218. WriteLn;
  219. WriteLn('***************************** TEST CONTRACTION 2 ******************');
  220. do_exec_test(@test_parser_contraction_2,APropagateException);
  221. WriteLn;
  222. WriteLn('***************************** TEST EXPANSION 1 ******************');
  223. do_exec_test(@test_parser_expansion_1,APropagateException);
  224. WriteLn;
  225. WriteLn('***************************** TEST SPECIAL CHAR 1 ******************');
  226. do_exec_test(@test_parser_special_char_1,APropagateException);
  227. WriteLn;
  228. WriteLn('***************************** TEST SPECIAL CHAR 2 ******************');
  229. do_exec_test(@test_parser_special_char_2,APropagateException);
  230. WriteLn;
  231. WriteLn('***************************** TEST SPECIAL CHAR 3 ******************');
  232. do_exec_test(@test_parser_special_char_3,APropagateException);
  233. WriteLn;
  234. WriteLn('***************************** TEST SPECIAL CHAR 4 ******************');
  235. do_exec_test(@test_parser_special_char_4,APropagateException);
  236. WriteLn;
  237. WriteLn('***************************** TEST SPECIAL CHAR 5 ******************');
  238. do_exec_test(@test_parser_special_char_5,APropagateException);
  239. WriteLn;
  240. WriteLn('***************************** TEST SPECIAL CHAR 6 ******************');
  241. do_exec_test(@test_parser_special_char_6,APropagateException);
  242. WriteLn;
  243. WriteLn('***************************** TEST SPECIAL CHAR 7 ******************');
  244. do_exec_test(@test_parser_special_char_7,APropagateException);
  245. WriteLn;
  246. WriteLn('***************************** TEST SKIP COMMENT 1 ******************');
  247. do_exec_test(@test_parser_skip_comment_1,APropagateException);
  248. WriteLn;
  249. WriteLn('***************************** TEST SKIP COMMENT 2 ******************');
  250. do_exec_test(@test_parser_skip_comment_2,APropagateException);
  251. WriteLn;
  252. WriteLn('***************************** TEST SKIP COMMENT 3 ******************');
  253. do_exec_test(@test_parser_skip_comment_3,APropagateException);
  254. WriteLn;
  255. WriteLn('***************************** TEST QUOTED STRING 1 ******************');
  256. do_exec_test(@test_parser_quoted_string_1,APropagateException);
  257. WriteLn;
  258. WriteLn('***************************** TEST QUOTED STRING 2 ******************');
  259. do_exec_test(@test_parser_quoted_string_2,APropagateException);
  260. WriteLn;
  261. WriteLn('***************************** TEST QUOTED STRING 3 ******************');
  262. do_exec_test(@test_parser_quoted_string_3,APropagateException);
  263. WriteLn;
  264. WriteLn('***************************** TEST QUOTED STRING 4 ******************');
  265. do_exec_test(@test_parser_quoted_string_4,APropagateException);
  266. WriteLn;
  267. WriteLn('***************************** TEST QUOTED STRING 5 ******************');
  268. do_exec_test(@test_parser_quoted_string_5,APropagateException);
  269. WriteLn;
  270. WriteLn('***************************** TEST QUOTED STRING 6 ******************');
  271. do_exec_test(@test_parser_quoted_string_6,APropagateException);
  272. WriteLn;
  273. WriteLn('***************************** TEST QUOTED STRING 7 ******************');
  274. do_exec_test(@test_parser_quoted_string_7,APropagateException);
  275. WriteLn;
  276. WriteLn('***************************** TEST QUOTED STRING 8 ******************');
  277. do_exec_test(@test_parser_quoted_string_8,APropagateException);
  278. WriteLn;
  279. WriteLn('***************************** TEST CONTEXT BEFORE 1 ******************');
  280. do_exec_test(@test_parser_contexte_before_1,APropagateException);
  281. WriteLn;
  282. WriteLn('***************************** TEST CONTEXT BEFORE 2 ******************');
  283. do_exec_test(@test_parser_contexte_before_2,APropagateException);
  284. WriteLn;
  285. WriteLn('***************************** TEST CONTEXT BEFORE 3 ******************');
  286. do_exec_test(@test_parser_contexte_before_3,APropagateException);
  287. WriteLn;
  288. WriteLn('***************************** TEST CONTEXT BEFORE 4 ******************');
  289. do_exec_test(@test_parser_contexte_before_4,APropagateException);
  290. WriteLn;
  291. WriteLn('***************************** TEST PLACEMENT BEFORE 1 ******************');
  292. do_exec_test(@test_parser_placement_before_1,APropagateException);
  293. WriteLn;
  294. WriteLn('***************************** TEST PLACEMENT BEFORE 2 ******************');
  295. do_exec_test(@test_parser_placement_before_2,APropagateException);
  296. WriteLn;
  297. WriteLn('***************************** TEST PLACEMENT BEFORE 3 ******************');
  298. do_exec_test(@test_parser_placement_before_3,APropagateException);
  299. WriteLn;
  300. WriteLn('***************************** TEST MULTI UNIT STATEMENT LINE 1 ******************');
  301. do_exec_test(@test_parser_multi_unit_statement_line_1,APropagateException);
  302. WriteLn;
  303. WriteLn('***************************** TEST MULTI UNIT STATEMENT LINE 2 ******************');
  304. do_exec_test(@test_parser_multi_unit_statement_line_2,APropagateException);
  305. WriteLn;
  306. WriteLn('***************************** TEST MULTI UNIT STATEMENT LINE 3 ******************');
  307. do_exec_test(@test_parser_multi_unit_statement_line_3,APropagateException);
  308. WriteLn;
  309. WriteLn('***************************** TEST MULTI STATEMENT LINE 1 ******************');
  310. do_exec_test(@test_parser_multi_statement_line_1,APropagateException);
  311. WriteLn;
  312. WriteLn('***************************** TEST MULTI STATEMENT LINE 2 ******************');
  313. do_exec_test(@test_parser_multi_statement_line_2,APropagateException);
  314. WriteLn;
  315. WriteLn('***************************** TEST MULTI STATEMENT LINE 3 ******************');
  316. do_exec_test(@test_parser_multi_statement_line_3,APropagateException);
  317. WriteLn;
  318. WriteLn('***************************** TEST MULTI STATEMENT LINE 4 ******************');
  319. do_exec_test(@test_parser_multi_statement_line_4,APropagateException);
  320. WriteLn;
  321. WriteLn('***************************** TEST MULTI LINE STATEMENTS 1 ******************');
  322. do_exec_test(@test_parser_multi_line_statements_1,APropagateException);
  323. WriteLn;
  324. WriteLn;
  325. WriteLn('***************************** TEST REPOSITORY 1 ******************');
  326. do_exec_test(@test_collation_parser_HeaderParsing,APropagateException);
  327. WriteLn;
  328. WriteLn('***************************** TEST REPOSITORY 2 ******************');
  329. do_exec_test(@test_collation_parser_FullParsing,APropagateException);
  330. WriteLn;
  331. WriteLn('***************************** TEST REPOSITORY 3 ******************');
  332. do_exec_test(@test_collation_parser_complete_rules,APropagateException);
  333. WriteLn;
  334. WriteLn('***************************** TEST REPOSITORY 4 ******************');
  335. do_exec_test(@test_collation_parser_HeaderParsing_2,APropagateException);
  336. WriteLn;
  337. WriteLn('***************************** TEST REPOSITORY 5 ******************');
  338. do_exec_test(@test_collation_parser_FullParsing_2,APropagateException);
  339. WriteLn;
  340. WriteLn('***************************** TEST REPOSITORY 6 ******************');
  341. do_exec_test(@test_collation_parser_complete_rules_2,APropagateException);
  342. WriteLn;
  343. WriteLn;
  344. WriteLn;
  345. end;
  346. procedure exec_tests(const APropagateException : Boolean);
  347. begin
  348. exec_utils_tests(APropagateException);
  349. exec_parser_tests(APropagateException);
  350. WriteLn('END PARSER TESTS');
  351. WriteLn('*******************************************************');
  352. WriteLn('***************************** TEST 1 ******************');
  353. do_exec_test(@test1,APropagateException);
  354. WriteLn('***************************** TEST 2 ******************');
  355. do_exec_test(@test2,APropagateException);
  356. WriteLn('***************************** TEST 3 ******************');
  357. do_exec_test(@test3,APropagateException);
  358. WriteLn('***************************** TEST 4 ******************');
  359. do_exec_test(@test4,APropagateException);
  360. WriteLn('***************************** TEST 5 ******************');
  361. do_exec_test(@test5,APropagateException);
  362. WriteLn('***************************** TEST 6 ******************');
  363. do_exec_test(@test6,APropagateException);
  364. WriteLn('***************************** TEST 7 ******************');
  365. do_exec_test(@test7,APropagateException);
  366. WriteLn('***************************** TEST 8 ******************');
  367. do_exec_test(@test8,APropagateException);
  368. WriteLn('***************************** TEST 9 ******************');
  369. do_exec_test(@test9,APropagateException);
  370. WriteLn('***************************** TEST 10 ******************');
  371. do_exec_test(@test10,APropagateException);
  372. WriteLn('***************************** TEST 11 ******************');
  373. do_exec_test(@test11,APropagateException);
  374. WriteLn('***************************** TEST 12 ******************');
  375. do_exec_test(@test12,APropagateException);
  376. WriteLn('***************************** TEST 13 ******************');
  377. do_exec_test(@test13,APropagateException);
  378. WriteLn('***************************** TEST 14 ******************');
  379. do_exec_test(@test14,APropagateException);
  380. WriteLn('***************************** TEST 15 ******************');
  381. do_exec_test(@test15,APropagateException);
  382. WriteLn('***************************** TEST 16 A ******************');
  383. do_exec_test(@test16a,APropagateException);
  384. WriteLn('***************************** TEST 16 B ******************');
  385. do_exec_test(@test16b,APropagateException);
  386. WriteLn('***************************** TEST 16 C ******************');
  387. do_exec_test(@test16c,APropagateException);
  388. WriteLn('***************************** TEST 16 D ******************');
  389. do_exec_test(@test16d,APropagateException);
  390. WriteLn('***************************** TEST 16 E ******************');
  391. do_exec_test(@test16e,APropagateException);
  392. WriteLn('**** END TESTS');
  393. end;
  394. function ToAnsiChars(const AValue : array of TUnicodeCodePoint) : string;
  395. var
  396. i : Integer;
  397. s : string;
  398. begin
  399. Result := '';
  400. for i := Low(AValue) to High(AValue) do begin
  401. if (AValue[i] <= 127) then
  402. Result := Result + AnsiChar(AValue[i])
  403. else
  404. begin
  405. s := Format('%x',[AValue[i]]);
  406. if (Length(s) < 4) then
  407. s := StringOfChar('0',4-Length(s)) + s;
  408. Result := Result + '$' + s;
  409. end;
  410. end;
  411. end;
  412. function DumpSequenceAnsi(const ASequence : TOrderedCharacters) : string;
  413. var
  414. i : Integer;
  415. s : string;
  416. p : PReorderUnit;
  417. begin
  418. s := '';
  419. if (ASequence.ActualLength < 1) then
  420. exit;
  421. p := @ASequence.Data[0];
  422. i := 0;
  423. while (i < ASequence.ActualLength) do begin
  424. if (p^.WeigthKind <> TReorderWeigthKind.Deletion) then
  425. Break;
  426. WriteStr(s,s, ' ',ToAnsiChars(p^.Characters),'- ');
  427. Inc(p);
  428. Inc(i);
  429. end;
  430. if (i < ASequence.ActualLength) then begin
  431. s := s + ' ' + ToAnsiChars(p^.Characters) + ' ';
  432. Inc(i);
  433. Inc(p);
  434. for i := i to ASequence.ActualLength - 1 do begin
  435. //WriteStr(s,s,AnsiChar(p^.Characters[0]),' <',(1+Ord(p^.WeigthKind)),' ');
  436. if p^.IsVirtual() then
  437. WriteStr(s,s,' [',GetEnumName(TypeInfo(TReorderLogicalReset),Ord(p^.VirtualPosition)),'] ')
  438. else
  439. WriteStr(s,s,'<',(1+Ord(p^.WeigthKind)),' ',ToAnsiChars(p^.Characters),' ');
  440. Inc(p);
  441. end;
  442. end;
  443. Result := s;
  444. end;
  445. function DumpWeigth(const AItem : TUCA_WeightRec) : string;overload;
  446. var
  447. r : string;
  448. begin
  449. r := '[';
  450. if AItem.Variable then
  451. r := r + '*'
  452. else
  453. r := r + '.';
  454. r := r + Format('%x.%x.%x',[AItem.Weights[0],AItem.Weights[1],AItem.Weights[2]]);
  455. r := r + ']';
  456. Result := r;
  457. end;
  458. function DumpWeigth(const AItems : array of TUCA_WeightRec) : string;
  459. var
  460. r : string;
  461. i : Integer;
  462. begin
  463. r := '';
  464. for i := 0 to Length(AItems) - 1 do
  465. r := r + ' ' +DumpWeigth(AItems[i]);
  466. Result := Trim(r);
  467. end;
  468. function DumpKey(const AItem : TUCASortKey) : string;
  469. var
  470. i : Integer;
  471. r : string;
  472. begin
  473. r := '';
  474. for i := Low(AItem) to High(AItem) do
  475. r := Trim(r) + ' ' + Format('%4x',[AItem[i]]);
  476. Result := r;
  477. end;
  478. function DumpLine(ALine : TUCA_LineRec) : string;
  479. var
  480. i : Integer;
  481. r : string;
  482. ctxItem : TUCA_LineContextItemRec;
  483. begin
  484. r := '';
  485. if ALine.HasContext() then begin
  486. r := r + '*';
  487. for i := 0 to Length(ALine.Context.Data) - 1 do begin
  488. ctxItem := ALine.Context.Data[i];
  489. r := r + sLineBreak +
  490. ' ' + ToAnsiChars(ctxItem.CodePoints) + ' => ' + DumpWeigth(ctxItem.Weights);
  491. end;
  492. r := r + sLineBreak + ' ';
  493. end;
  494. if (Length(ALine.Weights) = 0) then begin
  495. r := r + '[]';
  496. end else begin
  497. for i := Low(ALine.Weights) to High(ALine.Weights) do
  498. r := r + DumpWeigth(ALine.Weights[i]);
  499. end;
  500. Result := Format('%s %s',[ToAnsiChars(ALine.CodePoints),r]);
  501. end;
  502. function DumpLines(ALines : TUCA_LineRecArray) : string;
  503. var
  504. i : Integer;
  505. r : string;
  506. begin
  507. r := '';
  508. for i := Low(ALines) to High(ALines) do
  509. r := r + ' ' + DumpLine(ALines[i]) + sLineBreak;
  510. Result := r;
  511. end;
  512. function CodePointToArray(const ACodePoint : TUnicodeCodePoint) : TUnicodeCodePointArray;overload;
  513. begin
  514. SetLength(Result,1);
  515. Result[0] := ACodePoint;
  516. end;
  517. function CodePointToArray(const ACodePoints : array of TUnicodeCodePoint) : TUnicodeCodePointArray;overload;
  518. var
  519. i : Integer;
  520. begin
  521. SetLength(Result,Length(ACodePoints));
  522. for i := 0 to length(ACodePoints) - 1 do
  523. Result[i] := ACodePoints[i];
  524. end;
  525. function ToWeight(const APrimary, ASecondary, ATertiary : Cardinal) : TUCA_WeightRecArray;overload;
  526. begin
  527. SetLength(Result,1);
  528. Result[0].Weights[0] := APrimary;
  529. Result[0].Weights[1] := ASecondary;
  530. Result[0].Weights[2] := ATertiary;
  531. Result[0].Weights[3] := 0;
  532. end;
  533. function ToWeight(const AWeigths : array of Cardinal) : TUCA_WeightRecArray;overload;
  534. var
  535. i, k, c : Integer;
  536. begin
  537. c := Length(AWeigths);
  538. SetLength(Result,(c div 3));
  539. k := 0;
  540. for i := 0 to (c div 3) - 1 do begin
  541. Result[i].Weights[0] := AWeigths[k+0];
  542. Result[i].Weights[1] := AWeigths[k+1];
  543. Result[i].Weights[2] := AWeigths[k+2];
  544. Result[i].Weights[3] := 0;
  545. k := k + 3;
  546. end;
  547. end;
  548. procedure constructPropBook(
  549. var ABook : unicodedata.TUCA_DataBook;
  550. const AFirstTable : TucaBmpFirstTable;
  551. const ASecondTable : TucaBmpSecondTable;
  552. const AOFirstTable : TucaOBmpFirstTable;
  553. const AOSecondTable : TucaOBmpSecondTable;
  554. const AInitDataBook : helper.TUCA_DataBook;
  555. const AInitPropBook : helper.PUCA_PropBook
  556. );
  557. var
  558. c, i, k, ci : Integer;
  559. begin
  560. c := Length(AFirstTable);
  561. if (c > 0) then begin
  562. ABook.BMP_Table1 := AllocMem(c);
  563. Move(AFirstTable[0],ABook.BMP_Table1^,c);
  564. end;
  565. c := Length(ASecondTable);
  566. if (c > 0) then begin
  567. ABook.BMP_Table2 := AllocMem(c*SizeOf(UInt24)*256);
  568. for i := 0 to c - 1 do begin
  569. for k := 0 to 255 do
  570. ABook.BMP_Table2[(i*256)+k] := ASecondTable[i][k];
  571. end;
  572. end;
  573. c := Length(AOFirstTable);
  574. if (c > 0) then begin
  575. ABook.OBMP_Table1 := AllocMem(c*SizeOf(Word));
  576. Move(AOFirstTable[0],ABook.OBMP_Table1^,(c*SizeOf(Word)));
  577. end;
  578. c := Length(AOSecondTable);
  579. if (c > 0) then begin
  580. ci := Length(AOSecondTable[0]);
  581. ABook.OBMP_Table2 := AllocMem(c*SizeOf(UInt24)*ci);
  582. for i := 0 to c - 1 do begin
  583. for k := 0 to ci - 1 do
  584. ABook.OBMP_Table2[(i*ci)+k] := AOSecondTable[i][k];
  585. end;
  586. end;
  587. ABook.Version := AInitDataBook.Version;
  588. ABook.VariableWeight := unicodedata.TUCA_VariableKind(Ord(AInitDataBook.VariableWeight));
  589. ABook.Backwards := AInitDataBook.Backwards;
  590. ABook.PropCount := AInitPropBook^.ItemSize;
  591. ABook.Props := Pointer(AInitPropBook^.Items);
  592. ABook.VariableLowLimit := AInitPropBook^.VariableLowLimit;
  593. ABook.VariableHighLimit := AInitPropBook^.VariableHighLimit;
  594. end;
  595. procedure ConstructUnicodeBook(
  596. const AWeitghs : TUCA_LineRecArray;
  597. const AVersion : string;
  598. const ACollationName : string;
  599. const ABase : unicodedata.PUCA_DataBook;
  600. var AUnicodeBook : unicodedata.TUCA_DataBook
  601. );
  602. var
  603. dataBook : helper.TUCA_DataBook;
  604. propBook : helper.PUCA_PropBook;
  605. firstTable : TucaBmpFirstTable;
  606. secondTable : TucaBmpSecondTable;
  607. ofirstTable : TucaOBmpFirstTable;
  608. osecondTable : TucaOBmpSecondTable;
  609. i : Integer;
  610. begin
  611. FillByte(dataBook,SizeOf(dataBook),0);
  612. dataBook.Version := AVersion;
  613. SetLength(dataBook.Lines,Length(AWeitghs));
  614. for i := 0 to Length(AWeitghs)-1 do begin
  615. dataBook.Lines[i] := AWeitghs[i];
  616. dataBook.Lines[i].Stored := True;
  617. end;
  618. MakeUCA_Props(@dataBook,propBook);
  619. MakeUCA_BmpTables(firstTable,secondTable,propBook);
  620. MakeUCA_OBmpTables(ofirstTable,osecondTable,propBook);
  621. FillByte(AUnicodeBook,SizeOf(AUnicodeBook),0);
  622. constructPropBook(
  623. AUnicodeBook,firstTable,secondTable,ofirstTable,osecondTable,
  624. dataBook,propBook
  625. );
  626. AUnicodeBook.CollationName := ACollationName;
  627. AUnicodeBook.Base := ABase;
  628. end;
  629. procedure CheckEqual(A,B : UnicodeString; ACollation : unicodedata.PUCA_DataBook);
  630. var
  631. keyA, keyB : TUCASortKey;
  632. s : string;
  633. begin
  634. keyA := ComputeSortKey(A,ACollation);
  635. keyB := ComputeSortKey(B,ACollation);
  636. if (CompareSortKey(keyA,keyB) <> 0) then begin
  637. s := Format(' KeyA=%s%s KeyB=%s',[DumpKey(keyA),sLineBreak,DumpKey(keyB)]);
  638. s := Format('"%s" <>= "%s" %s%s',[A,B,sLineBreak,s]);
  639. raise Exception.Create(s);
  640. end;
  641. end;
  642. procedure CheckNotEqual(A,B : UnicodeString; ACollation : unicodedata.PUCA_DataBook);
  643. var
  644. keyA, keyB : TUCASortKey;
  645. s : string;
  646. begin
  647. keyA := ComputeSortKey(A,ACollation);
  648. keyB := ComputeSortKey(B,ACollation);
  649. if (CompareSortKey(keyA,keyB) = 0) then begin
  650. s := Format(' KeyA=%s%s KeyB=%s',[DumpKey(keyA),sLineBreak,DumpKey(keyB)]);
  651. s := Format('"%s" = "%s" %s%s',[A,B,sLineBreak,s]);
  652. raise Exception.Create(s);
  653. end;
  654. end;
  655. procedure CheckInf(A,B : UnicodeString; ACollation : unicodedata.PUCA_DataBook);
  656. var
  657. keyA, keyB : TUCASortKey;
  658. begin
  659. keyA := ComputeSortKey(A,ACollation);
  660. keyB := ComputeSortKey(B,ACollation);
  661. if (CompareSortKey(keyA,keyB) >= 0) then
  662. raise Exception.CreateFmt('"%s" >= "%s" !',[A,B]);
  663. end;
  664. procedure CheckInf(AStrings : array of UnicodeString; ACollation : unicodedata.PUCA_DataBook);
  665. var
  666. c, i : Integer;
  667. keyA, keyB : TUCASortKey;
  668. s : string;
  669. begin
  670. c := Length(AStrings);
  671. if (c < 2) then
  672. exit;
  673. keyA := ComputeSortKey(AStrings[0],ACollation);
  674. for i := 1 to c - 1 do begin
  675. keyB := ComputeSortKey(AStrings[i],ACollation);
  676. if (CompareSortKey(keyA,keyB) >= 0) then begin
  677. s := Format(' KeyA=%s%s KeyB=%s',[DumpKey(keyA),sLineBreak,DumpKey(keyB)]);
  678. s := Format('"%s" >= "%s" %s%s',[AStrings[i-1],AStrings[i],sLineBreak,s]);
  679. raise Exception.Create(s);
  680. end;
  681. keyA := keyB;
  682. end;
  683. end;
  684. procedure test1_prepareWeigth(var AData : TUCA_LineRecArray);
  685. var
  686. p : PUCA_LineRec;
  687. begin
  688. SetLength(AData,12);
  689. p := @AData[Low(AData)];
  690. p^.CodePoints := CodePointToArray(Ord('a'));
  691. p^.Weights := ToWeight($15EF,$0020,$0002);
  692. Inc(p);
  693. p^.CodePoints := CodePointToArray(Ord('b'));
  694. p^.Weights := ToWeight($1605,$0020,$0002);
  695. Inc(p);
  696. p^.CodePoints := CodePointToArray(Ord('c'));
  697. p^.Weights := ToWeight($161D,$0020,$0002);
  698. Inc(p);
  699. p^.CodePoints := CodePointToArray(Ord('d'));
  700. p^.Weights := ToWeight($1631,$0020,$0002);
  701. Inc(p);
  702. p^.CodePoints := CodePointToArray(Ord('e'));
  703. p^.Weights := ToWeight($164C,$0020,$0002);
  704. Inc(p);
  705. p^.CodePoints := CodePointToArray(Ord('f'));
  706. p^.Weights := ToWeight($1684,$0020,$0002);
  707. Inc(p);
  708. p^.CodePoints := CodePointToArray(Ord('g'));
  709. p^.Weights := ToWeight($1691,$0020,$0002);
  710. Inc(p);
  711. p^.CodePoints := CodePointToArray(Ord('h'));
  712. p^.Weights := ToWeight($16B4,$0020,$0002);
  713. Inc(p);
  714. p^.CodePoints := CodePointToArray(Ord('i'));
  715. p^.Weights := ToWeight($16CD,$0020,$0002);
  716. Inc(p);
  717. p^.CodePoints := CodePointToArray(Ord('j'));
  718. p^.Weights := ToWeight($16E6,$0020,$0002);
  719. Inc(p);
  720. p^.CodePoints := CodePointToArray(Ord('k'));
  721. p^.Weights := ToWeight($16FF,$0020,$0002);
  722. Inc(p);
  723. p^.CodePoints := CodePointToArray(Ord('l'));
  724. p^.Weights := ToWeight($1711,$0020,$0002);
  725. end;
  726. procedure test1();
  727. var
  728. sequence : TOrderedCharacters;
  729. statement : TReorderSequence;
  730. wfirst, wresult : TUCA_LineRecArray;
  731. i : Integer;
  732. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  733. begin
  734. statement.Clear();
  735. test1_prepareWeigth(wfirst);
  736. sequence := TOrderedCharacters.Create();
  737. sequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  738. sequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  739. sequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  740. sequence.Append(TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,4));
  741. sequence.Append(TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,5));
  742. sequence.Append(TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,6));
  743. sequence.Append(TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,7));
  744. sequence.Append(TReorderUnit.From(Ord('h'),TReorderWeigthKind.Primary,8));
  745. sequence.Append(TReorderUnit.From(Ord('i'),TReorderWeigthKind.Primary,9));
  746. sequence.Append(TReorderUnit.From(Ord('j'),TReorderWeigthKind.Primary,10));
  747. sequence.Append(TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,11));
  748. sequence.Append(TReorderUnit.From(Ord('l'),TReorderWeigthKind.Primary,12));
  749. for i := 0 to sequence.ActualLength - 1 do
  750. sequence.Data[i].Changed := False;
  751. WriteLn('Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  752. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  753. ConstructUnicodeBook(wfirst,'test1','first',nil,unicodeBook1);
  754. CheckInf(['a','b','c','d','e','f','g','h','i','j','k','l'],@unicodeBook1);
  755. SetLength(statement.Reset,1);
  756. statement.Reset[0] := Ord('a');
  757. statement.SetElementCount(1);
  758. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  759. sequence.ApplyStatement(@statement);
  760. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  761. wresult := nil;
  762. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  763. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  764. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  765. CheckInf(['a','g'{*},'b','c','d','e','f','h','i','j','k','l'],@unicodeBook2);
  766. SetLength(statement.Reset,1);
  767. statement.Reset[0] := Ord('a');
  768. statement.SetElementCount(2);
  769. statement.Elements[0] := TReorderUnit.From(Ord('h'),TReorderWeigthKind.Primary,0);
  770. statement.Elements[1] := TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,0);
  771. sequence.ApplyStatement(@statement);
  772. WriteLn('Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  773. wresult := nil;
  774. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  775. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  776. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  777. CheckInf(['a','h'{*},'k'{*},'g'{*},'b','c','d','e','f','i','j','l'],@unicodeBook2);
  778. SetLength(statement.Reset,1);
  779. statement.Reset[0] := Ord('h');
  780. statement.SetElementCount(1);
  781. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Secondary,0);
  782. sequence.ApplyStatement(@statement);
  783. WriteLn('Statement #3 = ',sLineBreak,' ',DumpSequenceAnsi(sequence));
  784. wresult := nil;
  785. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  786. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  787. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  788. CheckInf(['a','h'{*},'g'{*},'k'{*},'b','c','d','e','f','i','j','l'],@unicodeBook2);
  789. end;
  790. procedure test2_prepareWeigth(var AData : TUCA_LineRecArray);
  791. var
  792. p : PUCA_LineRec;
  793. begin
  794. SetLength(AData,11);
  795. p := @AData[Low(AData)];
  796. p^.CodePoints := CodePointToArray(Ord('a'));
  797. p^.Weights := ToWeight($15EF,$0020,$0002);
  798. Inc(p);
  799. p^.CodePoints := CodePointToArray([Ord('('),Ord('a'),Ord(')')]);
  800. p^.Weights := ToWeight($15EF,$0020,$0006); //15EF.0020.0006.24D0
  801. Inc(p);
  802. p^.CodePoints := CodePointToArray(Ord('A'));
  803. p^.Weights := ToWeight($15EF,$0020,$0008); //15EF.0020.0008.0041
  804. Inc(p);
  805. p^.CodePoints := CodePointToArray([Ord('('),Ord('A'),Ord(')')]);
  806. p^.Weights := ToWeight($15EF,$0020,$000C); //15EF.0020.000C
  807. Inc(p);
  808. p^.CodePoints := CodePointToArray([Ord('a'),Ord('`')]);
  809. p^.Weights := ToWeight([$15EF,$0020,$0002, $0000,$0035,$0002]); //[.15EF.0020.0002.0061][.0000.0035.0002.0300]
  810. Inc(p);
  811. p^.CodePoints := CodePointToArray([Ord('A'),Ord('`')]);
  812. p^.Weights := ToWeight([$15EF,$0020,$0008, $0000,$0035,$0002]); //[.15EF.0020.0008.0041][.0000.0035.0002.0300]
  813. Inc(p);
  814. p^.CodePoints := CodePointToArray([Ord('a'),Ord('e')]);
  815. p^.Weights := ToWeight([$15F0,$0020,$0002]); //[.15EF.0020.0004.00E6][.0000.0139.0004.00E6][.164C.0020.0004.00E6]
  816. Inc(p);
  817. p^.CodePoints := CodePointToArray([Ord(UpCase('a')),Ord(UpCase('e'))]);
  818. p^.Weights := ToWeight([$15F0,$0020,$0006]);//[.15EF.0020.000A.00C6][.0000.0139.0004.00C6][.164C.0020.000A.00C6]
  819. Inc(p);
  820. p^.CodePoints := CodePointToArray(Ord('b'));
  821. p^.Weights := ToWeight($1605,$0020,$0002);
  822. Inc(p);
  823. p^.CodePoints := CodePointToArray([Ord('('),Ord('b'),Ord(')')]);
  824. p^.Weights := ToWeight($1605,$0020,$0006); //.1605.0020.0006.24D1
  825. Inc(p);
  826. p^.CodePoints := CodePointToArray(Ord('B'));
  827. p^.Weights := ToWeight($1605,$0020,$0008); //1605.0020.0008.0042
  828. end;
  829. procedure test2();
  830. var
  831. sequenceClean, sequence : TOrderedCharacters;
  832. statement : TReorderSequence;
  833. wfirst, wresult : TUCA_LineRecArray;
  834. i : Integer;
  835. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  836. begin
  837. statement.Clear();
  838. test2_prepareWeigth(wfirst);
  839. sequenceClean := TOrderedCharacters.Create();
  840. sequenceClean.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  841. sequenceClean.Append(TReorderUnit.From([Ord('('),Ord('a'),Ord(')')],TReorderWeigthKind.Tertiary,2));
  842. sequenceClean.Append(TReorderUnit.From(Ord('A'),TReorderWeigthKind.Tertiary,3));
  843. sequenceClean.Append(TReorderUnit.From([Ord('('),Ord('A'),Ord(')')],TReorderWeigthKind.Tertiary,4));
  844. //sequenceClean.Append(TReorderUnit.From(Ord('à'),TReorderWeigthKind.Secondary,0));
  845. sequenceClean.Append(TReorderUnit.From([Ord('a'),Ord('`')],TReorderWeigthKind.Secondary,5));
  846. //sequenceClean.Append(TReorderUnit.From(Ord(UpCase('à')),TReorderWeigthKind.Tertiary,0));
  847. sequenceClean.Append(TReorderUnit.From([Ord('A'),Ord('`')],TReorderWeigthKind.Tertiary,6));
  848. sequenceClean.Append(TReorderUnit.From([Ord('a'),Ord('e')],TReorderWeigthKind.Primary,7));
  849. sequenceClean.Append(TReorderUnit.From([Ord(UpCase('a')),Ord(UpCase('e'))],TReorderWeigthKind.Tertiary,8));
  850. sequenceClean.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,9));
  851. sequenceClean.Append(TReorderUnit.From([Ord('('),Ord('b'),Ord(')')],TReorderWeigthKind.Tertiary,10));
  852. sequenceClean.Append(TReorderUnit.From(Ord('B'),TReorderWeigthKind.Tertiary,11));
  853. for i := 0 to sequenceClean.ActualLength - 1 do
  854. sequenceClean.Data[i].Changed := False;
  855. WriteLn('Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  856. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  857. ConstructUnicodeBook(wfirst,'test1','first',nil,unicodeBook1);
  858. CheckInf(['a','(a)','A','(A)', 'a`','A`', 'ae','AE', 'b','(b)','B'],@unicodeBook1);
  859. sequence := sequenceClean.Clone();
  860. SetLength(statement.Reset,1);
  861. statement.Reset[0] := Ord('a');
  862. SetLength(statement.Elements,1);
  863. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  864. sequence.ApplyStatement(@statement);
  865. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  866. wresult := nil;
  867. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  868. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  869. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  870. CheckInf(['a','(a)','A','(A)', 'a`','A`', 'g'{*}, 'ae','AE', 'b','(b)','B'],@unicodeBook2);
  871. CheckInf(['gg','ae'],@unicodeBook2);
  872. CheckInf(['gb','ae'],@unicodeBook2);
  873. //CheckInf(['aeae','AE'],@unicodeBook2);
  874. sequence := sequenceClean.Clone();
  875. SetLength(statement.Reset,1);
  876. statement.Reset[0] := Ord('a');
  877. SetLength(statement.Elements,1);
  878. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Secondary,0);
  879. sequence.ApplyStatement(@statement);
  880. WriteLn('Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  881. wresult := nil;
  882. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  883. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  884. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  885. CheckInf(['a','(a)','A','(A)', 'g'{*}, 'a`','A`', 'ae','AE', 'b','(b)','B'],@unicodeBook2);
  886. CheckInf(['(A)a','ga'],@unicodeBook2);
  887. CheckInf(['g','ae'],@unicodeBook2);
  888. sequence := sequenceClean.Clone();
  889. SetLength(statement.Reset,1);
  890. statement.Reset[0] := Ord('a');
  891. SetLength(statement.Elements,1);
  892. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Tertiary,0);
  893. sequence.ApplyStatement(@statement);
  894. WriteLn('Statement #3 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  895. wresult := nil;
  896. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  897. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  898. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  899. CheckInf(['a', 'g'{*},'(a)','A','(A)', 'a`','A`', 'ae','AE', 'b','(b)','B'],@unicodeBook2);
  900. CheckInf(['aa','ga'],@unicodeBook2);
  901. CheckInf(['ga','(a)a'],@unicodeBook2);
  902. sequence := sequenceClean.Clone();
  903. SetLength(statement.Reset,2);
  904. statement.Reset[0] := Ord('a');
  905. statement.Reset[1] := Ord('`');
  906. SetLength(statement.Elements,1);
  907. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Tertiary,0);
  908. sequence.ApplyStatement(@statement);
  909. WriteLn('Statement #4 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  910. wresult := nil;
  911. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  912. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  913. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  914. CheckInf(['a','(a)','A','(A)', 'a`', 'g'{*},'A`', 'ae','AE', 'b','(b)','B'],@unicodeBook2);
  915. CheckInf(['a`a','ga'],@unicodeBook2);
  916. CheckInf(['ga','ae'],@unicodeBook2);
  917. end;
  918. //------------------------------------------------------
  919. procedure test3_prepareWeigth(var AData : TUCA_LineRecArray);
  920. var
  921. p : PUCA_LineRec;
  922. begin
  923. SetLength(AData,12);
  924. p := @AData[Low(AData)];
  925. p^.CodePoints := CodePointToArray(Ord('a'));
  926. p^.Weights := ToWeight($15EF,$0020,$0002);
  927. Inc(p);
  928. p^.CodePoints := CodePointToArray(Ord('b'));
  929. p^.Weights := ToWeight($1605,$0020,$0002);
  930. Inc(p);
  931. p^.CodePoints := CodePointToArray(Ord('c'));
  932. p^.Weights := ToWeight($161D,$0020,$0002);
  933. Inc(p);
  934. p^.CodePoints := CodePointToArray(Ord('d'));
  935. p^.Weights := ToWeight($1631,$0020,$0002);
  936. Inc(p);
  937. p^.CodePoints := CodePointToArray(Ord('e'));
  938. p^.Weights := ToWeight($164C,$0020,$0002);
  939. Inc(p);
  940. p^.CodePoints := CodePointToArray(Ord('f'));
  941. p^.Weights := ToWeight($1684,$0020,$0002);
  942. Inc(p);
  943. p^.CodePoints := CodePointToArray(Ord('g'));
  944. p^.Weights := ToWeight($1691,$0020,$0002);
  945. Inc(p);
  946. p^.CodePoints := CodePointToArray(Ord('h'));
  947. p^.Weights := ToWeight($16B4,$0020,$0002);
  948. Inc(p);
  949. p^.CodePoints := CodePointToArray(Ord('i'));
  950. p^.Weights := ToWeight($16CD,$0020,$0002);
  951. Inc(p);
  952. p^.CodePoints := CodePointToArray(Ord('j'));
  953. p^.Weights := ToWeight($16E6,$0020,$0002);
  954. Inc(p);
  955. p^.CodePoints := CodePointToArray(Ord('k'));
  956. p^.Weights := ToWeight($16FF,$0020,$0002);
  957. Inc(p);
  958. p^.CodePoints := CodePointToArray(Ord('l'));
  959. p^.Weights := ToWeight($1711,$0020,$0002);
  960. end;
  961. procedure PopulateSequence(var ASequence : TOrderedCharacters);
  962. var
  963. i : Integer;
  964. begin
  965. ASequence := TOrderedCharacters.Create();
  966. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  967. ASequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  968. ASequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  969. ASequence.Append(TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,4));
  970. ASequence.Append(TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,5));
  971. ASequence.Append(TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,6));
  972. ASequence.Append(TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,7));
  973. ASequence.Append(TReorderUnit.From(Ord('h'),TReorderWeigthKind.Primary,8));
  974. ASequence.Append(TReorderUnit.From(Ord('i'),TReorderWeigthKind.Primary,9));
  975. ASequence.Append(TReorderUnit.From(Ord('j'),TReorderWeigthKind.Primary,10));
  976. ASequence.Append(TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,11));
  977. ASequence.Append(TReorderUnit.From(Ord('l'),TReorderWeigthKind.Primary,12));
  978. for i := 0 to ASequence.ActualLength - 1 do
  979. ASequence.Data[i].Changed := False;
  980. end;
  981. procedure test3();
  982. var
  983. sequence, sequenceClean : TOrderedCharacters;
  984. statement : TReorderSequence;
  985. wfirst, wresult : TUCA_LineRecArray;
  986. i : Integer;
  987. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  988. keyA, keyB : TUCASortKey;
  989. us : UnicodeString;
  990. begin //'a','b','c','d','e','f','g','h','i','j','k','l'
  991. statement.Clear();
  992. test3_prepareWeigth(wfirst);
  993. PopulateSequence(sequenceClean);
  994. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  995. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  996. //Generate the original tables
  997. ConstructUnicodeBook(wfirst,'test3','first',nil,unicodeBook1);
  998. us := 'a';
  999. keyA := ComputeSortKey(us,@unicodeBook1);
  1000. for i := Ord('b') to Ord('l') do begin
  1001. us := unicodeChar(i);
  1002. keyB := ComputeSortKey(us,@unicodeBook1);
  1003. if (CompareSortKey(keyA,keyB) >= 0) then
  1004. raise Exception.CreateFmt('"%s" >= "%s" !',[AnsiChar(i-1),AnsiChar(i)]);
  1005. keyA := keyB;
  1006. end;
  1007. // --- test 1
  1008. sequence := sequenceClean.Clone();
  1009. SetLength(statement.Reset,1);
  1010. statement.Reset[0] := Ord('b');
  1011. SetLength(statement.Elements,1);
  1012. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  1013. sequence.ApplyStatement(@statement);
  1014. wresult := nil;
  1015. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1016. //Generate updatet tables
  1017. ConstructUnicodeBook(wresult,'test3','second',@unicodeBook1,unicodeBook2);
  1018. CheckInf(['a','b','g'{*}, 'c','d','e','f','h','i','j','k','l'],@unicodeBook2);
  1019. CheckInf(['bb','g'{*}],@unicodeBook2);
  1020. CheckInf(['bc','g'{*}],@unicodeBook2);
  1021. CheckInf(['bc','gg'{*}],@unicodeBook2);
  1022. CheckInf(['bg','bc'{*}],@unicodeBook2);
  1023. WriteLn(' -- test 1 - ok');
  1024. // --- test 2
  1025. sequence := sequenceClean.Clone();
  1026. SetLength(statement.Reset,1);
  1027. statement.Reset[0] := Ord('c');
  1028. SetLength(statement.Elements,1);
  1029. statement.Elements[0] := TReorderUnit.From([Ord('c'),Ord('h')],TReorderWeigthKind.Primary,0);
  1030. sequence.ApplyStatement(@statement);
  1031. wresult := nil;
  1032. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1033. //Generate updatet tables
  1034. ConstructUnicodeBook(wresult,'test3','second',@unicodeBook1,unicodeBook2);
  1035. CheckInf(['a','b','c','ch'{*},'d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  1036. CheckInf(['ca','ch'{*}],@unicodeBook2);
  1037. CheckInf(['cc','ch'{*}],@unicodeBook2);
  1038. CheckInf(['cd','ch'{*}],@unicodeBook2);
  1039. CheckInf(['ce','ch'{*}],@unicodeBook2);
  1040. CheckInf(['cf','ch'{*}],@unicodeBook2);
  1041. CheckInf(['ci','ch'{*}],@unicodeBook2);
  1042. CheckInf(['cj','ch'{*}],@unicodeBook2);
  1043. CheckInf(['ck','ch'{*}],@unicodeBook2);
  1044. CheckInf(['cl','ch'{*}],@unicodeBook2);
  1045. CheckInf(['ac','ach'{*}],@unicodeBook2);
  1046. CheckInf(['aci','achat'{*}],@unicodeBook2);
  1047. WriteLn(' -- test 2 - ok');
  1048. // --- test 3
  1049. sequence := sequenceClean.Clone();
  1050. SetLength(statement.Reset,1);
  1051. statement.Reset[0] := Ord('c');
  1052. SetLength(statement.Elements,1);
  1053. statement.Elements[0] := TReorderUnit.From(Ord('k'),TReorderWeigthKind.Identity,0);
  1054. sequence.ApplyStatement(@statement);
  1055. wresult := nil;
  1056. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1057. //Generate updatet tables
  1058. ConstructUnicodeBook(wresult,'test3','second',@unicodeBook1,unicodeBook2);
  1059. CheckInf(['a','b','k'{*},'d','e','f','g','h','i','j','l'],@unicodeBook2);
  1060. CheckInf(['a','b','c'{*},'d','e','f','g','h','i','j','l'],@unicodeBook2);
  1061. CheckEqual('c','k',@unicodeBook2);
  1062. CheckEqual('cc','kk',@unicodeBook2);
  1063. CheckEqual('ck','kc',@unicodeBook2);
  1064. CheckEqual('kc','kk',@unicodeBook2);
  1065. CheckEqual('cckkc','kckcc',@unicodeBook2);
  1066. CheckInf(['acb','akc'{*}],@unicodeBook2);
  1067. WriteLn(' -- test 3 - ok');
  1068. // --- test 4
  1069. sequence := sequenceClean.Clone();
  1070. SetLength(statement.Reset,1);
  1071. statement.Reset[0] := Ord('a');
  1072. SetLength(statement.Elements,1);
  1073. statement.Elements[0] := TReorderUnit.From([Ord('c')],TReorderWeigthKind.Primary,0);
  1074. sequence.ApplyStatement(@statement);
  1075. statement.Reset[0] := Ord('c');
  1076. SetLength(statement.Elements,1);
  1077. statement.Elements[0] := TReorderUnit.From([Ord('c'),Ord('h')],TReorderWeigthKind.Primary,0);
  1078. sequence.ApplyStatement(@statement);
  1079. wresult := nil;
  1080. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1081. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1082. //Generate updatet tables
  1083. ConstructUnicodeBook(wresult,'test3','second',@unicodeBook1,unicodeBook2);
  1084. CheckInf(['a','c'{*},'ch'{*},'b','d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  1085. CheckInf(['ca','ch'{*}],@unicodeBook2);
  1086. CheckInf(['cc','ch'{*}],@unicodeBook2);
  1087. CheckInf(['cd','ch'{*}],@unicodeBook2);
  1088. CheckInf(['ce','ch'{*}],@unicodeBook2);
  1089. CheckInf(['cf','ch'{*}],@unicodeBook2);
  1090. CheckInf(['ci','ch'{*}],@unicodeBook2);
  1091. CheckInf(['cj','ch'{*}],@unicodeBook2);
  1092. CheckInf(['ck','ch'{*}],@unicodeBook2);
  1093. CheckInf(['cl','ch'{*}],@unicodeBook2);
  1094. CheckInf(['ac','ach'{*}],@unicodeBook2);
  1095. CheckInf(['aci','achat'{*}],@unicodeBook2);
  1096. WriteLn(' -- test 4 - ok');
  1097. end;
  1098. //------------------------------------------------------
  1099. procedure test4_prepareWeigth(var AData : TUCA_LineRecArray);
  1100. var
  1101. p : PUCA_LineRec;
  1102. begin
  1103. SetLength(AData,12);
  1104. p := @AData[Low(AData)];
  1105. p^.CodePoints := CodePointToArray(Ord('a'));
  1106. p^.Weights := ToWeight($15EF,$0020,$0002);
  1107. Inc(p);
  1108. p^.CodePoints := CodePointToArray(Ord('b'));
  1109. p^.Weights := ToWeight($1605,$0020,$0002);
  1110. Inc(p);
  1111. p^.CodePoints := CodePointToArray(Ord('c')); {*}
  1112. p^.Weights := ToWeight($1606,$0020,$0002);
  1113. Inc(p);
  1114. p^.CodePoints := CodePointToArray(Ord('d'));
  1115. p^.Weights := ToWeight($1631,$0020,$0002);
  1116. Inc(p);
  1117. p^.CodePoints := CodePointToArray(Ord('e'));
  1118. p^.Weights := ToWeight($164C,$0020,$0002);
  1119. Inc(p);
  1120. p^.CodePoints := CodePointToArray(Ord('f'));
  1121. p^.Weights := ToWeight($1684,$0020,$0002);
  1122. Inc(p);
  1123. p^.CodePoints := CodePointToArray(Ord('g'));
  1124. p^.Weights := ToWeight($1691,$0020,$0002);
  1125. Inc(p);
  1126. p^.CodePoints := CodePointToArray(Ord('h'));
  1127. p^.Weights := ToWeight($16B4,$0020,$0002);
  1128. Inc(p);
  1129. p^.CodePoints := CodePointToArray(Ord('i'));
  1130. p^.Weights := ToWeight($16CD,$0020,$0002);
  1131. Inc(p);
  1132. p^.CodePoints := CodePointToArray(Ord('j'));
  1133. p^.Weights := ToWeight($16E6,$0020,$0002);
  1134. Inc(p);
  1135. p^.CodePoints := CodePointToArray(Ord('k'));
  1136. p^.Weights := ToWeight($16FF,$0020,$0002);
  1137. Inc(p);
  1138. p^.CodePoints := CodePointToArray(Ord('l'));
  1139. p^.Weights := ToWeight($1711,$0020,$0002);
  1140. end;
  1141. procedure test4();
  1142. var
  1143. sequence, sequenceClean : TOrderedCharacters;
  1144. statement : TReorderSequence;
  1145. wfirst, wresult : TUCA_LineRecArray;
  1146. i : Integer;
  1147. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  1148. keyA, keyB : TUCASortKey;
  1149. us : UnicodeString;
  1150. begin
  1151. statement.Clear();
  1152. test4_prepareWeigth(wfirst);
  1153. PopulateSequence(sequenceClean);
  1154. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  1155. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  1156. //Generate the original tables
  1157. ConstructUnicodeBook(wfirst,'test4','first',nil,unicodeBook1);
  1158. us := 'a';
  1159. keyA := ComputeSortKey(us,@unicodeBook1);
  1160. for i := Ord('b') to Ord('l') do begin
  1161. us := unicodeChar(i);
  1162. keyB := ComputeSortKey(us,@unicodeBook1);
  1163. if (CompareSortKey(keyA,keyB) >= 0) then
  1164. raise Exception.CreateFmt('"%s" >= "%s" !',[AnsiChar(i-1),AnsiChar(i)]);
  1165. keyA := keyB;
  1166. end;
  1167. // --- test 1
  1168. sequence := sequenceClean.Clone();
  1169. SetLength(statement.Reset,1);
  1170. statement.Reset[0] := Ord('b');
  1171. SetLength(statement.Elements,1);
  1172. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  1173. sequence.ApplyStatement(@statement);
  1174. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1175. wresult := nil;
  1176. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1177. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1178. //Generate updatet tables
  1179. ConstructUnicodeBook(wresult,'test4','second',@unicodeBook1,unicodeBook2);
  1180. unicodeBook2.Base := @unicodeBook1;
  1181. CheckInf(['a','b','g'{*}, 'c','d','e','f','h','i','j','k','l'],@unicodeBook2);
  1182. CheckInf(['g'{*}, 'c'],@unicodeBook2);
  1183. CheckInf(['gg'{*}, 'c'],@unicodeBook2);
  1184. CheckInf(['gg'{*}, 'cc'],@unicodeBook2);
  1185. CheckInf(['g'{*}, 'ca'],@unicodeBook2);
  1186. CheckInf(['gg'{*}, 'ca'],@unicodeBook2);
  1187. CheckInf(['bb','g'{*}],@unicodeBook2);
  1188. CheckInf(['bc','g'{*}],@unicodeBook2);
  1189. CheckInf(['bc','gg'{*}],@unicodeBook2);
  1190. CheckInf(['bg','bc'{*}],@unicodeBook2);
  1191. WriteLn(' -- test 1 - ok',sLineBreak);
  1192. // --- test 2
  1193. sequence := sequenceClean.Clone();
  1194. SetLength(statement.Reset,1);
  1195. statement.Reset[0] := Ord('b');
  1196. SetLength(statement.Elements,2);
  1197. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  1198. statement.Elements[1] := TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,0);
  1199. sequence.ApplyStatement(@statement);
  1200. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1201. wresult := nil;
  1202. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1203. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1204. //Generate updatet tables
  1205. ConstructUnicodeBook(wresult,'test4','second',@unicodeBook1,unicodeBook2);
  1206. unicodeBook2.Base := @unicodeBook1;
  1207. CheckInf(['a','b','g'{*},'k'{*}, 'c','d','e','f','h','i','j','l'],@unicodeBook2);
  1208. CheckInf(['g'{*}, 'c'],@unicodeBook2);
  1209. CheckInf(['k'{*}, 'c'],@unicodeBook2);
  1210. CheckInf(['b','kk'{*}],@unicodeBook2);
  1211. CheckInf(['bb','kk'{*}],@unicodeBook2);
  1212. CheckInf(['b','kkk'{*}],@unicodeBook2);
  1213. CheckInf(['gk','kk'{*}],@unicodeBook2);
  1214. CheckInf(['gk','k'{*}],@unicodeBook2);
  1215. CheckInf(['gk','kkk'{*}],@unicodeBook2);
  1216. CheckInf(['gg'{*}, 'c'],@unicodeBook2);
  1217. CheckInf(['gg'{*}, 'cc'],@unicodeBook2);
  1218. CheckInf(['g'{*}, 'ca'],@unicodeBook2);
  1219. CheckInf(['gg'{*}, 'ca'],@unicodeBook2);
  1220. CheckInf(['bb','g'{*}],@unicodeBook2);
  1221. CheckInf(['bc','g'{*}],@unicodeBook2);
  1222. CheckInf(['bc','gg'{*}],@unicodeBook2);
  1223. CheckInf(['bg','bc'{*}],@unicodeBook2);
  1224. WriteLn(' -- test 2 - ok');
  1225. end;
  1226. //-------------------------------------------------------------------------
  1227. procedure test5_prepareWeigth(var AData : TUCA_LineRecArray);
  1228. var
  1229. p : PUCA_LineRec;
  1230. begin
  1231. SetLength(AData,6);
  1232. p := @AData[Low(AData)];
  1233. p^.CodePoints := CodePointToArray(Ord('a'));
  1234. p^.Weights := ToWeight($15EF,$0020,$0002);
  1235. Inc(p);
  1236. p^.CodePoints := CodePointToArray(Ord('b'));
  1237. p^.Weights := ToWeight($1605,$0020,$0002);
  1238. Inc(p);
  1239. p^.CodePoints := CodePointToArray([Ord('a'),Ord('d'),Ord('a')]);
  1240. p^.Weights := ToWeight($1609,$0020,$0002);
  1241. Inc(p);
  1242. p^.CodePoints := CodePointToArray(Ord('c'));
  1243. p^.Weights := ToWeight($161D,$0020,$0002);
  1244. Inc(p);
  1245. p^.CodePoints := CodePointToArray(Ord('d'));
  1246. p^.Weights := ToWeight($1631,$0020,$0002);
  1247. Inc(p);
  1248. p^.CodePoints := CodePointToArray(Ord('e'));
  1249. p^.Weights := ToWeight($164C,$0020,$0002);
  1250. end;
  1251. procedure test5_PopulateSequence(var ASequence : TOrderedCharacters);
  1252. var
  1253. i : Integer;
  1254. begin
  1255. ASequence := TOrderedCharacters.Create();
  1256. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  1257. ASequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  1258. ASequence.Append(TReorderUnit.From([Ord('a'),Ord('d'),Ord('a')],TReorderWeigthKind.Primary,3));
  1259. ASequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,4));
  1260. ASequence.Append(TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,5));
  1261. ASequence.Append(TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,6));
  1262. for i := 0 to ASequence.ActualLength - 1 do
  1263. ASequence.Data[i].Changed := False;
  1264. end;
  1265. procedure test5();
  1266. var
  1267. sequence, sequenceClean : TOrderedCharacters;
  1268. statement : TReorderSequence;
  1269. wfirst, wresult : TUCA_LineRecArray;
  1270. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  1271. begin
  1272. statement.Clear();
  1273. test5_prepareWeigth(wfirst);
  1274. test5_PopulateSequence(sequenceClean);
  1275. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  1276. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  1277. //Generate the original tables
  1278. ConstructUnicodeBook(wfirst,'test5','first',nil,unicodeBook1);
  1279. CheckInf(['a','b','ada','c','d','e'],@unicodeBook1);
  1280. CheckInf(['ba','adaa'],@unicodeBook1);
  1281. // --- test 1
  1282. sequence := sequenceClean.Clone();
  1283. SetLength(statement.Reset,0);
  1284. SetLength(statement.Elements,1);
  1285. statement.Elements[0] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Deletion,0);
  1286. sequence.ApplyStatement(@statement);
  1287. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1288. wresult := nil;
  1289. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1290. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1291. //Generate updatet tables
  1292. ConstructUnicodeBook(wresult,'test5','second',@unicodeBook1,unicodeBook2);
  1293. unicodeBook2.Base := @unicodeBook1;
  1294. CheckInf(['a','b','ada','d','e', 'c'{* deleted !}],@unicodeBook2);
  1295. CheckInf(['ee','ca'],@unicodeBook2);
  1296. WriteLn(' -- test 1 - ok',sLineBreak);
  1297. // --- test 2
  1298. sequence := sequenceClean.Clone();
  1299. SetLength(statement.Reset,0);
  1300. SetLength(statement.Elements,1);
  1301. statement.Elements[0] := TReorderUnit.From([Ord('a'),Ord('d'),Ord('a')],TReorderWeigthKind.Deletion,0);
  1302. sequence.ApplyStatement(@statement);
  1303. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1304. wresult := nil;
  1305. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1306. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1307. //Generate updatet tables
  1308. ConstructUnicodeBook(wresult,'test5','second',@unicodeBook1,unicodeBook2);
  1309. unicodeBook2.Base := @unicodeBook1;
  1310. CheckInf(['a', 'adac'{* deleted !}, 'b','c','d','e'],@unicodeBook2);
  1311. CheckInf(['a','ada'],@unicodeBook2);
  1312. CheckInf(['ada','b'],@unicodeBook2);
  1313. CheckInf(['ac','ada'],@unicodeBook2);
  1314. CheckInf(['ac','adac'],@unicodeBook2);
  1315. CheckInf(['abe','ada'],@unicodeBook2);
  1316. CheckInf(['abe','adae'],@unicodeBook2);
  1317. WriteLn(' -- test 2 - ok',sLineBreak);
  1318. end;
  1319. //-------------------------------------------------------------------------
  1320. procedure test6_prepareWeigth(var AData : TUCA_LineRecArray);
  1321. var
  1322. p : PUCA_LineRec;
  1323. begin
  1324. SetLength(AData,7);
  1325. p := @AData[Low(AData)];
  1326. p^.CodePoints := CodePointToArray(Ord('a'));
  1327. p^.Weights := ToWeight($15EF,$0020,$0002);
  1328. Inc(p);
  1329. p^.CodePoints := CodePointToArray(Ord('b'));
  1330. p^.Weights := ToWeight($1605,$0020,$0002);
  1331. Inc(p);
  1332. p^.CodePoints := CodePointToArray([Ord('a'),Ord('d')]);
  1333. p^.Weights := ToWeight($1609,$0020,$0002);
  1334. Inc(p);
  1335. p^.CodePoints := CodePointToArray([Ord('a'),Ord('d'),Ord('a')]);
  1336. p^.Weights := ToWeight($1613,$0020,$0002);
  1337. Inc(p);
  1338. p^.CodePoints := CodePointToArray(Ord('c'));
  1339. p^.Weights := ToWeight($161D,$0020,$0002);
  1340. Inc(p);
  1341. p^.CodePoints := CodePointToArray(Ord('d'));
  1342. p^.Weights := ToWeight($1631,$0020,$0002);
  1343. Inc(p);
  1344. p^.CodePoints := CodePointToArray(Ord('e'));
  1345. p^.Weights := ToWeight($164C,$0020,$0002);
  1346. end;
  1347. procedure test6_PopulateSequence(var ASequence : TOrderedCharacters);
  1348. var
  1349. i : Integer;
  1350. begin
  1351. ASequence := TOrderedCharacters.Create();
  1352. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  1353. ASequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  1354. ASequence.Append(TReorderUnit.From([Ord('a'),Ord('d')],TReorderWeigthKind.Primary,3));
  1355. ASequence.Append(TReorderUnit.From([Ord('a'),Ord('d'),Ord('a')],TReorderWeigthKind.Primary,4));
  1356. ASequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,5));
  1357. ASequence.Append(TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,6));
  1358. ASequence.Append(TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,7));
  1359. for i := 0 to ASequence.ActualLength - 1 do
  1360. ASequence.Data[i].Changed := False;
  1361. end;
  1362. procedure test6();
  1363. var
  1364. sequence, sequenceClean : TOrderedCharacters;
  1365. statement : TReorderSequence;
  1366. wfirst, wresult : TUCA_LineRecArray;
  1367. unicodeBook1, unicodeBook2, unicodeBook3 : unicodedata.TUCA_DataBook;
  1368. begin
  1369. statement.Clear();
  1370. test6_prepareWeigth(wfirst);
  1371. test6_PopulateSequence(sequenceClean);
  1372. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  1373. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  1374. //Generate the original tables
  1375. ConstructUnicodeBook(wfirst,'test6','first',nil,unicodeBook1);
  1376. CheckInf(['a','b','ad','ada','c','d','e'],@unicodeBook1);
  1377. CheckInf(['ba','ad'],@unicodeBook1);
  1378. CheckInf(['ba','adaa'],@unicodeBook1);
  1379. // --- test 1
  1380. sequence := sequenceClean.Clone();
  1381. SetLength(statement.Reset,0);
  1382. SetLength(statement.Elements,1);
  1383. statement.Elements[0] := TReorderUnit.From([Ord('a'),Ord('d')],TReorderWeigthKind.Deletion,0);
  1384. sequence.ApplyStatement(@statement);
  1385. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1386. wresult := nil;
  1387. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1388. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1389. //Generate updatet tables
  1390. ConstructUnicodeBook(wresult,'test6','second',@unicodeBook1,unicodeBook2);
  1391. unicodeBook2.Base := @unicodeBook1;
  1392. CheckInf(['a', 'ad'{*},'ada', 'b','c','d','e'],@unicodeBook2);
  1393. CheckInf(['ab','ad'],@unicodeBook2);
  1394. CheckInf(['ab','adb'],@unicodeBook2);
  1395. CheckInf(['ad','ba'],@unicodeBook2);
  1396. CheckInf(['adaa','ba'],@unicodeBook2);
  1397. WriteLn(' -- test 1 - ok',sLineBreak);
  1398. // --- test 2
  1399. //sequence := sequenceClean.Clone();
  1400. SetLength(statement.Reset,0);
  1401. SetLength(statement.Elements,1);
  1402. statement.Elements[0] := TReorderUnit.From([Ord('a'),Ord('d'),Ord('a')],TReorderWeigthKind.Deletion,0);
  1403. sequence.ApplyStatement(@statement);
  1404. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1405. wresult := nil;
  1406. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1407. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1408. //Generate updatet tables
  1409. ConstructUnicodeBook(wresult,'test6','second',@unicodeBook2,unicodeBook3);
  1410. unicodeBook3.Base := @unicodeBook2;
  1411. CheckInf(['a', 'ad'{*},'ada'{*}, 'b','c','d','e'],@unicodeBook3);
  1412. CheckInf(['ab','ad'],@unicodeBook3);
  1413. CheckInf(['ab','adb'],@unicodeBook3);
  1414. CheckInf(['ab','ada'],@unicodeBook3);
  1415. WriteLn(' -- test 2 - ok',sLineBreak);
  1416. // --- test 3
  1417. sequence := sequenceClean.Clone();
  1418. SetLength(statement.Reset,0);
  1419. SetLength(statement.Elements,1);
  1420. statement.Elements[0] := TReorderUnit.From([Ord('a'),Ord('d'),Ord('a')],TReorderWeigthKind.Deletion,0);
  1421. sequence.ApplyStatement(@statement);
  1422. WriteLn(' Statement #3 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1423. wresult := nil;
  1424. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1425. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1426. //Generate updatet tables
  1427. ConstructUnicodeBook(wresult,'test6','second',@unicodeBook1,unicodeBook2);
  1428. unicodeBook2.Base := @unicodeBook1;
  1429. CheckInf(['a', 'b', 'ad', 'c','d','e'],@unicodeBook2);
  1430. CheckInf(['ad','ada'],@unicodeBook2);
  1431. WriteLn(' -- test 3 - ok',sLineBreak);
  1432. end;
  1433. //-------------------------------------------------------------------------
  1434. procedure test7_prepareWeigth(var AData : TUCA_LineRecArray);
  1435. var
  1436. p : PUCA_LineRec;
  1437. begin
  1438. SetLength(AData,8);
  1439. p := @AData[Low(AData)];
  1440. p^.CodePoints := CodePointToArray($030A);//030A ; [.0000.0043.0002.030A] # COMBINING RING ABOVE
  1441. p^.Weights := ToWeight($0000,$0043,$0002);
  1442. Inc(p);
  1443. p^.CodePoints := CodePointToArray($0327);//0327 ; [.0000.0056.0002.0327] # COMBINING CEDILLA
  1444. p^.Weights := ToWeight($0000,$0056,$0002);
  1445. Inc(p);
  1446. p^.CodePoints := CodePointToArray($0061);//a
  1447. p^.Weights := ToWeight($15EF,$0020,$0002);
  1448. Inc(p);
  1449. p^.CodePoints := CodePointToArray($0062);//b
  1450. p^.Weights := ToWeight($1605,$0020,$0002);
  1451. Inc(p);
  1452. p^.CodePoints := CodePointToArray($0063);//c
  1453. p^.Weights := ToWeight($161D,$0020,$0002);
  1454. Inc(p);
  1455. p^.CodePoints := CodePointToArray($0064);//d
  1456. p^.Weights := ToWeight($1631,$0020,$0002);
  1457. Inc(p);
  1458. p^.CodePoints := CodePointToArray([$0061,$030A]);//a,030A;COMBINING RING ABOVE
  1459. p^.Weights := ToWeight($164C,$0020,$0002);
  1460. Inc(p);
  1461. p^.CodePoints := CodePointToArray(Ord('k'));
  1462. p^.Weights := ToWeight($16FF,$0020,$0002);
  1463. end;
  1464. procedure test7_PopulateSequence(var ASequence : TOrderedCharacters);
  1465. var
  1466. i : Integer;
  1467. begin
  1468. ASequence := TOrderedCharacters.Create();
  1469. ASequence.Append(TReorderUnit.From($030A,TReorderWeigthKind.Tertiary,1));
  1470. ASequence.Append(TReorderUnit.From($0327,TReorderWeigthKind.Tertiary,2));
  1471. ASequence.Append(TReorderUnit.From($0061,TReorderWeigthKind.Primary,3));
  1472. ASequence.Append(TReorderUnit.From($0062,TReorderWeigthKind.Primary,4));
  1473. ASequence.Append(TReorderUnit.From($0063,TReorderWeigthKind.Primary,5));
  1474. ASequence.Append(TReorderUnit.From($0064,TReorderWeigthKind.Primary,6));
  1475. ASequence.Append(TReorderUnit.From([$0061,$030A],TReorderWeigthKind.Primary,7));
  1476. ASequence.Append(TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,11));
  1477. for i := 0 to ASequence.ActualLength - 1 do
  1478. ASequence.Data[i].Changed := False;
  1479. end;
  1480. procedure test7();
  1481. var
  1482. sequence, sequenceClean : TOrderedCharacters;
  1483. statement : TReorderSequence;
  1484. wfirst, wresult : TUCA_LineRecArray;
  1485. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  1486. begin // Permutation simple test
  1487. statement.Clear();
  1488. test7_prepareWeigth(wfirst);
  1489. test7_PopulateSequence(sequenceClean);
  1490. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  1491. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  1492. //Generate the original tables
  1493. ConstructUnicodeBook(wfirst,'test7','first',nil,unicodeBook1);
  1494. CheckInf([#$030A,#$0327,#$0061,#$0062,#$0063,#$0064, #$0061#$030A,'k'],@unicodeBook1);
  1495. CheckInf([#$0064, #$0061#$030A#$0327#$0062,'k'],@unicodeBook1);// Permutation here $030A <=> #$0327
  1496. CheckInf([#$0064, #$0061#$0327#$030A#$0062,'k'],@unicodeBook1);
  1497. CheckEqual(#$0061#$030A#$0327, #$0061#$0327#$030A,@unicodeBook1);
  1498. // --- test 2
  1499. sequence := sequenceClean.Clone();
  1500. SetLength(statement.Reset,0);
  1501. SetLength(statement.Elements,1);
  1502. statement.Elements[0] := TReorderUnit.From([$0061,$030A],TReorderWeigthKind.Deletion,0);
  1503. sequence.ApplyStatement(@statement);
  1504. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1505. wresult := nil;
  1506. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1507. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1508. //Generate updatet tables
  1509. ConstructUnicodeBook(wresult,'test7','second',@unicodeBook1,unicodeBook2);
  1510. unicodeBook2.Base := @unicodeBook1;
  1511. CheckInf([#$030A,#$0327,#$0061,#$0061#$030A ,#$0062,#$0063,#$0064,'k'],@unicodeBook2);
  1512. CheckInf([#$0061, #$0061#$030A#$0327#$0062,#$0062,#$0064],@unicodeBook2);
  1513. CheckInf([#$0061, #$0061#$030A#$0062#$0327,#$0062,#$0064],@unicodeBook2);
  1514. WriteLn(' -- test 2 - ok',sLineBreak);
  1515. end;
  1516. //-------------------------------------------------------------------------
  1517. procedure test8_prepareWeigth(var AData : TUCA_LineRecArray);
  1518. var
  1519. p : PUCA_LineRec;
  1520. begin
  1521. SetLength(AData,12);
  1522. p := @AData[Low(AData)];
  1523. p^.CodePoints := CodePointToArray(Ord('a'));
  1524. p^.Weights := ToWeight($15EF,$0020,$0002);
  1525. Inc(p);
  1526. p^.CodePoints := CodePointToArray(Ord('b'));
  1527. p^.Weights := ToWeight($1605,$0020,$0002);
  1528. Inc(p);
  1529. p^.CodePoints := CodePointToArray(Ord('c'));
  1530. p^.Weights := ToWeight($161D,$0020,$0002);
  1531. Inc(p);
  1532. p^.CodePoints := CodePointToArray(Ord('d'));
  1533. p^.Weights := ToWeight($1631,$0020,$0002);
  1534. Inc(p);
  1535. p^.CodePoints := CodePointToArray(Ord('e'));
  1536. p^.Weights := ToWeight($164C,$0020,$0002);
  1537. Inc(p);
  1538. p^.CodePoints := CodePointToArray(Ord('f'));
  1539. p^.Weights := ToWeight($1684,$0020,$0002);
  1540. Inc(p);
  1541. p^.CodePoints := CodePointToArray(Ord('g'));
  1542. p^.Weights := ToWeight($1691,$0020,$0002);
  1543. Inc(p);
  1544. p^.CodePoints := CodePointToArray(Ord('h'));
  1545. p^.Weights := ToWeight($16B4,$0020,$0002);
  1546. Inc(p);
  1547. p^.CodePoints := CodePointToArray(Ord('i'));
  1548. p^.Weights := ToWeight($16CD,$0020,$0002);
  1549. Inc(p);
  1550. p^.CodePoints := CodePointToArray(Ord('j'));
  1551. p^.Weights := ToWeight($16E6,$0020,$0002);
  1552. Inc(p);
  1553. p^.CodePoints := CodePointToArray(Ord('k'));
  1554. p^.Weights := ToWeight($16FF,$0020,$0002);
  1555. Inc(p);
  1556. p^.CodePoints := CodePointToArray(Ord('l'));
  1557. p^.Weights := ToWeight($1711,$0020,$0002);
  1558. end;
  1559. procedure test8_PopulateSequence(var ASequence : TOrderedCharacters);
  1560. var
  1561. i : Integer;
  1562. begin
  1563. ASequence := TOrderedCharacters.Create();
  1564. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  1565. ASequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  1566. ASequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  1567. ASequence.Append(TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,4));
  1568. ASequence.Append(TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,5));
  1569. ASequence.Append(TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,6));
  1570. ASequence.Append(TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,7));
  1571. ASequence.Append(TReorderUnit.From(Ord('h'),TReorderWeigthKind.Primary,8));
  1572. ASequence.Append(TReorderUnit.From(Ord('i'),TReorderWeigthKind.Primary,9));
  1573. ASequence.Append(TReorderUnit.From(Ord('j'),TReorderWeigthKind.Primary,10));
  1574. ASequence.Append(TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,11));
  1575. ASequence.Append(TReorderUnit.From(Ord('l'),TReorderWeigthKind.Primary,12));
  1576. for i := 0 to ASequence.ActualLength - 1 do
  1577. ASequence.Data[i].Changed := False;
  1578. end;
  1579. procedure test8();
  1580. var
  1581. sequence, sequenceClean : TOrderedCharacters;
  1582. statement : TReorderSequence;
  1583. wfirst, wresult : TUCA_LineRecArray;
  1584. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  1585. begin
  1586. statement.Clear();
  1587. test8_prepareWeigth(wfirst);
  1588. test8_PopulateSequence(sequenceClean);
  1589. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  1590. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  1591. //Generate the original tables
  1592. ConstructUnicodeBook(wfirst,'test8','first',nil,unicodeBook1);
  1593. CheckInf('l','-'{* computed are greater},@unicodeBook1);
  1594. // --- test 1
  1595. sequence := sequenceClean.Clone();
  1596. SetLength(statement.Reset,1);
  1597. statement.Reset[0] := Ord('c');
  1598. SetLength(statement.Elements,1);
  1599. statement.Elements[0] := TReorderUnit.From(Ord('-'),[Ord('c')],TReorderWeigthKind.Identity,0);
  1600. sequence.ApplyStatement(@statement);
  1601. wresult := nil;
  1602. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1603. //Generate updatet tables
  1604. ConstructUnicodeBook(wresult,'test8','second',@unicodeBook1,unicodeBook2);
  1605. CheckInf(['a','b','c','d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  1606. CheckEqual('cc','c-'{*},@unicodeBook2);
  1607. CheckEqual('ccc','c-c'{*},@unicodeBook2);
  1608. CheckEqual('cca','c-a'{*},@unicodeBook2);
  1609. CheckEqual('cce','c-e'{*},@unicodeBook2);
  1610. CheckInf(['cc','c-c'{*}],@unicodeBook2);
  1611. CheckInf(['bc','bc-c'{*}],@unicodeBook2);
  1612. CheckInf('l','-'{* computed are greater},@unicodeBook2);
  1613. WriteLn(' -- test 1 - ok');
  1614. // --- test 2
  1615. sequence := sequenceClean.Clone();
  1616. SetLength(statement.Reset,1);
  1617. statement.Reset[0] := Ord('c');
  1618. SetLength(statement.Elements,1);
  1619. statement.Elements[0] := TReorderUnit.From(Ord('-'),[Ord('c')],TReorderWeigthKind.Primary,0);
  1620. sequence.ApplyStatement(@statement);
  1621. wresult := nil;
  1622. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1623. //Generate updatet tables
  1624. ConstructUnicodeBook(wresult,'test8','second',@unicodeBook1,unicodeBook2);
  1625. CheckInf(['a','b','c','d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  1626. CheckInf('cc','c-'{*},@unicodeBook2);
  1627. CheckInf('ccl','c-'{*},@unicodeBook2);
  1628. CheckInf('ccc','c-c'{*},@unicodeBook2);
  1629. CheckInf('cca','c-a'{*},@unicodeBook2);
  1630. CheckInf('cce','c-e'{*},@unicodeBook2);
  1631. CheckInf(['cc','c-c'{*}],@unicodeBook2);
  1632. CheckInf(['bc','bc-c'{*}],@unicodeBook2);
  1633. CheckInf('l','-'{* computed are greater},@unicodeBook2);
  1634. WriteLn(' -- test 2 - ok');
  1635. // --- test 3
  1636. sequence := sequenceClean.Clone();
  1637. SetLength(statement.Reset,1);
  1638. statement.Reset[0] := Ord('c');
  1639. SetLength(statement.Elements,1);
  1640. statement.Elements[0] := TReorderUnit.From([Ord('-'),Ord('+')],[Ord('c')],TReorderWeigthKind.Identity,0);
  1641. sequence.ApplyStatement(@statement);
  1642. wresult := nil;
  1643. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1644. //Generate updatet tables
  1645. ConstructUnicodeBook(wresult,'test8','second',@unicodeBook1,unicodeBook2);
  1646. CheckInf(['a','b','c','d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  1647. CheckEqual('cc','c-+'{*},@unicodeBook2);
  1648. CheckEqual('ccc','c-+c'{*},@unicodeBook2);
  1649. CheckEqual('cca','c-+a'{*},@unicodeBook2);
  1650. CheckEqual('cce','c-+e'{*},@unicodeBook2);
  1651. CheckInf(['cc','c-+c'{*}],@unicodeBook2);
  1652. CheckInf(['bc','bc-+c'{*}],@unicodeBook2);
  1653. CheckInf('l','-+'{* computed are greater},@unicodeBook2);
  1654. WriteLn(' -- test 3 - ok');
  1655. // --- test 4 : '-' has 3 contexts to force the context tree to have at least
  1656. // a "Left" and a "Right"
  1657. sequence := sequenceClean.Clone();
  1658. SetLength(statement.Reset,1);
  1659. statement.Reset[0] := Ord('c');
  1660. SetLength(statement.Elements,1);
  1661. statement.Elements[0] := TReorderUnit.From(Ord('-'),[Ord('c')],TReorderWeigthKind.Identity,0);
  1662. sequence.ApplyStatement(@statement);
  1663. statement.Reset[0] := Ord('f');
  1664. SetLength(statement.Elements,1);
  1665. statement.Elements[0] := TReorderUnit.From(Ord('-'),[Ord('f')],TReorderWeigthKind.Identity,0);
  1666. sequence.ApplyStatement(@statement);
  1667. statement.Reset[0] := Ord('a');
  1668. SetLength(statement.Elements,1);
  1669. statement.Elements[0] := TReorderUnit.From(Ord('-'),[Ord('a')],TReorderWeigthKind.Identity,0);
  1670. sequence.ApplyStatement(@statement);
  1671. wresult := nil;
  1672. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1673. //Generate updatet tables
  1674. ConstructUnicodeBook(wresult,'test8','second',@unicodeBook1,unicodeBook2);
  1675. CheckInf(['a','b','c','d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  1676. // Check c
  1677. CheckEqual('cc','c-'{*},@unicodeBook2);
  1678. CheckEqual('ccc','c-c'{*},@unicodeBook2);
  1679. CheckEqual('cca','c-a'{*},@unicodeBook2);
  1680. CheckEqual('cce','c-e'{*},@unicodeBook2);
  1681. CheckInf(['cc','c-c'{*}],@unicodeBook2);
  1682. CheckInf(['bc','bc-c'{*}],@unicodeBook2);
  1683. //check f
  1684. CheckEqual('ff','f-'{*},@unicodeBook2);
  1685. CheckEqual('fff','f-f'{*},@unicodeBook2);
  1686. CheckEqual('ffa','f-a'{*},@unicodeBook2);
  1687. CheckEqual('ffe','f-e'{*},@unicodeBook2);
  1688. CheckInf(['ff','f-f'{*}],@unicodeBook2);
  1689. CheckInf(['bf','bf-f'{*}],@unicodeBook2);
  1690. //check c and f
  1691. CheckEqual('ccf','c-f'{*},@unicodeBook2);
  1692. CheckEqual('ccff','c-f-'{*},@unicodeBook2);
  1693. CheckEqual('ccfff','c-f-f'{*},@unicodeBook2);
  1694. CheckEqual('ffcc','f-c-'{*},@unicodeBook2);
  1695. CheckEqual('ffccf','f-c-f'{*},@unicodeBook2);
  1696. CheckInf('ffccf','g'{*},@unicodeBook2);
  1697. CheckInf('a-','ab',@unicodeBook2);
  1698. // check - alone
  1699. CheckInf('l','-'{* computed are greater},@unicodeBook2);
  1700. WriteLn(' -- test 4 - ok');
  1701. // --- test 5 : Add a contraction to force the code path
  1702. sequence := sequenceClean.Clone();
  1703. SetLength(statement.Reset,1);
  1704. statement.Reset[0] := Ord('a');
  1705. SetLength(statement.Elements,1);
  1706. statement.Elements[0] := TReorderUnit.From([Ord('-'),Ord('h')],TReorderWeigthKind.Primary,0);
  1707. sequence.ApplyStatement(@statement);
  1708. statement.Reset[0] := Ord('c');
  1709. SetLength(statement.Elements,1);
  1710. statement.Elements[0] := TReorderUnit.From(Ord('-'),[Ord('c')],TReorderWeigthKind.Identity,0);
  1711. sequence.ApplyStatement(@statement);
  1712. wresult := nil;
  1713. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1714. //Generate updatet tables
  1715. ConstructUnicodeBook(wresult,'test8','second',@unicodeBook1,unicodeBook2);
  1716. CheckInf(['a','-h','b','c','d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  1717. CheckEqual('cc','c-'{*},@unicodeBook2);
  1718. CheckEqual('ccc','c-c'{*},@unicodeBook2);
  1719. CheckEqual('cca','c-a'{*},@unicodeBook2);
  1720. CheckEqual('cce','c-e'{*},@unicodeBook2);
  1721. CheckInf(['cc','c-c'{*}],@unicodeBook2);
  1722. CheckInf(['bc','bc-c'{*}],@unicodeBook2);
  1723. CheckInf(['ab','-hb'{*}],@unicodeBook2);
  1724. CheckInf(['-hb','ba'],@unicodeBook2);
  1725. CheckInf('l','-'{* computed are greater},@unicodeBook2);
  1726. WriteLn(' -- test 5 - ok');
  1727. WriteLn(' -- test - ok',sLineBreak);
  1728. end;
  1729. //-------------------------------------------------------------------------
  1730. procedure test9_prepareWeigth(var AData : TUCA_LineRecArray);
  1731. var
  1732. p : PUCA_LineRec;
  1733. begin
  1734. SetLength(AData,8);
  1735. p := @AData[Low(AData)];
  1736. p^.CodePoints := CodePointToArray($030A);//030A ; [.0000.0043.0002.030A] # COMBINING RING ABOVE
  1737. p^.Weights := ToWeight($0000,$0043,$0002);
  1738. Inc(p);
  1739. p^.CodePoints := CodePointToArray($0327);//0327 ; [.0000.0056.0002.0327] # COMBINING CEDILLA
  1740. p^.Weights := ToWeight($0000,$0056,$0002);
  1741. Inc(p);
  1742. p^.CodePoints := CodePointToArray($0061);//a
  1743. p^.Weights := ToWeight($15EF,$0020,$0002);
  1744. Inc(p);
  1745. p^.CodePoints := CodePointToArray($0062);//b
  1746. p^.Weights := ToWeight($1605,$0020,$0002);
  1747. Inc(p);
  1748. p^.CodePoints := CodePointToArray($0063);//c
  1749. p^.Weights := ToWeight($161D,$0020,$0002);
  1750. Inc(p);
  1751. p^.CodePoints := CodePointToArray($0064);//d
  1752. p^.Weights := ToWeight($1631,$0020,$0002);
  1753. Inc(p);
  1754. p^.CodePoints := CodePointToArray([$0061,$030A]);//a,030A;COMBINING RING ABOVE
  1755. p^.Weights := ToWeight($164C,$0020,$0002);
  1756. Inc(p);
  1757. p^.CodePoints := CodePointToArray(Ord('k'));
  1758. p^.Weights := ToWeight($16FF,$0020,$0002);
  1759. end;
  1760. procedure test9_PopulateSequence(var ASequence : TOrderedCharacters);
  1761. var
  1762. i : Integer;
  1763. begin
  1764. ASequence := TOrderedCharacters.Create();
  1765. ASequence.Append(TReorderUnit.From($030A,TReorderWeigthKind.Tertiary,1));
  1766. ASequence.Append(TReorderUnit.From($0327,TReorderWeigthKind.Tertiary,2));
  1767. ASequence.Append(TReorderUnit.From($0061,TReorderWeigthKind.Primary,3));
  1768. ASequence.Append(TReorderUnit.From($0062,TReorderWeigthKind.Primary,4));
  1769. ASequence.Append(TReorderUnit.From($0063,TReorderWeigthKind.Primary,5));
  1770. ASequence.Append(TReorderUnit.From($0064,TReorderWeigthKind.Primary,6));
  1771. ASequence.Append(TReorderUnit.From([$0061,$030A],TReorderWeigthKind.Primary,7));
  1772. ASequence.Append(TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,11));
  1773. for i := 0 to ASequence.ActualLength - 1 do
  1774. ASequence.Data[i].Changed := False;
  1775. end;
  1776. procedure test9();
  1777. var
  1778. sequence, sequenceClean : TOrderedCharacters;
  1779. statement : TReorderSequence;
  1780. wfirst, wresult : TUCA_LineRecArray;
  1781. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  1782. begin// Permutation with Context
  1783. statement.Clear();
  1784. test7_prepareWeigth(wfirst);
  1785. test7_PopulateSequence(sequenceClean);
  1786. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  1787. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  1788. //Generate the original tables
  1789. ConstructUnicodeBook(wfirst,'test9','first',nil,unicodeBook1);
  1790. CheckInf([#$030A,#$0327,#$0061,#$0062,#$0063,#$0064, #$0061#$030A,'k'],@unicodeBook1);
  1791. CheckInf([#$0064, #$0061#$030A#$0327#$0062,'k'],@unicodeBook1);// Permutation here $030A <=> #$0327
  1792. // --- test 2
  1793. sequence := sequenceClean.Clone();
  1794. SetLength(statement.Reset,1);
  1795. statement.Reset[0] := $0062;
  1796. SetLength(statement.Elements,1);
  1797. statement.Elements[0] := TReorderUnit.From([Ord('k'),$032D],[$0061],TReorderWeigthKind.Secondary,0); //032D;COMBINING CIRCUMFLEX ACCENT BELOW;Mn;220;NSM;;;;;N;NON-SPACING CIRCUMFLEX BELOW;;;;
  1798. sequence.ApplyStatement(@statement);
  1799. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1800. wresult := nil;
  1801. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1802. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1803. //Generate updatet tables
  1804. ConstructUnicodeBook(wresult,'test9','second',@unicodeBook1,unicodeBook2);
  1805. unicodeBook2.Base := @unicodeBook1;
  1806. CheckInf([#$030A,#$0327,#$0061,#$0062,#$0063,#$0064,'k'],@unicodeBook2);
  1807. CheckInf([#$0061'k'#$032D ,#$0061#$0063],@unicodeBook2);
  1808. CheckNotEqual(#$0061'k'#$0327#$032D, #$0061#$0327,@unicodeBook2);
  1809. CheckInf([#$0061'k'#$0327#$032D ,#$0061#$0063],@unicodeBook2);
  1810. WriteLn(' -- test 2 - ok',sLineBreak);
  1811. end;
  1812. //------------------------------------------------------
  1813. procedure test10_prepareWeigth(var AData : TUCA_LineRecArray);
  1814. var
  1815. p : PUCA_LineRec;
  1816. begin
  1817. SetLength(AData,12);
  1818. p := @AData[Low(AData)];
  1819. p^.CodePoints := CodePointToArray(Ord('a'));
  1820. p^.Weights := ToWeight($15EF,$0020,$0002);
  1821. Inc(p);
  1822. p^.CodePoints := CodePointToArray([Ord('('),Ord('a'),Ord(')')]);
  1823. p^.Weights := ToWeight($15EF,$0020,$0006); //15EF.0020.0006.24D0
  1824. Inc(p);
  1825. p^.CodePoints := CodePointToArray(Ord('A'));
  1826. p^.Weights := ToWeight($15EF,$0020,$0008); //15EF.0020.0008.0041
  1827. Inc(p);
  1828. p^.CodePoints := CodePointToArray([Ord('('),Ord('A'),Ord(')')]);
  1829. p^.Weights := ToWeight($15EF,$0020,$000C); //15EF.0020.000C
  1830. Inc(p);
  1831. p^.CodePoints := CodePointToArray([Ord('a'),Ord('`')]);
  1832. p^.Weights := ToWeight([$15EF,$0020,$0002, $0000,$0035,$0002]); //[.15EF.0020.0002.0061][.0000.0035.0002.0300]
  1833. Inc(p);
  1834. p^.CodePoints := CodePointToArray([Ord('A'),Ord('`')]);
  1835. p^.Weights := ToWeight([$15EF,$0020,$0008, $0000,$0035,$0002]); //[.15EF.0020.0008.0041][.0000.0035.0002.0300]
  1836. Inc(p);
  1837. p^.CodePoints := CodePointToArray([Ord('a'),Ord('e')]);
  1838. p^.Weights := ToWeight([$15F0,$0020,$0002]); //[.15EF.0020.0004.00E6][.0000.0139.0004.00E6][.164C.0020.0004.00E6]
  1839. Inc(p);
  1840. p^.CodePoints := CodePointToArray([Ord(UpCase('a')),Ord(UpCase('e'))]);
  1841. p^.Weights := ToWeight([$15F0,$0020,$0006]);//[.15EF.0020.000A.00C6][.0000.0139.0004.00C6][.164C.0020.000A.00C6]
  1842. Inc(p);
  1843. p^.CodePoints := CodePointToArray(Ord('b'));
  1844. p^.Weights := ToWeight($1605,$0020,$0002);
  1845. Inc(p);
  1846. p^.CodePoints := CodePointToArray([Ord('('),Ord('b'),Ord(')')]);
  1847. p^.Weights := ToWeight($1605,$0020,$0006); //.1605.0020.0006.24D1
  1848. Inc(p);
  1849. p^.CodePoints := CodePointToArray(Ord('B'));
  1850. p^.Weights := ToWeight($1605,$0020,$0008); //1605.0020.0008.0042
  1851. Inc(p);
  1852. p^.CodePoints := CodePointToArray(Ord('c'));
  1853. p^.Weights := ToWeight($161D,$0020,$0002);
  1854. end;
  1855. procedure test10_PopulateSequence(var ASequence : TOrderedCharacters);
  1856. var
  1857. i : Integer;
  1858. begin
  1859. ASequence := TOrderedCharacters.Create();
  1860. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  1861. ASequence.Append(TReorderUnit.From([Ord('('),Ord('a'),Ord(')')],TReorderWeigthKind.Tertiary,2));
  1862. ASequence.Append(TReorderUnit.From(Ord('A'),TReorderWeigthKind.Tertiary,3));
  1863. ASequence.Append(TReorderUnit.From([Ord('('),Ord('A'),Ord(')')],TReorderWeigthKind.Tertiary,4));
  1864. //ASequence.Append(TReorderUnit.From(Ord('à'),TReorderWeigthKind.Secondary,0));
  1865. ASequence.Append(TReorderUnit.From([Ord('a'),Ord('`')],TReorderWeigthKind.Secondary,5));
  1866. //ASequence.Append(TReorderUnit.From(Ord(UpCase('à')),TReorderWeigthKind.Tertiary,0));
  1867. ASequence.Append(TReorderUnit.From([Ord('A'),Ord('`')],TReorderWeigthKind.Tertiary,6));
  1868. ASequence.Append(TReorderUnit.From([Ord('a'),Ord('e')],TReorderWeigthKind.Primary,7));
  1869. ASequence.Append(TReorderUnit.From([Ord(UpCase('a')),Ord(UpCase('e'))],TReorderWeigthKind.Tertiary,8));
  1870. ASequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,9));
  1871. ASequence.Append(TReorderUnit.From([Ord('('),Ord('b'),Ord(')')],TReorderWeigthKind.Tertiary,10));
  1872. ASequence.Append(TReorderUnit.From(Ord('B'),TReorderWeigthKind.Tertiary,11));
  1873. ASequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,12));
  1874. for i := 0 to ASequence.ActualLength - 1 do
  1875. ASequence.Data[i].Changed := False;
  1876. end;
  1877. procedure test10();
  1878. var
  1879. sequence, sequenceClean : TOrderedCharacters;
  1880. statement : TReorderSequence;
  1881. wfirst, wresult : TUCA_LineRecArray;
  1882. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  1883. begin
  1884. statement.Clear();
  1885. test10_prepareWeigth(wfirst);
  1886. test10_PopulateSequence(sequenceClean);
  1887. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  1888. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  1889. //Generate the original tables
  1890. ConstructUnicodeBook(wfirst,'test6','first',nil,unicodeBook1);
  1891. CheckInf(['a','(a)','A','(A)', 'a`','A`', 'ae','AE', 'b','(b)','B', 'c'],@unicodeBook1);
  1892. // --- test 1
  1893. sequence := sequenceClean.Clone();
  1894. statement.Clear();
  1895. statement.Before := True;
  1896. SetLength(statement.Reset,2);
  1897. statement.Reset[0] := Ord('a');
  1898. statement.Reset[1] := Ord('e');
  1899. SetLength(statement.Elements,1);
  1900. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  1901. sequence.ApplyStatement(@statement);
  1902. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1903. wresult := nil;
  1904. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1905. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1906. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  1907. CheckInf(['a','(a)','A','(A)', 'a`','A`', 'g'{*}, 'ae','AE', 'b','(b)','B', 'c'],@unicodeBook2);
  1908. CheckInf(['gg','ae'],@unicodeBook2);
  1909. CheckInf(['gb','ae'],@unicodeBook2);
  1910. WriteLn(' -- test 1 - ok',sLineBreak);
  1911. // --- test 2
  1912. sequence := sequenceClean.Clone();
  1913. statement.Clear();
  1914. statement.Before := True;
  1915. SetLength(statement.Reset,2);
  1916. statement.Reset[0] := Ord('a');
  1917. statement.Reset[1] := Ord('e');
  1918. SetLength(statement.Elements,1);
  1919. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Secondary,0);
  1920. sequence.ApplyStatement(@statement);
  1921. WriteLn('Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1922. wresult := nil;
  1923. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1924. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1925. ConstructUnicodeBook(wresult,'test2','2',@unicodeBook1,unicodeBook2);
  1926. CheckInf(['a','(a)','A','(A)', 'a`','A`', 'g'{*}, 'ae','AE', 'b','(b)','B', 'c'],@unicodeBook2);
  1927. CheckInf(['A`B','gg'],@unicodeBook2);
  1928. CheckInf(['A`b','g'],@unicodeBook2);
  1929. WriteLn(' -- test 2 - ok',sLineBreak);
  1930. // --- test 3
  1931. sequence := sequenceClean.Clone();
  1932. statement.Clear();
  1933. statement.Before := True;
  1934. SetLength(statement.Reset,2);
  1935. statement.Reset[0] := Ord('a');
  1936. statement.Reset[1] := Ord('e');
  1937. SetLength(statement.Elements,1);
  1938. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Tertiary,0);
  1939. sequence.ApplyStatement(@statement);
  1940. WriteLn('Statement #3 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1941. wresult := nil;
  1942. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1943. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1944. ConstructUnicodeBook(wresult,'test2','2',@unicodeBook1,unicodeBook2);
  1945. CheckInf(['a','(a)','A','(A)', 'a`','A`', 'g'{*}, 'ae','AE', 'b','(b)','B', 'c'],@unicodeBook2);
  1946. CheckInf(['A`B','gg'],@unicodeBook2);
  1947. CheckInf(['A`b','g'],@unicodeBook2);
  1948. WriteLn(' -- test 3 - ok',sLineBreak);
  1949. // --- test 4
  1950. sequence := sequenceClean.Clone();
  1951. statement.Clear();
  1952. statement.Before := True;
  1953. SetLength(statement.Reset,2);
  1954. statement.Reset[0] := Ord('A');
  1955. statement.Reset[1] := Ord('`');
  1956. SetLength(statement.Elements,1);
  1957. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Tertiary,0);
  1958. sequence.ApplyStatement(@statement);
  1959. WriteLn('Statement #4.1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1960. wresult := nil;
  1961. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1962. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1963. statement.Clear();
  1964. statement.Before := True;
  1965. SetLength(statement.Reset,2);
  1966. statement.Reset[0] := Ord('A');
  1967. statement.Reset[1] := Ord('`');
  1968. SetLength(statement.Elements,1);
  1969. statement.Elements[0] := TReorderUnit.From(Ord('G'),TReorderWeigthKind.Secondary,0);
  1970. sequence.ApplyStatement(@statement);
  1971. WriteLn('Statement #4.2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1972. wresult := nil;
  1973. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1974. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1975. ConstructUnicodeBook(wresult,'test2','2',@unicodeBook1,unicodeBook2);
  1976. CheckInf(['a','(a)','A','(A)', 'G','a`','g'{*},'A`', 'ae','AE', 'b','(b)','B', 'c'],@unicodeBook2);
  1977. CheckInf(['gg','A`B'],@unicodeBook2);
  1978. CheckInf(['g','A`b'],@unicodeBook2);
  1979. CheckInf(['A','gg'],@unicodeBook2);
  1980. CheckInf(['A','Ga'],@unicodeBook2);
  1981. WriteLn(' -- test 4 - ok',sLineBreak);
  1982. // --- test 5
  1983. sequence := sequenceClean.Clone();
  1984. statement.Clear();
  1985. statement.Before := True;
  1986. SetLength(statement.Reset,1);
  1987. statement.Reset[0] := Ord('B');
  1988. SetLength(statement.Elements,1);
  1989. statement.Elements[0] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  1990. sequence.ApplyStatement(@statement);
  1991. WriteLn('Statement #5 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  1992. wresult := nil;
  1993. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  1994. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  1995. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  1996. CheckInf(['a','(a)','A','(A)', 'a`','A`', 'ae','AE', 'g'{*}, 'b','(b)','B', 'c'],@unicodeBook2);
  1997. CheckInf(['gg','b'],@unicodeBook2);
  1998. CheckInf(['ae','gb'],@unicodeBook2);
  1999. WriteLn(' -- test 5 - ok',sLineBreak);
  2000. end;
  2001. //------------------------------------------------------
  2002. procedure test11_prepareWeigth(var AData : TUCA_LineRecArray);
  2003. var
  2004. p : PUCA_LineRec;
  2005. begin
  2006. SetLength(AData,12);
  2007. p := @AData[Low(AData)];
  2008. p^.CodePoints := CodePointToArray(Ord('a'));
  2009. p^.Weights := ToWeight($15EF,$0020,$0002);
  2010. Inc(p);
  2011. p^.CodePoints := CodePointToArray(Ord('b'));
  2012. p^.Weights := ToWeight($1605,$0020,$0002);
  2013. Inc(p);
  2014. p^.CodePoints := CodePointToArray(Ord('c'));
  2015. p^.Weights := ToWeight($161D,$0020,$0002);
  2016. Inc(p);
  2017. p^.CodePoints := CodePointToArray(Ord('d'));
  2018. p^.Weights := ToWeight($1631,$0020,$0002);
  2019. Inc(p);
  2020. p^.CodePoints := CodePointToArray(Ord('e'));
  2021. p^.Weights := ToWeight($164C,$0020,$0002);
  2022. Inc(p);
  2023. p^.CodePoints := CodePointToArray(Ord('f'));
  2024. p^.Weights := ToWeight($1684,$0020,$0002);
  2025. Inc(p);
  2026. p^.CodePoints := CodePointToArray(Ord('g'));
  2027. p^.Weights := ToWeight($1691,$0020,$0002);
  2028. Inc(p);
  2029. p^.CodePoints := CodePointToArray(Ord('h'));
  2030. p^.Weights := ToWeight($16B4,$0020,$0002);
  2031. Inc(p);
  2032. p^.CodePoints := CodePointToArray(Ord('i'));
  2033. p^.Weights := ToWeight($16CD,$0020,$0002);
  2034. Inc(p);
  2035. p^.CodePoints := CodePointToArray(Ord('j'));
  2036. p^.Weights := ToWeight($16E6,$0020,$0002);
  2037. Inc(p);
  2038. p^.CodePoints := CodePointToArray(Ord('k'));
  2039. p^.Weights := ToWeight($16FF,$0020,$0002);
  2040. Inc(p);
  2041. p^.CodePoints := CodePointToArray(Ord('l'));
  2042. p^.Weights := ToWeight($1711,$0020,$0002);
  2043. end;
  2044. procedure test11_PopulateSequence(var ASequence : TOrderedCharacters);
  2045. var
  2046. i : Integer;
  2047. begin
  2048. ASequence := TOrderedCharacters.Create();
  2049. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  2050. ASequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  2051. ASequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  2052. ASequence.Append(TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,4));
  2053. ASequence.Append(TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,5));
  2054. ASequence.Append(TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,6));
  2055. ASequence.Append(TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,7));
  2056. ASequence.Append(TReorderUnit.From(Ord('h'),TReorderWeigthKind.Primary,8));
  2057. ASequence.Append(TReorderUnit.From(Ord('i'),TReorderWeigthKind.Primary,9));
  2058. ASequence.Append(TReorderUnit.From(Ord('j'),TReorderWeigthKind.Primary,10));
  2059. ASequence.Append(TReorderUnit.From(Ord('k'),TReorderWeigthKind.Primary,11));
  2060. ASequence.Append(TReorderUnit.From(Ord('l'),TReorderWeigthKind.Primary,12));
  2061. for i := 0 to ASequence.ActualLength - 1 do
  2062. ASequence.Data[i].Changed := False;
  2063. end;
  2064. procedure test11();
  2065. var
  2066. sequence, sequenceClean : TOrderedCharacters;
  2067. statement : TReorderSequence;
  2068. wfirst, wresult : TUCA_LineRecArray;
  2069. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  2070. begin
  2071. statement.Clear();
  2072. test11_prepareWeigth(wfirst);
  2073. test11_PopulateSequence(sequenceClean);
  2074. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  2075. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  2076. //Generate the original tables
  2077. ConstructUnicodeBook(wfirst,'test11','first',nil,unicodeBook1);
  2078. CheckInf(['a','b','c','d','e','f','g','h','i','j','k','l'],@unicodeBook1);
  2079. // --- test 1
  2080. sequence := sequenceClean.Clone();
  2081. SetLength(statement.Reset,1);
  2082. statement.Reset[0] := Ord('c');
  2083. SetLength(statement.Elements,1);
  2084. statement.Elements[0] := TReorderUnit.From(Ord('x'),TReorderWeigthKind.Tertiary,0);
  2085. statement.Elements[0].SetExpansion(Ord('h'));
  2086. sequence.ApplyStatement(@statement);
  2087. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2088. wresult := nil;
  2089. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2090. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2091. //Generate updatet tables
  2092. ConstructUnicodeBook(wresult,'test1','second',@unicodeBook1,unicodeBook2);
  2093. CheckInf(['a','b','c','x'{*},'d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  2094. CheckInf('ch','x'{*},@unicodeBook2);
  2095. CheckInf('cha','xa'{*},@unicodeBook2);
  2096. CheckInf('chk','xka'{*},@unicodeBook2);
  2097. WriteLn(' -- test 1 - ok');
  2098. // --- test 2
  2099. sequence := sequenceClean.Clone();
  2100. SetLength(statement.Reset,1);
  2101. statement.Reset[0] := Ord('c');
  2102. SetLength(statement.Elements,2);
  2103. statement.Elements[0] := TReorderUnit.From(Ord('x'),TReorderWeigthKind.Tertiary,0);
  2104. statement.Elements[0].SetExpansion(Ord('h'));
  2105. statement.Elements[1] := TReorderUnit.From(Ord('X'),TReorderWeigthKind.Tertiary,0);
  2106. sequence.ApplyStatement(@statement);
  2107. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2108. wresult := nil;
  2109. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2110. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2111. //Generate updatet tables
  2112. ConstructUnicodeBook(wresult,'test2','second',@unicodeBook1,unicodeBook2);
  2113. CheckInf(['a','b','c','x'{*},'X'{*},'d','e','f','g','h','i','j','k','l'],@unicodeBook2);
  2114. CheckInf('ch','x'{*},@unicodeBook2);
  2115. CheckInf('cha','xa'{*},@unicodeBook2);
  2116. CheckInf('chk','xka'{*},@unicodeBook2);
  2117. CheckInf('ch','X'{*},@unicodeBook2);
  2118. CheckInf('cha','Xa'{*},@unicodeBook2);
  2119. CheckInf('chk','Xka'{*},@unicodeBook2);
  2120. WriteLn(' -- test 2 - ok');
  2121. end;
  2122. //------------------------------------------------------
  2123. procedure test12_prepareWeigth(var AData : TUCA_LineRecArray);
  2124. var
  2125. p : PUCA_LineRec;
  2126. begin
  2127. SetLength(AData,1);
  2128. p := @AData[Low(AData)];
  2129. p^.CodePoints := CodePointToArray(Ord('a'));
  2130. p^.Weights := ToWeight($15EF,$0120,$0002);
  2131. end;
  2132. procedure test12_PopulateSequence(var ASequence : TOrderedCharacters);
  2133. var
  2134. i : Integer;
  2135. begin
  2136. ASequence := TOrderedCharacters.Create();
  2137. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  2138. for i := 0 to ASequence.ActualLength - 1 do
  2139. ASequence.Data[i].Changed := False;
  2140. end;
  2141. procedure Check(const ACondition : Boolean; const AMsg : string);overload;
  2142. begin
  2143. if not ACondition then
  2144. raise Exception.Create(AMsg);
  2145. end;
  2146. procedure Check(
  2147. const ACondition : Boolean;
  2148. const AFormatMsg : string;
  2149. const AArgs : array of const
  2150. );overload;
  2151. begin
  2152. Check(ACondition,Format(AFormatMsg,AArgs));
  2153. end;
  2154. procedure Check(const ACondition : Boolean);overload;
  2155. begin
  2156. Check(ACondition,'Check failed.')
  2157. end;
  2158. procedure CheckSimpleProps(
  2159. AItem : PUCA_PropItemRec;
  2160. AHasCodePoint,
  2161. AIsValid : Boolean;
  2162. AChildCount : Byte;
  2163. AContextual : Boolean
  2164. );overload;
  2165. var
  2166. p : PUCA_PropItemRec;
  2167. begin
  2168. p := AItem;
  2169. Check(p<>nil,'p = nil');
  2170. Check(p^.HasCodePoint()=AHasCodePoint,'HasCodePoint');
  2171. Check(p^.IsValid()=AIsValid,'IsValid');
  2172. Check(p^.ChildCount=AChildCount,'ChildCount');
  2173. Check(p^.Contextual=AContextual,'Contextual');
  2174. end;
  2175. procedure CheckSimpleProps(
  2176. AItem : PUCA_PropItemRec;
  2177. AHasCodePoint,
  2178. AIsValid : Boolean;
  2179. AChildCount : Byte;
  2180. AContextual,
  2181. AIsDeleted : Boolean
  2182. );overload;
  2183. begin
  2184. CheckSimpleProps(AItem,AHasCodePoint,AIsValid,AChildCount,AContextual);
  2185. Check(AItem^.IsDeleted=AIsDeleted,'IsDeleted');
  2186. end;
  2187. procedure CheckWeigths(AItem : PUCA_PropItemRec; const AWeigths : array of Word);overload;
  2188. var
  2189. p : PUCA_PropItemRec;
  2190. c, i : Integer;
  2191. pb : PByte;
  2192. pw : PWord;
  2193. begin
  2194. p := AItem;
  2195. c := Length(AWeigths);
  2196. if ((c mod 3) > 0) then
  2197. Check(False,'Invalid Weigth Array.');
  2198. c := c div 3;
  2199. Check(c=p^.WeightLength,'WeightLength');
  2200. if (c = 0) then
  2201. exit;
  2202. pb := PByte(PtrUInt(p)+SizeOf(TUCA_PropItemRec));
  2203. pw := @AWeigths[Low(AWeigths)];
  2204. //First Item
  2205. Check(PWord(pb)^ = pw^, 'First Item[0]');
  2206. pw := pw + 1;
  2207. pb := pb + 2;
  2208. if (pw^ > High(Byte)) then begin
  2209. Check(PWord(pb)^ = pw^, 'First Item[1]');
  2210. pb := pb + 2;
  2211. end else begin
  2212. Check(pb^ = pw^, 'First Item[1]');
  2213. pb := pb + 1;
  2214. end;
  2215. pw := pw + 1;
  2216. if (pw^ > High(Byte)) then begin
  2217. Check(PWord(pb)^ = pw^, 'First Item[2]');
  2218. pb := pb + 2;
  2219. end else begin
  2220. Check(pb^ = pw^, 'First Item[2]');
  2221. pb := pb + 1;
  2222. end;
  2223. pw := pw + 1;
  2224. // Others
  2225. for i := 1 to c-1 do begin
  2226. Check(PWord(pb)^ = pw^, 'Item[0],i=%d',[i]);
  2227. Inc(pw);
  2228. pb := pb + 2;
  2229. Check(PWord(pb)^ = pw^, 'Item[1],i=%d',[i]);
  2230. Inc(pw);
  2231. pb := pb + 2;
  2232. Check(PWord(pb)^ = pw^, 'Item[2],i=%d',[i]);
  2233. Inc(pw);
  2234. pb := pb + 2;
  2235. end;
  2236. end;
  2237. procedure CheckWeigths(
  2238. AData : PUCA_PropWeights;
  2239. const ADataCount : Integer;
  2240. const AWeigths : array of Word
  2241. );overload;
  2242. var
  2243. c: Integer;
  2244. begin
  2245. c := Length(AWeigths);
  2246. if ((c mod 3) > 0) then
  2247. Check(False,'Invalid Weigth Array.');
  2248. c := c div 3;
  2249. Check(c=ADataCount,'WeightLength');
  2250. if (c = 0) then
  2251. exit;
  2252. if not CompareMem(AData,@AWeigths[0],(ADataCount*3*SizeOf(Word))) then
  2253. Check(False,'Weight');
  2254. end;
  2255. function CalcWeigthSize(const AWeigths : array of Word) : Integer;
  2256. var
  2257. c : Integer;
  2258. begin
  2259. c := Length(AWeigths);
  2260. if ((c mod 3) > 0) then
  2261. Check(False,'Invalid Weigth Array.');
  2262. Result := c * SizeOf(Word);
  2263. if (c>0) then begin
  2264. if (AWeigths[1] <= High(Byte)) then
  2265. Result := Result - 1;
  2266. if (AWeigths[2] <= High(Byte)) then
  2267. Result := Result - 1;
  2268. end;
  2269. end;
  2270. procedure test12_check_1(const ABook : unicodedata.TUCA_DataBook);
  2271. var
  2272. p, px : PUCA_PropItemRec;
  2273. size, sizeTotal, t: Cardinal;
  2274. begin
  2275. sizeTotal := 0;
  2276. // for 'b'
  2277. p := ABook.Props;
  2278. CheckSimpleProps(p,False,True,0,False);
  2279. CheckWeigths(p,[$15F0,0,0, $15F0,0,0]);
  2280. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15F0,0,0, $15F0,0,0]);
  2281. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2282. Check(p^.Size = size,'size');
  2283. sizeTotal:= sizeTotal+size;
  2284. // for 'c'
  2285. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2286. CheckSimpleProps(p,False,True,0,False);
  2287. CheckWeigths(p,[$15F0,0,0, $15F1,0,0]);
  2288. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15F0,0,0, $15F0,0,0]);
  2289. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2290. Check(p^.Size = size,'size');
  2291. sizeTotal:= sizeTotal+size;
  2292. // for 'x'
  2293. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2294. px := p;
  2295. CheckSimpleProps(p,False,False,1,False);
  2296. CheckWeigths(p,[]);
  2297. size := SizeOf(TUCA_PropItemRec);
  2298. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2299. t := size;
  2300. sizeTotal:= sizeTotal+size;
  2301. // for 'y'
  2302. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2303. CheckSimpleProps(p,True,True,0,False);
  2304. CheckWeigths(p,[$15F0,0,0, $15F2,0,0]);
  2305. size := SizeOf(TUCA_PropItemRec) +
  2306. SizeOf(UInt24) +
  2307. CalcWeigthSize([$15F0,0,0, $15F2,0,0]);
  2308. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2309. Check(p^.Size = size,'size(y)');
  2310. Check(px^.Size = (t+size),'size(x)');
  2311. sizeTotal:= sizeTotal+size;
  2312. Check(ABook.PropCount = sizeTotal,'size(total)');
  2313. end;
  2314. procedure test12_check_2(const ABook : unicodedata.TUCA_DataBook);
  2315. var
  2316. p, ph : PUCA_PropItemRec;
  2317. size, sizeTotal, t: Integer;
  2318. begin
  2319. sizeTotal := 0;
  2320. // for 'b'
  2321. p := ABook.Props;
  2322. CheckSimpleProps(p,False,True,0,False);
  2323. CheckWeigths(p,[$15EF,$121,0, $15EF,0,0]);
  2324. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$121,0, $15EF,0,0]);
  2325. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2326. Check(p^.Size = size,'size');
  2327. sizeTotal:= sizeTotal+size;
  2328. // for 'c'
  2329. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2330. CheckSimpleProps(p,False,True,0,False);
  2331. CheckWeigths(p,[$15EF,$122,0, $15EF,0,0]);
  2332. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$122,0, $15EF,0,0]);
  2333. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2334. Check(p^.Size = size,'size');
  2335. sizeTotal:= sizeTotal+size;
  2336. // for 'h'
  2337. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2338. ph := p;
  2339. CheckSimpleProps(p,False,False,1,False);
  2340. CheckWeigths(p,[]);
  2341. size := SizeOf(TUCA_PropItemRec);
  2342. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2343. t := size;
  2344. sizeTotal:= sizeTotal+size;
  2345. // for 'i'
  2346. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2347. CheckSimpleProps(p,True,True,0,False);
  2348. CheckWeigths(p,[$15EF,$123,0, $15EF,0,0]);
  2349. size := SizeOf(TUCA_PropItemRec) +
  2350. SizeOf(UInt24) +
  2351. CalcWeigthSize([$15EF,$123,0, $15EF,0,0]);
  2352. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2353. Check(p^.Size = size,'size(i)');
  2354. sizeTotal:= sizeTotal+size;
  2355. Check(ph^.Size = (t+size),'size(h)');
  2356. // for 'k'
  2357. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2358. CheckSimpleProps(p,False,True,0,False);
  2359. CheckWeigths(p,[$15EF,$123,1, $15EF,0,0]);
  2360. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$123,1, $15EF,0,0]);
  2361. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2362. Check(p^.Size = size,'size(k)');
  2363. sizeTotal:= sizeTotal+size;
  2364. Check(ABook.PropCount = sizeTotal,'size(total)');
  2365. end;
  2366. procedure test12_check_3(const ABook : unicodedata.TUCA_DataBook);
  2367. var
  2368. p, pc : PUCA_PropItemRec;
  2369. size, sizeTotal, t: Integer;
  2370. begin
  2371. sizeTotal := 0;
  2372. // for 'b'
  2373. p := ABook.Props;
  2374. CheckSimpleProps(p,False,True,0,False);
  2375. CheckWeigths(p,[$15EF,$121,0, $15EF,0,0]);
  2376. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$121,0, $15EF,0,0]);
  2377. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2378. Check(p^.Size = size,'size');
  2379. sizeTotal:= sizeTotal+size;
  2380. // for 'c'
  2381. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2382. pc := p;
  2383. CheckSimpleProps(p,False,True,1,False);
  2384. CheckWeigths(p,[$15EF,$122,0, $15EF,0,0]);
  2385. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$122,0, $15EF,0,0]);
  2386. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2387. t := size;
  2388. sizeTotal:= sizeTotal+size;
  2389. // for 'i'
  2390. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2391. CheckSimpleProps(p,True,True,0,False);
  2392. CheckWeigths(p,[$15EF,$123,0, $15EF,0,0]);
  2393. size := SizeOf(TUCA_PropItemRec) +
  2394. SizeOf(UInt24) +
  2395. CalcWeigthSize([$15EF,$123,0, $15EF,0,0]);
  2396. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2397. Check(p^.Size = size,'size(i)');
  2398. sizeTotal:= sizeTotal+size;
  2399. Check(pc^.Size = (t+size),'size(c)');
  2400. // for 'k'
  2401. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2402. CheckSimpleProps(p,False,True,0,False);
  2403. CheckWeigths(p,[$15EF,$123,1, $15EF,0,0]);
  2404. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$123,1, $15EF,0,0]);
  2405. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2406. Check(p^.Size = size,'size(k)');
  2407. sizeTotal:= sizeTotal+size;
  2408. Check(ABook.PropCount = sizeTotal,'size(total)');
  2409. end;
  2410. procedure test12_check_4(const ABook : unicodedata.TUCA_DataBook);
  2411. var
  2412. p, pc : PUCA_PropItemRec;
  2413. size, sizeTotal, t: Integer;
  2414. begin
  2415. sizeTotal := 0;
  2416. // for 'b'
  2417. p := ABook.Props;
  2418. CheckSimpleProps(p,False,True,0,False);
  2419. CheckWeigths(p,[$15EF,$121,0, $15EF,0,0]);
  2420. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$121,0, $15EF,0,0]);
  2421. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2422. Check(p^.Size = size,'size');
  2423. sizeTotal:= sizeTotal+size;
  2424. // for 'c'
  2425. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2426. pc := p;
  2427. CheckSimpleProps(p,False,True,2,False);
  2428. CheckWeigths(p,[$15EF,$122,0, $15EF,0,0]);
  2429. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$122,0, $15EF,0,0]);
  2430. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2431. t := size;
  2432. sizeTotal:= sizeTotal+size;
  2433. // for 'i' as in 'ci'
  2434. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2435. CheckSimpleProps(p,True,True,0,False);
  2436. CheckWeigths(p,[$15EF,$123,0, $15EF,0,0]);
  2437. size := SizeOf(TUCA_PropItemRec) +
  2438. SizeOf(UInt24) +
  2439. CalcWeigthSize([$15EF,$123,0, $15EF,0,0]);
  2440. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2441. Check(p^.Size = size,'size(i)');
  2442. t := t+size;
  2443. sizeTotal:= sizeTotal+size;
  2444. // for 's' as in 'cs'
  2445. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2446. CheckSimpleProps(p,True,True,0,False);
  2447. CheckWeigths(p,[$15EF,$123,1, $15F0,0,0]);
  2448. size := SizeOf(TUCA_PropItemRec) +
  2449. SizeOf(UInt24) +
  2450. CalcWeigthSize([$15EF,$123,1, $15F0,0,0]);
  2451. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2452. Check(p^.Size = size,'size(s)');
  2453. t := t+size;
  2454. sizeTotal:= sizeTotal+size;
  2455. Check(pc^.Size = t,'size(c)');
  2456. // for 'k'
  2457. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2458. CheckSimpleProps(p,False,True,0,False);
  2459. CheckWeigths(p,[$15EF,$123,1, $15EF,0,0]);
  2460. size := SizeOf(TUCA_PropItemRec) + CalcWeigthSize([$15EF,$123,1, $15EF,0,0]);
  2461. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2462. Check(p^.Size = size,'size(k)');
  2463. sizeTotal:= sizeTotal+size;
  2464. Check(ABook.PropCount = sizeTotal,'size(total)');
  2465. end;
  2466. procedure test12();
  2467. var
  2468. sequence, sequenceClean : TOrderedCharacters;
  2469. statement : TReorderSequence;
  2470. wfirst, wresult : TUCA_LineRecArray;
  2471. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  2472. begin
  2473. statement.Clear();
  2474. test12_prepareWeigth(wfirst);
  2475. test12_PopulateSequence(sequenceClean);
  2476. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  2477. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  2478. //Generate the original tables
  2479. ConstructUnicodeBook(wfirst,'test','first',nil,unicodeBook1);
  2480. // --- test 1
  2481. sequence := sequenceClean.Clone();
  2482. SetLength(statement.Reset,1);
  2483. statement.Reset[0] := Ord('a');
  2484. SetLength(statement.Elements,3);
  2485. statement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  2486. statement.Elements[1] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  2487. statement.Elements[2] := TReorderUnit.From([Ord('x'),Ord('y')],TReorderWeigthKind.Primary,0);
  2488. sequence.ApplyStatement(@statement);
  2489. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2490. wresult := nil;
  2491. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2492. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2493. //Generate updatet tables
  2494. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  2495. CheckInf(['a','b','c','xy'],@unicodeBook2);
  2496. test12_check_1(unicodeBook2);
  2497. WriteLn(' -- test 1 - ok');
  2498. // --- test 2
  2499. sequence := sequenceClean.Clone();
  2500. statement.Clear();
  2501. SetLength(statement.Reset,1);
  2502. statement.Reset[0] := Ord('a');
  2503. SetLength(statement.Elements,4);
  2504. statement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Secondary,0);
  2505. statement.Elements[1] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Secondary,0);
  2506. statement.Elements[2] := TReorderUnit.From([Ord('h'),Ord('i')],TReorderWeigthKind.Secondary,0);
  2507. statement.Elements[3] := TReorderUnit.From(Ord('k'),TReorderWeigthKind.Tertiary,0);
  2508. sequence.ApplyStatement(@statement);
  2509. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2510. wresult := nil;
  2511. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2512. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2513. //Generate updatet tables
  2514. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  2515. CheckInf(['a','b','c','hi','k'],@unicodeBook2);
  2516. test12_check_2(unicodeBook2);
  2517. WriteLn(' -- test 2 - ok');
  2518. // --- test 3
  2519. sequence := sequenceClean.Clone();
  2520. statement.Clear();
  2521. SetLength(statement.Reset,1);
  2522. statement.Reset[0] := Ord('a');
  2523. SetLength(statement.Elements,4);
  2524. statement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Secondary,0);
  2525. statement.Elements[1] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Secondary,0);
  2526. statement.Elements[2] := TReorderUnit.From([Ord('c'),Ord('i')],TReorderWeigthKind.Secondary,0);
  2527. statement.Elements[3] := TReorderUnit.From(Ord('k'),TReorderWeigthKind.Tertiary,0);
  2528. sequence.ApplyStatement(@statement);
  2529. WriteLn(' Statement #3 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2530. wresult := nil;
  2531. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2532. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2533. //Generate updatet tables
  2534. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  2535. CheckInf(['a','b','c','ci','k'],@unicodeBook2);
  2536. test12_check_3(unicodeBook2);
  2537. WriteLn(' -- test 3 - ok');
  2538. // --- test 4
  2539. sequence := sequenceClean.Clone();
  2540. statement.Clear();
  2541. SetLength(statement.Reset,1);
  2542. statement.Reset[0] := Ord('a');
  2543. SetLength(statement.Elements,5);
  2544. statement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Secondary,0);
  2545. statement.Elements[1] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Secondary,0);
  2546. statement.Elements[2] := TReorderUnit.From([Ord('c'),Ord('i')],TReorderWeigthKind.Secondary,0);
  2547. statement.Elements[3] := TReorderUnit.From(Ord('k'),TReorderWeigthKind.Tertiary,0);
  2548. statement.Elements[4] := TReorderUnit.From([Ord('c'),Ord('s')],TReorderWeigthKind.Primary,0);
  2549. sequence.ApplyStatement(@statement);
  2550. WriteLn(' Statement #4 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2551. wresult := nil;
  2552. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2553. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2554. //Generate updatet tables
  2555. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  2556. CheckInf(['a','b','c','ci','k','cs'],@unicodeBook2);
  2557. test12_check_4(unicodeBook2);
  2558. WriteLn(' -- test 4 - ok');
  2559. end;
  2560. //------------------------------------------------------
  2561. procedure test13_prepareWeigth(var AData : TUCA_LineRecArray);
  2562. var
  2563. p : PUCA_LineRec;
  2564. begin
  2565. SetLength(AData,2);
  2566. p := @AData[Low(AData)];
  2567. p^.CodePoints := CodePointToArray(Ord('a'));
  2568. p^.Weights := ToWeight($15EF,$0120,$0002);
  2569. Inc(p);
  2570. p^.CodePoints := CodePointToArray([Ord('b')]);
  2571. p^.Weights := ToWeight($15F0,$0120,$0002);
  2572. end;
  2573. procedure test13_PopulateSequence(var ASequence : TOrderedCharacters);
  2574. var
  2575. i : Integer;
  2576. begin
  2577. ASequence := TOrderedCharacters.Create();
  2578. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  2579. ASequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  2580. for i := 0 to ASequence.ActualLength - 1 do
  2581. ASequence.Data[i].Changed := False;
  2582. end;
  2583. procedure test13_check_1(const ABook : unicodedata.TUCA_DataBook);
  2584. var
  2585. p, pb : PUCA_PropItemRec;
  2586. size, sizeTotal, t: Integer;
  2587. begin
  2588. sizeTotal := 0;
  2589. // for 'b'
  2590. p := ABook.Props;
  2591. pb := p;
  2592. CheckSimpleProps(p,False,True,1,False,True);
  2593. CheckWeigths(p,[]);
  2594. size := SizeOf(TUCA_PropItemRec);
  2595. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2596. t := size;
  2597. sizeTotal:= sizeTotal+size;
  2598. // for 'u' as in 'bu'
  2599. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2600. CheckSimpleProps(p,True,True,0,False,False);
  2601. CheckWeigths(p,[$15F0,0,0, $15F0,0,0]);
  2602. size := SizeOf(TUCA_PropItemRec) +
  2603. SizeOf(UInt24) +
  2604. CalcWeigthSize([$15F0,0,0, $15F0,0,0]);
  2605. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2606. Check(p^.Size = size,'size(u)');
  2607. t := t+size;
  2608. sizeTotal:= sizeTotal+size;
  2609. Check(pb^.Size = t,'size(c)');
  2610. Check(ABook.PropCount = sizeTotal,'size(total)');
  2611. end;
  2612. procedure test13_check_2(const ABook : unicodedata.TUCA_DataBook);
  2613. var
  2614. p, pb : PUCA_PropItemRec;
  2615. size, sizeTotal, t: Integer;
  2616. begin
  2617. sizeTotal := 0;
  2618. // for 'b'
  2619. p := ABook.Props;
  2620. pb := p;
  2621. CheckSimpleProps(p,False,True,1,False,True);
  2622. CheckWeigths(p,[]);
  2623. size := SizeOf(TUCA_PropItemRec);
  2624. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2625. t := size;
  2626. sizeTotal:= sizeTotal+size;
  2627. // for 'u' as in 'bu'
  2628. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2629. CheckSimpleProps(p,True,True,0,False,False);
  2630. CheckWeigths(p,[$15F0,0,0, $15F0,0,0]);
  2631. size := SizeOf(TUCA_PropItemRec) +
  2632. SizeOf(UInt24) +
  2633. CalcWeigthSize([$15F0,0,0, $15F0,0,0]);
  2634. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2635. Check(p^.Size = size,'size(u)');
  2636. t := t+size;
  2637. sizeTotal:= sizeTotal+size;
  2638. Check(pb^.Size = t,'size(c)');
  2639. // for 'c'
  2640. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2641. CheckSimpleProps(p,False,True,0,False,False);
  2642. CheckWeigths(p,[$15F0,0,0, $15F1,0,0]);
  2643. size := SizeOf(TUCA_PropItemRec) +
  2644. CalcWeigthSize([$15F0,0,0, $15F1,0,0]);
  2645. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2646. Check(p^.Size = size,'size(c)');
  2647. sizeTotal:= sizeTotal+size;
  2648. Check(ABook.PropCount = sizeTotal,'size(total)');
  2649. end;
  2650. procedure test13();
  2651. var
  2652. sequence, sequenceClean : TOrderedCharacters;
  2653. statement : TReorderSequence;
  2654. wfirst, wresult : TUCA_LineRecArray;
  2655. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  2656. begin
  2657. statement.Clear();
  2658. test12_prepareWeigth(wfirst);
  2659. test12_PopulateSequence(sequenceClean);
  2660. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  2661. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  2662. //Generate the original tables
  2663. ConstructUnicodeBook(wfirst,'test','first',nil,unicodeBook1);
  2664. // --- test 1
  2665. sequence := sequenceClean.Clone();
  2666. statement.Clear();
  2667. SetLength(statement.Elements,1);
  2668. statement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Deletion,0);
  2669. sequence.ApplyStatement(@statement);
  2670. statement.Clear();
  2671. SetLength(statement.Reset,1);
  2672. statement.Reset[0] := Ord('a');
  2673. SetLength(statement.Elements,1);
  2674. statement.Elements[0] := TReorderUnit.From([Ord('b'),Ord('u')],TReorderWeigthKind.Primary,0);
  2675. sequence.ApplyStatement(@statement);
  2676. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2677. wresult := nil;
  2678. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2679. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2680. //Generate updatet tables
  2681. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  2682. CheckInf(['a','bu','b'{because b's weigth is now computed!}],@unicodeBook2);
  2683. test13_check_1(unicodeBook2);
  2684. WriteLn(' -- test 1 - ok');
  2685. // --- test 2
  2686. sequence := sequenceClean.Clone();
  2687. statement.Clear();
  2688. SetLength(statement.Elements,1);
  2689. statement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Deletion,0);
  2690. sequence.ApplyStatement(@statement);
  2691. statement.Clear();
  2692. SetLength(statement.Reset,2);
  2693. statement.Reset[0] := Ord('a');
  2694. SetLength(statement.Elements,2);
  2695. statement.Elements[0] := TReorderUnit.From([Ord('b'),Ord('u')],TReorderWeigthKind.Primary,0);
  2696. statement.Elements[1] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  2697. sequence.ApplyStatement(@statement);
  2698. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  2699. wresult := nil;
  2700. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  2701. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  2702. //Generate updatet tables
  2703. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  2704. CheckInf(['a','bu','c','b'{because b's weigth is now computed!}],@unicodeBook2);
  2705. test13_check_2(unicodeBook2);
  2706. WriteLn(' -- test 2 - ok');
  2707. end;
  2708. //------------------------------------------------------
  2709. procedure test14_prepareWeigth(var AData : TUCA_LineRecArray);
  2710. var
  2711. p : PUCA_LineRec;
  2712. begin
  2713. SetLength(AData,1);
  2714. p := @AData[Low(AData)];
  2715. p^.CodePoints := CodePointToArray(Ord('a'));
  2716. p^.Weights := ToWeight($15EF,$0120,$0002);
  2717. end;
  2718. procedure test14_PopulateSequence(var ASequence : TOrderedCharacters);
  2719. var
  2720. i : Integer;
  2721. begin
  2722. ASequence := TOrderedCharacters.Create();
  2723. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  2724. for i := 0 to ASequence.ActualLength - 1 do
  2725. ASequence.Data[i].Changed := False;
  2726. end;
  2727. procedure test14_check_1(const ABook : unicodedata.TUCA_DataBook);
  2728. var
  2729. p : PUCA_PropItemRec;
  2730. size, sizeTotal: Integer;
  2731. ctx : PUCA_PropItemContextTreeRec;
  2732. ctxItem : PUCA_PropItemContextTreeNodeRec;
  2733. pb : PByte;
  2734. begin
  2735. sizeTotal := 0;
  2736. // for 'b'
  2737. p := ABook.Props;
  2738. pb := PByte(p);
  2739. size := 0;
  2740. CheckSimpleProps(p,True,True,0,True,False);
  2741. size := SizeOf(TUCA_PropItemRec)+SizeOf(UInt24){codepoint};
  2742. CheckWeigths(p,[]);
  2743. ctx := PUCA_PropItemContextTreeRec(PtrUInt(p)+SizeOf(TUCA_PropItemRec)+SizeOf(UInt24));
  2744. Check(ctx^.Size>0,'ctx^.Size');
  2745. ctxItem := PUCA_PropItemContextTreeNodeRec(PtrUInt(ctx)+SizeOf(ctx^.Size));
  2746. Check(ctxItem<>nil,'ctxItem');
  2747. Check(ctxItem^.Left=0,'ctxItem^.Left');
  2748. Check(ctxItem^.Right=0,'ctxItem^.Right');
  2749. Check(ctxItem^.Data.CodePointCount=1,'ctxItem^.Data.CodePointCount');
  2750. Check(ctxItem^.Data.WeightCount=2,'ctxItem^.Data.WeightCount');
  2751. pb := PByte(PtrUInt(@ctxItem^.Data)+SizeOf(ctxItem^.Data));
  2752. Check(Cardinal(PUInt24(pb)^)=Ord('a'),'Context CodePoint');
  2753. pb := pb + (ctxItem^.Data.CodePointCount*SizeOf(UInt24));
  2754. CheckWeigths(PUCA_PropWeights(pb),ctxItem^.Data.WeightCount,[$15EF,$120,$3, $15EF,0,0]);
  2755. size := SizeOf(TUCA_PropItemRec)+
  2756. SizeOf(UInt24){codepoint}+
  2757. SizeOf(TUCA_PropItemContextTreeRec.Size)+
  2758. SizeOf(TUCA_PropItemContextTreeNodeRec) +
  2759. (ctxItem^.Data.CodePointCount*SizeOf(UInt24))+
  2760. (ctxItem^.Data.WeightCount*SizeOf(TUCA_PropWeights));
  2761. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2762. sizeTotal:= sizeTotal+size;
  2763. Check(ABook.PropCount = sizeTotal,'size(total)');
  2764. end;
  2765. procedure test14_check_2(const ABook : unicodedata.TUCA_DataBook);
  2766. var
  2767. p : PUCA_PropItemRec;
  2768. size, sizeTotal : Integer;
  2769. ctx : PUCA_PropItemContextTreeRec;
  2770. ctxItem : PUCA_PropItemContextTreeNodeRec;
  2771. pb : PByte;
  2772. begin
  2773. sizeTotal := 0;
  2774. // for 'b'
  2775. p := ABook.Props;
  2776. pb := PByte(p);
  2777. size := 0;
  2778. CheckSimpleProps(p,True,True,0,True,False);
  2779. CheckWeigths(p,[]);
  2780. ctx := PUCA_PropItemContextTreeRec(PtrUInt(p)+SizeOf(TUCA_PropItemRec)+SizeOf(UInt24));
  2781. Check(ctx^.Size>0,'ctx^.Size');
  2782. ctxItem := PUCA_PropItemContextTreeNodeRec(PtrUInt(ctx)+SizeOf(ctx^.Size));
  2783. Check(ctxItem<>nil,'ctxItem');
  2784. Check(ctxItem^.Left=0,'ctxItem^.Left');
  2785. Check(ctxItem^.Right=0,'ctxItem^.Right');
  2786. Check(ctxItem^.Data.CodePointCount=1,'ctxItem^.Data.CodePointCount');
  2787. Check(ctxItem^.Data.WeightCount=2,'ctxItem^.Data.WeightCount');
  2788. pb := PByte(PtrUInt(@ctxItem^.Data)+SizeOf(ctxItem^.Data));
  2789. Check(Cardinal(PUInt24(pb)^)=Ord('a'),'Context CodePoint');
  2790. pb := pb + (ctxItem^.Data.CodePointCount*SizeOf(UInt24));
  2791. CheckWeigths(PUCA_PropWeights(pb),ctxItem^.Data.WeightCount,[$15EF,$120,$3, $15EF,0,0]);
  2792. size := SizeOf(TUCA_PropItemRec)+
  2793. SizeOf(UInt24){codepoint}+
  2794. SizeOf(TUCA_PropItemContextTreeRec.Size)+
  2795. SizeOf(TUCA_PropItemContextTreeNodeRec) +
  2796. (ctxItem^.Data.CodePointCount*SizeOf(UInt24))+
  2797. (ctxItem^.Data.WeightCount*SizeOf(TUCA_PropWeights));
  2798. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2799. sizeTotal:= sizeTotal+size;
  2800. // for 'c'
  2801. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2802. CheckSimpleProps(p,False,True,0,False,False);
  2803. CheckWeigths(p,[$15EF,$120,$3, $15F0,0,0]);
  2804. size := SizeOf(TUCA_PropItemRec) +
  2805. CalcWeigthSize([$15EF,$120,$3, $15F0,0,0]);
  2806. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2807. Check(p^.Size = size,'size(u)');
  2808. sizeTotal:= sizeTotal+size;
  2809. Check(ABook.PropCount = sizeTotal,'size(total)');
  2810. end;
  2811. procedure test14_check_3(const ABook : unicodedata.TUCA_DataBook);
  2812. var
  2813. p : PUCA_PropItemRec;
  2814. size, sizeTotal, t: Integer;
  2815. ctx : PUCA_PropItemContextTreeRec;
  2816. ctxItem : PUCA_PropItemContextTreeNodeRec;
  2817. pb : PByte;
  2818. begin
  2819. sizeTotal := 0;
  2820. // for 'b'
  2821. p := ABook.Props;
  2822. pb := PByte(p);
  2823. size := 0;
  2824. CheckSimpleProps(p,True,True,0,True,False);
  2825. CheckWeigths(p,[]);
  2826. ctx := PUCA_PropItemContextTreeRec(PtrUInt(p)+SizeOf(TUCA_PropItemRec)+SizeOf(UInt24));
  2827. Check(ctx^.Size>0,'ctx^.Size');
  2828. ctxItem := PUCA_PropItemContextTreeNodeRec(PtrUInt(ctx)+SizeOf(ctx^.Size));
  2829. Check(ctxItem<>nil,'ctxItem');
  2830. Check(ctxItem^.Left=0,'ctxItem^.Left');
  2831. Check(ctxItem^.Right<>0,'ctxItem^.Right');
  2832. Check(ctxItem^.Data.CodePointCount=1,'ctxItem^.Data.CodePointCount');
  2833. Check(ctxItem^.Data.WeightCount=2,'ctxItem^.Data.WeightCount');
  2834. pb := PByte(PtrUInt(@ctxItem^.Data)+SizeOf(ctxItem^.Data));
  2835. Check(Cardinal(PUInt24(pb)^)=Ord('a'),'Context CodePoint');
  2836. pb := pb + (ctxItem^.Data.CodePointCount*SizeOf(UInt24));
  2837. CheckWeigths(PUCA_PropWeights(pb),ctxItem^.Data.WeightCount,[$15EF,$120,$3, $15EF,0,0]);
  2838. t := SizeOf(TUCA_PropItemContextTreeNodeRec) +
  2839. (ctxItem^.Data.CodePointCount*SizeOf(UInt24))+
  2840. (ctxItem^.Data.WeightCount*SizeOf(TUCA_PropWeights));
  2841. Check(ctxItem^.Right = t,'ctxItem^.Right');
  2842. ctxItem := PUCA_PropItemContextTreeNodeRec(PtrUInt(ctxItem)+t);
  2843. Check(ctxItem^.Left=0,'ctxItem^.Left');
  2844. Check(ctxItem^.Right=0,'ctxItem^.Right');
  2845. Check(ctxItem^.Data.CodePointCount=1,'ctxItem^.Data.CodePointCount');
  2846. Check(ctxItem^.Data.WeightCount=2,'ctxItem^.Data.WeightCount');
  2847. pb := PByte(PtrUInt(@ctxItem^.Data)+SizeOf(ctxItem^.Data));
  2848. Check(Cardinal(PUInt24(pb)^)=Ord('f'),'Context CodePoint');
  2849. pb := pb + (ctxItem^.Data.CodePointCount*SizeOf(UInt24));
  2850. CheckWeigths(PUCA_PropWeights(pb),ctxItem^.Data.WeightCount,[$15EF,$120,$4, $15F1,0,0]);
  2851. size := SizeOf(TUCA_PropItemRec)+
  2852. SizeOf(UInt24){codepoint}+
  2853. SizeOf(TUCA_PropItemContextTreeRec.Size)+
  2854. t+
  2855. SizeOf(TUCA_PropItemContextTreeNodeRec) +
  2856. (ctxItem^.Data.CodePointCount*SizeOf(UInt24))+
  2857. (ctxItem^.Data.WeightCount*SizeOf(TUCA_PropWeights));
  2858. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2859. sizeTotal:= sizeTotal+size;
  2860. // for 'e'
  2861. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2862. CheckSimpleProps(p,False,True,0,False,False);
  2863. CheckWeigths(p,[$15EF,$120,$3, $15F0,0,0]);
  2864. size := SizeOf(TUCA_PropItemRec) +
  2865. CalcWeigthSize([$15EF,$120,$3, $15F0,0,0]);
  2866. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2867. Check(p^.Size = size,'size(e)');
  2868. sizeTotal:= sizeTotal+size;
  2869. // for 'f'
  2870. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2871. CheckSimpleProps(p,False,True,0,False,False);
  2872. CheckWeigths(p,[$15EF,$120,$3, $15F1,0,0]);
  2873. size := SizeOf(TUCA_PropItemRec) +
  2874. CalcWeigthSize([$15EF,$120,$3, $15F1,0,0]);
  2875. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2876. Check(p^.Size = size,'size(f)');
  2877. sizeTotal:= sizeTotal+size;
  2878. Check(ABook.PropCount = sizeTotal,'size(total)');
  2879. end;
  2880. procedure test14_check_4(const ABook : unicodedata.TUCA_DataBook);
  2881. var
  2882. p : PUCA_PropItemRec;
  2883. size, sizeTotal, t, ctxSize: Integer;
  2884. ctx : PUCA_PropItemContextTreeRec;
  2885. ctxItem, ctxItemParent : PUCA_PropItemContextTreeNodeRec;
  2886. pb : PByte;
  2887. begin
  2888. sizeTotal := 0;
  2889. ctxSize := 0;
  2890. // for 'b'
  2891. p := ABook.Props;
  2892. pb := PByte(p);
  2893. size := 0;
  2894. CheckSimpleProps(p,True,True,0,True,False);
  2895. CheckWeigths(p,[]);
  2896. ctx := PUCA_PropItemContextTreeRec(PtrUInt(p)+SizeOf(TUCA_PropItemRec)+SizeOf(UInt24));
  2897. Check(ctx^.Size>0,'ctx^.Size');
  2898. ctxItem := PUCA_PropItemContextTreeNodeRec(PtrUInt(ctx)+SizeOf(ctx^.Size));
  2899. ctxItemParent := ctxItem;
  2900. Check(ctxItem<>nil,'ctxItem');
  2901. Check(ctxItem^.Left<>0,'ctxItem^.Left');
  2902. Check(ctxItem^.Right<>0,'ctxItem^.Right');
  2903. Check(ctxItem^.Data.CodePointCount=1,'ctxItem^.Data.CodePointCount');
  2904. Check(ctxItem^.Data.WeightCount=2,'ctxItem^.Data.WeightCount');
  2905. pb := PByte(PtrUInt(@ctxItem^.Data)+SizeOf(ctxItem^.Data));
  2906. Check(Cardinal(PUInt24(pb)^)=Ord('f'),'Context CodePoint');
  2907. pb := pb + (ctxItem^.Data.CodePointCount*SizeOf(UInt24));
  2908. CheckWeigths(PUCA_PropWeights(pb),ctxItem^.Data.WeightCount,[$15EF,$120,$4, $15F1,0,0]);
  2909. t := SizeOf(TUCA_PropItemContextTreeNodeRec) +
  2910. (ctxItem^.Data.CodePointCount*SizeOf(UInt24))+
  2911. (ctxItem^.Data.WeightCount*SizeOf(TUCA_PropWeights));
  2912. ctxSize := ctxSize+t;
  2913. Check(ctxItem^.Left = t,'ctxItem^.Left');
  2914. ctxItem := PUCA_PropItemContextTreeNodeRec(PtrUInt(ctxItem)+t);
  2915. Check(ctxItem^.Left=0,'ctxItem^.Left');
  2916. Check(ctxItem^.Right=0,'ctxItem^.Right');
  2917. Check(ctxItem^.Data.CodePointCount=1,'ctxItem^.Data.CodePointCount');
  2918. Check(ctxItem^.Data.WeightCount=2,'ctxItem^.Data.WeightCount');
  2919. pb := PByte(PtrUInt(@ctxItem^.Data)+SizeOf(ctxItem^.Data));
  2920. Check(Cardinal(PUInt24(pb)^)=Ord('a'),'Context CodePoint');
  2921. pb := pb + (ctxItem^.Data.CodePointCount*SizeOf(UInt24));
  2922. CheckWeigths(PUCA_PropWeights(pb),ctxItem^.Data.WeightCount,[$15EF,$120,$3, $15EF,0,0]);
  2923. t := SizeOf(TUCA_PropItemContextTreeNodeRec) +
  2924. (ctxItem^.Data.CodePointCount*SizeOf(UInt24))+
  2925. (ctxItem^.Data.WeightCount*SizeOf(TUCA_PropWeights));
  2926. ctxSize := ctxSize+t;
  2927. ctxItem := PUCA_PropItemContextTreeNodeRec(PtrUInt(ctxItemParent)+ctxSize);
  2928. Check(ctxItem^.Left=0,'ctxItem^.Left');
  2929. Check(ctxItem^.Right=0,'ctxItem^.Right');
  2930. Check(ctxItem^.Data.CodePointCount=1,'ctxItem^.Data.CodePointCount');
  2931. Check(ctxItem^.Data.WeightCount=2,'ctxItem^.Data.WeightCount');
  2932. pb := PByte(PtrUInt(@ctxItem^.Data)+SizeOf(ctxItem^.Data));
  2933. Check(Cardinal(PUInt24(pb)^)=Ord('h'),'Context CodePoint');
  2934. pb := pb + (ctxItem^.Data.CodePointCount*SizeOf(UInt24));
  2935. CheckWeigths(PUCA_PropWeights(pb),ctxItem^.Data.WeightCount,[$15EF,$121,$6, $15F1,0,0]);
  2936. t := SizeOf(TUCA_PropItemContextTreeNodeRec) +
  2937. (ctxItem^.Data.CodePointCount*SizeOf(UInt24))+
  2938. (ctxItem^.Data.WeightCount*SizeOf(TUCA_PropWeights));
  2939. ctxSize := ctxSize+t;
  2940. ctxSize := ctxSize + SizeOf(TUCA_PropItemContextTreeRec.Size);
  2941. Check(ctx^.Size = ctxSize,'ctx^.Size');
  2942. size := SizeOf(TUCA_PropItemRec)+
  2943. SizeOf(UInt24){codepoint}+
  2944. ctxSize;
  2945. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2946. sizeTotal:= sizeTotal+size;
  2947. // for 'e'
  2948. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2949. CheckSimpleProps(p,False,True,0,False,False);
  2950. CheckWeigths(p,[$15EF,$120,$3, $15F0,0,0]);
  2951. size := SizeOf(TUCA_PropItemRec) +
  2952. CalcWeigthSize([$15EF,$120,$3, $15F0,0,0]);
  2953. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2954. Check(p^.Size = size,'size(e)');
  2955. sizeTotal:= sizeTotal+size;
  2956. // for 'f'
  2957. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2958. CheckSimpleProps(p,False,True,0,False,False);
  2959. CheckWeigths(p,[$15EF,$120,$3, $15F1,0,0]);
  2960. size := SizeOf(TUCA_PropItemRec) +
  2961. CalcWeigthSize([$15EF,$120,$3, $15F1,0,0]);
  2962. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2963. Check(p^.Size = size,'size(f)');
  2964. sizeTotal:= sizeTotal+size;
  2965. // for 'g'
  2966. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2967. CheckSimpleProps(p,False,True,0,False,False);
  2968. CheckWeigths(p,[$15EF,$120,$5, $15F1,0,0]);
  2969. size := SizeOf(TUCA_PropItemRec) +
  2970. CalcWeigthSize([$15EF,$120,$5, $15F1,0,0]);
  2971. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2972. Check(p^.Size = size,'size(g)');
  2973. sizeTotal:= sizeTotal+size;
  2974. // for 'h'
  2975. p := PUCA_PropItemRec(PtrUInt(p)+size);
  2976. CheckSimpleProps(p,False,True,0,False,False);
  2977. CheckWeigths(p,[$15EF,$121,$5, $15F1,0,0]);
  2978. size := SizeOf(TUCA_PropItemRec) +
  2979. CalcWeigthSize([$15EF,$121,$5, $15F1,0,0]);
  2980. Check(p^.GetSelfOnlySize() = size,'GetSelfOnlySize');
  2981. Check(p^.Size = size,'size(h)');
  2982. sizeTotal:= sizeTotal+size;
  2983. Check(ABook.PropCount = sizeTotal,'size(total)');
  2984. end;
  2985. procedure test14();
  2986. var
  2987. sequence, sequenceClean : TOrderedCharacters;
  2988. statement : TReorderSequence;
  2989. wfirst, wresult : TUCA_LineRecArray;
  2990. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  2991. begin
  2992. statement.Clear();
  2993. test12_prepareWeigth(wfirst);
  2994. test12_PopulateSequence(sequenceClean);
  2995. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  2996. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  2997. //Generate the original tables
  2998. ConstructUnicodeBook(wfirst,'test','first',nil,unicodeBook1);
  2999. // --- test 1
  3000. sequence := sequenceClean.Clone();
  3001. statement.Clear();
  3002. SetLength(statement.Reset,1);
  3003. statement.Reset[0] := Ord('a');
  3004. SetLength(statement.Elements,1);
  3005. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3006. sequence.ApplyStatement(@statement);
  3007. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3008. wresult := nil;
  3009. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3010. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3011. //Generate updatet tables
  3012. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3013. test14_check_1(unicodeBook2);
  3014. WriteLn(' -- test 1 - ok');
  3015. WriteLn;
  3016. // --- test 2
  3017. sequence := sequenceClean.Clone();
  3018. statement.Clear();
  3019. SetLength(statement.Reset,1);
  3020. statement.Reset[0] := Ord('a');
  3021. SetLength(statement.Elements,2);
  3022. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3023. statement.Elements[1] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  3024. sequence.ApplyStatement(@statement);
  3025. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3026. wresult := nil;
  3027. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3028. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3029. //Generate updatet tables
  3030. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3031. test14_check_2(unicodeBook2);
  3032. WriteLn(' -- test 2 - ok');
  3033. WriteLn;
  3034. // --- test 3
  3035. sequence := sequenceClean.Clone();
  3036. statement.Clear();
  3037. SetLength(statement.Reset,1);
  3038. statement.Reset[0] := Ord('a');
  3039. SetLength(statement.Elements,2);
  3040. statement.Elements[0] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,0);
  3041. statement.Elements[1] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,0);
  3042. sequence.ApplyStatement(@statement);
  3043. statement.Clear();
  3044. SetLength(statement.Reset,1);
  3045. statement.Reset[0] := Ord('a');
  3046. SetLength(statement.Elements,1);
  3047. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3048. sequence.ApplyStatement(@statement);
  3049. statement.Clear();
  3050. SetLength(statement.Reset,1);
  3051. statement.Reset[0] := Ord('f');
  3052. SetLength(statement.Elements,1);
  3053. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('f')],TReorderWeigthKind.Tertiary,0);
  3054. sequence.ApplyStatement(@statement);
  3055. WriteLn(' Statement #3 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3056. wresult := nil;
  3057. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3058. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3059. //Generate updatet tables
  3060. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3061. test14_check_3(unicodeBook2);
  3062. WriteLn(' -- test 3 - ok');
  3063. WriteLn;
  3064. // --- test 4
  3065. sequence := sequenceClean.Clone();
  3066. statement.Clear();
  3067. SetLength(statement.Reset,1);
  3068. statement.Reset[0] := Ord('a');
  3069. SetLength(statement.Elements,4);
  3070. statement.Elements[0] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,0);
  3071. statement.Elements[1] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,0);
  3072. statement.Elements[2] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Tertiary,0);
  3073. statement.Elements[3] := TReorderUnit.From(Ord('h'),TReorderWeigthKind.Secondary,0);
  3074. sequence.ApplyStatement(@statement);
  3075. statement.Clear();
  3076. SetLength(statement.Reset,1);
  3077. statement.Reset[0] := Ord('f');
  3078. SetLength(statement.Elements,1);
  3079. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('f')],TReorderWeigthKind.Tertiary,0);
  3080. sequence.ApplyStatement(@statement);
  3081. statement.Clear();
  3082. SetLength(statement.Reset,1);
  3083. statement.Reset[0] := Ord('a');
  3084. SetLength(statement.Elements,1);
  3085. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3086. sequence.ApplyStatement(@statement);
  3087. statement.Clear();
  3088. SetLength(statement.Reset,1);
  3089. statement.Reset[0] := Ord('h');
  3090. SetLength(statement.Elements,1);
  3091. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('h')],TReorderWeigthKind.Tertiary,0);
  3092. sequence.ApplyStatement(@statement);
  3093. WriteLn(' Statement #4 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3094. wresult := nil;
  3095. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3096. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3097. //Generate updatet tables
  3098. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3099. test14_check_4(unicodeBook2);
  3100. WriteLn(' -- test 4 - ok');
  3101. WriteLn;
  3102. end;
  3103. //------------------------------------------------------
  3104. procedure test15_prepareWeigth(var AData : TUCA_LineRecArray);
  3105. var
  3106. p : PUCA_LineRec;
  3107. begin
  3108. SetLength(AData,1);
  3109. p := @AData[Low(AData)];
  3110. p^.CodePoints := CodePointToArray(Ord('a'));
  3111. p^.Weights := ToWeight($15EF,$0120,$0002);
  3112. end;
  3113. procedure test15_PopulateSequence(var ASequence : TOrderedCharacters);
  3114. var
  3115. i : Integer;
  3116. begin
  3117. ASequence := TOrderedCharacters.Create();
  3118. ASequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  3119. for i := 0 to ASequence.ActualLength - 1 do
  3120. ASequence.Data[i].Changed := False;
  3121. end;
  3122. function ConvertEndianFromNative(
  3123. const AData : Pointer;
  3124. const ADataLen : Integer
  3125. ) : Boolean;
  3126. type
  3127. PUCA_PropItemRec = helper.PUCA_PropItemRec;
  3128. var
  3129. s : PUCA_PropItemRec;
  3130. x, y : array of Byte;
  3131. px, py : PUCA_PropItemRec;
  3132. begin
  3133. if (ADataLen <= 0) then
  3134. exit(True);
  3135. s := PUCA_PropItemRec(AData);
  3136. SetLength(x,ADataLen);
  3137. px := PUCA_PropItemRec(@x[0]);
  3138. ReverseFromNativeEndian(s,ADataLen,px);
  3139. SetLength(y,ADataLen);
  3140. py := PUCA_PropItemRec(@y[0]);
  3141. ReverseToNativeEndian(px,ADataLen,py);
  3142. Result := CompareMem(AData,@y[0],Length(x));
  3143. end;
  3144. procedure test15();
  3145. var
  3146. sequence, sequenceClean : TOrderedCharacters;
  3147. statement : TReorderSequence;
  3148. wfirst, wresult : TUCA_LineRecArray;
  3149. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  3150. begin
  3151. statement.Clear();
  3152. test12_prepareWeigth(wfirst);
  3153. test12_PopulateSequence(sequenceClean);
  3154. WriteLn(' Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequenceClean),sLineBreak);
  3155. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  3156. //Generate the original tables
  3157. ConstructUnicodeBook(wfirst,'test','first',nil,unicodeBook1);
  3158. // --- test 1
  3159. sequence := sequenceClean.Clone();
  3160. SetLength(statement.Reset,1);
  3161. statement.Reset[0] := Ord('a');
  3162. SetLength(statement.Elements,1);
  3163. statement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  3164. sequence.ApplyStatement(@statement);
  3165. WriteLn(' Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3166. wresult := nil;
  3167. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3168. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3169. //Generate updatet tables
  3170. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3171. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3172. WriteLn(' -- test 1 - ok');
  3173. // --- test 2
  3174. sequence := sequenceClean.Clone();
  3175. statement.Clear();
  3176. SetLength(statement.Reset,1);
  3177. statement.Reset[0] := Ord('a');
  3178. SetLength(statement.Elements,1);
  3179. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3180. sequence.ApplyStatement(@statement);
  3181. WriteLn(' Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3182. wresult := nil;
  3183. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3184. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3185. //Generate updatet tables
  3186. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3187. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3188. WriteLn(' -- test 2 - ok');
  3189. WriteLn;
  3190. // --- test 3
  3191. sequence := sequenceClean.Clone();
  3192. statement.Clear();
  3193. SetLength(statement.Reset,1);
  3194. statement.Reset[0] := Ord('a');
  3195. SetLength(statement.Elements,2);
  3196. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3197. statement.Elements[1] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  3198. sequence.ApplyStatement(@statement);
  3199. WriteLn(' Statement #3 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3200. wresult := nil;
  3201. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3202. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3203. //Generate updatet tables
  3204. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3205. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3206. WriteLn(' -- test 3 - ok');
  3207. WriteLn;
  3208. // --- test 4
  3209. sequence := sequenceClean.Clone();
  3210. statement.Clear();
  3211. SetLength(statement.Reset,1);
  3212. statement.Reset[0] := Ord('a');
  3213. SetLength(statement.Elements,2);
  3214. statement.Elements[0] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,0);
  3215. statement.Elements[1] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,0);
  3216. sequence.ApplyStatement(@statement);
  3217. statement.Clear();
  3218. SetLength(statement.Reset,1);
  3219. statement.Reset[0] := Ord('a');
  3220. SetLength(statement.Elements,1);
  3221. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3222. sequence.ApplyStatement(@statement);
  3223. statement.Clear();
  3224. SetLength(statement.Reset,1);
  3225. statement.Reset[0] := Ord('f');
  3226. SetLength(statement.Elements,1);
  3227. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('f')],TReorderWeigthKind.Tertiary,0);
  3228. sequence.ApplyStatement(@statement);
  3229. WriteLn(' Statement #4 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3230. wresult := nil;
  3231. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3232. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3233. //Generate updatet tables
  3234. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3235. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3236. WriteLn(' -- test 4 - ok');
  3237. WriteLn;
  3238. // --- test 5
  3239. sequence := sequenceClean.Clone();
  3240. statement.Clear();
  3241. SetLength(statement.Reset,1);
  3242. statement.Reset[0] := Ord('a');
  3243. SetLength(statement.Elements,4);
  3244. statement.Elements[0] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,0);
  3245. statement.Elements[1] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,0);
  3246. statement.Elements[2] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Tertiary,0);
  3247. statement.Elements[3] := TReorderUnit.From(Ord('h'),TReorderWeigthKind.Secondary,0);
  3248. sequence.ApplyStatement(@statement);
  3249. statement.Clear();
  3250. SetLength(statement.Reset,1);
  3251. statement.Reset[0] := Ord('f');
  3252. SetLength(statement.Elements,1);
  3253. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('f')],TReorderWeigthKind.Tertiary,0);
  3254. sequence.ApplyStatement(@statement);
  3255. statement.Clear();
  3256. SetLength(statement.Reset,1);
  3257. statement.Reset[0] := Ord('a');
  3258. SetLength(statement.Elements,1);
  3259. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3260. sequence.ApplyStatement(@statement);
  3261. statement.Clear();
  3262. SetLength(statement.Reset,1);
  3263. statement.Reset[0] := Ord('h');
  3264. SetLength(statement.Elements,1);
  3265. statement.Elements[0] := TReorderUnit.From(Ord('b'),[Ord('h')],TReorderWeigthKind.Tertiary,0);
  3266. sequence.ApplyStatement(@statement);
  3267. WriteLn(' Statement #5 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3268. wresult := nil;
  3269. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3270. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3271. //Generate updatet tables
  3272. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3273. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3274. WriteLn(' -- test 5 - ok');
  3275. WriteLn;
  3276. // --- test 6
  3277. sequence := sequenceClean.Clone();
  3278. statement.Clear();
  3279. SetLength(statement.Reset,1);
  3280. statement.Reset[0] := Ord('a');
  3281. SetLength(statement.Elements,2);
  3282. statement.Elements[0] := TReorderUnit.From([Ord('a'),Ord('d')],[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3283. statement.Elements[1] := TReorderUnit.From([Ord('a'),Ord('d')],TReorderWeigthKind.Primary,0);
  3284. sequence.ApplyStatement(@statement);
  3285. WriteLn(' Statement #6 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3286. wresult := nil;
  3287. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3288. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3289. //Generate updatet tables
  3290. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3291. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3292. WriteLn(' -- test 6 - ok');
  3293. WriteLn;
  3294. // --- test 7
  3295. sequence := sequenceClean.Clone();
  3296. statement.Clear();
  3297. SetLength(statement.Reset,1);
  3298. statement.Reset[0] := Ord('a');
  3299. SetLength(statement.Elements,3);
  3300. statement.Elements[0] := TReorderUnit.From([Ord('a'),Ord('d')],[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3301. statement.Elements[1] := TReorderUnit.From([Ord('a'),Ord('d')],TReorderWeigthKind.Primary,0);
  3302. statement.Elements[2] := TReorderUnit.From(Ord('e'),[Ord('a'),Ord('d')],TReorderWeigthKind.Identity,0);
  3303. sequence.ApplyStatement(@statement);
  3304. WriteLn(' Statement #7 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3305. wresult := nil;
  3306. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3307. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3308. //Generate updatet tables
  3309. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3310. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3311. WriteLn(' -- test 7 - ok');
  3312. WriteLn;
  3313. // --- test 8
  3314. sequence := sequenceClean.Clone();
  3315. statement.Clear();
  3316. SetLength(statement.Reset,1);
  3317. statement.Reset[0] := Ord('a');
  3318. SetLength(statement.Elements,3);
  3319. statement.Elements[0] := TReorderUnit.From([Ord('a'),Ord('d')],[Ord('a')],TReorderWeigthKind.Tertiary,0);
  3320. statement.Elements[1] := TReorderUnit.From([Ord('a'),Ord('x')],TReorderWeigthKind.Primary,0);
  3321. statement.Elements[2] := TReorderUnit.From([Ord('e'),Ord('a'),Ord('r')],[Ord('a'),Ord('d')],TReorderWeigthKind.Primary,0);
  3322. sequence.ApplyStatement(@statement);
  3323. WriteLn(' Statement #8 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3324. wresult := nil;
  3325. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3326. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3327. //Generate updatet tables
  3328. ConstructUnicodeBook(wresult,'test','second',@unicodeBook1,unicodeBook2);
  3329. Check(ConvertEndianFromNative(unicodeBook2.Props,unicodeBook2.PropCount),'Endian conversion failed.');
  3330. WriteLn(' -- test 8 - ok');
  3331. WriteLn;
  3332. end;
  3333. procedure test16_prepareWeigth(var AData : TUCA_LineRecArray);
  3334. var
  3335. p : PUCA_LineRec;
  3336. begin
  3337. SetLength(AData,3);
  3338. p := @AData[Low(AData)];
  3339. p^.CodePoints := CodePointToArray(Ord('a'));
  3340. p^.Weights := ToWeight($15EF,$0020,$0002);
  3341. Inc(p);
  3342. p^.CodePoints := CodePointToArray(Ord('b'));
  3343. p^.Weights := ToWeight($1605,$0020,$0002);
  3344. Inc(p);
  3345. p^.CodePoints := CodePointToArray(Ord('c'));
  3346. p^.Weights := ToWeight($161D,$0020,$0002);
  3347. end;
  3348. procedure test16a();
  3349. var
  3350. sequence : TOrderedCharacters;
  3351. statement : TReorderSequence;
  3352. wfirst, wresult : TUCA_LineRecArray;
  3353. i : Integer;
  3354. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  3355. begin
  3356. statement.Clear();
  3357. test16_prepareWeigth(wfirst);
  3358. sequence := TOrderedCharacters.Create();
  3359. sequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  3360. sequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  3361. sequence.Append(TReorderUnit.From(TReorderLogicalReset.LastRegular));
  3362. sequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  3363. for i := 0 to sequence.ActualLength - 1 do
  3364. sequence.Data[i].Changed := False;
  3365. WriteLn('Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3366. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  3367. ConstructUnicodeBook(wfirst,'test1','first',nil,unicodeBook1);
  3368. CheckInf(['a','b','c'],@unicodeBook1);
  3369. // --- test 1
  3370. SetLength(statement.Reset,1);
  3371. statement.LogicalPosition := TReorderLogicalReset.LastRegular;
  3372. SetLength(statement.Elements,1);
  3373. statement.Elements[0] := TReorderUnit.From(Ord('x'),TReorderWeigthKind.Primary,0);
  3374. sequence.ApplyStatement(@statement);
  3375. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3376. wresult := nil;
  3377. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3378. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3379. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  3380. CheckInf(['a','b','x'{*},'c'],@unicodeBook2);
  3381. WriteLn(' -- test 1 - ok');
  3382. end;
  3383. procedure test16b();
  3384. var
  3385. sequence : TOrderedCharacters;
  3386. statement : TReorderSequence;
  3387. wfirst, wresult : TUCA_LineRecArray;
  3388. i : Integer;
  3389. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  3390. begin
  3391. statement.Clear();
  3392. test16_prepareWeigth(wfirst);
  3393. sequence := TOrderedCharacters.Create();
  3394. sequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  3395. sequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  3396. sequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  3397. for i := 0 to sequence.ActualLength - 1 do
  3398. sequence.Data[i].Changed := False;
  3399. WriteLn('Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3400. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  3401. ConstructUnicodeBook(wfirst,'test1','first',nil,unicodeBook1);
  3402. CheckInf(['a','b','c'],@unicodeBook1);
  3403. // --- test 1
  3404. SetLength(statement.Reset,1);
  3405. statement.LogicalPosition := TReorderLogicalReset.LastRegular;
  3406. SetLength(statement.Elements,1);
  3407. statement.Elements[0] := TReorderUnit.From(Ord('x'),TReorderWeigthKind.Primary,0);
  3408. sequence.ApplyStatement(@statement);
  3409. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3410. wresult := nil;
  3411. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3412. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3413. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  3414. CheckInf(['a','b','c','x'{*}],@unicodeBook2);
  3415. WriteLn(' -- test 1 - ok');
  3416. writeln;
  3417. writeln;
  3418. // test 2
  3419. statement.Clear();
  3420. SetLength(statement.Reset,1);
  3421. statement.Reset[0] := Ord('x');
  3422. SetLength(statement.Elements,1);
  3423. statement.Elements[0] := TReorderUnit.From(Ord('y'),TReorderWeigthKind.Primary,0);
  3424. sequence.ApplyStatement(@statement);
  3425. WriteLn('Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3426. wresult := nil;
  3427. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3428. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3429. ConstructUnicodeBook(wresult,'test2','2',@unicodeBook1,unicodeBook2);
  3430. CheckInf(['a','b','c','x'{*},'y'{*}],@unicodeBook2);
  3431. WriteLn(' -- test 2 - ok');
  3432. end;
  3433. procedure test16c();
  3434. var
  3435. sequence : TOrderedCharacters;
  3436. statement : TReorderSequence;
  3437. wfirst, wresult : TUCA_LineRecArray;
  3438. i : Integer;
  3439. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  3440. begin
  3441. statement.Clear();
  3442. test16_prepareWeigth(wfirst);
  3443. sequence := TOrderedCharacters.Create();
  3444. sequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  3445. sequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  3446. sequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  3447. for i := 0 to sequence.ActualLength - 1 do
  3448. sequence.Data[i].Changed := False;
  3449. WriteLn('Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3450. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  3451. ConstructUnicodeBook(wfirst,'test1','first',nil,unicodeBook1);
  3452. CheckInf(['a','b','c'],@unicodeBook1);
  3453. // --- test 1
  3454. SetLength(statement.Reset,1);
  3455. statement.LogicalPosition := TReorderLogicalReset.LastRegular;
  3456. SetLength(statement.Elements,1);
  3457. statement.Elements[0] := TReorderUnit.From(Ord('x'),TReorderWeigthKind.Secondary,0);
  3458. sequence.ApplyStatement(@statement);
  3459. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3460. wresult := nil;
  3461. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3462. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3463. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  3464. CheckInf(['a','b','c','x'{*}],@unicodeBook2);
  3465. WriteLn(' -- test 1 - ok');
  3466. writeln;
  3467. writeln;
  3468. // test 2
  3469. statement.Clear();
  3470. SetLength(statement.Reset,1);
  3471. statement.Reset[0] := Ord('x');
  3472. SetLength(statement.Elements,1);
  3473. statement.Elements[0] := TReorderUnit.From(Ord('y'),TReorderWeigthKind.Primary,0);
  3474. sequence.ApplyStatement(@statement);
  3475. WriteLn('Statement #2 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3476. wresult := nil;
  3477. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3478. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3479. ConstructUnicodeBook(wresult,'test2','2',@unicodeBook1,unicodeBook2);
  3480. CheckInf(['a','b','c','x'{*},'y'{*}],@unicodeBook2);
  3481. WriteLn(' -- test 2 - ok');
  3482. end;
  3483. procedure test16d();
  3484. var
  3485. sequence : TOrderedCharacters;
  3486. statement : TReorderSequence;
  3487. wfirst, wresult : TUCA_LineRecArray;
  3488. i : Integer;
  3489. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  3490. begin
  3491. statement.Clear();
  3492. test16_prepareWeigth(wfirst);
  3493. sequence := TOrderedCharacters.Create();
  3494. sequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  3495. sequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  3496. sequence.Append(TReorderUnit.From(TReorderLogicalReset.LastRegular));
  3497. sequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,3));
  3498. for i := 0 to sequence.ActualLength - 1 do
  3499. sequence.Data[i].Changed := False;
  3500. WriteLn('Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3501. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  3502. ConstructUnicodeBook(wfirst,'test1','first',nil,unicodeBook1);
  3503. CheckInf(['a','b','c'],@unicodeBook1);
  3504. // --- test 1
  3505. SetLength(statement.Reset,1);
  3506. statement.LogicalPosition := TReorderLogicalReset.LastRegular;
  3507. statement.Before := True;
  3508. SetLength(statement.Elements,1);
  3509. statement.Elements[0] := TReorderUnit.From(Ord('x'),TReorderWeigthKind.Primary,0);
  3510. sequence.ApplyStatement(@statement);
  3511. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3512. wresult := nil;
  3513. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3514. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3515. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  3516. CheckInf(['a','x'{*},'b','c'],@unicodeBook2);
  3517. WriteLn(' -- test 1 - ok');
  3518. end;
  3519. procedure test16e_prepareWeigth(var AData : TUCA_LineRecArray);
  3520. var
  3521. p : PUCA_LineRec;
  3522. begin
  3523. SetLength(AData,5);
  3524. p := @AData[Low(AData)];
  3525. p^.CodePoints := CodePointToArray(Ord('a'));
  3526. p^.Weights := ToWeight(1,10,10);
  3527. Inc(p);
  3528. p^.CodePoints := CodePointToArray(Ord('b'));
  3529. p^.Weights := ToWeight(2,10,10);
  3530. Inc(p);
  3531. p^.CodePoints := CodePointToArray([Ord('b'),Ord('2')]);
  3532. p^.Weights := ToWeight(2,20,10);
  3533. Inc(p);
  3534. p^.CodePoints := CodePointToArray([Ord('b'),Ord('3')]);
  3535. p^.Weights := ToWeight(2,20,20);
  3536. Inc(p);
  3537. p^.CodePoints := CodePointToArray(Ord('c'));
  3538. p^.Weights := ToWeight(3,10,10);
  3539. end;
  3540. procedure test16e();
  3541. var
  3542. sequence : TOrderedCharacters;
  3543. statement : TReorderSequence;
  3544. wfirst, wresult : TUCA_LineRecArray;
  3545. i : Integer;
  3546. unicodeBook1, unicodeBook2 : unicodedata.TUCA_DataBook;
  3547. begin
  3548. statement.Clear();
  3549. test16e_prepareWeigth(wfirst);
  3550. sequence := TOrderedCharacters.Create();
  3551. sequence.Append(TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,1));
  3552. sequence.Append(TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,2));
  3553. sequence.Append(TReorderUnit.From([Ord('b'),Ord('2')],TReorderWeigthKind.Secondary,3));
  3554. sequence.Append(TReorderUnit.From([Ord('b'),Ord('3')],TReorderWeigthKind.Tertiary,4));
  3555. sequence.Append(TReorderUnit.From(TReorderLogicalReset.LastRegular));
  3556. sequence.Append(TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,5));
  3557. for i := 0 to sequence.ActualLength - 1 do
  3558. sequence.Data[i].Changed := False;
  3559. WriteLn('Initial = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3560. WriteLn(DumpLines(wfirst),sLineBreak+sLineBreak);
  3561. ConstructUnicodeBook(wfirst,'test1','first',nil,unicodeBook1);
  3562. CheckInf(['a','b','b2','b3','c'],@unicodeBook1);
  3563. // --- test 1
  3564. SetLength(statement.Reset,1);
  3565. statement.LogicalPosition := TReorderLogicalReset.LastRegular;
  3566. statement.Before := True;
  3567. SetLength(statement.Elements,1);
  3568. statement.Elements[0] := TReorderUnit.From(Ord('x'),TReorderWeigthKind.Secondary,0);
  3569. sequence.ApplyStatement(@statement);
  3570. WriteLn('Statement #1 = ',sLineBreak,' ',DumpSequenceAnsi(sequence),sLineBreak);
  3571. wresult := nil;
  3572. ComputeWeigths(@sequence.Data[0],sequence.ActualLength,wfirst,wresult);
  3573. WriteLn(DumpLines(wresult),sLineBreak+sLineBreak);
  3574. ConstructUnicodeBook(wresult,'test1','1',@unicodeBook1,unicodeBook2);
  3575. CheckInf(['a','b','x'{*},'b2','b3','c'],@unicodeBook2);
  3576. WriteLn(' -- test 1 - ok');
  3577. end;
  3578. procedure CheckEqual(A,B : array of TUnicodeCodePoint; const AMsg : string);overload;
  3579. var
  3580. i : Integer;
  3581. begin
  3582. Check((Length(A)=Length(B)),'Length() <>');
  3583. if (Length(A) > 0) then begin
  3584. for i := Low(A) to High(A) do
  3585. Check(A[i] = B[i],'%s, A[%d] <>',[AMsg,i]);
  3586. end;
  3587. end;
  3588. procedure CheckEqual(A,B : TReorderUnit; const AMsg : string);overload;
  3589. var
  3590. i : Integer;
  3591. begin
  3592. Check((A.VirtualPosition=B.VirtualPosition),'VirtualPosition <>');
  3593. Check((A.InitialPosition=B.InitialPosition),'InitialPosition <>');
  3594. Check((A.Changed=B.Changed),'Changed <>');
  3595. Check((A.WeigthKind=B.WeigthKind),'WeigthKind <>');
  3596. CheckEqual(A.Context,B.Context,'Context');
  3597. CheckEqual(A.ExpansionChars,B.ExpansionChars,'ExpansionChars');
  3598. CheckEqual(A.Characters,B.Characters,'Characters');
  3599. CheckEqual(A.Context,B.Context,'Context');
  3600. end;
  3601. procedure CheckEqual(A,B : TReorderSequence);overload;
  3602. var
  3603. i : Integer;
  3604. begin
  3605. Check((A.LogicalPosition=B.LogicalPosition),'LogicalPosition <>');
  3606. Check((A.Before=B.Before),'Before <>');
  3607. CheckEqual(A.Reset,B.Reset,'Reset');
  3608. Check((Length(A.Elements)=Length(B.Elements)),'Length(Elements) <>');
  3609. for i := Low(A.Elements) to High(A.Elements) do
  3610. CheckEqual(A.Elements[i],B.Elements[i],Format('Elements[%d]',[i]));
  3611. end;
  3612. function CountLines(const AStr : ansistring) : Integer;
  3613. var
  3614. c, i : Integer;
  3615. begin
  3616. c := 0;
  3617. for i := 1 to Length(AStr) do begin
  3618. if (AStr[i] = #10) then
  3619. c := c+1;
  3620. end;
  3621. if (c = 0) and (AStr <> '') then
  3622. c := c+1;
  3623. Result := c;
  3624. end;
  3625. procedure do_test_parser(
  3626. AText : ansistring;
  3627. const AExpected : TReorderSequence;
  3628. const ALineCount : Integer
  3629. );overload;
  3630. var
  3631. locText : UTF8String;
  3632. locTextPointer : PAnsiChar;
  3633. locStartPosition,
  3634. locMaxLen : Integer;
  3635. locStatement : TReorderSequence;
  3636. locNextPos,
  3637. locLineCount : Integer;
  3638. begin
  3639. locText := AText;
  3640. WriteLn('Parsing "',locText,'" ...');
  3641. locTextPointer := @locText[1];
  3642. locMaxLen := Length(locText);
  3643. locStartPosition := 0;
  3644. locNextPos := 0;
  3645. locLineCount := 0;
  3646. locStatement.Clear();
  3647. Check(
  3648. ParseStatement(
  3649. locTextPointer,locStartPosition,locMaxLen,@locStatement,locNextPos,locLineCount
  3650. ),
  3651. 'Fail to Parse : "%s".', [locText]
  3652. );
  3653. if (locLineCount > 1) then
  3654. WriteLn;
  3655. WriteLn(' Next Position : ',locNextPos);
  3656. WriteLn(' Line Count : ',locLineCount);
  3657. if (CountLines(locText) = 1) then
  3658. Check((locNextPos>=locMaxLen),'Next Position');
  3659. if (ALineCount > 0) then
  3660. Check((locLineCount=ALineCount),'Line Count');
  3661. CheckEqual(locStatement,AExpected);
  3662. WriteLn(' -- test ok');
  3663. end;
  3664. procedure do_test_parser(AText : ansistring; const AExpected : TReorderSequence);inline;overload;
  3665. begin
  3666. do_test_parser(AText,AExpected,1);
  3667. end;
  3668. procedure test_parser_1();
  3669. var
  3670. locStatement : TReorderSequence;
  3671. begin
  3672. locStatement.Clear();
  3673. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3674. locStatement.SetElementCount(1);
  3675. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Identity,0);
  3676. do_test_parser('& [last tertiary ignorable] = a',locStatement);
  3677. end;
  3678. procedure test_parser_2();
  3679. var
  3680. locStatement : TReorderSequence;
  3681. begin
  3682. locStatement.Clear();
  3683. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3684. locStatement.SetElementCount(1);
  3685. locStatement.Elements[0] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  3686. do_test_parser('& [last tertiary ignorable] < b',locStatement);
  3687. end;
  3688. procedure test_parser_3();
  3689. var
  3690. locStatement : TReorderSequence;
  3691. begin
  3692. locStatement.Clear();
  3693. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3694. locStatement.SetElementCount(1);
  3695. locStatement.Elements[0] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Secondary,0);
  3696. do_test_parser('& [last tertiary ignorable] << c',locStatement);
  3697. end;
  3698. procedure test_parser_4();
  3699. var
  3700. locStatement : TReorderSequence;
  3701. begin
  3702. locStatement.Clear();
  3703. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3704. locStatement.SetElementCount(1);
  3705. locStatement.Elements[0] := TReorderUnit.From(Ord('d'),TReorderWeigthKind.Tertiary,0);
  3706. do_test_parser('& [last tertiary ignorable] <<< d',locStatement);
  3707. end;
  3708. procedure test_parser_5();
  3709. var
  3710. locStatement : TReorderSequence;
  3711. begin
  3712. locStatement.Clear();
  3713. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3714. locStatement.SetElementCount(1);
  3715. locStatement.Elements[0] := TReorderUnit.From(1,TReorderWeigthKind.Primary,0);
  3716. do_test_parser('& [last tertiary ignorable] < ''\u0001''',locStatement);
  3717. end;
  3718. procedure test_parser_6();
  3719. var
  3720. locStatement : TReorderSequence;
  3721. begin
  3722. locStatement.Clear();
  3723. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3724. locStatement.SetElementCount(1);
  3725. locStatement.Elements[0] := TReorderUnit.From(7,TReorderWeigthKind.Secondary,0);
  3726. do_test_parser('& [last tertiary ignorable] << ''\u0007''',locStatement);
  3727. end;
  3728. procedure test_parser_7();
  3729. var
  3730. locStatement : TReorderSequence;
  3731. begin
  3732. locStatement.Clear();
  3733. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3734. locStatement.SetElementCount(1);
  3735. locStatement.Elements[0] := TReorderUnit.From(9,TReorderWeigthKind.Secondary,0);
  3736. do_test_parser('& [last tertiary ignorable] << ''\u0009''',locStatement);
  3737. end;
  3738. procedure test_parser_8();
  3739. var
  3740. locStatement : TReorderSequence;
  3741. begin
  3742. locStatement.Clear();
  3743. locStatement.LogicalPosition := TReorderLogicalReset.LastTertiaryIgnorable;
  3744. locStatement.SetElementCount(1);
  3745. locStatement.Elements[0] := TReorderUnit.From($000110BD,TReorderWeigthKind.Primary,0);
  3746. do_test_parser('& [last tertiary ignorable] < ''\U000110BD''',locStatement);
  3747. end;
  3748. procedure test_parser_9();
  3749. var
  3750. locStatement : TReorderSequence;
  3751. begin
  3752. locStatement.Clear();
  3753. SetLength(locStatement.Reset,1);
  3754. locStatement.Reset[0] := Ord('x');
  3755. locStatement.SetElementCount(1);
  3756. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  3757. do_test_parser('&x < a',locStatement);
  3758. end;
  3759. procedure test_parser_abreviating_1();
  3760. var
  3761. locStatement : TReorderSequence;
  3762. begin
  3763. locStatement.Clear();
  3764. SetLength(locStatement.Reset,1);
  3765. locStatement.Reset[0] := Ord('x');
  3766. locStatement.SetElementCount(3);
  3767. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  3768. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  3769. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  3770. do_test_parser('&x <* abc',locStatement);
  3771. end;
  3772. procedure test_parser_abreviating_2();
  3773. var
  3774. locStatement : TReorderSequence;
  3775. begin
  3776. locStatement.Clear();
  3777. SetLength(locStatement.Reset,1);
  3778. locStatement.Reset[0] := Ord('x');
  3779. locStatement.SetElementCount(7);
  3780. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  3781. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  3782. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  3783. locStatement.Elements[3] := TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,0);
  3784. locStatement.Elements[4] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,0);
  3785. locStatement.Elements[5] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,0);
  3786. locStatement.Elements[6] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  3787. do_test_parser('&x <* abcd-g',locStatement);
  3788. end;
  3789. procedure test_parser_abreviating_3();
  3790. var
  3791. locStatement : TReorderSequence;
  3792. begin
  3793. locStatement.Clear();
  3794. SetLength(locStatement.Reset,1);
  3795. locStatement.Reset[0] := Ord('x');
  3796. locStatement.SetElementCount(8);
  3797. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  3798. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  3799. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  3800. locStatement.Elements[3] := TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,0);
  3801. locStatement.Elements[4] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,0);
  3802. locStatement.Elements[5] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,0);
  3803. locStatement.Elements[6] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  3804. locStatement.Elements[7] := TReorderUnit.From(Ord('p'),TReorderWeigthKind.Primary,0);
  3805. do_test_parser('&x <* abcd-gp',locStatement);
  3806. end;
  3807. procedure test_parser_abreviating_4();
  3808. var
  3809. locStatement : TReorderSequence;
  3810. begin
  3811. locStatement.Clear();
  3812. SetLength(locStatement.Reset,1);
  3813. locStatement.Reset[0] := Ord('x');
  3814. locStatement.SetElementCount(11);
  3815. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  3816. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  3817. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  3818. locStatement.Elements[3] := TReorderUnit.From(Ord('d'),TReorderWeigthKind.Primary,0);
  3819. locStatement.Elements[4] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Primary,0);
  3820. locStatement.Elements[5] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Primary,0);
  3821. locStatement.Elements[6] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Primary,0);
  3822. locStatement.Elements[7] := TReorderUnit.From(Ord('p'),TReorderWeigthKind.Primary,0);
  3823. locStatement.Elements[8] := TReorderUnit.From(Ord('q'),TReorderWeigthKind.Primary,0);
  3824. locStatement.Elements[9] := TReorderUnit.From(Ord('r'),TReorderWeigthKind.Primary,0);
  3825. locStatement.Elements[10] := TReorderUnit.From(Ord('s'),TReorderWeigthKind.Primary,0);
  3826. do_test_parser('&x <* abcd-gp-s',locStatement);
  3827. end;
  3828. procedure test_parser_abreviating_5();
  3829. var
  3830. locStatement : TReorderSequence;
  3831. begin
  3832. locStatement.Clear();
  3833. SetLength(locStatement.Reset,1);
  3834. locStatement.Reset[0] := Ord('x');
  3835. locStatement.SetElementCount(3);
  3836. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Secondary,0);
  3837. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Secondary,0);
  3838. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Secondary,0);
  3839. do_test_parser('&x <<* abc',locStatement);
  3840. end;
  3841. procedure test_parser_abreviating_6();
  3842. var
  3843. locStatement : TReorderSequence;
  3844. begin
  3845. locStatement.Clear();
  3846. SetLength(locStatement.Reset,1);
  3847. locStatement.Reset[0] := Ord('x');
  3848. locStatement.SetElementCount(11);
  3849. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Secondary,0);
  3850. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Secondary,0);
  3851. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Secondary,0);
  3852. locStatement.Elements[3] := TReorderUnit.From(Ord('d'),TReorderWeigthKind.Secondary,0);
  3853. locStatement.Elements[4] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Secondary,0);
  3854. locStatement.Elements[5] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Secondary,0);
  3855. locStatement.Elements[6] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Secondary,0);
  3856. locStatement.Elements[7] := TReorderUnit.From(Ord('p'),TReorderWeigthKind.Secondary,0);
  3857. locStatement.Elements[8] := TReorderUnit.From(Ord('q'),TReorderWeigthKind.Secondary,0);
  3858. locStatement.Elements[9] := TReorderUnit.From(Ord('r'),TReorderWeigthKind.Secondary,0);
  3859. locStatement.Elements[10] := TReorderUnit.From(Ord('s'),TReorderWeigthKind.Secondary,0);
  3860. do_test_parser('&x <<* abcd-gp-s',locStatement);
  3861. end;
  3862. procedure test_parser_abreviating_7();
  3863. var
  3864. locStatement : TReorderSequence;
  3865. begin
  3866. locStatement.Clear();
  3867. SetLength(locStatement.Reset,1);
  3868. locStatement.Reset[0] := Ord('x');
  3869. locStatement.SetElementCount(3);
  3870. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Tertiary,0);
  3871. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Tertiary,0);
  3872. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Tertiary,0);
  3873. do_test_parser('&x <<<* abc',locStatement);
  3874. end;
  3875. procedure test_parser_abreviating_8();
  3876. var
  3877. locStatement : TReorderSequence;
  3878. begin
  3879. locStatement.Clear();
  3880. SetLength(locStatement.Reset,1);
  3881. locStatement.Reset[0] := Ord('x');
  3882. locStatement.SetElementCount(11);
  3883. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Tertiary,0);
  3884. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Tertiary,0);
  3885. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Tertiary,0);
  3886. locStatement.Elements[3] := TReorderUnit.From(Ord('d'),TReorderWeigthKind.Tertiary,0);
  3887. locStatement.Elements[4] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Tertiary,0);
  3888. locStatement.Elements[5] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Tertiary,0);
  3889. locStatement.Elements[6] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Tertiary,0);
  3890. locStatement.Elements[7] := TReorderUnit.From(Ord('p'),TReorderWeigthKind.Tertiary,0);
  3891. locStatement.Elements[8] := TReorderUnit.From(Ord('q'),TReorderWeigthKind.Tertiary,0);
  3892. locStatement.Elements[9] := TReorderUnit.From(Ord('r'),TReorderWeigthKind.Tertiary,0);
  3893. locStatement.Elements[10] := TReorderUnit.From(Ord('s'),TReorderWeigthKind.Tertiary,0);
  3894. do_test_parser('&x <<<* abcd-gp-s',locStatement);
  3895. end;
  3896. procedure test_parser_abreviating_9();
  3897. var
  3898. locStatement : TReorderSequence;
  3899. begin
  3900. locStatement.Clear();
  3901. SetLength(locStatement.Reset,1);
  3902. locStatement.Reset[0] := Ord('x');
  3903. locStatement.SetElementCount(3);
  3904. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Identity,0);
  3905. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Identity,0);
  3906. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Identity,0);
  3907. do_test_parser('&x =* abc',locStatement);
  3908. end;
  3909. procedure test_parser_abreviating_10();
  3910. var
  3911. locStatement : TReorderSequence;
  3912. begin
  3913. locStatement.Clear();
  3914. SetLength(locStatement.Reset,1);
  3915. locStatement.Reset[0] := Ord('x');
  3916. locStatement.SetElementCount(11);
  3917. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Identity,0);
  3918. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Identity,0);
  3919. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Identity,0);
  3920. locStatement.Elements[3] := TReorderUnit.From(Ord('d'),TReorderWeigthKind.Identity,0);
  3921. locStatement.Elements[4] := TReorderUnit.From(Ord('e'),TReorderWeigthKind.Identity,0);
  3922. locStatement.Elements[5] := TReorderUnit.From(Ord('f'),TReorderWeigthKind.Identity,0);
  3923. locStatement.Elements[6] := TReorderUnit.From(Ord('g'),TReorderWeigthKind.Identity,0);
  3924. locStatement.Elements[7] := TReorderUnit.From(Ord('p'),TReorderWeigthKind.Identity,0);
  3925. locStatement.Elements[8] := TReorderUnit.From(Ord('q'),TReorderWeigthKind.Identity,0);
  3926. locStatement.Elements[9] := TReorderUnit.From(Ord('r'),TReorderWeigthKind.Identity,0);
  3927. locStatement.Elements[10] := TReorderUnit.From(Ord('s'),TReorderWeigthKind.Identity,0);
  3928. do_test_parser('&x =* abcd-gp-s',locStatement);
  3929. end;
  3930. procedure test_parser_contraction_1();
  3931. var
  3932. locStatement : TReorderSequence;
  3933. begin
  3934. locStatement.Clear();
  3935. SetLength(locStatement.Reset,1);
  3936. locStatement.Reset[0] := Ord('k');
  3937. locStatement.SetElementCount(1);
  3938. locStatement.Elements[0] := TReorderUnit.From([Ord('c'),Ord('h')],TReorderWeigthKind.Primary,0);
  3939. do_test_parser('&k < ch',locStatement);
  3940. end;
  3941. procedure test_parser_contraction_2();
  3942. var
  3943. locStatement : TReorderSequence;
  3944. begin
  3945. locStatement.Clear();
  3946. SetLength(locStatement.Reset,3);
  3947. locStatement.Reset[0] := Ord('a');
  3948. locStatement.Reset[1] := Ord('b');
  3949. locStatement.Reset[2] := Ord('c');
  3950. locStatement.SetElementCount(1);
  3951. locStatement.Elements[0] := TReorderUnit.From([Ord('c'),Ord('h')],TReorderWeigthKind.Primary,0);
  3952. do_test_parser('&abc < ch',locStatement);
  3953. end;
  3954. procedure test_parser_expansion_1();
  3955. var
  3956. locStatement : TReorderSequence;
  3957. begin
  3958. locStatement.Clear();
  3959. SetLength(locStatement.Reset,1);
  3960. locStatement.Reset[0] := Ord('a');
  3961. locStatement.SetElementCount(1);
  3962. locStatement.Elements[0] := TReorderUnit.From(Ord('z'),TReorderWeigthKind.Primary,0);
  3963. locStatement.Elements[0].ExpansionChars := CodePointToArray(Ord('e'));
  3964. do_test_parser('&a < z/e',locStatement);
  3965. end;
  3966. procedure test_parser_special_char_1();
  3967. var
  3968. locStatement : TReorderSequence;
  3969. begin
  3970. locStatement.Clear();
  3971. SetLength(locStatement.Reset,1);
  3972. locStatement.Reset[0] := Ord('x');
  3973. locStatement.SetElementCount(1);
  3974. locStatement.Elements[0] := TReorderUnit.From(Ord('/'),TReorderWeigthKind.Primary,0);
  3975. do_test_parser('&x < ''/''',locStatement);
  3976. end;
  3977. procedure test_parser_special_char_2();
  3978. var
  3979. locStatement : TReorderSequence;
  3980. begin
  3981. locStatement.Clear();
  3982. SetLength(locStatement.Reset,1);
  3983. locStatement.Reset[0] := Ord('x');
  3984. locStatement.SetElementCount(1);
  3985. locStatement.Elements[0] := TReorderUnit.From(Ord('&'),TReorderWeigthKind.Primary,0);
  3986. do_test_parser('&x < ''&''',locStatement);
  3987. end;
  3988. procedure test_parser_special_char_3();
  3989. var
  3990. locStatement : TReorderSequence;
  3991. begin
  3992. locStatement.Clear();
  3993. SetLength(locStatement.Reset,1);
  3994. locStatement.Reset[0] := Ord('x');
  3995. locStatement.SetElementCount(1);
  3996. locStatement.Elements[0] := TReorderUnit.From(Ord('<'),TReorderWeigthKind.Primary,0);
  3997. do_test_parser('&x < ''<''',locStatement);
  3998. end;
  3999. procedure test_parser_special_char_4();
  4000. var
  4001. locStatement : TReorderSequence;
  4002. begin
  4003. locStatement.Clear();
  4004. SetLength(locStatement.Reset,1);
  4005. locStatement.Reset[0] := Ord('x');
  4006. locStatement.SetElementCount(1);
  4007. locStatement.Elements[0] := TReorderUnit.From(Ord('|'),TReorderWeigthKind.Primary,0);
  4008. do_test_parser('&x < ''|''',locStatement);
  4009. end;
  4010. procedure test_parser_special_char_5();
  4011. var
  4012. locStatement : TReorderSequence;
  4013. begin
  4014. locStatement.Clear();
  4015. SetLength(locStatement.Reset,1);
  4016. locStatement.Reset[0] := Ord('x');
  4017. locStatement.SetElementCount(1);
  4018. locStatement.Elements[0] := TReorderUnit.From(Ord('*'),TReorderWeigthKind.Primary,0);
  4019. do_test_parser('&x < ''*''',locStatement);
  4020. end;
  4021. procedure test_parser_special_char_6();
  4022. var
  4023. locStatement : TReorderSequence;
  4024. begin
  4025. locStatement.Clear();
  4026. SetLength(locStatement.Reset,1);
  4027. locStatement.Reset[0] := Ord('x');
  4028. locStatement.SetElementCount(1);
  4029. locStatement.Elements[0] := TReorderUnit.From(Ord('['),TReorderWeigthKind.Primary,0);
  4030. do_test_parser('&x < ''[''',locStatement);
  4031. end;
  4032. procedure test_parser_special_char_7();
  4033. var
  4034. locStatement : TReorderSequence;
  4035. begin
  4036. locStatement.Clear();
  4037. SetLength(locStatement.Reset,1);
  4038. locStatement.Reset[0] := Ord('x');
  4039. locStatement.SetElementCount(1);
  4040. locStatement.Elements[0] := TReorderUnit.From(Ord(']'),TReorderWeigthKind.Primary,0);
  4041. do_test_parser('&x < '']''',locStatement);
  4042. end;
  4043. procedure test_parser_skip_comment_1();
  4044. var
  4045. locStatement : TReorderSequence;
  4046. begin
  4047. locStatement.Clear();
  4048. SetLength(locStatement.Reset,1);
  4049. locStatement.Reset[0] := Ord('x');
  4050. locStatement.SetElementCount(1);
  4051. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4052. do_test_parser(
  4053. '&x #' + sLineBreak +
  4054. ' < a',
  4055. locStatement, 2
  4056. );
  4057. end;
  4058. procedure test_parser_skip_comment_2();
  4059. var
  4060. locStatement : TReorderSequence;
  4061. begin
  4062. locStatement.Clear();
  4063. SetLength(locStatement.Reset,1);
  4064. locStatement.Reset[0] := Ord('x');
  4065. locStatement.SetElementCount(1);
  4066. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4067. do_test_parser(
  4068. '&x # hello' + sLineBreak +
  4069. ' < a',
  4070. locStatement, 2
  4071. );
  4072. end;
  4073. procedure test_parser_skip_comment_3();
  4074. var
  4075. locStatement : TReorderSequence;
  4076. begin
  4077. locStatement.Clear();
  4078. SetLength(locStatement.Reset,1);
  4079. locStatement.Reset[0] := Ord('x');
  4080. locStatement.SetElementCount(1);
  4081. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4082. do_test_parser(
  4083. '&x # hello' + sLineBreak +
  4084. sLineBreak +
  4085. #9#9' ' + sLineBreak +
  4086. ' < a',
  4087. locStatement, 4
  4088. );
  4089. end;
  4090. procedure test_parser_quoted_string_1();
  4091. var
  4092. locStatement : TReorderSequence;
  4093. begin
  4094. locStatement.Clear();
  4095. SetLength(locStatement.Reset,1);
  4096. locStatement.Reset[0] := Ord('x');
  4097. locStatement.SetElementCount(1);
  4098. locStatement.Elements[0] :=
  4099. TReorderUnit.From(
  4100. [Ord('<'),Ord('#'),Ord('|'),Ord('/'),Ord('!')],
  4101. TReorderWeigthKind.Primary,0
  4102. );
  4103. do_test_parser('&x < ''<#|/!''',locStatement);
  4104. end;
  4105. procedure test_parser_quoted_string_2();
  4106. var
  4107. locStatement : TReorderSequence;
  4108. begin
  4109. locStatement.Clear();
  4110. SetLength(locStatement.Reset,1);
  4111. locStatement.Reset[0] := Ord('x');
  4112. locStatement.SetElementCount(1);
  4113. locStatement.Elements[0] :=
  4114. TReorderUnit.From(
  4115. [Ord('<'),Ord('#'),Ord('|'),Ord('/'),Ord('!'),Ord('A')],
  4116. TReorderWeigthKind.Primary,0
  4117. );
  4118. do_test_parser('&x < ''<#|/!''A',locStatement);
  4119. end;
  4120. procedure test_parser_quoted_string_3();
  4121. var
  4122. locStatement : TReorderSequence;
  4123. begin
  4124. locStatement.Clear();
  4125. SetLength(locStatement.Reset,1);
  4126. locStatement.Reset[0] := Ord('x');
  4127. locStatement.SetElementCount(1);
  4128. locStatement.Elements[0] :=
  4129. TReorderUnit.From(
  4130. [Ord('<'),Ord('#'),Ord('|'),Ord('/'),Ord('!')],
  4131. TReorderWeigthKind.Primary,0
  4132. );
  4133. do_test_parser('&x < ''<#|/!''#',locStatement);
  4134. end;
  4135. procedure test_parser_quoted_string_4();
  4136. var
  4137. locStatement : TReorderSequence;
  4138. begin
  4139. locStatement.Clear();
  4140. SetLength(locStatement.Reset,1);
  4141. locStatement.Reset[0] := Ord('x');
  4142. locStatement.SetElementCount(1);
  4143. locStatement.Elements[0] :=
  4144. TReorderUnit.From(
  4145. [Ord('<'),Ord('#'),Ord('|'),Ord('/'),Ord('!'),Ord('A')],
  4146. TReorderWeigthKind.Primary,0
  4147. );
  4148. do_test_parser('&x < ''<#|/!''A#',locStatement);
  4149. end;
  4150. procedure test_parser_quoted_string_5();
  4151. var
  4152. locStatement : TReorderSequence;
  4153. begin
  4154. locStatement.Clear();
  4155. SetLength(locStatement.Reset,3);
  4156. locStatement.Reset[0] := Ord('x');
  4157. locStatement.Reset[1] := Ord('-');
  4158. locStatement.Reset[2] := Ord('y');
  4159. locStatement.SetElementCount(1);
  4160. locStatement.Elements[0] :=
  4161. TReorderUnit.From(Ord('k'),TReorderWeigthKind.Tertiary,0);
  4162. do_test_parser('&''x''-''y''<<<k',locStatement);
  4163. end;
  4164. procedure test_parser_quoted_string_6();
  4165. var
  4166. locStatement : TReorderSequence;
  4167. begin
  4168. locStatement.Clear();
  4169. SetLength(locStatement.Reset,1);
  4170. locStatement.Reset[0] := Ord('x');
  4171. locStatement.SetElementCount(1);
  4172. locStatement.Elements[0] :=
  4173. TReorderUnit.From(Ord('|'),TReorderWeigthKind.Primary,0);
  4174. do_test_parser('&x < ''|''',locStatement);
  4175. end;
  4176. procedure test_parser_quoted_string_7();
  4177. var
  4178. locStatement : TReorderSequence;
  4179. begin
  4180. locStatement.Clear();
  4181. SetLength(locStatement.Reset,1);
  4182. locStatement.Reset[0] := Ord('x');
  4183. locStatement.SetElementCount(1);
  4184. locStatement.Elements[0] :=
  4185. TReorderUnit.From([Ord('a'),Ord('|')],TReorderWeigthKind.Primary,0);
  4186. do_test_parser('&x < a''|''',locStatement);
  4187. end;
  4188. procedure test_parser_quoted_string_8();
  4189. var
  4190. locStatement : TReorderSequence;
  4191. begin
  4192. locStatement.Clear();
  4193. SetLength(locStatement.Reset,1);
  4194. locStatement.Reset[0] := Ord('x');
  4195. locStatement.SetElementCount(1);
  4196. locStatement.Elements[0] :=
  4197. TReorderUnit.From([Ord('a'),Ord('|'),Ord('c')],TReorderWeigthKind.Primary,0);
  4198. do_test_parser('&x < a''|''c',locStatement);
  4199. end;
  4200. procedure test_parser_contexte_before_1();
  4201. var
  4202. locStatement : TReorderSequence;
  4203. begin
  4204. locStatement.Clear();
  4205. SetLength(locStatement.Reset,1);
  4206. locStatement.Reset[0] := Ord('x');
  4207. locStatement.SetElementCount(1);
  4208. locStatement.Elements[0] :=
  4209. TReorderUnit.From(Ord('-'),[Ord('a')],TReorderWeigthKind.Secondary,0);
  4210. do_test_parser('&x << a|-',locStatement);
  4211. end;
  4212. procedure test_parser_contexte_before_2();
  4213. var
  4214. locStatement : TReorderSequence;
  4215. begin
  4216. locStatement.Clear();
  4217. SetLength(locStatement.Reset,1);
  4218. locStatement.Reset[0] := Ord('a');
  4219. locStatement.SetElementCount(1);
  4220. locStatement.Elements[0] :=
  4221. TReorderUnit.From(Ord('-'),[Ord('a')],TReorderWeigthKind.Tertiary,0);
  4222. do_test_parser('&a <<< a|-',locStatement);
  4223. end;
  4224. procedure test_parser_contexte_before_3();
  4225. var
  4226. locStatement : TReorderSequence;
  4227. begin
  4228. locStatement.Clear();
  4229. SetLength(locStatement.Reset,1);
  4230. locStatement.Reset[0] := Ord('x');
  4231. locStatement.SetElementCount(1);
  4232. locStatement.Elements[0] :=
  4233. TReorderUnit.From(
  4234. Ord('-'),[Ord('a'),Ord('z'),Ord('k')],TReorderWeigthKind.Secondary,0
  4235. );
  4236. do_test_parser('&x << azk|-',locStatement);
  4237. end;
  4238. procedure test_parser_contexte_before_4();
  4239. var
  4240. locStatement : TReorderSequence;
  4241. begin
  4242. locStatement.Clear();
  4243. SetLength(locStatement.Reset,1);
  4244. locStatement.Reset[0] := Ord('x');
  4245. locStatement.SetElementCount(1);
  4246. locStatement.Elements[0] :=
  4247. TReorderUnit.From(
  4248. [Ord('a'),Ord(':')],[Ord('a'),Ord('z'),Ord('k')],
  4249. TReorderWeigthKind.Secondary,0
  4250. );
  4251. do_test_parser('&x << azk|a:',locStatement);
  4252. end;
  4253. procedure test_parser_placement_before_1();
  4254. var
  4255. locStatement : TReorderSequence;
  4256. begin
  4257. locStatement.Clear();
  4258. SetLength(locStatement.Reset,1);
  4259. locStatement.Reset[0] := Ord('x');
  4260. locStatement.Before := True;
  4261. locStatement.SetElementCount(1);
  4262. locStatement.Elements[0] := TReorderUnit.From(Ord('k'),TReorderWeigthKind.Secondary,0);
  4263. do_test_parser('&[before 2] x << k',locStatement);
  4264. end;
  4265. procedure test_parser_placement_before_2();
  4266. var
  4267. locStatement : TReorderSequence;
  4268. begin
  4269. locStatement.Clear();
  4270. SetLength(locStatement.Reset,1);
  4271. locStatement.Reset[0] := Ord('x');
  4272. locStatement.Before := True;
  4273. locStatement.SetElementCount(1);
  4274. locStatement.Elements[0] :=
  4275. TReorderUnit.From([Ord('z'),Ord('k')],TReorderWeigthKind.Tertiary,0);
  4276. do_test_parser('&[before 3] x <<< zk',locStatement);
  4277. end;
  4278. procedure test_parser_placement_before_3();
  4279. var
  4280. locStatement : TReorderSequence;
  4281. begin
  4282. locStatement.Clear();
  4283. SetLength(locStatement.Reset,1);
  4284. locStatement.Reset[0] := Ord('x');
  4285. locStatement.Before := True;
  4286. locStatement.SetElementCount(1);
  4287. locStatement.Elements[0] := TReorderUnit.From(Ord('z'),TReorderWeigthKind.Primary,0);
  4288. do_test_parser('&[before 1] x < z',locStatement);
  4289. end;
  4290. procedure test_parser_multi_unit_statement_line_1();
  4291. var
  4292. locStatement : TReorderSequence;
  4293. begin
  4294. locStatement.Clear();
  4295. SetLength(locStatement.Reset,1);
  4296. locStatement.Reset[0] := Ord('x');
  4297. locStatement.SetElementCount(3);
  4298. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4299. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  4300. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  4301. do_test_parser('&x < a < b < c',locStatement);
  4302. do_test_parser('&x <a <b <c',locStatement);
  4303. do_test_parser('&x <a<b<c',locStatement);
  4304. end;
  4305. procedure test_parser_multi_unit_statement_line_2();
  4306. var
  4307. locStatement : TReorderSequence;
  4308. begin
  4309. locStatement.Clear();
  4310. SetLength(locStatement.Reset,1);
  4311. locStatement.Reset[0] := Ord('x');
  4312. locStatement.SetElementCount(3);
  4313. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4314. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Secondary,0);
  4315. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Tertiary,0);
  4316. do_test_parser('&x < a << b <<< c',locStatement);
  4317. do_test_parser('&x <a <<b <<<c',locStatement);
  4318. do_test_parser('&x <a<<b<<<c',locStatement);
  4319. end;
  4320. procedure test_parser_multi_unit_statement_line_3();
  4321. var
  4322. locStatement : TReorderSequence;
  4323. begin
  4324. locStatement.Clear();
  4325. SetLength(locStatement.Reset,1);
  4326. locStatement.Reset[0] := Ord('x');
  4327. locStatement.SetElementCount(3);
  4328. locStatement.Elements[0] := TReorderUnit.From(Ord('a'),TReorderWeigthKind.Tertiary,0);
  4329. locStatement.Elements[1] := TReorderUnit.From(Ord('b'),TReorderWeigthKind.Secondary,0);
  4330. locStatement.Elements[2] := TReorderUnit.From(Ord('c'),TReorderWeigthKind.Tertiary,0);
  4331. do_test_parser('&x <<< a << b <<< c',locStatement);
  4332. do_test_parser('&x <<<a <<b <<<c',locStatement);
  4333. do_test_parser('&x <<<a<<b<<<c',locStatement);
  4334. end;
  4335. procedure test_parser_multi_statement_line_1();
  4336. const STATEMENT_BUFFER : UTF8String = '&r <<a &s <<< b';
  4337. var
  4338. locStatements : array of TReorderSequence;
  4339. locStatement : PReorderSequence;
  4340. locExpectedStatement : TReorderSequence;
  4341. lineCount, i, bufferLength, k, nextPost : Integer;
  4342. buffer : PAnsiChar;
  4343. begin
  4344. buffer := @STATEMENT_BUFFER[1];
  4345. WriteLn('Parsing "',buffer,'" ...');
  4346. bufferLength := Length(buffer);
  4347. SetLength(locStatements,10);
  4348. lineCount := 0;
  4349. nextPost := 0;
  4350. i := 0;
  4351. k := 0;
  4352. while (i < bufferLength) do begin
  4353. locStatement := @locStatements[k];
  4354. locStatement^.Clear();
  4355. if not ParseStatement(buffer,i,bufferLength,locStatement,nextPost,lineCount) then
  4356. Break;
  4357. i := nextPost;
  4358. k := k+1;
  4359. if (k > 2) then
  4360. raise Exception.Create('2 Statements expected, more was parsed.');
  4361. end;
  4362. Check((k=2), 'Statement Count');
  4363. locExpectedStatement.Clear();
  4364. SetLength(locExpectedStatement.Reset,1);
  4365. locExpectedStatement.Reset[0] := Ord('r');
  4366. locExpectedStatement.SetElementCount(1);
  4367. locExpectedStatement.Elements[0] :=
  4368. TReorderUnit.From(Ord('a'),TReorderWeigthKind.Secondary,0);
  4369. CheckEqual(locStatements[0],locExpectedStatement);
  4370. locExpectedStatement.Clear();
  4371. SetLength(locExpectedStatement.Reset,1);
  4372. locExpectedStatement.Reset[0] := Ord('s');
  4373. locExpectedStatement.SetElementCount(1);
  4374. locExpectedStatement.Elements[0] :=
  4375. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Tertiary,0);
  4376. CheckEqual(locStatements[1],locExpectedStatement);
  4377. WriteLn(' -- test ok');
  4378. end;
  4379. procedure test_parser_multi_statement_line_2();
  4380. const STATEMENT_BUFFER : UTF8String = '&r <a <b <<B &s <<< b <c';
  4381. var
  4382. locStatements : array of TReorderSequence;
  4383. locStatement : PReorderSequence;
  4384. locExpectedStatement : TReorderSequence;
  4385. lineCount, i, bufferLength, k, nextPost : Integer;
  4386. buffer : PAnsiChar;
  4387. begin
  4388. buffer := @STATEMENT_BUFFER[1];
  4389. WriteLn('Parsing "',buffer,'" ...');
  4390. bufferLength := Length(buffer);
  4391. SetLength(locStatements,10);
  4392. lineCount := 0;
  4393. nextPost := 0;
  4394. i := 0;
  4395. k := 0;
  4396. while (i < bufferLength) do begin
  4397. locStatement := @locStatements[k];
  4398. locStatement^.Clear();
  4399. if not ParseStatement(buffer,i,bufferLength,locStatement,nextPost,lineCount) then
  4400. Break;
  4401. i := nextPost;
  4402. k := k+1;
  4403. if (k > 2) then
  4404. raise Exception.Create('2 Statements expected, more was parsed.');
  4405. end;
  4406. Check((k=2), 'Statement Count');
  4407. locExpectedStatement.Clear();
  4408. SetLength(locExpectedStatement.Reset,1);
  4409. locExpectedStatement.Reset[0] := Ord('r');
  4410. locExpectedStatement.SetElementCount(3);
  4411. locExpectedStatement.Elements[0] :=
  4412. TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4413. locExpectedStatement.Elements[1] :=
  4414. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  4415. locExpectedStatement.Elements[2] :=
  4416. TReorderUnit.From(Ord('B'),TReorderWeigthKind.Secondary,0);
  4417. CheckEqual(locStatements[0],locExpectedStatement);
  4418. locExpectedStatement.Clear();
  4419. SetLength(locExpectedStatement.Reset,1);
  4420. locExpectedStatement.Reset[0] := Ord('s');
  4421. locExpectedStatement.SetElementCount(2);
  4422. locExpectedStatement.Elements[0] :=
  4423. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Tertiary,0);
  4424. locExpectedStatement.Elements[1] :=
  4425. TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  4426. CheckEqual(locStatements[1],locExpectedStatement);
  4427. WriteLn(' -- test ok');
  4428. end;
  4429. procedure test_parser_multi_statement_line_3();
  4430. const STATEMENT_BUFFER : UTF8String = '&r <a <b <<B &s <<< b <c &x <A <W';
  4431. var
  4432. locStatements : array of TReorderSequence;
  4433. locStatement : PReorderSequence;
  4434. locExpectedStatement : TReorderSequence;
  4435. lineCount, i, bufferLength, k, nextPost : Integer;
  4436. buffer : PAnsiChar;
  4437. begin
  4438. buffer := @STATEMENT_BUFFER[1];
  4439. WriteLn('Parsing "',buffer,'" ...');
  4440. bufferLength := Length(buffer);
  4441. SetLength(locStatements,10);
  4442. lineCount := 0;
  4443. nextPost := 0;
  4444. i := 0;
  4445. k := 0;
  4446. while (i < bufferLength) do begin
  4447. locStatement := @locStatements[k];
  4448. locStatement^.Clear();
  4449. if not ParseStatement(buffer,i,bufferLength,locStatement,nextPost,lineCount) then
  4450. Break;
  4451. i := nextPost;
  4452. k := k+1;
  4453. if (k > 3) then
  4454. raise Exception.Create('3 Statements expected, more was parsed.');
  4455. end;
  4456. Check((k=3), 'Statement Count');
  4457. locExpectedStatement.Clear();
  4458. SetLength(locExpectedStatement.Reset,1);
  4459. locExpectedStatement.Reset[0] := Ord('r');
  4460. locExpectedStatement.SetElementCount(3);
  4461. locExpectedStatement.Elements[0] :=
  4462. TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4463. locExpectedStatement.Elements[1] :=
  4464. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  4465. locExpectedStatement.Elements[2] :=
  4466. TReorderUnit.From(Ord('B'),TReorderWeigthKind.Secondary,0);
  4467. CheckEqual(locStatements[0],locExpectedStatement);
  4468. locExpectedStatement.Clear();
  4469. SetLength(locExpectedStatement.Reset,1);
  4470. locExpectedStatement.Reset[0] := Ord('s');
  4471. locExpectedStatement.SetElementCount(2);
  4472. locExpectedStatement.Elements[0] :=
  4473. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Tertiary,0);
  4474. locExpectedStatement.Elements[1] :=
  4475. TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  4476. CheckEqual(locStatements[1],locExpectedStatement);
  4477. locExpectedStatement.Clear();
  4478. SetLength(locExpectedStatement.Reset,1);
  4479. locExpectedStatement.Reset[0] := Ord('x');
  4480. locExpectedStatement.SetElementCount(2);
  4481. locExpectedStatement.Elements[0] :=
  4482. TReorderUnit.From(Ord('A'),TReorderWeigthKind.Primary,0);
  4483. locExpectedStatement.Elements[1] :=
  4484. TReorderUnit.From(Ord('W'),TReorderWeigthKind.Primary,0);
  4485. CheckEqual(locStatements[2],locExpectedStatement);
  4486. WriteLn(' -- test ok');
  4487. end;
  4488. procedure test_parser_multi_statement_line_4();
  4489. const STATEMENT_BUFFER : UTF8String =
  4490. ' &r <a <b <<B &s <<< b <c &x <A <W';
  4491. var
  4492. locStatements : array of TReorderSequence;
  4493. locStatement : PReorderSequence;
  4494. locExpectedStatement : TReorderSequence;
  4495. lineCount, i, bufferLength, k, nextPost : Integer;
  4496. buffer : PAnsiChar;
  4497. begin
  4498. buffer := @STATEMENT_BUFFER[1];
  4499. WriteLn('Parsing "',buffer,'" ...');
  4500. bufferLength := Length(buffer);
  4501. SetLength(locStatements,10);
  4502. lineCount := 0;
  4503. nextPost := 0;
  4504. i := 0;
  4505. k := 0;
  4506. while (i < bufferLength) do begin
  4507. locStatement := @locStatements[k];
  4508. locStatement^.Clear();
  4509. if not ParseStatement(buffer,i,bufferLength,locStatement,nextPost,lineCount) then
  4510. Break;
  4511. i := nextPost;
  4512. k := k+1;
  4513. if (k > 3) then
  4514. raise Exception.Create('3 Statements expected, more was parsed.');
  4515. end;
  4516. Check((k=3), 'Statement Count');
  4517. locExpectedStatement.Clear();
  4518. SetLength(locExpectedStatement.Reset,1);
  4519. locExpectedStatement.Reset[0] := Ord('r');
  4520. locExpectedStatement.SetElementCount(3);
  4521. locExpectedStatement.Elements[0] :=
  4522. TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4523. locExpectedStatement.Elements[1] :=
  4524. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Primary,0);
  4525. locExpectedStatement.Elements[2] :=
  4526. TReorderUnit.From(Ord('B'),TReorderWeigthKind.Secondary,0);
  4527. CheckEqual(locStatements[0],locExpectedStatement);
  4528. locExpectedStatement.Clear();
  4529. SetLength(locExpectedStatement.Reset,1);
  4530. locExpectedStatement.Reset[0] := Ord('s');
  4531. locExpectedStatement.SetElementCount(2);
  4532. locExpectedStatement.Elements[0] :=
  4533. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Tertiary,0);
  4534. locExpectedStatement.Elements[1] :=
  4535. TReorderUnit.From(Ord('c'),TReorderWeigthKind.Primary,0);
  4536. CheckEqual(locStatements[1],locExpectedStatement);
  4537. locExpectedStatement.Clear();
  4538. SetLength(locExpectedStatement.Reset,1);
  4539. locExpectedStatement.Reset[0] := Ord('x');
  4540. locExpectedStatement.SetElementCount(2);
  4541. locExpectedStatement.Elements[0] :=
  4542. TReorderUnit.From(Ord('A'),TReorderWeigthKind.Primary,0);
  4543. locExpectedStatement.Elements[1] :=
  4544. TReorderUnit.From(Ord('W'),TReorderWeigthKind.Primary,0);
  4545. CheckEqual(locStatements[2],locExpectedStatement);
  4546. WriteLn(' -- test ok');
  4547. end;
  4548. procedure test_parser_multi_line_statements_1();
  4549. const STATEMENT_BUFFER : UTF8String =
  4550. '&r <a #123'#10 +
  4551. '&s <<< b ';
  4552. var
  4553. locStatements : array of TReorderSequence;
  4554. locStatement : PReorderSequence;
  4555. locExpectedStatement : TReorderSequence;
  4556. lineCount, i, bufferLength, k, nextPost : Integer;
  4557. buffer : PAnsiChar;
  4558. begin
  4559. buffer := @STATEMENT_BUFFER[1];
  4560. WriteLn('Parsing "',buffer,'" ...');
  4561. bufferLength := Length(buffer);
  4562. SetLength(locStatements,10);
  4563. lineCount := 0;
  4564. nextPost := 0;
  4565. i := 0;
  4566. k := 0;
  4567. while (i < bufferLength) do begin
  4568. locStatement := @locStatements[k];
  4569. locStatement^.Clear();
  4570. if not ParseStatement(buffer,i,bufferLength,locStatement,nextPost,lineCount) then
  4571. Break;
  4572. i := nextPost;
  4573. k := k+1;
  4574. if (k > 2) then
  4575. raise Exception.Create('2 Statements expected, more was parsed.');
  4576. end;
  4577. Check((k=2), 'Statement Count');
  4578. locExpectedStatement.Clear();
  4579. SetLength(locExpectedStatement.Reset,1);
  4580. locExpectedStatement.Reset[0] := Ord('r');
  4581. locExpectedStatement.SetElementCount(1);
  4582. locExpectedStatement.Elements[0] :=
  4583. TReorderUnit.From(Ord('a'),TReorderWeigthKind.Primary,0);
  4584. CheckEqual(locStatements[0],locExpectedStatement);
  4585. locExpectedStatement.Clear();
  4586. SetLength(locExpectedStatement.Reset,1);
  4587. locExpectedStatement.Reset[0] := Ord('s');
  4588. locExpectedStatement.SetElementCount(1);
  4589. locExpectedStatement.Elements[0] :=
  4590. TReorderUnit.From(Ord('b'),TReorderWeigthKind.Tertiary,0);
  4591. CheckEqual(locStatements[1],locExpectedStatement);
  4592. WriteLn(' -- test ok');
  4593. end;
  4594. //----------------------------------------------------------------------------//
  4595. const
  4596. UNICODE_LINE_BREAK = #10;
  4597. COLLATION_XML_TEXT =
  4598. '<ldml>' + UNICODE_LINE_BREAK +
  4599. ' <identity>' + UNICODE_LINE_BREAK +
  4600. ' <version number="1.2.3"/>' + UNICODE_LINE_BREAK +
  4601. ' <generation date="$Date: 2014-07-08 21:39:31 -0500 (Tue, 08 Jul 2014) $"/>' + UNICODE_LINE_BREAK +
  4602. ' <language type="xy" />' + UNICODE_LINE_BREAK +
  4603. ' </identity>' + UNICODE_LINE_BREAK +
  4604. ' <collations >' + UNICODE_LINE_BREAK +
  4605. ' <defaultCollation>one</defaultCollation>' + UNICODE_LINE_BREAK +
  4606. ' <collation type="abc" >' + UNICODE_LINE_BREAK +
  4607. ' <import source="xy" type="private-two"/>' + UNICODE_LINE_BREAK +
  4608. ' <import source="xy" type="one"/>' + UNICODE_LINE_BREAK +
  4609. ' <suppress_contractions>[qh]</suppress_contractions>' + UNICODE_LINE_BREAK +
  4610. ' <cr><![CDATA[' + UNICODE_LINE_BREAK +
  4611. ' &w<u<v' + UNICODE_LINE_BREAK +
  4612. ' ]]></cr>' + UNICODE_LINE_BREAK +
  4613. ' </collation>' + UNICODE_LINE_BREAK +
  4614. ' <collation type="one" >' + UNICODE_LINE_BREAK +
  4615. ' <cr><![CDATA[' + UNICODE_LINE_BREAK +
  4616. ' &h<z<b' + UNICODE_LINE_BREAK +
  4617. ' ]]></cr>' + UNICODE_LINE_BREAK +
  4618. ' </collation>' + UNICODE_LINE_BREAK +
  4619. ' <collation type="private-two" >' + UNICODE_LINE_BREAK +
  4620. ' <cr><![CDATA[' + UNICODE_LINE_BREAK +
  4621. ' &f<c<<<ce' + UNICODE_LINE_BREAK +
  4622. ' &q<qh<<<p' + UNICODE_LINE_BREAK +
  4623. ' ]]></cr>' + UNICODE_LINE_BREAK +
  4624. ' </collation >' + UNICODE_LINE_BREAK +
  4625. ' <collation type="three" >' + UNICODE_LINE_BREAK +
  4626. ' <cr><![CDATA[' + UNICODE_LINE_BREAK +
  4627. ' &d<c<b<a' + UNICODE_LINE_BREAK +
  4628. ' ]]></cr>' + UNICODE_LINE_BREAK +
  4629. ' </collation>' + UNICODE_LINE_BREAK +
  4630. ' </collations>' + UNICODE_LINE_BREAK +
  4631. '</ldml>';
  4632. COLLATION_XML_TEXT2 =
  4633. '<ldml>' + UNICODE_LINE_BREAK +
  4634. ' <identity>' + UNICODE_LINE_BREAK +
  4635. ' <version number="1.2.3"/>' + UNICODE_LINE_BREAK +
  4636. ' <generation date="$Date: 2014-07-08 21:39:31 -0500 (Tue, 08 Jul 2014) $"/>' + UNICODE_LINE_BREAK +
  4637. ' <language type="kw" />' + UNICODE_LINE_BREAK +
  4638. ' </identity>' + UNICODE_LINE_BREAK +
  4639. ' <collations >' + UNICODE_LINE_BREAK +
  4640. ' <defaultCollation>wend</defaultCollation>' + UNICODE_LINE_BREAK +
  4641. ' <collation type="kis" >' + UNICODE_LINE_BREAK +
  4642. ' <cr><![CDATA[' + UNICODE_LINE_BREAK +
  4643. ' &x<c<v' + UNICODE_LINE_BREAK +
  4644. ' ]]></cr>' + UNICODE_LINE_BREAK +
  4645. ' </collation>' + UNICODE_LINE_BREAK +
  4646. ' <collation type="wend" >' + UNICODE_LINE_BREAK +
  4647. ' <import source="xy" type="one"/>' + UNICODE_LINE_BREAK +
  4648. ' <cr><![CDATA[' + UNICODE_LINE_BREAK +
  4649. ' &F<<P<<<C' + UNICODE_LINE_BREAK +
  4650. ' &L<a<<<Z' + UNICODE_LINE_BREAK +
  4651. ' ]]></cr>' + UNICODE_LINE_BREAK +
  4652. ' </collation>' + UNICODE_LINE_BREAK +
  4653. ' </collations>' + UNICODE_LINE_BREAK +
  4654. '</ldml>';
  4655. function PrepareCollationStream(const AText : string) : TStream;
  4656. begin
  4657. Result := TMemoryStream.Create();
  4658. if (AText <> '') then
  4659. Result.Write(AText[1],(Length(AText)*SizeOf(Char)));
  4660. end;
  4661. function PrepareRepositoryLoader() : ICldrCollationLoader;
  4662. var
  4663. s : array of TStream;
  4664. begin
  4665. SetLength(s,2);
  4666. s[0] := PrepareCollationStream(COLLATION_XML_TEXT);
  4667. s[1] := PrepareCollationStream(COLLATION_XML_TEXT2);
  4668. Result := TCldrCollationStreamLoader.Create(['xy','kw'],s) as ICldrCollationLoader;
  4669. end;
  4670. procedure test_collation_parser_HeaderParsing();
  4671. var
  4672. rep : TCldrCollationRepository;
  4673. col : TCldrCollation;
  4674. typ : TCldrCollationItem;
  4675. imp : TCldrImport;
  4676. begin
  4677. rep := TCldrCollationRepository.Create(PrepareRepositoryLoader());
  4678. try
  4679. Check(rep.Find('xy')=nil, 'Find() before load.');
  4680. Check(rep.Find('ab')=nil, 'Find() before load.');
  4681. col := rep.Load('xy',TCldrParserMode.HeaderParsing);
  4682. Check(col <> nil, 'load()');
  4683. Check(col.Mode=TCldrParserMode.HeaderParsing, 'Mode');
  4684. Check(rep.Find('xy') <> nil, 'Find() after load.');
  4685. Check(rep.Find('ab')=nil);
  4686. WriteLn(' - Step 1 ok');
  4687. Check(col.DefaultType='one', 'DefaultType');
  4688. Check(col.ItemCount=4, 'col.ItemCount');
  4689. Check(col.Find('one')<>nil, 'col.Find()');
  4690. Check(col.Find('private-two')<>nil, 'col.Find()');
  4691. Check(col.Find('three')<>nil, 'col.Find()');
  4692. Check(col.Find('abc')<>nil, 'col.Find()');
  4693. WriteLn(' - Step 2 ok');
  4694. typ := col.Find('private-two');
  4695. check(typ.IsPrivate(),'IsPrivate()');
  4696. WriteLn(' - Step 3 ok');
  4697. Check(col.Find('one').Imports.Count=0, 'one.imports=0');
  4698. Check(col.Find('private-two').Imports.Count=0, 'private-two.imports=0');
  4699. Check(col.Find('three').Imports.Count=0, 'three.imports=0');
  4700. WriteLn(' - Step 4 ok');
  4701. typ := col.Find('abc');
  4702. check(typ.Imports.Count=2,'abc.imports=2');
  4703. imp := typ.Imports[0];
  4704. check(imp<>nil, 'abc.Imports[0]');
  4705. check(
  4706. (imp.Source = 'xy') and (imp.TypeName = 'private-two'),
  4707. 'abc.Imports[0]'
  4708. );
  4709. imp := typ.Imports[1];
  4710. check(imp<>nil, 'abc.Imports[1]');
  4711. check(
  4712. (imp.Source = 'xy') and (imp.TypeName = 'one'),
  4713. 'abc.Imports[1]'
  4714. );
  4715. WriteLn(' - Step 5 ok');
  4716. finally
  4717. rep.Free();
  4718. end;
  4719. WriteLn(' -- test ok');
  4720. end;
  4721. procedure test_collation_parser_HeaderParsing_2();
  4722. var
  4723. rep : TCldrCollationRepository;
  4724. col : TCldrCollation;
  4725. typ : TCldrCollationItem;
  4726. imp : TCldrImport;
  4727. begin
  4728. rep := TCldrCollationRepository.Create(PrepareRepositoryLoader());
  4729. try
  4730. Check(rep.Find('kw')=nil, 'Find() before load.');
  4731. Check(rep.Find('xy')=nil, 'Find() before load.');
  4732. col := rep.Load('kw',TCldrParserMode.HeaderParsing);
  4733. Check(col <> nil, 'load()');
  4734. Check(col.Mode=TCldrParserMode.HeaderParsing, 'Mode');
  4735. Check(rep.Find('kw') <> nil, 'Find() after load.');
  4736. WriteLn(' - Step 1 ok');
  4737. Check(rep.Find('xy')=nil, 'Find(xy) after load.');
  4738. WriteLn(' - Step 2 ok');
  4739. typ := col.Find('wend');
  4740. check(typ.Imports.Count=1,'wend.imports=1');
  4741. imp := typ.Imports[0];
  4742. check(imp<>nil, 'wend.Imports[0]');
  4743. check(
  4744. (imp.Source = 'xy') and (imp.TypeName = 'one'),
  4745. 'wend.Imports[0]'
  4746. );
  4747. WriteLn(' - Step 3 ok');
  4748. finally
  4749. rep.Free();
  4750. end;
  4751. WriteLn(' -- test ok');
  4752. end;
  4753. function ParseSingleStatement(
  4754. const AText : UnicodeString;
  4755. AStatement : PReorderSequence
  4756. ) : Boolean;
  4757. var
  4758. np, lc : Integer;
  4759. u8 : UTF8String;
  4760. begin
  4761. u8 := UTF8Encode(AText);
  4762. np := 0;
  4763. lc := 0;
  4764. Result := ParseStatement(@u8[1],0,Length(u8),AStatement,np,lc);
  4765. end;
  4766. function ParseMultiStatements(
  4767. AText : UnicodeString;
  4768. AStatementList : PReorderSequence;
  4769. const AListLength : Integer
  4770. ) : Integer;
  4771. var
  4772. c, nextPos, lineCount, i : Integer;
  4773. u8 : UTF8String;
  4774. buffer : PAnsiChar;
  4775. statement, lastStatement : PReorderSequence;
  4776. begin
  4777. u8 := UTF8Encode(AText);
  4778. c := Length(u8);
  4779. buffer := @u8[1];
  4780. nextPos := 0;
  4781. i := 0;
  4782. lineCount := 0;
  4783. statement := AStatementList;
  4784. lastStatement := AStatementList+AListLength;
  4785. while (i < c) and (statement < lastStatement) do begin
  4786. statement^.Clear();
  4787. if not ParseStatement(buffer,i,c,statement,nextPos,lineCount) then
  4788. Break;
  4789. i := nextPos;
  4790. Inc(statement);
  4791. end;
  4792. Result := statement-AStatementList;
  4793. end;
  4794. type
  4795. TReorderSequenceArrayRec = record
  4796. Data : TReorderSequenceArray;
  4797. ActualLengh : Integer;
  4798. end;
  4799. PReorderSequenceArrayRec = ^TReorderSequenceArrayRec;
  4800. function CopyVisitorFunc(
  4801. ARule : PReorderSequence;
  4802. AOwner : TCldrCollationItem;
  4803. AData : Pointer
  4804. ) : Boolean;
  4805. var
  4806. p : PReorderSequenceArrayRec;
  4807. begin
  4808. p := PReorderSequenceArrayRec(AData);
  4809. Result := (p^.ActualLengh < Length(p^.Data));
  4810. if Result then begin
  4811. p^.Data[p^.ActualLengh].Assign(ARule);
  4812. p^.ActualLengh := p^.ActualLengh+1;
  4813. end;
  4814. end;
  4815. procedure test_collation_parser_FullParsing();
  4816. var
  4817. rep : TCldrCollationRepository;
  4818. col : TCldrCollation;
  4819. typ : TCldrCollationItem;
  4820. imp : TCldrImport;
  4821. locStatement : TReorderSequence;
  4822. locStatementList : TReorderSequenceArray;
  4823. c, i : Integer;
  4824. begin
  4825. rep := TCldrCollationRepository.Create(PrepareRepositoryLoader());
  4826. try
  4827. Check(rep.Find('xy')=nil, 'Find() before load.');
  4828. Check(rep.Find('ab')=nil, 'Find() before load.');
  4829. col := rep.Load('xy',TCldrParserMode.FullParsing);
  4830. Check(col <> nil, 'load()');
  4831. Check(col.Mode=TCldrParserMode.FullParsing, 'Mode');
  4832. Check(rep.Find('xy') <> nil, 'Find() after load.');
  4833. Check(rep.Find('ab')=nil);
  4834. WriteLn(' - Step 1 ok');
  4835. Check(col.DefaultType='one', 'DefaultType');
  4836. Check(col.ItemCount=4, 'col.ItemCount');
  4837. Check(col.Find('one')<>nil, 'col.Find()');
  4838. Check(col.Find('private-two')<>nil, 'col.Find()');
  4839. Check(col.Find('three')<>nil, 'col.Find()');
  4840. Check(col.Find('abc')<>nil, 'col.Find()');
  4841. WriteLn(' - Step 2 ok');
  4842. typ := col.Find('private-two');
  4843. check(typ.IsPrivate(),'IsPrivate()');
  4844. WriteLn(' - Step 3 ok');
  4845. Check(col.Find('one').Imports.Count=0, 'one.imports=0');
  4846. Check(col.Find('private-two').Imports.Count=0, 'private-two.imports=0');
  4847. Check(col.Find('three').Imports.Count=0, 'three.imports=0');
  4848. WriteLn(' - Step 4 ok');
  4849. typ := col.Find('abc');
  4850. check(typ.Imports.Count=2,'abc.imports=2');
  4851. imp := typ.Imports[0];
  4852. check(imp<>nil, 'abc.Imports[0]');
  4853. check(
  4854. (imp.Source = 'xy') and (imp.TypeName = 'private-two'),
  4855. 'abc.Imports[0]'
  4856. );
  4857. imp := typ.Imports[1];
  4858. check(imp<>nil, 'abc.Imports[1]');
  4859. check(
  4860. (imp.Source = 'xy') and (imp.TypeName = 'one'),
  4861. 'abc.Imports[1]'
  4862. );
  4863. Check(Length(typ.Rules)=2,'Length(abc.Rules)=2');
  4864. Check(Length(typ.Rules[0].Elements)=2,'Length(typ.Rules[0].Elements)=2');
  4865. Check(typ.Rules[0].Elements[0].WeigthKind=TReorderWeigthKind.Deletion,'typ.Rules[0].Elements[0].WeigthKind=TReorderWeigthKind.Deletion');
  4866. Check(Length(typ.Rules[0].Elements[0].Characters)=1,'Length(typ.Rules[0].Elements[0].Characters)=1');
  4867. Check(typ.Rules[0].Elements[0].Characters[0]=Ord('h'),'typ.Rules[0].Elements[0].Characters[0]=h');
  4868. Check(typ.Rules[0].Elements[1].Characters[0]=Ord('q'),'typ.Rules[0].Elements[1].Characters[0]=q');
  4869. WriteLn(' - Step 5 ok');
  4870. typ := col.Find('one');
  4871. Check(Length(typ.Rules)>0, 'one.Rules <> nil');
  4872. locStatement.Clear();
  4873. Check(ParseSingleStatement('&h<z<b',@locStatement));
  4874. CheckEqual(locStatement,typ.Rules[0]);
  4875. WriteLn(' - Step 6 ok');
  4876. typ := col.Find('private-two');
  4877. Check(Length(typ.Rules)>0, 'private-two.Rules <> nil');
  4878. c := 2;
  4879. SetLength(locStatementList,5);
  4880. Check(
  4881. ParseMultiStatements(
  4882. '&f<c<<<ce' + UNICODE_LINE_BREAK+'&q<qh<<<p ',
  4883. @locStatementList[0],
  4884. Length(locStatementList)
  4885. ) = c
  4886. );
  4887. for i := 0 to c-1 do
  4888. CheckEqual(locStatementList[i],typ.Rules[i]);
  4889. WriteLn(' - Step 7 ok');
  4890. typ := col.Find('three');
  4891. Check(Length(typ.Rules)>0, 'three.Rules <> nil');
  4892. locStatement.Clear();
  4893. Check(ParseSingleStatement('&d<c<b<a',@locStatement));
  4894. CheckEqual(locStatement,typ.Rules[0]);
  4895. WriteLn(' - Step 8 ok');
  4896. finally
  4897. rep.Free();
  4898. end;
  4899. WriteLn(' -- test ok');
  4900. end;
  4901. procedure test_collation_parser_FullParsing_2();
  4902. var
  4903. rep : TCldrCollationRepository;
  4904. col : TCldrCollation;
  4905. typ : TCldrCollationItem;
  4906. imp : TCldrImport;
  4907. locStatementList : TReorderSequenceArray;
  4908. c, i : Integer;
  4909. begin
  4910. rep := TCldrCollationRepository.Create(PrepareRepositoryLoader());
  4911. try
  4912. Check(rep.Find('kw')=nil, 'Find() before load.');
  4913. Check(rep.Find('xy')=nil, 'Find() before load.');
  4914. col := rep.Load('kw',TCldrParserMode.FullParsing);
  4915. Check(col <> nil, 'load()');
  4916. Check(col.Mode=TCldrParserMode.FullParsing, 'Mode');
  4917. Check(rep.Find('kw') <> nil, 'Find() after load.');
  4918. WriteLn(' - Step 1 ok');
  4919. typ := col.Find('wend');
  4920. check(typ.Imports.Count=1,'wend.imports=1');
  4921. imp := typ.Imports[0];
  4922. check(imp<>nil, 'wend.Imports[0]');
  4923. check(
  4924. (imp.Source = 'xy') and (imp.TypeName = 'one'),
  4925. 'wend.Imports[0]'
  4926. );
  4927. Check(Length(typ.Rules)>0, 'wend.Rules <> nil');
  4928. c := 2;
  4929. SetLength(locStatementList,5);
  4930. Check(
  4931. ParseMultiStatements(
  4932. '&F<<P<<<C' + UNICODE_LINE_BREAK+'&L<a<<<Z ',
  4933. @locStatementList[0],
  4934. Length(locStatementList)
  4935. ) = c
  4936. );
  4937. for i := 0 to c-1 do
  4938. CheckEqual(locStatementList[i],typ.Rules[i]);
  4939. WriteLn(' - Step 2 ok');
  4940. finally
  4941. rep.Free();
  4942. end;
  4943. WriteLn(' -- test ok');
  4944. end;
  4945. procedure test_collation_parser_complete_rules();
  4946. var
  4947. rep : TCldrCollationRepository;
  4948. col : TCldrCollation;
  4949. typ, xtyp : TCldrCollationItem;
  4950. c, i : Integer;
  4951. locData : TReorderSequenceArrayRec;
  4952. begin
  4953. rep := TCldrCollationRepository.Create(PrepareRepositoryLoader());
  4954. try
  4955. col := rep.Load('xy',TCldrParserMode.FullParsing);
  4956. SetLength(locData.Data,23);
  4957. typ := col.Find('one');
  4958. locData.ActualLengh := 0;
  4959. Check(ForEachRule(typ,@CopyVisitorFunc,@locData), 'ForEachRule(one) - 1');
  4960. Check(locData.ActualLengh = 1, 'ForEachRule(one) - 2');
  4961. CheckEqual(locData.Data[0],typ.Rules[0]);
  4962. WriteLn(' - Step 1 ok');
  4963. typ := col.Find('private-two');
  4964. locData.ActualLengh := 0;
  4965. Check(ForEachRule(typ,@CopyVisitorFunc,@locData), 'ForEachRule(private-two) - 1');
  4966. Check(locData.ActualLengh = 2, 'ForEachRule(private-two) - 2');
  4967. for i := 0 to locData.ActualLengh-1 do
  4968. CheckEqual(locData.Data[i],typ.Rules[i]);
  4969. WriteLn(' - Step 2 ok');
  4970. typ := col.Find('abc');
  4971. locData.ActualLengh := 0;
  4972. SetLength(locData.Data,23);
  4973. Check(ForEachRule(typ,@CopyVisitorFunc,@locData), 'ForEachRule(abc) - 1');
  4974. Check(locData.ActualLengh = 2+2{private-two}+1{one}, 'ForEachRule(abc) - 2');
  4975. xtyp := col.Find('private-two');
  4976. c := 0;
  4977. for i := 0 to Length(xtyp.Rules)-1 do
  4978. CheckEqual(locData.Data[c+i],xtyp.Rules[i]);
  4979. c := c+Length(xtyp.Rules);
  4980. xtyp := col.Find('one');
  4981. for i := 0 to Length(xtyp.Rules)-1 do
  4982. CheckEqual(locData.Data[c+i],xtyp.Rules[i]);
  4983. c := c+Length(xtyp.Rules);
  4984. for i := 0 to Length(typ.Rules)-1 do
  4985. CheckEqual(locData.Data[c+i],typ.Rules[i]);
  4986. WriteLn(' - Step 2 ok');
  4987. finally
  4988. rep.Free();
  4989. end;
  4990. WriteLn(' -- test ok');
  4991. end;
  4992. procedure test_collation_parser_complete_rules_2();
  4993. var
  4994. rep : TCldrCollationRepository;
  4995. col, xcol : TCldrCollation;
  4996. typ, xtyp : TCldrCollationItem;
  4997. locData : TReorderSequenceArrayRec;
  4998. c, i : Integer;
  4999. begin
  5000. rep := TCldrCollationRepository.Create(PrepareRepositoryLoader());
  5001. try
  5002. col := rep.Load('kw',TCldrParserMode.FullParsing);
  5003. SetLength(locData.Data,23);
  5004. typ := col.Find('wend');
  5005. locData.ActualLengh := 0;
  5006. Check(ForEachRule(typ,@CopyVisitorFunc,@locData), 'ForEachRule(wend) - 1');
  5007. Check(locData.ActualLengh = 2+1{one}, 'ForEachRule(wend) - 2');
  5008. xcol := rep.Find('xy');
  5009. Check(xcol <> nil);
  5010. xtyp := xcol.Find('one');
  5011. Check(xtyp <> nil);
  5012. Check(Length(xtyp.Rules)=1);
  5013. c := 0;
  5014. for i := 0 to Length(xtyp.Rules)-1 do
  5015. CheckEqual(locData.Data[c+i],xtyp.Rules[i]);
  5016. c := c+Length(xtyp.Rules);
  5017. for i := 0 to Length(typ.Rules)-1 do
  5018. CheckEqual(locData.Data[c+i],typ.Rules[i]);
  5019. WriteLn(' - Step 1 ok');
  5020. finally
  5021. rep.Free();
  5022. end;
  5023. WriteLn(' -- test ok');
  5024. end;
  5025. procedure test_unicode_set_1();
  5026. var
  5027. x : TUnicodeSet;
  5028. i : Integer;
  5029. s : string;
  5030. begin
  5031. x := TUnicodeSet.Create();
  5032. try
  5033. for i := 0 to 256-1 do
  5034. Check(not x.Contains(AnsiChar(i)));
  5035. WriteLn(' - Stept 1 ok');
  5036. s := 'azerty';
  5037. x.AddPattern(Format('[%s]',[s]));
  5038. for i := 1 to Length(s) do
  5039. Check(x.Contains(s[i]));
  5040. WriteLn(' - Stept 2 ok');
  5041. finally
  5042. x.Free();
  5043. end;
  5044. WriteLn(' -- test ok');
  5045. end;
  5046. procedure test_unicode_set_2();
  5047. var
  5048. x : TUnicodeSet;
  5049. i : Integer;
  5050. begin
  5051. x := TUnicodeSet.Create();
  5052. try
  5053. x.AddPattern('[d-h]');
  5054. for i := Ord('d') to Ord('h') do
  5055. Check(x.Contains(Char(i)));
  5056. WriteLn(' - Stept 1 ok');
  5057. for i := Ord('a') to Ord('d')-1 do
  5058. Check(not x.Contains(Char(i)));
  5059. WriteLn(' - Stept 2 ok');
  5060. for i := Ord('h')+1 to 256-1 do
  5061. Check(not x.Contains(Char(i)));
  5062. WriteLn(' - Stept 3 ok');
  5063. finally
  5064. x.Free();
  5065. end;
  5066. WriteLn(' -- test ok');
  5067. end;
  5068. procedure test_unicode_set_3();
  5069. var
  5070. x : TUnicodeSet;
  5071. s, s1 : string;
  5072. begin
  5073. x := TUnicodeSet.Create();
  5074. try
  5075. s := 'azerty';
  5076. x.AddPattern(Format('[{%s}]',[s]));
  5077. Check(x.Contains(s));
  5078. WriteLn(' - Stept 1 ok');
  5079. Check(not x.Contains(s+'12'));
  5080. WriteLn(' - Stept 2 ok');
  5081. Check(not x.Contains('qs'+s));
  5082. WriteLn(' - Stept 3 ok');
  5083. s1 := s+'x';
  5084. x.AddPattern(Format('[{%s}]',[s1]));
  5085. Check(x.Contains(s));
  5086. Check(x.Contains(s1));
  5087. WriteLn(' - Stept 4 ok');
  5088. finally
  5089. x.Free();
  5090. end;
  5091. WriteLn(' -- test ok');
  5092. end;
  5093. end.