Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

AjASTConverter.java 215KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877
  1. /*******************************************************************************
  2. * Copyright (c) 2000, 2010 IBM Corporation and others.
  3. * All rights reserved. This program and the accompanying materials
  4. * are made available under the terms of the Eclipse Public License v1.0
  5. * which accompanies this distribution, and is available at
  6. * http://www.eclipse.org/legal/epl-v10.html
  7. *
  8. * Contributors:
  9. * IBM Corporation - initial API and implementation
  10. * Nieraj Singh
  11. *******************************************************************************/
  12. package org.aspectj.org.eclipse.jdt.core.dom;
  13. import java.util.HashSet;
  14. import java.util.Iterator;
  15. import java.util.List;
  16. import java.util.Map;
  17. import org.aspectj.ajdt.internal.compiler.ast.AdviceDeclaration;
  18. import org.aspectj.ajdt.internal.compiler.ast.AspectDeclaration;
  19. import org.aspectj.ajdt.internal.compiler.ast.DeclareDeclaration;
  20. import org.aspectj.ajdt.internal.compiler.ast.InterTypeConstructorDeclaration;
  21. import org.aspectj.ajdt.internal.compiler.ast.InterTypeDeclaration;
  22. import org.aspectj.ajdt.internal.compiler.ast.InterTypeFieldDeclaration;
  23. import org.aspectj.ajdt.internal.compiler.ast.InterTypeMethodDeclaration;
  24. import org.aspectj.ajdt.internal.compiler.ast.PointcutDeclaration;
  25. import org.aspectj.org.eclipse.jdt.core.compiler.CategorizedProblem;
  26. import org.aspectj.org.eclipse.jdt.core.compiler.CharOperation;
  27. import org.aspectj.org.eclipse.jdt.core.compiler.IProblem;
  28. import org.aspectj.org.eclipse.jdt.core.compiler.InvalidInputException;
  29. import org.aspectj.org.eclipse.jdt.core.dom.Modifier.ModifierKeyword;
  30. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.AbstractMethodDeclaration;
  31. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument;
  32. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.ForeachStatement;
  33. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.JavadocArgumentExpression;
  34. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.JavadocFieldReference;
  35. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.JavadocMessageSend;
  36. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration;
  37. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.ParameterizedQualifiedTypeReference;
  38. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.ParameterizedSingleTypeReference;
  39. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedTypeReference;
  40. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.SingleTypeReference;
  41. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.StringLiteralConcatenation;
  42. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference;
  43. import org.aspectj.org.eclipse.jdt.internal.compiler.ast.Wildcard;
  44. import org.aspectj.org.eclipse.jdt.internal.compiler.classfmt.ClassFileConstants;
  45. import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.BlockScope;
  46. import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.ExtraCompilerModifiers;
  47. import org.aspectj.org.eclipse.jdt.internal.compiler.lookup.TypeConstants;
  48. import org.aspectj.org.eclipse.jdt.internal.compiler.parser.TerminalTokens;
  49. import org.aspectj.weaver.AdviceKind;
  50. import org.aspectj.weaver.patterns.Declare;
  51. import org.aspectj.weaver.patterns.DeclareAnnotation;
  52. import org.aspectj.weaver.patterns.DeclareErrorOrWarning;
  53. import org.aspectj.weaver.patterns.DeclareParents;
  54. import org.aspectj.weaver.patterns.DeclarePrecedence;
  55. import org.aspectj.weaver.patterns.DeclareSoft;
  56. import org.aspectj.weaver.patterns.ISignaturePattern;
  57. import org.aspectj.weaver.patterns.PatternNode;
  58. import org.aspectj.weaver.patterns.SignaturePattern;
  59. import org.aspectj.weaver.patterns.TypePattern;
  60. import org.eclipse.core.runtime.IProgressMonitor;
  61. /**
  62. * Internal class for converting internal compiler ASTs into public ASTs.
  63. */
  64. @SuppressWarnings("unchecked")
  65. public class AjASTConverter extends ASTConverter {
  66. public AjASTConverter(Map options, boolean resolveBindings, IProgressMonitor monitor) {
  67. super(options, resolveBindings, monitor);
  68. }
  69. public ASTNode convert(AdviceDeclaration adviceDeclaration) {
  70. // ajh02: method added
  71. org.aspectj.org.eclipse.jdt.core.dom.AdviceDeclaration adviceDecl = null;
  72. if (adviceDeclaration.kind.equals(AdviceKind.Before)) {
  73. adviceDecl = new org.aspectj.org.eclipse.jdt.core.dom.BeforeAdviceDeclaration(this.ast);
  74. } else if (adviceDeclaration.kind.equals(AdviceKind.After)) {
  75. adviceDecl = new org.aspectj.org.eclipse.jdt.core.dom.AfterAdviceDeclaration(this.ast);
  76. } else if (adviceDeclaration.kind.equals(AdviceKind.AfterThrowing)) {
  77. adviceDecl = new AfterThrowingAdviceDeclaration(this.ast);
  78. if (adviceDeclaration.extraArgument != null) {
  79. SingleVariableDeclaration throwing = convert(adviceDeclaration.extraArgument);
  80. ((AfterThrowingAdviceDeclaration) adviceDecl).setThrowing(throwing);
  81. }
  82. } else if (adviceDeclaration.kind.equals(AdviceKind.AfterReturning)) {
  83. adviceDecl = new AfterReturningAdviceDeclaration(this.ast);
  84. if (adviceDeclaration.extraArgument != null) {
  85. SingleVariableDeclaration returning = convert(adviceDeclaration.extraArgument);
  86. ((AfterReturningAdviceDeclaration) adviceDecl).setReturning(returning);
  87. }
  88. } else if (adviceDeclaration.kind.equals(AdviceKind.Around)) {
  89. adviceDecl = new AroundAdviceDeclaration(this.ast);
  90. // set the returnType
  91. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeReference = adviceDeclaration.returnType;
  92. if (typeReference != null) {
  93. Type returnType = convertType(typeReference);
  94. // get the positions of the right parenthesis
  95. setTypeForAroundAdviceDeclaration((AroundAdviceDeclaration) adviceDecl, returnType);
  96. }
  97. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeParameter[] typeParameters = adviceDeclaration.typeParameters();
  98. if (typeParameters != null) {
  99. switch (this.ast.apiLevel) {
  100. case AST.JLS2_INTERNAL:
  101. adviceDecl.setFlags(adviceDecl.getFlags() | ASTNode.MALFORMED);
  102. break;
  103. case AST.JLS3:
  104. for (int i = 0, max = typeParameters.length; i < max; i++) {
  105. ((AroundAdviceDeclaration) adviceDecl).typeParameters().add(convert(typeParameters[i]));
  106. }
  107. }
  108. }
  109. }
  110. // set its javadoc, parameters, throws, pointcut and body
  111. org.aspectj.weaver.patterns.Pointcut pointcut = adviceDeclaration.pointcutDesignator.getPointcut();
  112. adviceDecl.setPointcut(convert(pointcut));
  113. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference[] thrownExceptions = adviceDeclaration.thrownExceptions;
  114. if (thrownExceptions != null) {
  115. int thrownExceptionsLength = thrownExceptions.length;
  116. for (int i = 0; i < thrownExceptionsLength; i++) {
  117. adviceDecl.thrownExceptions().add(convert(thrownExceptions[i]));
  118. }
  119. }
  120. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument[] parameters = adviceDeclaration.arguments;
  121. if (parameters != null) {
  122. int parametersLength = parameters.length;
  123. for (int i = 0; i < parametersLength; i++) {
  124. adviceDecl.parameters().add(convert(parameters[i]));
  125. }
  126. }
  127. int start = adviceDeclaration.sourceStart;
  128. int end = retrieveIdentifierEndPosition(start, adviceDeclaration.sourceEnd);
  129. int declarationSourceStart = adviceDeclaration.declarationSourceStart;
  130. int declarationSourceEnd = adviceDeclaration.bodyEnd;
  131. adviceDecl.setSourceRange(declarationSourceStart, declarationSourceEnd - declarationSourceStart + 1);
  132. int closingPosition = retrieveRightBraceOrSemiColonPosition(adviceDeclaration.bodyEnd + 1,
  133. adviceDeclaration.declarationSourceEnd);
  134. if (closingPosition != -1) {
  135. int startPosition = adviceDecl.getStartPosition();
  136. adviceDecl.setSourceRange(startPosition, closingPosition - startPosition + 1);
  137. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement[] statements = adviceDeclaration.statements;
  138. start = retrieveStartBlockPosition(adviceDeclaration.sourceStart, declarationSourceEnd);
  139. end = retrieveEndBlockPosition(adviceDeclaration.sourceStart, adviceDeclaration.declarationSourceEnd);
  140. Block block = null;
  141. if (start != -1 && end != -1) {
  142. /*
  143. * start or end can be equal to -1 if we have an interface's method.
  144. */
  145. block = new Block(this.ast);
  146. block.setSourceRange(start, end - start + 1);
  147. adviceDecl.setBody(block);
  148. }
  149. if (block != null && statements != null) {
  150. int statementsLength = statements.length;
  151. for (int i = 0; i < statementsLength; i++) {
  152. if (statements[i] instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) {
  153. checkAndAddMultipleLocalDeclaration(statements, i, block.statements());
  154. } else {
  155. block.statements().add(convert(statements[i]));
  156. }
  157. }
  158. }
  159. if (block != null) {
  160. adviceDecl.setFlags(adviceDecl.getFlags() | ASTNode.MALFORMED);
  161. }
  162. } else {
  163. // syntax error in this advice declaration
  164. start = retrieveStartBlockPosition(adviceDeclaration.sourceStart, declarationSourceEnd);
  165. end = adviceDeclaration.bodyEnd;
  166. // try to get the best end position
  167. IProblem[] problems = adviceDeclaration.compilationResult().problems;
  168. if (problems != null) {
  169. for (int i = 0, max = adviceDeclaration.compilationResult().problemCount; i < max; i++) {
  170. IProblem currentProblem = problems[i];
  171. if (currentProblem.getSourceStart() == start && currentProblem.getID() == IProblem.ParsingErrorInsertToComplete) {
  172. end = currentProblem.getSourceEnd();
  173. break;
  174. }
  175. }
  176. }
  177. int startPosition = adviceDecl.getStartPosition();
  178. adviceDecl.setSourceRange(startPosition, end - startPosition + 1);
  179. if (start != -1 && end != -1) {
  180. /*
  181. * start or end can be equal to -1 if we have an interface's method.
  182. */
  183. Block block = new Block(this.ast);
  184. block.setSourceRange(start, end - start + 1);
  185. adviceDecl.setBody(block);
  186. }
  187. }
  188. // The javadoc comment is now got from list store in compilation unit declaration
  189. if (this.resolveBindings) {
  190. recordNodes(adviceDecl, adviceDeclaration);
  191. // if (adviceDecl.resolveBinding() != null) {
  192. // // ajh02: what is resolveBinding()?
  193. // convert(adviceDeclaration.javadoc, adviceDecl);
  194. // }
  195. } else {
  196. convert(adviceDeclaration.javadoc, adviceDecl);
  197. }
  198. return adviceDecl;
  199. }
  200. //public ASTNode convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.AbstractMethodDeclaration methodDeclaration) {
  201. public ASTNode convert(boolean isInterface, org.aspectj.org.eclipse.jdt.internal.compiler.ast.AbstractMethodDeclaration methodDeclaration) {
  202. checkCanceled();
  203. if (methodDeclaration instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.AnnotationMethodDeclaration) {
  204. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.AnnotationMethodDeclaration) methodDeclaration);
  205. }
  206. MethodDeclaration methodDecl = new MethodDeclaration(this.ast);
  207. boolean isConstructor = methodDeclaration.isConstructor();
  208. methodDecl.setConstructor(isConstructor);
  209. // //////////////// ajh02: added. ugh, polymorphism! Where are you!
  210. if (methodDeclaration instanceof DeclareDeclaration) {
  211. return convert((DeclareDeclaration) methodDeclaration);
  212. } else if (methodDeclaration instanceof InterTypeFieldDeclaration) {
  213. return convert((InterTypeFieldDeclaration) methodDeclaration);
  214. } else if (methodDeclaration instanceof InterTypeMethodDeclaration) {
  215. methodDecl = new org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration(this.ast);
  216. ((org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration) methodDecl)
  217. .setOnType(((InterTypeMethodDeclaration) methodDeclaration).getOnType().toString());
  218. } else if (methodDeclaration instanceof InterTypeConstructorDeclaration) {
  219. methodDecl = new org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration(this.ast);
  220. ((org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration) methodDecl)
  221. .setOnType(((InterTypeConstructorDeclaration) methodDeclaration).getOnType().toString());
  222. methodDecl.setConstructor(true);
  223. } else if (methodDeclaration instanceof PointcutDeclaration) {
  224. return convert((PointcutDeclaration) methodDeclaration);
  225. } else if (methodDeclaration instanceof AdviceDeclaration) {
  226. return convert((AdviceDeclaration) methodDeclaration);
  227. }
  228. // ///////////////////////
  229. // set modifiers after checking whether we're an itd, otherwise
  230. // the modifiers are not set on the correct object.
  231. setModifiers(methodDecl, methodDeclaration);
  232. final SimpleName methodName = new SimpleName(this.ast);
  233. // AspectJ Extension - for ITD's use the declaredSelector
  234. if (methodDeclaration instanceof InterTypeDeclaration) {
  235. InterTypeDeclaration itd = (InterTypeDeclaration) methodDeclaration;
  236. methodName.internalSetIdentifier(new String(itd.getDeclaredSelector()));
  237. } else {
  238. methodName.internalSetIdentifier(new String(methodDeclaration.selector));
  239. }
  240. // AspectJ Extension end
  241. int start = methodDeclaration.sourceStart;
  242. int end = retrieveIdentifierEndPosition(start, methodDeclaration.sourceEnd);
  243. methodName.setSourceRange(start, end - start + 1);
  244. methodDecl.setName(methodName);
  245. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference[] thrownExceptions = methodDeclaration.thrownExceptions;
  246. int methodHeaderEnd = methodDeclaration.sourceEnd;
  247. int thrownExceptionsLength = thrownExceptions == null ? 0 : thrownExceptions.length;
  248. if (thrownExceptionsLength > 0) {
  249. Name thrownException;
  250. int i = 0;
  251. do {
  252. thrownException = convert(thrownExceptions[i++]);
  253. methodDecl.thrownExceptions().add(thrownException);
  254. } while (i < thrownExceptionsLength);
  255. methodHeaderEnd = thrownException.getStartPosition() + thrownException.getLength();
  256. }
  257. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument[] parameters = methodDeclaration.arguments;
  258. int parametersLength = parameters == null ? 0 : parameters.length;
  259. if (parametersLength > 0) {
  260. SingleVariableDeclaration parameter;
  261. int i = 0;
  262. do {
  263. parameter = convert(parameters[i++]);
  264. methodDecl.parameters().add(parameter);
  265. } while (i < parametersLength);
  266. if (thrownExceptionsLength == 0) {
  267. methodHeaderEnd = parameter.getStartPosition() + parameter.getLength();
  268. }
  269. }
  270. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall explicitConstructorCall = null;
  271. if (isConstructor) {
  272. if (isInterface) {
  273. // interface cannot have a constructor
  274. methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  275. }
  276. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ConstructorDeclaration constructorDeclaration = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.ConstructorDeclaration) methodDeclaration;
  277. explicitConstructorCall = constructorDeclaration.constructorCall;
  278. switch(this.ast.apiLevel) {
  279. case AST.JLS2_INTERNAL :
  280. // set the return type to VOID
  281. PrimitiveType returnType = new PrimitiveType(this.ast);
  282. returnType.setPrimitiveTypeCode(PrimitiveType.VOID);
  283. returnType.setSourceRange(methodDeclaration.sourceStart, 0);
  284. methodDecl.internalSetReturnType(returnType);
  285. break;
  286. default :
  287. methodDecl.setReturnType2(null);
  288. }
  289. } else if (methodDeclaration instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.MethodDeclaration) {
  290. org.aspectj.org.eclipse.jdt.internal.compiler.ast.MethodDeclaration method = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.MethodDeclaration) methodDeclaration;
  291. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeReference = method.returnType;
  292. if (typeReference != null) {
  293. Type returnType = convertType(typeReference);
  294. // get the positions of the right parenthesis
  295. int rightParenthesisPosition = retrieveEndOfRightParenthesisPosition(end, method.bodyEnd);
  296. int extraDimensions = retrieveExtraDimension(rightParenthesisPosition, method.bodyEnd);
  297. methodDecl.setExtraDimensions(extraDimensions);
  298. setTypeForMethodDeclaration(methodDecl, returnType, extraDimensions);
  299. } else {
  300. // no return type for a method that is not a constructor
  301. methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  302. switch(this.ast.apiLevel) {
  303. case AST.JLS2_INTERNAL :
  304. break;
  305. default :
  306. methodDecl.setReturnType2(null);
  307. }
  308. }
  309. }
  310. int declarationSourceStart = methodDeclaration.declarationSourceStart;
  311. int bodyEnd = methodDeclaration.bodyEnd;
  312. methodDecl.setSourceRange(declarationSourceStart, bodyEnd - declarationSourceStart + 1);
  313. int declarationSourceEnd = methodDeclaration.declarationSourceEnd;
  314. int rightBraceOrSemiColonPositionStart = bodyEnd == declarationSourceEnd ? bodyEnd : bodyEnd + 1;
  315. int closingPosition = retrieveRightBraceOrSemiColonPosition(rightBraceOrSemiColonPositionStart, declarationSourceEnd);
  316. if (closingPosition != -1) {
  317. int startPosition = methodDecl.getStartPosition();
  318. methodDecl.setSourceRange(startPosition, closingPosition - startPosition + 1);
  319. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement[] statements = methodDeclaration.statements;
  320. start = retrieveStartBlockPosition(methodHeaderEnd, methodDeclaration.bodyStart);
  321. if (start == -1) start = methodDeclaration.bodyStart; // use recovery position for body start
  322. end = retrieveRightBrace(methodDeclaration.bodyEnd, declarationSourceEnd);
  323. Block block = null;
  324. if (start != -1 && end != -1) {
  325. /*
  326. * start or end can be equal to -1 if we have an interface's method.
  327. */
  328. block = new Block(this.ast);
  329. block.setSourceRange(start, closingPosition - start + 1);
  330. methodDecl.setBody(block);
  331. }
  332. if (block != null && (statements != null || explicitConstructorCall != null)) {
  333. if (explicitConstructorCall != null && explicitConstructorCall.accessMode != org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall.ImplicitSuper) {
  334. block.statements().add(convert(explicitConstructorCall));
  335. }
  336. int statementsLength = statements == null ? 0 : statements.length;
  337. for (int i = 0; i < statementsLength; i++) {
  338. if (statements[i] instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) {
  339. checkAndAddMultipleLocalDeclaration(statements, i, block.statements());
  340. } else {
  341. final Statement statement = convert(statements[i]);
  342. if (statement != null) {
  343. block.statements().add(statement);
  344. }
  345. }
  346. }
  347. }
  348. if (block != null
  349. && (Modifier.isAbstract(methodDecl.getModifiers())
  350. || Modifier.isNative(methodDecl.getModifiers())
  351. || isInterface)) {
  352. methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  353. }
  354. } else {
  355. // syntax error in this method declaration
  356. methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  357. if (!methodDeclaration.isNative() && !methodDeclaration.isAbstract()) {
  358. start = retrieveStartBlockPosition(methodHeaderEnd, bodyEnd);
  359. if (start == -1) start = methodDeclaration.bodyStart; // use recovery position for body start
  360. end = methodDeclaration.bodyEnd;
  361. // try to get the best end position
  362. CategorizedProblem[] problems = methodDeclaration.compilationResult().problems;
  363. if (problems != null) {
  364. for (int i = 0, max = methodDeclaration.compilationResult().problemCount; i < max; i++) {
  365. CategorizedProblem currentProblem = problems[i];
  366. if (currentProblem.getSourceStart() == start && currentProblem.getID() == IProblem.ParsingErrorInsertToComplete) {
  367. end = currentProblem.getSourceEnd();
  368. break;
  369. }
  370. }
  371. }
  372. int startPosition = methodDecl.getStartPosition();
  373. methodDecl.setSourceRange(startPosition, end - startPosition + 1);
  374. if (start != -1 && end != -1) {
  375. /*
  376. * start or end can be equal to -1 if we have an interface's method.
  377. */
  378. Block block = new Block(this.ast);
  379. block.setSourceRange(start, end - start + 1);
  380. methodDecl.setBody(block);
  381. }
  382. }
  383. }
  384. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeParameter[] typeParameters = methodDeclaration.typeParameters();
  385. if (typeParameters != null) {
  386. switch(this.ast.apiLevel) {
  387. case AST.JLS2_INTERNAL :
  388. methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  389. break;
  390. default :
  391. for (int i = 0, max = typeParameters.length; i < max; i++) {
  392. methodDecl.typeParameters().add(convert(typeParameters[i]));
  393. }
  394. }
  395. }
  396. // The javadoc comment is now got from list store in compilation unit declaration
  397. convert(methodDeclaration.javadoc, methodDecl);
  398. if (this.resolveBindings) {
  399. recordNodes(methodDecl, methodDeclaration);
  400. recordNodes(methodName, methodDeclaration);
  401. methodDecl.resolveBinding();
  402. }
  403. return methodDecl;
  404. }
  405. // checkCanceled();
  406. // if (methodDeclaration instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.AnnotationMethodDeclaration) {
  407. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.AnnotationMethodDeclaration) methodDeclaration);
  408. // }
  409. // MethodDeclaration methodDecl = new MethodDeclaration(this.ast);
  410. // boolean isConstructor = methodDeclaration.isConstructor();
  411. // methodDecl.setConstructor(isConstructor);
  412. //
  413. // // //////////////// ajh02: added. ugh, polymorphism! Where are you!
  414. // if (methodDeclaration instanceof DeclareDeclaration) {
  415. // return convert((DeclareDeclaration) methodDeclaration);
  416. // } else if (methodDeclaration instanceof InterTypeFieldDeclaration) {
  417. // return convert((InterTypeFieldDeclaration) methodDeclaration);
  418. // } else if (methodDeclaration instanceof InterTypeMethodDeclaration) {
  419. // methodDecl = new org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration(this.ast);
  420. // ((org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration) methodDecl)
  421. // .setOnType(((InterTypeMethodDeclaration) methodDeclaration).getOnType().toString());
  422. // } else if (methodDeclaration instanceof InterTypeConstructorDeclaration) {
  423. // methodDecl = new org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration(this.ast);
  424. // ((org.aspectj.org.eclipse.jdt.core.dom.InterTypeMethodDeclaration) methodDecl)
  425. // .setOnType(((InterTypeConstructorDeclaration) methodDeclaration).getOnType().toString());
  426. // methodDecl.setConstructor(true);
  427. // } else if (methodDeclaration instanceof PointcutDeclaration) {
  428. // return convert((PointcutDeclaration) methodDeclaration);
  429. // } else if (methodDeclaration instanceof AdviceDeclaration) {
  430. // return convert((AdviceDeclaration) methodDeclaration);
  431. // }
  432. // // ///////////////////////
  433. //
  434. // // set modifiers after checking whether we're an itd, otherwise
  435. // // the modifiers are not set on the correct object.
  436. // setModifiers(methodDecl, methodDeclaration);
  437. //
  438. // // for ITD's use the declaredSelector
  439. // final SimpleName methodName = new SimpleName(this.ast);
  440. // if (methodDeclaration instanceof InterTypeDeclaration) {
  441. // InterTypeDeclaration itd = (InterTypeDeclaration) methodDeclaration;
  442. // methodName.internalSetIdentifier(new String(itd.getDeclaredSelector()));
  443. // } else {
  444. // methodName.internalSetIdentifier(new String(methodDeclaration.selector));
  445. // }
  446. // int start = methodDeclaration.sourceStart;
  447. // int end = retrieveIdentifierEndPosition(start, methodDeclaration.sourceEnd);
  448. // methodName.setSourceRange(start, end - start + 1);
  449. // methodDecl.setName(methodName);
  450. //
  451. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference[] thrownExceptions = methodDeclaration.thrownExceptions;
  452. // if (thrownExceptions != null) {
  453. // int thrownExceptionsLength = thrownExceptions.length;
  454. // for (int i = 0; i < thrownExceptionsLength; i++) {
  455. // methodDecl.thrownExceptions().add(convert(thrownExceptions[i]));
  456. // }
  457. // }
  458. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument[] parameters = methodDeclaration.arguments;
  459. // if (parameters != null) {
  460. // int parametersLength = parameters.length;
  461. // for (int i = 0; i < parametersLength; i++) {
  462. // methodDecl.parameters().add(convert(parameters[i]));
  463. // }
  464. // }
  465. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall explicitConstructorCall = null;
  466. // if (isConstructor) {
  467. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ConstructorDeclaration constructorDeclaration = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.ConstructorDeclaration) methodDeclaration;
  468. // explicitConstructorCall = constructorDeclaration.constructorCall;
  469. // switch (this.ast.apiLevel) {
  470. // case AST.JLS2_INTERNAL:
  471. // // set the return type to VOID
  472. // PrimitiveType returnType = new PrimitiveType(this.ast);
  473. // returnType.setPrimitiveTypeCode(PrimitiveType.VOID);
  474. // returnType.setSourceRange(methodDeclaration.sourceStart, 0);
  475. // methodDecl.internalSetReturnType(returnType);
  476. // break;
  477. // case AST.JLS3:
  478. // methodDecl.setReturnType2(null);
  479. // }
  480. // } else if (methodDeclaration instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.MethodDeclaration) {
  481. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.MethodDeclaration method = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.MethodDeclaration) methodDeclaration;
  482. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeReference = method.returnType;
  483. // if (typeReference != null) {
  484. // Type returnType = convertType(typeReference);
  485. // // get the positions of the right parenthesis
  486. // int rightParenthesisPosition = retrieveEndOfRightParenthesisPosition(end, method.bodyEnd);
  487. // int extraDimensions = retrieveExtraDimension(rightParenthesisPosition, method.bodyEnd);
  488. // methodDecl.setExtraDimensions(extraDimensions);
  489. // setTypeForMethodDeclaration(methodDecl, returnType, extraDimensions);
  490. // }
  491. // }
  492. // int declarationSourceStart = methodDeclaration.declarationSourceStart;
  493. // int declarationSourceEnd = methodDeclaration.bodyEnd;
  494. // methodDecl.setSourceRange(declarationSourceStart, declarationSourceEnd - declarationSourceStart + 1);
  495. // int closingPosition = retrieveRightBraceOrSemiColonPosition(methodDeclaration.bodyEnd + 1,
  496. // methodDeclaration.declarationSourceEnd);
  497. // if (closingPosition != -1) {
  498. // int startPosition = methodDecl.getStartPosition();
  499. // methodDecl.setSourceRange(startPosition, closingPosition - startPosition + 1);
  500. //
  501. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement[] statements = methodDeclaration.statements;
  502. //
  503. // start = retrieveStartBlockPosition(methodDeclaration.sourceStart, declarationSourceEnd);
  504. // end = retrieveEndBlockPosition(methodDeclaration.sourceStart, methodDeclaration.declarationSourceEnd);
  505. // Block block = null;
  506. // if (start != -1 && end != -1) {
  507. // /*
  508. // * start or end can be equal to -1 if we have an interface's method.
  509. // */
  510. // block = new Block(this.ast);
  511. // block.setSourceRange(start, end - start + 1);
  512. // methodDecl.setBody(block);
  513. // }
  514. // if (block != null && (statements != null || explicitConstructorCall != null)) {
  515. // if (explicitConstructorCall != null
  516. // && explicitConstructorCall.accessMode != org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall.ImplicitSuper) {
  517. // block.statements().add(super.convert(explicitConstructorCall));
  518. // }
  519. // int statementsLength = statements == null ? 0 : statements.length;
  520. // for (int i = 0; i < statementsLength; i++) {
  521. // if (statements[i] instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) {
  522. // checkAndAddMultipleLocalDeclaration(statements, i, block.statements());
  523. // } else {
  524. // block.statements().add(convert(statements[i]));
  525. // }
  526. // }
  527. // }
  528. // if (block != null && (Modifier.isAbstract(methodDecl.getModifiers()) || Modifier.isNative(methodDecl.getModifiers()))) {
  529. // methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  530. // }
  531. // } else {
  532. // // syntax error in this method declaration
  533. // if (!methodDeclaration.isNative() && !methodDeclaration.isAbstract()) {
  534. // start = retrieveStartBlockPosition(methodDeclaration.sourceStart, declarationSourceEnd);
  535. // end = methodDeclaration.bodyEnd;
  536. // // try to get the best end position
  537. // IProblem[] problems = methodDeclaration.compilationResult().problems;
  538. // if (problems != null) {
  539. // for (int i = 0, max = methodDeclaration.compilationResult().problemCount; i < max; i++) {
  540. // IProblem currentProblem = problems[i];
  541. // if (currentProblem.getSourceStart() == start
  542. // && currentProblem.getID() == IProblem.ParsingErrorInsertToComplete) {
  543. // end = currentProblem.getSourceEnd();
  544. // break;
  545. // }
  546. // }
  547. // }
  548. // int startPosition = methodDecl.getStartPosition();
  549. // methodDecl.setSourceRange(startPosition, end - startPosition + 1);
  550. // if (start != -1 && end != -1) {
  551. // /*
  552. // * start or end can be equal to -1 if we have an interface's method.
  553. // */
  554. // Block block = new Block(this.ast);
  555. // block.setSourceRange(start, end - start + 1);
  556. // methodDecl.setBody(block);
  557. // }
  558. // }
  559. // }
  560. //
  561. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeParameter[] typeParameters = methodDeclaration.typeParameters();
  562. // if (typeParameters != null) {
  563. // switch (this.ast.apiLevel) {
  564. // case AST.JLS2_INTERNAL:
  565. // methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  566. // break;
  567. // case AST.JLS3:
  568. // for (int i = 0, max = typeParameters.length; i < max; i++) {
  569. // methodDecl.typeParameters().add(convert(typeParameters[i]));
  570. // }
  571. // }
  572. // }
  573. //
  574. // // The javadoc comment is now got from list store in compilation unit declaration
  575. // if (this.resolveBindings) {
  576. // recordNodes(methodDecl, methodDeclaration);
  577. // recordNodes(methodName, methodDeclaration);
  578. // if (methodDecl.resolveBinding() != null) {
  579. // convert(methodDeclaration.javadoc, methodDecl);
  580. // }
  581. // } else {
  582. // convert(methodDeclaration.javadoc, methodDecl);
  583. // }
  584. // return methodDecl;
  585. // }
  586. public ASTNode convert(DeclareDeclaration declareDecl) {
  587. checkCanceled(); // is this line needed?
  588. org.aspectj.org.eclipse.jdt.core.dom.DeclareDeclaration declareDeclaration = null;
  589. Declare declare = declareDecl.declareDecl;
  590. if (declare instanceof DeclareAnnotation) {
  591. DeclareAnnotation da = (DeclareAnnotation) declare;
  592. if (da.getKind().equals(DeclareAnnotation.AT_TYPE)) {
  593. declareDeclaration = new DeclareAtTypeDeclaration(this.ast);
  594. ((DeclareAtTypeDeclaration) declareDeclaration).setPatternNode(convert(da.getTypePattern()));
  595. SimpleName annotationName = new SimpleName(this.ast);
  596. annotationName.setSourceRange(da.getAnnotationSourceStart(),
  597. da.getAnnotationSourceEnd() - da.getAnnotationSourceStart());
  598. annotationName.internalSetIdentifier(da.getAnnotationString());
  599. ((DeclareAtTypeDeclaration) declareDeclaration).setAnnotationName(annotationName);
  600. } else if (da.getKind().equals(DeclareAnnotation.AT_CONSTRUCTOR)) {
  601. declareDeclaration = new DeclareAtConstructorDeclaration(this.ast);
  602. ((DeclareAtConstructorDeclaration) declareDeclaration).setPatternNode(convertSignature(da.getSignaturePattern()));
  603. SimpleName annotationName = new SimpleName(this.ast);
  604. annotationName.setSourceRange(da.getAnnotationSourceStart(),
  605. da.getAnnotationSourceEnd() - da.getAnnotationSourceStart());
  606. annotationName.internalSetIdentifier(da.getAnnotationString());
  607. ((DeclareAtConstructorDeclaration) declareDeclaration).setAnnotationName(annotationName);
  608. } else if (da.getKind().equals(DeclareAnnotation.AT_FIELD)) {
  609. declareDeclaration = new DeclareAtFieldDeclaration(this.ast);
  610. ((DeclareAtFieldDeclaration) declareDeclaration).setPatternNode(convertSignature(da.getSignaturePattern()));
  611. SimpleName annotationName = new SimpleName(this.ast);
  612. annotationName.setSourceRange(da.getAnnotationSourceStart(),
  613. da.getAnnotationSourceEnd() - da.getAnnotationSourceStart());
  614. annotationName.internalSetIdentifier(da.getAnnotationString());
  615. ((DeclareAtFieldDeclaration) declareDeclaration).setAnnotationName(annotationName);
  616. } else if (da.getKind().equals(DeclareAnnotation.AT_METHOD)) {
  617. declareDeclaration = new DeclareAtMethodDeclaration(this.ast);
  618. ((DeclareAtMethodDeclaration) declareDeclaration).setPatternNode(convertSignature(da.getSignaturePattern()));
  619. SimpleName annotationName = new SimpleName(this.ast);
  620. annotationName.setSourceRange(da.getAnnotationSourceStart(),
  621. da.getAnnotationSourceEnd() - da.getAnnotationSourceStart());
  622. annotationName.internalSetIdentifier(da.getAnnotationString());
  623. ((DeclareAtMethodDeclaration) declareDeclaration).setAnnotationName(annotationName);
  624. }
  625. } else if (declare instanceof DeclareErrorOrWarning) {
  626. DeclareErrorOrWarning deow = (DeclareErrorOrWarning) declare;
  627. if (deow.isError()) {
  628. declareDeclaration = new DeclareErrorDeclaration(this.ast);
  629. ((DeclareErrorDeclaration) declareDeclaration).setPointcut(convert(deow.getPointcut()));
  630. StringLiteral message = new StringLiteral(this.ast);
  631. message.setEscapedValue(updateString(deow.getMessage()));
  632. ((DeclareErrorDeclaration) declareDeclaration).setMessage(message);
  633. } else {
  634. declareDeclaration = new DeclareWarningDeclaration(this.ast);
  635. ((DeclareWarningDeclaration) declareDeclaration).setPointcut(convert(deow.getPointcut()));
  636. StringLiteral message = new StringLiteral(this.ast);
  637. message.setEscapedValue(updateString(deow.getMessage()));
  638. ((DeclareWarningDeclaration) declareDeclaration).setMessage(message);
  639. }
  640. } else if (declare instanceof DeclareParents) {
  641. DeclareParents dp = (DeclareParents) declare;
  642. declareDeclaration = new org.aspectj.org.eclipse.jdt.core.dom.DeclareParentsDeclaration(this.ast, dp.isExtends());
  643. org.aspectj.org.eclipse.jdt.core.dom.PatternNode pNode = convert(dp.getChild());
  644. if (pNode instanceof org.aspectj.org.eclipse.jdt.core.dom.TypePattern) {
  645. ((DeclareParentsDeclaration) declareDeclaration)
  646. .setChildTypePattern((org.aspectj.org.eclipse.jdt.core.dom.TypePattern) pNode);
  647. }
  648. TypePattern[] weaverTypePatterns = dp.getParents().getTypePatterns();
  649. List typePatterns = ((DeclareParentsDeclaration) declareDeclaration).parentTypePatterns();
  650. for (int i = 0; i < weaverTypePatterns.length; i++) {
  651. typePatterns.add(convert(weaverTypePatterns[i]));
  652. }
  653. } else if (declare instanceof DeclarePrecedence) {
  654. declareDeclaration = new org.aspectj.org.eclipse.jdt.core.dom.DeclarePrecedenceDeclaration(this.ast);
  655. DeclarePrecedence dp = (DeclarePrecedence) declare;
  656. TypePattern[] weaverTypePatterns = dp.getPatterns().getTypePatterns();
  657. List typePatterns = ((DeclarePrecedenceDeclaration) declareDeclaration).typePatterns();
  658. for (int i = 0; i < weaverTypePatterns.length; i++) {
  659. typePatterns.add(convert(weaverTypePatterns[i]));
  660. }
  661. } else if (declare instanceof DeclareSoft) {
  662. declareDeclaration = new DeclareSoftDeclaration(this.ast);
  663. DeclareSoft ds = (DeclareSoft) declare;
  664. ((DeclareSoftDeclaration) declareDeclaration).setPointcut(convert(ds.getPointcut()));
  665. org.aspectj.org.eclipse.jdt.core.dom.PatternNode pNode = convert(ds.getException());
  666. if (pNode instanceof org.aspectj.org.eclipse.jdt.core.dom.TypePattern) {
  667. ((DeclareSoftDeclaration) declareDeclaration)
  668. .setTypePattern((org.aspectj.org.eclipse.jdt.core.dom.TypePattern) pNode);
  669. }
  670. }
  671. if (declareDeclaration != null) {
  672. declareDeclaration.setSourceRange(declareDecl.declarationSourceStart, declareDecl.declarationSourceEnd
  673. - declareDecl.declarationSourceStart + 1);
  674. }
  675. return declareDeclaration;
  676. }
  677. private String updateString(String message) {
  678. StringBuffer sb = new StringBuffer(message);
  679. int nextQuote = sb.toString().indexOf("\"");
  680. while (nextQuote != -1) {
  681. sb.insert(nextQuote, "\\");
  682. nextQuote = sb.toString().indexOf("\"");
  683. }
  684. int nextNewLine = sb.toString().indexOf("\n");
  685. while (nextNewLine != -1) {
  686. sb.insert(nextNewLine, "\\");
  687. nextNewLine = sb.toString().indexOf("\n");
  688. }
  689. if (!sb.toString().startsWith("\"")) {
  690. sb.insert(0, "\"");
  691. }
  692. if (!sb.toString().endsWith("\"")) {
  693. sb.insert(sb.toString().length(), "\"");
  694. }
  695. return sb.toString();
  696. }
  697. public ASTNode convert(InterTypeFieldDeclaration fieldDecl) {
  698. // ajh02: method added
  699. checkCanceled(); // ajh02: is this line needed?
  700. VariableDeclarationFragment variableDeclarationFragment = convertToVariableDeclarationFragment(fieldDecl);
  701. final org.aspectj.org.eclipse.jdt.core.dom.InterTypeFieldDeclaration fieldDeclaration = new org.aspectj.org.eclipse.jdt.core.dom.InterTypeFieldDeclaration(
  702. this.ast);
  703. fieldDeclaration.fragments().add(variableDeclarationFragment);
  704. IVariableBinding binding = null;
  705. if (this.resolveBindings) {
  706. recordNodes(variableDeclarationFragment, fieldDecl);
  707. binding = variableDeclarationFragment.resolveBinding();
  708. }
  709. fieldDeclaration.setSourceRange(fieldDecl.declarationSourceStart, fieldDecl.declarationSourceEnd
  710. - fieldDecl.declarationSourceStart + 1);
  711. Type type = convertType(fieldDecl.returnType);
  712. setTypeForField(fieldDeclaration, type, variableDeclarationFragment.getExtraDimensions());
  713. setModifiers(fieldDeclaration, fieldDecl);
  714. if (!(this.resolveBindings && binding == null)) {
  715. convert(fieldDecl.javadoc, fieldDeclaration);
  716. }
  717. fieldDeclaration.setOnType(fieldDecl.getOnType().toString());
  718. return fieldDeclaration;
  719. }
  720. public ASTNode convert(PointcutDeclaration pointcutDeclaration) {
  721. // ajh02: method added
  722. checkCanceled();
  723. org.aspectj.org.eclipse.jdt.core.dom.PointcutDeclaration pointcutDecl = new org.aspectj.org.eclipse.jdt.core.dom.PointcutDeclaration(
  724. this.ast);
  725. setModifiers(pointcutDecl, pointcutDeclaration);
  726. final SimpleName pointcutName = new SimpleName(this.ast);
  727. pointcutName.internalSetIdentifier(new String(pointcutDeclaration.selector));
  728. int start = pointcutDeclaration.sourceStart;
  729. int end = retrieveIdentifierEndPosition(start, pointcutDeclaration.sourceEnd);
  730. pointcutName.setSourceRange(start, end - start + 1);
  731. pointcutDecl.setSourceRange(pointcutDeclaration.declarationSourceStart, (pointcutDeclaration.bodyEnd
  732. - pointcutDeclaration.declarationSourceStart + 1));
  733. pointcutDecl.setName(pointcutName);
  734. if (pointcutDeclaration.pointcutDesignator != null) {
  735. pointcutDecl.setDesignator(convert(pointcutDeclaration.pointcutDesignator.getPointcut()));
  736. } else {
  737. pointcutDecl.setDesignator(new org.aspectj.org.eclipse.jdt.core.dom.DefaultPointcut(this.ast, pointcutDeclaration
  738. .toString()));
  739. }
  740. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument[] parameters = pointcutDeclaration.arguments;
  741. if (parameters != null) {
  742. int parametersLength = parameters.length;
  743. for (int i = 0; i < parametersLength; i++) {
  744. pointcutDecl.parameters().add(convert(parameters[i]));
  745. }
  746. }
  747. // The javadoc comment is now got from list store in compilation unit declaration
  748. if (this.resolveBindings) {
  749. recordNodes(pointcutDecl, pointcutDeclaration);
  750. recordNodes(pointcutName, pointcutDeclaration);
  751. } else {
  752. convert(pointcutDeclaration.javadoc, pointcutDecl);
  753. }
  754. return pointcutDecl;
  755. }
  756. public org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator convert(org.aspectj.weaver.patterns.Pointcut pointcut) {
  757. // ajh02: this could do with being seperate methods
  758. // rather than a huge if.elseif..elseif.. thing
  759. org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator pointcutDesi = null;
  760. if (pointcut instanceof org.aspectj.weaver.patterns.ReferencePointcut) {
  761. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.ReferencePointcut(this.ast);
  762. final SimpleName pointcutName = new SimpleName(this.ast);
  763. int start = pointcut.getStart();
  764. int end = retrieveIdentifierEndPosition(start, pointcut.getEnd());
  765. pointcutName.setSourceRange(start, end - start + 1);
  766. pointcutName.internalSetIdentifier(((org.aspectj.weaver.patterns.ReferencePointcut) pointcut).name);
  767. ((org.aspectj.org.eclipse.jdt.core.dom.ReferencePointcut) pointcutDesi).setName(pointcutName);
  768. } else if (pointcut instanceof org.aspectj.weaver.patterns.NotPointcut) {
  769. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.NotPointcut(this.ast);
  770. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator body = convert(((org.aspectj.weaver.patterns.NotPointcut) pointcut)
  771. .getNegatedPointcut());
  772. ((org.aspectj.org.eclipse.jdt.core.dom.NotPointcut) pointcutDesi).setBody(body);
  773. } else if (pointcut instanceof org.aspectj.weaver.patterns.PerObject) {
  774. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.PerObject(this.ast);
  775. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator body = convert(((org.aspectj.weaver.patterns.PerObject) pointcut)
  776. .getEntry());
  777. ((org.aspectj.org.eclipse.jdt.core.dom.PerObject) pointcutDesi).setBody(body);
  778. } else if (pointcut instanceof org.aspectj.weaver.patterns.PerCflow) {
  779. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.PerCflow(this.ast);
  780. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator body = convert(((org.aspectj.weaver.patterns.PerCflow) pointcut)
  781. .getEntry());
  782. ((org.aspectj.org.eclipse.jdt.core.dom.PerCflow) pointcutDesi).setBody(body);
  783. } else if (pointcut instanceof org.aspectj.weaver.patterns.PerTypeWithin) {
  784. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.PerTypeWithin(this.ast);
  785. // should set its type pattern here
  786. } else if (pointcut instanceof org.aspectj.weaver.patterns.CflowPointcut) {
  787. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.CflowPointcut(this.ast);
  788. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator body = convert(((org.aspectj.weaver.patterns.CflowPointcut) pointcut)
  789. .getEntry());
  790. ((org.aspectj.org.eclipse.jdt.core.dom.CflowPointcut) pointcutDesi).setBody(body);
  791. ((org.aspectj.org.eclipse.jdt.core.dom.CflowPointcut) pointcutDesi)
  792. .setIsCflowBelow(((org.aspectj.weaver.patterns.CflowPointcut) pointcut).isCflowBelow());
  793. } else if (pointcut instanceof org.aspectj.weaver.patterns.AndPointcut) {
  794. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.AndPointcut(this.ast);
  795. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator left = convert(((org.aspectj.weaver.patterns.AndPointcut) pointcut)
  796. .getLeft());
  797. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator right = convert(((org.aspectj.weaver.patterns.AndPointcut) pointcut)
  798. .getRight());
  799. ((org.aspectj.org.eclipse.jdt.core.dom.AndPointcut) pointcutDesi).setLeft(left);
  800. ((org.aspectj.org.eclipse.jdt.core.dom.AndPointcut) pointcutDesi).setRight(right);
  801. } else if (pointcut instanceof org.aspectj.weaver.patterns.OrPointcut) {
  802. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.OrPointcut(this.ast);
  803. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator left = convert(((org.aspectj.weaver.patterns.OrPointcut) pointcut)
  804. .getLeft());
  805. final org.aspectj.org.eclipse.jdt.core.dom.PointcutDesignator right = convert(((org.aspectj.weaver.patterns.OrPointcut) pointcut)
  806. .getRight());
  807. ((org.aspectj.org.eclipse.jdt.core.dom.OrPointcut) pointcutDesi).setLeft(left);
  808. ((org.aspectj.org.eclipse.jdt.core.dom.OrPointcut) pointcutDesi).setRight(right);
  809. } else {
  810. // ajh02: default stub until I make all the concrete PointcutDesignator types
  811. pointcutDesi = new org.aspectj.org.eclipse.jdt.core.dom.DefaultPointcut(this.ast, pointcut.toString());
  812. }
  813. pointcutDesi.setSourceRange(pointcut.getStart(), (pointcut.getEnd() - pointcut.getStart() + 1));
  814. return pointcutDesi;
  815. }
  816. public org.aspectj.org.eclipse.jdt.core.dom.SignaturePattern convertSignature(ISignaturePattern patternNode) {
  817. org.aspectj.org.eclipse.jdt.core.dom.SignaturePattern pNode = null;
  818. if (patternNode instanceof SignaturePattern) {
  819. SignaturePattern sigPat = (SignaturePattern) patternNode;
  820. pNode = new org.aspectj.org.eclipse.jdt.core.dom.SignaturePattern(this.ast, sigPat.toString());
  821. pNode.setSourceRange(sigPat.getStart(), (sigPat.getEnd() - sigPat.getStart() + 1));
  822. } else {
  823. throw new IllegalStateException("Not yet implemented for " + patternNode.getClass());
  824. }
  825. return pNode;
  826. }
  827. public org.aspectj.org.eclipse.jdt.core.dom.PatternNode convert(
  828. PatternNode patternNode) {
  829. org.aspectj.org.eclipse.jdt.core.dom.PatternNode pNode = null;
  830. if (patternNode instanceof TypePattern) {
  831. TypePattern weaverTypePattern = (TypePattern) patternNode;
  832. return convert(weaverTypePattern);
  833. } else if (patternNode instanceof SignaturePattern) {
  834. SignaturePattern sigPat = (SignaturePattern) patternNode;
  835. pNode = new org.aspectj.org.eclipse.jdt.core.dom.SignaturePattern(this.ast, sigPat.toString());
  836. pNode.setSourceRange(sigPat.getStart(), (sigPat.getEnd() - sigPat.getStart() + 1));
  837. }
  838. return pNode;
  839. }
  840. public org.aspectj.org.eclipse.jdt.core.dom.TypePattern convert(
  841. TypePattern weaverNode) {
  842. // First check if the node is a Java type (WildType, ExactType,
  843. // BindingType)
  844. org.aspectj.org.eclipse.jdt.core.dom.TypePattern domNode = createIdentifierTypePattern(weaverNode);
  845. if (domNode == null) {
  846. if (weaverNode instanceof org.aspectj.weaver.patterns.EllipsisTypePattern) {
  847. domNode = new org.aspectj.org.eclipse.jdt.core.dom.EllipsisTypePattern(
  848. ast);
  849. } else if (weaverNode instanceof org.aspectj.weaver.patterns.NoTypePattern) {
  850. domNode = new org.aspectj.org.eclipse.jdt.core.dom.NoTypePattern(
  851. ast);
  852. } else if (weaverNode instanceof org.aspectj.weaver.patterns.AnyTypePattern) {
  853. domNode = new org.aspectj.org.eclipse.jdt.core.dom.AnyTypePattern(
  854. ast);
  855. } else if (weaverNode instanceof org.aspectj.weaver.patterns.AnyWithAnnotationTypePattern) {
  856. // For now construct the node with just the annotation
  857. // expression
  858. String annotationExpression = ((org.aspectj.weaver.patterns.AnyWithAnnotationTypePattern) weaverNode)
  859. .toString();
  860. domNode = new org.aspectj.org.eclipse.jdt.core.dom.AnyWithAnnotationTypePattern(
  861. ast, annotationExpression);
  862. } else if (weaverNode instanceof org.aspectj.weaver.patterns.OrTypePattern) {
  863. org.aspectj.weaver.patterns.OrTypePattern compilerOrNode = (org.aspectj.weaver.patterns.OrTypePattern) weaverNode;
  864. domNode = new OrTypePattern(this.ast,
  865. convert(compilerOrNode.getLeft()),
  866. convert(compilerOrNode.getRight()));
  867. } else if (weaverNode instanceof org.aspectj.weaver.patterns.AndTypePattern) {
  868. org.aspectj.weaver.patterns.AndTypePattern compilerAndType = (org.aspectj.weaver.patterns.AndTypePattern) weaverNode;
  869. domNode = new org.aspectj.org.eclipse.jdt.core.dom.AndTypePattern(
  870. this.ast, convert(compilerAndType.getLeft()),
  871. convert(compilerAndType.getRight()));
  872. } else if (weaverNode instanceof org.aspectj.weaver.patterns.NotTypePattern) {
  873. //NOTE: the source range for not type patterns is the source range of the negated type pattern
  874. // EXCLUDING the "!" character. Example: !A. If A starts at 1, the source starting point for the
  875. // nottypepattern is 1, NOT 0.
  876. TypePattern negatedTypePattern = ((org.aspectj.weaver.patterns.NotTypePattern) weaverNode)
  877. .getNegatedPattern();
  878. org.aspectj.org.eclipse.jdt.core.dom.TypePattern negatedDomTypePattern = convert(negatedTypePattern);
  879. domNode = new org.aspectj.org.eclipse.jdt.core.dom.NotTypePattern(
  880. ast, negatedDomTypePattern);
  881. } else if (weaverNode instanceof org.aspectj.weaver.patterns.TypeCategoryTypePattern) {
  882. org.aspectj.weaver.patterns.TypeCategoryTypePattern typeCategoryWeaverNode = (org.aspectj.weaver.patterns.TypeCategoryTypePattern) weaverNode;
  883. domNode = new org.aspectj.org.eclipse.jdt.core.dom.TypeCategoryTypePattern(
  884. ast, typeCategoryWeaverNode.getTypeCategory());
  885. } else if (weaverNode instanceof org.aspectj.weaver.patterns.HasMemberTypePattern) {
  886. ISignaturePattern weaverSignature = ((org.aspectj.weaver.patterns.HasMemberTypePattern) weaverNode)
  887. .getSignaturePattern();
  888. org.aspectj.org.eclipse.jdt.core.dom.SignaturePattern signature = convertSignature(weaverSignature);
  889. domNode = new org.aspectj.org.eclipse.jdt.core.dom.HasMemberTypePattern(
  890. ast, signature);
  891. } else {
  892. // Handle any cases that are not yet implemented. Create a
  893. // default node for
  894. // them.
  895. domNode = new DefaultTypePattern(this.ast,
  896. weaverNode.toString());
  897. }
  898. }
  899. if (domNode != null) {
  900. domNode.setSourceRange(weaverNode.getStart(), (weaverNode.getEnd()
  901. - weaverNode.getStart() + 1));
  902. }
  903. return domNode;
  904. }
  905. /**
  906. * Creates an ExactType, WildType, or BindingType, or null if none of the
  907. * three can be created
  908. *
  909. * @param weaverTypePattern
  910. * to convert to a DOM equivalent
  911. * @return DOM node or null if it was not created
  912. */
  913. protected org.aspectj.org.eclipse.jdt.core.dom.TypePattern createIdentifierTypePattern(
  914. TypePattern weaverTypePattern) {
  915. String typeExpression = weaverTypePattern.toString();
  916. org.aspectj.org.eclipse.jdt.core.dom.TypePattern domTypePattern = null;
  917. if (weaverTypePattern instanceof org.aspectj.weaver.patterns.WildTypePattern) {
  918. // Use the expression for wild type patterns as a Name may not be
  919. // constructed
  920. // for a Type with a unresolved typeExpression
  921. domTypePattern = new org.aspectj.org.eclipse.jdt.core.dom.WildTypePattern(
  922. ast, typeExpression);
  923. } else {
  924. // TODO: At this point, the type pattern should be resolved. Type
  925. // information
  926. // may be able to be obtained from the exact type in the weaver
  927. // pattern, therefore
  928. // replace using the expression to construct the Type and use more
  929. // appropriate
  930. // information obtained from the exact type
  931. if (weaverTypePattern instanceof org.aspectj.weaver.patterns.ExactTypePattern) {
  932. Type type = this.ast.newSimpleType(this.ast
  933. .newSimpleName(typeExpression));
  934. domTypePattern = new ExactTypePattern(ast, type);
  935. } else if (weaverTypePattern instanceof org.aspectj.weaver.patterns.BindingTypePattern) {
  936. Type type = this.ast.newSimpleType(this.ast
  937. .newSimpleName(typeExpression));
  938. String binding = ((org.aspectj.weaver.patterns.BindingTypePattern) weaverTypePattern)
  939. .getBindingName();
  940. FormalBinding formalBinding = new FormalBinding(type, binding,
  941. ast);
  942. domTypePattern = new org.aspectj.org.eclipse.jdt.core.dom.BindingTypePattern(
  943. ast, formalBinding);
  944. }
  945. }
  946. return domTypePattern;
  947. }
  948. public ASTNode convert(
  949. org.aspectj.org.eclipse.jdt.internal.compiler.ast.AnnotationMethodDeclaration annotationTypeMemberDeclaration) {
  950. checkCanceled();
  951. if (this.ast.apiLevel == AST.JLS2_INTERNAL) {
  952. return null;
  953. }
  954. AnnotationTypeMemberDeclaration annotationTypeMemberDeclaration2 = new AnnotationTypeMemberDeclaration(this.ast);
  955. setModifiers(annotationTypeMemberDeclaration2, annotationTypeMemberDeclaration);
  956. final SimpleName methodName = new SimpleName(this.ast);
  957. methodName.internalSetIdentifier(new String(annotationTypeMemberDeclaration.selector));
  958. int start = annotationTypeMemberDeclaration.sourceStart;
  959. int end = retrieveIdentifierEndPosition(start, annotationTypeMemberDeclaration.sourceEnd);
  960. methodName.setSourceRange(start, end - start + 1);
  961. annotationTypeMemberDeclaration2.setName(methodName);
  962. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeReference = annotationTypeMemberDeclaration.returnType;
  963. if (typeReference != null) {
  964. Type returnType = convertType(typeReference);
  965. setTypeForMethodDeclaration(annotationTypeMemberDeclaration2, returnType, 0);
  966. }
  967. int declarationSourceStart = annotationTypeMemberDeclaration.declarationSourceStart;
  968. int declarationSourceEnd = annotationTypeMemberDeclaration.bodyEnd;
  969. annotationTypeMemberDeclaration2.setSourceRange(declarationSourceStart, declarationSourceEnd - declarationSourceStart + 1);
  970. // The javadoc comment is now got from list store in compilation unit declaration
  971. convert(annotationTypeMemberDeclaration.javadoc, annotationTypeMemberDeclaration2);
  972. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression memberValue = annotationTypeMemberDeclaration.defaultValue;
  973. if (memberValue != null) {
  974. annotationTypeMemberDeclaration2.setDefault(super.convert(memberValue));
  975. }
  976. if (this.resolveBindings) {
  977. recordNodes(annotationTypeMemberDeclaration2, annotationTypeMemberDeclaration);
  978. recordNodes(methodName, annotationTypeMemberDeclaration);
  979. annotationTypeMemberDeclaration2.resolveBinding();
  980. }
  981. return annotationTypeMemberDeclaration2;
  982. }
  983. public SingleVariableDeclaration convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument argument) {
  984. SingleVariableDeclaration variableDecl = new SingleVariableDeclaration(this.ast);
  985. setModifiers(variableDecl, argument);
  986. final SimpleName name = new SimpleName(this.ast);
  987. name.internalSetIdentifier(new String(argument.name));
  988. int start = argument.sourceStart;
  989. int nameEnd = argument.sourceEnd;
  990. name.setSourceRange(start, nameEnd - start + 1);
  991. variableDecl.setName(name);
  992. final int typeSourceEnd = argument.type.sourceEnd;
  993. final int extraDimensions = retrieveExtraDimension(nameEnd + 1, typeSourceEnd);
  994. variableDecl.setExtraDimensions(extraDimensions);
  995. final boolean isVarArgs = argument.isVarArgs();
  996. if (isVarArgs && extraDimensions == 0) {
  997. // remove the ellipsis from the type source end
  998. argument.type.sourceEnd = retrieveEllipsisStartPosition(argument.type.sourceStart, typeSourceEnd);
  999. }
  1000. Type type = convertType(argument.type);
  1001. int typeEnd = type.getStartPosition() + type.getLength() - 1;
  1002. int rightEnd = Math.max(typeEnd, argument.declarationSourceEnd);
  1003. /*
  1004. * There is extra work to do to set the proper type positions See PR http://bugs.eclipse.org/bugs/show_bug.cgi?id=23284
  1005. */
  1006. if (isVarArgs) {
  1007. setTypeForSingleVariableDeclaration(variableDecl, type, extraDimensions + 1);
  1008. if (extraDimensions != 0) {
  1009. variableDecl.setFlags(variableDecl.getFlags() | ASTNode.MALFORMED);
  1010. }
  1011. } else {
  1012. setTypeForSingleVariableDeclaration(variableDecl, type, extraDimensions);
  1013. }
  1014. variableDecl.setSourceRange(argument.declarationSourceStart, rightEnd - argument.declarationSourceStart + 1);
  1015. if (isVarArgs) {
  1016. switch (this.ast.apiLevel) {
  1017. case AST.JLS2_INTERNAL:
  1018. variableDecl.setFlags(variableDecl.getFlags() | ASTNode.MALFORMED);
  1019. break;
  1020. case AST.JLS3:
  1021. variableDecl.setVarargs(true);
  1022. }
  1023. }
  1024. if (this.resolveBindings) {
  1025. recordNodes(name, argument);
  1026. recordNodes(variableDecl, argument);
  1027. variableDecl.resolveBinding();
  1028. }
  1029. return variableDecl;
  1030. }
  1031. // public Annotation convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation annotation) {
  1032. // if (annotation instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.SingleMemberAnnotation) {
  1033. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.SingleMemberAnnotation) annotation);
  1034. // } else if (annotation instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.MarkerAnnotation) {
  1035. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.MarkerAnnotation ma =
  1036. // (org.aspectj.org.eclipse.jdt.internal.compiler.ast.MarkerAnnotation) annotation;
  1037. // return convert( ma);//(org.aspectj.org.eclipse.jdt.internal.compiler.ast.MarkerAnnotation) annotation);
  1038. // } else {
  1039. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.NormalAnnotation) annotation);
  1040. // }
  1041. // }
  1042. // public ArrayCreation convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayAllocationExpression expression) {
  1043. // ArrayCreation arrayCreation = new ArrayCreation(this.ast);
  1044. // if (this.resolveBindings) {
  1045. // recordNodes(arrayCreation, expression);
  1046. // }
  1047. // arrayCreation.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1048. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression[] dimensions = expression.dimensions;
  1049. //
  1050. // int dimensionsLength = dimensions.length;
  1051. // for (int i = 0; i < dimensionsLength; i++) {
  1052. // if (dimensions[i] != null) {
  1053. // Expression dimension = convert(dimensions[i]);
  1054. // if (this.resolveBindings) {
  1055. // recordNodes(dimension, dimensions[i]);
  1056. // }
  1057. // arrayCreation.dimensions().add(dimension);
  1058. // }
  1059. // }
  1060. // Type type = convertType(expression.type);
  1061. // if (this.resolveBindings) {
  1062. // recordNodes(type, expression.type);
  1063. // }
  1064. // ArrayType arrayType = null;
  1065. // if (type.isArrayType()) {
  1066. // arrayType = (ArrayType) type;
  1067. // } else {
  1068. // arrayType = this.ast.newArrayType(type, dimensionsLength);
  1069. // if (this.resolveBindings) {
  1070. // completeRecord(arrayType, expression);
  1071. // }
  1072. // int start = type.getStartPosition();
  1073. // int end = type.getStartPosition() + type.getLength();
  1074. // int previousSearchStart = end;
  1075. // ArrayType componentType = (ArrayType) type.getParent();
  1076. // for (int i = 0; i < dimensionsLength; i++) {
  1077. // previousSearchStart = retrieveRightBracketPosition(previousSearchStart + 1, this.compilationUnitSourceLength);
  1078. // componentType.setSourceRange(start, previousSearchStart - start + 1);
  1079. // componentType = (ArrayType) componentType.getParent();
  1080. // }
  1081. // }
  1082. // arrayCreation.setType(arrayType);
  1083. // if (this.resolveBindings) {
  1084. // recordNodes(arrayType, expression);
  1085. // }
  1086. // if (expression.initializer != null) {
  1087. // arrayCreation.setInitializer(convert(expression.initializer));
  1088. // }
  1089. // return arrayCreation;
  1090. // }
  1091. public ArrayInitializer convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayInitializer expression) {
  1092. ArrayInitializer arrayInitializer = new ArrayInitializer(this.ast);
  1093. if (this.resolveBindings) {
  1094. recordNodes(arrayInitializer, expression);
  1095. }
  1096. arrayInitializer.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1097. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression[] expressions = expression.expressions;
  1098. if (expressions != null) {
  1099. int length = expressions.length;
  1100. for (int i = 0; i < length; i++) {
  1101. Expression expr = super.convert(expressions[i]);
  1102. if (this.resolveBindings) {
  1103. recordNodes(expr, expressions[i]);
  1104. }
  1105. arrayInitializer.expressions().add(expr);
  1106. }
  1107. }
  1108. return arrayInitializer;
  1109. }
  1110. // public ArrayAccess convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayReference reference) {
  1111. // ArrayAccess arrayAccess = new ArrayAccess(this.ast);
  1112. // if (this.resolveBindings) {
  1113. // recordNodes(arrayAccess, reference);
  1114. // }
  1115. // arrayAccess.setSourceRange(reference.sourceStart, reference.sourceEnd - reference.sourceStart + 1);
  1116. // arrayAccess.setArray(convert(reference.receiver));
  1117. // arrayAccess.setIndex(convert(reference.position));
  1118. // return arrayAccess;
  1119. // }
  1120. // public AssertStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.AssertStatement statement) {
  1121. // AssertStatement assertStatement = new AssertStatement(this.ast);
  1122. // int end = statement.assertExpression.sourceEnd + 1;
  1123. // assertStatement.setExpression(convert(statement.assertExpression));
  1124. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression exceptionArgument = statement.exceptionArgument;
  1125. // if (exceptionArgument != null) {
  1126. // end = exceptionArgument.sourceEnd + 1;
  1127. // assertStatement.setMessage(convert(exceptionArgument));
  1128. // }
  1129. // int start = statement.sourceStart;
  1130. // int sourceEnd = retrieveEndingSemiColonPosition(end, this.compilationUnitSourceLength);
  1131. // assertStatement.setSourceRange(start, sourceEnd - start + 1);
  1132. // return assertStatement;
  1133. // }
  1134. // public Assignment convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Assignment expression) {
  1135. // Assignment assignment = new Assignment(this.ast);
  1136. // if (this.resolveBindings) {
  1137. // recordNodes(assignment, expression);
  1138. // }
  1139. // Expression lhs = convert(expression.lhs);
  1140. // assignment.setLeftHandSide(lhs);
  1141. // assignment.setOperator(Assignment.Operator.ASSIGN);
  1142. // assignment.setRightHandSide(convert(expression.expression));
  1143. // int start = lhs.getStartPosition();
  1144. // assignment.setSourceRange(start, expression.sourceEnd - start + 1);
  1145. // return assignment;
  1146. // }
  1147. /*
  1148. * Internal use only Used to convert class body declarations
  1149. */
  1150. // public TypeDeclaration convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode[] nodes) {
  1151. // final TypeDeclaration typeDecl = TypeDeclaration.getTypeDeclaration(this.ast);
  1152. // typeDecl.setInterface(false);
  1153. // int nodesLength = nodes.length;
  1154. // for (int i = 0; i < nodesLength; i++) {
  1155. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode node = nodes[i];
  1156. // if (node instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.Initializer) {
  1157. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Initializer oldInitializer = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.Initializer) node;
  1158. // Initializer initializer = new Initializer(this.ast);
  1159. // initializer.setBody(convert(oldInitializer.block));
  1160. // setModifiers(initializer, oldInitializer);
  1161. // initializer.setSourceRange(oldInitializer.declarationSourceStart, oldInitializer.sourceEnd
  1162. // - oldInitializer.declarationSourceStart + 1);
  1163. // // setJavaDocComment(initializer);
  1164. // // initializer.setJavadoc(convert(oldInitializer.javadoc));
  1165. // convert(oldInitializer.javadoc, initializer);
  1166. // typeDecl.bodyDeclarations().add(initializer);
  1167. // } else if (node instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration) {
  1168. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration fieldDeclaration = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration) node;
  1169. // if (i > 0
  1170. // && (nodes[i - 1] instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration)
  1171. // && ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration) nodes[i - 1]).declarationSourceStart == fieldDeclaration.declarationSourceStart) {
  1172. // // we have a multiple field declaration
  1173. // // We retrieve the existing fieldDeclaration to add the new VariableDeclarationFragment
  1174. // FieldDeclaration currentFieldDeclaration = (FieldDeclaration) typeDecl.bodyDeclarations().get(
  1175. // typeDecl.bodyDeclarations().size() - 1);
  1176. // currentFieldDeclaration.fragments().add(convertToVariableDeclarationFragment(fieldDeclaration));
  1177. // } else {
  1178. // // we can create a new FieldDeclaration
  1179. // typeDecl.bodyDeclarations().add(convertToFieldDeclaration(fieldDeclaration));
  1180. // }
  1181. // } else if (node instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.AbstractMethodDeclaration) {
  1182. // AbstractMethodDeclaration nextMethodDeclaration = (AbstractMethodDeclaration) node;
  1183. // if (!nextMethodDeclaration.isDefaultConstructor() && !nextMethodDeclaration.isClinit()) {
  1184. // typeDecl.bodyDeclarations().add(convert(nextMethodDeclaration));
  1185. // }
  1186. // } else if (node instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration) {
  1187. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration nextMemberDeclaration = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration) node;
  1188. // ASTNode nextMemberDeclarationNode = convert(nextMemberDeclaration);
  1189. // if (nextMemberDeclarationNode == null) {
  1190. // typeDecl.setFlags(typeDecl.getFlags() | ASTNode.MALFORMED);
  1191. // } else {
  1192. // typeDecl.bodyDeclarations().add(nextMemberDeclarationNode);
  1193. // }
  1194. // }
  1195. // }
  1196. // return typeDecl;
  1197. // }
  1198. // public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression expression) {
  1199. // InfixExpression infixExpression = new InfixExpression(this.ast);
  1200. // if (this.resolveBindings) {
  1201. // this.recordNodes(infixExpression, expression);
  1202. // }
  1203. //
  1204. // int expressionOperatorID = (expression.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.OperatorMASK) >>
  1205. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.OperatorSHIFT;
  1206. // switch (expressionOperatorID) {
  1207. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.EQUAL_EQUAL :
  1208. // infixExpression.setOperator(InfixExpression.Operator.EQUALS);
  1209. // break;
  1210. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.LESS_EQUAL :
  1211. // infixExpression.setOperator(InfixExpression.Operator.LESS_EQUALS);
  1212. // break;
  1213. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.GREATER_EQUAL :
  1214. // infixExpression.setOperator(InfixExpression.Operator.GREATER_EQUALS);
  1215. // break;
  1216. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.NOT_EQUAL :
  1217. // infixExpression.setOperator(InfixExpression.Operator.NOT_EQUALS);
  1218. // break;
  1219. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.LEFT_SHIFT :
  1220. // infixExpression.setOperator(InfixExpression.Operator.LEFT_SHIFT);
  1221. // break;
  1222. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.RIGHT_SHIFT :
  1223. // infixExpression.setOperator(InfixExpression.Operator.RIGHT_SHIFT_SIGNED);
  1224. // break;
  1225. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.UNSIGNED_RIGHT_SHIFT :
  1226. // infixExpression.setOperator(InfixExpression.Operator.RIGHT_SHIFT_UNSIGNED);
  1227. // break;
  1228. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.OR_OR :
  1229. // infixExpression.setOperator(InfixExpression.Operator.CONDITIONAL_OR);
  1230. // break;
  1231. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.AND_AND :
  1232. // infixExpression.setOperator(InfixExpression.Operator.CONDITIONAL_AND);
  1233. // break;
  1234. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.PLUS :
  1235. // infixExpression.setOperator(InfixExpression.Operator.PLUS);
  1236. // break;
  1237. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MINUS :
  1238. // infixExpression.setOperator(InfixExpression.Operator.MINUS);
  1239. // break;
  1240. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.REMAINDER :
  1241. // infixExpression.setOperator(InfixExpression.Operator.REMAINDER);
  1242. // break;
  1243. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.XOR :
  1244. // infixExpression.setOperator(InfixExpression.Operator.XOR);
  1245. // break;
  1246. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.AND :
  1247. // infixExpression.setOperator(InfixExpression.Operator.AND);
  1248. // break;
  1249. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MULTIPLY :
  1250. // infixExpression.setOperator(InfixExpression.Operator.TIMES);
  1251. // break;
  1252. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.OR :
  1253. // infixExpression.setOperator(InfixExpression.Operator.OR);
  1254. // break;
  1255. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.DIVIDE :
  1256. // infixExpression.setOperator(InfixExpression.Operator.DIVIDE);
  1257. // break;
  1258. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.GREATER :
  1259. // infixExpression.setOperator(InfixExpression.Operator.GREATER);
  1260. // break;
  1261. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.LESS :
  1262. // infixExpression.setOperator(InfixExpression.Operator.LESS);
  1263. // }
  1264. //
  1265. // if (expression.left instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression
  1266. // && ((expression.left.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK) == 0)) {
  1267. // // create an extended string literal equivalent => use the extended operands list
  1268. // infixExpression.extendedOperands().add(convert(expression.right));
  1269. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression leftOperand = expression.left;
  1270. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression rightOperand = null;
  1271. // do {
  1272. // rightOperand = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression) leftOperand).right;
  1273. // if ((((leftOperand.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.OperatorMASK) >>
  1274. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.OperatorSHIFT) != expressionOperatorID
  1275. // && ((leftOperand.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK) == 0))
  1276. // || ((rightOperand instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression
  1277. // && ((rightOperand.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.OperatorMASK) >>
  1278. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.OperatorSHIFT) != expressionOperatorID)
  1279. // && ((rightOperand.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK) == 0))) {
  1280. // List extendedOperands = infixExpression.extendedOperands();
  1281. // InfixExpression temp = new InfixExpression(this.ast);
  1282. // if (this.resolveBindings) {
  1283. // this.recordNodes(temp, expression);
  1284. // }
  1285. // temp.setOperator(getOperatorFor(expressionOperatorID));
  1286. // Expression leftSide = convert(leftOperand);
  1287. // temp.setLeftOperand(leftSide);
  1288. // temp.setSourceRange(leftSide.getStartPosition(), leftSide.getLength());
  1289. // int size = extendedOperands.size();
  1290. // for (int i = 0; i < size - 1; i++) {
  1291. // Expression expr = temp;
  1292. // temp = new InfixExpression(this.ast);
  1293. //
  1294. // if (this.resolveBindings) {
  1295. // this.recordNodes(temp, expression);
  1296. // }
  1297. // temp.setLeftOperand(expr);
  1298. // temp.setOperator(getOperatorFor(expressionOperatorID));
  1299. // temp.setSourceRange(expr.getStartPosition(), expr.getLength());
  1300. // }
  1301. // infixExpression = temp;
  1302. // for (int i = 0; i < size; i++) {
  1303. // Expression extendedOperand = (Expression) extendedOperands.remove(size - 1 - i);
  1304. // temp.setRightOperand(extendedOperand);
  1305. // int startPosition = temp.getLeftOperand().getStartPosition();
  1306. // temp.setSourceRange(startPosition, extendedOperand.getStartPosition() + extendedOperand.getLength() - startPosition);
  1307. // if (temp.getLeftOperand().getNodeType() == ASTNode.INFIX_EXPRESSION) {
  1308. // temp = (InfixExpression) temp.getLeftOperand();
  1309. // }
  1310. // }
  1311. // int startPosition = infixExpression.getLeftOperand().getStartPosition();
  1312. // infixExpression.setSourceRange(startPosition, expression.sourceEnd - startPosition + 1);
  1313. // if (this.resolveBindings) {
  1314. // this.recordNodes(infixExpression, expression);
  1315. // }
  1316. // return infixExpression;
  1317. // }
  1318. // infixExpression.extendedOperands().add(0, convert(rightOperand));
  1319. // leftOperand = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression) leftOperand).left;
  1320. // } while (leftOperand instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression && ((leftOperand.bits &
  1321. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK) == 0));
  1322. // Expression leftExpression = convert(leftOperand);
  1323. // infixExpression.setLeftOperand(leftExpression);
  1324. // infixExpression.setRightOperand((Expression)infixExpression.extendedOperands().remove(0));
  1325. // int startPosition = leftExpression.getStartPosition();
  1326. // infixExpression.setSourceRange(startPosition, expression.sourceEnd - startPosition + 1);
  1327. // return infixExpression;
  1328. // } else if (expression.left instanceof StringLiteralConcatenation
  1329. // && ((expression.left.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK) == 0)) {
  1330. // StringLiteralConcatenation literal = (StringLiteralConcatenation) expression.left;
  1331. // final org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression[] stringLiterals = literal.literals;
  1332. // infixExpression.setLeftOperand(convert(stringLiterals[0]));
  1333. // infixExpression.setRightOperand(convert(stringLiterals[1]));
  1334. // for (int i = 2; i < literal.counter; i++) {
  1335. // infixExpression.extendedOperands().add(convert(stringLiterals[i]));
  1336. // }
  1337. // infixExpression.extendedOperands().add(convert(expression.right));
  1338. // int startPosition = literal.sourceStart;
  1339. // infixExpression.setSourceRange(startPosition, expression.sourceEnd - startPosition + 1);
  1340. // return infixExpression;
  1341. // }
  1342. // Expression leftExpression = convert(expression.left);
  1343. // infixExpression.setLeftOperand(leftExpression);
  1344. // infixExpression.setRightOperand(convert(expression.right));
  1345. // int startPosition = leftExpression.getStartPosition();
  1346. // infixExpression.setSourceRange(startPosition, expression.sourceEnd - startPosition + 1);
  1347. // return infixExpression;
  1348. // }
  1349. public Block convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Block statement) {
  1350. Block block = new Block(this.ast);
  1351. if (statement.sourceEnd > 0) {
  1352. block.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  1353. }
  1354. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement[] statements = statement.statements;
  1355. if (statements != null) {
  1356. int statementsLength = statements.length;
  1357. for (int i = 0; i < statementsLength; i++) {
  1358. if (statements[i] instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) {
  1359. checkAndAddMultipleLocalDeclaration(statements, i, block.statements());
  1360. } else {
  1361. block.statements().add(convert(statements[i]));
  1362. }
  1363. }
  1364. }
  1365. return block;
  1366. }
  1367. public BreakStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.BreakStatement statement) {
  1368. BreakStatement breakStatement = new BreakStatement(this.ast);
  1369. breakStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  1370. if (statement.label != null) {
  1371. final SimpleName name = new SimpleName(this.ast);
  1372. name.internalSetIdentifier(new String(statement.label));
  1373. retrieveIdentifierAndSetPositions(statement.sourceStart, statement.sourceEnd, name);
  1374. breakStatement.setLabel(name);
  1375. }
  1376. retrieveSemiColonPosition(breakStatement);
  1377. return breakStatement;
  1378. }
  1379. // public SwitchCase convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.CaseStatement statement) {
  1380. // SwitchCase switchCase = new SwitchCase(this.ast);
  1381. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression constantExpression = statement.constantExpression;
  1382. // if (constantExpression == null) {
  1383. // switchCase.setExpression(null);
  1384. // } else {
  1385. // switchCase.setExpression(convert(constantExpression));
  1386. // }
  1387. // switchCase.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  1388. // retrieveColonPosition(switchCase);
  1389. // return switchCase;
  1390. // }
  1391. // public CastExpression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.CastExpression expression) {
  1392. // CastExpression castExpression = new CastExpression(this.ast);
  1393. // castExpression.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1394. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression type = expression.type;
  1395. // trimWhiteSpacesAndComments(type);
  1396. // if (type instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference ) {
  1397. // castExpression.setType(convertType((org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference)type));
  1398. // } else if (type instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.NameReference) {
  1399. // castExpression.setType(convertToType((org.aspectj.org.eclipse.jdt.internal.compiler.ast.NameReference)type));
  1400. // }
  1401. // castExpression.setExpression(convert(expression.expression));
  1402. // if (this.resolveBindings) {
  1403. // recordNodes(castExpression, expression);
  1404. // }
  1405. // return castExpression;
  1406. // }
  1407. public CharacterLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.CharLiteral expression) {
  1408. int length = expression.sourceEnd - expression.sourceStart + 1;
  1409. int sourceStart = expression.sourceStart;
  1410. CharacterLiteral literal = new CharacterLiteral(this.ast);
  1411. if (this.resolveBindings) {
  1412. this.recordNodes(literal, expression);
  1413. }
  1414. literal.internalSetEscapedValue(new String(this.compilationUnitSource, sourceStart, length));
  1415. literal.setSourceRange(sourceStart, length);
  1416. removeLeadingAndTrailingCommentsFromLiteral(literal);
  1417. return literal;
  1418. }
  1419. public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ClassLiteralAccess expression) {
  1420. TypeLiteral typeLiteral = new TypeLiteral(this.ast);
  1421. if (this.resolveBindings) {
  1422. this.recordNodes(typeLiteral, expression);
  1423. }
  1424. typeLiteral.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1425. typeLiteral.setType(convertType(expression.type));
  1426. return typeLiteral;
  1427. }
  1428. public CompilationUnit convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.CompilationUnitDeclaration unit, char[] source) {
  1429. this.compilationUnitSource = source;
  1430. this.compilationUnitSourceLength = source.length;
  1431. this.scanner.setSource(source, unit.compilationResult);
  1432. CompilationUnit compilationUnit = new CompilationUnit(this.ast);
  1433. // Parse comments
  1434. int[][] comments = unit.comments;
  1435. if (comments != null) {
  1436. buildCommentsTable(compilationUnit, comments);
  1437. }
  1438. // handle the package declaration immediately
  1439. // There is no node corresponding to the package declaration
  1440. if (this.resolveBindings) {
  1441. recordNodes(compilationUnit, unit);
  1442. }
  1443. if (unit.currentPackage != null) {
  1444. PackageDeclaration packageDeclaration = convertPackage(unit);
  1445. compilationUnit.setPackage(packageDeclaration);
  1446. }
  1447. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ImportReference[] imports = unit.imports;
  1448. if (imports != null) {
  1449. int importLength = imports.length;
  1450. for (int i = 0; i < importLength; i++) {
  1451. compilationUnit.imports().add(convertImport(imports[i]));
  1452. }
  1453. }
  1454. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration[] types = unit.types;
  1455. if (types != null) {
  1456. int typesLength = types.length;
  1457. for (int i = 0; i < typesLength; i++) {
  1458. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration declaration = types[i];
  1459. if (CharOperation.equals(declaration.name, TypeConstants.PACKAGE_INFO_NAME)) {
  1460. continue;
  1461. }
  1462. ASTNode type = convert(declaration);
  1463. if (type == null) {
  1464. compilationUnit.setFlags(compilationUnit.getFlags() | ASTNode.MALFORMED);
  1465. } else {
  1466. compilationUnit.types().add(type);
  1467. }
  1468. }
  1469. }
  1470. compilationUnit.setSourceRange(unit.sourceStart, unit.sourceEnd - unit.sourceStart + 1);
  1471. int problemLength = unit.compilationResult.problemCount;
  1472. if (problemLength != 0) {
  1473. CategorizedProblem[] resizedProblems = null;
  1474. final CategorizedProblem[] problems = unit.compilationResult.getProblems();
  1475. final int realProblemLength = problems.length;
  1476. if (realProblemLength == problemLength) {
  1477. resizedProblems = problems;
  1478. } else {
  1479. System.arraycopy(problems, 0, (resizedProblems = new CategorizedProblem[realProblemLength]), 0, realProblemLength);
  1480. }
  1481. ASTSyntaxErrorPropagator syntaxErrorPropagator = new ASTSyntaxErrorPropagator(resizedProblems);
  1482. compilationUnit.accept(syntaxErrorPropagator);
  1483. compilationUnit.setProblems(resizedProblems);
  1484. }
  1485. if (this.resolveBindings) {
  1486. lookupForScopes();
  1487. }
  1488. compilationUnit.initCommentMapper(this.scanner);
  1489. return compilationUnit;
  1490. }
  1491. // public Assignment convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.CompoundAssignment expression) {
  1492. // Assignment assignment = new Assignment(this.ast);
  1493. // Expression lhs = convert(expression.lhs);
  1494. // assignment.setLeftHandSide(lhs);
  1495. // int start = lhs.getStartPosition();
  1496. // assignment.setSourceRange(start, expression.sourceEnd - start + 1);
  1497. // switch (expression.operator) {
  1498. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.PLUS :
  1499. // assignment.setOperator(Assignment.Operator.PLUS_ASSIGN);
  1500. // break;
  1501. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MINUS :
  1502. // assignment.setOperator(Assignment.Operator.MINUS_ASSIGN);
  1503. // break;
  1504. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MULTIPLY :
  1505. // assignment.setOperator(Assignment.Operator.TIMES_ASSIGN);
  1506. // break;
  1507. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.DIVIDE :
  1508. // assignment.setOperator(Assignment.Operator.DIVIDE_ASSIGN);
  1509. // break;
  1510. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.AND :
  1511. // assignment.setOperator(Assignment.Operator.BIT_AND_ASSIGN);
  1512. // break;
  1513. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.OR :
  1514. // assignment.setOperator(Assignment.Operator.BIT_OR_ASSIGN);
  1515. // break;
  1516. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.XOR :
  1517. // assignment.setOperator(Assignment.Operator.BIT_XOR_ASSIGN);
  1518. // break;
  1519. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.REMAINDER :
  1520. // assignment.setOperator(Assignment.Operator.REMAINDER_ASSIGN);
  1521. // break;
  1522. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.LEFT_SHIFT :
  1523. // assignment.setOperator(Assignment.Operator.LEFT_SHIFT_ASSIGN);
  1524. // break;
  1525. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.RIGHT_SHIFT :
  1526. // assignment.setOperator(Assignment.Operator.RIGHT_SHIFT_SIGNED_ASSIGN);
  1527. // break;
  1528. // case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.UNSIGNED_RIGHT_SHIFT :
  1529. // assignment.setOperator(Assignment.Operator.RIGHT_SHIFT_UNSIGNED_ASSIGN);
  1530. // break;
  1531. // }
  1532. // assignment.setRightHandSide(convert(expression.expression));
  1533. // if (this.resolveBindings) {
  1534. // recordNodes(assignment, expression);
  1535. // }
  1536. // return assignment;
  1537. // }
  1538. // public ConditionalExpression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ConditionalExpression expression) {
  1539. // ConditionalExpression conditionalExpression = new ConditionalExpression(this.ast);
  1540. // if (this.resolveBindings) {
  1541. // recordNodes(conditionalExpression, expression);
  1542. // }
  1543. // conditionalExpression.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1544. // conditionalExpression.setExpression(convert(expression.condition));
  1545. // conditionalExpression.setThenExpression(convert(expression.valueIfTrue));
  1546. // conditionalExpression.setElseExpression(convert(expression.valueIfFalse));
  1547. // return conditionalExpression;
  1548. // }
  1549. // public Statement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall statement) {
  1550. // Statement newStatement;
  1551. // int sourceStart = statement.sourceStart;
  1552. // if (statement.isSuperAccess() || statement.isSuper()) {
  1553. // SuperConstructorInvocation superConstructorInvocation = new SuperConstructorInvocation(this.ast);
  1554. // if (statement.qualification != null) {
  1555. // superConstructorInvocation.setExpression(convert(statement.qualification));
  1556. // }
  1557. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression[] arguments = statement.arguments;
  1558. // if (arguments != null) {
  1559. // int length = arguments.length;
  1560. // for (int i = 0; i < length; i++) {
  1561. // superConstructorInvocation.arguments().add(convert(arguments[i]));
  1562. // }
  1563. // }
  1564. // if (statement.typeArguments != null) {
  1565. // if (sourceStart > statement.typeArgumentsSourceStart) {
  1566. // sourceStart = statement.typeArgumentsSourceStart;
  1567. // }
  1568. // switch(this.ast.apiLevel) {
  1569. // case AST.JLS2_INTERNAL :
  1570. // superConstructorInvocation.setFlags(superConstructorInvocation.getFlags() | ASTNode.MALFORMED);
  1571. // break;
  1572. // case AST.JLS3 :
  1573. // for (int i = 0, max = statement.typeArguments.length; i < max; i++) {
  1574. // superConstructorInvocation.typeArguments().add(convertType(statement.typeArguments[i]));
  1575. // }
  1576. // break;
  1577. // }
  1578. // }
  1579. // newStatement = superConstructorInvocation;
  1580. // } else {
  1581. // ConstructorInvocation constructorInvocation = new ConstructorInvocation(this.ast);
  1582. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression[] arguments = statement.arguments;
  1583. // if (arguments != null) {
  1584. // int length = arguments.length;
  1585. // for (int i = 0; i < length; i++) {
  1586. // constructorInvocation.arguments().add(convert(arguments[i]));
  1587. // }
  1588. // }
  1589. // if (statement.typeArguments != null) {
  1590. // if (sourceStart > statement.typeArgumentsSourceStart) {
  1591. // sourceStart = statement.typeArgumentsSourceStart;
  1592. // }
  1593. // switch(this.ast.apiLevel) {
  1594. // case AST.JLS2_INTERNAL :
  1595. // constructorInvocation.setFlags(constructorInvocation.getFlags() | ASTNode.MALFORMED);
  1596. // break;
  1597. // case AST.JLS3 :
  1598. // for (int i = 0, max = statement.typeArguments.length; i < max; i++) {
  1599. // constructorInvocation.typeArguments().add(convertType(statement.typeArguments[i]));
  1600. // }
  1601. // break;
  1602. // }
  1603. // }
  1604. // if (statement.qualification != null) {
  1605. // // this is an error
  1606. // constructorInvocation.setFlags(constructorInvocation.getFlags() | ASTNode.MALFORMED);
  1607. // }
  1608. // newStatement = constructorInvocation;
  1609. // }
  1610. // newStatement.setSourceRange(sourceStart, statement.sourceEnd - sourceStart + 1);
  1611. // retrieveSemiColonPosition(newStatement);
  1612. // if (this.resolveBindings) {
  1613. // recordNodes(newStatement, statement);
  1614. // }
  1615. // return newStatement;
  1616. // }
  1617. // public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression expression) {
  1618. // if ((expression.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK) != 0) {
  1619. // return convertToParenthesizedExpression(expression);
  1620. // }
  1621. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation) {
  1622. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation) expression);
  1623. // }
  1624. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.CastExpression) {
  1625. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.CastExpression) expression);
  1626. // }
  1627. // // switch between all types of expression
  1628. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayAllocationExpression) {
  1629. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayAllocationExpression) expression);
  1630. // }
  1631. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedAllocationExpression) {
  1632. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedAllocationExpression) expression);
  1633. // }
  1634. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.AllocationExpression) {
  1635. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.AllocationExpression) expression);
  1636. // }
  1637. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayInitializer) {
  1638. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayInitializer) expression);
  1639. // }
  1640. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.PrefixExpression) {
  1641. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.PrefixExpression) expression);
  1642. // }
  1643. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.PostfixExpression) {
  1644. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.PostfixExpression) expression);
  1645. // }
  1646. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.CompoundAssignment) {
  1647. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.CompoundAssignment) expression);
  1648. // }
  1649. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.Assignment) {
  1650. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.Assignment) expression);
  1651. // }
  1652. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ClassLiteralAccess) {
  1653. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ClassLiteralAccess) expression);
  1654. // }
  1655. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.FalseLiteral) {
  1656. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.FalseLiteral) expression);
  1657. // }
  1658. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TrueLiteral) {
  1659. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.TrueLiteral) expression);
  1660. // }
  1661. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.NullLiteral) {
  1662. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.NullLiteral) expression);
  1663. // }
  1664. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.CharLiteral) {
  1665. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.CharLiteral) expression);
  1666. // }
  1667. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.DoubleLiteral) {
  1668. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.DoubleLiteral) expression);
  1669. // }
  1670. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.FloatLiteral) {
  1671. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.FloatLiteral) expression);
  1672. // }
  1673. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.IntLiteralMinValue) {
  1674. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.IntLiteralMinValue) expression);
  1675. // }
  1676. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.IntLiteral) {
  1677. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.IntLiteral) expression);
  1678. // }
  1679. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LongLiteralMinValue) {
  1680. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.LongLiteralMinValue) expression);
  1681. // }
  1682. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LongLiteral) {
  1683. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.LongLiteral) expression);
  1684. // }
  1685. // if (expression instanceof StringLiteralConcatenation) {
  1686. // return convert((StringLiteralConcatenation) expression);
  1687. // }
  1688. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExtendedStringLiteral) {
  1689. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExtendedStringLiteral) expression);
  1690. // }
  1691. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.StringLiteral) {
  1692. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.StringLiteral) expression);
  1693. // }
  1694. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.AND_AND_Expression) {
  1695. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.AND_AND_Expression) expression);
  1696. // }
  1697. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.OR_OR_Expression) {
  1698. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.OR_OR_Expression) expression);
  1699. // }
  1700. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.EqualExpression) {
  1701. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.EqualExpression) expression);
  1702. // }
  1703. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression) {
  1704. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.BinaryExpression) expression);
  1705. // }
  1706. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.InstanceOfExpression) {
  1707. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.InstanceOfExpression) expression);
  1708. // }
  1709. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.UnaryExpression) {
  1710. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.UnaryExpression) expression);
  1711. // }
  1712. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ConditionalExpression) {
  1713. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ConditionalExpression) expression);
  1714. // }
  1715. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.MessageSend) {
  1716. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.MessageSend) expression);
  1717. // }
  1718. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.Reference) {
  1719. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.Reference) expression);
  1720. // }
  1721. // if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) {
  1722. // return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) expression);
  1723. // }
  1724. // return null;
  1725. // }
  1726. public StringLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExtendedStringLiteral expression) {
  1727. expression.computeConstant();
  1728. StringLiteral literal = new StringLiteral(this.ast);
  1729. if (this.resolveBindings) {
  1730. this.recordNodes(literal, expression);
  1731. }
  1732. literal.setLiteralValue(expression.constant.stringValue());
  1733. literal.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1734. return literal;
  1735. }
  1736. public BooleanLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.FalseLiteral expression) {
  1737. final BooleanLiteral literal = new BooleanLiteral(this.ast);
  1738. literal.setBooleanValue(false);
  1739. if (this.resolveBindings) {
  1740. this.recordNodes(literal, expression);
  1741. }
  1742. literal.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1743. return literal;
  1744. }
  1745. public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldReference reference) {
  1746. if (reference.receiver.isSuper()) {
  1747. final SuperFieldAccess superFieldAccess = new SuperFieldAccess(this.ast);
  1748. if (this.resolveBindings) {
  1749. recordNodes(superFieldAccess, reference);
  1750. }
  1751. if (reference.receiver instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedSuperReference) {
  1752. Name qualifier = convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedSuperReference) reference.receiver);
  1753. superFieldAccess.setQualifier(qualifier);
  1754. if (this.resolveBindings) {
  1755. recordNodes(qualifier, reference.receiver);
  1756. }
  1757. }
  1758. final SimpleName simpleName = new SimpleName(this.ast);
  1759. simpleName.internalSetIdentifier(new String(reference.token));
  1760. int sourceStart = (int) (reference.nameSourcePosition >>> 32);
  1761. int length = (int) (reference.nameSourcePosition & 0xFFFFFFFF) - sourceStart + 1;
  1762. simpleName.setSourceRange(sourceStart, length);
  1763. superFieldAccess.setName(simpleName);
  1764. if (this.resolveBindings) {
  1765. recordNodes(simpleName, reference);
  1766. }
  1767. superFieldAccess.setSourceRange(reference.receiver.sourceStart, reference.sourceEnd - reference.receiver.sourceStart
  1768. + 1);
  1769. return superFieldAccess;
  1770. } else {
  1771. final FieldAccess fieldAccess = new FieldAccess(this.ast);
  1772. if (this.resolveBindings) {
  1773. recordNodes(fieldAccess, reference);
  1774. }
  1775. Expression receiver = super.convert(reference.receiver);
  1776. fieldAccess.setExpression(receiver);
  1777. final SimpleName simpleName = new SimpleName(this.ast);
  1778. simpleName.internalSetIdentifier(new String(reference.token));
  1779. int sourceStart = (int) (reference.nameSourcePosition >>> 32);
  1780. int length = (int) (reference.nameSourcePosition & 0xFFFFFFFF) - sourceStart + 1;
  1781. simpleName.setSourceRange(sourceStart, length);
  1782. fieldAccess.setName(simpleName);
  1783. if (this.resolveBindings) {
  1784. recordNodes(simpleName, reference);
  1785. }
  1786. fieldAccess.setSourceRange(receiver.getStartPosition(), reference.sourceEnd - receiver.getStartPosition() + 1);
  1787. return fieldAccess;
  1788. }
  1789. }
  1790. public NumberLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.FloatLiteral expression) {
  1791. int length = expression.sourceEnd - expression.sourceStart + 1;
  1792. int sourceStart = expression.sourceStart;
  1793. NumberLiteral literal = new NumberLiteral(this.ast);
  1794. literal.internalSetToken(new String(this.compilationUnitSource, sourceStart, length));
  1795. if (this.resolveBindings) {
  1796. this.recordNodes(literal, expression);
  1797. }
  1798. literal.setSourceRange(sourceStart, length);
  1799. removeLeadingAndTrailingCommentsFromLiteral(literal);
  1800. return literal;
  1801. }
  1802. public Statement convert(ForeachStatement statement) {
  1803. switch (this.ast.apiLevel) {
  1804. case AST.JLS2_INTERNAL:
  1805. return createFakeEmptyStatement(statement);
  1806. case AST.JLS3:
  1807. EnhancedForStatement enhancedForStatement = new EnhancedForStatement(this.ast);
  1808. enhancedForStatement.setParameter(convertToSingleVariableDeclaration(statement.elementVariable));
  1809. enhancedForStatement.setExpression(super.convert(statement.collection));
  1810. enhancedForStatement.setBody(convert(statement.action));
  1811. int start = statement.sourceStart;
  1812. int end = statement.sourceEnd;
  1813. enhancedForStatement.setSourceRange(start, end - start + 1);
  1814. return enhancedForStatement;
  1815. default:
  1816. return createFakeEmptyStatement(statement);
  1817. }
  1818. }
  1819. public ForStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ForStatement statement) {
  1820. ForStatement forStatement = new ForStatement(this.ast);
  1821. forStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  1822. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement[] initializations = statement.initializations;
  1823. if (initializations != null) {
  1824. // we know that we have at least one initialization
  1825. if (initializations[0] instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) {
  1826. VariableDeclarationExpression variableDeclarationExpression = convertToVariableDeclarationExpression((org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) initializations[0]);
  1827. int initializationsLength = initializations.length;
  1828. for (int i = 1; i < initializationsLength; i++) {
  1829. variableDeclarationExpression
  1830. .fragments()
  1831. .add(convertToVariableDeclarationFragment((org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) initializations[i]));
  1832. }
  1833. if (initializationsLength != 1) {
  1834. int start = variableDeclarationExpression.getStartPosition();
  1835. int end = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) initializations[initializationsLength - 1]).declarationSourceEnd;
  1836. variableDeclarationExpression.setSourceRange(start, end - start + 1);
  1837. }
  1838. forStatement.initializers().add(variableDeclarationExpression);
  1839. } else {
  1840. int initializationsLength = initializations.length;
  1841. for (int i = 0; i < initializationsLength; i++) {
  1842. Expression initializer = convertToExpression(initializations[i]);
  1843. if (initializer != null) {
  1844. forStatement.initializers().add(initializer);
  1845. } else {
  1846. forStatement.setFlags(forStatement.getFlags() | ASTNode.MALFORMED);
  1847. }
  1848. }
  1849. }
  1850. }
  1851. if (statement.condition != null) {
  1852. forStatement.setExpression(super.convert(statement.condition));
  1853. }
  1854. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement[] increments = statement.increments;
  1855. if (increments != null) {
  1856. int incrementsLength = increments.length;
  1857. for (int i = 0; i < incrementsLength; i++) {
  1858. forStatement.updaters().add(convertToExpression(increments[i]));
  1859. }
  1860. }
  1861. forStatement.setBody(convert(statement.action));
  1862. return forStatement;
  1863. }
  1864. public IfStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.IfStatement statement) {
  1865. IfStatement ifStatement = new IfStatement(this.ast);
  1866. ifStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  1867. ifStatement.setExpression(super.convert(statement.condition));
  1868. ifStatement.setThenStatement(convert(statement.thenStatement));
  1869. if (statement.elseStatement != null) {
  1870. ifStatement.setElseStatement(convert(statement.elseStatement));
  1871. }
  1872. return ifStatement;
  1873. }
  1874. public InstanceofExpression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.InstanceOfExpression expression) {
  1875. InstanceofExpression instanceOfExpression = new InstanceofExpression(this.ast);
  1876. if (this.resolveBindings) {
  1877. recordNodes(instanceOfExpression, expression);
  1878. }
  1879. Expression leftExpression = super.convert(expression.expression);
  1880. instanceOfExpression.setLeftOperand(leftExpression);
  1881. instanceOfExpression.setRightOperand(convertType(expression.type));
  1882. int startPosition = leftExpression.getStartPosition();
  1883. instanceOfExpression.setSourceRange(startPosition, expression.sourceEnd - startPosition + 1);
  1884. return instanceOfExpression;
  1885. }
  1886. public NumberLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.IntLiteral expression) {
  1887. int length = expression.sourceEnd - expression.sourceStart + 1;
  1888. int sourceStart = expression.sourceStart;
  1889. final NumberLiteral literal = new NumberLiteral(this.ast);
  1890. literal.internalSetToken(new String(this.compilationUnitSource, sourceStart, length));
  1891. if (this.resolveBindings) {
  1892. this.recordNodes(literal, expression);
  1893. }
  1894. literal.setSourceRange(sourceStart, length);
  1895. removeLeadingAndTrailingCommentsFromLiteral(literal);
  1896. return literal;
  1897. }
  1898. public NumberLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.IntLiteralMinValue expression) {
  1899. int length = expression.sourceEnd - expression.sourceStart + 1;
  1900. int sourceStart = expression.sourceStart;
  1901. NumberLiteral literal = new NumberLiteral(this.ast);
  1902. literal.internalSetToken(new String(this.compilationUnitSource, sourceStart, length));
  1903. if (this.resolveBindings) {
  1904. this.recordNodes(literal, expression);
  1905. }
  1906. literal.setSourceRange(sourceStart, length);
  1907. removeLeadingAndTrailingCommentsFromLiteral(literal);
  1908. return literal;
  1909. }
  1910. public void convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Javadoc javadoc, BodyDeclaration bodyDeclaration) {
  1911. if (bodyDeclaration.getJavadoc() == null) {
  1912. if (javadoc != null) {
  1913. if (this.commentMapper == null || !this.commentMapper.hasSameTable(this.commentsTable)) {
  1914. this.commentMapper = new DefaultCommentMapper(this.commentsTable);
  1915. }
  1916. Comment comment = this.commentMapper.getComment(javadoc.sourceStart);
  1917. if (comment != null && comment.isDocComment() && comment.getParent() == null) {
  1918. Javadoc docComment = (Javadoc) comment;
  1919. if (this.resolveBindings) {
  1920. recordNodes(docComment, javadoc);
  1921. // resolve member and method references binding
  1922. Iterator tags = docComment.tags().listIterator();
  1923. while (tags.hasNext()) {
  1924. recordNodes(javadoc, (TagElement) tags.next());
  1925. }
  1926. }
  1927. bodyDeclaration.setJavadoc(docComment);
  1928. }
  1929. }
  1930. }
  1931. }
  1932. public void convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Javadoc javadoc, PackageDeclaration packageDeclaration) {
  1933. if (ast.apiLevel == AST.JLS3 && packageDeclaration.getJavadoc() == null) {
  1934. if (javadoc != null) {
  1935. if (this.commentMapper == null || !this.commentMapper.hasSameTable(this.commentsTable)) {
  1936. this.commentMapper = new DefaultCommentMapper(this.commentsTable);
  1937. }
  1938. Comment comment = this.commentMapper.getComment(javadoc.sourceStart);
  1939. if (comment != null && comment.isDocComment() && comment.getParent() == null) {
  1940. Javadoc docComment = (Javadoc) comment;
  1941. if (this.resolveBindings) {
  1942. recordNodes(docComment, javadoc);
  1943. // resolve member and method references binding
  1944. Iterator tags = docComment.tags().listIterator();
  1945. while (tags.hasNext()) {
  1946. recordNodes(javadoc, (TagElement) tags.next());
  1947. }
  1948. }
  1949. packageDeclaration.setJavadoc(docComment);
  1950. }
  1951. }
  1952. }
  1953. }
  1954. public LabeledStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.LabeledStatement statement) {
  1955. LabeledStatement labeledStatement = new LabeledStatement(this.ast);
  1956. labeledStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  1957. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement body = statement.statement;
  1958. labeledStatement.setBody(convert(body));
  1959. final SimpleName name = new SimpleName(this.ast);
  1960. name.internalSetIdentifier(new String(statement.label));
  1961. retrieveIdentifierAndSetPositions(statement.sourceStart, statement.sourceEnd, name);
  1962. labeledStatement.setLabel(name);
  1963. return labeledStatement;
  1964. }
  1965. public InfixExpression convert(StringLiteralConcatenation expression) {
  1966. expression.computeConstant();
  1967. final InfixExpression infixExpression = new InfixExpression(this.ast);
  1968. infixExpression.setOperator(InfixExpression.Operator.PLUS);
  1969. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression[] stringLiterals = expression.literals;
  1970. infixExpression.setLeftOperand(super.convert(stringLiterals[0]));
  1971. infixExpression.setRightOperand(super.convert(stringLiterals[1]));
  1972. for (int i = 2; i < expression.counter; i++) {
  1973. infixExpression.extendedOperands().add(super.convert(stringLiterals[i]));
  1974. }
  1975. if (this.resolveBindings) {
  1976. this.recordNodes(infixExpression, expression);
  1977. }
  1978. infixExpression.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  1979. return infixExpression;
  1980. }
  1981. public NormalAnnotation convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.NormalAnnotation annotation) {
  1982. final NormalAnnotation normalAnnotation = new NormalAnnotation(this.ast);
  1983. setTypeNameForAnnotation(annotation, normalAnnotation);
  1984. org.aspectj.org.eclipse.jdt.internal.compiler.ast.MemberValuePair[] memberValuePairs = annotation.memberValuePairs;
  1985. if (memberValuePairs != null) {
  1986. for (int i = 0, max = memberValuePairs.length; i < max; i++) {
  1987. normalAnnotation.values().add(convert(memberValuePairs[i]));
  1988. }
  1989. }
  1990. int start = annotation.sourceStart;
  1991. int end = annotation.declarationSourceEnd;
  1992. normalAnnotation.setSourceRange(start, end - start + 1);
  1993. if (this.resolveBindings) {
  1994. recordNodes(normalAnnotation, annotation);
  1995. }
  1996. return normalAnnotation;
  1997. }
  1998. public NullLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.NullLiteral expression) {
  1999. final NullLiteral literal = new NullLiteral(this.ast);
  2000. if (this.resolveBindings) {
  2001. this.recordNodes(literal, expression);
  2002. }
  2003. literal.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  2004. return literal;
  2005. }
  2006. public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.OR_OR_Expression expression) {
  2007. final InfixExpression infixExpression = new InfixExpression(this.ast);
  2008. if (this.resolveBindings) {
  2009. recordNodes(infixExpression, expression);
  2010. }
  2011. Expression leftExpression = super.convert(expression.left);
  2012. infixExpression.setLeftOperand(leftExpression);
  2013. infixExpression.setRightOperand(super.convert(expression.right));
  2014. infixExpression.setOperator(InfixExpression.Operator.CONDITIONAL_OR);
  2015. int sourceStart = leftExpression.getStartPosition();
  2016. infixExpression.setSourceRange(sourceStart, expression.sourceEnd - sourceStart + 1);
  2017. return infixExpression;
  2018. }
  2019. public PostfixExpression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.PostfixExpression expression) {
  2020. final PostfixExpression postfixExpression = new PostfixExpression(this.ast);
  2021. if (this.resolveBindings) {
  2022. recordNodes(postfixExpression, expression);
  2023. }
  2024. postfixExpression.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  2025. postfixExpression.setOperand(super.convert(expression.lhs));
  2026. switch (expression.operator) {
  2027. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.PLUS:
  2028. postfixExpression.setOperator(PostfixExpression.Operator.INCREMENT);
  2029. break;
  2030. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MINUS:
  2031. postfixExpression.setOperator(PostfixExpression.Operator.DECREMENT);
  2032. break;
  2033. }
  2034. return postfixExpression;
  2035. }
  2036. public PrefixExpression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.PrefixExpression expression) {
  2037. final PrefixExpression prefixExpression = new PrefixExpression(this.ast);
  2038. if (this.resolveBindings) {
  2039. recordNodes(prefixExpression, expression);
  2040. }
  2041. prefixExpression.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  2042. prefixExpression.setOperand(super.convert(expression.lhs));
  2043. switch (expression.operator) {
  2044. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.PLUS:
  2045. prefixExpression.setOperator(PrefixExpression.Operator.INCREMENT);
  2046. break;
  2047. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MINUS:
  2048. prefixExpression.setOperator(PrefixExpression.Operator.DECREMENT);
  2049. break;
  2050. }
  2051. return prefixExpression;
  2052. }
  2053. public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedAllocationExpression allocation) {
  2054. final ClassInstanceCreation classInstanceCreation = new ClassInstanceCreation(this.ast);
  2055. if (allocation.enclosingInstance != null) {
  2056. classInstanceCreation.setExpression(super.convert(allocation.enclosingInstance));
  2057. }
  2058. switch (this.ast.apiLevel) {
  2059. case AST.JLS2_INTERNAL:
  2060. classInstanceCreation.internalSetName(convert(allocation.type));
  2061. break;
  2062. case AST.JLS3:
  2063. classInstanceCreation.setType(convertType(allocation.type));
  2064. }
  2065. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression[] arguments = allocation.arguments;
  2066. if (arguments != null) {
  2067. int length = arguments.length;
  2068. for (int i = 0; i < length; i++) {
  2069. Expression argument = super.convert(arguments[i]);
  2070. if (this.resolveBindings) {
  2071. recordNodes(argument, arguments[i]);
  2072. }
  2073. classInstanceCreation.arguments().add(argument);
  2074. }
  2075. }
  2076. if (allocation.typeArguments != null) {
  2077. switch (this.ast.apiLevel) {
  2078. case AST.JLS2_INTERNAL:
  2079. classInstanceCreation.setFlags(classInstanceCreation.getFlags() | ASTNode.MALFORMED);
  2080. break;
  2081. case AST.JLS3:
  2082. for (int i = 0, max = allocation.typeArguments.length; i < max; i++) {
  2083. classInstanceCreation.typeArguments().add(convertType(allocation.typeArguments[i]));
  2084. }
  2085. }
  2086. }
  2087. if (allocation.anonymousType != null) {
  2088. int declarationSourceStart = allocation.sourceStart;
  2089. classInstanceCreation.setSourceRange(declarationSourceStart, allocation.anonymousType.bodyEnd - declarationSourceStart
  2090. + 1);
  2091. final AnonymousClassDeclaration anonymousClassDeclaration = new AnonymousClassDeclaration(this.ast);
  2092. int start = retrieveStartBlockPosition(allocation.anonymousType.sourceEnd, allocation.anonymousType.bodyEnd);
  2093. anonymousClassDeclaration.setSourceRange(start, allocation.anonymousType.bodyEnd - start + 1);
  2094. classInstanceCreation.setAnonymousClassDeclaration(anonymousClassDeclaration);
  2095. buildBodyDeclarations(allocation.anonymousType, anonymousClassDeclaration);
  2096. if (this.resolveBindings) {
  2097. recordNodes(classInstanceCreation, allocation.anonymousType);
  2098. recordNodes(anonymousClassDeclaration, allocation.anonymousType);
  2099. anonymousClassDeclaration.resolveBinding();
  2100. }
  2101. return classInstanceCreation;
  2102. } else {
  2103. final int start = allocation.sourceStart;
  2104. classInstanceCreation.setSourceRange(start, allocation.sourceEnd - start + 1);
  2105. if (this.resolveBindings) {
  2106. recordNodes(classInstanceCreation, allocation);
  2107. }
  2108. removeTrailingCommentFromExpressionEndingWithAParen(classInstanceCreation);
  2109. return classInstanceCreation;
  2110. }
  2111. }
  2112. public Name convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedNameReference nameReference) {
  2113. return setQualifiedNameNameAndSourceRanges(nameReference.tokens, nameReference.sourcePositions, nameReference);
  2114. }
  2115. public Name convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedSuperReference reference) {
  2116. return convert(reference.qualification);
  2117. }
  2118. public ThisExpression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedThisReference reference) {
  2119. final ThisExpression thisExpression = new ThisExpression(this.ast);
  2120. thisExpression.setSourceRange(reference.sourceStart, reference.sourceEnd - reference.sourceStart + 1);
  2121. thisExpression.setQualifier(convert(reference.qualification));
  2122. if (this.resolveBindings) {
  2123. recordNodes(thisExpression, reference);
  2124. recordPendingThisExpressionScopeResolution(thisExpression);
  2125. }
  2126. return thisExpression;
  2127. }
  2128. public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Reference reference) {
  2129. if (reference instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.NameReference) {
  2130. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.NameReference) reference);
  2131. }
  2132. if (reference instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ThisReference) {
  2133. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ThisReference) reference);
  2134. }
  2135. if (reference instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayReference) {
  2136. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ArrayReference) reference);
  2137. }
  2138. if (reference instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldReference) {
  2139. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldReference) reference);
  2140. }
  2141. return null; // cannot be reached
  2142. }
  2143. public ReturnStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ReturnStatement statement) {
  2144. final ReturnStatement returnStatement = new ReturnStatement(this.ast);
  2145. returnStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  2146. if (statement.expression != null) {
  2147. returnStatement.setExpression(super.convert(statement.expression));
  2148. }
  2149. retrieveSemiColonPosition(returnStatement);
  2150. return returnStatement;
  2151. }
  2152. public SingleMemberAnnotation convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.SingleMemberAnnotation annotation) {
  2153. final SingleMemberAnnotation singleMemberAnnotation = new SingleMemberAnnotation(this.ast);
  2154. setTypeNameForAnnotation(annotation, singleMemberAnnotation);
  2155. singleMemberAnnotation.setValue(super.convert(annotation.memberValue));
  2156. int start = annotation.sourceStart;
  2157. int end = annotation.declarationSourceEnd;
  2158. singleMemberAnnotation.setSourceRange(start, end - start + 1);
  2159. if (this.resolveBindings) {
  2160. recordNodes(singleMemberAnnotation, annotation);
  2161. }
  2162. return singleMemberAnnotation;
  2163. }
  2164. public SimpleName convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.SingleNameReference nameReference) {
  2165. final SimpleName name = new SimpleName(this.ast);
  2166. name.internalSetIdentifier(new String(nameReference.token));
  2167. if (this.resolveBindings) {
  2168. recordNodes(name, nameReference);
  2169. }
  2170. name.setSourceRange(nameReference.sourceStart, nameReference.sourceEnd - nameReference.sourceStart + 1);
  2171. return name;
  2172. }
  2173. public Statement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement statement) {
  2174. if (statement instanceof ForeachStatement) {
  2175. return convert((ForeachStatement) statement);
  2176. }
  2177. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) {
  2178. return convertToVariableDeclarationStatement((org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration) statement);
  2179. }
  2180. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.AssertStatement) {
  2181. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.AssertStatement) statement);
  2182. }
  2183. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.Block) {
  2184. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.Block) statement);
  2185. }
  2186. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.BreakStatement) {
  2187. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.BreakStatement) statement);
  2188. }
  2189. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ContinueStatement) {
  2190. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ContinueStatement) statement);
  2191. }
  2192. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.CaseStatement) {
  2193. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.CaseStatement) statement);
  2194. }
  2195. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.DoStatement) {
  2196. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.DoStatement) statement);
  2197. }
  2198. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.EmptyStatement) {
  2199. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.EmptyStatement) statement);
  2200. }
  2201. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall) {
  2202. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ExplicitConstructorCall) statement);
  2203. }
  2204. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ForStatement) {
  2205. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ForStatement) statement);
  2206. }
  2207. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.IfStatement) {
  2208. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.IfStatement) statement);
  2209. }
  2210. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.LabeledStatement) {
  2211. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.LabeledStatement) statement);
  2212. }
  2213. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ReturnStatement) {
  2214. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ReturnStatement) statement);
  2215. }
  2216. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.SwitchStatement) {
  2217. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.SwitchStatement) statement);
  2218. }
  2219. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.SynchronizedStatement) {
  2220. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.SynchronizedStatement) statement);
  2221. }
  2222. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.ThrowStatement) {
  2223. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.ThrowStatement) statement);
  2224. }
  2225. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TryStatement) {
  2226. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.TryStatement) statement);
  2227. }
  2228. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration) {
  2229. ASTNode result = convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration) statement);
  2230. if (result == null) {
  2231. return createFakeEmptyStatement(statement);
  2232. }
  2233. switch (result.getNodeType()) {
  2234. case ASTNode.ENUM_DECLARATION:
  2235. switch (this.ast.apiLevel) {
  2236. case AST.JLS2_INTERNAL:
  2237. return createFakeEmptyStatement(statement);
  2238. case AST.JLS3:
  2239. final TypeDeclarationStatement typeDeclarationStatement = new TypeDeclarationStatement(this.ast);
  2240. typeDeclarationStatement.setDeclaration((EnumDeclaration) result);
  2241. AbstractTypeDeclaration typeDecl = typeDeclarationStatement.getDeclaration();
  2242. typeDeclarationStatement.setSourceRange(typeDecl.getStartPosition(), typeDecl.getLength());
  2243. return typeDeclarationStatement;
  2244. }
  2245. break;
  2246. case ASTNode.ANNOTATION_TYPE_DECLARATION:
  2247. switch (this.ast.apiLevel) {
  2248. case AST.JLS2_INTERNAL:
  2249. return createFakeEmptyStatement(statement);
  2250. case AST.JLS3:
  2251. TypeDeclarationStatement typeDeclarationStatement = new TypeDeclarationStatement(this.ast);
  2252. typeDeclarationStatement.setDeclaration((AnnotationTypeDeclaration) result);
  2253. AbstractTypeDeclaration typeDecl = typeDeclarationStatement.getDeclaration();
  2254. typeDeclarationStatement.setSourceRange(typeDecl.getStartPosition(), typeDecl.getLength());
  2255. return typeDeclarationStatement;
  2256. }
  2257. break;
  2258. default:
  2259. TypeDeclaration typeDeclaration = (TypeDeclaration) result;
  2260. if (typeDeclaration == null) {
  2261. return createFakeEmptyStatement(statement);
  2262. } else {
  2263. TypeDeclarationStatement typeDeclarationStatement = new TypeDeclarationStatement(this.ast);
  2264. typeDeclarationStatement.setDeclaration(typeDeclaration);
  2265. switch (this.ast.apiLevel) {
  2266. case AST.JLS2_INTERNAL:
  2267. TypeDeclaration typeDecl = typeDeclarationStatement.internalGetTypeDeclaration();
  2268. typeDeclarationStatement.setSourceRange(typeDecl.getStartPosition(), typeDecl.getLength());
  2269. break;
  2270. case AST.JLS3:
  2271. AbstractTypeDeclaration typeDeclAST3 = typeDeclarationStatement.getDeclaration();
  2272. typeDeclarationStatement.setSourceRange(typeDeclAST3.getStartPosition(), typeDeclAST3.getLength());
  2273. break;
  2274. }
  2275. return typeDeclarationStatement;
  2276. }
  2277. }
  2278. }
  2279. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.WhileStatement) {
  2280. return super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.WhileStatement) statement);
  2281. }
  2282. if (statement instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression) {
  2283. final Expression expr = super.convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression) statement);
  2284. final ExpressionStatement stmt = new ExpressionStatement(this.ast);
  2285. stmt.setExpression(expr);
  2286. stmt.setSourceRange(expr.getStartPosition(), expr.getLength());
  2287. retrieveSemiColonPosition(stmt);
  2288. return stmt;
  2289. }
  2290. return createFakeEmptyStatement(statement);
  2291. }
  2292. public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.StringLiteral expression) {
  2293. if (expression instanceof StringLiteralConcatenation) {
  2294. return convert((StringLiteralConcatenation) expression);
  2295. }
  2296. int length = expression.sourceEnd - expression.sourceStart + 1;
  2297. int sourceStart = expression.sourceStart;
  2298. StringLiteral literal = new StringLiteral(this.ast);
  2299. if (this.resolveBindings) {
  2300. this.recordNodes(literal, expression);
  2301. }
  2302. literal.internalSetEscapedValue(new String(this.compilationUnitSource, sourceStart, length));
  2303. literal.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  2304. return literal;
  2305. }
  2306. public SwitchStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.SwitchStatement statement) {
  2307. SwitchStatement switchStatement = new SwitchStatement(this.ast);
  2308. switchStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  2309. switchStatement.setExpression(super.convert(statement.expression));
  2310. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement[] statements = statement.statements;
  2311. if (statements != null) {
  2312. int statementsLength = statements.length;
  2313. for (int i = 0; i < statementsLength; i++) {
  2314. switchStatement.statements().add(convert(statements[i]));
  2315. }
  2316. }
  2317. return switchStatement;
  2318. }
  2319. public SynchronizedStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.SynchronizedStatement statement) {
  2320. SynchronizedStatement synchronizedStatement = new SynchronizedStatement(this.ast);
  2321. synchronizedStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  2322. synchronizedStatement.setBody(convert(statement.block));
  2323. synchronizedStatement.setExpression(super.convert(statement.expression));
  2324. return synchronizedStatement;
  2325. }
  2326. public Expression convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ThisReference reference) {
  2327. if (reference.isImplicitThis()) {
  2328. // There is no source associated with an implicit this
  2329. return null;
  2330. } else if (reference instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedSuperReference) {
  2331. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedSuperReference) reference);
  2332. } else if (reference instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedThisReference) {
  2333. return convert((org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedThisReference) reference);
  2334. } else {
  2335. ThisExpression thisExpression = new ThisExpression(this.ast);
  2336. thisExpression.setSourceRange(reference.sourceStart, reference.sourceEnd - reference.sourceStart + 1);
  2337. if (this.resolveBindings) {
  2338. recordNodes(thisExpression, reference);
  2339. recordPendingThisExpressionScopeResolution(thisExpression);
  2340. }
  2341. return thisExpression;
  2342. }
  2343. }
  2344. public ThrowStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.ThrowStatement statement) {
  2345. final ThrowStatement throwStatement = new ThrowStatement(this.ast);
  2346. throwStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  2347. throwStatement.setExpression(super.convert(statement.exception));
  2348. retrieveSemiColonPosition(throwStatement);
  2349. return throwStatement;
  2350. }
  2351. public BooleanLiteral convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.TrueLiteral expression) {
  2352. final BooleanLiteral literal = new BooleanLiteral(this.ast);
  2353. literal.setBooleanValue(true);
  2354. if (this.resolveBindings) {
  2355. this.recordNodes(literal, expression);
  2356. }
  2357. literal.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  2358. return literal;
  2359. }
  2360. public TryStatement convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.TryStatement statement) {
  2361. final TryStatement tryStatement = new TryStatement(this.ast);
  2362. tryStatement.setSourceRange(statement.sourceStart, statement.sourceEnd - statement.sourceStart + 1);
  2363. tryStatement.setBody(convert(statement.tryBlock));
  2364. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Argument[] catchArguments = statement.catchArguments;
  2365. if (catchArguments != null) {
  2366. int catchArgumentsLength = catchArguments.length;
  2367. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Block[] catchBlocks = statement.catchBlocks;
  2368. int start = statement.tryBlock.sourceEnd;
  2369. for (int i = 0; i < catchArgumentsLength; i++) {
  2370. CatchClause catchClause = new CatchClause(this.ast);
  2371. int catchClauseSourceStart = retrieveStartingCatchPosition(start, catchArguments[i].sourceStart);
  2372. catchClause.setSourceRange(catchClauseSourceStart, catchBlocks[i].sourceEnd - catchClauseSourceStart + 1);
  2373. catchClause.setBody(convert(catchBlocks[i]));
  2374. catchClause.setException(convert(catchArguments[i]));
  2375. tryStatement.catchClauses().add(catchClause);
  2376. start = catchBlocks[i].sourceEnd;
  2377. }
  2378. }
  2379. if (statement.finallyBlock != null) {
  2380. tryStatement.setFinally(convert(statement.finallyBlock));
  2381. }
  2382. return tryStatement;
  2383. }
  2384. public ASTNode convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration typeDeclaration) {
  2385. int kind = org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration.kind(typeDeclaration.modifiers);
  2386. switch (kind) {
  2387. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration.ENUM_DECL :
  2388. if (this.ast.apiLevel == AST.JLS2_INTERNAL) {
  2389. return null;
  2390. } else {
  2391. return convertToEnumDeclaration(typeDeclaration);
  2392. }
  2393. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration.ANNOTATION_TYPE_DECL :
  2394. if (this.ast.apiLevel == AST.JLS2_INTERNAL) {
  2395. return null;
  2396. } else {
  2397. return convertToAnnotationDeclaration(typeDeclaration);
  2398. }
  2399. }
  2400. checkCanceled();
  2401. TypeDeclaration typeDecl = TypeDeclaration.getTypeDeclaration(this.ast);
  2402. // ////////////// ajh02: added
  2403. if (typeDeclaration instanceof AspectDeclaration) {
  2404. org.aspectj.weaver.patterns.PerClause perClause = ((AspectDeclaration) typeDeclaration).perClause;
  2405. boolean isPrivileged = ((AspectDeclaration) typeDeclaration).isPrivileged;
  2406. if (perClause == null) {
  2407. typeDecl = new org.aspectj.org.eclipse.jdt.core.dom.AspectDeclaration(this.ast, null, isPrivileged);
  2408. } else {
  2409. typeDecl = new org.aspectj.org.eclipse.jdt.core.dom.AspectDeclaration(this.ast, convert(perClause), isPrivileged);
  2410. }
  2411. }
  2412. // /////////////////////////////
  2413. if (typeDeclaration.modifiersSourceStart != -1) {
  2414. setModifiers(typeDecl, typeDeclaration);
  2415. }
  2416. boolean isInterface = kind == org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration.INTERFACE_DECL;
  2417. typeDecl.setInterface(isInterface);
  2418. final SimpleName typeName = new SimpleName(this.ast);
  2419. typeName.internalSetIdentifier(new String(typeDeclaration.name));
  2420. typeName.setSourceRange(typeDeclaration.sourceStart, typeDeclaration.sourceEnd - typeDeclaration.sourceStart + 1);
  2421. typeDecl.setName(typeName);
  2422. typeDecl.setSourceRange(typeDeclaration.declarationSourceStart, typeDeclaration.bodyEnd - typeDeclaration.declarationSourceStart + 1);
  2423. // need to set the superclass and super interfaces here since we cannot distinguish them at
  2424. // the type references level.
  2425. if (typeDeclaration.superclass != null) {
  2426. switch(this.ast.apiLevel) {
  2427. case AST.JLS2_INTERNAL :
  2428. typeDecl.internalSetSuperclass(convert(typeDeclaration.superclass));
  2429. break;
  2430. default :
  2431. typeDecl.setSuperclassType(convertType(typeDeclaration.superclass));
  2432. break;
  2433. }
  2434. }
  2435. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference[] superInterfaces = typeDeclaration.superInterfaces;
  2436. if (superInterfaces != null) {
  2437. switch(this.ast.apiLevel) {
  2438. case AST.JLS2_INTERNAL :
  2439. for (int index = 0, length = superInterfaces.length; index < length; index++) {
  2440. typeDecl.internalSuperInterfaces().add(convert(superInterfaces[index]));
  2441. }
  2442. break;
  2443. default :
  2444. for (int index = 0, length = superInterfaces.length; index < length; index++) {
  2445. typeDecl.superInterfaceTypes().add(convertType(superInterfaces[index]));
  2446. }
  2447. }
  2448. }
  2449. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeParameter[] typeParameters = typeDeclaration.typeParameters;
  2450. if (typeParameters != null) {
  2451. switch(this.ast.apiLevel) {
  2452. case AST.JLS2_INTERNAL :
  2453. typeDecl.setFlags(typeDecl.getFlags() | ASTNode.MALFORMED);
  2454. break;
  2455. default :
  2456. for (int index = 0, length = typeParameters.length; index < length; index++) {
  2457. typeDecl.typeParameters().add(convert(typeParameters[index]));
  2458. }
  2459. }
  2460. }
  2461. buildBodyDeclarations(typeDeclaration, typeDecl, isInterface);
  2462. if (this.resolveBindings) {
  2463. recordNodes(typeDecl, typeDeclaration);
  2464. recordNodes(typeName, typeDeclaration);
  2465. typeDecl.resolveBinding();
  2466. }
  2467. return typeDecl;
  2468. }
  2469. public TypeParameter convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeParameter typeParameter) {
  2470. final TypeParameter typeParameter2 = new TypeParameter(this.ast);
  2471. final SimpleName simpleName = new SimpleName(this.ast);
  2472. simpleName.internalSetIdentifier(new String(typeParameter.name));
  2473. int start = typeParameter.sourceStart;
  2474. int end = typeParameter.sourceEnd;
  2475. simpleName.setSourceRange(start, end - start + 1);
  2476. typeParameter2.setName(simpleName);
  2477. final TypeReference superType = typeParameter.type;
  2478. end = typeParameter.declarationSourceEnd;
  2479. if (superType != null) {
  2480. Type type = convertType(superType);
  2481. typeParameter2.typeBounds().add(type);
  2482. end = type.getStartPosition() + type.getLength() - 1;
  2483. }
  2484. TypeReference[] bounds = typeParameter.bounds;
  2485. if (bounds != null) {
  2486. Type type = null;
  2487. for (int index = 0, length = bounds.length; index < length; index++) {
  2488. type = convertType(bounds[index]);
  2489. typeParameter2.typeBounds().add(type);
  2490. end = type.getStartPosition() + type.getLength() - 1;
  2491. }
  2492. }
  2493. start = typeParameter.declarationSourceStart;
  2494. end = retrieveClosingAngleBracketPosition(end);
  2495. typeParameter2.setSourceRange(start, end - start + 1);
  2496. if (this.resolveBindings) {
  2497. recordName(simpleName, typeParameter);
  2498. recordNodes(typeParameter2, typeParameter);
  2499. typeParameter2.resolveBinding();
  2500. }
  2501. return typeParameter2;
  2502. }
  2503. public Name convert(org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeReference) {
  2504. char[][] typeName = typeReference.getTypeName();
  2505. int length = typeName.length;
  2506. if (length > 1) {
  2507. // QualifiedName
  2508. org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedTypeReference qualifiedTypeReference = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedTypeReference) typeReference;
  2509. final long[] positions = qualifiedTypeReference.sourcePositions;
  2510. return setQualifiedNameNameAndSourceRanges(typeName, positions, typeReference);
  2511. } else {
  2512. final SimpleName name = new SimpleName(this.ast);
  2513. name.internalSetIdentifier(new String(typeName[0]));
  2514. name.setSourceRange(typeReference.sourceStart, typeReference.sourceEnd - typeReference.sourceStart + 1);
  2515. if (this.resolveBindings) {
  2516. recordNodes(name, typeReference);
  2517. }
  2518. return name;
  2519. }
  2520. }
  2521. protected FieldDeclaration convertToFieldDeclaration(
  2522. org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration fieldDecl) {
  2523. VariableDeclarationFragment variableDeclarationFragment = convertToVariableDeclarationFragment(fieldDecl);
  2524. final FieldDeclaration fieldDeclaration = new FieldDeclaration(this.ast);
  2525. fieldDeclaration.fragments().add(variableDeclarationFragment);
  2526. IVariableBinding binding = null;
  2527. if (this.resolveBindings) {
  2528. recordNodes(variableDeclarationFragment, fieldDecl);
  2529. binding = variableDeclarationFragment.resolveBinding();
  2530. }
  2531. fieldDeclaration.setSourceRange(fieldDecl.declarationSourceStart, fieldDecl.declarationEnd
  2532. - fieldDecl.declarationSourceStart + 1);
  2533. Type type = convertType(fieldDecl.type);
  2534. setTypeForField(fieldDeclaration, type, variableDeclarationFragment.getExtraDimensions());
  2535. setModifiers(fieldDeclaration, fieldDecl);
  2536. if (!(this.resolveBindings && binding == null)) {
  2537. convert(fieldDecl.javadoc, fieldDeclaration);
  2538. }
  2539. return fieldDeclaration;
  2540. }
  2541. // public ParenthesizedExpression convertToParenthesizedExpression(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression
  2542. // expression) {
  2543. // final ParenthesizedExpression parenthesizedExpression = new ParenthesizedExpression(this.ast);
  2544. // if (this.resolveBindings) {
  2545. // recordNodes(parenthesizedExpression, expression);
  2546. // }
  2547. // parenthesizedExpression.setSourceRange(expression.sourceStart, expression.sourceEnd - expression.sourceStart + 1);
  2548. // adjustSourcePositionsForParent(expression);
  2549. // trimWhiteSpacesAndComments(expression);
  2550. // // decrement the number of parenthesis
  2551. // int numberOfParenthesis = (expression.bits & org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK) >>
  2552. // org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedSHIFT;
  2553. // expression.bits &= ~org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedMASK;
  2554. // expression.bits |= (numberOfParenthesis - 1) << org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode.ParenthesizedSHIFT;
  2555. // parenthesizedExpression.setExpression(convert(expression));
  2556. // return parenthesizedExpression;
  2557. // }
  2558. // public Type convertToType(org.aspectj.org.eclipse.jdt.internal.compiler.ast.NameReference reference) {
  2559. // Name name = convert(reference);
  2560. // final SimpleType type = new SimpleType(this.ast);
  2561. // type.setName(name);
  2562. // type.setSourceRange(name.getStartPosition(), name.getLength());
  2563. // if (this.resolveBindings) {
  2564. // this.recordNodes(type, reference);
  2565. // }
  2566. // return type;
  2567. // }
  2568. protected VariableDeclarationExpression convertToVariableDeclarationExpression(
  2569. org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration localDeclaration) {
  2570. final VariableDeclarationFragment variableDeclarationFragment = convertToVariableDeclarationFragment(localDeclaration);
  2571. final VariableDeclarationExpression variableDeclarationExpression = new VariableDeclarationExpression(this.ast);
  2572. variableDeclarationExpression.fragments().add(variableDeclarationFragment);
  2573. if (this.resolveBindings) {
  2574. recordNodes(variableDeclarationFragment, localDeclaration);
  2575. }
  2576. variableDeclarationExpression.setSourceRange(localDeclaration.declarationSourceStart, localDeclaration.declarationSourceEnd
  2577. - localDeclaration.declarationSourceStart + 1);
  2578. Type type = convertType(localDeclaration.type);
  2579. setTypeForVariableDeclarationExpression(variableDeclarationExpression, type,
  2580. variableDeclarationFragment.getExtraDimensions());
  2581. if (localDeclaration.modifiersSourceStart != -1) {
  2582. setModifiers(variableDeclarationExpression, localDeclaration);
  2583. }
  2584. return variableDeclarationExpression;
  2585. }
  2586. protected SingleVariableDeclaration convertToSingleVariableDeclaration(LocalDeclaration localDeclaration) {
  2587. final SingleVariableDeclaration variableDecl = new SingleVariableDeclaration(this.ast);
  2588. setModifiers(variableDecl, localDeclaration);
  2589. final SimpleName name = new SimpleName(this.ast);
  2590. name.internalSetIdentifier(new String(localDeclaration.name));
  2591. int start = localDeclaration.sourceStart;
  2592. int nameEnd = localDeclaration.sourceEnd;
  2593. name.setSourceRange(start, nameEnd - start + 1);
  2594. variableDecl.setName(name);
  2595. final int extraDimensions = retrieveExtraDimension(nameEnd + 1, localDeclaration.type.sourceEnd);
  2596. variableDecl.setExtraDimensions(extraDimensions);
  2597. Type type = convertType(localDeclaration.type);
  2598. int typeEnd = type.getStartPosition() + type.getLength() - 1;
  2599. int rightEnd = Math.max(typeEnd, localDeclaration.declarationSourceEnd);
  2600. /*
  2601. * There is extra work to do to set the proper type positions See PR http://bugs.eclipse.org/bugs/show_bug.cgi?id=23284
  2602. */
  2603. setTypeForSingleVariableDeclaration(variableDecl, type, extraDimensions);
  2604. variableDecl
  2605. .setSourceRange(localDeclaration.declarationSourceStart, rightEnd - localDeclaration.declarationSourceStart + 1);
  2606. if (this.resolveBindings) {
  2607. recordNodes(name, localDeclaration);
  2608. recordNodes(variableDecl, localDeclaration);
  2609. variableDecl.resolveBinding();
  2610. }
  2611. return variableDecl;
  2612. }
  2613. protected VariableDeclarationFragment convertToVariableDeclarationFragment(InterTypeFieldDeclaration fieldDeclaration) {
  2614. // ajh02: method added
  2615. final VariableDeclarationFragment variableDeclarationFragment = new VariableDeclarationFragment(this.ast);
  2616. final SimpleName name = new SimpleName(this.ast);
  2617. name.internalSetIdentifier(new String(fieldDeclaration.getDeclaredSelector()));
  2618. name.setSourceRange(fieldDeclaration.sourceStart, fieldDeclaration.sourceEnd - fieldDeclaration.sourceStart + 1);
  2619. variableDeclarationFragment.setName(name);
  2620. int start = fieldDeclaration.sourceEnd;
  2621. if (fieldDeclaration.initialization != null) {
  2622. final Expression expression = super.convert(fieldDeclaration.initialization);
  2623. variableDeclarationFragment.setInitializer(expression);
  2624. start = expression.getStartPosition() + expression.getLength();
  2625. }
  2626. int end = retrievePositionBeforeNextCommaOrSemiColon(start, fieldDeclaration.declarationSourceEnd);
  2627. if (end == -1) {
  2628. variableDeclarationFragment.setSourceRange(fieldDeclaration.sourceStart, fieldDeclaration.declarationSourceEnd
  2629. - fieldDeclaration.sourceStart + 1);
  2630. variableDeclarationFragment.setFlags(variableDeclarationFragment.getFlags() | ASTNode.MALFORMED);
  2631. } else {
  2632. variableDeclarationFragment.setSourceRange(fieldDeclaration.sourceStart, end - fieldDeclaration.sourceStart + 1);
  2633. }
  2634. variableDeclarationFragment.setExtraDimensions(retrieveExtraDimension(fieldDeclaration.sourceEnd + 1,
  2635. fieldDeclaration.declarationSourceEnd));
  2636. if (this.resolveBindings) {
  2637. recordNodes(name, fieldDeclaration);
  2638. recordNodes(variableDeclarationFragment, fieldDeclaration);
  2639. variableDeclarationFragment.resolveBinding();
  2640. }
  2641. return variableDeclarationFragment;
  2642. }
  2643. protected VariableDeclarationFragment convertToVariableDeclarationFragment(
  2644. org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration fieldDeclaration) {
  2645. final VariableDeclarationFragment variableDeclarationFragment = new VariableDeclarationFragment(this.ast);
  2646. final SimpleName name = new SimpleName(this.ast);
  2647. name.internalSetIdentifier(new String(fieldDeclaration.name));
  2648. name.setSourceRange(fieldDeclaration.sourceStart, fieldDeclaration.sourceEnd - fieldDeclaration.sourceStart + 1);
  2649. variableDeclarationFragment.setName(name);
  2650. int start = fieldDeclaration.sourceEnd;
  2651. if (fieldDeclaration.initialization != null) {
  2652. final Expression expression = super.convert(fieldDeclaration.initialization);
  2653. variableDeclarationFragment.setInitializer(expression);
  2654. start = expression.getStartPosition() + expression.getLength();
  2655. }
  2656. int end = retrievePositionBeforeNextCommaOrSemiColon(start, fieldDeclaration.declarationSourceEnd);
  2657. if (end == -1) {
  2658. variableDeclarationFragment.setSourceRange(fieldDeclaration.sourceStart, fieldDeclaration.declarationSourceEnd
  2659. - fieldDeclaration.sourceStart + 1);
  2660. variableDeclarationFragment.setFlags(variableDeclarationFragment.getFlags() | ASTNode.MALFORMED);
  2661. } else {
  2662. variableDeclarationFragment.setSourceRange(fieldDeclaration.sourceStart, end - fieldDeclaration.sourceStart + 1);
  2663. }
  2664. variableDeclarationFragment.setExtraDimensions(retrieveExtraDimension(fieldDeclaration.sourceEnd + 1,
  2665. fieldDeclaration.declarationSourceEnd));
  2666. if (this.resolveBindings) {
  2667. recordNodes(name, fieldDeclaration);
  2668. recordNodes(variableDeclarationFragment, fieldDeclaration);
  2669. variableDeclarationFragment.resolveBinding();
  2670. }
  2671. return variableDeclarationFragment;
  2672. }
  2673. protected VariableDeclarationFragment convertToVariableDeclarationFragment(
  2674. org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration localDeclaration) {
  2675. final VariableDeclarationFragment variableDeclarationFragment = new VariableDeclarationFragment(this.ast);
  2676. final SimpleName name = new SimpleName(this.ast);
  2677. name.internalSetIdentifier(new String(localDeclaration.name));
  2678. name.setSourceRange(localDeclaration.sourceStart, localDeclaration.sourceEnd - localDeclaration.sourceStart + 1);
  2679. variableDeclarationFragment.setName(name);
  2680. int start = localDeclaration.sourceEnd;
  2681. if (localDeclaration.initialization != null) {
  2682. final Expression expression = super.convert(localDeclaration.initialization);
  2683. variableDeclarationFragment.setInitializer(expression);
  2684. start = expression.getStartPosition() + expression.getLength();
  2685. }
  2686. int end = retrievePositionBeforeNextCommaOrSemiColon(start, localDeclaration.declarationSourceEnd);
  2687. if (end == -1) {
  2688. if (localDeclaration.initialization != null) {
  2689. variableDeclarationFragment.setSourceRange(localDeclaration.sourceStart, localDeclaration.initialization.sourceEnd
  2690. - localDeclaration.sourceStart + 1);
  2691. } else {
  2692. variableDeclarationFragment.setSourceRange(localDeclaration.sourceStart, localDeclaration.sourceEnd
  2693. - localDeclaration.sourceStart + 1);
  2694. }
  2695. } else {
  2696. variableDeclarationFragment.setSourceRange(localDeclaration.sourceStart, end - localDeclaration.sourceStart + 1);
  2697. }
  2698. variableDeclarationFragment.setExtraDimensions(retrieveExtraDimension(localDeclaration.sourceEnd + 1,
  2699. this.compilationUnitSourceLength));
  2700. if (this.resolveBindings) {
  2701. recordNodes(variableDeclarationFragment, localDeclaration);
  2702. recordNodes(name, localDeclaration);
  2703. variableDeclarationFragment.resolveBinding();
  2704. }
  2705. return variableDeclarationFragment;
  2706. }
  2707. protected VariableDeclarationStatement convertToVariableDeclarationStatement(
  2708. org.aspectj.org.eclipse.jdt.internal.compiler.ast.LocalDeclaration localDeclaration) {
  2709. final VariableDeclarationFragment variableDeclarationFragment = convertToVariableDeclarationFragment(localDeclaration);
  2710. final VariableDeclarationStatement variableDeclarationStatement = new VariableDeclarationStatement(this.ast);
  2711. variableDeclarationStatement.fragments().add(variableDeclarationFragment);
  2712. if (this.resolveBindings) {
  2713. recordNodes(variableDeclarationFragment, localDeclaration);
  2714. }
  2715. variableDeclarationStatement.setSourceRange(localDeclaration.declarationSourceStart, localDeclaration.declarationSourceEnd
  2716. - localDeclaration.declarationSourceStart + 1);
  2717. Type type = convertType(localDeclaration.type);
  2718. setTypeForVariableDeclarationStatement(variableDeclarationStatement, type, variableDeclarationFragment.getExtraDimensions());
  2719. if (localDeclaration.modifiersSourceStart != -1) {
  2720. setModifiers(variableDeclarationStatement, localDeclaration);
  2721. }
  2722. return variableDeclarationStatement;
  2723. }
  2724. public Type convertType(TypeReference typeReference) {
  2725. if (typeReference instanceof Wildcard) {
  2726. final Wildcard wildcard = (Wildcard) typeReference;
  2727. final WildcardType wildcardType = new WildcardType(this.ast);
  2728. if (wildcard.bound != null) {
  2729. final Type bound = convertType(wildcard.bound);
  2730. wildcardType.setBound(bound, wildcard.kind == Wildcard.EXTENDS);
  2731. int start = wildcard.sourceStart;
  2732. wildcardType.setSourceRange(start, bound.getStartPosition() + bound.getLength() - start);
  2733. } else {
  2734. final int start = wildcard.sourceStart;
  2735. final int end = wildcard.sourceEnd;
  2736. wildcardType.setSourceRange(start, end - start + 1);
  2737. }
  2738. if (this.resolveBindings) {
  2739. recordNodes(wildcardType, typeReference);
  2740. }
  2741. return wildcardType;
  2742. }
  2743. Type type = null;
  2744. int sourceStart = -1;
  2745. int length = 0;
  2746. int dimensions = typeReference.dimensions();
  2747. if (typeReference instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.SingleTypeReference) {
  2748. // this is either an ArrayTypeReference or a SingleTypeReference
  2749. char[] name = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.SingleTypeReference) typeReference).getTypeName()[0];
  2750. sourceStart = typeReference.sourceStart;
  2751. length = typeReference.sourceEnd - typeReference.sourceStart + 1;
  2752. // need to find out if this is an array type of primitive types or not
  2753. if (isPrimitiveType(name)) {
  2754. int end = retrieveEndOfElementTypeNamePosition(sourceStart, sourceStart + length);
  2755. if (end == -1) {
  2756. end = sourceStart + length - 1;
  2757. }
  2758. final PrimitiveType primitiveType = new PrimitiveType(this.ast);
  2759. primitiveType.setPrimitiveTypeCode(getPrimitiveTypeCode(name));
  2760. primitiveType.setSourceRange(sourceStart, end - sourceStart + 1);
  2761. type = primitiveType;
  2762. } else if (typeReference instanceof ParameterizedSingleTypeReference) {
  2763. ParameterizedSingleTypeReference parameterizedSingleTypeReference = (ParameterizedSingleTypeReference) typeReference;
  2764. final SimpleName simpleName = new SimpleName(this.ast);
  2765. simpleName.internalSetIdentifier(new String(name));
  2766. int end = retrieveEndOfElementTypeNamePosition(sourceStart, sourceStart + length);
  2767. if (end == -1) {
  2768. end = sourceStart + length - 1;
  2769. }
  2770. simpleName.setSourceRange(sourceStart, end - sourceStart + 1);
  2771. switch (this.ast.apiLevel) {
  2772. case AST.JLS2_INTERNAL:
  2773. SimpleType simpleType = new SimpleType(this.ast);
  2774. simpleType.setName(simpleName);
  2775. simpleType.setFlags(simpleType.getFlags() | ASTNode.MALFORMED);
  2776. simpleType.setSourceRange(sourceStart, end - sourceStart + 1);
  2777. type = simpleType;
  2778. if (this.resolveBindings) {
  2779. this.recordNodes(simpleName, typeReference);
  2780. }
  2781. break;
  2782. case AST.JLS3:
  2783. simpleType = new SimpleType(this.ast);
  2784. simpleType.setName(simpleName);
  2785. simpleType.setSourceRange(simpleName.getStartPosition(), simpleName.getLength());
  2786. final ParameterizedType parameterizedType = new ParameterizedType(this.ast);
  2787. parameterizedType.setType(simpleType);
  2788. type = parameterizedType;
  2789. TypeReference[] typeArguments = parameterizedSingleTypeReference.typeArguments;
  2790. if (typeArguments != null) {
  2791. Type type2 = null;
  2792. for (int i = 0, max = typeArguments.length; i < max; i++) {
  2793. type2 = convertType(typeArguments[i]);
  2794. ((ParameterizedType) type).typeArguments().add(type2);
  2795. end = type2.getStartPosition() + type2.getLength() - 1;
  2796. }
  2797. end = retrieveClosingAngleBracketPosition(end + 1);
  2798. type.setSourceRange(sourceStart, end - sourceStart + 1);
  2799. } else {
  2800. type.setSourceRange(sourceStart, end - sourceStart + 1);
  2801. }
  2802. if (this.resolveBindings) {
  2803. this.recordNodes(simpleName, typeReference);
  2804. this.recordNodes(simpleType, typeReference);
  2805. }
  2806. }
  2807. } else {
  2808. final SimpleName simpleName = new SimpleName(this.ast);
  2809. simpleName.internalSetIdentifier(new String(name));
  2810. // we need to search for the starting position of the first brace in order to set the proper length
  2811. // PR http://dev.eclipse.org/bugs/show_bug.cgi?id=10759
  2812. int end = retrieveEndOfElementTypeNamePosition(sourceStart, sourceStart + length);
  2813. if (end == -1) {
  2814. end = sourceStart + length - 1;
  2815. }
  2816. simpleName.setSourceRange(sourceStart, end - sourceStart + 1);
  2817. final SimpleType simpleType = new SimpleType(this.ast);
  2818. simpleType.setName(simpleName);
  2819. type = simpleType;
  2820. type.setSourceRange(sourceStart, end - sourceStart + 1);
  2821. type = simpleType;
  2822. if (this.resolveBindings) {
  2823. this.recordNodes(simpleName, typeReference);
  2824. }
  2825. }
  2826. if (dimensions != 0) {
  2827. type = this.ast.newArrayType(type, dimensions);
  2828. type.setSourceRange(sourceStart, length);
  2829. ArrayType subarrayType = (ArrayType) type;
  2830. int index = dimensions - 1;
  2831. while (index > 0) {
  2832. subarrayType = (ArrayType) subarrayType.getComponentType();
  2833. int end = retrieveProperRightBracketPosition(index, sourceStart);
  2834. subarrayType.setSourceRange(sourceStart, end - sourceStart + 1);
  2835. index--;
  2836. }
  2837. if (this.resolveBindings) {
  2838. // store keys for inner types
  2839. completeRecord((ArrayType) type, typeReference);
  2840. }
  2841. }
  2842. } else {
  2843. if (typeReference instanceof ParameterizedQualifiedTypeReference) {
  2844. ParameterizedQualifiedTypeReference parameterizedQualifiedTypeReference = (ParameterizedQualifiedTypeReference) typeReference;
  2845. char[][] tokens = parameterizedQualifiedTypeReference.tokens;
  2846. TypeReference[][] typeArguments = parameterizedQualifiedTypeReference.typeArguments;
  2847. long[] positions = parameterizedQualifiedTypeReference.sourcePositions;
  2848. sourceStart = (int) (positions[0] >>> 32);
  2849. switch (this.ast.apiLevel) {
  2850. case AST.JLS2_INTERNAL: {
  2851. char[][] name = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedTypeReference) typeReference)
  2852. .getTypeName();
  2853. int nameLength = name.length;
  2854. sourceStart = (int) (positions[0] >>> 32);
  2855. length = (int) (positions[nameLength - 1] & 0xFFFFFFFF) - sourceStart + 1;
  2856. Name qualifiedName = this.setQualifiedNameNameAndSourceRanges(name, positions, typeReference);
  2857. final SimpleType simpleType = new SimpleType(this.ast);
  2858. simpleType.setName(qualifiedName);
  2859. simpleType.setSourceRange(sourceStart, length);
  2860. type = simpleType;
  2861. }
  2862. break;
  2863. case AST.JLS3:
  2864. if (typeArguments != null) {
  2865. int numberOfEnclosingType = 0;
  2866. int startingIndex = 0;
  2867. int endingIndex = 0;
  2868. for (int i = 0, max = typeArguments.length; i < max; i++) {
  2869. if (typeArguments[i] != null) {
  2870. numberOfEnclosingType++;
  2871. } else if (numberOfEnclosingType == 0) {
  2872. endingIndex++;
  2873. }
  2874. }
  2875. Name name = null;
  2876. if (endingIndex - startingIndex == 0) {
  2877. final SimpleName simpleName = new SimpleName(this.ast);
  2878. simpleName.internalSetIdentifier(new String(tokens[startingIndex]));
  2879. recordPendingNameScopeResolution(simpleName);
  2880. int start = (int) (positions[startingIndex] >>> 32);
  2881. int end = (int) positions[startingIndex];
  2882. simpleName.setSourceRange(start, end - start + 1);
  2883. simpleName.index = 1;
  2884. name = simpleName;
  2885. if (this.resolveBindings) {
  2886. recordNodes(simpleName, typeReference);
  2887. }
  2888. } else {
  2889. name = this.setQualifiedNameNameAndSourceRanges(tokens, positions, endingIndex, typeReference);
  2890. }
  2891. SimpleType simpleType = new SimpleType(this.ast);
  2892. simpleType.setName(name);
  2893. int start = (int) (positions[startingIndex] >>> 32);
  2894. int end = (int) positions[endingIndex];
  2895. simpleType.setSourceRange(start, end - start + 1);
  2896. ParameterizedType parameterizedType = new ParameterizedType(this.ast);
  2897. parameterizedType.setType(simpleType);
  2898. if (this.resolveBindings) {
  2899. recordNodes(simpleType, typeReference);
  2900. recordNodes(parameterizedType, typeReference);
  2901. }
  2902. start = simpleType.getStartPosition();
  2903. end = start + simpleType.getLength() - 1;
  2904. for (int i = 0, max = typeArguments[endingIndex].length; i < max; i++) {
  2905. final Type type2 = convertType(typeArguments[endingIndex][i]);
  2906. parameterizedType.typeArguments().add(type2);
  2907. end = type2.getStartPosition() + type2.getLength() - 1;
  2908. }
  2909. int indexOfEnclosingType = 1;
  2910. parameterizedType.index = indexOfEnclosingType;
  2911. end = retrieveClosingAngleBracketPosition(end + 1);
  2912. length = end + 1;
  2913. parameterizedType.setSourceRange(start, end - start + 1);
  2914. startingIndex = endingIndex + 1;
  2915. Type currentType = parameterizedType;
  2916. while (startingIndex < typeArguments.length) {
  2917. SimpleName simpleName = new SimpleName(this.ast);
  2918. simpleName.internalSetIdentifier(new String(tokens[startingIndex]));
  2919. simpleName.index = startingIndex + 1;
  2920. start = (int) (positions[startingIndex] >>> 32);
  2921. end = (int) positions[startingIndex];
  2922. simpleName.setSourceRange(start, end - start + 1);
  2923. recordPendingNameScopeResolution(simpleName);
  2924. QualifiedType qualifiedType = new QualifiedType(this.ast);
  2925. qualifiedType.setQualifier(currentType);
  2926. qualifiedType.setName(simpleName);
  2927. if (this.resolveBindings) {
  2928. recordNodes(simpleName, typeReference);
  2929. recordNodes(qualifiedType, typeReference);
  2930. }
  2931. start = currentType.getStartPosition();
  2932. end = simpleName.getStartPosition() + simpleName.getLength() - 1;
  2933. qualifiedType.setSourceRange(start, end - start + 1);
  2934. indexOfEnclosingType++;
  2935. if (typeArguments[startingIndex] != null) {
  2936. qualifiedType.index = indexOfEnclosingType;
  2937. ParameterizedType parameterizedType2 = new ParameterizedType(this.ast);
  2938. parameterizedType2.setType(qualifiedType);
  2939. parameterizedType2.index = indexOfEnclosingType;
  2940. if (this.resolveBindings) {
  2941. recordNodes(parameterizedType2, typeReference);
  2942. }
  2943. for (int i = 0, max = typeArguments[startingIndex].length; i < max; i++) {
  2944. final Type type2 = convertType(typeArguments[startingIndex][i]);
  2945. parameterizedType2.typeArguments().add(type2);
  2946. end = type2.getStartPosition() + type2.getLength() - 1;
  2947. }
  2948. end = retrieveClosingAngleBracketPosition(end + 1);
  2949. length = end + 1;
  2950. parameterizedType2.setSourceRange(start, end - start + 1);
  2951. currentType = parameterizedType2;
  2952. } else {
  2953. currentType = qualifiedType;
  2954. qualifiedType.index = indexOfEnclosingType;
  2955. }
  2956. startingIndex++;
  2957. }
  2958. if (this.resolveBindings) {
  2959. this.recordNodes(currentType, typeReference);
  2960. }
  2961. type = currentType;
  2962. length -= sourceStart;
  2963. }
  2964. }
  2965. } else {
  2966. char[][] name = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedTypeReference) typeReference)
  2967. .getTypeName();
  2968. int nameLength = name.length;
  2969. long[] positions = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.QualifiedTypeReference) typeReference).sourcePositions;
  2970. sourceStart = (int) (positions[0] >>> 32);
  2971. length = (int) (positions[nameLength - 1] & 0xFFFFFFFF) - sourceStart + 1;
  2972. final Name qualifiedName = this.setQualifiedNameNameAndSourceRanges(name, positions, typeReference);
  2973. final SimpleType simpleType = new SimpleType(this.ast);
  2974. simpleType.setName(qualifiedName);
  2975. type = simpleType;
  2976. type.setSourceRange(sourceStart, length);
  2977. }
  2978. if (dimensions != 0) {
  2979. type = this.ast.newArrayType(type, dimensions);
  2980. if (this.resolveBindings) {
  2981. completeRecord((ArrayType) type, typeReference);
  2982. }
  2983. int end = retrieveEndOfDimensionsPosition(sourceStart + length, this.compilationUnitSourceLength);
  2984. if (end != -1) {
  2985. type.setSourceRange(sourceStart, end - sourceStart + 1);
  2986. } else {
  2987. type.setSourceRange(sourceStart, length);
  2988. }
  2989. ArrayType subarrayType = (ArrayType) type;
  2990. int index = dimensions - 1;
  2991. while (index > 0) {
  2992. subarrayType = (ArrayType) subarrayType.getComponentType();
  2993. end = retrieveProperRightBracketPosition(index, sourceStart);
  2994. subarrayType.setSourceRange(sourceStart, end - sourceStart + 1);
  2995. index--;
  2996. }
  2997. }
  2998. }
  2999. if (this.resolveBindings) {
  3000. this.recordNodes(type, typeReference);
  3001. }
  3002. return type;
  3003. }
  3004. protected Comment createComment(int[] positions) {
  3005. // Create comment node
  3006. Comment comment = null;
  3007. int start = positions[0];
  3008. int end = positions[1];
  3009. if (positions[1] > 0) { // Javadoc comments have positive end position
  3010. Javadoc docComment = this.docParser.parse(positions);
  3011. if (docComment == null) {
  3012. return null;
  3013. }
  3014. comment = docComment;
  3015. } else {
  3016. end = -end;
  3017. if (positions[0] > 0) { // Block comment have positive start position
  3018. comment = new BlockComment(this.ast);
  3019. } else { // Line comment have negative start and end position
  3020. start = -start;
  3021. comment = new LineComment(this.ast);
  3022. }
  3023. comment.setSourceRange(start, end - start);
  3024. }
  3025. return comment;
  3026. }
  3027. protected Statement createFakeEmptyStatement(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Statement statement) {
  3028. EmptyStatement emptyStatement = new EmptyStatement(this.ast);
  3029. emptyStatement.setFlags(emptyStatement.getFlags() | ASTNode.MALFORMED);
  3030. int start = statement.sourceStart;
  3031. int end = statement.sourceEnd;
  3032. emptyStatement.setSourceRange(start, end - start + 1);
  3033. return emptyStatement;
  3034. }
  3035. /**
  3036. * @return a new modifier
  3037. */
  3038. private Modifier createModifier(ModifierKeyword keyword) {
  3039. final Modifier modifier = new Modifier(this.ast);
  3040. modifier.setKeyword(keyword);
  3041. int start = this.scanner.getCurrentTokenStartPosition();
  3042. int end = this.scanner.getCurrentTokenEndPosition();
  3043. modifier.setSourceRange(start, end - start + 1);
  3044. return modifier;
  3045. }
  3046. protected InfixExpression.Operator getOperatorFor(int operatorID) {
  3047. switch (operatorID) {
  3048. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.EQUAL_EQUAL:
  3049. return InfixExpression.Operator.EQUALS;
  3050. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.LESS_EQUAL:
  3051. return InfixExpression.Operator.LESS_EQUALS;
  3052. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.GREATER_EQUAL:
  3053. return InfixExpression.Operator.GREATER_EQUALS;
  3054. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.NOT_EQUAL:
  3055. return InfixExpression.Operator.NOT_EQUALS;
  3056. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.LEFT_SHIFT:
  3057. return InfixExpression.Operator.LEFT_SHIFT;
  3058. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.RIGHT_SHIFT:
  3059. return InfixExpression.Operator.RIGHT_SHIFT_SIGNED;
  3060. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.UNSIGNED_RIGHT_SHIFT:
  3061. return InfixExpression.Operator.RIGHT_SHIFT_UNSIGNED;
  3062. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.OR_OR:
  3063. return InfixExpression.Operator.CONDITIONAL_OR;
  3064. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.AND_AND:
  3065. return InfixExpression.Operator.CONDITIONAL_AND;
  3066. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.PLUS:
  3067. return InfixExpression.Operator.PLUS;
  3068. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MINUS:
  3069. return InfixExpression.Operator.MINUS;
  3070. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.REMAINDER:
  3071. return InfixExpression.Operator.REMAINDER;
  3072. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.XOR:
  3073. return InfixExpression.Operator.XOR;
  3074. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.AND:
  3075. return InfixExpression.Operator.AND;
  3076. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.MULTIPLY:
  3077. return InfixExpression.Operator.TIMES;
  3078. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.OR:
  3079. return InfixExpression.Operator.OR;
  3080. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.DIVIDE:
  3081. return InfixExpression.Operator.DIVIDE;
  3082. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.GREATER:
  3083. return InfixExpression.Operator.GREATER;
  3084. case org.aspectj.org.eclipse.jdt.internal.compiler.ast.OperatorIds.LESS:
  3085. return InfixExpression.Operator.LESS;
  3086. }
  3087. return null;
  3088. }
  3089. protected PrimitiveType.Code getPrimitiveTypeCode(char[] name) {
  3090. switch (name[0]) {
  3091. case 'i':
  3092. if (name.length == 3 && name[1] == 'n' && name[2] == 't') {
  3093. return PrimitiveType.INT;
  3094. }
  3095. break;
  3096. case 'l':
  3097. if (name.length == 4 && name[1] == 'o' && name[2] == 'n' && name[3] == 'g') {
  3098. return PrimitiveType.LONG;
  3099. }
  3100. break;
  3101. case 'd':
  3102. if (name.length == 6 && name[1] == 'o' && name[2] == 'u' && name[3] == 'b' && name[4] == 'l' && name[5] == 'e') {
  3103. return PrimitiveType.DOUBLE;
  3104. }
  3105. break;
  3106. case 'f':
  3107. if (name.length == 5 && name[1] == 'l' && name[2] == 'o' && name[3] == 'a' && name[4] == 't') {
  3108. return PrimitiveType.FLOAT;
  3109. }
  3110. break;
  3111. case 'b':
  3112. if (name.length == 4 && name[1] == 'y' && name[2] == 't' && name[3] == 'e') {
  3113. return PrimitiveType.BYTE;
  3114. } else if (name.length == 7 && name[1] == 'o' && name[2] == 'o' && name[3] == 'l' && name[4] == 'e' && name[5] == 'a'
  3115. && name[6] == 'n') {
  3116. return PrimitiveType.BOOLEAN;
  3117. }
  3118. break;
  3119. case 'c':
  3120. if (name.length == 4 && name[1] == 'h' && name[2] == 'a' && name[3] == 'r') {
  3121. return PrimitiveType.CHAR;
  3122. }
  3123. break;
  3124. case 's':
  3125. if (name.length == 5 && name[1] == 'h' && name[2] == 'o' && name[3] == 'r' && name[4] == 't') {
  3126. return PrimitiveType.SHORT;
  3127. }
  3128. break;
  3129. case 'v':
  3130. if (name.length == 4 && name[1] == 'o' && name[2] == 'i' && name[3] == 'd') {
  3131. return PrimitiveType.VOID;
  3132. }
  3133. }
  3134. return null; // cannot be reached
  3135. }
  3136. protected boolean isPrimitiveType(char[] name) {
  3137. switch (name[0]) {
  3138. case 'i':
  3139. if (name.length == 3 && name[1] == 'n' && name[2] == 't') {
  3140. return true;
  3141. }
  3142. return false;
  3143. case 'l':
  3144. if (name.length == 4 && name[1] == 'o' && name[2] == 'n' && name[3] == 'g') {
  3145. return true;
  3146. }
  3147. return false;
  3148. case 'd':
  3149. if (name.length == 6 && name[1] == 'o' && name[2] == 'u' && name[3] == 'b' && name[4] == 'l' && name[5] == 'e') {
  3150. return true;
  3151. }
  3152. return false;
  3153. case 'f':
  3154. if (name.length == 5 && name[1] == 'l' && name[2] == 'o' && name[3] == 'a' && name[4] == 't') {
  3155. return true;
  3156. }
  3157. return false;
  3158. case 'b':
  3159. if (name.length == 4 && name[1] == 'y' && name[2] == 't' && name[3] == 'e') {
  3160. return true;
  3161. } else if (name.length == 7 && name[1] == 'o' && name[2] == 'o' && name[3] == 'l' && name[4] == 'e' && name[5] == 'a'
  3162. && name[6] == 'n') {
  3163. return true;
  3164. }
  3165. return false;
  3166. case 'c':
  3167. if (name.length == 4 && name[1] == 'h' && name[2] == 'a' && name[3] == 'r') {
  3168. return true;
  3169. }
  3170. return false;
  3171. case 's':
  3172. if (name.length == 5 && name[1] == 'h' && name[2] == 'o' && name[3] == 'r' && name[4] == 't') {
  3173. return true;
  3174. }
  3175. return false;
  3176. case 'v':
  3177. if (name.length == 4 && name[1] == 'o' && name[2] == 'i' && name[3] == 'd') {
  3178. return true;
  3179. }
  3180. return false;
  3181. }
  3182. return false;
  3183. }
  3184. private void lookupForScopes() {
  3185. if (this.pendingNameScopeResolution != null) {
  3186. for (Iterator iterator = this.pendingNameScopeResolution.iterator(); iterator.hasNext();) {
  3187. Name name = (Name) iterator.next();
  3188. this.ast.getBindingResolver().recordScope(name, lookupScope(name));
  3189. }
  3190. }
  3191. if (this.pendingThisExpressionScopeResolution != null) {
  3192. for (Iterator iterator = this.pendingThisExpressionScopeResolution.iterator(); iterator.hasNext();) {
  3193. ThisExpression thisExpression = (ThisExpression) iterator.next();
  3194. this.ast.getBindingResolver().recordScope(thisExpression, lookupScope(thisExpression));
  3195. }
  3196. }
  3197. }
  3198. private BlockScope lookupScope(ASTNode node) {
  3199. ASTNode currentNode = node;
  3200. while (currentNode != null && !(currentNode instanceof MethodDeclaration) && !(currentNode instanceof Initializer)
  3201. && !(currentNode instanceof FieldDeclaration)) {
  3202. currentNode = currentNode.getParent();
  3203. }
  3204. if (currentNode == null) {
  3205. return null;
  3206. }
  3207. if (currentNode instanceof Initializer) {
  3208. Initializer initializer = (Initializer) currentNode;
  3209. while (!(currentNode instanceof AbstractTypeDeclaration)) {
  3210. currentNode = currentNode.getParent();
  3211. }
  3212. if (currentNode instanceof TypeDeclaration || currentNode instanceof EnumDeclaration
  3213. || currentNode instanceof AnnotationTypeDeclaration) {
  3214. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration typeDecl = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration) this.ast
  3215. .getBindingResolver().getCorrespondingNode(currentNode);
  3216. if ((initializer.getModifiers() & Modifier.STATIC) != 0) {
  3217. return typeDecl.staticInitializerScope;
  3218. } else {
  3219. return typeDecl.initializerScope;
  3220. }
  3221. }
  3222. } else if (currentNode instanceof FieldDeclaration) {
  3223. FieldDeclaration fieldDeclaration = (FieldDeclaration) currentNode;
  3224. while (!(currentNode instanceof AbstractTypeDeclaration)) {
  3225. currentNode = currentNode.getParent();
  3226. }
  3227. if (currentNode instanceof TypeDeclaration || currentNode instanceof EnumDeclaration
  3228. || currentNode instanceof AnnotationTypeDeclaration) {
  3229. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration typeDecl = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration) this.ast
  3230. .getBindingResolver().getCorrespondingNode(currentNode);
  3231. if ((fieldDeclaration.getModifiers() & Modifier.STATIC) != 0) {
  3232. return typeDecl.staticInitializerScope;
  3233. } else {
  3234. return typeDecl.initializerScope;
  3235. }
  3236. }
  3237. }
  3238. AbstractMethodDeclaration abstractMethodDeclaration = (AbstractMethodDeclaration) this.ast.getBindingResolver()
  3239. .getCorrespondingNode(currentNode);
  3240. return abstractMethodDeclaration.scope;
  3241. }
  3242. protected void recordName(Name name, org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode compilerNode) {
  3243. if (compilerNode != null) {
  3244. recordNodes(name, compilerNode);
  3245. if (compilerNode instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) {
  3246. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeRef = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) compilerNode;
  3247. if (name.isQualifiedName()) {
  3248. SimpleName simpleName = null;
  3249. while (name.isQualifiedName()) {
  3250. simpleName = ((QualifiedName) name).getName();
  3251. recordNodes(simpleName, typeRef);
  3252. name = ((QualifiedName) name).getQualifier();
  3253. recordNodes(name, typeRef);
  3254. }
  3255. }
  3256. }
  3257. }
  3258. }
  3259. protected void recordNodes(ASTNode node, org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode oldASTNode) {
  3260. this.ast.getBindingResolver().store(node, oldASTNode);
  3261. }
  3262. protected void recordNodes(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Javadoc javadoc, TagElement tagElement) {
  3263. Iterator fragments = tagElement.fragments().listIterator();
  3264. while (fragments.hasNext()) {
  3265. ASTNode node = (ASTNode) fragments.next();
  3266. if (node.getNodeType() == ASTNode.MEMBER_REF) {
  3267. MemberRef memberRef = (MemberRef) node;
  3268. Name name = memberRef.getName();
  3269. // get compiler node and record nodes
  3270. int start = name.getStartPosition();
  3271. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode compilerNode = javadoc.getNodeStartingAt(start);
  3272. if (compilerNode != null) {
  3273. recordNodes(name, compilerNode);
  3274. recordNodes(node, compilerNode);
  3275. }
  3276. // Replace qualifier to have all nodes recorded
  3277. if (memberRef.getQualifier() != null) {
  3278. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeRef = null;
  3279. if (compilerNode instanceof JavadocFieldReference) {
  3280. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression expression = ((JavadocFieldReference) compilerNode).receiver;
  3281. if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) {
  3282. typeRef = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) expression;
  3283. }
  3284. } else if (compilerNode instanceof JavadocMessageSend) {
  3285. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression expression = ((JavadocMessageSend) compilerNode).receiver;
  3286. if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) {
  3287. typeRef = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) expression;
  3288. }
  3289. }
  3290. if (typeRef != null) {
  3291. recordName(memberRef.getQualifier(), typeRef);
  3292. }
  3293. }
  3294. } else if (node.getNodeType() == ASTNode.METHOD_REF) {
  3295. MethodRef methodRef = (MethodRef) node;
  3296. Name name = methodRef.getName();
  3297. // get compiler node and record nodes
  3298. int start = name.getStartPosition();
  3299. // get compiler node and record nodes
  3300. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode compilerNode = javadoc.getNodeStartingAt(start);
  3301. // record nodes
  3302. if (compilerNode != null) {
  3303. recordNodes(methodRef, compilerNode);
  3304. // get type ref
  3305. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeRef = null;
  3306. if (compilerNode instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.JavadocAllocationExpression) {
  3307. typeRef = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.JavadocAllocationExpression) compilerNode).type;
  3308. if (typeRef != null) {
  3309. recordNodes(name, compilerNode);
  3310. }
  3311. } else if (compilerNode instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.JavadocMessageSend) {
  3312. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression expression = ((org.aspectj.org.eclipse.jdt.internal.compiler.ast.JavadocMessageSend) compilerNode).receiver;
  3313. if (expression instanceof org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) {
  3314. typeRef = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference) expression;
  3315. }
  3316. // TODO (frederic) remove following line to fix bug https://bugs.eclipse.org/bugs/show_bug.cgi?id=62650
  3317. recordNodes(name, compilerNode);
  3318. }
  3319. // record name and qualifier
  3320. if (typeRef != null && methodRef.getQualifier() != null) {
  3321. recordName(methodRef.getQualifier(), typeRef);
  3322. }
  3323. }
  3324. // Resolve parameters
  3325. Iterator parameters = methodRef.parameters().listIterator();
  3326. while (parameters.hasNext()) {
  3327. MethodRefParameter param = (MethodRefParameter) parameters.next();
  3328. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression expression = (org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression) javadoc
  3329. .getNodeStartingAt(param.getStartPosition());
  3330. if (expression != null) {
  3331. recordNodes(param, expression);
  3332. if (expression instanceof JavadocArgumentExpression) {
  3333. JavadocArgumentExpression argExpr = (JavadocArgumentExpression) expression;
  3334. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeReference typeRef = argExpr.argument.type;
  3335. if (this.ast.apiLevel >= AST.JLS3) {
  3336. param.setVarargs(argExpr.argument.isVarArgs());
  3337. }
  3338. recordNodes(param.getType(), typeRef);
  3339. if (param.getType().isSimpleType()) {
  3340. recordName(((SimpleType) param.getType()).getName(), typeRef);
  3341. } else if (param.getType().isArrayType()) {
  3342. Type type = ((ArrayType) param.getType()).getElementType();
  3343. recordNodes(type, typeRef);
  3344. if (type.isSimpleType()) {
  3345. recordName(((SimpleType) type).getName(), typeRef);
  3346. }
  3347. }
  3348. }
  3349. }
  3350. }
  3351. } else if (node.getNodeType() == ASTNode.SIMPLE_NAME || node.getNodeType() == ASTNode.QUALIFIED_NAME) {
  3352. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode compilerNode = javadoc.getNodeStartingAt(node
  3353. .getStartPosition());
  3354. recordName((Name) node, compilerNode);
  3355. } else if (node.getNodeType() == ASTNode.TAG_ELEMENT) {
  3356. // resolve member and method references binding
  3357. recordNodes(javadoc, (TagElement) node);
  3358. }
  3359. }
  3360. }
  3361. protected void recordPendingNameScopeResolution(Name name) {
  3362. if (this.pendingNameScopeResolution == null) {
  3363. this.pendingNameScopeResolution = new HashSet();
  3364. }
  3365. this.pendingNameScopeResolution.add(name);
  3366. }
  3367. protected void recordPendingThisExpressionScopeResolution(ThisExpression thisExpression) {
  3368. if (this.pendingThisExpressionScopeResolution == null) {
  3369. this.pendingThisExpressionScopeResolution = new HashSet();
  3370. }
  3371. this.pendingThisExpressionScopeResolution.add(thisExpression);
  3372. }
  3373. // /**
  3374. // * Remove whitespaces and comments before and after the expression.
  3375. // */
  3376. // private void trimWhiteSpacesAndComments(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Expression expression) {
  3377. // int start = expression.sourceStart;
  3378. // int end = expression.sourceEnd;
  3379. // int token;
  3380. // int trimLeftPosition = expression.sourceStart;
  3381. // int trimRightPosition = expression.sourceEnd;
  3382. // boolean first = true;
  3383. // Scanner removeBlankScanner = this.ast.scanner;
  3384. // try {
  3385. // removeBlankScanner.setSource(this.compilationUnitSource);
  3386. // removeBlankScanner.resetTo(start, end);
  3387. // while (true) {
  3388. // token = removeBlankScanner.getNextToken();
  3389. // switch (token) {
  3390. // case TerminalTokens.TokenNameCOMMENT_JAVADOC :
  3391. // case TerminalTokens.TokenNameCOMMENT_LINE :
  3392. // case TerminalTokens.TokenNameCOMMENT_BLOCK :
  3393. // if (first) {
  3394. // trimLeftPosition = removeBlankScanner.currentPosition;
  3395. // }
  3396. // break;
  3397. // case TerminalTokens.TokenNameWHITESPACE :
  3398. // if (first) {
  3399. // trimLeftPosition = removeBlankScanner.currentPosition;
  3400. // }
  3401. // break;
  3402. // case TerminalTokens.TokenNameEOF :
  3403. // expression.sourceStart = trimLeftPosition;
  3404. // expression.sourceEnd = trimRightPosition;
  3405. // return;
  3406. // default :
  3407. // /*
  3408. // * if we find something else than a whitespace or a comment,
  3409. // * then we reset the trimRigthPosition to the expression
  3410. // * source end.
  3411. // */
  3412. // trimRightPosition = removeBlankScanner.currentPosition - 1;
  3413. // first = false;
  3414. // }
  3415. // }
  3416. // } catch (InvalidInputException e){
  3417. // // ignore
  3418. // }
  3419. // }
  3420. protected int retrieveEndingSemiColonPosition(int start, int end) {
  3421. int count = 0;
  3422. this.scanner.resetTo(start, end);
  3423. try {
  3424. int token;
  3425. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3426. switch (token) {
  3427. case TerminalTokens.TokenNameSEMICOLON:
  3428. if (count == 0) {
  3429. return this.scanner.currentPosition - 1;
  3430. }
  3431. break;
  3432. case TerminalTokens.TokenNameLBRACE:
  3433. count++;
  3434. break;
  3435. case TerminalTokens.TokenNameRBRACE:
  3436. count--;
  3437. break;
  3438. case TerminalTokens.TokenNameLPAREN:
  3439. count++;
  3440. break;
  3441. case TerminalTokens.TokenNameRPAREN:
  3442. count--;
  3443. break;
  3444. case TerminalTokens.TokenNameLBRACKET:
  3445. count++;
  3446. break;
  3447. case TerminalTokens.TokenNameRBRACKET:
  3448. count--;
  3449. }
  3450. }
  3451. } catch (InvalidInputException e) {
  3452. // ignore
  3453. }
  3454. return -1;
  3455. }
  3456. /**
  3457. * This method is used to retrieve the ending position for a type declaration when the dimension is right after the type name.
  3458. * For example: int[] i; => return 5, but int i[] => return -1;
  3459. *
  3460. * @return int the dimension found
  3461. */
  3462. protected int retrieveEndOfDimensionsPosition(int start, int end) {
  3463. this.scanner.resetTo(start, end);
  3464. int foundPosition = -1;
  3465. try {
  3466. int token;
  3467. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3468. switch (token) {
  3469. case TerminalTokens.TokenNameLBRACKET:
  3470. case TerminalTokens.TokenNameCOMMENT_BLOCK:
  3471. case TerminalTokens.TokenNameCOMMENT_JAVADOC:
  3472. case TerminalTokens.TokenNameCOMMENT_LINE:
  3473. break;
  3474. case TerminalTokens.TokenNameRBRACKET:// 166
  3475. foundPosition = this.scanner.currentPosition - 1;
  3476. break;
  3477. default:
  3478. return foundPosition;
  3479. }
  3480. }
  3481. } catch (InvalidInputException e) {
  3482. // ignore
  3483. }
  3484. return foundPosition;
  3485. }
  3486. /**
  3487. * This method is used to retrieve the position just before the left bracket.
  3488. *
  3489. * @return int the dimension found, -1 if none
  3490. */
  3491. protected int retrieveEndOfElementTypeNamePosition(int start, int end) {
  3492. this.scanner.resetTo(start, end);
  3493. try {
  3494. int token;
  3495. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3496. switch (token) {
  3497. case TerminalTokens.TokenNameIdentifier:
  3498. case TerminalTokens.TokenNamebyte:
  3499. case TerminalTokens.TokenNamechar:
  3500. case TerminalTokens.TokenNamedouble:
  3501. case TerminalTokens.TokenNamefloat:
  3502. case TerminalTokens.TokenNameint:
  3503. case TerminalTokens.TokenNamelong:
  3504. case TerminalTokens.TokenNameshort:
  3505. case TerminalTokens.TokenNameboolean:
  3506. return this.scanner.currentPosition - 1;
  3507. }
  3508. }
  3509. } catch (InvalidInputException e) {
  3510. // ignore
  3511. }
  3512. return -1;
  3513. }
  3514. /**
  3515. * This method is used to retrieve the position after the right parenthesis.
  3516. *
  3517. * @return int the position found
  3518. */
  3519. protected int retrieveEndOfRightParenthesisPosition(int start, int end) {
  3520. this.scanner.resetTo(start, end);
  3521. try {
  3522. int token;
  3523. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3524. switch (token) {
  3525. case TerminalTokens.TokenNameRPAREN:
  3526. return this.scanner.currentPosition;
  3527. }
  3528. }
  3529. } catch (InvalidInputException e) {
  3530. // ignore
  3531. }
  3532. return -1;
  3533. }
  3534. /**
  3535. * This method is used to retrieve the array dimension declared after the name of a local or a field declaration. For example:
  3536. * int i, j[] = null, k[][] = {{}}; It should return 0 for i, 1 for j and 2 for k.
  3537. *
  3538. * @return int the dimension found
  3539. */
  3540. protected int retrieveExtraDimension(int start, int end) {
  3541. this.scanner.resetTo(start, end);
  3542. int dimensions = 0;
  3543. try {
  3544. int token;
  3545. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3546. switch (token) {
  3547. case TerminalTokens.TokenNameLBRACKET:
  3548. case TerminalTokens.TokenNameCOMMENT_BLOCK:
  3549. case TerminalTokens.TokenNameCOMMENT_JAVADOC:
  3550. case TerminalTokens.TokenNameCOMMENT_LINE:
  3551. break;
  3552. case TerminalTokens.TokenNameRBRACKET:// 166
  3553. dimensions++;
  3554. break;
  3555. default:
  3556. return dimensions;
  3557. }
  3558. }
  3559. } catch (InvalidInputException e) {
  3560. // ignore
  3561. }
  3562. return dimensions;
  3563. }
  3564. protected void retrieveIdentifierAndSetPositions(int start, int end, Name name) {
  3565. this.scanner.resetTo(start, end);
  3566. int token;
  3567. try {
  3568. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3569. if (token == TerminalTokens.TokenNameIdentifier) {
  3570. int startName = this.scanner.startPosition;
  3571. int endName = this.scanner.currentPosition - 1;
  3572. name.setSourceRange(startName, endName - startName + 1);
  3573. return;
  3574. }
  3575. }
  3576. } catch (InvalidInputException e) {
  3577. // ignore
  3578. }
  3579. }
  3580. /**
  3581. * This method is used to retrieve the start position of the block.
  3582. *
  3583. * @return int the dimension found, -1 if none
  3584. */
  3585. protected int retrieveIdentifierEndPosition(int start, int end) {
  3586. this.scanner.resetTo(start, end);
  3587. try {
  3588. int token;
  3589. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3590. switch (token) {
  3591. case TerminalTokens.TokenNameIdentifier:// 110
  3592. return this.scanner.getCurrentTokenEndPosition();
  3593. }
  3594. }
  3595. } catch (InvalidInputException e) {
  3596. // ignore
  3597. }
  3598. return -1;
  3599. }
  3600. /**
  3601. * This method is used to retrieve position before the next comma or semi-colon.
  3602. *
  3603. * @return int the position found.
  3604. */
  3605. protected int retrievePositionBeforeNextCommaOrSemiColon(int start, int end) {
  3606. this.scanner.resetTo(start, end);
  3607. int braceCounter = 0;
  3608. try {
  3609. int token;
  3610. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3611. switch (token) {
  3612. case TerminalTokens.TokenNameLBRACE:
  3613. braceCounter++;
  3614. break;
  3615. case TerminalTokens.TokenNameRBRACE:
  3616. braceCounter--;
  3617. break;
  3618. case TerminalTokens.TokenNameLPAREN:
  3619. braceCounter++;
  3620. break;
  3621. case TerminalTokens.TokenNameRPAREN:
  3622. braceCounter--;
  3623. break;
  3624. case TerminalTokens.TokenNameLBRACKET:
  3625. braceCounter++;
  3626. break;
  3627. case TerminalTokens.TokenNameRBRACKET:
  3628. braceCounter--;
  3629. break;
  3630. case TerminalTokens.TokenNameCOMMA:
  3631. case TerminalTokens.TokenNameSEMICOLON:
  3632. if (braceCounter == 0) {
  3633. return this.scanner.startPosition - 1;
  3634. }
  3635. }
  3636. }
  3637. } catch (InvalidInputException e) {
  3638. // ignore
  3639. }
  3640. return -1;
  3641. }
  3642. protected int retrieveProperRightBracketPosition(int bracketNumber, int start) {
  3643. this.scanner.resetTo(start, this.compilationUnitSourceLength);
  3644. try {
  3645. int token, count = 0;
  3646. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3647. switch (token) {
  3648. case TerminalTokens.TokenNameRBRACKET:
  3649. count++;
  3650. if (count == bracketNumber) {
  3651. return this.scanner.currentPosition - 1;
  3652. }
  3653. }
  3654. }
  3655. } catch (InvalidInputException e) {
  3656. // ignore
  3657. }
  3658. return -1;
  3659. }
  3660. /**
  3661. * This method is used to retrieve position before the next right brace or semi-colon.
  3662. *
  3663. * @return int the position found.
  3664. */
  3665. protected int retrieveRightBraceOrSemiColonPosition(int start, int end) {
  3666. this.scanner.resetTo(start, end);
  3667. try {
  3668. int token;
  3669. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3670. switch (token) {
  3671. case TerminalTokens.TokenNameRBRACE:
  3672. return this.scanner.currentPosition - 1;
  3673. case TerminalTokens.TokenNameSEMICOLON:
  3674. return this.scanner.currentPosition - 1;
  3675. }
  3676. }
  3677. } catch (InvalidInputException e) {
  3678. // ignore
  3679. }
  3680. return -1;
  3681. }
  3682. /**
  3683. * This method is used to retrieve position before the next right brace or semi-colon.
  3684. *
  3685. * @return int the position found.
  3686. */
  3687. protected int retrieveRightBrace(int start, int end) {
  3688. this.scanner.resetTo(start, end);
  3689. try {
  3690. int token;
  3691. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3692. switch (token) {
  3693. case TerminalTokens.TokenNameRBRACE:
  3694. return this.scanner.currentPosition - 1;
  3695. }
  3696. }
  3697. } catch (InvalidInputException e) {
  3698. // ignore
  3699. }
  3700. return -1;
  3701. }
  3702. /**
  3703. * This method is used to retrieve the position of the right bracket.
  3704. *
  3705. * @return int the dimension found, -1 if none
  3706. */
  3707. protected int retrieveRightBracketPosition(int start, int end) {
  3708. this.scanner.resetTo(start, end);
  3709. try {
  3710. int token;
  3711. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3712. switch (token) {
  3713. case TerminalTokens.TokenNameRBRACKET:
  3714. return this.scanner.currentPosition - 1;
  3715. }
  3716. }
  3717. } catch (InvalidInputException e) {
  3718. // ignore
  3719. }
  3720. return -1;
  3721. }
  3722. /*
  3723. * This method is used to set the right end position for expression statement. The actual AST nodes don't include the trailing
  3724. * semicolon. This method fixes the length of the corresponding node.
  3725. */
  3726. protected void retrieveSemiColonPosition(ASTNode node) {
  3727. int start = node.getStartPosition();
  3728. int length = node.getLength();
  3729. int end = start + length;
  3730. int count = 0;
  3731. this.scanner.resetTo(end, this.compilationUnitSourceLength);
  3732. try {
  3733. int token;
  3734. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3735. switch (token) {
  3736. case TerminalTokens.TokenNameSEMICOLON:
  3737. if (count == 0) {
  3738. node.setSourceRange(start, this.scanner.currentPosition - start);
  3739. return;
  3740. }
  3741. break;
  3742. case TerminalTokens.TokenNameLBRACE:
  3743. count++;
  3744. break;
  3745. case TerminalTokens.TokenNameRBRACE:
  3746. count--;
  3747. break;
  3748. case TerminalTokens.TokenNameLPAREN:
  3749. count++;
  3750. break;
  3751. case TerminalTokens.TokenNameRPAREN:
  3752. count--;
  3753. break;
  3754. case TerminalTokens.TokenNameLBRACKET:
  3755. count++;
  3756. break;
  3757. case TerminalTokens.TokenNameRBRACKET:
  3758. count--;
  3759. }
  3760. }
  3761. } catch (InvalidInputException e) {
  3762. // ignore
  3763. }
  3764. }
  3765. /**
  3766. * This method is used to retrieve the start position of the block.
  3767. *
  3768. * @return int the dimension found, -1 if none
  3769. */
  3770. protected int retrieveStartBlockPosition(int start, int end) {
  3771. this.scanner.resetTo(start, end);
  3772. try {
  3773. int token;
  3774. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3775. switch (token) {
  3776. case TerminalTokens.TokenNameLBRACE:// 110
  3777. return this.scanner.startPosition;
  3778. }
  3779. }
  3780. } catch (InvalidInputException e) {
  3781. // ignore
  3782. }
  3783. return -1;
  3784. }
  3785. /**
  3786. * This method is used to retrieve the starting position of the catch keyword.
  3787. *
  3788. * @return int the dimension found, -1 if none
  3789. */
  3790. protected int retrieveStartingCatchPosition(int start, int end) {
  3791. this.scanner.resetTo(start, end);
  3792. try {
  3793. int token;
  3794. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3795. switch (token) {
  3796. case TerminalTokens.TokenNamecatch:// 225
  3797. return this.scanner.startPosition;
  3798. }
  3799. }
  3800. } catch (InvalidInputException e) {
  3801. // ignore
  3802. }
  3803. return -1;
  3804. }
  3805. public void setAST(AST ast) {
  3806. this.ast = ast;
  3807. this.docParser = new DocCommentParser(this.ast, this.scanner, this.insideComments);
  3808. }
  3809. protected void setModifiers(AnnotationTypeDeclaration typeDecl,
  3810. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration typeDeclaration) {
  3811. this.scanner.resetTo(typeDeclaration.declarationSourceStart, typeDeclaration.sourceStart);
  3812. this.setModifiers(typeDecl, typeDeclaration.annotations);
  3813. }
  3814. protected void setModifiers(AnnotationTypeMemberDeclaration annotationTypeMemberDecl,
  3815. org.aspectj.org.eclipse.jdt.internal.compiler.ast.AnnotationMethodDeclaration annotationTypeMemberDeclaration) {
  3816. this.scanner.resetTo(annotationTypeMemberDeclaration.declarationSourceStart, annotationTypeMemberDeclaration.sourceStart);
  3817. this.setModifiers(annotationTypeMemberDecl, annotationTypeMemberDeclaration.annotations);
  3818. }
  3819. /**
  3820. * @param bodyDeclaration
  3821. */
  3822. protected void setModifiers(BodyDeclaration bodyDeclaration,
  3823. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation[] annotations) {
  3824. try {
  3825. int token;
  3826. int indexInAnnotations = 0;
  3827. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  3828. IExtendedModifier modifier = null;
  3829. switch (token) {
  3830. case TerminalTokens.TokenNameabstract:
  3831. modifier = createModifier(Modifier.ModifierKeyword.ABSTRACT_KEYWORD);
  3832. break;
  3833. case TerminalTokens.TokenNamepublic:
  3834. modifier = createModifier(Modifier.ModifierKeyword.PUBLIC_KEYWORD);
  3835. break;
  3836. case TerminalTokens.TokenNamestatic:
  3837. modifier = createModifier(Modifier.ModifierKeyword.STATIC_KEYWORD);
  3838. break;
  3839. case TerminalTokens.TokenNameprotected:
  3840. modifier = createModifier(Modifier.ModifierKeyword.PROTECTED_KEYWORD);
  3841. break;
  3842. case TerminalTokens.TokenNameprivate:
  3843. modifier = createModifier(Modifier.ModifierKeyword.PRIVATE_KEYWORD);
  3844. break;
  3845. case TerminalTokens.TokenNamefinal:
  3846. modifier = createModifier(Modifier.ModifierKeyword.FINAL_KEYWORD);
  3847. break;
  3848. case TerminalTokens.TokenNamenative:
  3849. modifier = createModifier(Modifier.ModifierKeyword.NATIVE_KEYWORD);
  3850. break;
  3851. case TerminalTokens.TokenNamesynchronized:
  3852. modifier = createModifier(Modifier.ModifierKeyword.SYNCHRONIZED_KEYWORD);
  3853. break;
  3854. case TerminalTokens.TokenNametransient:
  3855. modifier = createModifier(Modifier.ModifierKeyword.TRANSIENT_KEYWORD);
  3856. break;
  3857. case TerminalTokens.TokenNamevolatile:
  3858. modifier = createModifier(Modifier.ModifierKeyword.VOLATILE_KEYWORD);
  3859. break;
  3860. case TerminalTokens.TokenNamestrictfp:
  3861. modifier = createModifier(Modifier.ModifierKeyword.STRICTFP_KEYWORD);
  3862. break;
  3863. case TerminalTokens.TokenNameAT:
  3864. // we have an annotation
  3865. if (annotations != null && indexInAnnotations < annotations.length) {
  3866. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation annotation = annotations[indexInAnnotations++];
  3867. modifier = super.convert(annotation);
  3868. this.scanner.resetTo(annotation.declarationSourceEnd + 1, this.compilationUnitSourceLength);
  3869. }
  3870. break;
  3871. case TerminalTokens.TokenNameCOMMENT_BLOCK:
  3872. case TerminalTokens.TokenNameCOMMENT_LINE:
  3873. case TerminalTokens.TokenNameCOMMENT_JAVADOC:
  3874. break;
  3875. default:
  3876. return;
  3877. }
  3878. if (modifier != null) {
  3879. bodyDeclaration.modifiers().add(modifier);
  3880. }
  3881. }
  3882. } catch (InvalidInputException e) {
  3883. // ignore
  3884. }
  3885. }
  3886. protected void setModifiers(EnumDeclaration enumDeclaration,
  3887. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration enumDeclaration2) {
  3888. this.scanner.resetTo(enumDeclaration2.declarationSourceStart, enumDeclaration2.sourceStart);
  3889. this.setModifiers(enumDeclaration, enumDeclaration2.annotations);
  3890. }
  3891. protected void setModifiers(EnumConstantDeclaration enumConstantDeclaration,
  3892. org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration fieldDeclaration) {
  3893. switch (this.ast.apiLevel) {
  3894. case AST.JLS2_INTERNAL:
  3895. enumConstantDeclaration.internalSetModifiers(fieldDeclaration.modifiers & ExtraCompilerModifiers.AccJustFlag);
  3896. if (fieldDeclaration.annotations != null) {
  3897. enumConstantDeclaration.setFlags(enumConstantDeclaration.getFlags() | ASTNode.MALFORMED);
  3898. }
  3899. break;
  3900. case AST.JLS3:
  3901. this.scanner.resetTo(fieldDeclaration.declarationSourceStart, fieldDeclaration.sourceStart);
  3902. this.setModifiers(enumConstantDeclaration, fieldDeclaration.annotations);
  3903. }
  3904. }
  3905. /**
  3906. * @param fieldDeclaration
  3907. * @param fieldDecl
  3908. */
  3909. protected void setModifiers(FieldDeclaration fieldDeclaration,
  3910. org.aspectj.org.eclipse.jdt.internal.compiler.ast.FieldDeclaration fieldDecl) {
  3911. switch (this.ast.apiLevel) {
  3912. case AST.JLS2_INTERNAL:
  3913. fieldDeclaration.internalSetModifiers(fieldDecl.modifiers & ExtraCompilerModifiers.AccJustFlag);
  3914. if (fieldDecl.annotations != null) {
  3915. fieldDeclaration.setFlags(fieldDeclaration.getFlags() | ASTNode.MALFORMED);
  3916. }
  3917. break;
  3918. case AST.JLS3:
  3919. this.scanner.resetTo(fieldDecl.declarationSourceStart, fieldDecl.sourceStart);
  3920. this.setModifiers(fieldDeclaration, fieldDecl.annotations);
  3921. }
  3922. }
  3923. protected void setModifiers(org.aspectj.org.eclipse.jdt.core.dom.InterTypeFieldDeclaration fieldDeclaration,
  3924. InterTypeFieldDeclaration fieldDecl) {
  3925. // ajh02: method added
  3926. switch (this.ast.apiLevel) {
  3927. case AST.JLS2_INTERNAL:
  3928. fieldDeclaration.internalSetModifiers(fieldDecl.declaredModifiers & ExtraCompilerModifiers.AccJustFlag);
  3929. if (fieldDecl.annotations != null) {
  3930. fieldDeclaration.setFlags(fieldDeclaration.getFlags() | ASTNode.MALFORMED);
  3931. }
  3932. break;
  3933. case AST.JLS3:
  3934. this.scanner.resetTo(fieldDecl.declarationSourceStart, fieldDecl.sourceStart);
  3935. this.setModifiers(fieldDeclaration, fieldDecl.annotations);
  3936. }
  3937. }
  3938. /**
  3939. * @param initializer
  3940. * @param oldInitializer
  3941. */
  3942. protected void setModifiers(Initializer initializer,
  3943. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Initializer oldInitializer) {
  3944. switch (this.ast.apiLevel) {
  3945. case AST.JLS2_INTERNAL:
  3946. initializer.internalSetModifiers(oldInitializer.modifiers & ExtraCompilerModifiers.AccJustFlag);
  3947. if (oldInitializer.annotations != null) {
  3948. initializer.setFlags(initializer.getFlags() | ASTNode.MALFORMED);
  3949. }
  3950. break;
  3951. case AST.JLS3:
  3952. this.scanner.resetTo(oldInitializer.declarationSourceStart, oldInitializer.bodyStart);
  3953. this.setModifiers(initializer, oldInitializer.annotations);
  3954. }
  3955. }
  3956. /**
  3957. * @param methodDecl
  3958. * @param methodDeclaration
  3959. */
  3960. protected void setModifiers(MethodDeclaration methodDecl, AbstractMethodDeclaration methodDeclaration) {
  3961. switch (this.ast.apiLevel) {
  3962. case AST.JLS2_INTERNAL:
  3963. if (methodDeclaration instanceof InterTypeDeclaration) {
  3964. methodDecl.internalSetModifiers(((InterTypeDeclaration) methodDeclaration).declaredModifiers
  3965. & ExtraCompilerModifiers.AccJustFlag);
  3966. } else {
  3967. methodDecl.internalSetModifiers(methodDeclaration.modifiers & ExtraCompilerModifiers.AccJustFlag);
  3968. }
  3969. if (methodDeclaration.annotations != null) {
  3970. methodDecl.setFlags(methodDecl.getFlags() | ASTNode.MALFORMED);
  3971. }
  3972. break;
  3973. case AST.JLS3:
  3974. this.scanner.resetTo(methodDeclaration.declarationSourceStart, methodDeclaration.sourceStart);
  3975. this.setModifiers(methodDecl, methodDeclaration.annotations);
  3976. }
  3977. }
  3978. protected void setModifiers(org.aspectj.org.eclipse.jdt.core.dom.PointcutDeclaration pointcutDecl,
  3979. PointcutDeclaration pointcutDeclaration) {
  3980. // ajh02: method added
  3981. switch (this.ast.apiLevel) {
  3982. case AST.JLS2_INTERNAL:
  3983. pointcutDecl.internalSetModifiers(pointcutDeclaration.modifiers & ExtraCompilerModifiers.AccJustFlag);
  3984. if (pointcutDeclaration.annotations != null) {
  3985. pointcutDecl.setFlags(pointcutDecl.getFlags() | ASTNode.MALFORMED);
  3986. }
  3987. break;
  3988. case AST.JLS3:
  3989. this.scanner.resetTo(pointcutDeclaration.declarationSourceStart, pointcutDeclaration.sourceStart);
  3990. this.setModifiers(pointcutDecl, pointcutDeclaration.annotations);
  3991. }
  3992. }
  3993. /**
  3994. * @param variableDecl
  3995. * @param argument
  3996. */
  3997. protected void setModifiers(SingleVariableDeclaration variableDecl, Argument argument) {
  3998. switch (this.ast.apiLevel) {
  3999. case AST.JLS2_INTERNAL:
  4000. variableDecl.internalSetModifiers(argument.modifiers & ExtraCompilerModifiers.AccJustFlag);
  4001. if (argument.annotations != null) {
  4002. variableDecl.setFlags(variableDecl.getFlags() | ASTNode.MALFORMED);
  4003. }
  4004. break;
  4005. case AST.JLS3:
  4006. this.scanner.resetTo(argument.declarationSourceStart, argument.sourceStart);
  4007. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation[] annotations = argument.annotations;
  4008. int indexInAnnotations = 0;
  4009. try {
  4010. int token;
  4011. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  4012. IExtendedModifier modifier = null;
  4013. switch (token) {
  4014. case TerminalTokens.TokenNameabstract:
  4015. modifier = createModifier(Modifier.ModifierKeyword.ABSTRACT_KEYWORD);
  4016. break;
  4017. case TerminalTokens.TokenNamepublic:
  4018. modifier = createModifier(Modifier.ModifierKeyword.PUBLIC_KEYWORD);
  4019. break;
  4020. case TerminalTokens.TokenNamestatic:
  4021. modifier = createModifier(Modifier.ModifierKeyword.STATIC_KEYWORD);
  4022. break;
  4023. case TerminalTokens.TokenNameprotected:
  4024. modifier = createModifier(Modifier.ModifierKeyword.PROTECTED_KEYWORD);
  4025. break;
  4026. case TerminalTokens.TokenNameprivate:
  4027. modifier = createModifier(Modifier.ModifierKeyword.PRIVATE_KEYWORD);
  4028. break;
  4029. case TerminalTokens.TokenNamefinal:
  4030. modifier = createModifier(Modifier.ModifierKeyword.FINAL_KEYWORD);
  4031. break;
  4032. case TerminalTokens.TokenNamenative:
  4033. modifier = createModifier(Modifier.ModifierKeyword.NATIVE_KEYWORD);
  4034. break;
  4035. case TerminalTokens.TokenNamesynchronized:
  4036. modifier = createModifier(Modifier.ModifierKeyword.SYNCHRONIZED_KEYWORD);
  4037. break;
  4038. case TerminalTokens.TokenNametransient:
  4039. modifier = createModifier(Modifier.ModifierKeyword.TRANSIENT_KEYWORD);
  4040. break;
  4041. case TerminalTokens.TokenNamevolatile:
  4042. modifier = createModifier(Modifier.ModifierKeyword.VOLATILE_KEYWORD);
  4043. break;
  4044. case TerminalTokens.TokenNamestrictfp:
  4045. modifier = createModifier(Modifier.ModifierKeyword.STRICTFP_KEYWORD);
  4046. break;
  4047. case TerminalTokens.TokenNameAT:
  4048. // we have an annotation
  4049. if (annotations != null && indexInAnnotations < annotations.length) {
  4050. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation annotation = annotations[indexInAnnotations++];
  4051. modifier = super.convert(annotation);
  4052. this.scanner.resetTo(annotation.declarationSourceEnd + 1, this.compilationUnitSourceLength);
  4053. }
  4054. break;
  4055. case TerminalTokens.TokenNameCOMMENT_BLOCK:
  4056. case TerminalTokens.TokenNameCOMMENT_LINE:
  4057. case TerminalTokens.TokenNameCOMMENT_JAVADOC:
  4058. break;
  4059. default:
  4060. return;
  4061. }
  4062. if (modifier != null) {
  4063. variableDecl.modifiers().add(modifier);
  4064. }
  4065. }
  4066. } catch (InvalidInputException e) {
  4067. // ignore
  4068. }
  4069. }
  4070. }
  4071. protected void setModifiers(SingleVariableDeclaration variableDecl, LocalDeclaration localDeclaration) {
  4072. switch (this.ast.apiLevel) {
  4073. case AST.JLS2_INTERNAL:
  4074. variableDecl.internalSetModifiers(localDeclaration.modifiers & ExtraCompilerModifiers.AccJustFlag);
  4075. if (localDeclaration.annotations != null) {
  4076. variableDecl.setFlags(variableDecl.getFlags() | ASTNode.MALFORMED);
  4077. }
  4078. break;
  4079. case AST.JLS3:
  4080. this.scanner.resetTo(localDeclaration.declarationSourceStart, localDeclaration.sourceStart);
  4081. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation[] annotations = localDeclaration.annotations;
  4082. int indexInAnnotations = 0;
  4083. try {
  4084. int token;
  4085. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  4086. IExtendedModifier modifier = null;
  4087. switch (token) {
  4088. case TerminalTokens.TokenNameabstract:
  4089. modifier = createModifier(Modifier.ModifierKeyword.ABSTRACT_KEYWORD);
  4090. break;
  4091. case TerminalTokens.TokenNamepublic:
  4092. modifier = createModifier(Modifier.ModifierKeyword.PUBLIC_KEYWORD);
  4093. break;
  4094. case TerminalTokens.TokenNamestatic:
  4095. modifier = createModifier(Modifier.ModifierKeyword.STATIC_KEYWORD);
  4096. break;
  4097. case TerminalTokens.TokenNameprotected:
  4098. modifier = createModifier(Modifier.ModifierKeyword.PROTECTED_KEYWORD);
  4099. break;
  4100. case TerminalTokens.TokenNameprivate:
  4101. modifier = createModifier(Modifier.ModifierKeyword.PRIVATE_KEYWORD);
  4102. break;
  4103. case TerminalTokens.TokenNamefinal:
  4104. modifier = createModifier(Modifier.ModifierKeyword.FINAL_KEYWORD);
  4105. break;
  4106. case TerminalTokens.TokenNamenative:
  4107. modifier = createModifier(Modifier.ModifierKeyword.NATIVE_KEYWORD);
  4108. break;
  4109. case TerminalTokens.TokenNamesynchronized:
  4110. modifier = createModifier(Modifier.ModifierKeyword.SYNCHRONIZED_KEYWORD);
  4111. break;
  4112. case TerminalTokens.TokenNametransient:
  4113. modifier = createModifier(Modifier.ModifierKeyword.TRANSIENT_KEYWORD);
  4114. break;
  4115. case TerminalTokens.TokenNamevolatile:
  4116. modifier = createModifier(Modifier.ModifierKeyword.VOLATILE_KEYWORD);
  4117. break;
  4118. case TerminalTokens.TokenNamestrictfp:
  4119. modifier = createModifier(Modifier.ModifierKeyword.STRICTFP_KEYWORD);
  4120. break;
  4121. case TerminalTokens.TokenNameAT:
  4122. // we have an annotation
  4123. if (annotations != null && indexInAnnotations < annotations.length) {
  4124. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation annotation = annotations[indexInAnnotations++];
  4125. modifier = super.convert(annotation);
  4126. this.scanner.resetTo(annotation.declarationSourceEnd + 1, this.compilationUnitSourceLength);
  4127. }
  4128. break;
  4129. case TerminalTokens.TokenNameCOMMENT_BLOCK:
  4130. case TerminalTokens.TokenNameCOMMENT_LINE:
  4131. case TerminalTokens.TokenNameCOMMENT_JAVADOC:
  4132. break;
  4133. default:
  4134. return;
  4135. }
  4136. if (modifier != null) {
  4137. variableDecl.modifiers().add(modifier);
  4138. }
  4139. }
  4140. } catch (InvalidInputException e) {
  4141. // ignore
  4142. }
  4143. }
  4144. }
  4145. /**
  4146. * @param typeDecl
  4147. * @param typeDeclaration
  4148. */
  4149. protected void setModifiers(TypeDeclaration typeDecl,
  4150. org.aspectj.org.eclipse.jdt.internal.compiler.ast.TypeDeclaration typeDeclaration) {
  4151. switch (this.ast.apiLevel) {
  4152. case AST.JLS2_INTERNAL:
  4153. int modifiers = typeDeclaration.modifiers;
  4154. modifiers &= ~ClassFileConstants.AccInterface; // remove AccInterface flags
  4155. modifiers &= ExtraCompilerModifiers.AccJustFlag;
  4156. typeDecl.internalSetModifiers(modifiers);
  4157. if (typeDeclaration.annotations != null) {
  4158. typeDecl.setFlags(typeDecl.getFlags() | ASTNode.MALFORMED);
  4159. }
  4160. break;
  4161. case AST.JLS3:
  4162. this.scanner.resetTo(typeDeclaration.declarationSourceStart, typeDeclaration.sourceStart);
  4163. this.setModifiers(typeDecl, typeDeclaration.annotations);
  4164. }
  4165. }
  4166. /**
  4167. * @param variableDeclarationExpression
  4168. * @param localDeclaration
  4169. */
  4170. protected void setModifiers(VariableDeclarationExpression variableDeclarationExpression, LocalDeclaration localDeclaration) {
  4171. switch (this.ast.apiLevel) {
  4172. case AST.JLS2_INTERNAL:
  4173. int modifiers = localDeclaration.modifiers & ExtraCompilerModifiers.AccJustFlag;
  4174. modifiers &= ~ExtraCompilerModifiers.AccBlankFinal;
  4175. variableDeclarationExpression.internalSetModifiers(modifiers);
  4176. if (localDeclaration.annotations != null) {
  4177. variableDeclarationExpression.setFlags(variableDeclarationExpression.getFlags() | ASTNode.MALFORMED);
  4178. }
  4179. break;
  4180. case AST.JLS3:
  4181. this.scanner.resetTo(localDeclaration.declarationSourceStart, localDeclaration.sourceStart);
  4182. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation[] annotations = localDeclaration.annotations;
  4183. int indexInAnnotations = 0;
  4184. try {
  4185. int token;
  4186. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  4187. IExtendedModifier modifier = null;
  4188. switch (token) {
  4189. case TerminalTokens.TokenNameabstract:
  4190. modifier = createModifier(Modifier.ModifierKeyword.ABSTRACT_KEYWORD);
  4191. break;
  4192. case TerminalTokens.TokenNamepublic:
  4193. modifier = createModifier(Modifier.ModifierKeyword.PUBLIC_KEYWORD);
  4194. break;
  4195. case TerminalTokens.TokenNamestatic:
  4196. modifier = createModifier(Modifier.ModifierKeyword.STATIC_KEYWORD);
  4197. break;
  4198. case TerminalTokens.TokenNameprotected:
  4199. modifier = createModifier(Modifier.ModifierKeyword.PROTECTED_KEYWORD);
  4200. break;
  4201. case TerminalTokens.TokenNameprivate:
  4202. modifier = createModifier(Modifier.ModifierKeyword.PRIVATE_KEYWORD);
  4203. break;
  4204. case TerminalTokens.TokenNamefinal:
  4205. modifier = createModifier(Modifier.ModifierKeyword.FINAL_KEYWORD);
  4206. break;
  4207. case TerminalTokens.TokenNamenative:
  4208. modifier = createModifier(Modifier.ModifierKeyword.NATIVE_KEYWORD);
  4209. break;
  4210. case TerminalTokens.TokenNamesynchronized:
  4211. modifier = createModifier(Modifier.ModifierKeyword.SYNCHRONIZED_KEYWORD);
  4212. break;
  4213. case TerminalTokens.TokenNametransient:
  4214. modifier = createModifier(Modifier.ModifierKeyword.TRANSIENT_KEYWORD);
  4215. break;
  4216. case TerminalTokens.TokenNamevolatile:
  4217. modifier = createModifier(Modifier.ModifierKeyword.VOLATILE_KEYWORD);
  4218. break;
  4219. case TerminalTokens.TokenNamestrictfp:
  4220. modifier = createModifier(Modifier.ModifierKeyword.STRICTFP_KEYWORD);
  4221. break;
  4222. case TerminalTokens.TokenNameAT:
  4223. // we have an annotation
  4224. if (annotations != null && indexInAnnotations < annotations.length) {
  4225. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation annotation = annotations[indexInAnnotations++];
  4226. modifier = super.convert(annotation);
  4227. this.scanner.resetTo(annotation.declarationSourceEnd + 1, this.compilationUnitSourceLength);
  4228. }
  4229. break;
  4230. case TerminalTokens.TokenNameCOMMENT_BLOCK:
  4231. case TerminalTokens.TokenNameCOMMENT_LINE:
  4232. case TerminalTokens.TokenNameCOMMENT_JAVADOC:
  4233. break;
  4234. default:
  4235. return;
  4236. }
  4237. if (modifier != null) {
  4238. variableDeclarationExpression.modifiers().add(modifier);
  4239. }
  4240. }
  4241. } catch (InvalidInputException e) {
  4242. // ignore
  4243. }
  4244. }
  4245. }
  4246. /**
  4247. * @param variableDeclarationStatement
  4248. * @param localDeclaration
  4249. */
  4250. protected void setModifiers(VariableDeclarationStatement variableDeclarationStatement, LocalDeclaration localDeclaration) {
  4251. switch (this.ast.apiLevel) {
  4252. case AST.JLS2_INTERNAL:
  4253. int modifiers = localDeclaration.modifiers & ExtraCompilerModifiers.AccJustFlag;
  4254. modifiers &= ~ExtraCompilerModifiers.AccBlankFinal;
  4255. variableDeclarationStatement.internalSetModifiers(modifiers);
  4256. if (localDeclaration.annotations != null) {
  4257. variableDeclarationStatement.setFlags(variableDeclarationStatement.getFlags() | ASTNode.MALFORMED);
  4258. }
  4259. break;
  4260. case AST.JLS3:
  4261. this.scanner.resetTo(localDeclaration.declarationSourceStart, localDeclaration.sourceStart);
  4262. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation[] annotations = localDeclaration.annotations;
  4263. int indexInAnnotations = 0;
  4264. try {
  4265. int token;
  4266. while ((token = this.scanner.getNextToken()) != TerminalTokens.TokenNameEOF) {
  4267. IExtendedModifier modifier = null;
  4268. switch (token) {
  4269. case TerminalTokens.TokenNameabstract:
  4270. modifier = createModifier(Modifier.ModifierKeyword.ABSTRACT_KEYWORD);
  4271. break;
  4272. case TerminalTokens.TokenNamepublic:
  4273. modifier = createModifier(Modifier.ModifierKeyword.PUBLIC_KEYWORD);
  4274. break;
  4275. case TerminalTokens.TokenNamestatic:
  4276. modifier = createModifier(Modifier.ModifierKeyword.STATIC_KEYWORD);
  4277. break;
  4278. case TerminalTokens.TokenNameprotected:
  4279. modifier = createModifier(Modifier.ModifierKeyword.PROTECTED_KEYWORD);
  4280. break;
  4281. case TerminalTokens.TokenNameprivate:
  4282. modifier = createModifier(Modifier.ModifierKeyword.PRIVATE_KEYWORD);
  4283. break;
  4284. case TerminalTokens.TokenNamefinal:
  4285. modifier = createModifier(Modifier.ModifierKeyword.FINAL_KEYWORD);
  4286. break;
  4287. case TerminalTokens.TokenNamenative:
  4288. modifier = createModifier(Modifier.ModifierKeyword.NATIVE_KEYWORD);
  4289. break;
  4290. case TerminalTokens.TokenNamesynchronized:
  4291. modifier = createModifier(Modifier.ModifierKeyword.SYNCHRONIZED_KEYWORD);
  4292. break;
  4293. case TerminalTokens.TokenNametransient:
  4294. modifier = createModifier(Modifier.ModifierKeyword.TRANSIENT_KEYWORD);
  4295. break;
  4296. case TerminalTokens.TokenNamevolatile:
  4297. modifier = createModifier(Modifier.ModifierKeyword.VOLATILE_KEYWORD);
  4298. break;
  4299. case TerminalTokens.TokenNamestrictfp:
  4300. modifier = createModifier(Modifier.ModifierKeyword.STRICTFP_KEYWORD);
  4301. break;
  4302. case TerminalTokens.TokenNameAT:
  4303. // we have an annotation
  4304. if (annotations != null && indexInAnnotations < annotations.length) {
  4305. org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation annotation = annotations[indexInAnnotations++];
  4306. modifier = super.convert(annotation);
  4307. this.scanner.resetTo(annotation.declarationSourceEnd + 1, this.compilationUnitSourceLength);
  4308. }
  4309. break;
  4310. case TerminalTokens.TokenNameCOMMENT_BLOCK:
  4311. case TerminalTokens.TokenNameCOMMENT_LINE:
  4312. case TerminalTokens.TokenNameCOMMENT_JAVADOC:
  4313. break;
  4314. default:
  4315. return;
  4316. }
  4317. if (modifier != null) {
  4318. variableDeclarationStatement.modifiers().add(modifier);
  4319. }
  4320. }
  4321. } catch (InvalidInputException e) {
  4322. // ignore
  4323. }
  4324. }
  4325. }
  4326. protected QualifiedName setQualifiedNameNameAndSourceRanges(char[][] typeName, long[] positions,
  4327. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode node) {
  4328. int length = typeName.length;
  4329. final SimpleName firstToken = new SimpleName(this.ast);
  4330. firstToken.internalSetIdentifier(new String(typeName[0]));
  4331. firstToken.index = 1;
  4332. int start0 = (int) (positions[0] >>> 32);
  4333. int start = start0;
  4334. int end = (int) (positions[0] & 0xFFFFFFFF);
  4335. firstToken.setSourceRange(start, end - start + 1);
  4336. final SimpleName secondToken = new SimpleName(this.ast);
  4337. secondToken.internalSetIdentifier(new String(typeName[1]));
  4338. secondToken.index = 2;
  4339. start = (int) (positions[1] >>> 32);
  4340. end = (int) (positions[1] & 0xFFFFFFFF);
  4341. secondToken.setSourceRange(start, end - start + 1);
  4342. QualifiedName qualifiedName = new QualifiedName(this.ast);
  4343. qualifiedName.setQualifier(firstToken);
  4344. qualifiedName.setName(secondToken);
  4345. if (this.resolveBindings) {
  4346. recordNodes(qualifiedName, node);
  4347. recordPendingNameScopeResolution(qualifiedName);
  4348. recordNodes(firstToken, node);
  4349. recordNodes(secondToken, node);
  4350. recordPendingNameScopeResolution(firstToken);
  4351. recordPendingNameScopeResolution(secondToken);
  4352. }
  4353. qualifiedName.index = 2;
  4354. qualifiedName.setSourceRange(start0, end - start0 + 1);
  4355. SimpleName newPart = null;
  4356. for (int i = 2; i < length; i++) {
  4357. newPart = new SimpleName(this.ast);
  4358. newPart.internalSetIdentifier(new String(typeName[i]));
  4359. newPart.index = i + 1;
  4360. start = (int) (positions[i] >>> 32);
  4361. end = (int) (positions[i] & 0xFFFFFFFF);
  4362. newPart.setSourceRange(start, end - start + 1);
  4363. QualifiedName qualifiedName2 = new QualifiedName(this.ast);
  4364. qualifiedName2.setQualifier(qualifiedName);
  4365. qualifiedName2.setName(newPart);
  4366. qualifiedName = qualifiedName2;
  4367. qualifiedName.index = newPart.index;
  4368. qualifiedName.setSourceRange(start0, end - start0 + 1);
  4369. if (this.resolveBindings) {
  4370. recordNodes(qualifiedName, node);
  4371. recordNodes(newPart, node);
  4372. recordPendingNameScopeResolution(qualifiedName);
  4373. recordPendingNameScopeResolution(newPart);
  4374. }
  4375. }
  4376. QualifiedName name = qualifiedName;
  4377. if (this.resolveBindings) {
  4378. recordNodes(name, node);
  4379. recordPendingNameScopeResolution(name);
  4380. }
  4381. return name;
  4382. }
  4383. protected QualifiedName setQualifiedNameNameAndSourceRanges(char[][] typeName, long[] positions, int endingIndex,
  4384. org.aspectj.org.eclipse.jdt.internal.compiler.ast.ASTNode node) {
  4385. int length = endingIndex + 1;
  4386. final SimpleName firstToken = new SimpleName(this.ast);
  4387. firstToken.internalSetIdentifier(new String(typeName[0]));
  4388. firstToken.index = 1;
  4389. int start0 = (int) (positions[0] >>> 32);
  4390. int start = start0;
  4391. int end = (int) positions[0];
  4392. firstToken.setSourceRange(start, end - start + 1);
  4393. final SimpleName secondToken = new SimpleName(this.ast);
  4394. secondToken.internalSetIdentifier(new String(typeName[1]));
  4395. secondToken.index = 2;
  4396. start = (int) (positions[1] >>> 32);
  4397. end = (int) positions[1];
  4398. secondToken.setSourceRange(start, end - start + 1);
  4399. QualifiedName qualifiedName = new QualifiedName(this.ast);
  4400. qualifiedName.setQualifier(firstToken);
  4401. qualifiedName.setName(secondToken);
  4402. if (this.resolveBindings) {
  4403. recordNodes(qualifiedName, node);
  4404. recordPendingNameScopeResolution(qualifiedName);
  4405. recordNodes(firstToken, node);
  4406. recordNodes(secondToken, node);
  4407. recordPendingNameScopeResolution(firstToken);
  4408. recordPendingNameScopeResolution(secondToken);
  4409. }
  4410. qualifiedName.index = 2;
  4411. qualifiedName.setSourceRange(start0, end - start0 + 1);
  4412. SimpleName newPart = null;
  4413. for (int i = 2; i < length; i++) {
  4414. newPart = new SimpleName(this.ast);
  4415. newPart.internalSetIdentifier(new String(typeName[i]));
  4416. newPart.index = i + 1;
  4417. start = (int) (positions[i] >>> 32);
  4418. end = (int) positions[i];
  4419. newPart.setSourceRange(start, end - start + 1);
  4420. QualifiedName qualifiedName2 = new QualifiedName(this.ast);
  4421. qualifiedName2.setQualifier(qualifiedName);
  4422. qualifiedName2.setName(newPart);
  4423. qualifiedName = qualifiedName2;
  4424. qualifiedName.index = newPart.index;
  4425. qualifiedName.setSourceRange(start0, end - start0 + 1);
  4426. if (this.resolveBindings) {
  4427. recordNodes(qualifiedName, node);
  4428. recordNodes(newPart, node);
  4429. recordPendingNameScopeResolution(qualifiedName);
  4430. recordPendingNameScopeResolution(newPart);
  4431. }
  4432. }
  4433. if (newPart == null && this.resolveBindings) {
  4434. recordNodes(qualifiedName, node);
  4435. recordPendingNameScopeResolution(qualifiedName);
  4436. }
  4437. return qualifiedName;
  4438. }
  4439. protected void setTypeNameForAnnotation(org.aspectj.org.eclipse.jdt.internal.compiler.ast.Annotation compilerAnnotation,
  4440. Annotation annotation) {
  4441. TypeReference typeReference = compilerAnnotation.type;
  4442. if (typeReference instanceof QualifiedTypeReference) {
  4443. QualifiedTypeReference qualifiedTypeReference = (QualifiedTypeReference) typeReference;
  4444. char[][] tokens = qualifiedTypeReference.tokens;
  4445. long[] positions = qualifiedTypeReference.sourcePositions;
  4446. // QualifiedName
  4447. annotation.setTypeName(setQualifiedNameNameAndSourceRanges(tokens, positions, typeReference));
  4448. } else {
  4449. SingleTypeReference singleTypeReference = (SingleTypeReference) typeReference;
  4450. final SimpleName name = new SimpleName(this.ast);
  4451. name.internalSetIdentifier(new String(singleTypeReference.token));
  4452. int start = singleTypeReference.sourceStart;
  4453. int end = singleTypeReference.sourceEnd;
  4454. name.setSourceRange(start, end - start + 1);
  4455. annotation.setTypeName(name);
  4456. if (this.resolveBindings) {
  4457. recordNodes(name, typeReference);
  4458. }
  4459. }
  4460. }
  4461. protected void setTypeForField(FieldDeclaration fieldDeclaration, Type type, int extraDimension) {
  4462. if (extraDimension != 0) {
  4463. if (type.isArrayType()) {
  4464. ArrayType arrayType = (ArrayType) type;
  4465. int remainingDimensions = arrayType.getDimensions() - extraDimension;
  4466. if (remainingDimensions == 0) {
  4467. // the dimensions are after the name so the type of the fieldDeclaration is a simpleType
  4468. Type elementType = arrayType.getElementType();
  4469. // cut the child loose from its parent (without creating garbage)
  4470. elementType.setParent(null, null);
  4471. this.ast.getBindingResolver().updateKey(type, elementType);
  4472. fieldDeclaration.setType(elementType);
  4473. } else {
  4474. int start = type.getStartPosition();
  4475. ArrayType subarrayType = arrayType;
  4476. int index = extraDimension;
  4477. while (index > 0) {
  4478. subarrayType = (ArrayType) subarrayType.getComponentType();
  4479. index--;
  4480. }
  4481. int end = retrieveProperRightBracketPosition(remainingDimensions, start);
  4482. subarrayType.setSourceRange(start, end - start + 1);
  4483. // cut the child loose from its parent (without creating garbage)
  4484. subarrayType.setParent(null, null);
  4485. fieldDeclaration.setType(subarrayType);
  4486. updateInnerPositions(subarrayType, remainingDimensions);
  4487. this.ast.getBindingResolver().updateKey(type, subarrayType);
  4488. }
  4489. } else {
  4490. fieldDeclaration.setType(type);
  4491. }
  4492. } else {
  4493. if (type.isArrayType()) {
  4494. // update positions of the component types of the array type
  4495. int dimensions = ((ArrayType) type).getDimensions();
  4496. updateInnerPositions(type, dimensions);
  4497. }
  4498. fieldDeclaration.setType(type);
  4499. }
  4500. }
  4501. protected void setTypeForAroundAdviceDeclaration(AroundAdviceDeclaration adviceDeclaration, Type type) {
  4502. // ajh02: method added
  4503. switch (this.ast.apiLevel) {
  4504. case AST.JLS2_INTERNAL:
  4505. adviceDeclaration.internalSetReturnType(type);
  4506. break;
  4507. case AST.JLS3:
  4508. adviceDeclaration.setReturnType2(type);
  4509. break;
  4510. }
  4511. }
  4512. protected void setTypeForMethodDeclaration(MethodDeclaration methodDeclaration, Type type, int extraDimension) {
  4513. if (extraDimension != 0) {
  4514. if (type.isArrayType()) {
  4515. ArrayType arrayType = (ArrayType) type;
  4516. int remainingDimensions = arrayType.getDimensions() - extraDimension;
  4517. if (remainingDimensions == 0) {
  4518. // the dimensions are after the name so the type of the fieldDeclaration is a simpleType
  4519. Type elementType = arrayType.getElementType();
  4520. // cut the child loose from its parent (without creating garbage)
  4521. elementType.setParent(null, null);
  4522. this.ast.getBindingResolver().updateKey(type, elementType);
  4523. switch (this.ast.apiLevel) {
  4524. case AST.JLS2_INTERNAL:
  4525. methodDeclaration.internalSetReturnType(elementType);
  4526. break;
  4527. case AST.JLS3:
  4528. methodDeclaration.setReturnType2(elementType);
  4529. break;
  4530. }
  4531. } else {
  4532. int start = type.getStartPosition();
  4533. ArrayType subarrayType = arrayType;
  4534. int index = extraDimension;
  4535. while (index > 0) {
  4536. subarrayType = (ArrayType) subarrayType.getComponentType();
  4537. index--;
  4538. }
  4539. int end = retrieveProperRightBracketPosition(remainingDimensions, start);
  4540. subarrayType.setSourceRange(start, end - start + 1);
  4541. // cut the child loose from its parent (without creating garbage)
  4542. subarrayType.setParent(null, null);
  4543. updateInnerPositions(subarrayType, remainingDimensions);
  4544. switch (this.ast.apiLevel) {
  4545. case AST.JLS2_INTERNAL:
  4546. methodDeclaration.internalSetReturnType(subarrayType);
  4547. break;
  4548. case AST.JLS3:
  4549. methodDeclaration.setReturnType2(subarrayType);
  4550. break;
  4551. }
  4552. this.ast.getBindingResolver().updateKey(type, subarrayType);
  4553. }
  4554. } else {
  4555. switch (this.ast.apiLevel) {
  4556. case AST.JLS2_INTERNAL:
  4557. methodDeclaration.internalSetReturnType(type);
  4558. break;
  4559. case AST.JLS3:
  4560. methodDeclaration.setReturnType2(type);
  4561. break;
  4562. }
  4563. }
  4564. } else {
  4565. switch (this.ast.apiLevel) {
  4566. case AST.JLS2_INTERNAL:
  4567. methodDeclaration.internalSetReturnType(type);
  4568. break;
  4569. case AST.JLS3:
  4570. methodDeclaration.setReturnType2(type);
  4571. break;
  4572. }
  4573. }
  4574. }
  4575. protected void setTypeForMethodDeclaration(AnnotationTypeMemberDeclaration annotationTypeMemberDeclaration, Type type,
  4576. int extraDimension) {
  4577. annotationTypeMemberDeclaration.setType(type);
  4578. }
  4579. protected void setTypeForSingleVariableDeclaration(SingleVariableDeclaration singleVariableDeclaration, Type type,
  4580. int extraDimension) {
  4581. if (extraDimension != 0) {
  4582. if (type.isArrayType()) {
  4583. ArrayType arrayType = (ArrayType) type;
  4584. int remainingDimensions = arrayType.getDimensions() - extraDimension;
  4585. if (remainingDimensions == 0) {
  4586. // the dimensions are after the name so the type of the fieldDeclaration is a simpleType
  4587. Type elementType = arrayType.getElementType();
  4588. // cut the child loose from its parent (without creating garbage)
  4589. elementType.setParent(null, null);
  4590. this.ast.getBindingResolver().updateKey(type, elementType);
  4591. singleVariableDeclaration.setType(elementType);
  4592. } else {
  4593. int start = type.getStartPosition();
  4594. ArrayType subarrayType = arrayType;
  4595. int index = extraDimension;
  4596. while (index > 0) {
  4597. subarrayType = (ArrayType) subarrayType.getComponentType();
  4598. index--;
  4599. }
  4600. int end = retrieveProperRightBracketPosition(remainingDimensions, start);
  4601. subarrayType.setSourceRange(start, end - start + 1);
  4602. // cut the child loose from its parent (without creating garbage)
  4603. subarrayType.setParent(null, null);
  4604. updateInnerPositions(subarrayType, remainingDimensions);
  4605. singleVariableDeclaration.setType(subarrayType);
  4606. this.ast.getBindingResolver().updateKey(type, subarrayType);
  4607. }
  4608. } else {
  4609. singleVariableDeclaration.setType(type);
  4610. }
  4611. } else {
  4612. singleVariableDeclaration.setType(type);
  4613. }
  4614. }
  4615. protected void setTypeForVariableDeclarationExpression(VariableDeclarationExpression variableDeclarationExpression, Type type,
  4616. int extraDimension) {
  4617. if (extraDimension != 0) {
  4618. if (type.isArrayType()) {
  4619. ArrayType arrayType = (ArrayType) type;
  4620. int remainingDimensions = arrayType.getDimensions() - extraDimension;
  4621. if (remainingDimensions == 0) {
  4622. // the dimensions are after the name so the type of the fieldDeclaration is a simpleType
  4623. Type elementType = arrayType.getElementType();
  4624. // cut the child loose from its parent (without creating garbage)
  4625. elementType.setParent(null, null);
  4626. this.ast.getBindingResolver().updateKey(type, elementType);
  4627. variableDeclarationExpression.setType(elementType);
  4628. } else {
  4629. int start = type.getStartPosition();
  4630. ArrayType subarrayType = arrayType;
  4631. int index = extraDimension;
  4632. while (index > 0) {
  4633. subarrayType = (ArrayType) subarrayType.getComponentType();
  4634. index--;
  4635. }
  4636. int end = retrieveProperRightBracketPosition(remainingDimensions, start);
  4637. subarrayType.setSourceRange(start, end - start + 1);
  4638. // cut the child loose from its parent (without creating garbage)
  4639. subarrayType.setParent(null, null);
  4640. updateInnerPositions(subarrayType, remainingDimensions);
  4641. variableDeclarationExpression.setType(subarrayType);
  4642. this.ast.getBindingResolver().updateKey(type, subarrayType);
  4643. }
  4644. } else {
  4645. variableDeclarationExpression.setType(type);
  4646. }
  4647. } else {
  4648. variableDeclarationExpression.setType(type);
  4649. }
  4650. }
  4651. protected void setTypeForVariableDeclarationStatement(VariableDeclarationStatement variableDeclarationStatement, Type type,
  4652. int extraDimension) {
  4653. if (extraDimension != 0) {
  4654. if (type.isArrayType()) {
  4655. ArrayType arrayType = (ArrayType) type;
  4656. int remainingDimensions = arrayType.getDimensions() - extraDimension;
  4657. if (remainingDimensions == 0) {
  4658. // the dimensions are after the name so the type of the fieldDeclaration is a simpleType
  4659. Type elementType = arrayType.getElementType();
  4660. // cut the child loose from its parent (without creating garbage)
  4661. elementType.setParent(null, null);
  4662. this.ast.getBindingResolver().updateKey(type, elementType);
  4663. variableDeclarationStatement.setType(elementType);
  4664. } else {
  4665. int start = type.getStartPosition();
  4666. ArrayType subarrayType = arrayType;
  4667. int index = extraDimension;
  4668. while (index > 0) {
  4669. subarrayType = (ArrayType) subarrayType.getComponentType();
  4670. index--;
  4671. }
  4672. int end = retrieveProperRightBracketPosition(remainingDimensions, start);
  4673. subarrayType.setSourceRange(start, end - start + 1);
  4674. // cut the child loose from its parent (without creating garbage)
  4675. subarrayType.setParent(null, null);
  4676. updateInnerPositions(subarrayType, remainingDimensions);
  4677. variableDeclarationStatement.setType(subarrayType);
  4678. this.ast.getBindingResolver().updateKey(type, subarrayType);
  4679. }
  4680. } else {
  4681. variableDeclarationStatement.setType(type);
  4682. }
  4683. } else {
  4684. variableDeclarationStatement.setType(type);
  4685. }
  4686. }
  4687. protected void updateInnerPositions(Type type, int dimensions) {
  4688. if (dimensions > 1) {
  4689. // need to set positions for intermediate array type see 42839
  4690. int start = type.getStartPosition();
  4691. Type currentComponentType = ((ArrayType) type).getComponentType();
  4692. int searchedDimension = dimensions - 1;
  4693. int rightBracketEndPosition = start;
  4694. while (currentComponentType.isArrayType()) {
  4695. rightBracketEndPosition = retrieveProperRightBracketPosition(searchedDimension, start);
  4696. currentComponentType.setSourceRange(start, rightBracketEndPosition - start + 1);
  4697. currentComponentType = ((ArrayType) currentComponentType).getComponentType();
  4698. searchedDimension--;
  4699. }
  4700. }
  4701. }
  4702. }