xmlparse.c 235 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217
  1. /* 19ac4776051591216f1874e34ee99b6a43a3784c8bd7d70efeb9258dd22b906a (2.2.6+)
  2. __ __ _
  3. ___\ \/ /_ __ __ _| |_
  4. / _ \\ /| '_ \ / _` | __|
  5. | __// \| |_) | (_| | |_
  6. \___/_/\_\ .__/ \__,_|\__|
  7. |_| XML parser
  8. Copyright (c) 1997-2000 Thai Open Source Software Center Ltd
  9. Copyright (c) 2000-2017 Expat development team
  10. Licensed under the MIT license:
  11. Permission is hereby granted, free of charge, to any person obtaining
  12. a copy of this software and associated documentation files (the
  13. "Software"), to deal in the Software without restriction, including
  14. without limitation the rights to use, copy, modify, merge, publish,
  15. distribute, sublicense, and/or sell copies of the Software, and to permit
  16. persons to whom the Software is furnished to do so, subject to the
  17. following conditions:
  18. The above copyright notice and this permission notice shall be included
  19. in all copies or substantial portions of the Software.
  20. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  21. EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  22. MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
  23. NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
  24. DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
  25. OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
  26. USE OR OTHER DEALINGS IN THE SOFTWARE.
  27. */
  28. #if !defined(_GNU_SOURCE)
  29. # define _GNU_SOURCE 1 /* syscall prototype */
  30. #endif
  31. #include <stddef.h>
  32. #include <string.h> /* memset(), memcpy() */
  33. #include <assert.h>
  34. #include <limits.h> /* UINT_MAX */
  35. #include <stdio.h> /* fprintf */
  36. #include <stdlib.h> /* getenv */
  37. #ifdef _WIN32
  38. #define getpid GetCurrentProcessId
  39. #else
  40. #include <sys/time.h> /* gettimeofday() */
  41. #include <sys/types.h> /* getpid() */
  42. #include <unistd.h> /* getpid() */
  43. #include <fcntl.h> /* O_RDONLY */
  44. #include <errno.h>
  45. #endif
  46. #define XML_BUILDING_EXPAT 1
  47. #ifdef _WIN32
  48. #include "winconfig.h"
  49. #elif defined(HAVE_EXPAT_CONFIG_H)
  50. #include <expat_config.h>
  51. #endif /* ndef _WIN32 */
  52. #include "ascii.h"
  53. #include "expat.h"
  54. #include "siphash.h"
  55. #if defined(HAVE_GETRANDOM) || defined(HAVE_SYSCALL_GETRANDOM)
  56. # if defined(HAVE_GETRANDOM)
  57. # include <sys/random.h> /* getrandom */
  58. # else
  59. # include <unistd.h> /* syscall */
  60. # include <sys/syscall.h> /* SYS_getrandom */
  61. # endif
  62. # if ! defined(GRND_NONBLOCK)
  63. # define GRND_NONBLOCK 0x0001
  64. # endif /* defined(GRND_NONBLOCK) */
  65. #endif /* defined(HAVE_GETRANDOM) || defined(HAVE_SYSCALL_GETRANDOM) */
  66. #if defined(HAVE_LIBBSD) \
  67. && (defined(HAVE_ARC4RANDOM_BUF) || defined(HAVE_ARC4RANDOM))
  68. # include <bsd/stdlib.h>
  69. #endif
  70. #if defined(_WIN32) && !defined(LOAD_LIBRARY_SEARCH_SYSTEM32)
  71. # define LOAD_LIBRARY_SEARCH_SYSTEM32 0x00000800
  72. #endif
  73. #if !defined(HAVE_GETRANDOM) && !defined(HAVE_SYSCALL_GETRANDOM) \
  74. && !defined(HAVE_ARC4RANDOM_BUF) && !defined(HAVE_ARC4RANDOM) \
  75. && !defined(XML_DEV_URANDOM) \
  76. && !defined(_WIN32) \
  77. && !defined(XML_POOR_ENTROPY)
  78. # error \
  79. You do not have support for any sources of high quality entropy \
  80. enabled. For end user security, that is probably not what you want. \
  81. \
  82. Your options include: \
  83. * Linux + glibc >=2.25 (getrandom): HAVE_GETRANDOM, \
  84. * Linux + glibc <2.25 (syscall SYS_getrandom): HAVE_SYSCALL_GETRANDOM, \
  85. * BSD / macOS >=10.7 (arc4random_buf): HAVE_ARC4RANDOM_BUF, \
  86. * BSD / macOS <10.7 (arc4random): HAVE_ARC4RANDOM, \
  87. * libbsd (arc4random_buf): HAVE_ARC4RANDOM_BUF + HAVE_LIBBSD, \
  88. * libbsd (arc4random): HAVE_ARC4RANDOM + HAVE_LIBBSD, \
  89. * Linux / BSD / macOS (/dev/urandom): XML_DEV_URANDOM \
  90. * Windows (RtlGenRandom): _WIN32. \
  91. \
  92. If insist on not using any of these, bypass this error by defining \
  93. XML_POOR_ENTROPY; you have been warned. \
  94. \
  95. If you have reasons to patch this detection code away or need changes \
  96. to the build system, please open a bug. Thank you!
  97. #endif
  98. #ifdef XML_UNICODE
  99. #define XML_ENCODE_MAX XML_UTF16_ENCODE_MAX
  100. #define XmlConvert XmlUtf16Convert
  101. #define XmlGetInternalEncoding XmlGetUtf16InternalEncoding
  102. #define XmlGetInternalEncodingNS XmlGetUtf16InternalEncodingNS
  103. #define XmlEncode XmlUtf16Encode
  104. /* Using pointer subtraction to convert to integer type. */
  105. #define MUST_CONVERT(enc, s) (!(enc)->isUtf16 || (((char *)(s) - (char *)NULL) & 1))
  106. typedef unsigned short ICHAR;
  107. #else
  108. #define XML_ENCODE_MAX XML_UTF8_ENCODE_MAX
  109. #define XmlConvert XmlUtf8Convert
  110. #define XmlGetInternalEncoding XmlGetUtf8InternalEncoding
  111. #define XmlGetInternalEncodingNS XmlGetUtf8InternalEncodingNS
  112. #define XmlEncode XmlUtf8Encode
  113. #define MUST_CONVERT(enc, s) (!(enc)->isUtf8)
  114. typedef char ICHAR;
  115. #endif
  116. #ifndef XML_NS
  117. #define XmlInitEncodingNS XmlInitEncoding
  118. #define XmlInitUnknownEncodingNS XmlInitUnknownEncoding
  119. #undef XmlGetInternalEncodingNS
  120. #define XmlGetInternalEncodingNS XmlGetInternalEncoding
  121. #define XmlParseXmlDeclNS XmlParseXmlDecl
  122. #endif
  123. #ifdef XML_UNICODE
  124. #ifdef XML_UNICODE_WCHAR_T
  125. #define XML_T(x) (const wchar_t)x
  126. #define XML_L(x) L ## x
  127. #else
  128. #define XML_T(x) (const unsigned short)x
  129. #define XML_L(x) x
  130. #endif
  131. #else
  132. #define XML_T(x) x
  133. #define XML_L(x) x
  134. #endif
  135. /* Round up n to be a multiple of sz, where sz is a power of 2. */
  136. #define ROUND_UP(n, sz) (((n) + ((sz) - 1)) & ~((sz) - 1))
  137. /* Do safe (NULL-aware) pointer arithmetic */
  138. #define EXPAT_SAFE_PTR_DIFF(p, q) (((p) && (q)) ? ((p) - (q)) : 0)
  139. /* Handle the case where memmove() doesn't exist. */
  140. #ifndef HAVE_MEMMOVE
  141. #ifdef HAVE_BCOPY
  142. #define memmove(d,s,l) bcopy((s),(d),(l))
  143. #else
  144. #error memmove does not exist on this platform, nor is a substitute available
  145. #endif /* HAVE_BCOPY */
  146. #endif /* HAVE_MEMMOVE */
  147. #include "internal.h"
  148. #include "xmltok.h"
  149. #include "xmlrole.h"
  150. typedef const XML_Char *KEY;
  151. typedef struct {
  152. KEY name;
  153. } NAMED;
  154. typedef struct {
  155. NAMED **v;
  156. unsigned char power;
  157. size_t size;
  158. size_t used;
  159. const XML_Memory_Handling_Suite *mem;
  160. } HASH_TABLE;
  161. static size_t
  162. keylen(KEY s);
  163. static void
  164. copy_salt_to_sipkey(XML_Parser parser, struct sipkey * key);
  165. /* For probing (after a collision) we need a step size relative prime
  166. to the hash table size, which is a power of 2. We use double-hashing,
  167. since we can calculate a second hash value cheaply by taking those bits
  168. of the first hash value that were discarded (masked out) when the table
  169. index was calculated: index = hash & mask, where mask = table->size - 1.
  170. We limit the maximum step size to table->size / 4 (mask >> 2) and make
  171. it odd, since odd numbers are always relative prime to a power of 2.
  172. */
  173. #define SECOND_HASH(hash, mask, power) \
  174. ((((hash) & ~(mask)) >> ((power) - 1)) & ((mask) >> 2))
  175. #define PROBE_STEP(hash, mask, power) \
  176. ((unsigned char)((SECOND_HASH(hash, mask, power)) | 1))
  177. typedef struct {
  178. NAMED **p;
  179. NAMED **end;
  180. } HASH_TABLE_ITER;
  181. #define INIT_TAG_BUF_SIZE 32 /* must be a multiple of sizeof(XML_Char) */
  182. #define INIT_DATA_BUF_SIZE 1024
  183. #define INIT_ATTS_SIZE 16
  184. #define INIT_ATTS_VERSION 0xFFFFFFFF
  185. #define INIT_BLOCK_SIZE 1024
  186. #define INIT_BUFFER_SIZE 1024
  187. #define EXPAND_SPARE 24
  188. typedef struct binding {
  189. struct prefix *prefix;
  190. struct binding *nextTagBinding;
  191. struct binding *prevPrefixBinding;
  192. const struct attribute_id *attId;
  193. XML_Char *uri;
  194. int uriLen;
  195. int uriAlloc;
  196. } BINDING;
  197. typedef struct prefix {
  198. const XML_Char *name;
  199. BINDING *binding;
  200. } PREFIX;
  201. typedef struct {
  202. const XML_Char *str;
  203. const XML_Char *localPart;
  204. const XML_Char *prefix;
  205. int strLen;
  206. int uriLen;
  207. int prefixLen;
  208. } TAG_NAME;
  209. /* TAG represents an open element.
  210. The name of the element is stored in both the document and API
  211. encodings. The memory buffer 'buf' is a separately-allocated
  212. memory area which stores the name. During the XML_Parse()/
  213. XMLParseBuffer() when the element is open, the memory for the 'raw'
  214. version of the name (in the document encoding) is shared with the
  215. document buffer. If the element is open across calls to
  216. XML_Parse()/XML_ParseBuffer(), the buffer is re-allocated to
  217. contain the 'raw' name as well.
  218. A parser re-uses these structures, maintaining a list of allocated
  219. TAG objects in a free list.
  220. */
  221. typedef struct tag {
  222. struct tag *parent; /* parent of this element */
  223. const char *rawName; /* tagName in the original encoding */
  224. int rawNameLength;
  225. TAG_NAME name; /* tagName in the API encoding */
  226. char *buf; /* buffer for name components */
  227. char *bufEnd; /* end of the buffer */
  228. BINDING *bindings;
  229. } TAG;
  230. typedef struct {
  231. const XML_Char *name;
  232. const XML_Char *textPtr;
  233. int textLen; /* length in XML_Chars */
  234. int processed; /* # of processed bytes - when suspended */
  235. const XML_Char *systemId;
  236. const XML_Char *base;
  237. const XML_Char *publicId;
  238. const XML_Char *notation;
  239. XML_Bool open;
  240. XML_Bool is_param;
  241. XML_Bool is_internal; /* true if declared in internal subset outside PE */
  242. } ENTITY;
  243. typedef struct {
  244. enum XML_Content_Type type;
  245. enum XML_Content_Quant quant;
  246. const XML_Char * name;
  247. int firstchild;
  248. int lastchild;
  249. int childcnt;
  250. int nextsib;
  251. } CONTENT_SCAFFOLD;
  252. #define INIT_SCAFFOLD_ELEMENTS 32
  253. typedef struct block {
  254. struct block *next;
  255. int size;
  256. XML_Char s[1];
  257. } BLOCK;
  258. typedef struct {
  259. BLOCK *blocks;
  260. BLOCK *freeBlocks;
  261. const XML_Char *end;
  262. XML_Char *ptr;
  263. XML_Char *start;
  264. const XML_Memory_Handling_Suite *mem;
  265. } STRING_POOL;
  266. /* The XML_Char before the name is used to determine whether
  267. an attribute has been specified. */
  268. typedef struct attribute_id {
  269. XML_Char *name;
  270. PREFIX *prefix;
  271. XML_Bool maybeTokenized;
  272. XML_Bool xmlns;
  273. } ATTRIBUTE_ID;
  274. typedef struct {
  275. const ATTRIBUTE_ID *id;
  276. XML_Bool isCdata;
  277. const XML_Char *value;
  278. } DEFAULT_ATTRIBUTE;
  279. typedef struct {
  280. unsigned long version;
  281. unsigned long hash;
  282. const XML_Char *uriName;
  283. } NS_ATT;
  284. typedef struct {
  285. const XML_Char *name;
  286. PREFIX *prefix;
  287. const ATTRIBUTE_ID *idAtt;
  288. int nDefaultAtts;
  289. int allocDefaultAtts;
  290. DEFAULT_ATTRIBUTE *defaultAtts;
  291. } ELEMENT_TYPE;
  292. typedef struct {
  293. HASH_TABLE generalEntities;
  294. HASH_TABLE elementTypes;
  295. HASH_TABLE attributeIds;
  296. HASH_TABLE prefixes;
  297. STRING_POOL pool;
  298. STRING_POOL entityValuePool;
  299. /* false once a parameter entity reference has been skipped */
  300. XML_Bool keepProcessing;
  301. /* true once an internal or external PE reference has been encountered;
  302. this includes the reference to an external subset */
  303. XML_Bool hasParamEntityRefs;
  304. XML_Bool standalone;
  305. #ifdef XML_DTD
  306. /* indicates if external PE has been read */
  307. XML_Bool paramEntityRead;
  308. HASH_TABLE paramEntities;
  309. #endif /* XML_DTD */
  310. PREFIX defaultPrefix;
  311. /* === scaffolding for building content model === */
  312. XML_Bool in_eldecl;
  313. CONTENT_SCAFFOLD *scaffold;
  314. unsigned contentStringLen;
  315. unsigned scaffSize;
  316. unsigned scaffCount;
  317. int scaffLevel;
  318. int *scaffIndex;
  319. } DTD;
  320. typedef struct open_internal_entity {
  321. const char *internalEventPtr;
  322. const char *internalEventEndPtr;
  323. struct open_internal_entity *next;
  324. ENTITY *entity;
  325. int startTagLevel;
  326. XML_Bool betweenDecl; /* WFC: PE Between Declarations */
  327. } OPEN_INTERNAL_ENTITY;
  328. typedef enum XML_Error PTRCALL Processor(XML_Parser parser,
  329. const char *start,
  330. const char *end,
  331. const char **endPtr);
  332. static Processor prologProcessor;
  333. static Processor prologInitProcessor;
  334. static Processor contentProcessor;
  335. static Processor cdataSectionProcessor;
  336. #ifdef XML_DTD
  337. static Processor ignoreSectionProcessor;
  338. static Processor externalParEntProcessor;
  339. static Processor externalParEntInitProcessor;
  340. static Processor entityValueProcessor;
  341. static Processor entityValueInitProcessor;
  342. #endif /* XML_DTD */
  343. static Processor epilogProcessor;
  344. static Processor errorProcessor;
  345. static Processor externalEntityInitProcessor;
  346. static Processor externalEntityInitProcessor2;
  347. static Processor externalEntityInitProcessor3;
  348. static Processor externalEntityContentProcessor;
  349. static Processor internalEntityProcessor;
  350. static enum XML_Error
  351. handleUnknownEncoding(XML_Parser parser, const XML_Char *encodingName);
  352. static enum XML_Error
  353. processXmlDecl(XML_Parser parser, int isGeneralTextEntity,
  354. const char *s, const char *next);
  355. static enum XML_Error
  356. initializeEncoding(XML_Parser parser);
  357. static enum XML_Error
  358. doProlog(XML_Parser parser, const ENCODING *enc, const char *s,
  359. const char *end, int tok, const char *next, const char **nextPtr,
  360. XML_Bool haveMore);
  361. static enum XML_Error
  362. processInternalEntity(XML_Parser parser, ENTITY *entity,
  363. XML_Bool betweenDecl);
  364. static enum XML_Error
  365. doContent(XML_Parser parser, int startTagLevel, const ENCODING *enc,
  366. const char *start, const char *end, const char **endPtr,
  367. XML_Bool haveMore);
  368. static enum XML_Error
  369. doCdataSection(XML_Parser parser, const ENCODING *, const char **startPtr,
  370. const char *end, const char **nextPtr, XML_Bool haveMore);
  371. #ifdef XML_DTD
  372. static enum XML_Error
  373. doIgnoreSection(XML_Parser parser, const ENCODING *, const char **startPtr,
  374. const char *end, const char **nextPtr, XML_Bool haveMore);
  375. #endif /* XML_DTD */
  376. static void
  377. freeBindings(XML_Parser parser, BINDING *bindings);
  378. static enum XML_Error
  379. storeAtts(XML_Parser parser, const ENCODING *, const char *s,
  380. TAG_NAME *tagNamePtr, BINDING **bindingsPtr);
  381. static enum XML_Error
  382. addBinding(XML_Parser parser, PREFIX *prefix, const ATTRIBUTE_ID *attId,
  383. const XML_Char *uri, BINDING **bindingsPtr);
  384. static int
  385. defineAttribute(ELEMENT_TYPE *type, ATTRIBUTE_ID *, XML_Bool isCdata,
  386. XML_Bool isId, const XML_Char *dfltValue, XML_Parser parser);
  387. static enum XML_Error
  388. storeAttributeValue(XML_Parser parser, const ENCODING *, XML_Bool isCdata,
  389. const char *, const char *, STRING_POOL *);
  390. static enum XML_Error
  391. appendAttributeValue(XML_Parser parser, const ENCODING *, XML_Bool isCdata,
  392. const char *, const char *, STRING_POOL *);
  393. static ATTRIBUTE_ID *
  394. getAttributeId(XML_Parser parser, const ENCODING *enc, const char *start,
  395. const char *end);
  396. static int
  397. setElementTypePrefix(XML_Parser parser, ELEMENT_TYPE *);
  398. static enum XML_Error
  399. storeEntityValue(XML_Parser parser, const ENCODING *enc, const char *start,
  400. const char *end);
  401. static int
  402. reportProcessingInstruction(XML_Parser parser, const ENCODING *enc,
  403. const char *start, const char *end);
  404. static int
  405. reportComment(XML_Parser parser, const ENCODING *enc, const char *start,
  406. const char *end);
  407. static void
  408. reportDefault(XML_Parser parser, const ENCODING *enc, const char *start,
  409. const char *end);
  410. static const XML_Char * getContext(XML_Parser parser);
  411. static XML_Bool
  412. setContext(XML_Parser parser, const XML_Char *context);
  413. static void FASTCALL normalizePublicId(XML_Char *s);
  414. static DTD * dtdCreate(const XML_Memory_Handling_Suite *ms);
  415. /* do not call if m_parentParser != NULL */
  416. static void dtdReset(DTD *p, const XML_Memory_Handling_Suite *ms);
  417. static void
  418. dtdDestroy(DTD *p, XML_Bool isDocEntity, const XML_Memory_Handling_Suite *ms);
  419. static int
  420. dtdCopy(XML_Parser oldParser,
  421. DTD *newDtd, const DTD *oldDtd, const XML_Memory_Handling_Suite *ms);
  422. static int
  423. copyEntityTable(XML_Parser oldParser,
  424. HASH_TABLE *, STRING_POOL *, const HASH_TABLE *);
  425. static NAMED *
  426. lookup(XML_Parser parser, HASH_TABLE *table, KEY name, size_t createSize);
  427. static void FASTCALL
  428. hashTableInit(HASH_TABLE *, const XML_Memory_Handling_Suite *ms);
  429. static void FASTCALL hashTableClear(HASH_TABLE *);
  430. static void FASTCALL hashTableDestroy(HASH_TABLE *);
  431. static void FASTCALL
  432. hashTableIterInit(HASH_TABLE_ITER *, const HASH_TABLE *);
  433. static NAMED * FASTCALL hashTableIterNext(HASH_TABLE_ITER *);
  434. static void FASTCALL
  435. poolInit(STRING_POOL *, const XML_Memory_Handling_Suite *ms);
  436. static void FASTCALL poolClear(STRING_POOL *);
  437. static void FASTCALL poolDestroy(STRING_POOL *);
  438. static XML_Char *
  439. poolAppend(STRING_POOL *pool, const ENCODING *enc,
  440. const char *ptr, const char *end);
  441. static XML_Char *
  442. poolStoreString(STRING_POOL *pool, const ENCODING *enc,
  443. const char *ptr, const char *end);
  444. static XML_Bool FASTCALL poolGrow(STRING_POOL *pool);
  445. static const XML_Char * FASTCALL
  446. poolCopyString(STRING_POOL *pool, const XML_Char *s);
  447. static const XML_Char *
  448. poolCopyStringN(STRING_POOL *pool, const XML_Char *s, int n);
  449. static const XML_Char * FASTCALL
  450. poolAppendString(STRING_POOL *pool, const XML_Char *s);
  451. static int FASTCALL nextScaffoldPart(XML_Parser parser);
  452. static XML_Content * build_model(XML_Parser parser);
  453. static ELEMENT_TYPE *
  454. getElementType(XML_Parser parser, const ENCODING *enc,
  455. const char *ptr, const char *end);
  456. static XML_Char *copyString(const XML_Char *s,
  457. const XML_Memory_Handling_Suite *memsuite);
  458. static unsigned long generate_hash_secret_salt(XML_Parser parser);
  459. static XML_Bool startParsing(XML_Parser parser);
  460. static XML_Parser
  461. parserCreate(const XML_Char *encodingName,
  462. const XML_Memory_Handling_Suite *memsuite,
  463. const XML_Char *nameSep,
  464. DTD *dtd);
  465. static void
  466. parserInit(XML_Parser parser, const XML_Char *encodingName);
  467. #define poolStart(pool) ((pool)->start)
  468. #define poolEnd(pool) ((pool)->ptr)
  469. #define poolLength(pool) ((pool)->ptr - (pool)->start)
  470. #define poolChop(pool) ((void)--(pool->ptr))
  471. #define poolLastChar(pool) (((pool)->ptr)[-1])
  472. #define poolDiscard(pool) ((pool)->ptr = (pool)->start)
  473. #define poolFinish(pool) ((pool)->start = (pool)->ptr)
  474. #define poolAppendChar(pool, c) \
  475. (((pool)->ptr == (pool)->end && !poolGrow(pool)) \
  476. ? 0 \
  477. : ((*((pool)->ptr)++ = c), 1))
  478. struct XML_ParserStruct {
  479. /* The first member must be m_userData so that the XML_GetUserData
  480. macro works. */
  481. void *m_userData;
  482. void *m_handlerArg;
  483. char *m_buffer;
  484. const XML_Memory_Handling_Suite m_mem;
  485. /* first character to be parsed */
  486. const char *m_bufferPtr;
  487. /* past last character to be parsed */
  488. char *m_bufferEnd;
  489. /* allocated end of m_buffer */
  490. const char *m_bufferLim;
  491. XML_Index m_parseEndByteIndex;
  492. const char *m_parseEndPtr;
  493. XML_Char *m_dataBuf;
  494. XML_Char *m_dataBufEnd;
  495. XML_StartElementHandler m_startElementHandler;
  496. XML_EndElementHandler m_endElementHandler;
  497. XML_CharacterDataHandler m_characterDataHandler;
  498. XML_ProcessingInstructionHandler m_processingInstructionHandler;
  499. XML_CommentHandler m_commentHandler;
  500. XML_StartCdataSectionHandler m_startCdataSectionHandler;
  501. XML_EndCdataSectionHandler m_endCdataSectionHandler;
  502. XML_DefaultHandler m_defaultHandler;
  503. XML_StartDoctypeDeclHandler m_startDoctypeDeclHandler;
  504. XML_EndDoctypeDeclHandler m_endDoctypeDeclHandler;
  505. XML_UnparsedEntityDeclHandler m_unparsedEntityDeclHandler;
  506. XML_NotationDeclHandler m_notationDeclHandler;
  507. XML_StartNamespaceDeclHandler m_startNamespaceDeclHandler;
  508. XML_EndNamespaceDeclHandler m_endNamespaceDeclHandler;
  509. XML_NotStandaloneHandler m_notStandaloneHandler;
  510. XML_ExternalEntityRefHandler m_externalEntityRefHandler;
  511. XML_Parser m_externalEntityRefHandlerArg;
  512. XML_SkippedEntityHandler m_skippedEntityHandler;
  513. XML_UnknownEncodingHandler m_unknownEncodingHandler;
  514. XML_ElementDeclHandler m_elementDeclHandler;
  515. XML_AttlistDeclHandler m_attlistDeclHandler;
  516. XML_EntityDeclHandler m_entityDeclHandler;
  517. XML_XmlDeclHandler m_xmlDeclHandler;
  518. const ENCODING *m_encoding;
  519. INIT_ENCODING m_initEncoding;
  520. const ENCODING *m_internalEncoding;
  521. const XML_Char *m_protocolEncodingName;
  522. XML_Bool m_ns;
  523. XML_Bool m_ns_triplets;
  524. void *m_unknownEncodingMem;
  525. void *m_unknownEncodingData;
  526. void *m_unknownEncodingHandlerData;
  527. void (XMLCALL *m_unknownEncodingRelease)(void *);
  528. PROLOG_STATE m_prologState;
  529. Processor *m_processor;
  530. enum XML_Error m_errorCode;
  531. const char *m_eventPtr;
  532. const char *m_eventEndPtr;
  533. const char *m_positionPtr;
  534. OPEN_INTERNAL_ENTITY *m_openInternalEntities;
  535. OPEN_INTERNAL_ENTITY *m_freeInternalEntities;
  536. XML_Bool m_defaultExpandInternalEntities;
  537. int m_tagLevel;
  538. ENTITY *m_declEntity;
  539. const XML_Char *m_doctypeName;
  540. const XML_Char *m_doctypeSysid;
  541. const XML_Char *m_doctypePubid;
  542. const XML_Char *m_declAttributeType;
  543. const XML_Char *m_declNotationName;
  544. const XML_Char *m_declNotationPublicId;
  545. ELEMENT_TYPE *m_declElementType;
  546. ATTRIBUTE_ID *m_declAttributeId;
  547. XML_Bool m_declAttributeIsCdata;
  548. XML_Bool m_declAttributeIsId;
  549. DTD *m_dtd;
  550. const XML_Char *m_curBase;
  551. TAG *m_tagStack;
  552. TAG *m_freeTagList;
  553. BINDING *m_inheritedBindings;
  554. BINDING *m_freeBindingList;
  555. int m_attsSize;
  556. int m_nSpecifiedAtts;
  557. int m_idAttIndex;
  558. ATTRIBUTE *m_atts;
  559. NS_ATT *m_nsAtts;
  560. unsigned long m_nsAttsVersion;
  561. unsigned char m_nsAttsPower;
  562. #ifdef XML_ATTR_INFO
  563. XML_AttrInfo *m_attInfo;
  564. #endif
  565. POSITION m_position;
  566. STRING_POOL m_tempPool;
  567. STRING_POOL m_temp2Pool;
  568. char *m_groupConnector;
  569. unsigned int m_groupSize;
  570. XML_Char m_namespaceSeparator;
  571. XML_Parser m_parentParser;
  572. XML_ParsingStatus m_parsingStatus;
  573. #ifdef XML_DTD
  574. XML_Bool m_isParamEntity;
  575. XML_Bool m_useForeignDTD;
  576. enum XML_ParamEntityParsing m_paramEntityParsing;
  577. #endif
  578. unsigned long m_hash_secret_salt;
  579. };
  580. #define MALLOC(parser, s) (parser->m_mem.malloc_fcn((s)))
  581. #define REALLOC(parser, p, s) (parser->m_mem.realloc_fcn((p),(s)))
  582. #define FREE(parser, p) (parser->m_mem.free_fcn((p)))
  583. XML_Parser XMLCALL
  584. XML_ParserCreate(const XML_Char *encodingName)
  585. {
  586. return XML_ParserCreate_MM(encodingName, NULL, NULL);
  587. }
  588. XML_Parser XMLCALL
  589. XML_ParserCreateNS(const XML_Char *encodingName, XML_Char nsSep)
  590. {
  591. XML_Char tmp[2];
  592. *tmp = nsSep;
  593. return XML_ParserCreate_MM(encodingName, NULL, tmp);
  594. }
  595. static const XML_Char implicitContext[] = {
  596. ASCII_x, ASCII_m, ASCII_l, ASCII_EQUALS, ASCII_h, ASCII_t, ASCII_t, ASCII_p,
  597. ASCII_COLON, ASCII_SLASH, ASCII_SLASH, ASCII_w, ASCII_w, ASCII_w,
  598. ASCII_PERIOD, ASCII_w, ASCII_3, ASCII_PERIOD, ASCII_o, ASCII_r, ASCII_g,
  599. ASCII_SLASH, ASCII_X, ASCII_M, ASCII_L, ASCII_SLASH, ASCII_1, ASCII_9,
  600. ASCII_9, ASCII_8, ASCII_SLASH, ASCII_n, ASCII_a, ASCII_m, ASCII_e,
  601. ASCII_s, ASCII_p, ASCII_a, ASCII_c, ASCII_e, '\0'
  602. };
  603. /* To avoid warnings about unused functions: */
  604. #if ! defined(HAVE_ARC4RANDOM_BUF) && ! defined(HAVE_ARC4RANDOM)
  605. #if defined(HAVE_GETRANDOM) || defined(HAVE_SYSCALL_GETRANDOM)
  606. /* Obtain entropy on Linux 3.17+ */
  607. static int
  608. writeRandomBytes_getrandom_nonblock(void * target, size_t count) {
  609. int success = 0; /* full count bytes written? */
  610. size_t bytesWrittenTotal = 0;
  611. const unsigned int getrandomFlags = GRND_NONBLOCK;
  612. do {
  613. void * const currentTarget = (void*)((char*)target + bytesWrittenTotal);
  614. const size_t bytesToWrite = count - bytesWrittenTotal;
  615. const int bytesWrittenMore =
  616. #if defined(HAVE_GETRANDOM)
  617. getrandom(currentTarget, bytesToWrite, getrandomFlags);
  618. #else
  619. syscall(SYS_getrandom, currentTarget, bytesToWrite, getrandomFlags);
  620. #endif
  621. if (bytesWrittenMore > 0) {
  622. bytesWrittenTotal += bytesWrittenMore;
  623. if (bytesWrittenTotal >= count)
  624. success = 1;
  625. }
  626. } while (! success && (errno == EINTR));
  627. return success;
  628. }
  629. #endif /* defined(HAVE_GETRANDOM) || defined(HAVE_SYSCALL_GETRANDOM) */
  630. #if ! defined(_WIN32) && defined(XML_DEV_URANDOM)
  631. /* Extract entropy from /dev/urandom */
  632. static int
  633. writeRandomBytes_dev_urandom(void * target, size_t count) {
  634. int success = 0; /* full count bytes written? */
  635. size_t bytesWrittenTotal = 0;
  636. const int fd = open("/dev/urandom", O_RDONLY);
  637. if (fd < 0) {
  638. return 0;
  639. }
  640. do {
  641. void * const currentTarget = (void*)((char*)target + bytesWrittenTotal);
  642. const size_t bytesToWrite = count - bytesWrittenTotal;
  643. const ssize_t bytesWrittenMore = read(fd, currentTarget, bytesToWrite);
  644. if (bytesWrittenMore > 0) {
  645. bytesWrittenTotal += bytesWrittenMore;
  646. if (bytesWrittenTotal >= count)
  647. success = 1;
  648. }
  649. } while (! success && (errno == EINTR));
  650. close(fd);
  651. return success;
  652. }
  653. #endif /* ! defined(_WIN32) && defined(XML_DEV_URANDOM) */
  654. #endif /* ! defined(HAVE_ARC4RANDOM_BUF) && ! defined(HAVE_ARC4RANDOM) */
  655. #if defined(HAVE_ARC4RANDOM)
  656. static void
  657. writeRandomBytes_arc4random(void * target, size_t count) {
  658. size_t bytesWrittenTotal = 0;
  659. while (bytesWrittenTotal < count) {
  660. const uint32_t random32 = arc4random();
  661. size_t i = 0;
  662. for (; (i < sizeof(random32)) && (bytesWrittenTotal < count);
  663. i++, bytesWrittenTotal++) {
  664. const uint8_t random8 = (uint8_t)(random32 >> (i * 8));
  665. ((uint8_t *)target)[bytesWrittenTotal] = random8;
  666. }
  667. }
  668. }
  669. #endif /* defined(HAVE_ARC4RANDOM) */
  670. #ifdef _WIN32
  671. typedef BOOLEAN (APIENTRY *RTLGENRANDOM_FUNC)(PVOID, ULONG);
  672. HMODULE _Expat_LoadLibrary(LPCTSTR filename); /* see loadlibrary.c */
  673. /* Obtain entropy on Windows XP / Windows Server 2003 and later.
  674. * Hint on RtlGenRandom and the following article from libsodium.
  675. *
  676. * Michael Howard: Cryptographically Secure Random number on Windows without using CryptoAPI
  677. * https://blogs.msdn.microsoft.com/michael_howard/2005/01/14/cryptographically-secure-random-number-on-windows-without-using-cryptoapi/
  678. */
  679. static int
  680. writeRandomBytes_RtlGenRandom(void * target, size_t count) {
  681. int success = 0; /* full count bytes written? */
  682. const HMODULE advapi32 = _Expat_LoadLibrary(TEXT("ADVAPI32.DLL"));
  683. if (advapi32) {
  684. const RTLGENRANDOM_FUNC RtlGenRandom
  685. = (RTLGENRANDOM_FUNC)GetProcAddress(advapi32, "SystemFunction036");
  686. if (RtlGenRandom) {
  687. if (RtlGenRandom((PVOID)target, (ULONG)count) == TRUE) {
  688. success = 1;
  689. }
  690. }
  691. FreeLibrary(advapi32);
  692. }
  693. return success;
  694. }
  695. #endif /* _WIN32 */
  696. #if ! defined(HAVE_ARC4RANDOM_BUF) && ! defined(HAVE_ARC4RANDOM)
  697. static unsigned long
  698. gather_time_entropy(void)
  699. {
  700. #ifdef _WIN32
  701. FILETIME ft;
  702. GetSystemTimeAsFileTime(&ft); /* never fails */
  703. return ft.dwHighDateTime ^ ft.dwLowDateTime;
  704. #else
  705. struct timeval tv;
  706. int gettimeofday_res;
  707. gettimeofday_res = gettimeofday(&tv, NULL);
  708. #if defined(NDEBUG)
  709. (void)gettimeofday_res;
  710. #else
  711. assert (gettimeofday_res == 0);
  712. #endif /* defined(NDEBUG) */
  713. /* Microseconds time is <20 bits entropy */
  714. return tv.tv_usec;
  715. #endif
  716. }
  717. #endif /* ! defined(HAVE_ARC4RANDOM_BUF) && ! defined(HAVE_ARC4RANDOM) */
  718. static unsigned long
  719. ENTROPY_DEBUG(const char * label, unsigned long entropy) {
  720. const char * const EXPAT_ENTROPY_DEBUG = getenv("EXPAT_ENTROPY_DEBUG");
  721. if (EXPAT_ENTROPY_DEBUG && ! strcmp(EXPAT_ENTROPY_DEBUG, "1")) {
  722. fprintf(stderr, "Entropy: %s --> 0x%0*lx (%lu bytes)\n",
  723. label,
  724. (int)sizeof(entropy) * 2, entropy,
  725. (unsigned long)sizeof(entropy));
  726. }
  727. return entropy;
  728. }
  729. static unsigned long
  730. generate_hash_secret_salt(XML_Parser parser)
  731. {
  732. unsigned long entropy;
  733. (void)parser;
  734. /* "Failproof" high quality providers: */
  735. #if defined(HAVE_ARC4RANDOM_BUF)
  736. arc4random_buf(&entropy, sizeof(entropy));
  737. return ENTROPY_DEBUG("arc4random_buf", entropy);
  738. #elif defined(HAVE_ARC4RANDOM)
  739. writeRandomBytes_arc4random((void *)&entropy, sizeof(entropy));
  740. return ENTROPY_DEBUG("arc4random", entropy);
  741. #else
  742. /* Try high quality providers first .. */
  743. #ifdef _WIN32
  744. if (writeRandomBytes_RtlGenRandom((void *)&entropy, sizeof(entropy))) {
  745. return ENTROPY_DEBUG("RtlGenRandom", entropy);
  746. }
  747. #elif defined(HAVE_GETRANDOM) || defined(HAVE_SYSCALL_GETRANDOM)
  748. if (writeRandomBytes_getrandom_nonblock((void *)&entropy, sizeof(entropy))) {
  749. return ENTROPY_DEBUG("getrandom", entropy);
  750. }
  751. #endif
  752. #if ! defined(_WIN32) && defined(XML_DEV_URANDOM)
  753. if (writeRandomBytes_dev_urandom((void *)&entropy, sizeof(entropy))) {
  754. return ENTROPY_DEBUG("/dev/urandom", entropy);
  755. }
  756. #endif /* ! defined(_WIN32) && defined(XML_DEV_URANDOM) */
  757. /* .. and self-made low quality for backup: */
  758. /* Process ID is 0 bits entropy if attacker has local access */
  759. entropy = gather_time_entropy() ^ getpid();
  760. /* Factors are 2^31-1 and 2^61-1 (Mersenne primes M31 and M61) */
  761. if (sizeof(unsigned long) == 4) {
  762. return ENTROPY_DEBUG("fallback(4)", entropy * 2147483647);
  763. } else {
  764. return ENTROPY_DEBUG("fallback(8)",
  765. entropy * (unsigned long)2305843009213693951ULL);
  766. }
  767. #endif
  768. }
  769. static unsigned long
  770. get_hash_secret_salt(XML_Parser parser) {
  771. if (parser->m_parentParser != NULL)
  772. return get_hash_secret_salt(parser->m_parentParser);
  773. return parser->m_hash_secret_salt;
  774. }
  775. static XML_Bool /* only valid for root parser */
  776. startParsing(XML_Parser parser)
  777. {
  778. /* hash functions must be initialized before setContext() is called */
  779. if (parser->m_hash_secret_salt == 0)
  780. parser->m_hash_secret_salt = generate_hash_secret_salt(parser);
  781. if (parser->m_ns) {
  782. /* implicit context only set for root parser, since child
  783. parsers (i.e. external entity parsers) will inherit it
  784. */
  785. return setContext(parser, implicitContext);
  786. }
  787. return XML_TRUE;
  788. }
  789. XML_Parser XMLCALL
  790. XML_ParserCreate_MM(const XML_Char *encodingName,
  791. const XML_Memory_Handling_Suite *memsuite,
  792. const XML_Char *nameSep)
  793. {
  794. return parserCreate(encodingName, memsuite, nameSep, NULL);
  795. }
  796. static XML_Parser
  797. parserCreate(const XML_Char *encodingName,
  798. const XML_Memory_Handling_Suite *memsuite,
  799. const XML_Char *nameSep,
  800. DTD *dtd)
  801. {
  802. XML_Parser parser;
  803. if (memsuite) {
  804. XML_Memory_Handling_Suite *mtemp;
  805. parser = (XML_Parser)
  806. memsuite->malloc_fcn(sizeof(struct XML_ParserStruct));
  807. if (parser != NULL) {
  808. mtemp = (XML_Memory_Handling_Suite *)&(parser->m_mem);
  809. mtemp->malloc_fcn = memsuite->malloc_fcn;
  810. mtemp->realloc_fcn = memsuite->realloc_fcn;
  811. mtemp->free_fcn = memsuite->free_fcn;
  812. }
  813. }
  814. else {
  815. XML_Memory_Handling_Suite *mtemp;
  816. parser = (XML_Parser)malloc(sizeof(struct XML_ParserStruct));
  817. if (parser != NULL) {
  818. mtemp = (XML_Memory_Handling_Suite *)&(parser->m_mem);
  819. mtemp->malloc_fcn = malloc;
  820. mtemp->realloc_fcn = realloc;
  821. mtemp->free_fcn = free;
  822. }
  823. }
  824. if (!parser)
  825. return parser;
  826. parser->m_buffer = NULL;
  827. parser->m_bufferLim = NULL;
  828. parser->m_attsSize = INIT_ATTS_SIZE;
  829. parser->m_atts = (ATTRIBUTE *)MALLOC(parser, parser->m_attsSize * sizeof(ATTRIBUTE));
  830. if (parser->m_atts == NULL) {
  831. FREE(parser, parser);
  832. return NULL;
  833. }
  834. #ifdef XML_ATTR_INFO
  835. parser->m_attInfo = (XML_AttrInfo*)MALLOC(parser, parser->m_attsSize * sizeof(XML_AttrInfo));
  836. if (parser->m_attInfo == NULL) {
  837. FREE(parser, parser->m_atts);
  838. FREE(parser, parser);
  839. return NULL;
  840. }
  841. #endif
  842. parser->m_dataBuf = (XML_Char *)MALLOC(parser, INIT_DATA_BUF_SIZE * sizeof(XML_Char));
  843. if (parser->m_dataBuf == NULL) {
  844. FREE(parser, parser->m_atts);
  845. #ifdef XML_ATTR_INFO
  846. FREE(parser, parser->m_attInfo);
  847. #endif
  848. FREE(parser, parser);
  849. return NULL;
  850. }
  851. parser->m_dataBufEnd = parser->m_dataBuf + INIT_DATA_BUF_SIZE;
  852. if (dtd)
  853. parser->m_dtd = dtd;
  854. else {
  855. parser->m_dtd = dtdCreate(&parser->m_mem);
  856. if (parser->m_dtd == NULL) {
  857. FREE(parser, parser->m_dataBuf);
  858. FREE(parser, parser->m_atts);
  859. #ifdef XML_ATTR_INFO
  860. FREE(parser, parser->m_attInfo);
  861. #endif
  862. FREE(parser, parser);
  863. return NULL;
  864. }
  865. }
  866. parser->m_freeBindingList = NULL;
  867. parser->m_freeTagList = NULL;
  868. parser->m_freeInternalEntities = NULL;
  869. parser->m_groupSize = 0;
  870. parser->m_groupConnector = NULL;
  871. parser->m_unknownEncodingHandler = NULL;
  872. parser->m_unknownEncodingHandlerData = NULL;
  873. parser->m_namespaceSeparator = ASCII_EXCL;
  874. parser->m_ns = XML_FALSE;
  875. parser->m_ns_triplets = XML_FALSE;
  876. parser->m_nsAtts = NULL;
  877. parser->m_nsAttsVersion = 0;
  878. parser->m_nsAttsPower = 0;
  879. parser->m_protocolEncodingName = NULL;
  880. poolInit(&parser->m_tempPool, &(parser->m_mem));
  881. poolInit(&parser->m_temp2Pool, &(parser->m_mem));
  882. parserInit(parser, encodingName);
  883. if (encodingName && !parser->m_protocolEncodingName) {
  884. XML_ParserFree(parser);
  885. return NULL;
  886. }
  887. if (nameSep) {
  888. parser->m_ns = XML_TRUE;
  889. parser->m_internalEncoding = XmlGetInternalEncodingNS();
  890. parser->m_namespaceSeparator = *nameSep;
  891. }
  892. else {
  893. parser->m_internalEncoding = XmlGetInternalEncoding();
  894. }
  895. return parser;
  896. }
  897. static void
  898. parserInit(XML_Parser parser, const XML_Char *encodingName)
  899. {
  900. parser->m_processor = prologInitProcessor;
  901. XmlPrologStateInit(&parser->m_prologState);
  902. if (encodingName != NULL) {
  903. parser->m_protocolEncodingName = copyString(encodingName, &(parser->m_mem));
  904. }
  905. parser->m_curBase = NULL;
  906. XmlInitEncoding(&parser->m_initEncoding, &parser->m_encoding, 0);
  907. parser->m_userData = NULL;
  908. parser->m_handlerArg = NULL;
  909. parser->m_startElementHandler = NULL;
  910. parser->m_endElementHandler = NULL;
  911. parser->m_characterDataHandler = NULL;
  912. parser->m_processingInstructionHandler = NULL;
  913. parser->m_commentHandler = NULL;
  914. parser->m_startCdataSectionHandler = NULL;
  915. parser->m_endCdataSectionHandler = NULL;
  916. parser->m_defaultHandler = NULL;
  917. parser->m_startDoctypeDeclHandler = NULL;
  918. parser->m_endDoctypeDeclHandler = NULL;
  919. parser->m_unparsedEntityDeclHandler = NULL;
  920. parser->m_notationDeclHandler = NULL;
  921. parser->m_startNamespaceDeclHandler = NULL;
  922. parser->m_endNamespaceDeclHandler = NULL;
  923. parser->m_notStandaloneHandler = NULL;
  924. parser->m_externalEntityRefHandler = NULL;
  925. parser->m_externalEntityRefHandlerArg = parser;
  926. parser->m_skippedEntityHandler = NULL;
  927. parser->m_elementDeclHandler = NULL;
  928. parser->m_attlistDeclHandler = NULL;
  929. parser->m_entityDeclHandler = NULL;
  930. parser->m_xmlDeclHandler = NULL;
  931. parser->m_bufferPtr = parser->m_buffer;
  932. parser->m_bufferEnd = parser->m_buffer;
  933. parser->m_parseEndByteIndex = 0;
  934. parser->m_parseEndPtr = NULL;
  935. parser->m_declElementType = NULL;
  936. parser->m_declAttributeId = NULL;
  937. parser->m_declEntity = NULL;
  938. parser->m_doctypeName = NULL;
  939. parser->m_doctypeSysid = NULL;
  940. parser->m_doctypePubid = NULL;
  941. parser->m_declAttributeType = NULL;
  942. parser->m_declNotationName = NULL;
  943. parser->m_declNotationPublicId = NULL;
  944. parser->m_declAttributeIsCdata = XML_FALSE;
  945. parser->m_declAttributeIsId = XML_FALSE;
  946. memset(&parser->m_position, 0, sizeof(POSITION));
  947. parser->m_errorCode = XML_ERROR_NONE;
  948. parser->m_eventPtr = NULL;
  949. parser->m_eventEndPtr = NULL;
  950. parser->m_positionPtr = NULL;
  951. parser->m_openInternalEntities = NULL;
  952. parser->m_defaultExpandInternalEntities = XML_TRUE;
  953. parser->m_tagLevel = 0;
  954. parser->m_tagStack = NULL;
  955. parser->m_inheritedBindings = NULL;
  956. parser->m_nSpecifiedAtts = 0;
  957. parser->m_unknownEncodingMem = NULL;
  958. parser->m_unknownEncodingRelease = NULL;
  959. parser->m_unknownEncodingData = NULL;
  960. parser->m_parentParser = NULL;
  961. parser->m_parsingStatus.parsing = XML_INITIALIZED;
  962. #ifdef XML_DTD
  963. parser->m_isParamEntity = XML_FALSE;
  964. parser->m_useForeignDTD = XML_FALSE;
  965. parser->m_paramEntityParsing = XML_PARAM_ENTITY_PARSING_NEVER;
  966. #endif
  967. parser->m_hash_secret_salt = 0;
  968. }
  969. /* moves list of bindings to m_freeBindingList */
  970. static void FASTCALL
  971. moveToFreeBindingList(XML_Parser parser, BINDING *bindings)
  972. {
  973. while (bindings) {
  974. BINDING *b = bindings;
  975. bindings = bindings->nextTagBinding;
  976. b->nextTagBinding = parser->m_freeBindingList;
  977. parser->m_freeBindingList = b;
  978. }
  979. }
  980. XML_Bool XMLCALL
  981. XML_ParserReset(XML_Parser parser, const XML_Char *encodingName)
  982. {
  983. TAG *tStk;
  984. OPEN_INTERNAL_ENTITY *openEntityList;
  985. if (parser == NULL)
  986. return XML_FALSE;
  987. if (parser->m_parentParser)
  988. return XML_FALSE;
  989. /* move m_tagStack to m_freeTagList */
  990. tStk = parser->m_tagStack;
  991. while (tStk) {
  992. TAG *tag = tStk;
  993. tStk = tStk->parent;
  994. tag->parent = parser->m_freeTagList;
  995. moveToFreeBindingList(parser, tag->bindings);
  996. tag->bindings = NULL;
  997. parser->m_freeTagList = tag;
  998. }
  999. /* move m_openInternalEntities to m_freeInternalEntities */
  1000. openEntityList = parser->m_openInternalEntities;
  1001. while (openEntityList) {
  1002. OPEN_INTERNAL_ENTITY *openEntity = openEntityList;
  1003. openEntityList = openEntity->next;
  1004. openEntity->next = parser->m_freeInternalEntities;
  1005. parser->m_freeInternalEntities = openEntity;
  1006. }
  1007. moveToFreeBindingList(parser, parser->m_inheritedBindings);
  1008. FREE(parser, parser->m_unknownEncodingMem);
  1009. if (parser->m_unknownEncodingRelease)
  1010. parser->m_unknownEncodingRelease(parser->m_unknownEncodingData);
  1011. poolClear(&parser->m_tempPool);
  1012. poolClear(&parser->m_temp2Pool);
  1013. FREE(parser, (void *)parser->m_protocolEncodingName);
  1014. parser->m_protocolEncodingName = NULL;
  1015. parserInit(parser, encodingName);
  1016. dtdReset(parser->m_dtd, &parser->m_mem);
  1017. return XML_TRUE;
  1018. }
  1019. enum XML_Status XMLCALL
  1020. XML_SetEncoding(XML_Parser parser, const XML_Char *encodingName)
  1021. {
  1022. if (parser == NULL)
  1023. return XML_STATUS_ERROR;
  1024. /* Block after XML_Parse()/XML_ParseBuffer() has been called.
  1025. XXX There's no way for the caller to determine which of the
  1026. XXX possible error cases caused the XML_STATUS_ERROR return.
  1027. */
  1028. if (parser->m_parsingStatus.parsing == XML_PARSING || parser->m_parsingStatus.parsing == XML_SUSPENDED)
  1029. return XML_STATUS_ERROR;
  1030. /* Get rid of any previous encoding name */
  1031. FREE(parser, (void *)parser->m_protocolEncodingName);
  1032. if (encodingName == NULL)
  1033. /* No new encoding name */
  1034. parser->m_protocolEncodingName = NULL;
  1035. else {
  1036. /* Copy the new encoding name into allocated memory */
  1037. parser->m_protocolEncodingName = copyString(encodingName, &(parser->m_mem));
  1038. if (!parser->m_protocolEncodingName)
  1039. return XML_STATUS_ERROR;
  1040. }
  1041. return XML_STATUS_OK;
  1042. }
  1043. XML_Parser XMLCALL
  1044. XML_ExternalEntityParserCreate(XML_Parser oldParser,
  1045. const XML_Char *context,
  1046. const XML_Char *encodingName)
  1047. {
  1048. XML_Parser parser = oldParser;
  1049. DTD *newDtd = NULL;
  1050. DTD *oldDtd;
  1051. XML_StartElementHandler oldStartElementHandler;
  1052. XML_EndElementHandler oldEndElementHandler;
  1053. XML_CharacterDataHandler oldCharacterDataHandler;
  1054. XML_ProcessingInstructionHandler oldProcessingInstructionHandler;
  1055. XML_CommentHandler oldCommentHandler;
  1056. XML_StartCdataSectionHandler oldStartCdataSectionHandler;
  1057. XML_EndCdataSectionHandler oldEndCdataSectionHandler;
  1058. XML_DefaultHandler oldDefaultHandler;
  1059. XML_UnparsedEntityDeclHandler oldUnparsedEntityDeclHandler;
  1060. XML_NotationDeclHandler oldNotationDeclHandler;
  1061. XML_StartNamespaceDeclHandler oldStartNamespaceDeclHandler;
  1062. XML_EndNamespaceDeclHandler oldEndNamespaceDeclHandler;
  1063. XML_NotStandaloneHandler oldNotStandaloneHandler;
  1064. XML_ExternalEntityRefHandler oldExternalEntityRefHandler;
  1065. XML_SkippedEntityHandler oldSkippedEntityHandler;
  1066. XML_UnknownEncodingHandler oldUnknownEncodingHandler;
  1067. XML_ElementDeclHandler oldElementDeclHandler;
  1068. XML_AttlistDeclHandler oldAttlistDeclHandler;
  1069. XML_EntityDeclHandler oldEntityDeclHandler;
  1070. XML_XmlDeclHandler oldXmlDeclHandler;
  1071. ELEMENT_TYPE * oldDeclElementType;
  1072. void *oldUserData;
  1073. void *oldHandlerArg;
  1074. XML_Bool oldDefaultExpandInternalEntities;
  1075. XML_Parser oldExternalEntityRefHandlerArg;
  1076. #ifdef XML_DTD
  1077. enum XML_ParamEntityParsing oldParamEntityParsing;
  1078. int oldInEntityValue;
  1079. #endif
  1080. XML_Bool oldns_triplets;
  1081. /* Note that the new parser shares the same hash secret as the old
  1082. parser, so that dtdCopy and copyEntityTable can lookup values
  1083. from hash tables associated with either parser without us having
  1084. to worry which hash secrets each table has.
  1085. */
  1086. unsigned long oldhash_secret_salt;
  1087. /* Validate the oldParser parameter before we pull everything out of it */
  1088. if (oldParser == NULL)
  1089. return NULL;
  1090. /* Stash the original parser contents on the stack */
  1091. oldDtd = parser->m_dtd;
  1092. oldStartElementHandler = parser->m_startElementHandler;
  1093. oldEndElementHandler = parser->m_endElementHandler;
  1094. oldCharacterDataHandler = parser->m_characterDataHandler;
  1095. oldProcessingInstructionHandler = parser->m_processingInstructionHandler;
  1096. oldCommentHandler = parser->m_commentHandler;
  1097. oldStartCdataSectionHandler = parser->m_startCdataSectionHandler;
  1098. oldEndCdataSectionHandler = parser->m_endCdataSectionHandler;
  1099. oldDefaultHandler = parser->m_defaultHandler;
  1100. oldUnparsedEntityDeclHandler = parser->m_unparsedEntityDeclHandler;
  1101. oldNotationDeclHandler = parser->m_notationDeclHandler;
  1102. oldStartNamespaceDeclHandler = parser->m_startNamespaceDeclHandler;
  1103. oldEndNamespaceDeclHandler = parser->m_endNamespaceDeclHandler;
  1104. oldNotStandaloneHandler = parser->m_notStandaloneHandler;
  1105. oldExternalEntityRefHandler = parser->m_externalEntityRefHandler;
  1106. oldSkippedEntityHandler = parser->m_skippedEntityHandler;
  1107. oldUnknownEncodingHandler = parser->m_unknownEncodingHandler;
  1108. oldElementDeclHandler = parser->m_elementDeclHandler;
  1109. oldAttlistDeclHandler = parser->m_attlistDeclHandler;
  1110. oldEntityDeclHandler = parser->m_entityDeclHandler;
  1111. oldXmlDeclHandler = parser->m_xmlDeclHandler;
  1112. oldDeclElementType = parser->m_declElementType;
  1113. oldUserData = parser->m_userData;
  1114. oldHandlerArg = parser->m_handlerArg;
  1115. oldDefaultExpandInternalEntities = parser->m_defaultExpandInternalEntities;
  1116. oldExternalEntityRefHandlerArg = parser->m_externalEntityRefHandlerArg;
  1117. #ifdef XML_DTD
  1118. oldParamEntityParsing = parser->m_paramEntityParsing;
  1119. oldInEntityValue = parser->m_prologState.inEntityValue;
  1120. #endif
  1121. oldns_triplets = parser->m_ns_triplets;
  1122. /* Note that the new parser shares the same hash secret as the old
  1123. parser, so that dtdCopy and copyEntityTable can lookup values
  1124. from hash tables associated with either parser without us having
  1125. to worry which hash secrets each table has.
  1126. */
  1127. oldhash_secret_salt = parser->m_hash_secret_salt;
  1128. #ifdef XML_DTD
  1129. if (!context)
  1130. newDtd = oldDtd;
  1131. #endif /* XML_DTD */
  1132. /* Note that the magical uses of the pre-processor to make field
  1133. access look more like C++ require that `parser' be overwritten
  1134. here. This makes this function more painful to follow than it
  1135. would be otherwise.
  1136. */
  1137. if (parser->m_ns) {
  1138. XML_Char tmp[2];
  1139. *tmp = parser->m_namespaceSeparator;
  1140. parser = parserCreate(encodingName, &parser->m_mem, tmp, newDtd);
  1141. }
  1142. else {
  1143. parser = parserCreate(encodingName, &parser->m_mem, NULL, newDtd);
  1144. }
  1145. if (!parser)
  1146. return NULL;
  1147. parser->m_startElementHandler = oldStartElementHandler;
  1148. parser->m_endElementHandler = oldEndElementHandler;
  1149. parser->m_characterDataHandler = oldCharacterDataHandler;
  1150. parser->m_processingInstructionHandler = oldProcessingInstructionHandler;
  1151. parser->m_commentHandler = oldCommentHandler;
  1152. parser->m_startCdataSectionHandler = oldStartCdataSectionHandler;
  1153. parser->m_endCdataSectionHandler = oldEndCdataSectionHandler;
  1154. parser->m_defaultHandler = oldDefaultHandler;
  1155. parser->m_unparsedEntityDeclHandler = oldUnparsedEntityDeclHandler;
  1156. parser->m_notationDeclHandler = oldNotationDeclHandler;
  1157. parser->m_startNamespaceDeclHandler = oldStartNamespaceDeclHandler;
  1158. parser->m_endNamespaceDeclHandler = oldEndNamespaceDeclHandler;
  1159. parser->m_notStandaloneHandler = oldNotStandaloneHandler;
  1160. parser->m_externalEntityRefHandler = oldExternalEntityRefHandler;
  1161. parser->m_skippedEntityHandler = oldSkippedEntityHandler;
  1162. parser->m_unknownEncodingHandler = oldUnknownEncodingHandler;
  1163. parser->m_elementDeclHandler = oldElementDeclHandler;
  1164. parser->m_attlistDeclHandler = oldAttlistDeclHandler;
  1165. parser->m_entityDeclHandler = oldEntityDeclHandler;
  1166. parser->m_xmlDeclHandler = oldXmlDeclHandler;
  1167. parser->m_declElementType = oldDeclElementType;
  1168. parser->m_userData = oldUserData;
  1169. if (oldUserData == oldHandlerArg)
  1170. parser->m_handlerArg = parser->m_userData;
  1171. else
  1172. parser->m_handlerArg = parser;
  1173. if (oldExternalEntityRefHandlerArg != oldParser)
  1174. parser->m_externalEntityRefHandlerArg = oldExternalEntityRefHandlerArg;
  1175. parser->m_defaultExpandInternalEntities = oldDefaultExpandInternalEntities;
  1176. parser->m_ns_triplets = oldns_triplets;
  1177. parser->m_hash_secret_salt = oldhash_secret_salt;
  1178. parser->m_parentParser = oldParser;
  1179. #ifdef XML_DTD
  1180. parser->m_paramEntityParsing = oldParamEntityParsing;
  1181. parser->m_prologState.inEntityValue = oldInEntityValue;
  1182. if (context) {
  1183. #endif /* XML_DTD */
  1184. if (!dtdCopy(oldParser, parser->m_dtd, oldDtd, &parser->m_mem)
  1185. || !setContext(parser, context)) {
  1186. XML_ParserFree(parser);
  1187. return NULL;
  1188. }
  1189. parser->m_processor = externalEntityInitProcessor;
  1190. #ifdef XML_DTD
  1191. }
  1192. else {
  1193. /* The DTD instance referenced by parser->m_dtd is shared between the document's
  1194. root parser and external PE parsers, therefore one does not need to
  1195. call setContext. In addition, one also *must* not call setContext,
  1196. because this would overwrite existing prefix->binding pointers in
  1197. parser->m_dtd with ones that get destroyed with the external PE parser.
  1198. This would leave those prefixes with dangling pointers.
  1199. */
  1200. parser->m_isParamEntity = XML_TRUE;
  1201. XmlPrologStateInitExternalEntity(&parser->m_prologState);
  1202. parser->m_processor = externalParEntInitProcessor;
  1203. }
  1204. #endif /* XML_DTD */
  1205. return parser;
  1206. }
  1207. static void FASTCALL
  1208. destroyBindings(BINDING *bindings, XML_Parser parser)
  1209. {
  1210. for (;;) {
  1211. BINDING *b = bindings;
  1212. if (!b)
  1213. break;
  1214. bindings = b->nextTagBinding;
  1215. FREE(parser, b->uri);
  1216. FREE(parser, b);
  1217. }
  1218. }
  1219. void XMLCALL
  1220. XML_ParserFree(XML_Parser parser)
  1221. {
  1222. TAG *tagList;
  1223. OPEN_INTERNAL_ENTITY *entityList;
  1224. if (parser == NULL)
  1225. return;
  1226. /* free m_tagStack and m_freeTagList */
  1227. tagList = parser->m_tagStack;
  1228. for (;;) {
  1229. TAG *p;
  1230. if (tagList == NULL) {
  1231. if (parser->m_freeTagList == NULL)
  1232. break;
  1233. tagList = parser->m_freeTagList;
  1234. parser->m_freeTagList = NULL;
  1235. }
  1236. p = tagList;
  1237. tagList = tagList->parent;
  1238. FREE(parser, p->buf);
  1239. destroyBindings(p->bindings, parser);
  1240. FREE(parser, p);
  1241. }
  1242. /* free m_openInternalEntities and m_freeInternalEntities */
  1243. entityList = parser->m_openInternalEntities;
  1244. for (;;) {
  1245. OPEN_INTERNAL_ENTITY *openEntity;
  1246. if (entityList == NULL) {
  1247. if (parser->m_freeInternalEntities == NULL)
  1248. break;
  1249. entityList = parser->m_freeInternalEntities;
  1250. parser->m_freeInternalEntities = NULL;
  1251. }
  1252. openEntity = entityList;
  1253. entityList = entityList->next;
  1254. FREE(parser, openEntity);
  1255. }
  1256. destroyBindings(parser->m_freeBindingList, parser);
  1257. destroyBindings(parser->m_inheritedBindings, parser);
  1258. poolDestroy(&parser->m_tempPool);
  1259. poolDestroy(&parser->m_temp2Pool);
  1260. FREE(parser, (void *)parser->m_protocolEncodingName);
  1261. #ifdef XML_DTD
  1262. /* external parameter entity parsers share the DTD structure
  1263. parser->m_dtd with the root parser, so we must not destroy it
  1264. */
  1265. if (!parser->m_isParamEntity && parser->m_dtd)
  1266. #else
  1267. if (parser->m_dtd)
  1268. #endif /* XML_DTD */
  1269. dtdDestroy(parser->m_dtd, (XML_Bool)!parser->m_parentParser, &parser->m_mem);
  1270. FREE(parser, (void *)parser->m_atts);
  1271. #ifdef XML_ATTR_INFO
  1272. FREE(parser, (void *)parser->m_attInfo);
  1273. #endif
  1274. FREE(parser, parser->m_groupConnector);
  1275. FREE(parser, parser->m_buffer);
  1276. FREE(parser, parser->m_dataBuf);
  1277. FREE(parser, parser->m_nsAtts);
  1278. FREE(parser, parser->m_unknownEncodingMem);
  1279. if (parser->m_unknownEncodingRelease)
  1280. parser->m_unknownEncodingRelease(parser->m_unknownEncodingData);
  1281. FREE(parser, parser);
  1282. }
  1283. void XMLCALL
  1284. XML_UseParserAsHandlerArg(XML_Parser parser)
  1285. {
  1286. if (parser != NULL)
  1287. parser->m_handlerArg = parser;
  1288. }
  1289. enum XML_Error XMLCALL
  1290. XML_UseForeignDTD(XML_Parser parser, XML_Bool useDTD)
  1291. {
  1292. if (parser == NULL)
  1293. return XML_ERROR_INVALID_ARGUMENT;
  1294. #ifdef XML_DTD
  1295. /* block after XML_Parse()/XML_ParseBuffer() has been called */
  1296. if (parser->m_parsingStatus.parsing == XML_PARSING || parser->m_parsingStatus.parsing == XML_SUSPENDED)
  1297. return XML_ERROR_CANT_CHANGE_FEATURE_ONCE_PARSING;
  1298. parser->m_useForeignDTD = useDTD;
  1299. return XML_ERROR_NONE;
  1300. #else
  1301. return XML_ERROR_FEATURE_REQUIRES_XML_DTD;
  1302. #endif
  1303. }
  1304. void XMLCALL
  1305. XML_SetReturnNSTriplet(XML_Parser parser, int do_nst)
  1306. {
  1307. if (parser == NULL)
  1308. return;
  1309. /* block after XML_Parse()/XML_ParseBuffer() has been called */
  1310. if (parser->m_parsingStatus.parsing == XML_PARSING || parser->m_parsingStatus.parsing == XML_SUSPENDED)
  1311. return;
  1312. parser->m_ns_triplets = do_nst ? XML_TRUE : XML_FALSE;
  1313. }
  1314. void XMLCALL
  1315. XML_SetUserData(XML_Parser parser, void *p)
  1316. {
  1317. if (parser == NULL)
  1318. return;
  1319. if (parser->m_handlerArg == parser->m_userData)
  1320. parser->m_handlerArg = parser->m_userData = p;
  1321. else
  1322. parser->m_userData = p;
  1323. }
  1324. enum XML_Status XMLCALL
  1325. XML_SetBase(XML_Parser parser, const XML_Char *p)
  1326. {
  1327. if (parser == NULL)
  1328. return XML_STATUS_ERROR;
  1329. if (p) {
  1330. p = poolCopyString(&parser->m_dtd->pool, p);
  1331. if (!p)
  1332. return XML_STATUS_ERROR;
  1333. parser->m_curBase = p;
  1334. }
  1335. else
  1336. parser->m_curBase = NULL;
  1337. return XML_STATUS_OK;
  1338. }
  1339. const XML_Char * XMLCALL
  1340. XML_GetBase(XML_Parser parser)
  1341. {
  1342. if (parser == NULL)
  1343. return NULL;
  1344. return parser->m_curBase;
  1345. }
  1346. int XMLCALL
  1347. XML_GetSpecifiedAttributeCount(XML_Parser parser)
  1348. {
  1349. if (parser == NULL)
  1350. return -1;
  1351. return parser->m_nSpecifiedAtts;
  1352. }
  1353. int XMLCALL
  1354. XML_GetIdAttributeIndex(XML_Parser parser)
  1355. {
  1356. if (parser == NULL)
  1357. return -1;
  1358. return parser->m_idAttIndex;
  1359. }
  1360. #ifdef XML_ATTR_INFO
  1361. const XML_AttrInfo * XMLCALL
  1362. XML_GetAttributeInfo(XML_Parser parser)
  1363. {
  1364. if (parser == NULL)
  1365. return NULL;
  1366. return parser->m_attInfo;
  1367. }
  1368. #endif
  1369. void XMLCALL
  1370. XML_SetElementHandler(XML_Parser parser,
  1371. XML_StartElementHandler start,
  1372. XML_EndElementHandler end)
  1373. {
  1374. if (parser == NULL)
  1375. return;
  1376. parser->m_startElementHandler = start;
  1377. parser->m_endElementHandler = end;
  1378. }
  1379. void XMLCALL
  1380. XML_SetStartElementHandler(XML_Parser parser,
  1381. XML_StartElementHandler start) {
  1382. if (parser != NULL)
  1383. parser->m_startElementHandler = start;
  1384. }
  1385. void XMLCALL
  1386. XML_SetEndElementHandler(XML_Parser parser,
  1387. XML_EndElementHandler end) {
  1388. if (parser != NULL)
  1389. parser->m_endElementHandler = end;
  1390. }
  1391. void XMLCALL
  1392. XML_SetCharacterDataHandler(XML_Parser parser,
  1393. XML_CharacterDataHandler handler)
  1394. {
  1395. if (parser != NULL)
  1396. parser->m_characterDataHandler = handler;
  1397. }
  1398. void XMLCALL
  1399. XML_SetProcessingInstructionHandler(XML_Parser parser,
  1400. XML_ProcessingInstructionHandler handler)
  1401. {
  1402. if (parser != NULL)
  1403. parser->m_processingInstructionHandler = handler;
  1404. }
  1405. void XMLCALL
  1406. XML_SetCommentHandler(XML_Parser parser,
  1407. XML_CommentHandler handler)
  1408. {
  1409. if (parser != NULL)
  1410. parser->m_commentHandler = handler;
  1411. }
  1412. void XMLCALL
  1413. XML_SetCdataSectionHandler(XML_Parser parser,
  1414. XML_StartCdataSectionHandler start,
  1415. XML_EndCdataSectionHandler end)
  1416. {
  1417. if (parser == NULL)
  1418. return;
  1419. parser->m_startCdataSectionHandler = start;
  1420. parser->m_endCdataSectionHandler = end;
  1421. }
  1422. void XMLCALL
  1423. XML_SetStartCdataSectionHandler(XML_Parser parser,
  1424. XML_StartCdataSectionHandler start) {
  1425. if (parser != NULL)
  1426. parser->m_startCdataSectionHandler = start;
  1427. }
  1428. void XMLCALL
  1429. XML_SetEndCdataSectionHandler(XML_Parser parser,
  1430. XML_EndCdataSectionHandler end) {
  1431. if (parser != NULL)
  1432. parser->m_endCdataSectionHandler = end;
  1433. }
  1434. void XMLCALL
  1435. XML_SetDefaultHandler(XML_Parser parser,
  1436. XML_DefaultHandler handler)
  1437. {
  1438. if (parser == NULL)
  1439. return;
  1440. parser->m_defaultHandler = handler;
  1441. parser->m_defaultExpandInternalEntities = XML_FALSE;
  1442. }
  1443. void XMLCALL
  1444. XML_SetDefaultHandlerExpand(XML_Parser parser,
  1445. XML_DefaultHandler handler)
  1446. {
  1447. if (parser == NULL)
  1448. return;
  1449. parser->m_defaultHandler = handler;
  1450. parser->m_defaultExpandInternalEntities = XML_TRUE;
  1451. }
  1452. void XMLCALL
  1453. XML_SetDoctypeDeclHandler(XML_Parser parser,
  1454. XML_StartDoctypeDeclHandler start,
  1455. XML_EndDoctypeDeclHandler end)
  1456. {
  1457. if (parser == NULL)
  1458. return;
  1459. parser->m_startDoctypeDeclHandler = start;
  1460. parser->m_endDoctypeDeclHandler = end;
  1461. }
  1462. void XMLCALL
  1463. XML_SetStartDoctypeDeclHandler(XML_Parser parser,
  1464. XML_StartDoctypeDeclHandler start) {
  1465. if (parser != NULL)
  1466. parser->m_startDoctypeDeclHandler = start;
  1467. }
  1468. void XMLCALL
  1469. XML_SetEndDoctypeDeclHandler(XML_Parser parser,
  1470. XML_EndDoctypeDeclHandler end) {
  1471. if (parser != NULL)
  1472. parser->m_endDoctypeDeclHandler = end;
  1473. }
  1474. void XMLCALL
  1475. XML_SetUnparsedEntityDeclHandler(XML_Parser parser,
  1476. XML_UnparsedEntityDeclHandler handler)
  1477. {
  1478. if (parser != NULL)
  1479. parser->m_unparsedEntityDeclHandler = handler;
  1480. }
  1481. void XMLCALL
  1482. XML_SetNotationDeclHandler(XML_Parser parser,
  1483. XML_NotationDeclHandler handler)
  1484. {
  1485. if (parser != NULL)
  1486. parser->m_notationDeclHandler = handler;
  1487. }
  1488. void XMLCALL
  1489. XML_SetNamespaceDeclHandler(XML_Parser parser,
  1490. XML_StartNamespaceDeclHandler start,
  1491. XML_EndNamespaceDeclHandler end)
  1492. {
  1493. if (parser == NULL)
  1494. return;
  1495. parser->m_startNamespaceDeclHandler = start;
  1496. parser->m_endNamespaceDeclHandler = end;
  1497. }
  1498. void XMLCALL
  1499. XML_SetStartNamespaceDeclHandler(XML_Parser parser,
  1500. XML_StartNamespaceDeclHandler start) {
  1501. if (parser != NULL)
  1502. parser->m_startNamespaceDeclHandler = start;
  1503. }
  1504. void XMLCALL
  1505. XML_SetEndNamespaceDeclHandler(XML_Parser parser,
  1506. XML_EndNamespaceDeclHandler end) {
  1507. if (parser != NULL)
  1508. parser->m_endNamespaceDeclHandler = end;
  1509. }
  1510. void XMLCALL
  1511. XML_SetNotStandaloneHandler(XML_Parser parser,
  1512. XML_NotStandaloneHandler handler)
  1513. {
  1514. if (parser != NULL)
  1515. parser->m_notStandaloneHandler = handler;
  1516. }
  1517. void XMLCALL
  1518. XML_SetExternalEntityRefHandler(XML_Parser parser,
  1519. XML_ExternalEntityRefHandler handler)
  1520. {
  1521. if (parser != NULL)
  1522. parser->m_externalEntityRefHandler = handler;
  1523. }
  1524. void XMLCALL
  1525. XML_SetExternalEntityRefHandlerArg(XML_Parser parser, void *arg)
  1526. {
  1527. if (parser == NULL)
  1528. return;
  1529. if (arg)
  1530. parser->m_externalEntityRefHandlerArg = (XML_Parser)arg;
  1531. else
  1532. parser->m_externalEntityRefHandlerArg = parser;
  1533. }
  1534. void XMLCALL
  1535. XML_SetSkippedEntityHandler(XML_Parser parser,
  1536. XML_SkippedEntityHandler handler)
  1537. {
  1538. if (parser != NULL)
  1539. parser->m_skippedEntityHandler = handler;
  1540. }
  1541. void XMLCALL
  1542. XML_SetUnknownEncodingHandler(XML_Parser parser,
  1543. XML_UnknownEncodingHandler handler,
  1544. void *data)
  1545. {
  1546. if (parser == NULL)
  1547. return;
  1548. parser->m_unknownEncodingHandler = handler;
  1549. parser->m_unknownEncodingHandlerData = data;
  1550. }
  1551. void XMLCALL
  1552. XML_SetElementDeclHandler(XML_Parser parser,
  1553. XML_ElementDeclHandler eldecl)
  1554. {
  1555. if (parser != NULL)
  1556. parser->m_elementDeclHandler = eldecl;
  1557. }
  1558. void XMLCALL
  1559. XML_SetAttlistDeclHandler(XML_Parser parser,
  1560. XML_AttlistDeclHandler attdecl)
  1561. {
  1562. if (parser != NULL)
  1563. parser->m_attlistDeclHandler = attdecl;
  1564. }
  1565. void XMLCALL
  1566. XML_SetEntityDeclHandler(XML_Parser parser,
  1567. XML_EntityDeclHandler handler)
  1568. {
  1569. if (parser != NULL)
  1570. parser->m_entityDeclHandler = handler;
  1571. }
  1572. void XMLCALL
  1573. XML_SetXmlDeclHandler(XML_Parser parser,
  1574. XML_XmlDeclHandler handler) {
  1575. if (parser != NULL)
  1576. parser->m_xmlDeclHandler = handler;
  1577. }
  1578. int XMLCALL
  1579. XML_SetParamEntityParsing(XML_Parser parser,
  1580. enum XML_ParamEntityParsing peParsing)
  1581. {
  1582. if (parser == NULL)
  1583. return 0;
  1584. /* block after XML_Parse()/XML_ParseBuffer() has been called */
  1585. if (parser->m_parsingStatus.parsing == XML_PARSING || parser->m_parsingStatus.parsing == XML_SUSPENDED)
  1586. return 0;
  1587. #ifdef XML_DTD
  1588. parser->m_paramEntityParsing = peParsing;
  1589. return 1;
  1590. #else
  1591. return peParsing == XML_PARAM_ENTITY_PARSING_NEVER;
  1592. #endif
  1593. }
  1594. int XMLCALL
  1595. XML_SetHashSalt(XML_Parser parser,
  1596. unsigned long hash_salt)
  1597. {
  1598. if (parser == NULL)
  1599. return 0;
  1600. if (parser->m_parentParser)
  1601. return XML_SetHashSalt(parser->m_parentParser, hash_salt);
  1602. /* block after XML_Parse()/XML_ParseBuffer() has been called */
  1603. if (parser->m_parsingStatus.parsing == XML_PARSING || parser->m_parsingStatus.parsing == XML_SUSPENDED)
  1604. return 0;
  1605. parser->m_hash_secret_salt = hash_salt;
  1606. return 1;
  1607. }
  1608. enum XML_Status XMLCALL
  1609. XML_Parse(XML_Parser parser, const char *s, int len, int isFinal)
  1610. {
  1611. if ((parser == NULL) || (len < 0) || ((s == NULL) && (len != 0))) {
  1612. if (parser != NULL)
  1613. parser->m_errorCode = XML_ERROR_INVALID_ARGUMENT;
  1614. return XML_STATUS_ERROR;
  1615. }
  1616. switch (parser->m_parsingStatus.parsing) {
  1617. case XML_SUSPENDED:
  1618. parser->m_errorCode = XML_ERROR_SUSPENDED;
  1619. return XML_STATUS_ERROR;
  1620. case XML_FINISHED:
  1621. parser->m_errorCode = XML_ERROR_FINISHED;
  1622. return XML_STATUS_ERROR;
  1623. case XML_INITIALIZED:
  1624. if (parser->m_parentParser == NULL && !startParsing(parser)) {
  1625. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1626. return XML_STATUS_ERROR;
  1627. }
  1628. /* fall through */
  1629. default:
  1630. parser->m_parsingStatus.parsing = XML_PARSING;
  1631. }
  1632. if (len == 0) {
  1633. parser->m_parsingStatus.finalBuffer = (XML_Bool)isFinal;
  1634. if (!isFinal)
  1635. return XML_STATUS_OK;
  1636. parser->m_positionPtr = parser->m_bufferPtr;
  1637. parser->m_parseEndPtr = parser->m_bufferEnd;
  1638. /* If data are left over from last buffer, and we now know that these
  1639. data are the final chunk of input, then we have to check them again
  1640. to detect errors based on that fact.
  1641. */
  1642. parser->m_errorCode = parser->m_processor(parser, parser->m_bufferPtr, parser->m_parseEndPtr, &parser->m_bufferPtr);
  1643. if (parser->m_errorCode == XML_ERROR_NONE) {
  1644. switch (parser->m_parsingStatus.parsing) {
  1645. case XML_SUSPENDED:
  1646. /* It is hard to be certain, but it seems that this case
  1647. * cannot occur. This code is cleaning up a previous parse
  1648. * with no new data (since len == 0). Changing the parsing
  1649. * state requires getting to execute a handler function, and
  1650. * there doesn't seem to be an opportunity for that while in
  1651. * this circumstance.
  1652. *
  1653. * Given the uncertainty, we retain the code but exclude it
  1654. * from coverage tests.
  1655. *
  1656. * LCOV_EXCL_START
  1657. */
  1658. XmlUpdatePosition(parser->m_encoding, parser->m_positionPtr, parser->m_bufferPtr, &parser->m_position);
  1659. parser->m_positionPtr = parser->m_bufferPtr;
  1660. return XML_STATUS_SUSPENDED;
  1661. /* LCOV_EXCL_STOP */
  1662. case XML_INITIALIZED:
  1663. case XML_PARSING:
  1664. parser->m_parsingStatus.parsing = XML_FINISHED;
  1665. /* fall through */
  1666. default:
  1667. return XML_STATUS_OK;
  1668. }
  1669. }
  1670. parser->m_eventEndPtr = parser->m_eventPtr;
  1671. parser->m_processor = errorProcessor;
  1672. return XML_STATUS_ERROR;
  1673. }
  1674. #ifndef XML_CONTEXT_BYTES
  1675. else if (parser->m_bufferPtr == parser->m_bufferEnd) {
  1676. const char *end;
  1677. int nLeftOver;
  1678. enum XML_Status result;
  1679. /* Detect overflow (a+b > MAX <==> b > MAX-a) */
  1680. if (len > ((XML_Size)-1) / 2 - parser->m_parseEndByteIndex) {
  1681. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1682. parser->m_eventPtr = parser->m_eventEndPtr = NULL;
  1683. parser->m_processor = errorProcessor;
  1684. return XML_STATUS_ERROR;
  1685. }
  1686. parser->m_parseEndByteIndex += len;
  1687. parser->m_positionPtr = s;
  1688. parser->m_parsingStatus.finalBuffer = (XML_Bool)isFinal;
  1689. parser->m_errorCode = parser->m_processor(parser, s, parser->m_parseEndPtr = s + len, &end);
  1690. if (parser->m_errorCode != XML_ERROR_NONE) {
  1691. parser->m_eventEndPtr = parser->m_eventPtr;
  1692. parser->m_processor = errorProcessor;
  1693. return XML_STATUS_ERROR;
  1694. }
  1695. else {
  1696. switch (parser->m_parsingStatus.parsing) {
  1697. case XML_SUSPENDED:
  1698. result = XML_STATUS_SUSPENDED;
  1699. break;
  1700. case XML_INITIALIZED:
  1701. case XML_PARSING:
  1702. if (isFinal) {
  1703. parser->m_parsingStatus.parsing = XML_FINISHED;
  1704. return XML_STATUS_OK;
  1705. }
  1706. /* fall through */
  1707. default:
  1708. result = XML_STATUS_OK;
  1709. }
  1710. }
  1711. XmlUpdatePosition(parser->m_encoding, parser->m_positionPtr, end, &parser->m_position);
  1712. nLeftOver = s + len - end;
  1713. if (nLeftOver) {
  1714. if (parser->m_buffer == NULL || nLeftOver > parser->m_bufferLim - parser->m_buffer) {
  1715. /* avoid _signed_ integer overflow */
  1716. char *temp = NULL;
  1717. const int bytesToAllocate = (int)((unsigned)len * 2U);
  1718. if (bytesToAllocate > 0) {
  1719. temp = (char *)REALLOC(parser, parser->m_buffer, bytesToAllocate);
  1720. }
  1721. if (temp == NULL) {
  1722. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1723. parser->m_eventPtr = parser->m_eventEndPtr = NULL;
  1724. parser->m_processor = errorProcessor;
  1725. return XML_STATUS_ERROR;
  1726. }
  1727. parser->m_buffer = temp;
  1728. parser->m_bufferLim = parser->m_buffer + bytesToAllocate;
  1729. }
  1730. memcpy(parser->m_buffer, end, nLeftOver);
  1731. }
  1732. parser->m_bufferPtr = parser->m_buffer;
  1733. parser->m_bufferEnd = parser->m_buffer + nLeftOver;
  1734. parser->m_positionPtr = parser->m_bufferPtr;
  1735. parser->m_parseEndPtr = parser->m_bufferEnd;
  1736. parser->m_eventPtr = parser->m_bufferPtr;
  1737. parser->m_eventEndPtr = parser->m_bufferPtr;
  1738. return result;
  1739. }
  1740. #endif /* not defined XML_CONTEXT_BYTES */
  1741. else {
  1742. void *buff = XML_GetBuffer(parser, len);
  1743. if (buff == NULL)
  1744. return XML_STATUS_ERROR;
  1745. else {
  1746. memcpy(buff, s, len);
  1747. return XML_ParseBuffer(parser, len, isFinal);
  1748. }
  1749. }
  1750. }
  1751. enum XML_Status XMLCALL
  1752. XML_ParseBuffer(XML_Parser parser, int len, int isFinal)
  1753. {
  1754. const char *start;
  1755. enum XML_Status result = XML_STATUS_OK;
  1756. if (parser == NULL)
  1757. return XML_STATUS_ERROR;
  1758. switch (parser->m_parsingStatus.parsing) {
  1759. case XML_SUSPENDED:
  1760. parser->m_errorCode = XML_ERROR_SUSPENDED;
  1761. return XML_STATUS_ERROR;
  1762. case XML_FINISHED:
  1763. parser->m_errorCode = XML_ERROR_FINISHED;
  1764. return XML_STATUS_ERROR;
  1765. case XML_INITIALIZED:
  1766. if (parser->m_parentParser == NULL && !startParsing(parser)) {
  1767. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1768. return XML_STATUS_ERROR;
  1769. }
  1770. /* fall through */
  1771. default:
  1772. parser->m_parsingStatus.parsing = XML_PARSING;
  1773. }
  1774. start = parser->m_bufferPtr;
  1775. parser->m_positionPtr = start;
  1776. parser->m_bufferEnd += len;
  1777. parser->m_parseEndPtr = parser->m_bufferEnd;
  1778. parser->m_parseEndByteIndex += len;
  1779. parser->m_parsingStatus.finalBuffer = (XML_Bool)isFinal;
  1780. parser->m_errorCode = parser->m_processor(parser, start, parser->m_parseEndPtr, &parser->m_bufferPtr);
  1781. if (parser->m_errorCode != XML_ERROR_NONE) {
  1782. parser->m_eventEndPtr = parser->m_eventPtr;
  1783. parser->m_processor = errorProcessor;
  1784. return XML_STATUS_ERROR;
  1785. }
  1786. else {
  1787. switch (parser->m_parsingStatus.parsing) {
  1788. case XML_SUSPENDED:
  1789. result = XML_STATUS_SUSPENDED;
  1790. break;
  1791. case XML_INITIALIZED:
  1792. case XML_PARSING:
  1793. if (isFinal) {
  1794. parser->m_parsingStatus.parsing = XML_FINISHED;
  1795. return result;
  1796. }
  1797. default: ; /* should not happen */
  1798. }
  1799. }
  1800. XmlUpdatePosition(parser->m_encoding, parser->m_positionPtr, parser->m_bufferPtr, &parser->m_position);
  1801. parser->m_positionPtr = parser->m_bufferPtr;
  1802. return result;
  1803. }
  1804. void * XMLCALL
  1805. XML_GetBuffer(XML_Parser parser, int len)
  1806. {
  1807. if (parser == NULL)
  1808. return NULL;
  1809. if (len < 0) {
  1810. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1811. return NULL;
  1812. }
  1813. switch (parser->m_parsingStatus.parsing) {
  1814. case XML_SUSPENDED:
  1815. parser->m_errorCode = XML_ERROR_SUSPENDED;
  1816. return NULL;
  1817. case XML_FINISHED:
  1818. parser->m_errorCode = XML_ERROR_FINISHED;
  1819. return NULL;
  1820. default: ;
  1821. }
  1822. if (len > EXPAT_SAFE_PTR_DIFF(parser->m_bufferLim, parser->m_bufferEnd)) {
  1823. #ifdef XML_CONTEXT_BYTES
  1824. int keep;
  1825. #endif /* defined XML_CONTEXT_BYTES */
  1826. /* Do not invoke signed arithmetic overflow: */
  1827. int neededSize = (int) ((unsigned)len +
  1828. (unsigned)EXPAT_SAFE_PTR_DIFF(parser->m_bufferEnd,
  1829. parser->m_bufferPtr));
  1830. if (neededSize < 0) {
  1831. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1832. return NULL;
  1833. }
  1834. #ifdef XML_CONTEXT_BYTES
  1835. keep = (int)EXPAT_SAFE_PTR_DIFF(parser->m_bufferPtr, parser->m_buffer);
  1836. if (keep > XML_CONTEXT_BYTES)
  1837. keep = XML_CONTEXT_BYTES;
  1838. neededSize += keep;
  1839. #endif /* defined XML_CONTEXT_BYTES */
  1840. if (neededSize <= EXPAT_SAFE_PTR_DIFF(parser->m_bufferLim, parser->m_buffer)) {
  1841. #ifdef XML_CONTEXT_BYTES
  1842. if (keep < EXPAT_SAFE_PTR_DIFF(parser->m_bufferPtr, parser->m_buffer)) {
  1843. int offset = (int)EXPAT_SAFE_PTR_DIFF(parser->m_bufferPtr, parser->m_buffer) - keep;
  1844. /* The buffer pointers cannot be NULL here; we have at least some bytes in the buffer */
  1845. memmove(parser->m_buffer, &parser->m_buffer[offset], parser->m_bufferEnd - parser->m_bufferPtr + keep);
  1846. parser->m_bufferEnd -= offset;
  1847. parser->m_bufferPtr -= offset;
  1848. }
  1849. #else
  1850. if (parser->m_buffer && parser->m_bufferPtr) {
  1851. memmove(parser->m_buffer, parser->m_bufferPtr,
  1852. EXPAT_SAFE_PTR_DIFF(parser->m_bufferEnd, parser->m_bufferPtr));
  1853. parser->m_bufferEnd = parser->m_buffer +
  1854. EXPAT_SAFE_PTR_DIFF(parser->m_bufferEnd, parser->m_bufferPtr);
  1855. parser->m_bufferPtr = parser->m_buffer;
  1856. }
  1857. #endif /* not defined XML_CONTEXT_BYTES */
  1858. }
  1859. else {
  1860. char *newBuf;
  1861. int bufferSize = (int)EXPAT_SAFE_PTR_DIFF(parser->m_bufferLim, parser->m_bufferPtr);
  1862. if (bufferSize == 0)
  1863. bufferSize = INIT_BUFFER_SIZE;
  1864. do {
  1865. /* Do not invoke signed arithmetic overflow: */
  1866. bufferSize = (int) (2U * (unsigned) bufferSize);
  1867. } while (bufferSize < neededSize && bufferSize > 0);
  1868. if (bufferSize <= 0) {
  1869. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1870. return NULL;
  1871. }
  1872. newBuf = (char *)MALLOC(parser, bufferSize);
  1873. if (newBuf == 0) {
  1874. parser->m_errorCode = XML_ERROR_NO_MEMORY;
  1875. return NULL;
  1876. }
  1877. parser->m_bufferLim = newBuf + bufferSize;
  1878. #ifdef XML_CONTEXT_BYTES
  1879. if (parser->m_bufferPtr) {
  1880. int keep = (int)EXPAT_SAFE_PTR_DIFF(parser->m_bufferPtr, parser->m_buffer);
  1881. if (keep > XML_CONTEXT_BYTES)
  1882. keep = XML_CONTEXT_BYTES;
  1883. memcpy(newBuf, &parser->m_bufferPtr[-keep],
  1884. EXPAT_SAFE_PTR_DIFF(parser->m_bufferEnd, parser->m_bufferPtr) + keep);
  1885. FREE(parser, parser->m_buffer);
  1886. parser->m_buffer = newBuf;
  1887. parser->m_bufferEnd = parser->m_buffer +
  1888. EXPAT_SAFE_PTR_DIFF(parser->m_bufferEnd, parser->m_bufferPtr) + keep;
  1889. parser->m_bufferPtr = parser->m_buffer + keep;
  1890. }
  1891. else {
  1892. /* This must be a brand new buffer with no data in it yet */
  1893. parser->m_bufferEnd = newBuf;
  1894. parser->m_bufferPtr = parser->m_buffer = newBuf;
  1895. }
  1896. #else
  1897. if (parser->m_bufferPtr) {
  1898. memcpy(newBuf, parser->m_bufferPtr,
  1899. EXPAT_SAFE_PTR_DIFF(parser->m_bufferEnd, parser->m_bufferPtr));
  1900. FREE(parser, parser->m_buffer);
  1901. parser->m_bufferEnd = newBuf +
  1902. EXPAT_SAFE_PTR_DIFF(parser->m_bufferEnd, parser->m_bufferPtr);
  1903. }
  1904. else {
  1905. /* This must be a brand new buffer with no data in it yet */
  1906. parser->m_bufferEnd = newBuf;
  1907. }
  1908. parser->m_bufferPtr = parser->m_buffer = newBuf;
  1909. #endif /* not defined XML_CONTEXT_BYTES */
  1910. }
  1911. parser->m_eventPtr = parser->m_eventEndPtr = NULL;
  1912. parser->m_positionPtr = NULL;
  1913. }
  1914. return parser->m_bufferEnd;
  1915. }
  1916. enum XML_Status XMLCALL
  1917. XML_StopParser(XML_Parser parser, XML_Bool resumable)
  1918. {
  1919. if (parser == NULL)
  1920. return XML_STATUS_ERROR;
  1921. switch (parser->m_parsingStatus.parsing) {
  1922. case XML_SUSPENDED:
  1923. if (resumable) {
  1924. parser->m_errorCode = XML_ERROR_SUSPENDED;
  1925. return XML_STATUS_ERROR;
  1926. }
  1927. parser->m_parsingStatus.parsing = XML_FINISHED;
  1928. break;
  1929. case XML_FINISHED:
  1930. parser->m_errorCode = XML_ERROR_FINISHED;
  1931. return XML_STATUS_ERROR;
  1932. default:
  1933. if (resumable) {
  1934. #ifdef XML_DTD
  1935. if (parser->m_isParamEntity) {
  1936. parser->m_errorCode = XML_ERROR_SUSPEND_PE;
  1937. return XML_STATUS_ERROR;
  1938. }
  1939. #endif
  1940. parser->m_parsingStatus.parsing = XML_SUSPENDED;
  1941. }
  1942. else
  1943. parser->m_parsingStatus.parsing = XML_FINISHED;
  1944. }
  1945. return XML_STATUS_OK;
  1946. }
  1947. enum XML_Status XMLCALL
  1948. XML_ResumeParser(XML_Parser parser)
  1949. {
  1950. enum XML_Status result = XML_STATUS_OK;
  1951. if (parser == NULL)
  1952. return XML_STATUS_ERROR;
  1953. if (parser->m_parsingStatus.parsing != XML_SUSPENDED) {
  1954. parser->m_errorCode = XML_ERROR_NOT_SUSPENDED;
  1955. return XML_STATUS_ERROR;
  1956. }
  1957. parser->m_parsingStatus.parsing = XML_PARSING;
  1958. parser->m_errorCode = parser->m_processor(parser, parser->m_bufferPtr, parser->m_parseEndPtr, &parser->m_bufferPtr);
  1959. if (parser->m_errorCode != XML_ERROR_NONE) {
  1960. parser->m_eventEndPtr = parser->m_eventPtr;
  1961. parser->m_processor = errorProcessor;
  1962. return XML_STATUS_ERROR;
  1963. }
  1964. else {
  1965. switch (parser->m_parsingStatus.parsing) {
  1966. case XML_SUSPENDED:
  1967. result = XML_STATUS_SUSPENDED;
  1968. break;
  1969. case XML_INITIALIZED:
  1970. case XML_PARSING:
  1971. if (parser->m_parsingStatus.finalBuffer) {
  1972. parser->m_parsingStatus.parsing = XML_FINISHED;
  1973. return result;
  1974. }
  1975. default: ;
  1976. }
  1977. }
  1978. XmlUpdatePosition(parser->m_encoding, parser->m_positionPtr, parser->m_bufferPtr, &parser->m_position);
  1979. parser->m_positionPtr = parser->m_bufferPtr;
  1980. return result;
  1981. }
  1982. void XMLCALL
  1983. XML_GetParsingStatus(XML_Parser parser, XML_ParsingStatus *status)
  1984. {
  1985. if (parser == NULL)
  1986. return;
  1987. assert(status != NULL);
  1988. *status = parser->m_parsingStatus;
  1989. }
  1990. enum XML_Error XMLCALL
  1991. XML_GetErrorCode(XML_Parser parser)
  1992. {
  1993. if (parser == NULL)
  1994. return XML_ERROR_INVALID_ARGUMENT;
  1995. return parser->m_errorCode;
  1996. }
  1997. XML_Index XMLCALL
  1998. XML_GetCurrentByteIndex(XML_Parser parser)
  1999. {
  2000. if (parser == NULL)
  2001. return -1;
  2002. if (parser->m_eventPtr)
  2003. return (XML_Index)(parser->m_parseEndByteIndex - (parser->m_parseEndPtr - parser->m_eventPtr));
  2004. return -1;
  2005. }
  2006. int XMLCALL
  2007. XML_GetCurrentByteCount(XML_Parser parser)
  2008. {
  2009. if (parser == NULL)
  2010. return 0;
  2011. if (parser->m_eventEndPtr && parser->m_eventPtr)
  2012. return (int)(parser->m_eventEndPtr - parser->m_eventPtr);
  2013. return 0;
  2014. }
  2015. const char * XMLCALL
  2016. XML_GetInputContext(XML_Parser parser, int *offset, int *size)
  2017. {
  2018. #ifdef XML_CONTEXT_BYTES
  2019. if (parser == NULL)
  2020. return NULL;
  2021. if (parser->m_eventPtr && parser->m_buffer) {
  2022. if (offset != NULL)
  2023. *offset = (int)(parser->m_eventPtr - parser->m_buffer);
  2024. if (size != NULL)
  2025. *size = (int)(parser->m_bufferEnd - parser->m_buffer);
  2026. return parser->m_buffer;
  2027. }
  2028. #else
  2029. (void)parser;
  2030. (void)offset;
  2031. (void)size;
  2032. #endif /* defined XML_CONTEXT_BYTES */
  2033. return (char *) 0;
  2034. }
  2035. XML_Size XMLCALL
  2036. XML_GetCurrentLineNumber(XML_Parser parser)
  2037. {
  2038. if (parser == NULL)
  2039. return 0;
  2040. if (parser->m_eventPtr && parser->m_eventPtr >= parser->m_positionPtr) {
  2041. XmlUpdatePosition(parser->m_encoding, parser->m_positionPtr, parser->m_eventPtr, &parser->m_position);
  2042. parser->m_positionPtr = parser->m_eventPtr;
  2043. }
  2044. return parser->m_position.lineNumber + 1;
  2045. }
  2046. XML_Size XMLCALL
  2047. XML_GetCurrentColumnNumber(XML_Parser parser)
  2048. {
  2049. if (parser == NULL)
  2050. return 0;
  2051. if (parser->m_eventPtr && parser->m_eventPtr >= parser->m_positionPtr) {
  2052. XmlUpdatePosition(parser->m_encoding, parser->m_positionPtr, parser->m_eventPtr, &parser->m_position);
  2053. parser->m_positionPtr = parser->m_eventPtr;
  2054. }
  2055. return parser->m_position.columnNumber;
  2056. }
  2057. void XMLCALL
  2058. XML_FreeContentModel(XML_Parser parser, XML_Content *model)
  2059. {
  2060. if (parser != NULL)
  2061. FREE(parser, model);
  2062. }
  2063. void * XMLCALL
  2064. XML_MemMalloc(XML_Parser parser, size_t size)
  2065. {
  2066. if (parser == NULL)
  2067. return NULL;
  2068. return MALLOC(parser, size);
  2069. }
  2070. void * XMLCALL
  2071. XML_MemRealloc(XML_Parser parser, void *ptr, size_t size)
  2072. {
  2073. if (parser == NULL)
  2074. return NULL;
  2075. return REALLOC(parser, ptr, size);
  2076. }
  2077. void XMLCALL
  2078. XML_MemFree(XML_Parser parser, void *ptr)
  2079. {
  2080. if (parser != NULL)
  2081. FREE(parser, ptr);
  2082. }
  2083. void XMLCALL
  2084. XML_DefaultCurrent(XML_Parser parser)
  2085. {
  2086. if (parser == NULL)
  2087. return;
  2088. if (parser->m_defaultHandler) {
  2089. if (parser->m_openInternalEntities)
  2090. reportDefault(parser,
  2091. parser->m_internalEncoding,
  2092. parser->m_openInternalEntities->internalEventPtr,
  2093. parser->m_openInternalEntities->internalEventEndPtr);
  2094. else
  2095. reportDefault(parser, parser->m_encoding, parser->m_eventPtr, parser->m_eventEndPtr);
  2096. }
  2097. }
  2098. const XML_LChar * XMLCALL
  2099. XML_ErrorString(enum XML_Error code)
  2100. {
  2101. switch (code) {
  2102. case XML_ERROR_NONE:
  2103. return NULL;
  2104. case XML_ERROR_NO_MEMORY:
  2105. return XML_L("out of memory");
  2106. case XML_ERROR_SYNTAX:
  2107. return XML_L("syntax error");
  2108. case XML_ERROR_NO_ELEMENTS:
  2109. return XML_L("no element found");
  2110. case XML_ERROR_INVALID_TOKEN:
  2111. return XML_L("not well-formed (invalid token)");
  2112. case XML_ERROR_UNCLOSED_TOKEN:
  2113. return XML_L("unclosed token");
  2114. case XML_ERROR_PARTIAL_CHAR:
  2115. return XML_L("partial character");
  2116. case XML_ERROR_TAG_MISMATCH:
  2117. return XML_L("mismatched tag");
  2118. case XML_ERROR_DUPLICATE_ATTRIBUTE:
  2119. return XML_L("duplicate attribute");
  2120. case XML_ERROR_JUNK_AFTER_DOC_ELEMENT:
  2121. return XML_L("junk after document element");
  2122. case XML_ERROR_PARAM_ENTITY_REF:
  2123. return XML_L("illegal parameter entity reference");
  2124. case XML_ERROR_UNDEFINED_ENTITY:
  2125. return XML_L("undefined entity");
  2126. case XML_ERROR_RECURSIVE_ENTITY_REF:
  2127. return XML_L("recursive entity reference");
  2128. case XML_ERROR_ASYNC_ENTITY:
  2129. return XML_L("asynchronous entity");
  2130. case XML_ERROR_BAD_CHAR_REF:
  2131. return XML_L("reference to invalid character number");
  2132. case XML_ERROR_BINARY_ENTITY_REF:
  2133. return XML_L("reference to binary entity");
  2134. case XML_ERROR_ATTRIBUTE_EXTERNAL_ENTITY_REF:
  2135. return XML_L("reference to external entity in attribute");
  2136. case XML_ERROR_MISPLACED_XML_PI:
  2137. return XML_L("XML or text declaration not at start of entity");
  2138. case XML_ERROR_UNKNOWN_ENCODING:
  2139. return XML_L("unknown encoding");
  2140. case XML_ERROR_INCORRECT_ENCODING:
  2141. return XML_L("encoding specified in XML declaration is incorrect");
  2142. case XML_ERROR_UNCLOSED_CDATA_SECTION:
  2143. return XML_L("unclosed CDATA section");
  2144. case XML_ERROR_EXTERNAL_ENTITY_HANDLING:
  2145. return XML_L("error in processing external entity reference");
  2146. case XML_ERROR_NOT_STANDALONE:
  2147. return XML_L("document is not standalone");
  2148. case XML_ERROR_UNEXPECTED_STATE:
  2149. return XML_L("unexpected parser state - please send a bug report");
  2150. case XML_ERROR_ENTITY_DECLARED_IN_PE:
  2151. return XML_L("entity declared in parameter entity");
  2152. case XML_ERROR_FEATURE_REQUIRES_XML_DTD:
  2153. return XML_L("requested feature requires XML_DTD support in Expat");
  2154. case XML_ERROR_CANT_CHANGE_FEATURE_ONCE_PARSING:
  2155. return XML_L("cannot change setting once parsing has begun");
  2156. /* Added in 1.95.7. */
  2157. case XML_ERROR_UNBOUND_PREFIX:
  2158. return XML_L("unbound prefix");
  2159. /* Added in 1.95.8. */
  2160. case XML_ERROR_UNDECLARING_PREFIX:
  2161. return XML_L("must not undeclare prefix");
  2162. case XML_ERROR_INCOMPLETE_PE:
  2163. return XML_L("incomplete markup in parameter entity");
  2164. case XML_ERROR_XML_DECL:
  2165. return XML_L("XML declaration not well-formed");
  2166. case XML_ERROR_TEXT_DECL:
  2167. return XML_L("text declaration not well-formed");
  2168. case XML_ERROR_PUBLICID:
  2169. return XML_L("illegal character(s) in public id");
  2170. case XML_ERROR_SUSPENDED:
  2171. return XML_L("parser suspended");
  2172. case XML_ERROR_NOT_SUSPENDED:
  2173. return XML_L("parser not suspended");
  2174. case XML_ERROR_ABORTED:
  2175. return XML_L("parsing aborted");
  2176. case XML_ERROR_FINISHED:
  2177. return XML_L("parsing finished");
  2178. case XML_ERROR_SUSPEND_PE:
  2179. return XML_L("cannot suspend in external parameter entity");
  2180. /* Added in 2.0.0. */
  2181. case XML_ERROR_RESERVED_PREFIX_XML:
  2182. return XML_L("reserved prefix (xml) must not be undeclared or bound to another namespace name");
  2183. case XML_ERROR_RESERVED_PREFIX_XMLNS:
  2184. return XML_L("reserved prefix (xmlns) must not be declared or undeclared");
  2185. case XML_ERROR_RESERVED_NAMESPACE_URI:
  2186. return XML_L("prefix must not be bound to one of the reserved namespace names");
  2187. /* Added in 2.2.5. */
  2188. case XML_ERROR_INVALID_ARGUMENT: /* Constant added in 2.2.1, already */
  2189. return XML_L("invalid argument");
  2190. }
  2191. return NULL;
  2192. }
  2193. const XML_LChar * XMLCALL
  2194. XML_ExpatVersion(void) {
  2195. /* V1 is used to string-ize the version number. However, it would
  2196. string-ize the actual version macro *names* unless we get them
  2197. substituted before being passed to V1. CPP is defined to expand
  2198. a macro, then rescan for more expansions. Thus, we use V2 to expand
  2199. the version macros, then CPP will expand the resulting V1() macro
  2200. with the correct numerals. */
  2201. /* ### I'm assuming cpp is portable in this respect... */
  2202. #define V1(a,b,c) XML_L(#a)XML_L(".")XML_L(#b)XML_L(".")XML_L(#c)
  2203. #define V2(a,b,c) XML_L("expat_")V1(a,b,c)
  2204. return V2(XML_MAJOR_VERSION, XML_MINOR_VERSION, XML_MICRO_VERSION);
  2205. #undef V1
  2206. #undef V2
  2207. }
  2208. XML_Expat_Version XMLCALL
  2209. XML_ExpatVersionInfo(void)
  2210. {
  2211. XML_Expat_Version version;
  2212. version.major = XML_MAJOR_VERSION;
  2213. version.minor = XML_MINOR_VERSION;
  2214. version.micro = XML_MICRO_VERSION;
  2215. return version;
  2216. }
  2217. const XML_Feature * XMLCALL
  2218. XML_GetFeatureList(void)
  2219. {
  2220. static const XML_Feature features[] = {
  2221. {XML_FEATURE_SIZEOF_XML_CHAR, XML_L("sizeof(XML_Char)"),
  2222. sizeof(XML_Char)},
  2223. {XML_FEATURE_SIZEOF_XML_LCHAR, XML_L("sizeof(XML_LChar)"),
  2224. sizeof(XML_LChar)},
  2225. #ifdef XML_UNICODE
  2226. {XML_FEATURE_UNICODE, XML_L("XML_UNICODE"), 0},
  2227. #endif
  2228. #ifdef XML_UNICODE_WCHAR_T
  2229. {XML_FEATURE_UNICODE_WCHAR_T, XML_L("XML_UNICODE_WCHAR_T"), 0},
  2230. #endif
  2231. #ifdef XML_DTD
  2232. {XML_FEATURE_DTD, XML_L("XML_DTD"), 0},
  2233. #endif
  2234. #ifdef XML_CONTEXT_BYTES
  2235. {XML_FEATURE_CONTEXT_BYTES, XML_L("XML_CONTEXT_BYTES"),
  2236. XML_CONTEXT_BYTES},
  2237. #endif
  2238. #ifdef XML_MIN_SIZE
  2239. {XML_FEATURE_MIN_SIZE, XML_L("XML_MIN_SIZE"), 0},
  2240. #endif
  2241. #ifdef XML_NS
  2242. {XML_FEATURE_NS, XML_L("XML_NS"), 0},
  2243. #endif
  2244. #ifdef XML_LARGE_SIZE
  2245. {XML_FEATURE_LARGE_SIZE, XML_L("XML_LARGE_SIZE"), 0},
  2246. #endif
  2247. #ifdef XML_ATTR_INFO
  2248. {XML_FEATURE_ATTR_INFO, XML_L("XML_ATTR_INFO"), 0},
  2249. #endif
  2250. {XML_FEATURE_END, NULL, 0}
  2251. };
  2252. return features;
  2253. }
  2254. /* Initially tag->rawName always points into the parse buffer;
  2255. for those TAG instances opened while the current parse buffer was
  2256. processed, and not yet closed, we need to store tag->rawName in a more
  2257. permanent location, since the parse buffer is about to be discarded.
  2258. */
  2259. static XML_Bool
  2260. storeRawNames(XML_Parser parser)
  2261. {
  2262. TAG *tag = parser->m_tagStack;
  2263. while (tag) {
  2264. int bufSize;
  2265. int nameLen = sizeof(XML_Char) * (tag->name.strLen + 1);
  2266. char *rawNameBuf = tag->buf + nameLen;
  2267. /* Stop if already stored. Since m_tagStack is a stack, we can stop
  2268. at the first entry that has already been copied; everything
  2269. below it in the stack is already been accounted for in a
  2270. previous call to this function.
  2271. */
  2272. if (tag->rawName == rawNameBuf)
  2273. break;
  2274. /* For re-use purposes we need to ensure that the
  2275. size of tag->buf is a multiple of sizeof(XML_Char).
  2276. */
  2277. bufSize = nameLen + ROUND_UP(tag->rawNameLength, sizeof(XML_Char));
  2278. if (bufSize > tag->bufEnd - tag->buf) {
  2279. char *temp = (char *)REALLOC(parser, tag->buf, bufSize);
  2280. if (temp == NULL)
  2281. return XML_FALSE;
  2282. /* if tag->name.str points to tag->buf (only when namespace
  2283. processing is off) then we have to update it
  2284. */
  2285. if (tag->name.str == (XML_Char *)tag->buf)
  2286. tag->name.str = (XML_Char *)temp;
  2287. /* if tag->name.localPart is set (when namespace processing is on)
  2288. then update it as well, since it will always point into tag->buf
  2289. */
  2290. if (tag->name.localPart)
  2291. tag->name.localPart = (XML_Char *)temp + (tag->name.localPart -
  2292. (XML_Char *)tag->buf);
  2293. tag->buf = temp;
  2294. tag->bufEnd = temp + bufSize;
  2295. rawNameBuf = temp + nameLen;
  2296. }
  2297. memcpy(rawNameBuf, tag->rawName, tag->rawNameLength);
  2298. tag->rawName = rawNameBuf;
  2299. tag = tag->parent;
  2300. }
  2301. return XML_TRUE;
  2302. }
  2303. static enum XML_Error PTRCALL
  2304. contentProcessor(XML_Parser parser,
  2305. const char *start,
  2306. const char *end,
  2307. const char **endPtr)
  2308. {
  2309. enum XML_Error result = doContent(parser, 0, parser->m_encoding, start, end,
  2310. endPtr, (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  2311. if (result == XML_ERROR_NONE) {
  2312. if (!storeRawNames(parser))
  2313. return XML_ERROR_NO_MEMORY;
  2314. }
  2315. return result;
  2316. }
  2317. static enum XML_Error PTRCALL
  2318. externalEntityInitProcessor(XML_Parser parser,
  2319. const char *start,
  2320. const char *end,
  2321. const char **endPtr)
  2322. {
  2323. enum XML_Error result = initializeEncoding(parser);
  2324. if (result != XML_ERROR_NONE)
  2325. return result;
  2326. parser->m_processor = externalEntityInitProcessor2;
  2327. return externalEntityInitProcessor2(parser, start, end, endPtr);
  2328. }
  2329. static enum XML_Error PTRCALL
  2330. externalEntityInitProcessor2(XML_Parser parser,
  2331. const char *start,
  2332. const char *end,
  2333. const char **endPtr)
  2334. {
  2335. const char *next = start; /* XmlContentTok doesn't always set the last arg */
  2336. int tok = XmlContentTok(parser->m_encoding, start, end, &next);
  2337. switch (tok) {
  2338. case XML_TOK_BOM:
  2339. /* If we are at the end of the buffer, this would cause the next stage,
  2340. i.e. externalEntityInitProcessor3, to pass control directly to
  2341. doContent (by detecting XML_TOK_NONE) without processing any xml text
  2342. declaration - causing the error XML_ERROR_MISPLACED_XML_PI in doContent.
  2343. */
  2344. if (next == end && !parser->m_parsingStatus.finalBuffer) {
  2345. *endPtr = next;
  2346. return XML_ERROR_NONE;
  2347. }
  2348. start = next;
  2349. break;
  2350. case XML_TOK_PARTIAL:
  2351. if (!parser->m_parsingStatus.finalBuffer) {
  2352. *endPtr = start;
  2353. return XML_ERROR_NONE;
  2354. }
  2355. parser->m_eventPtr = start;
  2356. return XML_ERROR_UNCLOSED_TOKEN;
  2357. case XML_TOK_PARTIAL_CHAR:
  2358. if (!parser->m_parsingStatus.finalBuffer) {
  2359. *endPtr = start;
  2360. return XML_ERROR_NONE;
  2361. }
  2362. parser->m_eventPtr = start;
  2363. return XML_ERROR_PARTIAL_CHAR;
  2364. }
  2365. parser->m_processor = externalEntityInitProcessor3;
  2366. return externalEntityInitProcessor3(parser, start, end, endPtr);
  2367. }
  2368. static enum XML_Error PTRCALL
  2369. externalEntityInitProcessor3(XML_Parser parser,
  2370. const char *start,
  2371. const char *end,
  2372. const char **endPtr)
  2373. {
  2374. int tok;
  2375. const char *next = start; /* XmlContentTok doesn't always set the last arg */
  2376. parser->m_eventPtr = start;
  2377. tok = XmlContentTok(parser->m_encoding, start, end, &next);
  2378. parser->m_eventEndPtr = next;
  2379. switch (tok) {
  2380. case XML_TOK_XML_DECL:
  2381. {
  2382. enum XML_Error result;
  2383. result = processXmlDecl(parser, 1, start, next);
  2384. if (result != XML_ERROR_NONE)
  2385. return result;
  2386. switch (parser->m_parsingStatus.parsing) {
  2387. case XML_SUSPENDED:
  2388. *endPtr = next;
  2389. return XML_ERROR_NONE;
  2390. case XML_FINISHED:
  2391. return XML_ERROR_ABORTED;
  2392. default:
  2393. start = next;
  2394. }
  2395. }
  2396. break;
  2397. case XML_TOK_PARTIAL:
  2398. if (!parser->m_parsingStatus.finalBuffer) {
  2399. *endPtr = start;
  2400. return XML_ERROR_NONE;
  2401. }
  2402. return XML_ERROR_UNCLOSED_TOKEN;
  2403. case XML_TOK_PARTIAL_CHAR:
  2404. if (!parser->m_parsingStatus.finalBuffer) {
  2405. *endPtr = start;
  2406. return XML_ERROR_NONE;
  2407. }
  2408. return XML_ERROR_PARTIAL_CHAR;
  2409. }
  2410. parser->m_processor = externalEntityContentProcessor;
  2411. parser->m_tagLevel = 1;
  2412. return externalEntityContentProcessor(parser, start, end, endPtr);
  2413. }
  2414. static enum XML_Error PTRCALL
  2415. externalEntityContentProcessor(XML_Parser parser,
  2416. const char *start,
  2417. const char *end,
  2418. const char **endPtr)
  2419. {
  2420. enum XML_Error result = doContent(parser, 1, parser->m_encoding, start, end,
  2421. endPtr, (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  2422. if (result == XML_ERROR_NONE) {
  2423. if (!storeRawNames(parser))
  2424. return XML_ERROR_NO_MEMORY;
  2425. }
  2426. return result;
  2427. }
  2428. static enum XML_Error
  2429. doContent(XML_Parser parser,
  2430. int startTagLevel,
  2431. const ENCODING *enc,
  2432. const char *s,
  2433. const char *end,
  2434. const char **nextPtr,
  2435. XML_Bool haveMore)
  2436. {
  2437. /* save one level of indirection */
  2438. DTD * const dtd = parser->m_dtd;
  2439. const char **eventPP;
  2440. const char **eventEndPP;
  2441. if (enc == parser->m_encoding) {
  2442. eventPP = &parser->m_eventPtr;
  2443. eventEndPP = &parser->m_eventEndPtr;
  2444. }
  2445. else {
  2446. eventPP = &(parser->m_openInternalEntities->internalEventPtr);
  2447. eventEndPP = &(parser->m_openInternalEntities->internalEventEndPtr);
  2448. }
  2449. *eventPP = s;
  2450. for (;;) {
  2451. const char *next = s; /* XmlContentTok doesn't always set the last arg */
  2452. int tok = XmlContentTok(enc, s, end, &next);
  2453. *eventEndPP = next;
  2454. switch (tok) {
  2455. case XML_TOK_TRAILING_CR:
  2456. if (haveMore) {
  2457. *nextPtr = s;
  2458. return XML_ERROR_NONE;
  2459. }
  2460. *eventEndPP = end;
  2461. if (parser->m_characterDataHandler) {
  2462. XML_Char c = 0xA;
  2463. parser->m_characterDataHandler(parser->m_handlerArg, &c, 1);
  2464. }
  2465. else if (parser->m_defaultHandler)
  2466. reportDefault(parser, enc, s, end);
  2467. /* We are at the end of the final buffer, should we check for
  2468. XML_SUSPENDED, XML_FINISHED?
  2469. */
  2470. if (startTagLevel == 0)
  2471. return XML_ERROR_NO_ELEMENTS;
  2472. if (parser->m_tagLevel != startTagLevel)
  2473. return XML_ERROR_ASYNC_ENTITY;
  2474. *nextPtr = end;
  2475. return XML_ERROR_NONE;
  2476. case XML_TOK_NONE:
  2477. if (haveMore) {
  2478. *nextPtr = s;
  2479. return XML_ERROR_NONE;
  2480. }
  2481. if (startTagLevel > 0) {
  2482. if (parser->m_tagLevel != startTagLevel)
  2483. return XML_ERROR_ASYNC_ENTITY;
  2484. *nextPtr = s;
  2485. return XML_ERROR_NONE;
  2486. }
  2487. return XML_ERROR_NO_ELEMENTS;
  2488. case XML_TOK_INVALID:
  2489. *eventPP = next;
  2490. return XML_ERROR_INVALID_TOKEN;
  2491. case XML_TOK_PARTIAL:
  2492. if (haveMore) {
  2493. *nextPtr = s;
  2494. return XML_ERROR_NONE;
  2495. }
  2496. return XML_ERROR_UNCLOSED_TOKEN;
  2497. case XML_TOK_PARTIAL_CHAR:
  2498. if (haveMore) {
  2499. *nextPtr = s;
  2500. return XML_ERROR_NONE;
  2501. }
  2502. return XML_ERROR_PARTIAL_CHAR;
  2503. case XML_TOK_ENTITY_REF:
  2504. {
  2505. const XML_Char *name;
  2506. ENTITY *entity;
  2507. XML_Char ch = (XML_Char) XmlPredefinedEntityName(enc,
  2508. s + enc->minBytesPerChar,
  2509. next - enc->minBytesPerChar);
  2510. if (ch) {
  2511. if (parser->m_characterDataHandler)
  2512. parser->m_characterDataHandler(parser->m_handlerArg, &ch, 1);
  2513. else if (parser->m_defaultHandler)
  2514. reportDefault(parser, enc, s, next);
  2515. break;
  2516. }
  2517. name = poolStoreString(&dtd->pool, enc,
  2518. s + enc->minBytesPerChar,
  2519. next - enc->minBytesPerChar);
  2520. if (!name)
  2521. return XML_ERROR_NO_MEMORY;
  2522. entity = (ENTITY *)lookup(parser, &dtd->generalEntities, name, 0);
  2523. poolDiscard(&dtd->pool);
  2524. /* First, determine if a check for an existing declaration is needed;
  2525. if yes, check that the entity exists, and that it is internal,
  2526. otherwise call the skipped entity or default handler.
  2527. */
  2528. if (!dtd->hasParamEntityRefs || dtd->standalone) {
  2529. if (!entity)
  2530. return XML_ERROR_UNDEFINED_ENTITY;
  2531. else if (!entity->is_internal)
  2532. return XML_ERROR_ENTITY_DECLARED_IN_PE;
  2533. }
  2534. else if (!entity) {
  2535. if (parser->m_skippedEntityHandler)
  2536. parser->m_skippedEntityHandler(parser->m_handlerArg, name, 0);
  2537. else if (parser->m_defaultHandler)
  2538. reportDefault(parser, enc, s, next);
  2539. break;
  2540. }
  2541. if (entity->open)
  2542. return XML_ERROR_RECURSIVE_ENTITY_REF;
  2543. if (entity->notation)
  2544. return XML_ERROR_BINARY_ENTITY_REF;
  2545. if (entity->textPtr) {
  2546. enum XML_Error result;
  2547. if (!parser->m_defaultExpandInternalEntities) {
  2548. if (parser->m_skippedEntityHandler)
  2549. parser->m_skippedEntityHandler(parser->m_handlerArg, entity->name, 0);
  2550. else if (parser->m_defaultHandler)
  2551. reportDefault(parser, enc, s, next);
  2552. break;
  2553. }
  2554. result = processInternalEntity(parser, entity, XML_FALSE);
  2555. if (result != XML_ERROR_NONE)
  2556. return result;
  2557. }
  2558. else if (parser->m_externalEntityRefHandler) {
  2559. const XML_Char *context;
  2560. entity->open = XML_TRUE;
  2561. context = getContext(parser);
  2562. entity->open = XML_FALSE;
  2563. if (!context)
  2564. return XML_ERROR_NO_MEMORY;
  2565. if (!parser->m_externalEntityRefHandler(parser->m_externalEntityRefHandlerArg,
  2566. context,
  2567. entity->base,
  2568. entity->systemId,
  2569. entity->publicId))
  2570. return XML_ERROR_EXTERNAL_ENTITY_HANDLING;
  2571. poolDiscard(&parser->m_tempPool);
  2572. }
  2573. else if (parser->m_defaultHandler)
  2574. reportDefault(parser, enc, s, next);
  2575. break;
  2576. }
  2577. case XML_TOK_START_TAG_NO_ATTS:
  2578. /* fall through */
  2579. case XML_TOK_START_TAG_WITH_ATTS:
  2580. {
  2581. TAG *tag;
  2582. enum XML_Error result;
  2583. XML_Char *toPtr;
  2584. if (parser->m_freeTagList) {
  2585. tag = parser->m_freeTagList;
  2586. parser->m_freeTagList = parser->m_freeTagList->parent;
  2587. }
  2588. else {
  2589. tag = (TAG *)MALLOC(parser, sizeof(TAG));
  2590. if (!tag)
  2591. return XML_ERROR_NO_MEMORY;
  2592. tag->buf = (char *)MALLOC(parser, INIT_TAG_BUF_SIZE);
  2593. if (!tag->buf) {
  2594. FREE(parser, tag);
  2595. return XML_ERROR_NO_MEMORY;
  2596. }
  2597. tag->bufEnd = tag->buf + INIT_TAG_BUF_SIZE;
  2598. }
  2599. tag->bindings = NULL;
  2600. tag->parent = parser->m_tagStack;
  2601. parser->m_tagStack = tag;
  2602. tag->name.localPart = NULL;
  2603. tag->name.prefix = NULL;
  2604. tag->rawName = s + enc->minBytesPerChar;
  2605. tag->rawNameLength = XmlNameLength(enc, tag->rawName);
  2606. ++parser->m_tagLevel;
  2607. {
  2608. const char *rawNameEnd = tag->rawName + tag->rawNameLength;
  2609. const char *fromPtr = tag->rawName;
  2610. toPtr = (XML_Char *)tag->buf;
  2611. for (;;) {
  2612. int bufSize;
  2613. int convLen;
  2614. const enum XML_Convert_Result convert_res = XmlConvert(enc,
  2615. &fromPtr, rawNameEnd,
  2616. (ICHAR **)&toPtr, (ICHAR *)tag->bufEnd - 1);
  2617. convLen = (int)(toPtr - (XML_Char *)tag->buf);
  2618. if ((fromPtr >= rawNameEnd) || (convert_res == XML_CONVERT_INPUT_INCOMPLETE)) {
  2619. tag->name.strLen = convLen;
  2620. break;
  2621. }
  2622. bufSize = (int)(tag->bufEnd - tag->buf) << 1;
  2623. {
  2624. char *temp = (char *)REALLOC(parser, tag->buf, bufSize);
  2625. if (temp == NULL)
  2626. return XML_ERROR_NO_MEMORY;
  2627. tag->buf = temp;
  2628. tag->bufEnd = temp + bufSize;
  2629. toPtr = (XML_Char *)temp + convLen;
  2630. }
  2631. }
  2632. }
  2633. tag->name.str = (XML_Char *)tag->buf;
  2634. *toPtr = XML_T('\0');
  2635. result = storeAtts(parser, enc, s, &(tag->name), &(tag->bindings));
  2636. if (result)
  2637. return result;
  2638. if (parser->m_startElementHandler)
  2639. parser->m_startElementHandler(parser->m_handlerArg, tag->name.str,
  2640. (const XML_Char **)parser->m_atts);
  2641. else if (parser->m_defaultHandler)
  2642. reportDefault(parser, enc, s, next);
  2643. poolClear(&parser->m_tempPool);
  2644. break;
  2645. }
  2646. case XML_TOK_EMPTY_ELEMENT_NO_ATTS:
  2647. /* fall through */
  2648. case XML_TOK_EMPTY_ELEMENT_WITH_ATTS:
  2649. {
  2650. const char *rawName = s + enc->minBytesPerChar;
  2651. enum XML_Error result;
  2652. BINDING *bindings = NULL;
  2653. XML_Bool noElmHandlers = XML_TRUE;
  2654. TAG_NAME name;
  2655. name.str = poolStoreString(&parser->m_tempPool, enc, rawName,
  2656. rawName + XmlNameLength(enc, rawName));
  2657. if (!name.str)
  2658. return XML_ERROR_NO_MEMORY;
  2659. poolFinish(&parser->m_tempPool);
  2660. result = storeAtts(parser, enc, s, &name, &bindings);
  2661. if (result != XML_ERROR_NONE) {
  2662. freeBindings(parser, bindings);
  2663. return result;
  2664. }
  2665. poolFinish(&parser->m_tempPool);
  2666. if (parser->m_startElementHandler) {
  2667. parser->m_startElementHandler(parser->m_handlerArg, name.str, (const XML_Char **)parser->m_atts);
  2668. noElmHandlers = XML_FALSE;
  2669. }
  2670. if (parser->m_endElementHandler) {
  2671. if (parser->m_startElementHandler)
  2672. *eventPP = *eventEndPP;
  2673. parser->m_endElementHandler(parser->m_handlerArg, name.str);
  2674. noElmHandlers = XML_FALSE;
  2675. }
  2676. if (noElmHandlers && parser->m_defaultHandler)
  2677. reportDefault(parser, enc, s, next);
  2678. poolClear(&parser->m_tempPool);
  2679. freeBindings(parser, bindings);
  2680. }
  2681. if ((parser->m_tagLevel == 0) && (parser->m_parsingStatus.parsing != XML_FINISHED)) {
  2682. if (parser->m_parsingStatus.parsing == XML_SUSPENDED)
  2683. parser->m_processor = epilogProcessor;
  2684. else
  2685. return epilogProcessor(parser, next, end, nextPtr);
  2686. }
  2687. break;
  2688. case XML_TOK_END_TAG:
  2689. if (parser->m_tagLevel == startTagLevel)
  2690. return XML_ERROR_ASYNC_ENTITY;
  2691. else {
  2692. int len;
  2693. const char *rawName;
  2694. TAG *tag = parser->m_tagStack;
  2695. parser->m_tagStack = tag->parent;
  2696. tag->parent = parser->m_freeTagList;
  2697. parser->m_freeTagList = tag;
  2698. rawName = s + enc->minBytesPerChar*2;
  2699. len = XmlNameLength(enc, rawName);
  2700. if (len != tag->rawNameLength
  2701. || memcmp(tag->rawName, rawName, len) != 0) {
  2702. *eventPP = rawName;
  2703. return XML_ERROR_TAG_MISMATCH;
  2704. }
  2705. --parser->m_tagLevel;
  2706. if (parser->m_endElementHandler) {
  2707. const XML_Char *localPart;
  2708. const XML_Char *prefix;
  2709. XML_Char *uri;
  2710. localPart = tag->name.localPart;
  2711. if (parser->m_ns && localPart) {
  2712. /* localPart and prefix may have been overwritten in
  2713. tag->name.str, since this points to the binding->uri
  2714. buffer which gets re-used; so we have to add them again
  2715. */
  2716. uri = (XML_Char *)tag->name.str + tag->name.uriLen;
  2717. /* don't need to check for space - already done in storeAtts() */
  2718. while (*localPart) *uri++ = *localPart++;
  2719. prefix = (XML_Char *)tag->name.prefix;
  2720. if (parser->m_ns_triplets && prefix) {
  2721. *uri++ = parser->m_namespaceSeparator;
  2722. while (*prefix) *uri++ = *prefix++;
  2723. }
  2724. *uri = XML_T('\0');
  2725. }
  2726. parser->m_endElementHandler(parser->m_handlerArg, tag->name.str);
  2727. }
  2728. else if (parser->m_defaultHandler)
  2729. reportDefault(parser, enc, s, next);
  2730. while (tag->bindings) {
  2731. BINDING *b = tag->bindings;
  2732. if (parser->m_endNamespaceDeclHandler)
  2733. parser->m_endNamespaceDeclHandler(parser->m_handlerArg, b->prefix->name);
  2734. tag->bindings = tag->bindings->nextTagBinding;
  2735. b->nextTagBinding = parser->m_freeBindingList;
  2736. parser->m_freeBindingList = b;
  2737. b->prefix->binding = b->prevPrefixBinding;
  2738. }
  2739. if (parser->m_tagLevel == 0)
  2740. return epilogProcessor(parser, next, end, nextPtr);
  2741. }
  2742. break;
  2743. case XML_TOK_CHAR_REF:
  2744. {
  2745. int n = XmlCharRefNumber(enc, s);
  2746. if (n < 0)
  2747. return XML_ERROR_BAD_CHAR_REF;
  2748. if (parser->m_characterDataHandler) {
  2749. XML_Char buf[XML_ENCODE_MAX];
  2750. parser->m_characterDataHandler(parser->m_handlerArg, buf, XmlEncode(n, (ICHAR *)buf));
  2751. }
  2752. else if (parser->m_defaultHandler)
  2753. reportDefault(parser, enc, s, next);
  2754. }
  2755. break;
  2756. case XML_TOK_XML_DECL:
  2757. return XML_ERROR_MISPLACED_XML_PI;
  2758. case XML_TOK_DATA_NEWLINE:
  2759. if (parser->m_characterDataHandler) {
  2760. XML_Char c = 0xA;
  2761. parser->m_characterDataHandler(parser->m_handlerArg, &c, 1);
  2762. }
  2763. else if (parser->m_defaultHandler)
  2764. reportDefault(parser, enc, s, next);
  2765. break;
  2766. case XML_TOK_CDATA_SECT_OPEN:
  2767. {
  2768. enum XML_Error result;
  2769. if (parser->m_startCdataSectionHandler)
  2770. parser->m_startCdataSectionHandler(parser->m_handlerArg);
  2771. #if 0
  2772. /* Suppose you doing a transformation on a document that involves
  2773. changing only the character data. You set up a defaultHandler
  2774. and a characterDataHandler. The defaultHandler simply copies
  2775. characters through. The characterDataHandler does the
  2776. transformation and writes the characters out escaping them as
  2777. necessary. This case will fail to work if we leave out the
  2778. following two lines (because & and < inside CDATA sections will
  2779. be incorrectly escaped).
  2780. However, now we have a start/endCdataSectionHandler, so it seems
  2781. easier to let the user deal with this.
  2782. */
  2783. else if (parser->m_characterDataHandler)
  2784. parser->m_characterDataHandler(parser->m_handlerArg, parser->m_dataBuf, 0);
  2785. #endif
  2786. else if (parser->m_defaultHandler)
  2787. reportDefault(parser, enc, s, next);
  2788. result = doCdataSection(parser, enc, &next, end, nextPtr, haveMore);
  2789. if (result != XML_ERROR_NONE)
  2790. return result;
  2791. else if (!next) {
  2792. parser->m_processor = cdataSectionProcessor;
  2793. return result;
  2794. }
  2795. }
  2796. break;
  2797. case XML_TOK_TRAILING_RSQB:
  2798. if (haveMore) {
  2799. *nextPtr = s;
  2800. return XML_ERROR_NONE;
  2801. }
  2802. if (parser->m_characterDataHandler) {
  2803. if (MUST_CONVERT(enc, s)) {
  2804. ICHAR *dataPtr = (ICHAR *)parser->m_dataBuf;
  2805. XmlConvert(enc, &s, end, &dataPtr, (ICHAR *)parser->m_dataBufEnd);
  2806. parser->m_characterDataHandler(parser->m_handlerArg, parser->m_dataBuf,
  2807. (int)(dataPtr - (ICHAR *)parser->m_dataBuf));
  2808. }
  2809. else
  2810. parser->m_characterDataHandler(parser->m_handlerArg,
  2811. (XML_Char *)s,
  2812. (int)((XML_Char *)end - (XML_Char *)s));
  2813. }
  2814. else if (parser->m_defaultHandler)
  2815. reportDefault(parser, enc, s, end);
  2816. /* We are at the end of the final buffer, should we check for
  2817. XML_SUSPENDED, XML_FINISHED?
  2818. */
  2819. if (startTagLevel == 0) {
  2820. *eventPP = end;
  2821. return XML_ERROR_NO_ELEMENTS;
  2822. }
  2823. if (parser->m_tagLevel != startTagLevel) {
  2824. *eventPP = end;
  2825. return XML_ERROR_ASYNC_ENTITY;
  2826. }
  2827. *nextPtr = end;
  2828. return XML_ERROR_NONE;
  2829. case XML_TOK_DATA_CHARS:
  2830. {
  2831. XML_CharacterDataHandler charDataHandler = parser->m_characterDataHandler;
  2832. if (charDataHandler) {
  2833. if (MUST_CONVERT(enc, s)) {
  2834. for (;;) {
  2835. ICHAR *dataPtr = (ICHAR *)parser->m_dataBuf;
  2836. const enum XML_Convert_Result convert_res = XmlConvert(enc, &s, next, &dataPtr, (ICHAR *)parser->m_dataBufEnd);
  2837. *eventEndPP = s;
  2838. charDataHandler(parser->m_handlerArg, parser->m_dataBuf,
  2839. (int)(dataPtr - (ICHAR *)parser->m_dataBuf));
  2840. if ((convert_res == XML_CONVERT_COMPLETED) || (convert_res == XML_CONVERT_INPUT_INCOMPLETE))
  2841. break;
  2842. *eventPP = s;
  2843. }
  2844. }
  2845. else
  2846. charDataHandler(parser->m_handlerArg,
  2847. (XML_Char *)s,
  2848. (int)((XML_Char *)next - (XML_Char *)s));
  2849. }
  2850. else if (parser->m_defaultHandler)
  2851. reportDefault(parser, enc, s, next);
  2852. }
  2853. break;
  2854. case XML_TOK_PI:
  2855. if (!reportProcessingInstruction(parser, enc, s, next))
  2856. return XML_ERROR_NO_MEMORY;
  2857. break;
  2858. case XML_TOK_COMMENT:
  2859. if (!reportComment(parser, enc, s, next))
  2860. return XML_ERROR_NO_MEMORY;
  2861. break;
  2862. default:
  2863. /* All of the tokens produced by XmlContentTok() have their own
  2864. * explicit cases, so this default is not strictly necessary.
  2865. * However it is a useful safety net, so we retain the code and
  2866. * simply exclude it from the coverage tests.
  2867. *
  2868. * LCOV_EXCL_START
  2869. */
  2870. if (parser->m_defaultHandler)
  2871. reportDefault(parser, enc, s, next);
  2872. break;
  2873. /* LCOV_EXCL_STOP */
  2874. }
  2875. *eventPP = s = next;
  2876. switch (parser->m_parsingStatus.parsing) {
  2877. case XML_SUSPENDED:
  2878. *nextPtr = next;
  2879. return XML_ERROR_NONE;
  2880. case XML_FINISHED:
  2881. return XML_ERROR_ABORTED;
  2882. default: ;
  2883. }
  2884. }
  2885. /* not reached */
  2886. }
  2887. /* This function does not call free() on the allocated memory, merely
  2888. * moving it to the parser's m_freeBindingList where it can be freed or
  2889. * reused as appropriate.
  2890. */
  2891. static void
  2892. freeBindings(XML_Parser parser, BINDING *bindings)
  2893. {
  2894. while (bindings) {
  2895. BINDING *b = bindings;
  2896. /* m_startNamespaceDeclHandler will have been called for this
  2897. * binding in addBindings(), so call the end handler now.
  2898. */
  2899. if (parser->m_endNamespaceDeclHandler)
  2900. parser->m_endNamespaceDeclHandler(parser->m_handlerArg, b->prefix->name);
  2901. bindings = bindings->nextTagBinding;
  2902. b->nextTagBinding = parser->m_freeBindingList;
  2903. parser->m_freeBindingList = b;
  2904. b->prefix->binding = b->prevPrefixBinding;
  2905. }
  2906. }
  2907. /* Precondition: all arguments must be non-NULL;
  2908. Purpose:
  2909. - normalize attributes
  2910. - check attributes for well-formedness
  2911. - generate namespace aware attribute names (URI, prefix)
  2912. - build list of attributes for startElementHandler
  2913. - default attributes
  2914. - process namespace declarations (check and report them)
  2915. - generate namespace aware element name (URI, prefix)
  2916. */
  2917. static enum XML_Error
  2918. storeAtts(XML_Parser parser, const ENCODING *enc,
  2919. const char *attStr, TAG_NAME *tagNamePtr,
  2920. BINDING **bindingsPtr)
  2921. {
  2922. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  2923. ELEMENT_TYPE *elementType;
  2924. int nDefaultAtts;
  2925. const XML_Char **appAtts; /* the attribute list for the application */
  2926. int attIndex = 0;
  2927. int prefixLen;
  2928. int i;
  2929. int n;
  2930. XML_Char *uri;
  2931. int nPrefixes = 0;
  2932. BINDING *binding;
  2933. const XML_Char *localPart;
  2934. /* lookup the element type name */
  2935. elementType = (ELEMENT_TYPE *)lookup(parser, &dtd->elementTypes, tagNamePtr->str,0);
  2936. if (!elementType) {
  2937. const XML_Char *name = poolCopyString(&dtd->pool, tagNamePtr->str);
  2938. if (!name)
  2939. return XML_ERROR_NO_MEMORY;
  2940. elementType = (ELEMENT_TYPE *)lookup(parser, &dtd->elementTypes, name,
  2941. sizeof(ELEMENT_TYPE));
  2942. if (!elementType)
  2943. return XML_ERROR_NO_MEMORY;
  2944. if (parser->m_ns && !setElementTypePrefix(parser, elementType))
  2945. return XML_ERROR_NO_MEMORY;
  2946. }
  2947. nDefaultAtts = elementType->nDefaultAtts;
  2948. /* get the attributes from the tokenizer */
  2949. n = XmlGetAttributes(enc, attStr, parser->m_attsSize, parser->m_atts);
  2950. if (n + nDefaultAtts > parser->m_attsSize) {
  2951. int oldAttsSize = parser->m_attsSize;
  2952. ATTRIBUTE *temp;
  2953. #ifdef XML_ATTR_INFO
  2954. XML_AttrInfo *temp2;
  2955. #endif
  2956. parser->m_attsSize = n + nDefaultAtts + INIT_ATTS_SIZE;
  2957. temp = (ATTRIBUTE *)REALLOC(parser, (void *)parser->m_atts, parser->m_attsSize * sizeof(ATTRIBUTE));
  2958. if (temp == NULL) {
  2959. parser->m_attsSize = oldAttsSize;
  2960. return XML_ERROR_NO_MEMORY;
  2961. }
  2962. parser->m_atts = temp;
  2963. #ifdef XML_ATTR_INFO
  2964. temp2 = (XML_AttrInfo *)REALLOC(parser, (void *)parser->m_attInfo, parser->m_attsSize * sizeof(XML_AttrInfo));
  2965. if (temp2 == NULL) {
  2966. parser->m_attsSize = oldAttsSize;
  2967. return XML_ERROR_NO_MEMORY;
  2968. }
  2969. parser->m_attInfo = temp2;
  2970. #endif
  2971. if (n > oldAttsSize)
  2972. XmlGetAttributes(enc, attStr, n, parser->m_atts);
  2973. }
  2974. appAtts = (const XML_Char **)parser->m_atts;
  2975. for (i = 0; i < n; i++) {
  2976. ATTRIBUTE *currAtt = &parser->m_atts[i];
  2977. #ifdef XML_ATTR_INFO
  2978. XML_AttrInfo *currAttInfo = &parser->m_attInfo[i];
  2979. #endif
  2980. /* add the name and value to the attribute list */
  2981. ATTRIBUTE_ID *attId = getAttributeId(parser, enc, currAtt->name,
  2982. currAtt->name
  2983. + XmlNameLength(enc, currAtt->name));
  2984. if (!attId)
  2985. return XML_ERROR_NO_MEMORY;
  2986. #ifdef XML_ATTR_INFO
  2987. currAttInfo->nameStart = parser->m_parseEndByteIndex - (parser->m_parseEndPtr - currAtt->name);
  2988. currAttInfo->nameEnd = currAttInfo->nameStart +
  2989. XmlNameLength(enc, currAtt->name);
  2990. currAttInfo->valueStart = parser->m_parseEndByteIndex -
  2991. (parser->m_parseEndPtr - currAtt->valuePtr);
  2992. currAttInfo->valueEnd = parser->m_parseEndByteIndex - (parser->m_parseEndPtr - currAtt->valueEnd);
  2993. #endif
  2994. /* Detect duplicate attributes by their QNames. This does not work when
  2995. namespace processing is turned on and different prefixes for the same
  2996. namespace are used. For this case we have a check further down.
  2997. */
  2998. if ((attId->name)[-1]) {
  2999. if (enc == parser->m_encoding)
  3000. parser->m_eventPtr = parser->m_atts[i].name;
  3001. return XML_ERROR_DUPLICATE_ATTRIBUTE;
  3002. }
  3003. (attId->name)[-1] = 1;
  3004. appAtts[attIndex++] = attId->name;
  3005. if (!parser->m_atts[i].normalized) {
  3006. enum XML_Error result;
  3007. XML_Bool isCdata = XML_TRUE;
  3008. /* figure out whether declared as other than CDATA */
  3009. if (attId->maybeTokenized) {
  3010. int j;
  3011. for (j = 0; j < nDefaultAtts; j++) {
  3012. if (attId == elementType->defaultAtts[j].id) {
  3013. isCdata = elementType->defaultAtts[j].isCdata;
  3014. break;
  3015. }
  3016. }
  3017. }
  3018. /* normalize the attribute value */
  3019. result = storeAttributeValue(parser, enc, isCdata,
  3020. parser->m_atts[i].valuePtr, parser->m_atts[i].valueEnd,
  3021. &parser->m_tempPool);
  3022. if (result)
  3023. return result;
  3024. appAtts[attIndex] = poolStart(&parser->m_tempPool);
  3025. poolFinish(&parser->m_tempPool);
  3026. }
  3027. else {
  3028. /* the value did not need normalizing */
  3029. appAtts[attIndex] = poolStoreString(&parser->m_tempPool, enc, parser->m_atts[i].valuePtr,
  3030. parser->m_atts[i].valueEnd);
  3031. if (appAtts[attIndex] == 0)
  3032. return XML_ERROR_NO_MEMORY;
  3033. poolFinish(&parser->m_tempPool);
  3034. }
  3035. /* handle prefixed attribute names */
  3036. if (attId->prefix) {
  3037. if (attId->xmlns) {
  3038. /* deal with namespace declarations here */
  3039. enum XML_Error result = addBinding(parser, attId->prefix, attId,
  3040. appAtts[attIndex], bindingsPtr);
  3041. if (result)
  3042. return result;
  3043. --attIndex;
  3044. }
  3045. else {
  3046. /* deal with other prefixed names later */
  3047. attIndex++;
  3048. nPrefixes++;
  3049. (attId->name)[-1] = 2;
  3050. }
  3051. }
  3052. else
  3053. attIndex++;
  3054. }
  3055. /* set-up for XML_GetSpecifiedAttributeCount and XML_GetIdAttributeIndex */
  3056. parser->m_nSpecifiedAtts = attIndex;
  3057. if (elementType->idAtt && (elementType->idAtt->name)[-1]) {
  3058. for (i = 0; i < attIndex; i += 2)
  3059. if (appAtts[i] == elementType->idAtt->name) {
  3060. parser->m_idAttIndex = i;
  3061. break;
  3062. }
  3063. }
  3064. else
  3065. parser->m_idAttIndex = -1;
  3066. /* do attribute defaulting */
  3067. for (i = 0; i < nDefaultAtts; i++) {
  3068. const DEFAULT_ATTRIBUTE *da = elementType->defaultAtts + i;
  3069. if (!(da->id->name)[-1] && da->value) {
  3070. if (da->id->prefix) {
  3071. if (da->id->xmlns) {
  3072. enum XML_Error result = addBinding(parser, da->id->prefix, da->id,
  3073. da->value, bindingsPtr);
  3074. if (result)
  3075. return result;
  3076. }
  3077. else {
  3078. (da->id->name)[-1] = 2;
  3079. nPrefixes++;
  3080. appAtts[attIndex++] = da->id->name;
  3081. appAtts[attIndex++] = da->value;
  3082. }
  3083. }
  3084. else {
  3085. (da->id->name)[-1] = 1;
  3086. appAtts[attIndex++] = da->id->name;
  3087. appAtts[attIndex++] = da->value;
  3088. }
  3089. }
  3090. }
  3091. appAtts[attIndex] = 0;
  3092. /* expand prefixed attribute names, check for duplicates,
  3093. and clear flags that say whether attributes were specified */
  3094. i = 0;
  3095. if (nPrefixes) {
  3096. int j; /* hash table index */
  3097. unsigned long version = parser->m_nsAttsVersion;
  3098. int nsAttsSize = (int)1 << parser->m_nsAttsPower;
  3099. unsigned char oldNsAttsPower = parser->m_nsAttsPower;
  3100. /* size of hash table must be at least 2 * (# of prefixed attributes) */
  3101. if ((nPrefixes << 1) >> parser->m_nsAttsPower) { /* true for m_nsAttsPower = 0 */
  3102. NS_ATT *temp;
  3103. /* hash table size must also be a power of 2 and >= 8 */
  3104. while (nPrefixes >> parser->m_nsAttsPower++);
  3105. if (parser->m_nsAttsPower < 3)
  3106. parser->m_nsAttsPower = 3;
  3107. nsAttsSize = (int)1 << parser->m_nsAttsPower;
  3108. temp = (NS_ATT *)REALLOC(parser, parser->m_nsAtts, nsAttsSize * sizeof(NS_ATT));
  3109. if (!temp) {
  3110. /* Restore actual size of memory in m_nsAtts */
  3111. parser->m_nsAttsPower = oldNsAttsPower;
  3112. return XML_ERROR_NO_MEMORY;
  3113. }
  3114. parser->m_nsAtts = temp;
  3115. version = 0; /* force re-initialization of m_nsAtts hash table */
  3116. }
  3117. /* using a version flag saves us from initializing m_nsAtts every time */
  3118. if (!version) { /* initialize version flags when version wraps around */
  3119. version = INIT_ATTS_VERSION;
  3120. for (j = nsAttsSize; j != 0; )
  3121. parser->m_nsAtts[--j].version = version;
  3122. }
  3123. parser->m_nsAttsVersion = --version;
  3124. /* expand prefixed names and check for duplicates */
  3125. for (; i < attIndex; i += 2) {
  3126. const XML_Char *s = appAtts[i];
  3127. if (s[-1] == 2) { /* prefixed */
  3128. ATTRIBUTE_ID *id;
  3129. const BINDING *b;
  3130. unsigned long uriHash;
  3131. struct siphash sip_state;
  3132. struct sipkey sip_key;
  3133. copy_salt_to_sipkey(parser, &sip_key);
  3134. sip24_init(&sip_state, &sip_key);
  3135. ((XML_Char *)s)[-1] = 0; /* clear flag */
  3136. id = (ATTRIBUTE_ID *)lookup(parser, &dtd->attributeIds, s, 0);
  3137. if (!id || !id->prefix) {
  3138. /* This code is walking through the appAtts array, dealing
  3139. * with (in this case) a prefixed attribute name. To be in
  3140. * the array, the attribute must have already been bound, so
  3141. * has to have passed through the hash table lookup once
  3142. * already. That implies that an entry for it already
  3143. * exists, so the lookup above will return a pointer to
  3144. * already allocated memory. There is no opportunaity for
  3145. * the allocator to fail, so the condition above cannot be
  3146. * fulfilled.
  3147. *
  3148. * Since it is difficult to be certain that the above
  3149. * analysis is complete, we retain the test and merely
  3150. * remove the code from coverage tests.
  3151. */
  3152. return XML_ERROR_NO_MEMORY; /* LCOV_EXCL_LINE */
  3153. }
  3154. b = id->prefix->binding;
  3155. if (!b)
  3156. return XML_ERROR_UNBOUND_PREFIX;
  3157. for (j = 0; j < b->uriLen; j++) {
  3158. const XML_Char c = b->uri[j];
  3159. if (!poolAppendChar(&parser->m_tempPool, c))
  3160. return XML_ERROR_NO_MEMORY;
  3161. }
  3162. sip24_update(&sip_state, b->uri, b->uriLen * sizeof(XML_Char));
  3163. while (*s++ != XML_T(ASCII_COLON))
  3164. ;
  3165. sip24_update(&sip_state, s, keylen(s) * sizeof(XML_Char));
  3166. do { /* copies null terminator */
  3167. if (!poolAppendChar(&parser->m_tempPool, *s))
  3168. return XML_ERROR_NO_MEMORY;
  3169. } while (*s++);
  3170. uriHash = (unsigned long)sip24_final(&sip_state);
  3171. { /* Check hash table for duplicate of expanded name (uriName).
  3172. Derived from code in lookup(parser, HASH_TABLE *table, ...).
  3173. */
  3174. unsigned char step = 0;
  3175. unsigned long mask = nsAttsSize - 1;
  3176. j = uriHash & mask; /* index into hash table */
  3177. while (parser->m_nsAtts[j].version == version) {
  3178. /* for speed we compare stored hash values first */
  3179. if (uriHash == parser->m_nsAtts[j].hash) {
  3180. const XML_Char *s1 = poolStart(&parser->m_tempPool);
  3181. const XML_Char *s2 = parser->m_nsAtts[j].uriName;
  3182. /* s1 is null terminated, but not s2 */
  3183. for (; *s1 == *s2 && *s1 != 0; s1++, s2++);
  3184. if (*s1 == 0)
  3185. return XML_ERROR_DUPLICATE_ATTRIBUTE;
  3186. }
  3187. if (!step)
  3188. step = PROBE_STEP(uriHash, mask, parser->m_nsAttsPower);
  3189. j < step ? (j += nsAttsSize - step) : (j -= step);
  3190. }
  3191. }
  3192. if (parser->m_ns_triplets) { /* append namespace separator and prefix */
  3193. parser->m_tempPool.ptr[-1] = parser->m_namespaceSeparator;
  3194. s = b->prefix->name;
  3195. do {
  3196. if (!poolAppendChar(&parser->m_tempPool, *s))
  3197. return XML_ERROR_NO_MEMORY;
  3198. } while (*s++);
  3199. }
  3200. /* store expanded name in attribute list */
  3201. s = poolStart(&parser->m_tempPool);
  3202. poolFinish(&parser->m_tempPool);
  3203. appAtts[i] = s;
  3204. /* fill empty slot with new version, uriName and hash value */
  3205. parser->m_nsAtts[j].version = version;
  3206. parser->m_nsAtts[j].hash = uriHash;
  3207. parser->m_nsAtts[j].uriName = s;
  3208. if (!--nPrefixes) {
  3209. i += 2;
  3210. break;
  3211. }
  3212. }
  3213. else /* not prefixed */
  3214. ((XML_Char *)s)[-1] = 0; /* clear flag */
  3215. }
  3216. }
  3217. /* clear flags for the remaining attributes */
  3218. for (; i < attIndex; i += 2)
  3219. ((XML_Char *)(appAtts[i]))[-1] = 0;
  3220. for (binding = *bindingsPtr; binding; binding = binding->nextTagBinding)
  3221. binding->attId->name[-1] = 0;
  3222. if (!parser->m_ns)
  3223. return XML_ERROR_NONE;
  3224. /* expand the element type name */
  3225. if (elementType->prefix) {
  3226. binding = elementType->prefix->binding;
  3227. if (!binding)
  3228. return XML_ERROR_UNBOUND_PREFIX;
  3229. localPart = tagNamePtr->str;
  3230. while (*localPart++ != XML_T(ASCII_COLON))
  3231. ;
  3232. }
  3233. else if (dtd->defaultPrefix.binding) {
  3234. binding = dtd->defaultPrefix.binding;
  3235. localPart = tagNamePtr->str;
  3236. }
  3237. else
  3238. return XML_ERROR_NONE;
  3239. prefixLen = 0;
  3240. if (parser->m_ns_triplets && binding->prefix->name) {
  3241. for (; binding->prefix->name[prefixLen++];)
  3242. ; /* prefixLen includes null terminator */
  3243. }
  3244. tagNamePtr->localPart = localPart;
  3245. tagNamePtr->uriLen = binding->uriLen;
  3246. tagNamePtr->prefix = binding->prefix->name;
  3247. tagNamePtr->prefixLen = prefixLen;
  3248. for (i = 0; localPart[i++];)
  3249. ; /* i includes null terminator */
  3250. n = i + binding->uriLen + prefixLen;
  3251. if (n > binding->uriAlloc) {
  3252. TAG *p;
  3253. uri = (XML_Char *)MALLOC(parser, (n + EXPAND_SPARE) * sizeof(XML_Char));
  3254. if (!uri)
  3255. return XML_ERROR_NO_MEMORY;
  3256. binding->uriAlloc = n + EXPAND_SPARE;
  3257. memcpy(uri, binding->uri, binding->uriLen * sizeof(XML_Char));
  3258. for (p = parser->m_tagStack; p; p = p->parent)
  3259. if (p->name.str == binding->uri)
  3260. p->name.str = uri;
  3261. FREE(parser, binding->uri);
  3262. binding->uri = uri;
  3263. }
  3264. /* if m_namespaceSeparator != '\0' then uri includes it already */
  3265. uri = binding->uri + binding->uriLen;
  3266. memcpy(uri, localPart, i * sizeof(XML_Char));
  3267. /* we always have a namespace separator between localPart and prefix */
  3268. if (prefixLen) {
  3269. uri += i - 1;
  3270. *uri = parser->m_namespaceSeparator; /* replace null terminator */
  3271. memcpy(uri + 1, binding->prefix->name, prefixLen * sizeof(XML_Char));
  3272. }
  3273. tagNamePtr->str = binding->uri;
  3274. return XML_ERROR_NONE;
  3275. }
  3276. /* addBinding() overwrites the value of prefix->binding without checking.
  3277. Therefore one must keep track of the old value outside of addBinding().
  3278. */
  3279. static enum XML_Error
  3280. addBinding(XML_Parser parser, PREFIX *prefix, const ATTRIBUTE_ID *attId,
  3281. const XML_Char *uri, BINDING **bindingsPtr)
  3282. {
  3283. static const XML_Char xmlNamespace[] = {
  3284. ASCII_h, ASCII_t, ASCII_t, ASCII_p, ASCII_COLON, ASCII_SLASH, ASCII_SLASH,
  3285. ASCII_w, ASCII_w, ASCII_w, ASCII_PERIOD, ASCII_w, ASCII_3, ASCII_PERIOD,
  3286. ASCII_o, ASCII_r, ASCII_g, ASCII_SLASH, ASCII_X, ASCII_M, ASCII_L,
  3287. ASCII_SLASH, ASCII_1, ASCII_9, ASCII_9, ASCII_8, ASCII_SLASH,
  3288. ASCII_n, ASCII_a, ASCII_m, ASCII_e, ASCII_s, ASCII_p, ASCII_a, ASCII_c,
  3289. ASCII_e, '\0'
  3290. };
  3291. static const int xmlLen =
  3292. (int)sizeof(xmlNamespace)/sizeof(XML_Char) - 1;
  3293. static const XML_Char xmlnsNamespace[] = {
  3294. ASCII_h, ASCII_t, ASCII_t, ASCII_p, ASCII_COLON, ASCII_SLASH, ASCII_SLASH,
  3295. ASCII_w, ASCII_w, ASCII_w, ASCII_PERIOD, ASCII_w, ASCII_3, ASCII_PERIOD,
  3296. ASCII_o, ASCII_r, ASCII_g, ASCII_SLASH, ASCII_2, ASCII_0, ASCII_0,
  3297. ASCII_0, ASCII_SLASH, ASCII_x, ASCII_m, ASCII_l, ASCII_n, ASCII_s,
  3298. ASCII_SLASH, '\0'
  3299. };
  3300. static const int xmlnsLen =
  3301. (int)sizeof(xmlnsNamespace)/sizeof(XML_Char) - 1;
  3302. XML_Bool mustBeXML = XML_FALSE;
  3303. XML_Bool isXML = XML_TRUE;
  3304. XML_Bool isXMLNS = XML_TRUE;
  3305. BINDING *b;
  3306. int len;
  3307. /* empty URI is only valid for default namespace per XML NS 1.0 (not 1.1) */
  3308. if (*uri == XML_T('\0') && prefix->name)
  3309. return XML_ERROR_UNDECLARING_PREFIX;
  3310. if (prefix->name
  3311. && prefix->name[0] == XML_T(ASCII_x)
  3312. && prefix->name[1] == XML_T(ASCII_m)
  3313. && prefix->name[2] == XML_T(ASCII_l)) {
  3314. /* Not allowed to bind xmlns */
  3315. if (prefix->name[3] == XML_T(ASCII_n)
  3316. && prefix->name[4] == XML_T(ASCII_s)
  3317. && prefix->name[5] == XML_T('\0'))
  3318. return XML_ERROR_RESERVED_PREFIX_XMLNS;
  3319. if (prefix->name[3] == XML_T('\0'))
  3320. mustBeXML = XML_TRUE;
  3321. }
  3322. for (len = 0; uri[len]; len++) {
  3323. if (isXML && (len > xmlLen || uri[len] != xmlNamespace[len]))
  3324. isXML = XML_FALSE;
  3325. if (!mustBeXML && isXMLNS
  3326. && (len > xmlnsLen || uri[len] != xmlnsNamespace[len]))
  3327. isXMLNS = XML_FALSE;
  3328. }
  3329. isXML = isXML && len == xmlLen;
  3330. isXMLNS = isXMLNS && len == xmlnsLen;
  3331. if (mustBeXML != isXML)
  3332. return mustBeXML ? XML_ERROR_RESERVED_PREFIX_XML
  3333. : XML_ERROR_RESERVED_NAMESPACE_URI;
  3334. if (isXMLNS)
  3335. return XML_ERROR_RESERVED_NAMESPACE_URI;
  3336. if (parser->m_namespaceSeparator)
  3337. len++;
  3338. if (parser->m_freeBindingList) {
  3339. b = parser->m_freeBindingList;
  3340. if (len > b->uriAlloc) {
  3341. XML_Char *temp = (XML_Char *)REALLOC(parser, b->uri,
  3342. sizeof(XML_Char) * (len + EXPAND_SPARE));
  3343. if (temp == NULL)
  3344. return XML_ERROR_NO_MEMORY;
  3345. b->uri = temp;
  3346. b->uriAlloc = len + EXPAND_SPARE;
  3347. }
  3348. parser->m_freeBindingList = b->nextTagBinding;
  3349. }
  3350. else {
  3351. b = (BINDING *)MALLOC(parser, sizeof(BINDING));
  3352. if (!b)
  3353. return XML_ERROR_NO_MEMORY;
  3354. b->uri = (XML_Char *)MALLOC(parser, sizeof(XML_Char) * (len + EXPAND_SPARE));
  3355. if (!b->uri) {
  3356. FREE(parser, b);
  3357. return XML_ERROR_NO_MEMORY;
  3358. }
  3359. b->uriAlloc = len + EXPAND_SPARE;
  3360. }
  3361. b->uriLen = len;
  3362. memcpy(b->uri, uri, len * sizeof(XML_Char));
  3363. if (parser->m_namespaceSeparator)
  3364. b->uri[len - 1] = parser->m_namespaceSeparator;
  3365. b->prefix = prefix;
  3366. b->attId = attId;
  3367. b->prevPrefixBinding = prefix->binding;
  3368. /* NULL binding when default namespace undeclared */
  3369. if (*uri == XML_T('\0') && prefix == &parser->m_dtd->defaultPrefix)
  3370. prefix->binding = NULL;
  3371. else
  3372. prefix->binding = b;
  3373. b->nextTagBinding = *bindingsPtr;
  3374. *bindingsPtr = b;
  3375. /* if attId == NULL then we are not starting a namespace scope */
  3376. if (attId && parser->m_startNamespaceDeclHandler)
  3377. parser->m_startNamespaceDeclHandler(parser->m_handlerArg, prefix->name,
  3378. prefix->binding ? uri : 0);
  3379. return XML_ERROR_NONE;
  3380. }
  3381. /* The idea here is to avoid using stack for each CDATA section when
  3382. the whole file is parsed with one call.
  3383. */
  3384. static enum XML_Error PTRCALL
  3385. cdataSectionProcessor(XML_Parser parser,
  3386. const char *start,
  3387. const char *end,
  3388. const char **endPtr)
  3389. {
  3390. enum XML_Error result = doCdataSection(parser, parser->m_encoding, &start, end,
  3391. endPtr, (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  3392. if (result != XML_ERROR_NONE)
  3393. return result;
  3394. if (start) {
  3395. if (parser->m_parentParser) { /* we are parsing an external entity */
  3396. parser->m_processor = externalEntityContentProcessor;
  3397. return externalEntityContentProcessor(parser, start, end, endPtr);
  3398. }
  3399. else {
  3400. parser->m_processor = contentProcessor;
  3401. return contentProcessor(parser, start, end, endPtr);
  3402. }
  3403. }
  3404. return result;
  3405. }
  3406. /* startPtr gets set to non-null if the section is closed, and to null if
  3407. the section is not yet closed.
  3408. */
  3409. static enum XML_Error
  3410. doCdataSection(XML_Parser parser,
  3411. const ENCODING *enc,
  3412. const char **startPtr,
  3413. const char *end,
  3414. const char **nextPtr,
  3415. XML_Bool haveMore)
  3416. {
  3417. const char *s = *startPtr;
  3418. const char **eventPP;
  3419. const char **eventEndPP;
  3420. if (enc == parser->m_encoding) {
  3421. eventPP = &parser->m_eventPtr;
  3422. *eventPP = s;
  3423. eventEndPP = &parser->m_eventEndPtr;
  3424. }
  3425. else {
  3426. eventPP = &(parser->m_openInternalEntities->internalEventPtr);
  3427. eventEndPP = &(parser->m_openInternalEntities->internalEventEndPtr);
  3428. }
  3429. *eventPP = s;
  3430. *startPtr = NULL;
  3431. for (;;) {
  3432. const char *next;
  3433. int tok = XmlCdataSectionTok(enc, s, end, &next);
  3434. *eventEndPP = next;
  3435. switch (tok) {
  3436. case XML_TOK_CDATA_SECT_CLOSE:
  3437. if (parser->m_endCdataSectionHandler)
  3438. parser->m_endCdataSectionHandler(parser->m_handlerArg);
  3439. #if 0
  3440. /* see comment under XML_TOK_CDATA_SECT_OPEN */
  3441. else if (parser->m_characterDataHandler)
  3442. parser->m_characterDataHandler(parser->m_handlerArg, parser->m_dataBuf, 0);
  3443. #endif
  3444. else if (parser->m_defaultHandler)
  3445. reportDefault(parser, enc, s, next);
  3446. *startPtr = next;
  3447. *nextPtr = next;
  3448. if (parser->m_parsingStatus.parsing == XML_FINISHED)
  3449. return XML_ERROR_ABORTED;
  3450. else
  3451. return XML_ERROR_NONE;
  3452. case XML_TOK_DATA_NEWLINE:
  3453. if (parser->m_characterDataHandler) {
  3454. XML_Char c = 0xA;
  3455. parser->m_characterDataHandler(parser->m_handlerArg, &c, 1);
  3456. }
  3457. else if (parser->m_defaultHandler)
  3458. reportDefault(parser, enc, s, next);
  3459. break;
  3460. case XML_TOK_DATA_CHARS:
  3461. {
  3462. XML_CharacterDataHandler charDataHandler = parser->m_characterDataHandler;
  3463. if (charDataHandler) {
  3464. if (MUST_CONVERT(enc, s)) {
  3465. for (;;) {
  3466. ICHAR *dataPtr = (ICHAR *)parser->m_dataBuf;
  3467. const enum XML_Convert_Result convert_res = XmlConvert(enc, &s, next, &dataPtr, (ICHAR *)parser->m_dataBufEnd);
  3468. *eventEndPP = next;
  3469. charDataHandler(parser->m_handlerArg, parser->m_dataBuf,
  3470. (int)(dataPtr - (ICHAR *)parser->m_dataBuf));
  3471. if ((convert_res == XML_CONVERT_COMPLETED) || (convert_res == XML_CONVERT_INPUT_INCOMPLETE))
  3472. break;
  3473. *eventPP = s;
  3474. }
  3475. }
  3476. else
  3477. charDataHandler(parser->m_handlerArg,
  3478. (XML_Char *)s,
  3479. (int)((XML_Char *)next - (XML_Char *)s));
  3480. }
  3481. else if (parser->m_defaultHandler)
  3482. reportDefault(parser, enc, s, next);
  3483. }
  3484. break;
  3485. case XML_TOK_INVALID:
  3486. *eventPP = next;
  3487. return XML_ERROR_INVALID_TOKEN;
  3488. case XML_TOK_PARTIAL_CHAR:
  3489. if (haveMore) {
  3490. *nextPtr = s;
  3491. return XML_ERROR_NONE;
  3492. }
  3493. return XML_ERROR_PARTIAL_CHAR;
  3494. case XML_TOK_PARTIAL:
  3495. case XML_TOK_NONE:
  3496. if (haveMore) {
  3497. *nextPtr = s;
  3498. return XML_ERROR_NONE;
  3499. }
  3500. return XML_ERROR_UNCLOSED_CDATA_SECTION;
  3501. default:
  3502. /* Every token returned by XmlCdataSectionTok() has its own
  3503. * explicit case, so this default case will never be executed.
  3504. * We retain it as a safety net and exclude it from the coverage
  3505. * statistics.
  3506. *
  3507. * LCOV_EXCL_START
  3508. */
  3509. *eventPP = next;
  3510. return XML_ERROR_UNEXPECTED_STATE;
  3511. /* LCOV_EXCL_STOP */
  3512. }
  3513. *eventPP = s = next;
  3514. switch (parser->m_parsingStatus.parsing) {
  3515. case XML_SUSPENDED:
  3516. *nextPtr = next;
  3517. return XML_ERROR_NONE;
  3518. case XML_FINISHED:
  3519. return XML_ERROR_ABORTED;
  3520. default: ;
  3521. }
  3522. }
  3523. /* not reached */
  3524. }
  3525. #ifdef XML_DTD
  3526. /* The idea here is to avoid using stack for each IGNORE section when
  3527. the whole file is parsed with one call.
  3528. */
  3529. static enum XML_Error PTRCALL
  3530. ignoreSectionProcessor(XML_Parser parser,
  3531. const char *start,
  3532. const char *end,
  3533. const char **endPtr)
  3534. {
  3535. enum XML_Error result = doIgnoreSection(parser, parser->m_encoding, &start, end,
  3536. endPtr, (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  3537. if (result != XML_ERROR_NONE)
  3538. return result;
  3539. if (start) {
  3540. parser->m_processor = prologProcessor;
  3541. return prologProcessor(parser, start, end, endPtr);
  3542. }
  3543. return result;
  3544. }
  3545. /* startPtr gets set to non-null is the section is closed, and to null
  3546. if the section is not yet closed.
  3547. */
  3548. static enum XML_Error
  3549. doIgnoreSection(XML_Parser parser,
  3550. const ENCODING *enc,
  3551. const char **startPtr,
  3552. const char *end,
  3553. const char **nextPtr,
  3554. XML_Bool haveMore)
  3555. {
  3556. const char *next;
  3557. int tok;
  3558. const char *s = *startPtr;
  3559. const char **eventPP;
  3560. const char **eventEndPP;
  3561. if (enc == parser->m_encoding) {
  3562. eventPP = &parser->m_eventPtr;
  3563. *eventPP = s;
  3564. eventEndPP = &parser->m_eventEndPtr;
  3565. }
  3566. else {
  3567. /* It's not entirely clear, but it seems the following two lines
  3568. * of code cannot be executed. The only occasions on which 'enc'
  3569. * is not 'encoding' are when this function is called
  3570. * from the internal entity processing, and IGNORE sections are an
  3571. * error in internal entities.
  3572. *
  3573. * Since it really isn't clear that this is true, we keep the code
  3574. * and just remove it from our coverage tests.
  3575. *
  3576. * LCOV_EXCL_START
  3577. */
  3578. eventPP = &(parser->m_openInternalEntities->internalEventPtr);
  3579. eventEndPP = &(parser->m_openInternalEntities->internalEventEndPtr);
  3580. /* LCOV_EXCL_STOP */
  3581. }
  3582. *eventPP = s;
  3583. *startPtr = NULL;
  3584. tok = XmlIgnoreSectionTok(enc, s, end, &next);
  3585. *eventEndPP = next;
  3586. switch (tok) {
  3587. case XML_TOK_IGNORE_SECT:
  3588. if (parser->m_defaultHandler)
  3589. reportDefault(parser, enc, s, next);
  3590. *startPtr = next;
  3591. *nextPtr = next;
  3592. if (parser->m_parsingStatus.parsing == XML_FINISHED)
  3593. return XML_ERROR_ABORTED;
  3594. else
  3595. return XML_ERROR_NONE;
  3596. case XML_TOK_INVALID:
  3597. *eventPP = next;
  3598. return XML_ERROR_INVALID_TOKEN;
  3599. case XML_TOK_PARTIAL_CHAR:
  3600. if (haveMore) {
  3601. *nextPtr = s;
  3602. return XML_ERROR_NONE;
  3603. }
  3604. return XML_ERROR_PARTIAL_CHAR;
  3605. case XML_TOK_PARTIAL:
  3606. case XML_TOK_NONE:
  3607. if (haveMore) {
  3608. *nextPtr = s;
  3609. return XML_ERROR_NONE;
  3610. }
  3611. return XML_ERROR_SYNTAX; /* XML_ERROR_UNCLOSED_IGNORE_SECTION */
  3612. default:
  3613. /* All of the tokens that XmlIgnoreSectionTok() returns have
  3614. * explicit cases to handle them, so this default case is never
  3615. * executed. We keep it as a safety net anyway, and remove it
  3616. * from our test coverage statistics.
  3617. *
  3618. * LCOV_EXCL_START
  3619. */
  3620. *eventPP = next;
  3621. return XML_ERROR_UNEXPECTED_STATE;
  3622. /* LCOV_EXCL_STOP */
  3623. }
  3624. /* not reached */
  3625. }
  3626. #endif /* XML_DTD */
  3627. static enum XML_Error
  3628. initializeEncoding(XML_Parser parser)
  3629. {
  3630. const char *s;
  3631. #ifdef XML_UNICODE
  3632. char encodingBuf[128];
  3633. /* See comments abount `protoclEncodingName` in parserInit() */
  3634. if (!parser->m_protocolEncodingName)
  3635. s = NULL;
  3636. else {
  3637. int i;
  3638. for (i = 0; parser->m_protocolEncodingName[i]; i++) {
  3639. if (i == sizeof(encodingBuf) - 1
  3640. || (parser->m_protocolEncodingName[i] & ~0x7f) != 0) {
  3641. encodingBuf[0] = '\0';
  3642. break;
  3643. }
  3644. encodingBuf[i] = (char)parser->m_protocolEncodingName[i];
  3645. }
  3646. encodingBuf[i] = '\0';
  3647. s = encodingBuf;
  3648. }
  3649. #else
  3650. s = parser->m_protocolEncodingName;
  3651. #endif
  3652. if ((parser->m_ns ? XmlInitEncodingNS : XmlInitEncoding)(&parser->m_initEncoding, &parser->m_encoding, s))
  3653. return XML_ERROR_NONE;
  3654. return handleUnknownEncoding(parser, parser->m_protocolEncodingName);
  3655. }
  3656. static enum XML_Error
  3657. processXmlDecl(XML_Parser parser, int isGeneralTextEntity,
  3658. const char *s, const char *next)
  3659. {
  3660. const char *encodingName = NULL;
  3661. const XML_Char *storedEncName = NULL;
  3662. const ENCODING *newEncoding = NULL;
  3663. const char *version = NULL;
  3664. const char *versionend;
  3665. const XML_Char *storedversion = NULL;
  3666. int standalone = -1;
  3667. if (!(parser->m_ns
  3668. ? XmlParseXmlDeclNS
  3669. : XmlParseXmlDecl)(isGeneralTextEntity,
  3670. parser->m_encoding,
  3671. s,
  3672. next,
  3673. &parser->m_eventPtr,
  3674. &version,
  3675. &versionend,
  3676. &encodingName,
  3677. &newEncoding,
  3678. &standalone)) {
  3679. if (isGeneralTextEntity)
  3680. return XML_ERROR_TEXT_DECL;
  3681. else
  3682. return XML_ERROR_XML_DECL;
  3683. }
  3684. if (!isGeneralTextEntity && standalone == 1) {
  3685. parser->m_dtd->standalone = XML_TRUE;
  3686. #ifdef XML_DTD
  3687. if (parser->m_paramEntityParsing == XML_PARAM_ENTITY_PARSING_UNLESS_STANDALONE)
  3688. parser->m_paramEntityParsing = XML_PARAM_ENTITY_PARSING_NEVER;
  3689. #endif /* XML_DTD */
  3690. }
  3691. if (parser->m_xmlDeclHandler) {
  3692. if (encodingName != NULL) {
  3693. storedEncName = poolStoreString(&parser->m_temp2Pool,
  3694. parser->m_encoding,
  3695. encodingName,
  3696. encodingName
  3697. + XmlNameLength(parser->m_encoding, encodingName));
  3698. if (!storedEncName)
  3699. return XML_ERROR_NO_MEMORY;
  3700. poolFinish(&parser->m_temp2Pool);
  3701. }
  3702. if (version) {
  3703. storedversion = poolStoreString(&parser->m_temp2Pool,
  3704. parser->m_encoding,
  3705. version,
  3706. versionend - parser->m_encoding->minBytesPerChar);
  3707. if (!storedversion)
  3708. return XML_ERROR_NO_MEMORY;
  3709. }
  3710. parser->m_xmlDeclHandler(parser->m_handlerArg, storedversion, storedEncName, standalone);
  3711. }
  3712. else if (parser->m_defaultHandler)
  3713. reportDefault(parser, parser->m_encoding, s, next);
  3714. if (parser->m_protocolEncodingName == NULL) {
  3715. if (newEncoding) {
  3716. /* Check that the specified encoding does not conflict with what
  3717. * the parser has already deduced. Do we have the same number
  3718. * of bytes in the smallest representation of a character? If
  3719. * this is UTF-16, is it the same endianness?
  3720. */
  3721. if (newEncoding->minBytesPerChar != parser->m_encoding->minBytesPerChar
  3722. || (newEncoding->minBytesPerChar == 2 &&
  3723. newEncoding != parser->m_encoding)) {
  3724. parser->m_eventPtr = encodingName;
  3725. return XML_ERROR_INCORRECT_ENCODING;
  3726. }
  3727. parser->m_encoding = newEncoding;
  3728. }
  3729. else if (encodingName) {
  3730. enum XML_Error result;
  3731. if (!storedEncName) {
  3732. storedEncName = poolStoreString(
  3733. &parser->m_temp2Pool, parser->m_encoding, encodingName,
  3734. encodingName + XmlNameLength(parser->m_encoding, encodingName));
  3735. if (!storedEncName)
  3736. return XML_ERROR_NO_MEMORY;
  3737. }
  3738. result = handleUnknownEncoding(parser, storedEncName);
  3739. poolClear(&parser->m_temp2Pool);
  3740. if (result == XML_ERROR_UNKNOWN_ENCODING)
  3741. parser->m_eventPtr = encodingName;
  3742. return result;
  3743. }
  3744. }
  3745. if (storedEncName || storedversion)
  3746. poolClear(&parser->m_temp2Pool);
  3747. return XML_ERROR_NONE;
  3748. }
  3749. static enum XML_Error
  3750. handleUnknownEncoding(XML_Parser parser, const XML_Char *encodingName)
  3751. {
  3752. if (parser->m_unknownEncodingHandler) {
  3753. XML_Encoding info;
  3754. int i;
  3755. for (i = 0; i < 256; i++)
  3756. info.map[i] = -1;
  3757. info.convert = NULL;
  3758. info.data = NULL;
  3759. info.release = NULL;
  3760. if (parser->m_unknownEncodingHandler(parser->m_unknownEncodingHandlerData, encodingName,
  3761. &info)) {
  3762. ENCODING *enc;
  3763. parser->m_unknownEncodingMem = MALLOC(parser, XmlSizeOfUnknownEncoding());
  3764. if (!parser->m_unknownEncodingMem) {
  3765. if (info.release)
  3766. info.release(info.data);
  3767. return XML_ERROR_NO_MEMORY;
  3768. }
  3769. enc = (parser->m_ns
  3770. ? XmlInitUnknownEncodingNS
  3771. : XmlInitUnknownEncoding)(parser->m_unknownEncodingMem,
  3772. info.map,
  3773. info.convert,
  3774. info.data);
  3775. if (enc) {
  3776. parser->m_unknownEncodingData = info.data;
  3777. parser->m_unknownEncodingRelease = info.release;
  3778. parser->m_encoding = enc;
  3779. return XML_ERROR_NONE;
  3780. }
  3781. }
  3782. if (info.release != NULL)
  3783. info.release(info.data);
  3784. }
  3785. return XML_ERROR_UNKNOWN_ENCODING;
  3786. }
  3787. static enum XML_Error PTRCALL
  3788. prologInitProcessor(XML_Parser parser,
  3789. const char *s,
  3790. const char *end,
  3791. const char **nextPtr)
  3792. {
  3793. enum XML_Error result = initializeEncoding(parser);
  3794. if (result != XML_ERROR_NONE)
  3795. return result;
  3796. parser->m_processor = prologProcessor;
  3797. return prologProcessor(parser, s, end, nextPtr);
  3798. }
  3799. #ifdef XML_DTD
  3800. static enum XML_Error PTRCALL
  3801. externalParEntInitProcessor(XML_Parser parser,
  3802. const char *s,
  3803. const char *end,
  3804. const char **nextPtr)
  3805. {
  3806. enum XML_Error result = initializeEncoding(parser);
  3807. if (result != XML_ERROR_NONE)
  3808. return result;
  3809. /* we know now that XML_Parse(Buffer) has been called,
  3810. so we consider the external parameter entity read */
  3811. parser->m_dtd->paramEntityRead = XML_TRUE;
  3812. if (parser->m_prologState.inEntityValue) {
  3813. parser->m_processor = entityValueInitProcessor;
  3814. return entityValueInitProcessor(parser, s, end, nextPtr);
  3815. }
  3816. else {
  3817. parser->m_processor = externalParEntProcessor;
  3818. return externalParEntProcessor(parser, s, end, nextPtr);
  3819. }
  3820. }
  3821. static enum XML_Error PTRCALL
  3822. entityValueInitProcessor(XML_Parser parser,
  3823. const char *s,
  3824. const char *end,
  3825. const char **nextPtr)
  3826. {
  3827. int tok;
  3828. const char *start = s;
  3829. const char *next = start;
  3830. parser->m_eventPtr = start;
  3831. for (;;) {
  3832. tok = XmlPrologTok(parser->m_encoding, start, end, &next);
  3833. parser->m_eventEndPtr = next;
  3834. if (tok <= 0) {
  3835. if (!parser->m_parsingStatus.finalBuffer && tok != XML_TOK_INVALID) {
  3836. *nextPtr = s;
  3837. return XML_ERROR_NONE;
  3838. }
  3839. switch (tok) {
  3840. case XML_TOK_INVALID:
  3841. return XML_ERROR_INVALID_TOKEN;
  3842. case XML_TOK_PARTIAL:
  3843. return XML_ERROR_UNCLOSED_TOKEN;
  3844. case XML_TOK_PARTIAL_CHAR:
  3845. return XML_ERROR_PARTIAL_CHAR;
  3846. case XML_TOK_NONE: /* start == end */
  3847. default:
  3848. break;
  3849. }
  3850. /* found end of entity value - can store it now */
  3851. return storeEntityValue(parser, parser->m_encoding, s, end);
  3852. }
  3853. else if (tok == XML_TOK_XML_DECL) {
  3854. enum XML_Error result;
  3855. result = processXmlDecl(parser, 0, start, next);
  3856. if (result != XML_ERROR_NONE)
  3857. return result;
  3858. /* At this point, m_parsingStatus.parsing cannot be XML_SUSPENDED. For that
  3859. * to happen, a parameter entity parsing handler must have
  3860. * attempted to suspend the parser, which fails and raises an
  3861. * error. The parser can be aborted, but can't be suspended.
  3862. */
  3863. if (parser->m_parsingStatus.parsing == XML_FINISHED)
  3864. return XML_ERROR_ABORTED;
  3865. *nextPtr = next;
  3866. /* stop scanning for text declaration - we found one */
  3867. parser->m_processor = entityValueProcessor;
  3868. return entityValueProcessor(parser, next, end, nextPtr);
  3869. }
  3870. /* If we are at the end of the buffer, this would cause XmlPrologTok to
  3871. return XML_TOK_NONE on the next call, which would then cause the
  3872. function to exit with *nextPtr set to s - that is what we want for other
  3873. tokens, but not for the BOM - we would rather like to skip it;
  3874. then, when this routine is entered the next time, XmlPrologTok will
  3875. return XML_TOK_INVALID, since the BOM is still in the buffer
  3876. */
  3877. else if (tok == XML_TOK_BOM && next == end && !parser->m_parsingStatus.finalBuffer) {
  3878. *nextPtr = next;
  3879. return XML_ERROR_NONE;
  3880. }
  3881. /* If we get this token, we have the start of what might be a
  3882. normal tag, but not a declaration (i.e. it doesn't begin with
  3883. "<!"). In a DTD context, that isn't legal.
  3884. */
  3885. else if (tok == XML_TOK_INSTANCE_START) {
  3886. *nextPtr = next;
  3887. return XML_ERROR_SYNTAX;
  3888. }
  3889. start = next;
  3890. parser->m_eventPtr = start;
  3891. }
  3892. }
  3893. static enum XML_Error PTRCALL
  3894. externalParEntProcessor(XML_Parser parser,
  3895. const char *s,
  3896. const char *end,
  3897. const char **nextPtr)
  3898. {
  3899. const char *next = s;
  3900. int tok;
  3901. tok = XmlPrologTok(parser->m_encoding, s, end, &next);
  3902. if (tok <= 0) {
  3903. if (!parser->m_parsingStatus.finalBuffer && tok != XML_TOK_INVALID) {
  3904. *nextPtr = s;
  3905. return XML_ERROR_NONE;
  3906. }
  3907. switch (tok) {
  3908. case XML_TOK_INVALID:
  3909. return XML_ERROR_INVALID_TOKEN;
  3910. case XML_TOK_PARTIAL:
  3911. return XML_ERROR_UNCLOSED_TOKEN;
  3912. case XML_TOK_PARTIAL_CHAR:
  3913. return XML_ERROR_PARTIAL_CHAR;
  3914. case XML_TOK_NONE: /* start == end */
  3915. default:
  3916. break;
  3917. }
  3918. }
  3919. /* This would cause the next stage, i.e. doProlog to be passed XML_TOK_BOM.
  3920. However, when parsing an external subset, doProlog will not accept a BOM
  3921. as valid, and report a syntax error, so we have to skip the BOM
  3922. */
  3923. else if (tok == XML_TOK_BOM) {
  3924. s = next;
  3925. tok = XmlPrologTok(parser->m_encoding, s, end, &next);
  3926. }
  3927. parser->m_processor = prologProcessor;
  3928. return doProlog(parser, parser->m_encoding, s, end, tok, next,
  3929. nextPtr, (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  3930. }
  3931. static enum XML_Error PTRCALL
  3932. entityValueProcessor(XML_Parser parser,
  3933. const char *s,
  3934. const char *end,
  3935. const char **nextPtr)
  3936. {
  3937. const char *start = s;
  3938. const char *next = s;
  3939. const ENCODING *enc = parser->m_encoding;
  3940. int tok;
  3941. for (;;) {
  3942. tok = XmlPrologTok(enc, start, end, &next);
  3943. if (tok <= 0) {
  3944. if (!parser->m_parsingStatus.finalBuffer && tok != XML_TOK_INVALID) {
  3945. *nextPtr = s;
  3946. return XML_ERROR_NONE;
  3947. }
  3948. switch (tok) {
  3949. case XML_TOK_INVALID:
  3950. return XML_ERROR_INVALID_TOKEN;
  3951. case XML_TOK_PARTIAL:
  3952. return XML_ERROR_UNCLOSED_TOKEN;
  3953. case XML_TOK_PARTIAL_CHAR:
  3954. return XML_ERROR_PARTIAL_CHAR;
  3955. case XML_TOK_NONE: /* start == end */
  3956. default:
  3957. break;
  3958. }
  3959. /* found end of entity value - can store it now */
  3960. return storeEntityValue(parser, enc, s, end);
  3961. }
  3962. start = next;
  3963. }
  3964. }
  3965. #endif /* XML_DTD */
  3966. static enum XML_Error PTRCALL
  3967. prologProcessor(XML_Parser parser,
  3968. const char *s,
  3969. const char *end,
  3970. const char **nextPtr)
  3971. {
  3972. const char *next = s;
  3973. int tok = XmlPrologTok(parser->m_encoding, s, end, &next);
  3974. return doProlog(parser, parser->m_encoding, s, end, tok, next,
  3975. nextPtr, (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  3976. }
  3977. static enum XML_Error
  3978. doProlog(XML_Parser parser,
  3979. const ENCODING *enc,
  3980. const char *s,
  3981. const char *end,
  3982. int tok,
  3983. const char *next,
  3984. const char **nextPtr,
  3985. XML_Bool haveMore)
  3986. {
  3987. #ifdef XML_DTD
  3988. static const XML_Char externalSubsetName[] = { ASCII_HASH , '\0' };
  3989. #endif /* XML_DTD */
  3990. static const XML_Char atypeCDATA[] =
  3991. { ASCII_C, ASCII_D, ASCII_A, ASCII_T, ASCII_A, '\0' };
  3992. static const XML_Char atypeID[] = { ASCII_I, ASCII_D, '\0' };
  3993. static const XML_Char atypeIDREF[] =
  3994. { ASCII_I, ASCII_D, ASCII_R, ASCII_E, ASCII_F, '\0' };
  3995. static const XML_Char atypeIDREFS[] =
  3996. { ASCII_I, ASCII_D, ASCII_R, ASCII_E, ASCII_F, ASCII_S, '\0' };
  3997. static const XML_Char atypeENTITY[] =
  3998. { ASCII_E, ASCII_N, ASCII_T, ASCII_I, ASCII_T, ASCII_Y, '\0' };
  3999. static const XML_Char atypeENTITIES[] = { ASCII_E, ASCII_N,
  4000. ASCII_T, ASCII_I, ASCII_T, ASCII_I, ASCII_E, ASCII_S, '\0' };
  4001. static const XML_Char atypeNMTOKEN[] = {
  4002. ASCII_N, ASCII_M, ASCII_T, ASCII_O, ASCII_K, ASCII_E, ASCII_N, '\0' };
  4003. static const XML_Char atypeNMTOKENS[] = { ASCII_N, ASCII_M, ASCII_T,
  4004. ASCII_O, ASCII_K, ASCII_E, ASCII_N, ASCII_S, '\0' };
  4005. static const XML_Char notationPrefix[] = { ASCII_N, ASCII_O, ASCII_T,
  4006. ASCII_A, ASCII_T, ASCII_I, ASCII_O, ASCII_N, ASCII_LPAREN, '\0' };
  4007. static const XML_Char enumValueSep[] = { ASCII_PIPE, '\0' };
  4008. static const XML_Char enumValueStart[] = { ASCII_LPAREN, '\0' };
  4009. /* save one level of indirection */
  4010. DTD * const dtd = parser->m_dtd;
  4011. const char **eventPP;
  4012. const char **eventEndPP;
  4013. enum XML_Content_Quant quant;
  4014. if (enc == parser->m_encoding) {
  4015. eventPP = &parser->m_eventPtr;
  4016. eventEndPP = &parser->m_eventEndPtr;
  4017. }
  4018. else {
  4019. eventPP = &(parser->m_openInternalEntities->internalEventPtr);
  4020. eventEndPP = &(parser->m_openInternalEntities->internalEventEndPtr);
  4021. }
  4022. for (;;) {
  4023. int role;
  4024. XML_Bool handleDefault = XML_TRUE;
  4025. *eventPP = s;
  4026. *eventEndPP = next;
  4027. if (tok <= 0) {
  4028. if (haveMore && tok != XML_TOK_INVALID) {
  4029. *nextPtr = s;
  4030. return XML_ERROR_NONE;
  4031. }
  4032. switch (tok) {
  4033. case XML_TOK_INVALID:
  4034. *eventPP = next;
  4035. return XML_ERROR_INVALID_TOKEN;
  4036. case XML_TOK_PARTIAL:
  4037. return XML_ERROR_UNCLOSED_TOKEN;
  4038. case XML_TOK_PARTIAL_CHAR:
  4039. return XML_ERROR_PARTIAL_CHAR;
  4040. case -XML_TOK_PROLOG_S:
  4041. tok = -tok;
  4042. break;
  4043. case XML_TOK_NONE:
  4044. #ifdef XML_DTD
  4045. /* for internal PE NOT referenced between declarations */
  4046. if (enc != parser->m_encoding && !parser->m_openInternalEntities->betweenDecl) {
  4047. *nextPtr = s;
  4048. return XML_ERROR_NONE;
  4049. }
  4050. /* WFC: PE Between Declarations - must check that PE contains
  4051. complete markup, not only for external PEs, but also for
  4052. internal PEs if the reference occurs between declarations.
  4053. */
  4054. if (parser->m_isParamEntity || enc != parser->m_encoding) {
  4055. if (XmlTokenRole(&parser->m_prologState, XML_TOK_NONE, end, end, enc)
  4056. == XML_ROLE_ERROR)
  4057. return XML_ERROR_INCOMPLETE_PE;
  4058. *nextPtr = s;
  4059. return XML_ERROR_NONE;
  4060. }
  4061. #endif /* XML_DTD */
  4062. return XML_ERROR_NO_ELEMENTS;
  4063. default:
  4064. tok = -tok;
  4065. next = end;
  4066. break;
  4067. }
  4068. }
  4069. role = XmlTokenRole(&parser->m_prologState, tok, s, next, enc);
  4070. switch (role) {
  4071. case XML_ROLE_XML_DECL:
  4072. {
  4073. enum XML_Error result = processXmlDecl(parser, 0, s, next);
  4074. if (result != XML_ERROR_NONE)
  4075. return result;
  4076. enc = parser->m_encoding;
  4077. handleDefault = XML_FALSE;
  4078. }
  4079. break;
  4080. case XML_ROLE_DOCTYPE_NAME:
  4081. if (parser->m_startDoctypeDeclHandler) {
  4082. parser->m_doctypeName = poolStoreString(&parser->m_tempPool, enc, s, next);
  4083. if (!parser->m_doctypeName)
  4084. return XML_ERROR_NO_MEMORY;
  4085. poolFinish(&parser->m_tempPool);
  4086. parser->m_doctypePubid = NULL;
  4087. handleDefault = XML_FALSE;
  4088. }
  4089. parser->m_doctypeSysid = NULL; /* always initialize to NULL */
  4090. break;
  4091. case XML_ROLE_DOCTYPE_INTERNAL_SUBSET:
  4092. if (parser->m_startDoctypeDeclHandler) {
  4093. parser->m_startDoctypeDeclHandler(parser->m_handlerArg, parser->m_doctypeName, parser->m_doctypeSysid,
  4094. parser->m_doctypePubid, 1);
  4095. parser->m_doctypeName = NULL;
  4096. poolClear(&parser->m_tempPool);
  4097. handleDefault = XML_FALSE;
  4098. }
  4099. break;
  4100. #ifdef XML_DTD
  4101. case XML_ROLE_TEXT_DECL:
  4102. {
  4103. enum XML_Error result = processXmlDecl(parser, 1, s, next);
  4104. if (result != XML_ERROR_NONE)
  4105. return result;
  4106. enc = parser->m_encoding;
  4107. handleDefault = XML_FALSE;
  4108. }
  4109. break;
  4110. #endif /* XML_DTD */
  4111. case XML_ROLE_DOCTYPE_PUBLIC_ID:
  4112. #ifdef XML_DTD
  4113. parser->m_useForeignDTD = XML_FALSE;
  4114. parser->m_declEntity = (ENTITY *)lookup(parser,
  4115. &dtd->paramEntities,
  4116. externalSubsetName,
  4117. sizeof(ENTITY));
  4118. if (!parser->m_declEntity)
  4119. return XML_ERROR_NO_MEMORY;
  4120. #endif /* XML_DTD */
  4121. dtd->hasParamEntityRefs = XML_TRUE;
  4122. if (parser->m_startDoctypeDeclHandler) {
  4123. XML_Char *pubId;
  4124. if (!XmlIsPublicId(enc, s, next, eventPP))
  4125. return XML_ERROR_PUBLICID;
  4126. pubId = poolStoreString(&parser->m_tempPool, enc,
  4127. s + enc->minBytesPerChar,
  4128. next - enc->minBytesPerChar);
  4129. if (!pubId)
  4130. return XML_ERROR_NO_MEMORY;
  4131. normalizePublicId(pubId);
  4132. poolFinish(&parser->m_tempPool);
  4133. parser->m_doctypePubid = pubId;
  4134. handleDefault = XML_FALSE;
  4135. goto alreadyChecked;
  4136. }
  4137. /* fall through */
  4138. case XML_ROLE_ENTITY_PUBLIC_ID:
  4139. if (!XmlIsPublicId(enc, s, next, eventPP))
  4140. return XML_ERROR_PUBLICID;
  4141. alreadyChecked:
  4142. if (dtd->keepProcessing && parser->m_declEntity) {
  4143. XML_Char *tem = poolStoreString(&dtd->pool,
  4144. enc,
  4145. s + enc->minBytesPerChar,
  4146. next - enc->minBytesPerChar);
  4147. if (!tem)
  4148. return XML_ERROR_NO_MEMORY;
  4149. normalizePublicId(tem);
  4150. parser->m_declEntity->publicId = tem;
  4151. poolFinish(&dtd->pool);
  4152. /* Don't suppress the default handler if we fell through from
  4153. * the XML_ROLE_DOCTYPE_PUBLIC_ID case.
  4154. */
  4155. if (parser->m_entityDeclHandler && role == XML_ROLE_ENTITY_PUBLIC_ID)
  4156. handleDefault = XML_FALSE;
  4157. }
  4158. break;
  4159. case XML_ROLE_DOCTYPE_CLOSE:
  4160. if (parser->m_doctypeName) {
  4161. parser->m_startDoctypeDeclHandler(parser->m_handlerArg, parser->m_doctypeName,
  4162. parser->m_doctypeSysid, parser->m_doctypePubid, 0);
  4163. poolClear(&parser->m_tempPool);
  4164. handleDefault = XML_FALSE;
  4165. }
  4166. /* parser->m_doctypeSysid will be non-NULL in the case of a previous
  4167. XML_ROLE_DOCTYPE_SYSTEM_ID, even if parser->m_startDoctypeDeclHandler
  4168. was not set, indicating an external subset
  4169. */
  4170. #ifdef XML_DTD
  4171. if (parser->m_doctypeSysid || parser->m_useForeignDTD) {
  4172. XML_Bool hadParamEntityRefs = dtd->hasParamEntityRefs;
  4173. dtd->hasParamEntityRefs = XML_TRUE;
  4174. if (parser->m_paramEntityParsing && parser->m_externalEntityRefHandler) {
  4175. ENTITY *entity = (ENTITY *)lookup(parser,
  4176. &dtd->paramEntities,
  4177. externalSubsetName,
  4178. sizeof(ENTITY));
  4179. if (!entity) {
  4180. /* The external subset name "#" will have already been
  4181. * inserted into the hash table at the start of the
  4182. * external entity parsing, so no allocation will happen
  4183. * and lookup() cannot fail.
  4184. */
  4185. return XML_ERROR_NO_MEMORY; /* LCOV_EXCL_LINE */
  4186. }
  4187. if (parser->m_useForeignDTD)
  4188. entity->base = parser->m_curBase;
  4189. dtd->paramEntityRead = XML_FALSE;
  4190. if (!parser->m_externalEntityRefHandler(parser->m_externalEntityRefHandlerArg,
  4191. 0,
  4192. entity->base,
  4193. entity->systemId,
  4194. entity->publicId))
  4195. return XML_ERROR_EXTERNAL_ENTITY_HANDLING;
  4196. if (dtd->paramEntityRead) {
  4197. if (!dtd->standalone &&
  4198. parser->m_notStandaloneHandler &&
  4199. !parser->m_notStandaloneHandler(parser->m_handlerArg))
  4200. return XML_ERROR_NOT_STANDALONE;
  4201. }
  4202. /* if we didn't read the foreign DTD then this means that there
  4203. is no external subset and we must reset dtd->hasParamEntityRefs
  4204. */
  4205. else if (!parser->m_doctypeSysid)
  4206. dtd->hasParamEntityRefs = hadParamEntityRefs;
  4207. /* end of DTD - no need to update dtd->keepProcessing */
  4208. }
  4209. parser->m_useForeignDTD = XML_FALSE;
  4210. }
  4211. #endif /* XML_DTD */
  4212. if (parser->m_endDoctypeDeclHandler) {
  4213. parser->m_endDoctypeDeclHandler(parser->m_handlerArg);
  4214. handleDefault = XML_FALSE;
  4215. }
  4216. break;
  4217. case XML_ROLE_INSTANCE_START:
  4218. #ifdef XML_DTD
  4219. /* if there is no DOCTYPE declaration then now is the
  4220. last chance to read the foreign DTD
  4221. */
  4222. if (parser->m_useForeignDTD) {
  4223. XML_Bool hadParamEntityRefs = dtd->hasParamEntityRefs;
  4224. dtd->hasParamEntityRefs = XML_TRUE;
  4225. if (parser->m_paramEntityParsing && parser->m_externalEntityRefHandler) {
  4226. ENTITY *entity = (ENTITY *)lookup(parser, &dtd->paramEntities,
  4227. externalSubsetName,
  4228. sizeof(ENTITY));
  4229. if (!entity)
  4230. return XML_ERROR_NO_MEMORY;
  4231. entity->base = parser->m_curBase;
  4232. dtd->paramEntityRead = XML_FALSE;
  4233. if (!parser->m_externalEntityRefHandler(parser->m_externalEntityRefHandlerArg,
  4234. 0,
  4235. entity->base,
  4236. entity->systemId,
  4237. entity->publicId))
  4238. return XML_ERROR_EXTERNAL_ENTITY_HANDLING;
  4239. if (dtd->paramEntityRead) {
  4240. if (!dtd->standalone &&
  4241. parser->m_notStandaloneHandler &&
  4242. !parser->m_notStandaloneHandler(parser->m_handlerArg))
  4243. return XML_ERROR_NOT_STANDALONE;
  4244. }
  4245. /* if we didn't read the foreign DTD then this means that there
  4246. is no external subset and we must reset dtd->hasParamEntityRefs
  4247. */
  4248. else
  4249. dtd->hasParamEntityRefs = hadParamEntityRefs;
  4250. /* end of DTD - no need to update dtd->keepProcessing */
  4251. }
  4252. }
  4253. #endif /* XML_DTD */
  4254. parser->m_processor = contentProcessor;
  4255. return contentProcessor(parser, s, end, nextPtr);
  4256. case XML_ROLE_ATTLIST_ELEMENT_NAME:
  4257. parser->m_declElementType = getElementType(parser, enc, s, next);
  4258. if (!parser->m_declElementType)
  4259. return XML_ERROR_NO_MEMORY;
  4260. goto checkAttListDeclHandler;
  4261. case XML_ROLE_ATTRIBUTE_NAME:
  4262. parser->m_declAttributeId = getAttributeId(parser, enc, s, next);
  4263. if (!parser->m_declAttributeId)
  4264. return XML_ERROR_NO_MEMORY;
  4265. parser->m_declAttributeIsCdata = XML_FALSE;
  4266. parser->m_declAttributeType = NULL;
  4267. parser->m_declAttributeIsId = XML_FALSE;
  4268. goto checkAttListDeclHandler;
  4269. case XML_ROLE_ATTRIBUTE_TYPE_CDATA:
  4270. parser->m_declAttributeIsCdata = XML_TRUE;
  4271. parser->m_declAttributeType = atypeCDATA;
  4272. goto checkAttListDeclHandler;
  4273. case XML_ROLE_ATTRIBUTE_TYPE_ID:
  4274. parser->m_declAttributeIsId = XML_TRUE;
  4275. parser->m_declAttributeType = atypeID;
  4276. goto checkAttListDeclHandler;
  4277. case XML_ROLE_ATTRIBUTE_TYPE_IDREF:
  4278. parser->m_declAttributeType = atypeIDREF;
  4279. goto checkAttListDeclHandler;
  4280. case XML_ROLE_ATTRIBUTE_TYPE_IDREFS:
  4281. parser->m_declAttributeType = atypeIDREFS;
  4282. goto checkAttListDeclHandler;
  4283. case XML_ROLE_ATTRIBUTE_TYPE_ENTITY:
  4284. parser->m_declAttributeType = atypeENTITY;
  4285. goto checkAttListDeclHandler;
  4286. case XML_ROLE_ATTRIBUTE_TYPE_ENTITIES:
  4287. parser->m_declAttributeType = atypeENTITIES;
  4288. goto checkAttListDeclHandler;
  4289. case XML_ROLE_ATTRIBUTE_TYPE_NMTOKEN:
  4290. parser->m_declAttributeType = atypeNMTOKEN;
  4291. goto checkAttListDeclHandler;
  4292. case XML_ROLE_ATTRIBUTE_TYPE_NMTOKENS:
  4293. parser->m_declAttributeType = atypeNMTOKENS;
  4294. checkAttListDeclHandler:
  4295. if (dtd->keepProcessing && parser->m_attlistDeclHandler)
  4296. handleDefault = XML_FALSE;
  4297. break;
  4298. case XML_ROLE_ATTRIBUTE_ENUM_VALUE:
  4299. case XML_ROLE_ATTRIBUTE_NOTATION_VALUE:
  4300. if (dtd->keepProcessing && parser->m_attlistDeclHandler) {
  4301. const XML_Char *prefix;
  4302. if (parser->m_declAttributeType) {
  4303. prefix = enumValueSep;
  4304. }
  4305. else {
  4306. prefix = (role == XML_ROLE_ATTRIBUTE_NOTATION_VALUE
  4307. ? notationPrefix
  4308. : enumValueStart);
  4309. }
  4310. if (!poolAppendString(&parser->m_tempPool, prefix))
  4311. return XML_ERROR_NO_MEMORY;
  4312. if (!poolAppend(&parser->m_tempPool, enc, s, next))
  4313. return XML_ERROR_NO_MEMORY;
  4314. parser->m_declAttributeType = parser->m_tempPool.start;
  4315. handleDefault = XML_FALSE;
  4316. }
  4317. break;
  4318. case XML_ROLE_IMPLIED_ATTRIBUTE_VALUE:
  4319. case XML_ROLE_REQUIRED_ATTRIBUTE_VALUE:
  4320. if (dtd->keepProcessing) {
  4321. if (!defineAttribute(parser->m_declElementType, parser->m_declAttributeId,
  4322. parser->m_declAttributeIsCdata, parser->m_declAttributeIsId,
  4323. 0, parser))
  4324. return XML_ERROR_NO_MEMORY;
  4325. if (parser->m_attlistDeclHandler && parser->m_declAttributeType) {
  4326. if (*parser->m_declAttributeType == XML_T(ASCII_LPAREN)
  4327. || (*parser->m_declAttributeType == XML_T(ASCII_N)
  4328. && parser->m_declAttributeType[1] == XML_T(ASCII_O))) {
  4329. /* Enumerated or Notation type */
  4330. if (!poolAppendChar(&parser->m_tempPool, XML_T(ASCII_RPAREN))
  4331. || !poolAppendChar(&parser->m_tempPool, XML_T('\0')))
  4332. return XML_ERROR_NO_MEMORY;
  4333. parser->m_declAttributeType = parser->m_tempPool.start;
  4334. poolFinish(&parser->m_tempPool);
  4335. }
  4336. *eventEndPP = s;
  4337. parser->m_attlistDeclHandler(parser->m_handlerArg, parser->m_declElementType->name,
  4338. parser->m_declAttributeId->name, parser->m_declAttributeType,
  4339. 0, role == XML_ROLE_REQUIRED_ATTRIBUTE_VALUE);
  4340. poolClear(&parser->m_tempPool);
  4341. handleDefault = XML_FALSE;
  4342. }
  4343. }
  4344. break;
  4345. case XML_ROLE_DEFAULT_ATTRIBUTE_VALUE:
  4346. case XML_ROLE_FIXED_ATTRIBUTE_VALUE:
  4347. if (dtd->keepProcessing) {
  4348. const XML_Char *attVal;
  4349. enum XML_Error result =
  4350. storeAttributeValue(parser, enc, parser->m_declAttributeIsCdata,
  4351. s + enc->minBytesPerChar,
  4352. next - enc->minBytesPerChar,
  4353. &dtd->pool);
  4354. if (result)
  4355. return result;
  4356. attVal = poolStart(&dtd->pool);
  4357. poolFinish(&dtd->pool);
  4358. /* ID attributes aren't allowed to have a default */
  4359. if (!defineAttribute(parser->m_declElementType, parser->m_declAttributeId,
  4360. parser->m_declAttributeIsCdata, XML_FALSE, attVal, parser))
  4361. return XML_ERROR_NO_MEMORY;
  4362. if (parser->m_attlistDeclHandler && parser->m_declAttributeType) {
  4363. if (*parser->m_declAttributeType == XML_T(ASCII_LPAREN)
  4364. || (*parser->m_declAttributeType == XML_T(ASCII_N)
  4365. && parser->m_declAttributeType[1] == XML_T(ASCII_O))) {
  4366. /* Enumerated or Notation type */
  4367. if (!poolAppendChar(&parser->m_tempPool, XML_T(ASCII_RPAREN))
  4368. || !poolAppendChar(&parser->m_tempPool, XML_T('\0')))
  4369. return XML_ERROR_NO_MEMORY;
  4370. parser->m_declAttributeType = parser->m_tempPool.start;
  4371. poolFinish(&parser->m_tempPool);
  4372. }
  4373. *eventEndPP = s;
  4374. parser->m_attlistDeclHandler(parser->m_handlerArg, parser->m_declElementType->name,
  4375. parser->m_declAttributeId->name, parser->m_declAttributeType,
  4376. attVal,
  4377. role == XML_ROLE_FIXED_ATTRIBUTE_VALUE);
  4378. poolClear(&parser->m_tempPool);
  4379. handleDefault = XML_FALSE;
  4380. }
  4381. }
  4382. break;
  4383. case XML_ROLE_ENTITY_VALUE:
  4384. if (dtd->keepProcessing) {
  4385. enum XML_Error result = storeEntityValue(parser, enc,
  4386. s + enc->minBytesPerChar,
  4387. next - enc->minBytesPerChar);
  4388. if (parser->m_declEntity) {
  4389. parser->m_declEntity->textPtr = poolStart(&dtd->entityValuePool);
  4390. parser->m_declEntity->textLen = (int)(poolLength(&dtd->entityValuePool));
  4391. poolFinish(&dtd->entityValuePool);
  4392. if (parser->m_entityDeclHandler) {
  4393. *eventEndPP = s;
  4394. parser->m_entityDeclHandler(parser->m_handlerArg,
  4395. parser->m_declEntity->name,
  4396. parser->m_declEntity->is_param,
  4397. parser->m_declEntity->textPtr,
  4398. parser->m_declEntity->textLen,
  4399. parser->m_curBase, 0, 0, 0);
  4400. handleDefault = XML_FALSE;
  4401. }
  4402. }
  4403. else
  4404. poolDiscard(&dtd->entityValuePool);
  4405. if (result != XML_ERROR_NONE)
  4406. return result;
  4407. }
  4408. break;
  4409. case XML_ROLE_DOCTYPE_SYSTEM_ID:
  4410. #ifdef XML_DTD
  4411. parser->m_useForeignDTD = XML_FALSE;
  4412. #endif /* XML_DTD */
  4413. dtd->hasParamEntityRefs = XML_TRUE;
  4414. if (parser->m_startDoctypeDeclHandler) {
  4415. parser->m_doctypeSysid = poolStoreString(&parser->m_tempPool, enc,
  4416. s + enc->minBytesPerChar,
  4417. next - enc->minBytesPerChar);
  4418. if (parser->m_doctypeSysid == NULL)
  4419. return XML_ERROR_NO_MEMORY;
  4420. poolFinish(&parser->m_tempPool);
  4421. handleDefault = XML_FALSE;
  4422. }
  4423. #ifdef XML_DTD
  4424. else
  4425. /* use externalSubsetName to make parser->m_doctypeSysid non-NULL
  4426. for the case where no parser->m_startDoctypeDeclHandler is set */
  4427. parser->m_doctypeSysid = externalSubsetName;
  4428. #endif /* XML_DTD */
  4429. if (!dtd->standalone
  4430. #ifdef XML_DTD
  4431. && !parser->m_paramEntityParsing
  4432. #endif /* XML_DTD */
  4433. && parser->m_notStandaloneHandler
  4434. && !parser->m_notStandaloneHandler(parser->m_handlerArg))
  4435. return XML_ERROR_NOT_STANDALONE;
  4436. #ifndef XML_DTD
  4437. break;
  4438. #else /* XML_DTD */
  4439. if (!parser->m_declEntity) {
  4440. parser->m_declEntity = (ENTITY *)lookup(parser,
  4441. &dtd->paramEntities,
  4442. externalSubsetName,
  4443. sizeof(ENTITY));
  4444. if (!parser->m_declEntity)
  4445. return XML_ERROR_NO_MEMORY;
  4446. parser->m_declEntity->publicId = NULL;
  4447. }
  4448. #endif /* XML_DTD */
  4449. /* fall through */
  4450. case XML_ROLE_ENTITY_SYSTEM_ID:
  4451. if (dtd->keepProcessing && parser->m_declEntity) {
  4452. parser->m_declEntity->systemId = poolStoreString(&dtd->pool, enc,
  4453. s + enc->minBytesPerChar,
  4454. next - enc->minBytesPerChar);
  4455. if (!parser->m_declEntity->systemId)
  4456. return XML_ERROR_NO_MEMORY;
  4457. parser->m_declEntity->base = parser->m_curBase;
  4458. poolFinish(&dtd->pool);
  4459. /* Don't suppress the default handler if we fell through from
  4460. * the XML_ROLE_DOCTYPE_SYSTEM_ID case.
  4461. */
  4462. if (parser->m_entityDeclHandler && role == XML_ROLE_ENTITY_SYSTEM_ID)
  4463. handleDefault = XML_FALSE;
  4464. }
  4465. break;
  4466. case XML_ROLE_ENTITY_COMPLETE:
  4467. if (dtd->keepProcessing && parser->m_declEntity && parser->m_entityDeclHandler) {
  4468. *eventEndPP = s;
  4469. parser->m_entityDeclHandler(parser->m_handlerArg,
  4470. parser->m_declEntity->name,
  4471. parser->m_declEntity->is_param,
  4472. 0,0,
  4473. parser->m_declEntity->base,
  4474. parser->m_declEntity->systemId,
  4475. parser->m_declEntity->publicId,
  4476. 0);
  4477. handleDefault = XML_FALSE;
  4478. }
  4479. break;
  4480. case XML_ROLE_ENTITY_NOTATION_NAME:
  4481. if (dtd->keepProcessing && parser->m_declEntity) {
  4482. parser->m_declEntity->notation = poolStoreString(&dtd->pool, enc, s, next);
  4483. if (!parser->m_declEntity->notation)
  4484. return XML_ERROR_NO_MEMORY;
  4485. poolFinish(&dtd->pool);
  4486. if (parser->m_unparsedEntityDeclHandler) {
  4487. *eventEndPP = s;
  4488. parser->m_unparsedEntityDeclHandler(parser->m_handlerArg,
  4489. parser->m_declEntity->name,
  4490. parser->m_declEntity->base,
  4491. parser->m_declEntity->systemId,
  4492. parser->m_declEntity->publicId,
  4493. parser->m_declEntity->notation);
  4494. handleDefault = XML_FALSE;
  4495. }
  4496. else if (parser->m_entityDeclHandler) {
  4497. *eventEndPP = s;
  4498. parser->m_entityDeclHandler(parser->m_handlerArg,
  4499. parser->m_declEntity->name,
  4500. 0,0,0,
  4501. parser->m_declEntity->base,
  4502. parser->m_declEntity->systemId,
  4503. parser->m_declEntity->publicId,
  4504. parser->m_declEntity->notation);
  4505. handleDefault = XML_FALSE;
  4506. }
  4507. }
  4508. break;
  4509. case XML_ROLE_GENERAL_ENTITY_NAME:
  4510. {
  4511. if (XmlPredefinedEntityName(enc, s, next)) {
  4512. parser->m_declEntity = NULL;
  4513. break;
  4514. }
  4515. if (dtd->keepProcessing) {
  4516. const XML_Char *name = poolStoreString(&dtd->pool, enc, s, next);
  4517. if (!name)
  4518. return XML_ERROR_NO_MEMORY;
  4519. parser->m_declEntity = (ENTITY *)lookup(parser, &dtd->generalEntities, name,
  4520. sizeof(ENTITY));
  4521. if (!parser->m_declEntity)
  4522. return XML_ERROR_NO_MEMORY;
  4523. if (parser->m_declEntity->name != name) {
  4524. poolDiscard(&dtd->pool);
  4525. parser->m_declEntity = NULL;
  4526. }
  4527. else {
  4528. poolFinish(&dtd->pool);
  4529. parser->m_declEntity->publicId = NULL;
  4530. parser->m_declEntity->is_param = XML_FALSE;
  4531. /* if we have a parent parser or are reading an internal parameter
  4532. entity, then the entity declaration is not considered "internal"
  4533. */
  4534. parser->m_declEntity->is_internal = !(parser->m_parentParser || parser->m_openInternalEntities);
  4535. if (parser->m_entityDeclHandler)
  4536. handleDefault = XML_FALSE;
  4537. }
  4538. }
  4539. else {
  4540. poolDiscard(&dtd->pool);
  4541. parser->m_declEntity = NULL;
  4542. }
  4543. }
  4544. break;
  4545. case XML_ROLE_PARAM_ENTITY_NAME:
  4546. #ifdef XML_DTD
  4547. if (dtd->keepProcessing) {
  4548. const XML_Char *name = poolStoreString(&dtd->pool, enc, s, next);
  4549. if (!name)
  4550. return XML_ERROR_NO_MEMORY;
  4551. parser->m_declEntity = (ENTITY *)lookup(parser, &dtd->paramEntities,
  4552. name, sizeof(ENTITY));
  4553. if (!parser->m_declEntity)
  4554. return XML_ERROR_NO_MEMORY;
  4555. if (parser->m_declEntity->name != name) {
  4556. poolDiscard(&dtd->pool);
  4557. parser->m_declEntity = NULL;
  4558. }
  4559. else {
  4560. poolFinish(&dtd->pool);
  4561. parser->m_declEntity->publicId = NULL;
  4562. parser->m_declEntity->is_param = XML_TRUE;
  4563. /* if we have a parent parser or are reading an internal parameter
  4564. entity, then the entity declaration is not considered "internal"
  4565. */
  4566. parser->m_declEntity->is_internal = !(parser->m_parentParser || parser->m_openInternalEntities);
  4567. if (parser->m_entityDeclHandler)
  4568. handleDefault = XML_FALSE;
  4569. }
  4570. }
  4571. else {
  4572. poolDiscard(&dtd->pool);
  4573. parser->m_declEntity = NULL;
  4574. }
  4575. #else /* not XML_DTD */
  4576. parser->m_declEntity = NULL;
  4577. #endif /* XML_DTD */
  4578. break;
  4579. case XML_ROLE_NOTATION_NAME:
  4580. parser->m_declNotationPublicId = NULL;
  4581. parser->m_declNotationName = NULL;
  4582. if (parser->m_notationDeclHandler) {
  4583. parser->m_declNotationName = poolStoreString(&parser->m_tempPool, enc, s, next);
  4584. if (!parser->m_declNotationName)
  4585. return XML_ERROR_NO_MEMORY;
  4586. poolFinish(&parser->m_tempPool);
  4587. handleDefault = XML_FALSE;
  4588. }
  4589. break;
  4590. case XML_ROLE_NOTATION_PUBLIC_ID:
  4591. if (!XmlIsPublicId(enc, s, next, eventPP))
  4592. return XML_ERROR_PUBLICID;
  4593. if (parser->m_declNotationName) { /* means m_notationDeclHandler != NULL */
  4594. XML_Char *tem = poolStoreString(&parser->m_tempPool,
  4595. enc,
  4596. s + enc->minBytesPerChar,
  4597. next - enc->minBytesPerChar);
  4598. if (!tem)
  4599. return XML_ERROR_NO_MEMORY;
  4600. normalizePublicId(tem);
  4601. parser->m_declNotationPublicId = tem;
  4602. poolFinish(&parser->m_tempPool);
  4603. handleDefault = XML_FALSE;
  4604. }
  4605. break;
  4606. case XML_ROLE_NOTATION_SYSTEM_ID:
  4607. if (parser->m_declNotationName && parser->m_notationDeclHandler) {
  4608. const XML_Char *systemId
  4609. = poolStoreString(&parser->m_tempPool, enc,
  4610. s + enc->minBytesPerChar,
  4611. next - enc->minBytesPerChar);
  4612. if (!systemId)
  4613. return XML_ERROR_NO_MEMORY;
  4614. *eventEndPP = s;
  4615. parser->m_notationDeclHandler(parser->m_handlerArg,
  4616. parser->m_declNotationName,
  4617. parser->m_curBase,
  4618. systemId,
  4619. parser->m_declNotationPublicId);
  4620. handleDefault = XML_FALSE;
  4621. }
  4622. poolClear(&parser->m_tempPool);
  4623. break;
  4624. case XML_ROLE_NOTATION_NO_SYSTEM_ID:
  4625. if (parser->m_declNotationPublicId && parser->m_notationDeclHandler) {
  4626. *eventEndPP = s;
  4627. parser->m_notationDeclHandler(parser->m_handlerArg,
  4628. parser->m_declNotationName,
  4629. parser->m_curBase,
  4630. 0,
  4631. parser->m_declNotationPublicId);
  4632. handleDefault = XML_FALSE;
  4633. }
  4634. poolClear(&parser->m_tempPool);
  4635. break;
  4636. case XML_ROLE_ERROR:
  4637. switch (tok) {
  4638. case XML_TOK_PARAM_ENTITY_REF:
  4639. /* PE references in internal subset are
  4640. not allowed within declarations. */
  4641. return XML_ERROR_PARAM_ENTITY_REF;
  4642. case XML_TOK_XML_DECL:
  4643. return XML_ERROR_MISPLACED_XML_PI;
  4644. default:
  4645. return XML_ERROR_SYNTAX;
  4646. }
  4647. #ifdef XML_DTD
  4648. case XML_ROLE_IGNORE_SECT:
  4649. {
  4650. enum XML_Error result;
  4651. if (parser->m_defaultHandler)
  4652. reportDefault(parser, enc, s, next);
  4653. handleDefault = XML_FALSE;
  4654. result = doIgnoreSection(parser, enc, &next, end, nextPtr, haveMore);
  4655. if (result != XML_ERROR_NONE)
  4656. return result;
  4657. else if (!next) {
  4658. parser->m_processor = ignoreSectionProcessor;
  4659. return result;
  4660. }
  4661. }
  4662. break;
  4663. #endif /* XML_DTD */
  4664. case XML_ROLE_GROUP_OPEN:
  4665. if (parser->m_prologState.level >= parser->m_groupSize) {
  4666. if (parser->m_groupSize) {
  4667. char *temp = (char *)REALLOC(parser, parser->m_groupConnector, parser->m_groupSize *= 2);
  4668. if (temp == NULL) {
  4669. parser->m_groupSize /= 2;
  4670. return XML_ERROR_NO_MEMORY;
  4671. }
  4672. parser->m_groupConnector = temp;
  4673. if (dtd->scaffIndex) {
  4674. int *temp = (int *)REALLOC(parser, dtd->scaffIndex,
  4675. parser->m_groupSize * sizeof(int));
  4676. if (temp == NULL)
  4677. return XML_ERROR_NO_MEMORY;
  4678. dtd->scaffIndex = temp;
  4679. }
  4680. }
  4681. else {
  4682. parser->m_groupConnector = (char *)MALLOC(parser, parser->m_groupSize = 32);
  4683. if (!parser->m_groupConnector) {
  4684. parser->m_groupSize = 0;
  4685. return XML_ERROR_NO_MEMORY;
  4686. }
  4687. }
  4688. }
  4689. parser->m_groupConnector[parser->m_prologState.level] = 0;
  4690. if (dtd->in_eldecl) {
  4691. int myindex = nextScaffoldPart(parser);
  4692. if (myindex < 0)
  4693. return XML_ERROR_NO_MEMORY;
  4694. dtd->scaffIndex[dtd->scaffLevel] = myindex;
  4695. dtd->scaffLevel++;
  4696. dtd->scaffold[myindex].type = XML_CTYPE_SEQ;
  4697. if (parser->m_elementDeclHandler)
  4698. handleDefault = XML_FALSE;
  4699. }
  4700. break;
  4701. case XML_ROLE_GROUP_SEQUENCE:
  4702. if (parser->m_groupConnector[parser->m_prologState.level] == ASCII_PIPE)
  4703. return XML_ERROR_SYNTAX;
  4704. parser->m_groupConnector[parser->m_prologState.level] = ASCII_COMMA;
  4705. if (dtd->in_eldecl && parser->m_elementDeclHandler)
  4706. handleDefault = XML_FALSE;
  4707. break;
  4708. case XML_ROLE_GROUP_CHOICE:
  4709. if (parser->m_groupConnector[parser->m_prologState.level] == ASCII_COMMA)
  4710. return XML_ERROR_SYNTAX;
  4711. if (dtd->in_eldecl
  4712. && !parser->m_groupConnector[parser->m_prologState.level]
  4713. && (dtd->scaffold[dtd->scaffIndex[dtd->scaffLevel - 1]].type
  4714. != XML_CTYPE_MIXED)
  4715. ) {
  4716. dtd->scaffold[dtd->scaffIndex[dtd->scaffLevel - 1]].type
  4717. = XML_CTYPE_CHOICE;
  4718. if (parser->m_elementDeclHandler)
  4719. handleDefault = XML_FALSE;
  4720. }
  4721. parser->m_groupConnector[parser->m_prologState.level] = ASCII_PIPE;
  4722. break;
  4723. case XML_ROLE_PARAM_ENTITY_REF:
  4724. #ifdef XML_DTD
  4725. case XML_ROLE_INNER_PARAM_ENTITY_REF:
  4726. dtd->hasParamEntityRefs = XML_TRUE;
  4727. if (!parser->m_paramEntityParsing)
  4728. dtd->keepProcessing = dtd->standalone;
  4729. else {
  4730. const XML_Char *name;
  4731. ENTITY *entity;
  4732. name = poolStoreString(&dtd->pool, enc,
  4733. s + enc->minBytesPerChar,
  4734. next - enc->minBytesPerChar);
  4735. if (!name)
  4736. return XML_ERROR_NO_MEMORY;
  4737. entity = (ENTITY *)lookup(parser, &dtd->paramEntities, name, 0);
  4738. poolDiscard(&dtd->pool);
  4739. /* first, determine if a check for an existing declaration is needed;
  4740. if yes, check that the entity exists, and that it is internal,
  4741. otherwise call the skipped entity handler
  4742. */
  4743. if (parser->m_prologState.documentEntity &&
  4744. (dtd->standalone
  4745. ? !parser->m_openInternalEntities
  4746. : !dtd->hasParamEntityRefs)) {
  4747. if (!entity)
  4748. return XML_ERROR_UNDEFINED_ENTITY;
  4749. else if (!entity->is_internal) {
  4750. /* It's hard to exhaustively search the code to be sure,
  4751. * but there doesn't seem to be a way of executing the
  4752. * following line. There are two cases:
  4753. *
  4754. * If 'standalone' is false, the DTD must have no
  4755. * parameter entities or we wouldn't have passed the outer
  4756. * 'if' statement. That measn the only entity in the hash
  4757. * table is the external subset name "#" which cannot be
  4758. * given as a parameter entity name in XML syntax, so the
  4759. * lookup must have returned NULL and we don't even reach
  4760. * the test for an internal entity.
  4761. *
  4762. * If 'standalone' is true, it does not seem to be
  4763. * possible to create entities taking this code path that
  4764. * are not internal entities, so fail the test above.
  4765. *
  4766. * Because this analysis is very uncertain, the code is
  4767. * being left in place and merely removed from the
  4768. * coverage test statistics.
  4769. */
  4770. return XML_ERROR_ENTITY_DECLARED_IN_PE; /* LCOV_EXCL_LINE */
  4771. }
  4772. }
  4773. else if (!entity) {
  4774. dtd->keepProcessing = dtd->standalone;
  4775. /* cannot report skipped entities in declarations */
  4776. if ((role == XML_ROLE_PARAM_ENTITY_REF) && parser->m_skippedEntityHandler) {
  4777. parser->m_skippedEntityHandler(parser->m_handlerArg, name, 1);
  4778. handleDefault = XML_FALSE;
  4779. }
  4780. break;
  4781. }
  4782. if (entity->open)
  4783. return XML_ERROR_RECURSIVE_ENTITY_REF;
  4784. if (entity->textPtr) {
  4785. enum XML_Error result;
  4786. XML_Bool betweenDecl =
  4787. (role == XML_ROLE_PARAM_ENTITY_REF ? XML_TRUE : XML_FALSE);
  4788. result = processInternalEntity(parser, entity, betweenDecl);
  4789. if (result != XML_ERROR_NONE)
  4790. return result;
  4791. handleDefault = XML_FALSE;
  4792. break;
  4793. }
  4794. if (parser->m_externalEntityRefHandler) {
  4795. dtd->paramEntityRead = XML_FALSE;
  4796. entity->open = XML_TRUE;
  4797. if (!parser->m_externalEntityRefHandler(parser->m_externalEntityRefHandlerArg,
  4798. 0,
  4799. entity->base,
  4800. entity->systemId,
  4801. entity->publicId)) {
  4802. entity->open = XML_FALSE;
  4803. return XML_ERROR_EXTERNAL_ENTITY_HANDLING;
  4804. }
  4805. entity->open = XML_FALSE;
  4806. handleDefault = XML_FALSE;
  4807. if (!dtd->paramEntityRead) {
  4808. dtd->keepProcessing = dtd->standalone;
  4809. break;
  4810. }
  4811. }
  4812. else {
  4813. dtd->keepProcessing = dtd->standalone;
  4814. break;
  4815. }
  4816. }
  4817. #endif /* XML_DTD */
  4818. if (!dtd->standalone &&
  4819. parser->m_notStandaloneHandler &&
  4820. !parser->m_notStandaloneHandler(parser->m_handlerArg))
  4821. return XML_ERROR_NOT_STANDALONE;
  4822. break;
  4823. /* Element declaration stuff */
  4824. case XML_ROLE_ELEMENT_NAME:
  4825. if (parser->m_elementDeclHandler) {
  4826. parser->m_declElementType = getElementType(parser, enc, s, next);
  4827. if (!parser->m_declElementType)
  4828. return XML_ERROR_NO_MEMORY;
  4829. dtd->scaffLevel = 0;
  4830. dtd->scaffCount = 0;
  4831. dtd->in_eldecl = XML_TRUE;
  4832. handleDefault = XML_FALSE;
  4833. }
  4834. break;
  4835. case XML_ROLE_CONTENT_ANY:
  4836. case XML_ROLE_CONTENT_EMPTY:
  4837. if (dtd->in_eldecl) {
  4838. if (parser->m_elementDeclHandler) {
  4839. XML_Content * content = (XML_Content *) MALLOC(parser, sizeof(XML_Content));
  4840. if (!content)
  4841. return XML_ERROR_NO_MEMORY;
  4842. content->quant = XML_CQUANT_NONE;
  4843. content->name = NULL;
  4844. content->numchildren = 0;
  4845. content->children = NULL;
  4846. content->type = ((role == XML_ROLE_CONTENT_ANY) ?
  4847. XML_CTYPE_ANY :
  4848. XML_CTYPE_EMPTY);
  4849. *eventEndPP = s;
  4850. parser->m_elementDeclHandler(parser->m_handlerArg, parser->m_declElementType->name, content);
  4851. handleDefault = XML_FALSE;
  4852. }
  4853. dtd->in_eldecl = XML_FALSE;
  4854. }
  4855. break;
  4856. case XML_ROLE_CONTENT_PCDATA:
  4857. if (dtd->in_eldecl) {
  4858. dtd->scaffold[dtd->scaffIndex[dtd->scaffLevel - 1]].type
  4859. = XML_CTYPE_MIXED;
  4860. if (parser->m_elementDeclHandler)
  4861. handleDefault = XML_FALSE;
  4862. }
  4863. break;
  4864. case XML_ROLE_CONTENT_ELEMENT:
  4865. quant = XML_CQUANT_NONE;
  4866. goto elementContent;
  4867. case XML_ROLE_CONTENT_ELEMENT_OPT:
  4868. quant = XML_CQUANT_OPT;
  4869. goto elementContent;
  4870. case XML_ROLE_CONTENT_ELEMENT_REP:
  4871. quant = XML_CQUANT_REP;
  4872. goto elementContent;
  4873. case XML_ROLE_CONTENT_ELEMENT_PLUS:
  4874. quant = XML_CQUANT_PLUS;
  4875. elementContent:
  4876. if (dtd->in_eldecl) {
  4877. ELEMENT_TYPE *el;
  4878. const XML_Char *name;
  4879. int nameLen;
  4880. const char *nxt = (quant == XML_CQUANT_NONE
  4881. ? next
  4882. : next - enc->minBytesPerChar);
  4883. int myindex = nextScaffoldPart(parser);
  4884. if (myindex < 0)
  4885. return XML_ERROR_NO_MEMORY;
  4886. dtd->scaffold[myindex].type = XML_CTYPE_NAME;
  4887. dtd->scaffold[myindex].quant = quant;
  4888. el = getElementType(parser, enc, s, nxt);
  4889. if (!el)
  4890. return XML_ERROR_NO_MEMORY;
  4891. name = el->name;
  4892. dtd->scaffold[myindex].name = name;
  4893. nameLen = 0;
  4894. for (; name[nameLen++]; );
  4895. dtd->contentStringLen += nameLen;
  4896. if (parser->m_elementDeclHandler)
  4897. handleDefault = XML_FALSE;
  4898. }
  4899. break;
  4900. case XML_ROLE_GROUP_CLOSE:
  4901. quant = XML_CQUANT_NONE;
  4902. goto closeGroup;
  4903. case XML_ROLE_GROUP_CLOSE_OPT:
  4904. quant = XML_CQUANT_OPT;
  4905. goto closeGroup;
  4906. case XML_ROLE_GROUP_CLOSE_REP:
  4907. quant = XML_CQUANT_REP;
  4908. goto closeGroup;
  4909. case XML_ROLE_GROUP_CLOSE_PLUS:
  4910. quant = XML_CQUANT_PLUS;
  4911. closeGroup:
  4912. if (dtd->in_eldecl) {
  4913. if (parser->m_elementDeclHandler)
  4914. handleDefault = XML_FALSE;
  4915. dtd->scaffLevel--;
  4916. dtd->scaffold[dtd->scaffIndex[dtd->scaffLevel]].quant = quant;
  4917. if (dtd->scaffLevel == 0) {
  4918. if (!handleDefault) {
  4919. XML_Content *model = build_model(parser);
  4920. if (!model)
  4921. return XML_ERROR_NO_MEMORY;
  4922. *eventEndPP = s;
  4923. parser->m_elementDeclHandler(parser->m_handlerArg, parser->m_declElementType->name, model);
  4924. }
  4925. dtd->in_eldecl = XML_FALSE;
  4926. dtd->contentStringLen = 0;
  4927. }
  4928. }
  4929. break;
  4930. /* End element declaration stuff */
  4931. case XML_ROLE_PI:
  4932. if (!reportProcessingInstruction(parser, enc, s, next))
  4933. return XML_ERROR_NO_MEMORY;
  4934. handleDefault = XML_FALSE;
  4935. break;
  4936. case XML_ROLE_COMMENT:
  4937. if (!reportComment(parser, enc, s, next))
  4938. return XML_ERROR_NO_MEMORY;
  4939. handleDefault = XML_FALSE;
  4940. break;
  4941. case XML_ROLE_NONE:
  4942. switch (tok) {
  4943. case XML_TOK_BOM:
  4944. handleDefault = XML_FALSE;
  4945. break;
  4946. }
  4947. break;
  4948. case XML_ROLE_DOCTYPE_NONE:
  4949. if (parser->m_startDoctypeDeclHandler)
  4950. handleDefault = XML_FALSE;
  4951. break;
  4952. case XML_ROLE_ENTITY_NONE:
  4953. if (dtd->keepProcessing && parser->m_entityDeclHandler)
  4954. handleDefault = XML_FALSE;
  4955. break;
  4956. case XML_ROLE_NOTATION_NONE:
  4957. if (parser->m_notationDeclHandler)
  4958. handleDefault = XML_FALSE;
  4959. break;
  4960. case XML_ROLE_ATTLIST_NONE:
  4961. if (dtd->keepProcessing && parser->m_attlistDeclHandler)
  4962. handleDefault = XML_FALSE;
  4963. break;
  4964. case XML_ROLE_ELEMENT_NONE:
  4965. if (parser->m_elementDeclHandler)
  4966. handleDefault = XML_FALSE;
  4967. break;
  4968. } /* end of big switch */
  4969. if (handleDefault && parser->m_defaultHandler)
  4970. reportDefault(parser, enc, s, next);
  4971. switch (parser->m_parsingStatus.parsing) {
  4972. case XML_SUSPENDED:
  4973. *nextPtr = next;
  4974. return XML_ERROR_NONE;
  4975. case XML_FINISHED:
  4976. return XML_ERROR_ABORTED;
  4977. default:
  4978. s = next;
  4979. tok = XmlPrologTok(enc, s, end, &next);
  4980. }
  4981. }
  4982. /* not reached */
  4983. }
  4984. static enum XML_Error PTRCALL
  4985. epilogProcessor(XML_Parser parser,
  4986. const char *s,
  4987. const char *end,
  4988. const char **nextPtr)
  4989. {
  4990. parser->m_processor = epilogProcessor;
  4991. parser->m_eventPtr = s;
  4992. for (;;) {
  4993. const char *next = NULL;
  4994. int tok = XmlPrologTok(parser->m_encoding, s, end, &next);
  4995. parser->m_eventEndPtr = next;
  4996. switch (tok) {
  4997. /* report partial linebreak - it might be the last token */
  4998. case -XML_TOK_PROLOG_S:
  4999. if (parser->m_defaultHandler) {
  5000. reportDefault(parser, parser->m_encoding, s, next);
  5001. if (parser->m_parsingStatus.parsing == XML_FINISHED)
  5002. return XML_ERROR_ABORTED;
  5003. }
  5004. *nextPtr = next;
  5005. return XML_ERROR_NONE;
  5006. case XML_TOK_NONE:
  5007. *nextPtr = s;
  5008. return XML_ERROR_NONE;
  5009. case XML_TOK_PROLOG_S:
  5010. if (parser->m_defaultHandler)
  5011. reportDefault(parser, parser->m_encoding, s, next);
  5012. break;
  5013. case XML_TOK_PI:
  5014. if (!reportProcessingInstruction(parser, parser->m_encoding, s, next))
  5015. return XML_ERROR_NO_MEMORY;
  5016. break;
  5017. case XML_TOK_COMMENT:
  5018. if (!reportComment(parser, parser->m_encoding, s, next))
  5019. return XML_ERROR_NO_MEMORY;
  5020. break;
  5021. case XML_TOK_INVALID:
  5022. parser->m_eventPtr = next;
  5023. return XML_ERROR_INVALID_TOKEN;
  5024. case XML_TOK_PARTIAL:
  5025. if (!parser->m_parsingStatus.finalBuffer) {
  5026. *nextPtr = s;
  5027. return XML_ERROR_NONE;
  5028. }
  5029. return XML_ERROR_UNCLOSED_TOKEN;
  5030. case XML_TOK_PARTIAL_CHAR:
  5031. if (!parser->m_parsingStatus.finalBuffer) {
  5032. *nextPtr = s;
  5033. return XML_ERROR_NONE;
  5034. }
  5035. return XML_ERROR_PARTIAL_CHAR;
  5036. default:
  5037. return XML_ERROR_JUNK_AFTER_DOC_ELEMENT;
  5038. }
  5039. parser->m_eventPtr = s = next;
  5040. switch (parser->m_parsingStatus.parsing) {
  5041. case XML_SUSPENDED:
  5042. *nextPtr = next;
  5043. return XML_ERROR_NONE;
  5044. case XML_FINISHED:
  5045. return XML_ERROR_ABORTED;
  5046. default: ;
  5047. }
  5048. }
  5049. }
  5050. static enum XML_Error
  5051. processInternalEntity(XML_Parser parser, ENTITY *entity,
  5052. XML_Bool betweenDecl)
  5053. {
  5054. const char *textStart, *textEnd;
  5055. const char *next;
  5056. enum XML_Error result;
  5057. OPEN_INTERNAL_ENTITY *openEntity;
  5058. if (parser->m_freeInternalEntities) {
  5059. openEntity = parser->m_freeInternalEntities;
  5060. parser->m_freeInternalEntities = openEntity->next;
  5061. }
  5062. else {
  5063. openEntity = (OPEN_INTERNAL_ENTITY *)MALLOC(parser, sizeof(OPEN_INTERNAL_ENTITY));
  5064. if (!openEntity)
  5065. return XML_ERROR_NO_MEMORY;
  5066. }
  5067. entity->open = XML_TRUE;
  5068. entity->processed = 0;
  5069. openEntity->next = parser->m_openInternalEntities;
  5070. parser->m_openInternalEntities = openEntity;
  5071. openEntity->entity = entity;
  5072. openEntity->startTagLevel = parser->m_tagLevel;
  5073. openEntity->betweenDecl = betweenDecl;
  5074. openEntity->internalEventPtr = NULL;
  5075. openEntity->internalEventEndPtr = NULL;
  5076. textStart = (char *)entity->textPtr;
  5077. textEnd = (char *)(entity->textPtr + entity->textLen);
  5078. /* Set a safe default value in case 'next' does not get set */
  5079. next = textStart;
  5080. #ifdef XML_DTD
  5081. if (entity->is_param) {
  5082. int tok = XmlPrologTok(parser->m_internalEncoding, textStart, textEnd, &next);
  5083. result = doProlog(parser, parser->m_internalEncoding, textStart, textEnd, tok,
  5084. next, &next, XML_FALSE);
  5085. }
  5086. else
  5087. #endif /* XML_DTD */
  5088. result = doContent(parser, parser->m_tagLevel, parser->m_internalEncoding, textStart,
  5089. textEnd, &next, XML_FALSE);
  5090. if (result == XML_ERROR_NONE) {
  5091. if (textEnd != next && parser->m_parsingStatus.parsing == XML_SUSPENDED) {
  5092. entity->processed = (int)(next - textStart);
  5093. parser->m_processor = internalEntityProcessor;
  5094. }
  5095. else {
  5096. entity->open = XML_FALSE;
  5097. parser->m_openInternalEntities = openEntity->next;
  5098. /* put openEntity back in list of free instances */
  5099. openEntity->next = parser->m_freeInternalEntities;
  5100. parser->m_freeInternalEntities = openEntity;
  5101. }
  5102. }
  5103. return result;
  5104. }
  5105. static enum XML_Error PTRCALL
  5106. internalEntityProcessor(XML_Parser parser,
  5107. const char *s,
  5108. const char *end,
  5109. const char **nextPtr)
  5110. {
  5111. ENTITY *entity;
  5112. const char *textStart, *textEnd;
  5113. const char *next;
  5114. enum XML_Error result;
  5115. OPEN_INTERNAL_ENTITY *openEntity = parser->m_openInternalEntities;
  5116. if (!openEntity)
  5117. return XML_ERROR_UNEXPECTED_STATE;
  5118. entity = openEntity->entity;
  5119. textStart = ((char *)entity->textPtr) + entity->processed;
  5120. textEnd = (char *)(entity->textPtr + entity->textLen);
  5121. /* Set a safe default value in case 'next' does not get set */
  5122. next = textStart;
  5123. #ifdef XML_DTD
  5124. if (entity->is_param) {
  5125. int tok = XmlPrologTok(parser->m_internalEncoding, textStart, textEnd, &next);
  5126. result = doProlog(parser, parser->m_internalEncoding, textStart, textEnd, tok,
  5127. next, &next, XML_FALSE);
  5128. }
  5129. else
  5130. #endif /* XML_DTD */
  5131. result = doContent(parser, openEntity->startTagLevel, parser->m_internalEncoding,
  5132. textStart, textEnd, &next, XML_FALSE);
  5133. if (result != XML_ERROR_NONE)
  5134. return result;
  5135. else if (textEnd != next && parser->m_parsingStatus.parsing == XML_SUSPENDED) {
  5136. entity->processed = (int)(next - (char *)entity->textPtr);
  5137. return result;
  5138. }
  5139. else {
  5140. entity->open = XML_FALSE;
  5141. parser->m_openInternalEntities = openEntity->next;
  5142. /* put openEntity back in list of free instances */
  5143. openEntity->next = parser->m_freeInternalEntities;
  5144. parser->m_freeInternalEntities = openEntity;
  5145. }
  5146. #ifdef XML_DTD
  5147. if (entity->is_param) {
  5148. int tok;
  5149. parser->m_processor = prologProcessor;
  5150. tok = XmlPrologTok(parser->m_encoding, s, end, &next);
  5151. return doProlog(parser, parser->m_encoding, s, end, tok, next, nextPtr,
  5152. (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  5153. }
  5154. else
  5155. #endif /* XML_DTD */
  5156. {
  5157. parser->m_processor = contentProcessor;
  5158. /* see externalEntityContentProcessor vs contentProcessor */
  5159. return doContent(parser, parser->m_parentParser ? 1 : 0, parser->m_encoding, s, end,
  5160. nextPtr, (XML_Bool)!parser->m_parsingStatus.finalBuffer);
  5161. }
  5162. }
  5163. static enum XML_Error PTRCALL
  5164. errorProcessor(XML_Parser parser,
  5165. const char *UNUSED_P(s),
  5166. const char *UNUSED_P(end),
  5167. const char **UNUSED_P(nextPtr))
  5168. {
  5169. return parser->m_errorCode;
  5170. }
  5171. static enum XML_Error
  5172. storeAttributeValue(XML_Parser parser, const ENCODING *enc, XML_Bool isCdata,
  5173. const char *ptr, const char *end,
  5174. STRING_POOL *pool)
  5175. {
  5176. enum XML_Error result = appendAttributeValue(parser, enc, isCdata, ptr,
  5177. end, pool);
  5178. if (result)
  5179. return result;
  5180. if (!isCdata && poolLength(pool) && poolLastChar(pool) == 0x20)
  5181. poolChop(pool);
  5182. if (!poolAppendChar(pool, XML_T('\0')))
  5183. return XML_ERROR_NO_MEMORY;
  5184. return XML_ERROR_NONE;
  5185. }
  5186. static enum XML_Error
  5187. appendAttributeValue(XML_Parser parser, const ENCODING *enc, XML_Bool isCdata,
  5188. const char *ptr, const char *end,
  5189. STRING_POOL *pool)
  5190. {
  5191. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  5192. for (;;) {
  5193. const char *next;
  5194. int tok = XmlAttributeValueTok(enc, ptr, end, &next);
  5195. switch (tok) {
  5196. case XML_TOK_NONE:
  5197. return XML_ERROR_NONE;
  5198. case XML_TOK_INVALID:
  5199. if (enc == parser->m_encoding)
  5200. parser->m_eventPtr = next;
  5201. return XML_ERROR_INVALID_TOKEN;
  5202. case XML_TOK_PARTIAL:
  5203. if (enc == parser->m_encoding)
  5204. parser->m_eventPtr = ptr;
  5205. return XML_ERROR_INVALID_TOKEN;
  5206. case XML_TOK_CHAR_REF:
  5207. {
  5208. XML_Char buf[XML_ENCODE_MAX];
  5209. int i;
  5210. int n = XmlCharRefNumber(enc, ptr);
  5211. if (n < 0) {
  5212. if (enc == parser->m_encoding)
  5213. parser->m_eventPtr = ptr;
  5214. return XML_ERROR_BAD_CHAR_REF;
  5215. }
  5216. if (!isCdata
  5217. && n == 0x20 /* space */
  5218. && (poolLength(pool) == 0 || poolLastChar(pool) == 0x20))
  5219. break;
  5220. n = XmlEncode(n, (ICHAR *)buf);
  5221. /* The XmlEncode() functions can never return 0 here. That
  5222. * error return happens if the code point passed in is either
  5223. * negative or greater than or equal to 0x110000. The
  5224. * XmlCharRefNumber() functions will all return a number
  5225. * strictly less than 0x110000 or a negative value if an error
  5226. * occurred. The negative value is intercepted above, so
  5227. * XmlEncode() is never passed a value it might return an
  5228. * error for.
  5229. */
  5230. for (i = 0; i < n; i++) {
  5231. if (!poolAppendChar(pool, buf[i]))
  5232. return XML_ERROR_NO_MEMORY;
  5233. }
  5234. }
  5235. break;
  5236. case XML_TOK_DATA_CHARS:
  5237. if (!poolAppend(pool, enc, ptr, next))
  5238. return XML_ERROR_NO_MEMORY;
  5239. break;
  5240. case XML_TOK_TRAILING_CR:
  5241. next = ptr + enc->minBytesPerChar;
  5242. /* fall through */
  5243. case XML_TOK_ATTRIBUTE_VALUE_S:
  5244. case XML_TOK_DATA_NEWLINE:
  5245. if (!isCdata && (poolLength(pool) == 0 || poolLastChar(pool) == 0x20))
  5246. break;
  5247. if (!poolAppendChar(pool, 0x20))
  5248. return XML_ERROR_NO_MEMORY;
  5249. break;
  5250. case XML_TOK_ENTITY_REF:
  5251. {
  5252. const XML_Char *name;
  5253. ENTITY *entity;
  5254. char checkEntityDecl;
  5255. XML_Char ch = (XML_Char) XmlPredefinedEntityName(enc,
  5256. ptr + enc->minBytesPerChar,
  5257. next - enc->minBytesPerChar);
  5258. if (ch) {
  5259. if (!poolAppendChar(pool, ch))
  5260. return XML_ERROR_NO_MEMORY;
  5261. break;
  5262. }
  5263. name = poolStoreString(&parser->m_temp2Pool, enc,
  5264. ptr + enc->minBytesPerChar,
  5265. next - enc->minBytesPerChar);
  5266. if (!name)
  5267. return XML_ERROR_NO_MEMORY;
  5268. entity = (ENTITY *)lookup(parser, &dtd->generalEntities, name, 0);
  5269. poolDiscard(&parser->m_temp2Pool);
  5270. /* First, determine if a check for an existing declaration is needed;
  5271. if yes, check that the entity exists, and that it is internal.
  5272. */
  5273. if (pool == &dtd->pool) /* are we called from prolog? */
  5274. checkEntityDecl =
  5275. #ifdef XML_DTD
  5276. parser->m_prologState.documentEntity &&
  5277. #endif /* XML_DTD */
  5278. (dtd->standalone
  5279. ? !parser->m_openInternalEntities
  5280. : !dtd->hasParamEntityRefs);
  5281. else /* if (pool == &parser->m_tempPool): we are called from content */
  5282. checkEntityDecl = !dtd->hasParamEntityRefs || dtd->standalone;
  5283. if (checkEntityDecl) {
  5284. if (!entity)
  5285. return XML_ERROR_UNDEFINED_ENTITY;
  5286. else if (!entity->is_internal)
  5287. return XML_ERROR_ENTITY_DECLARED_IN_PE;
  5288. }
  5289. else if (!entity) {
  5290. /* Cannot report skipped entity here - see comments on
  5291. parser->m_skippedEntityHandler.
  5292. if (parser->m_skippedEntityHandler)
  5293. parser->m_skippedEntityHandler(parser->m_handlerArg, name, 0);
  5294. */
  5295. /* Cannot call the default handler because this would be
  5296. out of sync with the call to the startElementHandler.
  5297. if ((pool == &parser->m_tempPool) && parser->m_defaultHandler)
  5298. reportDefault(parser, enc, ptr, next);
  5299. */
  5300. break;
  5301. }
  5302. if (entity->open) {
  5303. if (enc == parser->m_encoding) {
  5304. /* It does not appear that this line can be executed.
  5305. *
  5306. * The "if (entity->open)" check catches recursive entity
  5307. * definitions. In order to be called with an open
  5308. * entity, it must have gone through this code before and
  5309. * been through the recursive call to
  5310. * appendAttributeValue() some lines below. That call
  5311. * sets the local encoding ("enc") to the parser's
  5312. * internal encoding (internal_utf8 or internal_utf16),
  5313. * which can never be the same as the principle encoding.
  5314. * It doesn't appear there is another code path that gets
  5315. * here with entity->open being TRUE.
  5316. *
  5317. * Since it is not certain that this logic is watertight,
  5318. * we keep the line and merely exclude it from coverage
  5319. * tests.
  5320. */
  5321. parser->m_eventPtr = ptr; /* LCOV_EXCL_LINE */
  5322. }
  5323. return XML_ERROR_RECURSIVE_ENTITY_REF;
  5324. }
  5325. if (entity->notation) {
  5326. if (enc == parser->m_encoding)
  5327. parser->m_eventPtr = ptr;
  5328. return XML_ERROR_BINARY_ENTITY_REF;
  5329. }
  5330. if (!entity->textPtr) {
  5331. if (enc == parser->m_encoding)
  5332. parser->m_eventPtr = ptr;
  5333. return XML_ERROR_ATTRIBUTE_EXTERNAL_ENTITY_REF;
  5334. }
  5335. else {
  5336. enum XML_Error result;
  5337. const XML_Char *textEnd = entity->textPtr + entity->textLen;
  5338. entity->open = XML_TRUE;
  5339. result = appendAttributeValue(parser, parser->m_internalEncoding, isCdata,
  5340. (char *)entity->textPtr,
  5341. (char *)textEnd, pool);
  5342. entity->open = XML_FALSE;
  5343. if (result)
  5344. return result;
  5345. }
  5346. }
  5347. break;
  5348. default:
  5349. /* The only token returned by XmlAttributeValueTok() that does
  5350. * not have an explicit case here is XML_TOK_PARTIAL_CHAR.
  5351. * Getting that would require an entity name to contain an
  5352. * incomplete XML character (e.g. \xE2\x82); however previous
  5353. * tokenisers will have already recognised and rejected such
  5354. * names before XmlAttributeValueTok() gets a look-in. This
  5355. * default case should be retained as a safety net, but the code
  5356. * excluded from coverage tests.
  5357. *
  5358. * LCOV_EXCL_START
  5359. */
  5360. if (enc == parser->m_encoding)
  5361. parser->m_eventPtr = ptr;
  5362. return XML_ERROR_UNEXPECTED_STATE;
  5363. /* LCOV_EXCL_STOP */
  5364. }
  5365. ptr = next;
  5366. }
  5367. /* not reached */
  5368. }
  5369. static enum XML_Error
  5370. storeEntityValue(XML_Parser parser,
  5371. const ENCODING *enc,
  5372. const char *entityTextPtr,
  5373. const char *entityTextEnd)
  5374. {
  5375. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  5376. STRING_POOL *pool = &(dtd->entityValuePool);
  5377. enum XML_Error result = XML_ERROR_NONE;
  5378. #ifdef XML_DTD
  5379. int oldInEntityValue = parser->m_prologState.inEntityValue;
  5380. parser->m_prologState.inEntityValue = 1;
  5381. #endif /* XML_DTD */
  5382. /* never return Null for the value argument in EntityDeclHandler,
  5383. since this would indicate an external entity; therefore we
  5384. have to make sure that entityValuePool.start is not null */
  5385. if (!pool->blocks) {
  5386. if (!poolGrow(pool))
  5387. return XML_ERROR_NO_MEMORY;
  5388. }
  5389. for (;;) {
  5390. const char *next;
  5391. int tok = XmlEntityValueTok(enc, entityTextPtr, entityTextEnd, &next);
  5392. switch (tok) {
  5393. case XML_TOK_PARAM_ENTITY_REF:
  5394. #ifdef XML_DTD
  5395. if (parser->m_isParamEntity || enc != parser->m_encoding) {
  5396. const XML_Char *name;
  5397. ENTITY *entity;
  5398. name = poolStoreString(&parser->m_tempPool, enc,
  5399. entityTextPtr + enc->minBytesPerChar,
  5400. next - enc->minBytesPerChar);
  5401. if (!name) {
  5402. result = XML_ERROR_NO_MEMORY;
  5403. goto endEntityValue;
  5404. }
  5405. entity = (ENTITY *)lookup(parser, &dtd->paramEntities, name, 0);
  5406. poolDiscard(&parser->m_tempPool);
  5407. if (!entity) {
  5408. /* not a well-formedness error - see XML 1.0: WFC Entity Declared */
  5409. /* cannot report skipped entity here - see comments on
  5410. parser->m_skippedEntityHandler
  5411. if (parser->m_skippedEntityHandler)
  5412. parser->m_skippedEntityHandler(parser->m_handlerArg, name, 0);
  5413. */
  5414. dtd->keepProcessing = dtd->standalone;
  5415. goto endEntityValue;
  5416. }
  5417. if (entity->open) {
  5418. if (enc == parser->m_encoding)
  5419. parser->m_eventPtr = entityTextPtr;
  5420. result = XML_ERROR_RECURSIVE_ENTITY_REF;
  5421. goto endEntityValue;
  5422. }
  5423. if (entity->systemId) {
  5424. if (parser->m_externalEntityRefHandler) {
  5425. dtd->paramEntityRead = XML_FALSE;
  5426. entity->open = XML_TRUE;
  5427. if (!parser->m_externalEntityRefHandler(parser->m_externalEntityRefHandlerArg,
  5428. 0,
  5429. entity->base,
  5430. entity->systemId,
  5431. entity->publicId)) {
  5432. entity->open = XML_FALSE;
  5433. result = XML_ERROR_EXTERNAL_ENTITY_HANDLING;
  5434. goto endEntityValue;
  5435. }
  5436. entity->open = XML_FALSE;
  5437. if (!dtd->paramEntityRead)
  5438. dtd->keepProcessing = dtd->standalone;
  5439. }
  5440. else
  5441. dtd->keepProcessing = dtd->standalone;
  5442. }
  5443. else {
  5444. entity->open = XML_TRUE;
  5445. result = storeEntityValue(parser,
  5446. parser->m_internalEncoding,
  5447. (char *)entity->textPtr,
  5448. (char *)(entity->textPtr
  5449. + entity->textLen));
  5450. entity->open = XML_FALSE;
  5451. if (result)
  5452. goto endEntityValue;
  5453. }
  5454. break;
  5455. }
  5456. #endif /* XML_DTD */
  5457. /* In the internal subset, PE references are not legal
  5458. within markup declarations, e.g entity values in this case. */
  5459. parser->m_eventPtr = entityTextPtr;
  5460. result = XML_ERROR_PARAM_ENTITY_REF;
  5461. goto endEntityValue;
  5462. case XML_TOK_NONE:
  5463. result = XML_ERROR_NONE;
  5464. goto endEntityValue;
  5465. case XML_TOK_ENTITY_REF:
  5466. case XML_TOK_DATA_CHARS:
  5467. if (!poolAppend(pool, enc, entityTextPtr, next)) {
  5468. result = XML_ERROR_NO_MEMORY;
  5469. goto endEntityValue;
  5470. }
  5471. break;
  5472. case XML_TOK_TRAILING_CR:
  5473. next = entityTextPtr + enc->minBytesPerChar;
  5474. /* fall through */
  5475. case XML_TOK_DATA_NEWLINE:
  5476. if (pool->end == pool->ptr && !poolGrow(pool)) {
  5477. result = XML_ERROR_NO_MEMORY;
  5478. goto endEntityValue;
  5479. }
  5480. *(pool->ptr)++ = 0xA;
  5481. break;
  5482. case XML_TOK_CHAR_REF:
  5483. {
  5484. XML_Char buf[XML_ENCODE_MAX];
  5485. int i;
  5486. int n = XmlCharRefNumber(enc, entityTextPtr);
  5487. if (n < 0) {
  5488. if (enc == parser->m_encoding)
  5489. parser->m_eventPtr = entityTextPtr;
  5490. result = XML_ERROR_BAD_CHAR_REF;
  5491. goto endEntityValue;
  5492. }
  5493. n = XmlEncode(n, (ICHAR *)buf);
  5494. /* The XmlEncode() functions can never return 0 here. That
  5495. * error return happens if the code point passed in is either
  5496. * negative or greater than or equal to 0x110000. The
  5497. * XmlCharRefNumber() functions will all return a number
  5498. * strictly less than 0x110000 or a negative value if an error
  5499. * occurred. The negative value is intercepted above, so
  5500. * XmlEncode() is never passed a value it might return an
  5501. * error for.
  5502. */
  5503. for (i = 0; i < n; i++) {
  5504. if (pool->end == pool->ptr && !poolGrow(pool)) {
  5505. result = XML_ERROR_NO_MEMORY;
  5506. goto endEntityValue;
  5507. }
  5508. *(pool->ptr)++ = buf[i];
  5509. }
  5510. }
  5511. break;
  5512. case XML_TOK_PARTIAL:
  5513. if (enc == parser->m_encoding)
  5514. parser->m_eventPtr = entityTextPtr;
  5515. result = XML_ERROR_INVALID_TOKEN;
  5516. goto endEntityValue;
  5517. case XML_TOK_INVALID:
  5518. if (enc == parser->m_encoding)
  5519. parser->m_eventPtr = next;
  5520. result = XML_ERROR_INVALID_TOKEN;
  5521. goto endEntityValue;
  5522. default:
  5523. /* This default case should be unnecessary -- all the tokens
  5524. * that XmlEntityValueTok() can return have their own explicit
  5525. * cases -- but should be retained for safety. We do however
  5526. * exclude it from the coverage statistics.
  5527. *
  5528. * LCOV_EXCL_START
  5529. */
  5530. if (enc == parser->m_encoding)
  5531. parser->m_eventPtr = entityTextPtr;
  5532. result = XML_ERROR_UNEXPECTED_STATE;
  5533. goto endEntityValue;
  5534. /* LCOV_EXCL_STOP */
  5535. }
  5536. entityTextPtr = next;
  5537. }
  5538. endEntityValue:
  5539. #ifdef XML_DTD
  5540. parser->m_prologState.inEntityValue = oldInEntityValue;
  5541. #endif /* XML_DTD */
  5542. return result;
  5543. }
  5544. static void FASTCALL
  5545. normalizeLines(XML_Char *s)
  5546. {
  5547. XML_Char *p;
  5548. for (;; s++) {
  5549. if (*s == XML_T('\0'))
  5550. return;
  5551. if (*s == 0xD)
  5552. break;
  5553. }
  5554. p = s;
  5555. do {
  5556. if (*s == 0xD) {
  5557. *p++ = 0xA;
  5558. if (*++s == 0xA)
  5559. s++;
  5560. }
  5561. else
  5562. *p++ = *s++;
  5563. } while (*s);
  5564. *p = XML_T('\0');
  5565. }
  5566. static int
  5567. reportProcessingInstruction(XML_Parser parser, const ENCODING *enc,
  5568. const char *start, const char *end)
  5569. {
  5570. const XML_Char *target;
  5571. XML_Char *data;
  5572. const char *tem;
  5573. if (!parser->m_processingInstructionHandler) {
  5574. if (parser->m_defaultHandler)
  5575. reportDefault(parser, enc, start, end);
  5576. return 1;
  5577. }
  5578. start += enc->minBytesPerChar * 2;
  5579. tem = start + XmlNameLength(enc, start);
  5580. target = poolStoreString(&parser->m_tempPool, enc, start, tem);
  5581. if (!target)
  5582. return 0;
  5583. poolFinish(&parser->m_tempPool);
  5584. data = poolStoreString(&parser->m_tempPool, enc,
  5585. XmlSkipS(enc, tem),
  5586. end - enc->minBytesPerChar*2);
  5587. if (!data)
  5588. return 0;
  5589. normalizeLines(data);
  5590. parser->m_processingInstructionHandler(parser->m_handlerArg, target, data);
  5591. poolClear(&parser->m_tempPool);
  5592. return 1;
  5593. }
  5594. static int
  5595. reportComment(XML_Parser parser, const ENCODING *enc,
  5596. const char *start, const char *end)
  5597. {
  5598. XML_Char *data;
  5599. if (!parser->m_commentHandler) {
  5600. if (parser->m_defaultHandler)
  5601. reportDefault(parser, enc, start, end);
  5602. return 1;
  5603. }
  5604. data = poolStoreString(&parser->m_tempPool,
  5605. enc,
  5606. start + enc->minBytesPerChar * 4,
  5607. end - enc->minBytesPerChar * 3);
  5608. if (!data)
  5609. return 0;
  5610. normalizeLines(data);
  5611. parser->m_commentHandler(parser->m_handlerArg, data);
  5612. poolClear(&parser->m_tempPool);
  5613. return 1;
  5614. }
  5615. static void
  5616. reportDefault(XML_Parser parser, const ENCODING *enc,
  5617. const char *s, const char *end)
  5618. {
  5619. if (MUST_CONVERT(enc, s)) {
  5620. enum XML_Convert_Result convert_res;
  5621. const char **eventPP;
  5622. const char **eventEndPP;
  5623. if (enc == parser->m_encoding) {
  5624. eventPP = &parser->m_eventPtr;
  5625. eventEndPP = &parser->m_eventEndPtr;
  5626. }
  5627. else {
  5628. /* To get here, two things must be true; the parser must be
  5629. * using a character encoding that is not the same as the
  5630. * encoding passed in, and the encoding passed in must need
  5631. * conversion to the internal format (UTF-8 unless XML_UNICODE
  5632. * is defined). The only occasions on which the encoding passed
  5633. * in is not the same as the parser's encoding are when it is
  5634. * the internal encoding (e.g. a previously defined parameter
  5635. * entity, already converted to internal format). This by
  5636. * definition doesn't need conversion, so the whole branch never
  5637. * gets executed.
  5638. *
  5639. * For safety's sake we don't delete these lines and merely
  5640. * exclude them from coverage statistics.
  5641. *
  5642. * LCOV_EXCL_START
  5643. */
  5644. eventPP = &(parser->m_openInternalEntities->internalEventPtr);
  5645. eventEndPP = &(parser->m_openInternalEntities->internalEventEndPtr);
  5646. /* LCOV_EXCL_STOP */
  5647. }
  5648. do {
  5649. ICHAR *dataPtr = (ICHAR *)parser->m_dataBuf;
  5650. convert_res = XmlConvert(enc, &s, end, &dataPtr, (ICHAR *)parser->m_dataBufEnd);
  5651. *eventEndPP = s;
  5652. parser->m_defaultHandler(parser->m_handlerArg, parser->m_dataBuf, (int)(dataPtr - (ICHAR *)parser->m_dataBuf));
  5653. *eventPP = s;
  5654. } while ((convert_res != XML_CONVERT_COMPLETED) && (convert_res != XML_CONVERT_INPUT_INCOMPLETE));
  5655. }
  5656. else
  5657. parser->m_defaultHandler(parser->m_handlerArg, (XML_Char *)s, (int)((XML_Char *)end - (XML_Char *)s));
  5658. }
  5659. static int
  5660. defineAttribute(ELEMENT_TYPE *type, ATTRIBUTE_ID *attId, XML_Bool isCdata,
  5661. XML_Bool isId, const XML_Char *value, XML_Parser parser)
  5662. {
  5663. DEFAULT_ATTRIBUTE *att;
  5664. if (value || isId) {
  5665. /* The handling of default attributes gets messed up if we have
  5666. a default which duplicates a non-default. */
  5667. int i;
  5668. for (i = 0; i < type->nDefaultAtts; i++)
  5669. if (attId == type->defaultAtts[i].id)
  5670. return 1;
  5671. if (isId && !type->idAtt && !attId->xmlns)
  5672. type->idAtt = attId;
  5673. }
  5674. if (type->nDefaultAtts == type->allocDefaultAtts) {
  5675. if (type->allocDefaultAtts == 0) {
  5676. type->allocDefaultAtts = 8;
  5677. type->defaultAtts = (DEFAULT_ATTRIBUTE *)MALLOC(parser, type->allocDefaultAtts
  5678. * sizeof(DEFAULT_ATTRIBUTE));
  5679. if (!type->defaultAtts) {
  5680. type->allocDefaultAtts = 0;
  5681. return 0;
  5682. }
  5683. }
  5684. else {
  5685. DEFAULT_ATTRIBUTE *temp;
  5686. int count = type->allocDefaultAtts * 2;
  5687. temp = (DEFAULT_ATTRIBUTE *)
  5688. REALLOC(parser, type->defaultAtts, (count * sizeof(DEFAULT_ATTRIBUTE)));
  5689. if (temp == NULL)
  5690. return 0;
  5691. type->allocDefaultAtts = count;
  5692. type->defaultAtts = temp;
  5693. }
  5694. }
  5695. att = type->defaultAtts + type->nDefaultAtts;
  5696. att->id = attId;
  5697. att->value = value;
  5698. att->isCdata = isCdata;
  5699. if (!isCdata)
  5700. attId->maybeTokenized = XML_TRUE;
  5701. type->nDefaultAtts += 1;
  5702. return 1;
  5703. }
  5704. static int
  5705. setElementTypePrefix(XML_Parser parser, ELEMENT_TYPE *elementType)
  5706. {
  5707. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  5708. const XML_Char *name;
  5709. for (name = elementType->name; *name; name++) {
  5710. if (*name == XML_T(ASCII_COLON)) {
  5711. PREFIX *prefix;
  5712. const XML_Char *s;
  5713. for (s = elementType->name; s != name; s++) {
  5714. if (!poolAppendChar(&dtd->pool, *s))
  5715. return 0;
  5716. }
  5717. if (!poolAppendChar(&dtd->pool, XML_T('\0')))
  5718. return 0;
  5719. prefix = (PREFIX *)lookup(parser, &dtd->prefixes, poolStart(&dtd->pool),
  5720. sizeof(PREFIX));
  5721. if (!prefix)
  5722. return 0;
  5723. if (prefix->name == poolStart(&dtd->pool))
  5724. poolFinish(&dtd->pool);
  5725. else
  5726. poolDiscard(&dtd->pool);
  5727. elementType->prefix = prefix;
  5728. }
  5729. }
  5730. return 1;
  5731. }
  5732. static ATTRIBUTE_ID *
  5733. getAttributeId(XML_Parser parser, const ENCODING *enc,
  5734. const char *start, const char *end)
  5735. {
  5736. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  5737. ATTRIBUTE_ID *id;
  5738. const XML_Char *name;
  5739. if (!poolAppendChar(&dtd->pool, XML_T('\0')))
  5740. return NULL;
  5741. name = poolStoreString(&dtd->pool, enc, start, end);
  5742. if (!name)
  5743. return NULL;
  5744. /* skip quotation mark - its storage will be re-used (like in name[-1]) */
  5745. ++name;
  5746. id = (ATTRIBUTE_ID *)lookup(parser, &dtd->attributeIds, name, sizeof(ATTRIBUTE_ID));
  5747. if (!id)
  5748. return NULL;
  5749. if (id->name != name)
  5750. poolDiscard(&dtd->pool);
  5751. else {
  5752. poolFinish(&dtd->pool);
  5753. if (!parser->m_ns)
  5754. ;
  5755. else if (name[0] == XML_T(ASCII_x)
  5756. && name[1] == XML_T(ASCII_m)
  5757. && name[2] == XML_T(ASCII_l)
  5758. && name[3] == XML_T(ASCII_n)
  5759. && name[4] == XML_T(ASCII_s)
  5760. && (name[5] == XML_T('\0') || name[5] == XML_T(ASCII_COLON))) {
  5761. if (name[5] == XML_T('\0'))
  5762. id->prefix = &dtd->defaultPrefix;
  5763. else
  5764. id->prefix = (PREFIX *)lookup(parser, &dtd->prefixes, name + 6, sizeof(PREFIX));
  5765. id->xmlns = XML_TRUE;
  5766. }
  5767. else {
  5768. int i;
  5769. for (i = 0; name[i]; i++) {
  5770. /* attributes without prefix are *not* in the default namespace */
  5771. if (name[i] == XML_T(ASCII_COLON)) {
  5772. int j;
  5773. for (j = 0; j < i; j++) {
  5774. if (!poolAppendChar(&dtd->pool, name[j]))
  5775. return NULL;
  5776. }
  5777. if (!poolAppendChar(&dtd->pool, XML_T('\0')))
  5778. return NULL;
  5779. id->prefix = (PREFIX *)lookup(parser, &dtd->prefixes, poolStart(&dtd->pool),
  5780. sizeof(PREFIX));
  5781. if (!id->prefix)
  5782. return NULL;
  5783. if (id->prefix->name == poolStart(&dtd->pool))
  5784. poolFinish(&dtd->pool);
  5785. else
  5786. poolDiscard(&dtd->pool);
  5787. break;
  5788. }
  5789. }
  5790. }
  5791. }
  5792. return id;
  5793. }
  5794. #define CONTEXT_SEP XML_T(ASCII_FF)
  5795. static const XML_Char *
  5796. getContext(XML_Parser parser)
  5797. {
  5798. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  5799. HASH_TABLE_ITER iter;
  5800. XML_Bool needSep = XML_FALSE;
  5801. if (dtd->defaultPrefix.binding) {
  5802. int i;
  5803. int len;
  5804. if (!poolAppendChar(&parser->m_tempPool, XML_T(ASCII_EQUALS)))
  5805. return NULL;
  5806. len = dtd->defaultPrefix.binding->uriLen;
  5807. if (parser->m_namespaceSeparator)
  5808. len--;
  5809. for (i = 0; i < len; i++) {
  5810. if (!poolAppendChar(&parser->m_tempPool, dtd->defaultPrefix.binding->uri[i])) {
  5811. /* Because of memory caching, I don't believe this line can be
  5812. * executed.
  5813. *
  5814. * This is part of a loop copying the default prefix binding
  5815. * URI into the parser's temporary string pool. Previously,
  5816. * that URI was copied into the same string pool, with a
  5817. * terminating NUL character, as part of setContext(). When
  5818. * the pool was cleared, that leaves a block definitely big
  5819. * enough to hold the URI on the free block list of the pool.
  5820. * The URI copy in getContext() therefore cannot run out of
  5821. * memory.
  5822. *
  5823. * If the pool is used between the setContext() and
  5824. * getContext() calls, the worst it can do is leave a bigger
  5825. * block on the front of the free list. Given that this is
  5826. * all somewhat inobvious and program logic can be changed, we
  5827. * don't delete the line but we do exclude it from the test
  5828. * coverage statistics.
  5829. */
  5830. return NULL; /* LCOV_EXCL_LINE */
  5831. }
  5832. }
  5833. needSep = XML_TRUE;
  5834. }
  5835. hashTableIterInit(&iter, &(dtd->prefixes));
  5836. for (;;) {
  5837. int i;
  5838. int len;
  5839. const XML_Char *s;
  5840. PREFIX *prefix = (PREFIX *)hashTableIterNext(&iter);
  5841. if (!prefix)
  5842. break;
  5843. if (!prefix->binding) {
  5844. /* This test appears to be (justifiable) paranoia. There does
  5845. * not seem to be a way of injecting a prefix without a binding
  5846. * that doesn't get errored long before this function is called.
  5847. * The test should remain for safety's sake, so we instead
  5848. * exclude the following line from the coverage statistics.
  5849. */
  5850. continue; /* LCOV_EXCL_LINE */
  5851. }
  5852. if (needSep && !poolAppendChar(&parser->m_tempPool, CONTEXT_SEP))
  5853. return NULL;
  5854. for (s = prefix->name; *s; s++)
  5855. if (!poolAppendChar(&parser->m_tempPool, *s))
  5856. return NULL;
  5857. if (!poolAppendChar(&parser->m_tempPool, XML_T(ASCII_EQUALS)))
  5858. return NULL;
  5859. len = prefix->binding->uriLen;
  5860. if (parser->m_namespaceSeparator)
  5861. len--;
  5862. for (i = 0; i < len; i++)
  5863. if (!poolAppendChar(&parser->m_tempPool, prefix->binding->uri[i]))
  5864. return NULL;
  5865. needSep = XML_TRUE;
  5866. }
  5867. hashTableIterInit(&iter, &(dtd->generalEntities));
  5868. for (;;) {
  5869. const XML_Char *s;
  5870. ENTITY *e = (ENTITY *)hashTableIterNext(&iter);
  5871. if (!e)
  5872. break;
  5873. if (!e->open)
  5874. continue;
  5875. if (needSep && !poolAppendChar(&parser->m_tempPool, CONTEXT_SEP))
  5876. return NULL;
  5877. for (s = e->name; *s; s++)
  5878. if (!poolAppendChar(&parser->m_tempPool, *s))
  5879. return 0;
  5880. needSep = XML_TRUE;
  5881. }
  5882. if (!poolAppendChar(&parser->m_tempPool, XML_T('\0')))
  5883. return NULL;
  5884. return parser->m_tempPool.start;
  5885. }
  5886. static XML_Bool
  5887. setContext(XML_Parser parser, const XML_Char *context)
  5888. {
  5889. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  5890. const XML_Char *s = context;
  5891. while (*context != XML_T('\0')) {
  5892. if (*s == CONTEXT_SEP || *s == XML_T('\0')) {
  5893. ENTITY *e;
  5894. if (!poolAppendChar(&parser->m_tempPool, XML_T('\0')))
  5895. return XML_FALSE;
  5896. e = (ENTITY *)lookup(parser, &dtd->generalEntities, poolStart(&parser->m_tempPool), 0);
  5897. if (e)
  5898. e->open = XML_TRUE;
  5899. if (*s != XML_T('\0'))
  5900. s++;
  5901. context = s;
  5902. poolDiscard(&parser->m_tempPool);
  5903. }
  5904. else if (*s == XML_T(ASCII_EQUALS)) {
  5905. PREFIX *prefix;
  5906. if (poolLength(&parser->m_tempPool) == 0)
  5907. prefix = &dtd->defaultPrefix;
  5908. else {
  5909. if (!poolAppendChar(&parser->m_tempPool, XML_T('\0')))
  5910. return XML_FALSE;
  5911. prefix = (PREFIX *)lookup(parser, &dtd->prefixes, poolStart(&parser->m_tempPool),
  5912. sizeof(PREFIX));
  5913. if (!prefix)
  5914. return XML_FALSE;
  5915. if (prefix->name == poolStart(&parser->m_tempPool)) {
  5916. prefix->name = poolCopyString(&dtd->pool, prefix->name);
  5917. if (!prefix->name)
  5918. return XML_FALSE;
  5919. }
  5920. poolDiscard(&parser->m_tempPool);
  5921. }
  5922. for (context = s + 1;
  5923. *context != CONTEXT_SEP && *context != XML_T('\0');
  5924. context++)
  5925. if (!poolAppendChar(&parser->m_tempPool, *context))
  5926. return XML_FALSE;
  5927. if (!poolAppendChar(&parser->m_tempPool, XML_T('\0')))
  5928. return XML_FALSE;
  5929. if (addBinding(parser, prefix, NULL, poolStart(&parser->m_tempPool),
  5930. &parser->m_inheritedBindings) != XML_ERROR_NONE)
  5931. return XML_FALSE;
  5932. poolDiscard(&parser->m_tempPool);
  5933. if (*context != XML_T('\0'))
  5934. ++context;
  5935. s = context;
  5936. }
  5937. else {
  5938. if (!poolAppendChar(&parser->m_tempPool, *s))
  5939. return XML_FALSE;
  5940. s++;
  5941. }
  5942. }
  5943. return XML_TRUE;
  5944. }
  5945. static void FASTCALL
  5946. normalizePublicId(XML_Char *publicId)
  5947. {
  5948. XML_Char *p = publicId;
  5949. XML_Char *s;
  5950. for (s = publicId; *s; s++) {
  5951. switch (*s) {
  5952. case 0x20:
  5953. case 0xD:
  5954. case 0xA:
  5955. if (p != publicId && p[-1] != 0x20)
  5956. *p++ = 0x20;
  5957. break;
  5958. default:
  5959. *p++ = *s;
  5960. }
  5961. }
  5962. if (p != publicId && p[-1] == 0x20)
  5963. --p;
  5964. *p = XML_T('\0');
  5965. }
  5966. static DTD *
  5967. dtdCreate(const XML_Memory_Handling_Suite *ms)
  5968. {
  5969. DTD *p = (DTD *)ms->malloc_fcn(sizeof(DTD));
  5970. if (p == NULL)
  5971. return p;
  5972. poolInit(&(p->pool), ms);
  5973. poolInit(&(p->entityValuePool), ms);
  5974. hashTableInit(&(p->generalEntities), ms);
  5975. hashTableInit(&(p->elementTypes), ms);
  5976. hashTableInit(&(p->attributeIds), ms);
  5977. hashTableInit(&(p->prefixes), ms);
  5978. #ifdef XML_DTD
  5979. p->paramEntityRead = XML_FALSE;
  5980. hashTableInit(&(p->paramEntities), ms);
  5981. #endif /* XML_DTD */
  5982. p->defaultPrefix.name = NULL;
  5983. p->defaultPrefix.binding = NULL;
  5984. p->in_eldecl = XML_FALSE;
  5985. p->scaffIndex = NULL;
  5986. p->scaffold = NULL;
  5987. p->scaffLevel = 0;
  5988. p->scaffSize = 0;
  5989. p->scaffCount = 0;
  5990. p->contentStringLen = 0;
  5991. p->keepProcessing = XML_TRUE;
  5992. p->hasParamEntityRefs = XML_FALSE;
  5993. p->standalone = XML_FALSE;
  5994. return p;
  5995. }
  5996. static void
  5997. dtdReset(DTD *p, const XML_Memory_Handling_Suite *ms)
  5998. {
  5999. HASH_TABLE_ITER iter;
  6000. hashTableIterInit(&iter, &(p->elementTypes));
  6001. for (;;) {
  6002. ELEMENT_TYPE *e = (ELEMENT_TYPE *)hashTableIterNext(&iter);
  6003. if (!e)
  6004. break;
  6005. if (e->allocDefaultAtts != 0)
  6006. ms->free_fcn(e->defaultAtts);
  6007. }
  6008. hashTableClear(&(p->generalEntities));
  6009. #ifdef XML_DTD
  6010. p->paramEntityRead = XML_FALSE;
  6011. hashTableClear(&(p->paramEntities));
  6012. #endif /* XML_DTD */
  6013. hashTableClear(&(p->elementTypes));
  6014. hashTableClear(&(p->attributeIds));
  6015. hashTableClear(&(p->prefixes));
  6016. poolClear(&(p->pool));
  6017. poolClear(&(p->entityValuePool));
  6018. p->defaultPrefix.name = NULL;
  6019. p->defaultPrefix.binding = NULL;
  6020. p->in_eldecl = XML_FALSE;
  6021. ms->free_fcn(p->scaffIndex);
  6022. p->scaffIndex = NULL;
  6023. ms->free_fcn(p->scaffold);
  6024. p->scaffold = NULL;
  6025. p->scaffLevel = 0;
  6026. p->scaffSize = 0;
  6027. p->scaffCount = 0;
  6028. p->contentStringLen = 0;
  6029. p->keepProcessing = XML_TRUE;
  6030. p->hasParamEntityRefs = XML_FALSE;
  6031. p->standalone = XML_FALSE;
  6032. }
  6033. static void
  6034. dtdDestroy(DTD *p, XML_Bool isDocEntity, const XML_Memory_Handling_Suite *ms)
  6035. {
  6036. HASH_TABLE_ITER iter;
  6037. hashTableIterInit(&iter, &(p->elementTypes));
  6038. for (;;) {
  6039. ELEMENT_TYPE *e = (ELEMENT_TYPE *)hashTableIterNext(&iter);
  6040. if (!e)
  6041. break;
  6042. if (e->allocDefaultAtts != 0)
  6043. ms->free_fcn(e->defaultAtts);
  6044. }
  6045. hashTableDestroy(&(p->generalEntities));
  6046. #ifdef XML_DTD
  6047. hashTableDestroy(&(p->paramEntities));
  6048. #endif /* XML_DTD */
  6049. hashTableDestroy(&(p->elementTypes));
  6050. hashTableDestroy(&(p->attributeIds));
  6051. hashTableDestroy(&(p->prefixes));
  6052. poolDestroy(&(p->pool));
  6053. poolDestroy(&(p->entityValuePool));
  6054. if (isDocEntity) {
  6055. ms->free_fcn(p->scaffIndex);
  6056. ms->free_fcn(p->scaffold);
  6057. }
  6058. ms->free_fcn(p);
  6059. }
  6060. /* Do a deep copy of the DTD. Return 0 for out of memory, non-zero otherwise.
  6061. The new DTD has already been initialized.
  6062. */
  6063. static int
  6064. dtdCopy(XML_Parser oldParser, DTD *newDtd, const DTD *oldDtd, const XML_Memory_Handling_Suite *ms)
  6065. {
  6066. HASH_TABLE_ITER iter;
  6067. /* Copy the prefix table. */
  6068. hashTableIterInit(&iter, &(oldDtd->prefixes));
  6069. for (;;) {
  6070. const XML_Char *name;
  6071. const PREFIX *oldP = (PREFIX *)hashTableIterNext(&iter);
  6072. if (!oldP)
  6073. break;
  6074. name = poolCopyString(&(newDtd->pool), oldP->name);
  6075. if (!name)
  6076. return 0;
  6077. if (!lookup(oldParser, &(newDtd->prefixes), name, sizeof(PREFIX)))
  6078. return 0;
  6079. }
  6080. hashTableIterInit(&iter, &(oldDtd->attributeIds));
  6081. /* Copy the attribute id table. */
  6082. for (;;) {
  6083. ATTRIBUTE_ID *newA;
  6084. const XML_Char *name;
  6085. const ATTRIBUTE_ID *oldA = (ATTRIBUTE_ID *)hashTableIterNext(&iter);
  6086. if (!oldA)
  6087. break;
  6088. /* Remember to allocate the scratch byte before the name. */
  6089. if (!poolAppendChar(&(newDtd->pool), XML_T('\0')))
  6090. return 0;
  6091. name = poolCopyString(&(newDtd->pool), oldA->name);
  6092. if (!name)
  6093. return 0;
  6094. ++name;
  6095. newA = (ATTRIBUTE_ID *)lookup(oldParser, &(newDtd->attributeIds), name,
  6096. sizeof(ATTRIBUTE_ID));
  6097. if (!newA)
  6098. return 0;
  6099. newA->maybeTokenized = oldA->maybeTokenized;
  6100. if (oldA->prefix) {
  6101. newA->xmlns = oldA->xmlns;
  6102. if (oldA->prefix == &oldDtd->defaultPrefix)
  6103. newA->prefix = &newDtd->defaultPrefix;
  6104. else
  6105. newA->prefix = (PREFIX *)lookup(oldParser, &(newDtd->prefixes),
  6106. oldA->prefix->name, 0);
  6107. }
  6108. }
  6109. /* Copy the element type table. */
  6110. hashTableIterInit(&iter, &(oldDtd->elementTypes));
  6111. for (;;) {
  6112. int i;
  6113. ELEMENT_TYPE *newE;
  6114. const XML_Char *name;
  6115. const ELEMENT_TYPE *oldE = (ELEMENT_TYPE *)hashTableIterNext(&iter);
  6116. if (!oldE)
  6117. break;
  6118. name = poolCopyString(&(newDtd->pool), oldE->name);
  6119. if (!name)
  6120. return 0;
  6121. newE = (ELEMENT_TYPE *)lookup(oldParser, &(newDtd->elementTypes), name,
  6122. sizeof(ELEMENT_TYPE));
  6123. if (!newE)
  6124. return 0;
  6125. if (oldE->nDefaultAtts) {
  6126. newE->defaultAtts = (DEFAULT_ATTRIBUTE *)
  6127. ms->malloc_fcn(oldE->nDefaultAtts * sizeof(DEFAULT_ATTRIBUTE));
  6128. if (!newE->defaultAtts) {
  6129. return 0;
  6130. }
  6131. }
  6132. if (oldE->idAtt)
  6133. newE->idAtt = (ATTRIBUTE_ID *)
  6134. lookup(oldParser, &(newDtd->attributeIds), oldE->idAtt->name, 0);
  6135. newE->allocDefaultAtts = newE->nDefaultAtts = oldE->nDefaultAtts;
  6136. if (oldE->prefix)
  6137. newE->prefix = (PREFIX *)lookup(oldParser, &(newDtd->prefixes),
  6138. oldE->prefix->name, 0);
  6139. for (i = 0; i < newE->nDefaultAtts; i++) {
  6140. newE->defaultAtts[i].id = (ATTRIBUTE_ID *)
  6141. lookup(oldParser, &(newDtd->attributeIds), oldE->defaultAtts[i].id->name, 0);
  6142. newE->defaultAtts[i].isCdata = oldE->defaultAtts[i].isCdata;
  6143. if (oldE->defaultAtts[i].value) {
  6144. newE->defaultAtts[i].value
  6145. = poolCopyString(&(newDtd->pool), oldE->defaultAtts[i].value);
  6146. if (!newE->defaultAtts[i].value)
  6147. return 0;
  6148. }
  6149. else
  6150. newE->defaultAtts[i].value = NULL;
  6151. }
  6152. }
  6153. /* Copy the entity tables. */
  6154. if (!copyEntityTable(oldParser,
  6155. &(newDtd->generalEntities),
  6156. &(newDtd->pool),
  6157. &(oldDtd->generalEntities)))
  6158. return 0;
  6159. #ifdef XML_DTD
  6160. if (!copyEntityTable(oldParser,
  6161. &(newDtd->paramEntities),
  6162. &(newDtd->pool),
  6163. &(oldDtd->paramEntities)))
  6164. return 0;
  6165. newDtd->paramEntityRead = oldDtd->paramEntityRead;
  6166. #endif /* XML_DTD */
  6167. newDtd->keepProcessing = oldDtd->keepProcessing;
  6168. newDtd->hasParamEntityRefs = oldDtd->hasParamEntityRefs;
  6169. newDtd->standalone = oldDtd->standalone;
  6170. /* Don't want deep copying for scaffolding */
  6171. newDtd->in_eldecl = oldDtd->in_eldecl;
  6172. newDtd->scaffold = oldDtd->scaffold;
  6173. newDtd->contentStringLen = oldDtd->contentStringLen;
  6174. newDtd->scaffSize = oldDtd->scaffSize;
  6175. newDtd->scaffLevel = oldDtd->scaffLevel;
  6176. newDtd->scaffIndex = oldDtd->scaffIndex;
  6177. return 1;
  6178. } /* End dtdCopy */
  6179. static int
  6180. copyEntityTable(XML_Parser oldParser,
  6181. HASH_TABLE *newTable,
  6182. STRING_POOL *newPool,
  6183. const HASH_TABLE *oldTable)
  6184. {
  6185. HASH_TABLE_ITER iter;
  6186. const XML_Char *cachedOldBase = NULL;
  6187. const XML_Char *cachedNewBase = NULL;
  6188. hashTableIterInit(&iter, oldTable);
  6189. for (;;) {
  6190. ENTITY *newE;
  6191. const XML_Char *name;
  6192. const ENTITY *oldE = (ENTITY *)hashTableIterNext(&iter);
  6193. if (!oldE)
  6194. break;
  6195. name = poolCopyString(newPool, oldE->name);
  6196. if (!name)
  6197. return 0;
  6198. newE = (ENTITY *)lookup(oldParser, newTable, name, sizeof(ENTITY));
  6199. if (!newE)
  6200. return 0;
  6201. if (oldE->systemId) {
  6202. const XML_Char *tem = poolCopyString(newPool, oldE->systemId);
  6203. if (!tem)
  6204. return 0;
  6205. newE->systemId = tem;
  6206. if (oldE->base) {
  6207. if (oldE->base == cachedOldBase)
  6208. newE->base = cachedNewBase;
  6209. else {
  6210. cachedOldBase = oldE->base;
  6211. tem = poolCopyString(newPool, cachedOldBase);
  6212. if (!tem)
  6213. return 0;
  6214. cachedNewBase = newE->base = tem;
  6215. }
  6216. }
  6217. if (oldE->publicId) {
  6218. tem = poolCopyString(newPool, oldE->publicId);
  6219. if (!tem)
  6220. return 0;
  6221. newE->publicId = tem;
  6222. }
  6223. }
  6224. else {
  6225. const XML_Char *tem = poolCopyStringN(newPool, oldE->textPtr,
  6226. oldE->textLen);
  6227. if (!tem)
  6228. return 0;
  6229. newE->textPtr = tem;
  6230. newE->textLen = oldE->textLen;
  6231. }
  6232. if (oldE->notation) {
  6233. const XML_Char *tem = poolCopyString(newPool, oldE->notation);
  6234. if (!tem)
  6235. return 0;
  6236. newE->notation = tem;
  6237. }
  6238. newE->is_param = oldE->is_param;
  6239. newE->is_internal = oldE->is_internal;
  6240. }
  6241. return 1;
  6242. }
  6243. #define INIT_POWER 6
  6244. static XML_Bool FASTCALL
  6245. keyeq(KEY s1, KEY s2)
  6246. {
  6247. for (; *s1 == *s2; s1++, s2++)
  6248. if (*s1 == 0)
  6249. return XML_TRUE;
  6250. return XML_FALSE;
  6251. }
  6252. static size_t
  6253. keylen(KEY s)
  6254. {
  6255. size_t len = 0;
  6256. for (; *s; s++, len++);
  6257. return len;
  6258. }
  6259. static void
  6260. copy_salt_to_sipkey(XML_Parser parser, struct sipkey * key)
  6261. {
  6262. key->k[0] = 0;
  6263. key->k[1] = get_hash_secret_salt(parser);
  6264. }
  6265. static unsigned long FASTCALL
  6266. hash(XML_Parser parser, KEY s)
  6267. {
  6268. struct siphash state;
  6269. struct sipkey key;
  6270. (void)sip24_valid;
  6271. copy_salt_to_sipkey(parser, &key);
  6272. sip24_init(&state, &key);
  6273. sip24_update(&state, s, keylen(s) * sizeof(XML_Char));
  6274. return (unsigned long)sip24_final(&state);
  6275. }
  6276. static NAMED *
  6277. lookup(XML_Parser parser, HASH_TABLE *table, KEY name, size_t createSize)
  6278. {
  6279. size_t i;
  6280. if (table->size == 0) {
  6281. size_t tsize;
  6282. if (!createSize)
  6283. return NULL;
  6284. table->power = INIT_POWER;
  6285. /* table->size is a power of 2 */
  6286. table->size = (size_t)1 << INIT_POWER;
  6287. tsize = table->size * sizeof(NAMED *);
  6288. table->v = (NAMED **)table->mem->malloc_fcn(tsize);
  6289. if (!table->v) {
  6290. table->size = 0;
  6291. return NULL;
  6292. }
  6293. memset(table->v, 0, tsize);
  6294. i = hash(parser, name) & ((unsigned long)table->size - 1);
  6295. }
  6296. else {
  6297. unsigned long h = hash(parser, name);
  6298. unsigned long mask = (unsigned long)table->size - 1;
  6299. unsigned char step = 0;
  6300. i = h & mask;
  6301. while (table->v[i]) {
  6302. if (keyeq(name, table->v[i]->name))
  6303. return table->v[i];
  6304. if (!step)
  6305. step = PROBE_STEP(h, mask, table->power);
  6306. i < step ? (i += table->size - step) : (i -= step);
  6307. }
  6308. if (!createSize)
  6309. return NULL;
  6310. /* check for overflow (table is half full) */
  6311. if (table->used >> (table->power - 1)) {
  6312. unsigned char newPower = table->power + 1;
  6313. size_t newSize = (size_t)1 << newPower;
  6314. unsigned long newMask = (unsigned long)newSize - 1;
  6315. size_t tsize = newSize * sizeof(NAMED *);
  6316. NAMED **newV = (NAMED **)table->mem->malloc_fcn(tsize);
  6317. if (!newV)
  6318. return NULL;
  6319. memset(newV, 0, tsize);
  6320. for (i = 0; i < table->size; i++)
  6321. if (table->v[i]) {
  6322. unsigned long newHash = hash(parser, table->v[i]->name);
  6323. size_t j = newHash & newMask;
  6324. step = 0;
  6325. while (newV[j]) {
  6326. if (!step)
  6327. step = PROBE_STEP(newHash, newMask, newPower);
  6328. j < step ? (j += newSize - step) : (j -= step);
  6329. }
  6330. newV[j] = table->v[i];
  6331. }
  6332. table->mem->free_fcn(table->v);
  6333. table->v = newV;
  6334. table->power = newPower;
  6335. table->size = newSize;
  6336. i = h & newMask;
  6337. step = 0;
  6338. while (table->v[i]) {
  6339. if (!step)
  6340. step = PROBE_STEP(h, newMask, newPower);
  6341. i < step ? (i += newSize - step) : (i -= step);
  6342. }
  6343. }
  6344. }
  6345. table->v[i] = (NAMED *)table->mem->malloc_fcn(createSize);
  6346. if (!table->v[i])
  6347. return NULL;
  6348. memset(table->v[i], 0, createSize);
  6349. table->v[i]->name = name;
  6350. (table->used)++;
  6351. return table->v[i];
  6352. }
  6353. static void FASTCALL
  6354. hashTableClear(HASH_TABLE *table)
  6355. {
  6356. size_t i;
  6357. for (i = 0; i < table->size; i++) {
  6358. table->mem->free_fcn(table->v[i]);
  6359. table->v[i] = NULL;
  6360. }
  6361. table->used = 0;
  6362. }
  6363. static void FASTCALL
  6364. hashTableDestroy(HASH_TABLE *table)
  6365. {
  6366. size_t i;
  6367. for (i = 0; i < table->size; i++)
  6368. table->mem->free_fcn(table->v[i]);
  6369. table->mem->free_fcn(table->v);
  6370. }
  6371. static void FASTCALL
  6372. hashTableInit(HASH_TABLE *p, const XML_Memory_Handling_Suite *ms)
  6373. {
  6374. p->power = 0;
  6375. p->size = 0;
  6376. p->used = 0;
  6377. p->v = NULL;
  6378. p->mem = ms;
  6379. }
  6380. static void FASTCALL
  6381. hashTableIterInit(HASH_TABLE_ITER *iter, const HASH_TABLE *table)
  6382. {
  6383. iter->p = table->v;
  6384. iter->end = iter->p + table->size;
  6385. }
  6386. static NAMED * FASTCALL
  6387. hashTableIterNext(HASH_TABLE_ITER *iter)
  6388. {
  6389. while (iter->p != iter->end) {
  6390. NAMED *tem = *(iter->p)++;
  6391. if (tem)
  6392. return tem;
  6393. }
  6394. return NULL;
  6395. }
  6396. static void FASTCALL
  6397. poolInit(STRING_POOL *pool, const XML_Memory_Handling_Suite *ms)
  6398. {
  6399. pool->blocks = NULL;
  6400. pool->freeBlocks = NULL;
  6401. pool->start = NULL;
  6402. pool->ptr = NULL;
  6403. pool->end = NULL;
  6404. pool->mem = ms;
  6405. }
  6406. static void FASTCALL
  6407. poolClear(STRING_POOL *pool)
  6408. {
  6409. if (!pool->freeBlocks)
  6410. pool->freeBlocks = pool->blocks;
  6411. else {
  6412. BLOCK *p = pool->blocks;
  6413. while (p) {
  6414. BLOCK *tem = p->next;
  6415. p->next = pool->freeBlocks;
  6416. pool->freeBlocks = p;
  6417. p = tem;
  6418. }
  6419. }
  6420. pool->blocks = NULL;
  6421. pool->start = NULL;
  6422. pool->ptr = NULL;
  6423. pool->end = NULL;
  6424. }
  6425. static void FASTCALL
  6426. poolDestroy(STRING_POOL *pool)
  6427. {
  6428. BLOCK *p = pool->blocks;
  6429. while (p) {
  6430. BLOCK *tem = p->next;
  6431. pool->mem->free_fcn(p);
  6432. p = tem;
  6433. }
  6434. p = pool->freeBlocks;
  6435. while (p) {
  6436. BLOCK *tem = p->next;
  6437. pool->mem->free_fcn(p);
  6438. p = tem;
  6439. }
  6440. }
  6441. static XML_Char *
  6442. poolAppend(STRING_POOL *pool, const ENCODING *enc,
  6443. const char *ptr, const char *end)
  6444. {
  6445. if (!pool->ptr && !poolGrow(pool))
  6446. return NULL;
  6447. for (;;) {
  6448. const enum XML_Convert_Result convert_res = XmlConvert(enc, &ptr, end, (ICHAR **)&(pool->ptr), (ICHAR *)pool->end);
  6449. if ((convert_res == XML_CONVERT_COMPLETED) || (convert_res == XML_CONVERT_INPUT_INCOMPLETE))
  6450. break;
  6451. if (!poolGrow(pool))
  6452. return NULL;
  6453. }
  6454. return pool->start;
  6455. }
  6456. static const XML_Char * FASTCALL
  6457. poolCopyString(STRING_POOL *pool, const XML_Char *s)
  6458. {
  6459. do {
  6460. if (!poolAppendChar(pool, *s))
  6461. return NULL;
  6462. } while (*s++);
  6463. s = pool->start;
  6464. poolFinish(pool);
  6465. return s;
  6466. }
  6467. static const XML_Char *
  6468. poolCopyStringN(STRING_POOL *pool, const XML_Char *s, int n)
  6469. {
  6470. if (!pool->ptr && !poolGrow(pool)) {
  6471. /* The following line is unreachable given the current usage of
  6472. * poolCopyStringN(). Currently it is called from exactly one
  6473. * place to copy the text of a simple general entity. By that
  6474. * point, the name of the entity is already stored in the pool, so
  6475. * pool->ptr cannot be NULL.
  6476. *
  6477. * If poolCopyStringN() is used elsewhere as it well might be,
  6478. * this line may well become executable again. Regardless, this
  6479. * sort of check shouldn't be removed lightly, so we just exclude
  6480. * it from the coverage statistics.
  6481. */
  6482. return NULL; /* LCOV_EXCL_LINE */
  6483. }
  6484. for (; n > 0; --n, s++) {
  6485. if (!poolAppendChar(pool, *s))
  6486. return NULL;
  6487. }
  6488. s = pool->start;
  6489. poolFinish(pool);
  6490. return s;
  6491. }
  6492. static const XML_Char * FASTCALL
  6493. poolAppendString(STRING_POOL *pool, const XML_Char *s)
  6494. {
  6495. while (*s) {
  6496. if (!poolAppendChar(pool, *s))
  6497. return NULL;
  6498. s++;
  6499. }
  6500. return pool->start;
  6501. }
  6502. static XML_Char *
  6503. poolStoreString(STRING_POOL *pool, const ENCODING *enc,
  6504. const char *ptr, const char *end)
  6505. {
  6506. if (!poolAppend(pool, enc, ptr, end))
  6507. return NULL;
  6508. if (pool->ptr == pool->end && !poolGrow(pool))
  6509. return NULL;
  6510. *(pool->ptr)++ = 0;
  6511. return pool->start;
  6512. }
  6513. static size_t
  6514. poolBytesToAllocateFor(int blockSize)
  6515. {
  6516. /* Unprotected math would be:
  6517. ** return offsetof(BLOCK, s) + blockSize * sizeof(XML_Char);
  6518. **
  6519. ** Detect overflow, avoiding _signed_ overflow undefined behavior
  6520. ** For a + b * c we check b * c in isolation first, so that addition of a
  6521. ** on top has no chance of making us accept a small non-negative number
  6522. */
  6523. const size_t stretch = sizeof(XML_Char); /* can be 4 bytes */
  6524. if (blockSize <= 0)
  6525. return 0;
  6526. if (blockSize > (int)(INT_MAX / stretch))
  6527. return 0;
  6528. {
  6529. const int stretchedBlockSize = blockSize * (int)stretch;
  6530. const int bytesToAllocate = (int)(
  6531. offsetof(BLOCK, s) + (unsigned)stretchedBlockSize);
  6532. if (bytesToAllocate < 0)
  6533. return 0;
  6534. return (size_t)bytesToAllocate;
  6535. }
  6536. }
  6537. static XML_Bool FASTCALL
  6538. poolGrow(STRING_POOL *pool)
  6539. {
  6540. if (pool->freeBlocks) {
  6541. if (pool->start == 0) {
  6542. pool->blocks = pool->freeBlocks;
  6543. pool->freeBlocks = pool->freeBlocks->next;
  6544. pool->blocks->next = NULL;
  6545. pool->start = pool->blocks->s;
  6546. pool->end = pool->start + pool->blocks->size;
  6547. pool->ptr = pool->start;
  6548. return XML_TRUE;
  6549. }
  6550. if (pool->end - pool->start < pool->freeBlocks->size) {
  6551. BLOCK *tem = pool->freeBlocks->next;
  6552. pool->freeBlocks->next = pool->blocks;
  6553. pool->blocks = pool->freeBlocks;
  6554. pool->freeBlocks = tem;
  6555. memcpy(pool->blocks->s, pool->start,
  6556. (pool->end - pool->start) * sizeof(XML_Char));
  6557. pool->ptr = pool->blocks->s + (pool->ptr - pool->start);
  6558. pool->start = pool->blocks->s;
  6559. pool->end = pool->start + pool->blocks->size;
  6560. return XML_TRUE;
  6561. }
  6562. }
  6563. if (pool->blocks && pool->start == pool->blocks->s) {
  6564. BLOCK *temp;
  6565. int blockSize = (int)((unsigned)(pool->end - pool->start)*2U);
  6566. size_t bytesToAllocate;
  6567. /* NOTE: Needs to be calculated prior to calling `realloc`
  6568. to avoid dangling pointers: */
  6569. const ptrdiff_t offsetInsideBlock = pool->ptr - pool->start;
  6570. if (blockSize < 0) {
  6571. /* This condition traps a situation where either more than
  6572. * INT_MAX/2 bytes have already been allocated. This isn't
  6573. * readily testable, since it is unlikely that an average
  6574. * machine will have that much memory, so we exclude it from the
  6575. * coverage statistics.
  6576. */
  6577. return XML_FALSE; /* LCOV_EXCL_LINE */
  6578. }
  6579. bytesToAllocate = poolBytesToAllocateFor(blockSize);
  6580. if (bytesToAllocate == 0)
  6581. return XML_FALSE;
  6582. temp = (BLOCK *)
  6583. pool->mem->realloc_fcn(pool->blocks, (unsigned)bytesToAllocate);
  6584. if (temp == NULL)
  6585. return XML_FALSE;
  6586. pool->blocks = temp;
  6587. pool->blocks->size = blockSize;
  6588. pool->ptr = pool->blocks->s + offsetInsideBlock;
  6589. pool->start = pool->blocks->s;
  6590. pool->end = pool->start + blockSize;
  6591. }
  6592. else {
  6593. BLOCK *tem;
  6594. int blockSize = (int)(pool->end - pool->start);
  6595. size_t bytesToAllocate;
  6596. if (blockSize < 0) {
  6597. /* This condition traps a situation where either more than
  6598. * INT_MAX bytes have already been allocated (which is prevented
  6599. * by various pieces of program logic, not least this one, never
  6600. * mind the unlikelihood of actually having that much memory) or
  6601. * the pool control fields have been corrupted (which could
  6602. * conceivably happen in an extremely buggy user handler
  6603. * function). Either way it isn't readily testable, so we
  6604. * exclude it from the coverage statistics.
  6605. */
  6606. return XML_FALSE; /* LCOV_EXCL_LINE */
  6607. }
  6608. if (blockSize < INIT_BLOCK_SIZE)
  6609. blockSize = INIT_BLOCK_SIZE;
  6610. else {
  6611. /* Detect overflow, avoiding _signed_ overflow undefined behavior */
  6612. if ((int)((unsigned)blockSize * 2U) < 0) {
  6613. return XML_FALSE;
  6614. }
  6615. blockSize *= 2;
  6616. }
  6617. bytesToAllocate = poolBytesToAllocateFor(blockSize);
  6618. if (bytesToAllocate == 0)
  6619. return XML_FALSE;
  6620. tem = (BLOCK *)pool->mem->malloc_fcn(bytesToAllocate);
  6621. if (!tem)
  6622. return XML_FALSE;
  6623. tem->size = blockSize;
  6624. tem->next = pool->blocks;
  6625. pool->blocks = tem;
  6626. if (pool->ptr != pool->start)
  6627. memcpy(tem->s, pool->start,
  6628. (pool->ptr - pool->start) * sizeof(XML_Char));
  6629. pool->ptr = tem->s + (pool->ptr - pool->start);
  6630. pool->start = tem->s;
  6631. pool->end = tem->s + blockSize;
  6632. }
  6633. return XML_TRUE;
  6634. }
  6635. static int FASTCALL
  6636. nextScaffoldPart(XML_Parser parser)
  6637. {
  6638. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  6639. CONTENT_SCAFFOLD * me;
  6640. int next;
  6641. if (!dtd->scaffIndex) {
  6642. dtd->scaffIndex = (int *)MALLOC(parser, parser->m_groupSize * sizeof(int));
  6643. if (!dtd->scaffIndex)
  6644. return -1;
  6645. dtd->scaffIndex[0] = 0;
  6646. }
  6647. if (dtd->scaffCount >= dtd->scaffSize) {
  6648. CONTENT_SCAFFOLD *temp;
  6649. if (dtd->scaffold) {
  6650. temp = (CONTENT_SCAFFOLD *)
  6651. REALLOC(parser, dtd->scaffold, dtd->scaffSize * 2 * sizeof(CONTENT_SCAFFOLD));
  6652. if (temp == NULL)
  6653. return -1;
  6654. dtd->scaffSize *= 2;
  6655. }
  6656. else {
  6657. temp = (CONTENT_SCAFFOLD *)MALLOC(parser, INIT_SCAFFOLD_ELEMENTS
  6658. * sizeof(CONTENT_SCAFFOLD));
  6659. if (temp == NULL)
  6660. return -1;
  6661. dtd->scaffSize = INIT_SCAFFOLD_ELEMENTS;
  6662. }
  6663. dtd->scaffold = temp;
  6664. }
  6665. next = dtd->scaffCount++;
  6666. me = &dtd->scaffold[next];
  6667. if (dtd->scaffLevel) {
  6668. CONTENT_SCAFFOLD *parent = &dtd->scaffold[dtd->scaffIndex[dtd->scaffLevel-1]];
  6669. if (parent->lastchild) {
  6670. dtd->scaffold[parent->lastchild].nextsib = next;
  6671. }
  6672. if (!parent->childcnt)
  6673. parent->firstchild = next;
  6674. parent->lastchild = next;
  6675. parent->childcnt++;
  6676. }
  6677. me->firstchild = me->lastchild = me->childcnt = me->nextsib = 0;
  6678. return next;
  6679. }
  6680. static void
  6681. build_node(XML_Parser parser,
  6682. int src_node,
  6683. XML_Content *dest,
  6684. XML_Content **contpos,
  6685. XML_Char **strpos)
  6686. {
  6687. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  6688. dest->type = dtd->scaffold[src_node].type;
  6689. dest->quant = dtd->scaffold[src_node].quant;
  6690. if (dest->type == XML_CTYPE_NAME) {
  6691. const XML_Char *src;
  6692. dest->name = *strpos;
  6693. src = dtd->scaffold[src_node].name;
  6694. for (;;) {
  6695. *(*strpos)++ = *src;
  6696. if (!*src)
  6697. break;
  6698. src++;
  6699. }
  6700. dest->numchildren = 0;
  6701. dest->children = NULL;
  6702. }
  6703. else {
  6704. unsigned int i;
  6705. int cn;
  6706. dest->numchildren = dtd->scaffold[src_node].childcnt;
  6707. dest->children = *contpos;
  6708. *contpos += dest->numchildren;
  6709. for (i = 0, cn = dtd->scaffold[src_node].firstchild;
  6710. i < dest->numchildren;
  6711. i++, cn = dtd->scaffold[cn].nextsib) {
  6712. build_node(parser, cn, &(dest->children[i]), contpos, strpos);
  6713. }
  6714. dest->name = NULL;
  6715. }
  6716. }
  6717. static XML_Content *
  6718. build_model (XML_Parser parser)
  6719. {
  6720. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  6721. XML_Content *ret;
  6722. XML_Content *cpos;
  6723. XML_Char * str;
  6724. int allocsize = (dtd->scaffCount * sizeof(XML_Content)
  6725. + (dtd->contentStringLen * sizeof(XML_Char)));
  6726. ret = (XML_Content *)MALLOC(parser, allocsize);
  6727. if (!ret)
  6728. return NULL;
  6729. str = (XML_Char *) (&ret[dtd->scaffCount]);
  6730. cpos = &ret[1];
  6731. build_node(parser, 0, ret, &cpos, &str);
  6732. return ret;
  6733. }
  6734. static ELEMENT_TYPE *
  6735. getElementType(XML_Parser parser,
  6736. const ENCODING *enc,
  6737. const char *ptr,
  6738. const char *end)
  6739. {
  6740. DTD * const dtd = parser->m_dtd; /* save one level of indirection */
  6741. const XML_Char *name = poolStoreString(&dtd->pool, enc, ptr, end);
  6742. ELEMENT_TYPE *ret;
  6743. if (!name)
  6744. return NULL;
  6745. ret = (ELEMENT_TYPE *) lookup(parser, &dtd->elementTypes, name, sizeof(ELEMENT_TYPE));
  6746. if (!ret)
  6747. return NULL;
  6748. if (ret->name != name)
  6749. poolDiscard(&dtd->pool);
  6750. else {
  6751. poolFinish(&dtd->pool);
  6752. if (!setElementTypePrefix(parser, ret))
  6753. return NULL;
  6754. }
  6755. return ret;
  6756. }
  6757. static XML_Char *
  6758. copyString(const XML_Char *s,
  6759. const XML_Memory_Handling_Suite *memsuite)
  6760. {
  6761. int charsRequired = 0;
  6762. XML_Char *result;
  6763. /* First determine how long the string is */
  6764. while (s[charsRequired] != 0) {
  6765. charsRequired++;
  6766. }
  6767. /* Include the terminator */
  6768. charsRequired++;
  6769. /* Now allocate space for the copy */
  6770. result = memsuite->malloc_fcn(charsRequired * sizeof(XML_Char));
  6771. if (result == NULL)
  6772. return NULL;
  6773. /* Copy the original into place */
  6774. memcpy(result, s, charsRequired * sizeof(XML_Char));
  6775. return result;
  6776. }