1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499105001050110502105031050410505105061050710508105091051010511105121051310514105151051610517105181051910520105211052210523105241052510526105271052810529105301053110532105331053410535105361053710538105391054010541105421054310544105451054610547105481054910550105511055210553105541055510556105571055810559105601056110562105631056410565105661056710568105691057010571105721057310574105751057610577105781057910580105811058210583105841058510586105871058810589105901059110592105931059410595105961059710598105991060010601106021060310604106051060610607106081060910610106111061210613106141061510616106171061810619106201062110622106231062410625106261062710628106291063010631106321063310634106351063610637106381063910640106411064210643106441064510646106471064810649106501065110652106531065410655106561065710658106591066010661106621066310664106651066610667106681066910670106711067210673106741067510676106771067810679106801068110682106831068410685106861068710688106891069010691106921069310694106951069610697106981069910700107011070210703107041070510706107071070810709107101071110712107131071410715107161071710718107191072010721107221072310724107251072610727107281072910730107311073210733107341073510736107371073810739107401074110742107431074410745107461074710748107491075010751107521075310754107551075610757107581075910760107611076210763107641076510766107671076810769107701077110772107731077410775107761077710778107791078010781107821078310784107851078610787107881078910790107911079210793107941079510796107971079810799108001080110802108031080410805108061080710808108091081010811108121081310814108151081610817108181081910820108211082210823108241082510826108271082810829108301083110832108331083410835108361083710838108391084010841108421084310844108451084610847108481084910850108511085210853108541085510856108571085810859108601086110862108631086410865108661086710868108691087010871108721087310874108751087610877108781087910880108811088210883108841088510886108871088810889108901089110892108931089410895108961089710898108991090010901109021090310904109051090610907109081090910910109111091210913109141091510916109171091810919109201092110922109231092410925109261092710928109291093010931109321093310934109351093610937109381093910940109411094210943109441094510946109471094810949109501095110952109531095410955109561095710958109591096010961109621096310964109651096610967109681096910970109711097210973109741097510976109771097810979109801098110982109831098410985109861098710988109891099010991109921099310994109951099610997109981099911000110011100211003110041100511006110071100811009110101101111012110131101411015110161101711018110191102011021110221102311024110251102611027110281102911030110311103211033110341103511036110371103811039110401104111042110431104411045110461104711048110491105011051110521105311054110551105611057110581105911060110611106211063110641106511066110671106811069110701107111072110731107411075110761107711078110791108011081110821108311084110851108611087110881108911090110911109211093110941109511096110971109811099111001110111102111031110411105111061110711108111091111011111111121111311114111151111611117111181111911120111211112211123111241112511126111271112811129111301113111132111331113411135111361113711138111391114011141111421114311144111451114611147111481114911150111511115211153111541115511156111571115811159111601116111162111631116411165111661116711168111691117011171111721117311174111751117611177111781117911180111811118211183111841118511186111871118811189111901119111192111931119411195111961119711198111991120011201112021120311204112051120611207112081120911210112111121211213112141121511216112171121811219112201122111222112231122411225112261122711228112291123011231112321123311234112351123611237112381123911240112411124211243112441124511246112471124811249112501125111252112531125411255112561125711258112591126011261112621126311264112651126611267112681126911270112711127211273112741127511276112771127811279112801128111282112831128411285112861128711288112891129011291112921129311294112951129611297112981129911300113011130211303113041130511306113071130811309113101131111312113131131411315113161131711318113191132011321113221132311324113251132611327113281132911330113311133211333113341133511336113371133811339113401134111342113431134411345113461134711348113491135011351113521135311354113551135611357113581135911360113611136211363113641136511366113671136811369113701137111372113731137411375113761137711378113791138011381113821138311384113851138611387113881138911390113911139211393113941139511396113971139811399114001140111402114031140411405114061140711408114091141011411114121141311414114151141611417114181141911420114211142211423114241142511426114271142811429114301143111432114331143411435114361143711438114391144011441114421144311444114451144611447114481144911450114511145211453114541145511456114571145811459114601146111462114631146411465114661146711468114691147011471114721147311474114751147611477114781147911480114811148211483114841148511486114871148811489114901149111492114931149411495114961149711498114991150011501115021150311504115051150611507115081150911510115111151211513115141151511516115171151811519115201152111522115231152411525115261152711528115291153011531115321153311534115351153611537115381153911540115411154211543115441154511546115471154811549115501155111552115531155411555115561155711558115591156011561115621156311564115651156611567115681156911570115711157211573115741157511576115771157811579115801158111582115831158411585115861158711588115891159011591115921159311594115951159611597115981159911600116011160211603116041160511606116071160811609116101161111612116131161411615116161161711618116191162011621116221162311624116251162611627116281162911630116311163211633116341163511636116371163811639116401164111642116431164411645116461164711648116491165011651116521165311654116551165611657116581165911660116611166211663116641166511666116671166811669116701167111672116731167411675116761167711678116791168011681116821168311684116851168611687116881168911690116911169211693116941169511696116971169811699117001170111702117031170411705117061170711708117091171011711117121171311714117151171611717117181171911720117211172211723117241172511726117271172811729117301173111732117331173411735117361173711738117391174011741117421174311744117451174611747117481174911750117511175211753117541175511756117571175811759117601176111762117631176411765117661176711768117691177011771117721177311774117751177611777117781177911780117811178211783117841178511786117871178811789117901179111792117931179411795117961179711798117991180011801118021180311804118051180611807118081180911810118111181211813118141181511816118171181811819118201182111822118231182411825118261182711828118291183011831118321183311834118351183611837118381183911840118411184211843118441184511846118471184811849118501185111852118531185411855118561185711858118591186011861118621186311864118651186611867118681186911870118711187211873118741187511876118771187811879118801188111882118831188411885118861188711888118891189011891118921189311894118951189611897118981189911900119011190211903119041190511906119071190811909119101191111912119131191411915119161191711918119191192011921119221192311924119251192611927119281192911930119311193211933119341193511936119371193811939119401194111942119431194411945119461194711948119491195011951119521195311954119551195611957119581195911960119611196211963119641196511966119671196811969119701197111972119731197411975119761197711978119791198011981119821198311984119851198611987119881198911990119911199211993119941199511996119971199811999120001200112002120031200412005120061200712008120091201012011120121201312014120151201612017120181201912020120211202212023120241202512026120271202812029120301203112032120331203412035120361203712038120391204012041120421204312044120451204612047120481204912050120511205212053120541205512056120571205812059120601206112062120631206412065120661206712068120691207012071120721207312074120751207612077120781207912080120811208212083120841208512086120871208812089120901209112092120931209412095120961209712098120991210012101121021210312104121051210612107121081210912110121111211212113121141211512116121171211812119121201212112122121231212412125121261212712128121291213012131121321213312134121351213612137121381213912140121411214212143121441214512146121471214812149121501215112152121531215412155121561215712158121591216012161121621216312164121651216612167121681216912170121711217212173121741217512176121771217812179121801218112182121831218412185121861218712188121891219012191121921219312194121951219612197121981219912200122011220212203122041220512206122071220812209122101221112212122131221412215122161221712218122191222012221122221222312224122251222612227122281222912230122311223212233122341223512236122371223812239122401224112242122431224412245122461224712248122491225012251122521225312254122551225612257122581225912260122611226212263122641226512266122671226812269122701227112272122731227412275122761227712278122791228012281122821228312284122851228612287122881228912290122911229212293122941229512296122971229812299123001230112302123031230412305123061230712308123091231012311123121231312314123151231612317123181231912320123211232212323123241232512326123271232812329123301233112332123331233412335123361233712338123391234012341123421234312344123451234612347123481234912350123511235212353123541235512356123571235812359123601236112362123631236412365123661236712368123691237012371123721237312374123751237612377123781237912380123811238212383123841238512386123871238812389123901239112392123931239412395123961239712398123991240012401124021240312404124051240612407124081240912410124111241212413124141241512416124171241812419124201242112422124231242412425124261242712428124291243012431124321243312434124351243612437124381243912440124411244212443124441244512446124471244812449124501245112452124531245412455124561245712458124591246012461124621246312464124651246612467124681246912470124711247212473124741247512476124771247812479124801248112482124831248412485124861248712488124891249012491124921249312494124951249612497124981249912500125011250212503125041250512506125071250812509125101251112512125131251412515125161251712518125191252012521125221252312524125251252612527125281252912530125311253212533125341253512536125371253812539125401254112542125431254412545125461254712548125491255012551125521255312554125551255612557125581255912560125611256212563125641256512566125671256812569125701257112572125731257412575125761257712578125791258012581125821258312584125851258612587125881258912590125911259212593125941259512596125971259812599126001260112602126031260412605126061260712608126091261012611126121261312614126151261612617126181261912620126211262212623126241262512626126271262812629126301263112632126331263412635126361263712638126391264012641126421264312644126451264612647126481264912650126511265212653126541265512656126571265812659126601266112662126631266412665126661266712668126691267012671126721267312674126751267612677126781267912680126811268212683126841268512686126871268812689126901269112692126931269412695126961269712698126991270012701127021270312704127051270612707127081270912710127111271212713127141271512716127171271812719127201272112722127231272412725127261272712728127291273012731127321273312734127351273612737127381273912740127411274212743127441274512746127471274812749127501275112752127531275412755127561275712758127591276012761127621276312764127651276612767127681276912770127711277212773127741277512776127771277812779127801278112782127831278412785127861278712788127891279012791127921279312794127951279612797127981279912800128011280212803128041280512806128071280812809128101281112812128131281412815128161281712818128191282012821128221282312824128251282612827128281282912830128311283212833128341283512836128371283812839128401284112842128431284412845128461284712848128491285012851128521285312854128551285612857128581285912860128611286212863128641286512866128671286812869128701287112872128731287412875128761287712878128791288012881128821288312884128851288612887128881288912890128911289212893128941289512896128971289812899129001290112902129031290412905129061290712908129091291012911129121291312914129151291612917129181291912920129211292212923129241292512926129271292812929129301293112932129331293412935129361293712938129391294012941129421294312944129451294612947129481294912950129511295212953129541295512956129571295812959129601296112962129631296412965129661296712968129691297012971129721297312974129751297612977129781297912980129811298212983129841298512986129871298812989129901299112992129931299412995129961299712998129991300013001130021300313004130051300613007130081300913010130111301213013130141301513016130171301813019130201302113022130231302413025130261302713028130291303013031130321303313034130351303613037130381303913040130411304213043130441304513046130471304813049130501305113052130531305413055130561305713058130591306013061130621306313064130651306613067130681306913070130711307213073130741307513076130771307813079130801308113082130831308413085130861308713088130891309013091130921309313094130951309613097130981309913100131011310213103131041310513106131071310813109131101311113112131131311413115131161311713118131191312013121131221312313124131251312613127131281312913130131311313213133131341313513136131371313813139131401314113142131431314413145131461314713148131491315013151131521315313154131551315613157131581315913160131611316213163131641316513166131671316813169131701317113172131731317413175131761317713178131791318013181131821318313184131851318613187131881318913190131911319213193131941319513196131971319813199132001320113202132031320413205132061320713208132091321013211132121321313214132151321613217132181321913220132211322213223132241322513226132271322813229132301323113232132331323413235132361323713238132391324013241132421324313244132451324613247132481324913250132511325213253132541325513256132571325813259132601326113262132631326413265132661326713268132691327013271132721327313274132751327613277132781327913280132811328213283132841328513286132871328813289132901329113292132931329413295132961329713298132991330013301133021330313304133051330613307133081330913310133111331213313133141331513316133171331813319133201332113322133231332413325133261332713328133291333013331133321333313334133351333613337133381333913340133411334213343133441334513346133471334813349133501335113352133531335413355133561335713358133591336013361133621336313364133651336613367133681336913370133711337213373133741337513376133771337813379133801338113382133831338413385133861338713388133891339013391133921339313394133951339613397133981339913400134011340213403134041340513406134071340813409134101341113412134131341413415134161341713418134191342013421134221342313424134251342613427134281342913430134311343213433134341343513436134371343813439134401344113442134431344413445134461344713448134491345013451134521345313454134551345613457134581345913460134611346213463134641346513466134671346813469134701347113472134731347413475134761347713478134791348013481134821348313484134851348613487134881348913490134911349213493134941349513496134971349813499135001350113502135031350413505135061350713508135091351013511135121351313514135151351613517135181351913520135211352213523135241352513526135271352813529135301353113532135331353413535135361353713538135391354013541135421354313544135451354613547135481354913550135511355213553135541355513556135571355813559135601356113562135631356413565135661356713568135691357013571135721357313574135751357613577135781357913580135811358213583135841358513586135871358813589135901359113592135931359413595135961359713598135991360013601136021360313604136051360613607136081360913610136111361213613136141361513616136171361813619136201362113622136231362413625136261362713628136291363013631136321363313634136351363613637136381363913640136411364213643136441364513646136471364813649136501365113652136531365413655136561365713658136591366013661136621366313664136651366613667136681366913670136711367213673136741367513676136771367813679136801368113682136831368413685136861368713688136891369013691136921369313694136951369613697136981369913700137011370213703137041370513706137071370813709137101371113712137131371413715137161371713718137191372013721137221372313724137251372613727137281372913730137311373213733137341373513736137371373813739137401374113742137431374413745137461374713748137491375013751137521375313754137551375613757137581375913760137611376213763137641376513766137671376813769137701377113772137731377413775137761377713778137791378013781137821378313784137851378613787137881378913790137911379213793137941379513796137971379813799138001380113802138031380413805138061380713808138091381013811138121381313814138151381613817138181381913820138211382213823138241382513826138271382813829138301383113832138331383413835138361383713838138391384013841138421384313844138451384613847138481384913850138511385213853138541385513856138571385813859138601386113862138631386413865138661386713868138691387013871138721387313874138751387613877138781387913880138811388213883138841388513886138871388813889138901389113892138931389413895138961389713898138991390013901139021390313904139051390613907139081390913910139111391213913139141391513916139171391813919139201392113922139231392413925139261392713928139291393013931139321393313934139351393613937139381393913940139411394213943139441394513946139471394813949139501395113952139531395413955139561395713958139591396013961139621396313964139651396613967139681396913970139711397213973139741397513976139771397813979139801398113982139831398413985139861398713988139891399013991139921399313994139951399613997139981399914000140011400214003140041400514006140071400814009140101401114012140131401414015140161401714018140191402014021140221402314024140251402614027140281402914030140311403214033140341403514036140371403814039140401404114042140431404414045140461404714048140491405014051140521405314054140551405614057140581405914060140611406214063140641406514066140671406814069140701407114072140731407414075140761407714078140791408014081140821408314084140851408614087140881408914090140911409214093140941409514096140971409814099141001410114102141031410414105141061410714108141091411014111141121411314114141151411614117141181411914120141211412214123141241412514126141271412814129141301413114132141331413414135141361413714138141391414014141141421414314144141451414614147141481414914150141511415214153141541415514156141571415814159141601416114162141631416414165141661416714168141691417014171141721417314174141751417614177141781417914180141811418214183141841418514186141871418814189141901419114192141931419414195141961419714198141991420014201142021420314204142051420614207142081420914210142111421214213142141421514216142171421814219142201422114222142231422414225142261422714228142291423014231142321423314234142351423614237142381423914240142411424214243142441424514246142471424814249142501425114252142531425414255142561425714258142591426014261142621426314264142651426614267142681426914270142711427214273142741427514276142771427814279142801428114282142831428414285142861428714288142891429014291142921429314294142951429614297142981429914300143011430214303143041430514306143071430814309143101431114312143131431414315143161431714318143191432014321143221432314324143251432614327143281432914330143311433214333143341433514336143371433814339143401434114342143431434414345143461434714348143491435014351143521435314354143551435614357143581435914360143611436214363143641436514366143671436814369143701437114372143731437414375143761437714378143791438014381143821438314384143851438614387143881438914390143911439214393143941439514396143971439814399144001440114402144031440414405144061440714408144091441014411144121441314414144151441614417144181441914420144211442214423144241442514426144271442814429144301443114432144331443414435144361443714438144391444014441144421444314444144451444614447144481444914450144511445214453144541445514456144571445814459144601446114462144631446414465144661446714468144691447014471144721447314474144751447614477144781447914480144811448214483144841448514486144871448814489144901449114492144931449414495144961449714498144991450014501145021450314504145051450614507145081450914510145111451214513145141451514516145171451814519145201452114522145231452414525145261452714528145291453014531145321453314534145351453614537145381453914540145411454214543145441454514546145471454814549145501455114552145531455414555145561455714558145591456014561145621456314564145651456614567145681456914570145711457214573145741457514576145771457814579145801458114582145831458414585145861458714588145891459014591145921459314594145951459614597145981459914600146011460214603146041460514606146071460814609146101461114612146131461414615146161461714618146191462014621146221462314624146251462614627146281462914630146311463214633146341463514636146371463814639146401464114642146431464414645146461464714648146491465014651146521465314654146551465614657146581465914660146611466214663146641466514666146671466814669146701467114672146731467414675146761467714678146791468014681146821468314684146851468614687146881468914690146911469214693146941469514696146971469814699147001470114702147031470414705147061470714708147091471014711147121471314714147151471614717147181471914720147211472214723147241472514726147271472814729147301473114732147331473414735147361473714738147391474014741147421474314744147451474614747147481474914750147511475214753147541475514756147571475814759147601476114762147631476414765147661476714768147691477014771147721477314774147751477614777147781477914780147811478214783147841478514786147871478814789147901479114792147931479414795147961479714798147991480014801148021480314804148051480614807148081480914810148111481214813148141481514816148171481814819148201482114822148231482414825148261482714828148291483014831148321483314834148351483614837148381483914840148411484214843148441484514846148471484814849148501485114852148531485414855148561485714858148591486014861148621486314864148651486614867148681486914870148711487214873148741487514876148771487814879148801488114882148831488414885148861488714888148891489014891148921489314894148951489614897148981489914900149011490214903149041490514906149071490814909149101491114912149131491414915149161491714918149191492014921149221492314924149251492614927149281492914930149311493214933149341493514936149371493814939149401494114942149431494414945149461494714948149491495014951149521495314954149551495614957149581495914960149611496214963149641496514966149671496814969149701497114972149731497414975149761497714978149791498014981149821498314984149851498614987149881498914990149911499214993149941499514996149971499814999150001500115002150031500415005150061500715008150091501015011150121501315014150151501615017150181501915020150211502215023150241502515026150271502815029150301503115032150331503415035150361503715038150391504015041150421504315044150451504615047150481504915050150511505215053150541505515056150571505815059150601506115062150631506415065150661506715068150691507015071150721507315074150751507615077150781507915080150811508215083150841508515086150871508815089150901509115092150931509415095150961509715098150991510015101151021510315104151051510615107151081510915110151111511215113151141511515116151171511815119151201512115122151231512415125151261512715128151291513015131151321513315134151351513615137151381513915140151411514215143151441514515146151471514815149151501515115152151531515415155151561515715158151591516015161151621516315164151651516615167151681516915170151711517215173151741517515176151771517815179151801518115182151831518415185151861518715188151891519015191151921519315194151951519615197151981519915200152011520215203152041520515206152071520815209152101521115212152131521415215152161521715218152191522015221152221522315224152251522615227152281522915230152311523215233152341523515236152371523815239152401524115242152431524415245152461524715248152491525015251152521525315254152551525615257152581525915260152611526215263152641526515266152671526815269152701527115272152731527415275152761527715278152791528015281152821528315284152851528615287152881528915290152911529215293152941529515296152971529815299153001530115302153031530415305153061530715308153091531015311153121531315314153151531615317153181531915320153211532215323153241532515326153271532815329153301533115332153331533415335153361533715338153391534015341153421534315344153451534615347153481534915350153511535215353153541535515356153571535815359153601536115362153631536415365153661536715368153691537015371153721537315374153751537615377153781537915380153811538215383153841538515386153871538815389153901539115392153931539415395153961539715398153991540015401154021540315404154051540615407154081540915410154111541215413154141541515416154171541815419154201542115422154231542415425154261542715428154291543015431154321543315434154351543615437154381543915440154411544215443154441544515446154471544815449154501545115452154531545415455154561545715458154591546015461154621546315464154651546615467154681546915470154711547215473154741547515476154771547815479154801548115482154831548415485154861548715488154891549015491154921549315494154951549615497154981549915500155011550215503155041550515506155071550815509155101551115512155131551415515155161551715518155191552015521155221552315524155251552615527155281552915530155311553215533155341553515536155371553815539155401554115542155431554415545155461554715548155491555015551155521555315554155551555615557155581555915560155611556215563155641556515566155671556815569155701557115572155731557415575155761557715578155791558015581155821558315584155851558615587155881558915590155911559215593155941559515596155971559815599156001560115602156031560415605156061560715608156091561015611156121561315614156151561615617156181561915620156211562215623156241562515626156271562815629156301563115632156331563415635156361563715638156391564015641156421564315644156451564615647156481564915650156511565215653156541565515656156571565815659156601566115662156631566415665156661566715668156691567015671156721567315674156751567615677156781567915680156811568215683156841568515686156871568815689156901569115692156931569415695156961569715698156991570015701157021570315704157051570615707157081570915710157111571215713157141571515716157171571815719157201572115722157231572415725157261572715728157291573015731157321573315734157351573615737157381573915740157411574215743157441574515746157471574815749157501575115752157531575415755157561575715758157591576015761157621576315764157651576615767157681576915770157711577215773157741577515776157771577815779157801578115782157831578415785157861578715788157891579015791157921579315794157951579615797157981579915800158011580215803158041580515806158071580815809158101581115812158131581415815158161581715818158191582015821158221582315824158251582615827158281582915830158311583215833158341583515836158371583815839158401584115842158431584415845158461584715848158491585015851158521585315854158551585615857158581585915860158611586215863158641586515866158671586815869158701587115872158731587415875158761587715878158791588015881158821588315884158851588615887158881588915890158911589215893158941589515896158971589815899159001590115902159031590415905159061590715908159091591015911159121591315914159151591615917159181591915920159211592215923159241592515926159271592815929159301593115932159331593415935159361593715938159391594015941159421594315944159451594615947159481594915950159511595215953159541595515956159571595815959159601596115962159631596415965159661596715968159691597015971159721597315974159751597615977159781597915980159811598215983159841598515986159871598815989159901599115992159931599415995159961599715998159991600016001160021600316004160051600616007160081600916010160111601216013160141601516016160171601816019160201602116022160231602416025160261602716028160291603016031160321603316034160351603616037160381603916040160411604216043160441604516046160471604816049160501605116052160531605416055160561605716058160591606016061160621606316064160651606616067160681606916070160711607216073160741607516076160771607816079160801608116082160831608416085160861608716088160891609016091160921609316094160951609616097160981609916100161011610216103161041610516106161071610816109161101611116112161131611416115161161611716118161191612016121161221612316124161251612616127161281612916130161311613216133161341613516136161371613816139161401614116142161431614416145161461614716148161491615016151161521615316154161551615616157161581615916160161611616216163161641616516166161671616816169161701617116172161731617416175161761617716178161791618016181161821618316184161851618616187161881618916190161911619216193161941619516196161971619816199162001620116202162031620416205162061620716208162091621016211162121621316214162151621616217162181621916220162211622216223162241622516226162271622816229162301623116232162331623416235162361623716238162391624016241162421624316244162451624616247162481624916250162511625216253162541625516256162571625816259162601626116262162631626416265162661626716268162691627016271162721627316274162751627616277162781627916280162811628216283162841628516286162871628816289162901629116292162931629416295162961629716298162991630016301163021630316304163051630616307163081630916310163111631216313163141631516316163171631816319163201632116322163231632416325163261632716328163291633016331163321633316334163351633616337163381633916340163411634216343163441634516346163471634816349163501635116352163531635416355163561635716358163591636016361163621636316364163651636616367163681636916370163711637216373163741637516376163771637816379163801638116382163831638416385163861638716388163891639016391163921639316394163951639616397163981639916400164011640216403164041640516406164071640816409164101641116412164131641416415164161641716418164191642016421164221642316424164251642616427164281642916430164311643216433164341643516436164371643816439164401644116442164431644416445164461644716448164491645016451164521645316454164551645616457164581645916460164611646216463164641646516466164671646816469164701647116472164731647416475164761647716478164791648016481164821648316484164851648616487164881648916490164911649216493164941649516496164971649816499165001650116502165031650416505165061650716508165091651016511165121651316514165151651616517165181651916520165211652216523165241652516526165271652816529165301653116532165331653416535165361653716538165391654016541165421654316544165451654616547165481654916550165511655216553165541655516556165571655816559165601656116562165631656416565165661656716568165691657016571165721657316574165751657616577165781657916580165811658216583165841658516586165871658816589165901659116592165931659416595165961659716598165991660016601166021660316604166051660616607166081660916610166111661216613166141661516616166171661816619166201662116622166231662416625166261662716628166291663016631166321663316634166351663616637166381663916640166411664216643166441664516646166471664816649166501665116652166531665416655166561665716658166591666016661166621666316664166651666616667166681666916670166711667216673166741667516676166771667816679166801668116682166831668416685166861668716688166891669016691166921669316694166951669616697166981669916700167011670216703167041670516706167071670816709167101671116712167131671416715167161671716718167191672016721167221672316724167251672616727167281672916730167311673216733167341673516736167371673816739167401674116742167431674416745167461674716748167491675016751167521675316754167551675616757167581675916760167611676216763167641676516766167671676816769167701677116772167731677416775167761677716778167791678016781167821678316784167851678616787167881678916790167911679216793167941679516796167971679816799168001680116802168031680416805168061680716808168091681016811168121681316814168151681616817168181681916820168211682216823168241682516826168271682816829168301683116832168331683416835168361683716838168391684016841168421684316844168451684616847168481684916850168511685216853168541685516856168571685816859168601686116862168631686416865168661686716868168691687016871168721687316874168751687616877168781687916880168811688216883168841688516886168871688816889168901689116892168931689416895168961689716898168991690016901169021690316904169051690616907169081690916910169111691216913169141691516916169171691816919169201692116922169231692416925169261692716928169291693016931169321693316934169351693616937169381693916940169411694216943169441694516946169471694816949169501695116952169531695416955169561695716958169591696016961169621696316964169651696616967169681696916970169711697216973169741697516976169771697816979169801698116982169831698416985169861698716988169891699016991169921699316994169951699616997169981699917000170011700217003170041700517006170071700817009170101701117012170131701417015170161701717018170191702017021170221702317024170251702617027170281702917030170311703217033170341703517036170371703817039170401704117042170431704417045170461704717048170491705017051170521705317054170551705617057170581705917060170611706217063170641706517066170671706817069170701707117072170731707417075170761707717078170791708017081170821708317084170851708617087170881708917090170911709217093170941709517096170971709817099171001710117102171031710417105171061710717108171091711017111171121711317114171151711617117171181711917120171211712217123171241712517126171271712817129171301713117132171331713417135171361713717138171391714017141171421714317144171451714617147171481714917150171511715217153171541715517156171571715817159171601716117162171631716417165171661716717168171691717017171171721717317174171751717617177171781717917180171811718217183171841718517186171871718817189171901719117192171931719417195171961719717198171991720017201172021720317204172051720617207172081720917210172111721217213172141721517216172171721817219172201722117222172231722417225172261722717228172291723017231172321723317234172351723617237172381723917240172411724217243172441724517246172471724817249172501725117252172531725417255172561725717258172591726017261172621726317264172651726617267172681726917270172711727217273172741727517276172771727817279172801728117282172831728417285172861728717288172891729017291172921729317294172951729617297172981729917300173011730217303173041730517306173071730817309173101731117312173131731417315173161731717318173191732017321173221732317324173251732617327173281732917330173311733217333173341733517336173371733817339173401734117342173431734417345173461734717348173491735017351173521735317354173551735617357173581735917360173611736217363173641736517366173671736817369173701737117372173731737417375173761737717378173791738017381173821738317384173851738617387173881738917390173911739217393173941739517396173971739817399174001740117402174031740417405174061740717408174091741017411174121741317414174151741617417174181741917420174211742217423174241742517426174271742817429174301743117432174331743417435174361743717438174391744017441174421744317444174451744617447174481744917450174511745217453174541745517456174571745817459174601746117462174631746417465174661746717468174691747017471174721747317474174751747617477174781747917480174811748217483174841748517486174871748817489174901749117492174931749417495174961749717498174991750017501175021750317504175051750617507175081750917510175111751217513175141751517516175171751817519175201752117522175231752417525175261752717528175291753017531175321753317534175351753617537175381753917540175411754217543175441754517546175471754817549175501755117552175531755417555175561755717558175591756017561175621756317564175651756617567175681756917570175711757217573175741757517576175771757817579175801758117582175831758417585175861758717588175891759017591175921759317594175951759617597175981759917600176011760217603176041760517606176071760817609176101761117612176131761417615176161761717618176191762017621176221762317624176251762617627176281762917630176311763217633176341763517636176371763817639176401764117642176431764417645176461764717648176491765017651176521765317654176551765617657176581765917660176611766217663176641766517666176671766817669176701767117672176731767417675176761767717678176791768017681176821768317684176851768617687176881768917690176911769217693176941769517696176971769817699177001770117702177031770417705177061770717708177091771017711177121771317714177151771617717177181771917720177211772217723177241772517726177271772817729177301773117732177331773417735177361773717738177391774017741177421774317744177451774617747177481774917750177511775217753177541775517756177571775817759177601776117762177631776417765177661776717768177691777017771177721777317774177751777617777177781777917780177811778217783177841778517786177871778817789177901779117792177931779417795177961779717798177991780017801178021780317804178051780617807178081780917810178111781217813178141781517816178171781817819178201782117822178231782417825178261782717828178291783017831178321783317834178351783617837178381783917840178411784217843178441784517846178471784817849178501785117852178531785417855178561785717858178591786017861178621786317864178651786617867178681786917870178711787217873178741787517876178771787817879178801788117882178831788417885178861788717888178891789017891178921789317894178951789617897178981789917900179011790217903179041790517906179071790817909179101791117912179131791417915179161791717918179191792017921179221792317924179251792617927179281792917930179311793217933179341793517936179371793817939179401794117942179431794417945179461794717948179491795017951179521795317954179551795617957179581795917960179611796217963179641796517966179671796817969179701797117972179731797417975179761797717978179791798017981179821798317984179851798617987179881798917990179911799217993179941799517996179971799817999180001800118002180031800418005180061800718008180091801018011180121801318014180151801618017180181801918020180211802218023180241802518026180271802818029180301803118032180331803418035180361803718038180391804018041180421804318044180451804618047180481804918050180511805218053180541805518056180571805818059180601806118062180631806418065180661806718068180691807018071180721807318074180751807618077180781807918080180811808218083180841808518086180871808818089180901809118092180931809418095180961809718098180991810018101181021810318104181051810618107181081810918110181111811218113181141811518116181171811818119181201812118122181231812418125181261812718128181291813018131181321813318134181351813618137181381813918140181411814218143181441814518146181471814818149181501815118152181531815418155181561815718158181591816018161181621816318164181651816618167181681816918170181711817218173181741817518176181771817818179181801818118182181831818418185181861818718188181891819018191181921819318194181951819618197181981819918200182011820218203182041820518206182071820818209182101821118212182131821418215182161821718218182191822018221182221822318224182251822618227182281822918230182311823218233182341823518236182371823818239182401824118242182431824418245182461824718248182491825018251182521825318254182551825618257182581825918260182611826218263182641826518266182671826818269182701827118272182731827418275182761827718278182791828018281182821828318284182851828618287182881828918290182911829218293182941829518296182971829818299183001830118302183031830418305183061830718308183091831018311183121831318314183151831618317183181831918320183211832218323183241832518326183271832818329183301833118332183331833418335183361833718338183391834018341183421834318344183451834618347183481834918350183511835218353183541835518356183571835818359183601836118362183631836418365183661836718368183691837018371183721837318374183751837618377183781837918380183811838218383183841838518386183871838818389183901839118392183931839418395183961839718398183991840018401184021840318404184051840618407184081840918410184111841218413184141841518416184171841818419184201842118422184231842418425184261842718428184291843018431184321843318434184351843618437184381843918440184411844218443184441844518446184471844818449184501845118452184531845418455184561845718458184591846018461184621846318464184651846618467184681846918470184711847218473184741847518476184771847818479184801848118482184831848418485184861848718488184891849018491184921849318494184951849618497184981849918500185011850218503185041850518506185071850818509185101851118512185131851418515185161851718518185191852018521185221852318524185251852618527185281852918530185311853218533185341853518536185371853818539185401854118542185431854418545185461854718548185491855018551185521855318554185551855618557185581855918560185611856218563185641856518566185671856818569185701857118572185731857418575185761857718578185791858018581185821858318584185851858618587185881858918590185911859218593185941859518596185971859818599186001860118602186031860418605186061860718608186091861018611186121861318614186151861618617186181861918620186211862218623186241862518626186271862818629186301863118632186331863418635186361863718638186391864018641186421864318644186451864618647186481864918650186511865218653186541865518656186571865818659186601866118662186631866418665186661866718668186691867018671186721867318674186751867618677186781867918680186811868218683186841868518686186871868818689186901869118692186931869418695186961869718698186991870018701187021870318704187051870618707187081870918710187111871218713187141871518716187171871818719187201872118722187231872418725187261872718728187291873018731187321873318734187351873618737187381873918740187411874218743187441874518746187471874818749187501875118752187531875418755187561875718758187591876018761187621876318764187651876618767187681876918770187711877218773187741877518776187771877818779187801878118782187831878418785187861878718788187891879018791187921879318794187951879618797187981879918800188011880218803188041880518806188071880818809188101881118812188131881418815188161881718818188191882018821188221882318824188251882618827188281882918830188311883218833188341883518836188371883818839188401884118842188431884418845188461884718848188491885018851188521885318854188551885618857188581885918860188611886218863188641886518866188671886818869188701887118872188731887418875188761887718878188791888018881188821888318884188851888618887188881888918890188911889218893188941889518896188971889818899189001890118902189031890418905189061890718908189091891018911189121891318914189151891618917189181891918920189211892218923189241892518926189271892818929189301893118932189331893418935189361893718938189391894018941189421894318944189451894618947189481894918950189511895218953189541895518956189571895818959189601896118962189631896418965189661896718968189691897018971189721897318974189751897618977189781897918980189811898218983189841898518986189871898818989189901899118992189931899418995189961899718998189991900019001190021900319004190051900619007190081900919010190111901219013190141901519016190171901819019190201902119022190231902419025190261902719028190291903019031190321903319034190351903619037190381903919040190411904219043190441904519046190471904819049190501905119052190531905419055190561905719058190591906019061190621906319064190651906619067190681906919070190711907219073190741907519076190771907819079190801908119082190831908419085190861908719088190891909019091190921909319094190951909619097190981909919100191011910219103191041910519106191071910819109191101911119112191131911419115191161911719118191191912019121191221912319124191251912619127191281912919130191311913219133191341913519136191371913819139191401914119142191431914419145191461914719148191491915019151191521915319154191551915619157191581915919160191611916219163191641916519166191671916819169191701917119172191731917419175191761917719178191791918019181191821918319184191851918619187191881918919190191911919219193191941919519196191971919819199192001920119202192031920419205192061920719208192091921019211192121921319214192151921619217192181921919220192211922219223192241922519226192271922819229192301923119232192331923419235192361923719238192391924019241192421924319244192451924619247192481924919250192511925219253192541925519256192571925819259192601926119262192631926419265192661926719268192691927019271192721927319274192751927619277192781927919280192811928219283192841928519286192871928819289192901929119292192931929419295192961929719298192991930019301193021930319304193051930619307193081930919310193111931219313193141931519316193171931819319193201932119322193231932419325193261932719328193291933019331193321933319334193351933619337193381933919340193411934219343193441934519346193471934819349193501935119352193531935419355193561935719358193591936019361193621936319364193651936619367193681936919370193711937219373193741937519376193771937819379193801938119382193831938419385193861938719388193891939019391193921939319394193951939619397193981939919400194011940219403194041940519406194071940819409194101941119412194131941419415194161941719418194191942019421194221942319424194251942619427194281942919430194311943219433194341943519436194371943819439194401944119442194431944419445194461944719448194491945019451194521945319454194551945619457194581945919460194611946219463194641946519466194671946819469194701947119472194731947419475194761947719478194791948019481194821948319484194851948619487194881948919490194911949219493194941949519496194971949819499195001950119502195031950419505195061950719508195091951019511195121951319514195151951619517195181951919520195211952219523195241952519526195271952819529195301953119532195331953419535195361953719538195391954019541195421954319544195451954619547195481954919550195511955219553195541955519556195571955819559195601956119562195631956419565195661956719568195691957019571195721957319574195751957619577195781957919580195811958219583195841958519586195871958819589195901959119592195931959419595195961959719598195991960019601196021960319604196051960619607196081960919610196111961219613196141961519616196171961819619196201962119622196231962419625196261962719628196291963019631196321963319634196351963619637196381963919640196411964219643196441964519646196471964819649196501965119652196531965419655196561965719658196591966019661196621966319664196651966619667196681966919670196711967219673196741967519676196771967819679196801968119682196831968419685196861968719688196891969019691196921969319694196951969619697196981969919700197011970219703197041970519706197071970819709197101971119712197131971419715197161971719718197191972019721197221972319724197251972619727197281972919730197311973219733197341973519736197371973819739197401974119742197431974419745197461974719748197491975019751197521975319754197551975619757197581975919760197611976219763197641976519766197671976819769197701977119772197731977419775197761977719778197791978019781197821978319784197851978619787197881978919790197911979219793197941979519796197971979819799198001980119802198031980419805198061980719808198091981019811198121981319814198151981619817198181981919820198211982219823198241982519826198271982819829198301983119832198331983419835198361983719838198391984019841198421984319844198451984619847198481984919850198511985219853198541985519856198571985819859198601986119862198631986419865198661986719868198691987019871198721987319874198751987619877198781987919880198811988219883198841988519886198871988819889198901989119892198931989419895198961989719898198991990019901199021990319904199051990619907199081990919910199111991219913199141991519916199171991819919199201992119922199231992419925199261992719928199291993019931199321993319934199351993619937199381993919940199411994219943199441994519946199471994819949199501995119952199531995419955199561995719958199591996019961199621996319964199651996619967199681996919970199711997219973199741997519976199771997819979199801998119982199831998419985199861998719988199891999019991199921999319994199951999619997199981999920000200012000220003200042000520006200072000820009200102001120012200132001420015200162001720018200192002020021200222002320024200252002620027200282002920030200312003220033200342003520036200372003820039200402004120042200432004420045200462004720048200492005020051200522005320054200552005620057200582005920060200612006220063200642006520066200672006820069200702007120072200732007420075200762007720078200792008020081200822008320084200852008620087200882008920090200912009220093200942009520096200972009820099201002010120102201032010420105201062010720108201092011020111201122011320114201152011620117201182011920120201212012220123201242012520126201272012820129201302013120132201332013420135201362013720138201392014020141201422014320144201452014620147201482014920150201512015220153201542015520156201572015820159201602016120162201632016420165201662016720168201692017020171201722017320174201752017620177201782017920180201812018220183201842018520186201872018820189201902019120192201932019420195201962019720198201992020020201202022020320204202052020620207202082020920210202112021220213202142021520216202172021820219202202022120222202232022420225202262022720228202292023020231202322023320234202352023620237202382023920240202412024220243202442024520246202472024820249202502025120252202532025420255202562025720258202592026020261202622026320264202652026620267202682026920270202712027220273202742027520276202772027820279202802028120282202832028420285202862028720288202892029020291202922029320294202952029620297202982029920300203012030220303203042030520306203072030820309203102031120312203132031420315203162031720318203192032020321203222032320324203252032620327203282032920330203312033220333203342033520336203372033820339203402034120342203432034420345203462034720348203492035020351203522035320354203552035620357203582035920360203612036220363203642036520366203672036820369203702037120372203732037420375203762037720378203792038020381203822038320384203852038620387203882038920390203912039220393203942039520396203972039820399204002040120402204032040420405204062040720408204092041020411204122041320414204152041620417204182041920420204212042220423204242042520426204272042820429204302043120432204332043420435204362043720438204392044020441204422044320444204452044620447204482044920450204512045220453204542045520456204572045820459204602046120462204632046420465204662046720468204692047020471204722047320474204752047620477204782047920480204812048220483204842048520486204872048820489204902049120492204932049420495204962049720498204992050020501205022050320504205052050620507205082050920510205112051220513205142051520516205172051820519205202052120522205232052420525205262052720528205292053020531205322053320534205352053620537205382053920540205412054220543205442054520546205472054820549205502055120552205532055420555205562055720558205592056020561205622056320564205652056620567205682056920570205712057220573205742057520576205772057820579205802058120582205832058420585205862058720588205892059020591205922059320594205952059620597205982059920600206012060220603206042060520606206072060820609206102061120612206132061420615206162061720618206192062020621206222062320624206252062620627206282062920630206312063220633206342063520636206372063820639206402064120642206432064420645206462064720648206492065020651206522065320654206552065620657206582065920660206612066220663206642066520666206672066820669206702067120672206732067420675206762067720678206792068020681206822068320684206852068620687206882068920690206912069220693206942069520696206972069820699207002070120702207032070420705207062070720708207092071020711207122071320714207152071620717207182071920720207212072220723207242072520726207272072820729207302073120732207332073420735207362073720738207392074020741207422074320744207452074620747207482074920750207512075220753207542075520756207572075820759207602076120762207632076420765207662076720768207692077020771207722077320774207752077620777207782077920780207812078220783207842078520786207872078820789207902079120792207932079420795207962079720798207992080020801208022080320804208052080620807208082080920810208112081220813208142081520816208172081820819208202082120822208232082420825208262082720828208292083020831208322083320834208352083620837208382083920840208412084220843208442084520846208472084820849208502085120852208532085420855208562085720858208592086020861208622086320864208652086620867208682086920870208712087220873208742087520876208772087820879208802088120882208832088420885208862088720888208892089020891208922089320894208952089620897208982089920900209012090220903209042090520906209072090820909209102091120912209132091420915209162091720918209192092020921209222092320924209252092620927209282092920930209312093220933209342093520936209372093820939209402094120942209432094420945209462094720948209492095020951209522095320954209552095620957209582095920960209612096220963209642096520966209672096820969209702097120972209732097420975209762097720978209792098020981209822098320984209852098620987209882098920990209912099220993209942099520996209972099820999210002100121002210032100421005210062100721008210092101021011210122101321014210152101621017210182101921020210212102221023210242102521026210272102821029210302103121032210332103421035210362103721038210392104021041210422104321044210452104621047210482104921050210512105221053210542105521056210572105821059210602106121062210632106421065210662106721068210692107021071210722107321074210752107621077210782107921080210812108221083210842108521086210872108821089210902109121092210932109421095210962109721098210992110021101211022110321104211052110621107211082110921110211112111221113211142111521116211172111821119211202112121122211232112421125211262112721128211292113021131211322113321134211352113621137211382113921140211412114221143211442114521146211472114821149211502115121152211532115421155211562115721158211592116021161211622116321164211652116621167211682116921170211712117221173211742117521176211772117821179211802118121182211832118421185211862118721188211892119021191211922119321194211952119621197211982119921200212012120221203212042120521206212072120821209212102121121212212132121421215212162121721218212192122021221212222122321224212252122621227212282122921230212312123221233212342123521236212372123821239212402124121242212432124421245212462124721248212492125021251212522125321254212552125621257212582125921260212612126221263212642126521266212672126821269212702127121272212732127421275212762127721278212792128021281212822128321284212852128621287212882128921290212912129221293212942129521296212972129821299213002130121302213032130421305213062130721308213092131021311213122131321314213152131621317213182131921320213212132221323213242132521326213272132821329213302133121332213332133421335213362133721338213392134021341213422134321344213452134621347213482134921350213512135221353213542135521356213572135821359213602136121362213632136421365213662136721368213692137021371213722137321374213752137621377213782137921380213812138221383213842138521386213872138821389213902139121392213932139421395213962139721398213992140021401214022140321404214052140621407214082140921410214112141221413214142141521416214172141821419214202142121422214232142421425214262142721428214292143021431214322143321434214352143621437214382143921440214412144221443214442144521446214472144821449214502145121452214532145421455214562145721458214592146021461214622146321464214652146621467214682146921470214712147221473214742147521476214772147821479214802148121482214832148421485214862148721488214892149021491214922149321494214952149621497214982149921500215012150221503215042150521506215072150821509215102151121512215132151421515215162151721518215192152021521215222152321524215252152621527215282152921530215312153221533215342153521536215372153821539215402154121542215432154421545215462154721548215492155021551215522155321554215552155621557215582155921560215612156221563215642156521566215672156821569215702157121572215732157421575215762157721578215792158021581215822158321584215852158621587215882158921590215912159221593215942159521596215972159821599216002160121602216032160421605216062160721608216092161021611216122161321614216152161621617216182161921620216212162221623216242162521626216272162821629216302163121632216332163421635216362163721638216392164021641216422164321644216452164621647216482164921650216512165221653216542165521656216572165821659216602166121662216632166421665216662166721668216692167021671216722167321674216752167621677216782167921680216812168221683216842168521686216872168821689216902169121692216932169421695216962169721698216992170021701217022170321704217052170621707217082170921710217112171221713217142171521716217172171821719217202172121722217232172421725217262172721728217292173021731217322173321734217352173621737217382173921740217412174221743217442174521746217472174821749217502175121752217532175421755217562175721758217592176021761217622176321764217652176621767217682176921770217712177221773217742177521776217772177821779217802178121782217832178421785217862178721788217892179021791217922179321794217952179621797217982179921800218012180221803218042180521806218072180821809218102181121812218132181421815218162181721818218192182021821218222182321824218252182621827218282182921830218312183221833218342183521836218372183821839218402184121842218432184421845218462184721848218492185021851218522185321854218552185621857218582185921860218612186221863218642186521866218672186821869218702187121872218732187421875218762187721878218792188021881218822188321884218852188621887218882188921890218912189221893218942189521896218972189821899219002190121902219032190421905219062190721908219092191021911219122191321914219152191621917219182191921920219212192221923219242192521926219272192821929219302193121932219332193421935219362193721938219392194021941219422194321944219452194621947219482194921950219512195221953219542195521956219572195821959219602196121962219632196421965219662196721968219692197021971219722197321974219752197621977219782197921980219812198221983219842198521986219872198821989219902199121992219932199421995219962199721998219992200022001220022200322004220052200622007220082200922010220112201222013220142201522016220172201822019220202202122022220232202422025220262202722028220292203022031220322203322034220352203622037220382203922040220412204222043220442204522046220472204822049220502205122052220532205422055220562205722058220592206022061220622206322064220652206622067220682206922070220712207222073220742207522076220772207822079220802208122082220832208422085220862208722088220892209022091220922209322094220952209622097220982209922100221012210222103221042210522106221072210822109221102211122112221132211422115221162211722118221192212022121221222212322124221252212622127221282212922130221312213222133221342213522136221372213822139221402214122142221432214422145221462214722148221492215022151221522215322154221552215622157221582215922160221612216222163221642216522166221672216822169221702217122172221732217422175221762217722178221792218022181221822218322184221852218622187221882218922190221912219222193221942219522196221972219822199222002220122202222032220422205222062220722208222092221022211222122221322214222152221622217222182221922220222212222222223222242222522226222272222822229222302223122232222332223422235222362223722238222392224022241222422224322244222452224622247222482224922250222512225222253222542225522256222572225822259222602226122262222632226422265222662226722268222692227022271222722227322274222752227622277222782227922280222812228222283222842228522286222872228822289222902229122292222932229422295222962229722298222992230022301223022230322304223052230622307223082230922310223112231222313223142231522316223172231822319223202232122322223232232422325223262232722328223292233022331223322233322334223352233622337223382233922340223412234222343223442234522346223472234822349223502235122352223532235422355223562235722358223592236022361223622236322364223652236622367223682236922370223712237222373223742237522376223772237822379223802238122382223832238422385223862238722388223892239022391223922239322394223952239622397223982239922400224012240222403224042240522406224072240822409224102241122412224132241422415224162241722418224192242022421224222242322424224252242622427224282242922430224312243222433224342243522436224372243822439224402244122442224432244422445224462244722448224492245022451224522245322454224552245622457224582245922460224612246222463224642246522466224672246822469224702247122472224732247422475224762247722478224792248022481224822248322484224852248622487224882248922490224912249222493224942249522496224972249822499225002250122502225032250422505225062250722508225092251022511225122251322514225152251622517225182251922520225212252222523225242252522526225272252822529225302253122532225332253422535225362253722538225392254022541225422254322544225452254622547225482254922550225512255222553225542255522556225572255822559225602256122562225632256422565225662256722568225692257022571225722257322574225752257622577225782257922580225812258222583225842258522586225872258822589225902259122592225932259422595225962259722598225992260022601226022260322604226052260622607226082260922610226112261222613226142261522616226172261822619226202262122622226232262422625226262262722628226292263022631226322263322634226352263622637226382263922640226412264222643226442264522646226472264822649226502265122652226532265422655226562265722658226592266022661226622266322664226652266622667226682266922670226712267222673226742267522676226772267822679226802268122682226832268422685226862268722688226892269022691226922269322694226952269622697226982269922700227012270222703227042270522706227072270822709227102271122712227132271422715227162271722718227192272022721227222272322724227252272622727227282272922730227312273222733227342273522736227372273822739227402274122742227432274422745227462274722748227492275022751227522275322754227552275622757227582275922760227612276222763227642276522766227672276822769227702277122772227732277422775227762277722778227792278022781227822278322784227852278622787227882278922790227912279222793227942279522796227972279822799228002280122802228032280422805228062280722808228092281022811228122281322814228152281622817228182281922820228212282222823228242282522826228272282822829228302283122832228332283422835228362283722838228392284022841228422284322844228452284622847228482284922850228512285222853228542285522856228572285822859228602286122862228632286422865228662286722868228692287022871228722287322874228752287622877228782287922880228812288222883228842288522886228872288822889228902289122892228932289422895228962289722898228992290022901229022290322904229052290622907229082290922910229112291222913229142291522916229172291822919229202292122922229232292422925229262292722928229292293022931229322293322934229352293622937229382293922940229412294222943229442294522946229472294822949229502295122952229532295422955229562295722958229592296022961229622296322964229652296622967229682296922970229712297222973229742297522976229772297822979229802298122982229832298422985229862298722988229892299022991229922299322994229952299622997229982299923000230012300223003230042300523006230072300823009230102301123012230132301423015230162301723018230192302023021230222302323024230252302623027230282302923030230312303223033230342303523036230372303823039230402304123042230432304423045230462304723048230492305023051230522305323054230552305623057230582305923060230612306223063230642306523066230672306823069230702307123072230732307423075230762307723078230792308023081230822308323084230852308623087230882308923090230912309223093230942309523096230972309823099231002310123102231032310423105231062310723108231092311023111231122311323114231152311623117231182311923120231212312223123231242312523126231272312823129231302313123132231332313423135231362313723138231392314023141231422314323144231452314623147231482314923150231512315223153231542315523156231572315823159231602316123162231632316423165231662316723168231692317023171231722317323174231752317623177231782317923180231812318223183231842318523186231872318823189231902319123192231932319423195231962319723198231992320023201232022320323204232052320623207232082320923210232112321223213232142321523216232172321823219232202322123222232232322423225232262322723228232292323023231232322323323234232352323623237232382323923240232412324223243232442324523246232472324823249232502325123252232532325423255232562325723258232592326023261232622326323264232652326623267232682326923270232712327223273232742327523276232772327823279232802328123282232832328423285232862328723288232892329023291232922329323294232952329623297232982329923300233012330223303233042330523306233072330823309233102331123312233132331423315233162331723318233192332023321233222332323324233252332623327233282332923330233312333223333233342333523336233372333823339233402334123342233432334423345233462334723348233492335023351233522335323354233552335623357233582335923360233612336223363233642336523366233672336823369233702337123372233732337423375233762337723378233792338023381233822338323384233852338623387233882338923390233912339223393233942339523396233972339823399234002340123402234032340423405234062340723408234092341023411234122341323414234152341623417234182341923420234212342223423234242342523426234272342823429234302343123432234332343423435234362343723438234392344023441234422344323444234452344623447234482344923450234512345223453234542345523456234572345823459234602346123462234632346423465234662346723468234692347023471234722347323474234752347623477234782347923480234812348223483234842348523486234872348823489234902349123492234932349423495234962349723498234992350023501235022350323504235052350623507235082350923510235112351223513235142351523516235172351823519235202352123522235232352423525235262352723528235292353023531235322353323534235352353623537235382353923540235412354223543235442354523546235472354823549235502355123552235532355423555235562355723558235592356023561235622356323564235652356623567235682356923570235712357223573235742357523576235772357823579235802358123582235832358423585235862358723588235892359023591235922359323594235952359623597235982359923600236012360223603236042360523606236072360823609236102361123612236132361423615236162361723618236192362023621236222362323624236252362623627236282362923630236312363223633236342363523636236372363823639236402364123642236432364423645236462364723648236492365023651236522365323654236552365623657236582365923660236612366223663236642366523666236672366823669236702367123672236732367423675236762367723678236792368023681236822368323684236852368623687236882368923690236912369223693236942369523696236972369823699237002370123702237032370423705237062370723708237092371023711237122371323714237152371623717237182371923720237212372223723237242372523726237272372823729237302373123732237332373423735237362373723738237392374023741237422374323744237452374623747237482374923750237512375223753237542375523756237572375823759237602376123762237632376423765237662376723768237692377023771237722377323774237752377623777237782377923780237812378223783237842378523786237872378823789237902379123792237932379423795237962379723798237992380023801238022380323804238052380623807238082380923810238112381223813238142381523816238172381823819238202382123822238232382423825238262382723828238292383023831238322383323834238352383623837238382383923840238412384223843238442384523846238472384823849238502385123852238532385423855238562385723858238592386023861238622386323864238652386623867238682386923870238712387223873238742387523876238772387823879238802388123882238832388423885238862388723888238892389023891238922389323894238952389623897238982389923900239012390223903239042390523906239072390823909239102391123912239132391423915239162391723918239192392023921239222392323924239252392623927239282392923930239312393223933239342393523936239372393823939239402394123942239432394423945239462394723948239492395023951239522395323954239552395623957239582395923960239612396223963239642396523966239672396823969239702397123972239732397423975239762397723978239792398023981239822398323984239852398623987239882398923990239912399223993239942399523996239972399823999240002400124002240032400424005240062400724008240092401024011240122401324014240152401624017240182401924020240212402224023240242402524026240272402824029240302403124032240332403424035240362403724038240392404024041240422404324044240452404624047240482404924050240512405224053240542405524056240572405824059240602406124062240632406424065240662406724068240692407024071240722407324074240752407624077240782407924080240812408224083240842408524086240872408824089240902409124092240932409424095240962409724098240992410024101241022410324104241052410624107241082410924110241112411224113241142411524116241172411824119241202412124122241232412424125241262412724128241292413024131241322413324134241352413624137241382413924140241412414224143241442414524146241472414824149241502415124152241532415424155241562415724158241592416024161241622416324164241652416624167241682416924170241712417224173241742417524176241772417824179241802418124182241832418424185241862418724188241892419024191241922419324194241952419624197241982419924200242012420224203242042420524206242072420824209242102421124212242132421424215242162421724218242192422024221242222422324224242252422624227242282422924230242312423224233242342423524236242372423824239242402424124242242432424424245242462424724248242492425024251242522425324254242552425624257242582425924260242612426224263242642426524266242672426824269242702427124272242732427424275242762427724278242792428024281242822428324284242852428624287242882428924290242912429224293242942429524296242972429824299243002430124302243032430424305243062430724308243092431024311243122431324314243152431624317243182431924320243212432224323243242432524326243272432824329243302433124332243332433424335243362433724338243392434024341243422434324344243452434624347243482434924350243512435224353243542435524356243572435824359243602436124362243632436424365243662436724368243692437024371243722437324374243752437624377243782437924380243812438224383243842438524386243872438824389243902439124392243932439424395243962439724398243992440024401244022440324404244052440624407244082440924410244112441224413244142441524416244172441824419244202442124422244232442424425244262442724428244292443024431244322443324434244352443624437244382443924440244412444224443244442444524446244472444824449244502445124452244532445424455244562445724458244592446024461244622446324464244652446624467244682446924470244712447224473244742447524476244772447824479244802448124482244832448424485244862448724488244892449024491244922449324494244952449624497244982449924500245012450224503245042450524506245072450824509245102451124512245132451424515245162451724518245192452024521245222452324524245252452624527245282452924530245312453224533245342453524536245372453824539245402454124542245432454424545245462454724548245492455024551245522455324554245552455624557245582455924560245612456224563245642456524566245672456824569245702457124572245732457424575245762457724578245792458024581245822458324584245852458624587245882458924590245912459224593245942459524596245972459824599246002460124602246032460424605246062460724608246092461024611246122461324614246152461624617246182461924620246212462224623246242462524626246272462824629246302463124632246332463424635246362463724638246392464024641246422464324644246452464624647246482464924650246512465224653246542465524656246572465824659246602466124662246632466424665246662466724668246692467024671246722467324674246752467624677246782467924680246812468224683246842468524686246872468824689246902469124692246932469424695246962469724698246992470024701247022470324704247052470624707247082470924710247112471224713247142471524716247172471824719247202472124722247232472424725247262472724728247292473024731247322473324734247352473624737247382473924740247412474224743247442474524746247472474824749247502475124752247532475424755247562475724758247592476024761247622476324764247652476624767247682476924770247712477224773247742477524776247772477824779247802478124782247832478424785247862478724788247892479024791247922479324794247952479624797247982479924800248012480224803248042480524806248072480824809248102481124812248132481424815248162481724818248192482024821248222482324824248252482624827248282482924830248312483224833248342483524836248372483824839248402484124842248432484424845248462484724848248492485024851248522485324854248552485624857248582485924860248612486224863248642486524866248672486824869248702487124872248732487424875248762487724878248792488024881248822488324884248852488624887248882488924890248912489224893248942489524896248972489824899249002490124902249032490424905249062490724908249092491024911249122491324914249152491624917249182491924920249212492224923249242492524926249272492824929249302493124932249332493424935249362493724938249392494024941249422494324944249452494624947249482494924950249512495224953249542495524956249572495824959249602496124962249632496424965249662496724968249692497024971249722497324974249752497624977249782497924980249812498224983249842498524986249872498824989249902499124992249932499424995249962499724998249992500025001250022500325004250052500625007250082500925010250112501225013250142501525016250172501825019250202502125022250232502425025250262502725028250292503025031250322503325034250352503625037250382503925040250412504225043250442504525046250472504825049250502505125052250532505425055250562505725058250592506025061250622506325064250652506625067250682506925070250712507225073250742507525076250772507825079250802508125082250832508425085250862508725088250892509025091250922509325094250952509625097250982509925100251012510225103251042510525106251072510825109251102511125112251132511425115251162511725118251192512025121251222512325124251252512625127251282512925130251312513225133251342513525136251372513825139251402514125142251432514425145251462514725148251492515025151251522515325154251552515625157251582515925160251612516225163251642516525166251672516825169251702517125172251732517425175251762517725178251792518025181251822518325184251852518625187251882518925190251912519225193251942519525196251972519825199252002520125202252032520425205252062520725208252092521025211252122521325214252152521625217252182521925220252212522225223252242522525226252272522825229252302523125232252332523425235252362523725238252392524025241252422524325244252452524625247252482524925250252512525225253252542525525256252572525825259252602526125262252632526425265252662526725268252692527025271252722527325274252752527625277252782527925280252812528225283252842528525286252872528825289252902529125292252932529425295252962529725298252992530025301253022530325304253052530625307253082530925310253112531225313253142531525316253172531825319253202532125322253232532425325253262532725328253292533025331253322533325334253352533625337253382533925340253412534225343253442534525346253472534825349253502535125352253532535425355253562535725358253592536025361253622536325364253652536625367253682536925370253712537225373253742537525376253772537825379253802538125382253832538425385253862538725388253892539025391253922539325394253952539625397253982539925400254012540225403254042540525406254072540825409254102541125412254132541425415254162541725418254192542025421254222542325424254252542625427254282542925430254312543225433254342543525436254372543825439254402544125442254432544425445254462544725448254492545025451254522545325454254552545625457254582545925460254612546225463254642546525466254672546825469254702547125472254732547425475254762547725478254792548025481254822548325484254852548625487254882548925490254912549225493254942549525496254972549825499255002550125502255032550425505255062550725508255092551025511255122551325514255152551625517255182551925520255212552225523255242552525526255272552825529255302553125532255332553425535255362553725538255392554025541255422554325544255452554625547255482554925550255512555225553255542555525556255572555825559255602556125562255632556425565255662556725568255692557025571255722557325574255752557625577255782557925580255812558225583255842558525586255872558825589255902559125592255932559425595255962559725598255992560025601256022560325604256052560625607256082560925610256112561225613256142561525616256172561825619256202562125622256232562425625256262562725628256292563025631256322563325634256352563625637256382563925640256412564225643256442564525646256472564825649256502565125652256532565425655256562565725658256592566025661256622566325664256652566625667256682566925670256712567225673256742567525676256772567825679256802568125682256832568425685256862568725688256892569025691256922569325694256952569625697256982569925700257012570225703257042570525706257072570825709257102571125712257132571425715257162571725718257192572025721257222572325724257252572625727257282572925730257312573225733257342573525736257372573825739257402574125742257432574425745257462574725748257492575025751257522575325754257552575625757257582575925760257612576225763257642576525766257672576825769257702577125772257732577425775257762577725778257792578025781257822578325784257852578625787257882578925790257912579225793257942579525796257972579825799258002580125802258032580425805258062580725808258092581025811258122581325814258152581625817258182581925820258212582225823258242582525826258272582825829258302583125832258332583425835258362583725838258392584025841258422584325844258452584625847258482584925850258512585225853258542585525856258572585825859258602586125862258632586425865258662586725868258692587025871258722587325874258752587625877258782587925880258812588225883258842588525886258872588825889258902589125892258932589425895258962589725898258992590025901259022590325904259052590625907259082590925910259112591225913259142591525916259172591825919259202592125922259232592425925259262592725928259292593025931259322593325934259352593625937259382593925940259412594225943259442594525946259472594825949259502595125952259532595425955259562595725958259592596025961259622596325964259652596625967259682596925970259712597225973259742597525976259772597825979259802598125982259832598425985259862598725988259892599025991259922599325994259952599625997259982599926000260012600226003260042600526006260072600826009260102601126012260132601426015260162601726018260192602026021260222602326024260252602626027260282602926030260312603226033260342603526036260372603826039260402604126042260432604426045260462604726048260492605026051260522605326054260552605626057260582605926060260612606226063260642606526066260672606826069260702607126072260732607426075260762607726078260792608026081260822608326084260852608626087260882608926090260912609226093260942609526096260972609826099261002610126102261032610426105261062610726108261092611026111261122611326114261152611626117261182611926120261212612226123261242612526126261272612826129261302613126132261332613426135261362613726138261392614026141261422614326144261452614626147261482614926150261512615226153261542615526156261572615826159261602616126162261632616426165261662616726168261692617026171261722617326174261752617626177261782617926180261812618226183261842618526186261872618826189261902619126192261932619426195261962619726198261992620026201262022620326204262052620626207262082620926210262112621226213262142621526216262172621826219262202622126222262232622426225262262622726228262292623026231262322623326234262352623626237262382623926240262412624226243262442624526246262472624826249262502625126252262532625426255262562625726258262592626026261262622626326264262652626626267262682626926270262712627226273262742627526276262772627826279262802628126282262832628426285262862628726288262892629026291262922629326294262952629626297262982629926300263012630226303263042630526306263072630826309263102631126312263132631426315263162631726318263192632026321263222632326324263252632626327263282632926330263312633226333263342633526336263372633826339263402634126342263432634426345263462634726348263492635026351263522635326354263552635626357263582635926360263612636226363263642636526366263672636826369263702637126372263732637426375263762637726378263792638026381263822638326384263852638626387263882638926390263912639226393263942639526396263972639826399264002640126402264032640426405264062640726408264092641026411264122641326414264152641626417264182641926420264212642226423264242642526426264272642826429264302643126432264332643426435264362643726438264392644026441264422644326444264452644626447264482644926450264512645226453264542645526456264572645826459264602646126462264632646426465264662646726468264692647026471264722647326474264752647626477264782647926480264812648226483264842648526486264872648826489264902649126492264932649426495264962649726498264992650026501265022650326504265052650626507265082650926510265112651226513265142651526516265172651826519265202652126522265232652426525265262652726528265292653026531265322653326534265352653626537265382653926540265412654226543265442654526546265472654826549265502655126552265532655426555265562655726558265592656026561265622656326564265652656626567265682656926570265712657226573265742657526576265772657826579265802658126582265832658426585265862658726588265892659026591265922659326594265952659626597265982659926600266012660226603266042660526606266072660826609266102661126612266132661426615266162661726618266192662026621266222662326624266252662626627266282662926630266312663226633266342663526636266372663826639266402664126642266432664426645266462664726648266492665026651266522665326654266552665626657266582665926660266612666226663266642666526666266672666826669266702667126672266732667426675266762667726678266792668026681266822668326684266852668626687266882668926690266912669226693266942669526696266972669826699267002670126702267032670426705267062670726708267092671026711267122671326714267152671626717267182671926720267212672226723267242672526726267272672826729267302673126732267332673426735267362673726738267392674026741267422674326744267452674626747267482674926750267512675226753267542675526756267572675826759267602676126762267632676426765267662676726768267692677026771267722677326774267752677626777267782677926780267812678226783267842678526786267872678826789267902679126792267932679426795267962679726798267992680026801268022680326804268052680626807268082680926810268112681226813268142681526816268172681826819268202682126822268232682426825268262682726828268292683026831268322683326834268352683626837268382683926840268412684226843268442684526846268472684826849268502685126852268532685426855268562685726858268592686026861268622686326864268652686626867268682686926870268712687226873268742687526876268772687826879268802688126882268832688426885268862688726888268892689026891268922689326894268952689626897268982689926900269012690226903269042690526906269072690826909269102691126912269132691426915269162691726918269192692026921269222692326924269252692626927269282692926930269312693226933269342693526936269372693826939269402694126942269432694426945269462694726948269492695026951269522695326954269552695626957269582695926960269612696226963269642696526966269672696826969269702697126972269732697426975269762697726978269792698026981269822698326984269852698626987269882698926990269912699226993269942699526996269972699826999270002700127002270032700427005270062700727008270092701027011270122701327014270152701627017270182701927020270212702227023270242702527026270272702827029270302703127032270332703427035270362703727038270392704027041270422704327044270452704627047270482704927050270512705227053270542705527056270572705827059270602706127062270632706427065270662706727068270692707027071270722707327074270752707627077270782707927080270812708227083270842708527086270872708827089270902709127092270932709427095270962709727098270992710027101271022710327104271052710627107271082710927110271112711227113271142711527116271172711827119271202712127122271232712427125271262712727128271292713027131271322713327134271352713627137271382713927140271412714227143271442714527146271472714827149271502715127152271532715427155271562715727158271592716027161271622716327164271652716627167271682716927170271712717227173271742717527176271772717827179271802718127182271832718427185271862718727188271892719027191271922719327194271952719627197271982719927200272012720227203272042720527206272072720827209272102721127212272132721427215272162721727218272192722027221272222722327224272252722627227272282722927230272312723227233272342723527236272372723827239272402724127242272432724427245272462724727248272492725027251272522725327254272552725627257272582725927260272612726227263272642726527266272672726827269272702727127272272732727427275272762727727278272792728027281272822728327284272852728627287272882728927290272912729227293272942729527296272972729827299273002730127302273032730427305273062730727308273092731027311273122731327314273152731627317273182731927320273212732227323273242732527326273272732827329273302733127332273332733427335273362733727338273392734027341273422734327344273452734627347273482734927350273512735227353273542735527356273572735827359273602736127362273632736427365273662736727368273692737027371273722737327374273752737627377273782737927380273812738227383273842738527386273872738827389273902739127392273932739427395273962739727398273992740027401274022740327404274052740627407274082740927410274112741227413274142741527416274172741827419274202742127422274232742427425274262742727428274292743027431274322743327434274352743627437274382743927440274412744227443274442744527446274472744827449274502745127452274532745427455274562745727458274592746027461274622746327464274652746627467274682746927470274712747227473274742747527476274772747827479274802748127482274832748427485274862748727488274892749027491274922749327494274952749627497274982749927500275012750227503275042750527506275072750827509275102751127512275132751427515275162751727518275192752027521275222752327524275252752627527275282752927530275312753227533275342753527536275372753827539275402754127542275432754427545275462754727548275492755027551275522755327554275552755627557275582755927560275612756227563275642756527566275672756827569275702757127572275732757427575275762757727578275792758027581275822758327584275852758627587275882758927590275912759227593275942759527596275972759827599276002760127602276032760427605276062760727608276092761027611276122761327614276152761627617276182761927620276212762227623276242762527626276272762827629276302763127632276332763427635276362763727638276392764027641276422764327644276452764627647276482764927650276512765227653276542765527656276572765827659276602766127662276632766427665276662766727668276692767027671276722767327674276752767627677276782767927680276812768227683276842768527686276872768827689276902769127692276932769427695276962769727698276992770027701277022770327704277052770627707277082770927710277112771227713277142771527716277172771827719277202772127722277232772427725277262772727728277292773027731277322773327734277352773627737277382773927740277412774227743277442774527746277472774827749277502775127752277532775427755277562775727758277592776027761277622776327764277652776627767277682776927770277712777227773277742777527776277772777827779277802778127782277832778427785277862778727788277892779027791277922779327794277952779627797277982779927800278012780227803278042780527806278072780827809278102781127812278132781427815278162781727818278192782027821278222782327824278252782627827278282782927830278312783227833278342783527836278372783827839278402784127842278432784427845278462784727848278492785027851278522785327854278552785627857278582785927860278612786227863278642786527866278672786827869278702787127872278732787427875278762787727878278792788027881278822788327884278852788627887278882788927890278912789227893278942789527896278972789827899279002790127902279032790427905279062790727908279092791027911279122791327914279152791627917279182791927920279212792227923279242792527926279272792827929279302793127932279332793427935279362793727938279392794027941279422794327944279452794627947279482794927950279512795227953279542795527956279572795827959279602796127962279632796427965279662796727968279692797027971279722797327974279752797627977279782797927980279812798227983279842798527986279872798827989279902799127992279932799427995279962799727998279992800028001280022800328004280052800628007280082800928010280112801228013280142801528016280172801828019280202802128022280232802428025280262802728028280292803028031280322803328034280352803628037280382803928040280412804228043280442804528046280472804828049280502805128052280532805428055280562805728058280592806028061280622806328064280652806628067280682806928070280712807228073280742807528076280772807828079280802808128082280832808428085280862808728088280892809028091280922809328094280952809628097280982809928100281012810228103281042810528106281072810828109281102811128112281132811428115281162811728118281192812028121281222812328124281252812628127281282812928130281312813228133281342813528136281372813828139281402814128142281432814428145281462814728148281492815028151281522815328154281552815628157281582815928160281612816228163281642816528166281672816828169281702817128172281732817428175281762817728178281792818028181281822818328184281852818628187281882818928190281912819228193281942819528196281972819828199282002820128202282032820428205282062820728208282092821028211282122821328214282152821628217282182821928220282212822228223282242822528226282272822828229282302823128232282332823428235282362823728238282392824028241282422824328244282452824628247282482824928250282512825228253282542825528256282572825828259282602826128262282632826428265282662826728268282692827028271282722827328274282752827628277282782827928280282812828228283282842828528286282872828828289282902829128292282932829428295282962829728298282992830028301283022830328304283052830628307283082830928310283112831228313283142831528316283172831828319283202832128322283232832428325283262832728328283292833028331283322833328334283352833628337283382833928340283412834228343283442834528346283472834828349283502835128352283532835428355283562835728358283592836028361283622836328364283652836628367283682836928370283712837228373283742837528376283772837828379283802838128382283832838428385283862838728388283892839028391283922839328394283952839628397283982839928400284012840228403284042840528406284072840828409284102841128412284132841428415284162841728418284192842028421284222842328424284252842628427284282842928430284312843228433284342843528436284372843828439284402844128442284432844428445284462844728448284492845028451284522845328454284552845628457284582845928460284612846228463284642846528466284672846828469284702847128472284732847428475284762847728478284792848028481284822848328484284852848628487284882848928490284912849228493284942849528496284972849828499285002850128502285032850428505285062850728508285092851028511285122851328514285152851628517285182851928520285212852228523285242852528526285272852828529285302853128532285332853428535285362853728538285392854028541285422854328544285452854628547285482854928550285512855228553285542855528556285572855828559285602856128562285632856428565285662856728568285692857028571285722857328574285752857628577285782857928580285812858228583285842858528586285872858828589285902859128592285932859428595285962859728598285992860028601286022860328604286052860628607286082860928610286112861228613286142861528616286172861828619286202862128622286232862428625286262862728628286292863028631286322863328634286352863628637286382863928640286412864228643286442864528646286472864828649286502865128652286532865428655286562865728658286592866028661286622866328664286652866628667286682866928670286712867228673286742867528676286772867828679286802868128682286832868428685286862868728688286892869028691286922869328694286952869628697286982869928700287012870228703287042870528706287072870828709287102871128712287132871428715287162871728718287192872028721287222872328724287252872628727287282872928730287312873228733287342873528736287372873828739287402874128742287432874428745287462874728748287492875028751287522875328754287552875628757287582875928760287612876228763287642876528766287672876828769287702877128772287732877428775287762877728778287792878028781287822878328784287852878628787287882878928790287912879228793287942879528796287972879828799288002880128802288032880428805288062880728808288092881028811288122881328814288152881628817288182881928820288212882228823288242882528826288272882828829288302883128832288332883428835288362883728838288392884028841288422884328844288452884628847288482884928850288512885228853288542885528856288572885828859288602886128862288632886428865288662886728868288692887028871288722887328874288752887628877288782887928880288812888228883288842888528886288872888828889288902889128892288932889428895288962889728898288992890028901289022890328904289052890628907289082890928910289112891228913289142891528916289172891828919289202892128922289232892428925289262892728928289292893028931289322893328934289352893628937289382893928940289412894228943289442894528946289472894828949289502895128952289532895428955289562895728958289592896028961289622896328964289652896628967289682896928970289712897228973289742897528976289772897828979289802898128982289832898428985289862898728988289892899028991289922899328994289952899628997289982899929000290012900229003290042900529006290072900829009290102901129012290132901429015290162901729018290192902029021290222902329024290252902629027290282902929030290312903229033290342903529036290372903829039290402904129042290432904429045290462904729048290492905029051290522905329054290552905629057290582905929060290612906229063290642906529066290672906829069290702907129072290732907429075290762907729078290792908029081290822908329084290852908629087290882908929090290912909229093290942909529096290972909829099291002910129102291032910429105291062910729108291092911029111291122911329114291152911629117291182911929120291212912229123291242912529126291272912829129291302913129132291332913429135291362913729138291392914029141291422914329144291452914629147291482914929150291512915229153291542915529156291572915829159291602916129162291632916429165291662916729168291692917029171291722917329174291752917629177291782917929180291812918229183291842918529186291872918829189291902919129192291932919429195291962919729198291992920029201292022920329204292052920629207292082920929210292112921229213292142921529216292172921829219292202922129222292232922429225292262922729228292292923029231292322923329234292352923629237292382923929240292412924229243292442924529246292472924829249292502925129252292532925429255292562925729258292592926029261292622926329264292652926629267292682926929270292712927229273292742927529276292772927829279292802928129282292832928429285292862928729288292892929029291292922929329294292952929629297292982929929300293012930229303293042930529306293072930829309293102931129312293132931429315293162931729318293192932029321293222932329324293252932629327293282932929330293312933229333293342933529336293372933829339293402934129342293432934429345293462934729348293492935029351293522935329354293552935629357293582935929360293612936229363293642936529366293672936829369293702937129372293732937429375293762937729378293792938029381293822938329384293852938629387293882938929390293912939229393293942939529396293972939829399294002940129402294032940429405294062940729408294092941029411294122941329414294152941629417294182941929420294212942229423294242942529426294272942829429294302943129432294332943429435294362943729438294392944029441294422944329444294452944629447294482944929450294512945229453294542945529456294572945829459294602946129462294632946429465294662946729468294692947029471294722947329474294752947629477294782947929480294812948229483294842948529486294872948829489294902949129492294932949429495294962949729498294992950029501295022950329504295052950629507295082950929510295112951229513295142951529516295172951829519295202952129522295232952429525295262952729528295292953029531295322953329534295352953629537295382953929540295412954229543295442954529546295472954829549295502955129552295532955429555295562955729558295592956029561295622956329564295652956629567295682956929570295712957229573295742957529576295772957829579295802958129582295832958429585295862958729588295892959029591295922959329594295952959629597295982959929600296012960229603296042960529606296072960829609296102961129612296132961429615296162961729618296192962029621296222962329624296252962629627296282962929630296312963229633296342963529636296372963829639296402964129642296432964429645296462964729648296492965029651296522965329654296552965629657296582965929660296612966229663296642966529666296672966829669296702967129672296732967429675296762967729678296792968029681296822968329684296852968629687296882968929690296912969229693296942969529696296972969829699297002970129702297032970429705297062970729708297092971029711297122971329714297152971629717297182971929720297212972229723297242972529726297272972829729297302973129732297332973429735297362973729738297392974029741297422974329744297452974629747297482974929750297512975229753297542975529756297572975829759297602976129762297632976429765297662976729768297692977029771297722977329774297752977629777297782977929780297812978229783297842978529786297872978829789297902979129792297932979429795297962979729798297992980029801298022980329804298052980629807298082980929810298112981229813298142981529816298172981829819298202982129822298232982429825298262982729828298292983029831298322983329834298352983629837298382983929840298412984229843298442984529846298472984829849298502985129852298532985429855298562985729858298592986029861298622986329864298652986629867298682986929870298712987229873298742987529876298772987829879298802988129882298832988429885298862988729888298892989029891298922989329894298952989629897298982989929900299012990229903299042990529906299072990829909299102991129912299132991429915299162991729918299192992029921299222992329924299252992629927299282992929930299312993229933299342993529936299372993829939299402994129942299432994429945299462994729948299492995029951299522995329954299552995629957299582995929960299612996229963299642996529966299672996829969299702997129972299732997429975299762997729978299792998029981299822998329984299852998629987299882998929990299912999229993299942999529996299972999829999300003000130002300033000430005300063000730008300093001030011300123001330014300153001630017300183001930020300213002230023300243002530026300273002830029300303003130032300333003430035300363003730038300393004030041300423004330044300453004630047300483004930050300513005230053300543005530056300573005830059300603006130062300633006430065300663006730068300693007030071300723007330074300753007630077300783007930080300813008230083300843008530086300873008830089300903009130092300933009430095300963009730098300993010030101301023010330104301053010630107301083010930110301113011230113301143011530116301173011830119301203012130122301233012430125301263012730128301293013030131301323013330134301353013630137301383013930140301413014230143301443014530146301473014830149301503015130152301533015430155301563015730158301593016030161301623016330164301653016630167301683016930170301713017230173301743017530176301773017830179301803018130182301833018430185301863018730188301893019030191301923019330194301953019630197301983019930200302013020230203302043020530206302073020830209302103021130212302133021430215302163021730218302193022030221302223022330224302253022630227302283022930230302313023230233302343023530236302373023830239302403024130242302433024430245302463024730248302493025030251302523025330254302553025630257302583025930260302613026230263302643026530266302673026830269302703027130272302733027430275302763027730278302793028030281302823028330284302853028630287302883028930290302913029230293302943029530296302973029830299303003030130302303033030430305303063030730308303093031030311303123031330314303153031630317303183031930320303213032230323303243032530326303273032830329303303033130332303333033430335303363033730338303393034030341303423034330344303453034630347303483034930350303513035230353303543035530356303573035830359303603036130362303633036430365303663036730368303693037030371303723037330374303753037630377303783037930380303813038230383303843038530386303873038830389303903039130392303933039430395303963039730398303993040030401304023040330404304053040630407304083040930410304113041230413304143041530416304173041830419304203042130422304233042430425304263042730428304293043030431304323043330434304353043630437304383043930440304413044230443304443044530446304473044830449304503045130452304533045430455304563045730458304593046030461304623046330464304653046630467304683046930470304713047230473304743047530476304773047830479304803048130482304833048430485304863048730488304893049030491304923049330494304953049630497304983049930500305013050230503305043050530506305073050830509305103051130512305133051430515305163051730518305193052030521305223052330524305253052630527305283052930530305313053230533305343053530536305373053830539305403054130542305433054430545305463054730548305493055030551305523055330554305553055630557305583055930560305613056230563305643056530566305673056830569305703057130572305733057430575305763057730578305793058030581305823058330584305853058630587305883058930590305913059230593305943059530596305973059830599306003060130602306033060430605306063060730608306093061030611306123061330614306153061630617306183061930620306213062230623306243062530626306273062830629306303063130632306333063430635306363063730638306393064030641306423064330644306453064630647306483064930650306513065230653306543065530656306573065830659306603066130662306633066430665306663066730668306693067030671306723067330674306753067630677306783067930680306813068230683306843068530686306873068830689306903069130692306933069430695306963069730698306993070030701307023070330704307053070630707307083070930710307113071230713307143071530716307173071830719307203072130722307233072430725307263072730728307293073030731307323073330734307353073630737307383073930740307413074230743307443074530746307473074830749307503075130752307533075430755307563075730758307593076030761307623076330764307653076630767307683076930770307713077230773307743077530776307773077830779307803078130782307833078430785307863078730788307893079030791307923079330794307953079630797307983079930800308013080230803308043080530806308073080830809308103081130812308133081430815308163081730818308193082030821308223082330824308253082630827308283082930830308313083230833308343083530836308373083830839308403084130842308433084430845308463084730848308493085030851308523085330854308553085630857308583085930860308613086230863308643086530866308673086830869308703087130872308733087430875308763087730878308793088030881308823088330884308853088630887308883088930890308913089230893308943089530896308973089830899309003090130902309033090430905309063090730908309093091030911309123091330914309153091630917309183091930920309213092230923309243092530926309273092830929309303093130932309333093430935309363093730938309393094030941309423094330944309453094630947309483094930950309513095230953309543095530956309573095830959309603096130962309633096430965309663096730968309693097030971309723097330974309753097630977309783097930980309813098230983309843098530986309873098830989309903099130992309933099430995309963099730998309993100031001310023100331004310053100631007310083100931010310113101231013310143101531016310173101831019310203102131022310233102431025310263102731028310293103031031310323103331034310353103631037310383103931040310413104231043310443104531046310473104831049310503105131052310533105431055310563105731058310593106031061310623106331064310653106631067310683106931070310713107231073310743107531076310773107831079310803108131082310833108431085310863108731088310893109031091310923109331094310953109631097310983109931100311013110231103311043110531106311073110831109311103111131112311133111431115311163111731118311193112031121311223112331124311253112631127311283112931130311313113231133311343113531136311373113831139311403114131142311433114431145311463114731148311493115031151311523115331154311553115631157311583115931160311613116231163311643116531166311673116831169311703117131172311733117431175311763117731178311793118031181311823118331184311853118631187311883118931190311913119231193311943119531196311973119831199312003120131202312033120431205312063120731208312093121031211312123121331214312153121631217312183121931220312213122231223312243122531226312273122831229312303123131232312333123431235312363123731238312393124031241312423124331244312453124631247312483124931250312513125231253312543125531256312573125831259312603126131262312633126431265312663126731268312693127031271312723127331274312753127631277312783127931280312813128231283312843128531286312873128831289312903129131292312933129431295312963129731298312993130031301313023130331304313053130631307313083130931310313113131231313313143131531316313173131831319313203132131322313233132431325313263132731328313293133031331313323133331334313353133631337313383133931340313413134231343313443134531346313473134831349313503135131352313533135431355313563135731358313593136031361313623136331364313653136631367313683136931370313713137231373313743137531376313773137831379313803138131382313833138431385313863138731388313893139031391313923139331394313953139631397313983139931400314013140231403314043140531406314073140831409314103141131412314133141431415314163141731418314193142031421314223142331424314253142631427314283142931430314313143231433314343143531436314373143831439314403144131442314433144431445314463144731448314493145031451314523145331454314553145631457314583145931460314613146231463314643146531466314673146831469314703147131472314733147431475314763147731478314793148031481314823148331484314853148631487314883148931490314913149231493314943149531496314973149831499315003150131502315033150431505315063150731508315093151031511315123151331514315153151631517315183151931520315213152231523315243152531526315273152831529315303153131532315333153431535315363153731538315393154031541315423154331544315453154631547315483154931550315513155231553315543155531556315573155831559315603156131562315633156431565315663156731568315693157031571315723157331574315753157631577315783157931580315813158231583315843158531586315873158831589315903159131592315933159431595315963159731598315993160031601316023160331604316053160631607316083160931610316113161231613316143161531616316173161831619316203162131622316233162431625316263162731628316293163031631316323163331634316353163631637316383163931640316413164231643316443164531646316473164831649316503165131652316533165431655316563165731658316593166031661316623166331664316653166631667316683166931670316713167231673316743167531676316773167831679316803168131682316833168431685316863168731688316893169031691316923169331694316953169631697316983169931700317013170231703317043170531706317073170831709317103171131712317133171431715317163171731718317193172031721317223172331724317253172631727317283172931730317313173231733317343173531736317373173831739317403174131742317433174431745317463174731748317493175031751317523175331754317553175631757317583175931760317613176231763317643176531766317673176831769317703177131772317733177431775317763177731778317793178031781317823178331784317853178631787317883178931790317913179231793317943179531796317973179831799318003180131802318033180431805318063180731808318093181031811318123181331814318153181631817318183181931820318213182231823318243182531826318273182831829318303183131832318333183431835318363183731838318393184031841318423184331844318453184631847318483184931850318513185231853318543185531856318573185831859318603186131862318633186431865318663186731868318693187031871318723187331874318753187631877318783187931880318813188231883318843188531886318873188831889318903189131892318933189431895318963189731898318993190031901319023190331904319053190631907319083190931910319113191231913319143191531916319173191831919319203192131922319233192431925319263192731928319293193031931319323193331934319353193631937319383193931940319413194231943319443194531946319473194831949319503195131952319533195431955319563195731958319593196031961319623196331964319653196631967319683196931970319713197231973319743197531976319773197831979319803198131982319833198431985319863198731988319893199031991319923199331994319953199631997319983199932000320013200232003320043200532006320073200832009320103201132012320133201432015320163201732018320193202032021320223202332024320253202632027320283202932030320313203232033320343203532036320373203832039320403204132042320433204432045320463204732048320493205032051320523205332054320553205632057320583205932060320613206232063320643206532066320673206832069320703207132072320733207432075320763207732078320793208032081320823208332084320853208632087320883208932090320913209232093320943209532096320973209832099321003210132102321033210432105321063210732108321093211032111321123211332114321153211632117321183211932120321213212232123321243212532126321273212832129321303213132132321333213432135321363213732138321393214032141321423214332144321453214632147321483214932150321513215232153321543215532156321573215832159321603216132162321633216432165321663216732168321693217032171321723217332174321753217632177321783217932180321813218232183321843218532186321873218832189321903219132192321933219432195321963219732198321993220032201322023220332204322053220632207322083220932210322113221232213322143221532216322173221832219322203222132222322233222432225322263222732228322293223032231322323223332234322353223632237322383223932240322413224232243322443224532246322473224832249322503225132252322533225432255322563225732258322593226032261322623226332264322653226632267322683226932270322713227232273322743227532276322773227832279322803228132282322833228432285322863228732288322893229032291322923229332294322953229632297322983229932300323013230232303323043230532306323073230832309323103231132312323133231432315323163231732318323193232032321323223232332324323253232632327323283232932330323313233232333323343233532336323373233832339323403234132342323433234432345323463234732348323493235032351323523235332354323553235632357323583235932360323613236232363323643236532366323673236832369323703237132372323733237432375323763237732378323793238032381323823238332384323853238632387323883238932390323913239232393323943239532396323973239832399324003240132402324033240432405324063240732408324093241032411324123241332414324153241632417324183241932420324213242232423324243242532426324273242832429324303243132432324333243432435324363243732438324393244032441324423244332444324453244632447324483244932450324513245232453324543245532456324573245832459324603246132462324633246432465324663246732468324693247032471324723247332474324753247632477324783247932480324813248232483324843248532486324873248832489324903249132492324933249432495324963249732498324993250032501325023250332504325053250632507325083250932510325113251232513325143251532516325173251832519325203252132522325233252432525325263252732528325293253032531325323253332534325353253632537325383253932540325413254232543325443254532546325473254832549325503255132552325533255432555325563255732558325593256032561325623256332564325653256632567325683256932570325713257232573325743257532576325773257832579325803258132582325833258432585325863258732588325893259032591325923259332594325953259632597325983259932600326013260232603326043260532606326073260832609326103261132612326133261432615326163261732618326193262032621326223262332624326253262632627326283262932630326313263232633326343263532636326373263832639326403264132642326433264432645326463264732648326493265032651326523265332654326553265632657326583265932660326613266232663326643266532666326673266832669326703267132672326733267432675326763267732678326793268032681326823268332684326853268632687326883268932690326913269232693326943269532696326973269832699327003270132702327033270432705327063270732708327093271032711327123271332714327153271632717327183271932720327213272232723327243272532726327273272832729327303273132732327333273432735327363273732738327393274032741327423274332744327453274632747327483274932750327513275232753327543275532756327573275832759327603276132762327633276432765327663276732768327693277032771327723277332774327753277632777327783277932780327813278232783327843278532786327873278832789327903279132792327933279432795327963279732798327993280032801328023280332804328053280632807328083280932810328113281232813328143281532816328173281832819328203282132822328233282432825328263282732828328293283032831328323283332834328353283632837328383283932840328413284232843328443284532846328473284832849328503285132852328533285432855328563285732858328593286032861328623286332864328653286632867328683286932870328713287232873328743287532876328773287832879328803288132882328833288432885328863288732888328893289032891328923289332894328953289632897328983289932900329013290232903329043290532906329073290832909329103291132912329133291432915329163291732918329193292032921329223292332924329253292632927329283292932930329313293232933329343293532936329373293832939329403294132942329433294432945329463294732948329493295032951329523295332954329553295632957329583295932960329613296232963329643296532966329673296832969329703297132972329733297432975329763297732978329793298032981329823298332984329853298632987329883298932990329913299232993329943299532996329973299832999330003300133002330033300433005330063300733008330093301033011330123301333014330153301633017330183301933020330213302233023330243302533026330273302833029330303303133032330333303433035330363303733038330393304033041330423304333044330453304633047330483304933050330513305233053330543305533056330573305833059330603306133062330633306433065330663306733068330693307033071330723307333074330753307633077330783307933080330813308233083330843308533086330873308833089330903309133092330933309433095330963309733098330993310033101331023310333104331053310633107331083310933110331113311233113331143311533116331173311833119331203312133122331233312433125331263312733128331293313033131331323313333134331353313633137331383313933140331413314233143331443314533146331473314833149331503315133152331533315433155331563315733158331593316033161331623316333164331653316633167331683316933170331713317233173331743317533176331773317833179331803318133182331833318433185331863318733188331893319033191331923319333194331953319633197331983319933200332013320233203332043320533206332073320833209332103321133212332133321433215332163321733218332193322033221332223322333224332253322633227332283322933230332313323233233332343323533236332373323833239332403324133242332433324433245332463324733248332493325033251332523325333254332553325633257332583325933260332613326233263332643326533266332673326833269332703327133272332733327433275332763327733278332793328033281332823328333284332853328633287332883328933290332913329233293332943329533296332973329833299333003330133302333033330433305333063330733308333093331033311333123331333314333153331633317333183331933320333213332233323333243332533326333273332833329333303333133332333333333433335333363333733338333393334033341333423334333344333453334633347333483334933350333513335233353333543335533356333573335833359333603336133362333633336433365333663336733368333693337033371333723337333374333753337633377333783337933380333813338233383333843338533386333873338833389333903339133392333933339433395333963339733398333993340033401334023340333404334053340633407334083340933410334113341233413334143341533416334173341833419334203342133422334233342433425334263342733428334293343033431334323343333434334353343633437334383343933440334413344233443334443344533446334473344833449334503345133452334533345433455334563345733458334593346033461334623346333464334653346633467334683346933470334713347233473334743347533476334773347833479334803348133482334833348433485334863348733488334893349033491334923349333494334953349633497334983349933500335013350233503335043350533506335073350833509335103351133512335133351433515335163351733518335193352033521335223352333524335253352633527335283352933530335313353233533335343353533536335373353833539335403354133542335433354433545335463354733548335493355033551335523355333554335553355633557335583355933560335613356233563335643356533566335673356833569335703357133572335733357433575335763357733578335793358033581335823358333584335853358633587335883358933590335913359233593335943359533596335973359833599336003360133602336033360433605336063360733608336093361033611336123361333614336153361633617336183361933620336213362233623336243362533626336273362833629336303363133632336333363433635336363363733638336393364033641336423364333644336453364633647336483364933650336513365233653336543365533656336573365833659336603366133662336633366433665336663366733668336693367033671336723367333674336753367633677336783367933680336813368233683336843368533686336873368833689336903369133692336933369433695336963369733698336993370033701337023370333704337053370633707337083370933710337113371233713337143371533716337173371833719337203372133722337233372433725337263372733728337293373033731337323373333734337353373633737337383373933740337413374233743337443374533746337473374833749337503375133752337533375433755337563375733758337593376033761337623376333764337653376633767337683376933770337713377233773337743377533776337773377833779337803378133782337833378433785337863378733788337893379033791337923379333794337953379633797337983379933800338013380233803338043380533806338073380833809338103381133812338133381433815338163381733818338193382033821338223382333824338253382633827338283382933830338313383233833338343383533836338373383833839338403384133842338433384433845338463384733848338493385033851338523385333854338553385633857338583385933860338613386233863338643386533866338673386833869338703387133872338733387433875338763387733878338793388033881338823388333884338853388633887338883388933890338913389233893338943389533896338973389833899339003390133902339033390433905339063390733908339093391033911339123391333914339153391633917339183391933920339213392233923339243392533926339273392833929339303393133932339333393433935339363393733938339393394033941339423394333944339453394633947339483394933950339513395233953339543395533956339573395833959339603396133962339633396433965339663396733968339693397033971339723397333974339753397633977339783397933980339813398233983339843398533986339873398833989339903399133992339933399433995339963399733998339993400034001340023400334004340053400634007340083400934010340113401234013340143401534016340173401834019340203402134022340233402434025340263402734028340293403034031340323403334034340353403634037340383403934040340413404234043340443404534046340473404834049340503405134052340533405434055340563405734058340593406034061340623406334064340653406634067340683406934070340713407234073340743407534076340773407834079340803408134082340833408434085340863408734088340893409034091340923409334094340953409634097340983409934100341013410234103341043410534106341073410834109341103411134112341133411434115341163411734118341193412034121341223412334124341253412634127341283412934130341313413234133341343413534136341373413834139341403414134142341433414434145341463414734148341493415034151341523415334154341553415634157341583415934160341613416234163341643416534166341673416834169341703417134172341733417434175341763417734178341793418034181341823418334184341853418634187341883418934190341913419234193341943419534196341973419834199342003420134202342033420434205342063420734208342093421034211342123421334214342153421634217342183421934220342213422234223342243422534226342273422834229342303423134232342333423434235342363423734238342393424034241342423424334244342453424634247342483424934250342513425234253342543425534256342573425834259342603426134262342633426434265342663426734268342693427034271342723427334274342753427634277342783427934280342813428234283342843428534286342873428834289342903429134292342933429434295342963429734298342993430034301343023430334304343053430634307343083430934310343113431234313343143431534316343173431834319343203432134322343233432434325343263432734328343293433034331343323433334334343353433634337343383433934340343413434234343343443434534346343473434834349343503435134352343533435434355343563435734358343593436034361343623436334364343653436634367343683436934370343713437234373343743437534376343773437834379343803438134382343833438434385343863438734388343893439034391343923439334394343953439634397343983439934400344013440234403344043440534406344073440834409344103441134412344133441434415344163441734418344193442034421344223442334424344253442634427344283442934430344313443234433344343443534436344373443834439344403444134442344433444434445344463444734448344493445034451344523445334454344553445634457344583445934460344613446234463344643446534466344673446834469344703447134472344733447434475344763447734478344793448034481344823448334484344853448634487344883448934490344913449234493344943449534496344973449834499345003450134502345033450434505345063450734508345093451034511345123451334514345153451634517345183451934520345213452234523345243452534526345273452834529345303453134532345333453434535345363453734538345393454034541345423454334544345453454634547345483454934550345513455234553345543455534556345573455834559345603456134562345633456434565345663456734568345693457034571345723457334574345753457634577345783457934580345813458234583345843458534586345873458834589345903459134592345933459434595345963459734598345993460034601346023460334604346053460634607346083460934610346113461234613346143461534616346173461834619346203462134622346233462434625346263462734628346293463034631346323463334634346353463634637346383463934640346413464234643346443464534646346473464834649346503465134652346533465434655346563465734658346593466034661346623466334664346653466634667346683466934670346713467234673346743467534676346773467834679346803468134682346833468434685346863468734688346893469034691346923469334694346953469634697346983469934700347013470234703347043470534706347073470834709347103471134712347133471434715347163471734718347193472034721347223472334724347253472634727347283472934730347313473234733347343473534736347373473834739347403474134742347433474434745347463474734748347493475034751347523475334754347553475634757347583475934760347613476234763347643476534766347673476834769347703477134772347733477434775347763477734778347793478034781347823478334784347853478634787347883478934790347913479234793347943479534796347973479834799348003480134802348033480434805348063480734808348093481034811348123481334814348153481634817348183481934820348213482234823348243482534826348273482834829348303483134832348333483434835348363483734838348393484034841348423484334844348453484634847348483484934850348513485234853348543485534856348573485834859348603486134862348633486434865348663486734868348693487034871348723487334874348753487634877348783487934880348813488234883348843488534886348873488834889348903489134892348933489434895348963489734898348993490034901349023490334904349053490634907349083490934910349113491234913349143491534916349173491834919349203492134922349233492434925349263492734928349293493034931349323493334934349353493634937349383493934940349413494234943349443494534946349473494834949349503495134952349533495434955349563495734958349593496034961349623496334964349653496634967349683496934970349713497234973349743497534976349773497834979349803498134982349833498434985349863498734988349893499034991349923499334994349953499634997349983499935000350013500235003350043500535006350073500835009350103501135012350133501435015350163501735018350193502035021350223502335024350253502635027350283502935030350313503235033350343503535036350373503835039350403504135042350433504435045350463504735048350493505035051350523505335054350553505635057350583505935060350613506235063350643506535066350673506835069350703507135072350733507435075350763507735078350793508035081350823508335084350853508635087350883508935090350913509235093350943509535096350973509835099351003510135102351033510435105351063510735108351093511035111351123511335114351153511635117351183511935120351213512235123351243512535126351273512835129351303513135132351333513435135351363513735138351393514035141351423514335144351453514635147351483514935150351513515235153351543515535156351573515835159351603516135162351633516435165351663516735168351693517035171351723517335174351753517635177351783517935180351813518235183351843518535186351873518835189351903519135192351933519435195351963519735198351993520035201352023520335204352053520635207352083520935210352113521235213352143521535216352173521835219352203522135222352233522435225352263522735228352293523035231352323523335234352353523635237352383523935240352413524235243352443524535246352473524835249352503525135252352533525435255352563525735258352593526035261352623526335264352653526635267352683526935270352713527235273352743527535276352773527835279352803528135282352833528435285352863528735288352893529035291352923529335294352953529635297352983529935300353013530235303353043530535306353073530835309353103531135312353133531435315353163531735318353193532035321353223532335324353253532635327353283532935330353313533235333353343533535336353373533835339353403534135342353433534435345353463534735348353493535035351353523535335354353553535635357353583535935360353613536235363353643536535366353673536835369353703537135372353733537435375353763537735378353793538035381353823538335384353853538635387353883538935390353913539235393353943539535396353973539835399354003540135402354033540435405354063540735408354093541035411354123541335414354153541635417354183541935420354213542235423354243542535426354273542835429354303543135432354333543435435354363543735438354393544035441354423544335444354453544635447354483544935450354513545235453354543545535456354573545835459354603546135462354633546435465354663546735468354693547035471354723547335474354753547635477354783547935480354813548235483354843548535486354873548835489354903549135492354933549435495354963549735498354993550035501355023550335504355053550635507355083550935510355113551235513355143551535516355173551835519355203552135522355233552435525355263552735528355293553035531355323553335534355353553635537355383553935540355413554235543355443554535546355473554835549355503555135552355533555435555355563555735558355593556035561355623556335564355653556635567355683556935570355713557235573355743557535576355773557835579355803558135582355833558435585355863558735588355893559035591355923559335594355953559635597355983559935600356013560235603356043560535606356073560835609356103561135612356133561435615356163561735618356193562035621356223562335624356253562635627356283562935630356313563235633356343563535636356373563835639356403564135642356433564435645356463564735648356493565035651356523565335654356553565635657356583565935660356613566235663356643566535666356673566835669356703567135672356733567435675356763567735678356793568035681356823568335684356853568635687356883568935690356913569235693356943569535696356973569835699357003570135702357033570435705357063570735708357093571035711357123571335714357153571635717357183571935720357213572235723357243572535726357273572835729357303573135732357333573435735357363573735738357393574035741357423574335744357453574635747357483574935750357513575235753357543575535756357573575835759357603576135762357633576435765357663576735768357693577035771357723577335774357753577635777357783577935780357813578235783357843578535786357873578835789357903579135792357933579435795357963579735798357993580035801358023580335804358053580635807358083580935810358113581235813358143581535816358173581835819358203582135822358233582435825358263582735828358293583035831358323583335834358353583635837358383583935840358413584235843358443584535846358473584835849358503585135852358533585435855358563585735858358593586035861358623586335864358653586635867358683586935870358713587235873358743587535876358773587835879358803588135882358833588435885358863588735888358893589035891358923589335894358953589635897358983589935900359013590235903359043590535906359073590835909359103591135912359133591435915359163591735918359193592035921359223592335924359253592635927359283592935930359313593235933359343593535936359373593835939359403594135942359433594435945359463594735948359493595035951359523595335954359553595635957359583595935960359613596235963359643596535966359673596835969359703597135972359733597435975359763597735978359793598035981359823598335984359853598635987359883598935990359913599235993359943599535996359973599835999360003600136002360033600436005360063600736008360093601036011360123601336014360153601636017360183601936020360213602236023360243602536026360273602836029360303603136032360333603436035360363603736038360393604036041360423604336044360453604636047360483604936050360513605236053360543605536056360573605836059360603606136062360633606436065360663606736068360693607036071360723607336074360753607636077360783607936080360813608236083360843608536086360873608836089360903609136092360933609436095360963609736098360993610036101361023610336104361053610636107361083610936110361113611236113361143611536116361173611836119361203612136122361233612436125361263612736128361293613036131361323613336134361353613636137361383613936140361413614236143361443614536146361473614836149361503615136152361533615436155361563615736158361593616036161361623616336164361653616636167361683616936170361713617236173361743617536176361773617836179361803618136182361833618436185361863618736188361893619036191361923619336194361953619636197361983619936200362013620236203362043620536206362073620836209362103621136212362133621436215362163621736218362193622036221362223622336224362253622636227362283622936230362313623236233362343623536236362373623836239362403624136242362433624436245362463624736248362493625036251362523625336254362553625636257362583625936260362613626236263362643626536266362673626836269362703627136272362733627436275362763627736278362793628036281362823628336284362853628636287362883628936290362913629236293362943629536296362973629836299363003630136302363033630436305363063630736308363093631036311363123631336314363153631636317363183631936320363213632236323363243632536326363273632836329363303633136332363333633436335363363633736338363393634036341363423634336344363453634636347363483634936350363513635236353363543635536356363573635836359363603636136362363633636436365363663636736368363693637036371363723637336374363753637636377363783637936380363813638236383363843638536386363873638836389363903639136392363933639436395363963639736398363993640036401364023640336404364053640636407364083640936410364113641236413364143641536416364173641836419364203642136422364233642436425364263642736428364293643036431364323643336434364353643636437364383643936440364413644236443364443644536446364473644836449364503645136452364533645436455364563645736458364593646036461364623646336464364653646636467364683646936470364713647236473364743647536476364773647836479364803648136482364833648436485364863648736488364893649036491364923649336494364953649636497364983649936500365013650236503365043650536506365073650836509365103651136512365133651436515365163651736518365193652036521365223652336524365253652636527365283652936530365313653236533365343653536536365373653836539365403654136542365433654436545365463654736548365493655036551365523655336554365553655636557365583655936560365613656236563365643656536566365673656836569365703657136572365733657436575365763657736578365793658036581365823658336584365853658636587365883658936590365913659236593365943659536596365973659836599366003660136602366033660436605366063660736608366093661036611366123661336614366153661636617366183661936620366213662236623366243662536626366273662836629366303663136632366333663436635366363663736638366393664036641366423664336644366453664636647366483664936650366513665236653366543665536656366573665836659366603666136662366633666436665366663666736668366693667036671366723667336674366753667636677366783667936680366813668236683366843668536686366873668836689366903669136692366933669436695366963669736698366993670036701367023670336704367053670636707367083670936710367113671236713367143671536716367173671836719367203672136722367233672436725367263672736728367293673036731367323673336734367353673636737367383673936740367413674236743367443674536746367473674836749367503675136752367533675436755367563675736758367593676036761367623676336764367653676636767367683676936770367713677236773367743677536776367773677836779367803678136782367833678436785367863678736788367893679036791367923679336794367953679636797367983679936800368013680236803368043680536806368073680836809368103681136812368133681436815368163681736818368193682036821368223682336824368253682636827368283682936830368313683236833368343683536836368373683836839368403684136842368433684436845368463684736848368493685036851368523685336854368553685636857368583685936860368613686236863368643686536866368673686836869368703687136872368733687436875368763687736878368793688036881368823688336884368853688636887368883688936890368913689236893368943689536896368973689836899369003690136902369033690436905369063690736908369093691036911369123691336914369153691636917369183691936920369213692236923369243692536926369273692836929369303693136932369333693436935369363693736938369393694036941369423694336944369453694636947369483694936950369513695236953369543695536956369573695836959369603696136962369633696436965369663696736968369693697036971369723697336974369753697636977369783697936980369813698236983369843698536986369873698836989369903699136992369933699436995369963699736998369993700037001370023700337004370053700637007370083700937010370113701237013370143701537016370173701837019370203702137022370233702437025370263702737028370293703037031370323703337034370353703637037370383703937040370413704237043370443704537046370473704837049370503705137052370533705437055370563705737058370593706037061370623706337064370653706637067370683706937070370713707237073370743707537076370773707837079370803708137082370833708437085370863708737088370893709037091370923709337094370953709637097370983709937100371013710237103371043710537106371073710837109371103711137112371133711437115371163711737118371193712037121371223712337124371253712637127371283712937130371313713237133371343713537136371373713837139371403714137142371433714437145371463714737148371493715037151371523715337154371553715637157371583715937160371613716237163371643716537166371673716837169371703717137172371733717437175371763717737178371793718037181371823718337184371853718637187371883718937190371913719237193371943719537196371973719837199372003720137202372033720437205372063720737208372093721037211372123721337214372153721637217372183721937220372213722237223372243722537226372273722837229372303723137232372333723437235372363723737238372393724037241372423724337244372453724637247372483724937250372513725237253372543725537256372573725837259372603726137262372633726437265372663726737268372693727037271372723727337274372753727637277372783727937280372813728237283372843728537286372873728837289372903729137292372933729437295372963729737298372993730037301373023730337304373053730637307373083730937310373113731237313373143731537316373173731837319373203732137322373233732437325373263732737328373293733037331373323733337334373353733637337373383733937340373413734237343373443734537346373473734837349373503735137352373533735437355373563735737358373593736037361373623736337364373653736637367373683736937370373713737237373373743737537376373773737837379373803738137382373833738437385373863738737388373893739037391373923739337394373953739637397373983739937400374013740237403374043740537406374073740837409374103741137412374133741437415374163741737418374193742037421374223742337424374253742637427374283742937430374313743237433374343743537436374373743837439374403744137442374433744437445374463744737448374493745037451374523745337454374553745637457374583745937460374613746237463374643746537466374673746837469374703747137472374733747437475374763747737478374793748037481374823748337484374853748637487374883748937490374913749237493374943749537496374973749837499375003750137502375033750437505375063750737508375093751037511375123751337514375153751637517375183751937520375213752237523375243752537526375273752837529375303753137532375333753437535375363753737538375393754037541375423754337544375453754637547375483754937550375513755237553375543755537556375573755837559375603756137562375633756437565375663756737568375693757037571375723757337574375753757637577375783757937580375813758237583375843758537586375873758837589375903759137592375933759437595375963759737598375993760037601376023760337604376053760637607376083760937610376113761237613376143761537616376173761837619376203762137622376233762437625376263762737628376293763037631376323763337634376353763637637376383763937640376413764237643376443764537646376473764837649376503765137652376533765437655376563765737658376593766037661376623766337664376653766637667376683766937670376713767237673376743767537676376773767837679376803768137682376833768437685376863768737688376893769037691376923769337694376953769637697376983769937700377013770237703377043770537706377073770837709377103771137712377133771437715377163771737718377193772037721377223772337724377253772637727377283772937730377313773237733377343773537736377373773837739377403774137742377433774437745377463774737748377493775037751377523775337754377553775637757377583775937760377613776237763377643776537766377673776837769377703777137772377733777437775377763777737778377793778037781377823778337784377853778637787377883778937790377913779237793377943779537796377973779837799378003780137802378033780437805378063780737808378093781037811378123781337814378153781637817378183781937820378213782237823378243782537826378273782837829378303783137832378333783437835378363783737838378393784037841378423784337844378453784637847378483784937850378513785237853378543785537856378573785837859378603786137862378633786437865378663786737868378693787037871378723787337874378753787637877378783787937880378813788237883378843788537886378873788837889378903789137892378933789437895378963789737898378993790037901379023790337904379053790637907379083790937910379113791237913379143791537916379173791837919379203792137922379233792437925379263792737928379293793037931379323793337934379353793637937379383793937940379413794237943379443794537946379473794837949379503795137952379533795437955379563795737958379593796037961379623796337964379653796637967379683796937970379713797237973379743797537976379773797837979379803798137982379833798437985379863798737988379893799037991379923799337994379953799637997379983799938000380013800238003380043800538006380073800838009380103801138012380133801438015380163801738018380193802038021380223802338024380253802638027380283802938030380313803238033380343803538036380373803838039380403804138042380433804438045380463804738048380493805038051380523805338054380553805638057380583805938060380613806238063380643806538066380673806838069380703807138072380733807438075380763807738078380793808038081380823808338084380853808638087380883808938090380913809238093380943809538096380973809838099381003810138102381033810438105381063810738108381093811038111381123811338114381153811638117381183811938120381213812238123381243812538126381273812838129381303813138132381333813438135381363813738138381393814038141381423814338144381453814638147381483814938150381513815238153381543815538156381573815838159381603816138162381633816438165381663816738168381693817038171381723817338174381753817638177381783817938180381813818238183381843818538186381873818838189381903819138192381933819438195381963819738198381993820038201382023820338204382053820638207382083820938210382113821238213382143821538216382173821838219382203822138222382233822438225382263822738228382293823038231382323823338234382353823638237382383823938240382413824238243382443824538246382473824838249382503825138252382533825438255382563825738258382593826038261382623826338264382653826638267382683826938270382713827238273382743827538276382773827838279382803828138282382833828438285382863828738288382893829038291382923829338294382953829638297382983829938300383013830238303383043830538306383073830838309383103831138312383133831438315383163831738318383193832038321383223832338324383253832638327383283832938330383313833238333383343833538336383373833838339383403834138342383433834438345383463834738348383493835038351383523835338354383553835638357383583835938360383613836238363383643836538366383673836838369383703837138372383733837438375383763837738378383793838038381383823838338384383853838638387383883838938390383913839238393383943839538396383973839838399384003840138402384033840438405384063840738408384093841038411384123841338414384153841638417384183841938420384213842238423384243842538426384273842838429384303843138432384333843438435384363843738438384393844038441384423844338444384453844638447384483844938450384513845238453384543845538456384573845838459384603846138462384633846438465384663846738468384693847038471384723847338474384753847638477384783847938480384813848238483384843848538486384873848838489384903849138492384933849438495384963849738498384993850038501385023850338504385053850638507385083850938510385113851238513385143851538516385173851838519385203852138522385233852438525385263852738528385293853038531385323853338534385353853638537385383853938540385413854238543385443854538546385473854838549385503855138552385533855438555385563855738558385593856038561385623856338564385653856638567385683856938570385713857238573385743857538576385773857838579385803858138582385833858438585385863858738588385893859038591385923859338594385953859638597385983859938600386013860238603386043860538606386073860838609386103861138612386133861438615386163861738618386193862038621386223862338624386253862638627386283862938630386313863238633386343863538636386373863838639386403864138642386433864438645386463864738648386493865038651386523865338654386553865638657386583865938660386613866238663386643866538666386673866838669386703867138672386733867438675386763867738678386793868038681386823868338684386853868638687386883868938690386913869238693386943869538696386973869838699387003870138702387033870438705387063870738708387093871038711387123871338714387153871638717387183871938720387213872238723387243872538726387273872838729387303873138732387333873438735387363873738738387393874038741387423874338744387453874638747387483874938750387513875238753387543875538756387573875838759387603876138762387633876438765387663876738768387693877038771387723877338774387753877638777387783877938780387813878238783387843878538786387873878838789387903879138792387933879438795387963879738798387993880038801388023880338804388053880638807388083880938810388113881238813388143881538816388173881838819388203882138822388233882438825388263882738828388293883038831388323883338834388353883638837388383883938840388413884238843388443884538846388473884838849388503885138852388533885438855388563885738858388593886038861388623886338864388653886638867388683886938870388713887238873388743887538876388773887838879388803888138882388833888438885388863888738888388893889038891388923889338894388953889638897388983889938900389013890238903389043890538906389073890838909389103891138912389133891438915389163891738918389193892038921389223892338924389253892638927389283892938930389313893238933389343893538936389373893838939389403894138942389433894438945389463894738948389493895038951389523895338954389553895638957389583895938960389613896238963389643896538966389673896838969389703897138972389733897438975389763897738978389793898038981389823898338984389853898638987389883898938990389913899238993389943899538996389973899838999390003900139002390033900439005390063900739008390093901039011390123901339014390153901639017390183901939020390213902239023390243902539026390273902839029390303903139032390333903439035390363903739038390393904039041390423904339044390453904639047390483904939050390513905239053390543905539056390573905839059390603906139062390633906439065390663906739068390693907039071390723907339074390753907639077390783907939080390813908239083390843908539086390873908839089390903909139092390933909439095390963909739098390993910039101391023910339104391053910639107391083910939110391113911239113391143911539116391173911839119391203912139122391233912439125391263912739128391293913039131391323913339134391353913639137391383913939140391413914239143391443914539146391473914839149391503915139152391533915439155391563915739158391593916039161391623916339164391653916639167391683916939170391713917239173391743917539176391773917839179391803918139182391833918439185391863918739188391893919039191391923919339194391953919639197391983919939200392013920239203392043920539206392073920839209392103921139212392133921439215392163921739218392193922039221392223922339224392253922639227392283922939230392313923239233392343923539236392373923839239392403924139242392433924439245392463924739248392493925039251392523925339254392553925639257392583925939260392613926239263392643926539266392673926839269392703927139272392733927439275392763927739278392793928039281392823928339284392853928639287392883928939290392913929239293392943929539296392973929839299393003930139302393033930439305393063930739308393093931039311393123931339314393153931639317393183931939320393213932239323393243932539326393273932839329393303933139332393333933439335393363933739338393393934039341393423934339344393453934639347393483934939350393513935239353393543935539356393573935839359393603936139362393633936439365393663936739368393693937039371393723937339374393753937639377393783937939380393813938239383393843938539386393873938839389393903939139392393933939439395393963939739398393993940039401394023940339404394053940639407394083940939410394113941239413394143941539416394173941839419394203942139422394233942439425394263942739428394293943039431394323943339434394353943639437394383943939440394413944239443394443944539446394473944839449394503945139452394533945439455394563945739458394593946039461394623946339464394653946639467394683946939470394713947239473394743947539476394773947839479394803948139482394833948439485394863948739488394893949039491394923949339494394953949639497394983949939500395013950239503395043950539506395073950839509395103951139512395133951439515395163951739518395193952039521395223952339524395253952639527395283952939530395313953239533395343953539536395373953839539395403954139542395433954439545395463954739548395493955039551395523955339554395553955639557395583955939560395613956239563395643956539566395673956839569395703957139572395733957439575395763957739578395793958039581395823958339584395853958639587395883958939590395913959239593395943959539596395973959839599396003960139602396033960439605396063960739608396093961039611396123961339614396153961639617396183961939620396213962239623396243962539626396273962839629396303963139632396333963439635396363963739638396393964039641396423964339644396453964639647396483964939650396513965239653396543965539656396573965839659396603966139662396633966439665396663966739668396693967039671396723967339674396753967639677396783967939680396813968239683396843968539686396873968839689396903969139692396933969439695396963969739698396993970039701397023970339704397053970639707397083970939710397113971239713397143971539716397173971839719397203972139722397233972439725397263972739728397293973039731397323973339734397353973639737397383973939740397413974239743397443974539746397473974839749397503975139752397533975439755397563975739758397593976039761397623976339764397653976639767397683976939770397713977239773397743977539776397773977839779397803978139782397833978439785397863978739788397893979039791397923979339794397953979639797397983979939800398013980239803398043980539806398073980839809398103981139812398133981439815398163981739818398193982039821398223982339824398253982639827398283982939830398313983239833398343983539836398373983839839398403984139842398433984439845398463984739848398493985039851398523985339854398553985639857398583985939860398613986239863398643986539866398673986839869398703987139872398733987439875398763987739878398793988039881398823988339884398853988639887398883988939890398913989239893398943989539896398973989839899399003990139902399033990439905399063990739908399093991039911399123991339914399153991639917399183991939920399213992239923399243992539926399273992839929399303993139932399333993439935399363993739938399393994039941399423994339944399453994639947399483994939950399513995239953399543995539956399573995839959399603996139962399633996439965399663996739968399693997039971399723997339974399753997639977399783997939980399813998239983399843998539986399873998839989399903999139992399933999439995399963999739998399994000040001400024000340004400054000640007400084000940010400114001240013400144001540016400174001840019400204002140022400234002440025400264002740028400294003040031400324003340034400354003640037400384003940040400414004240043400444004540046400474004840049400504005140052400534005440055400564005740058400594006040061400624006340064400654006640067400684006940070400714007240073400744007540076400774007840079400804008140082400834008440085400864008740088400894009040091400924009340094400954009640097400984009940100401014010240103401044010540106401074010840109401104011140112401134011440115401164011740118401194012040121401224012340124401254012640127401284012940130401314013240133401344013540136401374013840139401404014140142401434014440145401464014740148401494015040151401524015340154401554015640157401584015940160401614016240163401644016540166401674016840169401704017140172401734017440175401764017740178401794018040181401824018340184401854018640187401884018940190401914019240193401944019540196401974019840199402004020140202402034020440205402064020740208402094021040211402124021340214402154021640217402184021940220402214022240223402244022540226402274022840229402304023140232402334023440235402364023740238402394024040241402424024340244402454024640247402484024940250402514025240253402544025540256402574025840259402604026140262402634026440265402664026740268402694027040271402724027340274402754027640277402784027940280402814028240283402844028540286402874028840289402904029140292402934029440295402964029740298402994030040301403024030340304403054030640307403084030940310403114031240313403144031540316403174031840319403204032140322403234032440325403264032740328403294033040331403324033340334403354033640337403384033940340403414034240343403444034540346403474034840349403504035140352403534035440355403564035740358403594036040361403624036340364403654036640367403684036940370403714037240373403744037540376403774037840379403804038140382403834038440385403864038740388403894039040391403924039340394403954039640397403984039940400404014040240403404044040540406404074040840409404104041140412404134041440415404164041740418404194042040421404224042340424404254042640427404284042940430404314043240433404344043540436404374043840439404404044140442404434044440445404464044740448404494045040451404524045340454404554045640457404584045940460404614046240463404644046540466404674046840469404704047140472404734047440475404764047740478404794048040481404824048340484404854048640487404884048940490404914049240493404944049540496404974049840499405004050140502405034050440505405064050740508405094051040511405124051340514405154051640517405184051940520405214052240523405244052540526405274052840529405304053140532405334053440535405364053740538405394054040541405424054340544405454054640547405484054940550405514055240553405544055540556405574055840559405604056140562405634056440565405664056740568405694057040571405724057340574405754057640577405784057940580405814058240583405844058540586405874058840589405904059140592405934059440595405964059740598405994060040601406024060340604406054060640607406084060940610406114061240613406144061540616406174061840619406204062140622406234062440625406264062740628406294063040631406324063340634406354063640637406384063940640406414064240643406444064540646406474064840649406504065140652406534065440655406564065740658406594066040661406624066340664406654066640667406684066940670406714067240673406744067540676406774067840679406804068140682406834068440685406864068740688406894069040691406924069340694406954069640697406984069940700407014070240703407044070540706407074070840709407104071140712407134071440715407164071740718407194072040721407224072340724407254072640727407284072940730407314073240733407344073540736407374073840739407404074140742407434074440745407464074740748407494075040751407524075340754407554075640757407584075940760407614076240763407644076540766407674076840769407704077140772407734077440775407764077740778407794078040781407824078340784407854078640787407884078940790407914079240793407944079540796407974079840799408004080140802408034080440805408064080740808408094081040811408124081340814408154081640817408184081940820408214082240823408244082540826408274082840829408304083140832408334083440835408364083740838408394084040841408424084340844408454084640847408484084940850408514085240853408544085540856408574085840859408604086140862408634086440865408664086740868408694087040871408724087340874408754087640877408784087940880408814088240883408844088540886408874088840889408904089140892408934089440895408964089740898408994090040901409024090340904409054090640907409084090940910409114091240913409144091540916409174091840919409204092140922409234092440925409264092740928409294093040931409324093340934409354093640937409384093940940409414094240943409444094540946409474094840949409504095140952409534095440955409564095740958409594096040961409624096340964409654096640967409684096940970409714097240973409744097540976409774097840979409804098140982409834098440985409864098740988409894099040991409924099340994409954099640997409984099941000410014100241003410044100541006410074100841009410104101141012410134101441015410164101741018410194102041021410224102341024410254102641027410284102941030410314103241033410344103541036410374103841039410404104141042410434104441045410464104741048410494105041051410524105341054410554105641057410584105941060410614106241063410644106541066410674106841069410704107141072410734107441075410764107741078410794108041081410824108341084410854108641087410884108941090410914109241093410944109541096410974109841099411004110141102411034110441105411064110741108411094111041111411124111341114411154111641117411184111941120411214112241123411244112541126411274112841129411304113141132411334113441135411364113741138411394114041141411424114341144411454114641147411484114941150411514115241153411544115541156411574115841159411604116141162411634116441165411664116741168411694117041171411724117341174411754117641177411784117941180411814118241183411844118541186411874118841189411904119141192411934119441195411964119741198411994120041201412024120341204412054120641207412084120941210412114121241213412144121541216412174121841219412204122141222412234122441225412264122741228412294123041231412324123341234412354123641237412384123941240412414124241243412444124541246412474124841249412504125141252412534125441255412564125741258412594126041261412624126341264412654126641267412684126941270412714127241273412744127541276412774127841279412804128141282412834128441285412864128741288412894129041291412924129341294412954129641297412984129941300413014130241303413044130541306413074130841309413104131141312413134131441315413164131741318413194132041321413224132341324413254132641327413284132941330413314133241333413344133541336413374133841339413404134141342413434134441345413464134741348413494135041351413524135341354413554135641357413584135941360413614136241363413644136541366413674136841369413704137141372413734137441375413764137741378413794138041381413824138341384413854138641387413884138941390413914139241393413944139541396413974139841399414004140141402414034140441405414064140741408414094141041411414124141341414414154141641417414184141941420414214142241423414244142541426414274142841429414304143141432414334143441435414364143741438414394144041441414424144341444414454144641447414484144941450414514145241453414544145541456414574145841459414604146141462414634146441465414664146741468414694147041471414724147341474414754147641477414784147941480414814148241483414844148541486414874148841489414904149141492414934149441495414964149741498414994150041501415024150341504415054150641507415084150941510415114151241513415144151541516415174151841519415204152141522415234152441525415264152741528415294153041531415324153341534415354153641537415384153941540415414154241543415444154541546415474154841549415504155141552415534155441555415564155741558415594156041561415624156341564415654156641567415684156941570415714157241573415744157541576415774157841579415804158141582415834158441585415864158741588415894159041591415924159341594415954159641597415984159941600416014160241603416044160541606416074160841609416104161141612416134161441615416164161741618416194162041621416224162341624416254162641627416284162941630416314163241633416344163541636416374163841639416404164141642416434164441645416464164741648416494165041651416524165341654416554165641657416584165941660416614166241663416644166541666416674166841669416704167141672416734167441675416764167741678416794168041681416824168341684416854168641687416884168941690416914169241693416944169541696416974169841699417004170141702417034170441705417064170741708417094171041711417124171341714417154171641717417184171941720417214172241723417244172541726417274172841729417304173141732417334173441735417364173741738417394174041741417424174341744417454174641747417484174941750417514175241753417544175541756417574175841759417604176141762417634176441765417664176741768417694177041771417724177341774417754177641777417784177941780417814178241783417844178541786417874178841789417904179141792417934179441795417964179741798417994180041801418024180341804418054180641807418084180941810418114181241813418144181541816418174181841819418204182141822418234182441825418264182741828418294183041831418324183341834418354183641837418384183941840418414184241843418444184541846418474184841849418504185141852418534185441855418564185741858418594186041861418624186341864418654186641867418684186941870418714187241873418744187541876418774187841879418804188141882418834188441885418864188741888418894189041891418924189341894418954189641897418984189941900419014190241903419044190541906419074190841909419104191141912419134191441915419164191741918419194192041921419224192341924419254192641927419284192941930419314193241933419344193541936419374193841939419404194141942419434194441945419464194741948419494195041951419524195341954419554195641957419584195941960419614196241963419644196541966419674196841969419704197141972419734197441975419764197741978419794198041981419824198341984419854198641987419884198941990419914199241993419944199541996419974199841999420004200142002420034200442005420064200742008420094201042011420124201342014420154201642017420184201942020420214202242023420244202542026420274202842029420304203142032420334203442035420364203742038420394204042041420424204342044420454204642047420484204942050420514205242053420544205542056420574205842059420604206142062420634206442065420664206742068420694207042071420724207342074420754207642077420784207942080420814208242083420844208542086420874208842089420904209142092420934209442095420964209742098420994210042101421024210342104421054210642107421084210942110421114211242113421144211542116421174211842119421204212142122421234212442125421264212742128421294213042131421324213342134421354213642137421384213942140421414214242143421444214542146421474214842149421504215142152421534215442155421564215742158421594216042161421624216342164421654216642167421684216942170421714217242173421744217542176421774217842179421804218142182421834218442185421864218742188421894219042191421924219342194421954219642197421984219942200422014220242203422044220542206422074220842209422104221142212422134221442215422164221742218422194222042221422224222342224422254222642227422284222942230422314223242233422344223542236422374223842239422404224142242422434224442245422464224742248422494225042251422524225342254422554225642257422584225942260422614226242263422644226542266422674226842269422704227142272422734227442275422764227742278422794228042281422824228342284422854228642287422884228942290422914229242293422944229542296422974229842299423004230142302423034230442305423064230742308423094231042311423124231342314423154231642317423184231942320423214232242323423244232542326423274232842329423304233142332423334233442335423364233742338423394234042341423424234342344423454234642347423484234942350423514235242353423544235542356423574235842359423604236142362423634236442365423664236742368423694237042371423724237342374423754237642377423784237942380423814238242383423844238542386423874238842389423904239142392423934239442395423964239742398423994240042401424024240342404424054240642407424084240942410424114241242413424144241542416424174241842419424204242142422424234242442425424264242742428424294243042431424324243342434424354243642437424384243942440424414244242443424444244542446424474244842449424504245142452424534245442455424564245742458424594246042461424624246342464424654246642467424684246942470424714247242473424744247542476424774247842479424804248142482424834248442485424864248742488424894249042491424924249342494424954249642497424984249942500425014250242503425044250542506425074250842509425104251142512425134251442515425164251742518425194252042521425224252342524425254252642527425284252942530425314253242533425344253542536425374253842539425404254142542425434254442545425464254742548425494255042551425524255342554425554255642557425584255942560425614256242563425644256542566425674256842569425704257142572425734257442575425764257742578425794258042581425824258342584425854258642587425884258942590425914259242593425944259542596425974259842599426004260142602426034260442605426064260742608426094261042611426124261342614426154261642617426184261942620426214262242623426244262542626426274262842629426304263142632426334263442635426364263742638426394264042641426424264342644426454264642647426484264942650426514265242653426544265542656426574265842659426604266142662426634266442665426664266742668426694267042671426724267342674426754267642677426784267942680426814268242683426844268542686426874268842689426904269142692426934269442695426964269742698426994270042701427024270342704427054270642707427084270942710427114271242713427144271542716427174271842719427204272142722427234272442725427264272742728427294273042731427324273342734427354273642737427384273942740427414274242743427444274542746427474274842749427504275142752427534275442755427564275742758427594276042761427624276342764427654276642767427684276942770427714277242773427744277542776427774277842779427804278142782427834278442785427864278742788427894279042791427924279342794427954279642797427984279942800428014280242803428044280542806428074280842809428104281142812428134281442815428164281742818428194282042821428224282342824428254282642827428284282942830428314283242833428344283542836428374283842839428404284142842428434284442845428464284742848428494285042851428524285342854428554285642857428584285942860428614286242863428644286542866428674286842869428704287142872428734287442875428764287742878428794288042881428824288342884428854288642887428884288942890428914289242893428944289542896428974289842899429004290142902429034290442905429064290742908429094291042911429124291342914429154291642917429184291942920429214292242923429244292542926429274292842929429304293142932429334293442935429364293742938429394294042941429424294342944429454294642947429484294942950429514295242953429544295542956429574295842959429604296142962429634296442965429664296742968429694297042971429724297342974429754297642977429784297942980429814298242983429844298542986429874298842989429904299142992429934299442995429964299742998429994300043001430024300343004430054300643007430084300943010430114301243013430144301543016430174301843019430204302143022430234302443025430264302743028430294303043031430324303343034430354303643037430384303943040430414304243043430444304543046430474304843049430504305143052430534305443055430564305743058430594306043061430624306343064430654306643067430684306943070430714307243073430744307543076430774307843079430804308143082430834308443085430864308743088430894309043091430924309343094430954309643097430984309943100431014310243103431044310543106431074310843109431104311143112431134311443115431164311743118431194312043121431224312343124431254312643127431284312943130431314313243133431344313543136431374313843139431404314143142431434314443145431464314743148431494315043151431524315343154431554315643157431584315943160431614316243163431644316543166431674316843169431704317143172431734317443175431764317743178431794318043181431824318343184431854318643187431884318943190431914319243193431944319543196431974319843199432004320143202432034320443205432064320743208432094321043211432124321343214432154321643217432184321943220432214322243223432244322543226432274322843229432304323143232432334323443235432364323743238432394324043241432424324343244432454324643247432484324943250432514325243253432544325543256432574325843259432604326143262432634326443265432664326743268432694327043271432724327343274432754327643277432784327943280432814328243283432844328543286432874328843289432904329143292432934329443295432964329743298432994330043301433024330343304433054330643307433084330943310433114331243313433144331543316433174331843319433204332143322433234332443325433264332743328433294333043331433324333343334433354333643337433384333943340433414334243343433444334543346433474334843349433504335143352433534335443355433564335743358433594336043361433624336343364433654336643367433684336943370433714337243373433744337543376433774337843379433804338143382433834338443385433864338743388433894339043391433924339343394433954339643397433984339943400434014340243403434044340543406434074340843409434104341143412434134341443415434164341743418434194342043421434224342343424434254342643427434284342943430434314343243433434344343543436434374343843439434404344143442434434344443445434464344743448434494345043451434524345343454434554345643457434584345943460434614346243463434644346543466434674346843469434704347143472434734347443475434764347743478434794348043481434824348343484434854348643487434884348943490434914349243493434944349543496434974349843499435004350143502435034350443505435064350743508435094351043511435124351343514435154351643517435184351943520435214352243523435244352543526435274352843529435304353143532435334353443535435364353743538435394354043541435424354343544435454354643547435484354943550435514355243553435544355543556435574355843559435604356143562435634356443565435664356743568435694357043571435724357343574435754357643577435784357943580435814358243583435844358543586435874358843589435904359143592435934359443595435964359743598435994360043601436024360343604436054360643607436084360943610436114361243613436144361543616436174361843619436204362143622436234362443625436264362743628436294363043631436324363343634436354363643637436384363943640436414364243643436444364543646436474364843649436504365143652436534365443655436564365743658436594366043661436624366343664436654366643667436684366943670436714367243673436744367543676436774367843679436804368143682436834368443685436864368743688436894369043691436924369343694436954369643697436984369943700437014370243703437044370543706437074370843709437104371143712437134371443715437164371743718437194372043721437224372343724437254372643727437284372943730437314373243733437344373543736437374373843739437404374143742437434374443745437464374743748437494375043751437524375343754437554375643757437584375943760437614376243763437644376543766437674376843769437704377143772437734377443775437764377743778437794378043781437824378343784437854378643787437884378943790437914379243793437944379543796437974379843799438004380143802438034380443805438064380743808438094381043811438124381343814438154381643817438184381943820438214382243823438244382543826438274382843829438304383143832438334383443835438364383743838438394384043841438424384343844438454384643847438484384943850438514385243853438544385543856438574385843859438604386143862438634386443865438664386743868438694387043871438724387343874438754387643877438784387943880438814388243883438844388543886438874388843889438904389143892438934389443895438964389743898438994390043901439024390343904439054390643907439084390943910439114391243913439144391543916439174391843919439204392143922439234392443925439264392743928439294393043931439324393343934439354393643937439384393943940439414394243943439444394543946439474394843949439504395143952439534395443955439564395743958439594396043961439624396343964439654396643967439684396943970439714397243973439744397543976439774397843979439804398143982439834398443985439864398743988439894399043991439924399343994439954399643997439984399944000440014400244003440044400544006440074400844009440104401144012440134401444015440164401744018440194402044021440224402344024440254402644027440284402944030440314403244033440344403544036440374403844039440404404144042440434404444045440464404744048440494405044051440524405344054440554405644057440584405944060440614406244063440644406544066440674406844069440704407144072440734407444075440764407744078440794408044081440824408344084440854408644087440884408944090440914409244093440944409544096440974409844099441004410144102441034410444105441064410744108441094411044111441124411344114441154411644117441184411944120441214412244123441244412544126441274412844129441304413144132441334413444135441364413744138441394414044141441424414344144441454414644147441484414944150441514415244153441544415544156441574415844159441604416144162441634416444165441664416744168441694417044171441724417344174441754417644177441784417944180441814418244183441844418544186441874418844189441904419144192441934419444195441964419744198441994420044201442024420344204442054420644207442084420944210442114421244213442144421544216442174421844219442204422144222442234422444225442264422744228442294423044231442324423344234442354423644237442384423944240442414424244243442444424544246442474424844249442504425144252442534425444255442564425744258442594426044261442624426344264442654426644267442684426944270442714427244273442744427544276442774427844279442804428144282442834428444285442864428744288442894429044291442924429344294442954429644297442984429944300443014430244303443044430544306443074430844309443104431144312443134431444315443164431744318443194432044321443224432344324443254432644327443284432944330443314433244333443344433544336443374433844339443404434144342443434434444345443464434744348443494435044351443524435344354443554435644357443584435944360443614436244363443644436544366443674436844369443704437144372443734437444375443764437744378443794438044381443824438344384443854438644387443884438944390443914439244393443944439544396443974439844399444004440144402444034440444405444064440744408444094441044411444124441344414444154441644417444184441944420444214442244423444244442544426444274442844429444304443144432444334443444435444364443744438444394444044441444424444344444444454444644447444484444944450444514445244453444544445544456444574445844459444604446144462444634446444465444664446744468444694447044471444724447344474444754447644477444784447944480444814448244483444844448544486444874448844489444904449144492444934449444495444964449744498444994450044501445024450344504445054450644507445084450944510445114451244513445144451544516445174451844519445204452144522445234452444525445264452744528445294453044531445324453344534445354453644537445384453944540445414454244543445444454544546445474454844549445504455144552445534455444555445564455744558445594456044561445624456344564445654456644567445684456944570445714457244573445744457544576445774457844579445804458144582445834458444585445864458744588445894459044591445924459344594445954459644597445984459944600446014460244603446044460544606446074460844609446104461144612446134461444615446164461744618446194462044621446224462344624446254462644627446284462944630446314463244633446344463544636446374463844639446404464144642446434464444645446464464744648446494465044651446524465344654446554465644657446584465944660446614466244663446644466544666446674466844669446704467144672446734467444675446764467744678446794468044681446824468344684446854468644687446884468944690446914469244693446944469544696446974469844699447004470144702447034470444705447064470744708447094471044711447124471344714447154471644717447184471944720447214472244723447244472544726447274472844729447304473144732447334473444735447364473744738447394474044741447424474344744447454474644747447484474944750447514475244753447544475544756447574475844759447604476144762447634476444765447664476744768447694477044771447724477344774447754477644777447784477944780447814478244783447844478544786447874478844789447904479144792447934479444795447964479744798447994480044801448024480344804448054480644807448084480944810448114481244813448144481544816448174481844819448204482144822448234482444825448264482744828448294483044831448324483344834448354483644837448384483944840448414484244843448444484544846448474484844849448504485144852448534485444855448564485744858448594486044861448624486344864448654486644867448684486944870448714487244873448744487544876448774487844879448804488144882448834488444885448864488744888448894489044891448924489344894448954489644897448984489944900449014490244903449044490544906449074490844909449104491144912449134491444915449164491744918449194492044921449224492344924449254492644927449284492944930449314493244933449344493544936449374493844939449404494144942449434494444945449464494744948449494495044951449524495344954449554495644957449584495944960449614496244963449644496544966449674496844969449704497144972449734497444975449764497744978449794498044981449824498344984449854498644987449884498944990449914499244993449944499544996449974499844999450004500145002450034500445005450064500745008450094501045011450124501345014450154501645017450184501945020450214502245023450244502545026450274502845029450304503145032450334503445035450364503745038450394504045041450424504345044450454504645047450484504945050450514505245053450544505545056450574505845059450604506145062450634506445065450664506745068450694507045071450724507345074450754507645077450784507945080450814508245083450844508545086450874508845089450904509145092450934509445095450964509745098450994510045101451024510345104451054510645107451084510945110451114511245113451144511545116451174511845119451204512145122451234512445125451264512745128451294513045131451324513345134451354513645137451384513945140451414514245143451444514545146451474514845149451504515145152451534515445155451564515745158451594516045161451624516345164451654516645167451684516945170451714517245173451744517545176451774517845179451804518145182451834518445185451864518745188451894519045191451924519345194451954519645197451984519945200452014520245203452044520545206452074520845209452104521145212452134521445215452164521745218452194522045221452224522345224452254522645227452284522945230452314523245233452344523545236452374523845239452404524145242452434524445245452464524745248452494525045251452524525345254452554525645257452584525945260452614526245263452644526545266452674526845269452704527145272452734527445275452764527745278452794528045281452824528345284452854528645287452884528945290452914529245293452944529545296452974529845299453004530145302453034530445305453064530745308453094531045311453124531345314453154531645317453184531945320453214532245323453244532545326453274532845329453304533145332453334533445335453364533745338453394534045341453424534345344453454534645347453484534945350453514535245353453544535545356453574535845359453604536145362453634536445365453664536745368453694537045371453724537345374453754537645377453784537945380453814538245383453844538545386453874538845389453904539145392453934539445395453964539745398453994540045401454024540345404454054540645407454084540945410454114541245413454144541545416454174541845419454204542145422454234542445425454264542745428454294543045431454324543345434454354543645437454384543945440454414544245443454444544545446454474544845449454504545145452454534545445455454564545745458454594546045461454624546345464454654546645467454684546945470454714547245473454744547545476454774547845479454804548145482454834548445485454864548745488454894549045491454924549345494454954549645497454984549945500455014550245503455044550545506455074550845509455104551145512455134551445515455164551745518455194552045521455224552345524455254552645527455284552945530455314553245533455344553545536455374553845539455404554145542455434554445545455464554745548455494555045551455524555345554455554555645557455584555945560455614556245563455644556545566455674556845569455704557145572455734557445575455764557745578455794558045581455824558345584455854558645587455884558945590455914559245593455944559545596455974559845599456004560145602456034560445605456064560745608456094561045611456124561345614456154561645617456184561945620456214562245623456244562545626456274562845629456304563145632456334563445635456364563745638456394564045641456424564345644456454564645647456484564945650456514565245653456544565545656456574565845659456604566145662456634566445665456664566745668456694567045671456724567345674456754567645677456784567945680456814568245683456844568545686456874568845689456904569145692456934569445695456964569745698456994570045701457024570345704457054570645707457084570945710457114571245713457144571545716457174571845719457204572145722457234572445725457264572745728457294573045731457324573345734457354573645737457384573945740457414574245743457444574545746457474574845749457504575145752457534575445755457564575745758457594576045761457624576345764457654576645767457684576945770457714577245773457744577545776457774577845779457804578145782457834578445785457864578745788457894579045791457924579345794457954579645797457984579945800458014580245803458044580545806458074580845809458104581145812458134581445815458164581745818458194582045821458224582345824458254582645827458284582945830458314583245833458344583545836458374583845839458404584145842458434584445845458464584745848458494585045851458524585345854458554585645857458584585945860458614586245863458644586545866458674586845869458704587145872458734587445875458764587745878458794588045881458824588345884458854588645887458884588945890458914589245893458944589545896458974589845899459004590145902459034590445905459064590745908459094591045911459124591345914459154591645917459184591945920459214592245923459244592545926459274592845929459304593145932459334593445935459364593745938459394594045941459424594345944459454594645947459484594945950459514595245953459544595545956459574595845959459604596145962459634596445965459664596745968459694597045971459724597345974459754597645977459784597945980459814598245983459844598545986459874598845989459904599145992459934599445995459964599745998459994600046001460024600346004460054600646007460084600946010460114601246013460144601546016460174601846019460204602146022460234602446025460264602746028460294603046031460324603346034460354603646037460384603946040460414604246043460444604546046460474604846049460504605146052460534605446055460564605746058460594606046061460624606346064460654606646067460684606946070460714607246073460744607546076460774607846079460804608146082460834608446085460864608746088460894609046091460924609346094460954609646097460984609946100461014610246103461044610546106461074610846109461104611146112461134611446115461164611746118461194612046121461224612346124461254612646127461284612946130461314613246133461344613546136461374613846139461404614146142461434614446145461464614746148461494615046151461524615346154461554615646157461584615946160461614616246163461644616546166461674616846169461704617146172461734617446175461764617746178461794618046181461824618346184461854618646187461884618946190461914619246193461944619546196461974619846199462004620146202462034620446205462064620746208462094621046211462124621346214462154621646217462184621946220462214622246223462244622546226462274622846229462304623146232462334623446235462364623746238462394624046241462424624346244462454624646247462484624946250462514625246253462544625546256462574625846259462604626146262462634626446265462664626746268462694627046271462724627346274462754627646277462784627946280462814628246283462844628546286462874628846289462904629146292462934629446295462964629746298462994630046301463024630346304463054630646307463084630946310463114631246313463144631546316463174631846319463204632146322463234632446325463264632746328463294633046331463324633346334463354633646337463384633946340463414634246343463444634546346463474634846349463504635146352463534635446355463564635746358463594636046361463624636346364463654636646367463684636946370463714637246373463744637546376463774637846379463804638146382463834638446385463864638746388463894639046391463924639346394463954639646397463984639946400464014640246403464044640546406464074640846409464104641146412464134641446415464164641746418464194642046421464224642346424464254642646427464284642946430464314643246433464344643546436464374643846439464404644146442464434644446445464464644746448464494645046451464524645346454464554645646457464584645946460464614646246463464644646546466464674646846469464704647146472464734647446475464764647746478464794648046481464824648346484464854648646487464884648946490464914649246493464944649546496464974649846499465004650146502465034650446505465064650746508465094651046511465124651346514465154651646517465184651946520465214652246523465244652546526465274652846529465304653146532465334653446535465364653746538465394654046541465424654346544465454654646547465484654946550465514655246553465544655546556465574655846559465604656146562465634656446565465664656746568465694657046571465724657346574465754657646577465784657946580465814658246583465844658546586465874658846589465904659146592465934659446595465964659746598465994660046601466024660346604466054660646607466084660946610466114661246613466144661546616466174661846619466204662146622466234662446625466264662746628466294663046631466324663346634466354663646637466384663946640466414664246643466444664546646466474664846649466504665146652466534665446655466564665746658466594666046661466624666346664466654666646667466684666946670466714667246673466744667546676466774667846679466804668146682466834668446685466864668746688466894669046691466924669346694466954669646697466984669946700467014670246703467044670546706467074670846709467104671146712467134671446715467164671746718467194672046721467224672346724467254672646727467284672946730467314673246733467344673546736467374673846739467404674146742467434674446745467464674746748467494675046751467524675346754467554675646757467584675946760467614676246763467644676546766467674676846769467704677146772467734677446775467764677746778467794678046781467824678346784467854678646787467884678946790467914679246793467944679546796467974679846799468004680146802468034680446805468064680746808468094681046811468124681346814468154681646817468184681946820468214682246823468244682546826468274682846829468304683146832468334683446835468364683746838468394684046841468424684346844468454684646847468484684946850468514685246853468544685546856468574685846859468604686146862468634686446865468664686746868468694687046871468724687346874468754687646877468784687946880468814688246883468844688546886468874688846889468904689146892468934689446895468964689746898468994690046901469024690346904469054690646907469084690946910469114691246913469144691546916469174691846919469204692146922469234692446925469264692746928469294693046931469324693346934469354693646937469384693946940469414694246943469444694546946469474694846949469504695146952469534695446955469564695746958469594696046961469624696346964469654696646967469684696946970469714697246973469744697546976469774697846979469804698146982469834698446985469864698746988469894699046991469924699346994469954699646997469984699947000470014700247003470044700547006470074700847009470104701147012470134701447015470164701747018470194702047021470224702347024470254702647027470284702947030470314703247033470344703547036470374703847039470404704147042470434704447045470464704747048470494705047051470524705347054470554705647057470584705947060470614706247063470644706547066470674706847069470704707147072470734707447075470764707747078470794708047081470824708347084470854708647087470884708947090470914709247093470944709547096470974709847099471004710147102471034710447105471064710747108471094711047111471124711347114471154711647117471184711947120471214712247123471244712547126471274712847129471304713147132471334713447135471364713747138471394714047141471424714347144471454714647147471484714947150471514715247153471544715547156471574715847159471604716147162471634716447165471664716747168471694717047171471724717347174471754717647177471784717947180471814718247183471844718547186471874718847189471904719147192471934719447195471964719747198471994720047201472024720347204472054720647207472084720947210472114721247213472144721547216472174721847219472204722147222472234722447225472264722747228472294723047231472324723347234472354723647237472384723947240472414724247243472444724547246472474724847249472504725147252472534725447255472564725747258472594726047261472624726347264472654726647267472684726947270472714727247273472744727547276472774727847279472804728147282472834728447285472864728747288472894729047291472924729347294472954729647297472984729947300473014730247303473044730547306473074730847309473104731147312473134731447315473164731747318473194732047321473224732347324473254732647327473284732947330473314733247333473344733547336473374733847339473404734147342473434734447345473464734747348473494735047351473524735347354473554735647357473584735947360473614736247363473644736547366473674736847369473704737147372473734737447375473764737747378473794738047381473824738347384473854738647387473884738947390473914739247393473944739547396473974739847399474004740147402474034740447405474064740747408474094741047411474124741347414474154741647417474184741947420474214742247423474244742547426474274742847429474304743147432474334743447435474364743747438474394744047441474424744347444474454744647447474484744947450474514745247453474544745547456474574745847459474604746147462474634746447465474664746747468474694747047471474724747347474474754747647477474784747947480474814748247483474844748547486474874748847489474904749147492474934749447495474964749747498474994750047501475024750347504475054750647507475084750947510475114751247513475144751547516475174751847519475204752147522475234752447525475264752747528475294753047531475324753347534475354753647537475384753947540475414754247543475444754547546475474754847549475504755147552475534755447555475564755747558475594756047561475624756347564475654756647567475684756947570475714757247573475744757547576475774757847579475804758147582475834758447585475864758747588475894759047591475924759347594475954759647597475984759947600476014760247603476044760547606476074760847609476104761147612476134761447615476164761747618476194762047621476224762347624476254762647627476284762947630476314763247633476344763547636476374763847639476404764147642476434764447645476464764747648476494765047651476524765347654476554765647657476584765947660476614766247663476644766547666476674766847669476704767147672476734767447675476764767747678476794768047681476824768347684476854768647687476884768947690476914769247693476944769547696476974769847699477004770147702477034770447705477064770747708477094771047711477124771347714477154771647717477184771947720477214772247723477244772547726477274772847729477304773147732477334773447735477364773747738477394774047741477424774347744477454774647747477484774947750477514775247753477544775547756477574775847759477604776147762477634776447765477664776747768477694777047771477724777347774477754777647777477784777947780477814778247783477844778547786477874778847789477904779147792477934779447795477964779747798477994780047801478024780347804478054780647807478084780947810478114781247813478144781547816478174781847819478204782147822478234782447825478264782747828478294783047831478324783347834478354783647837478384783947840478414784247843478444784547846478474784847849478504785147852478534785447855478564785747858478594786047861478624786347864478654786647867478684786947870478714787247873478744787547876478774787847879478804788147882478834788447885478864788747888478894789047891478924789347894478954789647897478984789947900479014790247903479044790547906479074790847909479104791147912479134791447915479164791747918479194792047921479224792347924479254792647927479284792947930479314793247933479344793547936479374793847939479404794147942479434794447945479464794747948479494795047951479524795347954479554795647957479584795947960479614796247963479644796547966479674796847969479704797147972479734797447975479764797747978479794798047981479824798347984479854798647987479884798947990479914799247993479944799547996479974799847999480004800148002480034800448005480064800748008480094801048011480124801348014480154801648017480184801948020480214802248023480244802548026480274802848029480304803148032480334803448035480364803748038480394804048041480424804348044480454804648047480484804948050480514805248053480544805548056480574805848059480604806148062480634806448065480664806748068480694807048071480724807348074480754807648077480784807948080480814808248083480844808548086480874808848089480904809148092480934809448095480964809748098480994810048101481024810348104481054810648107481084810948110481114811248113481144811548116481174811848119481204812148122481234812448125481264812748128481294813048131481324813348134481354813648137481384813948140481414814248143481444814548146481474814848149481504815148152481534815448155481564815748158481594816048161481624816348164481654816648167481684816948170481714817248173481744817548176481774817848179481804818148182481834818448185481864818748188481894819048191481924819348194481954819648197481984819948200482014820248203482044820548206482074820848209482104821148212482134821448215482164821748218482194822048221482224822348224482254822648227482284822948230482314823248233482344823548236482374823848239482404824148242482434824448245482464824748248482494825048251482524825348254482554825648257482584825948260482614826248263482644826548266482674826848269482704827148272482734827448275482764827748278482794828048281482824828348284482854828648287482884828948290482914829248293482944829548296482974829848299483004830148302483034830448305483064830748308483094831048311483124831348314483154831648317483184831948320483214832248323483244832548326483274832848329483304833148332483334833448335483364833748338483394834048341483424834348344483454834648347483484834948350483514835248353483544835548356483574835848359483604836148362483634836448365483664836748368483694837048371483724837348374483754837648377483784837948380483814838248383483844838548386483874838848389483904839148392483934839448395483964839748398483994840048401484024840348404484054840648407484084840948410484114841248413484144841548416484174841848419484204842148422484234842448425484264842748428484294843048431484324843348434484354843648437484384843948440484414844248443484444844548446484474844848449484504845148452484534845448455484564845748458484594846048461484624846348464484654846648467484684846948470484714847248473484744847548476484774847848479484804848148482484834848448485484864848748488484894849048491484924849348494484954849648497484984849948500485014850248503485044850548506485074850848509485104851148512485134851448515485164851748518485194852048521485224852348524485254852648527485284852948530485314853248533485344853548536485374853848539485404854148542485434854448545485464854748548485494855048551485524855348554485554855648557485584855948560485614856248563485644856548566485674856848569485704857148572485734857448575485764857748578485794858048581485824858348584485854858648587485884858948590485914859248593485944859548596485974859848599486004860148602486034860448605486064860748608486094861048611486124861348614486154861648617486184861948620486214862248623486244862548626486274862848629486304863148632486334863448635486364863748638486394864048641486424864348644486454864648647486484864948650486514865248653486544865548656486574865848659486604866148662486634866448665486664866748668486694867048671486724867348674486754867648677486784867948680486814868248683486844868548686486874868848689486904869148692486934869448695486964869748698486994870048701487024870348704487054870648707487084870948710487114871248713487144871548716487174871848719487204872148722487234872448725487264872748728487294873048731487324873348734487354873648737487384873948740487414874248743487444874548746487474874848749487504875148752487534875448755487564875748758487594876048761487624876348764487654876648767487684876948770487714877248773487744877548776487774877848779487804878148782487834878448785487864878748788487894879048791487924879348794487954879648797487984879948800488014880248803488044880548806488074880848809488104881148812488134881448815488164881748818488194882048821488224882348824488254882648827488284882948830488314883248833488344883548836488374883848839488404884148842488434884448845488464884748848488494885048851488524885348854488554885648857488584885948860488614886248863488644886548866488674886848869488704887148872488734887448875488764887748878488794888048881488824888348884488854888648887488884888948890488914889248893488944889548896488974889848899489004890148902489034890448905489064890748908489094891048911489124891348914489154891648917489184891948920489214892248923489244892548926489274892848929489304893148932489334893448935489364893748938489394894048941489424894348944489454894648947489484894948950489514895248953489544895548956489574895848959489604896148962489634896448965489664896748968489694897048971489724897348974489754897648977489784897948980489814898248983489844898548986489874898848989489904899148992489934899448995489964899748998489994900049001490024900349004490054900649007490084900949010490114901249013490144901549016490174901849019490204902149022490234902449025490264902749028490294903049031490324903349034490354903649037490384903949040490414904249043490444904549046490474904849049490504905149052490534905449055490564905749058490594906049061490624906349064490654906649067490684906949070490714907249073490744907549076490774907849079490804908149082490834908449085490864908749088490894909049091490924909349094490954909649097490984909949100491014910249103491044910549106491074910849109491104911149112491134911449115491164911749118491194912049121491224912349124491254912649127491284912949130491314913249133491344913549136491374913849139491404914149142491434914449145491464914749148491494915049151491524915349154491554915649157491584915949160491614916249163491644916549166491674916849169491704917149172491734917449175491764917749178491794918049181491824918349184491854918649187491884918949190491914919249193491944919549196491974919849199492004920149202492034920449205492064920749208492094921049211492124921349214492154921649217492184921949220492214922249223492244922549226492274922849229492304923149232492334923449235492364923749238492394924049241492424924349244492454924649247492484924949250492514925249253492544925549256492574925849259492604926149262492634926449265492664926749268492694927049271492724927349274492754927649277492784927949280492814928249283492844928549286492874928849289492904929149292492934929449295492964929749298492994930049301493024930349304493054930649307493084930949310493114931249313493144931549316493174931849319493204932149322493234932449325493264932749328493294933049331493324933349334493354933649337493384933949340493414934249343493444934549346493474934849349493504935149352493534935449355493564935749358493594936049361493624936349364493654936649367493684936949370493714937249373493744937549376493774937849379493804938149382493834938449385493864938749388493894939049391493924939349394493954939649397493984939949400494014940249403494044940549406494074940849409494104941149412494134941449415494164941749418494194942049421494224942349424494254942649427494284942949430494314943249433494344943549436494374943849439494404944149442494434944449445494464944749448494494945049451494524945349454494554945649457494584945949460494614946249463494644946549466494674946849469494704947149472494734947449475494764947749478494794948049481494824948349484494854948649487494884948949490494914949249493494944949549496494974949849499495004950149502495034950449505495064950749508495094951049511495124951349514495154951649517495184951949520495214952249523495244952549526495274952849529495304953149532495334953449535495364953749538495394954049541495424954349544495454954649547495484954949550495514955249553495544955549556495574955849559495604956149562495634956449565495664956749568495694957049571495724957349574495754957649577495784957949580495814958249583495844958549586495874958849589495904959149592495934959449595495964959749598495994960049601496024960349604496054960649607496084960949610496114961249613496144961549616496174961849619496204962149622496234962449625496264962749628496294963049631496324963349634496354963649637496384963949640496414964249643496444964549646496474964849649496504965149652496534965449655496564965749658496594966049661496624966349664496654966649667496684966949670496714967249673496744967549676496774967849679496804968149682496834968449685496864968749688496894969049691496924969349694496954969649697496984969949700497014970249703497044970549706497074970849709497104971149712497134971449715497164971749718497194972049721497224972349724497254972649727497284972949730497314973249733497344973549736497374973849739497404974149742497434974449745497464974749748497494975049751497524975349754497554975649757497584975949760497614976249763497644976549766497674976849769497704977149772497734977449775497764977749778497794978049781497824978349784497854978649787497884978949790497914979249793497944979549796497974979849799498004980149802498034980449805498064980749808498094981049811498124981349814498154981649817498184981949820498214982249823498244982549826498274982849829498304983149832498334983449835498364983749838498394984049841498424984349844498454984649847498484984949850498514985249853498544985549856498574985849859498604986149862498634986449865498664986749868498694987049871498724987349874498754987649877498784987949880498814988249883498844988549886498874988849889498904989149892498934989449895498964989749898498994990049901499024990349904499054990649907499084990949910499114991249913499144991549916499174991849919499204992149922499234992449925499264992749928499294993049931499324993349934499354993649937499384993949940499414994249943499444994549946499474994849949499504995149952499534995449955499564995749958499594996049961499624996349964499654996649967499684996949970499714997249973499744997549976499774997849979499804998149982499834998449985499864998749988499894999049991499924999349994499954999649997499984999950000500015000250003500045000550006500075000850009500105001150012500135001450015500165001750018500195002050021500225002350024500255002650027500285002950030500315003250033500345003550036500375003850039500405004150042500435004450045500465004750048500495005050051500525005350054500555005650057500585005950060500615006250063500645006550066500675006850069500705007150072500735007450075500765007750078500795008050081500825008350084500855008650087500885008950090500915009250093500945009550096500975009850099501005010150102501035010450105501065010750108501095011050111501125011350114501155011650117501185011950120501215012250123501245012550126501275012850129501305013150132501335013450135501365013750138501395014050141501425014350144501455014650147501485014950150501515015250153501545015550156501575015850159501605016150162501635016450165501665016750168501695017050171501725017350174501755017650177501785017950180501815018250183501845018550186501875018850189501905019150192501935019450195501965019750198501995020050201502025020350204502055020650207502085020950210502115021250213502145021550216502175021850219502205022150222502235022450225502265022750228502295023050231502325023350234502355023650237502385023950240502415024250243502445024550246502475024850249502505025150252502535025450255502565025750258502595026050261502625026350264502655026650267502685026950270502715027250273502745027550276502775027850279502805028150282502835028450285502865028750288502895029050291502925029350294502955029650297502985029950300503015030250303503045030550306503075030850309503105031150312503135031450315503165031750318503195032050321503225032350324503255032650327503285032950330503315033250333503345033550336503375033850339503405034150342503435034450345503465034750348503495035050351503525035350354503555035650357503585035950360503615036250363503645036550366503675036850369503705037150372503735037450375503765037750378503795038050381503825038350384503855038650387503885038950390503915039250393503945039550396503975039850399504005040150402504035040450405504065040750408504095041050411504125041350414504155041650417504185041950420504215042250423504245042550426504275042850429504305043150432504335043450435504365043750438504395044050441504425044350444504455044650447504485044950450504515045250453504545045550456504575045850459504605046150462504635046450465504665046750468504695047050471504725047350474504755047650477504785047950480504815048250483504845048550486504875048850489504905049150492504935049450495504965049750498504995050050501505025050350504505055050650507505085050950510505115051250513505145051550516505175051850519505205052150522505235052450525505265052750528505295053050531505325053350534505355053650537505385053950540505415054250543505445054550546505475054850549505505055150552505535055450555505565055750558505595056050561505625056350564505655056650567505685056950570505715057250573505745057550576505775057850579505805058150582505835058450585505865058750588505895059050591505925059350594505955059650597505985059950600506015060250603506045060550606506075060850609506105061150612506135061450615506165061750618506195062050621506225062350624506255062650627506285062950630506315063250633506345063550636506375063850639506405064150642506435064450645506465064750648506495065050651506525065350654506555065650657506585065950660506615066250663506645066550666506675066850669506705067150672506735067450675506765067750678506795068050681506825068350684506855068650687506885068950690506915069250693506945069550696506975069850699507005070150702507035070450705507065070750708507095071050711507125071350714507155071650717507185071950720507215072250723507245072550726507275072850729507305073150732507335073450735507365073750738507395074050741507425074350744507455074650747507485074950750507515075250753507545075550756507575075850759507605076150762507635076450765507665076750768507695077050771507725077350774507755077650777507785077950780507815078250783507845078550786507875078850789507905079150792507935079450795507965079750798507995080050801508025080350804508055080650807508085080950810508115081250813508145081550816508175081850819508205082150822508235082450825508265082750828508295083050831508325083350834508355083650837508385083950840508415084250843508445084550846508475084850849508505085150852508535085450855508565085750858508595086050861508625086350864508655086650867508685086950870508715087250873508745087550876508775087850879508805088150882508835088450885508865088750888508895089050891508925089350894508955089650897508985089950900509015090250903509045090550906509075090850909509105091150912509135091450915509165091750918509195092050921509225092350924509255092650927509285092950930509315093250933509345093550936509375093850939509405094150942509435094450945509465094750948509495095050951509525095350954509555095650957509585095950960509615096250963509645096550966509675096850969509705097150972509735097450975509765097750978509795098050981509825098350984509855098650987509885098950990509915099250993509945099550996509975099850999510005100151002510035100451005510065100751008510095101051011510125101351014510155101651017510185101951020510215102251023510245102551026510275102851029510305103151032510335103451035510365103751038510395104051041510425104351044510455104651047510485104951050510515105251053510545105551056510575105851059510605106151062510635106451065510665106751068510695107051071510725107351074510755107651077510785107951080510815108251083510845108551086510875108851089510905109151092510935109451095510965109751098510995110051101511025110351104511055110651107511085110951110511115111251113511145111551116511175111851119511205112151122511235112451125511265112751128511295113051131511325113351134511355113651137511385113951140511415114251143511445114551146511475114851149511505115151152511535115451155511565115751158511595116051161511625116351164511655116651167511685116951170511715117251173511745117551176511775117851179511805118151182511835118451185511865118751188511895119051191511925119351194511955119651197511985119951200512015120251203512045120551206512075120851209512105121151212512135121451215512165121751218512195122051221512225122351224512255122651227512285122951230512315123251233512345123551236512375123851239512405124151242512435124451245512465124751248512495125051251512525125351254512555125651257512585125951260512615126251263512645126551266512675126851269512705127151272512735127451275512765127751278512795128051281512825128351284512855128651287512885128951290512915129251293512945129551296512975129851299513005130151302513035130451305513065130751308513095131051311513125131351314513155131651317513185131951320513215132251323513245132551326513275132851329513305133151332513335133451335513365133751338513395134051341513425134351344513455134651347513485134951350513515135251353513545135551356513575135851359513605136151362513635136451365513665136751368513695137051371513725137351374513755137651377513785137951380513815138251383513845138551386513875138851389513905139151392513935139451395513965139751398513995140051401514025140351404514055140651407514085140951410514115141251413514145141551416514175141851419514205142151422514235142451425514265142751428514295143051431514325143351434514355143651437514385143951440514415144251443514445144551446514475144851449514505145151452514535145451455514565145751458514595146051461514625146351464514655146651467514685146951470514715147251473514745147551476514775147851479514805148151482514835148451485514865148751488514895149051491514925149351494514955149651497514985149951500515015150251503515045150551506515075150851509515105151151512515135151451515515165151751518515195152051521515225152351524515255152651527515285152951530515315153251533515345153551536515375153851539515405154151542515435154451545515465154751548515495155051551515525155351554515555155651557515585155951560515615156251563515645156551566515675156851569515705157151572515735157451575515765157751578515795158051581515825158351584515855158651587515885158951590515915159251593515945159551596515975159851599516005160151602516035160451605516065160751608516095161051611516125161351614516155161651617516185161951620516215162251623516245162551626516275162851629516305163151632516335163451635516365163751638516395164051641516425164351644516455164651647516485164951650516515165251653516545165551656516575165851659516605166151662516635166451665516665166751668516695167051671516725167351674516755167651677516785167951680516815168251683516845168551686516875168851689516905169151692516935169451695516965169751698516995170051701517025170351704517055170651707517085170951710517115171251713517145171551716517175171851719517205172151722517235172451725517265172751728517295173051731517325173351734517355173651737517385173951740517415174251743517445174551746517475174851749517505175151752517535175451755517565175751758517595176051761517625176351764517655176651767517685176951770517715177251773517745177551776517775177851779517805178151782517835178451785517865178751788517895179051791517925179351794517955179651797517985179951800518015180251803518045180551806518075180851809518105181151812518135181451815518165181751818518195182051821518225182351824518255182651827518285182951830518315183251833518345183551836518375183851839518405184151842518435184451845518465184751848518495185051851518525185351854518555185651857518585185951860518615186251863518645186551866518675186851869518705187151872518735187451875518765187751878518795188051881518825188351884518855188651887518885188951890518915189251893518945189551896518975189851899519005190151902519035190451905519065190751908519095191051911519125191351914519155191651917519185191951920519215192251923519245192551926519275192851929519305193151932519335193451935519365193751938519395194051941519425194351944519455194651947519485194951950519515195251953519545195551956519575195851959519605196151962519635196451965519665196751968519695197051971519725197351974519755197651977519785197951980519815198251983519845198551986519875198851989519905199151992519935199451995519965199751998519995200052001520025200352004520055200652007520085200952010520115201252013520145201552016520175201852019520205202152022520235202452025520265202752028520295203052031520325203352034520355203652037520385203952040520415204252043520445204552046520475204852049520505205152052520535205452055520565205752058520595206052061520625206352064520655206652067520685206952070520715207252073520745207552076520775207852079520805208152082520835208452085520865208752088520895209052091520925209352094520955209652097520985209952100521015210252103521045210552106521075210852109521105211152112521135211452115521165211752118521195212052121521225212352124521255212652127521285212952130521315213252133521345213552136521375213852139521405214152142521435214452145521465214752148521495215052151521525215352154521555215652157521585215952160521615216252163521645216552166521675216852169521705217152172521735217452175521765217752178521795218052181521825218352184521855218652187521885218952190521915219252193521945219552196521975219852199522005220152202522035220452205522065220752208522095221052211522125221352214522155221652217522185221952220522215222252223522245222552226522275222852229522305223152232522335223452235522365223752238522395224052241522425224352244522455224652247522485224952250522515225252253522545225552256522575225852259522605226152262522635226452265522665226752268522695227052271522725227352274522755227652277522785227952280522815228252283522845228552286522875228852289522905229152292522935229452295522965229752298522995230052301523025230352304523055230652307523085230952310523115231252313523145231552316523175231852319523205232152322523235232452325523265232752328523295233052331523325233352334523355233652337523385233952340523415234252343523445234552346523475234852349523505235152352523535235452355523565235752358523595236052361523625236352364523655236652367523685236952370523715237252373523745237552376523775237852379523805238152382523835238452385523865238752388523895239052391523925239352394523955239652397523985239952400524015240252403524045240552406524075240852409524105241152412524135241452415524165241752418524195242052421524225242352424524255242652427524285242952430524315243252433524345243552436524375243852439524405244152442524435244452445524465244752448524495245052451524525245352454524555245652457524585245952460524615246252463524645246552466524675246852469524705247152472524735247452475524765247752478524795248052481524825248352484524855248652487524885248952490524915249252493524945249552496524975249852499525005250152502525035250452505525065250752508525095251052511525125251352514525155251652517525185251952520525215252252523525245252552526525275252852529525305253152532525335253452535525365253752538525395254052541525425254352544525455254652547525485254952550525515255252553525545255552556525575255852559525605256152562525635256452565525665256752568525695257052571525725257352574525755257652577525785257952580525815258252583525845258552586525875258852589525905259152592525935259452595525965259752598525995260052601526025260352604526055260652607526085260952610526115261252613526145261552616526175261852619526205262152622526235262452625526265262752628526295263052631526325263352634526355263652637526385263952640526415264252643526445264552646526475264852649526505265152652526535265452655526565265752658526595266052661526625266352664526655266652667526685266952670526715267252673526745267552676526775267852679526805268152682526835268452685526865268752688526895269052691526925269352694526955269652697526985269952700527015270252703527045270552706527075270852709527105271152712527135271452715527165271752718527195272052721527225272352724527255272652727527285272952730527315273252733527345273552736527375273852739527405274152742527435274452745527465274752748527495275052751527525275352754527555275652757527585275952760527615276252763527645276552766527675276852769527705277152772527735277452775527765277752778527795278052781527825278352784527855278652787527885278952790527915279252793527945279552796527975279852799528005280152802528035280452805528065280752808528095281052811528125281352814528155281652817528185281952820528215282252823528245282552826528275282852829528305283152832528335283452835528365283752838528395284052841528425284352844528455284652847528485284952850528515285252853528545285552856528575285852859528605286152862528635286452865528665286752868528695287052871528725287352874528755287652877528785287952880528815288252883528845288552886528875288852889528905289152892528935289452895528965289752898528995290052901529025290352904529055290652907529085290952910529115291252913529145291552916529175291852919529205292152922529235292452925529265292752928529295293052931529325293352934529355293652937529385293952940529415294252943529445294552946529475294852949529505295152952529535295452955529565295752958529595296052961529625296352964529655296652967529685296952970529715297252973529745297552976529775297852979529805298152982529835298452985529865298752988529895299052991529925299352994529955299652997529985299953000530015300253003530045300553006530075300853009530105301153012530135301453015530165301753018530195302053021530225302353024530255302653027530285302953030530315303253033530345303553036530375303853039530405304153042530435304453045530465304753048530495305053051530525305353054530555305653057530585305953060530615306253063530645306553066530675306853069530705307153072530735307453075530765307753078530795308053081530825308353084530855308653087530885308953090530915309253093530945309553096530975309853099531005310153102531035310453105531065310753108531095311053111531125311353114531155311653117531185311953120531215312253123531245312553126531275312853129531305313153132531335313453135531365313753138531395314053141531425314353144531455314653147531485314953150531515315253153531545315553156531575315853159531605316153162531635316453165531665316753168531695317053171531725317353174531755317653177531785317953180531815318253183531845318553186531875318853189531905319153192531935319453195531965319753198531995320053201532025320353204532055320653207532085320953210532115321253213532145321553216532175321853219532205322153222532235322453225532265322753228532295323053231532325323353234532355323653237532385323953240532415324253243532445324553246532475324853249532505325153252532535325453255532565325753258532595326053261532625326353264532655326653267532685326953270532715327253273532745327553276532775327853279532805328153282532835328453285532865328753288532895329053291532925329353294532955329653297532985329953300533015330253303533045330553306533075330853309533105331153312533135331453315533165331753318533195332053321533225332353324533255332653327533285332953330533315333253333533345333553336533375333853339533405334153342533435334453345533465334753348533495335053351533525335353354533555335653357533585335953360533615336253363533645336553366533675336853369533705337153372533735337453375533765337753378533795338053381533825338353384533855338653387533885338953390533915339253393533945339553396533975339853399534005340153402534035340453405534065340753408534095341053411534125341353414534155341653417534185341953420534215342253423534245342553426534275342853429534305343153432534335343453435534365343753438534395344053441534425344353444534455344653447534485344953450534515345253453534545345553456534575345853459534605346153462534635346453465534665346753468534695347053471534725347353474534755347653477534785347953480534815348253483534845348553486534875348853489534905349153492534935349453495534965349753498534995350053501535025350353504535055350653507535085350953510535115351253513535145351553516535175351853519535205352153522535235352453525535265352753528535295353053531535325353353534535355353653537535385353953540535415354253543535445354553546535475354853549535505355153552535535355453555535565355753558535595356053561535625356353564535655356653567535685356953570535715357253573535745357553576535775357853579535805358153582535835358453585535865358753588535895359053591535925359353594535955359653597535985359953600536015360253603536045360553606536075360853609536105361153612536135361453615536165361753618536195362053621536225362353624536255362653627536285362953630536315363253633536345363553636536375363853639536405364153642536435364453645536465364753648536495365053651536525365353654536555365653657536585365953660536615366253663536645366553666536675366853669536705367153672536735367453675536765367753678536795368053681536825368353684536855368653687536885368953690536915369253693536945369553696536975369853699537005370153702537035370453705537065370753708537095371053711537125371353714537155371653717537185371953720537215372253723537245372553726537275372853729537305373153732537335373453735537365373753738537395374053741537425374353744537455374653747537485374953750537515375253753537545375553756537575375853759537605376153762537635376453765537665376753768537695377053771537725377353774537755377653777537785377953780537815378253783537845378553786537875378853789537905379153792537935379453795537965379753798537995380053801538025380353804538055380653807538085380953810538115381253813538145381553816538175381853819538205382153822538235382453825538265382753828538295383053831538325383353834538355383653837538385383953840538415384253843538445384553846538475384853849538505385153852538535385453855538565385753858538595386053861538625386353864538655386653867538685386953870538715387253873538745387553876538775387853879538805388153882538835388453885538865388753888538895389053891538925389353894538955389653897538985389953900539015390253903539045390553906539075390853909539105391153912539135391453915539165391753918539195392053921539225392353924539255392653927539285392953930539315393253933539345393553936539375393853939539405394153942539435394453945539465394753948539495395053951539525395353954539555395653957539585395953960539615396253963539645396553966539675396853969539705397153972539735397453975539765397753978539795398053981539825398353984539855398653987539885398953990539915399253993539945399553996539975399853999540005400154002540035400454005540065400754008540095401054011540125401354014540155401654017540185401954020540215402254023540245402554026540275402854029540305403154032540335403454035540365403754038540395404054041540425404354044540455404654047540485404954050540515405254053540545405554056540575405854059540605406154062540635406454065540665406754068540695407054071540725407354074540755407654077540785407954080540815408254083540845408554086540875408854089540905409154092540935409454095540965409754098540995410054101541025410354104541055410654107541085410954110541115411254113541145411554116541175411854119541205412154122541235412454125541265412754128541295413054131541325413354134541355413654137541385413954140541415414254143541445414554146541475414854149541505415154152541535415454155541565415754158541595416054161541625416354164541655416654167541685416954170541715417254173541745417554176541775417854179541805418154182541835418454185541865418754188541895419054191541925419354194541955419654197541985419954200542015420254203542045420554206542075420854209542105421154212542135421454215542165421754218542195422054221542225422354224542255422654227542285422954230542315423254233542345423554236542375423854239542405424154242542435424454245542465424754248542495425054251542525425354254542555425654257542585425954260542615426254263542645426554266542675426854269542705427154272542735427454275542765427754278542795428054281542825428354284542855428654287542885428954290542915429254293542945429554296542975429854299543005430154302543035430454305543065430754308543095431054311543125431354314543155431654317543185431954320543215432254323543245432554326543275432854329543305433154332543335433454335543365433754338543395434054341543425434354344543455434654347543485434954350543515435254353543545435554356543575435854359543605436154362543635436454365543665436754368543695437054371543725437354374543755437654377543785437954380543815438254383543845438554386543875438854389543905439154392543935439454395543965439754398543995440054401544025440354404544055440654407544085440954410544115441254413544145441554416544175441854419544205442154422544235442454425544265442754428544295443054431544325443354434544355443654437544385443954440544415444254443544445444554446544475444854449544505445154452544535445454455544565445754458544595446054461544625446354464544655446654467544685446954470544715447254473544745447554476544775447854479544805448154482544835448454485544865448754488544895449054491544925449354494544955449654497544985449954500545015450254503545045450554506545075450854509545105451154512545135451454515545165451754518545195452054521545225452354524545255452654527545285452954530545315453254533545345453554536545375453854539545405454154542545435454454545545465454754548545495455054551545525455354554545555455654557545585455954560545615456254563545645456554566545675456854569545705457154572545735457454575545765457754578545795458054581545825458354584545855458654587545885458954590545915459254593545945459554596545975459854599546005460154602546035460454605546065460754608546095461054611546125461354614546155461654617546185461954620546215462254623546245462554626546275462854629546305463154632546335463454635546365463754638546395464054641546425464354644546455464654647546485464954650546515465254653546545465554656546575465854659546605466154662546635466454665546665466754668546695467054671546725467354674546755467654677546785467954680546815468254683546845468554686546875468854689546905469154692546935469454695546965469754698546995470054701547025470354704547055470654707547085470954710547115471254713547145471554716547175471854719547205472154722547235472454725547265472754728547295473054731547325473354734547355473654737547385473954740547415474254743547445474554746547475474854749547505475154752547535475454755547565475754758547595476054761547625476354764547655476654767547685476954770547715477254773547745477554776547775477854779547805478154782547835478454785547865478754788547895479054791547925479354794547955479654797547985479954800548015480254803548045480554806548075480854809548105481154812548135481454815548165481754818548195482054821548225482354824548255482654827548285482954830548315483254833548345483554836548375483854839548405484154842548435484454845548465484754848548495485054851548525485354854548555485654857548585485954860548615486254863548645486554866548675486854869548705487154872548735487454875548765487754878548795488054881548825488354884548855488654887548885488954890548915489254893548945489554896548975489854899549005490154902549035490454905549065490754908549095491054911549125491354914549155491654917549185491954920549215492254923549245492554926549275492854929549305493154932549335493454935549365493754938549395494054941549425494354944549455494654947549485494954950549515495254953549545495554956549575495854959549605496154962549635496454965549665496754968549695497054971549725497354974549755497654977549785497954980549815498254983549845498554986549875498854989549905499154992549935499454995549965499754998549995500055001550025500355004550055500655007550085500955010550115501255013550145501555016550175501855019550205502155022550235502455025550265502755028550295503055031550325503355034550355503655037550385503955040550415504255043550445504555046550475504855049550505505155052550535505455055550565505755058550595506055061550625506355064550655506655067550685506955070550715507255073550745507555076550775507855079550805508155082550835508455085550865508755088550895509055091550925509355094550955509655097550985509955100551015510255103551045510555106551075510855109551105511155112551135511455115551165511755118551195512055121551225512355124551255512655127551285512955130551315513255133551345513555136551375513855139551405514155142551435514455145551465514755148551495515055151551525515355154551555515655157551585515955160551615516255163551645516555166551675516855169551705517155172551735517455175551765517755178551795518055181551825518355184551855518655187551885518955190551915519255193551945519555196551975519855199552005520155202552035520455205552065520755208552095521055211552125521355214552155521655217552185521955220552215522255223552245522555226552275522855229552305523155232552335523455235552365523755238552395524055241552425524355244552455524655247552485524955250552515525255253552545525555256552575525855259552605526155262552635526455265552665526755268552695527055271552725527355274552755527655277552785527955280552815528255283552845528555286552875528855289552905529155292552935529455295552965529755298552995530055301553025530355304553055530655307553085530955310553115531255313553145531555316553175531855319553205532155322553235532455325553265532755328553295533055331553325533355334553355533655337553385533955340553415534255343553445534555346553475534855349553505535155352553535535455355553565535755358553595536055361553625536355364553655536655367553685536955370553715537255373553745537555376553775537855379553805538155382553835538455385553865538755388553895539055391553925539355394553955539655397553985539955400554015540255403554045540555406554075540855409554105541155412554135541455415554165541755418554195542055421554225542355424554255542655427554285542955430554315543255433554345543555436554375543855439554405544155442554435544455445554465544755448554495545055451554525545355454554555545655457554585545955460554615546255463554645546555466554675546855469554705547155472554735547455475554765547755478554795548055481554825548355484554855548655487554885548955490554915549255493554945549555496554975549855499555005550155502555035550455505555065550755508555095551055511555125551355514555155551655517555185551955520555215552255523555245552555526555275552855529555305553155532555335553455535555365553755538555395554055541555425554355544555455554655547555485554955550555515555255553555545555555556555575555855559555605556155562555635556455565555665556755568555695557055571555725557355574555755557655577555785557955580555815558255583555845558555586555875558855589555905559155592555935559455595555965559755598555995560055601556025560355604556055560655607556085560955610556115561255613556145561555616556175561855619556205562155622556235562455625556265562755628556295563055631556325563355634556355563655637556385563955640556415564255643556445564555646556475564855649556505565155652556535565455655556565565755658556595566055661556625566355664556655566655667556685566955670556715567255673556745567555676556775567855679556805568155682556835568455685556865568755688556895569055691556925569355694556955569655697556985569955700557015570255703557045570555706557075570855709557105571155712557135571455715557165571755718557195572055721557225572355724557255572655727557285572955730557315573255733557345573555736557375573855739557405574155742557435574455745557465574755748557495575055751557525575355754557555575655757557585575955760557615576255763557645576555766557675576855769557705577155772557735577455775557765577755778557795578055781557825578355784557855578655787557885578955790557915579255793557945579555796557975579855799558005580155802558035580455805558065580755808558095581055811558125581355814558155581655817558185581955820558215582255823558245582555826558275582855829558305583155832558335583455835558365583755838558395584055841558425584355844558455584655847558485584955850558515585255853558545585555856558575585855859558605586155862558635586455865558665586755868558695587055871558725587355874558755587655877558785587955880558815588255883558845588555886558875588855889558905589155892558935589455895558965589755898558995590055901559025590355904559055590655907559085590955910559115591255913559145591555916559175591855919559205592155922559235592455925559265592755928559295593055931559325593355934559355593655937559385593955940559415594255943559445594555946559475594855949559505595155952559535595455955559565595755958559595596055961559625596355964559655596655967559685596955970559715597255973559745597555976559775597855979559805598155982559835598455985559865598755988559895599055991559925599355994559955599655997559985599956000560015600256003560045600556006560075600856009560105601156012560135601456015560165601756018560195602056021560225602356024560255602656027560285602956030560315603256033560345603556036560375603856039560405604156042560435604456045560465604756048560495605056051560525605356054560555605656057560585605956060560615606256063560645606556066560675606856069560705607156072560735607456075560765607756078560795608056081560825608356084560855608656087560885608956090560915609256093560945609556096560975609856099561005610156102561035610456105561065610756108561095611056111561125611356114561155611656117561185611956120561215612256123561245612556126561275612856129561305613156132561335613456135561365613756138561395614056141561425614356144561455614656147561485614956150561515615256153561545615556156561575615856159561605616156162561635616456165561665616756168561695617056171561725617356174561755617656177561785617956180561815618256183561845618556186561875618856189561905619156192561935619456195561965619756198561995620056201562025620356204562055620656207562085620956210562115621256213562145621556216562175621856219562205622156222562235622456225562265622756228562295623056231562325623356234562355623656237562385623956240562415624256243562445624556246562475624856249562505625156252562535625456255562565625756258562595626056261562625626356264562655626656267562685626956270562715627256273562745627556276562775627856279562805628156282562835628456285562865628756288562895629056291562925629356294562955629656297562985629956300563015630256303563045630556306563075630856309563105631156312563135631456315563165631756318563195632056321563225632356324563255632656327563285632956330563315633256333563345633556336563375633856339563405634156342563435634456345563465634756348563495635056351563525635356354563555635656357563585635956360563615636256363563645636556366563675636856369563705637156372563735637456375563765637756378563795638056381563825638356384563855638656387563885638956390563915639256393563945639556396563975639856399564005640156402564035640456405564065640756408564095641056411564125641356414564155641656417564185641956420564215642256423564245642556426564275642856429564305643156432564335643456435564365643756438564395644056441564425644356444564455644656447564485644956450564515645256453564545645556456564575645856459564605646156462564635646456465564665646756468564695647056471564725647356474564755647656477564785647956480564815648256483564845648556486564875648856489564905649156492564935649456495564965649756498564995650056501565025650356504565055650656507565085650956510565115651256513565145651556516565175651856519565205652156522565235652456525565265652756528565295653056531565325653356534565355653656537565385653956540565415654256543565445654556546565475654856549565505655156552565535655456555565565655756558565595656056561565625656356564565655656656567565685656956570565715657256573565745657556576565775657856579565805658156582565835658456585565865658756588565895659056591565925659356594565955659656597565985659956600566015660256603566045660556606566075660856609566105661156612566135661456615566165661756618566195662056621566225662356624566255662656627566285662956630566315663256633566345663556636566375663856639566405664156642566435664456645566465664756648566495665056651566525665356654566555665656657566585665956660566615666256663566645666556666566675666856669566705667156672566735667456675566765667756678566795668056681566825668356684566855668656687566885668956690566915669256693566945669556696566975669856699567005670156702567035670456705567065670756708567095671056711567125671356714567155671656717567185671956720567215672256723567245672556726567275672856729567305673156732567335673456735567365673756738567395674056741567425674356744567455674656747567485674956750567515675256753567545675556756567575675856759567605676156762567635676456765567665676756768567695677056771567725677356774567755677656777567785677956780567815678256783567845678556786567875678856789567905679156792567935679456795567965679756798567995680056801568025680356804568055680656807568085680956810568115681256813568145681556816568175681856819568205682156822568235682456825568265682756828568295683056831568325683356834568355683656837568385683956840568415684256843568445684556846568475684856849568505685156852568535685456855568565685756858568595686056861568625686356864568655686656867568685686956870568715687256873568745687556876568775687856879568805688156882568835688456885568865688756888568895689056891568925689356894568955689656897568985689956900569015690256903569045690556906569075690856909569105691156912569135691456915569165691756918569195692056921569225692356924569255692656927569285692956930569315693256933569345693556936569375693856939569405694156942569435694456945569465694756948569495695056951569525695356954569555695656957569585695956960569615696256963569645696556966569675696856969569705697156972569735697456975569765697756978569795698056981569825698356984569855698656987569885698956990569915699256993569945699556996569975699856999570005700157002570035700457005570065700757008570095701057011570125701357014570155701657017570185701957020570215702257023570245702557026570275702857029570305703157032570335703457035570365703757038570395704057041570425704357044570455704657047570485704957050570515705257053570545705557056570575705857059570605706157062570635706457065570665706757068570695707057071570725707357074570755707657077570785707957080570815708257083570845708557086570875708857089570905709157092570935709457095570965709757098570995710057101571025710357104571055710657107571085710957110571115711257113571145711557116571175711857119571205712157122571235712457125571265712757128571295713057131571325713357134571355713657137571385713957140571415714257143571445714557146571475714857149571505715157152571535715457155571565715757158571595716057161571625716357164571655716657167571685716957170571715717257173571745717557176571775717857179571805718157182571835718457185571865718757188571895719057191571925719357194571955719657197571985719957200572015720257203572045720557206572075720857209572105721157212572135721457215572165721757218572195722057221572225722357224572255722657227572285722957230572315723257233572345723557236572375723857239572405724157242572435724457245572465724757248572495725057251572525725357254572555725657257572585725957260572615726257263572645726557266572675726857269572705727157272572735727457275572765727757278572795728057281572825728357284572855728657287572885728957290572915729257293572945729557296572975729857299573005730157302573035730457305573065730757308573095731057311573125731357314573155731657317573185731957320573215732257323573245732557326573275732857329573305733157332573335733457335573365733757338573395734057341573425734357344573455734657347573485734957350573515735257353573545735557356573575735857359573605736157362573635736457365573665736757368573695737057371573725737357374573755737657377573785737957380573815738257383573845738557386573875738857389573905739157392573935739457395573965739757398573995740057401574025740357404574055740657407574085740957410574115741257413574145741557416574175741857419574205742157422574235742457425574265742757428574295743057431574325743357434574355743657437574385743957440574415744257443574445744557446574475744857449574505745157452574535745457455574565745757458574595746057461574625746357464574655746657467574685746957470574715747257473574745747557476574775747857479574805748157482574835748457485574865748757488574895749057491574925749357494574955749657497574985749957500575015750257503575045750557506575075750857509575105751157512575135751457515575165751757518575195752057521575225752357524575255752657527575285752957530575315753257533575345753557536575375753857539575405754157542575435754457545575465754757548575495755057551575525755357554575555755657557575585755957560575615756257563575645756557566575675756857569575705757157572575735757457575575765757757578575795758057581575825758357584575855758657587575885758957590575915759257593575945759557596575975759857599576005760157602576035760457605576065760757608576095761057611576125761357614576155761657617576185761957620576215762257623576245762557626576275762857629576305763157632576335763457635576365763757638576395764057641576425764357644576455764657647576485764957650576515765257653576545765557656576575765857659576605766157662576635766457665576665766757668576695767057671576725767357674576755767657677576785767957680576815768257683576845768557686576875768857689576905769157692576935769457695576965769757698576995770057701577025770357704577055770657707577085770957710577115771257713577145771557716577175771857719577205772157722577235772457725577265772757728577295773057731577325773357734577355773657737577385773957740577415774257743577445774557746577475774857749577505775157752577535775457755577565775757758577595776057761577625776357764577655776657767577685776957770577715777257773577745777557776577775777857779577805778157782577835778457785577865778757788577895779057791577925779357794577955779657797577985779957800578015780257803578045780557806578075780857809578105781157812578135781457815578165781757818578195782057821578225782357824578255782657827578285782957830578315783257833578345783557836578375783857839578405784157842578435784457845578465784757848578495785057851578525785357854578555785657857578585785957860578615786257863578645786557866578675786857869578705787157872578735787457875578765787757878578795788057881578825788357884578855788657887578885788957890578915789257893578945789557896578975789857899579005790157902579035790457905579065790757908579095791057911579125791357914579155791657917579185791957920579215792257923579245792557926579275792857929579305793157932579335793457935579365793757938579395794057941579425794357944579455794657947579485794957950579515795257953579545795557956579575795857959579605796157962579635796457965579665796757968579695797057971579725797357974579755797657977579785797957980579815798257983579845798557986579875798857989579905799157992579935799457995579965799757998579995800058001580025800358004580055800658007580085800958010580115801258013580145801558016580175801858019580205802158022580235802458025580265802758028580295803058031580325803358034580355803658037580385803958040580415804258043580445804558046580475804858049580505805158052580535805458055580565805758058580595806058061580625806358064580655806658067580685806958070580715807258073580745807558076580775807858079580805808158082580835808458085580865808758088580895809058091580925809358094580955809658097580985809958100581015810258103581045810558106581075810858109581105811158112581135811458115581165811758118581195812058121581225812358124581255812658127581285812958130581315813258133581345813558136581375813858139581405814158142581435814458145581465814758148581495815058151581525815358154581555815658157581585815958160581615816258163581645816558166581675816858169581705817158172581735817458175581765817758178581795818058181581825818358184581855818658187581885818958190581915819258193581945819558196581975819858199582005820158202582035820458205582065820758208582095821058211582125821358214582155821658217582185821958220582215822258223582245822558226582275822858229582305823158232582335823458235582365823758238582395824058241582425824358244582455824658247582485824958250582515825258253582545825558256582575825858259582605826158262582635826458265582665826758268582695827058271582725827358274582755827658277582785827958280582815828258283582845828558286582875828858289582905829158292582935829458295582965829758298582995830058301583025830358304583055830658307583085830958310583115831258313583145831558316583175831858319583205832158322583235832458325583265832758328583295833058331583325833358334583355833658337583385833958340583415834258343583445834558346583475834858349583505835158352583535835458355583565835758358583595836058361583625836358364583655836658367583685836958370583715837258373583745837558376583775837858379583805838158382583835838458385583865838758388583895839058391583925839358394583955839658397583985839958400584015840258403584045840558406584075840858409584105841158412584135841458415584165841758418584195842058421584225842358424584255842658427584285842958430584315843258433584345843558436584375843858439584405844158442584435844458445584465844758448584495845058451584525845358454584555845658457584585845958460584615846258463584645846558466584675846858469584705847158472584735847458475584765847758478584795848058481584825848358484584855848658487584885848958490584915849258493584945849558496584975849858499585005850158502585035850458505585065850758508585095851058511585125851358514585155851658517585185851958520585215852258523585245852558526585275852858529585305853158532585335853458535585365853758538585395854058541585425854358544585455854658547585485854958550585515855258553585545855558556585575855858559585605856158562585635856458565585665856758568585695857058571585725857358574585755857658577585785857958580585815858258583585845858558586585875858858589585905859158592585935859458595585965859758598585995860058601586025860358604586055860658607586085860958610586115861258613586145861558616586175861858619586205862158622586235862458625586265862758628586295863058631586325863358634586355863658637586385863958640586415864258643586445864558646586475864858649586505865158652586535865458655586565865758658586595866058661586625866358664586655866658667586685866958670586715867258673586745867558676586775867858679586805868158682586835868458685586865868758688586895869058691586925869358694586955869658697586985869958700587015870258703587045870558706587075870858709587105871158712587135871458715587165871758718587195872058721587225872358724587255872658727587285872958730587315873258733587345873558736587375873858739587405874158742587435874458745587465874758748587495875058751587525875358754587555875658757587585875958760587615876258763587645876558766587675876858769587705877158772587735877458775587765877758778587795878058781587825878358784587855878658787587885878958790587915879258793587945879558796587975879858799588005880158802588035880458805588065880758808588095881058811588125881358814588155881658817588185881958820588215882258823588245882558826588275882858829588305883158832588335883458835588365883758838588395884058841588425884358844588455884658847588485884958850588515885258853588545885558856588575885858859588605886158862588635886458865588665886758868588695887058871588725887358874588755887658877588785887958880588815888258883588845888558886588875888858889588905889158892588935889458895588965889758898588995890058901589025890358904589055890658907589085890958910589115891258913589145891558916589175891858919589205892158922589235892458925589265892758928589295893058931589325893358934589355893658937589385893958940589415894258943589445894558946589475894858949589505895158952589535895458955589565895758958589595896058961589625896358964589655896658967589685896958970589715897258973589745897558976589775897858979589805898158982589835898458985589865898758988589895899058991589925899358994589955899658997589985899959000590015900259003590045900559006590075900859009590105901159012590135901459015590165901759018590195902059021590225902359024590255902659027590285902959030590315903259033590345903559036590375903859039590405904159042590435904459045590465904759048590495905059051590525905359054590555905659057590585905959060590615906259063590645906559066590675906859069590705907159072590735907459075590765907759078590795908059081590825908359084590855908659087590885908959090590915909259093590945909559096590975909859099591005910159102591035910459105591065910759108591095911059111591125911359114591155911659117591185911959120591215912259123591245912559126591275912859129591305913159132591335913459135591365913759138591395914059141591425914359144591455914659147591485914959150591515915259153591545915559156591575915859159591605916159162591635916459165591665916759168591695917059171591725917359174591755917659177591785917959180591815918259183591845918559186591875918859189591905919159192591935919459195591965919759198591995920059201592025920359204592055920659207592085920959210592115921259213592145921559216592175921859219592205922159222592235922459225592265922759228592295923059231592325923359234592355923659237592385923959240592415924259243592445924559246592475924859249592505925159252592535925459255592565925759258592595926059261592625926359264592655926659267592685926959270592715927259273592745927559276592775927859279592805928159282592835928459285592865928759288592895929059291592925929359294592955929659297592985929959300593015930259303593045930559306593075930859309593105931159312593135931459315593165931759318593195932059321593225932359324593255932659327593285932959330593315933259333593345933559336593375933859339593405934159342593435934459345593465934759348593495935059351593525935359354593555935659357593585935959360593615936259363593645936559366593675936859369593705937159372593735937459375593765937759378593795938059381593825938359384593855938659387593885938959390593915939259393593945939559396593975939859399594005940159402594035940459405594065940759408594095941059411594125941359414594155941659417594185941959420594215942259423594245942559426594275942859429594305943159432594335943459435594365943759438594395944059441594425944359444594455944659447594485944959450594515945259453594545945559456594575945859459594605946159462594635946459465594665946759468594695947059471594725947359474594755947659477594785947959480594815948259483594845948559486594875948859489594905949159492594935949459495594965949759498594995950059501595025950359504595055950659507595085950959510595115951259513595145951559516595175951859519595205952159522595235952459525595265952759528595295953059531595325953359534595355953659537595385953959540595415954259543595445954559546595475954859549595505955159552595535955459555595565955759558595595956059561595625956359564595655956659567595685956959570595715957259573595745957559576595775957859579595805958159582595835958459585595865958759588595895959059591595925959359594595955959659597595985959959600596015960259603596045960559606596075960859609596105961159612596135961459615596165961759618596195962059621596225962359624596255962659627596285962959630596315963259633596345963559636596375963859639596405964159642596435964459645596465964759648596495965059651596525965359654596555965659657596585965959660596615966259663596645966559666596675966859669596705967159672596735967459675596765967759678596795968059681596825968359684596855968659687596885968959690596915969259693596945969559696596975969859699597005970159702597035970459705597065970759708597095971059711597125971359714597155971659717597185971959720597215972259723597245972559726597275972859729597305973159732597335973459735597365973759738597395974059741597425974359744597455974659747597485974959750597515975259753597545975559756597575975859759597605976159762597635976459765597665976759768597695977059771597725977359774597755977659777597785977959780597815978259783597845978559786597875978859789597905979159792597935979459795597965979759798597995980059801598025980359804598055980659807598085980959810598115981259813598145981559816598175981859819598205982159822598235982459825598265982759828598295983059831598325983359834598355983659837598385983959840598415984259843598445984559846598475984859849598505985159852598535985459855598565985759858598595986059861598625986359864598655986659867598685986959870598715987259873598745987559876598775987859879598805988159882598835988459885598865988759888598895989059891598925989359894598955989659897598985989959900599015990259903599045990559906599075990859909599105991159912599135991459915599165991759918599195992059921599225992359924599255992659927599285992959930599315993259933599345993559936599375993859939599405994159942599435994459945599465994759948599495995059951599525995359954599555995659957599585995959960599615996259963599645996559966599675996859969599705997159972599735997459975599765997759978599795998059981599825998359984599855998659987599885998959990599915999259993599945999559996599975999859999600006000160002600036000460005600066000760008600096001060011600126001360014600156001660017600186001960020600216002260023600246002560026600276002860029600306003160032600336003460035600366003760038600396004060041600426004360044600456004660047600486004960050600516005260053600546005560056600576005860059600606006160062600636006460065600666006760068600696007060071600726007360074600756007660077600786007960080600816008260083600846008560086600876008860089600906009160092600936009460095600966009760098600996010060101601026010360104601056010660107601086010960110601116011260113601146011560116601176011860119601206012160122601236012460125601266012760128601296013060131601326013360134601356013660137601386013960140601416014260143601446014560146601476014860149601506015160152601536015460155601566015760158601596016060161601626016360164601656016660167601686016960170601716017260173601746017560176601776017860179601806018160182601836018460185601866018760188601896019060191601926019360194601956019660197601986019960200602016020260203602046020560206602076020860209602106021160212602136021460215602166021760218602196022060221602226022360224602256022660227602286022960230602316023260233602346023560236602376023860239602406024160242602436024460245602466024760248602496025060251602526025360254602556025660257602586025960260602616026260263602646026560266602676026860269602706027160272602736027460275602766027760278602796028060281602826028360284602856028660287602886028960290602916029260293602946029560296602976029860299603006030160302603036030460305603066030760308603096031060311603126031360314603156031660317603186031960320603216032260323603246032560326603276032860329603306033160332603336033460335603366033760338603396034060341603426034360344603456034660347603486034960350603516035260353603546035560356603576035860359603606036160362603636036460365603666036760368603696037060371603726037360374603756037660377603786037960380603816038260383603846038560386603876038860389603906039160392603936039460395603966039760398603996040060401604026040360404604056040660407604086040960410604116041260413604146041560416604176041860419604206042160422604236042460425604266042760428604296043060431604326043360434604356043660437604386043960440604416044260443604446044560446604476044860449604506045160452604536045460455604566045760458604596046060461604626046360464604656046660467604686046960470604716047260473604746047560476604776047860479604806048160482604836048460485604866048760488604896049060491604926049360494604956049660497604986049960500605016050260503605046050560506605076050860509605106051160512605136051460515605166051760518605196052060521605226052360524605256052660527605286052960530605316053260533605346053560536605376053860539605406054160542605436054460545605466054760548605496055060551605526055360554605556055660557605586055960560605616056260563605646056560566605676056860569605706057160572605736057460575605766057760578605796058060581605826058360584605856058660587605886058960590605916059260593605946059560596605976059860599606006060160602606036060460605606066060760608606096061060611606126061360614606156061660617606186061960620606216062260623606246062560626606276062860629606306063160632606336063460635606366063760638606396064060641606426064360644606456064660647606486064960650606516065260653606546065560656606576065860659606606066160662606636066460665606666066760668606696067060671606726067360674606756067660677606786067960680606816068260683606846068560686606876068860689606906069160692606936069460695606966069760698606996070060701607026070360704607056070660707607086070960710607116071260713607146071560716607176071860719607206072160722607236072460725607266072760728607296073060731607326073360734607356073660737607386073960740607416074260743607446074560746607476074860749607506075160752607536075460755607566075760758607596076060761607626076360764607656076660767607686076960770607716077260773607746077560776607776077860779607806078160782607836078460785607866078760788607896079060791607926079360794607956079660797607986079960800608016080260803608046080560806608076080860809608106081160812608136081460815608166081760818608196082060821608226082360824608256082660827608286082960830608316083260833608346083560836608376083860839608406084160842608436084460845608466084760848608496085060851608526085360854608556085660857608586085960860608616086260863608646086560866608676086860869608706087160872608736087460875608766087760878608796088060881608826088360884608856088660887608886088960890608916089260893608946089560896608976089860899609006090160902609036090460905609066090760908609096091060911609126091360914609156091660917609186091960920609216092260923609246092560926609276092860929609306093160932609336093460935609366093760938609396094060941609426094360944609456094660947609486094960950609516095260953609546095560956609576095860959609606096160962609636096460965609666096760968609696097060971609726097360974609756097660977609786097960980609816098260983609846098560986609876098860989609906099160992609936099460995609966099760998609996100061001610026100361004610056100661007610086100961010610116101261013610146101561016610176101861019610206102161022610236102461025610266102761028610296103061031610326103361034610356103661037610386103961040610416104261043610446104561046610476104861049610506105161052610536105461055610566105761058610596106061061610626106361064610656106661067610686106961070610716107261073610746107561076610776107861079610806108161082610836108461085610866108761088610896109061091610926109361094610956109661097610986109961100611016110261103611046110561106611076110861109611106111161112611136111461115611166111761118611196112061121611226112361124611256112661127611286112961130611316113261133611346113561136611376113861139611406114161142611436114461145611466114761148611496115061151611526115361154611556115661157611586115961160611616116261163611646116561166611676116861169611706117161172611736117461175611766117761178611796118061181611826118361184611856118661187611886118961190611916119261193611946119561196611976119861199612006120161202612036120461205612066120761208612096121061211612126121361214612156121661217612186121961220612216122261223612246122561226612276122861229612306123161232612336123461235612366123761238612396124061241612426124361244612456124661247612486124961250612516125261253612546125561256612576125861259612606126161262612636126461265612666126761268612696127061271612726127361274612756127661277612786127961280612816128261283612846128561286612876128861289612906129161292612936129461295612966129761298612996130061301613026130361304613056130661307613086130961310613116131261313613146131561316613176131861319613206132161322613236132461325613266132761328613296133061331613326133361334613356133661337613386133961340613416134261343613446134561346613476134861349613506135161352613536135461355613566135761358613596136061361613626136361364613656136661367613686136961370613716137261373613746137561376613776137861379613806138161382613836138461385613866138761388613896139061391613926139361394613956139661397613986139961400614016140261403614046140561406614076140861409614106141161412614136141461415614166141761418614196142061421614226142361424614256142661427614286142961430614316143261433614346143561436614376143861439614406144161442614436144461445614466144761448614496145061451614526145361454614556145661457614586145961460614616146261463614646146561466614676146861469614706147161472614736147461475614766147761478614796148061481614826148361484614856148661487614886148961490614916149261493614946149561496614976149861499615006150161502615036150461505615066150761508615096151061511615126151361514615156151661517615186151961520615216152261523615246152561526615276152861529615306153161532615336153461535615366153761538615396154061541615426154361544615456154661547615486154961550615516155261553615546155561556615576155861559615606156161562615636156461565615666156761568615696157061571615726157361574615756157661577615786157961580615816158261583615846158561586615876158861589615906159161592615936159461595615966159761598615996160061601616026160361604616056160661607616086160961610616116161261613616146161561616616176161861619616206162161622616236162461625616266162761628616296163061631616326163361634616356163661637616386163961640616416164261643616446164561646616476164861649616506165161652616536165461655616566165761658616596166061661616626166361664616656166661667616686166961670616716167261673616746167561676616776167861679616806168161682616836168461685616866168761688616896169061691616926169361694616956169661697616986169961700617016170261703617046170561706617076170861709617106171161712617136171461715617166171761718617196172061721617226172361724617256172661727617286172961730617316173261733617346173561736617376173861739617406174161742617436174461745617466174761748617496175061751617526175361754617556175661757617586175961760617616176261763617646176561766617676176861769617706177161772617736177461775617766177761778617796178061781617826178361784617856178661787617886178961790617916179261793617946179561796617976179861799618006180161802618036180461805618066180761808618096181061811618126181361814618156181661817618186181961820618216182261823618246182561826618276182861829618306183161832618336183461835618366183761838618396184061841618426184361844618456184661847618486184961850618516185261853618546185561856618576185861859618606186161862618636186461865618666186761868618696187061871618726187361874618756187661877618786187961880618816188261883618846188561886618876188861889618906189161892618936189461895618966189761898618996190061901619026190361904619056190661907619086190961910619116191261913619146191561916619176191861919619206192161922619236192461925619266192761928619296193061931619326193361934619356193661937619386193961940619416194261943619446194561946619476194861949619506195161952619536195461955619566195761958619596196061961619626196361964619656196661967619686196961970619716197261973619746197561976619776197861979619806198161982619836198461985619866198761988619896199061991619926199361994619956199661997619986199962000620016200262003620046200562006620076200862009620106201162012620136201462015620166201762018620196202062021620226202362024620256202662027620286202962030620316203262033620346203562036620376203862039620406204162042620436204462045620466204762048620496205062051620526205362054620556205662057620586205962060620616206262063620646206562066620676206862069620706207162072620736207462075620766207762078620796208062081620826208362084620856208662087620886208962090620916209262093620946209562096620976209862099621006210162102621036210462105621066210762108621096211062111621126211362114621156211662117621186211962120621216212262123621246212562126621276212862129621306213162132621336213462135621366213762138621396214062141621426214362144621456214662147621486214962150621516215262153621546215562156621576215862159621606216162162621636216462165621666216762168621696217062171621726217362174621756217662177621786217962180621816218262183621846218562186621876218862189621906219162192621936219462195621966219762198621996220062201622026220362204622056220662207622086220962210622116221262213622146221562216622176221862219622206222162222622236222462225622266222762228622296223062231622326223362234622356223662237622386223962240622416224262243622446224562246622476224862249622506225162252622536225462255622566225762258622596226062261622626226362264622656226662267622686226962270622716227262273622746227562276622776227862279622806228162282622836228462285622866228762288622896229062291622926229362294622956229662297622986229962300623016230262303623046230562306623076230862309623106231162312623136231462315623166231762318623196232062321623226232362324623256232662327623286232962330623316233262333623346233562336623376233862339623406234162342623436234462345623466234762348623496235062351623526235362354623556235662357623586235962360623616236262363623646236562366623676236862369623706237162372623736237462375623766237762378623796238062381623826238362384623856238662387623886238962390623916239262393623946239562396623976239862399624006240162402624036240462405624066240762408624096241062411624126241362414624156241662417624186241962420624216242262423624246242562426624276242862429624306243162432624336243462435624366243762438624396244062441624426244362444624456244662447624486244962450624516245262453624546245562456624576245862459624606246162462624636246462465624666246762468624696247062471624726247362474624756247662477624786247962480624816248262483624846248562486624876248862489624906249162492624936249462495624966249762498624996250062501625026250362504625056250662507625086250962510625116251262513625146251562516625176251862519625206252162522625236252462525625266252762528625296253062531625326253362534625356253662537625386253962540625416254262543625446254562546625476254862549625506255162552625536255462555625566255762558625596256062561625626256362564625656256662567625686256962570625716257262573625746257562576625776257862579625806258162582625836258462585625866258762588625896259062591625926259362594625956259662597625986259962600626016260262603626046260562606626076260862609626106261162612626136261462615626166261762618626196262062621626226262362624626256262662627626286262962630626316263262633626346263562636626376263862639626406264162642626436264462645626466264762648626496265062651626526265362654626556265662657626586265962660626616266262663626646266562666626676266862669626706267162672626736267462675626766267762678626796268062681626826268362684626856268662687626886268962690626916269262693626946269562696626976269862699627006270162702627036270462705627066270762708627096271062711627126271362714627156271662717627186271962720627216272262723627246272562726627276272862729627306273162732627336273462735627366273762738627396274062741627426274362744627456274662747627486274962750627516275262753627546275562756627576275862759627606276162762627636276462765627666276762768627696277062771627726277362774627756277662777627786277962780627816278262783627846278562786627876278862789627906279162792627936279462795627966279762798627996280062801628026280362804628056280662807628086280962810628116281262813628146281562816628176281862819628206282162822628236282462825628266282762828628296283062831628326283362834628356283662837628386283962840628416284262843628446284562846628476284862849628506285162852628536285462855628566285762858628596286062861628626286362864628656286662867628686286962870628716287262873628746287562876628776287862879628806288162882628836288462885628866288762888628896289062891628926289362894628956289662897628986289962900629016290262903629046290562906629076290862909629106291162912629136291462915629166291762918629196292062921629226292362924629256292662927629286292962930629316293262933629346293562936629376293862939629406294162942629436294462945629466294762948629496295062951629526295362954629556295662957629586295962960629616296262963629646296562966629676296862969629706297162972629736297462975629766297762978629796298062981629826298362984629856298662987629886298962990629916299262993629946299562996629976299862999630006300163002630036300463005630066300763008630096301063011630126301363014630156301663017630186301963020630216302263023630246302563026630276302863029630306303163032630336303463035630366303763038630396304063041630426304363044630456304663047630486304963050630516305263053630546305563056630576305863059630606306163062630636306463065630666306763068630696307063071630726307363074630756307663077630786307963080630816308263083630846308563086630876308863089630906309163092630936309463095630966309763098630996310063101631026310363104631056310663107631086310963110631116311263113631146311563116631176311863119631206312163122631236312463125631266312763128631296313063131631326313363134631356313663137631386313963140631416314263143631446314563146631476314863149631506315163152631536315463155631566315763158631596316063161631626316363164631656316663167631686316963170631716317263173631746317563176631776317863179631806318163182631836318463185631866318763188631896319063191631926319363194631956319663197631986319963200632016320263203632046320563206632076320863209632106321163212632136321463215632166321763218632196322063221632226322363224632256322663227632286322963230632316323263233632346323563236632376323863239632406324163242632436324463245632466324763248632496325063251632526325363254632556325663257632586325963260632616326263263632646326563266632676326863269632706327163272632736327463275632766327763278632796328063281632826328363284632856328663287632886328963290632916329263293632946329563296632976329863299633006330163302633036330463305633066330763308633096331063311633126331363314633156331663317633186331963320633216332263323633246332563326633276332863329633306333163332633336333463335633366333763338633396334063341633426334363344633456334663347633486334963350633516335263353633546335563356633576335863359633606336163362633636336463365633666336763368633696337063371633726337363374633756337663377633786337963380633816338263383633846338563386633876338863389633906339163392633936339463395633966339763398633996340063401634026340363404634056340663407634086340963410634116341263413634146341563416634176341863419634206342163422634236342463425634266342763428634296343063431634326343363434634356343663437634386343963440634416344263443634446344563446634476344863449634506345163452634536345463455634566345763458634596346063461634626346363464634656346663467634686346963470634716347263473634746347563476634776347863479634806348163482634836348463485634866348763488634896349063491634926349363494634956349663497634986349963500635016350263503635046350563506635076350863509635106351163512635136351463515635166351763518635196352063521635226352363524635256352663527635286352963530635316353263533635346353563536635376353863539635406354163542635436354463545635466354763548635496355063551635526355363554635556355663557635586355963560635616356263563635646356563566635676356863569635706357163572635736357463575635766357763578635796358063581635826358363584635856358663587635886358963590635916359263593635946359563596635976359863599636006360163602636036360463605636066360763608636096361063611636126361363614636156361663617636186361963620636216362263623636246362563626636276362863629636306363163632636336363463635636366363763638636396364063641636426364363644636456364663647636486364963650636516365263653636546365563656636576365863659636606366163662636636366463665636666366763668636696367063671636726367363674636756367663677636786367963680636816368263683636846368563686636876368863689636906369163692636936369463695636966369763698636996370063701637026370363704637056370663707637086370963710637116371263713637146371563716637176371863719637206372163722637236372463725637266372763728637296373063731637326373363734637356373663737637386373963740637416374263743637446374563746637476374863749637506375163752637536375463755637566375763758637596376063761637626376363764637656376663767637686376963770637716377263773637746377563776637776377863779637806378163782637836378463785637866378763788637896379063791637926379363794637956379663797637986379963800638016380263803638046380563806638076380863809638106381163812638136381463815638166381763818638196382063821638226382363824638256382663827638286382963830638316383263833638346383563836638376383863839638406384163842638436384463845638466384763848638496385063851638526385363854638556385663857638586385963860638616386263863638646386563866638676386863869638706387163872638736387463875638766387763878638796388063881638826388363884638856388663887638886388963890638916389263893638946389563896638976389863899639006390163902639036390463905639066390763908639096391063911639126391363914639156391663917639186391963920639216392263923639246392563926639276392863929639306393163932639336393463935639366393763938639396394063941639426394363944639456394663947639486394963950639516395263953639546395563956639576395863959639606396163962639636396463965639666396763968639696397063971639726397363974639756397663977639786397963980639816398263983639846398563986639876398863989639906399163992639936399463995639966399763998639996400064001640026400364004640056400664007640086400964010640116401264013640146401564016640176401864019640206402164022640236402464025640266402764028640296403064031640326403364034640356403664037640386403964040640416404264043640446404564046640476404864049640506405164052640536405464055640566405764058640596406064061640626406364064640656406664067640686406964070640716407264073640746407564076640776407864079640806408164082640836408464085640866408764088640896409064091640926409364094640956409664097640986409964100641016410264103641046410564106641076410864109641106411164112641136411464115641166411764118641196412064121641226412364124641256412664127641286412964130641316413264133641346413564136641376413864139641406414164142641436414464145641466414764148641496415064151641526415364154641556415664157641586415964160641616416264163641646416564166641676416864169641706417164172641736417464175641766417764178641796418064181641826418364184641856418664187641886418964190641916419264193641946419564196641976419864199642006420164202642036420464205642066420764208642096421064211642126421364214642156421664217642186421964220642216422264223642246422564226642276422864229642306423164232642336423464235642366423764238642396424064241642426424364244642456424664247642486424964250642516425264253642546425564256642576425864259642606426164262642636426464265642666426764268642696427064271642726427364274642756427664277642786427964280642816428264283642846428564286642876428864289642906429164292642936429464295642966429764298642996430064301643026430364304643056430664307643086430964310643116431264313643146431564316643176431864319643206432164322643236432464325643266432764328643296433064331643326433364334643356433664337643386433964340643416434264343643446434564346643476434864349643506435164352643536435464355643566435764358643596436064361643626436364364643656436664367643686436964370643716437264373643746437564376643776437864379643806438164382643836438464385643866438764388643896439064391643926439364394643956439664397643986439964400644016440264403644046440564406644076440864409644106441164412644136441464415644166441764418644196442064421644226442364424644256442664427644286442964430644316443264433644346443564436644376443864439644406444164442644436444464445644466444764448644496445064451644526445364454644556445664457644586445964460644616446264463644646446564466644676446864469644706447164472644736447464475644766447764478644796448064481644826448364484644856448664487644886448964490644916449264493644946449564496644976449864499645006450164502645036450464505645066450764508645096451064511645126451364514645156451664517645186451964520645216452264523645246452564526645276452864529645306453164532645336453464535645366453764538645396454064541645426454364544645456454664547645486454964550645516455264553645546455564556645576455864559645606456164562645636456464565645666456764568645696457064571645726457364574645756457664577645786457964580645816458264583645846458564586645876458864589645906459164592645936459464595645966459764598645996460064601646026460364604646056460664607646086460964610646116461264613646146461564616646176461864619646206462164622646236462464625646266462764628646296463064631646326463364634646356463664637646386463964640646416464264643646446464564646646476464864649646506465164652646536465464655646566465764658646596466064661646626466364664646656466664667646686466964670646716467264673646746467564676646776467864679646806468164682646836468464685646866468764688646896469064691646926469364694646956469664697646986469964700647016470264703647046470564706647076470864709647106471164712647136471464715647166471764718647196472064721647226472364724647256472664727647286472964730647316473264733647346473564736647376473864739647406474164742647436474464745647466474764748647496475064751647526475364754647556475664757647586475964760647616476264763647646476564766647676476864769647706477164772647736477464775647766477764778647796478064781647826478364784647856478664787647886478964790647916479264793647946479564796647976479864799648006480164802648036480464805648066480764808648096481064811648126481364814648156481664817648186481964820648216482264823648246482564826648276482864829648306483164832648336483464835648366483764838648396484064841648426484364844648456484664847648486484964850648516485264853648546485564856648576485864859648606486164862648636486464865648666486764868648696487064871648726487364874648756487664877648786487964880648816488264883648846488564886648876488864889648906489164892648936489464895648966489764898648996490064901649026490364904649056490664907649086490964910649116491264913649146491564916649176491864919649206492164922649236492464925649266492764928649296493064931649326493364934649356493664937649386493964940649416494264943649446494564946649476494864949649506495164952649536495464955649566495764958649596496064961649626496364964649656496664967649686496964970649716497264973649746497564976649776497864979649806498164982649836498464985649866498764988649896499064991649926499364994649956499664997649986499965000650016500265003650046500565006650076500865009650106501165012650136501465015650166501765018650196502065021650226502365024650256502665027650286502965030650316503265033650346503565036650376503865039650406504165042650436504465045650466504765048650496505065051650526505365054650556505665057650586505965060650616506265063650646506565066650676506865069650706507165072650736507465075650766507765078650796508065081650826508365084650856508665087650886508965090650916509265093650946509565096650976509865099651006510165102651036510465105651066510765108651096511065111651126511365114651156511665117651186511965120651216512265123651246512565126651276512865129651306513165132651336513465135651366513765138651396514065141651426514365144651456514665147651486514965150651516515265153651546515565156651576515865159651606516165162651636516465165651666516765168651696517065171651726517365174651756517665177651786517965180651816518265183651846518565186651876518865189651906519165192651936519465195651966519765198651996520065201652026520365204652056520665207652086520965210652116521265213652146521565216652176521865219652206522165222652236522465225652266522765228652296523065231652326523365234652356523665237652386523965240652416524265243652446524565246652476524865249652506525165252652536525465255652566525765258652596526065261652626526365264652656526665267652686526965270652716527265273652746527565276652776527865279652806528165282652836528465285652866528765288652896529065291652926529365294652956529665297652986529965300653016530265303653046530565306653076530865309653106531165312653136531465315653166531765318653196532065321653226532365324653256532665327653286532965330653316533265333653346533565336653376533865339653406534165342653436534465345653466534765348653496535065351653526535365354653556535665357653586535965360653616536265363653646536565366653676536865369653706537165372653736537465375653766537765378653796538065381653826538365384653856538665387653886538965390653916539265393653946539565396653976539865399654006540165402654036540465405654066540765408654096541065411654126541365414654156541665417654186541965420654216542265423654246542565426654276542865429654306543165432654336543465435654366543765438654396544065441654426544365444654456544665447654486544965450654516545265453654546545565456654576545865459654606546165462654636546465465654666546765468654696547065471654726547365474654756547665477654786547965480654816548265483654846548565486654876548865489654906549165492654936549465495654966549765498654996550065501655026550365504655056550665507655086550965510655116551265513655146551565516655176551865519655206552165522655236552465525655266552765528655296553065531655326553365534655356553665537655386553965540655416554265543655446554565546655476554865549655506555165552655536555465555655566555765558655596556065561655626556365564655656556665567655686556965570655716557265573655746557565576655776557865579655806558165582655836558465585655866558765588655896559065591655926559365594655956559665597655986559965600656016560265603656046560565606656076560865609656106561165612656136561465615656166561765618656196562065621656226562365624656256562665627656286562965630656316563265633656346563565636656376563865639656406564165642656436564465645656466564765648656496565065651656526565365654656556565665657656586565965660656616566265663656646566565666656676566865669656706567165672656736567465675656766567765678656796568065681656826568365684656856568665687656886568965690656916569265693656946569565696656976569865699657006570165702657036570465705657066570765708657096571065711657126571365714657156571665717657186571965720657216572265723657246572565726657276572865729657306573165732657336573465735657366573765738657396574065741657426574365744657456574665747657486574965750657516575265753657546575565756657576575865759657606576165762657636576465765657666576765768657696577065771657726577365774657756577665777657786577965780657816578265783657846578565786657876578865789657906579165792657936579465795657966579765798657996580065801658026580365804658056580665807658086580965810658116581265813658146581565816658176581865819658206582165822658236582465825658266582765828658296583065831658326583365834658356583665837658386583965840658416584265843658446584565846658476584865849658506585165852658536585465855658566585765858658596586065861658626586365864658656586665867658686586965870658716587265873658746587565876658776587865879658806588165882658836588465885658866588765888658896589065891658926589365894658956589665897658986589965900659016590265903659046590565906659076590865909659106591165912659136591465915659166591765918659196592065921659226592365924659256592665927659286592965930659316593265933659346593565936659376593865939659406594165942659436594465945659466594765948659496595065951659526595365954659556595665957659586595965960659616596265963659646596565966659676596865969659706597165972659736597465975659766597765978659796598065981659826598365984659856598665987659886598965990659916599265993659946599565996659976599865999660006600166002660036600466005660066600766008660096601066011660126601366014660156601666017660186601966020660216602266023660246602566026660276602866029660306603166032660336603466035660366603766038660396604066041660426604366044660456604666047660486604966050660516605266053660546605566056660576605866059660606606166062660636606466065660666606766068660696607066071660726607366074660756607666077660786607966080660816608266083660846608566086660876608866089660906609166092660936609466095660966609766098660996610066101661026610366104661056610666107661086610966110661116611266113661146611566116661176611866119661206612166122661236612466125661266612766128661296613066131661326613366134661356613666137661386613966140661416614266143661446614566146661476614866149661506615166152661536615466155661566615766158661596616066161661626616366164661656616666167661686616966170661716617266173661746617566176661776617866179661806618166182661836618466185661866618766188661896619066191661926619366194661956619666197661986619966200662016620266203662046620566206662076620866209662106621166212662136621466215662166621766218662196622066221662226622366224662256622666227662286622966230662316623266233662346623566236662376623866239662406624166242662436624466245662466624766248662496625066251662526625366254662556625666257662586625966260662616626266263662646626566266662676626866269662706627166272662736627466275662766627766278662796628066281662826628366284662856628666287662886628966290662916629266293662946629566296662976629866299663006630166302663036630466305663066630766308663096631066311663126631366314663156631666317663186631966320663216632266323663246632566326663276632866329663306633166332663336633466335663366633766338663396634066341663426634366344663456634666347663486634966350663516635266353663546635566356663576635866359663606636166362663636636466365663666636766368663696637066371663726637366374663756637666377663786637966380663816638266383663846638566386663876638866389663906639166392663936639466395663966639766398663996640066401664026640366404664056640666407664086640966410664116641266413664146641566416664176641866419664206642166422664236642466425664266642766428664296643066431664326643366434664356643666437664386643966440664416644266443664446644566446664476644866449664506645166452664536645466455664566645766458664596646066461664626646366464664656646666467664686646966470664716647266473664746647566476664776647866479664806648166482664836648466485664866648766488664896649066491664926649366494664956649666497664986649966500665016650266503665046650566506665076650866509665106651166512665136651466515665166651766518665196652066521665226652366524665256652666527665286652966530665316653266533665346653566536665376653866539665406654166542665436654466545665466654766548665496655066551665526655366554665556655666557665586655966560665616656266563665646656566566665676656866569665706657166572665736657466575665766657766578665796658066581665826658366584665856658666587665886658966590665916659266593665946659566596665976659866599666006660166602666036660466605666066660766608666096661066611666126661366614666156661666617666186661966620666216662266623666246662566626666276662866629666306663166632666336663466635666366663766638666396664066641666426664366644666456664666647666486664966650666516665266653666546665566656666576665866659666606666166662666636666466665666666666766668666696667066671666726667366674666756667666677666786667966680666816668266683666846668566686666876668866689666906669166692666936669466695666966669766698666996670066701667026670366704667056670666707667086670966710667116671266713667146671566716667176671866719667206672166722667236672466725667266672766728667296673066731667326673366734667356673666737667386673966740667416674266743667446674566746667476674866749667506675166752667536675466755667566675766758667596676066761667626676366764667656676666767667686676966770667716677266773667746677566776667776677866779667806678166782667836678466785667866678766788667896679066791667926679366794667956679666797667986679966800668016680266803668046680566806668076680866809668106681166812668136681466815668166681766818668196682066821668226682366824668256682666827668286682966830668316683266833668346683566836668376683866839668406684166842668436684466845668466684766848668496685066851668526685366854668556685666857668586685966860668616686266863668646686566866668676686866869668706687166872668736687466875668766687766878668796688066881668826688366884668856688666887668886688966890668916689266893668946689566896668976689866899669006690166902669036690466905669066690766908669096691066911669126691366914669156691666917669186691966920669216692266923669246692566926669276692866929669306693166932669336693466935669366693766938669396694066941669426694366944669456694666947669486694966950669516695266953669546695566956669576695866959669606696166962669636696466965669666696766968669696697066971669726697366974669756697666977669786697966980669816698266983669846698566986669876698866989669906699166992669936699466995669966699766998669996700067001670026700367004670056700667007670086700967010670116701267013670146701567016670176701867019670206702167022670236702467025670266702767028670296703067031670326703367034670356703667037670386703967040670416704267043670446704567046670476704867049670506705167052670536705467055670566705767058670596706067061670626706367064670656706667067670686706967070670716707267073670746707567076670776707867079670806708167082670836708467085670866708767088670896709067091670926709367094670956709667097670986709967100671016710267103671046710567106671076710867109671106711167112671136711467115671166711767118671196712067121671226712367124671256712667127671286712967130671316713267133671346713567136671376713867139671406714167142671436714467145671466714767148671496715067151671526715367154671556715667157671586715967160671616716267163671646716567166671676716867169671706717167172671736717467175671766717767178671796718067181671826718367184671856718667187671886718967190671916719267193671946719567196671976719867199672006720167202672036720467205672066720767208672096721067211672126721367214672156721667217672186721967220672216722267223672246722567226672276722867229672306723167232672336723467235672366723767238672396724067241672426724367244672456724667247672486724967250672516725267253672546725567256672576725867259672606726167262672636726467265672666726767268672696727067271672726727367274672756727667277672786727967280672816728267283672846728567286672876728867289672906729167292672936729467295672966729767298672996730067301673026730367304673056730667307673086730967310673116731267313673146731567316673176731867319673206732167322673236732467325673266732767328673296733067331673326733367334673356733667337673386733967340673416734267343673446734567346673476734867349673506735167352673536735467355673566735767358673596736067361673626736367364673656736667367673686736967370673716737267373673746737567376673776737867379673806738167382673836738467385673866738767388673896739067391673926739367394673956739667397673986739967400674016740267403674046740567406674076740867409674106741167412674136741467415674166741767418674196742067421674226742367424674256742667427674286742967430674316743267433674346743567436674376743867439674406744167442674436744467445674466744767448674496745067451674526745367454674556745667457674586745967460674616746267463674646746567466674676746867469674706747167472674736747467475674766747767478674796748067481674826748367484674856748667487674886748967490674916749267493674946749567496674976749867499675006750167502675036750467505675066750767508675096751067511675126751367514675156751667517675186751967520675216752267523675246752567526675276752867529675306753167532675336753467535675366753767538675396754067541675426754367544675456754667547675486754967550675516755267553675546755567556675576755867559675606756167562675636756467565675666756767568675696757067571675726757367574675756757667577675786757967580675816758267583675846758567586675876758867589675906759167592675936759467595675966759767598675996760067601676026760367604676056760667607676086760967610676116761267613676146761567616676176761867619676206762167622676236762467625676266762767628676296763067631676326763367634676356763667637676386763967640676416764267643676446764567646676476764867649676506765167652676536765467655676566765767658676596766067661676626766367664676656766667667676686766967670676716767267673676746767567676676776767867679676806768167682676836768467685676866768767688676896769067691676926769367694676956769667697676986769967700677016770267703677046770567706677076770867709677106771167712677136771467715677166771767718677196772067721677226772367724677256772667727677286772967730677316773267733677346773567736677376773867739677406774167742677436774467745677466774767748677496775067751677526775367754677556775667757677586775967760677616776267763677646776567766677676776867769677706777167772677736777467775677766777767778677796778067781677826778367784677856778667787677886778967790677916779267793677946779567796677976779867799678006780167802678036780467805678066780767808678096781067811678126781367814678156781667817678186781967820678216782267823678246782567826 |
- #!/usr/bin/env node
- (function(define, require){
- define('__wrap__', function (requirejs) {
- var module = void 0; // Bad UMDs workaround
- requirejs.resolve = require.resolve;
- require = requirejs;
- // This file is used to make additional changes
- // when building an app to run in node.js.
- // Free to edit. You can break tests (cli test runner uses
- // this to build itself - it is a node executable).
- define("amber/Platform", ["amber_core/Platform-Node"], {});
- define("amber/compatibility", ["amber/node-compatibility"], {});
- define("jquery", {});
- define("config-node", function(){});
- define('amber/brikz',[], function () {
- return function Brikz(api, apiKey, initKey) {
- "use strict";
- //jshint eqnull:true
- var brikz = this,
- backup = {};
- apiKey = apiKey || 'exports';
- initKey = initKey || '__init__';
- function mixin(src, target, what) {
- for (var keys = Object.keys(what || src), l = keys.length, i = 0; i < l; ++i) {
- if (src == null) {
- target[keys[i]] = undefined;
- } else {
- var value = src[keys[i]];
- if (typeof value !== "undefined") {
- target[keys[i]] = value;
- }
- }
- }
- return target;
- }
- Object.defineProperties(this, {
- rebuild: { value: null, enumerable: false, configurable: true, writable: true }
- });
- var exclude = mixin(this, {});
- this.rebuild = function () {
- Object.keys(backup).forEach(function (key) {
- mixin(null, api, (backup[key] || 0)[apiKey] || {});
- });
- var oapi = mixin(api, {}),
- order = [],
- chk = {};
- function ensure(key) {
- if (key in exclude) {
- return null;
- }
- var b = brikz[key],
- bak = backup[key];
- mixin(null, api, api);
- while (typeof b === "function") {
- (b.deps || []).forEach(ensure);
- b = new b(brikz, api, bak);
- }
- brikz[key] = b;
- if (b && !chk[key]) {
- chk[key] = true;
- order.push(b);
- }
- if (b && !b[apiKey]) {
- b[apiKey] = mixin(api, {});
- }
- }
- Object.keys(brikz).forEach(ensure);
- mixin(oapi, mixin(null, api, api));
- order.forEach(function (brik) {
- mixin(brik[apiKey] || {}, api);
- });
- order.forEach(function (brik) {
- if (brik[initKey]) {
- brik[initKey]();
- if (brik[initKey].once) {
- delete brik[initKey];
- }
- }
- });
- backup = mixin(brikz, {});
- };
- };
- });
- /*!
- * @overview es6-promise - a tiny implementation of Promises/A+.
- * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors (Conversion to ES6 API by Jake Archibald)
- * @license Licensed under MIT license
- * See https://raw.githubusercontent.com/stefanpenner/es6-promise/master/LICENSE
- * @version 3.3.1
- */
- (function (global, factory) {
- typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
- typeof define === 'function' && define.amd ? define('amber/es6-promise',factory) :
- (global.ES6Promise = factory());
- }(this, (function () { 'use strict';
- function objectOrFunction(x) {
- return typeof x === 'function' || typeof x === 'object' && x !== null;
- }
- function isFunction(x) {
- return typeof x === 'function';
- }
- var _isArray = undefined;
- if (!Array.isArray) {
- _isArray = function (x) {
- return Object.prototype.toString.call(x) === '[object Array]';
- };
- } else {
- _isArray = Array.isArray;
- }
- var isArray = _isArray;
- var len = 0;
- var vertxNext = undefined;
- var customSchedulerFn = undefined;
- var asap = function asap(callback, arg) {
- queue[len] = callback;
- queue[len + 1] = arg;
- len += 2;
- if (len === 2) {
- // If len is 2, that means that we need to schedule an async flush.
- // If additional callbacks are queued before the queue is flushed, they
- // will be processed by this flush that we are scheduling.
- if (customSchedulerFn) {
- customSchedulerFn(flush);
- } else {
- scheduleFlush();
- }
- }
- };
- function setScheduler(scheduleFn) {
- customSchedulerFn = scheduleFn;
- }
- function setAsap(asapFn) {
- asap = asapFn;
- }
- var browserWindow = typeof window !== 'undefined' ? window : undefined;
- var browserGlobal = browserWindow || {};
- var BrowserMutationObserver = browserGlobal.MutationObserver || browserGlobal.WebKitMutationObserver;
- var isNode = typeof self === 'undefined' && typeof process !== 'undefined' && ({}).toString.call(process) === '[object process]';
- // test for web worker but not in IE10
- var isWorker = typeof Uint8ClampedArray !== 'undefined' && typeof importScripts !== 'undefined' && typeof MessageChannel !== 'undefined';
- // node
- function useNextTick() {
- // node version 0.10.x displays a deprecation warning when nextTick is used recursively
- // see https://github.com/cujojs/when/issues/410 for details
- return function () {
- return process.nextTick(flush);
- };
- }
- // vertx
- function useVertxTimer() {
- return function () {
- vertxNext(flush);
- };
- }
- function useMutationObserver() {
- var iterations = 0;
- var observer = new BrowserMutationObserver(flush);
- var node = document.createTextNode('');
- observer.observe(node, { characterData: true });
- return function () {
- node.data = iterations = ++iterations % 2;
- };
- }
- // web worker
- function useMessageChannel() {
- var channel = new MessageChannel();
- channel.port1.onmessage = flush;
- return function () {
- return channel.port2.postMessage(0);
- };
- }
- function useSetTimeout() {
- // Store setTimeout reference so es6-promise will be unaffected by
- // other code modifying setTimeout (like sinon.useFakeTimers())
- var globalSetTimeout = setTimeout;
- return function () {
- return globalSetTimeout(flush, 1);
- };
- }
- var queue = new Array(1000);
- function flush() {
- for (var i = 0; i < len; i += 2) {
- var callback = queue[i];
- var arg = queue[i + 1];
- callback(arg);
- queue[i] = undefined;
- queue[i + 1] = undefined;
- }
- len = 0;
- }
- function attemptVertx() {
- try {
- var r = require;
- var vertx = r('vertx');
- vertxNext = vertx.runOnLoop || vertx.runOnContext;
- return useVertxTimer();
- } catch (e) {
- return useSetTimeout();
- }
- }
- var scheduleFlush = undefined;
- // Decide what async method to use to triggering processing of queued callbacks:
- if (isNode) {
- scheduleFlush = useNextTick();
- } else if (BrowserMutationObserver) {
- scheduleFlush = useMutationObserver();
- } else if (isWorker) {
- scheduleFlush = useMessageChannel();
- } else if (browserWindow === undefined && typeof require === 'function') {
- scheduleFlush = attemptVertx();
- } else {
- scheduleFlush = useSetTimeout();
- }
- function then(onFulfillment, onRejection) {
- var _arguments = arguments;
- var parent = this;
- var child = new this.constructor(noop);
- if (child[PROMISE_ID] === undefined) {
- makePromise(child);
- }
- var _state = parent._state;
- if (_state) {
- (function () {
- var callback = _arguments[_state - 1];
- asap(function () {
- return invokeCallback(_state, child, callback, parent._result);
- });
- })();
- } else {
- subscribe(parent, child, onFulfillment, onRejection);
- }
- return child;
- }
- /**
- `Promise.resolve` returns a promise that will become resolved with the
- passed `value`. It is shorthand for the following:
- ```javascript
- let promise = new Promise(function(resolve, reject){
- resolve(1);
- });
- promise.then(function(value){
- // value === 1
- });
- ```
- Instead of writing the above, your code now simply becomes the following:
- ```javascript
- let promise = Promise.resolve(1);
- promise.then(function(value){
- // value === 1
- });
- ```
- @method resolve
- @static
- @param {Any} value value that the returned promise will be resolved with
- Useful for tooling.
- @return {Promise} a promise that will become fulfilled with the given
- `value`
- */
- function resolve(object) {
- /*jshint validthis:true */
- var Constructor = this;
- if (object && typeof object === 'object' && object.constructor === Constructor) {
- return object;
- }
- var promise = new Constructor(noop);
- _resolve(promise, object);
- return promise;
- }
- var PROMISE_ID = Math.random().toString(36).substring(16);
- function noop() {}
- var PENDING = void 0;
- var FULFILLED = 1;
- var REJECTED = 2;
- var GET_THEN_ERROR = new ErrorObject();
- function selfFulfillment() {
- return new TypeError("You cannot resolve a promise with itself");
- }
- function cannotReturnOwn() {
- return new TypeError('A promises callback cannot return that same promise.');
- }
- function getThen(promise) {
- try {
- return promise.then;
- } catch (error) {
- GET_THEN_ERROR.error = error;
- return GET_THEN_ERROR;
- }
- }
- function tryThen(then, value, fulfillmentHandler, rejectionHandler) {
- try {
- then.call(value, fulfillmentHandler, rejectionHandler);
- } catch (e) {
- return e;
- }
- }
- function handleForeignThenable(promise, thenable, then) {
- asap(function (promise) {
- var sealed = false;
- var error = tryThen(then, thenable, function (value) {
- if (sealed) {
- return;
- }
- sealed = true;
- if (thenable !== value) {
- _resolve(promise, value);
- } else {
- fulfill(promise, value);
- }
- }, function (reason) {
- if (sealed) {
- return;
- }
- sealed = true;
- _reject(promise, reason);
- }, 'Settle: ' + (promise._label || ' unknown promise'));
- if (!sealed && error) {
- sealed = true;
- _reject(promise, error);
- }
- }, promise);
- }
- function handleOwnThenable(promise, thenable) {
- if (thenable._state === FULFILLED) {
- fulfill(promise, thenable._result);
- } else if (thenable._state === REJECTED) {
- _reject(promise, thenable._result);
- } else {
- subscribe(thenable, undefined, function (value) {
- return _resolve(promise, value);
- }, function (reason) {
- return _reject(promise, reason);
- });
- }
- }
- function handleMaybeThenable(promise, maybeThenable, then$$) {
- if (maybeThenable.constructor === promise.constructor && then$$ === then && maybeThenable.constructor.resolve === resolve) {
- handleOwnThenable(promise, maybeThenable);
- } else {
- if (then$$ === GET_THEN_ERROR) {
- _reject(promise, GET_THEN_ERROR.error);
- } else if (then$$ === undefined) {
- fulfill(promise, maybeThenable);
- } else if (isFunction(then$$)) {
- handleForeignThenable(promise, maybeThenable, then$$);
- } else {
- fulfill(promise, maybeThenable);
- }
- }
- }
- function _resolve(promise, value) {
- if (promise === value) {
- _reject(promise, selfFulfillment());
- } else if (objectOrFunction(value)) {
- handleMaybeThenable(promise, value, getThen(value));
- } else {
- fulfill(promise, value);
- }
- }
- function publishRejection(promise) {
- if (promise._onerror) {
- promise._onerror(promise._result);
- }
- publish(promise);
- }
- function fulfill(promise, value) {
- if (promise._state !== PENDING) {
- return;
- }
- promise._result = value;
- promise._state = FULFILLED;
- if (promise._subscribers.length !== 0) {
- asap(publish, promise);
- }
- }
- function _reject(promise, reason) {
- if (promise._state !== PENDING) {
- return;
- }
- promise._state = REJECTED;
- promise._result = reason;
- asap(publishRejection, promise);
- }
- function subscribe(parent, child, onFulfillment, onRejection) {
- var _subscribers = parent._subscribers;
- var length = _subscribers.length;
- parent._onerror = null;
- _subscribers[length] = child;
- _subscribers[length + FULFILLED] = onFulfillment;
- _subscribers[length + REJECTED] = onRejection;
- if (length === 0 && parent._state) {
- asap(publish, parent);
- }
- }
- function publish(promise) {
- var subscribers = promise._subscribers;
- var settled = promise._state;
- if (subscribers.length === 0) {
- return;
- }
- var child = undefined,
- callback = undefined,
- detail = promise._result;
- for (var i = 0; i < subscribers.length; i += 3) {
- child = subscribers[i];
- callback = subscribers[i + settled];
- if (child) {
- invokeCallback(settled, child, callback, detail);
- } else {
- callback(detail);
- }
- }
- promise._subscribers.length = 0;
- }
- function ErrorObject() {
- this.error = null;
- }
- var TRY_CATCH_ERROR = new ErrorObject();
- function tryCatch(callback, detail) {
- try {
- return callback(detail);
- } catch (e) {
- TRY_CATCH_ERROR.error = e;
- return TRY_CATCH_ERROR;
- }
- }
- function invokeCallback(settled, promise, callback, detail) {
- var hasCallback = isFunction(callback),
- value = undefined,
- error = undefined,
- succeeded = undefined,
- failed = undefined;
- if (hasCallback) {
- value = tryCatch(callback, detail);
- if (value === TRY_CATCH_ERROR) {
- failed = true;
- error = value.error;
- value = null;
- } else {
- succeeded = true;
- }
- if (promise === value) {
- _reject(promise, cannotReturnOwn());
- return;
- }
- } else {
- value = detail;
- succeeded = true;
- }
- if (promise._state !== PENDING) {
- // noop
- } else if (hasCallback && succeeded) {
- _resolve(promise, value);
- } else if (failed) {
- _reject(promise, error);
- } else if (settled === FULFILLED) {
- fulfill(promise, value);
- } else if (settled === REJECTED) {
- _reject(promise, value);
- }
- }
- function initializePromise(promise, resolver) {
- try {
- resolver(function resolvePromise(value) {
- _resolve(promise, value);
- }, function rejectPromise(reason) {
- _reject(promise, reason);
- });
- } catch (e) {
- _reject(promise, e);
- }
- }
- var id = 0;
- function nextId() {
- return id++;
- }
- function makePromise(promise) {
- promise[PROMISE_ID] = id++;
- promise._state = undefined;
- promise._result = undefined;
- promise._subscribers = [];
- }
- function Enumerator(Constructor, input) {
- this._instanceConstructor = Constructor;
- this.promise = new Constructor(noop);
- if (!this.promise[PROMISE_ID]) {
- makePromise(this.promise);
- }
- if (isArray(input)) {
- this._input = input;
- this.length = input.length;
- this._remaining = input.length;
- this._result = new Array(this.length);
- if (this.length === 0) {
- fulfill(this.promise, this._result);
- } else {
- this.length = this.length || 0;
- this._enumerate();
- if (this._remaining === 0) {
- fulfill(this.promise, this._result);
- }
- }
- } else {
- _reject(this.promise, validationError());
- }
- }
- function validationError() {
- return new Error('Array Methods must be provided an Array');
- };
- Enumerator.prototype._enumerate = function () {
- var length = this.length;
- var _input = this._input;
- for (var i = 0; this._state === PENDING && i < length; i++) {
- this._eachEntry(_input[i], i);
- }
- };
- Enumerator.prototype._eachEntry = function (entry, i) {
- var c = this._instanceConstructor;
- var resolve$$ = c.resolve;
- if (resolve$$ === resolve) {
- var _then = getThen(entry);
- if (_then === then && entry._state !== PENDING) {
- this._settledAt(entry._state, i, entry._result);
- } else if (typeof _then !== 'function') {
- this._remaining--;
- this._result[i] = entry;
- } else if (c === Promise) {
- var promise = new c(noop);
- handleMaybeThenable(promise, entry, _then);
- this._willSettleAt(promise, i);
- } else {
- this._willSettleAt(new c(function (resolve$$) {
- return resolve$$(entry);
- }), i);
- }
- } else {
- this._willSettleAt(resolve$$(entry), i);
- }
- };
- Enumerator.prototype._settledAt = function (state, i, value) {
- var promise = this.promise;
- if (promise._state === PENDING) {
- this._remaining--;
- if (state === REJECTED) {
- _reject(promise, value);
- } else {
- this._result[i] = value;
- }
- }
- if (this._remaining === 0) {
- fulfill(promise, this._result);
- }
- };
- Enumerator.prototype._willSettleAt = function (promise, i) {
- var enumerator = this;
- subscribe(promise, undefined, function (value) {
- return enumerator._settledAt(FULFILLED, i, value);
- }, function (reason) {
- return enumerator._settledAt(REJECTED, i, reason);
- });
- };
- /**
- `Promise.all` accepts an array of promises, and returns a new promise which
- is fulfilled with an array of fulfillment values for the passed promises, or
- rejected with the reason of the first passed promise to be rejected. It casts all
- elements of the passed iterable to promises as it runs this algorithm.
- Example:
- ```javascript
- let promise1 = resolve(1);
- let promise2 = resolve(2);
- let promise3 = resolve(3);
- let promises = [ promise1, promise2, promise3 ];
- Promise.all(promises).then(function(array){
- // The array here would be [ 1, 2, 3 ];
- });
- ```
- If any of the `promises` given to `all` are rejected, the first promise
- that is rejected will be given as an argument to the returned promises's
- rejection handler. For example:
- Example:
- ```javascript
- let promise1 = resolve(1);
- let promise2 = reject(new Error("2"));
- let promise3 = reject(new Error("3"));
- let promises = [ promise1, promise2, promise3 ];
- Promise.all(promises).then(function(array){
- // Code here never runs because there are rejected promises!
- }, function(error) {
- // error.message === "2"
- });
- ```
- @method all
- @static
- @param {Array} entries array of promises
- @param {String} label optional string for labeling the promise.
- Useful for tooling.
- @return {Promise} promise that is fulfilled when all `promises` have been
- fulfilled, or rejected if any of them become rejected.
- @static
- */
- function all(entries) {
- return new Enumerator(this, entries).promise;
- }
- /**
- `Promise.race` returns a new promise which is settled in the same way as the
- first passed promise to settle.
- Example:
- ```javascript
- let promise1 = new Promise(function(resolve, reject){
- setTimeout(function(){
- resolve('promise 1');
- }, 200);
- });
- let promise2 = new Promise(function(resolve, reject){
- setTimeout(function(){
- resolve('promise 2');
- }, 100);
- });
- Promise.race([promise1, promise2]).then(function(result){
- // result === 'promise 2' because it was resolved before promise1
- // was resolved.
- });
- ```
- `Promise.race` is deterministic in that only the state of the first
- settled promise matters. For example, even if other promises given to the
- `promises` array argument are resolved, but the first settled promise has
- become rejected before the other promises became fulfilled, the returned
- promise will become rejected:
- ```javascript
- let promise1 = new Promise(function(resolve, reject){
- setTimeout(function(){
- resolve('promise 1');
- }, 200);
- });
- let promise2 = new Promise(function(resolve, reject){
- setTimeout(function(){
- reject(new Error('promise 2'));
- }, 100);
- });
- Promise.race([promise1, promise2]).then(function(result){
- // Code here never runs
- }, function(reason){
- // reason.message === 'promise 2' because promise 2 became rejected before
- // promise 1 became fulfilled
- });
- ```
- An example real-world use case is implementing timeouts:
- ```javascript
- Promise.race([ajax('foo.json'), timeout(5000)])
- ```
- @method race
- @static
- @param {Array} promises array of promises to observe
- Useful for tooling.
- @return {Promise} a promise which settles in the same way as the first passed
- promise to settle.
- */
- function race(entries) {
- /*jshint validthis:true */
- var Constructor = this;
- if (!isArray(entries)) {
- return new Constructor(function (_, reject) {
- return reject(new TypeError('You must pass an array to race.'));
- });
- } else {
- return new Constructor(function (resolve, reject) {
- var length = entries.length;
- for (var i = 0; i < length; i++) {
- Constructor.resolve(entries[i]).then(resolve, reject);
- }
- });
- }
- }
- /**
- `Promise.reject` returns a promise rejected with the passed `reason`.
- It is shorthand for the following:
- ```javascript
- let promise = new Promise(function(resolve, reject){
- reject(new Error('WHOOPS'));
- });
- promise.then(function(value){
- // Code here doesn't run because the promise is rejected!
- }, function(reason){
- // reason.message === 'WHOOPS'
- });
- ```
- Instead of writing the above, your code now simply becomes the following:
- ```javascript
- let promise = Promise.reject(new Error('WHOOPS'));
- promise.then(function(value){
- // Code here doesn't run because the promise is rejected!
- }, function(reason){
- // reason.message === 'WHOOPS'
- });
- ```
- @method reject
- @static
- @param {Any} reason value that the returned promise will be rejected with.
- Useful for tooling.
- @return {Promise} a promise rejected with the given `reason`.
- */
- function reject(reason) {
- /*jshint validthis:true */
- var Constructor = this;
- var promise = new Constructor(noop);
- _reject(promise, reason);
- return promise;
- }
- function needsResolver() {
- throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');
- }
- function needsNew() {
- throw new TypeError("Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.");
- }
- /**
- Promise objects represent the eventual result of an asynchronous operation. The
- primary way of interacting with a promise is through its `then` method, which
- registers callbacks to receive either a promise's eventual value or the reason
- why the promise cannot be fulfilled.
- Terminology
- -----------
- - `promise` is an object or function with a `then` method whose behavior conforms to this specification.
- - `thenable` is an object or function that defines a `then` method.
- - `value` is any legal JavaScript value (including undefined, a thenable, or a promise).
- - `exception` is a value that is thrown using the throw statement.
- - `reason` is a value that indicates why a promise was rejected.
- - `settled` the final resting state of a promise, fulfilled or rejected.
- A promise can be in one of three states: pending, fulfilled, or rejected.
- Promises that are fulfilled have a fulfillment value and are in the fulfilled
- state. Promises that are rejected have a rejection reason and are in the
- rejected state. A fulfillment value is never a thenable.
- Promises can also be said to *resolve* a value. If this value is also a
- promise, then the original promise's settled state will match the value's
- settled state. So a promise that *resolves* a promise that rejects will
- itself reject, and a promise that *resolves* a promise that fulfills will
- itself fulfill.
- Basic Usage:
- ------------
- ```js
- let promise = new Promise(function(resolve, reject) {
- // on success
- resolve(value);
- // on failure
- reject(reason);
- });
- promise.then(function(value) {
- // on fulfillment
- }, function(reason) {
- // on rejection
- });
- ```
- Advanced Usage:
- ---------------
- Promises shine when abstracting away asynchronous interactions such as
- `XMLHttpRequest`s.
- ```js
- function getJSON(url) {
- return new Promise(function(resolve, reject){
- let xhr = new XMLHttpRequest();
- xhr.open('GET', url);
- xhr.onreadystatechange = handler;
- xhr.responseType = 'json';
- xhr.setRequestHeader('Accept', 'application/json');
- xhr.send();
- function handler() {
- if (this.readyState === this.DONE) {
- if (this.status === 200) {
- resolve(this.response);
- } else {
- reject(new Error('getJSON: `' + url + '` failed with status: [' + this.status + ']'));
- }
- }
- };
- });
- }
- getJSON('/posts.json').then(function(json) {
- // on fulfillment
- }, function(reason) {
- // on rejection
- });
- ```
- Unlike callbacks, promises are great composable primitives.
- ```js
- Promise.all([
- getJSON('/posts'),
- getJSON('/comments')
- ]).then(function(values){
- values[0] // => postsJSON
- values[1] // => commentsJSON
- return values;
- });
- ```
- @class Promise
- @param {function} resolver
- Useful for tooling.
- @constructor
- */
- function Promise(resolver) {
- this[PROMISE_ID] = nextId();
- this._result = this._state = undefined;
- this._subscribers = [];
- if (noop !== resolver) {
- typeof resolver !== 'function' && needsResolver();
- this instanceof Promise ? initializePromise(this, resolver) : needsNew();
- }
- }
- Promise.all = all;
- Promise.race = race;
- Promise.resolve = resolve;
- Promise.reject = reject;
- Promise._setScheduler = setScheduler;
- Promise._setAsap = setAsap;
- Promise._asap = asap;
- Promise.prototype = {
- constructor: Promise,
- /**
- The primary way of interacting with a promise is through its `then` method,
- which registers callbacks to receive either a promise's eventual value or the
- reason why the promise cannot be fulfilled.
-
- ```js
- findUser().then(function(user){
- // user is available
- }, function(reason){
- // user is unavailable, and you are given the reason why
- });
- ```
-
- Chaining
- --------
-
- The return value of `then` is itself a promise. This second, 'downstream'
- promise is resolved with the return value of the first promise's fulfillment
- or rejection handler, or rejected if the handler throws an exception.
-
- ```js
- findUser().then(function (user) {
- return user.name;
- }, function (reason) {
- return 'default name';
- }).then(function (userName) {
- // If `findUser` fulfilled, `userName` will be the user's name, otherwise it
- // will be `'default name'`
- });
-
- findUser().then(function (user) {
- throw new Error('Found user, but still unhappy');
- }, function (reason) {
- throw new Error('`findUser` rejected and we're unhappy');
- }).then(function (value) {
- // never reached
- }, function (reason) {
- // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.
- // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.
- });
- ```
- If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.
-
- ```js
- findUser().then(function (user) {
- throw new PedagogicalException('Upstream error');
- }).then(function (value) {
- // never reached
- }).then(function (value) {
- // never reached
- }, function (reason) {
- // The `PedgagocialException` is propagated all the way down to here
- });
- ```
-
- Assimilation
- ------------
-
- Sometimes the value you want to propagate to a downstream promise can only be
- retrieved asynchronously. This can be achieved by returning a promise in the
- fulfillment or rejection handler. The downstream promise will then be pending
- until the returned promise is settled. This is called *assimilation*.
-
- ```js
- findUser().then(function (user) {
- return findCommentsByAuthor(user);
- }).then(function (comments) {
- // The user's comments are now available
- });
- ```
-
- If the assimliated promise rejects, then the downstream promise will also reject.
-
- ```js
- findUser().then(function (user) {
- return findCommentsByAuthor(user);
- }).then(function (comments) {
- // If `findCommentsByAuthor` fulfills, we'll have the value here
- }, function (reason) {
- // If `findCommentsByAuthor` rejects, we'll have the reason here
- });
- ```
-
- Simple Example
- --------------
-
- Synchronous Example
-
- ```javascript
- let result;
-
- try {
- result = findResult();
- // success
- } catch(reason) {
- // failure
- }
- ```
-
- Errback Example
-
- ```js
- findResult(function(result, err){
- if (err) {
- // failure
- } else {
- // success
- }
- });
- ```
-
- Promise Example;
-
- ```javascript
- findResult().then(function(result){
- // success
- }, function(reason){
- // failure
- });
- ```
-
- Advanced Example
- --------------
-
- Synchronous Example
-
- ```javascript
- let author, books;
-
- try {
- author = findAuthor();
- books = findBooksByAuthor(author);
- // success
- } catch(reason) {
- // failure
- }
- ```
-
- Errback Example
-
- ```js
-
- function foundBooks(books) {
-
- }
-
- function failure(reason) {
-
- }
-
- findAuthor(function(author, err){
- if (err) {
- failure(err);
- // failure
- } else {
- try {
- findBoooksByAuthor(author, function(books, err) {
- if (err) {
- failure(err);
- } else {
- try {
- foundBooks(books);
- } catch(reason) {
- failure(reason);
- }
- }
- });
- } catch(error) {
- failure(err);
- }
- // success
- }
- });
- ```
-
- Promise Example;
-
- ```javascript
- findAuthor().
- then(findBooksByAuthor).
- then(function(books){
- // found books
- }).catch(function(reason){
- // something went wrong
- });
- ```
-
- @method then
- @param {Function} onFulfilled
- @param {Function} onRejected
- Useful for tooling.
- @return {Promise}
- */
- then: then,
- /**
- `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same
- as the catch block of a try/catch statement.
-
- ```js
- function findAuthor(){
- throw new Error('couldn't find that author');
- }
-
- // synchronous
- try {
- findAuthor();
- } catch(reason) {
- // something went wrong
- }
-
- // async with promises
- findAuthor().catch(function(reason){
- // something went wrong
- });
- ```
-
- @method catch
- @param {Function} onRejection
- Useful for tooling.
- @return {Promise}
- */
- 'catch': function _catch(onRejection) {
- return this.then(null, onRejection);
- }
- };
- function polyfill() {
- var local = undefined;
- if (typeof global !== 'undefined') {
- local = global;
- } else if (typeof self !== 'undefined') {
- local = self;
- } else {
- try {
- local = Function('return this')();
- } catch (e) {
- throw new Error('polyfill failed because global object is unavailable in this environment');
- }
- }
- var P = local.Promise;
- if (P) {
- var promiseToString = null;
- try {
- promiseToString = Object.prototype.toString.call(P.resolve());
- } catch (e) {
- // silently ignored
- }
- if (promiseToString === '[object Promise]' && !P.cast) {
- return;
- }
- }
- local.Promise = Promise;
- }
- polyfill();
- // Strange compat..
- Promise.polyfill = polyfill;
- Promise.Promise = Promise;
- return Promise;
- })));
- //# sourceMappingURL=es6-promise.map;
- define('amber/es2015-polyfills',['amber/es6-promise'], function (promiseLib) {
- promiseLib.polyfill();
- });
- // This file is injected dependencies by amber-compat-xxx modules.
- // Therefore it is important that it _does_not_have_ define call.
- ;
- define("amber/node-compatibility", ["./es2015-polyfills"], function(){});
- /* ====================================================================
- |
- | Amber Smalltalk
- | http://amber-lang.net
- |
- ======================================================================
- ======================================================================
- |
- | Copyright (c) 2010-2014
- | Nicolas Petton <petton.nicolas@gmail.com>
- |
- | Copyright (c) 2012-2016
- | The Amber team https://lolg.it/org/amber/members
- | Amber contributors (see /CONTRIBUTORS)
- |
- | Amber is released under the MIT license
- |
- | Permission is hereby granted, free of charge, to any person obtaining
- | a copy of this software and associated documentation files (the
- | 'Software'), to deal in the Software without restriction, including
- | without limitation the rights to use, copy, modify, merge, publish,
- | distribute, sublicense, and/or sell copies of the Software, and to
- | permit persons to whom the Software is furnished to do so, subject to
- | the following conditions:
- |
- | The above copyright notice and this permission notice shall be
- | included in all copies or substantial portions of the Software.
- |
- | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
- | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
- | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
- | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- |
- ==================================================================== */
- //jshint eqnull:true
- define('amber/kernel-fundamentals',['./compatibility'], function () {
- "use strict";
- function inherits (child, parent) {
- child.prototype = Object.create(parent.prototype, {
- constructor: {
- value: child,
- enumerable: false, configurable: true, writable: true
- }
- });
- return child;
- }
- function SmalltalkGlobalsBrik (brikz, st) {
- // jshint evil:true
- var jsGlobals = new Function("return this")();
- var globals = Object.create(jsGlobals);
- globals.SmalltalkSettings = {};
- this.globals = globals;
- }
- function RootBrik (brikz, st) {
- /* Smalltalk foundational objects */
- var coreFns = this.coreFns = {};
- /* SmalltalkRoot is the hidden root of the normal Amber hierarchy.
- All objects including `ProtoObject` inherit from SmalltalkRoot.
- Detached roots (eg. wrapped JS classes like Number or Date)
- do not directly inherit from SmalltalkRoot, but employ a workaround.*/
- function SmalltalkRoot () {
- }
- function SmalltalkProtoObject () {
- }
- function SmalltalkObject () {
- }
- coreFns.ProtoObject = inherits(SmalltalkProtoObject, SmalltalkRoot);
- coreFns.Object = inherits(SmalltalkObject, SmalltalkProtoObject);
- this.Root = SmalltalkRoot;
- this.Object = SmalltalkObject;
- }
- OrganizeBrik.deps = ["arraySet", "root"];
- function OrganizeBrik (brikz, st) {
- var SmalltalkObject = brikz.root.Object;
- var coreFns = brikz.root.coreFns;
- var addElement = brikz.arraySet.addElement;
- var removeElement = brikz.arraySet.removeElement;
- function SmalltalkOrganizer () {
- }
- function SmalltalkPackageOrganizer () {
- this.elements = [];
- }
- function SmalltalkClassOrganizer () {
- this.elements = [];
- }
- coreFns.Organizer = inherits(SmalltalkOrganizer, SmalltalkObject);
- coreFns.PackageOrganizer = inherits(SmalltalkPackageOrganizer, SmalltalkOrganizer);
- coreFns.ClassOrganizer = inherits(SmalltalkClassOrganizer, SmalltalkOrganizer);
- this.setupClassOrganization = function (behaviorBody) {
- behaviorBody.organization = new SmalltalkClassOrganizer();
- behaviorBody.organization.theClass = behaviorBody;
- };
- this.setupPackageOrganization = function (pkg) {
- pkg.organization = new SmalltalkPackageOrganizer();
- };
- this.addOrganizationElement = function (owner, element) {
- addElement(owner.organization.elements, element);
- };
- this.removeOrganizationElement = function (owner, element) {
- removeElement(owner.organization.elements, element);
- };
- }
- SelectorsBrik.deps = ["selectorConversion"];
- function SelectorsBrik (brikz, st) {
- var selectorSet = Object.create(null);
- var selectors = this.selectors = [];
- var selectorPairs = this.selectorPairs = [];
- this.registerSelector = function (stSelector) {
- if (selectorSet[stSelector]) return null;
- var jsSelector = st.st2js(stSelector);
- selectorSet[stSelector] = true;
- selectors.push(stSelector);
- var pair = {st: stSelector, js: jsSelector};
- selectorPairs.push(pair);
- return pair;
- };
- st.allSelectors = function () {
- return selectors;
- };
- }
- PackagesBrik.deps = ["organize", "root"];
- function PackagesBrik (brikz, st) {
- var setupPackageOrganization = brikz.organize.setupPackageOrganization;
- var SmalltalkObject = brikz.root.Object;
- var coreFns = brikz.root.coreFns;
- function SmalltalkPackage () {
- }
- coreFns.Package = inherits(SmalltalkPackage, SmalltalkObject);
- st.packages = {};
- /* Smalltalk package creation. To add a Package, use smalltalk.addPackage() */
- function pkg (spec) {
- var that = new SmalltalkPackage();
- that.pkgName = spec.pkgName;
- setupPackageOrganization(that);
- that.properties = spec.properties || {};
- return that;
- }
- /* Add a package to the system, creating a new one if needed.
- If pkgName is null or empty we return nil.
- If package already exists we still update the properties of it. */
- st.addPackage = function (pkgName, properties) {
- if (!pkgName) return null;
- if (!st.packages[pkgName]) {
- st.packages[pkgName] = pkg({
- pkgName: pkgName,
- properties: properties
- });
- } else {
- if (properties) {
- st.packages[pkgName].properties = properties;
- }
- }
- return st.packages[pkgName];
- };
- }
- BehaviorsBrik.deps = ["organize", "root", "smalltalkGlobals", "arraySet"];
- function BehaviorsBrik (brikz, st) {
- var addOrganizationElement = brikz.organize.addOrganizationElement;
- var removeOrganizationElement = brikz.organize.removeOrganizationElement;
- var globals = brikz.smalltalkGlobals.globals;
- var SmalltalkObject = brikz.root.Object;
- var coreFns = brikz.root.coreFns;
- var addElement = brikz.arraySet.addElement;
- var removeElement = brikz.arraySet.removeElement;
- function SmalltalkBehaviorBody () {
- }
- coreFns.BehaviorBody = inherits(SmalltalkBehaviorBody, SmalltalkObject);
- this.BehaviorBody = SmalltalkBehaviorBody;
- /* Smalltalk classes */
- var classes = [];
- this.buildBehaviorBody = function (pkgName, builder) {
- var pkg = st.packages[pkgName];
- if (!pkg) throw new Error("Missing package " + pkgName);
- var behaviorBody = globals.hasOwnProperty(builder.className) && globals[builder.className];
- if (behaviorBody) {
- builder.updateExisting(behaviorBody, pkg);
- } else {
- behaviorBody = builder.make(pkg);
- }
- addBehaviorBody(behaviorBody);
- return behaviorBody;
- };
- function addBehaviorBody (behaviorBody) {
- globals[behaviorBody.className] = behaviorBody;
- addElement(classes, behaviorBody);
- addOrganizationElement(behaviorBody.pkg, behaviorBody);
- behaviorBody.added();
- }
- function removeBehaviorBody (behaviorBody) {
- behaviorBody.removed();
- removeOrganizationElement(behaviorBody.pkg, behaviorBody);
- removeElement(classes, behaviorBody);
- delete globals[behaviorBody.className];
- }
- this.removeBehaviorBody = removeBehaviorBody;
- /* Create an alias for an existing class */
- st.alias = function (behaviorBody, alias) {
- globals[alias] = behaviorBody;
- };
- /* Answer all registered Smalltalk classes */
- //TODO: remove the function and make smalltalk.classes an array
- st.classes = this.classes = function () {
- return classes;
- };
- }
- MethodsBrik.deps = ["composition", "selectors", "root", "selectorConversion"];
- function MethodsBrik (brikz, st) {
- var registerSelector = brikz.selectors.registerSelector;
- var updateMethod = brikz.composition.updateMethod;
- var SmalltalkObject = brikz.root.Object;
- var coreFns = brikz.root.coreFns;
- function SmalltalkMethod () {
- }
- coreFns.CompiledMethod = inherits(SmalltalkMethod, SmalltalkObject);
- /* Smalltalk method object. To add a method to a class,
- use api.addMethod() */
- st.method = function (spec) {
- var that = new SmalltalkMethod();
- var selector = spec.selector;
- that.selector = selector;
- that.jsSelector = st.st2js(selector);
- that.args = spec.args || {};
- that.protocol = spec.protocol;
- that.source = spec.source;
- that.messageSends = spec.messageSends || [];
- that.referencedClasses = spec.referencedClasses || [];
- that.fn = spec.fn;
- return that;
- };
- /* Add/remove a method to/from a class */
- st.addMethod = function (method, behaviorBody) {
- if (method.methodClass != null) {
- throw new Error("addMethod: Method " + method.selector + " already bound to " + method.methodClass);
- }
- method.methodClass = behaviorBody;
- registerNewSelectors(method);
- behaviorBody.localMethods[method.selector] = method;
- updateMethod(method.selector, behaviorBody);
- };
- function registerNewSelectors (method) {
- var newSelectors = [];
- function selectorInUse (stSelector) {
- var pair = registerSelector(stSelector);
- if (pair) {
- newSelectors.push(pair);
- }
- }
- selectorInUse(method.selector);
- method.messageSends.forEach(selectorInUse);
- if (st._selectorsAdded) st._selectorsAdded(newSelectors);
- }
- st.removeMethod = function (method, behaviorBody) {
- if (behaviorBody.localMethods[method.selector] !== method) return;
- delete behaviorBody.localMethods[method.selector];
- updateMethod(method.selector, behaviorBody);
- };
- }
- MethodCompositionBrik.deps = ["organize"];
- function MethodCompositionBrik (brikz, st) {
- var setupClassOrganization = brikz.organize.setupClassOrganization;
- var addOrganizationElement = brikz.organize.addOrganizationElement;
- this.setupMethods = function (behaviorBody) {
- setupClassOrganization(behaviorBody);
- behaviorBody.traitComposition = [];
- behaviorBody.localMethods = Object.create(null);
- behaviorBody.methods = Object.create(null);
- };
- function addMethod (method, behaviorBody) {
- behaviorBody.methods[method.selector] = method;
- // During the bootstrap, #addCompiledMethod is not used.
- // Therefore we populate the organizer here too
- addOrganizationElement(behaviorBody, method.protocol);
- behaviorBody.methodAdded(method);
- }
- function removeMethod (method, behaviorBody) {
- delete behaviorBody.methods[method.selector];
- behaviorBody.methodRemoved(method);
- // Do *not* delete protocols from here.
- // This is handled by #removeCompiledMethod
- }
- function aliased (selector, method) {
- if (method.selector === selector) return method;
- var result = st.method({
- selector: selector,
- args: method.args,
- protocol: method.protocol,
- source: '"Aliased as ' + selector + '"\n' + method.source,
- messageSends: method.messageSends,
- referencesClasses: method.referencedClasses,
- fn: method.fn
- });
- result.methodClass = method.methodClass;
- return result;
- }
- function deleteKeysFrom (keys, obj) {
- keys.forEach(function (each) {
- delete obj[each];
- });
- }
- function fillTraitTransformation (traitTransformation, obj) {
- // assert(Object.getOwnProperties(obj).length === 0)
- var traitMethods = traitTransformation.trait.methods;
- Object.keys(traitMethods).forEach(function (selector) {
- obj[selector] = traitMethods[selector];
- });
- var traitAliases = traitTransformation.aliases;
- if (traitAliases) {
- Object.keys(traitAliases).forEach(function (aliasSelector) {
- var aliasedMethod = traitMethods[traitAliases[aliasSelector]];
- if (aliasedMethod) obj[aliasSelector] = aliased(aliasSelector, aliasedMethod);
- // else delete obj[aliasSelector]; // semantically correct; optimized away
- });
- }
- var traitExclusions = traitTransformation.exclusions;
- if (traitExclusions) {
- deleteKeysFrom(traitExclusions, obj);
- }
- return obj;
- }
- function buildCompositionChain (traitComposition) {
- return traitComposition.reduce(function (soFar, each) {
- return fillTraitTransformation(each, Object.create(soFar));
- }, null);
- }
- st.setTraitComposition = function (traitComposition, behaviorBody) {
- var oldLocalMethods = behaviorBody.localMethods,
- newLocalMethods = Object.create(buildCompositionChain(traitComposition));
- Object.keys(oldLocalMethods).forEach(function (selector) {
- newLocalMethods[selector] = oldLocalMethods[selector];
- });
- behaviorBody.localMethods = newLocalMethods;
- for (var selector in newLocalMethods) {
- updateMethod(selector, behaviorBody);
- }
- for (var selector in oldLocalMethods) {
- updateMethod(selector, behaviorBody);
- }
- behaviorBody.traitComposition.forEach(function (each) {
- each.trait.removeUser(behaviorBody);
- });
- behaviorBody.traitComposition = traitComposition;
- behaviorBody.traitComposition.forEach(function (each) {
- each.trait.addUser(behaviorBody);
- });
- };
- function updateMethod (selector, behaviorBody) {
- var oldMethod = behaviorBody.methods[selector],
- newMethod = behaviorBody.localMethods[selector];
- if (oldMethod == null && newMethod == null) {
- console.warn("Removal of nonexistent method " + behaviorBody + " >> " + selector);
- return;
- }
- if (newMethod === oldMethod) return;
- if (newMethod != null) addMethod(newMethod, behaviorBody);
- else removeMethod(oldMethod, behaviorBody);
- }
- this.updateMethod = updateMethod;
- function aliasesOfSelector (selector, traitAliases) {
- if (!traitAliases) return [selector];
- var result = Object.keys(traitAliases).filter(function (aliasSelector) {
- return traitAliases[aliasSelector] === selector
- });
- if (!traitAliases[selector]) result.push(selector);
- return result;
- }
- function applyTraitMethodAddition (selector, method, traitTransformation, obj) {
- var changes = aliasesOfSelector(selector, traitTransformation.aliases);
- changes.forEach(function (aliasSelector) {
- obj[aliasSelector] = aliased(aliasSelector, method);
- });
- var traitExclusions = traitTransformation.exclusions;
- if (traitExclusions) {
- deleteKeysFrom(traitExclusions, obj);
- }
- return changes;
- }
- function applyTraitMethodDeletion (selector, traitTransformation, obj) {
- var changes = aliasesOfSelector(selector, traitTransformation.aliases);
- deleteKeysFrom(changes, obj);
- return changes;
- }
- function traitMethodChanged (selector, method, trait, behaviorBody) {
- var traitComposition = behaviorBody.traitComposition,
- chain = behaviorBody.localMethods,
- changes = [];
- for (var i = traitComposition.length - 1; i >= 0; --i) {
- chain = Object.getPrototypeOf(chain);
- var traitTransformation = traitComposition[i];
- if (traitTransformation.trait !== trait) continue;
- changes.push.apply(changes, method ?
- applyTraitMethodAddition(selector, method, traitTransformation, chain) :
- applyTraitMethodDeletion(selector, traitTransformation, chain));
- }
- // assert(chain === null);
- changes.forEach(function (each) {
- updateMethod(each, behaviorBody);
- });
- }
- this.traitMethodChanged = traitMethodChanged;
- }
- function ArraySetBrik (brikz, st) {
- st.addElement = this.addElement = function (array, el) {
- if (typeof el === 'undefined') {
- return;
- }
- if (array.indexOf(el) === -1) {
- array.push(el);
- }
- };
- st.removeElement = this.removeElement = function (array, el) {
- var i = array.indexOf(el);
- if (i !== -1) {
- array.splice(i, 1);
- }
- };
- }
- function SelectorConversionBrik (brikz, st) {
- /* Convert a Smalltalk selector into a JS selector */
- st.st2js = function (string) {
- return '_' + string
- .replace(/:/g, '_')
- .replace(/[\&]/g, '_and')
- .replace(/[\|]/g, '_or')
- .replace(/[+]/g, '_plus')
- .replace(/-/g, '_minus')
- .replace(/[*]/g, '_star')
- .replace(/[\/]/g, '_slash')
- .replace(/[\\]/g, '_backslash')
- .replace(/[\~]/g, '_tild')
- .replace(/%/g, '_percent')
- .replace(/>/g, '_gt')
- .replace(/</g, '_lt')
- .replace(/=/g, '_eq')
- .replace(/,/g, '_comma')
- .replace(/[@]/g, '_at');
- };
- /* Convert a string to a valid smalltalk selector.
- if you modify the following functions, also change st2js
- accordingly */
- st.js2st = function (selector) {
- if (selector.match(/^__/)) {
- return binaryJsToSt(selector);
- } else {
- return keywordJsToSt(selector);
- }
- };
- function keywordJsToSt (selector) {
- return selector.replace(/^_/, '').replace(/_/g, ':');
- }
- function binaryJsToSt (selector) {
- return selector
- .replace(/^_/, '')
- .replace(/_and/g, '&')
- .replace(/_or/g, '|')
- .replace(/_plus/g, '+')
- .replace(/_minus/g, '-')
- .replace(/_star/g, '*')
- .replace(/_slash/g, '/')
- .replace(/_backslash/g, '\\')
- .replace(/_tild/g, '~')
- .replace(/_percent/g, '%')
- .replace(/_gt/g, '>')
- .replace(/_lt/g, '<')
- .replace(/_eq/g, '=')
- .replace(/_comma/g, ',')
- .replace(/_at/g, '@');
- }
- st.st2prop = function (stSelector) {
- var colonPosition = stSelector.indexOf(':');
- return colonPosition === -1 ? stSelector : stSelector.slice(0, colonPosition);
- };
- }
- /* Making smalltalk that has basic building blocks */
- function configureWithFundamentals (brikz) {
- brikz.smalltalkGlobals = SmalltalkGlobalsBrik;
- brikz.root = RootBrik;
- brikz.arraySet = ArraySetBrik;
- brikz.organize = OrganizeBrik;
- brikz.selectorConversion = SelectorConversionBrik;
- brikz.selectors = SelectorsBrik;
- brikz.packages = PackagesBrik;
- brikz.composition = MethodCompositionBrik;
- brikz.behaviors = BehaviorsBrik;
- brikz.methods = MethodsBrik;
- brikz.rebuild();
- }
- return configureWithFundamentals;
- });
- /* ====================================================================
- |
- | Amber Smalltalk
- | http://amber-lang.net
- |
- ======================================================================
- ======================================================================
- |
- | Copyright (c) 2010-2014
- | Nicolas Petton <petton.nicolas@gmail.com>
- |
- | Copyright (c) 2012-2016
- | The Amber team https://lolg.it/org/amber/members
- | Amber contributors (see /CONTRIBUTORS)
- |
- | Amber is released under the MIT license
- |
- | Permission is hereby granted, free of charge, to any person obtaining
- | a copy of this software and associated documentation files (the
- | 'Software'), to deal in the Software without restriction, including
- | without limitation the rights to use, copy, modify, merge, publish,
- | distribute, sublicense, and/or sell copies of the Software, and to
- | permit persons to whom the Software is furnished to do so, subject to
- | the following conditions:
- |
- | The above copyright notice and this permission notice shall be
- | included in all copies or substantial portions of the Software.
- |
- | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
- | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
- | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
- | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- |
- ==================================================================== */
- //jshint eqnull:true
- define('amber/kernel-language',['./compatibility'], function () {
- "use strict";
- function inherits (child, parent) {
- child.prototype = Object.create(parent.prototype, {
- constructor: {
- value: child,
- enumerable: false, configurable: true, writable: true
- }
- });
- return child;
- }
- function defineMethod (klass, name, method) {
- Object.defineProperty(klass.prototype, name, {
- value: method,
- enumerable: false, configurable: true, writable: true
- });
- }
- TraitsBrik.deps = ["behaviors", "composition", "arraySet", "root"];
- function TraitsBrik (brikz, st) {
- var coreFns = brikz.root.coreFns;
- var SmalltalkBehaviorBody = brikz.behaviors.BehaviorBody;
- var setupMethods = brikz.composition.setupMethods;
- var traitMethodChanged = brikz.composition.traitMethodChanged;
- var buildBehaviorBody = brikz.behaviors.buildBehaviorBody;
- var addElement = brikz.arraySet.addElement;
- var removeElement = brikz.arraySet.removeElement;
- function SmalltalkTrait () {
- }
- coreFns.Trait = inherits(SmalltalkTrait, SmalltalkBehaviorBody);
- SmalltalkTrait.prototype.trait = true;
- defineMethod(SmalltalkTrait, "toString", function () {
- return 'Smalltalk Trait ' + this.className;
- });
- defineMethod(SmalltalkTrait, "added", function () {
- if (st._traitAdded) st._traitAdded(this);
- });
- defineMethod(SmalltalkTrait, "removed", function () {
- if (st._traitRemoved) st._traitRemoved(this);
- });
- defineMethod(SmalltalkTrait, "methodAdded", function (method) {
- var self = this;
- this.traitUsers.forEach(function (each) {
- traitMethodChanged(method.selector, method, self, each);
- });
- if (st._traitMethodAdded) st._traitMethodAdded(method, this);
- });
- defineMethod(SmalltalkTrait, "methodRemoved", function (method) {
- var self = this;
- this.traitUsers.forEach(function (each) {
- traitMethodChanged(method.selector, null, self, each);
- });
- if (st._traitMethodRemoved) st._traitMethodRemoved(method, this);
- });
- defineMethod(SmalltalkTrait, "addUser", function (behaviorBody) {
- addElement(this.traitUsers, behaviorBody);
- });
- defineMethod(SmalltalkTrait, "removeUser", function (behaviorBody) {
- removeElement(this.traitUsers, behaviorBody);
- });
- function traitBuilder (className) {
- return {
- className: className,
- make: function (pkg) {
- var that = new SmalltalkTrait();
- that.className = className;
- that.pkg = pkg;
- that.traitUsers = [];
- setupMethods(that);
- return that;
- },
- updateExisting: function (trait, pkg) {
- if (pkg) trait.pkg = pkg;
- }
- };
- }
- st.addTrait = function (className, pkgName) {
- return buildBehaviorBody(pkgName, traitBuilder(className));
- };
- }
- ClassesBrik.deps = ["root", "behaviors", "composition", "arraySet", "smalltalkGlobals"];
- function ClassesBrik (brikz, st) {
- var SmalltalkRoot = brikz.root.Root;
- var coreFns = brikz.root.coreFns;
- var globals = brikz.smalltalkGlobals.globals;
- var SmalltalkBehaviorBody = brikz.behaviors.BehaviorBody;
- var buildBehaviorBody = brikz.behaviors.buildBehaviorBody;
- var setupMethods = brikz.composition.setupMethods;
- var removeBehaviorBody = brikz.behaviors.removeBehaviorBody;
- var addElement = brikz.arraySet.addElement;
- var removeElement = brikz.arraySet.removeElement;
- function SmalltalkBehavior () {
- }
- function SmalltalkClass () {
- }
- function SmalltalkMetaclass () {
- }
- coreFns.Behavior = inherits(SmalltalkBehavior, SmalltalkBehaviorBody);
- coreFns.Class = inherits(SmalltalkClass, SmalltalkBehavior);
- coreFns.Metaclass = inherits(SmalltalkMetaclass, SmalltalkBehavior);
- // Fake root class of the system.
- // Effective superclass of all classes created with `nil subclass: ...`.
- var nilAsClass = this.nilAsClass = {fn: SmalltalkRoot, klass: {fn: SmalltalkClass}};
- SmalltalkMetaclass.prototype.meta = true;
- defineMethod(SmalltalkClass, "toString", function () {
- return 'Smalltalk ' + this.className;
- });
- defineMethod(SmalltalkMetaclass, "toString", function () {
- return 'Smalltalk Metaclass ' + this.instanceClass.className;
- });
- defineMethod(SmalltalkClass, "added", function () {
- addSubclass(this);
- if (st._classAdded) st._classAdded(this);
- });
- defineMethod(SmalltalkClass, "removed", function () {
- if (st._classRemoved) st._classRemoved(this);
- removeSubclass(this);
- });
- defineMethod(SmalltalkBehavior, "methodAdded", function (method) {
- if (st._methodAdded) st._methodAdded(method, this);
- });
- defineMethod(SmalltalkBehavior, "methodRemoved", function (method) {
- if (st._methodRemoved) st._methodRemoved(method, this);
- });
- this.bootstrapHierarchy = function () {
- var nilSubclasses = [globals.ProtoObject];
- nilAsClass.klass = globals.Class;
- nilSubclasses.forEach(function (each) {
- each.klass.superclass = globals.Class;
- addSubclass(each.klass);
- });
- };
- /* Smalltalk class creation. A class is an instance of an automatically
- created metaclass object. Newly created classes (not their metaclass)
- should be added to the system, see smalltalk.addClass().
- Superclass linking is *not* handled here, see api.initialize() */
- function classBuilder (className, superclass, iVarNames, fn) {
- var logicalSuperclass = superclass;
- if (superclass == null || superclass.isNil) {
- superclass = nilAsClass;
- logicalSuperclass = null;
- }
- function klass (pkg) {
- var that = metaclass().instanceClass;
- that.superclass = logicalSuperclass;
- that.fn = fn || inherits(function () {
- }, superclass.fn);
- that.iVarNames = iVarNames || [];
- that.className = className;
- that.pkg = pkg;
- that.subclasses = [];
- setupMethods(that);
- return that;
- }
- function metaclass () {
- var that = new SmalltalkMetaclass();
- that.superclass = superclass.klass;
- that.fn = inherits(function () {
- }, that.superclass.fn);
- that.iVarNames = [];
- that.instanceClass = new that.fn();
- wireKlass(that);
- setupMethods(that);
- return that;
- }
- return {
- className: className,
- make: klass,
- updateExisting: function (klass, pkg) {
- if (klass.superclass == logicalSuperclass && (!fn || fn === klass.fn)) {
- if (iVarNames) klass.iVarNames = iVarNames;
- if (pkg) klass.pkg = pkg;
- } else throw new Error("Incompatible change of class: " + klass.className);
- }
- };
- }
- function wireKlass (klass) {
- Object.defineProperty(klass.fn.prototype, "klass", {
- value: klass,
- enumerable: false, configurable: true, writable: true
- });
- }
- this.wireKlass = wireKlass;
- /* Add a class to the system, creating a new one if needed.
- A Package is lazily created if one with given name does not exist. */
- st.addClass = function (className, superclass, iVarNames, pkgName) {
- // While subclassing nil is allowed, it might be an error, so
- // warn about it.
- if (typeof superclass == 'undefined' || superclass && superclass.isNil) {
- console.warn('Compiling ' + className + ' as a subclass of `nil`. A dependency might be missing.');
- }
- return buildBehaviorBody(pkgName, classBuilder(className, superclass, iVarNames, coreFns[className]));
- };
- st.removeClass = removeBehaviorBody;
- function addSubclass (klass) {
- if (klass.superclass) {
- addElement(klass.superclass.subclasses, klass);
- }
- }
- function removeSubclass (klass) {
- if (klass.superclass) {
- removeElement(klass.superclass.subclasses, klass);
- }
- }
- function metaSubclasses (metaclass) {
- return metaclass.instanceClass.subclasses
- .filter(function (each) {
- return !each.meta;
- })
- .map(function (each) {
- return each.klass;
- });
- }
- st.metaSubclasses = metaSubclasses;
- st.traverseClassTree = function (klass, fn) {
- var queue = [klass], sentinel = {};
- for (var i = 0; i < queue.length; ++i) {
- var item = queue[i];
- if (fn(item, sentinel) === sentinel) continue;
- var subclasses = item.meta ? metaSubclasses(item) : item.subclasses;
- queue.push.apply(queue, subclasses);
- }
- };
- }
- NilBrik.deps = ["root"];
- function NilBrik (brikz, st) {
- var SmalltalkObject = brikz.root.Object;
- var coreFns = brikz.root.coreFns;
- function SmalltalkNil () {
- }
- coreFns.UndefinedObject = inherits(SmalltalkNil, SmalltalkObject);
- this.nilAsReceiver = new SmalltalkNil();
- // Adds an `isNil` property to the `nil` object. When sending
- // nil objects from one environment to another, doing
- // `anObject == nil` (in JavaScript) does not always answer
- // true as the referenced nil object might come from the other
- // environment.
- Object.defineProperty(this.nilAsReceiver, 'isNil', {
- value: true,
- enumerable: false, configurable: false, writable: false
- });
- }
- /* Defines asReceiver to be present at load time */
- /* (logically it belongs more to PrimitiveBrik) */
- AsReceiverBrik.deps = ["nil"];
- function AsReceiverBrik (brikz, st) {
- var nilAsReceiver = brikz.nil.nilAsReceiver;
- /**
- * This function is used all over the compiled amber code.
- * It takes any value (JavaScript or Smalltalk)
- * and returns a proper Amber Smalltalk receiver.
- *
- * null or undefined -> nilAsReceiver,
- * object having Smalltalk signature -> unchanged,
- * otherwise wrapped foreign (JS) object
- */
- this.asReceiver = function (o) {
- if (o == null) return nilAsReceiver;
- else if (o.klass != null) return o;
- else return st.wrapJavaScript(o);
- };
- }
- /* Making smalltalk that can load */
- function configureWithHierarchy (brikz) {
- brikz.traits = TraitsBrik;
- brikz.classes = ClassesBrik;
- brikz.nil = NilBrik;
- brikz.asReceiver = AsReceiverBrik;
- brikz.rebuild();
- }
- return configureWithHierarchy;
- });
- /* ====================================================================
- |
- | Amber Smalltalk
- | http://amber-lang.net
- |
- ======================================================================
- ======================================================================
- |
- | Copyright (c) 2010-2014
- | Nicolas Petton <petton.nicolas@gmail.com>
- |
- | Copyright (c) 2012-2016
- | The Amber team https://lolg.it/org/amber/members
- | Amber contributors (see /CONTRIBUTORS)
- |
- | Amber is released under the MIT license
- |
- | Permission is hereby granted, free of charge, to any person obtaining
- | a copy of this software and associated documentation files (the
- | 'Software'), to deal in the Software without restriction, including
- | without limitation the rights to use, copy, modify, merge, publish,
- | distribute, sublicense, and/or sell copies of the Software, and to
- | permit persons to whom the Software is furnished to do so, subject to
- | the following conditions:
- |
- | The above copyright notice and this permission notice shall be
- | included in all copies or substantial portions of the Software.
- |
- | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
- | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
- | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
- | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- |
- ==================================================================== */
- //jshint eqnull:true
- define('amber/boot',[
- 'require', './brikz', './kernel-fundamentals', './kernel-language', './compatibility'
- ], function (require, Brikz, configureWithFundamentals, configureWithHierarchy) {
- "use strict";
- require(['./kernel-runtime']); // preload
- SmalltalkInitBrik.deps = ["classes"];
- function SmalltalkInitBrik (brikz, st) {
- var bootstrapHierarchy = brikz.classes.bootstrapHierarchy;
- var initialized = false;
- var runtimeLoadedPromise = new Promise(function (resolve, reject) {
- require(['./kernel-runtime'], resolve, reject);
- });
- /* Smalltalk initialization. Called on page load */
- st.initialize = function () {
- return runtimeLoadedPromise.then(function (configureWithRuntime) {
- if (initialized) return;
- bootstrapHierarchy();
- configureWithRuntime(brikz);
- initialized = true;
- });
- };
- }
- /* Adds AMD and requirejs related methods to the api */
- function AMDBrik (brikz, st) {
- st.amdRequire = require;
- st.defaultTransportType = st.defaultTransportType || "amd";
- st.defaultAmdNamespace = st.defaultAmdNamespace || "amber_core";
- }
- var api = {};
- var brikz = new Brikz(api);
- configureWithFundamentals(brikz);
- configureWithHierarchy(brikz);
- brikz.stInit = SmalltalkInitBrik;
- brikz.amd = AMDBrik;
- brikz.rebuild();
- return {
- api: api,
- nil/* TODO deprecate */: brikz.nil.nilAsReceiver,
- nilAsReceiver: brikz.nil.nilAsReceiver,
- dnu/* TODO deprecate */: brikz.classes.nilAsClass,
- nilAsClass: brikz.classes.nilAsClass,
- globals: brikz.smalltalkGlobals.globals,
- asReceiver: brikz.asReceiver.asReceiver
- };
- });
- define('amber/helpers',["amber/boot", "require"], function (boot, require) {
- var globals = boot.globals,
- exports = {},
- api = boot.api,
- nil = boot.nilAsReceiver;
- // API
- exports.popupHelios = function () {
- require(['helios/index'], function (helios) {
- helios.popup();
- }, function (err) {
- window.alert("Error loading helios.\nIf not present, you can install it with 'bower install helios --save-dev'.\nThe error follows:\n" + err);
- });
- };
- Object.defineProperty(exports, "api", {
- value: api,
- enumerable: true, configurable: true, writable: false
- });
- Object.defineProperty(exports, "globals", {
- value: globals,
- enumerable: true, configurable: true, writable: false
- });
- Object.defineProperty(exports, "nil", {
- value: nil,
- enumerable: true, configurable: true, writable: false
- });
- function mixinToSettings (source) {
- var settings = globals.SmalltalkSettings;
- Object.keys(source).forEach(function (key) {
- settings[key] = source[key];
- });
- }
- function settingsInLocalStorage () {
- //jshint evil:true
- var global = new Function('return this')(),
- storage = 'localStorage' in global && global.localStorage;
- if (storage) {
- var fromStorage;
- try {
- fromStorage = JSON.parse(storage.getItem('amber.SmalltalkSettings'));
- } catch (ex) {
- // pass
- }
- mixinToSettings(fromStorage || {});
- if (typeof window !== "undefined") {
- requirejs(['jquery'], function ($) {
- $(window).on('beforeunload', function () {
- storage.setItem('amber.SmalltalkSettings', JSON.stringify(globals.SmalltalkSettings));
- });
- });
- }
- }
- }
- exports.initialize = function (options) {
- return Promise.resolve()
- .then(function () {
- globals.SmalltalkSettings['transport.defaultAmdNamespace'] = api.defaultAmdNamespace;
- })
- .then(settingsInLocalStorage)
- .then(function () {
- return options || {};
- })
- .then(mixinToSettings)
- .then(function () {
- return api.initialize();
- });
- };
- // Exports
- return exports;
- });
- define('amber_core/Kernel-Objects',["amber/boot"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Objects");
- $core.packages["Kernel-Objects"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Objects"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("ProtoObject", null, [], "Kernel-Objects");
- $globals.ProtoObject.comment="I implement the basic behavior required for any object in Amber.\x0a\x0aIn most cases, subclassing `ProtoObject` is wrong and `Object` should be used instead. However subclassing `ProtoObject` can be useful in some special cases like proxy implementations.";
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.__eq_eq(anObject);
- }, function($ctx1) {$ctx1.fill(self,"=",{anObject:anObject},$globals.ProtoObject)});
- },
- args: ["anObject"],
- source: "= anObject\x0a\x09^ self == anObject",
- referencedClasses: [],
- messageSends: ["=="]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "==",
- protocol: "comparing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._class() === $recv(anObject)._class() && self._isSameInstanceAs_(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"==",{anObject:anObject},$globals.ProtoObject)});
- },
- args: ["anObject"],
- source: "== anObject\x0a<inlineJS:\x0a\x09'return self._class() === $recv(anObject)._class() && self._isSameInstanceAs_(anObject)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "asJSON",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._deprecatedAPI_("Use #asJavaScriptObject instead.");
- return self._asJavaScriptObject();
- }, function($ctx1) {$ctx1.fill(self,"asJSON",{},$globals.ProtoObject)});
- },
- args: [],
- source: "asJSON\x0a\x09self deprecatedAPI: 'Use #asJavaScriptObject instead.'.\x0a\x09^ self asJavaScriptObject",
- referencedClasses: [],
- messageSends: ["deprecatedAPI:", "asJavaScriptObject"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "asJavascript",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._deprecatedAPI_("Use #asJavaScriptSource instead.");
- return self._asJavaScriptSource();
- }, function($ctx1) {$ctx1.fill(self,"asJavascript",{},$globals.ProtoObject)});
- },
- args: [],
- source: "asJavascript\x0a\x09self deprecatedAPI: 'Use #asJavaScriptSource instead.'.\x0a\x09^ self asJavaScriptSource",
- referencedClasses: [],
- messageSends: ["deprecatedAPI:", "asJavaScriptSource"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "asString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._printString();
- }, function($ctx1) {$ctx1.fill(self,"asString",{},$globals.ProtoObject)});
- },
- args: [],
- source: "asString\x0a\x09^ self printString",
- referencedClasses: [],
- messageSends: ["printString"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "class",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.klass;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"class",{},$globals.ProtoObject)});
- },
- args: [],
- source: "class\x0a\x09<inlineJS: 'return self.klass'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "doesNotUnderstand:",
- protocol: "error handling",
- fn: function (aMessage){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.MessageNotUnderstood)._new();
- $recv($1)._receiver_(self);
- $recv($1)._message_(aMessage);
- $recv($1)._signal();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"doesNotUnderstand:",{aMessage:aMessage},$globals.ProtoObject)});
- },
- args: ["aMessage"],
- source: "doesNotUnderstand: aMessage\x0a\x09MessageNotUnderstood new\x0a\x09\x09receiver: self;\x0a\x09\x09message: aMessage;\x0a\x09\x09signal",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["receiver:", "new", "message:", "signal"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "evaluate:on:",
- protocol: "evaluating",
- fn: function (aString,anEvaluator){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anEvaluator)._evaluate_receiver_(aString,self);
- }, function($ctx1) {$ctx1.fill(self,"evaluate:on:",{aString:aString,anEvaluator:anEvaluator},$globals.ProtoObject)});
- },
- args: ["aString", "anEvaluator"],
- source: "evaluate: aString on: anEvaluator\x0a\x09^ anEvaluator evaluate: aString receiver: self",
- referencedClasses: [],
- messageSends: ["evaluate:receiver:"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "identityHash",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var hash=self.identityHash;
- if (hash) return hash;
- hash=$core.nextId();
- Object.defineProperty(self, 'identityHash', {value:hash});
- return hash;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"identityHash",{},$globals.ProtoObject)});
- },
- args: [],
- source: "identityHash\x0a\x09<inlineJS: '\x0a\x09\x09var hash=self.identityHash;\x0a\x09\x09if (hash) return hash;\x0a\x09\x09hash=$core.nextId();\x0a\x09\x09Object.defineProperty(self, ''identityHash'', {value:hash});\x0a\x09\x09return hash;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "ifNil:",
- protocol: "testing",
- fn: function (aBlock){
- var self=this;
- return self;
- },
- args: ["aBlock"],
- source: "ifNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "ifNil:ifNotNil:",
- protocol: "testing",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anotherBlock)._value_(self);
- }, function($ctx1) {$ctx1.fill(self,"ifNil:ifNotNil:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.ProtoObject)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifNil: aBlock ifNotNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ anotherBlock value: self",
- referencedClasses: [],
- messageSends: ["value:"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "ifNotNil:",
- protocol: "testing",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aBlock)._value_(self);
- }, function($ctx1) {$ctx1.fill(self,"ifNotNil:",{aBlock:aBlock},$globals.ProtoObject)});
- },
- args: ["aBlock"],
- source: "ifNotNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ aBlock value: self",
- referencedClasses: [],
- messageSends: ["value:"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "ifNotNil:ifNil:",
- protocol: "testing",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aBlock)._value_(self);
- }, function($ctx1) {$ctx1.fill(self,"ifNotNil:ifNil:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.ProtoObject)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifNotNil: aBlock ifNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ aBlock value: self",
- referencedClasses: [],
- messageSends: ["value:"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "initialize",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "inspect",
- protocol: "inspecting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Inspector)._inspect_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspect",{},$globals.ProtoObject)});
- },
- args: [],
- source: "inspect\x0a\x09Inspector inspect: self",
- referencedClasses: ["Inspector"],
- messageSends: ["inspect:"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "inspecting",
- fn: function (anInspector){
- var self=this;
- return self;
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "instVarAt:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self['@'+aString];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"instVarAt:",{aString:aString},$globals.ProtoObject)});
- },
- args: ["aString"],
- source: "instVarAt: aString\x0a\x09<inlineJS: 'return self[''@''+aString]'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "instVarAt:put:",
- protocol: "accessing",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self['@' + aString] = anObject;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"instVarAt:put:",{aString:aString,anObject:anObject},$globals.ProtoObject)});
- },
- args: ["aString", "anObject"],
- source: "instVarAt: aString put: anObject\x0a\x09<inlineJS: 'self[''@'' + aString] = anObject'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "isKindOf:",
- protocol: "testing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._isMemberOf_(aClass);
- if($core.assert($1)){
- return true;
- } else {
- return $recv(self._class())._inheritsFrom_(aClass);
- }
- }, function($ctx1) {$ctx1.fill(self,"isKindOf:",{aClass:aClass},$globals.ProtoObject)});
- },
- args: ["aClass"],
- source: "isKindOf: aClass\x0a\x09^ (self isMemberOf: aClass)\x0a\x09\x09ifTrue: [ true ]\x0a\x09\x09ifFalse: [ self class inheritsFrom: aClass ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "isMemberOf:", "inheritsFrom:", "class"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "isNil",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isNil\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "isSameInstanceAs:",
- protocol: "comparing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._identityHash();
- $ctx1.sendIdx["identityHash"]=1;
- return $recv($1).__eq($recv(anObject)._identityHash());
- }, function($ctx1) {$ctx1.fill(self,"isSameInstanceAs:",{anObject:anObject},$globals.ProtoObject)});
- },
- args: ["anObject"],
- source: "isSameInstanceAs: anObject\x0a\x09^ self identityHash = anObject identityHash",
- referencedClasses: [],
- messageSends: ["=", "identityHash"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "notNil",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._isNil())._not();
- }, function($ctx1) {$ctx1.fill(self,"notNil",{},$globals.ProtoObject)});
- },
- args: [],
- source: "notNil\x0a\x09^ self isNil not",
- referencedClasses: [],
- messageSends: ["not", "isNil"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "perform:",
- protocol: "message handling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._perform_withArguments_(aString,[]);
- }, function($ctx1) {$ctx1.fill(self,"perform:",{aString:aString},$globals.ProtoObject)});
- },
- args: ["aString"],
- source: "perform: aString\x0a\x09^ self perform: aString withArguments: #()",
- referencedClasses: [],
- messageSends: ["perform:withArguments:"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "perform:withArguments:",
- protocol: "message handling",
- fn: function (aString,aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.send2(self, aString, aCollection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"perform:withArguments:",{aString:aString,aCollection:aCollection},$globals.ProtoObject)});
- },
- args: ["aString", "aCollection"],
- source: "perform: aString withArguments: aCollection\x0a\x09<inlineJS: 'return $core.send2(self, aString, aCollection)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $5,$4,$3,$2,$1;
- $5=self._class();
- $ctx1.sendIdx["class"]=1;
- $4=$recv($5)._name();
- $ctx1.sendIdx["name"]=1;
- $3=$recv($4)._first();
- $2=$recv($3)._isVowel();
- if($core.assert($2)){
- $1="an ";
- } else {
- $1="a ";
- }
- $recv(aStream)._nextPutAll_($1);
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._nextPutAll_($recv(self._class())._name());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.ProtoObject)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09aStream nextPutAll: (self class name first isVowel\x0a\x09\x09ifTrue: [ 'an ' ]\x0a\x09\x09ifFalse: [ 'a ' ]).\x0a\x09aStream nextPutAll: self class name",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "ifTrue:ifFalse:", "isVowel", "first", "name", "class"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "printString",
- protocol: "printing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- return self._printOn_(str);
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"printString",{},$globals.ProtoObject)});
- },
- args: [],
- source: "printString\x0a\x09^ String streamContents: [ :str | \x0a\x09\x09self printOn: str ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "printOn:"]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "yourself",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "yourself\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "~=",
- protocol: "comparing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self.__eq(anObject)).__eq(false);
- $ctx1.sendIdx["="]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"~=",{anObject:anObject},$globals.ProtoObject)});
- },
- args: ["anObject"],
- source: "~= anObject\x0a\x09^ (self = anObject) = false",
- referencedClasses: [],
- messageSends: ["="]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "~~",
- protocol: "comparing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self.__eq_eq(anObject)).__eq(false);
- }, function($ctx1) {$ctx1.fill(self,"~~",{anObject:anObject},$globals.ProtoObject)});
- },
- args: ["anObject"],
- source: "~~ anObject\x0a\x09^ (self == anObject) = false",
- referencedClasses: [],
- messageSends: ["=", "=="]
- }),
- $globals.ProtoObject);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "initialize",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtoObject.klass);
- $core.addClass("Object", $globals.ProtoObject, [], "Kernel-Objects");
- $globals.Object.comment="**I am the root of the Smalltalk class system**. With the exception of unual subclasses of `ProtoObject`, all other classes in the system are subclasses of me.\x0a\x0aI provide default behavior common to all normal objects (some of it inherited from `ProtoObject`), such as:\x0a\x0a- accessing\x0a- copying\x0a- comparison\x0a- error handling\x0a- message sending\x0a- reflection\x0a\x0aAlso utility messages that all objects should respond to are defined here.\x0a\x0aI have no instance variable.\x0a\x0a##Access\x0a\x0aInstance variables can be accessed with `#instVarAt:` and `#instVarAt:put:`. `#instanceVariableNames` answers a collection of all instance variable names.\x0aAccessing JavaScript properties of an object is done through `#basicAt:`, `#basicAt:put:` and `basicDelete:`.\x0a\x0a##Copying\x0a\x0aCopying an object is handled by `#copy` and `#deepCopy`. The first one performs a shallow copy of the receiver, while the second one performs a deep copy.\x0aThe hook method `#postCopy` can be overriden in subclasses to copy fields as necessary to complete the full copy. It will be sent by the copy of the receiver.\x0a\x0a##Comparison\x0a\x0aI understand equality `#=` and identity `#==` comparison.\x0a\x0a##Error handling\x0a\x0a- `#halt` is the typical message to use for inserting breakpoints during debugging.\x0a- `#error:` throws a generic error exception\x0a- `#doesNotUnderstand:` handles the fact that there was an attempt to send the given message to the receiver but the receiver does not understand this message.\x0a\x09Overriding this message can be useful to implement proxies for example.";
- $core.addMethod(
- $core.method({
- selector: "->",
- protocol: "converting",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Association)._key_value_(self,anObject);
- }, function($ctx1) {$ctx1.fill(self,"->",{anObject:anObject},$globals.Object)});
- },
- args: ["anObject"],
- source: "-> anObject\x0a\x09^ Association key: self value: anObject",
- referencedClasses: ["Association"],
- messageSends: ["key:value:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "asJSONString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.JSON)._stringify_(self._asJavaScriptObject());
- }, function($ctx1) {$ctx1.fill(self,"asJSONString",{},$globals.Object)});
- },
- args: [],
- source: "asJSONString\x0a\x09^ JSON stringify: self asJavaScriptObject",
- referencedClasses: ["JSON"],
- messageSends: ["stringify:", "asJavaScriptObject"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- var variables;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.HashedCollection)._new();
- $recv($recv(self._class())._allInstanceVariableNames())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(variables)._at_put_(each,$recv(self._instVarAt_(each))._asJavaScriptObject());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return variables;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptObject",{variables:variables},$globals.Object)});
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09| variables |\x0a\x09variables := HashedCollection new.\x0a\x09self class allInstanceVariableNames do: [ :each |\x0a\x09\x09variables at: each put: (self instVarAt: each) asJavaScriptObject ].\x0a\x09^ variables",
- referencedClasses: ["HashedCollection"],
- messageSends: ["new", "do:", "allInstanceVariableNames", "class", "at:put:", "asJavaScriptObject", "instVarAt:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._asString();
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.Object)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09^ self asString",
- referencedClasses: [],
- messageSends: ["asString"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "basicAt:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self[aString];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicAt:",{aString:aString},$globals.Object)});
- },
- args: ["aString"],
- source: "basicAt: aString\x0a\x09<inlineJS: 'return self[aString]'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "basicAt:put:",
- protocol: "accessing",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self[aString] = anObject;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicAt:put:",{aString:aString,anObject:anObject},$globals.Object)});
- },
- args: ["aString", "anObject"],
- source: "basicAt: aString put: anObject\x0a\x09<inlineJS: 'return self[aString] = anObject'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "basicDelete:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- delete self[aString]; return aString;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicDelete:",{aString:aString},$globals.Object)});
- },
- args: ["aString"],
- source: "basicDelete: aString\x0a\x09<inlineJS: 'delete self[aString]; return aString'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "basicPerform:",
- protocol: "message handling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicPerform_withArguments_(aString,[]);
- }, function($ctx1) {$ctx1.fill(self,"basicPerform:",{aString:aString},$globals.Object)});
- },
- args: ["aString"],
- source: "basicPerform: aString\x0a\x09^ self basicPerform: aString withArguments: #()",
- referencedClasses: [],
- messageSends: ["basicPerform:withArguments:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "basicPerform:withArguments:",
- protocol: "message handling",
- fn: function (aString,aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self[aString].apply(self, aCollection);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicPerform:withArguments:",{aString:aString,aCollection:aCollection},$globals.Object)});
- },
- args: ["aString", "aCollection"],
- source: "basicPerform: aString withArguments: aCollection\x0a\x09<inlineJS: 'return self[aString].apply(self, aCollection);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "browse",
- protocol: "browsing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Finder)._findClass_(self._class());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"browse",{},$globals.Object)});
- },
- args: [],
- source: "browse\x0a\x09Finder findClass: self class",
- referencedClasses: ["Finder"],
- messageSends: ["findClass:", "class"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "copy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._shallowCopy())._postCopy();
- }, function($ctx1) {$ctx1.fill(self,"copy",{},$globals.Object)});
- },
- args: [],
- source: "copy\x0a\x09^ self shallowCopy postCopy",
- referencedClasses: [],
- messageSends: ["postCopy", "shallowCopy"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "deepCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var copy = self.klass._new();
- Object.keys(self).forEach(function (i) {
- if(/^@.+/.test(i)) {
- copy[i] = self[i]._deepCopy();
- }
- });
- return copy;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},$globals.Object)});
- },
- args: [],
- source: "deepCopy\x0a\x09<inlineJS: '\x0a\x09\x09var copy = self.klass._new();\x0a\x09\x09Object.keys(self).forEach(function (i) {\x0a\x09\x09if(/^@.+/.test(i)) {\x0a\x09\x09\x09copy[i] = self[i]._deepCopy();\x0a\x09\x09}\x0a\x09\x09});\x0a\x09\x09return copy;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "deprecatedAPI",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$6,$5,$4,$8,$7,$3,$2;
- $1=console;
- $6=$core.getThisContext()._home();
- $ctx1.sendIdx["home"]=1;
- $5=$recv($6)._asString();
- $ctx1.sendIdx["asString"]=1;
- $4=$recv($5).__comma(" is deprecated! (in ");
- $8=$recv($core.getThisContext()._home())._home();
- $ctx1.sendIdx["home"]=2;
- $7=$recv($8)._asString();
- $3=$recv($4).__comma($7);
- $ctx1.sendIdx[","]=2;
- $2=$recv($3).__comma(")");
- $ctx1.sendIdx[","]=1;
- $recv($1)._warn_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deprecatedAPI",{},$globals.Object)});
- },
- args: [],
- source: "deprecatedAPI\x0a\x09\x22Just a simple way to deprecate methods.\x0a\x09#deprecatedAPI is in the 'error handling' protocol even if it doesn't throw an error,\x0a\x09but it could in the future.\x22\x0a\x09console warn: thisContext home asString, ' is deprecated! (in ', thisContext home home asString, ')'.",
- referencedClasses: [],
- messageSends: ["warn:", ",", "asString", "home"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "deprecatedAPI:",
- protocol: "error handling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$6,$5,$4,$8,$7,$3,$2;
- $1=console;
- $6=$core.getThisContext()._home();
- $ctx1.sendIdx["home"]=1;
- $5=$recv($6)._asString();
- $ctx1.sendIdx["asString"]=1;
- $4=$recv($5).__comma(" is deprecated! (in ");
- $8=$recv($core.getThisContext()._home())._home();
- $ctx1.sendIdx["home"]=2;
- $7=$recv($8)._asString();
- $3=$recv($4).__comma($7);
- $ctx1.sendIdx[","]=2;
- $2=$recv($3).__comma(")");
- $ctx1.sendIdx[","]=1;
- $recv($1)._warn_($2);
- $ctx1.sendIdx["warn:"]=1;
- $recv(console)._warn_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deprecatedAPI:",{aString:aString},$globals.Object)});
- },
- args: ["aString"],
- source: "deprecatedAPI: aString\x0a\x09\x22Just a simple way to deprecate methods.\x0a\x09#deprecatedAPI is in the 'error handling' protocol even if it doesn't throw an error,\x0a\x09but it could in the future.\x22\x0a\x09console warn: thisContext home asString, ' is deprecated! (in ', thisContext home home asString, ')'.\x0a\x09console warn: aString",
- referencedClasses: [],
- messageSends: ["warn:", ",", "asString", "home"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "error:",
- protocol: "error handling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Error)._signal_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"error:",{aString:aString},$globals.Object)});
- },
- args: ["aString"],
- source: "error: aString\x0a\x09Error signal: aString",
- referencedClasses: ["Error"],
- messageSends: ["signal:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "halt",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Halt)._signal();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"halt",{},$globals.Object)});
- },
- args: [],
- source: "halt\x0a\x09Halt signal",
- referencedClasses: ["Halt"],
- messageSends: ["signal"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "in:",
- protocol: "evaluating",
- fn: function (aValuable){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aValuable)._value_(self);
- }, function($ctx1) {$ctx1.fill(self,"in:",{aValuable:aValuable},$globals.Object)});
- },
- args: ["aValuable"],
- source: "in: aValuable\x0a\x09^ aValuable value: self",
- referencedClasses: [],
- messageSends: ["value:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isBehavior",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isBehavior\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isBoolean",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isBoolean\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isClass",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isClass\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isCompiledMethod",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isCompiledMethod\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isImmutable\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isMemberOf:",
- protocol: "testing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class()).__eq(aClass);
- }, function($ctx1) {$ctx1.fill(self,"isMemberOf:",{aClass:aClass},$globals.Object)});
- },
- args: ["aClass"],
- source: "isMemberOf: aClass\x0a\x09^ self class = aClass",
- referencedClasses: [],
- messageSends: ["=", "class"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isMetaclass",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isMetaclass\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isNumber",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isNumber\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isPackage",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isPackage\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isParseFailure",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isParseFailure\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isString",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isString\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "isSymbol",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isSymbol\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "postCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "postCopy",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "putOn:",
- protocol: "streaming",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPut_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"putOn:",{aStream:aStream},$globals.Object)});
- },
- args: ["aStream"],
- source: "putOn: aStream\x0a\x09aStream nextPut: self",
- referencedClasses: [],
- messageSends: ["nextPut:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "respondsTo:",
- protocol: "testing",
- fn: function (aSelector){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._canUnderstand_(aSelector);
- }, function($ctx1) {$ctx1.fill(self,"respondsTo:",{aSelector:aSelector},$globals.Object)});
- },
- args: ["aSelector"],
- source: "respondsTo: aSelector\x0a\x09^ self class canUnderstand: aSelector",
- referencedClasses: [],
- messageSends: ["canUnderstand:", "class"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "shallowCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var copy = self.klass._new();
- Object.keys(self).forEach(function(i) {
- if(/^@.+/.test(i)) {
- copy[i] = self[i];
- }
- });
- return copy;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{},$globals.Object)});
- },
- args: [],
- source: "shallowCopy\x0a\x09<inlineJS: '\x0a\x09\x09var copy = self.klass._new();\x0a\x09\x09Object.keys(self).forEach(function(i) {\x0a\x09\x09if(/^@.+/.test(i)) {\x0a\x09\x09\x09copy[i] = self[i];\x0a\x09\x09}\x0a\x09\x09});\x0a\x09\x09return copy;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "shouldNotImplement",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._error_("This method should not be implemented in ".__comma($recv(self._class())._name()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldNotImplement",{},$globals.Object)});
- },
- args: [],
- source: "shouldNotImplement\x0a\x09self error: 'This method should not be implemented in ', self class name",
- referencedClasses: [],
- messageSends: ["error:", ",", "name", "class"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._error_("Object not indexable");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"size",{},$globals.Object)});
- },
- args: [],
- source: "size\x0a\x09self error: 'Object not indexable'",
- referencedClasses: [],
- messageSends: ["error:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "subclassResponsibility",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._error_("This method is a responsibility of a subclass");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"subclassResponsibility",{},$globals.Object)});
- },
- args: [],
- source: "subclassResponsibility\x0a\x09self error: 'This method is a responsibility of a subclass'",
- referencedClasses: [],
- messageSends: ["error:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "evaluating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.valueOf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"value",{},$globals.Object)});
- },
- args: [],
- source: "value\x0a\x09<inlineJS: 'return self.valueOf()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "accessorProtocolWith:",
- protocol: "helios",
- fn: function (aGenerator){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aGenerator)._accessorProtocolForObject();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"accessorProtocolWith:",{aGenerator:aGenerator},$globals.Object.klass)});
- },
- args: ["aGenerator"],
- source: "accessorProtocolWith: aGenerator\x0a\x09aGenerator accessorProtocolForObject",
- referencedClasses: [],
- messageSends: ["accessorProtocolForObject"]
- }),
- $globals.Object.klass);
- $core.addMethod(
- $core.method({
- selector: "accessorsSourceCodesWith:",
- protocol: "helios",
- fn: function (aGenerator){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aGenerator)._accessorsForObject();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"accessorsSourceCodesWith:",{aGenerator:aGenerator},$globals.Object.klass)});
- },
- args: ["aGenerator"],
- source: "accessorsSourceCodesWith: aGenerator\x0a\x09aGenerator accessorsForObject",
- referencedClasses: [],
- messageSends: ["accessorsForObject"]
- }),
- $globals.Object.klass);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "initialize\x0a\x09\x22no op\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object.klass);
- $core.addMethod(
- $core.method({
- selector: "initializeProtocolWith:",
- protocol: "helios",
- fn: function (aGenerator){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aGenerator)._initializeProtocolForObject();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initializeProtocolWith:",{aGenerator:aGenerator},$globals.Object.klass)});
- },
- args: ["aGenerator"],
- source: "initializeProtocolWith: aGenerator\x0a\x09aGenerator initializeProtocolForObject",
- referencedClasses: [],
- messageSends: ["initializeProtocolForObject"]
- }),
- $globals.Object.klass);
- $core.addMethod(
- $core.method({
- selector: "initializeSourceCodesWith:",
- protocol: "helios",
- fn: function (aGenerator){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aGenerator)._initializeForObject();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initializeSourceCodesWith:",{aGenerator:aGenerator},$globals.Object.klass)});
- },
- args: ["aGenerator"],
- source: "initializeSourceCodesWith: aGenerator\x0a\x09aGenerator initializeForObject",
- referencedClasses: [],
- messageSends: ["initializeForObject"]
- }),
- $globals.Object.klass);
- $core.addClass("Boolean", $globals.Object, [], "Kernel-Objects");
- $globals.Boolean.comment="I define the protocol for logic testing operations and conditional control structures for the logical values (see the `controlling` protocol).\x0a\x0aI have two instances, `true` and `false`.\x0a\x0aI am directly mapped to JavaScript Boolean. The `true` and `false` objects are the JavaScript boolean objects.\x0a\x0a## Usage Example:\x0a\x0a aBoolean not ifTrue: [ ... ] ifFalse: [ ... ]";
- $core.addMethod(
- $core.method({
- selector: "&",
- protocol: "controlling",
- fn: function (aBoolean){
- var self=this;
- return $core.withContext(function($ctx1) {
- if(self == true) {
- return aBoolean;
- } else {
- return false;
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"&",{aBoolean:aBoolean},$globals.Boolean)});
- },
- args: ["aBoolean"],
- source: "& aBoolean\x0a\x09<inlineJS: '\x0a\x09\x09if(self == true) {\x0a\x09\x09return aBoolean;\x0a\x09\x09} else {\x0a\x09\x09return false;\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "==",
- protocol: "comparing",
- fn: function (aBoolean){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (typeof aBoolean === "boolean") return self.valueOf() === aBoolean;
- else if (aBoolean != null && typeof aBoolean === "object") return self.valueOf() === aBoolean.valueOf();
- else return false;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"==",{aBoolean:aBoolean},$globals.Boolean)});
- },
- args: ["aBoolean"],
- source: "== aBoolean\x0a<inlineJS: '\x0a\x09if (typeof aBoolean === \x22boolean\x22) return self.valueOf() === aBoolean;\x0a\x09else if (aBoolean != null && typeof aBoolean === \x22object\x22) return self.valueOf() === aBoolean.valueOf();\x0a\x09else return false;\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "and:",
- protocol: "controlling",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- if($core.assert(self)){
- return $recv(aBlock)._value();
- } else {
- return false;
- }
- }, function($ctx1) {$ctx1.fill(self,"and:",{aBlock:aBlock},$globals.Boolean)});
- },
- args: ["aBlock"],
- source: "and: aBlock\x0a\x09^ self\x0a\x09\x09ifTrue: \x22aBlock\x22 [ aBlock value ]\x0a\x09\x09ifFalse: [ false ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "value"]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "asBit",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- if($core.assert(self)){
- return (1);
- } else {
- return (0);
- }
- }, function($ctx1) {$ctx1.fill(self,"asBit",{},$globals.Boolean)});
- },
- args: [],
- source: "asBit\x0a\x09^ self ifTrue: [ 1 ] ifFalse: [ 0 ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:"]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "asString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asString",{},$globals.Boolean)});
- },
- args: [],
- source: "asString\x0a\x09<inlineJS: 'return self.toString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "deepCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "deepCopy\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "ifFalse:",
- protocol: "controlling",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._ifTrue_ifFalse_((function(){
- }),aBlock);
- }, function($ctx1) {$ctx1.fill(self,"ifFalse:",{aBlock:aBlock},$globals.Boolean)});
- },
- args: ["aBlock"],
- source: "ifFalse: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ self ifTrue: [] ifFalse: aBlock",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:"]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "ifFalse:ifTrue:",
- protocol: "controlling",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._ifTrue_ifFalse_(anotherBlock,aBlock);
- }, function($ctx1) {$ctx1.fill(self,"ifFalse:ifTrue:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.Boolean)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifFalse: aBlock ifTrue: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ self ifTrue: anotherBlock ifFalse: aBlock",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:"]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "ifTrue:",
- protocol: "controlling",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._ifTrue_ifFalse_(aBlock,(function(){
- }));
- }, function($ctx1) {$ctx1.fill(self,"ifTrue:",{aBlock:aBlock},$globals.Boolean)});
- },
- args: ["aBlock"],
- source: "ifTrue: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ self ifTrue: aBlock ifFalse: []",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:"]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "ifTrue:ifFalse:",
- protocol: "controlling",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- if(self == true) {
- return aBlock._value();
- } else {
- return anotherBlock._value();
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"ifTrue:ifFalse:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.Boolean)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifTrue: aBlock ifFalse: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09<inlineJS: '\x0a\x09\x09if(self == true) {\x0a\x09\x09return aBlock._value();\x0a\x09\x09} else {\x0a\x09\x09return anotherBlock._value();\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "isBoolean",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isBoolean\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "not",
- protocol: "controlling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.__eq(false);
- }, function($ctx1) {$ctx1.fill(self,"not",{},$globals.Boolean)});
- },
- args: [],
- source: "not\x0a\x09^ self = false",
- referencedClasses: [],
- messageSends: ["="]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "or:",
- protocol: "controlling",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- if($core.assert(self)){
- return true;
- } else {
- return $recv(aBlock)._value();
- }
- }, function($ctx1) {$ctx1.fill(self,"or:",{aBlock:aBlock},$globals.Boolean)});
- },
- args: ["aBlock"],
- source: "or: aBlock\x0a\x09^ self\x0a\x09\x09ifTrue: [ true ]\x0a\x09\x09ifFalse: \x22aBlock\x22 [ aBlock value ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "value"]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutAll_(self._asString());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Boolean)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09aStream nextPutAll: self asString",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "asString"]
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "shallowCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "shallowCopy\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addMethod(
- $core.method({
- selector: "|",
- protocol: "controlling",
- fn: function (aBoolean){
- var self=this;
- return $core.withContext(function($ctx1) {
- if(self == true) {
- return true;
- } else {
- return aBoolean;
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"|",{aBoolean:aBoolean},$globals.Boolean)});
- },
- args: ["aBoolean"],
- source: "| aBoolean\x0a\x09<inlineJS: '\x0a\x09\x09if(self == true) {\x0a\x09\x09return true;\x0a\x09\x09} else {\x0a\x09\x09return aBoolean;\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Boolean);
- $core.addClass("Date", $globals.Object, [], "Kernel-Objects");
- $globals.Date.comment="I am used to work with both dates and times. Therefore `Date today` and `Date now` are both valid in\x0aAmber and answer the same date object.\x0a\x0aDate directly maps to the `Date()` JavaScript constructor, and Amber date objects are JavaScript date objects.\x0a\x0a## API\x0a\x0aThe class-side `instance creation` protocol contains some convenience methods for creating date/time objects such as `#fromSeconds:`.\x0a\x0aArithmetic and comparison is supported (see the `comparing` and `arithmetic` protocols).\x0a\x0aThe `converting` protocol provides convenience methods for various convertions (to numbers, strings, etc.).";
- $core.addMethod(
- $core.method({
- selector: "+",
- protocol: "arithmetic",
- fn: function (aDate){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self + aDate;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"+",{aDate:aDate},$globals.Date)});
- },
- args: ["aDate"],
- source: "+ aDate\x0a\x09<inlineJS: 'return self + aDate'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "-",
- protocol: "arithmetic",
- fn: function (aDate){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self - aDate;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"-",{aDate:aDate},$globals.Date)});
- },
- args: ["aDate"],
- source: "- aDate\x0a\x09<inlineJS: 'return self - aDate'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "<",
- protocol: "comparing",
- fn: function (aDate){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self < aDate;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"<",{aDate:aDate},$globals.Date)});
- },
- args: ["aDate"],
- source: "< aDate\x0a\x09<inlineJS: 'return self < aDate'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "<=",
- protocol: "comparing",
- fn: function (aDate){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self <= aDate;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"<=",{aDate:aDate},$globals.Date)});
- },
- args: ["aDate"],
- source: "<= aDate\x0a\x09<inlineJS: 'return self <= aDate'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (aDate){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3;
- $2=$recv(aDate)._class();
- $ctx1.sendIdx["class"]=1;
- $1=$recv($2).__eq_eq(self._class());
- $ctx1.sendIdx["=="]=1;
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- $3=self._asMilliseconds();
- $ctx2.sendIdx["asMilliseconds"]=1;
- return $recv($3).__eq_eq($recv(aDate)._asMilliseconds());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"=",{aDate:aDate},$globals.Date)});
- },
- args: ["aDate"],
- source: "= aDate\x0a\x09^ (aDate class == self class) and: [ self asMilliseconds == aDate asMilliseconds ]",
- referencedClasses: [],
- messageSends: ["and:", "==", "class", "asMilliseconds"]
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: ">",
- protocol: "comparing",
- fn: function (aDate){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self > aDate;
- return self;
- }, function($ctx1) {$ctx1.fill(self,">",{aDate:aDate},$globals.Date)});
- },
- args: ["aDate"],
- source: "> aDate\x0a\x09<inlineJS: 'return self > aDate'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: ">=",
- protocol: "comparing",
- fn: function (aDate){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self >= aDate;
- return self;
- }, function($ctx1) {$ctx1.fill(self,">=",{aDate:aDate},$globals.Date)});
- },
- args: ["aDate"],
- source: ">= aDate\x0a\x09<inlineJS: 'return self >= aDate'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "asDateString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toDateString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asDateString",{},$globals.Date)});
- },
- args: [],
- source: "asDateString\x0a\x09<inlineJS: 'return self.toDateString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "asLocaleString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toLocaleString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asLocaleString",{},$globals.Date)});
- },
- args: [],
- source: "asLocaleString\x0a\x09<inlineJS: 'return self.toLocaleString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "asMilliseconds",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._time();
- }, function($ctx1) {$ctx1.fill(self,"asMilliseconds",{},$globals.Date)});
- },
- args: [],
- source: "asMilliseconds\x0a\x09^ self time",
- referencedClasses: [],
- messageSends: ["time"]
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "asNumber",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._asMilliseconds();
- }, function($ctx1) {$ctx1.fill(self,"asNumber",{},$globals.Date)});
- },
- args: [],
- source: "asNumber\x0a\x09^ self asMilliseconds",
- referencedClasses: [],
- messageSends: ["asMilliseconds"]
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "asString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asString",{},$globals.Date)});
- },
- args: [],
- source: "asString\x0a\x09<inlineJS: 'return self.toString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "asTimeString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toTimeString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asTimeString",{},$globals.Date)});
- },
- args: [],
- source: "asTimeString\x0a\x09<inlineJS: 'return self.toTimeString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "day",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._dayOfWeek();
- }, function($ctx1) {$ctx1.fill(self,"day",{},$globals.Date)});
- },
- args: [],
- source: "day\x0a\x09^ self dayOfWeek",
- referencedClasses: [],
- messageSends: ["dayOfWeek"]
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "day:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._dayOfWeek_(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"day:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "day: aNumber\x0a\x09self dayOfWeek: aNumber",
- referencedClasses: [],
- messageSends: ["dayOfWeek:"]
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "dayOfMonth",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getDate();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dayOfMonth",{},$globals.Date)});
- },
- args: [],
- source: "dayOfMonth\x0a\x09<inlineJS: 'return self.getDate()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "dayOfMonth:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setDate(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dayOfMonth:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "dayOfMonth: aNumber\x0a\x09<inlineJS: 'self.setDate(aNumber)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "dayOfWeek",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getDay() + 1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dayOfWeek",{},$globals.Date)});
- },
- args: [],
- source: "dayOfWeek\x0a\x09<inlineJS: 'return self.getDay() + 1'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "dayOfWeek:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.setDay(aNumber - 1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dayOfWeek:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "dayOfWeek: aNumber\x0a\x09<inlineJS: 'return self.setDay(aNumber - 1)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "hours",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getHours();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"hours",{},$globals.Date)});
- },
- args: [],
- source: "hours\x0a\x09<inlineJS: 'return self.getHours()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "hours:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setHours(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"hours:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "hours: aNumber\x0a\x09<inlineJS: 'self.setHours(aNumber)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "milliseconds",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getMilliseconds();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"milliseconds",{},$globals.Date)});
- },
- args: [],
- source: "milliseconds\x0a\x09<inlineJS: 'return self.getMilliseconds()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "milliseconds:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setMilliseconds(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"milliseconds:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "milliseconds: aNumber\x0a\x09<inlineJS: 'self.setMilliseconds(aNumber)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "minutes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getMinutes();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"minutes",{},$globals.Date)});
- },
- args: [],
- source: "minutes\x0a\x09<inlineJS: 'return self.getMinutes()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "minutes:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setMinutes(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"minutes:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "minutes: aNumber\x0a\x09<inlineJS: 'self.setMinutes(aNumber)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "month",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getMonth() + 1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"month",{},$globals.Date)});
- },
- args: [],
- source: "month\x0a\x09<inlineJS: 'return self.getMonth() + 1'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "month:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setMonth(aNumber - 1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"month:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "month: aNumber\x0a\x09<inlineJS: 'self.setMonth(aNumber - 1)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutAll_(self._asString());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Date)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09aStream nextPutAll: self asString",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "asString"]
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "seconds",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getSeconds();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"seconds",{},$globals.Date)});
- },
- args: [],
- source: "seconds\x0a\x09<inlineJS: 'return self.getSeconds()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "seconds:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setSeconds(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"seconds:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "seconds: aNumber\x0a\x09<inlineJS: 'self.setSeconds(aNumber)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "time",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getTime();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"time",{},$globals.Date)});
- },
- args: [],
- source: "time\x0a\x09<inlineJS: 'return self.getTime()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "time:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setTime(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"time:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "time: aNumber\x0a\x09<inlineJS: 'self.setTime(aNumber)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "year",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.getFullYear();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"year",{},$globals.Date)});
- },
- args: [],
- source: "year\x0a\x09<inlineJS: 'return self.getFullYear()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "year:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.setFullYear(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"year:",{aNumber:aNumber},$globals.Date)});
- },
- args: ["aNumber"],
- source: "year: aNumber\x0a\x09<inlineJS: 'self.setFullYear(aNumber)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "magnitude";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'magnitude'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date.klass);
- $core.addMethod(
- $core.method({
- selector: "fromMilliseconds:",
- protocol: "instance creation",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._new_(aNumber);
- }, function($ctx1) {$ctx1.fill(self,"fromMilliseconds:",{aNumber:aNumber},$globals.Date.klass)});
- },
- args: ["aNumber"],
- source: "fromMilliseconds: aNumber\x0a\x09^ self new: aNumber",
- referencedClasses: [],
- messageSends: ["new:"]
- }),
- $globals.Date.klass);
- $core.addMethod(
- $core.method({
- selector: "fromSeconds:",
- protocol: "instance creation",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._fromMilliseconds_($recv(aNumber).__star((1000)));
- }, function($ctx1) {$ctx1.fill(self,"fromSeconds:",{aNumber:aNumber},$globals.Date.klass)});
- },
- args: ["aNumber"],
- source: "fromSeconds: aNumber\x0a\x09^ self fromMilliseconds: aNumber * 1000",
- referencedClasses: [],
- messageSends: ["fromMilliseconds:", "*"]
- }),
- $globals.Date.klass);
- $core.addMethod(
- $core.method({
- selector: "fromString:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._new_(aString);
- }, function($ctx1) {$ctx1.fill(self,"fromString:",{aString:aString},$globals.Date.klass)});
- },
- args: ["aString"],
- source: "fromString: aString\x0a\x09\x22Example: Date fromString('2011/04/15 00:00:00')\x22\x0a\x09^ self new: aString",
- referencedClasses: [],
- messageSends: ["new:"]
- }),
- $globals.Date.klass);
- $core.addMethod(
- $core.method({
- selector: "millisecondsToRun:",
- protocol: "instance creation",
- fn: function (aBlock){
- var self=this;
- var t;
- return $core.withContext(function($ctx1) {
- t=$recv($globals.Date)._now();
- $ctx1.sendIdx["now"]=1;
- $recv(aBlock)._value();
- return $recv($recv($globals.Date)._now()).__minus(t);
- }, function($ctx1) {$ctx1.fill(self,"millisecondsToRun:",{aBlock:aBlock,t:t},$globals.Date.klass)});
- },
- args: ["aBlock"],
- source: "millisecondsToRun: aBlock\x0a\x09| t |\x0a\x09t := Date now.\x0a\x09aBlock value.\x0a\x09^ Date now - t",
- referencedClasses: ["Date"],
- messageSends: ["now", "value", "-"]
- }),
- $globals.Date.klass);
- $core.addMethod(
- $core.method({
- selector: "new:",
- protocol: "instance creation",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new Date(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new:",{anObject:anObject},$globals.Date.klass)});
- },
- args: ["anObject"],
- source: "new: anObject\x0a\x09<inlineJS: 'return new Date(anObject)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Date.klass);
- $core.addMethod(
- $core.method({
- selector: "now",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._today();
- }, function($ctx1) {$ctx1.fill(self,"now",{},$globals.Date.klass)});
- },
- args: [],
- source: "now\x0a\x09^ self today",
- referencedClasses: [],
- messageSends: ["today"]
- }),
- $globals.Date.klass);
- $core.addMethod(
- $core.method({
- selector: "today",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._new();
- }, function($ctx1) {$ctx1.fill(self,"today",{},$globals.Date.klass)});
- },
- args: [],
- source: "today\x0a\x09^ self new",
- referencedClasses: [],
- messageSends: ["new"]
- }),
- $globals.Date.klass);
- $core.addClass("Number", $globals.Object, [], "Kernel-Objects");
- $globals.Number.comment="I am the Amber representation for all numbers.\x0aI am directly mapped to JavaScript Number.\x0a\x0a## API\x0a\x0aI provide all necessary methods for arithmetic operations, comparison, conversion and so on with numbers.\x0a\x0aMy instances can also be used to evaluate a block a fixed number of times:\x0a\x0a\x095 timesRepeat: [ Transcript show: 'This will be printed 5 times'; cr ].\x0a\x09\x0a\x091 to: 5 do: [ :aNumber| Transcript show: aNumber asString; cr ].\x0a\x09\x0a\x091 to: 10 by: 2 do: [ :aNumber| Transcript show: aNumber asString; cr ].";
- $core.addMethod(
- $core.method({
- selector: "&",
- protocol: "converting",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self & aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"&",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "& aNumber\x0a\x09<inlineJS: 'return self & aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "*",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self * aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"*",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "* aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self * aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "**",
- protocol: "mathematical functions",
- fn: function (exponent){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._raisedTo_(exponent);
- }, function($ctx1) {$ctx1.fill(self,"**",{exponent:exponent},$globals.Number)});
- },
- args: ["exponent"],
- source: "** exponent\x0a\x09^ self raisedTo: exponent",
- referencedClasses: [],
- messageSends: ["raisedTo:"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "+",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self + aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"+",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "+ aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self + aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "-",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self - aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"-",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "- aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self - aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "/",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self / aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"/",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "/ aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self / aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "//",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self.__slash(aNumber))._floor();
- }, function($ctx1) {$ctx1.fill(self,"//",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "// aNumber\x0a\x09^ (self / aNumber) floor",
- referencedClasses: [],
- messageSends: ["floor", "/"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "<",
- protocol: "comparing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self < aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"<",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "< aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self < aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "<=",
- protocol: "comparing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self <= aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"<=",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "<= aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self <= aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "==",
- protocol: "comparing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (typeof aNumber === "number") return Number(self) === aNumber;
- else if (aNumber != null && typeof aNumber === "object") return Number(self) === aNumber.valueOf();
- else return false;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"==",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "== aNumber\x0a<inlineJS: '\x0a\x09if (typeof aNumber === \x22number\x22) return Number(self) === aNumber;\x0a\x09else if (aNumber != null && typeof aNumber === \x22object\x22) return Number(self) === aNumber.valueOf();\x0a\x09else return false;\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: ">",
- protocol: "comparing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self > aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,">",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "> aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self > aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: ">=",
- protocol: "comparing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self >= aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,">=",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: ">= aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09<inlineJS: 'return self >= aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "@",
- protocol: "converting",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Point)._x_y_(self,aNumber);
- }, function($ctx1) {$ctx1.fill(self,"@",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "@ aNumber\x0a\x09^ Point x: self y: aNumber",
- referencedClasses: ["Point"],
- messageSends: ["x:y:"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "\x5c\x5c",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self % aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"\x5c\x5c",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "\x5c\x5c aNumber\x0a\x09<inlineJS: 'return self % aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "abs",
- protocol: "arithmetic",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.abs(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"abs",{},$globals.Number)});
- },
- args: [],
- source: "abs\x0a\x09<inlineJS: 'return Math.abs(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "arcCos",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.acos(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"arcCos",{},$globals.Number)});
- },
- args: [],
- source: "arcCos\x0a\x09<inlineJS: 'return Math.acos(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "arcSin",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.asin(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"arcSin",{},$globals.Number)});
- },
- args: [],
- source: "arcSin\x0a\x09<inlineJS: 'return Math.asin(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "arcTan",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.atan(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"arcTan",{},$globals.Number)});
- },
- args: [],
- source: "arcTan\x0a\x09<inlineJS: 'return Math.atan(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("(".__comma(self._printString())).__comma(")");
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.Number)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09^ '(', self printString, ')'",
- referencedClasses: [],
- messageSends: [",", "printString"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "asNumber",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asNumber\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "asPoint",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Point)._x_y_(self,self);
- }, function($ctx1) {$ctx1.fill(self,"asPoint",{},$globals.Number)});
- },
- args: [],
- source: "asPoint\x0a\x09^ Point x: self y: self",
- referencedClasses: ["Point"],
- messageSends: ["x:y:"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "asString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asString",{},$globals.Number)});
- },
- args: [],
- source: "asString\x0a\x09<inlineJS: 'return String(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "atRandom",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($recv($recv($recv($globals.Random)._new())._next()).__star(self))._truncated()).__plus((1));
- }, function($ctx1) {$ctx1.fill(self,"atRandom",{},$globals.Number)});
- },
- args: [],
- source: "atRandom\x0a\x09^ (Random new next * self) truncated + 1",
- referencedClasses: ["Random"],
- messageSends: ["+", "truncated", "*", "next", "new"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "ceiling",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.ceil(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"ceiling",{},$globals.Number)});
- },
- args: [],
- source: "ceiling\x0a\x09<inlineJS: 'return Math.ceil(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "copy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "copy\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "cos",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.cos(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"cos",{},$globals.Number)});
- },
- args: [],
- source: "cos\x0a\x09<inlineJS: 'return Math.cos(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "deepCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._copy();
- }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},$globals.Number)});
- },
- args: [],
- source: "deepCopy\x0a\x09^ self copy",
- referencedClasses: [],
- messageSends: ["copy"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "even",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return (0).__eq(self.__backslash_backslash((2)));
- }, function($ctx1) {$ctx1.fill(self,"even",{},$globals.Number)});
- },
- args: [],
- source: "even\x0a\x09^ 0 = (self \x5c\x5c 2)",
- referencedClasses: [],
- messageSends: ["=", "\x5c\x5c"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "floor",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.floor(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"floor",{},$globals.Number)});
- },
- args: [],
- source: "floor\x0a\x09<inlineJS: 'return Math.floor(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "isNumber",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isNumber\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "isZero",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.__eq((0));
- }, function($ctx1) {$ctx1.fill(self,"isZero",{},$globals.Number)});
- },
- args: [],
- source: "isZero\x0a\x09^ self = 0",
- referencedClasses: [],
- messageSends: ["="]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "ln",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.log(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"ln",{},$globals.Number)});
- },
- args: [],
- source: "ln\x0a\x09<inlineJS: 'return Math.log(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "log",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.log(self) / Math.LN10;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"log",{},$globals.Number)});
- },
- args: [],
- source: "log\x0a\x09<inlineJS: 'return Math.log(self) / Math.LN10;'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "log:",
- protocol: "mathematical functions",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.log(self) / Math.log(aNumber);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"log:",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "log: aNumber\x0a\x09<inlineJS: 'return Math.log(self) / Math.log(aNumber);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "max:",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.max(self, aNumber);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"max:",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "max: aNumber\x0a\x09<inlineJS: 'return Math.max(self, aNumber);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "min:",
- protocol: "arithmetic",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.min(self, aNumber);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"min:",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "min: aNumber\x0a\x09<inlineJS: 'return Math.min(self, aNumber);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "negated",
- protocol: "arithmetic",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return (0).__minus(self);
- }, function($ctx1) {$ctx1.fill(self,"negated",{},$globals.Number)});
- },
- args: [],
- source: "negated\x0a\x09^ 0 - self",
- referencedClasses: [],
- messageSends: ["-"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "negative",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.__lt((0));
- }, function($ctx1) {$ctx1.fill(self,"negative",{},$globals.Number)});
- },
- args: [],
- source: "negative\x0a\x09\x22Answer whether the receiver is mathematically negative.\x22\x0a\x0a\x09^ self < 0",
- referencedClasses: [],
- messageSends: ["<"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "odd",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._even())._not();
- }, function($ctx1) {$ctx1.fill(self,"odd",{},$globals.Number)});
- },
- args: [],
- source: "odd\x0a\x09^ self even not",
- referencedClasses: [],
- messageSends: ["not", "even"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "positive",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.__gt_eq((0));
- }, function($ctx1) {$ctx1.fill(self,"positive",{},$globals.Number)});
- },
- args: [],
- source: "positive\x0a\x09\x22Answer whether the receiver is positive or equal to 0. (ST-80 protocol).\x22\x0a\x0a\x09^ self >= 0",
- referencedClasses: [],
- messageSends: [">="]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutAll_(self._asString());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Number)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09aStream nextPutAll: self asString",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "asString"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "printShowingDecimalPlaces:",
- protocol: "printing",
- fn: function (placesDesired){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toFixed(placesDesired);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printShowingDecimalPlaces:",{placesDesired:placesDesired},$globals.Number)});
- },
- args: ["placesDesired"],
- source: "printShowingDecimalPlaces: placesDesired\x0a\x09<inlineJS: 'return self.toFixed(placesDesired)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "raisedTo:",
- protocol: "mathematical functions",
- fn: function (exponent){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.pow(self, exponent);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"raisedTo:",{exponent:exponent},$globals.Number)});
- },
- args: ["exponent"],
- source: "raisedTo: exponent\x0a\x09<inlineJS: 'return Math.pow(self, exponent);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "rounded",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.round(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"rounded",{},$globals.Number)});
- },
- args: [],
- source: "rounded\x0a\x09<inlineJS: 'return Math.round(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "sign",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=self._isZero();
- if($core.assert($1)){
- return (0);
- }
- $2=self._positive();
- if($core.assert($2)){
- return (1);
- } else {
- return (-1);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sign",{},$globals.Number)});
- },
- args: [],
- source: "sign\x0a\x09self isZero \x0a\x09\x09ifTrue: [ ^ 0 ].\x0a\x09self positive\x0a\x09\x09ifTrue: [ ^ 1 ]\x0a\x09\x09ifFalse: [ ^ -1 ].",
- referencedClasses: [],
- messageSends: ["ifTrue:", "isZero", "ifTrue:ifFalse:", "positive"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "sin",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.sin(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sin",{},$globals.Number)});
- },
- args: [],
- source: "sin\x0a\x09<inlineJS: 'return Math.sin(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "sqrt",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.sqrt(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sqrt",{},$globals.Number)});
- },
- args: [],
- source: "sqrt\x0a\x09<inlineJS: 'return Math.sqrt(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "squared",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.__star(self);
- }, function($ctx1) {$ctx1.fill(self,"squared",{},$globals.Number)});
- },
- args: [],
- source: "squared\x0a\x09^ self * self",
- referencedClasses: [],
- messageSends: ["*"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "tan",
- protocol: "mathematical functions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.tan(self);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tan",{},$globals.Number)});
- },
- args: [],
- source: "tan\x0a\x09<inlineJS: 'return Math.tan(self);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "timesRepeat:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var count;
- return $core.withContext(function($ctx1) {
- count=(1);
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(count).__gt(self);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aBlock)._value();
- count=$recv(count).__plus((1));
- return count;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"timesRepeat:",{aBlock:aBlock,count:count},$globals.Number)});
- },
- args: ["aBlock"],
- source: "timesRepeat: aBlock\x0a\x09| count |\x0a\x09count := 1.\x0a\x09[ count > self ] whileFalse: [\x0a\x09\x09aBlock value.\x0a\x09\x09count := count + 1 ]",
- referencedClasses: [],
- messageSends: ["whileFalse:", ">", "value", "+"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "to:",
- protocol: "converting",
- fn: function (aNumber){
- var self=this;
- var array,first,last,count;
- return $core.withContext(function($ctx1) {
- first=self._truncated();
- $ctx1.sendIdx["truncated"]=1;
- last=$recv($recv(aNumber)._truncated()).__plus((1));
- $ctx1.sendIdx["+"]=1;
- count=(1);
- array=$recv($globals.Array)._new();
- $recv($recv(last).__minus(first))._timesRepeat_((function(){
- return $core.withContext(function($ctx2) {
- $recv(array)._at_put_(count,first);
- count=$recv(count).__plus((1));
- $ctx2.sendIdx["+"]=2;
- count;
- first=$recv(first).__plus((1));
- return first;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return array;
- }, function($ctx1) {$ctx1.fill(self,"to:",{aNumber:aNumber,array:array,first:first,last:last,count:count},$globals.Number)});
- },
- args: ["aNumber"],
- source: "to: aNumber\x0a\x09| array first last count |\x0a\x09first := self truncated.\x0a\x09last := aNumber truncated + 1.\x0a\x09count := 1.\x0a\x09array := Array new.\x0a\x09(last - first) timesRepeat: [\x0a\x09\x09array at: count put: first.\x0a\x09\x09count := count + 1.\x0a\x09\x09first := first + 1 ].\x0a\x09^ array",
- referencedClasses: ["Array"],
- messageSends: ["truncated", "+", "new", "timesRepeat:", "-", "at:put:"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "to:by:",
- protocol: "converting",
- fn: function (stop,step){
- var self=this;
- var array,value,pos;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- value=self;
- array=$recv($globals.Array)._new();
- pos=(1);
- $1=$recv(step).__eq((0));
- if($core.assert($1)){
- self._error_("step must be non-zero");
- }
- $2=$recv(step).__lt((0));
- if($core.assert($2)){
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(value).__gt_eq(stop);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- $recv(array)._at_put_(pos,value);
- $ctx2.sendIdx["at:put:"]=1;
- pos=$recv(pos).__plus((1));
- $ctx2.sendIdx["+"]=1;
- pos;
- value=$recv(value).__plus(step);
- $ctx2.sendIdx["+"]=2;
- return value;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,4)});
- }));
- $ctx1.sendIdx["whileTrue:"]=1;
- } else {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(value).__lt_eq(stop);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,6)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- $recv(array)._at_put_(pos,value);
- pos=$recv(pos).__plus((1));
- $ctx2.sendIdx["+"]=3;
- pos;
- value=$recv(value).__plus(step);
- return value;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,7)});
- }));
- }
- return array;
- }, function($ctx1) {$ctx1.fill(self,"to:by:",{stop:stop,step:step,array:array,value:value,pos:pos},$globals.Number)});
- },
- args: ["stop", "step"],
- source: "to: stop by: step\x0a\x09| array value pos |\x0a\x09value := self.\x0a\x09array := Array new.\x0a\x09pos := 1.\x0a\x09step = 0 ifTrue: [ self error: 'step must be non-zero' ].\x0a\x09step < 0\x0a\x09\x09ifTrue: [ [ value >= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09array at: pos put: value.\x0a\x09\x09\x09\x09\x09pos := pos + 1.\x0a\x09\x09\x09\x09\x09value := value + step ]]\x0a\x09\x09ifFalse: [ [ value <= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09array at: pos put: value.\x0a\x09\x09\x09\x09pos := pos + 1.\x0a\x09\x09\x09\x09\x09value := value + step ]].\x0a\x09^ array",
- referencedClasses: ["Array"],
- messageSends: ["new", "ifTrue:", "=", "error:", "ifTrue:ifFalse:", "<", "whileTrue:", ">=", "at:put:", "+", "<="]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "to:by:do:",
- protocol: "enumerating",
- fn: function (stop,step,aBlock){
- var self=this;
- var value;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- value=self;
- $1=$recv(step).__eq((0));
- if($core.assert($1)){
- self._error_("step must be non-zero");
- }
- $2=$recv(step).__lt((0));
- if($core.assert($2)){
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(value).__gt_eq(stop);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aBlock)._value_(value);
- $ctx2.sendIdx["value:"]=1;
- value=$recv(value).__plus(step);
- $ctx2.sendIdx["+"]=1;
- return value;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,4)});
- }));
- $ctx1.sendIdx["whileTrue:"]=1;
- } else {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(value).__lt_eq(stop);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,6)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aBlock)._value_(value);
- value=$recv(value).__plus(step);
- return value;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,7)});
- }));
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"to:by:do:",{stop:stop,step:step,aBlock:aBlock,value:value},$globals.Number)});
- },
- args: ["stop", "step", "aBlock"],
- source: "to: stop by: step do: aBlock\x0a\x09| value |\x0a\x09value := self.\x0a\x09step = 0 ifTrue: [ self error: 'step must be non-zero' ].\x0a\x09step < 0\x0a\x09\x09ifTrue: [ [ value >= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09aBlock value: value.\x0a\x09\x09\x09\x09\x09value := value + step ]]\x0a\x09\x09ifFalse: [ [ value <= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09aBlock value: value.\x0a\x09\x09\x09\x09\x09value := value + step ]]",
- referencedClasses: [],
- messageSends: ["ifTrue:", "=", "error:", "ifTrue:ifFalse:", "<", "whileTrue:", ">=", "value:", "+", "<="]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "to:do:",
- protocol: "enumerating",
- fn: function (stop,aBlock){
- var self=this;
- var nextValue;
- return $core.withContext(function($ctx1) {
- nextValue=self;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(nextValue).__lt_eq(stop);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aBlock)._value_(nextValue);
- nextValue=$recv(nextValue).__plus((1));
- return nextValue;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"to:do:",{stop:stop,aBlock:aBlock,nextValue:nextValue},$globals.Number)});
- },
- args: ["stop", "aBlock"],
- source: "to: stop do: aBlock\x0a\x09\x22Evaluate aBlock for each number from self to aNumber.\x22\x0a\x09| nextValue |\x0a\x09nextValue := self.\x0a\x09[ nextValue <= stop ]\x0a\x09\x09whileTrue:\x0a\x09\x09\x09[ aBlock value: nextValue.\x0a\x09\x09\x09nextValue := nextValue + 1 ]",
- referencedClasses: [],
- messageSends: ["whileTrue:", "<=", "value:", "+"]
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "truncated",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- if(self >= 0) {
- return Math.floor(self);
- } else {
- return Math.floor(self * (-1)) * (-1);
- };
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"truncated",{},$globals.Number)});
- },
- args: [],
- source: "truncated\x0a\x09<inlineJS: '\x0a\x09\x09if(self >= 0) {\x0a\x09\x09\x09return Math.floor(self);\x0a\x09\x09} else {\x0a\x09\x09\x09return Math.floor(self * (-1)) * (-1);\x0a\x09\x09};\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "|",
- protocol: "converting",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self | aNumber;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"|",{aNumber:aNumber},$globals.Number)});
- },
- args: ["aNumber"],
- source: "| aNumber\x0a\x09<inlineJS: 'return self | aNumber'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "magnitude";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'magnitude'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number.klass);
- $core.addMethod(
- $core.method({
- selector: "e",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.E;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"e",{},$globals.Number.klass)});
- },
- args: [],
- source: "e\x0a\x09<inlineJS: 'return Math.E;'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number.klass);
- $core.addMethod(
- $core.method({
- selector: "pi",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.PI;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"pi",{},$globals.Number.klass)});
- },
- args: [],
- source: "pi\x0a\x09<inlineJS: 'return Math.PI'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Number.klass);
- $core.addClass("Point", $globals.Object, ["x", "y"], "Kernel-Objects");
- $globals.Point.comment="I represent an x-y pair of numbers usually designating a geometric coordinate.\x0a\x0a## API\x0a\x0aInstances are traditionally created using the binary `#@` message to a number:\x0a\x0a\x09100@120\x0a\x0aPoints can then be arithmetically manipulated:\x0a\x0a\x09100@100 + (10@10)\x0a\x0a...or for example:\x0a\x0a\x09(100@100) * 2\x0a\x0a**NOTE:** Creating a point with a negative y-value will need a space after `@` in order to avoid a parsing error:\x0a\x0a\x09100@ -100 \x22but 100@-100 would not parse\x22";
- $core.addMethod(
- $core.method({
- selector: "*",
- protocol: "arithmetic",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$4,$3,$1,$6,$5;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $4=$recv(aPoint)._asPoint();
- $ctx1.sendIdx["asPoint"]=1;
- $3=$recv($4)._x();
- $1=$recv($2).__star($3);
- $ctx1.sendIdx["*"]=1;
- $6=self._y();
- $ctx1.sendIdx["y"]=1;
- $5=$recv($6).__star($recv($recv(aPoint)._asPoint())._y());
- return $recv($globals.Point)._x_y_($1,$5);
- }, function($ctx1) {$ctx1.fill(self,"*",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "* aPoint\x0a\x09^ Point x: self x * aPoint asPoint x y: self y * aPoint asPoint y",
- referencedClasses: ["Point"],
- messageSends: ["x:y:", "*", "x", "asPoint", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "+",
- protocol: "arithmetic",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$4,$3,$1,$6,$5;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $4=$recv(aPoint)._asPoint();
- $ctx1.sendIdx["asPoint"]=1;
- $3=$recv($4)._x();
- $1=$recv($2).__plus($3);
- $ctx1.sendIdx["+"]=1;
- $6=self._y();
- $ctx1.sendIdx["y"]=1;
- $5=$recv($6).__plus($recv($recv(aPoint)._asPoint())._y());
- return $recv($globals.Point)._x_y_($1,$5);
- }, function($ctx1) {$ctx1.fill(self,"+",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "+ aPoint\x0a\x09^ Point x: self x + aPoint asPoint x y: self y + aPoint asPoint y",
- referencedClasses: ["Point"],
- messageSends: ["x:y:", "+", "x", "asPoint", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "-",
- protocol: "arithmetic",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$4,$3,$1,$6,$5;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $4=$recv(aPoint)._asPoint();
- $ctx1.sendIdx["asPoint"]=1;
- $3=$recv($4)._x();
- $1=$recv($2).__minus($3);
- $ctx1.sendIdx["-"]=1;
- $6=self._y();
- $ctx1.sendIdx["y"]=1;
- $5=$recv($6).__minus($recv($recv(aPoint)._asPoint())._y());
- return $recv($globals.Point)._x_y_($1,$5);
- }, function($ctx1) {$ctx1.fill(self,"-",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "- aPoint\x0a\x09^ Point x: self x - aPoint asPoint x y: self y - aPoint asPoint y",
- referencedClasses: ["Point"],
- messageSends: ["x:y:", "-", "x", "asPoint", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "/",
- protocol: "arithmetic",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$4,$3,$1,$6,$5;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $4=$recv(aPoint)._asPoint();
- $ctx1.sendIdx["asPoint"]=1;
- $3=$recv($4)._x();
- $1=$recv($2).__slash($3);
- $ctx1.sendIdx["/"]=1;
- $6=self._y();
- $ctx1.sendIdx["y"]=1;
- $5=$recv($6).__slash($recv($recv(aPoint)._asPoint())._y());
- return $recv($globals.Point)._x_y_($1,$5);
- }, function($ctx1) {$ctx1.fill(self,"/",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "/ aPoint\x0a\x09^ Point x: self x / aPoint asPoint x y: self y / aPoint asPoint y",
- referencedClasses: ["Point"],
- messageSends: ["x:y:", "/", "x", "asPoint", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "<",
- protocol: "comparing",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $1=$recv($2).__lt($recv(aPoint)._x());
- $ctx1.sendIdx["<"]=1;
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- $3=self._y();
- $ctx2.sendIdx["y"]=1;
- return $recv($3).__lt($recv(aPoint)._y());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"<",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "< aPoint\x0a\x09^ self x < aPoint x and: [\x0a\x09\x09self y < aPoint y ]",
- referencedClasses: [],
- messageSends: ["and:", "<", "x", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "<=",
- protocol: "comparing",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $1=$recv($2).__lt_eq($recv(aPoint)._x());
- $ctx1.sendIdx["<="]=1;
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- $3=self._y();
- $ctx2.sendIdx["y"]=1;
- return $recv($3).__lt_eq($recv(aPoint)._y());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"<=",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "<= aPoint\x0a\x09^ self x <= aPoint x and: [\x0a\x09\x09self y <= aPoint y ]",
- referencedClasses: [],
- messageSends: ["and:", "<=", "x", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5;
- $2=$recv(aPoint)._class();
- $ctx1.sendIdx["class"]=1;
- $1=$recv($2).__eq(self._class());
- $ctx1.sendIdx["="]=1;
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- $4=$recv(aPoint)._x();
- $ctx2.sendIdx["x"]=1;
- $3=$recv($4).__eq(self._x());
- $ctx2.sendIdx["="]=2;
- $6=$recv(aPoint)._y();
- $ctx2.sendIdx["y"]=1;
- $5=$recv($6).__eq(self._y());
- return $recv($3).__and($5);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"=",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "= aPoint\x0a\x09^ aPoint class = self class and: [\x0a\x09\x09(aPoint x = self x) & (aPoint y = self y) ]",
- referencedClasses: [],
- messageSends: ["and:", "=", "class", "&", "x", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: ">",
- protocol: "comparing",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $1=$recv($2).__gt($recv(aPoint)._x());
- $ctx1.sendIdx[">"]=1;
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- $3=self._y();
- $ctx2.sendIdx["y"]=1;
- return $recv($3).__gt($recv(aPoint)._y());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,">",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: "> aPoint\x0a\x09^ self x > aPoint x and: [\x0a\x09\x09self y > aPoint y ]",
- referencedClasses: [],
- messageSends: ["and:", ">", "x", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: ">=",
- protocol: "comparing",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3;
- $2=self._x();
- $ctx1.sendIdx["x"]=1;
- $1=$recv($2).__gt_eq($recv(aPoint)._x());
- $ctx1.sendIdx[">="]=1;
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- $3=self._y();
- $ctx2.sendIdx["y"]=1;
- return $recv($3).__gt_eq($recv(aPoint)._y());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,">=",{aPoint:aPoint},$globals.Point)});
- },
- args: ["aPoint"],
- source: ">= aPoint\x0a\x09^ self x >= aPoint x and: [\x0a\x09\x09self y >= aPoint y ]",
- referencedClasses: [],
- messageSends: ["and:", ">=", "x", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "asPoint",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asPoint\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "dist:",
- protocol: "transforming",
- fn: function (aPoint){
- var self=this;
- var dx,dy;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- dx=$recv($recv(aPoint)._x()).__minus(self["@x"]);
- $ctx1.sendIdx["-"]=1;
- dy=$recv($recv(aPoint)._y()).__minus(self["@y"]);
- $2=$recv(dx).__star(dx);
- $ctx1.sendIdx["*"]=1;
- $1=$recv($2).__plus($recv(dy).__star(dy));
- return $recv($1)._sqrt();
- }, function($ctx1) {$ctx1.fill(self,"dist:",{aPoint:aPoint,dx:dx,dy:dy},$globals.Point)});
- },
- args: ["aPoint"],
- source: "dist: aPoint \x0a\x09\x22Answer the distance between aPoint and the receiver.\x22\x0a\x09| dx dy |\x0a\x09dx := aPoint x - x.\x0a\x09dy := aPoint y - y.\x0a\x09^ (dx * dx + (dy * dy)) sqrt",
- referencedClasses: [],
- messageSends: ["-", "x", "y", "sqrt", "+", "*"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(self["@x"])._printOn_(aStream);
- $ctx1.sendIdx["printOn:"]=1;
- $recv(aStream)._nextPutAll_("@");
- $1=$recv($recv(self["@y"])._notNil())._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@y"])._negative();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- if($core.assert($1)){
- $recv(aStream)._space();
- }
- $recv(self["@y"])._printOn_(aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Point)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09\x22Print receiver in classic x@y notation.\x22\x0a\x0a\x09x printOn: aStream.\x0a\x09\x0a\x09aStream nextPutAll: '@'.\x0a\x09(y notNil and: [ y negative ]) ifTrue: [\x0a\x09\x09\x09\x22Avoid ambiguous @- construct\x22\x0a\x09\x09\x09aStream space ].\x0a\x09\x0a\x09y printOn: aStream",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "ifTrue:", "and:", "notNil", "negative", "space"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "translateBy:",
- protocol: "transforming",
- fn: function (delta){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($recv(delta)._x()).__plus(self["@x"]);
- $ctx1.sendIdx["+"]=1;
- return $recv($1).__at($recv($recv(delta)._y()).__plus(self["@y"]));
- }, function($ctx1) {$ctx1.fill(self,"translateBy:",{delta:delta},$globals.Point)});
- },
- args: ["delta"],
- source: "translateBy: delta\x0a\x09\x22Answer a Point translated by delta (an instance of Point).\x22\x0a\x09^ (delta x + x) @ (delta y + y)",
- referencedClasses: [],
- messageSends: ["@", "+", "x", "y"]
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "x",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@x"];
- },
- args: [],
- source: "x\x0a\x09^ x",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "x:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- self["@x"]=aNumber;
- return self;
- },
- args: ["aNumber"],
- source: "x: aNumber\x0a\x09x := aNumber",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "y",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@y"];
- },
- args: [],
- source: "y\x0a\x09^ y",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "y:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- self["@y"]=aNumber;
- return self;
- },
- args: ["aNumber"],
- source: "y: aNumber\x0a\x09y := aNumber",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Point);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "magnitude";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'magnitude'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Point.klass);
- $core.addMethod(
- $core.method({
- selector: "x:y:",
- protocol: "instance creation",
- fn: function (aNumber,anotherNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._x_(aNumber);
- $recv($1)._y_(anotherNumber);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"x:y:",{aNumber:aNumber,anotherNumber:anotherNumber},$globals.Point.klass)});
- },
- args: ["aNumber", "anotherNumber"],
- source: "x: aNumber y: anotherNumber\x0a\x09^ self new\x0a\x09\x09x: aNumber;\x0a\x09\x09y: anotherNumber;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["x:", "new", "y:", "yourself"]
- }),
- $globals.Point.klass);
- $core.addClass("Random", $globals.Object, [], "Kernel-Objects");
- $globals.Random.comment="I an used to generate a random number and I am implemented as a trivial wrapper around javascript `Math.random()`.\x0a\x0a## API\x0a\x0aThe typical use case it to use the `#next` method like the following:\x0a\x0a\x09Random new next\x0a\x0aThis will return a float x where x < 1 and x > 0. If you want a random integer from 1 to 10 you can use `#atRandom`\x0a\x0a\x0910 atRandom\x0a\x0aA random number in a specific interval can be obtained with the following:\x0a\x0a\x09(3 to: 7) atRandom\x0a\x0aBe aware that `#to:` does not create an Interval as in other Smalltalk implementations but in fact an `Array` of numbers, so it's better to use:\x0a\x0a\x095 atRandom + 2\x0a\x0aSince `#atRandom` is implemented in `SequencableCollection` you can easy pick an element at random:\x0a\x0a\x09#('a' 'b' 'c') atRandom\x0a\x0aAs well as letter from a `String`:\x0a\x0a\x09'abc' atRandom\x0a\x0aSince Amber does not have Characters this will return a `String` of length 1 like for example `'b'`.";
- $core.addMethod(
- $core.method({
- selector: "next",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Math.random();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"next",{},$globals.Random)});
- },
- args: [],
- source: "next\x0a\x09<inlineJS: 'return Math.random()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Random);
- $core.addMethod(
- $core.method({
- selector: "next:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv((1)._to_(anInteger))._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return self._next();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"next:",{anInteger:anInteger},$globals.Random)});
- },
- args: ["anInteger"],
- source: "next: anInteger\x0a\x09^ (1 to: anInteger) collect: [ :each | self next ]",
- referencedClasses: [],
- messageSends: ["collect:", "to:", "next"]
- }),
- $globals.Random);
- $core.addClass("UndefinedObject", $globals.Object, [], "Kernel-Objects");
- $globals.UndefinedObject.comment="I describe the behavior of my sole instance, `nil`. `nil` represents a prior value for variables that have not been initialized, or for results which are meaningless.\x0a\x0a`nil` is the Smalltalk equivalent of the `undefined` JavaScript object.\x0a\x0a__note:__ When sending messages to the `undefined` JavaScript object, it will be replaced by `nil`.";
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return null;
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ null",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "deepCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "deepCopy\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "ifNil:",
- protocol: "testing",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._ifNil_ifNotNil_(aBlock,(function(){
- }));
- }, function($ctx1) {$ctx1.fill(self,"ifNil:",{aBlock:aBlock},$globals.UndefinedObject)});
- },
- args: ["aBlock"],
- source: "ifNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ self ifNil: aBlock ifNotNil: []",
- referencedClasses: [],
- messageSends: ["ifNil:ifNotNil:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "ifNil:ifNotNil:",
- protocol: "testing",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aBlock)._value();
- }, function($ctx1) {$ctx1.fill(self,"ifNil:ifNotNil:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.UndefinedObject)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifNil: aBlock ifNotNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ aBlock value",
- referencedClasses: [],
- messageSends: ["value"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "ifNotNil:",
- protocol: "testing",
- fn: function (aBlock){
- var self=this;
- return self;
- },
- args: ["aBlock"],
- source: "ifNotNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "ifNotNil:ifNil:",
- protocol: "testing",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anotherBlock)._value();
- }, function($ctx1) {$ctx1.fill(self,"ifNotNil:ifNil:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.UndefinedObject)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifNotNil: aBlock ifNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^ anotherBlock value",
- referencedClasses: [],
- messageSends: ["value"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "isNil",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isNil\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "notNil",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "notNil\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutAll_("nil");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.UndefinedObject)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09aStream nextPutAll: 'nil'",
- referencedClasses: [],
- messageSends: ["nextPutAll:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "shallowCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "shallowCopy\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._error_("You cannot create new instances of UndefinedObject. Use nil");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.UndefinedObject.klass)});
- },
- args: [],
- source: "new\x0a\x09\x09self error: 'You cannot create new instances of UndefinedObject. Use nil'",
- referencedClasses: [],
- messageSends: ["error:"]
- }),
- $globals.UndefinedObject.klass);
- });
- define('amber_core/Kernel-Collections',["amber/boot", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Collections");
- $core.packages["Kernel-Collections"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Collections"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("Association", $globals.Object, ["key", "value"], "Kernel-Collections");
- $globals.Association.comment="I represent a pair of associated objects, a key and a value. My instances can serve as entries in a dictionary.\x0a\x0aInstances can be created with the class-side method `#key:value:`";
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (anAssociation){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$5,$4,$6,$1;
- $3=self._class();
- $ctx1.sendIdx["class"]=1;
- $2=$recv($3).__eq($recv(anAssociation)._class());
- $ctx1.sendIdx["="]=1;
- $1=$recv($2)._and_((function(){
- return $core.withContext(function($ctx2) {
- $5=self._key();
- $ctx2.sendIdx["key"]=1;
- $4=$recv($5).__eq($recv(anAssociation)._key());
- $ctx2.sendIdx["="]=2;
- return $recv($4)._and_((function(){
- return $core.withContext(function($ctx3) {
- $6=self._value();
- $ctx3.sendIdx["value"]=1;
- return $recv($6).__eq($recv(anAssociation)._value());
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["and:"]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"=",{anAssociation:anAssociation},$globals.Association)});
- },
- args: ["anAssociation"],
- source: "= anAssociation\x0a\x09^ self class = anAssociation class and: [\x0a\x09\x09self key = anAssociation key and: [\x0a\x09\x09self value = anAssociation value ]]",
- referencedClasses: [],
- messageSends: ["and:", "=", "class", "key", "value"]
- }),
- $globals.Association);
- $core.addMethod(
- $core.method({
- selector: "key",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@key"];
- },
- args: [],
- source: "key\x0a\x09^ key",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Association);
- $core.addMethod(
- $core.method({
- selector: "key:",
- protocol: "accessing",
- fn: function (aKey){
- var self=this;
- self["@key"]=aKey;
- return self;
- },
- args: ["aKey"],
- source: "key: aKey\x0a\x09key := aKey",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Association);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._key())._printOn_(aStream);
- $ctx1.sendIdx["printOn:"]=1;
- $recv(aStream)._nextPutAll_(" -> ");
- $recv(self._value())._printOn_(aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Association)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09self key printOn: aStream.\x0a\x09aStream nextPutAll: ' -> '.\x0a\x09self value printOn: aStream",
- referencedClasses: [],
- messageSends: ["printOn:", "key", "nextPutAll:", "value"]
- }),
- $globals.Association);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@value"];
- },
- args: [],
- source: "value\x0a\x09^ value",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Association);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "accessing",
- fn: function (aValue){
- var self=this;
- self["@value"]=aValue;
- return self;
- },
- args: ["aValue"],
- source: "value: aValue\x0a\x09value := aValue",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Association);
- $core.addMethod(
- $core.method({
- selector: "key:value:",
- protocol: "instance creation",
- fn: function (aKey,aValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._key_(aKey);
- $recv($1)._value_(aValue);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"key:value:",{aKey:aKey,aValue:aValue},$globals.Association.klass)});
- },
- args: ["aKey", "aValue"],
- source: "key: aKey value: aValue\x0a\x09\x09^ self new\x0a\x09\x09key: aKey;\x0a\x09\x09value: aValue;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["key:", "new", "value:", "yourself"]
- }),
- $globals.Association.klass);
- $core.addClass("BucketStore", $globals.Object, ["buckets", "hashBlock"], "Kernel-Collections");
- $globals.BucketStore.comment="I am an helper class for hash-based stores.\x0a\x0aI hold buckets which are selected by a hash, specified using `#hashBlock:`.\x0aThe hash can be any object, and\x0ait is used as a JS property (that is, in ES5\x0aits toString() value counts).\x0a\x0a## API\x0aI maintain a list of buckets. Client code can use this API:\x0a - `#bucketOfElement:` (to ask a bucket for element, I can return JS null if n/a)\x0a - `#do:` (to enumerate all elements of all buckets)\x0a - `#removeAll` (to remove all buckets)\x0a\x0aClient code itself should add/remove elements\x0ain a bucket. The `nil` object should not be put into any bucket.\x0a\x0aTypes of buckets are the responsibility of subclasses via `#newBucket`.";
- $core.addMethod(
- $core.method({
- selector: "bucketOfElement:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var hash = self['@hashBlock'](anObject);
- if (!hash) return null;
- var buckets = self['@buckets'],
- bucket = buckets[hash];
- if (!bucket) { bucket = buckets[hash] = self._newBucket(); }
- return bucket;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"bucketOfElement:",{anObject:anObject},$globals.BucketStore)});
- },
- args: ["anObject"],
- source: "bucketOfElement: anObject\x0a\x09<inlineJS: '\x0a\x09\x09var hash = self[''@hashBlock''](anObject);\x0a\x09\x09if (!hash) return null;\x0a\x09\x09var buckets = self[''@buckets''],\x0a\x09\x09\x09bucket = buckets[hash];\x0a\x09\x09if (!bucket) { bucket = buckets[hash] = self._newBucket(); }\x0a\x09\x09return bucket;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BucketStore);
- $core.addMethod(
- $core.method({
- selector: "do:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var buckets = self['@buckets'];
- var keys = Object.keys(buckets);
- for (var i = 0; i < keys.length; ++i) { buckets[keys[i]]._do_(aBlock); }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},$globals.BucketStore)});
- },
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09var buckets = self[''@buckets''];\x0a\x09\x09var keys = Object.keys(buckets);\x0a\x09\x09for (var i = 0; i < keys.length; ++i) { buckets[keys[i]]._do_(aBlock); }\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BucketStore);
- $core.addMethod(
- $core.method({
- selector: "hashBlock:",
- protocol: "accessing",
- fn: function (aBlock){
- var self=this;
- self["@hashBlock"]=aBlock;
- return self;
- },
- args: ["aBlock"],
- source: "hashBlock: aBlock\x0a\x09hashBlock := aBlock",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BucketStore);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.BucketStore.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self._removeAll();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.BucketStore)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09self removeAll",
- referencedClasses: [],
- messageSends: ["initialize", "removeAll"]
- }),
- $globals.BucketStore);
- $core.addMethod(
- $core.method({
- selector: "newBucket",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"newBucket",{},$globals.BucketStore)});
- },
- args: [],
- source: "newBucket\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.BucketStore);
- $core.addMethod(
- $core.method({
- selector: "removeAll",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self['@buckets'] = Object.create(null);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeAll",{},$globals.BucketStore)});
- },
- args: [],
- source: "removeAll\x0a\x09<inlineJS: 'self[''@buckets''] = Object.create(null);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BucketStore);
- $core.addMethod(
- $core.method({
- selector: "hashBlock:",
- protocol: "instance creation",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._hashBlock_(aBlock);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"hashBlock:",{aBlock:aBlock},$globals.BucketStore.klass)});
- },
- args: ["aBlock"],
- source: "hashBlock: aBlock\x0a\x09^ self new\x0a\x09\x09hashBlock: aBlock;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["hashBlock:", "new", "yourself"]
- }),
- $globals.BucketStore.klass);
- $core.addClass("ArrayBucketStore", $globals.BucketStore, [], "Kernel-Collections");
- $globals.ArrayBucketStore.comment="I am a concrete `BucketStore` with buckets being instance of `Array`.";
- $core.addMethod(
- $core.method({
- selector: "newBucket",
- protocol: "private",
- fn: function (){
- var self=this;
- return [];
- },
- args: [],
- source: "newBucket\x0a\x09^ #()",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayBucketStore);
- $core.addClass("Collection", $globals.Object, [], "Kernel-Collections");
- $globals.Collection.comment="I am the abstract superclass of all classes that represent a group of elements.\x0a\x0aI provide a set of useful methods to the Collection hierarchy such as enumerating and converting methods.";
- $core.addMethod(
- $core.method({
- selector: ",",
- protocol: "copying",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._copy();
- $recv($1)._addAll_(aCollection);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,",",{aCollection:aCollection},$globals.Collection)});
- },
- args: ["aCollection"],
- source: ", aCollection\x0a\x09^ self copy\x0a\x09\x09addAll: aCollection;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["addAll:", "copy", "yourself"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "add:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject},$globals.Collection)});
- },
- args: ["anObject"],
- source: "add: anObject\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "addAll:",
- protocol: "adding/removing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return aCollection;
- }, function($ctx1) {$ctx1.fill(self,"addAll:",{aCollection:aCollection},$globals.Collection)});
- },
- args: ["aCollection"],
- source: "addAll: aCollection\x0a\x09aCollection do: [ :each |\x0a\x09\x09self add: each ].\x0a\x09^ aCollection",
- referencedClasses: [],
- messageSends: ["do:", "add:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "allSatisfy:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(aBlock)._value_(each);
- if(!$core.assert($1)){
- throw $early=[false];
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return true;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"allSatisfy:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "allSatisfy: aBlock\x0a\x09\x22Evaluate aBlock with the elements of the receiver.\x0a\x09If aBlock returns false for any element return false.\x0a\x09Otherwise return true.\x22\x0a\x0a\x09self do: [ :each | (aBlock value: each) ifFalse: [ ^ false ] ].\x0a\x09^ true",
- referencedClasses: [],
- messageSends: ["do:", "ifFalse:", "value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "anyOne",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $early={};
- try {
- self._ifEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return self._error_("Collection is empty");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- self._do_((function(each){
- throw $early=[each];
- }));
- return self;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"anyOne",{},$globals.Collection)});
- },
- args: [],
- source: "anyOne\x0a\x09\x22Answer a representative sample of the receiver. This method can\x0a\x09be helpful when needing to preinfer the nature of the contents of \x0a\x09semi-homogeneous collections.\x22\x0a\x0a\x09self ifEmpty: [ self error: 'Collection is empty' ].\x0a\x09self do: [ :each | ^ each ]",
- referencedClasses: [],
- messageSends: ["ifEmpty:", "error:", "do:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "anySatisfy:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(aBlock)._value_(each);
- if($core.assert($1)){
- throw $early=[true];
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return false;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"anySatisfy:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "anySatisfy: aBlock\x0a\x09\x22Evaluate aBlock with the elements of the receiver.\x0a\x09If aBlock returns true for any element return true.\x0a\x09Otherwise return false.\x22\x0a\x0a\x09self do: [ :each | (aBlock value: each) ifTrue: [ ^ true ] ].\x0a\x09^ false",
- referencedClasses: [],
- messageSends: ["do:", "ifTrue:", "value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "asArray",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Array)._withAll_(self);
- }, function($ctx1) {$ctx1.fill(self,"asArray",{},$globals.Collection)});
- },
- args: [],
- source: "asArray\x0a\x09^ Array withAll: self",
- referencedClasses: ["Array"],
- messageSends: ["withAll:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asArray())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._asJavaScriptObject();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptObject",{},$globals.Collection)});
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ self asArray collect: [ :each | each asJavaScriptObject ]",
- referencedClasses: [],
- messageSends: ["collect:", "asArray", "asJavaScriptObject"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "asOrderedCollection",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._asArray();
- }, function($ctx1) {$ctx1.fill(self,"asOrderedCollection",{},$globals.Collection)});
- },
- args: [],
- source: "asOrderedCollection\x0a\x09^ self asArray",
- referencedClasses: [],
- messageSends: ["asArray"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "asSet",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Set)._withAll_(self);
- }, function($ctx1) {$ctx1.fill(self,"asSet",{},$globals.Collection)});
- },
- args: [],
- source: "asSet\x0a\x09^ Set withAll: self",
- referencedClasses: ["Set"],
- messageSends: ["withAll:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "collect:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var stream;
- return $core.withContext(function($ctx1) {
- stream=$recv($recv(self._class())._new())._writeStream();
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(stream)._nextPut_($recv(aBlock)._value_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return $recv(stream)._contents();
- }, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock,stream:stream},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "collect: aBlock\x0a\x09| stream |\x0a\x09stream := self class new writeStream.\x0a\x09self do: [ :each |\x0a\x09\x09stream nextPut: (aBlock value: each) ].\x0a\x09^ stream contents",
- referencedClasses: [],
- messageSends: ["writeStream", "new", "class", "do:", "nextPut:", "value:", "contents"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "copyWith:",
- protocol: "copying",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._copy();
- $recv($1)._add_(anObject);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"copyWith:",{anObject:anObject},$globals.Collection)});
- },
- args: ["anObject"],
- source: "copyWith: anObject\x0a\x09^ self copy add: anObject; yourself",
- referencedClasses: [],
- messageSends: ["add:", "copy", "yourself"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "copyWithAll:",
- protocol: "copying",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._copy();
- $recv($1)._addAll_(aCollection);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"copyWithAll:",{aCollection:aCollection},$globals.Collection)});
- },
- args: ["aCollection"],
- source: "copyWithAll: aCollection\x0a\x09^ self copy addAll: aCollection; yourself",
- referencedClasses: [],
- messageSends: ["addAll:", "copy", "yourself"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "copyWithout:",
- protocol: "copying",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._reject_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__eq(anObject);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"copyWithout:",{anObject:anObject},$globals.Collection)});
- },
- args: ["anObject"],
- source: "copyWithout: anObject\x0a\x09\x22Answer a copy of the receiver that does not contain\x0a\x09any occurrences of anObject.\x22\x0a\x0a\x09^ self reject: [ :each | each = anObject ]",
- referencedClasses: [],
- messageSends: ["reject:", "="]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "copyWithoutAll:",
- protocol: "copying",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._reject_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(aCollection)._includes_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"copyWithoutAll:",{aCollection:aCollection},$globals.Collection)});
- },
- args: ["aCollection"],
- source: "copyWithoutAll: aCollection\x0a\x09\x22Answer a copy of the receiver that does not contain any elements\x0a\x09equal to those in aCollection.\x22\x0a\x0a\x09^ self reject: [ :each | aCollection includes: each ]",
- referencedClasses: [],
- messageSends: ["reject:", "includes:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "deepCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._deepCopy();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},$globals.Collection)});
- },
- args: [],
- source: "deepCopy\x0a\x09^ self collect: [ :each | each deepCopy ]",
- referencedClasses: [],
- messageSends: ["collect:", "deepCopy"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "detect:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._detect_ifNone_(aBlock,(function(){
- return $core.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"detect:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "detect: aBlock\x0a\x09^ self detect: aBlock ifNone: [ self errorNotFound ]",
- referencedClasses: [],
- messageSends: ["detect:ifNone:", "errorNotFound"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "detect:ifNone:",
- protocol: "enumerating",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"detect:ifNone:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.Collection)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "detect: aBlock ifNone: anotherBlock\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "do:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "do:separatedBy:",
- protocol: "enumerating",
- fn: function (aBlock,anotherBlock){
- var self=this;
- var actionBeforeElement;
- return $core.withContext(function($ctx1) {
- actionBeforeElement=(function(){
- actionBeforeElement=anotherBlock;
- return actionBeforeElement;
- });
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $recv(actionBeforeElement)._value();
- return $recv(aBlock)._value_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:separatedBy:",{aBlock:aBlock,anotherBlock:anotherBlock,actionBeforeElement:actionBeforeElement},$globals.Collection)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "do: aBlock separatedBy: anotherBlock\x0a\x09| actionBeforeElement |\x0a\x09actionBeforeElement := [ actionBeforeElement := anotherBlock ].\x0a\x09self do: [ :each |\x0a\x09\x09actionBeforeElement value.\x0a\x09\x09aBlock value: each ]",
- referencedClasses: [],
- messageSends: ["do:", "value", "value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "errorNotFound",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._error_("Object is not in the collection");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"errorNotFound",{},$globals.Collection)});
- },
- args: [],
- source: "errorNotFound\x0a\x09self error: 'Object is not in the collection'",
- referencedClasses: [],
- messageSends: ["error:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "ifEmpty:",
- protocol: "testing",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._isEmpty();
- if($core.assert($1)){
- return $recv(aBlock)._value();
- } else {
- return self;
- }
- }, function($ctx1) {$ctx1.fill(self,"ifEmpty:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "ifEmpty: aBlock\x0a\x09\x22Evaluate the given block with the receiver as argument, answering its value if the receiver is empty, otherwise answer the receiver. \x0a\x09Note that the fact that this method returns its argument in case the receiver is not empty allows one to write expressions like the following ones: \x0a\x09\x09self classifyMethodAs:\x0a\x09\x09\x09(myProtocol ifEmpty: ['As yet unclassified'])\x22\x0a\x09^ self isEmpty\x0a\x09\x09ifTrue: \x22aBlock\x22 [ aBlock value ]\x0a\x09\x09ifFalse: [ self ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "isEmpty", "value"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "ifEmpty:ifNotEmpty:",
- protocol: "testing",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._isEmpty();
- if($core.assert($1)){
- return $recv(aBlock)._value();
- } else {
- return $recv(anotherBlock)._value_(self);
- }
- }, function($ctx1) {$ctx1.fill(self,"ifEmpty:ifNotEmpty:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.Collection)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifEmpty: aBlock ifNotEmpty: anotherBlock\x0a\x09^ self isEmpty\x0a\x09\x09ifTrue: \x22aBlock\x22 [ aBlock value ]\x0a\x09\x09ifFalse: [ anotherBlock value: self ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "isEmpty", "value", "value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "ifNotEmpty:",
- protocol: "testing",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._notEmpty();
- if($core.assert($1)){
- return $recv(aBlock)._value_(self);
- } else {
- return self;
- }
- }, function($ctx1) {$ctx1.fill(self,"ifNotEmpty:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "ifNotEmpty: aBlock\x0a\x09^ self notEmpty\x0a\x09\x09ifTrue: [ aBlock value: self ]\x0a\x09\x09ifFalse: [ self ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "notEmpty", "value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "ifNotEmpty:ifEmpty:",
- protocol: "testing",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._notEmpty();
- if($core.assert($1)){
- return $recv(aBlock)._value_(self);
- } else {
- return $recv(anotherBlock)._value();
- }
- }, function($ctx1) {$ctx1.fill(self,"ifNotEmpty:ifEmpty:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.Collection)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "ifNotEmpty: aBlock ifEmpty: anotherBlock\x0a\x09^ self notEmpty\x0a\x09\x09ifTrue: [ aBlock value: self ]\x0a\x09\x09ifFalse: \x22anotherBlock\x22 [ anotherBlock value ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "notEmpty", "value:", "value"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "includes:",
- protocol: "testing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._anySatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__eq(anObject);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},$globals.Collection)});
- },
- args: ["anObject"],
- source: "includes: anObject\x0a\x09^ self anySatisfy: [ :each | each = anObject ]",
- referencedClasses: [],
- messageSends: ["anySatisfy:", "="]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "inject:into:",
- protocol: "enumerating",
- fn: function (anObject,aBlock){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- result=anObject;
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- result=$recv(aBlock)._value_value_(result,each);
- return result;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return result;
- }, function($ctx1) {$ctx1.fill(self,"inject:into:",{anObject:anObject,aBlock:aBlock,result:result},$globals.Collection)});
- },
- args: ["anObject", "aBlock"],
- source: "inject: anObject into: aBlock\x0a\x09| result |\x0a\x09result := anObject.\x0a\x09self do: [ :each |\x0a\x09\x09result := aBlock value: result value: each ].\x0a\x09^ result",
- referencedClasses: [],
- messageSends: ["do:", "value:value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "intersection:",
- protocol: "enumerating",
- fn: function (aCollection){
- var self=this;
- var set,outputSet;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- set=self._asSet();
- outputSet=$recv($globals.Set)._new();
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $2=$recv(set)._includes_(each);
- $ctx2.sendIdx["includes:"]=1;
- $1=$recv($2)._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv(outputSet)._includes_(each))._not();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- if($core.assert($1)){
- return $recv(outputSet)._add_(each);
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return $recv(self._class())._withAll_($recv(outputSet)._asArray());
- }, function($ctx1) {$ctx1.fill(self,"intersection:",{aCollection:aCollection,set:set,outputSet:outputSet},$globals.Collection)});
- },
- args: ["aCollection"],
- source: "intersection: aCollection\x0a\x09\x22Answer the set theoretic intersection of two collections.\x22\x0a\x0a\x09| set outputSet |\x0a\x09\x0a\x09set := self asSet.\x0a\x09outputSet := Set new.\x0a\x09\x0a\x09aCollection do: [ :each |\x0a\x09\x09((set includes: each) and: [ (outputSet includes: each) not ])\x0a\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09outputSet add: each ]].\x0a\x09\x09\x0a\x09^ self class withAll: outputSet asArray",
- referencedClasses: ["Set"],
- messageSends: ["asSet", "new", "do:", "ifTrue:", "and:", "includes:", "not", "add:", "withAll:", "class", "asArray"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "isEmpty",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._size()).__eq((0));
- }, function($ctx1) {$ctx1.fill(self,"isEmpty",{},$globals.Collection)});
- },
- args: [],
- source: "isEmpty\x0a\x09^ self size = 0",
- referencedClasses: [],
- messageSends: ["=", "size"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "noneSatisfy:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- self._do_((function(item){
- return $core.withContext(function($ctx2) {
- $1=$recv(aBlock)._value_(item);
- if($core.assert($1)){
- throw $early=[false];
- }
- }, function($ctx2) {$ctx2.fillBlock({item:item},$ctx1,1)});
- }));
- return true;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"noneSatisfy:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "noneSatisfy: aBlock\x0a\x09\x22Evaluate aBlock with the elements of the receiver.\x0a\x09If aBlock returns false for all elements return true.\x0a\x09Otherwise return false\x22\x0a\x0a\x09self do: [ :item | (aBlock value: item) ifTrue: [ ^ false ] ].\x0a\x09^ true",
- referencedClasses: [],
- messageSends: ["do:", "ifTrue:", "value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "notEmpty",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._isEmpty())._not();
- }, function($ctx1) {$ctx1.fill(self,"notEmpty",{},$globals.Collection)});
- },
- args: [],
- source: "notEmpty\x0a\x09^ self isEmpty not",
- referencedClasses: [],
- messageSends: ["not", "isEmpty"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "occurrencesOf:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- var tally;
- return $core.withContext(function($ctx1) {
- var $1;
- tally=(0);
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(anObject).__eq(each);
- if($core.assert($1)){
- tally=$recv(tally).__plus((1));
- return tally;
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return tally;
- }, function($ctx1) {$ctx1.fill(self,"occurrencesOf:",{anObject:anObject,tally:tally},$globals.Collection)});
- },
- args: ["anObject"],
- source: "occurrencesOf: anObject\x0a\x09\x22Answer how many of the receiver's elements are equal to anObject.\x22\x0a\x0a\x09| tally |\x0a\x09tally := 0.\x0a\x09self do: [ :each | anObject = each ifTrue: [ tally := tally + 1 ]].\x0a\x09^ tally",
- referencedClasses: [],
- messageSends: ["do:", "ifTrue:", "=", "+"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "putOn:",
- protocol: "streaming",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._putOn_(aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"putOn:",{aStream:aStream},$globals.Collection)});
- },
- args: ["aStream"],
- source: "putOn: aStream\x0a\x09self do: [ :each | each putOn: aStream ]",
- referencedClasses: [],
- messageSends: ["do:", "putOn:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "reject:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(aBlock)._value_(each)).__eq(false);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"reject:",{aBlock:aBlock},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "reject: aBlock\x0a\x09^ self select: [ :each | (aBlock value: each) = false ]",
- referencedClasses: [],
- messageSends: ["select:", "=", "value:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "remove:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._remove_ifAbsent_(anObject,(function(){
- return $core.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"remove:",{anObject:anObject},$globals.Collection)});
- },
- args: ["anObject"],
- source: "remove: anObject\x0a\x09^ self remove: anObject ifAbsent: [ self errorNotFound ]",
- referencedClasses: [],
- messageSends: ["remove:ifAbsent:", "errorNotFound"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "remove:ifAbsent:",
- protocol: "adding/removing",
- fn: function (anObject,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"remove:ifAbsent:",{anObject:anObject,aBlock:aBlock},$globals.Collection)});
- },
- args: ["anObject", "aBlock"],
- source: "remove: anObject ifAbsent: aBlock\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "removeAll",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeAll",{},$globals.Collection)});
- },
- args: [],
- source: "removeAll\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "select:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var stream;
- return $core.withContext(function($ctx1) {
- var $1;
- stream=$recv($recv(self._class())._new())._writeStream();
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(aBlock)._value_(each);
- if($core.assert($1)){
- return $recv(stream)._nextPut_(each);
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return $recv(stream)._contents();
- }, function($ctx1) {$ctx1.fill(self,"select:",{aBlock:aBlock,stream:stream},$globals.Collection)});
- },
- args: ["aBlock"],
- source: "select: aBlock\x0a\x09| stream |\x0a\x09stream := self class new writeStream.\x0a\x09self do: [ :each |\x0a\x09\x09(aBlock value: each) ifTrue: [\x0a\x09\x09stream nextPut: each ] ].\x0a\x09^ stream contents",
- referencedClasses: [],
- messageSends: ["writeStream", "new", "class", "do:", "ifTrue:", "value:", "nextPut:", "contents"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "select:thenCollect:",
- protocol: "enumerating",
- fn: function (selectBlock,collectBlock){
- var self=this;
- var stream;
- return $core.withContext(function($ctx1) {
- var $1;
- stream=$recv($recv(self._class())._new())._writeStream();
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(selectBlock)._value_(each);
- $ctx2.sendIdx["value:"]=1;
- if($core.assert($1)){
- return $recv(stream)._nextPut_($recv(collectBlock)._value_(each));
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return $recv(stream)._contents();
- }, function($ctx1) {$ctx1.fill(self,"select:thenCollect:",{selectBlock:selectBlock,collectBlock:collectBlock,stream:stream},$globals.Collection)});
- },
- args: ["selectBlock", "collectBlock"],
- source: "select: selectBlock thenCollect: collectBlock\x0a\x09| stream |\x0a\x09stream := self class new writeStream.\x0a\x09self do: [ :each |\x0a\x09\x09(selectBlock value: each) ifTrue: [\x0a\x09\x09stream nextPut: (collectBlock value: each) ] ].\x0a\x09^ stream contents",
- referencedClasses: [],
- messageSends: ["writeStream", "new", "class", "do:", "ifTrue:", "value:", "nextPut:", "contents"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "shallowCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._collect_((function(each){
- return each;
- }));
- }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{},$globals.Collection)});
- },
- args: [],
- source: "shallowCopy\x0a\x09^ self collect: [ :each | each ]",
- referencedClasses: [],
- messageSends: ["collect:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "single",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- self._ifEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return self._error_("Collection is empty");
- $ctx2.sendIdx["error:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $1=$recv(self._size()).__gt((1));
- if($core.assert($1)){
- self._error_("Collection holds more than one element");
- }
- return self._anyOne();
- }, function($ctx1) {$ctx1.fill(self,"single",{},$globals.Collection)});
- },
- args: [],
- source: "single\x0a\x09\x22Answer a single element.\x0a\x09Raise an error if collection holds less or more than one element.\x22\x0a\x0a\x09self ifEmpty: [ self error: 'Collection is empty' ].\x0a\x09self size > 1 ifTrue: [ self error: 'Collection holds more than one element' ].\x0a\x09^ self anyOne",
- referencedClasses: [],
- messageSends: ["ifEmpty:", "error:", "ifTrue:", ">", "size", "anyOne"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"size",{},$globals.Collection)});
- },
- args: [],
- source: "size\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "collection";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'collection'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Collection.klass);
- $core.addMethod(
- $core.method({
- selector: "new:",
- protocol: "instance creation",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._new();
- }, function($ctx1) {$ctx1.fill(self,"new:",{anInteger:anInteger},$globals.Collection.klass)});
- },
- args: ["anInteger"],
- source: "new: anInteger\x0a\x09^ self new",
- referencedClasses: [],
- messageSends: ["new"]
- }),
- $globals.Collection.klass);
- $core.addMethod(
- $core.method({
- selector: "with:",
- protocol: "instance creation",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._add_(anObject);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"with:",{anObject:anObject},$globals.Collection.klass)});
- },
- args: ["anObject"],
- source: "with: anObject\x0a\x09\x09^ self new\x0a\x09\x09add: anObject;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["add:", "new", "yourself"]
- }),
- $globals.Collection.klass);
- $core.addMethod(
- $core.method({
- selector: "with:with:",
- protocol: "instance creation",
- fn: function (anObject,anotherObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._add_(anObject);
- $ctx1.sendIdx["add:"]=1;
- $recv($1)._add_(anotherObject);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"with:with:",{anObject:anObject,anotherObject:anotherObject},$globals.Collection.klass)});
- },
- args: ["anObject", "anotherObject"],
- source: "with: anObject with: anotherObject\x0a\x09\x09^ self new\x0a\x09\x09add: anObject;\x0a\x09\x09add: anotherObject;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["add:", "new", "yourself"]
- }),
- $globals.Collection.klass);
- $core.addMethod(
- $core.method({
- selector: "with:with:with:",
- protocol: "instance creation",
- fn: function (firstObject,secondObject,thirdObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._add_(firstObject);
- $ctx1.sendIdx["add:"]=1;
- $recv($1)._add_(secondObject);
- $ctx1.sendIdx["add:"]=2;
- $recv($1)._add_(thirdObject);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"with:with:with:",{firstObject:firstObject,secondObject:secondObject,thirdObject:thirdObject},$globals.Collection.klass)});
- },
- args: ["firstObject", "secondObject", "thirdObject"],
- source: "with: firstObject with: secondObject with: thirdObject\x0a\x09\x09^ self new\x0a\x09\x09add: firstObject;\x0a\x09\x09add: secondObject;\x0a\x09\x09add: thirdObject;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["add:", "new", "yourself"]
- }),
- $globals.Collection.klass);
- $core.addMethod(
- $core.method({
- selector: "withAll:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._addAll_(aCollection);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"withAll:",{aCollection:aCollection},$globals.Collection.klass)});
- },
- args: ["aCollection"],
- source: "withAll: aCollection\x0a\x09\x09^ self new\x0a\x09\x09addAll: aCollection;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["addAll:", "new", "yourself"]
- }),
- $globals.Collection.klass);
- $core.addClass("IndexableCollection", $globals.Collection, [], "Kernel-Collections");
- $globals.IndexableCollection.comment="I am a key-value store collection, that is,\x0aI store values under indexes.\x0a\x0aAs a rule of thumb, if a collection has `#at:` and `#at:put:`,\x0ait is an IndexableCollection.";
- $core.addMethod(
- $core.method({
- selector: "at:",
- protocol: "accessing",
- fn: function (anIndex){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_ifAbsent_(anIndex,(function(){
- return $core.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"at:",{anIndex:anIndex},$globals.IndexableCollection)});
- },
- args: ["anIndex"],
- source: "at: anIndex\x0a\x09\x22Lookup the given index in the receiver.\x0a\x09If it is present, answer the value stored at anIndex.\x0a\x09Otherwise, raise an error.\x22\x0a\x0a\x09^ self at: anIndex ifAbsent: [ self errorNotFound ]",
- referencedClasses: [],
- messageSends: ["at:ifAbsent:", "errorNotFound"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsent:",
- protocol: "accessing",
- fn: function (anIndex,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{anIndex:anIndex,aBlock:aBlock},$globals.IndexableCollection)});
- },
- args: ["anIndex", "aBlock"],
- source: "at: anIndex ifAbsent: aBlock\x0a\x09\x22Lookup the given index in the receiver.\x0a\x09If it is present, answer the value stored at anIndex.\x0a\x09Otherwise, answer the value of aBlock.\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsentPut:",
- protocol: "accessing",
- fn: function (aKey,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_ifAbsent_(aKey,(function(){
- return $core.withContext(function($ctx2) {
- return self._at_put_(aKey,$recv(aBlock)._value());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsentPut:",{aKey:aKey,aBlock:aBlock},$globals.IndexableCollection)});
- },
- args: ["aKey", "aBlock"],
- source: "at: aKey ifAbsentPut: aBlock\x0a\x09^ self at: aKey ifAbsent: [\x0a\x09\x09self at: aKey put: aBlock value ]",
- referencedClasses: [],
- messageSends: ["at:ifAbsent:", "at:put:", "value"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "at:ifPresent:",
- protocol: "accessing",
- fn: function (anIndex,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_ifPresent_ifAbsent_(anIndex,aBlock,(function(){
- return nil;
- }));
- }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:",{anIndex:anIndex,aBlock:aBlock},$globals.IndexableCollection)});
- },
- args: ["anIndex", "aBlock"],
- source: "at: anIndex ifPresent: aBlock\x0a\x09\x22Lookup the given index in the receiver.\x0a\x09If it is present, answer the value of evaluating aBlock with the value stored at anIndex.\x0a\x09Otherwise, answer nil.\x22\x0a\x0a\x09^ self at: anIndex ifPresent: aBlock ifAbsent: [ nil ]",
- referencedClasses: [],
- messageSends: ["at:ifPresent:ifAbsent:"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: "accessing",
- fn: function (anIndex,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{anIndex:anIndex,aBlock:aBlock,anotherBlock:anotherBlock},$globals.IndexableCollection)});
- },
- args: ["anIndex", "aBlock", "anotherBlock"],
- source: "at: anIndex ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09\x22Lookup the given index in the receiver.\x0a\x09If it is present, answer the value of evaluating aBlock with the value stored at anIndex.\x0a\x09Otherwise, answer the value of anotherBlock.\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "at:put:",
- protocol: "accessing",
- fn: function (anIndex,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:put:",{anIndex:anIndex,anObject:anObject},$globals.IndexableCollection)});
- },
- args: ["anIndex", "anObject"],
- source: "at: anIndex put: anObject\x0a\x09\x22Store anObject under the given index in the receiver.\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "indexOf:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._indexOf_ifAbsent_(anObject,(function(){
- return $core.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"indexOf:",{anObject:anObject},$globals.IndexableCollection)});
- },
- args: ["anObject"],
- source: "indexOf: anObject\x0a\x09\x22Lookup index at which anObject is stored in the receiver.\x0a\x09If not present, raise an error.\x22\x0a\x0a\x09^ self indexOf: anObject ifAbsent: [ self errorNotFound ]",
- referencedClasses: [],
- messageSends: ["indexOf:ifAbsent:", "errorNotFound"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "indexOf:ifAbsent:",
- protocol: "accessing",
- fn: function (anObject,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"indexOf:ifAbsent:",{anObject:anObject,aBlock:aBlock},$globals.IndexableCollection)});
- },
- args: ["anObject", "aBlock"],
- source: "indexOf: anObject ifAbsent: aBlock\x0a\x09\x22Lookup index at which anObject is stored in the receiver.\x0a\x09If not present, return value of executing aBlock.\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "with:do:",
- protocol: "enumerating",
- fn: function (anotherCollection,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._withIndexDo_((function(each,index){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._value_value_(each,$recv(anotherCollection)._at_(index));
- }, function($ctx2) {$ctx2.fillBlock({each:each,index:index},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"with:do:",{anotherCollection:anotherCollection,aBlock:aBlock},$globals.IndexableCollection)});
- },
- args: ["anotherCollection", "aBlock"],
- source: "with: anotherCollection do: aBlock\x0a\x09\x22Calls aBlock with every value from self\x0a\x09and with indetically-indexed value from anotherCollection\x22\x0a\x0a\x09self withIndexDo: [ :each :index |\x0a\x09\x09aBlock value: each value: (anotherCollection at: index) ]",
- referencedClasses: [],
- messageSends: ["withIndexDo:", "value:value:", "at:"]
- }),
- $globals.IndexableCollection);
- $core.addMethod(
- $core.method({
- selector: "withIndexDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"withIndexDo:",{aBlock:aBlock},$globals.IndexableCollection)});
- },
- args: ["aBlock"],
- source: "withIndexDo: aBlock\x0a\x09\x22Calls aBlock with every value from self\x0a\x09and with its index as the second argument\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollection);
- $core.addClass("AssociativeCollection", $globals.IndexableCollection, [], "Kernel-Collections");
- $globals.AssociativeCollection.comment="I am a base class for object-indexed collections (Dictionary et.al.).";
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (anAssocitativeCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5;
- $2=self._class();
- $ctx1.sendIdx["class"]=1;
- $1=$recv($2).__eq($recv(anAssocitativeCollection)._class());
- $ctx1.sendIdx["="]=1;
- if(!$core.assert($1)){
- return false;
- }
- $4=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=$recv($4).__eq($recv(anAssocitativeCollection)._size());
- $ctx1.sendIdx["="]=2;
- if(!$core.assert($3)){
- return false;
- }
- $5=self._associations();
- $ctx1.sendIdx["associations"]=1;
- return $recv($5).__eq($recv(anAssocitativeCollection)._associations());
- }, function($ctx1) {$ctx1.fill(self,"=",{anAssocitativeCollection:anAssocitativeCollection},$globals.AssociativeCollection)});
- },
- args: ["anAssocitativeCollection"],
- source: "= anAssocitativeCollection\x0a\x09self class = anAssocitativeCollection class ifFalse: [ ^ false ].\x0a\x09self size = anAssocitativeCollection size ifFalse: [ ^ false ].\x0a\x09^ self associations = anAssocitativeCollection associations",
- referencedClasses: [],
- messageSends: ["ifFalse:", "=", "class", "size", "associations"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "add:",
- protocol: "adding/removing",
- fn: function (anAssociation){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._at_put_($recv(anAssociation)._key(),$recv(anAssociation)._value());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"add:",{anAssociation:anAssociation},$globals.AssociativeCollection)});
- },
- args: ["anAssociation"],
- source: "add: anAssociation\x0a\x09self at: anAssociation key put: anAssociation value",
- referencedClasses: [],
- messageSends: ["at:put:", "key", "value"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "addAll:",
- protocol: "adding/removing",
- fn: function (anAssociativeCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.AssociativeCollection.superclass||$boot.nilAsClass).fn.prototype._addAll_.apply($recv(self), [$recv(anAssociativeCollection)._associations()]));
- $ctx1.supercall = false;
- return anAssociativeCollection;
- }, function($ctx1) {$ctx1.fill(self,"addAll:",{anAssociativeCollection:anAssociativeCollection},$globals.AssociativeCollection)});
- },
- args: ["anAssociativeCollection"],
- source: "addAll: anAssociativeCollection\x0a\x09super addAll: anAssociativeCollection associations.\x0a\x09^ anAssociativeCollection",
- referencedClasses: [],
- messageSends: ["addAll:", "associations"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "asDictionary",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Dictionary)._from_(self._associations());
- }, function($ctx1) {$ctx1.fill(self,"asDictionary",{},$globals.AssociativeCollection)});
- },
- args: [],
- source: "asDictionary\x0a\x09^ Dictionary from: self associations",
- referencedClasses: ["Dictionary"],
- messageSends: ["from:", "associations"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "asHashedCollection",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.HashedCollection)._from_(self._associations());
- }, function($ctx1) {$ctx1.fill(self,"asHashedCollection",{},$globals.AssociativeCollection)});
- },
- args: [],
- source: "asHashedCollection\x0a\x09^ HashedCollection from: self associations",
- referencedClasses: ["HashedCollection"],
- messageSends: ["from:", "associations"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- var hash;
- return $core.withContext(function($ctx1) {
- hash=$recv($globals.HashedCollection)._new();
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(hash)._at_put_(key,$recv(value)._asJavaScriptObject());
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return hash;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptObject",{hash:hash},$globals.AssociativeCollection)});
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09| hash |\x0a\x09hash := HashedCollection new.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09hash at: key put: value asJavaScriptObject ].\x0a\x09^ hash",
- referencedClasses: ["HashedCollection"],
- messageSends: ["new", "keysAndValuesDo:", "at:put:", "asJavaScriptObject"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "associations",
- protocol: "accessing",
- fn: function (){
- var self=this;
- var associations;
- return $core.withContext(function($ctx1) {
- associations=[];
- self._associationsDo_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(associations)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return associations;
- }, function($ctx1) {$ctx1.fill(self,"associations",{associations:associations},$globals.AssociativeCollection)});
- },
- args: [],
- source: "associations\x0a\x09| associations |\x0a\x09associations := #().\x0a\x09self associationsDo: [ :each | associations add: each ].\x0a\x09^ associations",
- referencedClasses: [],
- messageSends: ["associationsDo:", "add:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "associationsDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._value_($recv($globals.Association)._key_value_(key,value));
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"associationsDo:",{aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "associationsDo: aBlock\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09aBlock value: (Association key: key value: value) ]",
- referencedClasses: ["Association"],
- messageSends: ["keysAndValuesDo:", "value:", "key:value:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: "accessing",
- fn: function (aKey,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._includesKey_(aKey);
- if($core.assert($1)){
- return $recv(aBlock)._value_(self._at_(aKey));
- } else {
- return $recv(anotherBlock)._value();
- }
- }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{aKey:aKey,aBlock:aBlock,anotherBlock:anotherBlock},$globals.AssociativeCollection)});
- },
- args: ["aKey", "aBlock", "anotherBlock"],
- source: "at: aKey ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09\x22Lookup the given key in the receiver.\x0a\x09If it is present, answer the value of evaluating the oneArgBlock \x0a\x09with the value associated with the key, otherwise answer the value \x0a\x09of absentBlock.\x22\x0a\x09\x0a\x09^ (self includesKey: aKey)\x0a\x09\x09ifTrue: [ aBlock value: (self at: aKey) ]\x0a\x09\x09ifFalse: [ anotherBlock value ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "includesKey:", "value:", "at:", "value"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "collect:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var newDict;
- return $core.withContext(function($ctx1) {
- newDict=$recv(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(newDict)._at_put_(key,$recv(aBlock)._value_(value));
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return newDict;
- }, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock,newDict:newDict},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "collect: aBlock\x0a\x09| newDict |\x0a\x09newDict := self class new.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09newDict at: key put: (aBlock value: value) ].\x0a\x09^ newDict",
- referencedClasses: [],
- messageSends: ["new", "class", "keysAndValuesDo:", "at:put:", "value:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "deepCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- var copy;
- return $core.withContext(function($ctx1) {
- copy=$recv(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(copy)._at_put_(key,$recv(value)._deepCopy());
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return copy;
- }, function($ctx1) {$ctx1.fill(self,"deepCopy",{copy:copy},$globals.AssociativeCollection)});
- },
- args: [],
- source: "deepCopy\x0a\x09| copy |\x0a\x09copy := self class new.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09copy at: key put: value deepCopy ].\x0a\x09^ copy",
- referencedClasses: [],
- messageSends: ["new", "class", "keysAndValuesDo:", "at:put:", "deepCopy"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "detect:ifNone:",
- protocol: "enumerating",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._values())._detect_ifNone_(aBlock,anotherBlock);
- }, function($ctx1) {$ctx1.fill(self,"detect:ifNone:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.AssociativeCollection)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "detect: aBlock ifNone: anotherBlock\x0a\x09^ self values detect: aBlock ifNone: anotherBlock",
- referencedClasses: [],
- messageSends: ["detect:ifNone:", "values"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "do:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._valuesDo_(aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09self valuesDo: aBlock",
- referencedClasses: [],
- messageSends: ["valuesDo:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "includes:",
- protocol: "enumerating",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._values())._includes_(anObject);
- }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},$globals.AssociativeCollection)});
- },
- args: ["anObject"],
- source: "includes: anObject\x0a\x09^ self values includes: anObject",
- referencedClasses: [],
- messageSends: ["includes:", "values"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "includesKey:",
- protocol: "testing",
- fn: function (aKey){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"includesKey:",{aKey:aKey},$globals.AssociativeCollection)});
- },
- args: ["aKey"],
- source: "includesKey: aKey\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "indexOf:ifAbsent:",
- protocol: "accessing",
- fn: function (anObject,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._keys())._detect_ifNone_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self._at_(each)).__eq(anObject);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),aBlock);
- }, function($ctx1) {$ctx1.fill(self,"indexOf:ifAbsent:",{anObject:anObject,aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["anObject", "aBlock"],
- source: "indexOf: anObject ifAbsent: aBlock\x0a\x09^ self keys \x0a\x09\x09detect: [ :each | (self at: each) = anObject ] \x0a\x09\x09ifNone: aBlock",
- referencedClasses: [],
- messageSends: ["detect:ifNone:", "keys", "=", "at:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "keyAtValue:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._keyAtValue_ifAbsent_(anObject,(function(){
- return $core.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"keyAtValue:",{anObject:anObject},$globals.AssociativeCollection)});
- },
- args: ["anObject"],
- source: "keyAtValue: anObject\x0a\x09^ self keyAtValue: anObject ifAbsent: [ self errorNotFound ]",
- referencedClasses: [],
- messageSends: ["keyAtValue:ifAbsent:", "errorNotFound"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "keyAtValue:ifAbsent:",
- protocol: "accessing",
- fn: function (anObject,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._indexOf_ifAbsent_(anObject,aBlock);
- }, function($ctx1) {$ctx1.fill(self,"keyAtValue:ifAbsent:",{anObject:anObject,aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["anObject", "aBlock"],
- source: "keyAtValue: anObject ifAbsent: aBlock\x0a\x09^ self indexOf: anObject ifAbsent: aBlock",
- referencedClasses: [],
- messageSends: ["indexOf:ifAbsent:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "keys",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"keys",{},$globals.AssociativeCollection)});
- },
- args: [],
- source: "keys\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "keysAndValuesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._keysDo_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._value_value_(each,self._at_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"keysAndValuesDo:",{aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "keysAndValuesDo: aBlock\x0a\x09self keysDo: [ :each |\x0a\x09\x09aBlock value: each value: (self at: each) ]",
- referencedClasses: [],
- messageSends: ["keysDo:", "value:value:", "at:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "keysDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"keysDo:",{aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "keysDo: aBlock\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.AssociativeCollection.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $ctx1.sendIdx["printOn:"]=1;
- $recv(aStream)._nextPutAll_(" (");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(self._associations())._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._printOn_(aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(aStream)._nextPutAll_(" , ");
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.AssociativeCollection)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09\x0a\x09aStream nextPutAll: ' ('.\x0a\x09self associations\x0a\x09\x09do: [ :each | each printOn: aStream ]\x0a\x09\x09separatedBy: [ aStream nextPutAll: ' , ' ].\x0a\x09aStream nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "do:separatedBy:", "associations"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "remove:ifAbsent:",
- protocol: "adding/removing",
- fn: function (aKey,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._removeKey_ifAbsent_(aKey,aBlock);
- }, function($ctx1) {$ctx1.fill(self,"remove:ifAbsent:",{aKey:aKey,aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aKey", "aBlock"],
- source: "remove: aKey ifAbsent: aBlock\x0a\x09^ self removeKey: aKey ifAbsent: aBlock",
- referencedClasses: [],
- messageSends: ["removeKey:ifAbsent:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "removeAll",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._keys())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._removeKey_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"removeAll",{},$globals.AssociativeCollection)});
- },
- args: [],
- source: "removeAll\x0a\x09^ self keys do: [ :each | self removeKey: each ]",
- referencedClasses: [],
- messageSends: ["do:", "keys", "removeKey:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "removeKey:",
- protocol: "adding/removing",
- fn: function (aKey){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._remove_(aKey);
- }, function($ctx1) {$ctx1.fill(self,"removeKey:",{aKey:aKey},$globals.AssociativeCollection)});
- },
- args: ["aKey"],
- source: "removeKey: aKey\x0a\x09^ self remove: aKey",
- referencedClasses: [],
- messageSends: ["remove:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "removeKey:ifAbsent:",
- protocol: "adding/removing",
- fn: function (aKey,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeKey:ifAbsent:",{aKey:aKey,aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aKey", "aBlock"],
- source: "removeKey: aKey ifAbsent: aBlock\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "select:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var newDict;
- return $core.withContext(function($ctx1) {
- var $1;
- newDict=$recv(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- $1=$recv(aBlock)._value_(value);
- if($core.assert($1)){
- return $recv(newDict)._at_put_(key,value);
- }
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return newDict;
- }, function($ctx1) {$ctx1.fill(self,"select:",{aBlock:aBlock,newDict:newDict},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "select: aBlock\x0a\x09| newDict |\x0a\x09newDict := self class new.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09(aBlock value: value) ifTrue: [ newDict at: key put: value ]].\x0a\x09^ newDict",
- referencedClasses: [],
- messageSends: ["new", "class", "keysAndValuesDo:", "ifTrue:", "value:", "at:put:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "select:thenCollect:",
- protocol: "enumerating",
- fn: function (selectBlock,collectBlock){
- var self=this;
- var newDict;
- return $core.withContext(function($ctx1) {
- var $1;
- newDict=$recv(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- $1=$recv(selectBlock)._value_(value);
- $ctx2.sendIdx["value:"]=1;
- if($core.assert($1)){
- return $recv(newDict)._at_put_(key,$recv(collectBlock)._value_(value));
- }
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return newDict;
- }, function($ctx1) {$ctx1.fill(self,"select:thenCollect:",{selectBlock:selectBlock,collectBlock:collectBlock,newDict:newDict},$globals.AssociativeCollection)});
- },
- args: ["selectBlock", "collectBlock"],
- source: "select: selectBlock thenCollect: collectBlock\x0a\x09| newDict |\x0a\x09newDict := self class new.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09(selectBlock value: value) ifTrue: [ newDict at: key put: (collectBlock value: value) ]].\x0a\x09^ newDict",
- referencedClasses: [],
- messageSends: ["new", "class", "keysAndValuesDo:", "ifTrue:", "value:", "at:put:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "shallowCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- var copy;
- return $core.withContext(function($ctx1) {
- copy=$recv(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(copy)._at_put_(key,value);
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return copy;
- }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{copy:copy},$globals.AssociativeCollection)});
- },
- args: [],
- source: "shallowCopy\x0a\x09| copy |\x0a\x09copy := self class new.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09copy at: key put: value ].\x0a\x09^ copy",
- referencedClasses: [],
- messageSends: ["new", "class", "keysAndValuesDo:", "at:put:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._keys())._size();
- }, function($ctx1) {$ctx1.fill(self,"size",{},$globals.AssociativeCollection)});
- },
- args: [],
- source: "size\x0a\x09^ self keys size",
- referencedClasses: [],
- messageSends: ["size", "keys"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "values",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"values",{},$globals.AssociativeCollection)});
- },
- args: [],
- source: "values\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "valuesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"valuesDo:",{aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "valuesDo: aBlock\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "withIndexDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._value_value_(value,key);
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"withIndexDo:",{aBlock:aBlock},$globals.AssociativeCollection)});
- },
- args: ["aBlock"],
- source: "withIndexDo: aBlock\x0a\x09self keysAndValuesDo: [ :key :value | aBlock value: value value: key ]",
- referencedClasses: [],
- messageSends: ["keysAndValuesDo:", "value:value:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "from:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- var newCollection;
- return $core.withContext(function($ctx1) {
- newCollection=self._new();
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(newCollection)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return newCollection;
- }, function($ctx1) {$ctx1.fill(self,"from:",{aCollection:aCollection,newCollection:newCollection},$globals.AssociativeCollection.klass)});
- },
- args: ["aCollection"],
- source: "from: aCollection\x0a\x09| newCollection |\x0a\x09newCollection := self new.\x0a\x09aCollection do: [ :each | newCollection add: each ].\x0a\x09^ newCollection",
- referencedClasses: [],
- messageSends: ["new", "do:", "add:"]
- }),
- $globals.AssociativeCollection.klass);
- $core.addMethod(
- $core.method({
- selector: "fromPairs:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._from_(aCollection);
- }, function($ctx1) {$ctx1.fill(self,"fromPairs:",{aCollection:aCollection},$globals.AssociativeCollection.klass)});
- },
- args: ["aCollection"],
- source: "fromPairs: aCollection\x0a\x09\x22This message is poorly named and has been replaced by #from:\x22\x0a\x09^ self from: aCollection",
- referencedClasses: [],
- messageSends: ["from:"]
- }),
- $globals.AssociativeCollection.klass);
- $core.addMethod(
- $core.method({
- selector: "newFromPairs:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- var newCollection;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$4;
- $2=$recv(aCollection)._size();
- $ctx1.sendIdx["size"]=1;
- $1=$recv($2)._even();
- if(!$core.assert($1)){
- self._error_("#newFromPairs only accepts arrays of an even length");
- }
- newCollection=self._new();
- $recv((1)._to_by_($recv(aCollection)._size(),(2)))._do_((function(each){
- return $core.withContext(function($ctx2) {
- $3=newCollection;
- $4=$recv(aCollection)._at_(each);
- $ctx2.sendIdx["at:"]=1;
- return $recv($3)._at_put_($4,$recv(aCollection)._at_($recv(each).__plus((1))));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- return newCollection;
- }, function($ctx1) {$ctx1.fill(self,"newFromPairs:",{aCollection:aCollection,newCollection:newCollection},$globals.AssociativeCollection.klass)});
- },
- args: ["aCollection"],
- source: "newFromPairs: aCollection\x0a\x09\x22Accept an array of elements where every two elements form an \x0a\x09association - the odd element being the key, and the even element the value.\x22\x0a\x09\x0a\x09| newCollection |\x0a\x09\x0a\x09aCollection size even ifFalse: [ \x0a\x09\x09self error: '#newFromPairs only accepts arrays of an even length' ].\x0a\x09\x09\x0a\x09newCollection := self new.\x0a\x09( 1 to: aCollection size by: 2 ) do: [ :each | \x0a\x09\x09newCollection at: (aCollection at: each) put: (aCollection at: each + 1) ].\x0a\x09\x09\x0a\x09^ newCollection",
- referencedClasses: [],
- messageSends: ["ifFalse:", "even", "size", "error:", "new", "do:", "to:by:", "at:put:", "at:", "+"]
- }),
- $globals.AssociativeCollection.klass);
- $core.addClass("Dictionary", $globals.AssociativeCollection, ["keys", "values"], "Kernel-Collections");
- $globals.Dictionary.comment="I represent a set of elements that can be viewed from one of two perspectives: a set of associations,\x0aor a container of values that are externally named where the name can be any object that responds to `=`.\x0a\x0aThe external name is referred to as the key.";
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsent:",
- protocol: "accessing",
- fn: function (aKey,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var index = self._positionOfKey_(aKey);
- return index >=0 ? self['@values'][index] : aBlock._value();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aKey:aKey,aBlock:aBlock},$globals.Dictionary)});
- },
- args: ["aKey", "aBlock"],
- source: "at: aKey ifAbsent: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09var index = self._positionOfKey_(aKey);\x0a\x09\x09return index >=0 ? self[''@values''][index] : aBlock._value();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "at:put:",
- protocol: "accessing",
- fn: function (aKey,aValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- var index = self._positionOfKey_(aKey);
- if(index === -1) {
- var keys = self['@keys'];
- index = keys.length;
- keys.push(aKey);
- }
- return self['@values'][index] = aValue;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:put:",{aKey:aKey,aValue:aValue},$globals.Dictionary)});
- },
- args: ["aKey", "aValue"],
- source: "at: aKey put: aValue\x0a\x09<inlineJS: '\x0a\x09\x09var index = self._positionOfKey_(aKey);\x0a\x09\x09if(index === -1) {\x0a\x09\x09\x09var keys = self[''@keys''];\x0a\x09\x09\x09index = keys.length;\x0a\x09\x09\x09keys.push(aKey);\x0a\x09\x09}\x0a\x0a\x09\x09return self[''@values''][index] = aValue;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "includesKey:",
- protocol: "testing",
- fn: function (aKey){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._positionOfKey_(aKey) >= 0;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"includesKey:",{aKey:aKey},$globals.Dictionary)});
- },
- args: ["aKey"],
- source: "includesKey: aKey\x0a\x09<inlineJS: 'return self._positionOfKey_(aKey) >= 0;'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "indexOf:ifAbsent:",
- protocol: "accessing",
- fn: function (anObject,aBlock){
- var self=this;
- var index;
- return $core.withContext(function($ctx1) {
- var $1;
- index=$recv(self["@values"])._indexOf_ifAbsent_(anObject,(function(){
- return (0);
- }));
- $1=$recv(index).__eq((0));
- if($core.assert($1)){
- return $recv(aBlock)._value();
- } else {
- return $recv(self["@keys"])._at_(index);
- }
- }, function($ctx1) {$ctx1.fill(self,"indexOf:ifAbsent:",{anObject:anObject,aBlock:aBlock,index:index},$globals.Dictionary)});
- },
- args: ["anObject", "aBlock"],
- source: "indexOf: anObject ifAbsent: aBlock\x0a\x09| index |\x0a\x09index := values \x0a\x09\x09indexOf: anObject \x0a\x09\x09ifAbsent: [ 0 ].\x0a\x09^ index = 0 \x0a\x09\x09ifTrue: [ aBlock value ] \x0a\x09\x09ifFalse: [ keys at: index ]",
- referencedClasses: [],
- messageSends: ["indexOf:ifAbsent:", "ifTrue:ifFalse:", "=", "value", "at:"]
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Dictionary.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@keys"]=[];
- self["@values"]=[];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Dictionary)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09keys := #().\x0a\x09values := #()",
- referencedClasses: [],
- messageSends: ["initialize"]
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "keys",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@keys"])._copy();
- }, function($ctx1) {$ctx1.fill(self,"keys",{},$globals.Dictionary)});
- },
- args: [],
- source: "keys\x0a\x09^ keys copy",
- referencedClasses: [],
- messageSends: ["copy"]
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "keysAndValuesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@keys"])._with_do_(self["@values"],aBlock);
- }, function($ctx1) {$ctx1.fill(self,"keysAndValuesDo:",{aBlock:aBlock},$globals.Dictionary)});
- },
- args: ["aBlock"],
- source: "keysAndValuesDo: aBlock\x0a\x09^ keys with: values do: aBlock",
- referencedClasses: [],
- messageSends: ["with:do:"]
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "keysDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@keys"])._do_(aBlock);
- }, function($ctx1) {$ctx1.fill(self,"keysDo:",{aBlock:aBlock},$globals.Dictionary)});
- },
- args: ["aBlock"],
- source: "keysDo: aBlock\x0a\x09^ keys do: aBlock",
- referencedClasses: [],
- messageSends: ["do:"]
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "positionOfKey:",
- protocol: "private",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var keys = self['@keys'];
- for(var i=0;i<keys.length;i++){
- if(keys[i].__eq(anObject)) { return i;}
- }
- return -1;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"positionOfKey:",{anObject:anObject},$globals.Dictionary)});
- },
- args: ["anObject"],
- source: "positionOfKey: anObject\x0a\x09<inlineJS: '\x0a\x09\x09var keys = self[''@keys''];\x0a\x09\x09for(var i=0;i<keys.length;i++){\x0a\x09\x09\x09if(keys[i].__eq(anObject)) { return i;}\x0a\x09\x09}\x0a\x09\x09return -1;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "removeAll",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@keys"])._removeAll();
- $ctx1.sendIdx["removeAll"]=1;
- $recv(self["@values"])._removeAll();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeAll",{},$globals.Dictionary)});
- },
- args: [],
- source: "removeAll\x0a\x09keys removeAll.\x0a\x09values removeAll",
- referencedClasses: [],
- messageSends: ["removeAll"]
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "removeKey:ifAbsent:",
- protocol: "adding/removing",
- fn: function (aKey,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var index = self._positionOfKey_(aKey);
- if(index === -1) {
- return aBlock._value()
- } else {
- var keys = self['@keys'], values = self['@values'];
- var value = values[index], l = keys.length;
- keys[index] = keys[l-1];
- keys.pop();
- values[index] = values[l-1];
- values.pop();
- return value;
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeKey:ifAbsent:",{aKey:aKey,aBlock:aBlock},$globals.Dictionary)});
- },
- args: ["aKey", "aBlock"],
- source: "removeKey: aKey ifAbsent: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09var index = self._positionOfKey_(aKey);\x0a\x09\x09if(index === -1) {\x0a\x09\x09\x09return aBlock._value()\x0a\x09\x09} else {\x0a\x09\x09\x09var keys = self[''@keys''], values = self[''@values''];\x0a\x09\x09\x09var value = values[index], l = keys.length;\x0a\x09\x09\x09keys[index] = keys[l-1];\x0a\x09\x09\x09keys.pop();\x0a\x09\x09\x09values[index] = values[l-1];\x0a\x09\x09\x09values.pop();\x0a\x09\x09\x09return value;\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "values",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@values"];
- },
- args: [],
- source: "values\x0a\x09^ values",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Dictionary);
- $core.addMethod(
- $core.method({
- selector: "valuesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@values"])._do_(aBlock);
- }, function($ctx1) {$ctx1.fill(self,"valuesDo:",{aBlock:aBlock},$globals.Dictionary)});
- },
- args: ["aBlock"],
- source: "valuesDo: aBlock\x0a\x09^ values do: aBlock",
- referencedClasses: [],
- messageSends: ["do:"]
- }),
- $globals.Dictionary);
- $core.addClass("HashedCollection", $globals.AssociativeCollection, [], "Kernel-Collections");
- $globals.HashedCollection.comment="I am a traditional JavaScript object, or a Smalltalk `Dictionary`.\x0a\x0aUnlike a `Dictionary`, I can only have strings as keys.";
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsent:",
- protocol: "accessing",
- fn: function (aKey,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._includesKey_(aKey);
- if($core.assert($1)){
- return self._basicAt_(aKey);
- } else {
- return $recv(aBlock)._value();
- }
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aKey:aKey,aBlock:aBlock},$globals.HashedCollection)});
- },
- args: ["aKey", "aBlock"],
- source: "at: aKey ifAbsent: aBlock\x0a\x09^ (self includesKey: aKey)\x0a\x09\x09ifTrue: [ self basicAt: aKey ]\x0a\x09\x09ifFalse: [ aBlock value ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "includesKey:", "basicAt:", "value"]
- }),
- $globals.HashedCollection);
- $core.addMethod(
- $core.method({
- selector: "at:put:",
- protocol: "accessing",
- fn: function (aKey,aValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_put_(aKey,aValue);
- }, function($ctx1) {$ctx1.fill(self,"at:put:",{aKey:aKey,aValue:aValue},$globals.HashedCollection)});
- },
- args: ["aKey", "aValue"],
- source: "at: aKey put: aValue\x0a\x09^ self basicAt: aKey put: aValue",
- referencedClasses: [],
- messageSends: ["basicAt:put:"]
- }),
- $globals.HashedCollection);
- $core.addMethod(
- $core.method({
- selector: "includesKey:",
- protocol: "testing",
- fn: function (aKey){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.hasOwnProperty(aKey);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"includesKey:",{aKey:aKey},$globals.HashedCollection)});
- },
- args: ["aKey"],
- source: "includesKey: aKey\x0a\x09<inlineJS: 'return self.hasOwnProperty(aKey)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollection);
- $core.addMethod(
- $core.method({
- selector: "keys",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Object.keys(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"keys",{},$globals.HashedCollection)});
- },
- args: [],
- source: "keys\x0a\x09<inlineJS: 'return Object.keys(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollection);
- $core.addMethod(
- $core.method({
- selector: "keysDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._keys())._do_(aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"keysDo:",{aBlock:aBlock},$globals.HashedCollection)});
- },
- args: ["aBlock"],
- source: "keysDo: aBlock\x0a\x09self keys do: aBlock",
- referencedClasses: [],
- messageSends: ["do:", "keys"]
- }),
- $globals.HashedCollection);
- $core.addMethod(
- $core.method({
- selector: "removeKey:ifAbsent:",
- protocol: "adding/removing",
- fn: function (aKey,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_ifPresent_ifAbsent_(aKey,(function(removed){
- return $core.withContext(function($ctx2) {
- self._basicDelete_(aKey);
- return removed;
- }, function($ctx2) {$ctx2.fillBlock({removed:removed},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._value();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"removeKey:ifAbsent:",{aKey:aKey,aBlock:aBlock},$globals.HashedCollection)});
- },
- args: ["aKey", "aBlock"],
- source: "removeKey: aKey ifAbsent: aBlock\x0a\x09^ self\x0a\x09\x09at: aKey\x0a\x09\x09ifPresent: [ :removed | self basicDelete: aKey. removed ]\x0a\x09\x09ifAbsent: [ aBlock value ]",
- referencedClasses: [],
- messageSends: ["at:ifPresent:ifAbsent:", "basicDelete:", "value"]
- }),
- $globals.HashedCollection);
- $core.addMethod(
- $core.method({
- selector: "values",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._keys().map(function(key){
- return self._at_(key);
- });
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"values",{},$globals.HashedCollection)});
- },
- args: [],
- source: "values\x0a\x09<inlineJS: '\x0a\x09\x09return self._keys().map(function(key){\x0a\x09\x09\x09return self._at_(key);\x0a\x09\x09});\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollection);
- $core.addMethod(
- $core.method({
- selector: "valuesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._values())._do_(aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"valuesDo:",{aBlock:aBlock},$globals.HashedCollection)});
- },
- args: ["aBlock"],
- source: "valuesDo: aBlock\x0a\x09self values do: aBlock",
- referencedClasses: [],
- messageSends: ["do:", "values"]
- }),
- $globals.HashedCollection);
- $core.addClass("SequenceableCollection", $globals.IndexableCollection, [], "Kernel-Collections");
- $globals.SequenceableCollection.comment="I am an IndexableCollection\x0awith numeric indexes starting with 1.";
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$4,$1,$5;
- var $early={};
- try {
- $3=self._class();
- $ctx1.sendIdx["class"]=1;
- $2=$recv($3).__eq($recv(aCollection)._class());
- $ctx1.sendIdx["="]=1;
- $1=$recv($2)._and_((function(){
- return $core.withContext(function($ctx2) {
- $4=self._size();
- $ctx2.sendIdx["size"]=1;
- return $recv($4).__eq($recv(aCollection)._size());
- $ctx2.sendIdx["="]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- if(!$core.assert($1)){
- return false;
- }
- self._withIndexDo_((function(each,i){
- return $core.withContext(function($ctx2) {
- $5=$recv($recv(aCollection)._at_(i)).__eq(each);
- if(!$core.assert($5)){
- throw $early=[false];
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1,3)});
- }));
- return true;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"=",{aCollection:aCollection},$globals.SequenceableCollection)});
- },
- args: ["aCollection"],
- source: "= aCollection\x0a\x09(self class = aCollection class and: [\x0a\x09\x09self size = aCollection size ]) ifFalse: [ ^ false ].\x0a\x09self withIndexDo: [ :each :i |\x0a\x09\x09\x09\x09(aCollection at: i) = each ifFalse: [ ^ false ]].\x0a\x09^ true",
- referencedClasses: [],
- messageSends: ["ifFalse:", "and:", "=", "class", "size", "withIndexDo:", "at:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "addLast:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._add_(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addLast:",{anObject:anObject},$globals.SequenceableCollection)});
- },
- args: ["anObject"],
- source: "addLast: anObject\x0a\x09self add: anObject",
- referencedClasses: [],
- messageSends: ["add:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "allButFirst",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._copyFrom_to_((2),self._size());
- }, function($ctx1) {$ctx1.fill(self,"allButFirst",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "allButFirst\x0a\x09^ self copyFrom: 2 to: self size",
- referencedClasses: [],
- messageSends: ["copyFrom:to:", "size"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "allButLast",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._copyFrom_to_((1),$recv(self._size()).__minus((1)));
- }, function($ctx1) {$ctx1.fill(self,"allButLast",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "allButLast\x0a\x09^ self copyFrom: 1 to: self size - 1",
- referencedClasses: [],
- messageSends: ["copyFrom:to:", "-", "size"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "anyOne",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_((1));
- }, function($ctx1) {$ctx1.fill(self,"anyOne",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "anyOne\x0a\x09^ self at: 1",
- referencedClasses: [],
- messageSends: ["at:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "atRandom",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_($recv(self._size())._atRandom());
- }, function($ctx1) {$ctx1.fill(self,"atRandom",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "atRandom\x0a\x09^ self at: self size atRandom",
- referencedClasses: [],
- messageSends: ["at:", "atRandom", "size"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "beginsWith:",
- protocol: "testing",
- fn: function (prefix){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=$recv(prefix)._size();
- $ctx1.sendIdx["size"]=2;
- $1=$recv($2).__lt($3);
- if($core.assert($1)){
- return false;
- }
- return $recv(self._first_($recv(prefix)._size())).__eq(prefix);
- }, function($ctx1) {$ctx1.fill(self,"beginsWith:",{prefix:prefix},$globals.SequenceableCollection)});
- },
- args: ["prefix"],
- source: "beginsWith: prefix\x0a\x09self size < prefix size ifTrue: [ ^ false ].\x0a\x09^ (self first: prefix size) = prefix",
- referencedClasses: [],
- messageSends: ["ifTrue:", "<", "size", "=", "first:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "copyFrom:to:",
- protocol: "copying",
- fn: function (anIndex,anotherIndex){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"copyFrom:to:",{anIndex:anIndex,anotherIndex:anotherIndex},$globals.SequenceableCollection)});
- },
- args: ["anIndex", "anotherIndex"],
- source: "copyFrom: anIndex to: anotherIndex\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "detect:ifNone:",
- protocol: "enumerating",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self = self._numericallyIndexable();
- for(var i = 0; i < self.length; i++)
- if(aBlock._value_(self[i]))
- return self[i];
- return anotherBlock._value();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"detect:ifNone:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.SequenceableCollection)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "detect: aBlock ifNone: anotherBlock\x0a\x09<inlineJS: '\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09for(var i = 0; i < self.length; i++)\x0a\x09\x09\x09if(aBlock._value_(self[i]))\x0a\x09\x09\x09\x09return self[i];\x0a\x09\x09return anotherBlock._value();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "do:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self = self._numericallyIndexable();
- for(var i=0; i < self.length; i++) {
- aBlock._value_(self[i]);
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},$globals.SequenceableCollection)});
- },
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09for(var i=0; i < self.length; i++) {\x0a\x09\x09\x09aBlock._value_(self[i]);\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "endsWith:",
- protocol: "testing",
- fn: function (suffix){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=$recv(suffix)._size();
- $ctx1.sendIdx["size"]=2;
- $1=$recv($2).__lt($3);
- if($core.assert($1)){
- return false;
- }
- return $recv(self._last_($recv(suffix)._size())).__eq(suffix);
- }, function($ctx1) {$ctx1.fill(self,"endsWith:",{suffix:suffix},$globals.SequenceableCollection)});
- },
- args: ["suffix"],
- source: "endsWith: suffix\x0a\x09self size < suffix size ifTrue: [ ^ false ].\x0a\x09^ (self last: suffix size) = suffix",
- referencedClasses: [],
- messageSends: ["ifTrue:", "<", "size", "=", "last:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "first",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_((1));
- }, function($ctx1) {$ctx1.fill(self,"first",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "first\x0a\x09^ self at: 1",
- referencedClasses: [],
- messageSends: ["at:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "first:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._size()).__lt(aNumber);
- if($core.assert($1)){
- self._error_("Invalid number of elements");
- }
- return self._copyFrom_to_((1),aNumber);
- }, function($ctx1) {$ctx1.fill(self,"first:",{aNumber:aNumber},$globals.SequenceableCollection)});
- },
- args: ["aNumber"],
- source: "first: aNumber\x0a\x09\x22Answer the first `aNumber` elements of the receiver.\x0a\x09Raise an error if there are not enough elements in the receiver.\x22\x0a\x0a\x09self size < aNumber ifTrue: [ self error: 'Invalid number of elements' ].\x0a\x0a\x09^ self copyFrom: 1 to: aNumber",
- referencedClasses: [],
- messageSends: ["ifTrue:", "<", "size", "error:", "copyFrom:to:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "fourth",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_((4));
- }, function($ctx1) {$ctx1.fill(self,"fourth",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "fourth\x0a\x09^ self at: 4",
- referencedClasses: [],
- messageSends: ["at:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "includes:",
- protocol: "testing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._indexOf_ifAbsent_(anObject,(function(){
- return nil;
- })))._notNil();
- }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},$globals.SequenceableCollection)});
- },
- args: ["anObject"],
- source: "includes: anObject\x0a\x09^ (self indexOf: anObject ifAbsent: [ nil ]) notNil",
- referencedClasses: [],
- messageSends: ["notNil", "indexOf:ifAbsent:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "indexOf:ifAbsent:",
- protocol: "accessing",
- fn: function (anObject,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self = self._numericallyIndexable();
- for(var i=0; i < self.length; i++) {
- if($recv(self[i]).__eq(anObject)) {return i+1}
- };
- return aBlock._value();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"indexOf:ifAbsent:",{anObject:anObject,aBlock:aBlock},$globals.SequenceableCollection)});
- },
- args: ["anObject", "aBlock"],
- source: "indexOf: anObject ifAbsent: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09for(var i=0; i < self.length; i++) {\x0a\x09\x09\x09if($recv(self[i]).__eq(anObject)) {return i+1}\x0a\x09\x09};\x0a\x09\x09return aBlock._value();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "indexOf:startingAt:",
- protocol: "accessing",
- fn: function (anObject,start){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._indexOf_startingAt_ifAbsent_(anObject,start,(function(){
- return (0);
- }));
- }, function($ctx1) {$ctx1.fill(self,"indexOf:startingAt:",{anObject:anObject,start:start},$globals.SequenceableCollection)});
- },
- args: ["anObject", "start"],
- source: "indexOf: anObject startingAt: start\x0a\x09\x22Answer the index of the first occurence of anElement after start\x0a\x09within the receiver. If the receiver does not contain anElement,\x0a\x09answer 0.\x22\x0a\x09^ self indexOf: anObject startingAt: start ifAbsent: [ 0 ]",
- referencedClasses: [],
- messageSends: ["indexOf:startingAt:ifAbsent:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "indexOf:startingAt:ifAbsent:",
- protocol: "accessing",
- fn: function (anObject,start,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self = self._numericallyIndexable();
- for(var i=start - 1; i < self.length; i++){
- if($recv(self[i]).__eq(anObject)) {return i+1}
- }
- return aBlock._value();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"indexOf:startingAt:ifAbsent:",{anObject:anObject,start:start,aBlock:aBlock},$globals.SequenceableCollection)});
- },
- args: ["anObject", "start", "aBlock"],
- source: "indexOf: anObject startingAt: start ifAbsent: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09for(var i=start - 1; i < self.length; i++){\x0a\x09\x09\x09if($recv(self[i]).__eq(anObject)) {return i+1}\x0a\x09\x09}\x0a\x09\x09return aBlock._value();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "last",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_(self._size());
- }, function($ctx1) {$ctx1.fill(self,"last",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "last\x0a\x09^ self at: self size",
- referencedClasses: [],
- messageSends: ["at:", "size"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "last:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$5,$4,$3;
- $2=self._size();
- $ctx1.sendIdx["size"]=1;
- $1=$recv($2).__lt(aNumber);
- if($core.assert($1)){
- self._error_("Invalid number of elements");
- }
- $5=self._size();
- $ctx1.sendIdx["size"]=2;
- $4=$recv($5).__minus(aNumber);
- $3=$recv($4).__plus((1));
- return self._copyFrom_to_($3,self._size());
- }, function($ctx1) {$ctx1.fill(self,"last:",{aNumber:aNumber},$globals.SequenceableCollection)});
- },
- args: ["aNumber"],
- source: "last: aNumber\x0a\x09\x22Answer the last aNumber elements of the receiver.\x0a\x09Raise an error if there are not enough elements in the receiver.\x22\x0a\x0a\x09self size < aNumber ifTrue: [ self error: 'Invalid number of elements' ].\x0a\x0a\x09^ self copyFrom: self size - aNumber + 1 to: self size",
- referencedClasses: [],
- messageSends: ["ifTrue:", "<", "size", "error:", "copyFrom:to:", "+", "-"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "newStream",
- protocol: "streaming",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._streamClass())._on_(self);
- }, function($ctx1) {$ctx1.fill(self,"newStream",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "newStream\x0a\x09^ self streamClass on: self",
- referencedClasses: [],
- messageSends: ["on:", "streamClass"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "numericallyIndexable",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"numericallyIndexable",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "numericallyIndexable\x0a\x09\x22This is an internal converting message.\x0a\x09It answeres a representation of the receiver\x0a\x09that can use foo[i] in JavaScript code.\x0a\x09\x0a\x09It fixes IE8, where boxed String is unable\x0a\x09to numerically index its characters,\x0a\x09but primitive string can.\x22\x0a\x09\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "readStream",
- protocol: "streaming",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._stream();
- }, function($ctx1) {$ctx1.fill(self,"readStream",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "readStream\x0a\x09\x22For Pharo compatibility\x22\x0a\x09\x0a\x09^ self stream",
- referencedClasses: [],
- messageSends: ["stream"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "removeLast",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._remove_(self._last());
- }, function($ctx1) {$ctx1.fill(self,"removeLast",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "removeLast\x0a\x09^ self remove: self last",
- referencedClasses: [],
- messageSends: ["remove:", "last"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "reverseDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._reversed())._do_(aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"reverseDo:",{aBlock:aBlock},$globals.SequenceableCollection)});
- },
- args: ["aBlock"],
- source: "reverseDo: aBlock\x0a\x09self reversed do: aBlock",
- referencedClasses: [],
- messageSends: ["do:", "reversed"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "reversed",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"reversed",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "reversed\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "second",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_((2));
- }, function($ctx1) {$ctx1.fill(self,"second",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "second\x0a\x09^ self at: 2",
- referencedClasses: [],
- messageSends: ["at:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "single",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (self.length == 0) throw new Error("Collection is empty");
- if (self.length > 1) throw new Error("Collection holds more than one element.");
- return self[0];;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"single",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "single\x0a<inlineJS: '\x0a\x09if (self.length == 0) throw new Error(\x22Collection is empty\x22);\x0a\x09if (self.length > 1) throw new Error(\x22Collection holds more than one element.\x22);\x0a\x09return self[0];\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "stream",
- protocol: "streaming",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._newStream();
- }, function($ctx1) {$ctx1.fill(self,"stream",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "stream\x0a\x09^ self newStream",
- referencedClasses: [],
- messageSends: ["newStream"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "streamClass",
- protocol: "streaming",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._streamClass();
- }, function($ctx1) {$ctx1.fill(self,"streamClass",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "streamClass\x0a\x09^ self class streamClass",
- referencedClasses: [],
- messageSends: ["streamClass", "class"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "third",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._at_((3));
- }, function($ctx1) {$ctx1.fill(self,"third",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "third\x0a\x09^ self at: 3",
- referencedClasses: [],
- messageSends: ["at:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "with:do:",
- protocol: "enumerating",
- fn: function (anotherCollection,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self = self._numericallyIndexable();
- anotherCollection = anotherCollection._numericallyIndexable();
- for(var i=0; i<self.length; i++) {
- aBlock._value_value_(self[i], anotherCollection[i]);
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"with:do:",{anotherCollection:anotherCollection,aBlock:aBlock},$globals.SequenceableCollection)});
- },
- args: ["anotherCollection", "aBlock"],
- source: "with: anotherCollection do: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09anotherCollection = anotherCollection._numericallyIndexable();\x0a\x09\x09for(var i=0; i<self.length; i++) {\x0a\x09\x09\x09aBlock._value_value_(self[i], anotherCollection[i]);\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "withIndexDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self = self._numericallyIndexable();
- for(var i=0; i < self.length; i++) {
- aBlock._value_value_(self[i], i+1);
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"withIndexDo:",{aBlock:aBlock},$globals.SequenceableCollection)});
- },
- args: ["aBlock"],
- source: "withIndexDo: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09for(var i=0; i < self.length; i++) {\x0a\x09\x09\x09aBlock._value_value_(self[i], i+1);\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "writeStream",
- protocol: "streaming",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._stream();
- }, function($ctx1) {$ctx1.fill(self,"writeStream",{},$globals.SequenceableCollection)});
- },
- args: [],
- source: "writeStream\x0a\x09\x22For Pharo compatibility\x22\x0a\x09\x0a\x09^ self stream",
- referencedClasses: [],
- messageSends: ["stream"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "streamClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.Stream;
- },
- args: [],
- source: "streamClass\x0a\x09\x09^ Stream",
- referencedClasses: ["Stream"],
- messageSends: []
- }),
- $globals.SequenceableCollection.klass);
- $core.addMethod(
- $core.method({
- selector: "streamContents:",
- protocol: "streaming",
- fn: function (aBlock){
- var self=this;
- var stream;
- return $core.withContext(function($ctx1) {
- stream=$recv(self._streamClass())._on_(self._new());
- $recv(aBlock)._value_(stream);
- return $recv(stream)._contents();
- }, function($ctx1) {$ctx1.fill(self,"streamContents:",{aBlock:aBlock,stream:stream},$globals.SequenceableCollection.klass)});
- },
- args: ["aBlock"],
- source: "streamContents: aBlock\x0a\x09| stream |\x0a\x09stream := (self streamClass on: self new).\x0a\x09aBlock value: stream.\x0a\x09^ stream contents",
- referencedClasses: [],
- messageSends: ["on:", "streamClass", "new", "value:", "contents"]
- }),
- $globals.SequenceableCollection.klass);
- $core.addClass("Array", $globals.SequenceableCollection, [], "Kernel-Collections");
- $globals.Array.comment="I represent a collection of objects ordered by the collector. The size of arrays is dynamic.\x0a\x0aI am directly mapped to JavaScript Number.\x0a\x0a*Note* In Amber, `OrderedCollection` is an alias for `Array`.";
- $core.addMethod(
- $core.method({
- selector: "add:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.push(anObject); return anObject;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject},$globals.Array)});
- },
- args: ["anObject"],
- source: "add: anObject\x0a\x09<inlineJS: 'self.push(anObject); return anObject;'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "addAll:",
- protocol: "adding/removing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (Array.isArray(aCollection) && aCollection.length < 65000) self.push.apply(self, aCollection);
- else $globals.Array.superclass.fn.prototype._addAll_.call(self, aCollection);
- return aCollection;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addAll:",{aCollection:aCollection},$globals.Array)});
- },
- args: ["aCollection"],
- source: "addAll: aCollection\x0a<inlineJS: '\x0a\x09if (Array.isArray(aCollection) && aCollection.length < 65000) self.push.apply(self, aCollection);\x0a\x09else $globals.Array.superclass.fn.prototype._addAll_.call(self, aCollection);\x0a\x09return aCollection;\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "addFirst:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.unshift(anObject); return anObject;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addFirst:",{anObject:anObject},$globals.Array)});
- },
- args: ["anObject"],
- source: "addFirst: anObject\x0a\x09<inlineJS: 'self.unshift(anObject); return anObject;'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("[".__comma($recv(self._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._asJavaScriptSource();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- })))._join_(", "))).__comma("]");
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.Array)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09^ '[', ((self collect: [:each | each asJavaScriptSource ]) join: ', '), ']'",
- referencedClasses: [],
- messageSends: [",", "join:", "collect:", "asJavaScriptSource"]
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsent:",
- protocol: "accessing",
- fn: function (anIndex,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return anIndex >= 1 && anIndex <= self.length
- ? self[anIndex - 1]
- : aBlock._value()
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{anIndex:anIndex,aBlock:aBlock},$globals.Array)});
- },
- args: ["anIndex", "aBlock"],
- source: "at: anIndex ifAbsent: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09return anIndex >= 1 && anIndex <= self.length\x0a\x09\x09\x09? self[anIndex - 1]\x0a\x09\x09\x09: aBlock._value()\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: "accessing",
- fn: function (anIndex,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return anIndex >= 1 && anIndex <= self.length
- ? aBlock._value_(self[anIndex - 1])
- : anotherBlock._value()
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{anIndex:anIndex,aBlock:aBlock,anotherBlock:anotherBlock},$globals.Array)});
- },
- args: ["anIndex", "aBlock", "anotherBlock"],
- source: "at: anIndex ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09<inlineJS: '\x0a\x09\x09return anIndex >= 1 && anIndex <= self.length\x0a\x09\x09\x09? aBlock._value_(self[anIndex - 1])\x0a\x09\x09\x09: anotherBlock._value()\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "at:put:",
- protocol: "accessing",
- fn: function (anIndex,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self[anIndex - 1] = anObject;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:put:",{anIndex:anIndex,anObject:anObject},$globals.Array)});
- },
- args: ["anIndex", "anObject"],
- source: "at: anIndex put: anObject\x0a\x09<inlineJS: 'return self[anIndex - 1] = anObject'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "collect:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.map(function(each) {return aBlock._value_(each)});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock},$globals.Array)});
- },
- args: ["aBlock"],
- source: "collect: aBlock\x0a\x09\x22Optimized version\x22\x0a\x09\x0a\x09<inlineJS: 'return self.map(function(each) {return aBlock._value_(each)})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "copyFrom:to:",
- protocol: "copying",
- fn: function (anIndex,anotherIndex){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (anIndex >= 1 && anotherIndex <= self.length) {
- return self.slice(anIndex - 1, anotherIndex);
- } else {
- self._at_(anIndex);
- self._at_(self.length + 1);
- throw new Error("Incorrect indexes in #copyFrom:to: not caught by #at:");
- };
- return self;
- }, function($ctx1) {$ctx1.fill(self,"copyFrom:to:",{anIndex:anIndex,anotherIndex:anotherIndex},$globals.Array)});
- },
- args: ["anIndex", "anotherIndex"],
- source: "copyFrom: anIndex to: anotherIndex\x0a<inlineJS: '\x0a\x09if (anIndex >= 1 && anotherIndex <= self.length) {\x0a\x09\x09return self.slice(anIndex - 1, anotherIndex);\x0a\x09} else {\x0a\x09\x09self._at_(anIndex);\x0a\x09\x09self._at_(self.length + 1);\x0a\x09\x09throw new Error(\x22Incorrect indexes in #copyFrom:to: not caught by #at:\x22);\x0a\x09}\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "join:",
- protocol: "enumerating",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.join(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"join:",{aString:aString},$globals.Array)});
- },
- args: ["aString"],
- source: "join: aString\x0a\x09<inlineJS: 'return self.join(aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "numericallyIndexable",
- protocol: "private",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "numericallyIndexable\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Array.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $ctx1.sendIdx["printOn:"]=1;
- $recv(aStream)._nextPutAll_(" (");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._printOn_(aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(aStream)._nextPutAll_(" ");
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Array)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09\x0a\x09aStream nextPutAll: ' ('.\x0a\x09self \x0a\x09\x09do: [ :each | each printOn: aStream ]\x0a\x09\x09separatedBy: [ aStream nextPutAll: ' ' ].\x0a\x09aStream nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "do:separatedBy:"]
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "remove:ifAbsent:",
- protocol: "adding/removing",
- fn: function (anObject,aBlock){
- var self=this;
- var index;
- return $core.withContext(function($ctx1) {
- var $1;
- index=self._indexOf_ifAbsent_(anObject,(function(){
- return (0);
- }));
- $1=$recv(index).__eq((0));
- if($core.assert($1)){
- return $recv(aBlock)._value();
- } else {
- self._removeIndex_(index);
- return anObject;
- }
- }, function($ctx1) {$ctx1.fill(self,"remove:ifAbsent:",{anObject:anObject,aBlock:aBlock,index:index},$globals.Array)});
- },
- args: ["anObject", "aBlock"],
- source: "remove: anObject ifAbsent: aBlock\x0a\x09| index |\x0a\x09index := self indexOf: anObject ifAbsent: [ 0 ].\x0a\x09^ index = 0\x0a\x09\x09ifFalse: [ self removeIndex: index. anObject ]\x0a\x09\x09ifTrue: [ aBlock value ]",
- referencedClasses: [],
- messageSends: ["indexOf:ifAbsent:", "ifFalse:ifTrue:", "=", "removeIndex:", "value"]
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "removeAll",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.length = 0;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeAll",{},$globals.Array)});
- },
- args: [],
- source: "removeAll\x0a\x09<inlineJS: 'self.length = 0'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "removeFrom:to:",
- protocol: "adding/removing",
- fn: function (aNumber,anotherNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.splice(aNumber -1, anotherNumber - aNumber + 1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeFrom:to:",{aNumber:aNumber,anotherNumber:anotherNumber},$globals.Array)});
- },
- args: ["aNumber", "anotherNumber"],
- source: "removeFrom: aNumber to: anotherNumber\x0a\x09<inlineJS: 'self.splice(aNumber -1, anotherNumber - aNumber + 1)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "removeIndex:",
- protocol: "adding/removing",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.splice(anInteger - 1, 1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeIndex:",{anInteger:anInteger},$globals.Array)});
- },
- args: ["anInteger"],
- source: "removeIndex: anInteger\x0a\x09<inlineJS: 'self.splice(anInteger - 1, 1)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "removeLast",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.pop();;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeLast",{},$globals.Array)});
- },
- args: [],
- source: "removeLast\x0a\x09<inlineJS: 'return self.pop();'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "reversed",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.slice().reverse();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"reversed",{},$globals.Array)});
- },
- args: [],
- source: "reversed\x0a\x09<inlineJS: 'return self.slice().reverse()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "select:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.filter(function(each) {return aBlock._value_(each)});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"select:",{aBlock:aBlock},$globals.Array)});
- },
- args: ["aBlock"],
- source: "select: aBlock\x0a\x09\x22Optimized version\x22\x0a\x09\x0a\x09<inlineJS: 'return self.filter(function(each) {return aBlock._value_(each)})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "shallowCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.slice();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{},$globals.Array)});
- },
- args: [],
- source: "shallowCopy\x0a\x09<inlineJS: 'return self.slice()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.length;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"size",{},$globals.Array)});
- },
- args: [],
- source: "size\x0a\x09<inlineJS: 'return self.length'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "sort",
- protocol: "enumerating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._sort_((function(a,b){
- return $core.withContext(function($ctx2) {
- return $recv(a).__lt(b);
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"sort",{},$globals.Array)});
- },
- args: [],
- source: "sort\x0a\x09^ self sort: [ :a :b | a < b ]",
- referencedClasses: [],
- messageSends: ["sort:", "<"]
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "sort:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.sort(function(a, b) {
- if(aBlock._value_value_(a,b)) {return -1} else {return 1}
- })
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sort:",{aBlock:aBlock},$globals.Array)});
- },
- args: ["aBlock"],
- source: "sort: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09return self.sort(function(a, b) {\x0a\x09\x09\x09if(aBlock._value_value_(a,b)) {return -1} else {return 1}\x0a\x09\x09})\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "sorted",
- protocol: "enumerating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._copy())._sort();
- }, function($ctx1) {$ctx1.fill(self,"sorted",{},$globals.Array)});
- },
- args: [],
- source: "sorted\x0a\x09^ self copy sort",
- referencedClasses: [],
- messageSends: ["sort", "copy"]
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "sorted:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._copy())._sort_(aBlock);
- }, function($ctx1) {$ctx1.fill(self,"sorted:",{aBlock:aBlock},$globals.Array)});
- },
- args: ["aBlock"],
- source: "sorted: aBlock\x0a\x09^ self copy sort: aBlock",
- referencedClasses: [],
- messageSends: ["sort:", "copy"]
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "new:",
- protocol: "instance creation",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new Array(anInteger);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new:",{anInteger:anInteger},$globals.Array.klass)});
- },
- args: ["anInteger"],
- source: "new: anInteger\x0a\x09<inlineJS: 'return new Array(anInteger)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Array.klass);
- $core.addMethod(
- $core.method({
- selector: "with:",
- protocol: "instance creation",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new_((1));
- $recv($1)._at_put_((1),anObject);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"with:",{anObject:anObject},$globals.Array.klass)});
- },
- args: ["anObject"],
- source: "with: anObject\x0a\x09\x09^ (self new: 1)\x0a\x09\x09at: 1 put: anObject;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["at:put:", "new:", "yourself"]
- }),
- $globals.Array.klass);
- $core.addMethod(
- $core.method({
- selector: "with:with:",
- protocol: "instance creation",
- fn: function (anObject,anObject2){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new_((2));
- $recv($1)._at_put_((1),anObject);
- $ctx1.sendIdx["at:put:"]=1;
- $recv($1)._at_put_((2),anObject2);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"with:with:",{anObject:anObject,anObject2:anObject2},$globals.Array.klass)});
- },
- args: ["anObject", "anObject2"],
- source: "with: anObject with: anObject2\x0a\x09\x09^ (self new: 2)\x0a\x09\x09at: 1 put: anObject;\x0a\x09\x09at: 2 put: anObject2;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["at:put:", "new:", "yourself"]
- }),
- $globals.Array.klass);
- $core.addMethod(
- $core.method({
- selector: "with:with:with:",
- protocol: "instance creation",
- fn: function (anObject,anObject2,anObject3){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new_((3));
- $recv($1)._at_put_((1),anObject);
- $ctx1.sendIdx["at:put:"]=1;
- $recv($1)._at_put_((2),anObject2);
- $ctx1.sendIdx["at:put:"]=2;
- $recv($1)._at_put_((3),anObject3);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"with:with:with:",{anObject:anObject,anObject2:anObject2,anObject3:anObject3},$globals.Array.klass)});
- },
- args: ["anObject", "anObject2", "anObject3"],
- source: "with: anObject with: anObject2 with: anObject3\x0a\x09\x09^ (self new: 3)\x0a\x09\x09at: 1 put: anObject;\x0a\x09\x09at: 2 put: anObject2;\x0a\x09\x09at: 3 put: anObject3;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["at:put:", "new:", "yourself"]
- }),
- $globals.Array.klass);
- $core.addMethod(
- $core.method({
- selector: "withAll:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- var instance,index;
- return $core.withContext(function($ctx1) {
- index=(1);
- instance=self._new_($recv(aCollection)._size());
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $recv(instance)._at_put_(index,each);
- index=$recv(index).__plus((1));
- return index;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return instance;
- }, function($ctx1) {$ctx1.fill(self,"withAll:",{aCollection:aCollection,instance:instance,index:index},$globals.Array.klass)});
- },
- args: ["aCollection"],
- source: "withAll: aCollection\x0a\x09| instance index |\x0a\x09index := 1.\x0a\x09instance := self new: aCollection size.\x0a\x09aCollection do: [ :each |\x0a\x09\x09instance at: index put: each.\x0a\x09\x09index := index + 1 ].\x0a\x09^ instance",
- referencedClasses: [],
- messageSends: ["new:", "size", "do:", "at:put:", "+"]
- }),
- $globals.Array.klass);
- $core.addClass("CharacterArray", $globals.SequenceableCollection, [], "Kernel-Collections");
- $globals.CharacterArray.comment="I am the abstract superclass of string-like collections.";
- $core.addMethod(
- $core.method({
- selector: ",",
- protocol: "copying",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._asString();
- $ctx1.sendIdx["asString"]=1;
- return $recv($1).__comma($recv(aString)._asString());
- }, function($ctx1) {$ctx1.fill(self,",",{aString:aString},$globals.CharacterArray)});
- },
- args: ["aString"],
- source: ", aString\x0a\x09^ self asString, aString asString",
- referencedClasses: [],
- messageSends: [",", "asString"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "add:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._errorReadOnly();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject},$globals.CharacterArray)});
- },
- args: ["anObject"],
- source: "add: anObject\x0a\x09self errorReadOnly",
- referencedClasses: [],
- messageSends: ["errorReadOnly"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "asLowercase",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._fromString_($recv(self._asString())._asLowercase());
- }, function($ctx1) {$ctx1.fill(self,"asLowercase",{},$globals.CharacterArray)});
- },
- args: [],
- source: "asLowercase\x0a\x09^ self class fromString: self asString asLowercase",
- referencedClasses: [],
- messageSends: ["fromString:", "class", "asLowercase", "asString"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "asNumber",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asString())._asNumber();
- }, function($ctx1) {$ctx1.fill(self,"asNumber",{},$globals.CharacterArray)});
- },
- args: [],
- source: "asNumber\x0a\x09^ self asString asNumber",
- referencedClasses: [],
- messageSends: ["asNumber", "asString"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "asString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclassResponsibility();
- }, function($ctx1) {$ctx1.fill(self,"asString",{},$globals.CharacterArray)});
- },
- args: [],
- source: "asString\x0a\x09^ self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "asSymbol",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._asString();
- }, function($ctx1) {$ctx1.fill(self,"asSymbol",{},$globals.CharacterArray)});
- },
- args: [],
- source: "asSymbol\x0a\x09^ self asString",
- referencedClasses: [],
- messageSends: ["asString"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "asSymbolPrintOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(aStream)._nextPutAll_("#");
- $1=$recv(self._asString())._isSelector();
- if($core.assert($1)){
- $recv(aStream)._nextPut_(self);
- } else {
- self._printOn_(aStream);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asSymbolPrintOn:",{aStream:aStream},$globals.CharacterArray)});
- },
- args: ["aStream"],
- source: "asSymbolPrintOn: aStream\x0a\x09aStream nextPutAll: '#'.\x0a\x09self asString isSelector\x0a\x09\x09ifTrue: [ aStream nextPut: self ]\x0a\x09\x09ifFalse: [ self printOn: aStream ]",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "ifTrue:ifFalse:", "isSelector", "asString", "nextPut:", "printOn:"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "asUppercase",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._fromString_($recv(self._asString())._asUppercase());
- }, function($ctx1) {$ctx1.fill(self,"asUppercase",{},$globals.CharacterArray)});
- },
- args: [],
- source: "asUppercase\x0a\x09^ self class fromString: self asString asUppercase",
- referencedClasses: [],
- messageSends: ["fromString:", "class", "asUppercase", "asString"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "at:put:",
- protocol: "accessing",
- fn: function (anIndex,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._errorReadOnly();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:put:",{anIndex:anIndex,anObject:anObject},$globals.CharacterArray)});
- },
- args: ["anIndex", "anObject"],
- source: "at: anIndex put: anObject\x0a\x09self errorReadOnly",
- referencedClasses: [],
- messageSends: ["errorReadOnly"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "errorReadOnly",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._error_("Object is read-only");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"errorReadOnly",{},$globals.CharacterArray)});
- },
- args: [],
- source: "errorReadOnly\x0a\x09self error: 'Object is read-only'",
- referencedClasses: [],
- messageSends: ["error:"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._asString())._printOn_(aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.CharacterArray)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09self asString printOn: aStream",
- referencedClasses: [],
- messageSends: ["printOn:", "asString"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "putOn:",
- protocol: "streaming",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutString_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"putOn:",{aStream:aStream},$globals.CharacterArray)});
- },
- args: ["aStream"],
- source: "putOn: aStream\x0a\x09aStream nextPutString: self",
- referencedClasses: [],
- messageSends: ["nextPutString:"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "remove:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._errorReadOnly();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"remove:",{anObject:anObject},$globals.CharacterArray)});
- },
- args: ["anObject"],
- source: "remove: anObject\x0a\x09self errorReadOnly",
- referencedClasses: [],
- messageSends: ["errorReadOnly"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "symbolPrintString",
- protocol: "printing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- return self._asSymbolPrintOn_(str);
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"symbolPrintString",{},$globals.CharacterArray)});
- },
- args: [],
- source: "symbolPrintString\x0a\x09^ String streamContents: [ :str | self asSymbolPrintOn: str ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "asSymbolPrintOn:"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "fromString:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fromString:",{aString:aString},$globals.CharacterArray.klass)});
- },
- args: ["aString"],
- source: "fromString: aString\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.CharacterArray.klass);
- $core.addClass("String", $globals.CharacterArray, [], "Kernel-Collections");
- $globals.String.comment="I am an indexed collection of Characters. Unlike most Smalltalk dialects, Amber doesn't provide the Character class. Instead, elements of a String are single character strings.\x0a\x0aString inherits many useful methods from its hierarchy, such as\x0a\x09`Collection >> #,`";
- $core.addMethod(
- $core.method({
- selector: ",",
- protocol: "copying",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self) + aString;
- return self;
- }, function($ctx1) {$ctx1.fill(self,",",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: ", aString\x0a\x09<inlineJS: 'return String(self) + aString'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "<",
- protocol: "comparing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self) < aString._asString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"<",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: "< aString\x0a\x09<inlineJS: 'return String(self) < aString._asString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "<=",
- protocol: "comparing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self) <= aString._asString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"<=",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: "<= aString\x0a\x09<inlineJS: 'return String(self) <= aString._asString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return aString != null && String(self) === (typeof aString === "string" ? aString : aString.valueOf());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"=",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: "= aString\x0a<inlineJS:\x0a\x09'return aString != null && String(self) === (typeof aString === \x22string\x22 ? aString : aString.valueOf())'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "==",
- protocol: "comparing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (typeof aString === "string") return String(self) === aString;
- else if (aString != null && typeof aString === "object") return String(self) === aString.valueOf();
- else return false;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"==",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: "== aString\x0a<inlineJS: '\x0a\x09if (typeof aString === \x22string\x22) return String(self) === aString;\x0a\x09else if (aString != null && typeof aString === \x22object\x22) return String(self) === aString.valueOf();\x0a\x09else return false;\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: ">",
- protocol: "comparing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self) > aString._asString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,">",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: "> aString\x0a\x09<inlineJS: 'return String(self) > aString._asString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: ">=",
- protocol: "comparing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self) >= aString._asString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,">=",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: ">= aString\x0a\x09<inlineJS: 'return String(self) >= aString._asString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptMethodName",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.st2js(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptMethodName",{},$globals.String)});
- },
- args: [],
- source: "asJavaScriptMethodName\x0a\x09<inlineJS: 'return $core.st2js(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- if(self.search(/^[a-zA-Z0-9_:.$ ]*$/) == -1)
- return "\"" + self.replace(/[\x00-\x1f"\\\x7f-\x9f]/g, function(ch){var c=ch.charCodeAt(0);return "\\x"+("0"+c.toString(16)).slice(-2)}) + "\"";
- else
- return "\"" + self + "\"";
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.String)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09<inlineJS: '\x0a\x09\x09if(self.search(/^[a-zA-Z0-9_:.$ ]*$/) == -1)\x0a\x09\x09\x09return \x22\x5c\x22\x22 + self.replace(/[\x5cx00-\x5cx1f\x22\x5c\x5c\x5cx7f-\x5cx9f]/g, function(ch){var c=ch.charCodeAt(0);return \x22\x5c\x5cx\x22+(\x220\x22+c.toString(16)).slice(-2)}) + \x22\x5c\x22\x22;\x0a\x09\x09else\x0a\x09\x09\x09return \x22\x5c\x22\x22 + self + \x22\x5c\x22\x22;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asLowercase",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toLowerCase();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asLowercase",{},$globals.String)});
- },
- args: [],
- source: "asLowercase\x0a\x09<inlineJS: 'return self.toLowerCase()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asMutator",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._last()).__eq(":");
- if(!$core.assert($1)){
- return self.__comma(":");
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asMutator",{},$globals.String)});
- },
- args: [],
- source: "asMutator\x0a\x09\x22Answer a setter selector. For example,\x0a\x09#name asMutator returns #name:\x22\x0a\x0a\x09self last = ':' ifFalse: [ ^ self, ':' ].\x0a\x09^ self",
- referencedClasses: [],
- messageSends: ["ifFalse:", "=", "last", ","]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asNumber",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Number(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asNumber",{},$globals.String)});
- },
- args: [],
- source: "asNumber\x0a\x09<inlineJS: 'return Number(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asRegexp",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.RegularExpression)._fromString_(self);
- }, function($ctx1) {$ctx1.fill(self,"asRegexp",{},$globals.String)});
- },
- args: [],
- source: "asRegexp\x0a\x09^ RegularExpression fromString: self",
- referencedClasses: ["RegularExpression"],
- messageSends: ["fromString:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asString\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asSymbol",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asSymbol\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asUppercase",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toUpperCase();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asUppercase",{},$globals.String)});
- },
- args: [],
- source: "asUppercase\x0a\x09<inlineJS: 'return self.toUpperCase()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asciiValue",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.charCodeAt(0);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asciiValue",{},$globals.String)});
- },
- args: [],
- source: "asciiValue\x0a\x09<inlineJS: 'return self.charCodeAt(0);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsent:",
- protocol: "accessing",
- fn: function (anIndex,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self)[anIndex - 1] || aBlock._value();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{anIndex:anIndex,aBlock:aBlock},$globals.String)});
- },
- args: ["anIndex", "aBlock"],
- source: "at: anIndex ifAbsent: aBlock\x0a\x09<inlineJS: 'return String(self)[anIndex - 1] || aBlock._value()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: "accessing",
- fn: function (anIndex,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var result = String(self)[anIndex - 1];
- return result ? aBlock._value_(result) : anotherBlock._value();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{anIndex:anIndex,aBlock:aBlock,anotherBlock:anotherBlock},$globals.String)});
- },
- args: ["anIndex", "aBlock", "anotherBlock"],
- source: "at: anIndex ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09<inlineJS: '\x0a\x09\x09var result = String(self)[anIndex - 1];\x0a\x09\x09return result ? aBlock._value_(result) : anotherBlock._value();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "capitalized",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv(self._first())._asUppercase()).__comma(self._allButFirst());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"capitalized",{},$globals.String)});
- },
- args: [],
- source: "capitalized\x0a\x09^ self ifNotEmpty: [ self first asUppercase, self allButFirst ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", ",", "asUppercase", "first", "allButFirst"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "charCodeAt:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.charCodeAt(anInteger - 1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"charCodeAt:",{anInteger:anInteger},$globals.String)});
- },
- args: ["anInteger"],
- source: "charCodeAt: anInteger\x0a\x09<inlineJS: 'return self.charCodeAt(anInteger - 1)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "copyFrom:to:",
- protocol: "copying",
- fn: function (anIndex,anotherIndex){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.substring(anIndex - 1, anotherIndex);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"copyFrom:to:",{anIndex:anIndex,anotherIndex:anotherIndex},$globals.String)});
- },
- args: ["anIndex", "anotherIndex"],
- source: "copyFrom: anIndex to: anotherIndex\x0a\x09<inlineJS: 'return self.substring(anIndex - 1, anotherIndex)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "crlfSanitized",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._lines())._join_($recv($globals.String)._lf());
- }, function($ctx1) {$ctx1.fill(self,"crlfSanitized",{},$globals.String)});
- },
- args: [],
- source: "crlfSanitized\x0a\x09^ self lines join: String lf",
- referencedClasses: ["String"],
- messageSends: ["join:", "lines", "lf"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "deepCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._shallowCopy();
- }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},$globals.String)});
- },
- args: [],
- source: "deepCopy\x0a\x09^ self shallowCopy",
- referencedClasses: [],
- messageSends: ["shallowCopy"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "escaped",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return escape(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"escaped",{},$globals.String)});
- },
- args: [],
- source: "escaped\x0a\x09<inlineJS: 'return escape(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "includesSubString:",
- protocol: "testing",
- fn: function (subString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.indexOf(subString) != -1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"includesSubString:",{subString:subString},$globals.String)});
- },
- args: ["subString"],
- source: "includesSubString: subString\x0a\x09<inlineJS: 'return self.indexOf(subString) != -1'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "isCapitalized",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._first();
- $ctx1.sendIdx["first"]=1;
- $1=$recv($2)._asUppercase();
- return $recv($1).__eq_eq(self._first());
- }, function($ctx1) {$ctx1.fill(self,"isCapitalized",{},$globals.String)});
- },
- args: [],
- source: "isCapitalized\x0a\x09^ self first asUppercase == self first",
- referencedClasses: [],
- messageSends: ["==", "asUppercase", "first"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "isSelector",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return !!self.match(/^([a-zA-Z][a-zA-Z0-9]*|[\\+*/=><,@%~|&-]+|([a-zA-Z][a-zA-Z0-9]*\:)+)$/);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"isSelector",{},$globals.String)});
- },
- args: [],
- source: "isSelector\x0a<inlineJS:\x0a\x09'return !!self.match(/^([a-zA-Z][a-zA-Z0-9]*|[\x5c\x5c+*/=><,@%~|&-]+|([a-zA-Z][a-zA-Z0-9]*\x5c:)+)$/)'\x0a>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "isString",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isString\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "isVowel",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._size()).__eq((1)))._and_((function(){
- return $core.withContext(function($ctx2) {
- return "aeiou"._includes_(self._asLowercase());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"isVowel",{},$globals.String)});
- },
- args: [],
- source: "isVowel\x0a\x09\x22Answer true if the receiver is a one character string containing a voyel\x22\x0a\x09\x0a\x09^ self size = 1 and: [ 'aeiou' includes: self asLowercase ]",
- referencedClasses: [],
- messageSends: ["and:", "=", "size", "includes:", "asLowercase"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "join:",
- protocol: "split join",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- return $recv(aCollection)._do_separatedBy_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(stream)._nextPutAll_($recv(each)._asString());
- $ctx3.sendIdx["nextPutAll:"]=1;
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)});
- }),(function(){
- return $core.withContext(function($ctx3) {
- return $recv(stream)._nextPutAll_(self);
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"join:",{aCollection:aCollection},$globals.String)});
- },
- args: ["aCollection"],
- source: "join: aCollection\x0a\x09^ String\x0a\x09\x09streamContents: [ :stream | aCollection\x0a\x09\x09\x09\x09do: [ :each | stream nextPutAll: each asString ]\x0a\x09\x09\x09\x09separatedBy: [ stream nextPutAll: self ]]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "do:separatedBy:", "nextPutAll:", "asString"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "lineIndicesDo:",
- protocol: "split join",
- fn: function (aBlock){
- var self=this;
- var cr,lf,start,sz,nextLF,nextCR;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$5,$3,$6,$7,$9,$8,$10,$11;
- var $early={};
- try {
- start=(1);
- sz=self._size();
- cr=$recv($globals.String)._cr();
- nextCR=self._indexOf_startingAt_(cr,(1));
- $ctx1.sendIdx["indexOf:startingAt:"]=1;
- lf=$recv($globals.String)._lf();
- nextLF=self._indexOf_startingAt_(lf,(1));
- $ctx1.sendIdx["indexOf:startingAt:"]=2;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(start).__lt_eq(sz);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- $2=$recv(nextLF).__eq((0));
- $ctx2.sendIdx["="]=1;
- $1=$recv($2)._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(nextCR).__eq((0));
- $ctx3.sendIdx["="]=2;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- $ctx2.sendIdx["and:"]=1;
- if($core.assert($1)){
- $recv(aBlock)._value_value_value_(start,sz,sz);
- $ctx2.sendIdx["value:value:value:"]=1;
- throw $early=[self];
- }
- $4=$recv(nextCR).__eq((0));
- $ctx2.sendIdx["="]=3;
- $3=$recv($4)._or_((function(){
- return $core.withContext(function($ctx3) {
- $5=(0).__lt(nextLF);
- $ctx3.sendIdx["<"]=1;
- return $recv($5)._and_((function(){
- return $core.withContext(function($ctx4) {
- return $recv(nextLF).__lt(nextCR);
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,6)});
- }));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,5)});
- }));
- if($core.assert($3)){
- $6=start;
- $7=$recv(nextLF).__minus((1));
- $ctx2.sendIdx["-"]=1;
- $recv(aBlock)._value_value_value_($6,$7,nextLF);
- $ctx2.sendIdx["value:value:value:"]=2;
- start=(1).__plus(nextLF);
- $ctx2.sendIdx["+"]=1;
- start;
- nextLF=self._indexOf_startingAt_(lf,start);
- $ctx2.sendIdx["indexOf:startingAt:"]=3;
- return nextLF;
- } else {
- $9=(1).__plus(nextCR);
- $ctx2.sendIdx["+"]=2;
- $8=$recv($9).__eq(nextLF);
- if($core.assert($8)){
- $10=start;
- $11=$recv(nextCR).__minus((1));
- $ctx2.sendIdx["-"]=2;
- $recv(aBlock)._value_value_value_($10,$11,nextLF);
- $ctx2.sendIdx["value:value:value:"]=3;
- start=(1).__plus(nextLF);
- $ctx2.sendIdx["+"]=3;
- start;
- nextCR=self._indexOf_startingAt_(cr,start);
- $ctx2.sendIdx["indexOf:startingAt:"]=4;
- nextCR;
- nextLF=self._indexOf_startingAt_(lf,start);
- $ctx2.sendIdx["indexOf:startingAt:"]=5;
- return nextLF;
- } else {
- $recv(aBlock)._value_value_value_(start,$recv(nextCR).__minus((1)),nextCR);
- start=(1).__plus(nextCR);
- start;
- nextCR=self._indexOf_startingAt_(cr,start);
- return nextCR;
- }
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"lineIndicesDo:",{aBlock:aBlock,cr:cr,lf:lf,start:start,sz:sz,nextLF:nextLF,nextCR:nextCR},$globals.String)});
- },
- args: ["aBlock"],
- source: "lineIndicesDo: aBlock\x0a\x09\x22execute aBlock with 3 arguments for each line:\x0a\x09- start index of line\x0a\x09- end index of line without line delimiter\x0a\x09- end index of line including line delimiter(s) CR, LF or CRLF\x22\x0a\x09\x0a\x09| cr lf start sz nextLF nextCR |\x0a\x09start := 1.\x0a\x09sz := self size.\x0a\x09cr := String cr.\x0a\x09nextCR := self indexOf: cr startingAt: 1.\x0a\x09lf := String lf.\x0a\x09nextLF := self indexOf: lf startingAt: 1.\x0a\x09[ start <= sz ] whileTrue: [ \x0a\x09\x09(nextLF = 0 and: [ nextCR = 0 ])\x0a\x09\x09\x09ifTrue: [ \x22No more CR, nor LF, the string is over\x22\x0a\x09\x09\x09\x09\x09aBlock value: start value: sz value: sz.\x0a\x09\x09\x09\x09\x09^ self ].\x0a\x09\x09(nextCR = 0 or: [ 0 < nextLF and: [ nextLF < nextCR ] ])\x0a\x09\x09\x09ifTrue: [ \x22Found a LF\x22\x0a\x09\x09\x09\x09\x09aBlock value: start value: nextLF - 1 value: nextLF.\x0a\x09\x09\x09\x09\x09start := 1 + nextLF.\x0a\x09\x09\x09\x09\x09nextLF := self indexOf: lf startingAt: start ]\x0a\x09\x09\x09ifFalse: [ 1 + nextCR = nextLF\x0a\x09\x09\x09\x09ifTrue: [ \x22Found a CR-LF pair\x22\x0a\x09\x09\x09\x09\x09aBlock value: start value: nextCR - 1 value: nextLF.\x0a\x09\x09\x09\x09\x09start := 1 + nextLF.\x0a\x09\x09\x09\x09\x09nextCR := self indexOf: cr startingAt: start.\x0a\x09\x09\x09\x09\x09nextLF := self indexOf: lf startingAt: start ]\x0a\x09\x09\x09\x09ifFalse: [ \x22Found a CR\x22\x0a\x09\x09\x09\x09\x09aBlock value: start value: nextCR - 1 value: nextCR.\x0a\x09\x09\x09\x09\x09start := 1 + nextCR.\x0a\x09\x09\x09\x09\x09nextCR := self indexOf: cr startingAt: start ] ]]",
- referencedClasses: ["String"],
- messageSends: ["size", "cr", "indexOf:startingAt:", "lf", "whileTrue:", "<=", "ifTrue:", "and:", "=", "value:value:value:", "ifTrue:ifFalse:", "or:", "<", "-", "+"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "lineNumber:",
- protocol: "split join",
- fn: function (anIndex){
- var self=this;
- var lineCount;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- var $early={};
- try {
- lineCount=(0);
- self._lineIndicesDo_((function(start,endWithoutDelimiters,end){
- return $core.withContext(function($ctx2) {
- lineCount=$recv(lineCount).__plus((1));
- $2=lineCount;
- $1=$recv($2).__eq(anIndex);
- if($core.assert($1)){
- throw $early=[self._copyFrom_to_(start,endWithoutDelimiters)];
- }
- }, function($ctx2) {$ctx2.fillBlock({start:start,endWithoutDelimiters:endWithoutDelimiters,end:end},$ctx1,1)});
- }));
- return nil;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"lineNumber:",{anIndex:anIndex,lineCount:lineCount},$globals.String)});
- },
- args: ["anIndex"],
- source: "lineNumber: anIndex\x0a\x09\x22Answer a string containing the characters in the given line number.\x22\x0a\x0a\x09| lineCount |\x0a\x09lineCount := 0.\x0a\x09self lineIndicesDo: [ :start :endWithoutDelimiters :end |\x0a\x09\x09(lineCount := lineCount + 1) = anIndex ifTrue: [ ^ self copyFrom: start to: endWithoutDelimiters ]].\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: ["lineIndicesDo:", "ifTrue:", "=", "+", "copyFrom:to:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "lines",
- protocol: "split join",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var result = self.split(/\r\n|\r|\n/);
- if (!result[result.length-1]) result.pop();
- return result;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"lines",{},$globals.String)});
- },
- args: [],
- source: "lines\x0a\x09\x22Answer an array of lines composing this receiver without the line ending delimiters.\x22\x0a<inlineJS: '\x0a\x09var result = self.split(/\x5cr\x5cn|\x5cr|\x5cn/);\x0a\x09if (!result[result.length-1]) result.pop();\x0a\x09return result;\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "linesDo:",
- protocol: "split join",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._lines())._do_(aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"linesDo:",{aBlock:aBlock},$globals.String)});
- },
- args: ["aBlock"],
- source: "linesDo: aBlock\x0a\x09\x22Execute aBlock with each line in this string. The terminating line\x0a\x09delimiters CR, LF or CRLF pairs are not included in what is passed to aBlock\x22\x0a\x0a\x09self lines do: aBlock",
- referencedClasses: [],
- messageSends: ["do:", "lines"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "match:",
- protocol: "regular expressions",
- fn: function (aRegexp){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.search(aRegexp) != -1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"match:",{aRegexp:aRegexp},$globals.String)});
- },
- args: ["aRegexp"],
- source: "match: aRegexp\x0a\x09<inlineJS: 'return self.search(aRegexp) != -1'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "matchesOf:",
- protocol: "regular expressions",
- fn: function (aRegularExpression){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.match(aRegularExpression);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"matchesOf:",{aRegularExpression:aRegularExpression},$globals.String)});
- },
- args: ["aRegularExpression"],
- source: "matchesOf: aRegularExpression\x0a\x09<inlineJS: 'return self.match(aRegularExpression)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "numericallyIndexable",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"numericallyIndexable",{},$globals.String)});
- },
- args: [],
- source: "numericallyIndexable\x0a\x09<inlineJS: 'return String(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "printNl",
- protocol: "printing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- console.log(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printNl",{},$globals.String)});
- },
- args: [],
- source: "printNl\x0a\x09<inlineJS: 'console.log(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutAll_("'");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._nextPutAll_(self._replace_with_("'","''"));
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv(aStream)._nextPutAll_("'");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.String)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09aStream \x0a\x09\x09nextPutAll: '''';\x0a\x09\x09nextPutAll: (self replace: '''' with: '''''');\x0a\x09\x09nextPutAll: ''''",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "replace:with:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "replace:with:",
- protocol: "regular expressions",
- fn: function (aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._replaceRegexp_with_($recv($globals.RegularExpression)._fromString_flag_(aString,"g"),anotherString);
- }, function($ctx1) {$ctx1.fill(self,"replace:with:",{aString:aString,anotherString:anotherString},$globals.String)});
- },
- args: ["aString", "anotherString"],
- source: "replace: aString with: anotherString\x0a\x09^ self replaceRegexp: (RegularExpression fromString: aString flag: 'g') with: anotherString",
- referencedClasses: ["RegularExpression"],
- messageSends: ["replaceRegexp:with:", "fromString:flag:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "replaceRegexp:with:",
- protocol: "regular expressions",
- fn: function (aRegexp,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.replace(aRegexp, aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"replaceRegexp:with:",{aRegexp:aRegexp,aString:aString},$globals.String)});
- },
- args: ["aRegexp", "aString"],
- source: "replaceRegexp: aRegexp with: aString\x0a\x09<inlineJS: 'return self.replace(aRegexp, aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "reversed",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.split("").reverse().join("");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"reversed",{},$globals.String)});
- },
- args: [],
- source: "reversed\x0a\x09<inlineJS: 'return self.split(\x22\x22).reverse().join(\x22\x22)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "shallowCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "shallowCopy\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.length;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"size",{},$globals.String)});
- },
- args: [],
- source: "size\x0a\x09<inlineJS: 'return self.length'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "subStrings:",
- protocol: "split join",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._tokenize_(aString);
- }, function($ctx1) {$ctx1.fill(self,"subStrings:",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: "subStrings: aString\x0a\x09^ self tokenize: aString",
- referencedClasses: [],
- messageSends: ["tokenize:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "tokenize:",
- protocol: "split join",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.split(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tokenize:",{aString:aString},$globals.String)});
- },
- args: ["aString"],
- source: "tokenize: aString\x0a\x09<inlineJS: 'return self.split(aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "trimBoth",
- protocol: "regular expressions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._trimBoth_("\x5cs");
- }, function($ctx1) {$ctx1.fill(self,"trimBoth",{},$globals.String)});
- },
- args: [],
- source: "trimBoth\x0a\x09^ self trimBoth: '\x5cs'",
- referencedClasses: [],
- messageSends: ["trimBoth:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "trimBoth:",
- protocol: "regular expressions",
- fn: function (separators){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._trimLeft_(separators))._trimRight_(separators);
- }, function($ctx1) {$ctx1.fill(self,"trimBoth:",{separators:separators},$globals.String)});
- },
- args: ["separators"],
- source: "trimBoth: separators\x0a\x09^ (self trimLeft: separators) trimRight: separators",
- referencedClasses: [],
- messageSends: ["trimRight:", "trimLeft:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "trimLeft",
- protocol: "regular expressions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._trimLeft_("\x5cs");
- }, function($ctx1) {$ctx1.fill(self,"trimLeft",{},$globals.String)});
- },
- args: [],
- source: "trimLeft\x0a\x09^ self trimLeft: '\x5cs'",
- referencedClasses: [],
- messageSends: ["trimLeft:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "trimLeft:",
- protocol: "regular expressions",
- fn: function (separators){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv("^[".__comma(separators)).__comma("]+");
- $ctx1.sendIdx[","]=1;
- $1=$recv($globals.RegularExpression)._fromString_flag_($2,"g");
- return self._replaceRegexp_with_($1,"");
- }, function($ctx1) {$ctx1.fill(self,"trimLeft:",{separators:separators},$globals.String)});
- },
- args: ["separators"],
- source: "trimLeft: separators\x0a\x09^ self replaceRegexp: (RegularExpression fromString: '^[', separators, ']+' flag: 'g') with: ''",
- referencedClasses: ["RegularExpression"],
- messageSends: ["replaceRegexp:with:", "fromString:flag:", ","]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "trimRight",
- protocol: "regular expressions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._trimRight_("\x5cs");
- }, function($ctx1) {$ctx1.fill(self,"trimRight",{},$globals.String)});
- },
- args: [],
- source: "trimRight\x0a\x09^ self trimRight: '\x5cs'",
- referencedClasses: [],
- messageSends: ["trimRight:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "trimRight:",
- protocol: "regular expressions",
- fn: function (separators){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv("[".__comma(separators)).__comma("]+$");
- $ctx1.sendIdx[","]=1;
- $1=$recv($globals.RegularExpression)._fromString_flag_($2,"g");
- return self._replaceRegexp_with_($1,"");
- }, function($ctx1) {$ctx1.fill(self,"trimRight:",{separators:separators},$globals.String)});
- },
- args: ["separators"],
- source: "trimRight: separators\x0a\x09^ self replaceRegexp: (RegularExpression fromString: '[', separators, ']+$' flag: 'g') with: ''",
- referencedClasses: ["RegularExpression"],
- messageSends: ["replaceRegexp:with:", "fromString:flag:", ","]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "unescaped",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return unescape(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"unescaped",{},$globals.String)});
- },
- args: [],
- source: "unescaped\x0a\x09<inlineJS: 'return unescape(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "uriComponentDecoded",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return decodeURIComponent(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"uriComponentDecoded",{},$globals.String)});
- },
- args: [],
- source: "uriComponentDecoded\x0a\x09<inlineJS: 'return decodeURIComponent(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "uriComponentEncoded",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return encodeURIComponent(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"uriComponentEncoded",{},$globals.String)});
- },
- args: [],
- source: "uriComponentEncoded\x0a\x09<inlineJS: 'return encodeURIComponent(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "uriDecoded",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return decodeURI(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"uriDecoded",{},$globals.String)});
- },
- args: [],
- source: "uriDecoded\x0a\x09<inlineJS: 'return decodeURI(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "uriEncoded",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return encodeURI(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"uriEncoded",{},$globals.String)});
- },
- args: [],
- source: "uriEncoded\x0a\x09<inlineJS: 'return encodeURI(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "evaluating",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anObject)._perform_(self);
- }, function($ctx1) {$ctx1.fill(self,"value:",{anObject:anObject},$globals.String)});
- },
- args: ["anObject"],
- source: "value: anObject \x0a\x09^ anObject perform: self",
- referencedClasses: [],
- messageSends: ["perform:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "cr",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "\r";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"cr",{},$globals.String.klass)});
- },
- args: [],
- source: "cr\x0a\x09<inlineJS: 'return \x22\x5cr\x22'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "crlf",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "\r\n";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"crlf",{},$globals.String.klass)});
- },
- args: [],
- source: "crlf\x0a\x09<inlineJS: 'return \x22\x5cr\x5cn\x22'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "esc",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._fromCharCode_((27));
- }, function($ctx1) {$ctx1.fill(self,"esc",{},$globals.String.klass)});
- },
- args: [],
- source: "esc\x0a\x09^ self fromCharCode: 27",
- referencedClasses: [],
- messageSends: ["fromCharCode:"]
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "fromCharCode:",
- protocol: "instance creation",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String.fromCharCode(anInteger);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fromCharCode:",{anInteger:anInteger},$globals.String.klass)});
- },
- args: ["anInteger"],
- source: "fromCharCode: anInteger\x0a\x09<inlineJS: 'return String.fromCharCode(anInteger)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "fromString:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fromString:",{aString:aString},$globals.String.klass)});
- },
- args: ["aString"],
- source: "fromString: aString\x0a\x09\x09<inlineJS: 'return String(aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "lf",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "\n";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"lf",{},$globals.String.klass)});
- },
- args: [],
- source: "lf\x0a\x09<inlineJS: 'return \x22\x5cn\x22'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "random",
- protocol: "random",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return (Math.random()*(22/32)+(10/32)).toString(32).slice(2);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"random",{},$globals.String.klass)});
- },
- args: [],
- source: "random\x0a\x09\x22Returns random alphanumeric string beginning with letter\x22\x0a\x09<inlineJS: 'return (Math.random()*(22/32)+(10/32)).toString(32).slice(2);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "randomNotIn:",
- protocol: "random",
- fn: function (aString){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- result=self._random();
- result;
- return $recv(aString)._includesSubString_(result);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileTrue();
- return result;
- }, function($ctx1) {$ctx1.fill(self,"randomNotIn:",{aString:aString,result:result},$globals.String.klass)});
- },
- args: ["aString"],
- source: "randomNotIn: aString\x0a\x09| result |\x0a\x09[ result := self random. aString includesSubString: result ] whileTrue.\x0a\x09^ result",
- referencedClasses: [],
- messageSends: ["whileTrue", "random", "includesSubString:"]
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "space",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return " ";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"space",{},$globals.String.klass)});
- },
- args: [],
- source: "space\x0a\x09<inlineJS: 'return \x22 \x22'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "streamClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.StringStream;
- },
- args: [],
- source: "streamClass\x0a\x09\x09^ StringStream",
- referencedClasses: ["StringStream"],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "tab",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "\t";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tab",{},$globals.String.klass)});
- },
- args: [],
- source: "tab\x0a\x09<inlineJS: 'return \x22\x5ct\x22'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "instance creation",
- fn: function (aUTFCharCode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return String.fromCharCode(aUTFCharCode);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"value:",{aUTFCharCode:aUTFCharCode},$globals.String.klass)});
- },
- args: ["aUTFCharCode"],
- source: "value: aUTFCharCode\x0a\x0a\x09<inlineJS: 'return String.fromCharCode(aUTFCharCode);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String.klass);
- $core.addClass("Set", $globals.Collection, ["defaultBucket", "slowBucketStores", "fastBuckets", "size"], "Kernel-Collections");
- $globals.Set.comment="I represent an unordered set of objects without duplicates.\x0a\x0a## Implementation notes\x0a\x0aI put elements into different stores based on their type.\x0aThe goal is to store some elements into native JS object property names to be fast.\x0a\x0aIf an unboxed element has typeof 'string', 'boolean' or 'number', or an element is nil, null or undefined,\x0aI store it as a property name in an empty (== Object.create(null)) JS object, different for each type\x0a(for simplicity, nil/null/undefined is treated as one and included with the two booleans).\x0a\x0aIf element happen to be an object, I try to store them in `ArrayBucketStore`. I have two of them by default,\x0aone hashed using the Smalltalk class name, the other one using the JS constructor name. It is possible to have more or less\x0ainstances of `ArrayBucketStores`, see `#initializeSlowBucketStores`.\x0a\x0aAs a last resort, if none of the `ArrayBucketStore` instances can find a suitable bucket, the `defaultBucket` is used,\x0awhich is an `Array`.";
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5;
- var $early={};
- try {
- $2=self._class();
- $ctx1.sendIdx["class"]=1;
- $1=$recv($2).__eq($recv(aCollection)._class());
- $ctx1.sendIdx["="]=1;
- if(!$core.assert($1)){
- return false;
- }
- $4=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=$recv($4).__eq($recv(aCollection)._size());
- if(!$core.assert($3)){
- return false;
- }
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $5=$recv(aCollection)._includes_(each);
- if(!$core.assert($5)){
- throw $early=[false];
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- return true;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"=",{aCollection:aCollection},$globals.Set)});
- },
- args: ["aCollection"],
- source: "= aCollection\x0a\x09self class = aCollection class ifFalse: [ ^ false ].\x0a\x09self size = aCollection size ifFalse: [ ^ false ].\x0a\x09self do: [ :each | (aCollection includes: each) ifFalse: [ ^ false ] ].\x0a\x09^ true",
- referencedClasses: [],
- messageSends: ["ifFalse:", "=", "class", "size", "do:", "includes:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "add:",
- protocol: "adding/removing",
- fn: function (anObject){
- var self=this;
- var bucket;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- bucket=self._bucketsOfElement_(anObject);
- $1=$recv(bucket)._second();
- if(($receiver = $1) == null || $receiver.isNil){
- var object,slowBucket;
- object=$recv(bucket)._first();
- $ctx1.sendIdx["first"]=1;
- object;
- slowBucket=$recv(bucket)._third();
- slowBucket;
- $recv(slowBucket)._indexOf_ifAbsent_(object,(function(){
- return $core.withContext(function($ctx2) {
- $recv(slowBucket)._add_(object);
- self["@size"]=$recv(self["@size"]).__plus((1));
- return self["@size"];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return object;
- } else {
- var primitiveBucket;
- primitiveBucket=$receiver;
- return self._add_in_($recv(bucket)._first(),primitiveBucket);
- }
- }, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject,bucket:bucket},$globals.Set)});
- },
- args: ["anObject"],
- source: "add: anObject\x0a\x09| bucket |\x0a\x09bucket := self bucketsOfElement: anObject.\x0a\x09^ bucket second\x0a\x09\x09ifNil: [\x0a\x09\x09\x09| object slowBucket |\x0a\x09\x09\x09object := bucket first.\x0a\x09\x09\x09slowBucket := bucket third.\x0a\x09\x09\x09slowBucket \x0a\x09\x09\x09\x09indexOf: object \x0a\x09\x09\x09\x09ifAbsent: [ \x0a\x09\x09\x09\x09\x09slowBucket add: object. \x0a\x09\x09\x09\x09\x09size := size + 1 ].\x0a\x09\x09\x09object ]\x0a\x09\x09ifNotNil: [ :primitiveBucket | \x0a\x09\x09\x09self \x0a\x09\x09\x09\x09add: bucket first \x0a\x09\x09\x09\x09in: primitiveBucket ]",
- referencedClasses: [],
- messageSends: ["bucketsOfElement:", "ifNil:ifNotNil:", "second", "first", "third", "indexOf:ifAbsent:", "add:", "+", "add:in:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "add:in:",
- protocol: "private",
- fn: function (anObject,anotherObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (anObject in anotherObject.store) { return false; }
- self['@size']++;
- anotherObject.store[anObject] = true;
- return anObject;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"add:in:",{anObject:anObject,anotherObject:anotherObject},$globals.Set)});
- },
- args: ["anObject", "anotherObject"],
- source: "add: anObject in: anotherObject\x0a\x09<inlineJS: '\x0a\x09\x09if (anObject in anotherObject.store) { return false; }\x0a\x09\x09self[''@size'']++;\x0a\x09\x09anotherObject.store[anObject] = true;\x0a\x09\x09return anObject;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "bucketsOfElement:",
- protocol: "private",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- // include nil to well-known objects under "boolean" fastBucket
- if (anObject == null || anObject.isNil) return [ null, self['@fastBuckets'].boolean ];
-
- var prim = anObject.valueOf();
- if (typeof prim === "object" || typeof prim === "function" || !self['@fastBuckets'][typeof prim]) {
- var bucket = null;
- self['@slowBucketStores'].some(function (store) {
- return bucket = store._bucketOfElement_(anObject);
- });
- return [ anObject, null, bucket || self['@defaultBucket'] ];
- }
- return [ prim, self['@fastBuckets'][typeof prim] ];
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"bucketsOfElement:",{anObject:anObject},$globals.Set)});
- },
- args: ["anObject"],
- source: "bucketsOfElement: anObject\x0a\x09\x22Find the appropriate bucket for `anObject`.\x0a\x09For optimization purposes, directly answer an array with: \x0a\x09- the object to be store\x0a\x09- the primitive bucket\x0a\x09- the slow bucket\x22\x0a\x09\x0a\x09<inlineJS: '\x0a\x09\x09// include nil to well-known objects under \x22boolean\x22 fastBucket\x0a\x09\x09if (anObject == null || anObject.isNil) return [ null, self[''@fastBuckets''].boolean ];\x0a\x09\x09\x0a\x09\x09var prim = anObject.valueOf();\x0a\x09\x09if (typeof prim === \x22object\x22 || typeof prim === \x22function\x22 || !self[''@fastBuckets''][typeof prim]) {\x0a\x09\x09\x09var bucket = null;\x0a\x09\x09\x09self[''@slowBucketStores''].some(function (store) {\x0a\x09\x09\x09\x09return bucket = store._bucketOfElement_(anObject);\x0a\x09\x09\x09});\x0a\x09\x09\x09return [ anObject, null, bucket || self[''@defaultBucket''] ];\x0a\x09\x09}\x0a\x09\x09return [ prim, self[''@fastBuckets''][typeof prim] ];\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "classNameOf:",
- protocol: "private",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return anObject.klass != null && anObject.klass.className;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"classNameOf:",{anObject:anObject},$globals.Set)});
- },
- args: ["anObject"],
- source: "classNameOf: anObject\x0a\x09\x22Answer the class name of `anObject`, or `undefined` \x0a\x09if `anObject` is not an Smalltalk object\x22\x0a\x09\x0a\x09<inlineJS: 'return anObject.klass != null && anObject.klass.className'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "collect:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var collection;
- return $core.withContext(function($ctx1) {
- collection=$recv(self._class())._new();
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(collection)._add_($recv(aBlock)._value_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return collection;
- }, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock,collection:collection},$globals.Set)});
- },
- args: ["aBlock"],
- source: "collect: aBlock\x0a\x09| collection |\x0a\x09collection := self class new.\x0a\x09self do: [ :each | collection add: (aBlock value: each) ].\x0a\x09^ collection",
- referencedClasses: [],
- messageSends: ["new", "class", "do:", "add:", "value:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "detect:ifNone:",
- protocol: "enumerating",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(aBlock)._value_(each);
- if($core.assert($1)){
- throw $early=[each];
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return $recv(anotherBlock)._value();
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"detect:ifNone:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.Set)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "detect: aBlock ifNone: anotherBlock\x0a\x09self do: [ :each | (aBlock value: each) ifTrue: [ ^each ] ].\x0a\x09^ anotherBlock value",
- referencedClasses: [],
- messageSends: ["do:", "ifTrue:", "value:", "value"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "do:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var el, keys, i;
- el = self['@fastBuckets'];
- keys = Object.keys(el);
- for (i = 0; i < keys.length; ++i) {
- var fastBucket = el[keys[i]], fn = fastBucket.fn, store = Object.keys(fastBucket.store);
- if (fn) { for (var j = 0; j < store.length; ++j) { aBlock._value_(fn(store[j])); } }
- else { store._do_(aBlock); }
- }
- el = self['@slowBucketStores'];
- for (i = 0; i < el.length; ++i) { el[i]._do_(aBlock); }
- self['@defaultBucket']._do_(aBlock);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},$globals.Set)});
- },
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09var el, keys, i;\x0a\x09\x09el = self[''@fastBuckets''];\x0a\x09\x09keys = Object.keys(el);\x0a\x09\x09for (i = 0; i < keys.length; ++i) {\x0a\x09\x09\x09var fastBucket = el[keys[i]], fn = fastBucket.fn, store = Object.keys(fastBucket.store);\x0a\x09\x09\x09if (fn) { for (var j = 0; j < store.length; ++j) { aBlock._value_(fn(store[j])); } }\x0a\x09\x09\x09else { store._do_(aBlock); }\x0a\x09\x09}\x0a\x09\x09el = self[''@slowBucketStores''];\x0a\x09\x09for (i = 0; i < el.length; ++i) { el[i]._do_(aBlock); }\x0a\x09\x09self[''@defaultBucket'']._do_(aBlock);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "includes:",
- protocol: "testing",
- fn: function (anObject){
- var self=this;
- var bucket;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- bucket=self._bucketsOfElement_(anObject);
- $1=$recv(bucket)._second();
- if(($receiver = $1) == null || $receiver.isNil){
- $2=$recv(bucket)._third();
- $3=$recv(bucket)._first();
- $ctx1.sendIdx["first"]=1;
- return $recv($2)._includes_($3);
- } else {
- var primitiveBucket;
- primitiveBucket=$receiver;
- return self._includes_in_($recv(bucket)._first(),primitiveBucket);
- }
- }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject,bucket:bucket},$globals.Set)});
- },
- args: ["anObject"],
- source: "includes: anObject\x0a\x09| bucket |\x0a\x09bucket := self bucketsOfElement: anObject.\x0a\x09^ bucket second\x0a\x09\x09ifNil: [ bucket third includes: bucket first ]\x0a\x09\x09ifNotNil: [ :primitiveBucket | self includes: bucket first in: primitiveBucket ]",
- referencedClasses: [],
- messageSends: ["bucketsOfElement:", "ifNil:ifNotNil:", "second", "includes:", "third", "first", "includes:in:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "includes:in:",
- protocol: "private",
- fn: function (anObject,anotherObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return anObject in anotherObject.store;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"includes:in:",{anObject:anObject,anotherObject:anotherObject},$globals.Set)});
- },
- args: ["anObject", "anotherObject"],
- source: "includes: anObject in: anotherObject\x0a\x09<inlineJS: 'return anObject in anotherObject.store'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Set.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@defaultBucket"]=[];
- self._initializeSlowBucketStores();
- self._removeAll();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Set)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09\x0a\x09defaultBucket := #().\x0a\x09self\x0a\x09\x09initializeSlowBucketStores;\x0a\x09\x09removeAll",
- referencedClasses: [],
- messageSends: ["initialize", "initializeSlowBucketStores", "removeAll"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "initializeSlowBucketStores",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.ArrayBucketStore)._hashBlock_((function(x){
- return $core.withContext(function($ctx2) {
- return self._classNameOf_(x);
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
- }));
- $ctx1.sendIdx["hashBlock:"]=1;
- self["@slowBucketStores"]=[$1,$recv($globals.ArrayBucketStore)._hashBlock_((function(x){
- return $core.withContext(function($ctx2) {
- return self._jsConstructorNameOf_(x);
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,2)});
- }))];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initializeSlowBucketStores",{},$globals.Set)});
- },
- args: [],
- source: "initializeSlowBucketStores\x0a\x09slowBucketStores := {\x0a\x09\x09ArrayBucketStore hashBlock: [ :x | self classNameOf: x ].\x0a\x09\x09ArrayBucketStore hashBlock: [ :x | self jsConstructorNameOf: x ]\x0a\x09}",
- referencedClasses: ["ArrayBucketStore"],
- messageSends: ["hashBlock:", "classNameOf:", "jsConstructorNameOf:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "jsConstructorNameOf:",
- protocol: "private",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return anObject.constructor && anObject.constructor.name;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"jsConstructorNameOf:",{anObject:anObject},$globals.Set)});
- },
- args: ["anObject"],
- source: "jsConstructorNameOf: anObject\x0a\x09<inlineJS: 'return anObject.constructor && anObject.constructor.name'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Set.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $ctx1.sendIdx["printOn:"]=1;
- $recv(aStream)._nextPutAll_(" (");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._printOn_(aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(aStream)._nextPutAll_(" ");
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Set)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09\x0a\x09aStream nextPutAll: ' ('.\x0a\x09self \x0a\x09\x09do: [ :each | each printOn: aStream ]\x0a\x09\x09separatedBy: [ aStream nextPutAll: ' ' ].\x0a\x09aStream nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "do:separatedBy:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "remove:ifAbsent:",
- protocol: "adding/removing",
- fn: function (anObject,aBlock){
- var self=this;
- var bucket;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- var $early={};
- try {
- bucket=self._bucketsOfElement_(anObject);
- $1=$recv(bucket)._second();
- if(($receiver = $1) == null || $receiver.isNil){
- $2=$recv(bucket)._third();
- $3=$recv(bucket)._first();
- $ctx1.sendIdx["first"]=1;
- $recv($2)._remove_ifAbsent_($3,(function(){
- return $core.withContext(function($ctx2) {
- throw $early=[$recv(aBlock)._value()];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- self["@size"]=$recv(self["@size"]).__minus((1));
- return self["@size"];
- } else {
- var primitiveBucket;
- primitiveBucket=$receiver;
- return self._remove_in_($recv(bucket)._first(),primitiveBucket);
- }
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"remove:ifAbsent:",{anObject:anObject,aBlock:aBlock,bucket:bucket},$globals.Set)});
- },
- args: ["anObject", "aBlock"],
- source: "remove: anObject ifAbsent: aBlock\x0a\x09| bucket |\x0a\x09bucket := self bucketsOfElement: anObject.\x0a\x09^ bucket second\x0a\x09\x09ifNil: [ bucket third remove: bucket first ifAbsent: [ ^aBlock value ]. size := size - 1 ]\x0a\x09\x09ifNotNil: [ :primitiveBucket | self remove: bucket first in: primitiveBucket ]",
- referencedClasses: [],
- messageSends: ["bucketsOfElement:", "ifNil:ifNotNil:", "second", "remove:ifAbsent:", "third", "first", "value", "-", "remove:in:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "remove:in:",
- protocol: "private",
- fn: function (anObject,anotherObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (delete anotherObject.store[anObject]) self['@size']--;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"remove:in:",{anObject:anObject,anotherObject:anotherObject},$globals.Set)});
- },
- args: ["anObject", "anotherObject"],
- source: "remove: anObject in: anotherObject\x0a\x09<inlineJS: 'if (delete anotherObject.store[anObject]) self[''@size'']--'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "removeAll",
- protocol: "adding/removing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self['@fastBuckets'] = {
- "boolean": { store: Object.create(null), fn: function (x) { return {"true": true, "false": false, "null": null}[x]; } },
- "number": { store: Object.create(null), fn: Number },
- "string": { store: Object.create(null) }
- };
- self['@slowBucketStores'].forEach(function (x) { x._removeAll(); });
- self['@defaultBucket']._removeAll();
- self['@size'] = 0;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeAll",{},$globals.Set)});
- },
- args: [],
- source: "removeAll\x0a\x09<inlineJS: '\x0a\x09\x09self[''@fastBuckets''] = {\x0a\x09\x09\x09\x22boolean\x22: { store: Object.create(null), fn: function (x) { return {\x22true\x22: true, \x22false\x22: false, \x22null\x22: null}[x]; } },\x0a\x09\x09\x09\x22number\x22: { store: Object.create(null), fn: Number },\x0a\x09\x09\x09\x22string\x22: { store: Object.create(null) }\x0a\x09\x09};\x0a\x09\x09self[''@slowBucketStores''].forEach(function (x) { x._removeAll(); });\x0a\x09\x09self[''@defaultBucket'']._removeAll();\x0a\x09\x09self[''@size''] = 0;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "select:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var collection;
- return $core.withContext(function($ctx1) {
- var $1;
- collection=$recv(self._class())._new();
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(aBlock)._value_(each);
- if($core.assert($1)){
- return $recv(collection)._add_(each);
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return collection;
- }, function($ctx1) {$ctx1.fill(self,"select:",{aBlock:aBlock,collection:collection},$globals.Set)});
- },
- args: ["aBlock"],
- source: "select: aBlock\x0a\x09| collection |\x0a\x09collection := self class new.\x0a\x09self do: [ :each |\x0a\x09\x09(aBlock value: each) ifTrue: [\x0a\x09\x09\x09collection add: each ] ].\x0a\x09^ collection",
- referencedClasses: [],
- messageSends: ["new", "class", "do:", "ifTrue:", "value:", "add:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "select:thenCollect:",
- protocol: "enumerating",
- fn: function (selectBlock,collectBlock){
- var self=this;
- var collection;
- return $core.withContext(function($ctx1) {
- var $1;
- collection=$recv(self._class())._new();
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(selectBlock)._value_(each);
- $ctx2.sendIdx["value:"]=1;
- if($core.assert($1)){
- return $recv(collection)._add_($recv(collectBlock)._value_(each));
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return collection;
- }, function($ctx1) {$ctx1.fill(self,"select:thenCollect:",{selectBlock:selectBlock,collectBlock:collectBlock,collection:collection},$globals.Set)});
- },
- args: ["selectBlock", "collectBlock"],
- source: "select: selectBlock thenCollect: collectBlock\x0a\x09| collection |\x0a\x09collection := self class new.\x0a\x09self do: [ :each |\x0a\x09\x09(selectBlock value: each) ifTrue: [\x0a\x09\x09\x09collection add: (collectBlock value: each) ] ].\x0a\x09^ collection",
- referencedClasses: [],
- messageSends: ["new", "class", "do:", "ifTrue:", "value:", "add:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@size"];
- },
- args: [],
- source: "size\x0a\x09^ size",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Set);
- $core.addClass("ProtoStream", $globals.Object, [], "Kernel-Collections");
- $globals.ProtoStream.comment="I am the abstract base for different accessor for a sequence of objects. This sequence is referred to as my \x22contents\x22.\x0aMy instances are read/write streams modifying the contents.";
- $core.addMethod(
- $core.method({
- selector: "<<",
- protocol: "writing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._write_(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"<<",{anObject:anObject},$globals.ProtoStream)});
- },
- args: ["anObject"],
- source: "<< anObject\x0a\x09self write: anObject",
- referencedClasses: [],
- messageSends: ["write:"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "atEnd",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"atEnd",{},$globals.ProtoStream)});
- },
- args: [],
- source: "atEnd\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "atStart",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"atStart",{},$globals.ProtoStream)});
- },
- args: [],
- source: "atStart\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "contents",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"contents",{},$globals.ProtoStream)});
- },
- args: [],
- source: "contents\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "do:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._atEnd();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._value_(self._next());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},$globals.ProtoStream)});
- },
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09[ self atEnd ] whileFalse: [ aBlock value: self next ]",
- referencedClasses: [],
- messageSends: ["whileFalse:", "atEnd", "value:", "next"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "isEmpty",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._atStart())._and_((function(){
- return $core.withContext(function($ctx2) {
- return self._atEnd();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"isEmpty",{},$globals.ProtoStream)});
- },
- args: [],
- source: "isEmpty\x0a\x09^ self atStart and: [ self atEnd ]",
- referencedClasses: [],
- messageSends: ["and:", "atStart", "atEnd"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "next",
- protocol: "reading",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._atEnd();
- if($core.assert($1)){
- return nil;
- } else {
- return self._subclassResponsibility();
- }
- }, function($ctx1) {$ctx1.fill(self,"next",{},$globals.ProtoStream)});
- },
- args: [],
- source: "next\x0a\x09^ self atEnd\x0a\x09\x09ifTrue: [ nil ]\x0a\x09\x09ifFalse: [ self subclassResponsibility ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "atEnd", "subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "nextPut:",
- protocol: "writing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPut:",{anObject:anObject},$globals.ProtoStream)});
- },
- args: ["anObject"],
- source: "nextPut: anObject\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutAll:",
- protocol: "writing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._nextPut_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutAll:",{aCollection:aCollection},$globals.ProtoStream)});
- },
- args: ["aCollection"],
- source: "nextPutAll: aCollection\x0a\x09aCollection do: [ :each |\x0a\x09\x09self nextPut: each ]",
- referencedClasses: [],
- messageSends: ["do:", "nextPut:"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutString:",
- protocol: "writing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._nextPut_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutString:",{aString:aString},$globals.ProtoStream)});
- },
- args: ["aString"],
- source: "nextPutString: aString\x0a\x09self nextPut: aString",
- referencedClasses: [],
- messageSends: ["nextPut:"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "peek",
- protocol: "reading",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._atEnd();
- if($core.assert($1)){
- return nil;
- } else {
- return self._subclassResponsibility();
- }
- }, function($ctx1) {$ctx1.fill(self,"peek",{},$globals.ProtoStream)});
- },
- args: [],
- source: "peek\x0a\x09^ self atEnd\x0a\x09\x09ifTrue: [ nil ]\x0a\x09\x09ifFalse: [ self subclassResponsibility ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "atEnd", "subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "reset",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"reset",{},$globals.ProtoStream)});
- },
- args: [],
- source: "reset\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "resetContents",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"resetContents",{},$globals.ProtoStream)});
- },
- args: [],
- source: "resetContents\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "setToEnd",
- protocol: "positioning",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setToEnd",{},$globals.ProtoStream)});
- },
- args: [],
- source: "setToEnd\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "setToStart",
- protocol: "positioning",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._reset();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setToStart",{},$globals.ProtoStream)});
- },
- args: [],
- source: "setToStart\x0a\x09self reset",
- referencedClasses: [],
- messageSends: ["reset"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "write:",
- protocol: "writing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anObject)._putOn_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"write:",{anObject:anObject},$globals.ProtoStream)});
- },
- args: ["anObject"],
- source: "write: anObject\x0a\x09anObject putOn: self",
- referencedClasses: [],
- messageSends: ["putOn:"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._setCollection_(aCollection);
- $recv($1)._setStreamSize_($recv(aCollection)._size());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{aCollection:aCollection},$globals.ProtoStream.klass)});
- },
- args: ["aCollection"],
- source: "on: aCollection\x0a\x09\x09^ self new\x0a\x09\x09setCollection: aCollection;\x0a\x09\x09setStreamSize: aCollection size;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["setCollection:", "new", "setStreamSize:", "size", "yourself"]
- }),
- $globals.ProtoStream.klass);
- $core.addClass("Stream", $globals.ProtoStream, ["collection", "position", "streamSize"], "Kernel-Collections");
- $globals.Stream.comment="I represent an accessor for a sequence of objects. This sequence is referred to as my \x22contents\x22.\x0aMy instances are read/write streams to the contents sequence collection.";
- $core.addMethod(
- $core.method({
- selector: "atEnd",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._position()).__eq(self._size());
- }, function($ctx1) {$ctx1.fill(self,"atEnd",{},$globals.Stream)});
- },
- args: [],
- source: "atEnd\x0a\x09^ self position = self size",
- referencedClasses: [],
- messageSends: ["=", "position", "size"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "atStart",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._position()).__eq((0));
- }, function($ctx1) {$ctx1.fill(self,"atStart",{},$globals.Stream)});
- },
- args: [],
- source: "atStart\x0a\x09^ self position = 0",
- referencedClasses: [],
- messageSends: ["=", "position"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "close",
- protocol: "actions",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "close",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "collection",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@collection"];
- },
- args: [],
- source: "collection\x0a\x09^ collection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "contents",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._collection())._copyFrom_to_((1),self._streamSize());
- }, function($ctx1) {$ctx1.fill(self,"contents",{},$globals.Stream)});
- },
- args: [],
- source: "contents\x0a\x09^ self collection\x0a\x09\x09copyFrom: 1\x0a\x09\x09to: self streamSize",
- referencedClasses: [],
- messageSends: ["copyFrom:to:", "collection", "streamSize"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "flush",
- protocol: "actions",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "flush",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "isEmpty",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._size()).__eq((0));
- }, function($ctx1) {$ctx1.fill(self,"isEmpty",{},$globals.Stream)});
- },
- args: [],
- source: "isEmpty\x0a\x09^ self size = 0",
- referencedClasses: [],
- messageSends: ["=", "size"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "next",
- protocol: "reading",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- $1=self._atEnd();
- if($core.assert($1)){
- return nil;
- } else {
- $3=self._position();
- $ctx1.sendIdx["position"]=1;
- $2=$recv($3).__plus((1));
- self._position_($2);
- return $recv(self["@collection"])._at_(self._position());
- }
- }, function($ctx1) {$ctx1.fill(self,"next",{},$globals.Stream)});
- },
- args: [],
- source: "next\x0a\x09^ self atEnd\x0a\x09\x09ifTrue: [ nil ]\x0a\x09\x09ifFalse: [\x0a\x09\x09\x09self position: self position + 1.\x0a\x09\x09\x09collection at: self position ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "atEnd", "position:", "+", "position", "at:"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "next:",
- protocol: "reading",
- fn: function (anInteger){
- var self=this;
- var tempCollection;
- return $core.withContext(function($ctx1) {
- var $1;
- tempCollection=$recv($recv(self._collection())._class())._new();
- $recv(anInteger)._timesRepeat_((function(){
- return $core.withContext(function($ctx2) {
- $1=self._atEnd();
- if(!$core.assert($1)){
- return $recv(tempCollection)._add_(self._next());
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return tempCollection;
- }, function($ctx1) {$ctx1.fill(self,"next:",{anInteger:anInteger,tempCollection:tempCollection},$globals.Stream)});
- },
- args: ["anInteger"],
- source: "next: anInteger\x0a\x09| tempCollection |\x0a\x09tempCollection := self collection class new.\x0a\x09anInteger timesRepeat: [\x0a\x09\x09self atEnd ifFalse: [\x0a\x09\x09tempCollection add: self next ]].\x0a\x09^ tempCollection",
- referencedClasses: [],
- messageSends: ["new", "class", "collection", "timesRepeat:", "ifFalse:", "atEnd", "add:", "next"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "nextPut:",
- protocol: "writing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$4;
- $2=self._position();
- $ctx1.sendIdx["position"]=1;
- $1=$recv($2).__plus((1));
- self._position_($1);
- $3=self._collection();
- $4=self._position();
- $ctx1.sendIdx["position"]=2;
- $recv($3)._at_put_($4,anObject);
- self._setStreamSize_($recv(self._streamSize())._max_(self._position()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPut:",{anObject:anObject},$globals.Stream)});
- },
- args: ["anObject"],
- source: "nextPut: anObject\x0a\x09self position: self position + 1.\x0a\x09self collection at: self position put: anObject.\x0a\x09self setStreamSize: (self streamSize max: self position)",
- referencedClasses: [],
- messageSends: ["position:", "+", "position", "at:put:", "collection", "setStreamSize:", "max:", "streamSize"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "peek",
- protocol: "reading",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._atEnd();
- if(!$core.assert($1)){
- return $recv(self._collection())._at_($recv(self._position()).__plus((1)));
- }
- }, function($ctx1) {$ctx1.fill(self,"peek",{},$globals.Stream)});
- },
- args: [],
- source: "peek\x0a\x09^ self atEnd ifFalse: [\x0a\x09\x09self collection at: self position + 1 ]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "atEnd", "at:", "collection", "+", "position"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "position",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@position"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@position"]=(0);
- return self["@position"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"position",{},$globals.Stream)});
- },
- args: [],
- source: "position\x0a\x09^ position ifNil: [ position := 0 ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "position:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@position"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "position: anInteger\x0a\x09position := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "reset",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._position_((0));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"reset",{},$globals.Stream)});
- },
- args: [],
- source: "reset\x0a\x09self position: 0",
- referencedClasses: [],
- messageSends: ["position:"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "resetContents",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._reset();
- self._setStreamSize_((0));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"resetContents",{},$globals.Stream)});
- },
- args: [],
- source: "resetContents\x0a\x09self reset.\x0a\x09self setStreamSize: 0",
- referencedClasses: [],
- messageSends: ["reset", "setStreamSize:"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "setCollection:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@collection"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "setCollection: aCollection\x0a\x09collection := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "setStreamSize:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@streamSize"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "setStreamSize: anInteger\x0a\x09streamSize := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "setToEnd",
- protocol: "positioning",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._position_(self._size());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setToEnd",{},$globals.Stream)});
- },
- args: [],
- source: "setToEnd\x0a\x09self position: self size",
- referencedClasses: [],
- messageSends: ["position:", "size"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._streamSize();
- }, function($ctx1) {$ctx1.fill(self,"size",{},$globals.Stream)});
- },
- args: [],
- source: "size\x0a\x09^ self streamSize",
- referencedClasses: [],
- messageSends: ["streamSize"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "skip:",
- protocol: "positioning",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._position_($recv($recv(self._position()).__plus(anInteger))._min_max_(self._size(),(0)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"skip:",{anInteger:anInteger},$globals.Stream)});
- },
- args: ["anInteger"],
- source: "skip: anInteger\x0a\x09self position: ((self position + anInteger) min: self size max: 0)",
- referencedClasses: [],
- messageSends: ["position:", "min:max:", "+", "position", "size"]
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "streamSize",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@streamSize"];
- },
- args: [],
- source: "streamSize\x0a\x09^ streamSize",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Stream);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._setCollection_(aCollection);
- $recv($1)._setStreamSize_($recv(aCollection)._size());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{aCollection:aCollection},$globals.Stream.klass)});
- },
- args: ["aCollection"],
- source: "on: aCollection\x0a\x09\x09^ self new\x0a\x09\x09setCollection: aCollection;\x0a\x09\x09setStreamSize: aCollection size;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["setCollection:", "new", "setStreamSize:", "size", "yourself"]
- }),
- $globals.Stream.klass);
- $core.addClass("StringStream", $globals.Stream, [], "Kernel-Collections");
- $globals.StringStream.comment="I am a Stream specific to `String` objects.";
- $core.addMethod(
- $core.method({
- selector: "cr",
- protocol: "writing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._nextPutAll_($recv($globals.String)._cr());
- }, function($ctx1) {$ctx1.fill(self,"cr",{},$globals.StringStream)});
- },
- args: [],
- source: "cr\x0a\x09^ self nextPutAll: String cr",
- referencedClasses: ["String"],
- messageSends: ["nextPutAll:", "cr"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "crlf",
- protocol: "writing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._nextPutAll_($recv($globals.String)._crlf());
- }, function($ctx1) {$ctx1.fill(self,"crlf",{},$globals.StringStream)});
- },
- args: [],
- source: "crlf\x0a\x09^ self nextPutAll: String crlf",
- referencedClasses: ["String"],
- messageSends: ["nextPutAll:", "crlf"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "lf",
- protocol: "writing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._nextPutAll_($recv($globals.String)._lf());
- }, function($ctx1) {$ctx1.fill(self,"lf",{},$globals.StringStream)});
- },
- args: [],
- source: "lf\x0a\x09^ self nextPutAll: String lf",
- referencedClasses: ["String"],
- messageSends: ["nextPutAll:", "lf"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "next:",
- protocol: "reading",
- fn: function (anInteger){
- var self=this;
- var tempCollection;
- return $core.withContext(function($ctx1) {
- var $1;
- tempCollection=$recv($recv(self._collection())._class())._new();
- $recv(anInteger)._timesRepeat_((function(){
- return $core.withContext(function($ctx2) {
- $1=self._atEnd();
- if(!$core.assert($1)){
- tempCollection=$recv(tempCollection).__comma(self._next());
- return tempCollection;
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return tempCollection;
- }, function($ctx1) {$ctx1.fill(self,"next:",{anInteger:anInteger,tempCollection:tempCollection},$globals.StringStream)});
- },
- args: ["anInteger"],
- source: "next: anInteger\x0a\x09| tempCollection |\x0a\x09tempCollection := self collection class new.\x0a\x09anInteger timesRepeat: [\x0a\x09\x09self atEnd ifFalse: [\x0a\x09\x09tempCollection := tempCollection, self next ]].\x0a\x09^ tempCollection",
- referencedClasses: [],
- messageSends: ["new", "class", "collection", "timesRepeat:", "ifFalse:", "atEnd", ",", "next"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "nextPut:",
- protocol: "writing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._nextPutAll_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPut:",{aString:aString},$globals.StringStream)});
- },
- args: ["aString"],
- source: "nextPut: aString\x0a\x09self nextPutAll: aString",
- referencedClasses: [],
- messageSends: ["nextPutAll:"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutAll:",
- protocol: "writing",
- fn: function (aString){
- var self=this;
- var pre,post;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$5,$6,$9,$8,$10,$7,$11,$12,$14,$13;
- $1=self._atEnd();
- if($core.assert($1)){
- $3=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $2=$recv($3).__comma(aString);
- $ctx1.sendIdx[","]=1;
- self._setCollection_($2);
- $ctx1.sendIdx["setCollection:"]=1;
- } else {
- $4=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $5=self._position();
- $ctx1.sendIdx["position"]=1;
- pre=$recv($4)._copyFrom_to_((1),$5);
- $ctx1.sendIdx["copyFrom:to:"]=1;
- pre;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $9=self._position();
- $ctx1.sendIdx["position"]=2;
- $8=$recv($9).__plus((1));
- $ctx1.sendIdx["+"]=2;
- $10=$recv(aString)._size();
- $ctx1.sendIdx["size"]=1;
- $7=$recv($8).__plus($10);
- $ctx1.sendIdx["+"]=1;
- $11=$recv(self._collection())._size();
- $ctx1.sendIdx["size"]=2;
- post=$recv($6)._copyFrom_to_($7,$11);
- post;
- $12=$recv($recv(pre).__comma(aString)).__comma(post);
- $ctx1.sendIdx[","]=2;
- self._setCollection_($12);
- }
- $14=self._position();
- $ctx1.sendIdx["position"]=3;
- $13=$recv($14).__plus($recv(aString)._size());
- self._position_($13);
- self._setStreamSize_($recv(self._streamSize())._max_(self._position()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutAll:",{aString:aString,pre:pre,post:post},$globals.StringStream)});
- },
- args: ["aString"],
- source: "nextPutAll: aString\x0a\x09| pre post |\x0a\x09self atEnd ifTrue: [ self setCollection: self collection, aString ] ifFalse: [\x0a\x09\x09pre := self collection copyFrom: 1 to: self position.\x0a\x09\x09post := self collection copyFrom: (self position + 1 + aString size) to: self collection size.\x0a\x09\x09self setCollection: pre, aString, post\x0a\x09].\x0a\x09self position: self position + aString size.\x0a\x09self setStreamSize: (self streamSize max: self position)",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "atEnd", "setCollection:", ",", "collection", "copyFrom:to:", "position", "+", "size", "position:", "setStreamSize:", "max:", "streamSize"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutString:",
- protocol: "writing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._nextPutAll_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutString:",{aString:aString},$globals.StringStream)});
- },
- args: ["aString"],
- source: "nextPutString: aString\x0a\x09self nextPutAll: aString",
- referencedClasses: [],
- messageSends: ["nextPutAll:"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "print:",
- protocol: "writing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anObject)._printOn_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"print:",{anObject:anObject},$globals.StringStream)});
- },
- args: ["anObject"],
- source: "print: anObject\x0a\x09anObject printOn: self",
- referencedClasses: [],
- messageSends: ["printOn:"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "printSymbol:",
- protocol: "writing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anObject)._asSymbolPrintOn_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printSymbol:",{anObject:anObject},$globals.StringStream)});
- },
- args: ["anObject"],
- source: "printSymbol: anObject\x0a\x09anObject asSymbolPrintOn: self",
- referencedClasses: [],
- messageSends: ["asSymbolPrintOn:"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "space",
- protocol: "writing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._nextPut_(" ");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"space",{},$globals.StringStream)});
- },
- args: [],
- source: "space\x0a\x09self nextPut: ' '",
- referencedClasses: [],
- messageSends: ["nextPut:"]
- }),
- $globals.StringStream);
- $core.addMethod(
- $core.method({
- selector: "tab",
- protocol: "writing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._nextPutAll_($recv($globals.String)._tab());
- }, function($ctx1) {$ctx1.fill(self,"tab",{},$globals.StringStream)});
- },
- args: [],
- source: "tab\x0a\x09^ self nextPutAll: String tab",
- referencedClasses: ["String"],
- messageSends: ["nextPutAll:", "tab"]
- }),
- $globals.StringStream);
- $core.addClass("Queue", $globals.Object, ["read", "readIndex", "write"], "Kernel-Collections");
- $globals.Queue.comment="I am a one-sided queue.\x0a\x0a## Usage\x0a\x0aUse `#nextPut:` to add items to the queue.\x0aUse `#next` or `#nextIfAbsent:` to get (and remove) the next item in the queue.\x0a\x0a## Implementation notes\x0a\x0aA Queue uses two OrderedCollections inside,\x0a`read` is at the front, is not modified and only read using `readIndex`.\x0a`write` is at the back and is appended new items.\x0aWhen `read` is exhausted, `write` is promoted to `read` and new `write` is created.\x0a\x0aAs a consequence, no data moving is done by me, write appending may do data moving\x0awhen growing `write`, but this is left to engine to implement as good as it chooses to.";
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Queue.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@read"]=$recv($globals.OrderedCollection)._new();
- $ctx1.sendIdx["new"]=1;
- self["@write"]=$recv($globals.OrderedCollection)._new();
- self["@readIndex"]=(1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Queue)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09read := OrderedCollection new.\x0a\x09write := OrderedCollection new.\x0a\x09readIndex := 1",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["initialize", "new"]
- }),
- $globals.Queue);
- $core.addMethod(
- $core.method({
- selector: "next",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._nextIfAbsent_((function(){
- return $core.withContext(function($ctx2) {
- return self._error_("Cannot read from empty Queue.");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"next",{},$globals.Queue)});
- },
- args: [],
- source: "next\x0a\x09^ self nextIfAbsent: [ self error: 'Cannot read from empty Queue.' ]",
- referencedClasses: [],
- messageSends: ["nextIfAbsent:", "error:"]
- }),
- $globals.Queue);
- $core.addMethod(
- $core.method({
- selector: "nextIfAbsent:",
- protocol: "accessing",
- fn: function (aBlock){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- result=$recv(self["@read"])._at_ifAbsent_(self["@readIndex"],(function(){
- return $core.withContext(function($ctx2) {
- $recv(self["@write"])._ifEmpty_((function(){
- return $core.withContext(function($ctx3) {
- $1=$recv(self["@readIndex"]).__gt((1));
- if($core.assert($1)){
- self["@read"]=[];
- self["@read"];
- self["@readIndex"]=(1);
- self["@readIndex"];
- }
- throw $early=[$recv(aBlock)._value()];
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- self["@read"]=self["@write"];
- self["@read"];
- self["@readIndex"]=(1);
- self["@readIndex"];
- self["@write"]=$recv($globals.OrderedCollection)._new();
- self["@write"];
- return $recv(self["@read"])._first();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv(self["@read"])._at_put_(self["@readIndex"],nil);
- self["@readIndex"]=$recv(self["@readIndex"]).__plus((1));
- return result;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"nextIfAbsent:",{aBlock:aBlock,result:result},$globals.Queue)});
- },
- args: ["aBlock"],
- source: "nextIfAbsent: aBlock\x0a\x09| result |\x0a\x09result := read at: readIndex ifAbsent: [\x0a\x09\x09write ifEmpty: [\x0a\x09\x09\x09readIndex > 1 ifTrue: [ read := #(). readIndex := 1 ].\x0a\x09\x09\x09^ aBlock value ].\x0a\x09\x09read := write.\x0a\x09\x09readIndex := 1.\x0a\x09\x09write := OrderedCollection new.\x0a\x09\x09read first ].\x0a\x09read at: readIndex put: nil.\x0a\x09readIndex := readIndex + 1.\x0a\x09^ result",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["at:ifAbsent:", "ifEmpty:", "ifTrue:", ">", "value", "new", "first", "at:put:", "+"]
- }),
- $globals.Queue);
- $core.addMethod(
- $core.method({
- selector: "nextPut:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@write"])._add_(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPut:",{anObject:anObject},$globals.Queue)});
- },
- args: ["anObject"],
- source: "nextPut: anObject\x0a\x09write add: anObject",
- referencedClasses: [],
- messageSends: ["add:"]
- }),
- $globals.Queue);
- $core.addClass("RegularExpression", $globals.Object, [], "Kernel-Collections");
- $globals.RegularExpression.comment="I represent a regular expression object. My instances are JavaScript `RegExp` object.";
- $core.addMethod(
- $core.method({
- selector: "compile:",
- protocol: "evaluating",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.compile(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"compile:",{aString:aString},$globals.RegularExpression)});
- },
- args: ["aString"],
- source: "compile: aString\x0a\x09<inlineJS: 'return self.compile(aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.RegularExpression);
- $core.addMethod(
- $core.method({
- selector: "exec:",
- protocol: "evaluating",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.exec(aString) || nil;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exec:",{aString:aString},$globals.RegularExpression)});
- },
- args: ["aString"],
- source: "exec: aString\x0a\x09<inlineJS: 'return self.exec(aString) || nil'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.RegularExpression);
- $core.addMethod(
- $core.method({
- selector: "test:",
- protocol: "evaluating",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.test(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"test:",{aString:aString},$globals.RegularExpression)});
- },
- args: ["aString"],
- source: "test: aString\x0a\x09<inlineJS: 'return self.test(aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.RegularExpression);
- $core.addMethod(
- $core.method({
- selector: "fromString:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._fromString_flag_(aString,"");
- }, function($ctx1) {$ctx1.fill(self,"fromString:",{aString:aString},$globals.RegularExpression.klass)});
- },
- args: ["aString"],
- source: "fromString: aString\x0a\x09\x09^ self fromString: aString flag: ''",
- referencedClasses: [],
- messageSends: ["fromString:flag:"]
- }),
- $globals.RegularExpression.klass);
- $core.addMethod(
- $core.method({
- selector: "fromString:flag:",
- protocol: "instance creation",
- fn: function (aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new RegExp(aString, anotherString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fromString:flag:",{aString:aString,anotherString:anotherString},$globals.RegularExpression.klass)});
- },
- args: ["aString", "anotherString"],
- source: "fromString: aString flag: anotherString\x0a\x09<inlineJS: 'return new RegExp(aString, anotherString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.RegularExpression.klass);
- });
- define('amber_core/Kernel-Classes',["amber/boot", "amber_core/Kernel-Collections", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Classes");
- $core.packages["Kernel-Classes"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Classes"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("BehaviorBody", $globals.Object, [], "Kernel-Classes");
- $globals.BehaviorBody.comment="I am the superclass of all behaviors.\x0a\x0aMy instances hold the method dictionary.\x0a\x0aI also provides methods for compiling methods and examining the method dictionary.";
- $core.addMethod(
- $core.method({
- selector: ">>",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._methodAt_(aString);
- }, function($ctx1) {$ctx1.fill(self,">>",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: ">> aString\x0a\x09^ self methodAt: aString",
- referencedClasses: [],
- messageSends: ["methodAt:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "addCompiledMethod:",
- protocol: "compiling",
- fn: function (aMethod){
- var self=this;
- var oldMethod,announcement;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$4,$5,$6,$7,$8,$9,$10,$receiver;
- oldMethod=$recv(self._methodDictionary())._at_ifAbsent_($recv(aMethod)._selector(),(function(){
- return nil;
- }));
- $2=self._protocols();
- $3=$recv(aMethod)._protocol();
- $ctx1.sendIdx["protocol"]=1;
- $1=$recv($2)._includes_($3);
- if(!$core.assert($1)){
- $4=self._organization();
- $5=$recv(aMethod)._protocol();
- $ctx1.sendIdx["protocol"]=2;
- $recv($4)._addElement_($5);
- }
- self._basicAddCompiledMethod_(aMethod);
- $6=oldMethod;
- if(($receiver = $6) == null || $receiver.isNil){
- $6;
- } else {
- self._removeProtocolIfEmpty_($recv(oldMethod)._protocol());
- }
- $7=oldMethod;
- if(($receiver = $7) == null || $receiver.isNil){
- $8=$recv($globals.MethodAdded)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($8)._method_(aMethod);
- $ctx1.sendIdx["method:"]=1;
- $9=$recv($8)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- announcement=$9;
- } else {
- $10=$recv($globals.MethodModified)._new();
- $recv($10)._oldMethod_(oldMethod);
- $recv($10)._method_(aMethod);
- announcement=$recv($10)._yourself();
- }
- $recv($recv($globals.SystemAnnouncer)._current())._announce_(announcement);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addCompiledMethod:",{aMethod:aMethod,oldMethod:oldMethod,announcement:announcement},$globals.BehaviorBody)});
- },
- args: ["aMethod"],
- source: "addCompiledMethod: aMethod\x0a\x09| oldMethod announcement |\x0a\x09\x0a\x09oldMethod := self methodDictionary\x0a\x09\x09at: aMethod selector\x0a\x09\x09ifAbsent: [ nil ].\x0a\x09\x0a\x09(self protocols includes: aMethod protocol)\x0a\x09\x09ifFalse: [ self organization addElement: aMethod protocol ].\x0a\x0a\x09self basicAddCompiledMethod: aMethod.\x0a\x09\x0a\x09oldMethod ifNotNil: [\x0a\x09\x09self removeProtocolIfEmpty: oldMethod protocol ].\x0a\x09\x0a\x09announcement := oldMethod\x0a\x09\x09ifNil: [\x0a\x09\x09\x09MethodAdded new\x0a\x09\x09\x09\x09\x09method: aMethod;\x0a\x09\x09\x09\x09\x09yourself ]\x0a\x09\x09ifNotNil: [\x0a\x09\x09\x09MethodModified new\x0a\x09\x09\x09\x09\x09oldMethod: oldMethod;\x0a\x09\x09\x09\x09\x09method: aMethod;\x0a\x09\x09\x09\x09\x09yourself ].\x0a\x09\x09\x09\x09\x09\x0a\x09\x09\x09\x09\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09\x09\x09announce: announcement",
- referencedClasses: ["MethodAdded", "MethodModified", "SystemAnnouncer"],
- messageSends: ["at:ifAbsent:", "methodDictionary", "selector", "ifFalse:", "includes:", "protocols", "protocol", "addElement:", "organization", "basicAddCompiledMethod:", "ifNotNil:", "removeProtocolIfEmpty:", "ifNil:ifNotNil:", "method:", "new", "yourself", "oldMethod:", "announce:", "current"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "allInstanceVariableNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return [];
- },
- args: [],
- source: "allInstanceVariableNames\x0a\x09\x22Default for non-classes; to be able to send #allInstanceVariableNames to any class / trait.\x22\x0a\x09^ #()",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "allSubclassesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return self;
- },
- args: ["aBlock"],
- source: "allSubclassesDo: aBlock\x0a\x09\x22Default for non-classes; to be able to send #allSubclassesDo: to any class / trait.\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "basicAddCompiledMethod:",
- protocol: "private",
- fn: function (aMethod){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.addMethod(aMethod, self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicAddCompiledMethod:",{aMethod:aMethod},$globals.BehaviorBody)});
- },
- args: ["aMethod"],
- source: "basicAddCompiledMethod: aMethod\x0a\x09<inlineJS: '$core.addMethod(aMethod, self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "basicRemoveCompiledMethod:",
- protocol: "private",
- fn: function (aMethod){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.removeMethod(aMethod,self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicRemoveCompiledMethod:",{aMethod:aMethod},$globals.BehaviorBody)});
- },
- args: ["aMethod"],
- source: "basicRemoveCompiledMethod: aMethod\x0a\x09<inlineJS: '$core.removeMethod(aMethod,self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "comment",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._basicAt_("comment");
- if(($receiver = $1) == null || $receiver.isNil){
- return "";
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"comment",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "comment\x0a\x09^ (self basicAt: 'comment') ifNil: [ '' ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "basicAt:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "comment:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- self._basicAt_put_("comment",aString);
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.ClassCommentChanged)._new();
- $recv($3)._theClass_(self);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"comment:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "comment: aString\x0a\x09self basicAt: 'comment' put: aString.\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassCommentChanged new\x0a\x09\x09\x09theClass: self;\x0a\x09\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ClassCommentChanged"],
- messageSends: ["basicAt:put:", "announce:", "current", "theClass:", "new", "yourself"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "compile:protocol:",
- protocol: "compiling",
- fn: function (aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Compiler)._new())._install_forClass_protocol_(aString,self,anotherString);
- }, function($ctx1) {$ctx1.fill(self,"compile:protocol:",{aString:aString,anotherString:anotherString},$globals.BehaviorBody)});
- },
- args: ["aString", "anotherString"],
- source: "compile: aString protocol: anotherString\x0a\x09^ Compiler new\x0a\x09\x09install: aString\x0a\x09\x09forClass: self\x0a\x09\x09protocol: anotherString",
- referencedClasses: ["Compiler"],
- messageSends: ["install:forClass:protocol:", "new"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"definition",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "definition\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "includesSelector:",
- protocol: "testing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._methodDictionary())._includesKey_(aString);
- }, function($ctx1) {$ctx1.fill(self,"includesSelector:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "includesSelector: aString\x0a\x09^ self methodDictionary includesKey: aString",
- referencedClasses: [],
- messageSends: ["includesKey:", "methodDictionary"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "methodAt:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._methodDictionary())._at_(aString);
- }, function($ctx1) {$ctx1.fill(self,"methodAt:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "methodAt: aString\x0a\x09^ self methodDictionary at: aString",
- referencedClasses: [],
- messageSends: ["at:", "methodDictionary"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "methodDictionary",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var dict = $globals.HashedCollection._new();
- var methods = self.methods;
- Object.keys(methods).forEach(function(i) {
- if(methods[i].selector) {
- dict._at_put_(methods[i].selector, methods[i]);
- }
- });
- return dict;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"methodDictionary",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "methodDictionary\x0a\x09<inlineJS: 'var dict = $globals.HashedCollection._new();\x0a\x09var methods = self.methods;\x0a\x09Object.keys(methods).forEach(function(i) {\x0a\x09\x09if(methods[i].selector) {\x0a\x09\x09\x09dict._at_put_(methods[i].selector, methods[i]);\x0a\x09\x09}\x0a\x09});\x0a\x09return dict'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "methodTemplate",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $recv(stream)._write_("messageSelectorAndArgumentNames");
- $ctx2.sendIdx["write:"]=1;
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=1;
- $recv(stream)._tab();
- $ctx2.sendIdx["tab"]=1;
- $recv(stream)._write_("\x22comment stating purpose of message\x22");
- $ctx2.sendIdx["write:"]=2;
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=2;
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=3;
- $recv(stream)._tab();
- $ctx2.sendIdx["tab"]=2;
- $recv(stream)._write_("| temporary variable names |");
- $ctx2.sendIdx["write:"]=3;
- $recv(stream)._lf();
- $recv(stream)._tab();
- return $recv(stream)._write_("statements");
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"methodTemplate",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "methodTemplate\x0a\x09^ String streamContents: [ :stream | stream \x0a\x09\x09write: 'messageSelectorAndArgumentNames'; lf;\x0a\x09\x09tab; write: '\x22comment stating purpose of message\x22'; lf;\x0a\x09\x09lf;\x0a\x09\x09tab; write: '| temporary variable names |'; lf;\x0a\x09\x09tab; write: 'statements' ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "write:", "lf", "tab"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "methods",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._methodDictionary())._values();
- }, function($ctx1) {$ctx1.fill(self,"methods",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "methods\x0a\x09^ self methodDictionary values",
- referencedClasses: [],
- messageSends: ["values", "methodDictionary"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "methodsInProtocol:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._methods())._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._protocol()).__eq(aString);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"methodsInProtocol:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "methodsInProtocol: aString\x0a\x09^ self methods select: [ :each | each protocol = aString ]",
- referencedClasses: [],
- messageSends: ["select:", "methods", "=", "protocol"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "name",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.className || nil;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"name",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "name\x0a\x09<inlineJS: 'return self.className || nil'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "organization",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("organization");
- }, function($ctx1) {$ctx1.fill(self,"organization",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "organization\x0a\x09^ self basicAt: 'organization'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "ownMethods",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv($recv(self._ownProtocols())._inject_into_($recv($globals.OrderedCollection)._new(),(function(acc,each){
- return $core.withContext(function($ctx2) {
- return $recv(acc).__comma(self._ownMethodsInProtocol_(each));
- }, function($ctx2) {$ctx2.fillBlock({acc:acc,each:each},$ctx1,1)});
- })))._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $1=$recv(a)._selector();
- $ctx2.sendIdx["selector"]=1;
- return $recv($1).__lt_eq($recv(b)._selector());
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"ownMethods",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "ownMethods\x0a\x09\x22Answer the methods of the receiver that are not package extensions\x0a\x09nor obtained via trait composition\x22\x0a\x0a\x09^ (self ownProtocols \x0a\x09\x09inject: OrderedCollection new\x0a\x09\x09into: [ :acc :each | acc, (self ownMethodsInProtocol: each) ])\x0a\x09\x09\x09sorted: [ :a :b | a selector <= b selector ]",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["sorted:", "inject:into:", "ownProtocols", "new", ",", "ownMethodsInProtocol:", "<=", "selector"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "ownMethodsInProtocol:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._methodsInProtocol_(aString))._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._methodClass()).__eq(self);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"ownMethodsInProtocol:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "ownMethodsInProtocol: aString\x0a\x09^ (self methodsInProtocol: aString) select: [ :each | each methodClass = self ]",
- referencedClasses: [],
- messageSends: ["select:", "methodsInProtocol:", "=", "methodClass"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "ownProtocols",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._protocols())._reject_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._match_("^\x5c*");
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"ownProtocols",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "ownProtocols\x0a\x09\x22Answer the protocols of the receiver that are not package extensions\x22\x0a\x0a\x09^ self protocols reject: [ :each |\x0a\x09\x09each match: '^\x5c*' ]",
- referencedClasses: [],
- messageSends: ["reject:", "protocols", "match:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "packageOfProtocol:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(aString)._beginsWith_("*");
- if(!$core.assert($1)){
- return self._package();
- }
- return $recv($globals.Package)._named_ifAbsent_($recv(aString)._allButFirst(),(function(){
- return nil;
- }));
- }, function($ctx1) {$ctx1.fill(self,"packageOfProtocol:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "packageOfProtocol: aString\x0a\x09\x22Answer the package the method of receiver belongs to:\x0a\x09- if it is an extension method, answer the corresponding package\x0a\x09- else answer the receiver's package\x22\x0a\x09\x0a\x09(aString beginsWith: '*') ifFalse: [\x0a\x09\x09^ self package ].\x0a\x09\x09\x0a\x09^ Package \x0a\x09\x09named: aString allButFirst\x0a\x09\x09ifAbsent: [ nil ]",
- referencedClasses: ["Package"],
- messageSends: ["ifFalse:", "beginsWith:", "package", "named:ifAbsent:", "allButFirst"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._name();
- if(($receiver = $1) == null || $receiver.isNil){
- (
- $ctx1.supercall = true,
- ($globals.BehaviorBody.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- } else {
- var name;
- name=$receiver;
- $recv(aStream)._nextPutAll_(name);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.BehaviorBody)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09self name\x0a\x09\x09ifNil: [ super printOn: aStream ]\x0a\x09\x09ifNotNil: [ :name | aStream nextPutAll: name ]",
- referencedClasses: [],
- messageSends: ["ifNil:ifNotNil:", "name", "printOn:", "nextPutAll:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "protocols",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._organization())._elements())._sorted();
- }, function($ctx1) {$ctx1.fill(self,"protocols",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "protocols\x0a\x09^ self organization elements sorted",
- referencedClasses: [],
- messageSends: ["sorted", "elements", "organization"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "protocolsDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- var methodsByProtocol;
- return $core.withContext(function($ctx1) {
- methodsByProtocol=$recv($globals.HashedCollection)._new();
- $ctx1.sendIdx["new"]=1;
- $recv(self._methodDictionary())._valuesDo_((function(m){
- return $core.withContext(function($ctx2) {
- return $recv($recv(methodsByProtocol)._at_ifAbsentPut_($recv(m)._protocol(),(function(){
- return $core.withContext(function($ctx3) {
- return $recv($globals.Array)._new();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- })))._add_(m);
- }, function($ctx2) {$ctx2.fillBlock({m:m},$ctx1,1)});
- }));
- $recv(self._protocols())._do_((function(protocol){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._value_value_(protocol,$recv(methodsByProtocol)._at_(protocol));
- }, function($ctx2) {$ctx2.fillBlock({protocol:protocol},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"protocolsDo:",{aBlock:aBlock,methodsByProtocol:methodsByProtocol},$globals.BehaviorBody)});
- },
- args: ["aBlock"],
- source: "protocolsDo: aBlock\x0a\x09\x22Execute aBlock for each method protocol with\x0a\x09its collection of methods in the sort order of protocol name.\x22\x0a\x0a\x09| methodsByProtocol |\x0a\x09methodsByProtocol := HashedCollection new.\x0a\x09self methodDictionary valuesDo: [ :m |\x0a\x09\x09(methodsByProtocol at: m protocol ifAbsentPut: [ Array new ])\x0a\x09\x09\x09add: m ].\x0a\x09self protocols do: [ :protocol |\x0a\x09\x09aBlock value: protocol value: (methodsByProtocol at: protocol) ]",
- referencedClasses: ["HashedCollection", "Array"],
- messageSends: ["new", "valuesDo:", "methodDictionary", "add:", "at:ifAbsentPut:", "protocol", "do:", "protocols", "value:value:", "at:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "recompile",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Compiler)._new())._recompile_(self);
- }, function($ctx1) {$ctx1.fill(self,"recompile",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "recompile\x0a\x09^ Compiler new recompile: self",
- referencedClasses: ["Compiler"],
- messageSends: ["recompile:", "new"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "removeCompiledMethod:",
- protocol: "compiling",
- fn: function (aMethod){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- self._basicRemoveCompiledMethod_(aMethod);
- self._removeProtocolIfEmpty_($recv(aMethod)._protocol());
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.MethodRemoved)._new();
- $recv($3)._method_(aMethod);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeCompiledMethod:",{aMethod:aMethod},$globals.BehaviorBody)});
- },
- args: ["aMethod"],
- source: "removeCompiledMethod: aMethod\x0a\x09self basicRemoveCompiledMethod: aMethod.\x0a\x09\x0a\x09self removeProtocolIfEmpty: aMethod protocol.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (MethodRemoved new\x0a\x09\x09\x09method: aMethod;\x0a\x09\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "MethodRemoved"],
- messageSends: ["basicRemoveCompiledMethod:", "removeProtocolIfEmpty:", "protocol", "announce:", "current", "method:", "new", "yourself"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "removeProtocolIfEmpty:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._methods())._detect_ifNone_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._protocol()).__eq(aString);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._organization())._removeElement_(aString);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeProtocolIfEmpty:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "removeProtocolIfEmpty: aString\x0a\x09self methods\x0a\x09\x09detect: [ :each | each protocol = aString ]\x0a\x09\x09ifNone: [ self organization removeElement: aString ]",
- referencedClasses: [],
- messageSends: ["detect:ifNone:", "methods", "=", "protocol", "removeElement:", "organization"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "selectors",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._methodDictionary())._keys();
- }, function($ctx1) {$ctx1.fill(self,"selectors",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "selectors\x0a\x09^ self methodDictionary keys",
- referencedClasses: [],
- messageSends: ["keys", "methodDictionary"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "setTraitComposition:",
- protocol: "compiling",
- fn: function (aTraitComposition){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.setTraitComposition(aTraitComposition._asJavaScriptObject(), self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setTraitComposition:",{aTraitComposition:aTraitComposition},$globals.BehaviorBody)});
- },
- args: ["aTraitComposition"],
- source: "setTraitComposition: aTraitComposition\x0a\x09<inlineJS: '$core.setTraitComposition(aTraitComposition._asJavaScriptObject(), self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "superclass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return nil;
- },
- args: [],
- source: "superclass\x0a\x09\x22Default for non-classes; to be able to send #superclass to any class / trait.\x22\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "theMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"theMetaClass",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "theMetaClass\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "theNonMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"theNonMetaClass",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "theNonMetaClass\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "traitComposition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._basicAt_("traitComposition"))._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($globals.TraitTransformation)._fromJSON_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"traitComposition",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "traitComposition\x0a\x09^ (self basicAt: 'traitComposition') collect: [ :each | TraitTransformation fromJSON: each ]",
- referencedClasses: ["TraitTransformation"],
- messageSends: ["collect:", "basicAt:", "fromJSON:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "traitCompositionDefinition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._traitComposition())._ifNotEmpty_((function(traitComposition){
- return $core.withContext(function($ctx2) {
- return $recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx3) {
- $recv(str)._write_("{");
- $ctx3.sendIdx["write:"]=1;
- $recv(traitComposition)._do_separatedBy_((function(each){
- return $core.withContext(function($ctx4) {
- return $recv(str)._write_($recv(each)._definition());
- $ctx4.sendIdx["write:"]=2;
- }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3,3)});
- }),(function(){
- return $core.withContext(function($ctx4) {
- return $recv(str)._write_(". ");
- $ctx4.sendIdx["write:"]=3;
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,4)});
- }));
- return $recv(str)._write_("}");
- }, function($ctx3) {$ctx3.fillBlock({str:str},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({traitComposition:traitComposition},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"traitCompositionDefinition",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "traitCompositionDefinition\x0a\x09^ self traitComposition ifNotEmpty: [ :traitComposition |\x0a\x09\x09String streamContents: [ :str |\x0a\x09\x09\x09str write: '{'.\x0a\x09\x09\x09traitComposition\x0a\x09\x09\x09\x09do: [ :each | str write: each definition ]\x0a\x09\x09\x09\x09separatedBy: [ str write: '. ' ].\x0a\x09\x09\x09str write: '}' ] ]",
- referencedClasses: ["String"],
- messageSends: ["ifNotEmpty:", "traitComposition", "streamContents:", "write:", "do:separatedBy:", "definition"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "traitUsers",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return [];
- },
- args: [],
- source: "traitUsers\x0a\x09\x22Default for non-traits; to be able to send #traitUsers to any class / trait\x22\x0a\x09^ #()",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addClass("Behavior", $globals.BehaviorBody, [], "Kernel-Classes");
- $globals.Behavior.comment="I am the superclass of all class objects.\x0a\x0aIn addition to BehaviorBody, I define superclass/subclass relationships and instantiation.\x0a\x0aI define the protocol for creating instances of a class with `#basicNew` and `#new` (see `boot.js` for class constructors details).\x0a\x0aMy instances know about the subclass/superclass relationships between classes and contain the description that instances are created from.\x0a\x0aI also provide iterating over the class hierarchy.";
- $core.addMethod(
- $core.method({
- selector: "allInstanceVariableNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- result=$recv(self._instanceVariableNames())._copy();
- $1=self._superclass();
- $ctx1.sendIdx["superclass"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $recv(result)._addAll_($recv(self._superclass())._allInstanceVariableNames());
- }
- return result;
- }, function($ctx1) {$ctx1.fill(self,"allInstanceVariableNames",{result:result},$globals.Behavior)});
- },
- args: [],
- source: "allInstanceVariableNames\x0a\x09| result |\x0a\x09result := self instanceVariableNames copy.\x0a\x09self superclass ifNotNil: [\x0a\x09\x09result addAll: self superclass allInstanceVariableNames ].\x0a\x09^ result",
- referencedClasses: [],
- messageSends: ["copy", "instanceVariableNames", "ifNotNil:", "superclass", "addAll:", "allInstanceVariableNames"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "allSelectors",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=self._allSuperclasses();
- $2=self._selectors();
- $ctx1.sendIdx["selectors"]=1;
- return $recv($1)._inject_into_($2,(function(acc,each){
- return $core.withContext(function($ctx2) {
- $recv(acc)._addAll_($recv(each)._selectors());
- return $recv(acc)._yourself();
- }, function($ctx2) {$ctx2.fillBlock({acc:acc,each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"allSelectors",{},$globals.Behavior)});
- },
- args: [],
- source: "allSelectors\x0a\x09^ self allSuperclasses\x0a\x09\x09inject: self selectors\x0a\x09\x09into: [ :acc :each | acc addAll: each selectors; yourself ]",
- referencedClasses: [],
- messageSends: ["inject:into:", "allSuperclasses", "selectors", "addAll:", "yourself"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "allSubclasses",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Array)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- return self._allSubclassesDo_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(str)._nextPut_(each);
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"allSubclasses",{},$globals.Behavior)});
- },
- args: [],
- source: "allSubclasses\x0a\x09\x22Answer an collection of the receiver's and the receiver's descendent's subclasses. \x22\x0a\x0a\x09^ Array streamContents: [ :str | self allSubclassesDo: [ :each | str nextPut: each ] ]",
- referencedClasses: ["Array"],
- messageSends: ["streamContents:", "allSubclassesDo:", "nextPut:"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "allSubclassesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.traverseClassTree(self, function(subclass) {
- if (subclass !== self) aBlock._value_(subclass);
- });
- return self;
- }, function($ctx1) {$ctx1.fill(self,"allSubclassesDo:",{aBlock:aBlock},$globals.Behavior)});
- },
- args: ["aBlock"],
- source: "allSubclassesDo: aBlock\x0a\x09\x22Evaluate the argument, aBlock, for each of the receiver's subclasses.\x22\x0a\x0a<inlineJS: '$core.traverseClassTree(self, function(subclass) {\x0a\x09if (subclass !== self) aBlock._value_(subclass);\x0a})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "allSuperclasses",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$receiver;
- $1=self._superclass();
- $ctx1.sendIdx["superclass"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return [];
- } else {
- $1;
- }
- $3=self._superclass();
- $ctx1.sendIdx["superclass"]=2;
- $2=$recv($globals.OrderedCollection)._with_($3);
- $recv($2)._addAll_($recv(self._superclass())._allSuperclasses());
- return $recv($2)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"allSuperclasses",{},$globals.Behavior)});
- },
- args: [],
- source: "allSuperclasses\x0a\x09\x0a\x09self superclass ifNil: [ ^ #() ].\x0a\x09\x0a\x09^ (OrderedCollection with: self superclass)\x0a\x09\x09addAll: self superclass allSuperclasses;\x0a\x09\x09yourself",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["ifNil:", "superclass", "addAll:", "with:", "allSuperclasses", "yourself"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "basicNew",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new self.fn();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicNew",{},$globals.Behavior)});
- },
- args: [],
- source: "basicNew\x0a\x09<inlineJS: 'return new self.fn()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "canUnderstand:",
- protocol: "testing",
- fn: function (aSelector){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- return $recv(self._includesSelector_($recv(aSelector)._asString()))._or_((function(){
- return $core.withContext(function($ctx2) {
- $2=self._superclass();
- $ctx2.sendIdx["superclass"]=1;
- $1=$recv($2)._notNil();
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(self._superclass())._canUnderstand_(aSelector);
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"canUnderstand:",{aSelector:aSelector},$globals.Behavior)});
- },
- args: ["aSelector"],
- source: "canUnderstand: aSelector\x0a\x09^ (self includesSelector: aSelector asString) or: [\x0a\x09\x09self superclass notNil and: [ self superclass canUnderstand: aSelector ]]",
- referencedClasses: [],
- messageSends: ["or:", "includesSelector:", "asString", "and:", "notNil", "superclass", "canUnderstand:"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "includesBehavior:",
- protocol: "testing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self.__eq_eq(aClass))._or_((function(){
- return $core.withContext(function($ctx2) {
- return self._inheritsFrom_(aClass);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"includesBehavior:",{aClass:aClass},$globals.Behavior)});
- },
- args: ["aClass"],
- source: "includesBehavior: aClass\x0a\x09^ self == aClass or: [\x0a\x09\x09\x09self inheritsFrom: aClass ]",
- referencedClasses: [],
- messageSends: ["or:", "==", "inheritsFrom:"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "inheritsFrom:",
- protocol: "testing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$receiver;
- $1=self._superclass();
- $ctx1.sendIdx["superclass"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- $1;
- }
- $3=self._superclass();
- $ctx1.sendIdx["superclass"]=2;
- $2=$recv(aClass).__eq_eq($3);
- return $recv($2)._or_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._superclass())._inheritsFrom_(aClass);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"inheritsFrom:",{aClass:aClass},$globals.Behavior)});
- },
- args: ["aClass"],
- source: "inheritsFrom: aClass\x0a\x09self superclass ifNil: [ ^ false ].\x0a\x0a\x09^ aClass == self superclass or: [ \x0a\x09\x09self superclass inheritsFrom: aClass ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "superclass", "or:", "==", "inheritsFrom:"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "instanceVariableNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.iVarNames;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"instanceVariableNames",{},$globals.Behavior)});
- },
- args: [],
- source: "instanceVariableNames\x0a\x09<inlineJS: 'return self.iVarNames'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "isBehavior",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isBehavior\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "javascriptConstructor",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.fn;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"javascriptConstructor",{},$globals.Behavior)});
- },
- args: [],
- source: "javascriptConstructor\x0a\x09\x22Answer the JS constructor used to instantiate. See boot.js\x22\x0a\x09\x0a\x09<inlineJS: 'return self.fn'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "javascriptConstructor:",
- protocol: "accessing",
- fn: function (aJavaScriptFunction){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.setClassConstructor(self, aJavaScriptFunction);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"javascriptConstructor:",{aJavaScriptFunction:aJavaScriptFunction},$globals.Behavior)});
- },
- args: ["aJavaScriptFunction"],
- source: "javascriptConstructor: aJavaScriptFunction\x0a\x09\x22Set the JS constructor used to instantiate.\x0a\x09See the JS counter-part in boot.js `$core.setClassConstructor'\x22\x0a\x09\x0a\x09<inlineJS: '$core.setClassConstructor(self, aJavaScriptFunction);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "lookupSelector:",
- protocol: "accessing",
- fn: function (selector){
- var self=this;
- var lookupClass;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- lookupClass=self;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(lookupClass).__eq(nil);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- $1=$recv(lookupClass)._includesSelector_(selector);
- if($core.assert($1)){
- throw $early=[$recv(lookupClass)._methodAt_(selector)];
- }
- lookupClass=$recv(lookupClass)._superclass();
- return lookupClass;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return nil;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"lookupSelector:",{selector:selector,lookupClass:lookupClass},$globals.Behavior)});
- },
- args: ["selector"],
- source: "lookupSelector: selector\x0a\x09\x22Look up the given selector in my methodDictionary.\x0a\x09Return the corresponding method if found.\x0a\x09Otherwise chase the superclass chain and try again.\x0a\x09Return nil if no method is found.\x22\x0a\x09\x0a\x09| lookupClass |\x0a\x09\x0a\x09lookupClass := self.\x0a\x09[ lookupClass = nil ] whileFalse: [\x0a\x09\x09(lookupClass includesSelector: selector)\x0a\x09\x09\x09\x09ifTrue: [ ^ lookupClass methodAt: selector ].\x0a\x09\x09\x09lookupClass := lookupClass superclass ].\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: ["whileFalse:", "=", "ifTrue:", "includesSelector:", "methodAt:", "superclass"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._basicNew())._initialize();
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.Behavior)});
- },
- args: [],
- source: "new\x0a\x09^ self basicNew initialize",
- referencedClasses: [],
- messageSends: ["initialize", "basicNew"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "prototype",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.fn.prototype;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"prototype",{},$globals.Behavior)});
- },
- args: [],
- source: "prototype\x0a\x09<inlineJS: 'return self.fn.prototype'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "subclasses",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"subclasses",{},$globals.Behavior)});
- },
- args: [],
- source: "subclasses\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "superclass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.superclass;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"superclass",{},$globals.Behavior)});
- },
- args: [],
- source: "superclass\x0a\x09<inlineJS: 'return self.superclass'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "theMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"theMetaClass",{},$globals.Behavior)});
- },
- args: [],
- source: "theMetaClass\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "theNonMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"theNonMetaClass",{},$globals.Behavior)});
- },
- args: [],
- source: "theNonMetaClass\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Behavior);
- $core.addMethod(
- $core.method({
- selector: "withAllSubclasses",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Array)._with_(self);
- $recv($1)._addAll_(self._allSubclasses());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"withAllSubclasses",{},$globals.Behavior)});
- },
- args: [],
- source: "withAllSubclasses\x0a\x09^ (Array with: self) addAll: self allSubclasses; yourself",
- referencedClasses: ["Array"],
- messageSends: ["addAll:", "with:", "allSubclasses", "yourself"]
- }),
- $globals.Behavior);
- $core.addClass("Class", $globals.Behavior, [], "Kernel-Classes");
- $globals.Class.comment="I am __the__ class object.\x0a\x0aMy instances are the classes of the system.\x0aClass creation is done throught a `ClassBuilder` instance.";
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "$globals.".__comma(self._name());
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.Class)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09^ '$globals.', self name",
- referencedClasses: [],
- messageSends: [",", "name"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "browse",
- protocol: "browsing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Finder)._findClass_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"browse",{},$globals.Class)});
- },
- args: [],
- source: "browse\x0a\x09Finder findClass: self",
- referencedClasses: ["Finder"],
- messageSends: ["findClass:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "category",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._package();
- $ctx1.sendIdx["package"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return "Unclassified";
- } else {
- return $recv(self._package())._name();
- }
- }, function($ctx1) {$ctx1.fill(self,"category",{},$globals.Class)});
- },
- args: [],
- source: "category\x0a\x09^ self package ifNil: [ 'Unclassified' ] ifNotNil: [ self package name ]",
- referencedClasses: [],
- messageSends: ["ifNil:ifNotNil:", "package", "name"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "class";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'class'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $recv(stream)._print_(self._superclass());
- $ctx2.sendIdx["print:"]=1;
- $recv(stream)._write_(" subclass: ");
- $ctx2.sendIdx["write:"]=1;
- $recv(stream)._printSymbol_(self._name());
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=1;
- $recv(stream)._write_($recv(self._traitCompositionDefinition())._ifNotEmpty_((function(tcd){
- return $core.withContext(function($ctx3) {
- $1=$recv($globals.String)._tab();
- $ctx3.sendIdx["tab"]=1;
- $2=$recv($globals.String)._lf();
- $ctx3.sendIdx["lf"]=2;
- return [$1,"uses: ",tcd,$2];
- }, function($ctx3) {$ctx3.fillBlock({tcd:tcd},$ctx2,2)});
- })));
- $ctx2.sendIdx["write:"]=2;
- $recv(stream)._tab();
- $ctx2.sendIdx["tab"]=2;
- $recv(stream)._write_("instanceVariableNames: ");
- $ctx2.sendIdx["write:"]=3;
- $recv(stream)._print_(" "._join_(self._instanceVariableNames()));
- $ctx2.sendIdx["print:"]=2;
- $recv(stream)._lf();
- $recv(stream)._tab();
- $recv(stream)._write_("package: ");
- return $recv(stream)._print_(self._category());
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"definition",{},$globals.Class)});
- },
- args: [],
- source: "definition\x0a\x09^ String streamContents: [ :stream | stream\x0a\x09\x09print: self superclass; write: ' subclass: '; printSymbol: self name; lf;\x0a\x09\x09write: (self traitCompositionDefinition ifNotEmpty: [ :tcd | { String tab. 'uses: '. tcd. String lf }]);\x0a\x09\x09tab; write: 'instanceVariableNames: '; print: (' ' join: self instanceVariableNames); lf;\x0a\x09\x09tab; write: 'package: '; print: self category ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "print:", "superclass", "write:", "printSymbol:", "name", "lf", "ifNotEmpty:", "traitCompositionDefinition", "tab", "join:", "instanceVariableNames", "category"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "isClass",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isClass\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "package",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("pkg");
- }, function($ctx1) {$ctx1.fill(self,"package",{},$globals.Class)});
- },
- args: [],
- source: "package\x0a\x09^ self basicAt: 'pkg'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "package:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- var oldPackage;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$4,$6,$5;
- $2=self._package();
- $ctx1.sendIdx["package"]=1;
- $1=$recv($2).__eq(aPackage);
- if($core.assert($1)){
- return self;
- }
- oldPackage=self._package();
- self._basicAt_put_("pkg",aPackage);
- $3=$recv(oldPackage)._organization();
- $ctx1.sendIdx["organization"]=1;
- $recv($3)._removeElement_(self);
- $recv($recv(aPackage)._organization())._addElement_(self);
- $4=$recv($globals.SystemAnnouncer)._current();
- $6=$recv($globals.ClassMoved)._new();
- $recv($6)._theClass_(self);
- $recv($6)._oldPackage_(oldPackage);
- $5=$recv($6)._yourself();
- $recv($4)._announce_($5);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"package:",{aPackage:aPackage,oldPackage:oldPackage},$globals.Class)});
- },
- args: ["aPackage"],
- source: "package: aPackage\x0a\x09| oldPackage |\x0a\x09\x0a\x09self package = aPackage ifTrue: [ ^ self ].\x0a\x09\x0a\x09oldPackage := self package.\x0a\x09\x0a\x09self basicAt: 'pkg' put: aPackage.\x0a\x09oldPackage organization removeElement: self.\x0a\x09aPackage organization addElement: self.\x0a\x0a\x09SystemAnnouncer current announce: (ClassMoved new\x0a\x09\x09theClass: self;\x0a\x09\x09oldPackage: oldPackage;\x0a\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ClassMoved"],
- messageSends: ["ifTrue:", "=", "package", "basicAt:put:", "removeElement:", "organization", "addElement:", "announce:", "current", "theClass:", "new", "oldPackage:", "yourself"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "rename:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.ClassBuilder)._new())._renameClass_to_(self,aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"rename:",{aString:aString},$globals.Class)});
- },
- args: ["aString"],
- source: "rename: aString\x0a\x09ClassBuilder new renameClass: self to: aString",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["renameClass:to:", "new"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:",
- protocol: "class creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,"",nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:",{aString:aString},$globals.Class)});
- },
- args: ["aString"],
- source: "subclass: aString \x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString instanceVariableNames: '' package: nil",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:",
- protocol: "class creation",
- fn: function (aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,anotherString,nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:",{aString:aString,anotherString:anotherString},$globals.Class)});
- },
- args: ["aString", "anotherString"],
- source: "subclass: aString instanceVariableNames: anotherString\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString instanceVariableNames: anotherString package: nil",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:category:",
- protocol: "class creation",
- fn: function (aString,aString2,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:category:",{aString:aString,aString2:aString2,aString3:aString3},$globals.Class)});
- },
- args: ["aString", "aString2", "aString3"],
- source: "subclass: aString instanceVariableNames: aString2 category: aString3\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:classVariableNames:poolDictionaries:category:",
- protocol: "class creation",
- fn: function (aString,aString2,classVars,pools,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:classVariableNames:poolDictionaries:category:",{aString:aString,aString2:aString2,classVars:classVars,pools:pools,aString3:aString3},$globals.Class)});
- },
- args: ["aString", "aString2", "classVars", "pools", "aString3"],
- source: "subclass: aString instanceVariableNames: aString2 classVariableNames: classVars poolDictionaries: pools category: aString3\x0a\x09\x22Kept for file-in compatibility. ignores class variables and pools.\x22\x0a\x09^ self subclass: aString instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:package:",
- protocol: "class creation",
- fn: function (aString,aString2,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.ClassBuilder)._new())._superclass_subclass_instanceVariableNames_package_(self,$recv(aString)._asString(),aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:package:",{aString:aString,aString2:aString2,aString3:aString3},$globals.Class)});
- },
- args: ["aString", "aString2", "aString3"],
- source: "subclass: aString instanceVariableNames: aString2 package: aString3\x0a\x09^ ClassBuilder new\x0a\x09\x09superclass: self subclass: aString asString instanceVariableNames: aString2 package: aString3",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["superclass:subclass:instanceVariableNames:package:", "new", "asString"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:",
- protocol: "class creation",
- fn: function (aString,aTraitCompositionDescription){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,"",nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription},$globals.Class)});
- },
- args: ["aString", "aTraitCompositionDescription"],
- source: "subclass: aString uses: aTraitCompositionDescription \x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: '' package: nil",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:",
- protocol: "class creation",
- fn: function (aString,aTraitCompositionDescription,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,anotherString,nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,anotherString:anotherString},$globals.Class)});
- },
- args: ["aString", "aTraitCompositionDescription", "anotherString"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: anotherString\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: anotherString package: nil",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:category:",
- protocol: "class creation",
- fn: function (aString,aTraitCompositionDescription,aString2,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:category:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,aString2:aString2,aString3:aString3},$globals.Class)});
- },
- args: ["aString", "aTraitCompositionDescription", "aString2", "aString3"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 category: aString3\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:classVariableNames:poolDictionaries:category:",
- protocol: "class creation",
- fn: function (aString,aTraitCompositionDescription,aString2,classVars,pools,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:classVariableNames:poolDictionaries:category:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,aString2:aString2,classVars:classVars,pools:pools,aString3:aString3},$globals.Class)});
- },
- args: ["aString", "aTraitCompositionDescription", "aString2", "classVars", "pools", "aString3"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 classVariableNames: classVars poolDictionaries: pools category: aString3\x0a\x09\x22Kept for file-in compatibility. ignores class variables and pools.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:package:",
- protocol: "class creation",
- fn: function (aString,aTraitCompositionDescription,aString2,aString3){
- var self=this;
- var cls;
- return $core.withContext(function($ctx1) {
- cls=self._subclass_instanceVariableNames_package_(aString,aString2,aString3);
- $recv(cls)._setTraitComposition_($recv(aTraitCompositionDescription)._asTraitComposition());
- return cls;
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:package:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,aString2:aString2,aString3:aString3,cls:cls},$globals.Class)});
- },
- args: ["aString", "aTraitCompositionDescription", "aString2", "aString3"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 package: aString3\x0a\x09| cls |\x0a\x09cls := self subclass: aString instanceVariableNames: aString2 package: aString3.\x0a\x09cls setTraitComposition: aTraitCompositionDescription asTraitComposition.\x0a\x09^ cls",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:", "setTraitComposition:", "asTraitComposition"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "subclasses",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.subclasses._copy();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"subclasses",{},$globals.Class)});
- },
- args: [],
- source: "subclasses\x0a\x09<inlineJS: 'return self.subclasses._copy()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "theMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._class();
- }, function($ctx1) {$ctx1.fill(self,"theMetaClass",{},$globals.Class)});
- },
- args: [],
- source: "theMetaClass\x0a\x09^ self class",
- referencedClasses: [],
- messageSends: ["class"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "theNonMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "theNonMetaClass\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Class);
- $core.addClass("Metaclass", $globals.Behavior, [], "Kernel-Classes");
- $globals.Metaclass.comment="I am the root of the class hierarchy.\x0a\x0aMy instances are metaclasses, one for each real class, and have a single instance, which they hold onto: the class that they are the metaclass of.";
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("$globals.".__comma($recv(self._instanceClass())._name())).__comma(".klass");
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.Metaclass)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09^ '$globals.', self instanceClass name, '.klass'",
- referencedClasses: [],
- messageSends: [",", "name", "instanceClass"]
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $recv(stream)._print_(self);
- $ctx2.sendIdx["print:"]=1;
- $recv(stream)._write_($recv(self._traitCompositionDefinition())._ifEmpty_ifNotEmpty_((function(){
- return " ";
- }),(function(tcd){
- return $core.withContext(function($ctx3) {
- $1=$recv($globals.String)._lf();
- $ctx3.sendIdx["lf"]=1;
- $2=$recv($globals.String)._tab();
- $ctx3.sendIdx["tab"]=1;
- return [$1,$2,"uses: ",tcd,$recv($globals.String)._lf(),$recv($globals.String)._tab()];
- }, function($ctx3) {$ctx3.fillBlock({tcd:tcd},$ctx2,3)});
- })));
- $ctx2.sendIdx["write:"]=1;
- $recv(stream)._write_("instanceVariableNames: ");
- return $recv(stream)._print_(" "._join_(self._instanceVariableNames()));
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"definition",{},$globals.Metaclass)});
- },
- args: [],
- source: "definition\x0a\x09^ String streamContents: [ :stream | stream\x0a\x09\x09print: self;\x0a\x09\x09write: (self traitCompositionDefinition\x0a\x09\x09\x09ifEmpty: [' ']\x0a\x09\x09\x09ifNotEmpty: [ :tcd | { String lf. String tab. 'uses: '. tcd. String lf. String tab }]);\x0a\x09\x09write: 'instanceVariableNames: ';\x0a\x09\x09print: (' ' join: self instanceVariableNames) ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "print:", "write:", "ifEmpty:ifNotEmpty:", "traitCompositionDefinition", "lf", "tab", "join:", "instanceVariableNames"]
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "instanceClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.instanceClass;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"instanceClass",{},$globals.Metaclass)});
- },
- args: [],
- source: "instanceClass\x0a\x09<inlineJS: 'return self.instanceClass'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "instanceVariableNames:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.ClassBuilder)._new())._class_instanceVariableNames_(self,aCollection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"instanceVariableNames:",{aCollection:aCollection},$globals.Metaclass)});
- },
- args: ["aCollection"],
- source: "instanceVariableNames: aCollection\x0a\x09ClassBuilder new\x0a\x09\x09class: self instanceVariableNames: aCollection.\x0a\x09^ self",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["class:instanceVariableNames:", "new"]
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "isMetaclass",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isMetaclass\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "name",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._instanceClass())._name()).__comma(" class");
- }, function($ctx1) {$ctx1.fill(self,"name",{},$globals.Metaclass)});
- },
- args: [],
- source: "name\x0a\x09^ self instanceClass name, ' class'",
- referencedClasses: [],
- messageSends: [",", "name", "instanceClass"]
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "package",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._instanceClass())._package();
- }, function($ctx1) {$ctx1.fill(self,"package",{},$globals.Metaclass)});
- },
- args: [],
- source: "package\x0a\x09^ self instanceClass package",
- referencedClasses: [],
- messageSends: ["package", "instanceClass"]
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "subclasses",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.metaSubclasses(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"subclasses",{},$globals.Metaclass)});
- },
- args: [],
- source: "subclasses\x0a\x09<inlineJS: 'return $core.metaSubclasses(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "theMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "theMetaClass\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "theNonMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._instanceClass();
- }, function($ctx1) {$ctx1.fill(self,"theNonMetaClass",{},$globals.Metaclass)});
- },
- args: [],
- source: "theNonMetaClass\x0a\x09^ self instanceClass",
- referencedClasses: [],
- messageSends: ["instanceClass"]
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "uses:instanceVariableNames:",
- protocol: "accessing",
- fn: function (aTraitCompositionDescription,aCollection){
- var self=this;
- var metaclass;
- return $core.withContext(function($ctx1) {
- metaclass=self._instanceVariableNames_(aCollection);
- $recv(metaclass)._setTraitComposition_($recv(aTraitCompositionDescription)._asTraitComposition());
- return metaclass;
- }, function($ctx1) {$ctx1.fill(self,"uses:instanceVariableNames:",{aTraitCompositionDescription:aTraitCompositionDescription,aCollection:aCollection,metaclass:metaclass},$globals.Metaclass)});
- },
- args: ["aTraitCompositionDescription", "aCollection"],
- source: "uses: aTraitCompositionDescription instanceVariableNames: aCollection\x0a\x09| metaclass |\x0a\x09metaclass := self instanceVariableNames: aCollection.\x0a\x09metaclass setTraitComposition: aTraitCompositionDescription asTraitComposition.\x0a\x09^ metaclass",
- referencedClasses: [],
- messageSends: ["instanceVariableNames:", "setTraitComposition:", "asTraitComposition"]
- }),
- $globals.Metaclass);
- $core.addClass("Trait", $globals.BehaviorBody, [], "Kernel-Classes");
- $core.addMethod(
- $core.method({
- selector: "-",
- protocol: "composition",
- fn: function (anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asTraitTransformation()).__minus(anArray);
- }, function($ctx1) {$ctx1.fill(self,"-",{anArray:anArray},$globals.Trait)});
- },
- args: ["anArray"],
- source: "- anArray\x0a\x09^ self asTraitTransformation - anArray",
- referencedClasses: [],
- messageSends: ["-", "asTraitTransformation"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "@",
- protocol: "composition",
- fn: function (anArrayOfAssociations){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asTraitTransformation()).__at(anArrayOfAssociations);
- }, function($ctx1) {$ctx1.fill(self,"@",{anArrayOfAssociations:anArrayOfAssociations},$globals.Trait)});
- },
- args: ["anArrayOfAssociations"],
- source: "@ anArrayOfAssociations\x0a\x09^ self asTraitTransformation @ anArrayOfAssociations",
- referencedClasses: [],
- messageSends: ["@", "asTraitTransformation"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "$globals.".__comma(self._name());
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.Trait)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09^ '$globals.', self name",
- referencedClasses: [],
- messageSends: [",", "name"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "asTraitComposition",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asTraitTransformation())._asTraitComposition();
- }, function($ctx1) {$ctx1.fill(self,"asTraitComposition",{},$globals.Trait)});
- },
- args: [],
- source: "asTraitComposition\x0a\x09^ self asTraitTransformation asTraitComposition",
- referencedClasses: [],
- messageSends: ["asTraitComposition", "asTraitTransformation"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "asTraitTransformation",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.TraitTransformation)._on_(self);
- }, function($ctx1) {$ctx1.fill(self,"asTraitTransformation",{},$globals.Trait)});
- },
- args: [],
- source: "asTraitTransformation\x0a\x09^ TraitTransformation on: self",
- referencedClasses: ["TraitTransformation"],
- messageSends: ["on:"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "category",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._package();
- $ctx1.sendIdx["package"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return "Unclassified";
- } else {
- return $recv(self._package())._name();
- }
- }, function($ctx1) {$ctx1.fill(self,"category",{},$globals.Trait)});
- },
- args: [],
- source: "category\x0a\x09^ self package ifNil: [ 'Unclassified' ] ifNotNil: [ self package name ]",
- referencedClasses: [],
- messageSends: ["ifNil:ifNotNil:", "package", "name"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "trait";
- },
- args: [],
- source: "classTag\x0a\x09^ 'trait'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $recv(stream)._write_("Trait named: ");
- $ctx2.sendIdx["write:"]=1;
- $recv(stream)._printSymbol_(self._name());
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=1;
- $recv(stream)._write_($recv(self._traitCompositionDefinition())._ifNotEmpty_((function(tcd){
- return $core.withContext(function($ctx3) {
- $1=$recv($globals.String)._tab();
- $ctx3.sendIdx["tab"]=1;
- return [$1,"uses: ",tcd,$recv($globals.String)._lf()];
- }, function($ctx3) {$ctx3.fillBlock({tcd:tcd},$ctx2,2)});
- })));
- $ctx2.sendIdx["write:"]=2;
- $recv(stream)._tab();
- $recv(stream)._write_("package: ");
- return $recv(stream)._print_(self._category());
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"definition",{},$globals.Trait)});
- },
- args: [],
- source: "definition\x0a\x09^ String streamContents: [ :stream | stream\x0a\x09\x09write: 'Trait named: '; printSymbol: self name; lf;\x0a\x09\x09write: (self traitCompositionDefinition ifNotEmpty: [ :tcd | { String tab. 'uses: '. tcd. String lf }]);\x0a\x09\x09tab; write: 'package: '; print: self category ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "write:", "printSymbol:", "name", "lf", "ifNotEmpty:", "traitCompositionDefinition", "tab", "print:", "category"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "package",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("pkg");
- }, function($ctx1) {$ctx1.fill(self,"package",{},$globals.Trait)});
- },
- args: [],
- source: "package\x0a\x09^ self basicAt: 'pkg'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "package:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- var oldPackage;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$4,$6,$5;
- $2=self._package();
- $ctx1.sendIdx["package"]=1;
- $1=$recv($2).__eq(aPackage);
- if($core.assert($1)){
- return self;
- }
- oldPackage=self._package();
- self._basicAt_put_("pkg",aPackage);
- $3=$recv(oldPackage)._organization();
- $ctx1.sendIdx["organization"]=1;
- $recv($3)._removeElement_(self);
- $recv($recv(aPackage)._organization())._addElement_(self);
- $4=$recv($globals.SystemAnnouncer)._current();
- $6=$recv($globals.ClassMoved)._new();
- $recv($6)._theClass_(self);
- $recv($6)._oldPackage_(oldPackage);
- $5=$recv($6)._yourself();
- $recv($4)._announce_($5);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"package:",{aPackage:aPackage,oldPackage:oldPackage},$globals.Trait)});
- },
- args: ["aPackage"],
- source: "package: aPackage\x0a\x09| oldPackage |\x0a\x09\x0a\x09self package = aPackage ifTrue: [ ^ self ].\x0a\x09\x0a\x09oldPackage := self package.\x0a\x09\x0a\x09self basicAt: 'pkg' put: aPackage.\x0a\x09oldPackage organization removeElement: self.\x0a\x09aPackage organization addElement: self.\x0a\x0a\x09SystemAnnouncer current announce: (ClassMoved new\x0a\x09\x09theClass: self;\x0a\x09\x09oldPackage: oldPackage;\x0a\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ClassMoved"],
- messageSends: ["ifTrue:", "=", "package", "basicAt:put:", "removeElement:", "organization", "addElement:", "announce:", "current", "theClass:", "new", "oldPackage:", "yourself"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "theMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return nil;
- },
- args: [],
- source: "theMetaClass\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "theNonMetaClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "theNonMetaClass\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "traitUsers",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._basicAt_("traitUsers"))._copy();
- }, function($ctx1) {$ctx1.fill(self,"traitUsers",{},$globals.Trait)});
- },
- args: [],
- source: "traitUsers\x0a\x09^ (self basicAt: 'traitUsers') copy",
- referencedClasses: [],
- messageSends: ["copy", "basicAt:"]
- }),
- $globals.Trait);
- $core.addMethod(
- $core.method({
- selector: "named:package:",
- protocol: "instance creation",
- fn: function (aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.ClassBuilder)._new())._addTraitNamed_package_(aString,anotherString);
- }, function($ctx1) {$ctx1.fill(self,"named:package:",{aString:aString,anotherString:anotherString},$globals.Trait.klass)});
- },
- args: ["aString", "anotherString"],
- source: "named: aString package: anotherString\x0a\x09^ ClassBuilder new addTraitNamed: aString package: anotherString",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["addTraitNamed:package:", "new"]
- }),
- $globals.Trait.klass);
- $core.addMethod(
- $core.method({
- selector: "named:uses:package:",
- protocol: "instance creation",
- fn: function (aString,aTraitCompositionDescription,anotherString){
- var self=this;
- var trait;
- return $core.withContext(function($ctx1) {
- trait=self._named_package_(aString,anotherString);
- $recv(trait)._setTraitComposition_($recv(aTraitCompositionDescription)._asTraitComposition());
- return trait;
- }, function($ctx1) {$ctx1.fill(self,"named:uses:package:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,anotherString:anotherString,trait:trait},$globals.Trait.klass)});
- },
- args: ["aString", "aTraitCompositionDescription", "anotherString"],
- source: "named: aString uses: aTraitCompositionDescription package: anotherString\x0a\x09| trait |\x0a\x09trait := self named: aString package: anotherString.\x0a\x09trait setTraitComposition: aTraitCompositionDescription asTraitComposition.\x0a\x09^ trait",
- referencedClasses: [],
- messageSends: ["named:package:", "setTraitComposition:", "asTraitComposition"]
- }),
- $globals.Trait.klass);
- $core.addClass("ClassBuilder", $globals.Object, [], "Kernel-Classes");
- $globals.ClassBuilder.comment="I am responsible for compiling new classes or modifying existing classes in the system.\x0a\x0aRather than using me directly to compile a class, use `Class >> subclass:instanceVariableNames:package:`.";
- $core.addMethod(
- $core.method({
- selector: "addSubclassOf:named:instanceVariableNames:package:",
- protocol: "class definition",
- fn: function (aClass,className,aCollection,packageName){
- var self=this;
- var theClass,thePackage;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- theClass=$recv($recv($globals.Smalltalk)._globals())._at_(className);
- thePackage=$recv($globals.Package)._named_(packageName);
- $1=theClass;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $recv(theClass)._package_(thePackage);
- $2=$recv($recv(theClass)._superclass()).__eq_eq(aClass);
- if(!$core.assert($2)){
- return self._migrateClassNamed_superclass_instanceVariableNames_package_(className,aClass,aCollection,packageName);
- }
- }
- $3=self._basicAddSubclassOf_named_instanceVariableNames_package_(aClass,className,aCollection,packageName);
- $recv($3)._recompile();
- return $recv($3)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"addSubclassOf:named:instanceVariableNames:package:",{aClass:aClass,className:className,aCollection:aCollection,packageName:packageName,theClass:theClass,thePackage:thePackage},$globals.ClassBuilder)});
- },
- args: ["aClass", "className", "aCollection", "packageName"],
- source: "addSubclassOf: aClass named: className instanceVariableNames: aCollection package: packageName\x0a\x09| theClass thePackage |\x0a\x09\x0a\x09theClass := Smalltalk globals at: className.\x0a\x09thePackage := Package named: packageName.\x0a\x09\x0a\x09theClass ifNotNil: [\x0a\x09\x09theClass package: thePackage.\x0a\x09\x09theClass superclass == aClass\x0a\x09\x09\x09ifFalse: [ ^ self\x0a\x09\x09\x09\x09migrateClassNamed: className\x0a\x09\x09\x09\x09superclass: aClass\x0a\x09\x09\x09\x09instanceVariableNames: aCollection\x0a\x09\x09\x09\x09package: packageName ] ].\x0a\x09\x09\x0a\x09^ (self\x0a\x09\x09basicAddSubclassOf: aClass\x0a\x09\x09named: className\x0a\x09\x09instanceVariableNames: aCollection\x0a\x09\x09package: packageName) recompile; yourself",
- referencedClasses: ["Smalltalk", "Package"],
- messageSends: ["at:", "globals", "named:", "ifNotNil:", "package:", "ifFalse:", "==", "superclass", "migrateClassNamed:superclass:instanceVariableNames:package:", "recompile", "basicAddSubclassOf:named:instanceVariableNames:package:", "yourself"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "addTraitNamed:package:",
- protocol: "class definition",
- fn: function (traitName,packageName){
- var self=this;
- var theTrait,thePackage;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- theTrait=$recv($recv($globals.Smalltalk)._globals())._at_(traitName);
- thePackage=$recv($globals.Package)._named_(packageName);
- $1=theTrait;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $2=theTrait;
- $recv($2)._package_(thePackage);
- $recv($2)._recompile();
- return $recv($2)._yourself();
- }
- return self._basicAddTraitNamed_package_(traitName,packageName);
- }, function($ctx1) {$ctx1.fill(self,"addTraitNamed:package:",{traitName:traitName,packageName:packageName,theTrait:theTrait,thePackage:thePackage},$globals.ClassBuilder)});
- },
- args: ["traitName", "packageName"],
- source: "addTraitNamed: traitName package: packageName\x0a\x09| theTrait thePackage |\x0a\x09\x0a\x09theTrait := Smalltalk globals at: traitName.\x0a\x09thePackage := Package named: packageName.\x0a\x09\x0a\x09theTrait ifNotNil: [ ^ theTrait package: thePackage; recompile; yourself ].\x0a\x09\x09\x0a\x09^ self\x0a\x09\x09basicAddTraitNamed: traitName\x0a\x09\x09package: packageName",
- referencedClasses: ["Smalltalk", "Package"],
- messageSends: ["at:", "globals", "named:", "ifNotNil:", "package:", "recompile", "yourself", "basicAddTraitNamed:package:"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "basicAddSubclassOf:named:instanceVariableNames:package:",
- protocol: "private",
- fn: function (aClass,aString,aCollection,packageName){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.addClass(aString, aClass, aCollection, packageName);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicAddSubclassOf:named:instanceVariableNames:package:",{aClass:aClass,aString:aString,aCollection:aCollection,packageName:packageName},$globals.ClassBuilder)});
- },
- args: ["aClass", "aString", "aCollection", "packageName"],
- source: "basicAddSubclassOf: aClass named: aString instanceVariableNames: aCollection package: packageName\x0a\x09<inlineJS: '\x0a\x09\x09return $core.addClass(aString, aClass, aCollection, packageName);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "basicAddTraitNamed:package:",
- protocol: "private",
- fn: function (aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.addTrait(aString, anotherString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicAddTraitNamed:package:",{aString:aString,anotherString:anotherString},$globals.ClassBuilder)});
- },
- args: ["aString", "anotherString"],
- source: "basicAddTraitNamed: aString package: anotherString\x0a\x09<inlineJS: 'return $core.addTrait(aString, anotherString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "basicClass:instanceVariableNames:",
- protocol: "private",
- fn: function (aClass,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._basicClass_instanceVariables_(aClass,self._instanceVariableNamesFor_(aString));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicClass:instanceVariableNames:",{aClass:aClass,aString:aString},$globals.ClassBuilder)});
- },
- args: ["aClass", "aString"],
- source: "basicClass: aClass instanceVariableNames: aString\x0a\x09self basicClass: aClass instanceVariables: (self instanceVariableNamesFor: aString)",
- referencedClasses: [],
- messageSends: ["basicClass:instanceVariables:", "instanceVariableNamesFor:"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "basicClass:instanceVariables:",
- protocol: "private",
- fn: function (aClass,aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(aClass)._isMetaclass();
- if(!$core.assert($1)){
- self._error_($recv($recv(aClass)._name()).__comma(" is not a metaclass"));
- }
- $recv(aClass)._basicAt_put_("iVarNames",aCollection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicClass:instanceVariables:",{aClass:aClass,aCollection:aCollection},$globals.ClassBuilder)});
- },
- args: ["aClass", "aCollection"],
- source: "basicClass: aClass instanceVariables: aCollection\x0a\x0a\x09aClass isMetaclass ifFalse: [ self error: aClass name, ' is not a metaclass' ].\x0a\x09aClass basicAt: 'iVarNames' put: aCollection",
- referencedClasses: [],
- messageSends: ["ifFalse:", "isMetaclass", "error:", ",", "name", "basicAt:put:"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "basicRemoveClass:",
- protocol: "private",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.removeClass(aClass);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicRemoveClass:",{aClass:aClass},$globals.ClassBuilder)});
- },
- args: ["aClass"],
- source: "basicRemoveClass: aClass\x0a\x09<inlineJS: '$core.removeClass(aClass)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "basicRenameClass:to:",
- protocol: "private",
- fn: function (aClass,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $globals[aString] = aClass;
- delete $globals[aClass.className];
- aClass.className = aString;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicRenameClass:to:",{aClass:aClass,aString:aString},$globals.ClassBuilder)});
- },
- args: ["aClass", "aString"],
- source: "basicRenameClass: aClass to: aString\x0a\x09<inlineJS: '\x0a\x09\x09$globals[aString] = aClass;\x0a\x09\x09delete $globals[aClass.className];\x0a\x09\x09aClass.className = aString;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "basicSwapClassNames:with:",
- protocol: "private",
- fn: function (aClass,anotherClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var tmp = aClass.className;
- aClass.className = anotherClass.className;
- anotherClass.className = tmp;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicSwapClassNames:with:",{aClass:aClass,anotherClass:anotherClass},$globals.ClassBuilder)});
- },
- args: ["aClass", "anotherClass"],
- source: "basicSwapClassNames: aClass with: anotherClass\x0a\x09<inlineJS: '\x0a\x09\x09var tmp = aClass.className;\x0a\x09\x09aClass.className = anotherClass.className;\x0a\x09\x09anotherClass.className = tmp;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "class:instanceVariableNames:",
- protocol: "class definition",
- fn: function (aClass,ivarNames){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- self._basicClass_instanceVariableNames_(aClass,ivarNames);
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.ClassDefinitionChanged)._new();
- $recv($3)._theClass_(aClass);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"class:instanceVariableNames:",{aClass:aClass,ivarNames:ivarNames},$globals.ClassBuilder)});
- },
- args: ["aClass", "ivarNames"],
- source: "class: aClass instanceVariableNames: ivarNames\x0a\x09self basicClass: aClass instanceVariableNames: ivarNames.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassDefinitionChanged new\x0a\x09\x09\x09theClass: aClass;\x0a\x09\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ClassDefinitionChanged"],
- messageSends: ["basicClass:instanceVariableNames:", "announce:", "current", "theClass:", "new", "yourself"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "copyClass:named:",
- protocol: "copying",
- fn: function (aClass,className){
- var self=this;
- var newClass;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- newClass=self._addSubclassOf_named_instanceVariableNames_package_($recv(aClass)._superclass(),className,$recv(aClass)._instanceVariableNames(),$recv($recv(aClass)._package())._name());
- self._copyClass_to_(aClass,newClass);
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.ClassAdded)._new();
- $recv($3)._theClass_(newClass);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return newClass;
- }, function($ctx1) {$ctx1.fill(self,"copyClass:named:",{aClass:aClass,className:className,newClass:newClass},$globals.ClassBuilder)});
- },
- args: ["aClass", "className"],
- source: "copyClass: aClass named: className\x0a\x09| newClass |\x0a\x0a\x09newClass := self\x0a\x09\x09addSubclassOf: aClass superclass\x0a\x09\x09named: className\x0a\x09\x09instanceVariableNames: aClass instanceVariableNames\x0a\x09\x09package: aClass package name.\x0a\x0a\x09self copyClass: aClass to: newClass.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassAdded new\x0a\x09\x09\x09theClass: newClass;\x0a\x09\x09\x09yourself).\x0a\x09\x0a\x09^ newClass",
- referencedClasses: ["SystemAnnouncer", "ClassAdded"],
- messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "superclass", "instanceVariableNames", "name", "package", "copyClass:to:", "announce:", "current", "theClass:", "new", "yourself"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "copyClass:to:",
- protocol: "copying",
- fn: function (aClass,anotherClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$5,$6,$7,$8,$10,$9,$12,$11,$14,$15,$13,$16,$17,$18,$19;
- $recv(anotherClass)._comment_($recv(aClass)._comment());
- $1=$recv(aClass)._methodDictionary();
- $ctx1.sendIdx["methodDictionary"]=1;
- $recv($1)._valuesDo_((function(each){
- return $core.withContext(function($ctx2) {
- $3=$recv(each)._methodClass();
- $ctx2.sendIdx["methodClass"]=1;
- $2=$recv($3).__eq(aClass);
- $ctx2.sendIdx["="]=1;
- if($core.assert($2)){
- $4=$recv($globals.Compiler)._new();
- $ctx2.sendIdx["new"]=1;
- $5=$recv(each)._source();
- $ctx2.sendIdx["source"]=1;
- $6=$recv(each)._protocol();
- $ctx2.sendIdx["protocol"]=1;
- return $recv($4)._install_forClass_protocol_($5,anotherClass,$6);
- $ctx2.sendIdx["install:forClass:protocol:"]=1;
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["valuesDo:"]=1;
- $7=$recv(aClass)._traitComposition();
- $ctx1.sendIdx["traitComposition"]=1;
- $recv(anotherClass)._setTraitComposition_($7);
- $ctx1.sendIdx["setTraitComposition:"]=1;
- $8=$recv(anotherClass)._class();
- $ctx1.sendIdx["class"]=1;
- $10=$recv(aClass)._class();
- $ctx1.sendIdx["class"]=2;
- $9=$recv($10)._instanceVariableNames();
- self._basicClass_instanceVariables_($8,$9);
- $12=$recv(aClass)._class();
- $ctx1.sendIdx["class"]=3;
- $11=$recv($12)._methodDictionary();
- $recv($11)._valuesDo_((function(each){
- return $core.withContext(function($ctx2) {
- $14=$recv(each)._methodClass();
- $15=$recv(aClass)._class();
- $ctx2.sendIdx["class"]=4;
- $13=$recv($14).__eq($15);
- if($core.assert($13)){
- $16=$recv($globals.Compiler)._new();
- $17=$recv(each)._source();
- $18=$recv(anotherClass)._class();
- $ctx2.sendIdx["class"]=5;
- return $recv($16)._install_forClass_protocol_($17,$18,$recv(each)._protocol());
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- $19=$recv(anotherClass)._class();
- $ctx1.sendIdx["class"]=6;
- $recv($19)._setTraitComposition_($recv($recv(aClass)._class())._traitComposition());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"copyClass:to:",{aClass:aClass,anotherClass:anotherClass},$globals.ClassBuilder)});
- },
- args: ["aClass", "anotherClass"],
- source: "copyClass: aClass to: anotherClass\x0a\x0a\x09anotherClass comment: aClass comment.\x0a\x0a\x09aClass methodDictionary valuesDo: [ :each |\x0a\x09\x09each methodClass = aClass ifTrue: [\x0a\x09\x09\x09Compiler new install: each source forClass: anotherClass protocol: each protocol ] ].\x0a\x09anotherClass setTraitComposition: aClass traitComposition.\x0a\x0a\x09self basicClass: anotherClass class instanceVariables: aClass class instanceVariableNames.\x0a\x0a\x09aClass class methodDictionary valuesDo: [ :each |\x0a\x09\x09each methodClass = aClass class ifTrue: [\x0a\x09\x09\x09Compiler new install: each source forClass: anotherClass class protocol: each protocol ] ].\x0a\x09anotherClass class setTraitComposition: aClass class traitComposition",
- referencedClasses: ["Compiler"],
- messageSends: ["comment:", "comment", "valuesDo:", "methodDictionary", "ifTrue:", "=", "methodClass", "install:forClass:protocol:", "new", "source", "protocol", "setTraitComposition:", "traitComposition", "basicClass:instanceVariables:", "class", "instanceVariableNames"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "installMethod:forClass:protocol:",
- protocol: "method definition",
- fn: function (aCompiledMethod,aBehavior,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aCompiledMethod)._protocol_(aString);
- $recv(aBehavior)._addCompiledMethod_(aCompiledMethod);
- return aCompiledMethod;
- }, function($ctx1) {$ctx1.fill(self,"installMethod:forClass:protocol:",{aCompiledMethod:aCompiledMethod,aBehavior:aBehavior,aString:aString},$globals.ClassBuilder)});
- },
- args: ["aCompiledMethod", "aBehavior", "aString"],
- source: "installMethod: aCompiledMethod forClass: aBehavior protocol: aString\x0a\x09aCompiledMethod protocol: aString.\x0a\x09aBehavior addCompiledMethod: aCompiledMethod.\x0a\x09^ aCompiledMethod",
- referencedClasses: [],
- messageSends: ["protocol:", "addCompiledMethod:"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "instanceVariableNamesFor:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(aString)._tokenize_(" "))._reject_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._isEmpty();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"instanceVariableNamesFor:",{aString:aString},$globals.ClassBuilder)});
- },
- args: ["aString"],
- source: "instanceVariableNamesFor: aString\x0a\x09^ (aString tokenize: ' ') reject: [ :each | each isEmpty ]",
- referencedClasses: [],
- messageSends: ["reject:", "tokenize:", "isEmpty"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "migrateClass:superclass:",
- protocol: "class migration",
- fn: function (aClass,anotherClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(aClass)._name();
- $ctx1.sendIdx["name"]=1;
- return self._migrateClassNamed_superclass_instanceVariableNames_package_($1,anotherClass,$recv(aClass)._instanceVariableNames(),$recv($recv(aClass)._package())._name());
- }, function($ctx1) {$ctx1.fill(self,"migrateClass:superclass:",{aClass:aClass,anotherClass:anotherClass},$globals.ClassBuilder)});
- },
- args: ["aClass", "anotherClass"],
- source: "migrateClass: aClass superclass: anotherClass\x0a\x09^ self\x0a\x09\x09migrateClassNamed: aClass name\x0a\x09\x09superclass: anotherClass\x0a\x09\x09instanceVariableNames: aClass instanceVariableNames\x0a\x09\x09package: aClass package name",
- referencedClasses: [],
- messageSends: ["migrateClassNamed:superclass:instanceVariableNames:package:", "name", "instanceVariableNames", "package"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "migrateClassNamed:superclass:instanceVariableNames:package:",
- protocol: "class migration",
- fn: function (className,aClass,aCollection,packageName){
- var self=this;
- var oldClass,newClass,tmp;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3;
- tmp="new*".__comma(className);
- oldClass=$recv($recv($globals.Smalltalk)._globals())._at_(className);
- newClass=self._addSubclassOf_named_instanceVariableNames_package_(aClass,tmp,aCollection,packageName);
- self._basicSwapClassNames_with_(oldClass,newClass);
- $ctx1.sendIdx["basicSwapClassNames:with:"]=1;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._copyClass_to_(oldClass,newClass);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(exception){
- return $core.withContext(function($ctx2) {
- self._basicSwapClassNames_with_(oldClass,newClass);
- $1=self._basicRemoveClass_(newClass);
- $ctx2.sendIdx["basicRemoveClass:"]=1;
- $1;
- return $recv(exception)._resignal();
- }, function($ctx2) {$ctx2.fillBlock({exception:exception},$ctx1,2)});
- }));
- self._rawRenameClass_to_(oldClass,tmp);
- $ctx1.sendIdx["rawRenameClass:to:"]=1;
- self._rawRenameClass_to_(newClass,className);
- $recv($recv(oldClass)._subclasses())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._migrateClass_superclass_(each,newClass);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- self._basicRemoveClass_(oldClass);
- $2=$recv($globals.SystemAnnouncer)._current();
- $4=$recv($globals.ClassMigrated)._new();
- $recv($4)._theClass_(newClass);
- $recv($4)._oldClass_(oldClass);
- $3=$recv($4)._yourself();
- $recv($2)._announce_($3);
- return newClass;
- }, function($ctx1) {$ctx1.fill(self,"migrateClassNamed:superclass:instanceVariableNames:package:",{className:className,aClass:aClass,aCollection:aCollection,packageName:packageName,oldClass:oldClass,newClass:newClass,tmp:tmp},$globals.ClassBuilder)});
- },
- args: ["className", "aClass", "aCollection", "packageName"],
- source: "migrateClassNamed: className superclass: aClass instanceVariableNames: aCollection package: packageName\x0a\x09| oldClass newClass tmp |\x0a\x09\x0a\x09tmp := 'new*', className.\x0a\x09oldClass := Smalltalk globals at: className.\x0a\x09\x0a\x09newClass := self\x0a\x09\x09addSubclassOf: aClass\x0a\x09\x09named: tmp\x0a\x09\x09instanceVariableNames: aCollection\x0a\x09\x09package: packageName.\x0a\x0a\x09self basicSwapClassNames: oldClass with: newClass.\x0a\x0a\x09[ self copyClass: oldClass to: newClass ]\x0a\x09\x09on: Error\x0a\x09\x09do: [ :exception |\x0a\x09\x09\x09self\x0a\x09\x09\x09\x09basicSwapClassNames: oldClass with: newClass;\x0a\x09\x09\x09\x09basicRemoveClass: newClass.\x0a\x09\x09\x09\x09exception resignal ].\x0a\x0a\x09self\x0a\x09\x09rawRenameClass: oldClass to: tmp;\x0a\x09\x09rawRenameClass: newClass to: className.\x0a\x0a\x09oldClass subclasses \x0a\x09\x09do: [ :each | self migrateClass: each superclass: newClass ].\x0a\x0a\x09self basicRemoveClass: oldClass.\x0a\x09\x0a\x09SystemAnnouncer current announce: (ClassMigrated new\x0a\x09\x09theClass: newClass;\x0a\x09\x09oldClass: oldClass;\x0a\x09\x09yourself).\x0a\x09\x0a\x09^ newClass",
- referencedClasses: ["Smalltalk", "Error", "SystemAnnouncer", "ClassMigrated"],
- messageSends: [",", "at:", "globals", "addSubclassOf:named:instanceVariableNames:package:", "basicSwapClassNames:with:", "on:do:", "copyClass:to:", "basicRemoveClass:", "resignal", "rawRenameClass:to:", "do:", "subclasses", "migrateClass:superclass:", "announce:", "current", "theClass:", "new", "oldClass:", "yourself"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "rawRenameClass:to:",
- protocol: "private",
- fn: function (aClass,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $globals[aString] = aClass;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"rawRenameClass:to:",{aClass:aClass,aString:aString},$globals.ClassBuilder)});
- },
- args: ["aClass", "aString"],
- source: "rawRenameClass: aClass to: aString\x0a\x09<inlineJS: '\x0a\x09\x09$globals[aString] = aClass;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "renameClass:to:",
- protocol: "class migration",
- fn: function (aClass,className){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- self._basicRenameClass_to_(aClass,className);
- $recv(aClass)._recompile();
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.ClassRenamed)._new();
- $recv($3)._theClass_(aClass);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"renameClass:to:",{aClass:aClass,className:className},$globals.ClassBuilder)});
- },
- args: ["aClass", "className"],
- source: "renameClass: aClass to: className\x0a\x09self basicRenameClass: aClass to: className.\x0a\x09\x0a\x09\x22Recompile the class to fix potential issues with super sends\x22\x0a\x09aClass recompile.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassRenamed new\x0a\x09\x09\x09theClass: aClass;\x0a\x09\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ClassRenamed"],
- messageSends: ["basicRenameClass:to:", "recompile", "announce:", "current", "theClass:", "new", "yourself"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "setupClass:",
- protocol: "public",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._deprecatedAPI_("Classes are now auto-inited.");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setupClass:",{aClass:aClass},$globals.ClassBuilder)});
- },
- args: ["aClass"],
- source: "setupClass: aClass\x0a\x09self deprecatedAPI: 'Classes are now auto-inited.'",
- referencedClasses: [],
- messageSends: ["deprecatedAPI:"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "superclass:subclass:",
- protocol: "class definition",
- fn: function (aClass,className){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._superclass_subclass_instanceVariableNames_package_(aClass,className,"",nil);
- }, function($ctx1) {$ctx1.fill(self,"superclass:subclass:",{aClass:aClass,className:className},$globals.ClassBuilder)});
- },
- args: ["aClass", "className"],
- source: "superclass: aClass subclass: className\x0a\x09^ self superclass: aClass subclass: className instanceVariableNames: '' package: nil",
- referencedClasses: [],
- messageSends: ["superclass:subclass:instanceVariableNames:package:"]
- }),
- $globals.ClassBuilder);
- $core.addMethod(
- $core.method({
- selector: "superclass:subclass:instanceVariableNames:package:",
- protocol: "class definition",
- fn: function (aClass,className,ivarNames,packageName){
- var self=this;
- var newClass;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4,$receiver;
- $1=self._instanceVariableNamesFor_(ivarNames);
- if(($receiver = packageName) == null || $receiver.isNil){
- $2="unclassified";
- } else {
- $2=packageName;
- }
- newClass=self._addSubclassOf_named_instanceVariableNames_package_(aClass,className,$1,$2);
- $3=$recv($globals.SystemAnnouncer)._current();
- $5=$recv($globals.ClassAdded)._new();
- $recv($5)._theClass_(newClass);
- $4=$recv($5)._yourself();
- $recv($3)._announce_($4);
- return newClass;
- }, function($ctx1) {$ctx1.fill(self,"superclass:subclass:instanceVariableNames:package:",{aClass:aClass,className:className,ivarNames:ivarNames,packageName:packageName,newClass:newClass},$globals.ClassBuilder)});
- },
- args: ["aClass", "className", "ivarNames", "packageName"],
- source: "superclass: aClass subclass: className instanceVariableNames: ivarNames package: packageName\x0a\x09| newClass |\x0a\x09\x0a\x09newClass := self addSubclassOf: aClass\x0a\x09\x09named: className instanceVariableNames: (self instanceVariableNamesFor: ivarNames)\x0a\x09\x09package: (packageName ifNil: [ 'unclassified' ]).\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassAdded new\x0a\x09\x09\x09theClass: newClass;\x0a\x09\x09\x09yourself).\x0a\x09\x0a\x09^ newClass",
- referencedClasses: ["SystemAnnouncer", "ClassAdded"],
- messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "instanceVariableNamesFor:", "ifNil:", "announce:", "current", "theClass:", "new", "yourself"]
- }),
- $globals.ClassBuilder);
- $core.addClass("ClassSorterNode", $globals.Object, ["theClass", "level", "nodes"], "Kernel-Classes");
- $globals.ClassSorterNode.comment="I provide an algorithm for sorting classes alphabetically.\x0a\x0aSee [Issue #143](https://lolg.it/amber/amber/issues/143).";
- $core.addMethod(
- $core.method({
- selector: "getNodesFrom:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- var children,others;
- return $core.withContext(function($ctx1) {
- var $1;
- children=[];
- others=[];
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv($recv(each)._superclass()).__eq(self._theClass());
- if($core.assert($1)){
- return $recv(children)._add_(each);
- $ctx2.sendIdx["add:"]=1;
- } else {
- return $recv(others)._add_(each);
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self["@nodes"]=$recv(children)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($globals.ClassSorterNode)._on_classes_level_(each,others,$recv(self._level()).__plus((1)));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,4)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"getNodesFrom:",{aCollection:aCollection,children:children,others:others},$globals.ClassSorterNode)});
- },
- args: ["aCollection"],
- source: "getNodesFrom: aCollection\x0a\x09| children others |\x0a\x09children := #().\x0a\x09others := #().\x0a\x09aCollection do: [ :each |\x0a\x09\x09(each superclass = self theClass)\x0a\x09\x09\x09ifTrue: [ children add: each ]\x0a\x09\x09\x09ifFalse: [ others add: each ]].\x0a\x09nodes:= children collect: [ :each |\x0a\x09\x09ClassSorterNode on: each classes: others level: self level + 1 ]",
- referencedClasses: ["ClassSorterNode"],
- messageSends: ["do:", "ifTrue:ifFalse:", "=", "superclass", "theClass", "add:", "collect:", "on:classes:level:", "+", "level"]
- }),
- $globals.ClassSorterNode);
- $core.addMethod(
- $core.method({
- selector: "level",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@level"];
- },
- args: [],
- source: "level\x0a\x09^ level",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassSorterNode);
- $core.addMethod(
- $core.method({
- selector: "level:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@level"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "level: anInteger\x0a\x09level := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassSorterNode);
- $core.addMethod(
- $core.method({
- selector: "nodes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@nodes"];
- },
- args: [],
- source: "nodes\x0a\x09^ nodes",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassSorterNode);
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@theClass"];
- },
- args: [],
- source: "theClass\x0a\x09^ theClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassSorterNode);
- $core.addMethod(
- $core.method({
- selector: "theClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@theClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "theClass: aClass\x0a\x09theClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassSorterNode);
- $core.addMethod(
- $core.method({
- selector: "traverseClassesWith:",
- protocol: "visiting",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- $1=self._theClass();
- $ctx1.sendIdx["theClass"]=1;
- $recv(aCollection)._add_($1);
- $recv($recv(self._nodes())._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $3=$recv(a)._theClass();
- $ctx2.sendIdx["theClass"]=2;
- $2=$recv($3)._name();
- $ctx2.sendIdx["name"]=1;
- return $recv($2).__lt_eq($recv($recv(b)._theClass())._name());
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,1)});
- })))._do_((function(aNode){
- return $core.withContext(function($ctx2) {
- return $recv(aNode)._traverseClassesWith_(aCollection);
- }, function($ctx2) {$ctx2.fillBlock({aNode:aNode},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"traverseClassesWith:",{aCollection:aCollection},$globals.ClassSorterNode)});
- },
- args: ["aCollection"],
- source: "traverseClassesWith: aCollection\x0a\x09\x22sort classes alphabetically Issue #143\x22\x0a\x0a\x09aCollection add: self theClass.\x0a\x09(self nodes sorted: [ :a :b | a theClass name <= b theClass name ]) do: [ :aNode |\x0a\x09\x09aNode traverseClassesWith: aCollection ].",
- referencedClasses: [],
- messageSends: ["add:", "theClass", "do:", "sorted:", "nodes", "<=", "name", "traverseClassesWith:"]
- }),
- $globals.ClassSorterNode);
- $core.addMethod(
- $core.method({
- selector: "on:classes:level:",
- protocol: "instance creation",
- fn: function (aClass,aCollection,anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._theClass_(aClass);
- $recv($1)._level_(anInteger);
- $recv($1)._getNodesFrom_(aCollection);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:classes:level:",{aClass:aClass,aCollection:aCollection,anInteger:anInteger},$globals.ClassSorterNode.klass)});
- },
- args: ["aClass", "aCollection", "anInteger"],
- source: "on: aClass classes: aCollection level: anInteger\x0a\x09^ self new\x0a\x09\x09theClass: aClass;\x0a\x09\x09level: anInteger;\x0a\x09\x09getNodesFrom: aCollection;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["theClass:", "new", "level:", "getNodesFrom:", "yourself"]
- }),
- $globals.ClassSorterNode.klass);
- $core.addClass("TraitTransformation", $globals.Object, ["trait", "aliases", "exclusions"], "Kernel-Classes");
- $globals.TraitTransformation.comment="I am a single step in trait composition.\x0a\x0aI represent one trait including its aliases and exclusions.";
- $core.addMethod(
- $core.method({
- selector: "-",
- protocol: "composition",
- fn: function (anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._copy();
- $recv($1)._addExclusions_(anArray);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"-",{anArray:anArray},$globals.TraitTransformation)});
- },
- args: ["anArray"],
- source: "- anArray\x0a\x09^ self copy addExclusions: anArray; yourself",
- referencedClasses: [],
- messageSends: ["addExclusions:", "copy", "yourself"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "@",
- protocol: "composition",
- fn: function (anArrayOfAssociations){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._copy();
- $recv($1)._addAliases_(anArrayOfAssociations);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"@",{anArrayOfAssociations:anArrayOfAssociations},$globals.TraitTransformation)});
- },
- args: ["anArrayOfAssociations"],
- source: "@ anArrayOfAssociations\x0a\x09^ self copy addAliases: anArrayOfAssociations; yourself",
- referencedClasses: [],
- messageSends: ["addAliases:", "copy", "yourself"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "addAliases:",
- protocol: "accessing",
- fn: function (anArrayOfAssociations){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anArrayOfAssociations)._do_((function(each){
- var key;
- return $core.withContext(function($ctx2) {
- key=$recv(each)._key();
- key;
- return $recv(self["@aliases"])._at_ifPresent_ifAbsent_(key,(function(){
- return $core.withContext(function($ctx3) {
- return self._error_("Cannot use same alias name twice.");
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }),(function(){
- return $core.withContext(function($ctx3) {
- return $recv(self["@aliases"])._at_put_(key,$recv(each)._value());
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({each:each,key:key},$ctx1,1)});
- }));
- return anArrayOfAssociations;
- }, function($ctx1) {$ctx1.fill(self,"addAliases:",{anArrayOfAssociations:anArrayOfAssociations},$globals.TraitTransformation)});
- },
- args: ["anArrayOfAssociations"],
- source: "addAliases: anArrayOfAssociations\x0a\x09anArrayOfAssociations do: [ :each |\x0a\x09\x09| key |\x0a\x09\x09key := each key.\x0a\x09\x09aliases at: key\x0a\x09\x09\x09ifPresent: [ self error: 'Cannot use same alias name twice.' ]\x0a\x09\x09\x09ifAbsent: [ aliases at: key put: each value ] ].\x0a\x09^ anArrayOfAssociations",
- referencedClasses: [],
- messageSends: ["do:", "key", "at:ifPresent:ifAbsent:", "error:", "at:put:", "value"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "addExclusions:",
- protocol: "accessing",
- fn: function (anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@exclusions"])._addAll_(anArray);
- return anArray;
- }, function($ctx1) {$ctx1.fill(self,"addExclusions:",{anArray:anArray},$globals.TraitTransformation)});
- },
- args: ["anArray"],
- source: "addExclusions: anArray\x0a\x09exclusions addAll: anArray.\x0a\x09^ anArray",
- referencedClasses: [],
- messageSends: ["addAll:"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "aliases",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@aliases"];
- },
- args: [],
- source: "aliases\x0a\x09^ aliases",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $globals.HashedCollection._newFromPairs_(["trait",self._trait(),"aliases",self._aliases(),"exclusions",$recv($recv(self._exclusions())._asArray())._sorted()]);
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptObject",{},$globals.TraitTransformation)});
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ #{\x0a\x09\x09'trait' -> self trait.\x0a\x09\x09'aliases' -> self aliases.\x0a\x09\x09'exclusions' -> self exclusions asArray sorted }",
- referencedClasses: [],
- messageSends: ["trait", "aliases", "sorted", "asArray", "exclusions"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptSource",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1;
- return $recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- $2=$recv(self._trait())._asJavaScriptSource();
- $ctx2.sendIdx["asJavaScriptSource"]=1;
- $3=$recv(self._aliases())._ifNotEmpty_((function(al){
- return $core.withContext(function($ctx3) {
- return [", aliases: ",$recv(al)._asJSONString()];
- }, function($ctx3) {$ctx3.fillBlock({al:al},$ctx2,2)});
- }));
- $ctx2.sendIdx["ifNotEmpty:"]=1;
- $1=["{trait: ",$2,$3,$recv(self._exclusions())._ifNotEmpty_((function(ex){
- return $core.withContext(function($ctx3) {
- return [", exclusions: ",$recv($recv($recv(ex)._asArray())._sorted())._asJavaScriptSource()];
- }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,3)});
- })),"}"];
- return $recv(str)._write_($1);
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSource",{},$globals.TraitTransformation)});
- },
- args: [],
- source: "asJavaScriptSource\x0a\x09^ String streamContents: [ :str | str write: {\x0a\x09\x09'{trait: '. self trait asJavaScriptSource.\x0a\x09\x09self aliases ifNotEmpty: [ :al |\x0a\x09\x09\x09{', aliases: '. al asJSONString} ].\x0a\x09\x09self exclusions ifNotEmpty: [ :ex |\x0a\x09\x09\x09{', exclusions: '. ex asArray sorted asJavaScriptSource} ].\x0a\x09\x09'}' } ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "write:", "asJavaScriptSource", "trait", "ifNotEmpty:", "aliases", "asJSONString", "exclusions", "sorted", "asArray"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "asTraitComposition",
- protocol: "converting",
- fn: function (){
- var self=this;
- return [self];
- },
- args: [],
- source: "asTraitComposition\x0a\x09^ { self }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "asTraitTransformation",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asTraitTransformation\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- $recv(str)._print_(self._trait());
- $recv(self._aliases())._ifNotEmpty_((function(al){
- return $core.withContext(function($ctx3) {
- $recv(str)._write_(" @ {");
- $ctx3.sendIdx["write:"]=1;
- $recv($recv(al)._associations())._do_separatedBy_((function(each){
- return $core.withContext(function($ctx4) {
- $recv(str)._printSymbol_($recv(each)._key());
- $ctx4.sendIdx["printSymbol:"]=1;
- $recv(str)._write_(" -> ");
- $ctx4.sendIdx["write:"]=2;
- return $recv(str)._printSymbol_($recv(each)._value());
- }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3,3)});
- }),(function(){
- return $core.withContext(function($ctx4) {
- return $recv(str)._write_(". ");
- $ctx4.sendIdx["write:"]=3;
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,4)});
- }));
- $ctx3.sendIdx["do:separatedBy:"]=1;
- return $recv(str)._write_("}");
- $ctx3.sendIdx["write:"]=4;
- }, function($ctx3) {$ctx3.fillBlock({al:al},$ctx2,2)});
- }));
- $ctx2.sendIdx["ifNotEmpty:"]=1;
- return $recv(self._exclusions())._ifNotEmpty_((function(ex){
- return $core.withContext(function($ctx3) {
- $recv(str)._write_(" - #(");
- $ctx3.sendIdx["write:"]=5;
- $recv($recv($recv(ex)._asArray())._sorted())._do_separatedBy_((function(each){
- return $core.withContext(function($ctx4) {
- return $recv(str)._write_($recv($recv(each)._symbolPrintString())._allButFirst());
- $ctx4.sendIdx["write:"]=6;
- }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3,6)});
- }),(function(){
- return $core.withContext(function($ctx4) {
- return $recv(str)._space();
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,7)});
- }));
- return $recv(str)._write_(")");
- }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,5)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"definition",{},$globals.TraitTransformation)});
- },
- args: [],
- source: "definition\x0a\x09^ String streamContents: [ :str |\x0a\x09\x09str print: self trait.\x0a\x09\x09self aliases ifNotEmpty: [ :al |\x0a\x09\x09\x09str write: ' @ {'.\x0a\x09\x09\x09al associations\x0a\x09\x09\x09\x09do: [ :each | str printSymbol: each key; write: ' -> '; printSymbol: each value ]\x0a\x09\x09\x09\x09separatedBy: [ str write: '. ' ].\x0a\x09\x09\x09str write: '}' ].\x0a\x09\x09self exclusions ifNotEmpty: [ :ex |\x0a\x09\x09\x09str write: ' - #('.\x0a\x09\x09\x09ex asArray sorted \x0a\x09\x09\x09\x09do: [ :each | str write: each symbolPrintString allButFirst ]\x0a\x09\x09\x09\x09separatedBy: [ str space ].\x0a\x09\x09\x09str write: ')' ] ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "print:", "trait", "ifNotEmpty:", "aliases", "write:", "do:separatedBy:", "associations", "printSymbol:", "key", "value", "exclusions", "sorted", "asArray", "allButFirst", "symbolPrintString", "space"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "exclusions",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@exclusions"];
- },
- args: [],
- source: "exclusions\x0a\x09^ exclusions",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.TraitTransformation.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@aliases"]=$globals.HashedCollection._newFromPairs_([]);
- self["@exclusions"]=$recv($globals.Set)._new();
- self["@trait"]=nil;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TraitTransformation)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x0a\x09aliases := #{}.\x0a\x09exclusions := Set new.\x0a\x09trait := nil",
- referencedClasses: ["Set"],
- messageSends: ["initialize", "new"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "postCopy",
- protocol: "copying",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@aliases"]=$recv(self["@aliases"])._copy();
- $ctx1.sendIdx["copy"]=1;
- self["@exclusions"]=$recv(self["@exclusions"])._copy();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"postCopy",{},$globals.TraitTransformation)});
- },
- args: [],
- source: "postCopy\x0a\x09aliases := aliases copy.\x0a\x09exclusions := exclusions copy",
- referencedClasses: [],
- messageSends: ["copy"]
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "trait",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@trait"];
- },
- args: [],
- source: "trait\x0a\x09^ trait",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "trait:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@trait"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "trait: anObject\x0a\x09trait := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TraitTransformation);
- $core.addMethod(
- $core.method({
- selector: "fromJSON:",
- protocol: "instance creation",
- fn: function (aJSObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$4,$3,$2;
- $1=(
- $ctx1.supercall = true,
- ($globals.TraitTransformation.klass.superclass||$boot.nilAsClass).fn.prototype._new.apply($recv(self), []));
- $ctx1.supercall = false;
- $recv($1)._trait_($recv(aJSObject)._at_("trait"));
- $4=$recv(aJSObject)._at_ifAbsent_("aliases",(function(){
- return $globals.HashedCollection._newFromPairs_([]);
- }));
- $ctx1.sendIdx["at:ifAbsent:"]=1;
- $3=$recv($globals.Smalltalk)._readJSObject_($4);
- $2=$recv($3)._associations();
- $recv($1)._addAliases_($2);
- $recv($1)._addExclusions_($recv(aJSObject)._at_ifAbsent_("exclusions",(function(){
- return [];
- })));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"fromJSON:",{aJSObject:aJSObject},$globals.TraitTransformation.klass)});
- },
- args: ["aJSObject"],
- source: "fromJSON: aJSObject\x0a\x09^ super new\x0a\x09\x09trait: (aJSObject at: #trait);\x0a\x09\x09addAliases: (Smalltalk readJSObject: (aJSObject at: #aliases ifAbsent: [#{}])) associations;\x0a\x09\x09addExclusions: (aJSObject at: #exclusions ifAbsent: [#()]);\x0a\x09\x09yourself",
- referencedClasses: ["Smalltalk"],
- messageSends: ["trait:", "new", "at:", "addAliases:", "associations", "readJSObject:", "at:ifAbsent:", "addExclusions:", "yourself"]
- }),
- $globals.TraitTransformation.klass);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aTrait){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(
- $ctx1.supercall = true,
- ($globals.TraitTransformation.klass.superclass||$boot.nilAsClass).fn.prototype._new.apply($recv(self), []));
- $ctx1.supercall = false;
- $recv($1)._trait_(aTrait);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{aTrait:aTrait},$globals.TraitTransformation.klass)});
- },
- args: ["aTrait"],
- source: "on: aTrait\x0a\x09^ super new trait: aTrait; yourself",
- referencedClasses: [],
- messageSends: ["trait:", "new", "yourself"]
- }),
- $globals.TraitTransformation.klass);
- $core.addMethod(
- $core.method({
- selector: "asTraitComposition",
- protocol: "*Kernel-Classes",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._asTraitTransformation();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"asTraitComposition",{},$globals.Array)});
- },
- args: [],
- source: "asTraitComposition\x0a\x09\x22not implemented yet, noop atm\x22\x0a\x09^ self collect: [ :each | each asTraitTransformation ]",
- referencedClasses: [],
- messageSends: ["collect:", "asTraitTransformation"]
- }),
- $globals.Array);
- $core.addMethod(
- $core.method({
- selector: "subclass:",
- protocol: "*Kernel-Classes",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,"",nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:",{aString:aString},$globals.UndefinedObject)});
- },
- args: ["aString"],
- source: "subclass: aString \x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString instanceVariableNames: '' package: nil",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:",
- protocol: "*Kernel-Classes",
- fn: function (aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,anotherString,nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:",{aString:aString,anotherString:anotherString},$globals.UndefinedObject)});
- },
- args: ["aString", "anotherString"],
- source: "subclass: aString instanceVariableNames: anotherString\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString instanceVariableNames: anotherString package: nil",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:category:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aString2,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:category:",{aString:aString,aString2:aString2,aString3:aString3},$globals.UndefinedObject)});
- },
- args: ["aString", "aString2", "aString3"],
- source: "subclass: aString instanceVariableNames: aString2 category: aString3\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:classVariableNames:poolDictionaries:category:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aString2,classVars,pools,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_instanceVariableNames_package_(aString,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:classVariableNames:poolDictionaries:category:",{aString:aString,aString2:aString2,classVars:classVars,pools:pools,aString3:aString3},$globals.UndefinedObject)});
- },
- args: ["aString", "aString2", "classVars", "pools", "aString3"],
- source: "subclass: aString instanceVariableNames: aString2 classVariableNames: classVars poolDictionaries: pools category: aString3\x0a\x09\x22Kept for file-in compatibility. ignores class variables and pools.\x22\x0a\x09^ self subclass: aString instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:instanceVariableNames:package:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aString2,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.ClassBuilder)._new())._superclass_subclass_instanceVariableNames_package_(self,$recv(aString)._asString(),aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:package:",{aString:aString,aString2:aString2,aString3:aString3},$globals.UndefinedObject)});
- },
- args: ["aString", "aString2", "aString3"],
- source: "subclass: aString instanceVariableNames: aString2 package: aString3\x0a\x09^ ClassBuilder new\x0a\x09\x09superclass: self subclass: aString asString instanceVariableNames: aString2 package: aString3",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["superclass:subclass:instanceVariableNames:package:", "new", "asString"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aTraitCompositionDescription){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,"",nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription},$globals.UndefinedObject)});
- },
- args: ["aString", "aTraitCompositionDescription"],
- source: "subclass: aString uses: aTraitCompositionDescription \x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: '' package: nil",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aTraitCompositionDescription,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,anotherString,nil);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,anotherString:anotherString},$globals.UndefinedObject)});
- },
- args: ["aString", "aTraitCompositionDescription", "anotherString"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: anotherString\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: anotherString package: nil",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:category:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aTraitCompositionDescription,aString2,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:category:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,aString2:aString2,aString3:aString3},$globals.UndefinedObject)});
- },
- args: ["aString", "aTraitCompositionDescription", "aString2", "aString3"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 category: aString3\x0a\x09\x22Kept for file-in compatibility.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:classVariableNames:poolDictionaries:category:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aTraitCompositionDescription,aString2,classVars,pools,aString3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._subclass_uses_instanceVariableNames_package_(aString,aTraitCompositionDescription,aString2,aString3);
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:classVariableNames:poolDictionaries:category:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,aString2:aString2,classVars:classVars,pools:pools,aString3:aString3},$globals.UndefinedObject)});
- },
- args: ["aString", "aTraitCompositionDescription", "aString2", "classVars", "pools", "aString3"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 classVariableNames: classVars poolDictionaries: pools category: aString3\x0a\x09\x22Kept for file-in compatibility. ignores class variables and pools.\x22\x0a\x09^ self subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 package: aString3",
- referencedClasses: [],
- messageSends: ["subclass:uses:instanceVariableNames:package:"]
- }),
- $globals.UndefinedObject);
- $core.addMethod(
- $core.method({
- selector: "subclass:uses:instanceVariableNames:package:",
- protocol: "*Kernel-Classes",
- fn: function (aString,aTraitCompositionDescription,aString2,aString3){
- var self=this;
- var cls;
- return $core.withContext(function($ctx1) {
- cls=self._subclass_instanceVariableNames_package_(aString,aString2,aString3);
- $recv(cls)._setTraitComposition_($recv(aTraitCompositionDescription)._asTraitComposition());
- return cls;
- }, function($ctx1) {$ctx1.fill(self,"subclass:uses:instanceVariableNames:package:",{aString:aString,aTraitCompositionDescription:aTraitCompositionDescription,aString2:aString2,aString3:aString3,cls:cls},$globals.UndefinedObject)});
- },
- args: ["aString", "aTraitCompositionDescription", "aString2", "aString3"],
- source: "subclass: aString uses: aTraitCompositionDescription instanceVariableNames: aString2 package: aString3\x0a\x09| cls |\x0a\x09cls := self subclass: aString instanceVariableNames: aString2 package: aString3.\x0a\x09cls setTraitComposition: aTraitCompositionDescription asTraitComposition.\x0a\x09^ cls",
- referencedClasses: [],
- messageSends: ["subclass:instanceVariableNames:package:", "setTraitComposition:", "asTraitComposition"]
- }),
- $globals.UndefinedObject);
- });
- define('amber_core/Kernel-Methods',["amber/boot", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Methods");
- $core.packages["Kernel-Methods"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Methods"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("BlockClosure", $globals.Object, [], "Kernel-Methods");
- $globals.BlockClosure.comment="I represent a lexical closure.\x0aI am is directly mapped to JavaScript Function.\x0a\x0a## API\x0a\x0a1. Evaluation\x0a\x0a My instances get evaluated with the `#value*` methods in the 'evaluating' protocol.\x0a\x0a Example: ` [ :x | x + 1 ] value: 3 \x22Answers 4\x22 `\x0a\x0a2. Control structures\x0a\x0a Blocks are used (together with `Boolean`) for control structures (methods in the `controlling` protocol).\x0a\x0a Example: `aBlock whileTrue: [ ... ]`\x0a\x0a3. Error handling\x0a\x0a I provide the `#on:do:` method for handling exceptions.\x0a\x0a Example: ` aBlock on: MessageNotUnderstood do: [ :ex | ... ] `";
- $core.addMethod(
- $core.method({
- selector: "applyTo:arguments:",
- protocol: "evaluating",
- fn: function (anObject,aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.apply(anObject, aCollection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"applyTo:arguments:",{anObject:anObject,aCollection:aCollection},$globals.BlockClosure)});
- },
- args: ["anObject", "aCollection"],
- source: "applyTo: anObject arguments: aCollection\x0a\x09<inlineJS: 'return self.apply(anObject, aCollection)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "asCompiledMethod:",
- protocol: "converting",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.method({selector:aString, fn:self});;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asCompiledMethod:",{aString:aString},$globals.BlockClosure)});
- },
- args: ["aString"],
- source: "asCompiledMethod: aString\x0a\x09<inlineJS: 'return $core.method({selector:aString, fn:self});'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "compiledSource",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.toString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"compiledSource",{},$globals.BlockClosure)});
- },
- args: [],
- source: "compiledSource\x0a\x09<inlineJS: 'return self.toString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "currySelf",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return function () {
- var args = [ this ];
- args.push.apply(args, arguments);
- return self.apply(null, args);
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"currySelf",{},$globals.BlockClosure)});
- },
- args: [],
- source: "currySelf\x0a\x09\x22Transforms [ :selfarg :x :y | stcode ] block\x0a\x09which represents JS function (selfarg, x, y, ...) {jscode}\x0a\x09into function (x, y, ...) {jscode} that takes selfarg from 'this'.\x0a\x09IOW, it is usable as JS method and first arg takes the receiver.\x22\x0a\x09\x0a\x09<inlineJS: '\x0a\x09\x09return function () {\x0a\x09\x09\x09var args = [ this ];\x0a\x09\x09\x09args.push.apply(args, arguments);\x0a\x09\x09\x09return self.apply(null, args);\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "ensure:",
- protocol: "evaluating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- try{return self._value()}finally{aBlock._value()};
- return self;
- }, function($ctx1) {$ctx1.fill(self,"ensure:",{aBlock:aBlock},$globals.BlockClosure)});
- },
- args: ["aBlock"],
- source: "ensure: aBlock\x0a\x09<inlineJS: 'try{return self._value()}finally{aBlock._value()}'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "fork",
- protocol: "timeout/interval",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.ForkPool)._default())._fork_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fork",{},$globals.BlockClosure)});
- },
- args: [],
- source: "fork\x0a\x09ForkPool default fork: self",
- referencedClasses: ["ForkPool"],
- messageSends: ["fork:", "default"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "evaluating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new self();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.BlockClosure)});
- },
- args: [],
- source: "new\x0a\x09\x22Use the receiver as a JS constructor.\x0a\x09*Do not* use this method to instanciate Smalltalk objects!\x22\x0a\x09<inlineJS: 'return new self()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "newValue:",
- protocol: "evaluating",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._newWithValues_([anObject]);
- }, function($ctx1) {$ctx1.fill(self,"newValue:",{anObject:anObject},$globals.BlockClosure)});
- },
- args: ["anObject"],
- source: "newValue: anObject\x0a\x09^ self newWithValues: { anObject }",
- referencedClasses: [],
- messageSends: ["newWithValues:"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "newValue:value:",
- protocol: "evaluating",
- fn: function (anObject,anObject2){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._newWithValues_([anObject,anObject2]);
- }, function($ctx1) {$ctx1.fill(self,"newValue:value:",{anObject:anObject,anObject2:anObject2},$globals.BlockClosure)});
- },
- args: ["anObject", "anObject2"],
- source: "newValue: anObject value: anObject2\x0a\x09^ self newWithValues: { anObject. anObject2 }.",
- referencedClasses: [],
- messageSends: ["newWithValues:"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "newValue:value:value:",
- protocol: "evaluating",
- fn: function (anObject,anObject2,anObject3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._newWithValues_([anObject,anObject2,anObject3]);
- }, function($ctx1) {$ctx1.fill(self,"newValue:value:value:",{anObject:anObject,anObject2:anObject2,anObject3:anObject3},$globals.BlockClosure)});
- },
- args: ["anObject", "anObject2", "anObject3"],
- source: "newValue: anObject value: anObject2 value: anObject3\x0a\x09^ self newWithValues: { anObject. anObject2. anObject3 }.",
- referencedClasses: [],
- messageSends: ["newWithValues:"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "newWithValues:",
- protocol: "evaluating",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var object = Object.create(self.prototype);
- var result = self.apply(object, aCollection);
- return typeof result === "object" ? result : object;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"newWithValues:",{aCollection:aCollection},$globals.BlockClosure)});
- },
- args: ["aCollection"],
- source: "newWithValues: aCollection\x0a\x09\x22Simulates JS new operator by combination of Object.create and .apply\x22\x0a\x09<inlineJS: '\x0a\x09\x09var object = Object.create(self.prototype);\x0a\x09\x09var result = self.apply(object, aCollection);\x0a\x09\x09return typeof result === \x22object\x22 ? result : object;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "numArgs",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.length;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"numArgs",{},$globals.BlockClosure)});
- },
- args: [],
- source: "numArgs\x0a\x09<inlineJS: 'return self.length'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "on:do:",
- protocol: "error handling",
- fn: function (anErrorClass,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return self._tryCatch_((function(error){
- var smalltalkError;
- return $core.withContext(function($ctx2) {
- smalltalkError=$recv($globals.Smalltalk)._asSmalltalkException_(error);
- smalltalkError;
- $1=$recv(smalltalkError)._isKindOf_(anErrorClass);
- if($core.assert($1)){
- return $recv(aBlock)._value_(smalltalkError);
- } else {
- return $recv(smalltalkError)._resignal();
- }
- }, function($ctx2) {$ctx2.fillBlock({error:error,smalltalkError:smalltalkError},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"on:do:",{anErrorClass:anErrorClass,aBlock:aBlock},$globals.BlockClosure)});
- },
- args: ["anErrorClass", "aBlock"],
- source: "on: anErrorClass do: aBlock\x0a\x09\x22All exceptions thrown in the Smalltalk stack are cought.\x0a\x09Convert all JS exceptions to JavaScriptException instances.\x22\x0a\x09\x0a\x09^ self tryCatch: [ :error | | smalltalkError |\x0a\x09\x09smalltalkError := Smalltalk asSmalltalkException: error.\x0a\x09\x09(smalltalkError isKindOf: anErrorClass)\x0a\x09\x09ifTrue: [ aBlock value: smalltalkError ]\x0a\x09\x09ifFalse: [ smalltalkError resignal ] ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["tryCatch:", "asSmalltalkException:", "ifTrue:ifFalse:", "isKindOf:", "value:", "resignal"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return nil;
- },
- args: [],
- source: "receiver\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "timeToRun",
- protocol: "evaluating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Date)._millisecondsToRun_(self);
- }, function($ctx1) {$ctx1.fill(self,"timeToRun",{},$globals.BlockClosure)});
- },
- args: [],
- source: "timeToRun\x0a\x09\x22Answer the number of milliseconds taken to execute this block.\x22\x0a\x0a\x09^ Date millisecondsToRun: self",
- referencedClasses: ["Date"],
- messageSends: ["millisecondsToRun:"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "tryCatch:",
- protocol: "error handling",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- try {
- return self._value();
- } catch(error) {
- // pass non-local returns undetected
- if (Array.isArray(error) && error.length === 1) throw error;
- return aBlock._value_(error);
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tryCatch:",{aBlock:aBlock},$globals.BlockClosure)});
- },
- args: ["aBlock"],
- source: "tryCatch: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09try {\x0a\x09\x09\x09return self._value();\x0a\x09\x09} catch(error) {\x0a\x09\x09\x09// pass non-local returns undetected\x0a\x09\x09\x09if (Array.isArray(error) && error.length === 1) throw error;\x0a\x09\x09\x09return aBlock._value_(error);\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "evaluating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self();;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"value",{},$globals.BlockClosure)});
- },
- args: [],
- source: "value\x0a\x09<inlineJS: 'return self();'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "evaluating",
- fn: function (anArg){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self(anArg);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"value:",{anArg:anArg},$globals.BlockClosure)});
- },
- args: ["anArg"],
- source: "value: anArg\x0a\x09<inlineJS: 'return self(anArg);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value:value:",
- protocol: "evaluating",
- fn: function (firstArg,secondArg){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self(firstArg, secondArg);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"value:value:",{firstArg:firstArg,secondArg:secondArg},$globals.BlockClosure)});
- },
- args: ["firstArg", "secondArg"],
- source: "value: firstArg value: secondArg\x0a\x09<inlineJS: 'return self(firstArg, secondArg);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value:value:value:",
- protocol: "evaluating",
- fn: function (firstArg,secondArg,thirdArg){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self(firstArg, secondArg, thirdArg);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"value:value:value:",{firstArg:firstArg,secondArg:secondArg,thirdArg:thirdArg},$globals.BlockClosure)});
- },
- args: ["firstArg", "secondArg", "thirdArg"],
- source: "value: firstArg value: secondArg value: thirdArg\x0a\x09<inlineJS: 'return self(firstArg, secondArg, thirdArg);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "valueWithInterval:",
- protocol: "timeout/interval",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- var interval = setInterval(self, aNumber);
- return $globals.Timeout._on_(interval);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"valueWithInterval:",{aNumber:aNumber},$globals.BlockClosure)});
- },
- args: ["aNumber"],
- source: "valueWithInterval: aNumber\x0a\x09<inlineJS: '\x0a\x09\x09var interval = setInterval(self, aNumber);\x0a\x09\x09return $globals.Timeout._on_(interval);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "valueWithPossibleArguments:",
- protocol: "evaluating",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.apply(null, aCollection);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"valueWithPossibleArguments:",{aCollection:aCollection},$globals.BlockClosure)});
- },
- args: ["aCollection"],
- source: "valueWithPossibleArguments: aCollection\x0a\x09<inlineJS: 'return self.apply(null, aCollection);'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "valueWithTimeout:",
- protocol: "timeout/interval",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- var timeout = setTimeout(self, aNumber);
- return $globals.Timeout._on_(timeout);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"valueWithTimeout:",{aNumber:aNumber},$globals.BlockClosure)});
- },
- args: ["aNumber"],
- source: "valueWithTimeout: aNumber\x0a\x09<inlineJS: '\x0a\x09\x09var timeout = setTimeout(self, aNumber);\x0a\x09\x09return $globals.Timeout._on_(timeout);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "whileFalse",
- protocol: "controlling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._whileFalse_((function(){
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"whileFalse",{},$globals.BlockClosure)});
- },
- args: [],
- source: "whileFalse\x0a\x09self whileFalse: []",
- referencedClasses: [],
- messageSends: ["whileFalse:"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "whileFalse:",
- protocol: "controlling",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- while(!$core.assert(self._value())) {aBlock._value()};
- return self;
- }, function($ctx1) {$ctx1.fill(self,"whileFalse:",{aBlock:aBlock},$globals.BlockClosure)});
- },
- args: ["aBlock"],
- source: "whileFalse: aBlock\x0a\x09<inlineJS: 'while(!$core.assert(self._value())) {aBlock._value()}'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "whileTrue",
- protocol: "controlling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._whileTrue_((function(){
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"whileTrue",{},$globals.BlockClosure)});
- },
- args: [],
- source: "whileTrue\x0a\x09self whileTrue: []",
- referencedClasses: [],
- messageSends: ["whileTrue:"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "whileTrue:",
- protocol: "controlling",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- while($core.assert(self._value())) {aBlock._value()};
- return self;
- }, function($ctx1) {$ctx1.fill(self,"whileTrue:",{aBlock:aBlock},$globals.BlockClosure)});
- },
- args: ["aBlock"],
- source: "whileTrue: aBlock\x0a\x09<inlineJS: 'while($core.assert(self._value())) {aBlock._value()}'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosure);
- $core.addClass("CompiledMethod", $globals.Object, [], "Kernel-Methods");
- $globals.CompiledMethod.comment="I represent a class method of the system. I hold the source and compiled code of a class method.\x0a\x0a## API\x0aMy instances can be accessed using `Behavior >> #methodAt:`\x0a\x0a Object methodAt: 'asString'\x0a\x0aSource code access:\x0a\x0a\x09(String methodAt: 'lines') source\x0a\x0aReferenced classes:\x0a\x0a\x09(String methodAt: 'lines') referencedClasses\x0a\x0aMessages sent from an instance:\x0a\x09\x0a\x09(String methodAt: 'lines') messageSends";
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.args || [];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"arguments",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "arguments\x0a\x09<inlineJS: 'return self.args || []'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "browse",
- protocol: "browsing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Finder)._findMethod_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"browse",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "browse\x0a\x09Finder findMethod: self",
- referencedClasses: ["Finder"],
- messageSends: ["findMethod:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "category",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._protocol();
- }, function($ctx1) {$ctx1.fill(self,"category",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "category\x0a\x09^ self protocol",
- referencedClasses: [],
- messageSends: ["protocol"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "defaultProtocol",
- protocol: "defaults",
- fn: function (){
- var self=this;
- return "as yet unclassified";
- },
- args: [],
- source: "defaultProtocol\x0a\x09^ 'as yet unclassified'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "fn",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("fn");
- }, function($ctx1) {$ctx1.fill(self,"fn",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "fn\x0a\x09^ self basicAt: 'fn'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "fn:",
- protocol: "accessing",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._basicAt_put_("fn",aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fn:",{aBlock:aBlock},$globals.CompiledMethod)});
- },
- args: ["aBlock"],
- source: "fn: aBlock\x0a\x09self basicAt: 'fn' put: aBlock",
- referencedClasses: [],
- messageSends: ["basicAt:put:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "isCompiledMethod",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isCompiledMethod\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "isOverridden",
- protocol: "testing",
- fn: function (){
- var self=this;
- var selector;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- selector=self._selector();
- $recv(self._methodClass())._allSubclassesDo_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(each)._includesSelector_(selector);
- if($core.assert($1)){
- throw $early=[true];
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return false;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"isOverridden",{selector:selector},$globals.CompiledMethod)});
- },
- args: [],
- source: "isOverridden\x0a\x09| selector |\x0a \x0a selector := self selector.\x0a self methodClass allSubclassesDo: [ :each |\x0a\x09 (each includesSelector: selector)\x0a \x09ifTrue: [ ^ true ] ].\x0a\x09^ false",
- referencedClasses: [],
- messageSends: ["selector", "allSubclassesDo:", "methodClass", "ifTrue:", "includesSelector:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "isOverride",
- protocol: "testing",
- fn: function (){
- var self=this;
- var superclass;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=self._methodClass();
- $ctx1.sendIdx["methodClass"]=1;
- superclass=$recv($1)._superclass();
- $ctx1.sendIdx["superclass"]=1;
- $2=superclass;
- if(($receiver = $2) == null || $receiver.isNil){
- return false;
- } else {
- $2;
- }
- return $recv($recv($recv(self._methodClass())._superclass())._lookupSelector_(self._selector()))._notNil();
- }, function($ctx1) {$ctx1.fill(self,"isOverride",{superclass:superclass},$globals.CompiledMethod)});
- },
- args: [],
- source: "isOverride\x0a\x09| superclass |\x0a \x0a superclass := self methodClass superclass.\x0a\x09superclass ifNil: [ ^ false ].\x0a\x09\x0a ^ (self methodClass superclass lookupSelector: self selector) notNil",
- referencedClasses: [],
- messageSends: ["superclass", "methodClass", "ifNil:", "notNil", "lookupSelector:", "selector"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "messageSends",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("messageSends");
- }, function($ctx1) {$ctx1.fill(self,"messageSends",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "messageSends\x0a\x09^ self basicAt: 'messageSends'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "methodClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("methodClass");
- }, function($ctx1) {$ctx1.fill(self,"methodClass",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "methodClass\x0a\x09^ self basicAt: 'methodClass'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "package",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._methodClass();
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- var class_;
- class_=$receiver;
- return $recv(class_)._packageOfProtocol_(self._protocol());
- }
- }, function($ctx1) {$ctx1.fill(self,"package",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "package\x0a\x09\x22Answer the package the receiver belongs to:\x0a\x09- if it is an extension method, answer the corresponding package\x0a\x09- else answer the `methodClass` package\x22\x0a\x09\x0a\x09^ self methodClass ifNotNil: [ :class | class packageOfProtocol: self protocol ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "methodClass", "packageOfProtocol:", "protocol"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "protocol",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._basicAt_("protocol");
- if(($receiver = $1) == null || $receiver.isNil){
- return self._defaultProtocol();
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"protocol",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "protocol\x0a\x09^ (self basicAt: 'protocol') ifNil: [ self defaultProtocol ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "basicAt:", "defaultProtocol"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "protocol:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- var oldProtocol;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$receiver;
- oldProtocol=self._protocol();
- self._basicAt_put_("protocol",aString);
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.MethodMoved)._new();
- $recv($3)._method_(self);
- $recv($3)._oldProtocol_(oldProtocol);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- $4=self._methodClass();
- if(($receiver = $4) == null || $receiver.isNil){
- $4;
- } else {
- var methodClass;
- methodClass=$receiver;
- $recv($recv(methodClass)._organization())._addElement_(aString);
- $recv(methodClass)._removeProtocolIfEmpty_(oldProtocol);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"protocol:",{aString:aString,oldProtocol:oldProtocol},$globals.CompiledMethod)});
- },
- args: ["aString"],
- source: "protocol: aString\x0a\x09| oldProtocol |\x0a\x09oldProtocol := self protocol.\x0a\x09self basicAt: 'protocol' put: aString.\x0a\x0a\x09SystemAnnouncer current announce: (MethodMoved new\x0a\x09\x09method: self;\x0a\x09\x09oldProtocol: oldProtocol;\x0a\x09\x09yourself).\x0a\x0a\x09self methodClass ifNotNil: [ :methodClass |\x0a\x09\x09methodClass organization addElement: aString.\x0a\x09\x09methodClass removeProtocolIfEmpty: oldProtocol ]",
- referencedClasses: ["SystemAnnouncer", "MethodMoved"],
- messageSends: ["protocol", "basicAt:put:", "announce:", "current", "method:", "new", "oldProtocol:", "yourself", "ifNotNil:", "methodClass", "addElement:", "organization", "removeProtocolIfEmpty:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "referencedClasses",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("referencedClasses");
- }, function($ctx1) {$ctx1.fill(self,"referencedClasses",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "referencedClasses\x0a\x09^ self basicAt: 'referencedClasses'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("selector");
- }, function($ctx1) {$ctx1.fill(self,"selector",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "selector\x0a\x09^ self basicAt: 'selector'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._basicAt_put_("selector",aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},$globals.CompiledMethod)});
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09self basicAt: 'selector' put: aString",
- referencedClasses: [],
- messageSends: ["basicAt:put:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "sendTo:arguments:",
- protocol: "evaluating",
- fn: function (anObject,aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._fn())._applyTo_arguments_(anObject,aCollection);
- }, function($ctx1) {$ctx1.fill(self,"sendTo:arguments:",{anObject:anObject,aCollection:aCollection},$globals.CompiledMethod)});
- },
- args: ["anObject", "aCollection"],
- source: "sendTo: anObject arguments: aCollection\x0a\x09^ self fn applyTo: anObject arguments: aCollection",
- referencedClasses: [],
- messageSends: ["applyTo:arguments:", "fn"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._basicAt_("source");
- if(($receiver = $1) == null || $receiver.isNil){
- return "";
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "source\x0a\x09^ (self basicAt: 'source') ifNil: [ '' ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "basicAt:"]
- }),
- $globals.CompiledMethod);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._basicAt_put_("source",aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},$globals.CompiledMethod)});
- },
- args: ["aString"],
- source: "source: aString\x0a\x09self basicAt: 'source' put: aString",
- referencedClasses: [],
- messageSends: ["basicAt:put:"]
- }),
- $globals.CompiledMethod);
- $core.addClass("ForkPool", $globals.Object, ["poolSize", "maxPoolSize", "queue", "worker"], "Kernel-Methods");
- $globals.ForkPool.comment="I am responsible for handling forked blocks.\x0aThe pool size sets the maximum concurrent forked blocks.\x0a\x0a## API\x0a\x0aThe default instance is accessed with `#default`.\x0aThe maximum concurrent forked blocks can be set with `#maxPoolSize:`.\x0a\x0aForking is done via `BlockClosure >> #fork`";
- $core.addMethod(
- $core.method({
- selector: "addWorker",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@worker"])._valueWithTimeout_((0));
- self["@poolSize"]=$recv(self["@poolSize"]).__plus((1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addWorker",{},$globals.ForkPool)});
- },
- args: [],
- source: "addWorker\x0a\x09worker valueWithTimeout: 0.\x0a\x09poolSize := poolSize + 1",
- referencedClasses: [],
- messageSends: ["valueWithTimeout:", "+"]
- }),
- $globals.ForkPool);
- $core.addMethod(
- $core.method({
- selector: "defaultMaxPoolSize",
- protocol: "defaults",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._defaultMaxPoolSize();
- }, function($ctx1) {$ctx1.fill(self,"defaultMaxPoolSize",{},$globals.ForkPool)});
- },
- args: [],
- source: "defaultMaxPoolSize\x0a\x09^ self class defaultMaxPoolSize",
- referencedClasses: [],
- messageSends: ["defaultMaxPoolSize", "class"]
- }),
- $globals.ForkPool);
- $core.addMethod(
- $core.method({
- selector: "fork:",
- protocol: "actions",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self["@poolSize"]).__lt(self._maxPoolSize());
- if($core.assert($1)){
- self._addWorker();
- }
- $recv(self["@queue"])._nextPut_(aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fork:",{aBlock:aBlock},$globals.ForkPool)});
- },
- args: ["aBlock"],
- source: "fork: aBlock\x0a\x09poolSize < self maxPoolSize ifTrue: [ self addWorker ].\x0a\x09queue nextPut: aBlock",
- referencedClasses: [],
- messageSends: ["ifTrue:", "<", "maxPoolSize", "addWorker", "nextPut:"]
- }),
- $globals.ForkPool);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.ForkPool.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@poolSize"]=(0);
- self["@queue"]=$recv($globals.Queue)._new();
- self["@worker"]=self._makeWorker();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.ForkPool)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09\x0a\x09poolSize := 0.\x0a\x09queue := Queue new.\x0a\x09worker := self makeWorker",
- referencedClasses: ["Queue"],
- messageSends: ["initialize", "new", "makeWorker"]
- }),
- $globals.ForkPool);
- $core.addMethod(
- $core.method({
- selector: "makeWorker",
- protocol: "initialization",
- fn: function (){
- var self=this;
- var sentinel;
- return $core.withContext(function($ctx1) {
- var $1;
- sentinel=$recv($globals.Object)._new();
- return (function(){
- var block;
- return $core.withContext(function($ctx2) {
- self["@poolSize"]=$recv(self["@poolSize"]).__minus((1));
- self["@poolSize"];
- block=$recv(self["@queue"])._nextIfAbsent_((function(){
- return sentinel;
- }));
- block;
- $1=$recv(block).__eq_eq(sentinel);
- if(!$core.assert($1)){
- return $recv((function(){
- return $core.withContext(function($ctx3) {
- return $recv(block)._value();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,4)});
- }))._ensure_((function(){
- return $core.withContext(function($ctx3) {
- return self._addWorker();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,5)});
- }));
- }
- }, function($ctx2) {$ctx2.fillBlock({block:block},$ctx1,1)});
- });
- }, function($ctx1) {$ctx1.fill(self,"makeWorker",{sentinel:sentinel},$globals.ForkPool)});
- },
- args: [],
- source: "makeWorker\x0a\x09| sentinel |\x0a\x09sentinel := Object new.\x0a\x09^ [ | block |\x0a\x09\x09poolSize := poolSize - 1.\x0a\x09\x09block := queue nextIfAbsent: [ sentinel ].\x0a\x09\x09block == sentinel ifFalse: [\x0a\x09\x09\x09[ block value ] ensure: [ self addWorker ] ]]",
- referencedClasses: ["Object"],
- messageSends: ["new", "-", "nextIfAbsent:", "ifFalse:", "==", "ensure:", "value", "addWorker"]
- }),
- $globals.ForkPool);
- $core.addMethod(
- $core.method({
- selector: "maxPoolSize",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@maxPoolSize"];
- if(($receiver = $1) == null || $receiver.isNil){
- return self._defaultMaxPoolSize();
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"maxPoolSize",{},$globals.ForkPool)});
- },
- args: [],
- source: "maxPoolSize\x0a\x09^ maxPoolSize ifNil: [ self defaultMaxPoolSize ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "defaultMaxPoolSize"]
- }),
- $globals.ForkPool);
- $core.addMethod(
- $core.method({
- selector: "maxPoolSize:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@maxPoolSize"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "maxPoolSize: anInteger\x0a\x09maxPoolSize := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ForkPool);
- $globals.ForkPool.klass.iVarNames = ["default"];
- $core.addMethod(
- $core.method({
- selector: "default",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@default"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@default"]=self._new();
- return self["@default"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"default",{},$globals.ForkPool.klass)});
- },
- args: [],
- source: "default\x0a\x09^ default ifNil: [ default := self new ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.ForkPool.klass);
- $core.addMethod(
- $core.method({
- selector: "defaultMaxPoolSize",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return (100);
- },
- args: [],
- source: "defaultMaxPoolSize\x0a\x09^ 100",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ForkPool.klass);
- $core.addMethod(
- $core.method({
- selector: "resetDefault",
- protocol: "accessing",
- fn: function (){
- var self=this;
- self["@default"]=nil;
- return self;
- },
- args: [],
- source: "resetDefault\x0a\x09default := nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ForkPool.klass);
- $core.addClass("Message", $globals.Object, ["selector", "arguments"], "Kernel-Methods");
- $globals.Message.comment="In general, the system does not use instances of me for efficiency reasons.\x0aHowever, when a message is not understood by its receiver, the interpreter will make up an instance of it in order to capture the information involved in an actual message transmission.\x0aThis instance is sent it as an argument with the message `#doesNotUnderstand:` to the receiver.\x0a\x0aSee boot.js, `messageNotUnderstood` and its counterpart `Object >> #doesNotUnderstand:`\x0a\x0a## API\x0a\x0aBesides accessing methods, `#sendTo:` provides a convenient way to send a message to an object.";
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@arguments"];
- },
- args: [],
- source: "arguments\x0a\x09^ arguments",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Message);
- $core.addMethod(
- $core.method({
- selector: "arguments:",
- protocol: "accessing",
- fn: function (anArray){
- var self=this;
- self["@arguments"]=anArray;
- return self;
- },
- args: ["anArray"],
- source: "arguments: anArray\x0a\x09arguments := anArray",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Message);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Message.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $recv(aStream)._nextPutAll_("(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._nextPutAll_(self._selector());
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Message)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream\x0a\x09\x09nextPutAll: '(';\x0a\x09\x09nextPutAll: self selector;\x0a\x09\x09nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "selector"]
- }),
- $globals.Message);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@selector"];
- },
- args: [],
- source: "selector\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Message);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@selector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09selector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Message);
- $core.addMethod(
- $core.method({
- selector: "sendTo:",
- protocol: "actions",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anObject)._perform_withArguments_(self._selector(),self._arguments());
- }, function($ctx1) {$ctx1.fill(self,"sendTo:",{anObject:anObject},$globals.Message)});
- },
- args: ["anObject"],
- source: "sendTo: anObject\x0a\x09^ anObject perform: self selector withArguments: self arguments",
- referencedClasses: [],
- messageSends: ["perform:withArguments:", "selector", "arguments"]
- }),
- $globals.Message);
- $core.addMethod(
- $core.method({
- selector: "selector:arguments:",
- protocol: "instance creation",
- fn: function (aString,anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._selector_(aString);
- $recv($1)._arguments_(anArray);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"selector:arguments:",{aString:aString,anArray:anArray},$globals.Message.klass)});
- },
- args: ["aString", "anArray"],
- source: "selector: aString arguments: anArray\x0a\x09^ self new\x0a\x09\x09selector: aString;\x0a\x09\x09arguments: anArray;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["selector:", "new", "arguments:", "yourself"]
- }),
- $globals.Message.klass);
- $core.addClass("MessageSend", $globals.Object, ["receiver", "message"], "Kernel-Methods");
- $globals.MessageSend.comment="I encapsulate message sends to objects. Arguments can be either predefined or supplied when the message send is performed. \x0a\x0a## API\x0a\x0aUse `#value` to perform a message send with its predefined arguments and `#value:*` if additonal arguments have to supplied.";
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@message"])._arguments();
- }, function($ctx1) {$ctx1.fill(self,"arguments",{},$globals.MessageSend)});
- },
- args: [],
- source: "arguments\x0a\x09^ message arguments",
- referencedClasses: [],
- messageSends: ["arguments"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "arguments:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@message"])._arguments_(aCollection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"arguments:",{aCollection:aCollection},$globals.MessageSend)});
- },
- args: ["aCollection"],
- source: "arguments: aCollection\x0a\x09message arguments: aCollection",
- referencedClasses: [],
- messageSends: ["arguments:"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.MessageSend.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@message"]=$recv($globals.Message)._new();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.MessageSend)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09message := Message new",
- referencedClasses: ["Message"],
- messageSends: ["initialize", "new"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.MessageSend.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $recv(aStream)._nextPutAll_("(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._nextPutAll_(self._receiver());
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv(aStream)._nextPutAll_(" >> ");
- $ctx1.sendIdx["nextPutAll:"]=3;
- $recv(aStream)._nextPutAll_(self._selector());
- $ctx1.sendIdx["nextPutAll:"]=4;
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.MessageSend)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream\x0a\x09\x09nextPutAll: '(';\x0a\x09\x09nextPutAll: self receiver;\x0a\x09\x09nextPutAll: ' >> ';\x0a\x09\x09nextPutAll: self selector;\x0a\x09\x09nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "receiver", "selector"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@receiver"];
- },
- args: [],
- source: "receiver\x0a\x09^ receiver",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "receiver:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@receiver"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "receiver: anObject\x0a\x09receiver := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@message"])._selector();
- }, function($ctx1) {$ctx1.fill(self,"selector",{},$globals.MessageSend)});
- },
- args: [],
- source: "selector\x0a\x09^ message selector",
- referencedClasses: [],
- messageSends: ["selector"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@message"])._selector_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},$globals.MessageSend)});
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09message selector: aString",
- referencedClasses: [],
- messageSends: ["selector:"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "evaluating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@message"])._sendTo_(self._receiver());
- }, function($ctx1) {$ctx1.fill(self,"value",{},$globals.MessageSend)});
- },
- args: [],
- source: "value\x0a\x09^ message sendTo: self receiver",
- referencedClasses: [],
- messageSends: ["sendTo:", "receiver"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "evaluating",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self["@message"];
- $recv($1)._arguments_([anObject]);
- return $recv($1)._sendTo_(self._receiver());
- }, function($ctx1) {$ctx1.fill(self,"value:",{anObject:anObject},$globals.MessageSend)});
- },
- args: ["anObject"],
- source: "value: anObject\x0a\x09^ message \x0a\x09\x09arguments: { anObject };\x0a\x09\x09sendTo: self receiver",
- referencedClasses: [],
- messageSends: ["arguments:", "sendTo:", "receiver"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "value:value:",
- protocol: "evaluating",
- fn: function (firstArgument,secondArgument){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self["@message"];
- $recv($1)._arguments_([firstArgument,secondArgument]);
- return $recv($1)._sendTo_(self._receiver());
- }, function($ctx1) {$ctx1.fill(self,"value:value:",{firstArgument:firstArgument,secondArgument:secondArgument},$globals.MessageSend)});
- },
- args: ["firstArgument", "secondArgument"],
- source: "value: firstArgument value: secondArgument\x0a\x09^ message \x0a\x09\x09arguments: { firstArgument. secondArgument };\x0a\x09\x09sendTo: self receiver",
- referencedClasses: [],
- messageSends: ["arguments:", "sendTo:", "receiver"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "value:value:value:",
- protocol: "evaluating",
- fn: function (firstArgument,secondArgument,thirdArgument){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self["@message"];
- $recv($1)._arguments_([firstArgument,secondArgument,thirdArgument]);
- return $recv($1)._sendTo_(self._receiver());
- }, function($ctx1) {$ctx1.fill(self,"value:value:value:",{firstArgument:firstArgument,secondArgument:secondArgument,thirdArgument:thirdArgument},$globals.MessageSend)});
- },
- args: ["firstArgument", "secondArgument", "thirdArgument"],
- source: "value: firstArgument value: secondArgument value: thirdArgument\x0a\x09^ message \x0a\x09\x09arguments: { firstArgument. secondArgument. thirdArgument };\x0a\x09\x09sendTo: self receiver",
- referencedClasses: [],
- messageSends: ["arguments:", "sendTo:", "receiver"]
- }),
- $globals.MessageSend);
- $core.addMethod(
- $core.method({
- selector: "valueWithPossibleArguments:",
- protocol: "evaluating",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._arguments_(aCollection);
- return self._value();
- }, function($ctx1) {$ctx1.fill(self,"valueWithPossibleArguments:",{aCollection:aCollection},$globals.MessageSend)});
- },
- args: ["aCollection"],
- source: "valueWithPossibleArguments: aCollection\x0a\x09self arguments: aCollection.\x0a\x09^ self value",
- referencedClasses: [],
- messageSends: ["arguments:", "value"]
- }),
- $globals.MessageSend);
- $core.addClass("MethodContext", $globals.Object, [], "Kernel-Methods");
- $globals.MethodContext.comment="I hold all the dynamic state associated with the execution of either a method activation resulting from a message send. I am used to build the call stack while debugging.\x0a\x0aMy instances are JavaScript `SmalltalkMethodContext` objects defined in `boot.js`.";
- $core.addMethod(
- $core.method({
- selector: "asString",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$5,$7,$6,$4,$11,$10,$9,$8,$12,$16,$15,$14,$13,$1;
- $2=self._isBlockContext();
- if($core.assert($2)){
- $3="a block (in ".__comma($recv(self._methodContext())._asString());
- $ctx1.sendIdx[","]=2;
- $1=$recv($3).__comma(")");
- $ctx1.sendIdx[","]=1;
- } else {
- var methodClass;
- methodClass=$recv(self._method())._methodClass();
- methodClass;
- $5=methodClass;
- $7=self._receiver();
- $ctx1.sendIdx["receiver"]=1;
- $6=$recv($7)._class();
- $ctx1.sendIdx["class"]=1;
- $4=$recv($5).__eq($6);
- if($core.assert($4)){
- $11=self._receiver();
- $ctx1.sendIdx["receiver"]=2;
- $10=$recv($11)._class();
- $ctx1.sendIdx["class"]=2;
- $9=$recv($10)._name();
- $ctx1.sendIdx["name"]=1;
- $8=$recv($9).__comma(" >> ");
- $ctx1.sendIdx[","]=4;
- $12=self._selector();
- $ctx1.sendIdx["selector"]=1;
- $1=$recv($8).__comma($12);
- $ctx1.sendIdx[","]=3;
- } else {
- $16=$recv($recv(self._receiver())._class())._name();
- $ctx1.sendIdx["name"]=2;
- $15=$recv($16).__comma("(");
- $14=$recv($15).__comma($recv(methodClass)._name());
- $ctx1.sendIdx[","]=7;
- $13=$recv($14).__comma(") >> ");
- $ctx1.sendIdx[","]=6;
- $1=$recv($13).__comma(self._selector());
- $ctx1.sendIdx[","]=5;
- }
- }
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asString",{},$globals.MethodContext)});
- },
- args: [],
- source: "asString\x0a\x09^ self isBlockContext\x0a\x09\x09ifTrue: [ 'a block (in ', self methodContext asString, ')' ]\x0a\x09\x09ifFalse: [ \x0a\x09\x09\x09| methodClass |\x0a\x09\x09\x09methodClass := self method methodClass.\x0a\x09\x09\x09methodClass = self receiver class \x0a\x09\x09\x09\x09ifTrue: [ self receiver class name, ' >> ', self selector ]\x0a\x09\x09\x09\x09ifFalse: [ self receiver class name, '(', methodClass name, ') >> ', self selector ] ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "isBlockContext", ",", "asString", "methodContext", "methodClass", "method", "=", "class", "receiver", "name", "selector"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "basicReceiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.receiver;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicReceiver",{},$globals.MethodContext)});
- },
- args: [],
- source: "basicReceiver\x0a\x09<inlineJS: 'return self.receiver'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "evaluatedSelector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.evaluatedSelector;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"evaluatedSelector",{},$globals.MethodContext)});
- },
- args: [],
- source: "evaluatedSelector\x0a\x09<inlineJS: 'return self.evaluatedSelector'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "findContextSuchThat:",
- protocol: "accessing",
- fn: function (testBlock){
- var self=this;
- var context;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- context=self;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(context)._isNil();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- $1=$recv(testBlock)._value_(context);
- if($core.assert($1)){
- throw $early=[context];
- }
- context=$recv(context)._outerContext();
- return context;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return nil;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"findContextSuchThat:",{testBlock:testBlock,context:context},$globals.MethodContext)});
- },
- args: ["testBlock"],
- source: "findContextSuchThat: testBlock\x0a\x09\x22Search self and my sender chain for first one that satisfies `testBlock`. \x0a\x09Answer `nil` if none satisfy\x22\x0a\x0a\x09| context |\x0a\x09\x0a\x09context := self.\x0a\x09[ context isNil] whileFalse: [\x0a\x09\x09(testBlock value: context) \x0a\x09\x09\x09ifTrue: [ ^ context ].\x0a\x09\x09context := context outerContext ].\x0a\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: ["whileFalse:", "isNil", "ifTrue:", "value:", "outerContext"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "home",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.homeContext;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"home",{},$globals.MethodContext)});
- },
- args: [],
- source: "home\x0a\x09<inlineJS: 'return self.homeContext'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "index",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.index || 0;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"index",{},$globals.MethodContext)});
- },
- args: [],
- source: "index\x0a\x09<inlineJS: 'return self.index || 0'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "isBlockContext",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._selector())._isNil();
- }, function($ctx1) {$ctx1.fill(self,"isBlockContext",{},$globals.MethodContext)});
- },
- args: [],
- source: "isBlockContext\x0a\x09\x22Block context do not have selectors.\x22\x0a\x09\x0a\x09^ self selector isNil",
- referencedClasses: [],
- messageSends: ["isNil", "selector"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "locals",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.locals || {};
- return self;
- }, function($ctx1) {$ctx1.fill(self,"locals",{},$globals.MethodContext)});
- },
- args: [],
- source: "locals\x0a\x09<inlineJS: 'return self.locals || {}'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- var method,lookupClass,receiverClass,supercall;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$6,$5,$7,$8,$receiver;
- $1=self._methodContext();
- $ctx1.sendIdx["methodContext"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return nil;
- } else {
- $1;
- }
- $3=self._methodContext();
- $ctx1.sendIdx["methodContext"]=2;
- $2=$recv($3)._receiver();
- receiverClass=$recv($2)._class();
- $4=receiverClass;
- $6=self._methodContext();
- $ctx1.sendIdx["methodContext"]=3;
- $5=$recv($6)._selector();
- $ctx1.sendIdx["selector"]=1;
- method=$recv($4)._lookupSelector_($5);
- $ctx1.sendIdx["lookupSelector:"]=1;
- $7=self._outerContext();
- if(($receiver = $7) == null || $receiver.isNil){
- supercall=false;
- } else {
- var outer;
- outer=$receiver;
- supercall=$recv(outer)._supercall();
- }
- $8=supercall;
- if($core.assert($8)){
- return $recv($recv($recv(method)._methodClass())._superclass())._lookupSelector_($recv(self._methodContext())._selector());
- } else {
- return method;
- }
- }, function($ctx1) {$ctx1.fill(self,"method",{method:method,lookupClass:lookupClass,receiverClass:receiverClass,supercall:supercall},$globals.MethodContext)});
- },
- args: [],
- source: "method\x0a\x09| method lookupClass receiverClass supercall |\x0a\x09\x0a\x09self methodContext ifNil: [ ^ nil ].\x0a\x0a\x09receiverClass := self methodContext receiver class.\x0a\x09method := receiverClass lookupSelector: self methodContext selector.\x0a\x09supercall := self outerContext \x0a\x09\x09ifNil: [ false ]\x0a\x09\x09ifNotNil: [ :outer | outer supercall ].\x0a\x0a\x09^ supercall\x0a\x09\x09ifFalse: [ method ]\x0a\x09\x09ifTrue: [ method methodClass superclass lookupSelector: self methodContext selector ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "methodContext", "class", "receiver", "lookupSelector:", "selector", "ifNil:ifNotNil:", "outerContext", "supercall", "ifFalse:ifTrue:", "superclass", "methodClass"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "methodContext",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=self._isBlockContext();
- if(!$core.assert($1)){
- return self;
- }
- $2=self._outerContext();
- if(($receiver = $2) == null || $receiver.isNil){
- return $2;
- } else {
- var outer;
- outer=$receiver;
- return $recv(outer)._methodContext();
- }
- }, function($ctx1) {$ctx1.fill(self,"methodContext",{},$globals.MethodContext)});
- },
- args: [],
- source: "methodContext\x0a\x09self isBlockContext ifFalse: [ ^ self ].\x0a\x09\x0a\x09^ self outerContext ifNotNil: [ :outer |\x0a\x09\x09outer methodContext ]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "isBlockContext", "ifNotNil:", "outerContext", "methodContext"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "outerContext",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.outerContext || self.homeContext;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"outerContext",{},$globals.MethodContext)});
- },
- args: [],
- source: "outerContext\x0a\x09<inlineJS: 'return self.outerContext || self.homeContext'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.MethodContext.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $recv(aStream)._nextPutAll_("(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._nextPutAll_(self._asString());
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.MethodContext)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream \x0a\x09\x09nextPutAll: '(';\x0a\x09\x09nextPutAll: self asString;\x0a\x09\x09nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "asString"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $1=$recv(self._isBlockContext())._and_((function(){
- return $core.withContext(function($ctx2) {
- $2=self._outerContext();
- $ctx2.sendIdx["outerContext"]=1;
- return $recv($2)._notNil();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- if($core.assert($1)){
- return $recv(self._outerContext())._receiver();
- } else {
- return self._basicReceiver();
- }
- }, function($ctx1) {$ctx1.fill(self,"receiver",{},$globals.MethodContext)});
- },
- args: [],
- source: "receiver\x0a\x09^ (self isBlockContext and: [ self outerContext notNil ])\x0a\x09\x09ifTrue: [ self outerContext receiver ]\x0a\x09\x09ifFalse: [ self basicReceiver ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "and:", "isBlockContext", "notNil", "outerContext", "receiver", "basicReceiver"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- if(self.selector) {
- return $core.js2st(self.selector);
- } else {
- return nil;
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"selector",{},$globals.MethodContext)});
- },
- args: [],
- source: "selector\x0a\x09<inlineJS: '\x0a\x09\x09if(self.selector) {\x0a\x09\x09\x09return $core.js2st(self.selector);\x0a\x09\x09} else {\x0a\x09\x09\x09return nil;\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "sendIndexAt:",
- protocol: "accessing",
- fn: function (aSelector){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.sendIdx[aSelector] || 0;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sendIndexAt:",{aSelector:aSelector},$globals.MethodContext)});
- },
- args: ["aSelector"],
- source: "sendIndexAt: aSelector\x0a\x09<inlineJS: 'return self.sendIdx[aSelector] || 0'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "sendIndexes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.sendIdx;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sendIndexes",{},$globals.MethodContext)});
- },
- args: [],
- source: "sendIndexes\x0a\x09<inlineJS: 'return self.sendIdx'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "supercall",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.supercall == true;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"supercall",{},$globals.MethodContext)});
- },
- args: [],
- source: "supercall\x0a\x09<inlineJS: 'return self.supercall == true'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodContext);
- $core.addClass("NativeFunction", $globals.Object, [], "Kernel-Methods");
- $globals.NativeFunction.comment="I am a wrapper around native functions, such as `WebSocket`.\x0aFor 'normal' functions (whose constructor is the JavaScript `Function` object), use `BlockClosure`.\x0a\x0a## API\x0a\x0aSee the class-side `instance creation` methods for instance creation.\x0a\x0aCreated instances will most probably be instance of `JSObjectProxy`.\x0a\x0a## Usage example:\x0a\x0a\x09| ws |\x0a\x09ws := NativeFunction constructor: 'WebSocket' value: 'ws://localhost'.\x0a\x09ws at: 'onopen' put: [ ws send: 'hey there from Amber' ]";
- $core.addMethod(
- $core.method({
- selector: "constructorNamed:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return new nativeFunc();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorNamed:",{aString:aString},$globals.NativeFunction.klass)});
- },
- args: ["aString"],
- source: "constructorNamed: aString\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return new nativeFunc();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "constructorNamed:value:",
- protocol: "instance creation",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return new nativeFunc(anObject);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorNamed:value:",{aString:aString,anObject:anObject},$globals.NativeFunction.klass)});
- },
- args: ["aString", "anObject"],
- source: "constructorNamed: aString value: anObject\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return new nativeFunc(anObject);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "constructorNamed:value:value:",
- protocol: "instance creation",
- fn: function (aString,anObject,anObject2){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return new nativeFunc(anObject,anObject2);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorNamed:value:value:",{aString:aString,anObject:anObject,anObject2:anObject2},$globals.NativeFunction.klass)});
- },
- args: ["aString", "anObject", "anObject2"],
- source: "constructorNamed: aString value: anObject value: anObject2\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return new nativeFunc(anObject,anObject2);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "constructorNamed:value:value:value:",
- protocol: "instance creation",
- fn: function (aString,anObject,anObject2,anObject3){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return new nativeFunc(anObject,anObject2, anObject3);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorNamed:value:value:value:",{aString:aString,anObject:anObject,anObject2:anObject2,anObject3:anObject3},$globals.NativeFunction.klass)});
- },
- args: ["aString", "anObject", "anObject2", "anObject3"],
- source: "constructorNamed: aString value: anObject value: anObject2 value: anObject3\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return new nativeFunc(anObject,anObject2, anObject3);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "constructorOf:",
- protocol: "instance creation",
- fn: function (nativeFunc){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new nativeFunc();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorOf:",{nativeFunc:nativeFunc},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc"],
- source: "constructorOf: nativeFunc\x0a\x09<inlineJS: '\x0a\x09\x09return new nativeFunc();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "constructorOf:value:",
- protocol: "instance creation",
- fn: function (nativeFunc,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new nativeFunc(anObject);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorOf:value:",{nativeFunc:nativeFunc,anObject:anObject},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "anObject"],
- source: "constructorOf: nativeFunc value: anObject\x0a\x09<inlineJS: '\x0a\x09\x09return new nativeFunc(anObject);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "constructorOf:value:value:",
- protocol: "instance creation",
- fn: function (nativeFunc,anObject,anObject2){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new nativeFunc(anObject,anObject2);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorOf:value:value:",{nativeFunc:nativeFunc,anObject:anObject,anObject2:anObject2},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "anObject", "anObject2"],
- source: "constructorOf: nativeFunc value: anObject value: anObject2\x0a\x09<inlineJS: '\x0a\x09\x09return new nativeFunc(anObject,anObject2);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "constructorOf:value:value:value:",
- protocol: "instance creation",
- fn: function (nativeFunc,anObject,anObject2,anObject3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new nativeFunc(anObject,anObject2, anObject3);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"constructorOf:value:value:value:",{nativeFunc:nativeFunc,anObject:anObject,anObject2:anObject2,anObject3:anObject3},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "anObject", "anObject2", "anObject3"],
- source: "constructorOf: nativeFunc value: anObject value: anObject2 value: anObject3\x0a\x09<inlineJS: '\x0a\x09\x09return new nativeFunc(anObject,anObject2, anObject3);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "exists:",
- protocol: "testing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._existsJsGlobal_(aString);
- }, function($ctx1) {$ctx1.fill(self,"exists:",{aString:aString},$globals.NativeFunction.klass)});
- },
- args: ["aString"],
- source: "exists: aString\x0a\x09^ Smalltalk existsJsGlobal: aString",
- referencedClasses: ["Smalltalk"],
- messageSends: ["existsJsGlobal:"]
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionNamed:",
- protocol: "function calling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return nativeFunc();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionNamed:",{aString:aString},$globals.NativeFunction.klass)});
- },
- args: ["aString"],
- source: "functionNamed: aString\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return nativeFunc();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionNamed:value:",
- protocol: "function calling",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return nativeFunc(anObject);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionNamed:value:",{aString:aString,anObject:anObject},$globals.NativeFunction.klass)});
- },
- args: ["aString", "anObject"],
- source: "functionNamed: aString value: anObject\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return nativeFunc(anObject);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionNamed:value:value:",
- protocol: "function calling",
- fn: function (aString,anObject,anObject2){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return nativeFunc(anObject,anObject2);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionNamed:value:value:",{aString:aString,anObject:anObject,anObject2:anObject2},$globals.NativeFunction.klass)});
- },
- args: ["aString", "anObject", "anObject2"],
- source: "functionNamed: aString value: anObject value: anObject2\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return nativeFunc(anObject,anObject2);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionNamed:value:value:value:",
- protocol: "function calling",
- fn: function (aString,anObject,anObject2,anObject3){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return nativeFunc(anObject,anObject2, anObject3);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionNamed:value:value:value:",{aString:aString,anObject:anObject,anObject2:anObject2,anObject3:anObject3},$globals.NativeFunction.klass)});
- },
- args: ["aString", "anObject", "anObject2", "anObject3"],
- source: "functionNamed: aString value: anObject value: anObject2 value: anObject3\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return nativeFunc(anObject,anObject2, anObject3);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionNamed:valueWithArgs:",
- protocol: "function calling",
- fn: function (aString,args){
- var self=this;
- return $core.withContext(function($ctx1) {
- var nativeFunc=(new Function('return this'))()[aString];
- return Function.prototype.apply.call(nativeFunc, null, args);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionNamed:valueWithArgs:",{aString:aString,args:args},$globals.NativeFunction.klass)});
- },
- args: ["aString", "args"],
- source: "functionNamed: aString valueWithArgs: args\x0a\x09<inlineJS: '\x0a\x09\x09var nativeFunc=(new Function(''return this''))()[aString];\x0a\x09\x09return Function.prototype.apply.call(nativeFunc, null, args);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionOf:",
- protocol: "function calling",
- fn: function (nativeFunc){
- var self=this;
- return $core.withContext(function($ctx1) {
- return nativeFunc();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionOf:",{nativeFunc:nativeFunc},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc"],
- source: "functionOf: nativeFunc\x0a\x09<inlineJS: '\x0a\x09\x09return nativeFunc();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionOf:value:",
- protocol: "function calling",
- fn: function (nativeFunc,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return nativeFunc(anObject);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionOf:value:",{nativeFunc:nativeFunc,anObject:anObject},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "anObject"],
- source: "functionOf: nativeFunc value: anObject\x0a\x09<inlineJS: '\x0a\x09\x09return nativeFunc(anObject);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionOf:value:value:",
- protocol: "function calling",
- fn: function (nativeFunc,anObject,anObject2){
- var self=this;
- return $core.withContext(function($ctx1) {
- return nativeFunc(anObject,anObject2);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionOf:value:value:",{nativeFunc:nativeFunc,anObject:anObject,anObject2:anObject2},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "anObject", "anObject2"],
- source: "functionOf: nativeFunc value: anObject value: anObject2\x0a\x09<inlineJS: '\x0a\x09\x09return nativeFunc(anObject,anObject2);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionOf:value:value:value:",
- protocol: "function calling",
- fn: function (nativeFunc,anObject,anObject2,anObject3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return nativeFunc(anObject,anObject2, anObject3);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionOf:value:value:value:",{nativeFunc:nativeFunc,anObject:anObject,anObject2:anObject2,anObject3:anObject3},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "anObject", "anObject2", "anObject3"],
- source: "functionOf: nativeFunc value: anObject value: anObject2 value: anObject3\x0a\x09<inlineJS: '\x0a\x09\x09return nativeFunc(anObject,anObject2, anObject3);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "functionOf:valueWithArgs:",
- protocol: "function calling",
- fn: function (nativeFunc,args){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Function.prototype.apply.call(nativeFunc, null, args);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"functionOf:valueWithArgs:",{nativeFunc:nativeFunc,args:args},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "args"],
- source: "functionOf: nativeFunc valueWithArgs: args\x0a\x09<inlineJS: '\x0a\x09\x09return Function.prototype.apply.call(nativeFunc, null, args);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "methodOf:this:",
- protocol: "method calling",
- fn: function (nativeFunc,thisObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Function.prototype.call.call(nativeFunc, thisObject);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"methodOf:this:",{nativeFunc:nativeFunc,thisObject:thisObject},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "thisObject"],
- source: "methodOf: nativeFunc this: thisObject\x0a\x09<inlineJS: '\x0a\x09\x09return Function.prototype.call.call(nativeFunc, thisObject);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "methodOf:this:value:",
- protocol: "method calling",
- fn: function (nativeFunc,thisObject,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Function.prototype.call.call(nativeFunc, thisObject, anObject);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"methodOf:this:value:",{nativeFunc:nativeFunc,thisObject:thisObject,anObject:anObject},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "thisObject", "anObject"],
- source: "methodOf: nativeFunc this: thisObject value: anObject\x0a\x09<inlineJS: '\x0a\x09\x09return Function.prototype.call.call(nativeFunc, thisObject, anObject);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "methodOf:this:value:value:",
- protocol: "method calling",
- fn: function (nativeFunc,thisObject,anObject,anObject2){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Function.prototype.call.call(nativeFunc, thisObject,anObject,anObject2);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"methodOf:this:value:value:",{nativeFunc:nativeFunc,thisObject:thisObject,anObject:anObject,anObject2:anObject2},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "thisObject", "anObject", "anObject2"],
- source: "methodOf: nativeFunc this: thisObject value: anObject value: anObject2\x0a\x09<inlineJS: '\x0a\x09\x09return Function.prototype.call.call(nativeFunc, thisObject,anObject,anObject2);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "methodOf:this:value:value:value:",
- protocol: "method calling",
- fn: function (nativeFunc,thisObject,anObject,anObject2,anObject3){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Function.prototype.call.call(nativeFunc, thisObject,anObject,anObject2, anObject3);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"methodOf:this:value:value:value:",{nativeFunc:nativeFunc,thisObject:thisObject,anObject:anObject,anObject2:anObject2,anObject3:anObject3},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "thisObject", "anObject", "anObject2", "anObject3"],
- source: "methodOf: nativeFunc this: thisObject value: anObject value: anObject2 value: anObject3\x0a\x09<inlineJS: '\x0a\x09\x09return Function.prototype.call.call(nativeFunc, thisObject,anObject,anObject2, anObject3);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addMethod(
- $core.method({
- selector: "methodOf:this:valueWithArgs:",
- protocol: "method calling",
- fn: function (nativeFunc,thisObject,args){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Function.prototype.apply.call(nativeFunc, thisObject, args);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"methodOf:this:valueWithArgs:",{nativeFunc:nativeFunc,thisObject:thisObject,args:args},$globals.NativeFunction.klass)});
- },
- args: ["nativeFunc", "thisObject", "args"],
- source: "methodOf: nativeFunc this: thisObject valueWithArgs: args\x0a\x09<inlineJS: '\x0a\x09\x09return Function.prototype.apply.call(nativeFunc, thisObject, args);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NativeFunction.klass);
- $core.addClass("Timeout", $globals.Object, ["rawTimeout"], "Kernel-Methods");
- $globals.Timeout.comment="I am wrapping the returns from `set{Timeout,Interval}`.\x0a\x0a## Motivation\x0a\x0aNumber suffices in browsers, but node.js returns an object.";
- $core.addMethod(
- $core.method({
- selector: "clearInterval",
- protocol: "timeout/interval",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var interval = self["@rawTimeout"];
- clearInterval(interval);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"clearInterval",{},$globals.Timeout)});
- },
- args: [],
- source: "clearInterval\x0a\x09<inlineJS: '\x0a\x09\x09var interval = self[\x22@rawTimeout\x22];\x0a\x09\x09clearInterval(interval);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Timeout);
- $core.addMethod(
- $core.method({
- selector: "clearTimeout",
- protocol: "timeout/interval",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var timeout = self["@rawTimeout"];
- clearTimeout(timeout);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"clearTimeout",{},$globals.Timeout)});
- },
- args: [],
- source: "clearTimeout\x0a\x09<inlineJS: '\x0a\x09\x09var timeout = self[\x22@rawTimeout\x22];\x0a\x09\x09clearTimeout(timeout);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Timeout);
- $core.addMethod(
- $core.method({
- selector: "rawTimeout:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@rawTimeout"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "rawTimeout: anObject\x0a\x09rawTimeout := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Timeout);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._rawTimeout_(anObject);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{anObject:anObject},$globals.Timeout.klass)});
- },
- args: ["anObject"],
- source: "on: anObject\x0a\x09^ self new rawTimeout: anObject; yourself",
- referencedClasses: [],
- messageSends: ["rawTimeout:", "new", "yourself"]
- }),
- $globals.Timeout.klass);
- });
- define('amber_core/Kernel-Dag',["amber/boot", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Dag");
- $core.packages["Kernel-Dag"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Dag"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("AbstractDagVisitor", $globals.Object, [], "Kernel-Dag");
- $globals.AbstractDagVisitor.comment="I am base class of `DagNode` visitor.\x0a\x0aConcrete classes should implement `visitDagNode:`,\x0athey can reuse possible variants of implementation\x0aoffered directly: `visitDagNodeVariantSimple:`\x0aand `visitDagNodeVariantRedux:`.";
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "evaluating",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visit_(anObject);
- }, function($ctx1) {$ctx1.fill(self,"value:",{anObject:anObject},$globals.AbstractDagVisitor)});
- },
- args: ["anObject"],
- source: "value: anObject\x0a\x09^ self visit: anObject",
- referencedClasses: [],
- messageSends: ["visit:"]
- }),
- $globals.AbstractDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visit:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aNode)._acceptDagVisitor_(self);
- }, function($ctx1) {$ctx1.fill(self,"visit:",{aNode:aNode},$globals.AbstractDagVisitor)});
- },
- args: ["aNode"],
- source: "visit: aNode\x0a\x09^ aNode acceptDagVisitor: self",
- referencedClasses: [],
- messageSends: ["acceptDagVisitor:"]
- }),
- $globals.AbstractDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitAll:",
- protocol: "visiting",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aCollection)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return self._visit_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"visitAll:",{aCollection:aCollection},$globals.AbstractDagVisitor)});
- },
- args: ["aCollection"],
- source: "visitAll: aCollection\x0a\x09^ aCollection collect: [ :each | self visit: each ]",
- referencedClasses: [],
- messageSends: ["collect:", "visit:"]
- }),
- $globals.AbstractDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitAllChildren:",
- protocol: "visiting",
- fn: function (aDagNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitAll_($recv(aDagNode)._dagChildren());
- }, function($ctx1) {$ctx1.fill(self,"visitAllChildren:",{aDagNode:aDagNode},$globals.AbstractDagVisitor)});
- },
- args: ["aDagNode"],
- source: "visitAllChildren: aDagNode\x0a\x09^ self visitAll: aDagNode dagChildren",
- referencedClasses: [],
- messageSends: ["visitAll:", "dagChildren"]
- }),
- $globals.AbstractDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitDagNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitDagNode:",{aNode:aNode},$globals.AbstractDagVisitor)});
- },
- args: ["aNode"],
- source: "visitDagNode: aNode\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AbstractDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitDagNodeVariantRedux:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var newChildren,oldChildren;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$4,$5;
- var $early={};
- try {
- oldChildren=$recv(aNode)._dagChildren();
- newChildren=self._visitAllChildren_(aNode);
- $2=$recv(oldChildren)._size();
- $ctx1.sendIdx["size"]=1;
- $3=$recv(newChildren)._size();
- $ctx1.sendIdx["size"]=2;
- $1=$recv($2).__eq($3);
- if($core.assert($1)){
- $recv((1)._to_($recv(oldChildren)._size()))._detect_ifNone_((function(i){
- return $core.withContext(function($ctx2) {
- $4=$recv(oldChildren)._at_(i);
- $ctx2.sendIdx["at:"]=1;
- return $recv($4).__tild_eq($recv(newChildren)._at_(i));
- }, function($ctx2) {$ctx2.fillBlock({i:i},$ctx1,2)});
- }),(function(){
- throw $early=[aNode];
- }));
- }
- $5=$recv(aNode)._copy();
- $recv($5)._dagChildren_(newChildren);
- return $recv($5)._yourself();
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"visitDagNodeVariantRedux:",{aNode:aNode,newChildren:newChildren,oldChildren:oldChildren},$globals.AbstractDagVisitor)});
- },
- args: ["aNode"],
- source: "visitDagNodeVariantRedux: aNode\x0a\x09\x22Immutable-guarded implementation of visitDagNode:.\x0a\x09Visits all children and checks if there were changes.\x0a\x09If not, returns aNode.\x0a\x09If yes, returns copy of aNode with new children.\x22\x0a\x0a\x09| newChildren oldChildren |\x0a\x09oldChildren := aNode dagChildren.\x0a\x09newChildren := self visitAllChildren: aNode.\x0a\x09oldChildren size = newChildren size ifTrue: [\x0a\x09\x09(1 to: oldChildren size) detect: [ :i |\x0a\x09\x09\x09(oldChildren at: i) ~= (newChildren at: i)\x0a\x09\x09] ifNone: [ \x22no change\x22 ^ aNode ] ].\x0a\x09^ aNode copy dagChildren: newChildren; yourself",
- referencedClasses: [],
- messageSends: ["dagChildren", "visitAllChildren:", "ifTrue:", "=", "size", "detect:ifNone:", "to:", "~=", "at:", "dagChildren:", "copy", "yourself"]
- }),
- $globals.AbstractDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitDagNodeVariantSimple:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._visitAllChildren_(aNode);
- return aNode;
- }, function($ctx1) {$ctx1.fill(self,"visitDagNodeVariantSimple:",{aNode:aNode},$globals.AbstractDagVisitor)});
- },
- args: ["aNode"],
- source: "visitDagNodeVariantSimple: aNode\x0a\x09\x22Simple implementation of visitDagNode:.\x0a\x09Visits children, then returns aNode\x22\x0a\x0a\x09self visitAllChildren: aNode.\x0a\x09^ aNode",
- referencedClasses: [],
- messageSends: ["visitAllChildren:"]
- }),
- $globals.AbstractDagVisitor);
- $core.addClass("PathDagVisitor", $globals.AbstractDagVisitor, ["path"], "Kernel-Dag");
- $globals.PathDagVisitor.comment="I am base class of `DagNode` visitor.\x0a\x0aI hold the path of ancestors up to actual node\x0ain `self path`.";
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.PathDagVisitor.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@path"]=[];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.PathDagVisitor)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x0a\x09path := #()",
- referencedClasses: [],
- messageSends: ["initialize"]
- }),
- $globals.PathDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "path",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@path"];
- },
- args: [],
- source: "path\x0a\x09^ path",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PathDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visit:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var oldPath,result;
- return $core.withContext(function($ctx1) {
- result=aNode;
- oldPath=self["@path"];
- $recv((function(){
- return $core.withContext(function($ctx2) {
- self["@path"]=$recv(self["@path"]).__comma([aNode]);
- self["@path"];
- result=(
- $ctx2.supercall = true,
- ($globals.PathDagVisitor.superclass||$boot.nilAsClass).fn.prototype._visit_.apply($recv(self), [aNode]));
- $ctx2.supercall = false;
- return result;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._ensure_((function(){
- self["@path"]=oldPath;
- return self["@path"];
- }));
- return result;
- }, function($ctx1) {$ctx1.fill(self,"visit:",{aNode:aNode,oldPath:oldPath,result:result},$globals.PathDagVisitor)});
- },
- args: ["aNode"],
- source: "visit: aNode\x0a\x09| oldPath result |\x0a\x09result := aNode.\x0a\x09oldPath := path.\x0a\x09[\x0a\x09\x09path := path, {aNode}.\x0a\x09\x09result := super visit: aNode\x0a\x09] ensure: [ path := oldPath ].\x0a\x09^ result",
- referencedClasses: [],
- messageSends: ["ensure:", ",", "visit:"]
- }),
- $globals.PathDagVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitDagNodeVariantRedux:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var newNode;
- return $core.withContext(function($ctx1) {
- var $1;
- newNode=(
- $ctx1.supercall = true,
- ($globals.PathDagVisitor.superclass||$boot.nilAsClass).fn.prototype._visitDagNodeVariantRedux_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- $1=$recv(aNode).__eq_eq(newNode);
- if(!$core.assert($1)){
- $recv(self["@path"])._at_put_($recv(self["@path"])._size(),newNode);
- }
- return newNode;
- }, function($ctx1) {$ctx1.fill(self,"visitDagNodeVariantRedux:",{aNode:aNode,newNode:newNode},$globals.PathDagVisitor)});
- },
- args: ["aNode"],
- source: "visitDagNodeVariantRedux: aNode\x0a\x09| newNode |\x0a\x09newNode := super visitDagNodeVariantRedux: aNode.\x0a\x09aNode == newNode ifFalse: [ path at: path size put: newNode ].\x0a\x09^ newNode",
- referencedClasses: [],
- messageSends: ["visitDagNodeVariantRedux:", "ifFalse:", "==", "at:put:", "size"]
- }),
- $globals.PathDagVisitor);
- $core.addClass("DagNode", $globals.Object, [], "Kernel-Dag");
- $globals.DagNode.comment="I am the abstract root class of any directed acyclic graph.\x0a\x0aConcrete classes should implement `dagChildren` and `dagChildren:`\x0ato get / set direct successor nodes (aka child nodes / subnodes).";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitDagNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.DagNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitDagNode: self",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.DagNode);
- $core.addMethod(
- $core.method({
- selector: "allDagChildren",
- protocol: "accessing",
- fn: function (){
- var self=this;
- var allNodes;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- allNodes=$recv($1)._asSet();
- $recv(self._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(allNodes)._addAll_($recv(each)._allDagChildren());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return allNodes;
- }, function($ctx1) {$ctx1.fill(self,"allDagChildren",{allNodes:allNodes},$globals.DagNode)});
- },
- args: [],
- source: "allDagChildren\x0a\x09| allNodes |\x0a\x09\x0a\x09allNodes := self dagChildren asSet.\x0a\x09self dagChildren do: [ :each | \x0a\x09\x09allNodes addAll: each allDagChildren ].\x0a\x09\x0a\x09^ allNodes",
- referencedClasses: [],
- messageSends: ["asSet", "dagChildren", "do:", "addAll:", "allDagChildren"]
- }),
- $globals.DagNode);
- $core.addMethod(
- $core.method({
- selector: "dagChildren",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dagChildren",{},$globals.DagNode)});
- },
- args: [],
- source: "dagChildren\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.DagNode);
- $core.addMethod(
- $core.method({
- selector: "dagChildren:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dagChildren:",{aCollection:aCollection},$globals.DagNode)});
- },
- args: ["aCollection"],
- source: "dagChildren: aCollection\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.DagNode);
- $core.addMethod(
- $core.method({
- selector: "isDagNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isDagNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.DagNode);
- $core.addClass("DagParentNode", $globals.DagNode, ["nodes"], "Kernel-Dag");
- $globals.DagParentNode.comment="I am `DagNode` that stores a collection of its children,\x0alazy initialized to empty array.\x0a\x0aI can `addDagChild:` to add a child.";
- $core.addMethod(
- $core.method({
- selector: "addDagChild:",
- protocol: "accessing",
- fn: function (aDagNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._dagChildren())._add_(aDagNode);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addDagChild:",{aDagNode:aDagNode},$globals.DagParentNode)});
- },
- args: ["aDagNode"],
- source: "addDagChild: aDagNode\x0a\x09self dagChildren add: aDagNode",
- referencedClasses: [],
- messageSends: ["add:", "dagChildren"]
- }),
- $globals.DagParentNode);
- $core.addMethod(
- $core.method({
- selector: "dagChildren",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@nodes"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@nodes"]=$recv($globals.Array)._new();
- return self["@nodes"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"dagChildren",{},$globals.DagParentNode)});
- },
- args: [],
- source: "dagChildren\x0a\x09^ nodes ifNil: [ nodes := Array new ]",
- referencedClasses: ["Array"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.DagParentNode);
- $core.addMethod(
- $core.method({
- selector: "dagChildren:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@nodes"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "dagChildren: aCollection\x0a\x09nodes := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.DagParentNode);
- $core.addClass("DagSink", $globals.DagNode, ["nodes"], "Kernel-Dag");
- $globals.DagSink.comment="I am `DagNode` with no direct successors.\x0a\x0aSending `dagChildren:` with empty collection is legal.";
- $core.addMethod(
- $core.method({
- selector: "dagChildren",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return [];
- },
- args: [],
- source: "dagChildren\x0a\x09^ #()",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.DagSink);
- $core.addMethod(
- $core.method({
- selector: "dagChildren:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aCollection)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return self._error_("A DagSink cannot have children.");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dagChildren:",{aCollection:aCollection},$globals.DagSink)});
- },
- args: ["aCollection"],
- source: "dagChildren: aCollection\x0a\x09aCollection ifNotEmpty: [ self error: 'A DagSink cannot have children.' ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "error:"]
- }),
- $globals.DagSink);
- $core.addMethod(
- $core.method({
- selector: "isDagNode",
- protocol: "*Kernel-Dag",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isDagNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Object);
- });
- define('amber_core/Kernel-Exceptions',["amber/boot", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Exceptions");
- $core.packages["Kernel-Exceptions"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Exceptions"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("Error", $globals.Object, ["messageText"], "Kernel-Exceptions");
- $globals.Error.comment="From the ANSI standard:\x0a\x0aThis protocol describes the behavior of instances of class `Error`.\x0aThese are used to represent error conditions that prevent the normal continuation of processing.\x0aActual error exceptions used by an application may be subclasses of this class.\x0aAs `Error` is explicitly specified to be subclassable, conforming implementations must implement its behavior in a non-fragile manner.";
- $core.addMethod(
- $core.method({
- selector: "beHandled",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.amberHandled = true;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"beHandled",{},$globals.Error)});
- },
- args: [],
- source: "beHandled\x0a\x09<inlineJS: 'self.amberHandled = true'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "beUnhandled",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.amberHandled = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"beUnhandled",{},$globals.Error)});
- },
- args: [],
- source: "beUnhandled\x0a\x09<inlineJS: 'self.amberHandled = false'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "context",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.context;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"context",{},$globals.Error)});
- },
- args: [],
- source: "context\x0a\x09<inlineJS: 'return self.context'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._messageText_("Errorclass: ".__comma($recv(self._class())._name()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Error)});
- },
- args: [],
- source: "initialize\x0a\x09self messageText: 'Errorclass: ', (self class name).",
- referencedClasses: [],
- messageSends: ["messageText:", ",", "name", "class"]
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "isSmalltalkError",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.smalltalkError === true;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"isSmalltalkError",{},$globals.Error)});
- },
- args: [],
- source: "isSmalltalkError\x0a\x09<inlineJS: 'return self.smalltalkError === true'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "jsStack",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.stack;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"jsStack",{},$globals.Error)});
- },
- args: [],
- source: "jsStack\x0a\x09<inlineJS: 'return self.stack'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "messageText",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@messageText"];
- },
- args: [],
- source: "messageText\x0a\x09^ messageText",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "messageText:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@messageText"]=aString;
- return self;
- },
- args: ["aString"],
- source: "messageText: aString\x0a\x09messageText := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "resignal",
- protocol: "signaling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.amberHandled = false;
- throw(self);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"resignal",{},$globals.Error)});
- },
- args: [],
- source: "resignal\x0a\x09\x22Resignal the receiver without changing its exception context\x22\x0a\x09\x0a\x09<inlineJS: '\x0a\x09\x09self.amberHandled = false;\x0a\x09\x09throw(self);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "signal",
- protocol: "signaling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.amberHandled = false;
- self.context = $core.getThisContext();
- self.smalltalkError = true;
- throw self;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"signal",{},$globals.Error)});
- },
- args: [],
- source: "signal\x0a\x09<inlineJS: '\x0a\x09\x09self.amberHandled = false;\x0a\x09\x09self.context = $core.getThisContext(); \x0a\x09\x09self.smalltalkError = true;\x0a\x09\x09throw self;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "signal:",
- protocol: "signaling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._messageText_(aString);
- self._signal();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"signal:",{aString:aString},$globals.Error)});
- },
- args: ["aString"],
- source: "signal: aString\x0a\x09self messageText: aString.\x0a\x09self signal",
- referencedClasses: [],
- messageSends: ["messageText:", "signal"]
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "signalerContext",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._signalerContextFrom_(self._context());
- }, function($ctx1) {$ctx1.fill(self,"signalerContext",{},$globals.Error)});
- },
- args: [],
- source: "signalerContext\x0a\x09^ self signalerContextFrom: self context",
- referencedClasses: [],
- messageSends: ["signalerContextFrom:", "context"]
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "signalerContextFrom:",
- protocol: "accessing",
- fn: function (aContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- return $recv(aContext)._findContextSuchThat_((function(context){
- return $core.withContext(function($ctx2) {
- $3=$recv(context)._receiver();
- $ctx2.sendIdx["receiver"]=1;
- $2=$recv($3).__eq_eq(self);
- $ctx2.sendIdx["=="]=1;
- $1=$recv($2)._or_((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv(context)._receiver()).__eq_eq(self._class());
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- return $recv($1)._not();
- }, function($ctx2) {$ctx2.fillBlock({context:context},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"signalerContextFrom:",{aContext:aContext},$globals.Error)});
- },
- args: ["aContext"],
- source: "signalerContextFrom: aContext\x0a\x09\x22Find the first sender of signal(:), the first context which is neither \x0a\x09for an instance method nor for a class side method of Exception (or subclass).\x0a\x09This will make sure that the same context is found for both, `Error signal` \x0a\x09and `Error new signal`\x22\x0a\x0a\x09^ aContext findContextSuchThat: [ :context |\x0a\x09\x09(context receiver == self \x0a\x09\x09or: [ context receiver == self class ]) not ]",
- referencedClasses: [],
- messageSends: ["findContextSuchThat:", "not", "or:", "==", "receiver", "class"]
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "wasHandled",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.amberHandled || false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"wasHandled",{},$globals.Error)});
- },
- args: [],
- source: "wasHandled\x0a\x09<inlineJS: 'return self.amberHandled || false'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "exception";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'exception'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Error.klass);
- $core.addMethod(
- $core.method({
- selector: "signal",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._new())._signal();
- }, function($ctx1) {$ctx1.fill(self,"signal",{},$globals.Error.klass)});
- },
- args: [],
- source: "signal\x0a\x09^ self new signal",
- referencedClasses: [],
- messageSends: ["signal", "new"]
- }),
- $globals.Error.klass);
- $core.addMethod(
- $core.method({
- selector: "signal:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._new())._signal_(aString);
- }, function($ctx1) {$ctx1.fill(self,"signal:",{aString:aString},$globals.Error.klass)});
- },
- args: ["aString"],
- source: "signal: aString\x0a\x09^ self new\x0a\x09\x09signal: aString",
- referencedClasses: [],
- messageSends: ["signal:", "new"]
- }),
- $globals.Error.klass);
- $core.addClass("Halt", $globals.Error, [], "Kernel-Exceptions");
- $globals.Halt.comment="I am provided to support `Object>>#halt`.";
- $core.addMethod(
- $core.method({
- selector: "messageText",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "Halt encountered";
- },
- args: [],
- source: "messageText\x0a\x09^ 'Halt encountered'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Halt);
- $core.addMethod(
- $core.method({
- selector: "signalerContextFrom:",
- protocol: "accessing",
- fn: function (aContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- return $recv(aContext)._findContextSuchThat_((function(context){
- return $core.withContext(function($ctx2) {
- $3=$recv(context)._receiver();
- $ctx2.sendIdx["receiver"]=1;
- $2=$recv($3).__eq_eq(self);
- $ctx2.sendIdx["=="]=1;
- $1=$recv($2)._or_((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv($recv(context)._receiver()).__eq_eq(self._class()))._or_((function(){
- return $core.withContext(function($ctx4) {
- return $recv($recv($recv(context)._method())._selector()).__eq("halt");
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,3)});
- }));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- $ctx2.sendIdx["or:"]=1;
- return $recv($1)._not();
- }, function($ctx2) {$ctx2.fillBlock({context:context},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"signalerContextFrom:",{aContext:aContext},$globals.Halt)});
- },
- args: ["aContext"],
- source: "signalerContextFrom: aContext\x0a\x09\x22specialized version to find the proper context to open the debugger on.\x0a\x09This will find the first context whose method is no longer on `Halt` or \x0a\x09`Halt class` nor is `#halt` method itself.\x22\x0a\x09\x0a\x09^ aContext findContextSuchThat: [ :context |\x0a\x09\x09(context receiver == self \x0a\x09\x09or: [ (context receiver == self class) \x0a\x09\x09or: [ context method selector = #halt ]]) not ]",
- referencedClasses: [],
- messageSends: ["findContextSuchThat:", "not", "or:", "==", "receiver", "class", "=", "selector", "method"]
- }),
- $globals.Halt);
- $core.addClass("JavaScriptException", $globals.Error, ["exception"], "Kernel-Exceptions");
- $globals.JavaScriptException.comment="A JavaScriptException is thrown when a non-Smalltalk exception occurs while in the Smalltalk stack.\x0aSee `boot.js` `inContext()` and `BlockClosure >> on:do:`";
- $core.addMethod(
- $core.method({
- selector: "context:",
- protocol: "accessing",
- fn: function (aMethodContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.context = aMethodContext;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"context:",{aMethodContext:aMethodContext},$globals.JavaScriptException)});
- },
- args: ["aMethodContext"],
- source: "context: aMethodContext\x0a\x09\x22Set the context from the outside.\x0a\x09See boot.js `inContext()` exception handling\x22\x0a\x09\x0a\x09<inlineJS: 'self.context = aMethodContext'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JavaScriptException);
- $core.addMethod(
- $core.method({
- selector: "exception",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@exception"];
- },
- args: [],
- source: "exception\x0a\x09^ exception",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JavaScriptException);
- $core.addMethod(
- $core.method({
- selector: "exception:",
- protocol: "accessing",
- fn: function (anException){
- var self=this;
- self["@exception"]=anException;
- return self;
- },
- args: ["anException"],
- source: "exception: anException\x0a\x09exception := anException",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JavaScriptException);
- $core.addMethod(
- $core.method({
- selector: "messageText",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "JavaScript exception: " + self["@exception"].toString();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"messageText",{},$globals.JavaScriptException)});
- },
- args: [],
- source: "messageText\x0a\x09<inlineJS: 'return \x22JavaScript exception: \x22 + self[\x22@exception\x22].toString()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JavaScriptException);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (anException){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._exception_(anException);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{anException:anException},$globals.JavaScriptException.klass)});
- },
- args: ["anException"],
- source: "on: anException\x0a\x09^ self new\x0a\x09\x09exception: anException;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["exception:", "new", "yourself"]
- }),
- $globals.JavaScriptException.klass);
- $core.addMethod(
- $core.method({
- selector: "on:context:",
- protocol: "instance creation",
- fn: function (anException,aMethodContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._exception_(anException);
- $recv($1)._context_(aMethodContext);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:context:",{anException:anException,aMethodContext:aMethodContext},$globals.JavaScriptException.klass)});
- },
- args: ["anException", "aMethodContext"],
- source: "on: anException context: aMethodContext\x0a\x09^ self new\x0a\x09\x09exception: anException;\x0a\x09\x09context: aMethodContext;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["exception:", "new", "context:", "yourself"]
- }),
- $globals.JavaScriptException.klass);
- $core.addClass("MessageNotUnderstood", $globals.Error, ["message", "receiver"], "Kernel-Exceptions");
- $globals.MessageNotUnderstood.comment="This exception is provided to support `Object>>doesNotUnderstand:`.";
- $core.addMethod(
- $core.method({
- selector: "message",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@message"];
- },
- args: [],
- source: "message\x0a\x09^ message",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MessageNotUnderstood);
- $core.addMethod(
- $core.method({
- selector: "message:",
- protocol: "accessing",
- fn: function (aMessage){
- var self=this;
- self["@message"]=aMessage;
- return self;
- },
- args: ["aMessage"],
- source: "message: aMessage\x0a\x09message := aMessage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MessageNotUnderstood);
- $core.addMethod(
- $core.method({
- selector: "messageText",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($recv($recv(self._receiver())._asString()).__comma(" does not understand #")).__comma($recv(self._message())._selector());
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"messageText",{},$globals.MessageNotUnderstood)});
- },
- args: [],
- source: "messageText\x0a\x09^ self receiver asString, ' does not understand #', self message selector",
- referencedClasses: [],
- messageSends: [",", "asString", "receiver", "selector", "message"]
- }),
- $globals.MessageNotUnderstood);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@receiver"];
- },
- args: [],
- source: "receiver\x0a\x09^ receiver",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MessageNotUnderstood);
- $core.addMethod(
- $core.method({
- selector: "receiver:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@receiver"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "receiver: anObject\x0a\x09receiver := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MessageNotUnderstood);
- $core.addClass("NonBooleanReceiver", $globals.Error, ["object"], "Kernel-Exceptions");
- $globals.NonBooleanReceiver.comment="NonBooleanReceiver exceptions may be thrown when executing inlined methods such as `#ifTrue:` with a non boolean receiver.";
- $core.addMethod(
- $core.method({
- selector: "object",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@object"];
- },
- args: [],
- source: "object\x0a\x09^ object",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NonBooleanReceiver);
- $core.addMethod(
- $core.method({
- selector: "object:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@object"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "object: anObject\x0a\x09object := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NonBooleanReceiver);
- });
- define('amber_core/Kernel-Infrastructure',["amber/boot", "amber_core/Kernel-Collections", "amber_core/Kernel-Exceptions", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Infrastructure");
- $core.packages["Kernel-Infrastructure"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Infrastructure"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("JSObjectProxy", $globals.ProtoObject, ["jsObject"], "Kernel-Infrastructure");
- $globals.JSObjectProxy.comment="I handle sending messages to JavaScript objects, making JavaScript object accessing from Amber fully transparent.\x0aMy instances make intensive use of `#doesNotUnderstand:`.\x0a\x0aMy instances are automatically created by Amber whenever a message is sent to a JavaScript object.\x0a\x0a## Usage examples\x0a\x0aJSObjectProxy objects are instanciated by Amber when a Smalltalk message is sent to a JavaScript object.\x0a\x0a\x09window alert: 'hello world'.\x0a\x09window inspect.\x0a\x09(window jQuery: 'body') append: 'hello world'\x0a\x0aAmber messages sends are converted to JavaScript function calls or object property access _(in this order)_. If n one of them match, a `MessageNotUnderstood` error will be thrown.\x0a\x0a## Message conversion rules\x0a\x0a- `someUser name` becomes `someUser.name`\x0a- `someUser name: 'John'` becomes `someUser name = \x22John\x22`\x0a- `console log: 'hello world'` becomes `console.log('hello world')`\x0a- `(window jQuery: 'foo') css: 'background' color: 'red'` becomes `window.jQuery('foo').css('background', 'red')`\x0a\x0a__Note:__ For keyword-based messages, only the first keyword is kept: `window foo: 1 bar: 2` is equivalent to `window foo: 1 baz: 2`.";
- $core.addMethod(
- $core.method({
- selector: "=",
- protocol: "comparing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv(anObject)._class();
- $ctx1.sendIdx["class"]=1;
- $1=$recv($2).__eq_eq(self._class());
- if(!$core.assert($1)){
- return false;
- }
- return $recv($globals.JSObjectProxy)._compareJSObjectOfProxy_withProxy_(self,anObject);
- }, function($ctx1) {$ctx1.fill(self,"=",{anObject:anObject},$globals.JSObjectProxy)});
- },
- args: ["anObject"],
- source: "= anObject\x0a\x09anObject class == self class ifFalse: [ ^ false ].\x0a\x09^ JSObjectProxy compareJSObjectOfProxy: self withProxy: anObject",
- referencedClasses: ["JSObjectProxy"],
- messageSends: ["ifFalse:", "==", "class", "compareJSObjectOfProxy:withProxy:"]
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return self["@jsObject"];
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09\x22Answers the receiver in a stringify-friendly fashion\x22\x0a\x0a\x09^ jsObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "at:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self['@jsObject'][aString];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:",{aString:aString},$globals.JSObjectProxy)});
- },
- args: ["aString"],
- source: "at: aString\x0a\x09<inlineJS: 'return self[''@jsObject''][aString]'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsent:",
- protocol: "accessing",
- fn: function (aString,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var obj = self['@jsObject'];
- return aString in obj ? obj[aString] : aBlock._value();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aString:aString,aBlock:aBlock},$globals.JSObjectProxy)});
- },
- args: ["aString", "aBlock"],
- source: "at: aString ifAbsent: aBlock\x0a\x09\x22return the aString property or evaluate aBlock if the property is not defined on the object\x22\x0a\x09<inlineJS: '\x0a\x09\x09var obj = self[''@jsObject''];\x0a\x09\x09return aString in obj ? obj[aString] : aBlock._value();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "at:ifPresent:",
- protocol: "accessing",
- fn: function (aString,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var obj = self['@jsObject'];
- return aString in obj ? aBlock._value_(obj[aString]) : nil;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:",{aString:aString,aBlock:aBlock},$globals.JSObjectProxy)});
- },
- args: ["aString", "aBlock"],
- source: "at: aString ifPresent: aBlock\x0a\x09\x22return the evaluation of aBlock with the value if the property is defined or return nil\x22\x0a\x09<inlineJS: '\x0a\x09\x09var obj = self[''@jsObject''];\x0a\x09\x09return aString in obj ? aBlock._value_(obj[aString]) : nil;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: "accessing",
- fn: function (aString,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var obj = self['@jsObject'];
- return aString in obj ? aBlock._value_(obj[aString]) : anotherBlock._value();
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{aString:aString,aBlock:aBlock,anotherBlock:anotherBlock},$globals.JSObjectProxy)});
- },
- args: ["aString", "aBlock", "anotherBlock"],
- source: "at: aString ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09\x22return the evaluation of aBlock with the value if the property is defined\x0a\x09or return value of anotherBlock\x22\x0a\x09<inlineJS: '\x0a\x09\x09var obj = self[''@jsObject''];\x0a\x09\x09return aString in obj ? aBlock._value_(obj[aString]) : anotherBlock._value();\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "at:put:",
- protocol: "accessing",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self['@jsObject'][aString] = anObject;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"at:put:",{aString:aString,anObject:anObject},$globals.JSObjectProxy)});
- },
- args: ["aString", "anObject"],
- source: "at: aString put: anObject\x0a\x09<inlineJS: 'return self[''@jsObject''][aString] = anObject'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "doesNotUnderstand:",
- protocol: "proxy",
- fn: function (aMessage){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv($globals.JSObjectProxy)._lookupProperty_ofProxy_($recv($recv(aMessage)._selector())._asJavaScriptPropertyName(),self);
- if(($receiver = $1) == null || $receiver.isNil){
- return (
- $ctx1.supercall = true,
- ($globals.JSObjectProxy.superclass||$boot.nilAsClass).fn.prototype._doesNotUnderstand_.apply($recv(self), [aMessage]));
- $ctx1.supercall = false;
- } else {
- var jsSelector;
- jsSelector=$receiver;
- return $recv($globals.JSObjectProxy)._forwardMessage_withArguments_ofProxy_(jsSelector,$recv(aMessage)._arguments(),self);
- }
- }, function($ctx1) {$ctx1.fill(self,"doesNotUnderstand:",{aMessage:aMessage},$globals.JSObjectProxy)});
- },
- args: ["aMessage"],
- source: "doesNotUnderstand: aMessage\x0a\x09^ (JSObjectProxy lookupProperty: aMessage selector asJavaScriptPropertyName ofProxy: self)\x0a\x09\x09ifNil: [ super doesNotUnderstand: aMessage ]\x0a\x09\x09ifNotNil: [ :jsSelector | \x0a\x09\x09\x09JSObjectProxy \x0a\x09\x09\x09\x09forwardMessage: jsSelector \x0a\x09\x09\x09\x09withArguments: aMessage arguments\x0a\x09\x09\x09\x09ofProxy: self ]",
- referencedClasses: ["JSObjectProxy"],
- messageSends: ["ifNil:ifNotNil:", "lookupProperty:ofProxy:", "asJavaScriptPropertyName", "selector", "doesNotUnderstand:", "forwardMessage:withArguments:ofProxy:", "arguments"]
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "in:",
- protocol: "accessing",
- fn: function (aValuable){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aValuable)._value_(self["@jsObject"]);
- }, function($ctx1) {$ctx1.fill(self,"in:",{aValuable:aValuable},$globals.JSObjectProxy)});
- },
- args: ["aValuable"],
- source: "in: aValuable\x0a\x09^ aValuable value: jsObject",
- referencedClasses: [],
- messageSends: ["value:"]
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "jsObject",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@jsObject"];
- },
- args: [],
- source: "jsObject\x0a\x09^ jsObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "keysAndValuesDo:",
- protocol: "enumerating",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var o = self['@jsObject'];
- for(var i in o) {
- aBlock._value_value_(i, o[i]);
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"keysAndValuesDo:",{aBlock:aBlock},$globals.JSObjectProxy)});
- },
- args: ["aBlock"],
- source: "keysAndValuesDo: aBlock\x0a\x09<inlineJS: '\x0a\x09\x09var o = self[''@jsObject''];\x0a\x09\x09for(var i in o) {\x0a\x09\x09\x09aBlock._value_value_(i, o[i]);\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutAll_(self._printString());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.JSObjectProxy)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09aStream nextPutAll: self printString",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "printString"]
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "printString",
- protocol: "printing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self['@jsObject'];
- return js.toString
- ? js.toString()
- : Object.prototype.toString.call(js)
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printString",{},$globals.JSObjectProxy)});
- },
- args: [],
- source: "printString\x0a\x09<inlineJS: '\x0a\x09\x09var js = self[''@jsObject''];\x0a\x09\x09return js.toString\x0a\x09\x09\x09? js.toString()\x0a\x09\x09\x09: Object.prototype.toString.call(js)\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "putOn:",
- protocol: "streaming",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._nextPutJSObject_(self["@jsObject"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"putOn:",{aStream:aStream},$globals.JSObjectProxy)});
- },
- args: ["aStream"],
- source: "putOn: aStream\x0a\x09aStream nextPutJSObject: jsObject",
- referencedClasses: [],
- messageSends: ["nextPutJSObject:"]
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "addObjectVariablesTo:ofProxy:",
- protocol: "proxy",
- fn: function (aDictionary,aProxy){
- var self=this;
- return $core.withContext(function($ctx1) {
- var jsObject = aProxy['@jsObject'];
- for(var i in jsObject) {
- aDictionary._at_put_(i, jsObject[i]);
- }
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addObjectVariablesTo:ofProxy:",{aDictionary:aDictionary,aProxy:aProxy},$globals.JSObjectProxy.klass)});
- },
- args: ["aDictionary", "aProxy"],
- source: "addObjectVariablesTo: aDictionary ofProxy: aProxy\x0a\x09<inlineJS: '\x0a\x09\x09var jsObject = aProxy[''@jsObject''];\x0a\x09\x09for(var i in jsObject) {\x0a\x09\x09\x09aDictionary._at_put_(i, jsObject[i]);\x0a\x09\x09}\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy.klass);
- $core.addMethod(
- $core.method({
- selector: "compareJSObjectOfProxy:withProxy:",
- protocol: "proxy",
- fn: function (aProxy,anotherProxy){
- var self=this;
- return $core.withContext(function($ctx1) {
- var anotherJSObject = anotherProxy.klass ? anotherProxy["@jsObject"] : anotherProxy;
- return aProxy["@jsObject"] === anotherJSObject;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"compareJSObjectOfProxy:withProxy:",{aProxy:aProxy,anotherProxy:anotherProxy},$globals.JSObjectProxy.klass)});
- },
- args: ["aProxy", "anotherProxy"],
- source: "compareJSObjectOfProxy: aProxy withProxy: anotherProxy\x0a<inlineJS: '\x0a\x09var anotherJSObject = anotherProxy.klass ? anotherProxy[\x22@jsObject\x22] : anotherProxy;\x0a\x09return aProxy[\x22@jsObject\x22] === anotherJSObject\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy.klass);
- $core.addMethod(
- $core.method({
- selector: "forwardMessage:withArguments:ofProxy:",
- protocol: "proxy",
- fn: function (aString,anArray,aProxy){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.accessJavaScript(aProxy._jsObject(), aString, anArray);
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"forwardMessage:withArguments:ofProxy:",{aString:aString,anArray:anArray,aProxy:aProxy},$globals.JSObjectProxy.klass)});
- },
- args: ["aString", "anArray", "aProxy"],
- source: "forwardMessage: aString withArguments: anArray ofProxy: aProxy\x0a\x09<inlineJS: '\x0a\x09\x09return $core.accessJavaScript(aProxy._jsObject(), aString, anArray);\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy.klass);
- $core.addMethod(
- $core.method({
- selector: "jsObject:ofProxy:",
- protocol: "proxy",
- fn: function (aJSObject,aProxy){
- var self=this;
- return $core.withContext(function($ctx1) {
- aProxy['@jsObject'] = aJSObject;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"jsObject:ofProxy:",{aJSObject:aJSObject,aProxy:aProxy},$globals.JSObjectProxy.klass)});
- },
- args: ["aJSObject", "aProxy"],
- source: "jsObject: aJSObject ofProxy: aProxy\x0a\x09<inlineJS: 'aProxy[''@jsObject''] = aJSObject'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy.klass);
- $core.addMethod(
- $core.method({
- selector: "lookupProperty:ofProxy:",
- protocol: "proxy",
- fn: function (aString,aProxy){
- var self=this;
- return $core.withContext(function($ctx1) {
- return aString in aProxy._jsObject() ? aString : nil;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"lookupProperty:ofProxy:",{aString:aString,aProxy:aProxy},$globals.JSObjectProxy.klass)});
- },
- args: ["aString", "aProxy"],
- source: "lookupProperty: aString ofProxy: aProxy\x0a\x09\x22Looks up a property in JS object.\x0a\x09Answer the property if it is present, or nil if it is not present.\x22\x0a\x09\x0a\x09<inlineJS: 'return aString in aProxy._jsObject() ? aString : nil'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy.klass);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aJSObject){
- var self=this;
- var instance;
- return $core.withContext(function($ctx1) {
- instance=self._new();
- self._jsObject_ofProxy_(aJSObject,instance);
- return instance;
- }, function($ctx1) {$ctx1.fill(self,"on:",{aJSObject:aJSObject,instance:instance},$globals.JSObjectProxy.klass)});
- },
- args: ["aJSObject"],
- source: "on: aJSObject\x0a\x09| instance |\x0a\x09instance := self new.\x0a\x09self jsObject: aJSObject ofProxy: instance.\x0a\x09^ instance",
- referencedClasses: [],
- messageSends: ["new", "jsObject:ofProxy:"]
- }),
- $globals.JSObjectProxy.klass);
- $core.addClass("Organizer", $globals.Object, [], "Kernel-Infrastructure");
- $globals.Organizer.comment="I represent categorization information. \x0a\x0a## API\x0a\x0aUse `#addElement:` and `#removeElement:` to manipulate instances.";
- $core.addMethod(
- $core.method({
- selector: "addElement:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.addElement(self.elements, anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addElement:",{anObject:anObject},$globals.Organizer)});
- },
- args: ["anObject"],
- source: "addElement: anObject\x0a\x09<inlineJS: '$core.addElement(self.elements, anObject)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Organizer);
- $core.addMethod(
- $core.method({
- selector: "elements",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._basicAt_("elements"))._copy();
- }, function($ctx1) {$ctx1.fill(self,"elements",{},$globals.Organizer)});
- },
- args: [],
- source: "elements\x0a\x09^ (self basicAt: 'elements') copy",
- referencedClasses: [],
- messageSends: ["copy", "basicAt:"]
- }),
- $globals.Organizer);
- $core.addMethod(
- $core.method({
- selector: "removeElement:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.removeElement(self.elements, anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeElement:",{anObject:anObject},$globals.Organizer)});
- },
- args: ["anObject"],
- source: "removeElement: anObject\x0a\x09<inlineJS: '$core.removeElement(self.elements, anObject)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Organizer);
- $core.addClass("ClassOrganizer", $globals.Organizer, [], "Kernel-Infrastructure");
- $globals.ClassOrganizer.comment="I am an organizer specific to classes. I hold method categorization information for classes.";
- $core.addMethod(
- $core.method({
- selector: "addElement:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- (
- $ctx1.supercall = true,
- ($globals.ClassOrganizer.superclass||$boot.nilAsClass).fn.prototype._addElement_.apply($recv(self), [aString]));
- $ctx1.supercall = false;
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.ProtocolAdded)._new();
- $recv($3)._protocol_(aString);
- $recv($3)._theClass_(self._theClass());
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addElement:",{aString:aString},$globals.ClassOrganizer)});
- },
- args: ["aString"],
- source: "addElement: aString\x0a\x09super addElement: aString.\x0a\x0a\x09SystemAnnouncer current announce: (ProtocolAdded new\x0a\x09\x09protocol: aString;\x0a\x09\x09theClass: self theClass;\x0a\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ProtocolAdded"],
- messageSends: ["addElement:", "announce:", "current", "protocol:", "new", "theClass:", "theClass", "yourself"]
- }),
- $globals.ClassOrganizer);
- $core.addMethod(
- $core.method({
- selector: "removeElement:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- (
- $ctx1.supercall = true,
- ($globals.ClassOrganizer.superclass||$boot.nilAsClass).fn.prototype._removeElement_.apply($recv(self), [aString]));
- $ctx1.supercall = false;
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.ProtocolRemoved)._new();
- $recv($3)._protocol_(aString);
- $recv($3)._theClass_(self._theClass());
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeElement:",{aString:aString},$globals.ClassOrganizer)});
- },
- args: ["aString"],
- source: "removeElement: aString\x0a\x09super removeElement: aString.\x0a\x0a\x09SystemAnnouncer current announce: (ProtocolRemoved new\x0a\x09\x09protocol: aString;\x0a\x09\x09theClass: self theClass;\x0a\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ProtocolRemoved"],
- messageSends: ["removeElement:", "announce:", "current", "protocol:", "new", "theClass:", "theClass", "yourself"]
- }),
- $globals.ClassOrganizer);
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.theClass;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"theClass",{},$globals.ClassOrganizer)});
- },
- args: [],
- source: "theClass\x0a\x09<inlineJS: 'return self.theClass'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassOrganizer);
- $core.addClass("PackageOrganizer", $globals.Organizer, [], "Kernel-Infrastructure");
- $globals.PackageOrganizer.comment="I am an organizer specific to packages. I hold classes categorization information.";
- $core.addClass("Package", $globals.Object, ["transport", "imports", "dirty"], "Kernel-Infrastructure");
- $globals.Package.comment="I am similar to a \x22class category\x22 typically found in other Smalltalks like Pharo or Squeak. Amber does not have class categories anymore, it had in the beginning but now each class in the system knows which package it belongs to.\x0a\x0aEach package has a name and can be queried for its classes, but it will then resort to a reverse scan of all classes to find them.\x0a\x0a## API\x0a\x0aPackages are manipulated through \x22Smalltalk current\x22, like for example finding one based on a name or with `Package class >> #name` directly:\x0a\x0a Smalltalk current packageAt: 'Kernel'\x0a Package named: 'Kernel'\x0a\x0aA package differs slightly from a Monticello package which can span multiple class categories using a naming convention based on hyphenation. But just as in Monticello a package supports \x22class extensions\x22 so a package can define behaviors in foreign classes using a naming convention for method categories where the category starts with an asterisk and then the name of the owning package follows.\x0a\x0aYou can fetch a package from the server:\x0a\x0a\x09Package load: 'Additional-Examples'";
- $core.addMethod(
- $core.method({
- selector: "basicImports",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.imports || [];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicImports",{},$globals.Package)});
- },
- args: [],
- source: "basicImports\x0a\x09\x22Answer the imports literal JavaScript object as setup in the JavaScript file, if any\x22\x0a\x09\x0a\x09<inlineJS: 'return self.imports || []'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "basicName:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self.pkgName = aString;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicName:",{aString:aString},$globals.Package)});
- },
- args: ["aString"],
- source: "basicName: aString\x0a\x09<inlineJS: 'self.pkgName = aString'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "basicTransport",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.transport;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicTransport",{},$globals.Package)});
- },
- args: [],
- source: "basicTransport\x0a\x09\x22Answer the transport literal JavaScript object as setup in the JavaScript file, if any\x22\x0a\x09\x0a\x09<inlineJS: 'return self.transport'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "beClean",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- self["@dirty"]=false;
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.PackageClean)._new();
- $recv($3)._package_(self);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"beClean",{},$globals.Package)});
- },
- args: [],
- source: "beClean\x0a\x09dirty := false.\x0a\x09\x0a\x09SystemAnnouncer current announce: (PackageClean new\x0a\x09\x09package: self;\x0a\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "PackageClean"],
- messageSends: ["announce:", "current", "package:", "new", "yourself"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "beDirty",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- self["@dirty"]=true;
- $1=$recv($globals.SystemAnnouncer)._current();
- $3=$recv($globals.PackageDirty)._new();
- $recv($3)._package_(self);
- $2=$recv($3)._yourself();
- $recv($1)._announce_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"beDirty",{},$globals.Package)});
- },
- args: [],
- source: "beDirty\x0a\x09dirty := true.\x0a\x09\x0a\x09SystemAnnouncer current announce: (PackageDirty new\x0a\x09\x09package: self;\x0a\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "PackageDirty"],
- messageSends: ["announce:", "current", "package:", "new", "yourself"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "classTemplate",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $recv(stream)._write_("Object subclass: #NameOfSubclass");
- $ctx2.sendIdx["write:"]=1;
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=1;
- $recv(stream)._tab();
- $ctx2.sendIdx["tab"]=1;
- $recv(stream)._write_("instanceVariableNames: ''");
- $ctx2.sendIdx["write:"]=2;
- $recv(stream)._lf();
- $recv(stream)._tab();
- $recv(stream)._write_("package: ");
- return $recv(stream)._print_(self._name());
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"classTemplate",{},$globals.Package)});
- },
- args: [],
- source: "classTemplate\x0a\x09^ String streamContents: [ :stream | stream\x0a\x09\x09write: 'Object subclass: #NameOfSubclass'; lf;\x0a\x09\x09tab; write: 'instanceVariableNames: '''''; lf;\x0a\x09\x09tab; write: 'package: '; print: self name ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "write:", "lf", "tab", "print:", "name"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "classes",
- protocol: "classes",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._organization())._elements();
- }, function($ctx1) {$ctx1.fill(self,"classes",{},$globals.Package)});
- },
- args: [],
- source: "classes\x0a\x09^ self organization elements",
- referencedClasses: [],
- messageSends: ["elements", "organization"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $1=$recv(self._class())._name();
- $ctx2.sendIdx["name"]=1;
- $recv(stream)._write_($1);
- $ctx2.sendIdx["write:"]=1;
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=1;
- $recv(stream)._tab();
- $ctx2.sendIdx["tab"]=1;
- $recv(stream)._write_("named: ");
- $ctx2.sendIdx["write:"]=2;
- $recv(stream)._print_(self._name());
- $recv(stream)._lf();
- $ctx2.sendIdx["lf"]=2;
- $recv(stream)._tab();
- $ctx2.sendIdx["tab"]=2;
- $recv(stream)._write_(["imports: ",self._importsDefinition()]);
- $ctx2.sendIdx["write:"]=3;
- $recv(stream)._lf();
- $recv(stream)._tab();
- return $recv(stream)._write_(["transport: (",$recv(self._transport())._definition(),")"]);
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"definition",{},$globals.Package)});
- },
- args: [],
- source: "definition\x0a\x09^ String streamContents: [ :stream | stream\x0a\x09\x09write: self class name; lf;\x0a\x09\x09tab; write: 'named: '; print: self name; lf;\x0a\x09\x09tab; write: { 'imports: '. self importsDefinition }; lf;\x0a\x09\x09tab; write: { 'transport: ('. self transport definition. ')' } ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "write:", "name", "class", "lf", "tab", "print:", "importsDefinition", "definition", "transport"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "imports",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@imports"];
- if(($receiver = $1) == null || $receiver.isNil){
- var parsed;
- parsed=self._importsFromJson_(self._basicImports());
- parsed;
- self._imports_(parsed);
- return self["@imports"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"imports",{},$globals.Package)});
- },
- args: [],
- source: "imports\x0a\x09^ imports ifNil: [\x0a\x09\x09| parsed |\x0a\x09\x09parsed := self importsFromJson: self basicImports.\x0a\x09\x09self imports: parsed.\x0a\x09\x09imports ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "importsFromJson:", "basicImports", "imports:"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "imports:",
- protocol: "accessing",
- fn: function (anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._validateImports_(anArray);
- self["@imports"]=$recv(anArray)._asSet();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"imports:",{anArray:anArray},$globals.Package)});
- },
- args: ["anArray"],
- source: "imports: anArray\x0a\x09self validateImports: anArray.\x0a\x09imports := anArray asSet",
- referencedClasses: [],
- messageSends: ["validateImports:", "asSet"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "importsAsJson",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv(self._sortedImportsAsArray())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(each)._isString();
- if($core.assert($1)){
- return each;
- } else {
- return $recv($recv($recv(each)._key()).__comma("=")).__comma($recv(each)._value());
- $ctx2.sendIdx[","]=1;
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"importsAsJson",{},$globals.Package)});
- },
- args: [],
- source: "importsAsJson\x0a\x0a\x09^ self sortedImportsAsArray collect: [ :each |\x0a\x09\x09each isString\x0a\x09\x09\x09ifTrue: [ each ]\x0a\x09\x09\x09ifFalse: [ each key, '=', each value ]]",
- referencedClasses: [],
- messageSends: ["collect:", "sortedImportsAsArray", "ifTrue:ifFalse:", "isString", ",", "key", "value"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "importsDefinition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $recv(stream)._write_("{");
- $ctx2.sendIdx["write:"]=1;
- $recv(self._sortedImportsAsArray())._do_separatedBy_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(stream)._print_(each);
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)});
- }),(function(){
- return $core.withContext(function($ctx3) {
- return $recv(stream)._write_(". ");
- $ctx3.sendIdx["write:"]=2;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- return $recv(stream)._write_("}");
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"importsDefinition",{},$globals.Package)});
- },
- args: [],
- source: "importsDefinition\x0a\x09^ String streamContents: [ :stream |\x0a\x09\x09stream write: '{'.\x0a\x09\x09self sortedImportsAsArray\x0a\x09\x09\x09do: [ :each | stream print: each ]\x0a\x09\x09\x09separatedBy: [ stream write: '. ' ].\x0a\x09\x09stream write: '}' ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "write:", "do:separatedBy:", "sortedImportsAsArray", "print:"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "importsFromJson:",
- protocol: "converting",
- fn: function (anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv(anArray)._collect_((function(each){
- var split;
- return $core.withContext(function($ctx2) {
- split=$recv(each)._tokenize_("=");
- split;
- $1=$recv($recv(split)._size()).__eq((1));
- if($core.assert($1)){
- return $recv(split)._first();
- $ctx2.sendIdx["first"]=1;
- } else {
- return $recv($recv(split)._first()).__minus_gt($recv(split)._second());
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each,split:split},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"importsFromJson:",{anArray:anArray},$globals.Package)});
- },
- args: ["anArray"],
- source: "importsFromJson: anArray\x0a\x09\x22Parses array of string, eg. #('asdf' 'qwer=tyuo')\x0a\x09into array of Strings and Associations,\x0a\x09eg. {'asdf'. 'qwer'->'tyuo'}\x22\x0a\x0a\x09^ anArray collect: [ :each |\x0a\x09\x09| split |\x0a\x09\x09split := each tokenize: '='.\x0a\x09\x09split size = 1\x0a\x09\x09\x09ifTrue: [ split first ]\x0a\x09\x09\x09ifFalse: [ split first -> split second ]]",
- referencedClasses: [],
- messageSends: ["collect:", "tokenize:", "ifTrue:ifFalse:", "=", "size", "first", "->", "second"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "isDirty",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@dirty"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"isDirty",{},$globals.Package)});
- },
- args: [],
- source: "isDirty\x0a\x09^ dirty ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "isPackage",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isPackage\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "loadDependencies",
- protocol: "dependencies",
- fn: function (){
- var self=this;
- var classes,packages;
- return $core.withContext(function($ctx1) {
- var $1;
- classes=self._loadDependencyClasses();
- $1=$recv($recv(classes)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._package();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- })))._asSet();
- $recv($1)._remove_ifAbsent_(self,(function(){
- }));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"loadDependencies",{classes:classes,packages:packages},$globals.Package)});
- },
- args: [],
- source: "loadDependencies\x0a\x09\x22Returns list of packages that need to be loaded\x0a\x09before loading this package.\x22\x0a\x09\x0a\x09| classes packages |\x0a\x09classes := self loadDependencyClasses.\x0a\x09^ (classes collect: [ :each | each package ]) asSet\x0a\x09\x09remove: self ifAbsent: [];\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["loadDependencyClasses", "remove:ifAbsent:", "asSet", "collect:", "package", "yourself"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "loadDependencyClasses",
- protocol: "dependencies",
- fn: function (){
- var self=this;
- var starCategoryName;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$5,$7,$6,$4,$receiver;
- starCategoryName="*".__comma(self._name());
- $ctx1.sendIdx[","]=1;
- $3=self._classes();
- $ctx1.sendIdx["classes"]=1;
- $2=$recv($3)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._superclass();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["collect:"]=1;
- $1=$recv($2)._asSet();
- $recv($1)._addAll_($recv($recv($globals.Smalltalk)._classes())._select_((function(each){
- return $core.withContext(function($ctx2) {
- $5=$recv(each)._protocols();
- $ctx2.sendIdx["protocols"]=1;
- $7=$recv(each)._theMetaClass();
- if(($receiver = $7) == null || $receiver.isNil){
- $6=[];
- } else {
- var meta;
- meta=$receiver;
- $6=$recv(meta)._protocols();
- }
- $4=$recv($5).__comma($6);
- return $recv($4)._includes_(starCategoryName);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- })));
- $ctx1.sendIdx["addAll:"]=1;
- $recv($1)._addAll_($recv($globals.Array)._streamContents_((function(as){
- return $core.withContext(function($ctx2) {
- return $recv(self._traitCompositions())._valuesDo_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(as)._write_($recv(each)._collect_((function(eachTT){
- return $core.withContext(function($ctx4) {
- return $recv(eachTT)._trait();
- }, function($ctx4) {$ctx4.fillBlock({eachTT:eachTT},$ctx3,7)});
- })));
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,6)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({as:as},$ctx1,5)});
- })));
- $recv($1)._remove_ifAbsent_(nil,(function(){
- }));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"loadDependencyClasses",{starCategoryName:starCategoryName},$globals.Package)});
- },
- args: [],
- source: "loadDependencyClasses\x0a\x09\x22Returns classes needed at the time of loading a package.\x0a\x09These are all that are used to subclass\x0a\x09and to define an extension method\x0a\x09as well as all traits used\x22\x0a\x09\x0a\x09| starCategoryName |\x0a\x09starCategoryName := '*', self name.\x0a\x09^ (self classes collect: [ :each | each superclass ]) asSet\x0a\x09\x09addAll: (Smalltalk classes select: [ :each |\x0a\x09\x09\x09each protocols, (each theMetaClass ifNil: [ #() ] ifNotNil: [ :meta | meta protocols])\x0a\x09\x09\x09\x09includes: starCategoryName ]);\x0a\x09\x09addAll: (Array streamContents: [ :as | self traitCompositions valuesDo: [ :each | as write: (each collect: [ :eachTT | eachTT trait ])]]);\x0a\x09\x09remove: nil ifAbsent: [];\x0a\x09\x09yourself",
- referencedClasses: ["Smalltalk", "Array"],
- messageSends: [",", "name", "addAll:", "asSet", "collect:", "classes", "superclass", "select:", "includes:", "protocols", "ifNil:ifNotNil:", "theMetaClass", "streamContents:", "valuesDo:", "traitCompositions", "write:", "trait", "remove:ifAbsent:", "yourself"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "name",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.pkgName;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"name",{},$globals.Package)});
- },
- args: [],
- source: "name\x0a\x09<inlineJS: 'return self.pkgName'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "name:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._basicName_(aString);
- self._beDirty();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"name:",{aString:aString},$globals.Package)});
- },
- args: ["aString"],
- source: "name: aString\x0a\x09self basicName: aString.\x0a\x09self beDirty",
- referencedClasses: [],
- messageSends: ["basicName:", "beDirty"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "organization",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._basicAt_("organization");
- }, function($ctx1) {$ctx1.fill(self,"organization",{},$globals.Package)});
- },
- args: [],
- source: "organization\x0a\x09^ self basicAt: 'organization'",
- referencedClasses: [],
- messageSends: ["basicAt:"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Package.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $recv(aStream)._nextPutAll_(" (");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._nextPutAll_(self._name());
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.Package)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream \x0a\x09\x09nextPutAll: ' (';\x0a\x09\x09nextPutAll: self name;\x0a\x09\x09nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "name"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "setupClasses",
- protocol: "classes",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._classes())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._initialize();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setupClasses",{},$globals.Package)});
- },
- args: [],
- source: "setupClasses\x0a\x09self classes do: [ :each | each initialize ]",
- referencedClasses: [],
- messageSends: ["do:", "classes", "initialize"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "sortedClasses",
- protocol: "classes",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._sortedClasses_(self._classes());
- }, function($ctx1) {$ctx1.fill(self,"sortedClasses",{},$globals.Package)});
- },
- args: [],
- source: "sortedClasses\x0a\x09\x22Answer all classes in the receiver, sorted by superclass/subclasses and by class name for common subclasses (Issue #143).\x22\x0a\x0a\x09^ self class sortedClasses: self classes",
- referencedClasses: [],
- messageSends: ["sortedClasses:", "class", "classes"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "sortedImportsAsArray",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$4,$1,$6,$5,$7;
- return $recv($recv(self._imports())._asArray())._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $3=$recv(a)._isString();
- $ctx2.sendIdx["isString"]=1;
- $2=$recv($3)._not();
- $4=$recv(b)._isString();
- $ctx2.sendIdx["isString"]=2;
- $1=$recv($2).__and($4);
- return $recv($1)._or_((function(){
- return $core.withContext(function($ctx3) {
- $6=$recv(a)._isString();
- $ctx3.sendIdx["isString"]=3;
- $5=$recv($6).__eq($recv(b)._isString());
- return $recv($5)._and_((function(){
- return $core.withContext(function($ctx4) {
- $7=$recv(a)._value();
- $ctx4.sendIdx["value"]=1;
- return $recv($7).__lt_eq($recv(b)._value());
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,3)});
- }));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"sortedImportsAsArray",{},$globals.Package)});
- },
- args: [],
- source: "sortedImportsAsArray\x0a\x09\x22Answer imports sorted first by type (associations first),\x0a\x09then by value\x22\x0a\x0a\x09^ self imports asArray\x0a\x09\x09sorted: [ :a :b |\x0a\x09\x09\x09a isString not & b isString or: [\x0a\x09\x09\x09\x09a isString = b isString and: [\x0a\x09\x09\x09\x09\x09a value <= b value ]]]",
- referencedClasses: [],
- messageSends: ["sorted:", "asArray", "imports", "or:", "&", "not", "isString", "and:", "=", "<=", "value"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "traitCompositions",
- protocol: "dependencies",
- fn: function (){
- var self=this;
- var traitCompositions;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- traitCompositions=$recv($globals.Dictionary)._new();
- $recv(self._classes())._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=traitCompositions;
- $2=$recv(each)._traitComposition();
- $ctx2.sendIdx["traitComposition"]=1;
- $recv($1)._at_put_(each,$2);
- $ctx2.sendIdx["at:put:"]=1;
- $3=$recv(each)._theMetaClass();
- if(($receiver = $3) == null || $receiver.isNil){
- return $3;
- } else {
- var meta;
- meta=$receiver;
- return $recv(traitCompositions)._at_put_(meta,$recv(meta)._traitComposition());
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return $recv(traitCompositions)._reject_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._isEmpty();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"traitCompositions",{traitCompositions:traitCompositions},$globals.Package)});
- },
- args: [],
- source: "traitCompositions\x0a\x09| traitCompositions |\x0a\x09traitCompositions := Dictionary new.\x0a\x09self classes do: [ :each |\x0a\x09\x09traitCompositions at: each put: each traitComposition.\x0a\x09\x09each theMetaClass ifNotNil: [ :meta | traitCompositions at: meta put: meta traitComposition ] ].\x0a\x09^ traitCompositions reject: [ :each | each isEmpty ]",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "do:", "classes", "at:put:", "traitComposition", "ifNotNil:", "theMetaClass", "reject:", "isEmpty"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "transport",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=self["@transport"];
- if(($receiver = $1) == null || $receiver.isNil){
- $2=$recv($globals.PackageTransport)._fromJson_(self._basicTransport());
- $recv($2)._package_(self);
- self["@transport"]=$recv($2)._yourself();
- return self["@transport"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"transport",{},$globals.Package)});
- },
- args: [],
- source: "transport\x0a\x09^ transport ifNil: [ \x0a\x09\x09transport := (PackageTransport fromJson: self basicTransport)\x0a\x09\x09\x09package: self;\x0a\x09\x09\x09yourself ]",
- referencedClasses: ["PackageTransport"],
- messageSends: ["ifNil:", "package:", "fromJson:", "basicTransport", "yourself"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "transport:",
- protocol: "accessing",
- fn: function (aPackageTransport){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@transport"]=aPackageTransport;
- $recv(aPackageTransport)._package_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"transport:",{aPackageTransport:aPackageTransport},$globals.Package)});
- },
- args: ["aPackageTransport"],
- source: "transport: aPackageTransport\x0a\x09transport := aPackageTransport.\x0a\x09aPackageTransport package: self",
- referencedClasses: [],
- messageSends: ["package:"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "validateImports:",
- protocol: "validation",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$5,$4,$3,$6;
- $recv(aCollection)._do_((function(import_){
- return $core.withContext(function($ctx2) {
- $1=$recv(import_)._isString();
- $ctx2.sendIdx["isString"]=1;
- if(!$core.assert($1)){
- $2=$recv(import_)._respondsTo_("key");
- if(!$core.assert($2)){
- self._error_("Imports must be Strings or Associations");
- $ctx2.sendIdx["error:"]=1;
- }
- $5=$recv(import_)._key();
- $ctx2.sendIdx["key"]=1;
- $4=$recv($5)._isString();
- $ctx2.sendIdx["isString"]=2;
- $3=$recv($4).__and($recv($recv(import_)._value())._isString());
- if(!$core.assert($3)){
- self._error_("Key and value must be Strings");
- $ctx2.sendIdx["error:"]=2;
- }
- $6=$recv($recv(import_)._key())._match_("^[a-zA-Z][a-zA-Z0-9]*$");
- if(!$core.assert($6)){
- return self._error_("Keys must be identifiers");
- }
- }
- }, function($ctx2) {$ctx2.fillBlock({import_:import_},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"validateImports:",{aCollection:aCollection},$globals.Package)});
- },
- args: ["aCollection"],
- source: "validateImports: aCollection\x0a\x0a\x09aCollection do: [ :import |\x0a\x09\x09import isString ifFalse: [\x0a\x09\x09\x09(import respondsTo: #key) ifFalse: [\x0a\x09\x09\x09\x09self error: 'Imports must be Strings or Associations' ].\x0a\x09\x09\x09import key isString & import value isString ifFalse: [\x0a\x09\x09\x09\x09self error: 'Key and value must be Strings' ].\x0a\x09\x09\x09(import key match: '^[a-zA-Z][a-zA-Z0-9]*$') ifFalse: [\x0a\x09\x09\x09\x09self error: 'Keys must be identifiers' ]]]",
- referencedClasses: [],
- messageSends: ["do:", "ifFalse:", "isString", "respondsTo:", "error:", "&", "key", "value", "match:"]
- }),
- $globals.Package);
- $globals.Package.klass.iVarNames = ["defaultCommitPathJs", "defaultCommitPathSt"];
- $core.addMethod(
- $core.method({
- selector: "named:",
- protocol: "accessing",
- fn: function (aPackageName){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._packageAt_ifAbsent_(aPackageName,(function(){
- return $core.withContext(function($ctx2) {
- return $recv($globals.Smalltalk)._createPackage_(aPackageName);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"named:",{aPackageName:aPackageName},$globals.Package.klass)});
- },
- args: ["aPackageName"],
- source: "named: aPackageName\x0a\x09^ Smalltalk \x0a\x09\x09packageAt: aPackageName\x0a\x09\x09ifAbsent: [ \x0a\x09\x09\x09Smalltalk createPackage: aPackageName ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["packageAt:ifAbsent:", "createPackage:"]
- }),
- $globals.Package.klass);
- $core.addMethod(
- $core.method({
- selector: "named:ifAbsent:",
- protocol: "accessing",
- fn: function (aPackageName,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._packageAt_ifAbsent_(aPackageName,aBlock);
- }, function($ctx1) {$ctx1.fill(self,"named:ifAbsent:",{aPackageName:aPackageName,aBlock:aBlock},$globals.Package.klass)});
- },
- args: ["aPackageName", "aBlock"],
- source: "named: aPackageName ifAbsent: aBlock\x0a\x09^ Smalltalk packageAt: aPackageName ifAbsent: aBlock",
- referencedClasses: ["Smalltalk"],
- messageSends: ["packageAt:ifAbsent:"]
- }),
- $globals.Package.klass);
- $core.addMethod(
- $core.method({
- selector: "named:imports:transport:",
- protocol: "accessing",
- fn: function (aPackageName,anArray,aTransport){
- var self=this;
- var package_;
- return $core.withContext(function($ctx1) {
- package_=self._named_(aPackageName);
- $recv(package_)._imports_(anArray);
- $recv(package_)._transport_(aTransport);
- return package_;
- }, function($ctx1) {$ctx1.fill(self,"named:imports:transport:",{aPackageName:aPackageName,anArray:anArray,aTransport:aTransport,package_:package_},$globals.Package.klass)});
- },
- args: ["aPackageName", "anArray", "aTransport"],
- source: "named: aPackageName imports: anArray transport: aTransport\x0a\x09| package |\x0a\x09\x0a\x09package := self named: aPackageName.\x0a\x09package imports: anArray.\x0a\x09package transport: aTransport.\x0a\x09\x0a\x09^ package",
- referencedClasses: [],
- messageSends: ["named:", "imports:", "transport:"]
- }),
- $globals.Package.klass);
- $core.addMethod(
- $core.method({
- selector: "named:transport:",
- protocol: "accessing",
- fn: function (aPackageName,aTransport){
- var self=this;
- var package_;
- return $core.withContext(function($ctx1) {
- package_=self._named_(aPackageName);
- $recv(package_)._transport_(aTransport);
- return package_;
- }, function($ctx1) {$ctx1.fill(self,"named:transport:",{aPackageName:aPackageName,aTransport:aTransport,package_:package_},$globals.Package.klass)});
- },
- args: ["aPackageName", "aTransport"],
- source: "named: aPackageName transport: aTransport\x0a\x09| package |\x0a\x09\x0a\x09package := self named: aPackageName.\x0a\x09package transport: aTransport.\x0a\x09\x0a\x09^ package",
- referencedClasses: [],
- messageSends: ["named:", "transport:"]
- }),
- $globals.Package.klass);
- $core.addMethod(
- $core.method({
- selector: "sortedClasses:",
- protocol: "sorting",
- fn: function (classes){
- var self=this;
- var children,others,nodes,expandedClasses;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- children=[];
- others=[];
- $recv(classes)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(classes)._includes_($recv(each)._superclass());
- if($core.assert($1)){
- return $recv(others)._add_(each);
- } else {
- return $recv(children)._add_(each);
- $ctx2.sendIdx["add:"]=1;
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- nodes=$recv(children)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($globals.ClassSorterNode)._on_classes_level_(each,others,(0));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,4)});
- }));
- nodes=$recv(nodes)._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $3=$recv(a)._theClass();
- $ctx2.sendIdx["theClass"]=1;
- $2=$recv($3)._name();
- $ctx2.sendIdx["name"]=1;
- return $recv($2).__lt_eq($recv($recv(b)._theClass())._name());
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,5)});
- }));
- expandedClasses=$recv($globals.Array)._new();
- $recv(nodes)._do_((function(aNode){
- return $core.withContext(function($ctx2) {
- return $recv(aNode)._traverseClassesWith_(expandedClasses);
- }, function($ctx2) {$ctx2.fillBlock({aNode:aNode},$ctx1,6)});
- }));
- return expandedClasses;
- }, function($ctx1) {$ctx1.fill(self,"sortedClasses:",{classes:classes,children:children,others:others,nodes:nodes,expandedClasses:expandedClasses},$globals.Package.klass)});
- },
- args: ["classes"],
- source: "sortedClasses: classes\x0a\x09\x22Answer classes, sorted by superclass/subclasses and by class name for common subclasses (Issue #143)\x22\x0a\x0a\x09| children others nodes expandedClasses |\x0a\x09children := #().\x0a\x09others := #().\x0a\x09classes do: [ :each |\x0a\x09\x09(classes includes: each superclass)\x0a\x09\x09\x09ifFalse: [ children add: each ]\x0a\x09\x09\x09ifTrue: [ others add: each ]].\x0a\x09nodes := children collect: [ :each |\x0a\x09\x09ClassSorterNode on: each classes: others level: 0 ].\x0a\x09nodes := nodes sorted: [ :a :b | a theClass name <= b theClass name ].\x0a\x09expandedClasses := Array new.\x0a\x09nodes do: [ :aNode |\x0a\x09\x09aNode traverseClassesWith: expandedClasses ].\x0a\x09^ expandedClasses",
- referencedClasses: ["ClassSorterNode", "Array"],
- messageSends: ["do:", "ifFalse:ifTrue:", "includes:", "superclass", "add:", "collect:", "on:classes:level:", "sorted:", "<=", "name", "theClass", "new", "traverseClassesWith:"]
- }),
- $globals.Package.klass);
- $core.addClass("PackageStateObserver", $globals.Object, [], "Kernel-Infrastructure");
- $globals.PackageStateObserver.comment="My current instance listens for any changes in the system that might affect the state of a package (being dirty).";
- $core.addMethod(
- $core.method({
- selector: "announcer",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.SystemAnnouncer)._current();
- }, function($ctx1) {$ctx1.fill(self,"announcer",{},$globals.PackageStateObserver)});
- },
- args: [],
- source: "announcer\x0a\x09^ SystemAnnouncer current",
- referencedClasses: ["SystemAnnouncer"],
- messageSends: ["current"]
- }),
- $globals.PackageStateObserver);
- $core.addMethod(
- $core.method({
- selector: "observeSystem",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._announcer();
- $recv($1)._on_send_to_($globals.PackageAdded,"onPackageAdded:",self);
- $ctx1.sendIdx["on:send:to:"]=1;
- $recv($1)._on_send_to_($globals.ClassAnnouncement,"onClassModification:",self);
- $ctx1.sendIdx["on:send:to:"]=2;
- $recv($1)._on_send_to_($globals.MethodAnnouncement,"onMethodModification:",self);
- $ctx1.sendIdx["on:send:to:"]=3;
- $recv($1)._on_send_to_($globals.ProtocolAnnouncement,"onProtocolModification:",self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"observeSystem",{},$globals.PackageStateObserver)});
- },
- args: [],
- source: "observeSystem\x0a\x09self announcer\x0a\x09\x09on: PackageAdded\x0a\x09\x09send: #onPackageAdded:\x0a\x09\x09to: self;\x0a\x09\x09\x0a\x09\x09on: ClassAnnouncement\x0a\x09\x09send: #onClassModification:\x0a\x09\x09to: self;\x0a\x09\x09\x0a\x09\x09on: MethodAnnouncement\x0a\x09\x09send: #onMethodModification:\x0a\x09\x09to: self;\x0a\x09\x09\x0a\x09\x09on: ProtocolAnnouncement\x0a\x09\x09send: #onProtocolModification:\x0a\x09\x09to: self",
- referencedClasses: ["PackageAdded", "ClassAnnouncement", "MethodAnnouncement", "ProtocolAnnouncement"],
- messageSends: ["on:send:to:", "announcer"]
- }),
- $globals.PackageStateObserver);
- $core.addMethod(
- $core.method({
- selector: "onClassModification:",
- protocol: "reactions",
- fn: function (anAnnouncement){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv(anAnnouncement)._theClass();
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- var theClass;
- theClass=$receiver;
- $recv($recv(theClass)._package())._beDirty();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"onClassModification:",{anAnnouncement:anAnnouncement},$globals.PackageStateObserver)});
- },
- args: ["anAnnouncement"],
- source: "onClassModification: anAnnouncement\x0a\x09anAnnouncement theClass ifNotNil: [ :theClass | theClass package beDirty ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "theClass", "beDirty", "package"]
- }),
- $globals.PackageStateObserver);
- $core.addMethod(
- $core.method({
- selector: "onMethodModification:",
- protocol: "reactions",
- fn: function (anAnnouncement){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv($recv(anAnnouncement)._method())._package();
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- var package_;
- package_=$receiver;
- $recv(package_)._beDirty();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"onMethodModification:",{anAnnouncement:anAnnouncement},$globals.PackageStateObserver)});
- },
- args: ["anAnnouncement"],
- source: "onMethodModification: anAnnouncement\x0a\x09anAnnouncement method package ifNotNil: [ :package | package beDirty ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "package", "method", "beDirty"]
- }),
- $globals.PackageStateObserver);
- $core.addMethod(
- $core.method({
- selector: "onPackageAdded:",
- protocol: "reactions",
- fn: function (anAnnouncement){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(anAnnouncement)._package())._beDirty();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"onPackageAdded:",{anAnnouncement:anAnnouncement},$globals.PackageStateObserver)});
- },
- args: ["anAnnouncement"],
- source: "onPackageAdded: anAnnouncement\x0a\x09anAnnouncement package beDirty",
- referencedClasses: [],
- messageSends: ["beDirty", "package"]
- }),
- $globals.PackageStateObserver);
- $core.addMethod(
- $core.method({
- selector: "onProtocolModification:",
- protocol: "reactions",
- fn: function (anAnnouncement){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv(anAnnouncement)._package();
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- var package_;
- package_=$receiver;
- $recv(package_)._beDirty();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"onProtocolModification:",{anAnnouncement:anAnnouncement},$globals.PackageStateObserver)});
- },
- args: ["anAnnouncement"],
- source: "onProtocolModification: anAnnouncement\x0a\x09anAnnouncement package ifNotNil: [ :package | package beDirty ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "package", "beDirty"]
- }),
- $globals.PackageStateObserver);
- $globals.PackageStateObserver.klass.iVarNames = ["current"];
- $core.addMethod(
- $core.method({
- selector: "current",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@current"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@current"]=self._new();
- return self["@current"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"current",{},$globals.PackageStateObserver.klass)});
- },
- args: [],
- source: "current\x0a\x09^ current ifNil: [ current := self new ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.PackageStateObserver.klass);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._current())._observeSystem();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.PackageStateObserver.klass)});
- },
- args: [],
- source: "initialize\x0a\x09self current observeSystem",
- referencedClasses: [],
- messageSends: ["observeSystem", "current"]
- }),
- $globals.PackageStateObserver.klass);
- $core.addClass("ParseError", $globals.Error, [], "Kernel-Infrastructure");
- $globals.ParseError.comment="Instance of ParseError are signaled on any parsing error.\x0aSee `Smalltalk >> #parse:`";
- $core.addClass("Setting", $globals.Object, ["key", "value", "defaultValue"], "Kernel-Infrastructure");
- $globals.Setting.comment="I represent a setting **stored** at `Smalltalk settings`. \x0aIn the current implementation, `Smalltalk settings` is an object persisted in the localStorage.\x0a\x0a## API\x0a\x0aA `Setting` value can be read using `value` and set using `value:`.\x0a\x0aSettings are accessed with `'key' asSetting` or `'key' asSettingIfAbsent: aDefaultValue`.\x0a\x0aTo read the value of a setting you can also use the convenience:\x0a\x0a`theValueSet := 'any.characteristic' settingValue` \x0a\x0aor with a default using:\x0a\x0a `theEnsuredValueSet := 'any.characteristic' settingValueIfAbsent: true`";
- $core.addMethod(
- $core.method({
- selector: "defaultValue",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@defaultValue"];
- },
- args: [],
- source: "defaultValue\x0a\x09^ defaultValue",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Setting);
- $core.addMethod(
- $core.method({
- selector: "defaultValue:",
- protocol: "accessing",
- fn: function (aStringifiableObject){
- var self=this;
- self["@defaultValue"]=aStringifiableObject;
- return self;
- },
- args: ["aStringifiableObject"],
- source: "defaultValue: aStringifiableObject\x0a\x09defaultValue := aStringifiableObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Setting);
- $core.addMethod(
- $core.method({
- selector: "key",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@key"];
- },
- args: [],
- source: "key\x0a\x09^ key",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Setting);
- $core.addMethod(
- $core.method({
- selector: "key:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@key"]=aString;
- return self;
- },
- args: ["aString"],
- source: "key: aString\x0a\x09key := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Setting);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Smalltalk)._settings())._at_ifAbsent_(self._key(),(function(){
- return $core.withContext(function($ctx2) {
- return self._defaultValue();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"value",{},$globals.Setting)});
- },
- args: [],
- source: "value\x0a\x09^ Smalltalk settings at: self key ifAbsent: [ self defaultValue ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["at:ifAbsent:", "settings", "key", "defaultValue"]
- }),
- $globals.Setting);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "accessing",
- fn: function (aStringifiableObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Smalltalk)._settings())._at_put_(self._key(),aStringifiableObject);
- }, function($ctx1) {$ctx1.fill(self,"value:",{aStringifiableObject:aStringifiableObject},$globals.Setting)});
- },
- args: ["aStringifiableObject"],
- source: "value: aStringifiableObject\x0a\x09^ Smalltalk settings at: self key put: aStringifiableObject",
- referencedClasses: ["Smalltalk"],
- messageSends: ["at:put:", "settings", "key"]
- }),
- $globals.Setting);
- $core.addMethod(
- $core.method({
- selector: "at:ifAbsent:",
- protocol: "instance creation",
- fn: function (aString,aDefaultValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(
- $ctx1.supercall = true,
- ($globals.Setting.klass.superclass||$boot.nilAsClass).fn.prototype._new.apply($recv(self), []));
- $ctx1.supercall = false;
- $recv($1)._key_(aString);
- $recv($1)._defaultValue_(aDefaultValue);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aString:aString,aDefaultValue:aDefaultValue},$globals.Setting.klass)});
- },
- args: ["aString", "aDefaultValue"],
- source: "at: aString ifAbsent: aDefaultValue\x0a\x09\x0a\x09^ super new\x0a\x09\x09key: aString;\x0a\x09\x09defaultValue: aDefaultValue;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["key:", "new", "defaultValue:", "yourself"]
- }),
- $globals.Setting.klass);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldNotImplement();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.Setting.klass)});
- },
- args: [],
- source: "new\x0a\x09self shouldNotImplement",
- referencedClasses: [],
- messageSends: ["shouldNotImplement"]
- }),
- $globals.Setting.klass);
- $core.addClass("SmalltalkImage", $globals.Object, [], "Kernel-Infrastructure");
- $globals.SmalltalkImage.comment="I represent the Smalltalk system, wrapping\x0aoperations of variable `$core` declared in `support/boot.js`.\x0a\x0a## API\x0a\x0aI have only one instance, accessed with global variable `Smalltalk`.\x0a\x0a## Classes\x0a\x0aClasses can be accessed using the following methods:\x0a\x0a- `#classes` answers the full list of Smalltalk classes in the system\x0a- `#globals #at:` answers a specific global (usually, a class) or `nil`\x0a\x0a## Packages\x0a\x0aPackages can be accessed using the following methods:\x0a\x0a- `#packages` answers the full list of packages\x0a- `#packageAt:` answers a specific package or `nil`\x0a\x0a## Parsing\x0a\x0aThe `#parse:` method is used to parse Amber source code.\x0aIt requires the `Compiler` package and the `support/parser.js` parser file in order to work.";
- $core.addMethod(
- $core.method({
- selector: "addGlobalJsVariable:",
- protocol: "globals",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._globalJsVariables())._add_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addGlobalJsVariable:",{aString:aString},$globals.SmalltalkImage)});
- },
- args: ["aString"],
- source: "addGlobalJsVariable: aString\x0a\x09self globalJsVariables add: aString",
- referencedClasses: [],
- messageSends: ["add:", "globalJsVariables"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "amdRequire",
- protocol: "accessing amd",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._core())._at_("amdRequire");
- }, function($ctx1) {$ctx1.fill(self,"amdRequire",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "amdRequire\x0a\x09^ self core at: 'amdRequire'",
- referencedClasses: [],
- messageSends: ["at:", "core"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "asSmalltalkException:",
- protocol: "error handling",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._isSmalltalkObject_(anObject))._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(anObject)._isKindOf_($globals.Error);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- if($core.assert($1)){
- return anObject;
- } else {
- return $recv($globals.JavaScriptException)._on_(anObject);
- }
- }, function($ctx1) {$ctx1.fill(self,"asSmalltalkException:",{anObject:anObject},$globals.SmalltalkImage)});
- },
- args: ["anObject"],
- source: "asSmalltalkException: anObject\x0a\x09\x22A JavaScript exception may be thrown.\x0a\x09We then need to convert it back to a Smalltalk object\x22\x0a\x09\x0a\x09^ ((self isSmalltalkObject: anObject) and: [ anObject isKindOf: Error ])\x0a\x09\x09ifTrue: [ anObject ]\x0a\x09\x09ifFalse: [ JavaScriptException on: anObject ]",
- referencedClasses: ["Error", "JavaScriptException"],
- messageSends: ["ifTrue:ifFalse:", "and:", "isSmalltalkObject:", "isKindOf:", "on:"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "basicCreatePackage:",
- protocol: "private",
- fn: function (packageName){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.addPackage(packageName);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicCreatePackage:",{packageName:packageName},$globals.SmalltalkImage)});
- },
- args: ["packageName"],
- source: "basicCreatePackage: packageName\x0a\x09\x22Create and bind a new bare package with given name and return it.\x22\x0a\x09<inlineJS: 'return $core.addPackage(packageName)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "basicParse:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.SmalltalkParser)._parse_(aString);
- }, function($ctx1) {$ctx1.fill(self,"basicParse:",{aString:aString},$globals.SmalltalkImage)});
- },
- args: ["aString"],
- source: "basicParse: aString\x0a\x09^ SmalltalkParser parse: aString",
- referencedClasses: ["SmalltalkParser"],
- messageSends: ["parse:"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "basicRegisterPackage:",
- protocol: "private",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.packages[aPackage.pkgName]=aPackage;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicRegisterPackage:",{aPackage:aPackage},$globals.SmalltalkImage)});
- },
- args: ["aPackage"],
- source: "basicRegisterPackage: aPackage\x0a\x09\x22Put aPackage in $core.packages object.\x22\x0a\x09<inlineJS: '$core.packages[aPackage.pkgName]=aPackage'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "cancelOptOut:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- delete anObject.klass;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"cancelOptOut:",{anObject:anObject},$globals.SmalltalkImage)});
- },
- args: ["anObject"],
- source: "cancelOptOut: anObject\x0a\x09\x22A Smalltalk object has a 'klass' property.\x0a\x09If this property is shadowed for anObject by optOut:,\x0a\x09the object is treated as plain JS object.\x0a\x09This removes the shadow and anObject is Smalltalk object\x0a\x09again if it was before.\x22\x0a\x09\x0a\x09<inlineJS: 'delete anObject.klass'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "classes",
- protocol: "classes",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.classes();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"classes",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "classes\x0a\x09<inlineJS: 'return $core.classes()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "core",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"core",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "core\x0a\x09<inlineJS: 'return $core'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "createPackage:",
- protocol: "packages",
- fn: function (packageName){
- var self=this;
- var package_,announcement;
- return $core.withContext(function($ctx1) {
- var $1;
- package_=self._basicCreatePackage_(packageName);
- $1=$recv($globals.PackageAdded)._new();
- $recv($1)._package_(package_);
- announcement=$recv($1)._yourself();
- $recv($recv($globals.SystemAnnouncer)._current())._announce_(announcement);
- return package_;
- }, function($ctx1) {$ctx1.fill(self,"createPackage:",{packageName:packageName,package_:package_,announcement:announcement},$globals.SmalltalkImage)});
- },
- args: ["packageName"],
- source: "createPackage: packageName\x0a\x09| package announcement |\x0a\x09\x0a\x09package := self basicCreatePackage: packageName.\x0a\x09\x0a\x09announcement := PackageAdded new\x0a\x09\x09package: package;\x0a\x09\x09yourself.\x0a\x09\x09\x0a\x09SystemAnnouncer current announce: announcement.\x0a\x09\x0a\x09^ package",
- referencedClasses: ["PackageAdded", "SystemAnnouncer"],
- messageSends: ["basicCreatePackage:", "package:", "new", "yourself", "announce:", "current"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "defaultAmdNamespace",
- protocol: "accessing amd",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "transport.defaultAmdNamespace"._settingValue();
- }, function($ctx1) {$ctx1.fill(self,"defaultAmdNamespace",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "defaultAmdNamespace\x0a\x09^ 'transport.defaultAmdNamespace' settingValue",
- referencedClasses: [],
- messageSends: ["settingValue"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "defaultAmdNamespace:",
- protocol: "accessing amd",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- "transport.defaultAmdNamespace"._settingValue_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"defaultAmdNamespace:",{aString:aString},$globals.SmalltalkImage)});
- },
- args: ["aString"],
- source: "defaultAmdNamespace: aString\x0a\x09'transport.defaultAmdNamespace' settingValue: aString",
- referencedClasses: [],
- messageSends: ["settingValue:"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "deleteClass:",
- protocol: "private",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $core.removeClass(aClass);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deleteClass:",{aClass:aClass},$globals.SmalltalkImage)});
- },
- args: ["aClass"],
- source: "deleteClass: aClass\x0a\x09\x22Deletes a class by deleting its binding only. Use #removeClass instead\x22\x0a\x09\x0a\x09<inlineJS: '$core.removeClass(aClass)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "deleteGlobalJsVariable:",
- protocol: "globals",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._globalJsVariables())._remove_ifAbsent_(aString,(function(){
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deleteGlobalJsVariable:",{aString:aString},$globals.SmalltalkImage)});
- },
- args: ["aString"],
- source: "deleteGlobalJsVariable: aString\x0a\x09self globalJsVariables remove: aString ifAbsent:[]",
- referencedClasses: [],
- messageSends: ["remove:ifAbsent:", "globalJsVariables"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "deletePackage:",
- protocol: "private",
- fn: function (packageName){
- var self=this;
- return $core.withContext(function($ctx1) {
- delete $core.packages[packageName];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deletePackage:",{packageName:packageName},$globals.SmalltalkImage)});
- },
- args: ["packageName"],
- source: "deletePackage: packageName\x0a\x09\x22Deletes a package by deleting its binding, but does not check if it contains classes etc.\x0a\x09To remove a package, use #removePackage instead.\x22\x0a\x0a\x09<inlineJS: 'delete $core.packages[packageName]'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "existsJsGlobal:",
- protocol: "testing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Platform)._globals())._at_ifPresent_ifAbsent_(aString,(function(){
- return true;
- }),(function(){
- return false;
- }));
- }, function($ctx1) {$ctx1.fill(self,"existsJsGlobal:",{aString:aString},$globals.SmalltalkImage)});
- },
- args: ["aString"],
- source: "existsJsGlobal: aString\x0a\x09^ Platform globals \x0a\x09\x09at: aString \x0a\x09\x09ifPresent: [ true ] \x0a\x09\x09ifAbsent: [ false ]",
- referencedClasses: ["Platform"],
- messageSends: ["at:ifPresent:ifAbsent:", "globals"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "globalJsVariables",
- protocol: "globals",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.globalJsVariables;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"globalJsVariables",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "globalJsVariables\x0a\x09\x22Array of global JavaScript variables\x22\x0a\x09<inlineJS: 'return $core.globalJsVariables'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "globals",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $globals;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"globals",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "globals\x0a\x09<inlineJS: 'return $globals'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "includesKey:",
- protocol: "accessing",
- fn: function (aKey){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.hasOwnProperty(aKey);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"includesKey:",{aKey:aKey},$globals.SmalltalkImage)});
- },
- args: ["aKey"],
- source: "includesKey: aKey\x0a\x09<inlineJS: 'return $core.hasOwnProperty(aKey)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "isSmalltalkObject:",
- protocol: "testing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return anObject.klass != null;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"isSmalltalkObject:",{anObject:anObject},$globals.SmalltalkImage)});
- },
- args: ["anObject"],
- source: "isSmalltalkObject: anObject\x0a\x09\x22Consider anObject a Smalltalk object if it has a 'klass' property.\x0a\x09Note that this may be unaccurate\x22\x0a\x09\x0a\x09<inlineJS: 'return anObject.klass != null'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "optOut:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- anObject.klass = null;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"optOut:",{anObject:anObject},$globals.SmalltalkImage)});
- },
- args: ["anObject"],
- source: "optOut: anObject\x0a\x09\x22A Smalltalk object has a 'klass' property.\x0a\x09This shadows the property for anObject.\x0a\x09The object is treated as plain JS object following this.\x22\x0a\x09\x0a\x09<inlineJS: 'anObject.klass = null'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "packageAt:",
- protocol: "packages",
- fn: function (packageName){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.packages[packageName];
- return self;
- }, function($ctx1) {$ctx1.fill(self,"packageAt:",{packageName:packageName},$globals.SmalltalkImage)});
- },
- args: ["packageName"],
- source: "packageAt: packageName\x0a\x09<inlineJS: 'return $core.packages[packageName]'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "packageAt:ifAbsent:",
- protocol: "packages",
- fn: function (packageName,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._packageAt_(packageName);
- return $recv($1)._ifNil_(aBlock);
- }, function($ctx1) {$ctx1.fill(self,"packageAt:ifAbsent:",{packageName:packageName,aBlock:aBlock},$globals.SmalltalkImage)});
- },
- args: ["packageName", "aBlock"],
- source: "packageAt: packageName ifAbsent: aBlock\x0a\x09^ (self packageAt: packageName) ifNil: aBlock",
- referencedClasses: [],
- messageSends: ["ifNil:", "packageAt:"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "packages",
- protocol: "packages",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Object.keys($core.packages).map(function(k) {
- return $core.packages[k];
- })
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"packages",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "packages\x0a\x09\x22Return all Package instances in the system.\x22\x0a\x0a\x09<inlineJS: '\x0a\x09\x09return Object.keys($core.packages).map(function(k) {\x0a\x09\x09\x09return $core.packages[k];\x0a\x09\x09})\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "parse:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- result=self._basicParse_(aString);
- return result;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._tryCatch_((function(ex){
- return $core.withContext(function($ctx2) {
- return $recv(self._parseError_parsing_(ex,aString))._signal();
- }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,2)});
- }));
- $1=result;
- $recv($1)._source_(aString);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString,result:result},$globals.SmalltalkImage)});
- },
- args: ["aString"],
- source: "parse: aString\x0a\x09| result |\x0a\x09\x0a\x09[ result := self basicParse: aString ] \x0a\x09\x09tryCatch: [ :ex | (self parseError: ex parsing: aString) signal ].\x0a\x09\x09\x0a\x09^ result\x0a\x09\x09source: aString;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["tryCatch:", "basicParse:", "signal", "parseError:parsing:", "source:", "yourself"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "parseError:parsing:",
- protocol: "error handling",
- fn: function (anException,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$7,$6,$5,$8,$4,$3,$2;
- $1=$recv($globals.ParseError)._new();
- $7=$recv(anException)._basicAt_("line");
- $ctx1.sendIdx["basicAt:"]=1;
- $6="Parse error on line ".__comma($7);
- $5=$recv($6).__comma(" column ");
- $ctx1.sendIdx[","]=4;
- $8=$recv(anException)._basicAt_("column");
- $ctx1.sendIdx["basicAt:"]=2;
- $4=$recv($5).__comma($8);
- $ctx1.sendIdx[","]=3;
- $3=$recv($4).__comma(" : Unexpected character ");
- $ctx1.sendIdx[","]=2;
- $2=$recv($3).__comma($recv(anException)._basicAt_("found"));
- $ctx1.sendIdx[","]=1;
- return $recv($1)._messageText_($2);
- }, function($ctx1) {$ctx1.fill(self,"parseError:parsing:",{anException:anException,aString:aString},$globals.SmalltalkImage)});
- },
- args: ["anException", "aString"],
- source: "parseError: anException parsing: aString\x0a\x09^ ParseError new messageText: 'Parse error on line ', (anException basicAt: 'line') ,' column ' , (anException basicAt: 'column') ,' : Unexpected character ', (anException basicAt: 'found')",
- referencedClasses: ["ParseError"],
- messageSends: ["messageText:", "new", ",", "basicAt:"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "pseudoVariableNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return ["self", "super", "nil", "true", "false", "thisContext"];
- },
- args: [],
- source: "pseudoVariableNames\x0a\x09^ #('self' 'super' 'nil' 'true' 'false' 'thisContext')",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "readJSObject:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.readJSObject(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"readJSObject:",{anObject:anObject},$globals.SmalltalkImage)});
- },
- args: ["anObject"],
- source: "readJSObject: anObject\x0a\x09<inlineJS: 'return $core.readJSObject(anObject)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "removeClass:",
- protocol: "classes",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$5,$4,$6,$3,$7,$9,$8;
- $1=$recv(aClass)._isMetaclass();
- if($core.assert($1)){
- $2=$recv($recv(aClass)._asString()).__comma(" is a Metaclass and cannot be removed!");
- $ctx1.sendIdx[","]=1;
- self._error_($2);
- $ctx1.sendIdx["error:"]=1;
- }
- $recv(aClass)._allSubclassesDo_((function(subclass){
- return $core.withContext(function($ctx2) {
- $5=$recv(aClass)._name();
- $ctx2.sendIdx["name"]=1;
- $4=$recv($5).__comma(" has a subclass: ");
- $ctx2.sendIdx[","]=3;
- $6=$recv(subclass)._name();
- $ctx2.sendIdx["name"]=2;
- $3=$recv($4).__comma($6);
- $ctx2.sendIdx[","]=2;
- return self._error_($3);
- $ctx2.sendIdx["error:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({subclass:subclass},$ctx1,2)});
- }));
- $recv($recv(aClass)._traitUsers())._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return self._error_($recv($recv(aClass)._name()).__comma(" has trait users."));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- self._deleteClass_(aClass);
- $recv(aClass)._setTraitComposition_([]);
- $ctx1.sendIdx["setTraitComposition:"]=1;
- $recv($recv(aClass)._class())._setTraitComposition_([]);
- $7=$recv($globals.SystemAnnouncer)._current();
- $9=$recv($globals.ClassRemoved)._new();
- $recv($9)._theClass_(aClass);
- $8=$recv($9)._yourself();
- $recv($7)._announce_($8);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeClass:",{aClass:aClass},$globals.SmalltalkImage)});
- },
- args: ["aClass"],
- source: "removeClass: aClass\x0a\x09aClass isMetaclass ifTrue: [ self error: aClass asString, ' is a Metaclass and cannot be removed!' ].\x0a\x09aClass allSubclassesDo: [ :subclass | self error: aClass name, ' has a subclass: ', subclass name ].\x0a\x09aClass traitUsers ifNotEmpty: [ self error: aClass name, ' has trait users.' ].\x0a\x09\x0a\x09self deleteClass: aClass.\x0a\x09aClass setTraitComposition: #().\x0a\x09aClass class setTraitComposition: #().\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassRemoved new\x0a\x09\x09\x09theClass: aClass;\x0a\x09\x09\x09yourself)",
- referencedClasses: ["SystemAnnouncer", "ClassRemoved"],
- messageSends: ["ifTrue:", "isMetaclass", "error:", ",", "asString", "allSubclassesDo:", "name", "ifNotEmpty:", "traitUsers", "deleteClass:", "setTraitComposition:", "class", "announce:", "current", "theClass:", "new", "yourself"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "removePackage:",
- protocol: "packages",
- fn: function (packageName){
- var self=this;
- var pkg;
- return $core.withContext(function($ctx1) {
- pkg=self._packageAt_ifAbsent_(packageName,(function(){
- return $core.withContext(function($ctx2) {
- return self._error_("Missing package: ".__comma(packageName));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv($recv(pkg)._classes())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._removeClass_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- self._deletePackage_(packageName);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removePackage:",{packageName:packageName,pkg:pkg},$globals.SmalltalkImage)});
- },
- args: ["packageName"],
- source: "removePackage: packageName\x0a\x09\x22Removes a package and all its classes.\x22\x0a\x0a\x09| pkg |\x0a\x09pkg := self packageAt: packageName ifAbsent: [ self error: 'Missing package: ', packageName ].\x0a\x09pkg classes do: [ :each |\x0a\x09\x09\x09self removeClass: each ].\x0a\x09self deletePackage: packageName",
- referencedClasses: [],
- messageSends: ["packageAt:ifAbsent:", "error:", ",", "do:", "classes", "removeClass:", "deletePackage:"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "renamePackage:to:",
- protocol: "packages",
- fn: function (packageName,newName){
- var self=this;
- var pkg;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- pkg=self._packageAt_ifAbsent_(packageName,(function(){
- return $core.withContext(function($ctx2) {
- $1="Missing package: ".__comma(packageName);
- $ctx2.sendIdx[","]=1;
- return self._error_($1);
- $ctx2.sendIdx["error:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $2=self._packageAt_(newName);
- if(($receiver = $2) == null || $receiver.isNil){
- $2;
- } else {
- self._error_("Already exists a package called: ".__comma(newName));
- }
- $recv(pkg)._name_(newName);
- self._basicRegisterPackage_(pkg);
- self._deletePackage_(packageName);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"renamePackage:to:",{packageName:packageName,newName:newName,pkg:pkg},$globals.SmalltalkImage)});
- },
- args: ["packageName", "newName"],
- source: "renamePackage: packageName to: newName\x0a\x09\x22Rename a package.\x22\x0a\x0a\x09| pkg |\x0a\x09pkg := self packageAt: packageName ifAbsent: [ self error: 'Missing package: ', packageName ].\x0a\x09(self packageAt: newName) ifNotNil: [ self error: 'Already exists a package called: ', newName ].\x0a\x09pkg name: newName.\x0a\x09self basicRegisterPackage: pkg.\x0a\x09self deletePackage: packageName.",
- referencedClasses: [],
- messageSends: ["packageAt:ifAbsent:", "error:", ",", "ifNotNil:", "packageAt:", "name:", "basicRegisterPackage:", "deletePackage:"]
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "reservedWords",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.reservedWords;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"reservedWords",{},$globals.SmalltalkImage)});
- },
- args: [],
- source: "reservedWords\x0a\x09\x22JavaScript reserved words\x22\x0a\x09<inlineJS: 'return $core.reservedWords'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "settings",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.SmalltalkSettings;
- },
- args: [],
- source: "settings\x0a\x09^ SmalltalkSettings",
- referencedClasses: ["SmalltalkSettings"],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $core.addMethod(
- $core.method({
- selector: "version",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "0.18.5";
- },
- args: [],
- source: "version\x0a\x09\x22Answer the version string of Amber\x22\x0a\x09\x0a\x09^ '0.18.5'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SmalltalkImage);
- $globals.SmalltalkImage.klass.iVarNames = ["current"];
- $core.addMethod(
- $core.method({
- selector: "current",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@current"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@current"]=(
- $ctx1.supercall = true,
- ($globals.SmalltalkImage.klass.superclass||$boot.nilAsClass).fn.prototype._new.apply($recv(self), []));
- $ctx1.supercall = false;
- return self["@current"];
- } else {
- self._deprecatedAPI();
- return self["@current"];
- }
- }, function($ctx1) {$ctx1.fill(self,"current",{},$globals.SmalltalkImage.klass)});
- },
- args: [],
- source: "current\x0a\x09^ current ifNil: [ current := super new ] ifNotNil: [ self deprecatedAPI. current ]",
- referencedClasses: [],
- messageSends: ["ifNil:ifNotNil:", "new", "deprecatedAPI"]
- }),
- $globals.SmalltalkImage.klass);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- var st;
- return $core.withContext(function($ctx1) {
- st=self._current();
- $recv($recv(st)._globals())._at_put_("Smalltalk",st);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{st:st},$globals.SmalltalkImage.klass)});
- },
- args: [],
- source: "initialize\x0a\x09| st |\x0a\x09st := self current.\x0a\x09st globals at: 'Smalltalk' put: st",
- referencedClasses: [],
- messageSends: ["current", "at:put:", "globals"]
- }),
- $globals.SmalltalkImage.klass);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldNotImplement();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.SmalltalkImage.klass)});
- },
- args: [],
- source: "new\x0a\x09self shouldNotImplement",
- referencedClasses: [],
- messageSends: ["shouldNotImplement"]
- }),
- $globals.SmalltalkImage.klass);
- $core.addMethod(
- $core.method({
- selector: "nextPutJSObject:",
- protocol: "*Kernel-Infrastructure",
- fn: function (aJSObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._nextPut_(aJSObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutJSObject:",{aJSObject:aJSObject},$globals.ProtoStream)});
- },
- args: ["aJSObject"],
- source: "nextPutJSObject: aJSObject\x0a\x09self nextPut: aJSObject",
- referencedClasses: [],
- messageSends: ["nextPut:"]
- }),
- $globals.ProtoStream);
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptPropertyName",
- protocol: "*Kernel-Infrastructure",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $core.st2prop(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptPropertyName",{},$globals.String)});
- },
- args: [],
- source: "asJavaScriptPropertyName\x0a<inlineJS: 'return $core.st2prop(self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asSetting",
- protocol: "*Kernel-Infrastructure",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Setting)._at_ifAbsent_(self,nil);
- }, function($ctx1) {$ctx1.fill(self,"asSetting",{},$globals.String)});
- },
- args: [],
- source: "asSetting\x0a\x09\x22Answer aSetting dedicated to locally store a value using this string as key.\x0a\x09Nil will be the default value.\x22\x0a\x09^ Setting at: self ifAbsent: nil",
- referencedClasses: ["Setting"],
- messageSends: ["at:ifAbsent:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "asSettingIfAbsent:",
- protocol: "*Kernel-Infrastructure",
- fn: function (aDefaultValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Setting)._at_ifAbsent_(self,aDefaultValue);
- }, function($ctx1) {$ctx1.fill(self,"asSettingIfAbsent:",{aDefaultValue:aDefaultValue},$globals.String)});
- },
- args: ["aDefaultValue"],
- source: "asSettingIfAbsent: aDefaultValue\x0a\x09\x22Answer aSetting dedicated to locally store a value using this string as key.\x0a\x09Make this setting to have aDefaultValue.\x22\x0a\x09^ Setting at: self ifAbsent: aDefaultValue",
- referencedClasses: ["Setting"],
- messageSends: ["at:ifAbsent:"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "settingValue",
- protocol: "*Kernel-Infrastructure",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asSetting())._value();
- }, function($ctx1) {$ctx1.fill(self,"settingValue",{},$globals.String)});
- },
- args: [],
- source: "settingValue\x0a\x09^ self asSetting value",
- referencedClasses: [],
- messageSends: ["value", "asSetting"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "settingValue:",
- protocol: "*Kernel-Infrastructure",
- fn: function (aValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asSetting())._value_(aValue);
- }, function($ctx1) {$ctx1.fill(self,"settingValue:",{aValue:aValue},$globals.String)});
- },
- args: ["aValue"],
- source: "settingValue: aValue\x0a\x09\x22Sets the value of the setting that will be locally stored using this string as key.\x0a\x09Note that aValue can be any object that can be stringifyed\x22\x0a\x09^ self asSetting value: aValue",
- referencedClasses: [],
- messageSends: ["value:", "asSetting"]
- }),
- $globals.String);
- $core.addMethod(
- $core.method({
- selector: "settingValueIfAbsent:",
- protocol: "*Kernel-Infrastructure",
- fn: function (aDefaultValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._asSettingIfAbsent_(aDefaultValue))._value();
- }, function($ctx1) {$ctx1.fill(self,"settingValueIfAbsent:",{aDefaultValue:aDefaultValue},$globals.String)});
- },
- args: ["aDefaultValue"],
- source: "settingValueIfAbsent: aDefaultValue\x0a\x09\x22Answer the value of the locally stored setting using this string as key.\x0a\x09Use aDefaultValue in case no setting is found\x22\x0a\x09^ (self asSettingIfAbsent: aDefaultValue) value",
- referencedClasses: [],
- messageSends: ["value", "asSettingIfAbsent:"]
- }),
- $globals.String);
- });
- define('amber_core/Kernel-Promises',["amber/boot", "amber_core/Kernel-Infrastructure", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Promises");
- $core.packages["Kernel-Promises"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Promises"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("Thenable", $globals.Object, [], "Kernel-Promises");
- $globals.Thenable.comment="I am the abstract base class for Promises.\x0a\x0aMy subclasses should wrap existing JS implementations.\x0a\x0aI contain methods that wrap Promises/A+ `.then` behaviour.";
- $core.addMethod(
- $core.method({
- selector: "catch:",
- protocol: "promises",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.then(null, function (err) {return $core.seamless(function () {
- return aBlock._value_(err);
- })});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"catch:",{aBlock:aBlock},$globals.Thenable)});
- },
- args: ["aBlock"],
- source: "catch: aBlock\x0a<inlineJS: 'return self.then(null, function (err) {return $core.seamless(function () {\x0a return aBlock._value_(err);\x0a})})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Thenable);
- $core.addMethod(
- $core.method({
- selector: "on:do:",
- protocol: "promises",
- fn: function (aClass,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.then(null, function (err) {return $core.seamless(function () {
- if (err._isKindOf_(aClass)) return aBlock._value_(err);
- else throw err;
- })});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:do:",{aClass:aClass,aBlock:aBlock},$globals.Thenable)});
- },
- args: ["aClass", "aBlock"],
- source: "on: aClass do: aBlock\x0a<inlineJS: 'return self.then(null, function (err) {return $core.seamless(function () {\x0a if (err._isKindOf_(aClass)) return aBlock._value_(err);\x0a else throw err;\x0a})})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Thenable);
- $core.addMethod(
- $core.method({
- selector: "on:do:catch:",
- protocol: "promises",
- fn: function (aClass,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.then(null, function (err) {return $core.seamless(function () {
- try { if (err._isKindOf_(aClass)) return aBlock._value_(err); } catch (e) { err = e; }
- return anotherBlock._value_(err);
- })});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:do:catch:",{aClass:aClass,aBlock:aBlock,anotherBlock:anotherBlock},$globals.Thenable)});
- },
- args: ["aClass", "aBlock", "anotherBlock"],
- source: "on: aClass do: aBlock catch: anotherBlock\x0a<inlineJS: 'return self.then(null, function (err) {return $core.seamless(function () {\x0a try { if (err._isKindOf_(aClass)) return aBlock._value_(err); } catch (e) { err = e; }\x0a return anotherBlock._value_(err);\x0a})})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Thenable);
- $core.addMethod(
- $core.method({
- selector: "then:",
- protocol: "promises",
- fn: function (aBlockOrArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var array = Array.isArray(aBlockOrArray) ? aBlockOrArray : [aBlockOrArray];
- return array.reduce(function (soFar, aBlock) {
- return soFar.then(typeof aBlock === "function" && aBlock.length > 1 ?
- function (result) {return $core.seamless(function () {
- if (Array.isArray(result)) {
- return aBlock._valueWithPossibleArguments_([result].concat(result.slice(0, aBlock.length-1)));
- } else {
- return aBlock._value_(result);
- }
- })} :
- function (result) {return $core.seamless(function () {
- return aBlock._value_(result);
- })}
- );
- }, self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"then:",{aBlockOrArray:aBlockOrArray},$globals.Thenable)});
- },
- args: ["aBlockOrArray"],
- source: "then: aBlockOrArray\x0a\x22Accepts a block or array of blocks.\x0aEach of blocks in the array or the singleton one is\x0aused in .then call to a promise, to accept a result\x0aand transform it to the result for the next one.\x0aIn case a block has more than one argument\x0aand result is an array, first n-1 elements of the array\x0aare put into additional arguments beyond the first.\x0aThe first argument always contains the result as-is.\x22\x0a<inlineJS: '\x0avar array = Array.isArray(aBlockOrArray) ? aBlockOrArray : [aBlockOrArray];\x0areturn array.reduce(function (soFar, aBlock) {\x0a return soFar.then(typeof aBlock === \x22function\x22 && aBlock.length > 1 ?\x0a function (result) {return $core.seamless(function () {\x0a if (Array.isArray(result)) {\x0a return aBlock._valueWithPossibleArguments_([result].concat(result.slice(0, aBlock.length-1)));\x0a } else {\x0a return aBlock._value_(result);\x0a }\x0a })} :\x0a function (result) {return $core.seamless(function () {\x0a return aBlock._value_(result);\x0a })}\x0a );\x0a}, self)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Thenable);
- $core.addMethod(
- $core.method({
- selector: "then:catch:",
- protocol: "promises",
- fn: function (aBlockOrArray,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._then_(aBlockOrArray))._catch_(anotherBlock);
- }, function($ctx1) {$ctx1.fill(self,"then:catch:",{aBlockOrArray:aBlockOrArray,anotherBlock:anotherBlock},$globals.Thenable)});
- },
- args: ["aBlockOrArray", "anotherBlock"],
- source: "then: aBlockOrArray catch: anotherBlock\x0a\x09^ (self then: aBlockOrArray) catch: anotherBlock",
- referencedClasses: [],
- messageSends: ["catch:", "then:"]
- }),
- $globals.Thenable);
- $core.addMethod(
- $core.method({
- selector: "then:on:do:",
- protocol: "promises",
- fn: function (aBlockOrArray,aClass,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._then_(aBlockOrArray))._on_do_(aClass,aBlock);
- }, function($ctx1) {$ctx1.fill(self,"then:on:do:",{aBlockOrArray:aBlockOrArray,aClass:aClass,aBlock:aBlock},$globals.Thenable)});
- },
- args: ["aBlockOrArray", "aClass", "aBlock"],
- source: "then: aBlockOrArray on: aClass do: aBlock\x0a\x09^ (self then: aBlockOrArray) on: aClass do: aBlock",
- referencedClasses: [],
- messageSends: ["on:do:", "then:"]
- }),
- $globals.Thenable);
- $core.addMethod(
- $core.method({
- selector: "then:on:do:catch:",
- protocol: "promises",
- fn: function (aBlockOrArray,aClass,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._then_(aBlockOrArray))._on_do_(aClass,aBlock))._catch_(anotherBlock);
- }, function($ctx1) {$ctx1.fill(self,"then:on:do:catch:",{aBlockOrArray:aBlockOrArray,aClass:aClass,aBlock:aBlock,anotherBlock:anotherBlock},$globals.Thenable)});
- },
- args: ["aBlockOrArray", "aClass", "aBlock", "anotherBlock"],
- source: "then: aBlockOrArray on: aClass do: aBlock catch: anotherBlock\x0a\x09^ ((self then: aBlockOrArray) on: aClass do: aBlock) catch: anotherBlock",
- referencedClasses: [],
- messageSends: ["catch:", "on:do:", "then:"]
- }),
- $globals.Thenable);
- $core.addClass("Promise", $globals.Thenable, [], "Kernel-Promises");
- $core.addMethod(
- $core.method({
- selector: "all:",
- protocol: "composites",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Promise.all($recv(aCollection)._asArray());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"all:",{aCollection:aCollection},$globals.Promise.klass)});
- },
- args: ["aCollection"],
- source: "all: aCollection\x0a\x22Returns a Promise resolved with results of sub-promises.\x22\x0a<inlineJS: 'return Promise.all($recv(aCollection)._asArray())'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Promise.klass);
- $core.addMethod(
- $core.method({
- selector: "any:",
- protocol: "composites",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Promise.race($recv(aCollection)._asArray());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"any:",{aCollection:aCollection},$globals.Promise.klass)});
- },
- args: ["aCollection"],
- source: "any: aCollection\x0a\x22Returns a Promise resolved with first result of sub-promises.\x22\x0a<inlineJS: 'return Promise.race($recv(aCollection)._asArray())'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Promise.klass);
- $core.addMethod(
- $core.method({
- selector: "forBlock:",
- protocol: "instance creation",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._new())._then_(aBlock);
- }, function($ctx1) {$ctx1.fill(self,"forBlock:",{aBlock:aBlock},$globals.Promise.klass)});
- },
- args: ["aBlock"],
- source: "forBlock: aBlock\x0a\x22Returns a Promise that is resolved with the value of aBlock,\x0aand rejected if error happens while evaluating aBlock.\x22\x0a\x09^ self new then: aBlock",
- referencedClasses: [],
- messageSends: ["then:", "new"]
- }),
- $globals.Promise.klass);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Promise.resolve();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.Promise.klass)});
- },
- args: [],
- source: "new\x0a\x22Returns a dumb Promise resolved with nil.\x22\x0a<inlineJS: 'return Promise.resolve()'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Promise.klass);
- $core.addMethod(
- $core.method({
- selector: "new:",
- protocol: "instance creation",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new Promise(function (resolve, reject) {
- var model = {value: resolve, signal: reject}; // TODO make faster
- aBlock._value_(model);
- });
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new:",{aBlock:aBlock},$globals.Promise.klass)});
- },
- args: ["aBlock"],
- source: "new: aBlock\x0a\x22Returns a Promise that is eventually resolved or rejected.\x0aPass a block that is called with one argument, model.\x0aYou should call model value: ... to resolve the promise\x0aand model signal: ... to reject the promise.\x0aIf error happens during run of the block,\x0apromise is rejected with that error as well.\x22\x0a<inlineJS: 'return new Promise(function (resolve, reject) {\x0a var model = {value: resolve, signal: reject}; // TODO make faster\x0a aBlock._value_(model);\x0a})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Promise.klass);
- $core.addMethod(
- $core.method({
- selector: "signal:",
- protocol: "instance creation",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anObject)._in_(function (x) {return Promise.reject(x)});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"signal:",{anObject:anObject},$globals.Promise.klass)});
- },
- args: ["anObject"],
- source: "signal: anObject\x0a\x22Returns a Promise rejected with anObject.\x22\x0a<inlineJS: 'return $recv(anObject)._in_(function (x) {return Promise.reject(x)})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Promise.klass);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "instance creation",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anObject)._in_(function (x) {return Promise.resolve(x)});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"value:",{anObject:anObject},$globals.Promise.klass)});
- },
- args: ["anObject"],
- source: "value: anObject\x0a\x22Returns a Promise resolved with anObject.\x22\x0a<inlineJS: 'return $recv(anObject)._in_(function (x) {return Promise.resolve(x)})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Promise.klass);
- $core.addMethod(
- $core.method({
- selector: "catch:",
- protocol: "*Kernel-Promises",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self["@jsObject"];
- if (typeof js.then === "function")
- return $globals.Thenable.fn.prototype._catch_.call(js, aBlock);
- else
- return self._doesNotUnderstand_(
- $globals.Message._new()
- ._selector_("catch:")
- ._arguments_([aBlock])
- );
- return self;
- }, function($ctx1) {$ctx1.fill(self,"catch:",{aBlock:aBlock},$globals.JSObjectProxy)});
- },
- args: ["aBlock"],
- source: "catch: aBlock\x0a<inlineJS: 'var js = self[\x22@jsObject\x22];\x0aif (typeof js.then === \x22function\x22)\x0a return $globals.Thenable.fn.prototype._catch_.call(js, aBlock);\x0aelse\x0a return self._doesNotUnderstand_(\x0a $globals.Message._new()\x0a ._selector_(\x22catch:\x22)\x0a ._arguments_([aBlock])\x0a )'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "on:do:",
- protocol: "*Kernel-Promises",
- fn: function (aClass,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self["@jsObject"];
- if (typeof js.then === "function")
- return $globals.Thenable.fn.prototype._on_do_.call(js, aClass, aBlock);
- else
- return self._doesNotUnderstand_(
- $globals.Message._new()
- ._selector_("on:do:")
- ._arguments_([aClass, aBlock])
- );
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:do:",{aClass:aClass,aBlock:aBlock},$globals.JSObjectProxy)});
- },
- args: ["aClass", "aBlock"],
- source: "on: aClass do: aBlock\x0a<inlineJS: 'var js = self[\x22@jsObject\x22];\x0aif (typeof js.then === \x22function\x22)\x0a return $globals.Thenable.fn.prototype._on_do_.call(js, aClass, aBlock);\x0aelse\x0a return self._doesNotUnderstand_(\x0a $globals.Message._new()\x0a ._selector_(\x22on:do:\x22)\x0a ._arguments_([aClass, aBlock])\x0a )'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "on:do:catch:",
- protocol: "*Kernel-Promises",
- fn: function (aClass,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self["@jsObject"];
- if (typeof js.then === "function")
- return $globals.Thenable.fn.prototype._on_do_catch_.call(js, aClass, aBlock, anotherBlock);
- else
- return self._doesNotUnderstand_(
- $globals.Message._new()
- ._selector_("on:do:catch:")
- ._arguments_([aClass, aBlock, anotherBlock])
- );
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:do:catch:",{aClass:aClass,aBlock:aBlock,anotherBlock:anotherBlock},$globals.JSObjectProxy)});
- },
- args: ["aClass", "aBlock", "anotherBlock"],
- source: "on: aClass do: aBlock catch: anotherBlock\x0a<inlineJS: 'var js = self[\x22@jsObject\x22];\x0aif (typeof js.then === \x22function\x22)\x0a return $globals.Thenable.fn.prototype._on_do_catch_.call(js, aClass, aBlock, anotherBlock);\x0aelse\x0a return self._doesNotUnderstand_(\x0a $globals.Message._new()\x0a ._selector_(\x22on:do:catch:\x22)\x0a ._arguments_([aClass, aBlock, anotherBlock])\x0a )'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "then:",
- protocol: "*Kernel-Promises",
- fn: function (aBlockOrArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self["@jsObject"];
- if (typeof js.then === "function")
- return $globals.Thenable.fn.prototype._then_.call(js, aBlockOrArray);
- else
- return self._doesNotUnderstand_(
- $globals.Message._new()
- ._selector_("then:")
- ._arguments_([aBlockOrArray])
- );
- return self;
- }, function($ctx1) {$ctx1.fill(self,"then:",{aBlockOrArray:aBlockOrArray},$globals.JSObjectProxy)});
- },
- args: ["aBlockOrArray"],
- source: "then: aBlockOrArray\x0a<inlineJS: 'var js = self[\x22@jsObject\x22];\x0aif (typeof js.then === \x22function\x22)\x0a return $globals.Thenable.fn.prototype._then_.call(js, aBlockOrArray);\x0aelse\x0a return self._doesNotUnderstand_(\x0a $globals.Message._new()\x0a ._selector_(\x22then:\x22)\x0a ._arguments_([aBlockOrArray])\x0a )'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "then:catch:",
- protocol: "*Kernel-Promises",
- fn: function (aBlockOrArray,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self["@jsObject"];
- if (typeof js.then === "function")
- return $globals.Thenable.fn.prototype._then_catch_.call(js, aBlockOrArray, anotherBlock);
- else
- return self._doesNotUnderstand_(
- $globals.Message._new()
- ._selector_("then:catch:")
- ._arguments_([aBlockOrArray, anotherBlock])
- );
- return self;
- }, function($ctx1) {$ctx1.fill(self,"then:catch:",{aBlockOrArray:aBlockOrArray,anotherBlock:anotherBlock},$globals.JSObjectProxy)});
- },
- args: ["aBlockOrArray", "anotherBlock"],
- source: "then: aBlockOrArray catch: anotherBlock\x0a<inlineJS: 'var js = self[\x22@jsObject\x22];\x0aif (typeof js.then === \x22function\x22)\x0a return $globals.Thenable.fn.prototype._then_catch_.call(js, aBlockOrArray, anotherBlock);\x0aelse\x0a return self._doesNotUnderstand_(\x0a $globals.Message._new()\x0a ._selector_(\x22then:catch:\x22)\x0a ._arguments_([aBlockOrArray, anotherBlock])\x0a )'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "then:on:do:",
- protocol: "*Kernel-Promises",
- fn: function (aBlockOrArray,aClass,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self["@jsObject"];
- if (typeof js.then === "function")
- return $globals.Thenable.fn.prototype._then_on_do_.call(js, aBlockOrArray, aClass, aBlock);
- else
- return self._doesNotUnderstand_(
- $globals.Message._new()
- ._selector_("then:on:do:")
- ._arguments_([aBlockOrArray, aClass, aBlock])
- );
- return self;
- }, function($ctx1) {$ctx1.fill(self,"then:on:do:",{aBlockOrArray:aBlockOrArray,aClass:aClass,aBlock:aBlock},$globals.JSObjectProxy)});
- },
- args: ["aBlockOrArray", "aClass", "aBlock"],
- source: "then: aBlockOrArray on: aClass do: aBlock\x0a<inlineJS: 'var js = self[\x22@jsObject\x22];\x0aif (typeof js.then === \x22function\x22)\x0a return $globals.Thenable.fn.prototype._then_on_do_.call(js, aBlockOrArray, aClass, aBlock);\x0aelse\x0a return self._doesNotUnderstand_(\x0a $globals.Message._new()\x0a ._selector_(\x22then:on:do:\x22)\x0a ._arguments_([aBlockOrArray, aClass, aBlock])\x0a )'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "then:on:do:catch:",
- protocol: "*Kernel-Promises",
- fn: function (aBlockOrArray,aClass,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var js = self["@jsObject"];
- if (typeof js.then === "function")
- return $globals.Thenable.fn.prototype._then_on_do_catch_.call(js, aBlockOrArray, aClass, aBlock, anotherBlock);
- else
- return self._doesNotUnderstand_(
- $globals.Message._new()
- ._selector_("then:on:do:catch:")
- ._arguments_([aBlockOrArray, aClass, aBlock, anotherBlock])
- );
- return self;
- }, function($ctx1) {$ctx1.fill(self,"then:on:do:catch:",{aBlockOrArray:aBlockOrArray,aClass:aClass,aBlock:aBlock,anotherBlock:anotherBlock},$globals.JSObjectProxy)});
- },
- args: ["aBlockOrArray", "aClass", "aBlock", "anotherBlock"],
- source: "then: aBlockOrArray on: aClass do: aBlock catch: anotherBlock\x0a<inlineJS: 'var js = self[\x22@jsObject\x22];\x0aif (typeof js.then === \x22function\x22)\x0a return $globals.Thenable.fn.prototype._then_on_do_catch_.call(js, aBlockOrArray, aClass, aBlock, anotherBlock);\x0aelse\x0a return self._doesNotUnderstand_(\x0a $globals.Message._new()\x0a ._selector_(\x22then:on:do:catch:\x22)\x0a ._arguments_([aBlockOrArray, aClass, aBlock, anotherBlock])\x0a )'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxy);
- });
- define('amber_core/Kernel-Announcements',["amber/boot", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Announcements");
- $core.packages["Kernel-Announcements"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Announcements"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("AnnouncementSubscription", $globals.Object, ["valuable", "announcementClass"], "Kernel-Announcements");
- $globals.AnnouncementSubscription.comment="I am a single entry in a subscription registry of an `Announcer`.\x0aSeveral subscriptions by the same object is possible.";
- $core.addMethod(
- $core.method({
- selector: "announcementClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@announcementClass"];
- },
- args: [],
- source: "announcementClass\x0a\x09^ announcementClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementSubscription);
- $core.addMethod(
- $core.method({
- selector: "announcementClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@announcementClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "announcementClass: aClass\x0a\x09announcementClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementSubscription);
- $core.addMethod(
- $core.method({
- selector: "deliver:",
- protocol: "announcing",
- fn: function (anAnnouncement){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._handlesAnnouncement_(anAnnouncement);
- if($core.assert($1)){
- $recv(self._valuable())._value_(anAnnouncement);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deliver:",{anAnnouncement:anAnnouncement},$globals.AnnouncementSubscription)});
- },
- args: ["anAnnouncement"],
- source: "deliver: anAnnouncement\x0a\x09(self handlesAnnouncement: anAnnouncement)\x0a\x09\x09ifTrue: [ self valuable value: anAnnouncement ]",
- referencedClasses: [],
- messageSends: ["ifTrue:", "handlesAnnouncement:", "value:", "valuable"]
- }),
- $globals.AnnouncementSubscription);
- $core.addMethod(
- $core.method({
- selector: "handlesAnnouncement:",
- protocol: "announcing",
- fn: function (anAnnouncement){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$receiver;
- $2=$recv($globals.Smalltalk)._globals();
- $ctx1.sendIdx["globals"]=1;
- $3=$recv(self._announcementClass())._name();
- $ctx1.sendIdx["name"]=1;
- $1=$recv($2)._at_($3);
- $ctx1.sendIdx["at:"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- var class_;
- class_=$receiver;
- return $recv($recv($recv($globals.Smalltalk)._globals())._at_($recv($recv($recv(anAnnouncement)._class())._theNonMetaClass())._name()))._includesBehavior_(class_);
- }
- }, function($ctx1) {$ctx1.fill(self,"handlesAnnouncement:",{anAnnouncement:anAnnouncement},$globals.AnnouncementSubscription)});
- },
- args: ["anAnnouncement"],
- source: "handlesAnnouncement: anAnnouncement\x0a\x09\x22anAnnouncement might be announced from within another Amber environment\x22\x0a\x09\x0a\x09^ (Smalltalk globals at: self announcementClass name)\x0a\x09\x09ifNil: [ ^ false ]\x0a\x09\x09ifNotNil: [ :class |\x0a\x09\x09(Smalltalk globals at: anAnnouncement class theNonMetaClass name) includesBehavior: class ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifNil:ifNotNil:", "at:", "globals", "name", "announcementClass", "includesBehavior:", "theNonMetaClass", "class"]
- }),
- $globals.AnnouncementSubscription);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._valuable())._receiver();
- }, function($ctx1) {$ctx1.fill(self,"receiver",{},$globals.AnnouncementSubscription)});
- },
- args: [],
- source: "receiver\x0a\x09^ self valuable receiver",
- referencedClasses: [],
- messageSends: ["receiver", "valuable"]
- }),
- $globals.AnnouncementSubscription);
- $core.addMethod(
- $core.method({
- selector: "valuable",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@valuable"];
- },
- args: [],
- source: "valuable\x0a\x09^ valuable",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementSubscription);
- $core.addMethod(
- $core.method({
- selector: "valuable:",
- protocol: "accessing",
- fn: function (aValuable){
- var self=this;
- self["@valuable"]=aValuable;
- return self;
- },
- args: ["aValuable"],
- source: "valuable: aValuable\x0a\x09valuable := aValuable",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementSubscription);
- $core.addClass("AnnouncementValuable", $globals.Object, ["valuable", "receiver"], "Kernel-Announcements");
- $globals.AnnouncementValuable.comment="I wrap `valuable` objects (typically instances of `BlockClosure`) with a `receiver` to be able to unregister subscriptions based on a `receiver`.";
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@receiver"];
- },
- args: [],
- source: "receiver\x0a\x09^ receiver",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementValuable);
- $core.addMethod(
- $core.method({
- selector: "receiver:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@receiver"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "receiver: anObject\x0a\x09receiver := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementValuable);
- $core.addMethod(
- $core.method({
- selector: "valuable",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@valuable"];
- },
- args: [],
- source: "valuable\x0a\x09^ valuable",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementValuable);
- $core.addMethod(
- $core.method({
- selector: "valuable:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@valuable"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "valuable: anObject\x0a\x09valuable := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AnnouncementValuable);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "evaluating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._valuable())._value();
- }, function($ctx1) {$ctx1.fill(self,"value",{},$globals.AnnouncementValuable)});
- },
- args: [],
- source: "value\x0a\x09^ self valuable value",
- referencedClasses: [],
- messageSends: ["value", "valuable"]
- }),
- $globals.AnnouncementValuable);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "evaluating",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._valuable())._value_(anObject);
- }, function($ctx1) {$ctx1.fill(self,"value:",{anObject:anObject},$globals.AnnouncementValuable)});
- },
- args: ["anObject"],
- source: "value: anObject\x0a\x09^ self valuable value: anObject",
- referencedClasses: [],
- messageSends: ["value:", "valuable"]
- }),
- $globals.AnnouncementValuable);
- $core.addClass("Announcer", $globals.Object, ["registry", "subscriptions"], "Kernel-Announcements");
- $globals.Announcer.comment="I hold annoncement subscriptions (instances of `AnnouncementSubscription`) in a private registry.\x0aI announce (trigger) announces, which are then dispatched to all subscriptions.\x0a\x0aThe code is based on the announcements as [described by Vassili Bykov](http://www.cincomsmalltalk.com/userblogs/vbykov/blogView?searchCategory=Announcements%20Framework).\x0a\x0a## API\x0a\x0aUse `#announce:` to trigger an announcement.\x0a\x0aUse `#on:do:` or `#on:send:to:` to register subscriptions.\x0a\x0aWhen using `#on:send:to:`, unregistration can be done with `#unregister:`.\x0a\x0a## Usage example:\x0a\x0a SystemAnnouncer current\x0a on: ClassAdded\x0a do: [ :ann | window alert: ann theClass name, ' added' ].";
- $core.addMethod(
- $core.method({
- selector: "announce:",
- protocol: "announcing",
- fn: function (anAnnouncement){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@subscriptions"])._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._deliver_(anAnnouncement);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"announce:",{anAnnouncement:anAnnouncement},$globals.Announcer)});
- },
- args: ["anAnnouncement"],
- source: "announce: anAnnouncement\x0a\x09subscriptions do: [ :each |\x0a\x09\x09each deliver: anAnnouncement ]",
- referencedClasses: [],
- messageSends: ["do:", "deliver:"]
- }),
- $globals.Announcer);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Announcer.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@subscriptions"]=$recv($globals.OrderedCollection)._new();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Announcer)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09subscriptions := OrderedCollection new",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["initialize", "new"]
- }),
- $globals.Announcer);
- $core.addMethod(
- $core.method({
- selector: "on:do:",
- protocol: "subscribing",
- fn: function (aClass,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._on_do_for_(aClass,aBlock,nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:do:",{aClass:aClass,aBlock:aBlock},$globals.Announcer)});
- },
- args: ["aClass", "aBlock"],
- source: "on: aClass do: aBlock\x0a\x09self on: aClass do: aBlock for: nil",
- referencedClasses: [],
- messageSends: ["on:do:for:"]
- }),
- $globals.Announcer);
- $core.addMethod(
- $core.method({
- selector: "on:do:for:",
- protocol: "subscribing",
- fn: function (aClass,aBlock,aReceiver){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$5,$6,$4,$2;
- $1=self["@subscriptions"];
- $3=$recv($globals.AnnouncementSubscription)._new();
- $ctx1.sendIdx["new"]=1;
- $5=$recv($globals.AnnouncementValuable)._new();
- $recv($5)._valuable_(aBlock);
- $recv($5)._receiver_(aReceiver);
- $6=$recv($5)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $4=$6;
- $recv($3)._valuable_($4);
- $ctx1.sendIdx["valuable:"]=1;
- $recv($3)._announcementClass_(aClass);
- $2=$recv($3)._yourself();
- $recv($1)._add_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:do:for:",{aClass:aClass,aBlock:aBlock,aReceiver:aReceiver},$globals.Announcer)});
- },
- args: ["aClass", "aBlock", "aReceiver"],
- source: "on: aClass do: aBlock for: aReceiver\x0a\x09subscriptions add: (AnnouncementSubscription new\x0a\x09\x09valuable: (AnnouncementValuable new\x0a\x09\x09\x09valuable: aBlock;\x0a\x09\x09\x09receiver: aReceiver;\x0a\x09\x09\x09yourself);\x0a\x09\x09announcementClass: aClass;\x0a\x09\x09yourself)",
- referencedClasses: ["AnnouncementSubscription", "AnnouncementValuable"],
- messageSends: ["add:", "valuable:", "new", "receiver:", "yourself", "announcementClass:"]
- }),
- $globals.Announcer);
- $core.addMethod(
- $core.method({
- selector: "on:doOnce:",
- protocol: "subscribing",
- fn: function (aClass,aBlock){
- var self=this;
- var subscription;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.AnnouncementSubscription)._new();
- $recv($1)._announcementClass_(aClass);
- subscription=$recv($1)._yourself();
- $recv(subscription)._valuable_((function(ann){
- return $core.withContext(function($ctx2) {
- $recv(self["@subscriptions"])._remove_(subscription);
- return $recv(aBlock)._value_(ann);
- }, function($ctx2) {$ctx2.fillBlock({ann:ann},$ctx1,1)});
- }));
- $recv(self["@subscriptions"])._add_(subscription);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:doOnce:",{aClass:aClass,aBlock:aBlock,subscription:subscription},$globals.Announcer)});
- },
- args: ["aClass", "aBlock"],
- source: "on: aClass doOnce: aBlock\x0a\x09| subscription |\x0a\x09\x0a\x09subscription := AnnouncementSubscription new\x0a\x09\x09announcementClass: aClass;\x0a\x09\x09yourself.\x0a\x09subscription valuable: [ :ann |\x0a\x09\x09subscriptions remove: subscription.\x0a\x09\x09aBlock value: ann ].\x0a\x0a\x09subscriptions add: subscription",
- referencedClasses: ["AnnouncementSubscription"],
- messageSends: ["announcementClass:", "new", "yourself", "valuable:", "remove:", "value:", "add:"]
- }),
- $globals.Announcer);
- $core.addMethod(
- $core.method({
- selector: "on:send:to:",
- protocol: "subscribing",
- fn: function (aClass,aSelector,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$5,$6,$4,$2;
- $1=self["@subscriptions"];
- $3=$recv($globals.AnnouncementSubscription)._new();
- $ctx1.sendIdx["new"]=1;
- $5=$recv($globals.MessageSend)._new();
- $recv($5)._receiver_(anObject);
- $recv($5)._selector_(aSelector);
- $6=$recv($5)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $4=$6;
- $recv($3)._valuable_($4);
- $recv($3)._announcementClass_(aClass);
- $2=$recv($3)._yourself();
- $recv($1)._add_($2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"on:send:to:",{aClass:aClass,aSelector:aSelector,anObject:anObject},$globals.Announcer)});
- },
- args: ["aClass", "aSelector", "anObject"],
- source: "on: aClass send: aSelector to: anObject\x0a\x09subscriptions add: (AnnouncementSubscription new\x0a\x09\x09valuable: (MessageSend new\x0a\x09\x09\x09receiver: anObject;\x0a\x09\x09\x09selector: aSelector;\x0a\x09\x09\x09yourself);\x0a\x09\x09announcementClass: aClass;\x0a\x09\x09yourself)",
- referencedClasses: ["AnnouncementSubscription", "MessageSend"],
- messageSends: ["add:", "valuable:", "new", "receiver:", "selector:", "yourself", "announcementClass:"]
- }),
- $globals.Announcer);
- $core.addMethod(
- $core.method({
- selector: "unsubscribe:",
- protocol: "subscribing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@subscriptions"]=$recv(self["@subscriptions"])._reject_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._receiver()).__eq(anObject);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"unsubscribe:",{anObject:anObject},$globals.Announcer)});
- },
- args: ["anObject"],
- source: "unsubscribe: anObject\x0a\x09subscriptions := subscriptions reject: [ :each |\x0a\x09\x09each receiver = anObject ]",
- referencedClasses: [],
- messageSends: ["reject:", "=", "receiver"]
- }),
- $globals.Announcer);
- $core.addClass("SystemAnnouncer", $globals.Announcer, [], "Kernel-Announcements");
- $globals.SystemAnnouncer.comment="My unique instance is the global announcer handling all Amber system-related announces.\x0a\x0a## API\x0a\x0aAccess to the unique instance is done via `#current`";
- $globals.SystemAnnouncer.klass.iVarNames = ["current"];
- $core.addMethod(
- $core.method({
- selector: "current",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@current"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@current"]=(
- $ctx1.supercall = true,
- ($globals.SystemAnnouncer.klass.superclass||$boot.nilAsClass).fn.prototype._new.apply($recv(self), []));
- $ctx1.supercall = false;
- return self["@current"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"current",{},$globals.SystemAnnouncer.klass)});
- },
- args: [],
- source: "current\x0a\x09^ current ifNil: [ current := super new ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.SystemAnnouncer.klass);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldNotImplement();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.SystemAnnouncer.klass)});
- },
- args: [],
- source: "new\x0a\x09self shouldNotImplement",
- referencedClasses: [],
- messageSends: ["shouldNotImplement"]
- }),
- $globals.SystemAnnouncer.klass);
- $core.addClass("SystemAnnouncement", $globals.Object, [], "Kernel-Announcements");
- $globals.SystemAnnouncement.comment="I am the superclass of all system announcements";
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "announcement";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'announcement'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SystemAnnouncement.klass);
- $core.addClass("ClassAnnouncement", $globals.SystemAnnouncement, ["theClass"], "Kernel-Announcements");
- $globals.ClassAnnouncement.comment="I am the abstract superclass of class-related announcements.";
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@theClass"];
- },
- args: [],
- source: "theClass\x0a\x09^ theClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "theClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@theClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "theClass: aClass\x0a\x09theClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassAnnouncement);
- $core.addClass("ClassAdded", $globals.ClassAnnouncement, [], "Kernel-Announcements");
- $globals.ClassAdded.comment="I am emitted when a class is added to the system.\x0aSee ClassBuilder >> #addSubclassOf:... methods";
- $core.addClass("ClassCommentChanged", $globals.ClassAnnouncement, [], "Kernel-Announcements");
- $globals.ClassCommentChanged.comment="I am emitted when the comment of a class changes. (Behavior >> #comment)";
- $core.addClass("ClassDefinitionChanged", $globals.ClassAnnouncement, [], "Kernel-Announcements");
- $globals.ClassDefinitionChanged.comment="I am emitted when the definition of a class changes.\x0aSee ClassBuilder >> #class:instanceVariableNames:";
- $core.addClass("ClassMigrated", $globals.ClassAnnouncement, ["oldClass"], "Kernel-Announcements");
- $globals.ClassMigrated.comment="I am emitted when a class is migrated.";
- $core.addMethod(
- $core.method({
- selector: "oldClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@oldClass"];
- },
- args: [],
- source: "oldClass\x0a\x09^ oldClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassMigrated);
- $core.addMethod(
- $core.method({
- selector: "oldClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@oldClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "oldClass: aClass\x0a\x09oldClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassMigrated);
- $core.addClass("ClassMoved", $globals.ClassAnnouncement, ["oldPackage"], "Kernel-Announcements");
- $globals.ClassMoved.comment="I am emitted when a class is moved from one package to another.";
- $core.addMethod(
- $core.method({
- selector: "oldPackage",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@oldPackage"];
- },
- args: [],
- source: "oldPackage\x0a\x09^ oldPackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassMoved);
- $core.addMethod(
- $core.method({
- selector: "oldPackage:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- self["@oldPackage"]=aPackage;
- return self;
- },
- args: ["aPackage"],
- source: "oldPackage: aPackage\x0a\x09oldPackage := aPackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassMoved);
- $core.addClass("ClassRemoved", $globals.ClassAnnouncement, [], "Kernel-Announcements");
- $globals.ClassRemoved.comment="I am emitted when a class is removed.\x0aSee Smalltalk >> #removeClass:";
- $core.addClass("ClassRenamed", $globals.ClassAnnouncement, [], "Kernel-Announcements");
- $globals.ClassRenamed.comment="I am emitted when a class is renamed.\x0aSee ClassBuilder >> #renameClass:to:";
- $core.addClass("MethodAnnouncement", $globals.SystemAnnouncement, ["method"], "Kernel-Announcements");
- $globals.MethodAnnouncement.comment="I am the abstract superclass of method-related announcements.";
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@method"];
- },
- args: [],
- source: "method\x0a\x09^ method",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "method:",
- protocol: "accessing",
- fn: function (aCompiledMethod){
- var self=this;
- self["@method"]=aCompiledMethod;
- return self;
- },
- args: ["aCompiledMethod"],
- source: "method: aCompiledMethod\x0a\x09method := aCompiledMethod",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodAnnouncement);
- $core.addClass("MethodAdded", $globals.MethodAnnouncement, [], "Kernel-Announcements");
- $globals.MethodAdded.comment="I am emitted when a `CompiledMethod` is added to a class.";
- $core.addClass("MethodModified", $globals.MethodAnnouncement, ["oldMethod"], "Kernel-Announcements");
- $globals.MethodModified.comment="I am emitted when a `CompiledMethod` is modified (a new method is installed). I hold a reference to the old method being replaced.";
- $core.addMethod(
- $core.method({
- selector: "oldMethod",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@oldMethod"];
- },
- args: [],
- source: "oldMethod\x0a\x09^ oldMethod",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodModified);
- $core.addMethod(
- $core.method({
- selector: "oldMethod:",
- protocol: "accessing",
- fn: function (aMethod){
- var self=this;
- self["@oldMethod"]=aMethod;
- return self;
- },
- args: ["aMethod"],
- source: "oldMethod: aMethod\x0a\x09oldMethod := aMethod",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodModified);
- $core.addClass("MethodMoved", $globals.MethodAnnouncement, ["oldProtocol"], "Kernel-Announcements");
- $globals.MethodMoved.comment="I am emitted when a `CompiledMethod` is moved to another protocol. I hold a refernce to the old protocol of the method.";
- $core.addMethod(
- $core.method({
- selector: "oldProtocol",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@oldProtocol"];
- },
- args: [],
- source: "oldProtocol\x0a\x09^ oldProtocol",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodMoved);
- $core.addMethod(
- $core.method({
- selector: "oldProtocol:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@oldProtocol"]=aString;
- return self;
- },
- args: ["aString"],
- source: "oldProtocol: aString\x0a\x09oldProtocol := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodMoved);
- $core.addClass("MethodRemoved", $globals.MethodAnnouncement, [], "Kernel-Announcements");
- $globals.MethodRemoved.comment="I am emitted when a `CompiledMethod` is removed from a class.";
- $core.addClass("PackageAnnouncement", $globals.SystemAnnouncement, ["package"], "Kernel-Announcements");
- $globals.PackageAnnouncement.comment="I am the abstract superclass of package-related announcements.";
- $core.addMethod(
- $core.method({
- selector: "package",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@package"];
- },
- args: [],
- source: "package\x0a\x09^ package",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PackageAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "package:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- self["@package"]=aPackage;
- return self;
- },
- args: ["aPackage"],
- source: "package: aPackage\x0a\x09package := aPackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PackageAnnouncement);
- $core.addClass("PackageAdded", $globals.PackageAnnouncement, [], "Kernel-Announcements");
- $globals.PackageAdded.comment="I am emitted when a `Package` is added to the system.";
- $core.addClass("PackageClean", $globals.PackageAnnouncement, [], "Kernel-Announcements");
- $globals.PackageClean.comment="I am emitted when a package is committed and becomes clean.";
- $core.addClass("PackageDirty", $globals.PackageAnnouncement, [], "Kernel-Announcements");
- $globals.PackageDirty.comment="I am emitted when a package becomes dirty.";
- $core.addClass("PackageRemoved", $globals.PackageAnnouncement, [], "Kernel-Announcements");
- $globals.PackageRemoved.comment="I am emitted when a `Package` is removed from the system.";
- $core.addClass("ProtocolAnnouncement", $globals.SystemAnnouncement, ["theClass", "protocol"], "Kernel-Announcements");
- $globals.ProtocolAnnouncement.comment="I am the abstract superclass of protocol-related announcements.";
- $core.addMethod(
- $core.method({
- selector: "package",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._theClass();
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- var class_;
- class_=$receiver;
- return $recv(class_)._packageOfProtocol_(self._protocol());
- }
- }, function($ctx1) {$ctx1.fill(self,"package",{},$globals.ProtocolAnnouncement)});
- },
- args: [],
- source: "package\x0a\x09\x0a\x09^ self theClass ifNotNil: [ :class | class packageOfProtocol: self protocol ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "theClass", "packageOfProtocol:", "protocol"]
- }),
- $globals.ProtocolAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "protocol",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@protocol"];
- },
- args: [],
- source: "protocol\x0a\x09^ protocol",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtocolAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "protocol:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@protocol"]=aString;
- return self;
- },
- args: ["aString"],
- source: "protocol: aString\x0a\x09protocol := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtocolAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@theClass"];
- },
- args: [],
- source: "theClass\x0a\x09^ theClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtocolAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "theClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@theClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "theClass: aClass\x0a\x09theClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ProtocolAnnouncement);
- $core.addClass("ProtocolAdded", $globals.ProtocolAnnouncement, [], "Kernel-Announcements");
- $globals.ProtocolAdded.comment="I am emitted when a protocol is added to a class.";
- $core.addClass("ProtocolRemoved", $globals.ProtocolAnnouncement, [], "Kernel-Announcements");
- $globals.ProtocolRemoved.comment="I am emitted when a protocol is removed from a class.";
- });
- define('amber_core/Platform-Services',["amber/boot", "amber_core/Kernel-Collections", "amber_core/Kernel-Infrastructure", "amber_core/Kernel-Methods", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Platform-Services");
- $core.packages["Platform-Services"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Platform-Services"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("ConsoleErrorHandler", $globals.Object, [], "Platform-Services");
- $globals.ConsoleErrorHandler.comment="I am manage Smalltalk errors, displaying the stack in the console.";
- $core.addMethod(
- $core.method({
- selector: "handleError:",
- protocol: "error handling",
- fn: function (anError){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv(anError)._context();
- $ctx1.sendIdx["context"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- self._logErrorContext_($recv(anError)._context());
- }
- self._logError_(anError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"handleError:",{anError:anError},$globals.ConsoleErrorHandler)});
- },
- args: ["anError"],
- source: "handleError: anError\x0a\x09anError context ifNotNil: [ self logErrorContext: anError context ].\x0a\x09self logError: anError",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "context", "logErrorContext:", "logError:"]
- }),
- $globals.ConsoleErrorHandler);
- $core.addMethod(
- $core.method({
- selector: "log:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(console)._log_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"log:",{aString:aString},$globals.ConsoleErrorHandler)});
- },
- args: ["aString"],
- source: "log: aString\x0a\x09console log: aString",
- referencedClasses: [],
- messageSends: ["log:"]
- }),
- $globals.ConsoleErrorHandler);
- $core.addMethod(
- $core.method({
- selector: "logContext:",
- protocol: "private",
- fn: function (aContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv(aContext)._home();
- $ctx1.sendIdx["home"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- self._logContext_($recv(aContext)._home());
- }
- self._log_($recv(aContext)._asString());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"logContext:",{aContext:aContext},$globals.ConsoleErrorHandler)});
- },
- args: ["aContext"],
- source: "logContext: aContext\x0a\x09aContext home ifNotNil: [\x0a\x09\x09self logContext: aContext home ].\x0a\x09self log: aContext asString",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "home", "logContext:", "log:", "asString"]
- }),
- $globals.ConsoleErrorHandler);
- $core.addMethod(
- $core.method({
- selector: "logError:",
- protocol: "private",
- fn: function (anError){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._log_($recv(anError)._messageText());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"logError:",{anError:anError},$globals.ConsoleErrorHandler)});
- },
- args: ["anError"],
- source: "logError: anError\x0a\x09self log: anError messageText",
- referencedClasses: [],
- messageSends: ["log:", "messageText"]
- }),
- $globals.ConsoleErrorHandler);
- $core.addMethod(
- $core.method({
- selector: "logErrorContext:",
- protocol: "private",
- fn: function (aContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- if(($receiver = aContext) == null || $receiver.isNil){
- aContext;
- } else {
- $1=$recv(aContext)._home();
- $ctx1.sendIdx["home"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- self._logContext_($recv(aContext)._home());
- }
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"logErrorContext:",{aContext:aContext},$globals.ConsoleErrorHandler)});
- },
- args: ["aContext"],
- source: "logErrorContext: aContext\x0a\x09aContext ifNotNil: [\x0a\x09\x09aContext home ifNotNil: [\x0a\x09\x09\x09self logContext: aContext home ]]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "home", "logContext:"]
- }),
- $globals.ConsoleErrorHandler);
- $globals.ConsoleErrorHandler.klass.iVarNames = ["current"];
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.ErrorHandler)._registerIfNone_(self._new());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.ConsoleErrorHandler.klass)});
- },
- args: [],
- source: "initialize\x0a\x09ErrorHandler registerIfNone: self new",
- referencedClasses: ["ErrorHandler"],
- messageSends: ["registerIfNone:", "new"]
- }),
- $globals.ConsoleErrorHandler.klass);
- $core.addClass("ConsoleTranscript", $globals.Object, ["textarea"], "Platform-Services");
- $globals.ConsoleTranscript.comment="I am a specific transcript emitting to the JavaScript console.\x0a\x0aIf no other transcript is registered, I am the default.";
- $core.addMethod(
- $core.method({
- selector: "clear",
- protocol: "printing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "clear\x0a\x09\x22no op\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ConsoleTranscript);
- $core.addMethod(
- $core.method({
- selector: "cr",
- protocol: "printing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "cr\x0a\x09\x22no op\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ConsoleTranscript);
- $core.addMethod(
- $core.method({
- selector: "open",
- protocol: "actions",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "open",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ConsoleTranscript);
- $core.addMethod(
- $core.method({
- selector: "show:",
- protocol: "printing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- console.log(String($recv(anObject)._asString()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"show:",{anObject:anObject},$globals.ConsoleTranscript)});
- },
- args: ["anObject"],
- source: "show: anObject\x0a\x22Smalltalk objects should have no trouble displaying themselves on the Transcript; Javascript objects don't know how, so must be wrapped in a JSObectProxy.\x22\x0a<inlineJS: 'console.log(String($recv(anObject)._asString()))'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ConsoleTranscript);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Transcript)._registerIfNone_(self._new());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.ConsoleTranscript.klass)});
- },
- args: [],
- source: "initialize\x0a\x09Transcript registerIfNone: self new",
- referencedClasses: ["Transcript"],
- messageSends: ["registerIfNone:", "new"]
- }),
- $globals.ConsoleTranscript.klass);
- $core.addClass("Environment", $globals.Object, [], "Platform-Services");
- $globals.Environment.comment="I provide an unified entry point to manipulate Amber packages, classes and methods.\x0a\x0aTypical use cases include IDEs, remote access and restricting browsing.";
- $core.addMethod(
- $core.method({
- selector: "addInstVarNamed:to:",
- protocol: "compiling",
- fn: function (aString,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4;
- $1=self._classBuilder();
- $2=$recv(aClass)._superclass();
- $3=$recv(aClass)._name();
- $ctx1.sendIdx["name"]=1;
- $5=$recv($recv(aClass)._instanceVariableNames())._copy();
- $recv($5)._add_(aString);
- $4=$recv($5)._yourself();
- $recv($1)._addSubclassOf_named_instanceVariableNames_package_($2,$3,$4,$recv($recv(aClass)._package())._name());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addInstVarNamed:to:",{aString:aString,aClass:aClass},$globals.Environment)});
- },
- args: ["aString", "aClass"],
- source: "addInstVarNamed: aString to: aClass\x0a\x09self classBuilder\x0a\x09\x09addSubclassOf: aClass superclass \x0a\x09\x09named: aClass name \x0a\x09\x09instanceVariableNames: (aClass instanceVariableNames copy add: aString; yourself)\x0a\x09\x09package: aClass package name",
- referencedClasses: [],
- messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "classBuilder", "superclass", "name", "add:", "copy", "instanceVariableNames", "yourself", "package"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "allSelectors",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Smalltalk)._core())._allSelectors();
- }, function($ctx1) {$ctx1.fill(self,"allSelectors",{},$globals.Environment)});
- },
- args: [],
- source: "allSelectors\x0a\x09^ Smalltalk core allSelectors",
- referencedClasses: ["Smalltalk"],
- messageSends: ["allSelectors", "core"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "availableClassNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Smalltalk)._classes())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._name();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"availableClassNames",{},$globals.Environment)});
- },
- args: [],
- source: "availableClassNames\x0a\x09^ Smalltalk classes \x0a\x09\x09collect: [ :each | each name ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["collect:", "classes", "name"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "availablePackageNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Smalltalk)._packages())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._name();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"availablePackageNames",{},$globals.Environment)});
- },
- args: [],
- source: "availablePackageNames\x0a\x09^ Smalltalk packages \x0a\x09\x09collect: [ :each | each name ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["collect:", "packages", "name"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "availableProtocolsFor:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- var protocols;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- protocols=$recv(aClass)._protocols();
- $1=$recv(aClass)._superclass();
- $ctx1.sendIdx["superclass"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $recv(protocols)._addAll_(self._availableProtocolsFor_($recv(aClass)._superclass()));
- }
- return $recv($recv($recv(protocols)._asSet())._asArray())._sort();
- }, function($ctx1) {$ctx1.fill(self,"availableProtocolsFor:",{aClass:aClass,protocols:protocols},$globals.Environment)});
- },
- args: ["aClass"],
- source: "availableProtocolsFor: aClass\x0a\x09| protocols |\x0a\x09\x0a\x09protocols := aClass protocols.\x0a\x09aClass superclass ifNotNil: [ protocols addAll: (self availableProtocolsFor: aClass superclass) ].\x0a\x09^ protocols asSet asArray sort",
- referencedClasses: [],
- messageSends: ["protocols", "ifNotNil:", "superclass", "addAll:", "availableProtocolsFor:", "sort", "asArray", "asSet"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "classBuilder",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.ClassBuilder)._new();
- }, function($ctx1) {$ctx1.fill(self,"classBuilder",{},$globals.Environment)});
- },
- args: [],
- source: "classBuilder\x0a\x09^ ClassBuilder new",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["new"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "classNamed:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv($recv($globals.Smalltalk)._globals())._at_($recv(aString)._asSymbol());
- if(($receiver = $1) == null || $receiver.isNil){
- return self._error_("Invalid class name");
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"classNamed:",{aString:aString},$globals.Environment)});
- },
- args: ["aString"],
- source: "classNamed: aString\x0a\x09^ (Smalltalk globals at: aString asSymbol)\x0a\x09\x09ifNil: [ self error: 'Invalid class name' ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifNil:", "at:", "globals", "asSymbol", "error:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "classes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._classes();
- }, function($ctx1) {$ctx1.fill(self,"classes",{},$globals.Environment)});
- },
- args: [],
- source: "classes\x0a\x09^ Smalltalk classes",
- referencedClasses: ["Smalltalk"],
- messageSends: ["classes"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "commitPackage:onSuccess:onError:",
- protocol: "actions",
- fn: function (aPackage,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aPackage)._transport())._commitOnSuccess_onError_(aBlock,anotherBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commitPackage:onSuccess:onError:",{aPackage:aPackage,aBlock:aBlock,anotherBlock:anotherBlock},$globals.Environment)});
- },
- args: ["aPackage", "aBlock", "anotherBlock"],
- source: "commitPackage: aPackage onSuccess: aBlock onError: anotherBlock\x0a\x09aPackage transport\x0a\x09\x09commitOnSuccess: aBlock\x0a\x09\x09onError: anotherBlock",
- referencedClasses: [],
- messageSends: ["commitOnSuccess:onError:", "transport"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "compileClassComment:for:",
- protocol: "compiling",
- fn: function (aString,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aClass)._comment_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"compileClassComment:for:",{aString:aString,aClass:aClass},$globals.Environment)});
- },
- args: ["aString", "aClass"],
- source: "compileClassComment: aString for: aClass\x0a\x09aClass comment: aString",
- referencedClasses: [],
- messageSends: ["comment:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "compileClassDefinition:",
- protocol: "compiling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._evaluate_for_(aString,$recv($globals.DoIt)._new());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(error){
- return $core.withContext(function($ctx2) {
- return $recv($globals.Terminal)._alert_($recv(error)._messageText());
- }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"compileClassDefinition:",{aString:aString},$globals.Environment)});
- },
- args: ["aString"],
- source: "compileClassDefinition: aString\x0a\x09[ self evaluate: aString for: DoIt new ]\x0a\x09\x09on: Error\x0a\x09\x09do: [ :error | Terminal alert: error messageText ]",
- referencedClasses: ["DoIt", "Error", "Terminal"],
- messageSends: ["on:do:", "evaluate:for:", "new", "alert:", "messageText"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "compileMethod:for:protocol:",
- protocol: "compiling",
- fn: function (sourceCode,class_,protocol){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(class_)._compile_protocol_(sourceCode,protocol);
- }, function($ctx1) {$ctx1.fill(self,"compileMethod:for:protocol:",{sourceCode:sourceCode,class_:class_,protocol:protocol},$globals.Environment)});
- },
- args: ["sourceCode", "class", "protocol"],
- source: "compileMethod: sourceCode for: class protocol: protocol\x0a\x09^ class\x0a\x09\x09compile: sourceCode\x0a\x09\x09protocol: protocol",
- referencedClasses: [],
- messageSends: ["compile:protocol:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "copyClass:to:",
- protocol: "actions",
- fn: function (aClass,aClassName){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=$recv($recv($globals.Smalltalk)._globals())._at_(aClassName);
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $2=$recv("A class named ".__comma(aClassName)).__comma(" already exists");
- $ctx1.sendIdx[","]=1;
- self._error_($2);
- }
- $recv($recv($globals.ClassBuilder)._new())._copyClass_named_(aClass,aClassName);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"copyClass:to:",{aClass:aClass,aClassName:aClassName},$globals.Environment)});
- },
- args: ["aClass", "aClassName"],
- source: "copyClass: aClass to: aClassName\x0a\x09(Smalltalk globals at: aClassName)\x0a\x09\x09ifNotNil: [ self error: 'A class named ', aClassName, ' already exists' ].\x0a\x09\x09\x0a\x09ClassBuilder new copyClass: aClass named: aClassName",
- referencedClasses: ["Smalltalk", "ClassBuilder"],
- messageSends: ["ifNotNil:", "at:", "globals", "error:", ",", "copyClass:named:", "new"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "doItReceiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.DoIt)._new();
- }, function($ctx1) {$ctx1.fill(self,"doItReceiver",{},$globals.Environment)});
- },
- args: [],
- source: "doItReceiver\x0a\x09^ DoIt new",
- referencedClasses: ["DoIt"],
- messageSends: ["new"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "evaluate:for:",
- protocol: "evaluating",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Evaluator)._evaluate_for_(aString,anObject);
- }, function($ctx1) {$ctx1.fill(self,"evaluate:for:",{aString:aString,anObject:anObject},$globals.Environment)});
- },
- args: ["aString", "anObject"],
- source: "evaluate: aString for: anObject\x0a\x09^ Evaluator evaluate: aString for: anObject",
- referencedClasses: ["Evaluator"],
- messageSends: ["evaluate:for:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "evaluate:on:do:",
- protocol: "error handling",
- fn: function (aBlock,anErrorClass,exceptionBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(aBlock)._tryCatch_((function(exception){
- return $core.withContext(function($ctx2) {
- $1=$recv(exception)._isKindOf_(self._classNamed_($recv(anErrorClass)._name()));
- if($core.assert($1)){
- return $recv(exceptionBlock)._value_(exception);
- } else {
- return $recv(exception)._resignal();
- }
- }, function($ctx2) {$ctx2.fillBlock({exception:exception},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"evaluate:on:do:",{aBlock:aBlock,anErrorClass:anErrorClass,exceptionBlock:exceptionBlock},$globals.Environment)});
- },
- args: ["aBlock", "anErrorClass", "exceptionBlock"],
- source: "evaluate: aBlock on: anErrorClass do: exceptionBlock\x0a\x09\x22Evaluate a block and catch exceptions happening on the environment stack\x22\x0a\x09\x0a\x09aBlock tryCatch: [ :exception | \x0a\x09\x09(exception isKindOf: (self classNamed: anErrorClass name))\x0a\x09\x09\x09ifTrue: [ exceptionBlock value: exception ]\x0a \x09\x09\x09ifFalse: [ exception resignal ] ]",
- referencedClasses: [],
- messageSends: ["tryCatch:", "ifTrue:ifFalse:", "isKindOf:", "classNamed:", "name", "value:", "resignal"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "inspect:",
- protocol: "actions",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Inspector)._inspect_(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspect:",{anObject:anObject},$globals.Environment)});
- },
- args: ["anObject"],
- source: "inspect: anObject\x0a\x09Inspector inspect: anObject",
- referencedClasses: ["Inspector"],
- messageSends: ["inspect:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "moveClass:toPackage:",
- protocol: "actions",
- fn: function (aClass,aPackageName){
- var self=this;
- var package_;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- package_=$recv($globals.Package)._named_(aPackageName);
- $1=package_;
- if(($receiver = $1) == null || $receiver.isNil){
- self._error_("Invalid package name");
- } else {
- $1;
- }
- $2=$recv(package_).__eq_eq($recv(aClass)._package());
- if($core.assert($2)){
- return self;
- }
- $recv(aClass)._package_(package_);
- $recv(aClass)._recompile();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"moveClass:toPackage:",{aClass:aClass,aPackageName:aPackageName,package_:package_},$globals.Environment)});
- },
- args: ["aClass", "aPackageName"],
- source: "moveClass: aClass toPackage: aPackageName\x0a\x09| package |\x0a\x09\x0a\x09package := Package named: aPackageName.\x0a\x09package ifNil: [ self error: 'Invalid package name' ].\x0a\x09package == aClass package ifTrue: [ ^ self ].\x0a\x09\x0a\x09aClass package: package.\x0a\x09aClass recompile",
- referencedClasses: ["Package"],
- messageSends: ["named:", "ifNil:", "error:", "ifTrue:", "==", "package", "package:", "recompile"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "moveMethod:toClass:",
- protocol: "actions",
- fn: function (aMethod,aClassName){
- var self=this;
- var destinationClass;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$5,$4;
- destinationClass=self._classNamed_(aClassName);
- $2=destinationClass;
- $3=$recv(aMethod)._methodClass();
- $ctx1.sendIdx["methodClass"]=1;
- $1=$recv($2).__eq_eq($3);
- if($core.assert($1)){
- return self;
- }
- $5=$recv(aMethod)._methodClass();
- $ctx1.sendIdx["methodClass"]=2;
- $4=$recv($5)._isMetaclass();
- if($core.assert($4)){
- destinationClass=$recv(destinationClass)._theMetaClass();
- destinationClass;
- }
- $recv(destinationClass)._compile_protocol_($recv(aMethod)._source(),$recv(aMethod)._protocol());
- $recv($recv(aMethod)._methodClass())._removeCompiledMethod_(aMethod);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"moveMethod:toClass:",{aMethod:aMethod,aClassName:aClassName,destinationClass:destinationClass},$globals.Environment)});
- },
- args: ["aMethod", "aClassName"],
- source: "moveMethod: aMethod toClass: aClassName\x0a\x09| destinationClass |\x0a\x09\x0a\x09destinationClass := self classNamed: aClassName.\x0a\x09destinationClass == aMethod methodClass ifTrue: [ ^ self ].\x0a\x09\x0a\x09aMethod methodClass isMetaclass ifTrue: [ \x0a\x09\x09destinationClass := destinationClass theMetaClass ].\x0a\x09\x0a\x09destinationClass \x0a\x09\x09compile: aMethod source\x0a\x09\x09protocol: aMethod protocol.\x0a\x09aMethod methodClass \x0a\x09\x09removeCompiledMethod: aMethod",
- referencedClasses: [],
- messageSends: ["classNamed:", "ifTrue:", "==", "methodClass", "isMetaclass", "theMetaClass", "compile:protocol:", "source", "protocol", "removeCompiledMethod:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "moveMethod:toProtocol:",
- protocol: "actions",
- fn: function (aMethod,aProtocol){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aMethod)._protocol_(aProtocol);
- $recv($recv(aMethod)._methodClass())._compile_protocol_($recv(aMethod)._source(),$recv(aMethod)._protocol());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"moveMethod:toProtocol:",{aMethod:aMethod,aProtocol:aProtocol},$globals.Environment)});
- },
- args: ["aMethod", "aProtocol"],
- source: "moveMethod: aMethod toProtocol: aProtocol\x0a\x09aMethod protocol: aProtocol.\x0a\x0a\x09aMethod methodClass\x0a\x09\x09compile: aMethod source\x0a\x09\x09protocol: aMethod protocol",
- referencedClasses: [],
- messageSends: ["protocol:", "compile:protocol:", "methodClass", "source", "protocol"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "packages",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._packages();
- }, function($ctx1) {$ctx1.fill(self,"packages",{},$globals.Environment)});
- },
- args: [],
- source: "packages\x0a\x09^ Smalltalk packages",
- referencedClasses: ["Smalltalk"],
- messageSends: ["packages"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "registerErrorHandler:",
- protocol: "services",
- fn: function (anErrorHandler){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.ErrorHandler)._register_(anErrorHandler);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"registerErrorHandler:",{anErrorHandler:anErrorHandler},$globals.Environment)});
- },
- args: ["anErrorHandler"],
- source: "registerErrorHandler: anErrorHandler\x0a\x09ErrorHandler register: anErrorHandler",
- referencedClasses: ["ErrorHandler"],
- messageSends: ["register:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "registerFinder:",
- protocol: "services",
- fn: function (aFinder){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Finder)._register_(aFinder);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"registerFinder:",{aFinder:aFinder},$globals.Environment)});
- },
- args: ["aFinder"],
- source: "registerFinder: aFinder\x0a\x09Finder register: aFinder",
- referencedClasses: ["Finder"],
- messageSends: ["register:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "registerInspector:",
- protocol: "services",
- fn: function (anInspector){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Inspector)._register_(anInspector);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"registerInspector:",{anInspector:anInspector},$globals.Environment)});
- },
- args: ["anInspector"],
- source: "registerInspector: anInspector\x0a\x09Inspector register: anInspector",
- referencedClasses: ["Inspector"],
- messageSends: ["register:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "registerProgressHandler:",
- protocol: "services",
- fn: function (aProgressHandler){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.ProgressHandler)._register_(aProgressHandler);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"registerProgressHandler:",{aProgressHandler:aProgressHandler},$globals.Environment)});
- },
- args: ["aProgressHandler"],
- source: "registerProgressHandler: aProgressHandler\x0a\x09ProgressHandler register: aProgressHandler",
- referencedClasses: ["ProgressHandler"],
- messageSends: ["register:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "registerTranscript:",
- protocol: "services",
- fn: function (aTranscript){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Transcript)._register_(aTranscript);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"registerTranscript:",{aTranscript:aTranscript},$globals.Environment)});
- },
- args: ["aTranscript"],
- source: "registerTranscript: aTranscript\x0a\x09Transcript register: aTranscript",
- referencedClasses: ["Transcript"],
- messageSends: ["register:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "removeClass:",
- protocol: "actions",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Smalltalk)._removeClass_(aClass);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeClass:",{aClass:aClass},$globals.Environment)});
- },
- args: ["aClass"],
- source: "removeClass: aClass\x0a\x09Smalltalk removeClass: aClass",
- referencedClasses: ["Smalltalk"],
- messageSends: ["removeClass:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "removeMethod:",
- protocol: "actions",
- fn: function (aMethod){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aMethod)._methodClass())._removeCompiledMethod_(aMethod);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeMethod:",{aMethod:aMethod},$globals.Environment)});
- },
- args: ["aMethod"],
- source: "removeMethod: aMethod\x0a\x09aMethod methodClass removeCompiledMethod: aMethod",
- referencedClasses: [],
- messageSends: ["removeCompiledMethod:", "methodClass"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "removeProtocol:from:",
- protocol: "actions",
- fn: function (aString,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aClass)._methodsInProtocol_(aString))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(aClass)._removeCompiledMethod_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeProtocol:from:",{aString:aString,aClass:aClass},$globals.Environment)});
- },
- args: ["aString", "aClass"],
- source: "removeProtocol: aString from: aClass\x0a\x09(aClass methodsInProtocol: aString)\x0a\x09\x09do: [ :each | aClass removeCompiledMethod: each ]",
- referencedClasses: [],
- messageSends: ["do:", "methodsInProtocol:", "removeCompiledMethod:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "renameClass:to:",
- protocol: "actions",
- fn: function (aClass,aClassName){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=$recv($recv($globals.Smalltalk)._globals())._at_(aClassName);
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $2=$recv("A class named ".__comma(aClassName)).__comma(" already exists");
- $ctx1.sendIdx[","]=1;
- self._error_($2);
- }
- $recv($recv($globals.ClassBuilder)._new())._renameClass_to_(aClass,aClassName);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"renameClass:to:",{aClass:aClass,aClassName:aClassName},$globals.Environment)});
- },
- args: ["aClass", "aClassName"],
- source: "renameClass: aClass to: aClassName\x0a\x09(Smalltalk globals at: aClassName)\x0a\x09\x09ifNotNil: [ self error: 'A class named ', aClassName, ' already exists' ].\x0a\x09\x09\x0a\x09ClassBuilder new renameClass: aClass to: aClassName",
- referencedClasses: ["Smalltalk", "ClassBuilder"],
- messageSends: ["ifNotNil:", "at:", "globals", "error:", ",", "renameClass:to:", "new"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "renamePackage:to:",
- protocol: "actions",
- fn: function (aPackageName,aNewPackageName){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=$recv($recv($globals.Smalltalk)._globals())._at_(aNewPackageName);
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $2=$recv("A package named ".__comma(aNewPackageName)).__comma(" already exists");
- $ctx1.sendIdx[","]=1;
- self._error_($2);
- }
- $recv($globals.Smalltalk)._renamePackage_to_(aPackageName,aNewPackageName);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"renamePackage:to:",{aPackageName:aPackageName,aNewPackageName:aNewPackageName},$globals.Environment)});
- },
- args: ["aPackageName", "aNewPackageName"],
- source: "renamePackage: aPackageName to: aNewPackageName\x0a (Smalltalk globals at: aNewPackageName)\x0a ifNotNil: [ self error: 'A package named ', aNewPackageName, ' already exists' ].\x0a\x0a Smalltalk renamePackage: aPackageName to: aNewPackageName",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifNotNil:", "at:", "globals", "error:", ",", "renamePackage:to:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "renameProtocol:to:in:",
- protocol: "actions",
- fn: function (aString,anotherString,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aClass)._methodsInProtocol_(aString))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._protocol_(anotherString);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"renameProtocol:to:in:",{aString:aString,anotherString:anotherString,aClass:aClass},$globals.Environment)});
- },
- args: ["aString", "anotherString", "aClass"],
- source: "renameProtocol: aString to: anotherString in: aClass\x0a\x09(aClass methodsInProtocol: aString)\x0a\x09\x09do: [ :each | each protocol: anotherString ]",
- referencedClasses: [],
- messageSends: ["do:", "methodsInProtocol:", "protocol:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "setClassCommentOf:to:",
- protocol: "actions",
- fn: function (aClass,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aClass)._comment_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setClassCommentOf:to:",{aClass:aClass,aString:aString},$globals.Environment)});
- },
- args: ["aClass", "aString"],
- source: "setClassCommentOf: aClass to: aString\x0a\x09aClass comment: aString",
- referencedClasses: [],
- messageSends: ["comment:"]
- }),
- $globals.Environment);
- $core.addMethod(
- $core.method({
- selector: "systemAnnouncer",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($recv($globals.Smalltalk)._globals())._at_("SystemAnnouncer"))._current();
- }, function($ctx1) {$ctx1.fill(self,"systemAnnouncer",{},$globals.Environment)});
- },
- args: [],
- source: "systemAnnouncer\x0a\x09^ (Smalltalk globals at: #SystemAnnouncer) current",
- referencedClasses: ["Smalltalk"],
- messageSends: ["current", "at:", "globals"]
- }),
- $globals.Environment);
- $core.addClass("NullProgressHandler", $globals.Object, [], "Platform-Services");
- $globals.NullProgressHandler.comment="I am the default progress handler. I do not display any progress, and simply iterate over the collection.";
- $core.addMethod(
- $core.method({
- selector: "do:on:displaying:",
- protocol: "progress handling",
- fn: function (aBlock,aCollection,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aCollection)._do_(aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:on:displaying:",{aBlock:aBlock,aCollection:aCollection,aString:aString},$globals.NullProgressHandler)});
- },
- args: ["aBlock", "aCollection", "aString"],
- source: "do: aBlock on: aCollection displaying: aString\x0a\x09aCollection do: aBlock",
- referencedClasses: [],
- messageSends: ["do:"]
- }),
- $globals.NullProgressHandler);
- $globals.NullProgressHandler.klass.iVarNames = ["current"];
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.ProgressHandler)._registerIfNone_(self._new());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.NullProgressHandler.klass)});
- },
- args: [],
- source: "initialize\x0a\x09ProgressHandler registerIfNone: self new",
- referencedClasses: ["ProgressHandler"],
- messageSends: ["registerIfNone:", "new"]
- }),
- $globals.NullProgressHandler.klass);
- $core.addClass("Service", $globals.Object, [], "Platform-Services");
- $globals.Service.comment="I implement the basic behavior for class registration to a service.\x0a\x0aSee the `Transcript` class for a concrete service.\x0a\x0a## API\x0a\x0aUse class-side methods `#register:` and `#registerIfNone:` to register classes to a specific service.";
- $globals.Service.klass.iVarNames = ["current"];
- $core.addMethod(
- $core.method({
- selector: "current",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@current"];
- },
- args: [],
- source: "current\x0a\x09^ current",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Service.klass);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldNotImplement();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.Service.klass)});
- },
- args: [],
- source: "new\x0a\x09self shouldNotImplement",
- referencedClasses: [],
- messageSends: ["shouldNotImplement"]
- }),
- $globals.Service.klass);
- $core.addMethod(
- $core.method({
- selector: "register:",
- protocol: "registration",
- fn: function (anObject){
- var self=this;
- self["@current"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "register: anObject\x0a\x09current := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Service.klass);
- $core.addMethod(
- $core.method({
- selector: "registerIfNone:",
- protocol: "registration",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._current();
- if(($receiver = $1) == null || $receiver.isNil){
- self._register_(anObject);
- } else {
- $1;
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"registerIfNone:",{anObject:anObject},$globals.Service.klass)});
- },
- args: ["anObject"],
- source: "registerIfNone: anObject\x0a\x09self current ifNil: [ self register: anObject ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "current", "register:"]
- }),
- $globals.Service.klass);
- $core.addClass("ErrorHandler", $globals.Service, [], "Platform-Services");
- $globals.ErrorHandler.comment="I am the service used to handle Smalltalk errors.\x0aSee `boot.js` `handleError()` function.\x0a\x0aRegistered service instances must implement `#handleError:` to perform an action on the thrown exception.";
- $core.addMethod(
- $core.method({
- selector: "handleError:",
- protocol: "error handling",
- fn: function (anError){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._handleUnhandledError_(anError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"handleError:",{anError:anError},$globals.ErrorHandler.klass)});
- },
- args: ["anError"],
- source: "handleError: anError\x0a\x09self handleUnhandledError: anError",
- referencedClasses: [],
- messageSends: ["handleUnhandledError:"]
- }),
- $globals.ErrorHandler.klass);
- $core.addMethod(
- $core.method({
- selector: "handleUnhandledError:",
- protocol: "error handling",
- fn: function (anError){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(anError)._wasHandled();
- if($core.assert($1)){
- return self;
- }
- return $recv(self._current())._handleError_(anError);
- }, function($ctx1) {$ctx1.fill(self,"handleUnhandledError:",{anError:anError},$globals.ErrorHandler.klass)});
- },
- args: ["anError"],
- source: "handleUnhandledError: anError\x0a\x09anError wasHandled ifTrue: [ ^ self ].\x0a\x09\x0a\x09^ self current handleError: anError",
- referencedClasses: [],
- messageSends: ["ifTrue:", "wasHandled", "handleError:", "current"]
- }),
- $globals.ErrorHandler.klass);
- $core.addClass("Finder", $globals.Service, [], "Platform-Services");
- $globals.Finder.comment="I am the service responsible for finding classes/methods.\x0a__There is no default finder.__\x0a\x0a## API\x0a\x0aUse `#browse` on an object to find it.";
- $core.addMethod(
- $core.method({
- selector: "findClass:",
- protocol: "finding",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._findClass_(aClass);
- }, function($ctx1) {$ctx1.fill(self,"findClass:",{aClass:aClass},$globals.Finder.klass)});
- },
- args: ["aClass"],
- source: "findClass: aClass\x0a\x09^ self current findClass: aClass",
- referencedClasses: [],
- messageSends: ["findClass:", "current"]
- }),
- $globals.Finder.klass);
- $core.addMethod(
- $core.method({
- selector: "findMethod:",
- protocol: "finding",
- fn: function (aCompiledMethod){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._findMethod_(aCompiledMethod);
- }, function($ctx1) {$ctx1.fill(self,"findMethod:",{aCompiledMethod:aCompiledMethod},$globals.Finder.klass)});
- },
- args: ["aCompiledMethod"],
- source: "findMethod: aCompiledMethod\x0a\x09^ self current findMethod: aCompiledMethod",
- referencedClasses: [],
- messageSends: ["findMethod:", "current"]
- }),
- $globals.Finder.klass);
- $core.addMethod(
- $core.method({
- selector: "findString:",
- protocol: "finding",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._findString_(aString);
- }, function($ctx1) {$ctx1.fill(self,"findString:",{aString:aString},$globals.Finder.klass)});
- },
- args: ["aString"],
- source: "findString: aString\x0a\x09^ self current findString: aString",
- referencedClasses: [],
- messageSends: ["findString:", "current"]
- }),
- $globals.Finder.klass);
- $core.addClass("Inspector", $globals.Service, [], "Platform-Services");
- $globals.Inspector.comment="I am the service responsible for inspecting objects.\x0a\x0aThe default inspector object is the transcript.";
- $core.addMethod(
- $core.method({
- selector: "inspect:",
- protocol: "inspecting",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._inspect_(anObject);
- }, function($ctx1) {$ctx1.fill(self,"inspect:",{anObject:anObject},$globals.Inspector.klass)});
- },
- args: ["anObject"],
- source: "inspect: anObject\x0a\x09^ self current inspect: anObject",
- referencedClasses: [],
- messageSends: ["inspect:", "current"]
- }),
- $globals.Inspector.klass);
- $core.addClass("Platform", $globals.Service, [], "Platform-Services");
- $globals.Platform.comment="I am bridge to JS environment.\x0a\x0a## API\x0a\x0a Platform globals. \x22JS global object\x22\x0a Platform newXHR \x22new XMLHttpRequest() or its shim\x22";
- $core.addMethod(
- $core.method({
- selector: "globals",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._globals();
- }, function($ctx1) {$ctx1.fill(self,"globals",{},$globals.Platform.klass)});
- },
- args: [],
- source: "globals\x0a\x09^ self current globals",
- referencedClasses: [],
- messageSends: ["globals", "current"]
- }),
- $globals.Platform.klass);
- $core.addMethod(
- $core.method({
- selector: "newXhr",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._newXhr();
- }, function($ctx1) {$ctx1.fill(self,"newXhr",{},$globals.Platform.klass)});
- },
- args: [],
- source: "newXhr\x0a\x09^ self current newXhr",
- referencedClasses: [],
- messageSends: ["newXhr", "current"]
- }),
- $globals.Platform.klass);
- $core.addClass("ProgressHandler", $globals.Service, [], "Platform-Services");
- $globals.ProgressHandler.comment="I am used to manage progress in collection iterations, see `SequenceableCollection >> #do:displayingProgress:`.\x0a\x0aRegistered instances must implement `#do:on:displaying:`.\x0a\x0aThe default behavior is to simply iterate over the collection, using `NullProgressHandler`.";
- $core.addMethod(
- $core.method({
- selector: "do:on:displaying:",
- protocol: "progress handling",
- fn: function (aBlock,aCollection,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._current())._do_on_displaying_(aBlock,aCollection,aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:on:displaying:",{aBlock:aBlock,aCollection:aCollection,aString:aString},$globals.ProgressHandler.klass)});
- },
- args: ["aBlock", "aCollection", "aString"],
- source: "do: aBlock on: aCollection displaying: aString\x0a\x09self current do: aBlock on: aCollection displaying: aString",
- referencedClasses: [],
- messageSends: ["do:on:displaying:", "current"]
- }),
- $globals.ProgressHandler.klass);
- $core.addClass("Terminal", $globals.Service, [], "Platform-Services");
- $globals.Terminal.comment="I am UI interface service.\x0a\x0a## API\x0a\x0a Terminal alert: 'Hey, there is a problem'.\x0a Terminal confirm: 'Affirmative?'.\x0a Terminal prompt: 'Your name:'.";
- $core.addMethod(
- $core.method({
- selector: "alert:",
- protocol: "dialogs",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._alert_(aString);
- }, function($ctx1) {$ctx1.fill(self,"alert:",{aString:aString},$globals.Terminal.klass)});
- },
- args: ["aString"],
- source: "alert: aString\x0a\x09^ self current alert: aString",
- referencedClasses: [],
- messageSends: ["alert:", "current"]
- }),
- $globals.Terminal.klass);
- $core.addMethod(
- $core.method({
- selector: "confirm:",
- protocol: "dialogs",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._confirm_(aString);
- }, function($ctx1) {$ctx1.fill(self,"confirm:",{aString:aString},$globals.Terminal.klass)});
- },
- args: ["aString"],
- source: "confirm: aString\x0a\x09^ self current confirm: aString",
- referencedClasses: [],
- messageSends: ["confirm:", "current"]
- }),
- $globals.Terminal.klass);
- $core.addMethod(
- $core.method({
- selector: "prompt:",
- protocol: "dialogs",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._prompt_(aString);
- }, function($ctx1) {$ctx1.fill(self,"prompt:",{aString:aString},$globals.Terminal.klass)});
- },
- args: ["aString"],
- source: "prompt: aString\x0a\x09^ self current prompt: aString",
- referencedClasses: [],
- messageSends: ["prompt:", "current"]
- }),
- $globals.Terminal.klass);
- $core.addMethod(
- $core.method({
- selector: "prompt:default:",
- protocol: "dialogs",
- fn: function (aString,defaultString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._current())._prompt_default_(aString,defaultString);
- }, function($ctx1) {$ctx1.fill(self,"prompt:default:",{aString:aString,defaultString:defaultString},$globals.Terminal.klass)});
- },
- args: ["aString", "defaultString"],
- source: "prompt: aString default: defaultString\x0a\x09^ self current prompt: aString default: defaultString",
- referencedClasses: [],
- messageSends: ["prompt:default:", "current"]
- }),
- $globals.Terminal.klass);
- $core.addClass("Transcript", $globals.Service, [], "Platform-Services");
- $globals.Transcript.comment="I am a facade for Transcript actions.\x0a\x0aI delegate actions to the currently registered transcript.\x0a\x0a## API\x0a\x0a Transcript \x0a show: 'hello world';\x0a cr;\x0a show: anObject.";
- $core.addMethod(
- $core.method({
- selector: "clear",
- protocol: "printing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._current())._clear();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"clear",{},$globals.Transcript.klass)});
- },
- args: [],
- source: "clear\x0a\x09self current clear",
- referencedClasses: [],
- messageSends: ["clear", "current"]
- }),
- $globals.Transcript.klass);
- $core.addMethod(
- $core.method({
- selector: "cr",
- protocol: "printing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._current())._show_($recv($globals.String)._cr());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"cr",{},$globals.Transcript.klass)});
- },
- args: [],
- source: "cr\x0a\x09self current show: String cr",
- referencedClasses: ["String"],
- messageSends: ["show:", "current", "cr"]
- }),
- $globals.Transcript.klass);
- $core.addMethod(
- $core.method({
- selector: "inspect:",
- protocol: "printing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._show_(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspect:",{anObject:anObject},$globals.Transcript.klass)});
- },
- args: ["anObject"],
- source: "inspect: anObject\x0a\x09self show: anObject",
- referencedClasses: [],
- messageSends: ["show:"]
- }),
- $globals.Transcript.klass);
- $core.addMethod(
- $core.method({
- selector: "open",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._current())._open();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"open",{},$globals.Transcript.klass)});
- },
- args: [],
- source: "open\x0a\x09self current open",
- referencedClasses: [],
- messageSends: ["open", "current"]
- }),
- $globals.Transcript.klass);
- $core.addMethod(
- $core.method({
- selector: "show:",
- protocol: "printing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._current())._show_(anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"show:",{anObject:anObject},$globals.Transcript.klass)});
- },
- args: ["anObject"],
- source: "show: anObject\x0a\x09self current show: anObject",
- referencedClasses: [],
- messageSends: ["show:", "current"]
- }),
- $globals.Transcript.klass);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var variables;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.Dictionary)._new();
- $recv(variables)._at_put_("#self",self);
- $ctx1.sendIdx["at:put:"]=1;
- $recv(variables)._at_put_("#keys",self._keys());
- $ctx1.sendIdx["at:put:"]=2;
- self._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(variables)._at_put_(key,value);
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)});
- }));
- $recv(anInspector)._setLabel_(self._printString());
- $recv(anInspector)._setVariables_(variables);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},$globals.AssociativeCollection)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self.\x0a\x09variables at: '#keys' put: self keys.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09variables at: key put: value ].\x0a\x09anInspector\x0a\x09\x09setLabel: self printString;\x0a\x09\x09setVariables: variables",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:", "keys", "keysAndValuesDo:", "setLabel:", "printString", "setVariables:"]
- }),
- $globals.AssociativeCollection);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var variables;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.Dictionary)._new();
- $recv(variables)._at_put_("#self",self);
- $ctx1.sendIdx["at:put:"]=1;
- self._withIndexDo_((function(each,i){
- return $core.withContext(function($ctx2) {
- return $recv(variables)._at_put_(i,each);
- }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1,1)});
- }));
- $recv(anInspector)._setLabel_(self._printString());
- $recv(anInspector)._setVariables_(variables);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},$globals.Collection)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self.\x0a\x09self withIndexDo: [ :each :i |\x0a\x09\x09variables at: i put: each ].\x0a\x09anInspector\x0a\x09\x09setLabel: self printString;\x0a\x09\x09setVariables: variables",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:", "withIndexDo:", "setLabel:", "printString", "setVariables:"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var variables;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.Dictionary)._new();
- $recv(variables)._at_put_("#self",self);
- $ctx1.sendIdx["at:put:"]=1;
- $recv(variables)._at_put_("#year",self._year());
- $ctx1.sendIdx["at:put:"]=2;
- $recv(variables)._at_put_("#month",self._month());
- $ctx1.sendIdx["at:put:"]=3;
- $recv(variables)._at_put_("#day",self._day());
- $ctx1.sendIdx["at:put:"]=4;
- $recv(variables)._at_put_("#hours",self._hours());
- $ctx1.sendIdx["at:put:"]=5;
- $recv(variables)._at_put_("#minutes",self._minutes());
- $ctx1.sendIdx["at:put:"]=6;
- $recv(variables)._at_put_("#seconds",self._seconds());
- $ctx1.sendIdx["at:put:"]=7;
- $recv(variables)._at_put_("#milliseconds",self._milliseconds());
- $recv(anInspector)._setLabel_(self._printString());
- $recv(anInspector)._setVariables_(variables);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},$globals.Date)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self.\x0a\x09variables at: '#year' put: self year.\x0a\x09variables at: '#month' put: self month.\x0a\x09variables at: '#day' put: self day.\x0a\x09variables at: '#hours' put: self hours.\x0a\x09variables at: '#minutes' put: self minutes.\x0a\x09variables at: '#seconds' put: self seconds.\x0a\x09variables at: '#milliseconds' put: self milliseconds.\x0a\x09anInspector\x0a\x09\x09setLabel: self printString;\x0a\x09\x09setVariables: variables",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:", "year", "month", "day", "hours", "minutes", "seconds", "milliseconds", "setLabel:", "printString", "setVariables:"]
- }),
- $globals.Date);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var variables;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.Dictionary)._new();
- $recv(variables)._at_put_("#self",self._jsObject());
- $recv(anInspector)._setLabel_(self._printString());
- $recv($globals.JSObjectProxy)._addObjectVariablesTo_ofProxy_(variables,self);
- $recv(anInspector)._setVariables_(variables);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},$globals.JSObjectProxy)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self jsObject.\x0a\x09anInspector setLabel: self printString.\x0a\x09JSObjectProxy addObjectVariablesTo: variables ofProxy: self.\x0a\x09anInspector setVariables: variables",
- referencedClasses: ["Dictionary", "JSObjectProxy"],
- messageSends: ["new", "at:put:", "jsObject", "setLabel:", "printString", "addObjectVariablesTo:ofProxy:", "setVariables:"]
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var variables;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.Dictionary)._new();
- $recv(variables)._at_put_("#self",self);
- $ctx1.sendIdx["at:put:"]=1;
- $recv(variables)._at_put_("#home",self._home());
- $ctx1.sendIdx["at:put:"]=2;
- $recv(variables)._at_put_("#receiver",self._receiver());
- $ctx1.sendIdx["at:put:"]=3;
- $recv(variables)._at_put_("#selector",self._selector());
- $ctx1.sendIdx["at:put:"]=4;
- $recv(variables)._at_put_("#locals",self._locals());
- $ctx1.sendIdx["at:put:"]=5;
- $recv($recv(self._class())._instanceVariableNames())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(variables)._at_put_(each,self._instVarAt_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $recv(anInspector)._setLabel_(self._printString());
- $recv(anInspector)._setVariables_(variables);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},$globals.MethodContext)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self.\x0a\x09variables at: '#home' put: self home.\x0a\x09variables at: '#receiver' put: self receiver.\x0a\x09variables at: '#selector' put: self selector.\x0a\x09variables at: '#locals' put: self locals.\x0a\x09self class instanceVariableNames do: [ :each |\x0a\x09\x09variables at: each put: (self instVarAt: each) ].\x0a\x09anInspector\x0a\x09\x09setLabel: self printString;\x0a\x09\x09setVariables: variables",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:", "home", "receiver", "selector", "locals", "do:", "instanceVariableNames", "class", "instVarAt:", "setLabel:", "printString", "setVariables:"]
- }),
- $globals.MethodContext);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var variables;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.Dictionary)._new();
- $recv(variables)._at_put_("#self",self);
- $ctx1.sendIdx["at:put:"]=1;
- $recv($recv(self._class())._allInstanceVariableNames())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(variables)._at_put_(each,self._instVarAt_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $recv(anInspector)._setLabel_(self._printString());
- $recv(anInspector)._setVariables_(variables);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},$globals.Object)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self.\x0a\x09self class allInstanceVariableNames do: [ :each |\x0a\x09\x09variables at: each put: (self instVarAt: each) ].\x0a\x09anInspector\x0a\x09\x09setLabel: self printString;\x0a\x09\x09setVariables: variables",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:", "do:", "allInstanceVariableNames", "class", "instVarAt:", "setLabel:", "printString", "setVariables:"]
- }),
- $globals.Object);
- $core.addMethod(
- $core.method({
- selector: "do:displayingProgress:",
- protocol: "*Platform-Services",
- fn: function (aBlock,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.ProgressHandler)._do_on_displaying_(aBlock,self,aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"do:displayingProgress:",{aBlock:aBlock,aString:aString},$globals.SequenceableCollection)});
- },
- args: ["aBlock", "aString"],
- source: "do: aBlock displayingProgress: aString\x0a\x09ProgressHandler \x0a\x09\x09do: aBlock \x0a\x09\x09on: self \x0a\x09\x09displaying: aString",
- referencedClasses: ["ProgressHandler"],
- messageSends: ["do:on:displaying:"]
- }),
- $globals.SequenceableCollection);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var variables,i;
- return $core.withContext(function($ctx1) {
- variables=$recv($globals.Dictionary)._new();
- $recv(variables)._at_put_("#self",self);
- $ctx1.sendIdx["at:put:"]=1;
- i=(1);
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- $recv(variables)._at_put_(i,each);
- i=$recv(i).__plus((1));
- return i;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $recv(anInspector)._setLabel_(self._printString());
- $recv(anInspector)._setVariables_(variables);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables,i:i},$globals.Set)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| variables i |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self.\x0a\x09i := 1.\x0a\x09self do: [ :each |\x0a\x09\x09variables at: i put: each.\x0a\x09\x09i := i + 1 ].\x0a\x09anInspector\x0a\x09\x09setLabel: self printString;\x0a\x09\x09setVariables: variables",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:", "do:", "+", "setLabel:", "printString", "setVariables:"]
- }),
- $globals.Set);
- $core.addMethod(
- $core.method({
- selector: "inspectOn:",
- protocol: "*Platform-Services",
- fn: function (anInspector){
- var self=this;
- var label;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$5,$4;
- (
- $ctx1.supercall = true,
- ($globals.String.superclass||$boot.nilAsClass).fn.prototype._inspectOn_.apply($recv(self), [anInspector]));
- $ctx1.supercall = false;
- $3=self._printString();
- $ctx1.sendIdx["printString"]=1;
- $2=$recv($3)._size();
- $1=$recv($2).__gt((30));
- if($core.assert($1)){
- $5=self._printString();
- $ctx1.sendIdx["printString"]=2;
- $4=$recv($5)._copyFrom_to_((1),(30));
- label=$recv($4).__comma("...'");
- label;
- } else {
- label=self._printString();
- label;
- }
- $recv(anInspector)._setLabel_(label);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,label:label},$globals.String)});
- },
- args: ["anInspector"],
- source: "inspectOn: anInspector\x0a\x09| label |\x0a\x09super inspectOn: anInspector.\x0a\x09self printString size > 30\x0a\x09\x09ifTrue: [ label := (self printString copyFrom: 1 to: 30), '...''' ]\x0a\x09\x09ifFalse: [ label := self printString ].\x0a\x09anInspector setLabel: label",
- referencedClasses: [],
- messageSends: ["inspectOn:", "ifTrue:ifFalse:", ">", "size", "printString", ",", "copyFrom:to:", "setLabel:"]
- }),
- $globals.String);
- });
- define('amber_core/Platform-Node',["amber/boot", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Platform-Node");
- $core.packages["Platform-Node"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Platform-Node"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("NodePlatform", $globals.Object, [], "Platform-Node");
- $globals.NodePlatform.comment="I am `Platform` service implementation for node-like environment.";
- $core.addMethod(
- $core.method({
- selector: "globals",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return global;
- },
- args: [],
- source: "globals\x0a\x09^ global",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NodePlatform);
- $core.addMethod(
- $core.method({
- selector: "newXhr",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $receiver;
- if(($receiver = $globals.XMLHttpRequest) == null || $receiver.isNil){
- self._error_("XMLHttpRequest not available.");
- } else {
- return $recv($globals.XMLHttpRequest)._new();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"newXhr",{},$globals.NodePlatform)});
- },
- args: [],
- source: "newXhr\x0a\x09XMLHttpRequest\x0a\x09\x09ifNotNil: [ ^ XMLHttpRequest new ]\x0a\x09\x09ifNil: [ self error: 'XMLHttpRequest not available.' ]",
- referencedClasses: ["XMLHttpRequest"],
- messageSends: ["ifNotNil:ifNil:", "new", "error:"]
- }),
- $globals.NodePlatform);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._isFeasible();
- if($core.assert($1)){
- $recv($globals.Platform)._registerIfNone_(self._new());
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.NodePlatform.klass)});
- },
- args: [],
- source: "initialize\x0a\x09self isFeasible ifTrue: [ Platform registerIfNone: self new ]",
- referencedClasses: ["Platform"],
- messageSends: ["ifTrue:", "isFeasible", "registerIfNone:", "new"]
- }),
- $globals.NodePlatform.klass);
- $core.addMethod(
- $core.method({
- selector: "isFeasible",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return typeof global !== "undefined";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"isFeasible",{},$globals.NodePlatform.klass)});
- },
- args: [],
- source: "isFeasible\x0a<inlineJS: 'return typeof global !== \x22undefined\x22'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.NodePlatform.klass);
- });
- define('amber/deploy',[
- './helpers',
- './compatibility', // pre-fetch, dep of ./boot
- './kernel-fundamentals', // pre-fetch, dep of ./boot
- './kernel-language', // pre-fetch, dep of ./boot
- './boot', // pre-fetch, dep of ./helpers
- // --- packages of the core Amber begin here ---
- 'amber_core/Kernel-Objects',
- 'amber_core/Kernel-Classes',
- 'amber_core/Kernel-Methods',
- 'amber_core/Kernel-Collections',
- 'amber_core/Kernel-Dag',
- 'amber_core/Kernel-Infrastructure',
- 'amber_core/Kernel-Promises',
- 'amber_core/Kernel-Exceptions',
- 'amber_core/Kernel-Announcements',
- 'amber_core/Platform-Services',
- 'amber/Platform'
- // --- packages of the core Amber end here ---
- ], function (amber) {
- return amber;
- });
- define('amber/parser',['./boot'], function($boot) {
- var $globals = $boot.globals;
- $globals.SmalltalkParser = (function() {
- "use strict";
- /*
- * Generated by PEG.js 0.9.0.
- *
- * http://pegjs.org/
- */
- function peg$subclass(child, parent) {
- function ctor() { this.constructor = child; }
- ctor.prototype = parent.prototype;
- child.prototype = new ctor();
- }
- function peg$SyntaxError(message, expected, found, location) {
- this.message = message;
- this.expected = expected;
- this.found = found;
- this.location = location;
- this.name = "SyntaxError";
- if (typeof Error.captureStackTrace === "function") {
- Error.captureStackTrace(this, peg$SyntaxError);
- }
- }
- peg$subclass(peg$SyntaxError, Error);
- function peg$parse(input) {
- var options = arguments.length > 1 ? arguments[1] : {},
- parser = this,
- peg$FAILED = {},
- peg$startRuleFunctions = { start: peg$parsestart },
- peg$startRuleFunction = peg$parsestart,
- peg$c0 = /^[ \t\x0B\f\xA0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF\n\r\u2028\u2029]/,
- peg$c1 = { type: "class", value: "[ \\t\\v\\f\\u00A0\\u1680\\u2000-\\u200A\\u202F\\u205F\\u3000\\uFEFF\\n\\r\\u2028\\u2029]", description: "[ \\t\\v\\f\\u00A0\\u1680\\u2000-\\u200A\\u202F\\u205F\\u3000\\uFEFF\\n\\r\\u2028\\u2029]" },
- peg$c2 = "\"",
- peg$c3 = { type: "literal", value: "\"", description: "\"\\\"\"" },
- peg$c4 = /^[^"]/,
- peg$c5 = { type: "class", value: "[^\"]", description: "[^\"]" },
- peg$c6 = ".",
- peg$c7 = { type: "literal", value: ".", description: "\".\"" },
- peg$c8 = /^[a-zA-Z]/,
- peg$c9 = { type: "class", value: "[a-zA-Z]", description: "[a-zA-Z]" },
- peg$c10 = /^[a-zA-Z0-9]/,
- peg$c11 = { type: "class", value: "[a-zA-Z0-9]", description: "[a-zA-Z0-9]" },
- peg$c12 = ":",
- peg$c13 = { type: "literal", value: ":", description: "\":\"" },
- peg$c14 = /^[A-Z]/,
- peg$c15 = { type: "class", value: "[A-Z]", description: "[A-Z]" },
- peg$c16 = function(val) {
- return $globals.ValueNode._new()
- ._location_(location())
- ._source_(text())
- ._value_(val);
- },
- peg$c17 = "'",
- peg$c18 = { type: "literal", value: "'", description: "\"'\"" },
- peg$c19 = "''",
- peg$c20 = { type: "literal", value: "''", description: "\"''\"" },
- peg$c21 = function() {return '\'';},
- peg$c22 = /^[^']/,
- peg$c23 = { type: "class", value: "[^']", description: "[^']" },
- peg$c24 = function(val) {return val.join('');},
- peg$c25 = "$",
- peg$c26 = { type: "literal", value: "$", description: "\"$\"" },
- peg$c27 = { type: "any", description: "any character" },
- peg$c28 = function(char) {
- return $globals.ValueNode._new()
- ._location_(location())
- ._source_(text())
- ._value_(char);
- },
- peg$c29 = "#",
- peg$c30 = { type: "literal", value: "#", description: "\"#\"" },
- peg$c31 = function(rest) {return rest;},
- peg$c32 = "e",
- peg$c33 = { type: "literal", value: "e", description: "\"e\"" },
- peg$c34 = function(n) {return parseFloat(n);},
- peg$c35 = "-",
- peg$c36 = { type: "literal", value: "-", description: "\"-\"" },
- peg$c37 = "16r",
- peg$c38 = { type: "literal", value: "16r", description: "\"16r\"" },
- peg$c39 = /^[0-9a-fA-F]/,
- peg$c40 = { type: "class", value: "[0-9a-fA-F]", description: "[0-9a-fA-F]" },
- peg$c41 = function(neg, num) {
- return parseInt(((neg || '') + num), 16);
- },
- peg$c42 = /^[0-9]/,
- peg$c43 = { type: "class", value: "[0-9]", description: "[0-9]" },
- peg$c44 = function(n) {return parseFloat(n, 10);},
- peg$c45 = function(n) {return parseInt(n, 10);},
- peg$c46 = "#(",
- peg$c47 = { type: "literal", value: "#(", description: "\"#(\"" },
- peg$c48 = ")",
- peg$c49 = { type: "literal", value: ")", description: "\")\"" },
- peg$c50 = function(rest) {
- return rest
- ._location_(location())
- ._source_(text());
- },
- peg$c51 = "(",
- peg$c52 = { type: "literal", value: "(", description: "\"(\"" },
- peg$c53 = function(lit) {return lit._value();},
- peg$c54 = function(lits) {
- return $globals.ValueNode._new()
- ._value_(lits);
- },
- peg$c55 = "{",
- peg$c56 = { type: "literal", value: "{", description: "\"{\"" },
- peg$c57 = "}",
- peg$c58 = { type: "literal", value: "}", description: "\"}\"" },
- peg$c59 = function(expressions) {
- return $globals.DynamicArrayNode._new()
- ._location_(location())
- ._source_(text())
- ._dagChildren_(expressions || []);
- },
- peg$c60 = "#{",
- peg$c61 = { type: "literal", value: "#{", description: "\"#{\"" },
- peg$c62 = function(expressions) {
- return $globals.DynamicDictionaryNode._new()
- ._location_(location())
- ._source_(text())
- ._dagChildren_(expressions || []);
- },
- peg$c63 = "true",
- peg$c64 = { type: "literal", value: "true", description: "\"true\"" },
- peg$c65 = function() {return true;},
- peg$c66 = "false",
- peg$c67 = { type: "literal", value: "false", description: "\"false\"" },
- peg$c68 = function() {return false;},
- peg$c69 = "nil",
- peg$c70 = { type: "literal", value: "nil", description: "\"nil\"" },
- peg$c71 = function() {return null;},
- peg$c72 = function(identifier) {
- return $globals.VariableNode._new()
- ._location_(location())
- ._source_(text())
- ._value_(identifier);
- },
- peg$c73 = /^[\\+*\/=><,@%~|&\-]/,
- peg$c74 = { type: "class", value: "[\\\\+*/=><,@%~|&-]", description: "[\\\\+*/=><,@%~|&-]" },
- peg$c75 = function(key, arg) {return {key:key, arg:arg};},
- peg$c76 = function(pairs) {
- var selector = '';
- var params = [];
- for(var i = 0; i < pairs.length; i++) {
- selector += pairs[i].key;
- params.push(pairs[i].arg);
- }
- return [selector, params];
- },
- peg$c77 = function(selector, arg) {
- return [selector, [arg]];
- },
- peg$c78 = function(selector) {return [selector, []];},
- peg$c79 = function(expression) {
- return expression;
- },
- peg$c80 = function(first, others) {
- return [first].concat(others);
- },
- peg$c81 = ":=",
- peg$c82 = { type: "literal", value: ":=", description: "\":=\"" },
- peg$c83 = function(variable, expression) {
- return $globals.AssignmentNode._new()
- ._location_(location())
- ._source_(text())
- ._left_(variable)
- ._right_(expression);
- },
- peg$c84 = "^",
- peg$c85 = { type: "literal", value: "^", description: "\"^\"" },
- peg$c86 = function(expression) {
- return $globals.ReturnNode._new()
- ._location_(location())
- ._source_(text())
- ._dagChildren_([expression]);
- },
- peg$c87 = "|",
- peg$c88 = { type: "literal", value: "|", description: "\"|\"" },
- peg$c89 = function(variable) {return variable;},
- peg$c90 = function(vars) {
- return vars;
- },
- peg$c91 = function(param) {return param;},
- peg$c92 = function(params) {
- return params;
- },
- peg$c93 = function(ret) {return [ret];},
- peg$c94 = function(exps, ret) {
- var expressions = exps;
- expressions.push(ret);
- return expressions;
- },
- peg$c95 = function(expressions) {return expressions || [];},
- peg$c96 = function(js) {return js;},
- peg$c97 = function(temps, statements) {
- return $globals.SequenceNode._new()
- ._location_(location())
- ._source_(text())
- ._temps_(temps || [])
- ._dagChildren_(statements || []);
- },
- peg$c98 = "[",
- peg$c99 = { type: "literal", value: "[", description: "\"[\"" },
- peg$c100 = "]",
- peg$c101 = { type: "literal", value: "]", description: "\"]\"" },
- peg$c102 = function(params, sequence) {
- return $globals.BlockNode._new()
- ._location_(location())
- ._source_(text())
- ._parameters_(params || [])
- ._dagChildren_([sequence._asBlockSequenceNode()]);
- },
- peg$c103 = function(selector) {
- return $globals.SendNode._new()
- ._location_(location())
- ._source_(text())
- ._selector_(selector);
- },
- peg$c104 = function(receiver, tail) {
- return receiver._withTail_(tail);
- },
- peg$c105 = function(selector, arg) {
- return $globals.SendNode._new()
- ._location_(location())
- ._source_(text())
- ._selector_(selector)
- ._arguments_([arg]);
- },
- peg$c106 = function(pairs) {
- var selector = '';
- var args = [];
- for(var i = 0; i < pairs.length; i++) {
- selector += pairs[i].key;
- args.push(pairs[i].arg);
- }
- return $globals.SendNode._new()
- ._location_(location())
- ._source_(text())
- ._selector_(selector)
- ._arguments_(args);
- },
- peg$c107 = function(receiver, tail) {
- return tail ? receiver._withTail_([tail]) : receiver;
- },
- peg$c108 = function(send) {return send._isSendNode();},
- peg$c109 = ";",
- peg$c110 = { type: "literal", value: ";", description: "\";\"" },
- peg$c111 = function(send, mess) {return mess;},
- peg$c112 = function(send, messages) {
- messages.unshift(send);
- return $globals.CascadeNode._new()
- ._location_(location())
- ._source_(text())
- ._dagChildren_(messages);
- },
- peg$c113 = "<",
- peg$c114 = { type: "literal", value: "<", description: "\"<\"" },
- peg$c115 = ">>",
- peg$c116 = { type: "literal", value: ">>", description: "\">>\"" },
- peg$c117 = function() {return '>';},
- peg$c118 = /^[^>]/,
- peg$c119 = { type: "class", value: "[^>]", description: "[^>]" },
- peg$c120 = ">",
- peg$c121 = { type: "literal", value: ">", description: "\">\"" },
- peg$c122 = function(val) {return !/^\s*inlineJS/.test(val.join(''));},
- peg$c123 = function(val) {
- console.warn('Use of <...js code...> is deprecated, in:\n' + val.join(''));
- return $globals.JSStatementNode._new()
- ._location_(location())
- ._source_(val.join(''))
- },
- peg$c124 = "inlineJS:",
- peg$c125 = { type: "literal", value: "inlineJS:", description: "\"inlineJS:\"" },
- peg$c126 = function(val) {
- return $globals.JSStatementNode._new()
- ._location_(location())
- ._source_(val)
- },
- peg$c127 = function(pattern, sequence) {
- return $globals.MethodNode._new()
- ._location_(location())
- ._source_(text())
- ._selector_(pattern[0])
- ._arguments_(pattern[1])
- ._dagChildren_([sequence]);
- },
- peg$c128 = function(send) { return send._isSendNode() && send._selector() === '->' },
- peg$c129 = function(send) {
- return [send._receiver(), send._arguments()[0]];
- },
- peg$c130 = function(first, others) {
- return first.concat.apply(first, others);
- },
- peg$currPos = 0,
- peg$savedPos = 0,
- peg$posDetailsCache = [{ line: 1, column: 1, seenCR: false }],
- peg$maxFailPos = 0,
- peg$maxFailExpected = [],
- peg$silentFails = 0,
- peg$resultsCache = {},
- peg$result;
- if ("startRule" in options) {
- if (!(options.startRule in peg$startRuleFunctions)) {
- throw new Error("Can't start parsing from rule \"" + options.startRule + "\".");
- }
- peg$startRuleFunction = peg$startRuleFunctions[options.startRule];
- }
- function text() {
- return input.substring(peg$savedPos, peg$currPos);
- }
- function location() {
- return peg$computeLocation(peg$savedPos, peg$currPos);
- }
- function expected(description) {
- throw peg$buildException(
- null,
- [{ type: "other", description: description }],
- input.substring(peg$savedPos, peg$currPos),
- peg$computeLocation(peg$savedPos, peg$currPos)
- );
- }
- function error(message) {
- throw peg$buildException(
- message,
- null,
- input.substring(peg$savedPos, peg$currPos),
- peg$computeLocation(peg$savedPos, peg$currPos)
- );
- }
- function peg$computePosDetails(pos) {
- var details = peg$posDetailsCache[pos],
- p, ch;
- if (details) {
- return details;
- } else {
- p = pos - 1;
- while (!peg$posDetailsCache[p]) {
- p--;
- }
- details = peg$posDetailsCache[p];
- details = {
- line: details.line,
- column: details.column,
- seenCR: details.seenCR
- };
- while (p < pos) {
- ch = input.charAt(p);
- if (ch === "\n") {
- if (!details.seenCR) { details.line++; }
- details.column = 1;
- details.seenCR = false;
- } else if (ch === "\r" || ch === "\u2028" || ch === "\u2029") {
- details.line++;
- details.column = 1;
- details.seenCR = true;
- } else {
- details.column++;
- details.seenCR = false;
- }
- p++;
- }
- peg$posDetailsCache[pos] = details;
- return details;
- }
- }
- function peg$computeLocation(startPos, endPos) {
- var startPosDetails = peg$computePosDetails(startPos),
- endPosDetails = peg$computePosDetails(endPos);
- return {
- start: {
- offset: startPos,
- line: startPosDetails.line,
- column: startPosDetails.column
- },
- end: {
- offset: endPos,
- line: endPosDetails.line,
- column: endPosDetails.column
- }
- };
- }
- function peg$fail(expected) {
- if (peg$currPos < peg$maxFailPos) { return; }
- if (peg$currPos > peg$maxFailPos) {
- peg$maxFailPos = peg$currPos;
- peg$maxFailExpected = [];
- }
- peg$maxFailExpected.push(expected);
- }
- function peg$buildException(message, expected, found, location) {
- function cleanupExpected(expected) {
- var i = 1;
- expected.sort(function(a, b) {
- if (a.description < b.description) {
- return -1;
- } else if (a.description > b.description) {
- return 1;
- } else {
- return 0;
- }
- });
- while (i < expected.length) {
- if (expected[i - 1] === expected[i]) {
- expected.splice(i, 1);
- } else {
- i++;
- }
- }
- }
- function buildMessage(expected, found) {
- function stringEscape(s) {
- function hex(ch) { return ch.charCodeAt(0).toString(16).toUpperCase(); }
- return s
- .replace(/\\/g, '\\\\')
- .replace(/"/g, '\\"')
- .replace(/\x08/g, '\\b')
- .replace(/\t/g, '\\t')
- .replace(/\n/g, '\\n')
- .replace(/\f/g, '\\f')
- .replace(/\r/g, '\\r')
- .replace(/[\x00-\x07\x0B\x0E\x0F]/g, function(ch) { return '\\x0' + hex(ch); })
- .replace(/[\x10-\x1F\x80-\xFF]/g, function(ch) { return '\\x' + hex(ch); })
- .replace(/[\u0100-\u0FFF]/g, function(ch) { return '\\u0' + hex(ch); })
- .replace(/[\u1000-\uFFFF]/g, function(ch) { return '\\u' + hex(ch); });
- }
- var expectedDescs = new Array(expected.length),
- expectedDesc, foundDesc, i;
- for (i = 0; i < expected.length; i++) {
- expectedDescs[i] = expected[i].description;
- }
- expectedDesc = expected.length > 1
- ? expectedDescs.slice(0, -1).join(", ")
- + " or "
- + expectedDescs[expected.length - 1]
- : expectedDescs[0];
- foundDesc = found ? "\"" + stringEscape(found) + "\"" : "end of input";
- return "Expected " + expectedDesc + " but " + foundDesc + " found.";
- }
- if (expected !== null) {
- cleanupExpected(expected);
- }
- return new peg$SyntaxError(
- message !== null ? message : buildMessage(expected, found),
- expected,
- found,
- location
- );
- }
- function peg$parsestart() {
- var s0;
- var key = peg$currPos * 62 + 0,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parsemethod();
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseseparator() {
- var s0, s1;
- var key = peg$currPos * 62 + 1,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = [];
- if (peg$c0.test(input.charAt(peg$currPos))) {
- s1 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c1); }
- }
- if (s1 !== peg$FAILED) {
- while (s1 !== peg$FAILED) {
- s0.push(s1);
- if (peg$c0.test(input.charAt(peg$currPos))) {
- s1 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c1); }
- }
- }
- } else {
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsecomments() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 2,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = [];
- s1 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 34) {
- s2 = peg$c2;
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c3); }
- }
- if (s2 !== peg$FAILED) {
- s3 = [];
- if (peg$c4.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c5); }
- }
- while (s4 !== peg$FAILED) {
- s3.push(s4);
- if (peg$c4.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c5); }
- }
- }
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 34) {
- s4 = peg$c2;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c3); }
- }
- if (s4 !== peg$FAILED) {
- s2 = [s2, s3, s4];
- s1 = s2;
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- while (s1 !== peg$FAILED) {
- s0.push(s1);
- s1 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 34) {
- s2 = peg$c2;
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c3); }
- }
- if (s2 !== peg$FAILED) {
- s3 = [];
- if (peg$c4.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c5); }
- }
- while (s4 !== peg$FAILED) {
- s3.push(s4);
- if (peg$c4.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c5); }
- }
- }
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 34) {
- s4 = peg$c2;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c3); }
- }
- if (s4 !== peg$FAILED) {
- s2 = [s2, s3, s4];
- s1 = s2;
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- }
- } else {
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsews() {
- var s0, s1;
- var key = peg$currPos * 62 + 3,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = [];
- s1 = peg$parseseparator();
- if (s1 === peg$FAILED) {
- s1 = peg$parsecomments();
- }
- while (s1 !== peg$FAILED) {
- s0.push(s1);
- s1 = peg$parseseparator();
- if (s1 === peg$FAILED) {
- s1 = peg$parsecomments();
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsemaybeDotsWs() {
- var s0, s1;
- var key = peg$currPos * 62 + 4,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = [];
- if (input.charCodeAt(peg$currPos) === 46) {
- s1 = peg$c6;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c7); }
- }
- if (s1 === peg$FAILED) {
- s1 = peg$parseseparator();
- if (s1 === peg$FAILED) {
- s1 = peg$parsecomments();
- }
- }
- while (s1 !== peg$FAILED) {
- s0.push(s1);
- if (input.charCodeAt(peg$currPos) === 46) {
- s1 = peg$c6;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c7); }
- }
- if (s1 === peg$FAILED) {
- s1 = peg$parseseparator();
- if (s1 === peg$FAILED) {
- s1 = peg$parsecomments();
- }
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseidentifier() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 5,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- if (peg$c8.test(input.charAt(peg$currPos))) {
- s2 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c9); }
- }
- if (s2 !== peg$FAILED) {
- s3 = [];
- if (peg$c10.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c11); }
- }
- while (s4 !== peg$FAILED) {
- s3.push(s4);
- if (peg$c10.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c11); }
- }
- }
- if (s3 !== peg$FAILED) {
- s2 = [s2, s3];
- s1 = s2;
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- s0 = input.substring(s0, peg$currPos);
- } else {
- s0 = s1;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsekeyword() {
- var s0, s1, s2, s3;
- var key = peg$currPos * 62 + 6,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- s2 = peg$parseidentifier();
- if (s2 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 58) {
- s3 = peg$c12;
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c13); }
- }
- if (s3 !== peg$FAILED) {
- s2 = [s2, s3];
- s1 = s2;
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- s0 = input.substring(s0, peg$currPos);
- } else {
- s0 = s1;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseclassName() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 7,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- if (peg$c14.test(input.charAt(peg$currPos))) {
- s2 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c15); }
- }
- if (s2 !== peg$FAILED) {
- s3 = [];
- if (peg$c10.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c11); }
- }
- while (s4 !== peg$FAILED) {
- s3.push(s4);
- if (peg$c10.test(input.charAt(peg$currPos))) {
- s4 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c11); }
- }
- }
- if (s3 !== peg$FAILED) {
- s2 = [s2, s3];
- s1 = s2;
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- } else {
- peg$currPos = s1;
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- s0 = input.substring(s0, peg$currPos);
- } else {
- s0 = s1;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsestring() {
- var s0, s1;
- var key = peg$currPos * 62 + 8,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parserawString();
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c16(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parserawString() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 9,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 39) {
- s1 = peg$c17;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c18); }
- }
- if (s1 !== peg$FAILED) {
- s2 = [];
- s3 = peg$currPos;
- if (input.substr(peg$currPos, 2) === peg$c19) {
- s4 = peg$c19;
- peg$currPos += 2;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c20); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s3;
- s4 = peg$c21();
- }
- s3 = s4;
- if (s3 === peg$FAILED) {
- if (peg$c22.test(input.charAt(peg$currPos))) {
- s3 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c23); }
- }
- }
- while (s3 !== peg$FAILED) {
- s2.push(s3);
- s3 = peg$currPos;
- if (input.substr(peg$currPos, 2) === peg$c19) {
- s4 = peg$c19;
- peg$currPos += 2;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c20); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s3;
- s4 = peg$c21();
- }
- s3 = s4;
- if (s3 === peg$FAILED) {
- if (peg$c22.test(input.charAt(peg$currPos))) {
- s3 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c23); }
- }
- }
- }
- if (s2 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 39) {
- s3 = peg$c17;
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c18); }
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c24(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsecharacter() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 10,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 36) {
- s1 = peg$c25;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c26); }
- }
- if (s1 !== peg$FAILED) {
- if (input.length > peg$currPos) {
- s2 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c27); }
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c28(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsesymbol() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 11,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 35) {
- s1 = peg$c29;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c30); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsebareSymbol();
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c31(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsebareSymbol() {
- var s0, s1, s2, s3;
- var key = peg$currPos * 62 + 12,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- s2 = [];
- s3 = peg$parsekeyword();
- if (s3 !== peg$FAILED) {
- while (s3 !== peg$FAILED) {
- s2.push(s3);
- s3 = peg$parsekeyword();
- }
- } else {
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- s1 = input.substring(s1, peg$currPos);
- } else {
- s1 = s2;
- }
- if (s1 === peg$FAILED) {
- s1 = peg$parsebinarySelector();
- if (s1 === peg$FAILED) {
- s1 = peg$parseidentifier();
- if (s1 === peg$FAILED) {
- s1 = peg$parserawString();
- }
- }
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c16(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsenumber() {
- var s0, s1;
- var key = peg$currPos * 62 + 13,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parserawNumber();
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c16(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parserawNumber() {
- var s0;
- var key = peg$currPos * 62 + 14,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parsenumberExp();
- if (s0 === peg$FAILED) {
- s0 = peg$parsehex();
- if (s0 === peg$FAILED) {
- s0 = peg$parsefloat();
- if (s0 === peg$FAILED) {
- s0 = peg$parseinteger();
- }
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsenumberExp() {
- var s0, s1, s2, s3, s4, s5;
- var key = peg$currPos * 62 + 15,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- s2 = peg$currPos;
- s3 = peg$parsefloat();
- if (s3 === peg$FAILED) {
- s3 = peg$parseinteger();
- }
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 101) {
- s4 = peg$c32;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c33); }
- }
- if (s4 !== peg$FAILED) {
- s5 = peg$parseinteger();
- if (s5 !== peg$FAILED) {
- s3 = [s3, s4, s5];
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- s1 = input.substring(s1, peg$currPos);
- } else {
- s1 = s2;
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c34(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsehex() {
- var s0, s1, s2, s3, s4, s5;
- var key = peg$currPos * 62 + 16,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 45) {
- s1 = peg$c35;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c36); }
- }
- if (s1 === peg$FAILED) {
- s1 = null;
- }
- if (s1 !== peg$FAILED) {
- if (input.substr(peg$currPos, 3) === peg$c37) {
- s2 = peg$c37;
- peg$currPos += 3;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c38); }
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$currPos;
- s4 = [];
- if (peg$c39.test(input.charAt(peg$currPos))) {
- s5 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c40); }
- }
- if (s5 !== peg$FAILED) {
- while (s5 !== peg$FAILED) {
- s4.push(s5);
- if (peg$c39.test(input.charAt(peg$currPos))) {
- s5 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c40); }
- }
- }
- } else {
- s4 = peg$FAILED;
- }
- if (s4 !== peg$FAILED) {
- s3 = input.substring(s3, peg$currPos);
- } else {
- s3 = s4;
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c41(s1, s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsefloat() {
- var s0, s1, s2, s3, s4, s5, s6, s7;
- var key = peg$currPos * 62 + 17,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- s2 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 45) {
- s3 = peg$c35;
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c36); }
- }
- if (s3 === peg$FAILED) {
- s3 = null;
- }
- if (s3 !== peg$FAILED) {
- s4 = [];
- if (peg$c42.test(input.charAt(peg$currPos))) {
- s5 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c43); }
- }
- if (s5 !== peg$FAILED) {
- while (s5 !== peg$FAILED) {
- s4.push(s5);
- if (peg$c42.test(input.charAt(peg$currPos))) {
- s5 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c43); }
- }
- }
- } else {
- s4 = peg$FAILED;
- }
- if (s4 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 46) {
- s5 = peg$c6;
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c7); }
- }
- if (s5 !== peg$FAILED) {
- s6 = [];
- if (peg$c42.test(input.charAt(peg$currPos))) {
- s7 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s7 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c43); }
- }
- if (s7 !== peg$FAILED) {
- while (s7 !== peg$FAILED) {
- s6.push(s7);
- if (peg$c42.test(input.charAt(peg$currPos))) {
- s7 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s7 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c43); }
- }
- }
- } else {
- s6 = peg$FAILED;
- }
- if (s6 !== peg$FAILED) {
- s3 = [s3, s4, s5, s6];
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- s1 = input.substring(s1, peg$currPos);
- } else {
- s1 = s2;
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c44(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseinteger() {
- var s0, s1, s2, s3, s4, s5;
- var key = peg$currPos * 62 + 18,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- s2 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 45) {
- s3 = peg$c35;
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c36); }
- }
- if (s3 === peg$FAILED) {
- s3 = null;
- }
- if (s3 !== peg$FAILED) {
- s4 = [];
- if (peg$c42.test(input.charAt(peg$currPos))) {
- s5 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c43); }
- }
- if (s5 !== peg$FAILED) {
- while (s5 !== peg$FAILED) {
- s4.push(s5);
- if (peg$c42.test(input.charAt(peg$currPos))) {
- s5 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c43); }
- }
- }
- } else {
- s4 = peg$FAILED;
- }
- if (s4 !== peg$FAILED) {
- s3 = [s3, s4];
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- s1 = input.substring(s1, peg$currPos);
- } else {
- s1 = s2;
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c45(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseliteralArray() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 19,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.substr(peg$currPos, 2) === peg$c46) {
- s1 = peg$c46;
- peg$currPos += 2;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c47); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsewsLiteralArrayContents();
- if (s2 !== peg$FAILED) {
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 41) {
- s4 = peg$c48;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c49); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c50(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsebareLiteralArray() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 20,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 40) {
- s1 = peg$c51;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c52); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsewsLiteralArrayContents();
- if (s2 !== peg$FAILED) {
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 41) {
- s4 = peg$c48;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c49); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c50(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseliteralArrayElement() {
- var s0;
- var key = peg$currPos * 62 + 21,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parseparseTimeLiteral();
- if (s0 === peg$FAILED) {
- s0 = peg$parsebareLiteralArray();
- if (s0 === peg$FAILED) {
- s0 = peg$parsebareSymbol();
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsLiteralArrayContents() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 22,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = [];
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parseliteralArrayElement();
- if (s4 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c53(s4);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- while (s2 !== peg$FAILED) {
- s1.push(s2);
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parseliteralArrayElement();
- if (s4 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c53(s4);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c54(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsedynamicArray() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 23,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 123) {
- s1 = peg$c55;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c56); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsewsExpressions();
- if (s2 === peg$FAILED) {
- s2 = null;
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$parsemaybeDotsWs();
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 125) {
- s4 = peg$c57;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c58); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c59(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsedynamicDictionary() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 24,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.substr(peg$currPos, 2) === peg$c60) {
- s1 = peg$c60;
- peg$currPos += 2;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c61); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsewsAssociations();
- if (s2 === peg$FAILED) {
- s2 = null;
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$parsemaybeDotsWs();
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 125) {
- s4 = peg$c57;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c58); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c62(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsepseudoVariable() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 25,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$currPos;
- if (input.substr(peg$currPos, 4) === peg$c63) {
- s2 = peg$c63;
- peg$currPos += 4;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c64); }
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s1;
- s2 = peg$c65();
- }
- s1 = s2;
- if (s1 === peg$FAILED) {
- s1 = peg$currPos;
- if (input.substr(peg$currPos, 5) === peg$c66) {
- s2 = peg$c66;
- peg$currPos += 5;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c67); }
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s1;
- s2 = peg$c68();
- }
- s1 = s2;
- if (s1 === peg$FAILED) {
- s1 = peg$currPos;
- if (input.substr(peg$currPos, 3) === peg$c69) {
- s2 = peg$c69;
- peg$currPos += 3;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c70); }
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s1;
- s2 = peg$c71();
- }
- s1 = s2;
- }
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c16(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseparseTimeLiteral() {
- var s0;
- var key = peg$currPos * 62 + 26,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parsepseudoVariable();
- if (s0 === peg$FAILED) {
- s0 = peg$parsenumber();
- if (s0 === peg$FAILED) {
- s0 = peg$parseliteralArray();
- if (s0 === peg$FAILED) {
- s0 = peg$parsestring();
- if (s0 === peg$FAILED) {
- s0 = peg$parsesymbol();
- if (s0 === peg$FAILED) {
- s0 = peg$parsecharacter();
- }
- }
- }
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseruntimeLiteral() {
- var s0;
- var key = peg$currPos * 62 + 27,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parsedynamicDictionary();
- if (s0 === peg$FAILED) {
- s0 = peg$parsedynamicArray();
- if (s0 === peg$FAILED) {
- s0 = peg$parseblock();
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseliteral() {
- var s0;
- var key = peg$currPos * 62 + 28,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parseruntimeLiteral();
- if (s0 === peg$FAILED) {
- s0 = peg$parseparseTimeLiteral();
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsevariable() {
- var s0, s1;
- var key = peg$currPos * 62 + 29,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parseidentifier();
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c72(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsebinarySelector() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 30,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = [];
- if (peg$c73.test(input.charAt(peg$currPos))) {
- s2 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c74); }
- }
- if (s2 !== peg$FAILED) {
- while (s2 !== peg$FAILED) {
- s1.push(s2);
- if (peg$c73.test(input.charAt(peg$currPos))) {
- s2 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c74); }
- }
- }
- } else {
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- s0 = input.substring(s0, peg$currPos);
- } else {
- s0 = s1;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsKeywordPattern() {
- var s0, s1, s2, s3, s4, s5, s6;
- var key = peg$currPos * 62 + 31,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = [];
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parsekeyword();
- if (s4 !== peg$FAILED) {
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- s6 = peg$parseidentifier();
- if (s6 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c75(s4, s6);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- while (s2 !== peg$FAILED) {
- s1.push(s2);
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parsekeyword();
- if (s4 !== peg$FAILED) {
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- s6 = peg$parseidentifier();
- if (s6 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c75(s4, s6);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- }
- } else {
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c76(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsBinaryPattern() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 32,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- s2 = peg$parsebinarySelector();
- if (s2 !== peg$FAILED) {
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parseidentifier();
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c77(s2, s4);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsUnaryPattern() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 33,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- s2 = peg$parseidentifier();
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c78(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseexpression() {
- var s0;
- var key = peg$currPos * 62 + 34,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parseassignment();
- if (s0 === peg$FAILED) {
- s0 = peg$parsecascade();
- if (s0 === peg$FAILED) {
- s0 = peg$parsekeywordSend();
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsExpressionsRest() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 35,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 46) {
- s2 = peg$c6;
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c7); }
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$parsemaybeDotsWs();
- if (s3 !== peg$FAILED) {
- s4 = peg$parseexpression();
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c79(s4);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsExpressions() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 36,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsemaybeDotsWs();
- if (s1 !== peg$FAILED) {
- s2 = peg$parseexpression();
- if (s2 !== peg$FAILED) {
- s3 = [];
- s4 = peg$parsewsExpressionsRest();
- while (s4 !== peg$FAILED) {
- s3.push(s4);
- s4 = peg$parsewsExpressionsRest();
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c80(s2, s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseassignment() {
- var s0, s1, s2, s3, s4, s5;
- var key = peg$currPos * 62 + 37,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsevariable();
- if (s1 !== peg$FAILED) {
- s2 = peg$parsews();
- if (s2 !== peg$FAILED) {
- if (input.substr(peg$currPos, 2) === peg$c81) {
- s3 = peg$c81;
- peg$currPos += 2;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c82); }
- }
- if (s3 !== peg$FAILED) {
- s4 = peg$parsews();
- if (s4 !== peg$FAILED) {
- s5 = peg$parseexpression();
- if (s5 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c83(s1, s5);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseret() {
- var s0, s1, s2, s3;
- var key = peg$currPos * 62 + 38,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 94) {
- s1 = peg$c84;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c85); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsews();
- if (s2 !== peg$FAILED) {
- s3 = peg$parseexpression();
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c86(s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsetemps() {
- var s0, s1, s2, s3, s4, s5;
- var key = peg$currPos * 62 + 39,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 124) {
- s1 = peg$c87;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c88); }
- }
- if (s1 !== peg$FAILED) {
- s2 = [];
- s3 = peg$currPos;
- s4 = peg$parsews();
- if (s4 !== peg$FAILED) {
- s5 = peg$parseidentifier();
- if (s5 !== peg$FAILED) {
- peg$savedPos = s3;
- s4 = peg$c89(s5);
- s3 = s4;
- } else {
- peg$currPos = s3;
- s3 = peg$FAILED;
- }
- } else {
- peg$currPos = s3;
- s3 = peg$FAILED;
- }
- while (s3 !== peg$FAILED) {
- s2.push(s3);
- s3 = peg$currPos;
- s4 = peg$parsews();
- if (s4 !== peg$FAILED) {
- s5 = peg$parseidentifier();
- if (s5 !== peg$FAILED) {
- peg$savedPos = s3;
- s4 = peg$c89(s5);
- s3 = s4;
- } else {
- peg$currPos = s3;
- s3 = peg$FAILED;
- }
- } else {
- peg$currPos = s3;
- s3 = peg$FAILED;
- }
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 124) {
- s4 = peg$c87;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c88); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c90(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsBlockParamList() {
- var s0, s1, s2, s3, s4, s5, s6;
- var key = peg$currPos * 62 + 40,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = [];
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 58) {
- s4 = peg$c12;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c13); }
- }
- if (s4 !== peg$FAILED) {
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- s6 = peg$parseidentifier();
- if (s6 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c91(s6);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- while (s2 !== peg$FAILED) {
- s1.push(s2);
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 58) {
- s4 = peg$c12;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c13); }
- }
- if (s4 !== peg$FAILED) {
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- s6 = peg$parseidentifier();
- if (s6 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c91(s6);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- }
- } else {
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsews();
- if (s2 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 124) {
- s3 = peg$c87;
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c88); }
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c92(s1);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsesubexpression() {
- var s0, s1, s2, s3, s4, s5;
- var key = peg$currPos * 62 + 41,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 40) {
- s1 = peg$c51;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c52); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsews();
- if (s2 !== peg$FAILED) {
- s3 = peg$parseexpression();
- if (s3 !== peg$FAILED) {
- s4 = peg$parsews();
- if (s4 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 41) {
- s5 = peg$c48;
- peg$currPos++;
- } else {
- s5 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c49); }
- }
- if (s5 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c79(s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsStatementsWs() {
- var s0, s1, s2, s3, s4, s5, s6;
- var key = peg$currPos * 62 + 42,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsemaybeDotsWs();
- if (s1 !== peg$FAILED) {
- s2 = peg$parseret();
- if (s2 !== peg$FAILED) {
- s3 = peg$parsemaybeDotsWs();
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c93(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- if (s0 === peg$FAILED) {
- s0 = peg$currPos;
- s1 = peg$parsewsExpressions();
- if (s1 !== peg$FAILED) {
- s2 = peg$parsews();
- if (s2 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 46) {
- s3 = peg$c6;
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c7); }
- }
- if (s3 !== peg$FAILED) {
- s4 = peg$parsemaybeDotsWs();
- if (s4 !== peg$FAILED) {
- s5 = peg$parseret();
- if (s5 !== peg$FAILED) {
- s6 = peg$parsemaybeDotsWs();
- if (s6 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c94(s1, s5);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- if (s0 === peg$FAILED) {
- s0 = peg$currPos;
- s1 = peg$parsewsExpressions();
- if (s1 === peg$FAILED) {
- s1 = null;
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsemaybeDotsWs();
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c95(s1);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsSequenceWs() {
- var s0, s1, s2, s3;
- var key = peg$currPos * 62 + 43,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- s2 = peg$parsejsStatement();
- if (s2 !== peg$FAILED) {
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c96(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- if (s0 === peg$FAILED) {
- s0 = peg$parsewsStSequenceWs();
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsStSequenceWs() {
- var s0, s1, s2, s3;
- var key = peg$currPos * 62 + 44,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- s2 = peg$parsetemps();
- if (s2 === peg$FAILED) {
- s2 = null;
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$parsewsStatementsWs();
- if (s3 === peg$FAILED) {
- s3 = null;
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c97(s2, s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseblock() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 45,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 91) {
- s1 = peg$c98;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c99); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsewsBlockParamList();
- if (s2 === peg$FAILED) {
- s2 = null;
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$parsewsSequenceWs();
- if (s3 === peg$FAILED) {
- s3 = null;
- }
- if (s3 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 93) {
- s4 = peg$c100;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c101); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c102(s2, s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseoperand() {
- var s0;
- var key = peg$currPos * 62 + 46,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parseliteral();
- if (s0 === peg$FAILED) {
- s0 = peg$parsevariable();
- if (s0 === peg$FAILED) {
- s0 = peg$parsesubexpression();
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsUnaryMessage() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 47,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- s2 = peg$parseidentifier();
- if (s2 !== peg$FAILED) {
- s3 = peg$currPos;
- peg$silentFails++;
- if (input.charCodeAt(peg$currPos) === 58) {
- s4 = peg$c12;
- peg$currPos++;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c13); }
- }
- peg$silentFails--;
- if (s4 === peg$FAILED) {
- s3 = void 0;
- } else {
- peg$currPos = s3;
- s3 = peg$FAILED;
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c103(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseunarySend() {
- var s0, s1, s2, s3;
- var key = peg$currPos * 62 + 48,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parseoperand();
- if (s1 !== peg$FAILED) {
- s2 = [];
- s3 = peg$parsewsUnaryMessage();
- while (s3 !== peg$FAILED) {
- s2.push(s3);
- s3 = peg$parsewsUnaryMessage();
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c104(s1, s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsBinaryMessage() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 49,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- s2 = peg$parsebinarySelector();
- if (s2 !== peg$FAILED) {
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parseunarySend();
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c105(s2, s4);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsebinarySend() {
- var s0, s1, s2, s3;
- var key = peg$currPos * 62 + 50,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parseunarySend();
- if (s1 !== peg$FAILED) {
- s2 = [];
- s3 = peg$parsewsBinaryMessage();
- while (s3 !== peg$FAILED) {
- s2.push(s3);
- s3 = peg$parsewsBinaryMessage();
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c104(s1, s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsKeywordMessage() {
- var s0, s1, s2, s3, s4, s5, s6;
- var key = peg$currPos * 62 + 51,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = [];
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parsekeyword();
- if (s4 !== peg$FAILED) {
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- s6 = peg$parsebinarySend();
- if (s6 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c75(s4, s6);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- while (s2 !== peg$FAILED) {
- s1.push(s2);
- s2 = peg$currPos;
- s3 = peg$parsews();
- if (s3 !== peg$FAILED) {
- s4 = peg$parsekeyword();
- if (s4 !== peg$FAILED) {
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- s6 = peg$parsebinarySend();
- if (s6 !== peg$FAILED) {
- peg$savedPos = s2;
- s3 = peg$c75(s4, s6);
- s2 = s3;
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- } else {
- peg$currPos = s2;
- s2 = peg$FAILED;
- }
- }
- } else {
- s1 = peg$FAILED;
- }
- if (s1 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c106(s1);
- }
- s0 = s1;
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsekeywordSend() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 52,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsebinarySend();
- if (s1 !== peg$FAILED) {
- s2 = peg$parsewsKeywordMessage();
- if (s2 === peg$FAILED) {
- s2 = null;
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c107(s1, s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsMessage() {
- var s0;
- var key = peg$currPos * 62 + 53,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parsewsBinaryMessage();
- if (s0 === peg$FAILED) {
- s0 = peg$parsewsUnaryMessage();
- if (s0 === peg$FAILED) {
- s0 = peg$parsewsKeywordMessage();
- }
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsecascade() {
- var s0, s1, s2, s3, s4, s5, s6, s7;
- var key = peg$currPos * 62 + 54,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsekeywordSend();
- if (s1 !== peg$FAILED) {
- peg$savedPos = peg$currPos;
- s2 = peg$c108(s1);
- if (s2) {
- s2 = void 0;
- } else {
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- s3 = [];
- s4 = peg$currPos;
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 59) {
- s6 = peg$c109;
- peg$currPos++;
- } else {
- s6 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c110); }
- }
- if (s6 !== peg$FAILED) {
- s7 = peg$parsewsMessage();
- if (s7 !== peg$FAILED) {
- peg$savedPos = s4;
- s5 = peg$c111(s1, s7);
- s4 = s5;
- } else {
- peg$currPos = s4;
- s4 = peg$FAILED;
- }
- } else {
- peg$currPos = s4;
- s4 = peg$FAILED;
- }
- } else {
- peg$currPos = s4;
- s4 = peg$FAILED;
- }
- if (s4 !== peg$FAILED) {
- while (s4 !== peg$FAILED) {
- s3.push(s4);
- s4 = peg$currPos;
- s5 = peg$parsews();
- if (s5 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 59) {
- s6 = peg$c109;
- peg$currPos++;
- } else {
- s6 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c110); }
- }
- if (s6 !== peg$FAILED) {
- s7 = peg$parsewsMessage();
- if (s7 !== peg$FAILED) {
- peg$savedPos = s4;
- s5 = peg$c111(s1, s7);
- s4 = s5;
- } else {
- peg$currPos = s4;
- s4 = peg$FAILED;
- }
- } else {
- peg$currPos = s4;
- s4 = peg$FAILED;
- }
- } else {
- peg$currPos = s4;
- s4 = peg$FAILED;
- }
- }
- } else {
- s3 = peg$FAILED;
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c112(s1, s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsejsStatement() {
- var s0;
- var key = peg$currPos * 62 + 55,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$parsepragmaJsStatement();
- if (s0 === peg$FAILED) {
- s0 = peg$parselegacyJsStatement();
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parselegacyJsStatement() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 56,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 60) {
- s1 = peg$c113;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c114); }
- }
- if (s1 !== peg$FAILED) {
- s2 = [];
- s3 = peg$currPos;
- if (input.substr(peg$currPos, 2) === peg$c115) {
- s4 = peg$c115;
- peg$currPos += 2;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c116); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s3;
- s4 = peg$c117();
- }
- s3 = s4;
- if (s3 === peg$FAILED) {
- if (peg$c118.test(input.charAt(peg$currPos))) {
- s3 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c119); }
- }
- }
- while (s3 !== peg$FAILED) {
- s2.push(s3);
- s3 = peg$currPos;
- if (input.substr(peg$currPos, 2) === peg$c115) {
- s4 = peg$c115;
- peg$currPos += 2;
- } else {
- s4 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c116); }
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s3;
- s4 = peg$c117();
- }
- s3 = s4;
- if (s3 === peg$FAILED) {
- if (peg$c118.test(input.charAt(peg$currPos))) {
- s3 = input.charAt(peg$currPos);
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c119); }
- }
- }
- }
- if (s2 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 62) {
- s3 = peg$c120;
- peg$currPos++;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c121); }
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = peg$currPos;
- s4 = peg$c122(s2);
- if (s4) {
- s4 = void 0;
- } else {
- s4 = peg$FAILED;
- }
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c123(s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsepragmaJsStatement() {
- var s0, s1, s2, s3, s4, s5, s6, s7;
- var key = peg$currPos * 62 + 57,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- if (input.charCodeAt(peg$currPos) === 60) {
- s1 = peg$c113;
- peg$currPos++;
- } else {
- s1 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c114); }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsews();
- if (s2 !== peg$FAILED) {
- if (input.substr(peg$currPos, 9) === peg$c124) {
- s3 = peg$c124;
- peg$currPos += 9;
- } else {
- s3 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c125); }
- }
- if (s3 !== peg$FAILED) {
- s4 = peg$parsews();
- if (s4 !== peg$FAILED) {
- s5 = peg$parserawString();
- if (s5 !== peg$FAILED) {
- s6 = peg$parsews();
- if (s6 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 62) {
- s7 = peg$c120;
- peg$currPos++;
- } else {
- s7 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c121); }
- }
- if (s7 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c126(s5);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsemethod() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 58,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsewsKeywordPattern();
- if (s1 === peg$FAILED) {
- s1 = peg$parsewsBinaryPattern();
- if (s1 === peg$FAILED) {
- s1 = peg$parsewsUnaryPattern();
- }
- }
- if (s1 !== peg$FAILED) {
- s2 = peg$parsewsSequenceWs();
- if (s2 === peg$FAILED) {
- s2 = null;
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c127(s1, s2);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parseassociationSend() {
- var s0, s1, s2;
- var key = peg$currPos * 62 + 59,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsebinarySend();
- if (s1 !== peg$FAILED) {
- peg$savedPos = peg$currPos;
- s2 = peg$c128(s1);
- if (s2) {
- s2 = void 0;
- } else {
- s2 = peg$FAILED;
- }
- if (s2 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c129(s1);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsAssociationsRest() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 60,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsews();
- if (s1 !== peg$FAILED) {
- if (input.charCodeAt(peg$currPos) === 46) {
- s2 = peg$c6;
- peg$currPos++;
- } else {
- s2 = peg$FAILED;
- if (peg$silentFails === 0) { peg$fail(peg$c7); }
- }
- if (s2 !== peg$FAILED) {
- s3 = peg$parsemaybeDotsWs();
- if (s3 !== peg$FAILED) {
- s4 = peg$parseassociationSend();
- if (s4 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c79(s4);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- function peg$parsewsAssociations() {
- var s0, s1, s2, s3, s4;
- var key = peg$currPos * 62 + 61,
- cached = peg$resultsCache[key];
- if (cached) {
- peg$currPos = cached.nextPos;
- return cached.result;
- }
- s0 = peg$currPos;
- s1 = peg$parsemaybeDotsWs();
- if (s1 !== peg$FAILED) {
- s2 = peg$parseassociationSend();
- if (s2 !== peg$FAILED) {
- s3 = [];
- s4 = peg$parsewsAssociationsRest();
- while (s4 !== peg$FAILED) {
- s3.push(s4);
- s4 = peg$parsewsAssociationsRest();
- }
- if (s3 !== peg$FAILED) {
- peg$savedPos = s0;
- s1 = peg$c130(s2, s3);
- s0 = s1;
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- } else {
- peg$currPos = s0;
- s0 = peg$FAILED;
- }
- peg$resultsCache[key] = { nextPos: peg$currPos, result: s0 };
- return s0;
- }
- peg$result = peg$startRuleFunction();
- if (peg$result !== peg$FAILED && peg$currPos === input.length) {
- return peg$result;
- } else {
- if (peg$result !== peg$FAILED && peg$currPos < input.length) {
- peg$fail({ type: "end", description: "end of input" });
- }
- throw peg$buildException(
- null,
- peg$maxFailExpected,
- peg$maxFailPos < input.length ? input.charAt(peg$maxFailPos) : null,
- peg$maxFailPos < input.length
- ? peg$computeLocation(peg$maxFailPos, peg$maxFailPos + 1)
- : peg$computeLocation(peg$maxFailPos, peg$maxFailPos)
- );
- }
- }
- return {
- SyntaxError: peg$SyntaxError,
- parse: peg$parse
- };
- })();
- });
- define('amber_core/Platform-ImportExport',["amber/boot", "amber_core/Kernel-Classes", "amber_core/Kernel-Exceptions", "amber_core/Kernel-Infrastructure", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Platform-ImportExport");
- $core.packages["Platform-ImportExport"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Platform-ImportExport"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("AbstractExporter", $globals.Object, [], "Platform-ImportExport");
- $globals.AbstractExporter.comment="I am an abstract exporter for Amber source code.\x0a\x0a## API\x0a\x0aUse `#exportPackage:on:` to export a given package on a Stream.";
- $core.addMethod(
- $core.method({
- selector: "exportPackage:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackage:on:",{aPackage:aPackage,aStream:aStream},$globals.AbstractExporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackage: aPackage on: aStream\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AbstractExporter);
- $core.addMethod(
- $core.method({
- selector: "extensionMethodsOfPackage:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- result=$recv($globals.OrderedCollection)._new();
- $recv(self._extensionProtocolsOfPackage_(aPackage))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(result)._addAll_($recv(each)._ownMethods());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return result;
- }, function($ctx1) {$ctx1.fill(self,"extensionMethodsOfPackage:",{aPackage:aPackage,result:result},$globals.AbstractExporter)});
- },
- args: ["aPackage"],
- source: "extensionMethodsOfPackage: aPackage\x0a\x09| result |\x0a\x09\x0a\x09result := OrderedCollection new.\x0a\x09\x0a\x09(self extensionProtocolsOfPackage: aPackage) do: [ :each |\x0a\x09\x09result addAll: each ownMethods ].\x0a\x09\x09\x0a\x09^ result",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["new", "do:", "extensionProtocolsOfPackage:", "addAll:", "ownMethods"]
- }),
- $globals.AbstractExporter);
- $core.addMethod(
- $core.method({
- selector: "extensionProtocolsOfPackage:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- var extensionName,result;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- $1=$recv(aPackage)._name();
- $ctx1.sendIdx["name"]=1;
- extensionName="*".__comma($1);
- result=$recv($globals.OrderedCollection)._new();
- $recv($recv($recv($recv($globals.Smalltalk)._classes())._asArray())._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $2=$recv(a)._name();
- $ctx2.sendIdx["name"]=2;
- return $recv($2).__lt($recv(b)._name());
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,1)});
- })))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv([each,$recv(each)._theMetaClass()])._copyWithout_(nil))._do_((function(behavior){
- return $core.withContext(function($ctx3) {
- $3=$recv($recv(behavior)._protocols())._includes_(extensionName);
- if($core.assert($3)){
- return $recv(result)._add_($recv($globals.ExportMethodProtocol)._name_theClass_(extensionName,behavior));
- }
- }, function($ctx3) {$ctx3.fillBlock({behavior:behavior},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- $ctx1.sendIdx["do:"]=1;
- return result;
- }, function($ctx1) {$ctx1.fill(self,"extensionProtocolsOfPackage:",{aPackage:aPackage,extensionName:extensionName,result:result},$globals.AbstractExporter)});
- },
- args: ["aPackage"],
- source: "extensionProtocolsOfPackage: aPackage\x0a\x09| extensionName result |\x0a\x09\x0a\x09extensionName := '*', aPackage name.\x0a\x09result := OrderedCollection new.\x0a\x09\x0a\x09\x22The classes must be loaded since it is extensions only.\x0a\x09Therefore topological sorting (dependency resolution) does not matter here.\x0a\x09Not sorting topologically improves the speed by a number of magnitude.\x0a\x09\x0a\x09Not to shuffle diffs, classes are sorted by their name.\x22\x0a\x09\x0a\x09(Smalltalk classes asArray sorted: [ :a :b | a name < b name ]) do: [ :each |\x0a\x09\x09({each. each theMetaClass} copyWithout: nil) do: [ :behavior |\x0a\x09\x09\x09(behavior protocols includes: extensionName) ifTrue: [\x0a\x09\x09\x09\x09result add: (ExportMethodProtocol name: extensionName theClass: behavior) ] ] ].\x0a\x0a\x09^ result",
- referencedClasses: ["OrderedCollection", "Smalltalk", "ExportMethodProtocol"],
- messageSends: [",", "name", "new", "do:", "sorted:", "asArray", "classes", "<", "copyWithout:", "theMetaClass", "ifTrue:", "includes:", "protocols", "add:", "name:theClass:"]
- }),
- $globals.AbstractExporter);
- $core.addClass("ChunkExporter", $globals.AbstractExporter, [], "Platform-ImportExport");
- $globals.ChunkExporter.comment="I am an exporter dedicated to outputting Amber source code in the classic Smalltalk chunk format.\x0a\x0aI do not output any compiled code.";
- $core.addMethod(
- $core.method({
- selector: "chunkEscape:",
- protocol: "convenience",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(aString)._replace_with_("!","!!"))._trimBoth();
- }, function($ctx1) {$ctx1.fill(self,"chunkEscape:",{aString:aString},$globals.ChunkExporter)});
- },
- args: ["aString"],
- source: "chunkEscape: aString\x0a\x09\x22Replace all occurrences of ! with !! and trim at both ends.\x22\x0a\x0a\x09^ (aString replace: '!' with: '!!') trimBoth",
- referencedClasses: [],
- messageSends: ["trimBoth", "replace:with:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportBehavior:on:",
- protocol: "output",
- fn: function (aBehavior,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aBehavior)._exportBehaviorDefinitionTo_using_(aStream,self);
- self._exportProtocols_on_(self._ownMethodProtocolsOfClass_(aBehavior),aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportBehavior:on:",{aBehavior:aBehavior,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aBehavior", "aStream"],
- source: "exportBehavior: aBehavior on: aStream\x0a\x09aBehavior exportBehaviorDefinitionTo: aStream using: self.\x0a\x09self \x0a\x09\x09exportProtocols: (self ownMethodProtocolsOfClass: aBehavior)\x0a\x09\x09on: aStream",
- referencedClasses: [],
- messageSends: ["exportBehaviorDefinitionTo:using:", "exportProtocols:on:", "ownMethodProtocolsOfClass:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportCategoryEpilogueOf:on:",
- protocol: "output",
- fn: function (aCategory,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_(" !");
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportCategoryEpilogueOf:on:",{aCategory:aCategory,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aCategory", "aStream"],
- source: "exportCategoryEpilogueOf: aCategory on: aStream\x0a\x09aStream write: ' !'; lf; lf",
- referencedClasses: [],
- messageSends: ["write:", "lf"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportCategoryPrologueOf:on:",
- protocol: "output",
- fn: function (aCategory,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_("!");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._print_($recv(aCategory)._theClass());
- $ctx1.sendIdx["print:"]=1;
- $recv(aStream)._write_(" methodsFor: ");
- $ctx1.sendIdx["write:"]=2;
- $recv(aStream)._print_(aCategory);
- $recv(aStream)._write_("!");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportCategoryPrologueOf:on:",{aCategory:aCategory,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aCategory", "aStream"],
- source: "exportCategoryPrologueOf: aCategory on: aStream\x0a\x09aStream\x0a\x09\x09write: '!';\x0a\x09\x09print: aCategory theClass;\x0a\x09\x09write: ' methodsFor: ';\x0a\x09\x09print: aCategory;\x0a\x09\x09write: '!'",
- referencedClasses: [],
- messageSends: ["write:", "print:", "theClass"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportDefinitionOf:on:",
- protocol: "output",
- fn: function (aClass,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- $recv(aStream)._print_($recv(aClass)._superclass());
- $ctx1.sendIdx["print:"]=1;
- $recv(aStream)._write_(" subclass: ");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._printSymbol_($recv(aClass)._name());
- $1=$recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._tab();
- $ctx1.sendIdx["tab"]=1;
- $recv(aStream)._write_("instanceVariableNames: ");
- $ctx1.sendIdx["write:"]=2;
- $recv(aStream)._print_(" "._join_($recv(aClass)._instanceVariableNames()));
- $ctx1.sendIdx["print:"]=2;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=2;
- $recv(aStream)._tab();
- $recv(aStream)._write_("package: ");
- $ctx1.sendIdx["write:"]=3;
- $recv(aStream)._print_($recv(aClass)._category());
- $ctx1.sendIdx["print:"]=3;
- $recv(aStream)._write_("!");
- $ctx1.sendIdx["write:"]=4;
- $2=$recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=3;
- $3=$recv(aClass)._comment();
- $ctx1.sendIdx["comment"]=1;
- $recv($3)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aStream)._write_("!");
- $ctx2.sendIdx["write:"]=5;
- $recv(aStream)._print_(aClass);
- $recv(aStream)._write_(" commentStamp!");
- $ctx2.sendIdx["write:"]=6;
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=4;
- $recv(aStream)._write_([self._chunkEscape_($recv(aClass)._comment()),"!"]);
- $4=$recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=5;
- return $4;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportDefinitionOf:on:",{aClass:aClass,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aClass", "aStream"],
- source: "exportDefinitionOf: aClass on: aStream\x0a\x09\x22Chunk format.\x22\x0a\x0a\x09aStream\x0a\x09\x09print: aClass superclass;\x0a\x09\x09write: ' subclass: ';\x0a\x09\x09printSymbol: aClass name;\x0a\x09\x09lf.\x0a\x09\x22aClass traitComposition\x0a\x09\x09ifNotEmpty: [ aStream tab; write: {'uses: '. aClass traitCompositionDefinition}; lf ].\x22\x0a\x09aStream\x0a\x09\x09tab;\x0a\x09\x09write: 'instanceVariableNames: ';\x0a\x09\x09print: (' ' join: aClass instanceVariableNames);\x0a\x09\x09lf;\x0a\x09\x09tab;\x0a\x09\x09write: 'package: ';\x0a\x09\x09print: aClass category;\x0a\x09\x09write: '!';\x0a\x09\x09lf.\x0a\x09aClass comment ifNotEmpty: [ aStream\x0a\x09\x09write: '!'; print: aClass; write: ' commentStamp!'; lf;\x0a\x09\x09write: { self chunkEscape: aClass comment. '!' }; lf ].\x0a\x09aStream lf",
- referencedClasses: [],
- messageSends: ["print:", "superclass", "write:", "printSymbol:", "name", "lf", "tab", "join:", "instanceVariableNames", "category", "ifNotEmpty:", "comment", "chunkEscape:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportMetaDefinitionOf:on:",
- protocol: "output",
- fn: function (aClass,aStream){
- var self=this;
- var classIvars,classTraitComposition;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv(aClass)._class();
- $ctx1.sendIdx["class"]=1;
- classIvars=$recv($1)._instanceVariableNames();
- classTraitComposition=$recv($recv(aClass)._class())._traitComposition();
- $2=$recv(classIvars)._notEmpty();
- if($core.assert($2)){
- $recv(aStream)._print_($recv(aClass)._theMetaClass());
- $ctx1.sendIdx["print:"]=1;
- $recv(aStream)._space();
- $recv(aStream)._write_("instanceVariableNames: ");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._print_(" "._join_(classIvars));
- $recv(aStream)._write_("!");
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._lf();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportMetaDefinitionOf:on:",{aClass:aClass,aStream:aStream,classIvars:classIvars,classTraitComposition:classTraitComposition},$globals.ChunkExporter)});
- },
- args: ["aClass", "aStream"],
- source: "exportMetaDefinitionOf: aClass on: aStream\x0a\x0a\x09| classIvars classTraitComposition |\x0a\x09classIvars := aClass class instanceVariableNames.\x0a\x09classTraitComposition := aClass class traitComposition.\x0a\x0a\x09(classIvars notEmpty \x22or: [classTraitComposition notEmpty]\x22) ifTrue: [\x0a\x09\x09aStream\x0a\x09\x09\x09print: aClass theMetaClass.\x0a\x09\x09aStream space. \x22classTraitComposition\x0a\x09\x09\x09ifEmpty: [ aStream space ]\x0a\x09\x09\x09ifNotEmpty: [ aStream lf; tab; write: {'uses: '. aClass class traitCompositionDefinition}; lf; tab ].\x22\x0a\x09\x09aStream\x0a\x09\x09\x09write: 'instanceVariableNames: ';\x0a\x09\x09\x09print: (' ' join: classIvars);\x0a\x09\x09\x09write: '!'; lf; lf ]",
- referencedClasses: [],
- messageSends: ["instanceVariableNames", "class", "traitComposition", "ifTrue:", "notEmpty", "print:", "theMetaClass", "space", "write:", "join:", "lf"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportMethod:on:",
- protocol: "output",
- fn: function (aMethod,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=2;
- $recv(aStream)._write_(self._chunkEscape_($recv(aMethod)._source()));
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._lf();
- $recv(aStream)._write_("!");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportMethod:on:",{aMethod:aMethod,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aMethod", "aStream"],
- source: "exportMethod: aMethod on: aStream\x0a\x09aStream\x0a\x09\x09lf; lf; write: (self chunkEscape: aMethod source); lf;\x0a\x09\x09write: '!'",
- referencedClasses: [],
- messageSends: ["lf", "write:", "chunkEscape:", "source"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackage:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- self._exportPackageDefinitionOf_on_(aPackage,aStream);
- self._exportPackageImportsOf_on_(aPackage,aStream);
- $recv($recv(aPackage)._sortedClasses())._do_((function(each){
- return $core.withContext(function($ctx2) {
- self._exportBehavior_on_(each,aStream);
- $ctx2.sendIdx["exportBehavior:on:"]=1;
- $1=$recv(each)._theMetaClass();
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- var meta;
- meta=$receiver;
- return self._exportBehavior_on_(meta,aStream);
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._exportPackageTraitCompositionsOf_on_(aPackage,aStream);
- self._exportProtocols_on_(self._extensionProtocolsOfPackage_(aPackage),aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackage:on:",{aPackage:aPackage,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackage: aPackage on: aStream\x0a\x0a\x09self\x0a\x09\x09exportPackageDefinitionOf: aPackage on: aStream;\x0a\x09\x09exportPackageImportsOf: aPackage on: aStream.\x0a\x09\x0a\x09aPackage sortedClasses do: [ :each |\x0a\x09\x09self exportBehavior: each on: aStream.\x0a\x09\x09each theMetaClass ifNotNil: [ :meta | self exportBehavior: meta on: aStream ] ].\x0a\x09\x0a\x09self exportPackageTraitCompositionsOf: aPackage on: aStream.\x0a\x0a\x09self \x0a\x09\x09exportProtocols: (self extensionProtocolsOfPackage: aPackage)\x0a\x09\x09on: aStream",
- referencedClasses: [],
- messageSends: ["exportPackageDefinitionOf:on:", "exportPackageImportsOf:on:", "do:", "sortedClasses", "exportBehavior:on:", "ifNotNil:", "theMetaClass", "exportPackageTraitCompositionsOf:on:", "exportProtocols:on:", "extensionProtocolsOfPackage:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageDefinitionOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_("Smalltalk createPackage: ");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._print_($recv(aPackage)._name());
- $recv(aStream)._write_("!");
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageDefinitionOf:on:",{aPackage:aPackage,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageDefinitionOf: aPackage on: aStream\x0a\x09aStream\x0a\x09\x09write: 'Smalltalk createPackage: ';\x0a\x09\x09print: aPackage name;\x0a\x09\x09write: '!';\x0a\x09\x09lf",
- referencedClasses: [],
- messageSends: ["write:", "print:", "name", "lf"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageImportsOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aPackage)._imports())._ifNotEmpty_((function(imports){
- return $core.withContext(function($ctx2) {
- $recv(aStream)._write_("(Smalltalk packageAt: ");
- $ctx2.sendIdx["write:"]=1;
- $recv(aStream)._print_($recv(aPackage)._name());
- $recv(aStream)._write_([") imports: ",self._chunkEscape_($recv(aPackage)._importsDefinition()),"!"]);
- return $recv(aStream)._lf();
- }, function($ctx2) {$ctx2.fillBlock({imports:imports},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageImportsOf:on:",{aPackage:aPackage,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageImportsOf: aPackage on: aStream\x0a\x09aPackage imports ifNotEmpty: [ :imports | aStream\x0a\x09\x09write: '(Smalltalk packageAt: ';\x0a\x09\x09print: aPackage name;\x0a\x09\x09write: { ') imports: '. self chunkEscape: aPackage importsDefinition. '!' };\x0a\x09\x09lf ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "imports", "write:", "print:", "name", "chunkEscape:", "importsDefinition", "lf"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageTraitCompositionsOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aPackage)._traitCompositions())._ifNotEmpty_((function(traitCompositions){
- return $core.withContext(function($ctx2) {
- $recv(traitCompositions)._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx3) {
- return self._exportTraitComposition_of_on_(value,key,aStream);
- }, function($ctx3) {$ctx3.fillBlock({key:key,value:value},$ctx2,2)});
- }));
- $recv(aStream)._write_("! !");
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=1;
- return $recv(aStream)._lf();
- }, function($ctx2) {$ctx2.fillBlock({traitCompositions:traitCompositions},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageTraitCompositionsOf:on:",{aPackage:aPackage,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageTraitCompositionsOf: aPackage on: aStream\x0a\x09aPackage traitCompositions ifNotEmpty: [ :traitCompositions |\x0a\x09\x09traitCompositions keysAndValuesDo: [ :key :value | self exportTraitComposition: value of: key on: aStream ].\x0a\x09\x09aStream write: '! !'; lf; lf ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "traitCompositions", "keysAndValuesDo:", "exportTraitComposition:of:on:", "write:", "lf"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportProtocol:on:",
- protocol: "output",
- fn: function (aProtocol,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aProtocol)._ownMethods())._ifNotEmpty_((function(methods){
- return $core.withContext(function($ctx2) {
- self._exportProtocolPrologueOf_on_(aProtocol,aStream);
- $recv(methods)._do_((function(method){
- return $core.withContext(function($ctx3) {
- return self._exportMethod_on_(method,aStream);
- }, function($ctx3) {$ctx3.fillBlock({method:method},$ctx2,2)});
- }));
- return self._exportProtocolEpilogueOf_on_(aProtocol,aStream);
- }, function($ctx2) {$ctx2.fillBlock({methods:methods},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportProtocol:on:",{aProtocol:aProtocol,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aProtocol", "aStream"],
- source: "exportProtocol: aProtocol on: aStream\x0a\x09aProtocol ownMethods ifNotEmpty: [ :methods |\x0a\x09\x09self exportProtocolPrologueOf: aProtocol on: aStream.\x0a\x09\x09methods do: [ :method | \x0a\x09\x09\x09self exportMethod: method on: aStream ].\x0a\x09\x09self exportProtocolEpilogueOf: aProtocol on: aStream ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "ownMethods", "exportProtocolPrologueOf:on:", "do:", "exportMethod:on:", "exportProtocolEpilogueOf:on:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportProtocolEpilogueOf:on:",
- protocol: "output",
- fn: function (aProtocol,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_(" !");
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportProtocolEpilogueOf:on:",{aProtocol:aProtocol,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aProtocol", "aStream"],
- source: "exportProtocolEpilogueOf: aProtocol on: aStream\x0a\x09aStream write: ' !'; lf; lf",
- referencedClasses: [],
- messageSends: ["write:", "lf"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportProtocolPrologueOf:on:",
- protocol: "output",
- fn: function (aProtocol,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_("!");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._print_($recv(aProtocol)._theClass());
- $ctx1.sendIdx["print:"]=1;
- $recv(aStream)._write_(" methodsFor: ");
- $ctx1.sendIdx["write:"]=2;
- $recv(aStream)._print_($recv(aProtocol)._name());
- $recv(aStream)._write_("!");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportProtocolPrologueOf:on:",{aProtocol:aProtocol,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aProtocol", "aStream"],
- source: "exportProtocolPrologueOf: aProtocol on: aStream\x0a\x09aStream\x0a\x09\x09write: '!';\x0a\x09\x09print: aProtocol theClass;\x0a\x09\x09write: ' methodsFor: ';\x0a\x09\x09print: aProtocol name;\x0a\x09\x09write: '!'",
- referencedClasses: [],
- messageSends: ["write:", "print:", "theClass", "name"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportProtocols:on:",
- protocol: "output",
- fn: function (aCollection,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._exportProtocol_on_(each,aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportProtocols:on:",{aCollection:aCollection,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aCollection", "aStream"],
- source: "exportProtocols: aCollection on: aStream\x0a\x09aCollection do: [ :each |\x0a\x09\x09self exportProtocol: each on: aStream ]",
- referencedClasses: [],
- messageSends: ["do:", "exportProtocol:on:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportTraitComposition:of:on:",
- protocol: "output",
- fn: function (aTraitComposition,aBehavior,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._print_(aBehavior);
- $recv(aStream)._write_(" setTraitComposition: ");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._write_($recv(aBehavior)._traitCompositionDefinition());
- $ctx1.sendIdx["write:"]=2;
- $recv(aStream)._write_(" asTraitComposition!");
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportTraitComposition:of:on:",{aTraitComposition:aTraitComposition,aBehavior:aBehavior,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aTraitComposition", "aBehavior", "aStream"],
- source: "exportTraitComposition: aTraitComposition of: aBehavior on: aStream\x0a\x09aStream \x0a\x09\x09print: aBehavior;\x0a\x09\x09write: ' setTraitComposition: ';\x0a\x09\x09write: aBehavior traitCompositionDefinition;\x0a\x09\x09write: ' asTraitComposition!';\x0a\x09\x09lf",
- referencedClasses: [],
- messageSends: ["print:", "write:", "traitCompositionDefinition", "lf"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "exportTraitDefinitionOf:on:",
- protocol: "output",
- fn: function (aClass,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- $recv(aStream)._write_("Trait named: ");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._printSymbol_($recv(aClass)._name());
- $1=$recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._tab();
- $recv(aStream)._write_("package: ");
- $ctx1.sendIdx["write:"]=2;
- $recv(aStream)._print_($recv(aClass)._category());
- $ctx1.sendIdx["print:"]=1;
- $recv(aStream)._write_("!");
- $ctx1.sendIdx["write:"]=3;
- $2=$recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=2;
- $3=$recv(aClass)._comment();
- $ctx1.sendIdx["comment"]=1;
- $recv($3)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aStream)._write_("!");
- $ctx2.sendIdx["write:"]=4;
- $recv(aStream)._print_(aClass);
- $recv(aStream)._write_(" commentStamp!");
- $ctx2.sendIdx["write:"]=5;
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=3;
- $recv(aStream)._write_([self._chunkEscape_($recv(aClass)._comment()),"!"]);
- $4=$recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=4;
- return $4;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportTraitDefinitionOf:on:",{aClass:aClass,aStream:aStream},$globals.ChunkExporter)});
- },
- args: ["aClass", "aStream"],
- source: "exportTraitDefinitionOf: aClass on: aStream\x0a\x09\x22Chunk format.\x22\x0a\x0a\x09aStream\x0a\x09\x09write: 'Trait named: '; printSymbol: aClass name; lf.\x0a\x09\x22aClass traitComposition\x0a\x09\x09ifNotEmpty: [ aStream tab; write: {'uses: '. aClass traitCompositionDefinition}; lf ].\x22\x0a\x09aStream\x0a\x09\x09tab; write: 'package: '; print:\x09aClass category; write: '!'; lf.\x0a\x09aClass comment ifNotEmpty: [\x0a\x09\x09aStream\x0a\x09\x09write: '!'; print: aClass; write: ' commentStamp!'; lf;\x0a\x09\x09write: { self chunkEscape: aClass comment. '!' }; lf ].\x0a\x09aStream lf",
- referencedClasses: [],
- messageSends: ["write:", "printSymbol:", "name", "lf", "tab", "print:", "category", "ifNotEmpty:", "comment", "chunkEscape:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "extensionCategoriesOfPackage:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- var name,map,result;
- return $core.withContext(function($ctx1) {
- var $1;
- name=$recv(aPackage)._name();
- result=$recv($globals.OrderedCollection)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($recv($globals.Package)._sortedClasses_($recv($globals.Smalltalk)._classes()))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv([each,$recv(each)._theMetaClass()])._do_((function(aClass){
- return $core.withContext(function($ctx3) {
- map=$recv($globals.Dictionary)._new();
- map;
- $recv(aClass)._protocolsDo_((function(category,methods){
- return $core.withContext(function($ctx4) {
- $1=$recv(category).__eq("*".__comma(name));
- if($core.assert($1)){
- return $recv(map)._at_put_(category,methods);
- }
- }, function($ctx4) {$ctx4.fillBlock({category:category,methods:methods},$ctx3,3)});
- }));
- return $recv(result)._addAll_($recv($recv($recv(map)._keys())._sorted_((function(a,b){
- return $core.withContext(function($ctx4) {
- return $recv(a).__lt_eq(b);
- }, function($ctx4) {$ctx4.fillBlock({a:a,b:b},$ctx3,5)});
- })))._collect_((function(category){
- return $core.withContext(function($ctx4) {
- return $recv($globals.MethodCategory)._name_theClass_methods_(category,aClass,$recv(map)._at_(category));
- }, function($ctx4) {$ctx4.fillBlock({category:category},$ctx3,6)});
- })));
- }, function($ctx3) {$ctx3.fillBlock({aClass:aClass},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- return result;
- }, function($ctx1) {$ctx1.fill(self,"extensionCategoriesOfPackage:",{aPackage:aPackage,name:name,map:map,result:result},$globals.ChunkExporter)});
- },
- args: ["aPackage"],
- source: "extensionCategoriesOfPackage: aPackage\x0a\x09\x22Issue #143: sort protocol alphabetically\x22\x0a\x0a\x09| name map result |\x0a\x09name := aPackage name.\x0a\x09result := OrderedCollection new.\x0a\x09(Package sortedClasses: Smalltalk classes) do: [ :each |\x0a\x09\x09{each. each theMetaClass} do: [ :aClass |\x0a\x09\x09\x09map := Dictionary new.\x0a\x09\x09\x09aClass protocolsDo: [ :category :methods |\x0a\x09\x09\x09\x09category = ('*', name) ifTrue: [ map at: category put: methods ] ].\x0a\x09\x09\x09result addAll: ((map keys sorted: [ :a :b | a <= b ]) collect: [ :category |\x0a\x09\x09\x09\x09MethodCategory name: category theClass: aClass methods: (map at: category) ]) ] ].\x0a\x09^ result",
- referencedClasses: ["OrderedCollection", "Package", "Smalltalk", "Dictionary", "MethodCategory"],
- messageSends: ["name", "new", "do:", "sortedClasses:", "classes", "theMetaClass", "protocolsDo:", "ifTrue:", "=", ",", "at:put:", "addAll:", "collect:", "sorted:", "keys", "<=", "name:theClass:methods:", "at:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "ownCategoriesOfClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- var map;
- return $core.withContext(function($ctx1) {
- var $1;
- map=$recv($globals.Dictionary)._new();
- $recv(aClass)._protocolsDo_((function(each,methods){
- return $core.withContext(function($ctx2) {
- $1=$recv(each)._match_("^\x5c*");
- if(!$core.assert($1)){
- return $recv(map)._at_put_(each,methods);
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each,methods:methods},$ctx1,1)});
- }));
- return $recv($recv($recv(map)._keys())._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- return $recv(a).__lt_eq(b);
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,3)});
- })))._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($globals.MethodCategory)._name_theClass_methods_(each,aClass,$recv(map)._at_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,4)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"ownCategoriesOfClass:",{aClass:aClass,map:map},$globals.ChunkExporter)});
- },
- args: ["aClass"],
- source: "ownCategoriesOfClass: aClass\x0a\x09\x22Answer the protocols of aClass that are not package extensions\x22\x0a\x09\x0a\x09\x22Issue #143: sort protocol alphabetically\x22\x0a\x0a\x09| map |\x0a\x09map := Dictionary new.\x0a\x09aClass protocolsDo: [ :each :methods |\x0a\x09\x09(each match: '^\x5c*') ifFalse: [ map at: each put: methods ] ].\x0a\x09^ (map keys sorted: [ :a :b | a <= b ]) collect: [ :each |\x0a\x09\x09MethodCategory name: each theClass: aClass methods: (map at: each) ]",
- referencedClasses: ["Dictionary", "MethodCategory"],
- messageSends: ["new", "protocolsDo:", "ifFalse:", "match:", "at:put:", "collect:", "sorted:", "keys", "<=", "name:theClass:methods:", "at:"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "ownCategoriesOfMetaClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._ownCategoriesOfClass_($recv(aClass)._theMetaClass());
- }, function($ctx1) {$ctx1.fill(self,"ownCategoriesOfMetaClass:",{aClass:aClass},$globals.ChunkExporter)});
- },
- args: ["aClass"],
- source: "ownCategoriesOfMetaClass: aClass\x0a\x09\x22Issue #143: sort protocol alphabetically\x22\x0a\x0a\x09^ self ownCategoriesOfClass: aClass theMetaClass",
- referencedClasses: [],
- messageSends: ["ownCategoriesOfClass:", "theMetaClass"]
- }),
- $globals.ChunkExporter);
- $core.addMethod(
- $core.method({
- selector: "ownMethodProtocolsOfClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(aClass)._ownProtocols())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($globals.ExportMethodProtocol)._name_theClass_(each,aClass);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"ownMethodProtocolsOfClass:",{aClass:aClass},$globals.ChunkExporter)});
- },
- args: ["aClass"],
- source: "ownMethodProtocolsOfClass: aClass\x0a\x09\x22Answer a collection of ExportMethodProtocol object of aClass that are not package extensions\x22\x0a\x09\x0a\x09^ aClass ownProtocols collect: [ :each |\x0a\x09\x09ExportMethodProtocol name: each theClass: aClass ]",
- referencedClasses: ["ExportMethodProtocol"],
- messageSends: ["collect:", "ownProtocols", "name:theClass:"]
- }),
- $globals.ChunkExporter);
- $core.addClass("Exporter", $globals.AbstractExporter, [], "Platform-ImportExport");
- $globals.Exporter.comment="I am responsible for outputting Amber code into a JavaScript string.\x0a\x0aThe generated output is enough to reconstruct the exported data, including Smalltalk source code and other metadata.\x0a\x0a## Use case\x0a\x0aI am typically used to save code outside of the Amber runtime (committing to disk, etc.).";
- $core.addMethod(
- $core.method({
- selector: "exportBehavior:on:",
- protocol: "output",
- fn: function (aBehavior,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aBehavior)._exportBehaviorDefinitionTo_using_(aStream,self);
- $recv($recv(aBehavior)._ownMethods())._do_((function(method){
- return $core.withContext(function($ctx2) {
- return self._exportMethod_on_(method,aStream);
- }, function($ctx2) {$ctx2.fillBlock({method:method},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportBehavior:on:",{aBehavior:aBehavior,aStream:aStream},$globals.Exporter)});
- },
- args: ["aBehavior", "aStream"],
- source: "exportBehavior: aBehavior on: aStream\x0a\x09aBehavior exportBehaviorDefinitionTo: aStream using: self.\x0a\x09aBehavior ownMethods do: [ :method |\x0a\x09\x09self exportMethod: method on: aStream ]",
- referencedClasses: [],
- messageSends: ["exportBehaviorDefinitionTo:using:", "do:", "ownMethods", "exportMethod:on:"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportDefinitionOf:on:",
- protocol: "output",
- fn: function (aClass,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$5,$4,$6,$7,$2,$1,$8,$10,$9,$receiver;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $3=$recv($recv(aClass)._name())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=1;
- $5=$recv(aClass)._superclass();
- if(($receiver = $5) == null || $receiver.isNil){
- $4="null";
- } else {
- var superclass;
- superclass=$receiver;
- $4=$recv(superclass)._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=2;
- }
- $6=$recv($recv(aClass)._instanceVariableNames())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=3;
- $7=$recv($recv(aClass)._category())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=4;
- $2=["$core.addClass(",$3,", ",$4,", ",$6,", ",$7,");"];
- $1=$recv(aStream)._write_($2);
- $ctx1.sendIdx["write:"]=1;
- $8=$recv(aClass)._comment();
- $ctx1.sendIdx["comment"]=1;
- $recv($8)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=2;
- $recv(aStream)._write_("//>>excludeStart(\x22ide\x22, pragmas.excludeIdeData);");
- $ctx2.sendIdx["write:"]=2;
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=3;
- $10=$recv(aClass)._asJavaScriptSource();
- $ctx2.sendIdx["asJavaScriptSource"]=5;
- $9=[$10,".comment=",$recv($recv($recv(aClass)._comment())._crlfSanitized())._asJavaScriptSource(),";"];
- $recv(aStream)._write_($9);
- $ctx2.sendIdx["write:"]=3;
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=4;
- return $recv(aStream)._write_("//>>excludeEnd(\x22ide\x22);");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportDefinitionOf:on:",{aClass:aClass,aStream:aStream},$globals.Exporter)});
- },
- args: ["aClass", "aStream"],
- source: "exportDefinitionOf: aClass on: aStream\x0a\x09aStream\x0a\x09\x09lf;\x0a\x09\x09write: {\x0a\x09\x09\x09'$core.addClass('.\x0a\x09\x09\x09aClass name asJavaScriptSource. ', '.\x0a\x09\x09\x09aClass superclass ifNil: [ 'null' ] ifNotNil: [ :superclass | superclass asJavaScriptSource ]. ', '.\x0a\x09\x09\x09aClass instanceVariableNames asJavaScriptSource. ', '.\x0a\x09\x09\x09aClass category asJavaScriptSource.\x0a\x09\x09\x09');' }.\x0a\x09aClass comment ifNotEmpty: [\x0a\x09\x09aStream\x0a\x09\x09\x09lf;\x0a\x09\x09\x09write: '//>>excludeStart(\x22ide\x22, pragmas.excludeIdeData);'; lf;\x0a\x09\x09\x09write: { aClass asJavaScriptSource. '.comment='. aClass comment crlfSanitized asJavaScriptSource. ';' }; lf;\x0a\x09\x09\x09write: '//>>excludeEnd(\x22ide\x22);' ].\x0a\x09aStream lf",
- referencedClasses: [],
- messageSends: ["lf", "write:", "asJavaScriptSource", "name", "ifNil:ifNotNil:", "superclass", "instanceVariableNames", "category", "ifNotEmpty:", "comment", "crlfSanitized"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportMetaDefinitionOf:on:",
- protocol: "output",
- fn: function (aClass,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $2=$recv(aClass)._theMetaClass();
- $ctx1.sendIdx["theMetaClass"]=1;
- $1=$recv($2)._instanceVariableNames();
- $recv($1)._ifNotEmpty_((function(classIvars){
- return $core.withContext(function($ctx2) {
- $4=$recv($recv(aClass)._theMetaClass())._asJavaScriptSource();
- $ctx2.sendIdx["asJavaScriptSource"]=1;
- $3=[$4,".iVarNames = ",$recv(classIvars)._asJavaScriptSource(),";"];
- $recv(aStream)._write_($3);
- return $recv(aStream)._lf();
- }, function($ctx2) {$ctx2.fillBlock({classIvars:classIvars},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportMetaDefinitionOf:on:",{aClass:aClass,aStream:aStream},$globals.Exporter)});
- },
- args: ["aClass", "aStream"],
- source: "exportMetaDefinitionOf: aClass on: aStream\x0a\x09aStream lf.\x0a\x09aClass theMetaClass instanceVariableNames ifNotEmpty: [ :classIvars | aStream\x0a\x09\x09write: { aClass theMetaClass asJavaScriptSource. '.iVarNames = '. classIvars asJavaScriptSource. ';' };\x0a\x09\x09lf ]",
- referencedClasses: [],
- messageSends: ["lf", "ifNotEmpty:", "instanceVariableNames", "theMetaClass", "write:", "asJavaScriptSource"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportMethod:on:",
- protocol: "output",
- fn: function (aMethod,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$8,$7,$10,$9,$12,$11;
- $recv(aStream)._write_("$core.addMethod(");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._write_("$core.method({");
- $ctx1.sendIdx["write:"]=2;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=2;
- $2=$recv($recv(aMethod)._selector())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=1;
- $1=["selector: ",$2,","];
- $recv(aStream)._write_($1);
- $ctx1.sendIdx["write:"]=3;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=3;
- $4=$recv($recv(aMethod)._protocol())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=2;
- $3=["protocol: ",$4,","];
- $recv(aStream)._write_($3);
- $ctx1.sendIdx["write:"]=4;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=4;
- $recv(aStream)._write_(["fn: ",$recv($recv(aMethod)._fn())._compiledSource(),","]);
- $ctx1.sendIdx["write:"]=5;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=5;
- $recv(aStream)._write_("//>>excludeStart(\x22ide\x22, pragmas.excludeIdeData);");
- $ctx1.sendIdx["write:"]=6;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=6;
- $6=$recv($recv(aMethod)._arguments())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=3;
- $5=["args: ",$6,","];
- $recv(aStream)._write_($5);
- $ctx1.sendIdx["write:"]=7;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=7;
- $8=$recv($recv(aMethod)._source())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=4;
- $7=["source: ",$8,","];
- $recv(aStream)._write_($7);
- $ctx1.sendIdx["write:"]=8;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=8;
- $10=$recv($recv(aMethod)._referencedClasses())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=5;
- $9=["referencedClasses: ",$10,","];
- $recv(aStream)._write_($9);
- $ctx1.sendIdx["write:"]=9;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=9;
- $recv(aStream)._write_("//>>excludeEnd(\x22ide\x22);");
- $ctx1.sendIdx["write:"]=10;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=10;
- $12=$recv($recv(aMethod)._messageSends())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=6;
- $11=["messageSends: ",$12];
- $recv(aStream)._write_($11);
- $ctx1.sendIdx["write:"]=11;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=11;
- $recv(aStream)._write_("}),");
- $ctx1.sendIdx["write:"]=12;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=12;
- $recv(aStream)._write_([$recv($recv(aMethod)._methodClass())._asJavaScriptSource(),");"]);
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=13;
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportMethod:on:",{aMethod:aMethod,aStream:aStream},$globals.Exporter)});
- },
- args: ["aMethod", "aStream"],
- source: "exportMethod: aMethod on: aStream\x0a\x09aStream\x0a\x09\x09write: '$core.addMethod('; lf;\x0a\x09\x09write: '$core.method({'; lf;\x0a\x09\x09write: { 'selector: '. aMethod selector asJavaScriptSource. ',' }; lf;\x0a\x09\x09write: { 'protocol: '. aMethod protocol asJavaScriptSource. ',' }; lf;\x0a\x09\x09write: { 'fn: '. aMethod fn compiledSource. ',' }; lf;\x0a\x09\x09write: '//>>excludeStart(\x22ide\x22, pragmas.excludeIdeData);'; lf;\x0a\x09\x09write: { 'args: '. aMethod arguments asJavaScriptSource. ',' }; lf;\x0a\x09\x09write: { 'source: '. aMethod source asJavaScriptSource. ',' }; lf;\x0a\x09\x09write: { 'referencedClasses: '. aMethod referencedClasses asJavaScriptSource. ',' }; lf;\x0a\x09\x09write: '//>>excludeEnd(\x22ide\x22);'; lf;\x0a\x09\x09write: { 'messageSends: '. aMethod messageSends asJavaScriptSource }; lf;\x0a\x09\x09write: '}),'; lf;\x0a\x09\x09write: { aMethod methodClass asJavaScriptSource. ');' }; lf; lf",
- referencedClasses: [],
- messageSends: ["write:", "lf", "asJavaScriptSource", "selector", "protocol", "compiledSource", "fn", "arguments", "source", "referencedClasses", "messageSends", "methodClass"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackage:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- self._exportPackagePrologueOf_on_(aPackage,aStream);
- self._exportPackageDefinitionOf_on_(aPackage,aStream);
- self._exportPackageContextOf_on_(aPackage,aStream);
- self._exportPackageImportsOf_on_(aPackage,aStream);
- self._exportPackageTransportOf_on_(aPackage,aStream);
- $recv($recv(aPackage)._sortedClasses())._do_((function(each){
- return $core.withContext(function($ctx2) {
- self._exportBehavior_on_(each,aStream);
- $ctx2.sendIdx["exportBehavior:on:"]=1;
- $1=$recv(each)._theMetaClass();
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- var meta;
- meta=$receiver;
- return self._exportBehavior_on_(meta,aStream);
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- self._exportPackageTraitCompositionsOf_on_(aPackage,aStream);
- $recv(self._extensionMethodsOfPackage_(aPackage))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._exportMethod_on_(each,aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- self._exportPackageEpilogueOf_on_(aPackage,aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackage:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackage: aPackage on: aStream\x0a\x09\x0a\x09self \x0a\x09\x09exportPackagePrologueOf: aPackage on: aStream;\x0a\x09\x09exportPackageDefinitionOf: aPackage on: aStream;\x0a\x09\x09exportPackageContextOf: aPackage on: aStream;\x0a\x09\x09exportPackageImportsOf: aPackage on: aStream;\x0a\x09\x09exportPackageTransportOf: aPackage on: aStream.\x0a\x09\x0a\x09aPackage sortedClasses do: [ :each |\x0a\x09\x09self exportBehavior: each on: aStream.\x0a\x09\x09each theMetaClass ifNotNil: [ :meta | self exportBehavior: meta on: aStream ] ].\x0a\x09\x09\x09\x0a\x09self exportPackageTraitCompositionsOf: aPackage on: aStream.\x0a\x0a\x09(self extensionMethodsOfPackage: aPackage) do: [ :each |\x0a\x09\x09self exportMethod: each on: aStream ].\x0a\x09\x09\x0a\x09self exportPackageEpilogueOf: aPackage on: aStream",
- referencedClasses: [],
- messageSends: ["exportPackagePrologueOf:on:", "exportPackageDefinitionOf:on:", "exportPackageContextOf:on:", "exportPackageImportsOf:on:", "exportPackageTransportOf:on:", "do:", "sortedClasses", "exportBehavior:on:", "ifNotNil:", "theMetaClass", "exportPackageTraitCompositionsOf:on:", "extensionMethodsOfPackage:", "exportMethod:on:", "exportPackageEpilogueOf:on:"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageBodyBlockPrologueOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_("if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;");
- $ctx1.sendIdx["write:"]=1;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aStream)._write_("var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;");
- $ctx1.sendIdx["write:"]=2;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=2;
- $recv(aStream)._write_("if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;");
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageBodyBlockPrologueOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageBodyBlockPrologueOf: aPackage on: aStream\x0a\x09aStream\x0a\x09\x09write: 'if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;'; lf;\x0a\x09\x09write: 'var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;'; lf;\x0a\x09\x09write: 'if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;'; lf",
- referencedClasses: [],
- messageSends: ["write:", "lf"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageContextOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_(["$core.packages[",$recv($recv(aPackage)._name())._asJavaScriptSource(),"].innerEval = ","function (expr) { return eval(expr); }",";"]);
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageContextOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageContextOf: aPackage on: aStream\x0a\x09aStream\x0a\x09\x09write: {\x0a\x09\x09\x09'$core.packages['.\x0a\x09\x09\x09aPackage name asJavaScriptSource.\x0a\x09\x09\x09'].innerEval = '.\x0a\x09\x09\x09'function (expr) { return eval(expr); }'.\x0a\x09\x09\x09';' };\x0a\x09\x09lf",
- referencedClasses: [],
- messageSends: ["write:", "asJavaScriptSource", "name", "lf"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageDefinitionOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_(["$core.addPackage(",$recv($recv(aPackage)._name())._asJavaScriptSource(),");"]);
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageDefinitionOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageDefinitionOf: aPackage on: aStream\x0a\x09aStream\x0a\x09\x09write: { '$core.addPackage('. aPackage name asJavaScriptSource. ');' };\x0a\x09\x09lf",
- referencedClasses: [],
- messageSends: ["write:", "asJavaScriptSource", "name", "lf"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageEpilogueOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageEpilogueOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageEpilogueOf: aPackage on: aStream\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageImportsOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $recv($recv(aPackage)._importsAsJson())._ifNotEmpty_((function(imports){
- return $core.withContext(function($ctx2) {
- $2=$recv($recv(aPackage)._name())._asJavaScriptSource();
- $ctx2.sendIdx["asJavaScriptSource"]=1;
- $1=["$core.packages[",$2,"].imports = ",$recv(imports)._asJavaScriptSource(),";"];
- $recv(aStream)._write_($1);
- return $recv(aStream)._lf();
- }, function($ctx2) {$ctx2.fillBlock({imports:imports},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageImportsOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageImportsOf: aPackage on: aStream\x0a\x09aPackage importsAsJson ifNotEmpty: [ :imports |\x0a\x09\x09aStream\x0a\x09\x09\x09write: {\x0a\x09\x09\x09\x09'$core.packages['.\x0a\x09\x09\x09\x09aPackage name asJavaScriptSource.\x0a\x09\x09\x09\x09'].imports = '.\x0a\x09\x09\x09\x09imports asJavaScriptSource.\x0a\x09\x09\x09\x09';' };\x0a\x09\x09\x09lf ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "importsAsJson", "write:", "asJavaScriptSource", "name", "lf"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackagePrologueOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackagePrologueOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackagePrologueOf: aPackage on: aStream\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageTraitCompositionsOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aPackage)._traitCompositions())._ifNotEmpty_((function(traitCompositions){
- return $core.withContext(function($ctx2) {
- $recv(traitCompositions)._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx3) {
- return self._exportTraitComposition_of_on_(value,key,aStream);
- }, function($ctx3) {$ctx3.fillBlock({key:key,value:value},$ctx2,2)});
- }));
- return $recv(aStream)._lf();
- }, function($ctx2) {$ctx2.fillBlock({traitCompositions:traitCompositions},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageTraitCompositionsOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageTraitCompositionsOf: aPackage on: aStream\x0a\x09aPackage traitCompositions ifNotEmpty: [ :traitCompositions |\x0a\x09\x09traitCompositions keysAndValuesDo: [ :key :value | self exportTraitComposition: value of: key on: aStream ].\x0a\x09\x09aStream lf ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "traitCompositions", "keysAndValuesDo:", "exportTraitComposition:of:on:", "lf"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageTransportOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_(["$core.packages[",$recv($recv(aPackage)._name())._asJavaScriptSource(),"].transport = ",$recv($recv(aPackage)._transport())._asJSONString(),";"]);
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageTransportOf:on:",{aPackage:aPackage,aStream:aStream},$globals.Exporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageTransportOf: aPackage on: aStream\x0a\x09aStream\x0a\x09\x09write: {\x0a\x09\x09\x09'$core.packages['.\x0a\x09\x09\x09aPackage name asJavaScriptSource.\x0a\x09\x09\x09'].transport = '.\x0a\x09\x09\x09aPackage transport asJSONString.\x0a\x09\x09\x09';' };\x0a\x09\x09lf",
- referencedClasses: [],
- messageSends: ["write:", "asJavaScriptSource", "name", "asJSONString", "transport", "lf"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportTraitComposition:of:on:",
- protocol: "output",
- fn: function (aTraitComposition,aBehavior,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv(aTraitComposition)._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=1;
- $1=["$core.setTraitComposition(",$2,", ",$recv(aBehavior)._asJavaScriptSource(),");"];
- $recv(aStream)._write_($1);
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportTraitComposition:of:on:",{aTraitComposition:aTraitComposition,aBehavior:aBehavior,aStream:aStream},$globals.Exporter)});
- },
- args: ["aTraitComposition", "aBehavior", "aStream"],
- source: "exportTraitComposition: aTraitComposition of: aBehavior on: aStream\x0a\x09aStream write: {\x0a\x09\x09'$core.setTraitComposition('.\x0a\x09\x09aTraitComposition asJavaScriptSource.\x0a\x09\x09', '.\x0a\x09\x09aBehavior asJavaScriptSource.\x0a\x09\x09');' };\x0a\x09lf",
- referencedClasses: [],
- messageSends: ["write:", "asJavaScriptSource", "lf"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "exportTraitDefinitionOf:on:",
- protocol: "output",
- fn: function (aClass,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$4,$2,$1,$5,$7,$6;
- $recv(aStream)._lf();
- $ctx1.sendIdx["lf"]=1;
- $3=$recv($recv(aClass)._name())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=1;
- $4=$recv($recv(aClass)._category())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=2;
- $2=["$core.addTrait(",$3,", ",$4,");"];
- $1=$recv(aStream)._write_($2);
- $ctx1.sendIdx["write:"]=1;
- $5=$recv(aClass)._comment();
- $ctx1.sendIdx["comment"]=1;
- $recv($5)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=2;
- $recv(aStream)._write_("//>>excludeStart(\x22ide\x22, pragmas.excludeIdeData);");
- $ctx2.sendIdx["write:"]=2;
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=3;
- $7=$recv(aClass)._asJavaScriptSource();
- $ctx2.sendIdx["asJavaScriptSource"]=3;
- $6=[$7,".comment=",$recv($recv($recv(aClass)._comment())._crlfSanitized())._asJavaScriptSource(),";"];
- $recv(aStream)._write_($6);
- $ctx2.sendIdx["write:"]=3;
- $recv(aStream)._lf();
- $ctx2.sendIdx["lf"]=4;
- return $recv(aStream)._write_("//>>excludeEnd(\x22ide\x22);");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportTraitDefinitionOf:on:",{aClass:aClass,aStream:aStream},$globals.Exporter)});
- },
- args: ["aClass", "aStream"],
- source: "exportTraitDefinitionOf: aClass on: aStream\x0a\x09aStream\x0a\x09\x09lf;\x0a\x09\x09write: {\x0a\x09\x09\x09'$core.addTrait('.\x0a\x09\x09\x09aClass name asJavaScriptSource. ', '.\x0a\x09\x09\x09aClass category asJavaScriptSource.\x0a\x09\x09\x09');' }.\x0a\x09aClass comment ifNotEmpty: [\x0a\x09\x09aStream\x0a\x09\x09\x09lf;\x0a\x09\x09\x09write: '//>>excludeStart(\x22ide\x22, pragmas.excludeIdeData);'; lf;\x0a\x09\x09\x09write: { aClass asJavaScriptSource. '.comment='. aClass comment crlfSanitized asJavaScriptSource. ';' }; lf;\x0a\x09\x09\x09write: '//>>excludeEnd(\x22ide\x22);' ].\x0a\x09aStream lf",
- referencedClasses: [],
- messageSends: ["lf", "write:", "asJavaScriptSource", "name", "category", "ifNotEmpty:", "comment", "crlfSanitized"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "ownMethodsOfClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv($recv($recv($recv(aClass)._methodDictionary())._values())._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $1=$recv(a)._selector();
- $ctx2.sendIdx["selector"]=1;
- return $recv($1).__lt_eq($recv(b)._selector());
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,1)});
- })))._reject_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._protocol())._match_("^\x5c*");
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"ownMethodsOfClass:",{aClass:aClass},$globals.Exporter)});
- },
- args: ["aClass"],
- source: "ownMethodsOfClass: aClass\x0a\x09\x22Issue #143: sort methods alphabetically\x22\x0a\x0a\x09^ ((aClass methodDictionary values) sorted: [ :a :b | a selector <= b selector ])\x0a\x09\x09reject: [ :each | (each protocol match: '^\x5c*') ]",
- referencedClasses: [],
- messageSends: ["reject:", "sorted:", "values", "methodDictionary", "<=", "selector", "match:", "protocol"]
- }),
- $globals.Exporter);
- $core.addMethod(
- $core.method({
- selector: "ownMethodsOfMetaClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._ownMethodsOfClass_($recv(aClass)._theMetaClass());
- }, function($ctx1) {$ctx1.fill(self,"ownMethodsOfMetaClass:",{aClass:aClass},$globals.Exporter)});
- },
- args: ["aClass"],
- source: "ownMethodsOfMetaClass: aClass\x0a\x09\x22Issue #143: sort methods alphabetically\x22\x0a\x0a\x09^ self ownMethodsOfClass: aClass theMetaClass",
- referencedClasses: [],
- messageSends: ["ownMethodsOfClass:", "theMetaClass"]
- }),
- $globals.Exporter);
- $core.addClass("AmdExporter", $globals.Exporter, ["namespace"], "Platform-ImportExport");
- $globals.AmdExporter.comment="I am used to export Packages in an AMD (Asynchronous Module Definition) JavaScript format.";
- $core.addMethod(
- $core.method({
- selector: "amdNamesOfPackages:",
- protocol: "private",
- fn: function (anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv($recv(anArray)._select_((function(each){
- return $core.withContext(function($ctx2) {
- $1=self._amdNamespaceOfPackage_(each);
- $ctx2.sendIdx["amdNamespaceOfPackage:"]=1;
- return $recv($1)._notNil();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- })))._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(self._amdNamespaceOfPackage_(each)).__comma("/")).__comma($recv(each)._name());
- $ctx2.sendIdx[","]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"amdNamesOfPackages:",{anArray:anArray},$globals.AmdExporter)});
- },
- args: ["anArray"],
- source: "amdNamesOfPackages: anArray\x0a\x09^ (anArray\x0a\x09\x09select: [ :each | (self amdNamespaceOfPackage: each) notNil ])\x0a\x09\x09collect: [ :each | (self amdNamespaceOfPackage: each), '/', each name ]",
- referencedClasses: [],
- messageSends: ["collect:", "select:", "notNil", "amdNamespaceOfPackage:", ",", "name"]
- }),
- $globals.AmdExporter);
- $core.addMethod(
- $core.method({
- selector: "amdNamespaceOfPackage:",
- protocol: "private",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=$recv(aPackage)._transport();
- $ctx1.sendIdx["transport"]=1;
- $2=$recv($3)._type();
- $1=$recv($2).__eq("amd");
- if($core.assert($1)){
- return $recv($recv(aPackage)._transport())._namespace();
- } else {
- return nil;
- }
- }, function($ctx1) {$ctx1.fill(self,"amdNamespaceOfPackage:",{aPackage:aPackage},$globals.AmdExporter)});
- },
- args: ["aPackage"],
- source: "amdNamespaceOfPackage: aPackage\x0a\x09^ (aPackage transport type = 'amd')\x0a\x09\x09ifTrue: [ aPackage transport namespace ]\x0a\x09\x09ifFalse: [ nil ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "=", "type", "transport", "namespace"]
- }),
- $globals.AmdExporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackageEpilogueOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aStream)._write_("});");
- $recv(aStream)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackageEpilogueOf:on:",{aPackage:aPackage,aStream:aStream},$globals.AmdExporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackageEpilogueOf: aPackage on: aStream\x0a\x09aStream\x0a\x09\x09write: '});';\x0a\x09\x09lf",
- referencedClasses: [],
- messageSends: ["write:", "lf"]
- }),
- $globals.AmdExporter);
- $core.addMethod(
- $core.method({
- selector: "exportPackagePrologueOf:on:",
- protocol: "output",
- fn: function (aPackage,aStream){
- var self=this;
- var importsForOutput,loadDependencies,pragmaStart,pragmaEnd;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$6,$5,$7,$14,$13,$12,$11,$10,$9,$18,$17,$16,$15,$8;
- pragmaStart="";
- pragmaEnd="";
- importsForOutput=self._importsForOutput_(aPackage);
- loadDependencies=self._amdNamesOfPackages_($recv(aPackage)._loadDependencies());
- $1=$recv(importsForOutput)._value();
- $ctx1.sendIdx["value"]=1;
- $recv($1)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- $3=$recv($globals.String)._lf();
- $ctx2.sendIdx["lf"]=1;
- $2=$recv($3).__comma("//>>excludeStart(\x22imports\x22, pragmas.excludeImports);");
- $ctx2.sendIdx[","]=2;
- $4=$recv($globals.String)._lf();
- $ctx2.sendIdx["lf"]=2;
- pragmaStart=$recv($2).__comma($4);
- $ctx2.sendIdx[","]=1;
- pragmaStart;
- $6=$recv($globals.String)._lf();
- $ctx2.sendIdx["lf"]=3;
- $5=$recv($6).__comma("//>>excludeEnd(\x22imports\x22);");
- $ctx2.sendIdx[","]=4;
- $7=$recv($globals.String)._lf();
- $ctx2.sendIdx["lf"]=4;
- pragmaEnd=$recv($5).__comma($7);
- $ctx2.sendIdx[","]=3;
- return pragmaEnd;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $14=["amber/boot", ":1:"].__comma($recv(importsForOutput)._value());
- $ctx1.sendIdx[","]=7;
- $13=$recv($14).__comma([":2:"]);
- $ctx1.sendIdx[","]=6;
- $12=$recv($13).__comma($recv($recv(loadDependencies)._asArray())._sorted());
- $ctx1.sendIdx[","]=5;
- $11=$recv($12)._asJavaScriptSource();
- $10=$recv($11)._replace_with_(",\x5cs*[\x22']:1:[\x22']",pragmaStart);
- $ctx1.sendIdx["replace:with:"]=2;
- $9=$recv($10)._replace_with_(",\x5cs*[\x22']:2:[\x22']",pragmaEnd);
- $ctx1.sendIdx["replace:with:"]=1;
- $18=$recv(["$boot", ":1:"].__comma($recv(importsForOutput)._key())).__comma([":2:"]);
- $ctx1.sendIdx[","]=8;
- $17=$recv($18)._join_(",");
- $16=$recv($17)._replace_with_(",\x5cs*:1:",pragmaStart);
- $15=$recv($16)._replace_with_(",\x5cs*:2:",pragmaEnd);
- $ctx1.sendIdx["replace:with:"]=3;
- $8=["define(",$9,", function(",$15,"){\x22use strict\x22;"];
- $recv(aStream)._write_($8);
- $recv(aStream)._lf();
- self._exportPackageBodyBlockPrologueOf_on_(aPackage,aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportPackagePrologueOf:on:",{aPackage:aPackage,aStream:aStream,importsForOutput:importsForOutput,loadDependencies:loadDependencies,pragmaStart:pragmaStart,pragmaEnd:pragmaEnd},$globals.AmdExporter)});
- },
- args: ["aPackage", "aStream"],
- source: "exportPackagePrologueOf: aPackage on: aStream\x0a\x09| importsForOutput loadDependencies pragmaStart pragmaEnd |\x0a\x09pragmaStart := ''.\x0a\x09pragmaEnd := ''.\x0a\x09importsForOutput := self importsForOutput: aPackage.\x0a\x09loadDependencies := self amdNamesOfPackages: aPackage loadDependencies.\x0a\x09importsForOutput value ifNotEmpty: [\x0a\x09\x09pragmaStart := String lf, '//>>excludeStart(\x22imports\x22, pragmas.excludeImports);', String lf.\x0a\x09\x09pragmaEnd := String lf, '//>>excludeEnd(\x22imports\x22);', String lf ].\x0a\x09aStream\x0a\x09\x09write: {\x0a\x09\x09\x09'define('.\x0a\x09\x09\x09((#('amber/boot' ':1:'), importsForOutput value, #(':2:'), loadDependencies asArray sorted) asJavaScriptSource\x0a\x09\x09\x09\x09replace: ',\x5cs*[\x22'']:1:[\x22'']' with: pragmaStart)\x0a\x09\x09\x09\x09replace: ',\x5cs*[\x22'']:2:[\x22'']' with: pragmaEnd.\x0a\x09\x09\x09', function('.\x0a\x09\x09\x09((((#('$boot' ':1:'), importsForOutput key, #(':2:')) join: ',') \x0a\x09\x09\x09\x09replace: ',\x5cs*:1:' with: pragmaStart)\x0a\x09\x09\x09\x09replace: ',\x5cs*:2:' with: pragmaEnd).\x0a\x09\x09\x09'){\x22use strict\x22;' };\x0a\x09\x09lf.\x0a\x09self exportPackageBodyBlockPrologueOf: aPackage on: aStream",
- referencedClasses: ["String"],
- messageSends: ["importsForOutput:", "amdNamesOfPackages:", "loadDependencies", "ifNotEmpty:", "value", ",", "lf", "write:", "replace:with:", "asJavaScriptSource", "sorted", "asArray", "join:", "key", "exportPackageBodyBlockPrologueOf:on:"]
- }),
- $globals.AmdExporter);
- $core.addMethod(
- $core.method({
- selector: "importsForOutput:",
- protocol: "private",
- fn: function (aPackage){
- var self=this;
- var namedImports,anonImports,importVarNames;
- return $core.withContext(function($ctx1) {
- var $1;
- namedImports=[];
- anonImports=[];
- importVarNames=[];
- $recv($recv(aPackage)._imports())._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(each)._isString();
- if($core.assert($1)){
- return $recv(anonImports)._add_(each);
- $ctx2.sendIdx["add:"]=1;
- } else {
- $recv(namedImports)._add_($recv(each)._value());
- $ctx2.sendIdx["add:"]=2;
- return $recv(importVarNames)._add_($recv(each)._key());
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return $recv(importVarNames).__minus_gt($recv(namedImports).__comma(anonImports));
- }, function($ctx1) {$ctx1.fill(self,"importsForOutput:",{aPackage:aPackage,namedImports:namedImports,anonImports:anonImports,importVarNames:importVarNames},$globals.AmdExporter)});
- },
- args: ["aPackage"],
- source: "importsForOutput: aPackage\x0a\x09\x22Returns an association where key is list of import variables\x0a\x09and value is list of external dependencies, with ones imported as variables\x0a\x09put at the beginning with same order as is in key.\x0a\x09\x0a\x09For example imports:{'jQuery'->'jquery'. 'bootstrap'} would yield\x0a\x09#('jQuery') -> #('jquery' 'bootstrap')\x22\x0a\x09| namedImports anonImports importVarNames |\x0a\x09namedImports := #().\x0a\x09anonImports := #().\x0a\x09importVarNames := #().\x0a\x09aPackage imports do: [ :each | each isString\x0a\x09\x09ifTrue: [ anonImports add: each ]\x0a\x09\x09ifFalse: [ namedImports add: each value.\x0a\x09\x09\x09importVarNames add: each key ]].\x0a\x09^ importVarNames -> (namedImports, anonImports)",
- referencedClasses: [],
- messageSends: ["do:", "imports", "ifTrue:ifFalse:", "isString", "add:", "value", "key", "->", ","]
- }),
- $globals.AmdExporter);
- $core.addClass("ChunkParser", $globals.Object, ["stream", "last"], "Platform-ImportExport");
- $globals.ChunkParser.comment="I am responsible for parsing aStream contents in the chunk format.\x0a\x0a## API\x0a\x0a ChunkParser new\x0a stream: aStream;\x0a nextChunk";
- $core.addMethod(
- $core.method({
- selector: "last",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@last"];
- },
- args: [],
- source: "last\x0a\x09^ last",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ChunkParser);
- $core.addMethod(
- $core.method({
- selector: "nextChunk",
- protocol: "reading",
- fn: function (){
- var self=this;
- var char,result,chunk;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- var $early={};
- try {
- result=""._writeStream();
- $recv((function(){
- return $core.withContext(function($ctx2) {
- char=$recv(self["@stream"])._next();
- $ctx2.sendIdx["next"]=1;
- char;
- return $recv(char)._notNil();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- $1=$recv(char).__eq("!");
- $ctx2.sendIdx["="]=1;
- if($core.assert($1)){
- $2=$recv($recv(self["@stream"])._peek()).__eq("!");
- if($core.assert($2)){
- $recv(self["@stream"])._next();
- } else {
- self["@last"]=$recv($recv(result)._contents())._trimBoth();
- $3=self["@last"];
- throw $early=[$3];
- }
- }
- return $recv(result)._nextPut_(char);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- self["@last"]=nil;
- $4=self["@last"];
- return $4;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"nextChunk",{char:char,result:result,chunk:chunk},$globals.ChunkParser)});
- },
- args: [],
- source: "nextChunk\x0a\x09\x22The chunk format (Smalltalk Interchange Format or Fileout format)\x0a\x09is a trivial format but can be a bit tricky to understand:\x0a\x09\x09- Uses the exclamation mark as delimiter of chunks.\x0a\x09\x09- Inside a chunk a normal exclamation mark must be doubled.\x0a\x09\x09- A non empty chunk must be a valid Smalltalk expression.\x0a\x09\x09- A chunk on top level with a preceding empty chunk is an instruction chunk:\x0a\x09\x09\x09- The object created by the expression then takes over reading chunks.\x0a\x0a\x09This method returns next chunk as a String (trimmed), empty String (all whitespace) or nil.\x22\x0a\x0a\x09| char result chunk |\x0a\x09result := '' writeStream.\x0a\x09\x09[ char := stream next.\x0a\x09\x09char notNil ] whileTrue: [\x0a\x09\x09\x09\x09char = '!' ifTrue: [\x0a\x09\x09\x09\x09\x09\x09stream peek = '!'\x0a\x09\x09\x09\x09\x09\x09\x09\x09ifTrue: [ stream next \x22skipping the escape double\x22 ]\x0a\x09\x09\x09\x09\x09\x09\x09\x09ifFalse: [ ^ last := result contents trimBoth \x22chunk end marker found\x22 ]].\x0a\x09\x09\x09\x09result nextPut: char ].\x0a\x09^ last := nil \x22a chunk needs to end with !\x22",
- referencedClasses: [],
- messageSends: ["writeStream", "whileTrue:", "next", "notNil", "ifTrue:", "=", "ifTrue:ifFalse:", "peek", "trimBoth", "contents", "nextPut:"]
- }),
- $globals.ChunkParser);
- $core.addMethod(
- $core.method({
- selector: "stream:",
- protocol: "accessing",
- fn: function (aStream){
- var self=this;
- self["@stream"]=aStream;
- return self;
- },
- args: ["aStream"],
- source: "stream: aStream\x0a\x09stream := aStream",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ChunkParser);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._new())._stream_(aStream);
- }, function($ctx1) {$ctx1.fill(self,"on:",{aStream:aStream},$globals.ChunkParser.klass)});
- },
- args: ["aStream"],
- source: "on: aStream\x0a\x09^ self new stream: aStream",
- referencedClasses: [],
- messageSends: ["stream:", "new"]
- }),
- $globals.ChunkParser.klass);
- $core.addClass("ClassCommentReader", $globals.Object, ["class"], "Platform-ImportExport");
- $globals.ClassCommentReader.comment="I provide a mechanism for retrieving class comments stored on a file.\x0a\x0aSee also `ClassCategoryReader`.";
- $core.addMethod(
- $core.method({
- selector: "class:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@class"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "class: aClass\x0a\x09class := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassCommentReader);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.ClassCommentReader.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.ClassCommentReader)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.",
- referencedClasses: [],
- messageSends: ["initialize"]
- }),
- $globals.ClassCommentReader);
- $core.addMethod(
- $core.method({
- selector: "scanFrom:",
- protocol: "fileIn",
- fn: function (aChunkParser){
- var self=this;
- var chunk;
- return $core.withContext(function($ctx1) {
- chunk=$recv(aChunkParser)._nextChunk();
- $recv(chunk)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return self._setComment_(chunk);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"scanFrom:",{aChunkParser:aChunkParser,chunk:chunk},$globals.ClassCommentReader)});
- },
- args: ["aChunkParser"],
- source: "scanFrom: aChunkParser\x0a\x09| chunk |\x0a\x09chunk := aChunkParser nextChunk.\x0a\x09chunk ifNotEmpty: [\x0a\x09\x09self setComment: chunk ].",
- referencedClasses: [],
- messageSends: ["nextChunk", "ifNotEmpty:", "setComment:"]
- }),
- $globals.ClassCommentReader);
- $core.addMethod(
- $core.method({
- selector: "setComment:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@class"])._comment_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setComment:",{aString:aString},$globals.ClassCommentReader)});
- },
- args: ["aString"],
- source: "setComment: aString\x0a\x09class comment: aString",
- referencedClasses: [],
- messageSends: ["comment:"]
- }),
- $globals.ClassCommentReader);
- $core.addClass("ClassProtocolReader", $globals.Object, ["class", "category"], "Platform-ImportExport");
- $globals.ClassProtocolReader.comment="I provide a mechanism for retrieving class descriptions stored on a file in the Smalltalk chunk format.";
- $core.addMethod(
- $core.method({
- selector: "class:category:",
- protocol: "accessing",
- fn: function (aClass,aString){
- var self=this;
- self["@class"]=aClass;
- self["@category"]=aString;
- return self;
- },
- args: ["aClass", "aString"],
- source: "class: aClass category: aString\x0a\x09class := aClass.\x0a\x09category := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassProtocolReader);
- $core.addMethod(
- $core.method({
- selector: "compileMethod:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.Compiler)._new())._install_forClass_protocol_(aString,self["@class"],self["@category"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"compileMethod:",{aString:aString},$globals.ClassProtocolReader)});
- },
- args: ["aString"],
- source: "compileMethod: aString\x0a\x09Compiler new install: aString forClass: class protocol: category",
- referencedClasses: ["Compiler"],
- messageSends: ["install:forClass:protocol:", "new"]
- }),
- $globals.ClassProtocolReader);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.ClassProtocolReader.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.ClassProtocolReader)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.",
- referencedClasses: [],
- messageSends: ["initialize"]
- }),
- $globals.ClassProtocolReader);
- $core.addMethod(
- $core.method({
- selector: "scanFrom:",
- protocol: "fileIn",
- fn: function (aChunkParser){
- var self=this;
- var chunk;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- chunk=$recv(aChunkParser)._nextChunk();
- chunk;
- return $recv(chunk)._isEmpty();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- return self._compileMethod_(chunk);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"scanFrom:",{aChunkParser:aChunkParser,chunk:chunk},$globals.ClassProtocolReader)});
- },
- args: ["aChunkParser"],
- source: "scanFrom: aChunkParser\x0a\x09| chunk |\x0a\x09[ chunk := aChunkParser nextChunk.\x0a\x09chunk isEmpty ] whileFalse: [\x0a\x09\x09self compileMethod: chunk ]",
- referencedClasses: [],
- messageSends: ["whileFalse:", "nextChunk", "isEmpty", "compileMethod:"]
- }),
- $globals.ClassProtocolReader);
- $core.addClass("ExportMethodProtocol", $globals.Object, ["name", "theClass"], "Platform-ImportExport");
- $globals.ExportMethodProtocol.comment="I am an abstraction for a method protocol in a class / metaclass.\x0a\x0aI know of my class, name and methods.\x0aI am used when exporting a package.";
- $core.addMethod(
- $core.method({
- selector: "methods",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv($recv(self._theClass())._methodsInProtocol_(self._name()))._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $1=$recv(a)._selector();
- $ctx2.sendIdx["selector"]=1;
- return $recv($1).__lt_eq($recv(b)._selector());
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"methods",{},$globals.ExportMethodProtocol)});
- },
- args: [],
- source: "methods\x0a\x09^ (self theClass methodsInProtocol: self name)\x0a\x09\x09sorted: [ :a :b | a selector <= b selector ]",
- referencedClasses: [],
- messageSends: ["sorted:", "methodsInProtocol:", "theClass", "name", "<=", "selector"]
- }),
- $globals.ExportMethodProtocol);
- $core.addMethod(
- $core.method({
- selector: "name",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@name"];
- },
- args: [],
- source: "name\x0a\x09^ name",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ExportMethodProtocol);
- $core.addMethod(
- $core.method({
- selector: "name:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@name"]=aString;
- return self;
- },
- args: ["aString"],
- source: "name: aString\x0a\x09name := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ExportMethodProtocol);
- $core.addMethod(
- $core.method({
- selector: "ownMethods",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv($recv(self._theClass())._ownMethodsInProtocol_(self._name()))._sorted_((function(a,b){
- return $core.withContext(function($ctx2) {
- $1=$recv(a)._selector();
- $ctx2.sendIdx["selector"]=1;
- return $recv($1).__lt_eq($recv(b)._selector());
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"ownMethods",{},$globals.ExportMethodProtocol)});
- },
- args: [],
- source: "ownMethods\x0a\x09^ (self theClass ownMethodsInProtocol: self name)\x0a\x09\x09sorted: [ :a :b | a selector <= b selector ]",
- referencedClasses: [],
- messageSends: ["sorted:", "ownMethodsInProtocol:", "theClass", "name", "<=", "selector"]
- }),
- $globals.ExportMethodProtocol);
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@theClass"];
- },
- args: [],
- source: "theClass\x0a\x09^ theClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ExportMethodProtocol);
- $core.addMethod(
- $core.method({
- selector: "theClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@theClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "theClass: aClass\x0a\x09theClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ExportMethodProtocol);
- $core.addMethod(
- $core.method({
- selector: "name:theClass:",
- protocol: "instance creation",
- fn: function (aString,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._name_(aString);
- $recv($1)._theClass_(aClass);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"name:theClass:",{aString:aString,aClass:aClass},$globals.ExportMethodProtocol.klass)});
- },
- args: ["aString", "aClass"],
- source: "name: aString theClass: aClass\x0a\x09^ self new\x0a\x09\x09name: aString;\x0a\x09\x09theClass: aClass;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["name:", "new", "theClass:", "yourself"]
- }),
- $globals.ExportMethodProtocol.klass);
- $core.addClass("Importer", $globals.Object, ["lastSection", "lastChunk"], "Platform-ImportExport");
- $globals.Importer.comment="I can import Amber code from a string in the chunk format.\x0a\x0a## API\x0a\x0a Importer new import: aString";
- $core.addMethod(
- $core.method({
- selector: "import:",
- protocol: "fileIn",
- fn: function (aStream){
- var self=this;
- var chunk,result,parser,lastEmpty;
- return $core.withContext(function($ctx1) {
- var $1;
- parser=$recv($globals.ChunkParser)._on_(aStream);
- lastEmpty=false;
- self["@lastSection"]="n/a, not started";
- self["@lastChunk"]=nil;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- $recv((function(){
- return $core.withContext(function($ctx3) {
- chunk=$recv(parser)._nextChunk();
- chunk;
- return $recv(chunk)._isNil();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(chunk)._ifEmpty_ifNotEmpty_((function(){
- lastEmpty=true;
- return lastEmpty;
- }),(function(){
- return $core.withContext(function($ctx4) {
- self["@lastSection"]=chunk;
- self["@lastSection"];
- result=$recv($recv($globals.Compiler)._new())._evaluateExpression_(chunk);
- result;
- $1=lastEmpty;
- if($core.assert($1)){
- lastEmpty=false;
- lastEmpty;
- return $recv(result)._scanFrom_(parser);
- }
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,5)});
- }));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- self["@lastSection"]="n/a, finished";
- return self["@lastSection"];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(e){
- return $core.withContext(function($ctx2) {
- self["@lastChunk"]=$recv(parser)._last();
- self["@lastChunk"];
- return $recv(e)._resignal();
- }, function($ctx2) {$ctx2.fillBlock({e:e},$ctx1,7)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"import:",{aStream:aStream,chunk:chunk,result:result,parser:parser,lastEmpty:lastEmpty},$globals.Importer)});
- },
- args: ["aStream"],
- source: "import: aStream\x0a\x09| chunk result parser lastEmpty |\x0a\x09parser := ChunkParser on: aStream.\x0a\x09lastEmpty := false.\x0a\x09lastSection := 'n/a, not started'.\x0a\x09lastChunk := nil.\x0a\x09[\x0a\x09[ chunk := parser nextChunk.\x0a\x09chunk isNil ] whileFalse: [\x0a\x09\x09chunk\x0a\x09\x09\x09ifEmpty: [ lastEmpty := true ]\x0a\x09\x09\x09ifNotEmpty: [\x0a\x09\x09\x09\x09lastSection := chunk.\x0a\x09\x09\x09\x09result := Compiler new evaluateExpression: chunk.\x0a\x09\x09\x09\x09lastEmpty\x0a\x09\x09\x09\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09\x09\x09\x09\x09\x09lastEmpty := false.\x0a\x09\x09\x09\x09\x09\x09\x09\x09\x09result scanFrom: parser ]] ].\x0a\x09lastSection := 'n/a, finished'\x0a\x09] on: Error do: [:e | lastChunk := parser last. e resignal ].",
- referencedClasses: ["ChunkParser", "Compiler", "Error"],
- messageSends: ["on:", "on:do:", "whileFalse:", "nextChunk", "isNil", "ifEmpty:ifNotEmpty:", "evaluateExpression:", "new", "ifTrue:", "scanFrom:", "last", "resignal"]
- }),
- $globals.Importer);
- $core.addMethod(
- $core.method({
- selector: "lastChunk",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@lastChunk"];
- },
- args: [],
- source: "lastChunk\x0a\x09^ lastChunk",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Importer);
- $core.addMethod(
- $core.method({
- selector: "lastSection",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@lastSection"];
- },
- args: [],
- source: "lastSection\x0a\x09^ lastSection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Importer);
- $core.addClass("PackageCommitError", $globals.Error, [], "Platform-ImportExport");
- $globals.PackageCommitError.comment="I get signaled when an attempt to commit a package has failed.";
- $core.addClass("PackageHandler", $globals.Object, [], "Platform-ImportExport");
- $globals.PackageHandler.comment="I am responsible for handling package loading and committing.\x0a\x0aI should not be used directly. Instead, use the corresponding `Package` methods.";
- $core.addMethod(
- $core.method({
- selector: "ajaxPutAt:data:onSuccess:onError:",
- protocol: "private",
- fn: function (aURL,aString,aBlock,anotherBlock){
- var self=this;
- var xhr;
- return $core.withContext(function($ctx1) {
- var $1,$4,$3,$2;
- xhr=$recv($globals.Platform)._newXhr();
- $recv(xhr)._open_url_async_("PUT",aURL,true);
- $recv(xhr)._onreadystatechange_((function(){
- return $core.withContext(function($ctx2) {
- $1=$recv($recv(xhr)._readyState()).__eq((4));
- if($core.assert($1)){
- $4=$recv(xhr)._status();
- $ctx2.sendIdx["status"]=1;
- $3=$recv($4).__gt_eq((200));
- $2=$recv($3)._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv(xhr)._status()).__lt((300));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- return $recv($2)._ifTrue_ifFalse_(aBlock,anotherBlock);
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv(xhr)._send_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"ajaxPutAt:data:onSuccess:onError:",{aURL:aURL,aString:aString,aBlock:aBlock,anotherBlock:anotherBlock,xhr:xhr},$globals.PackageHandler)});
- },
- args: ["aURL", "aString", "aBlock", "anotherBlock"],
- source: "ajaxPutAt: aURL data: aString onSuccess: aBlock onError: anotherBlock\x0a\x09| xhr |\x0a\x09xhr := Platform newXhr.\x0a\x09xhr open: 'PUT' url: aURL async: true.\x0a\x09xhr onreadystatechange: [\x0a\x09\x09xhr readyState = 4 ifTrue: [\x0a\x09\x09\x09(xhr status >= 200 and: [ xhr status < 300 ])\x0a\x09\x09\x09\x09ifTrue: aBlock\x0a\x09\x09\x09\x09ifFalse: anotherBlock ]].\x0a\x09xhr send: aString",
- referencedClasses: ["Platform"],
- messageSends: ["newXhr", "open:url:async:", "onreadystatechange:", "ifTrue:", "=", "readyState", "ifTrue:ifFalse:", "and:", ">=", "status", "<", "send:"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "chunkContentsFor:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- return $recv(self._chunkExporter())._exportPackage_on_(aPackage,str);
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"chunkContentsFor:",{aPackage:aPackage},$globals.PackageHandler)});
- },
- args: ["aPackage"],
- source: "chunkContentsFor: aPackage\x0a\x09^ String streamContents: [ :str |\x0a\x09\x09self chunkExporter exportPackage: aPackage on: str ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "exportPackage:on:", "chunkExporter"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "chunkExporter",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._chunkExporterClass())._new();
- }, function($ctx1) {$ctx1.fill(self,"chunkExporter",{},$globals.PackageHandler)});
- },
- args: [],
- source: "chunkExporter\x0a\x09^ self chunkExporterClass new",
- referencedClasses: [],
- messageSends: ["new", "chunkExporterClass"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "chunkExporterClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.ChunkExporter;
- },
- args: [],
- source: "chunkExporterClass\x0a\x09^ ChunkExporter",
- referencedClasses: ["ChunkExporter"],
- messageSends: []
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "commit:",
- protocol: "committing",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- self._commit_onSuccess_onError_(aPackage,(function(){
- }),(function(error){
- return $core.withContext(function($ctx2) {
- $1=$recv($globals.PackageCommitError)._new();
- $2=$recv("Commiting failed with reason: \x22".__comma($recv(error)._responseText())).__comma("\x22");
- $ctx2.sendIdx[","]=1;
- $recv($1)._messageText_($2);
- return $recv($1)._signal();
- }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commit:",{aPackage:aPackage},$globals.PackageHandler)});
- },
- args: ["aPackage"],
- source: "commit: aPackage\x0a\x09self \x0a\x09\x09commit: aPackage\x0a\x09\x09onSuccess: []\x0a\x09\x09onError: [ :error |\x0a\x09\x09\x09PackageCommitError new\x0a\x09\x09\x09\x09messageText: 'Commiting failed with reason: \x22' , (error responseText) , '\x22';\x0a\x09\x09\x09\x09signal ]",
- referencedClasses: ["PackageCommitError"],
- messageSends: ["commit:onSuccess:onError:", "messageText:", "new", ",", "responseText", "signal"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "commit:onSuccess:onError:",
- protocol: "committing",
- fn: function (aPackage,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._commitJsFileFor_onSuccess_onError_(aPackage,(function(){
- return $core.withContext(function($ctx2) {
- return self._commitStFileFor_onSuccess_onError_(aPackage,(function(){
- return $core.withContext(function($ctx3) {
- $recv(aPackage)._beClean();
- return $recv(aBlock)._value();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }),anotherBlock);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),anotherBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commit:onSuccess:onError:",{aPackage:aPackage,aBlock:aBlock,anotherBlock:anotherBlock},$globals.PackageHandler)});
- },
- args: ["aPackage", "aBlock", "anotherBlock"],
- source: "commit: aPackage onSuccess: aBlock onError: anotherBlock\x0a\x09self \x0a\x09\x09commitJsFileFor: aPackage \x0a\x09\x09onSuccess: [\x0a\x09\x09\x09self \x0a\x09\x09\x09\x09commitStFileFor: aPackage \x0a\x09\x09\x09\x09onSuccess: [ aPackage beClean. aBlock value ]\x0a\x09\x09\x09\x09onError: anotherBlock ] \x0a\x09\x09onError: anotherBlock",
- referencedClasses: [],
- messageSends: ["commitJsFileFor:onSuccess:onError:", "commitStFileFor:onSuccess:onError:", "beClean", "value"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "commitJsFileFor:onSuccess:onError:",
- protocol: "committing",
- fn: function (aPackage,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv($recv(self._commitPathJsFor_(aPackage)).__comma("/")).__comma($recv(aPackage)._name());
- $ctx1.sendIdx[","]=2;
- $1=$recv($2).__comma(".js");
- $ctx1.sendIdx[","]=1;
- self._ajaxPutAt_data_onSuccess_onError_($1,self._contentsFor_(aPackage),aBlock,anotherBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commitJsFileFor:onSuccess:onError:",{aPackage:aPackage,aBlock:aBlock,anotherBlock:anotherBlock},$globals.PackageHandler)});
- },
- args: ["aPackage", "aBlock", "anotherBlock"],
- source: "commitJsFileFor: aPackage onSuccess: aBlock onError: anotherBlock\x0a\x09self \x0a\x09\x09ajaxPutAt: (self commitPathJsFor: aPackage), '/', aPackage name, '.js'\x0a\x09\x09data: (self contentsFor: aPackage)\x0a\x09\x09onSuccess: aBlock\x0a\x09\x09onError: anotherBlock",
- referencedClasses: [],
- messageSends: ["ajaxPutAt:data:onSuccess:onError:", ",", "commitPathJsFor:", "name", "contentsFor:"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "commitPathJsFor:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commitPathJsFor:",{aPackage:aPackage},$globals.PackageHandler)});
- },
- args: ["aPackage"],
- source: "commitPathJsFor: aPackage\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "commitPathStFor:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commitPathStFor:",{aPackage:aPackage},$globals.PackageHandler)});
- },
- args: ["aPackage"],
- source: "commitPathStFor: aPackage\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "commitStFileFor:onSuccess:onError:",
- protocol: "committing",
- fn: function (aPackage,aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv($recv(self._commitPathStFor_(aPackage)).__comma("/")).__comma($recv(aPackage)._name());
- $ctx1.sendIdx[","]=2;
- $1=$recv($2).__comma(".st");
- $ctx1.sendIdx[","]=1;
- self._ajaxPutAt_data_onSuccess_onError_($1,self._chunkContentsFor_(aPackage),aBlock,anotherBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commitStFileFor:onSuccess:onError:",{aPackage:aPackage,aBlock:aBlock,anotherBlock:anotherBlock},$globals.PackageHandler)});
- },
- args: ["aPackage", "aBlock", "anotherBlock"],
- source: "commitStFileFor: aPackage onSuccess: aBlock onError: anotherBlock\x0a\x09self \x0a\x09\x09ajaxPutAt: (self commitPathStFor: aPackage), '/', aPackage name, '.st'\x0a\x09\x09data: (self chunkContentsFor: aPackage)\x0a\x09\x09onSuccess: aBlock\x0a\x09\x09onError: anotherBlock",
- referencedClasses: [],
- messageSends: ["ajaxPutAt:data:onSuccess:onError:", ",", "commitPathStFor:", "name", "chunkContentsFor:"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "contentsFor:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- return $recv(self._exporter())._exportPackage_on_(aPackage,str);
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"contentsFor:",{aPackage:aPackage},$globals.PackageHandler)});
- },
- args: ["aPackage"],
- source: "contentsFor: aPackage\x0a\x09^ String streamContents: [ :str |\x0a\x09\x09self exporter exportPackage: aPackage on: str ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "exportPackage:on:", "exporter"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "exporter",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._exporterClass())._new();
- }, function($ctx1) {$ctx1.fill(self,"exporter",{},$globals.PackageHandler)});
- },
- args: [],
- source: "exporter\x0a\x09^ self exporterClass new",
- referencedClasses: [],
- messageSends: ["new", "exporterClass"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "exporterClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exporterClass",{},$globals.PackageHandler)});
- },
- args: [],
- source: "exporterClass\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "load:",
- protocol: "loading",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"load:",{aPackage:aPackage},$globals.PackageHandler)});
- },
- args: ["aPackage"],
- source: "load: aPackage\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.PackageHandler);
- $core.addMethod(
- $core.method({
- selector: "onCommitError:",
- protocol: "error handling",
- fn: function (anError){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv($globals.PackageCommitError)._new();
- $2=$recv("Commiting failed with reason: \x22".__comma($recv(anError)._responseText())).__comma("\x22");
- $ctx1.sendIdx[","]=1;
- $recv($1)._messageText_($2);
- $recv($1)._signal();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"onCommitError:",{anError:anError},$globals.PackageHandler)});
- },
- args: ["anError"],
- source: "onCommitError: anError\x0a\x09PackageCommitError new\x0a\x09\x09messageText: 'Commiting failed with reason: \x22' , (anError responseText) , '\x22';\x0a\x09\x09signal",
- referencedClasses: ["PackageCommitError"],
- messageSends: ["messageText:", "new", ",", "responseText", "signal"]
- }),
- $globals.PackageHandler);
- $core.addClass("AmdPackageHandler", $globals.PackageHandler, [], "Platform-ImportExport");
- $globals.AmdPackageHandler.comment="I am responsible for handling package loading and committing.\x0a\x0aI should not be used directly. Instead, use the corresponding `Package` methods.";
- $core.addMethod(
- $core.method({
- selector: "commitPathJsFor:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._toUrl_(self._namespaceFor_(aPackage));
- }, function($ctx1) {$ctx1.fill(self,"commitPathJsFor:",{aPackage:aPackage},$globals.AmdPackageHandler)});
- },
- args: ["aPackage"],
- source: "commitPathJsFor: aPackage\x0a\x09^ self toUrl: (self namespaceFor: aPackage)",
- referencedClasses: [],
- messageSends: ["toUrl:", "namespaceFor:"]
- }),
- $globals.AmdPackageHandler);
- $core.addMethod(
- $core.method({
- selector: "commitPathStFor:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- var path,pathWithout;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv(self._namespaceFor_(aPackage)).__comma("/_source");
- $ctx1.sendIdx[","]=1;
- path=self._toUrl_($1);
- pathWithout=self._commitPathJsFor_(aPackage);
- $2=$recv(path).__eq($recv(pathWithout).__comma("/_source"));
- if($core.assert($2)){
- return pathWithout;
- } else {
- return path;
- }
- }, function($ctx1) {$ctx1.fill(self,"commitPathStFor:",{aPackage:aPackage,path:path,pathWithout:pathWithout},$globals.AmdPackageHandler)});
- },
- args: ["aPackage"],
- source: "commitPathStFor: aPackage\x0a\x09\x22If _source is not mapped, .st will be committed to .js path.\x0a\x09It is recommended not to use _source as it can be deprecated.\x22\x0a\x09\x0a\x09| path pathWithout |\x0a\x09path := self toUrl: (self namespaceFor: aPackage), '/_source'.\x0a\x09pathWithout := self commitPathJsFor: aPackage.\x0a\x09^ path = (pathWithout, '/_source') ifTrue: [ pathWithout ] ifFalse: [ path ]",
- referencedClasses: [],
- messageSends: ["toUrl:", ",", "namespaceFor:", "commitPathJsFor:", "ifTrue:ifFalse:", "="]
- }),
- $globals.AmdPackageHandler);
- $core.addMethod(
- $core.method({
- selector: "exporterClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.AmdExporter;
- },
- args: [],
- source: "exporterClass\x0a\x09^ AmdExporter",
- referencedClasses: ["AmdExporter"],
- messageSends: []
- }),
- $globals.AmdPackageHandler);
- $core.addMethod(
- $core.method({
- selector: "load:",
- protocol: "loading",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$receiver;
- $1=$recv($globals.Smalltalk)._amdRequire();
- if(($receiver = $1) == null || $receiver.isNil){
- self._error_("AMD loader not present");
- } else {
- var require;
- require=$receiver;
- $3=$recv($recv(self._namespaceFor_(aPackage)).__comma("/")).__comma($recv(aPackage)._name());
- $ctx1.sendIdx[","]=1;
- $2=$recv($globals.Array)._with_($3);
- $recv(require)._value_($2);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"load:",{aPackage:aPackage},$globals.AmdPackageHandler)});
- },
- args: ["aPackage"],
- source: "load: aPackage\x0a\x09Smalltalk amdRequire\x0a\x09\x09ifNil: [ self error: 'AMD loader not present' ]\x0a\x09\x09ifNotNil: [ :require |\x0a\x09\x09\x09require value: (Array with: (self namespaceFor: aPackage), '/', aPackage name ) ]",
- referencedClasses: ["Smalltalk", "Array"],
- messageSends: ["ifNil:ifNotNil:", "amdRequire", "error:", "value:", "with:", ",", "namespaceFor:", "name"]
- }),
- $globals.AmdPackageHandler);
- $core.addMethod(
- $core.method({
- selector: "namespaceFor:",
- protocol: "committing",
- fn: function (aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(aPackage)._transport())._namespace();
- }, function($ctx1) {$ctx1.fill(self,"namespaceFor:",{aPackage:aPackage},$globals.AmdPackageHandler)});
- },
- args: ["aPackage"],
- source: "namespaceFor: aPackage\x0a\x09^ aPackage transport namespace",
- referencedClasses: [],
- messageSends: ["namespace", "transport"]
- }),
- $globals.AmdPackageHandler);
- $core.addMethod(
- $core.method({
- selector: "toUrl:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv($globals.Smalltalk)._amdRequire();
- if(($receiver = $1) == null || $receiver.isNil){
- return self._error_("AMD loader not present");
- } else {
- var require;
- require=$receiver;
- return $recv($recv(require)._basicAt_("toUrl"))._value_(aString);
- }
- }, function($ctx1) {$ctx1.fill(self,"toUrl:",{aString:aString},$globals.AmdPackageHandler)});
- },
- args: ["aString"],
- source: "toUrl: aString\x0a\x09^ Smalltalk amdRequire\x0a\x09\x09ifNil: [ self error: 'AMD loader not present' ]\x0a\x09\x09ifNotNil: [ :require | (require basicAt: 'toUrl') value: aString ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifNil:ifNotNil:", "amdRequire", "error:", "value:", "basicAt:"]
- }),
- $globals.AmdPackageHandler);
- $core.addMethod(
- $core.method({
- selector: "defaultNamespace",
- protocol: "commit paths",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._defaultAmdNamespace();
- }, function($ctx1) {$ctx1.fill(self,"defaultNamespace",{},$globals.AmdPackageHandler.klass)});
- },
- args: [],
- source: "defaultNamespace\x0a\x09^ Smalltalk defaultAmdNamespace",
- referencedClasses: ["Smalltalk"],
- messageSends: ["defaultAmdNamespace"]
- }),
- $globals.AmdPackageHandler.klass);
- $core.addMethod(
- $core.method({
- selector: "defaultNamespace:",
- protocol: "commit paths",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Smalltalk)._defaultAmdNamespace_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"defaultNamespace:",{aString:aString},$globals.AmdPackageHandler.klass)});
- },
- args: ["aString"],
- source: "defaultNamespace: aString\x0a\x09Smalltalk defaultAmdNamespace: aString",
- referencedClasses: ["Smalltalk"],
- messageSends: ["defaultAmdNamespace:"]
- }),
- $globals.AmdPackageHandler.klass);
- $core.addClass("PackageTransport", $globals.Object, ["package"], "Platform-ImportExport");
- $globals.PackageTransport.comment="I represent the transport mechanism used to commit a package.\x0a\x0aMy concrete subclasses have a `#handler` to which committing is delegated.";
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $globals.HashedCollection._newFromPairs_(["type",self._type()]);
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptObject",{},$globals.PackageTransport)});
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ #{ 'type' -> self type }",
- referencedClasses: [],
- messageSends: ["type"]
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "commit",
- protocol: "committing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._commitHandler())._commit_(self._package());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commit",{},$globals.PackageTransport)});
- },
- args: [],
- source: "commit\x0a\x09self commitHandler commit: self package",
- referencedClasses: [],
- messageSends: ["commit:", "commitHandler", "package"]
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "commitHandler",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._commitHandlerClass())._new();
- }, function($ctx1) {$ctx1.fill(self,"commitHandler",{},$globals.PackageTransport)});
- },
- args: [],
- source: "commitHandler\x0a\x09^ self commitHandlerClass new",
- referencedClasses: [],
- messageSends: ["new", "commitHandlerClass"]
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "commitHandlerClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commitHandlerClass",{},$globals.PackageTransport)});
- },
- args: [],
- source: "commitHandlerClass\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "commitOnSuccess:onError:",
- protocol: "committing",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._commitHandler())._commit_onSuccess_onError_(self._package(),aBlock,anotherBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"commitOnSuccess:onError:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.PackageTransport)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "commitOnSuccess: aBlock onError: anotherBlock\x0a\x09self commitHandler \x0a\x09\x09commit: self package\x0a\x09\x09onSuccess: aBlock\x0a\x09\x09onError: anotherBlock",
- referencedClasses: [],
- messageSends: ["commit:onSuccess:onError:", "commitHandler", "package"]
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "";
- },
- args: [],
- source: "definition\x0a\x09^ ''",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "load",
- protocol: "loading",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._commitHandler())._load_(self._package());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"load",{},$globals.PackageTransport)});
- },
- args: [],
- source: "load\x0a\x09self commitHandler load: self package",
- referencedClasses: [],
- messageSends: ["load:", "commitHandler", "package"]
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "package",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@package"];
- },
- args: [],
- source: "package\x0a\x09^ package",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "package:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- self["@package"]=aPackage;
- return self;
- },
- args: ["aPackage"],
- source: "package: aPackage\x0a\x09package := aPackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "setupFromJson:",
- protocol: "initialization",
- fn: function (anObject){
- var self=this;
- return self;
- },
- args: ["anObject"],
- source: "setupFromJson: anObject\x0a\x09\x22no op. override if needed in subclasses\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PackageTransport);
- $core.addMethod(
- $core.method({
- selector: "type",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._type();
- }, function($ctx1) {$ctx1.fill(self,"type",{},$globals.PackageTransport)});
- },
- args: [],
- source: "type\x0a\x09^ self class type",
- referencedClasses: [],
- messageSends: ["type", "class"]
- }),
- $globals.PackageTransport);
- $globals.PackageTransport.klass.iVarNames = ["registry"];
- $core.addMethod(
- $core.method({
- selector: "classRegisteredFor:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@registry"])._at_(aString);
- }, function($ctx1) {$ctx1.fill(self,"classRegisteredFor:",{aString:aString},$globals.PackageTransport.klass)});
- },
- args: ["aString"],
- source: "classRegisteredFor: aString\x0a\x09^ registry at: aString",
- referencedClasses: [],
- messageSends: ["at:"]
- }),
- $globals.PackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "defaultType",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.AmdPackageTransport)._type();
- }, function($ctx1) {$ctx1.fill(self,"defaultType",{},$globals.PackageTransport.klass)});
- },
- args: [],
- source: "defaultType\x0a\x09^ AmdPackageTransport type",
- referencedClasses: ["AmdPackageTransport"],
- messageSends: ["type"]
- }),
- $globals.PackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "for:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._classRegisteredFor_(aString))._new();
- }, function($ctx1) {$ctx1.fill(self,"for:",{aString:aString},$globals.PackageTransport.klass)});
- },
- args: ["aString"],
- source: "for: aString\x0a\x09^ (self classRegisteredFor: aString) new",
- referencedClasses: [],
- messageSends: ["new", "classRegisteredFor:"]
- }),
- $globals.PackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "fromJson:",
- protocol: "instance creation",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- if(($receiver = anObject) == null || $receiver.isNil){
- $1=self._for_(self._defaultType());
- $ctx1.sendIdx["for:"]=1;
- return $1;
- } else {
- anObject;
- }
- $2=self._for_($recv(anObject)._type());
- $recv($2)._setupFromJson_(anObject);
- return $recv($2)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"fromJson:",{anObject:anObject},$globals.PackageTransport.klass)});
- },
- args: ["anObject"],
- source: "fromJson: anObject\x0a\x09anObject ifNil: [ ^ self for: self defaultType ].\x0a\x09\x0a\x09^ (self for: anObject type)\x0a\x09\x09setupFromJson: anObject;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["ifNil:", "for:", "defaultType", "setupFromJson:", "type", "yourself"]
- }),
- $globals.PackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- (
- $ctx1.supercall = true,
- ($globals.PackageTransport.klass.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- $1=self.__eq_eq($globals.PackageTransport);
- if($core.assert($1)){
- self["@registry"]=$globals.HashedCollection._newFromPairs_([]);
- self["@registry"];
- } else {
- self._register();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.PackageTransport.klass)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09self == PackageTransport\x0a\x09\x09ifTrue: [ registry := #{} ]\x0a\x09\x09ifFalse: [ self register ]",
- referencedClasses: ["PackageTransport"],
- messageSends: ["initialize", "ifTrue:ifFalse:", "==", "register"]
- }),
- $globals.PackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "register",
- protocol: "registration",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.PackageTransport)._register_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"register",{},$globals.PackageTransport.klass)});
- },
- args: [],
- source: "register\x0a\x09PackageTransport register: self",
- referencedClasses: ["PackageTransport"],
- messageSends: ["register:"]
- }),
- $globals.PackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "register:",
- protocol: "registration",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv(aClass)._type();
- $ctx1.sendIdx["type"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $recv(self["@registry"])._at_put_($recv(aClass)._type(),aClass);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"register:",{aClass:aClass},$globals.PackageTransport.klass)});
- },
- args: ["aClass"],
- source: "register: aClass\x0a\x09aClass type ifNotNil: [\x0a\x09\x09registry at: aClass type put: aClass ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "type", "at:put:"]
- }),
- $globals.PackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "type",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return nil;
- },
- args: [],
- source: "type\x0a\x09\x22Override in subclasses\x22\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PackageTransport.klass);
- $core.addClass("AmdPackageTransport", $globals.PackageTransport, ["namespace"], "Platform-ImportExport");
- $globals.AmdPackageTransport.comment="I am the default transport for committing packages.\x0a\x0aSee `AmdExporter` and `AmdPackageHandler`.";
- $core.addMethod(
- $core.method({
- selector: "asJavaScriptObject",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(
- $ctx1.supercall = true,
- ($globals.AmdPackageTransport.superclass||$boot.nilAsClass).fn.prototype._asJavaScriptObject.apply($recv(self), []));
- $ctx1.supercall = false;
- $recv($1)._at_put_("amdNamespace",self._namespace());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"asJavaScriptObject",{},$globals.AmdPackageTransport)});
- },
- args: [],
- source: "asJavaScriptObject\x0a\x09^ super asJavaScriptObject\x0a\x09\x09at: 'amdNamespace' put: self namespace;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["at:put:", "asJavaScriptObject", "namespace", "yourself"]
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "commitHandlerClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.AmdPackageHandler;
- },
- args: [],
- source: "commitHandlerClass\x0a\x09^ AmdPackageHandler",
- referencedClasses: ["AmdPackageHandler"],
- messageSends: []
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "defaultNamespace",
- protocol: "defaults",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._defaultAmdNamespace();
- }, function($ctx1) {$ctx1.fill(self,"defaultNamespace",{},$globals.AmdPackageTransport)});
- },
- args: [],
- source: "defaultNamespace\x0a\x09^ Smalltalk defaultAmdNamespace",
- referencedClasses: ["Smalltalk"],
- messageSends: ["defaultAmdNamespace"]
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "definition",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.String)._streamContents_((function(stream){
- return $core.withContext(function($ctx2) {
- $recv(stream)._write_([$recv(self._class())._name()," namespace: "]);
- return $recv(stream)._print_(self._namespace());
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"definition",{},$globals.AmdPackageTransport)});
- },
- args: [],
- source: "definition\x0a\x09^ String streamContents: [ :stream | stream \x0a\x09\x09write: { self class name. ' namespace: ' }; print: self namespace ]",
- referencedClasses: ["String"],
- messageSends: ["streamContents:", "write:", "name", "class", "print:", "namespace"]
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "namespace",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@namespace"];
- if(($receiver = $1) == null || $receiver.isNil){
- return self._defaultNamespace();
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"namespace",{},$globals.AmdPackageTransport)});
- },
- args: [],
- source: "namespace\x0a\x09^ namespace ifNil: [ self defaultNamespace ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "defaultNamespace"]
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "namespace:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@namespace"]=aString;
- return self;
- },
- args: ["aString"],
- source: "namespace: aString\x0a\x09namespace := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "printOn:",
- protocol: "printing",
- fn: function (aStream){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.AmdPackageTransport.superclass||$boot.nilAsClass).fn.prototype._printOn_.apply($recv(self), [aStream]));
- $ctx1.supercall = false;
- $recv(aStream)._nextPutAll_(" (AMD Namespace: ");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._nextPutAll_(self._namespace());
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv(aStream)._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},$globals.AmdPackageTransport)});
- },
- args: ["aStream"],
- source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream\x0a\x09\x09nextPutAll: ' (AMD Namespace: ';\x0a\x09\x09nextPutAll: self namespace;\x0a\x09\x09nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["printOn:", "nextPutAll:", "namespace"]
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "setPath:",
- protocol: "actions",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(require)._basicAt_("config"))._value_($globals.HashedCollection._newFromPairs_(["paths",$globals.HashedCollection._newFromPairs_([self._namespace(),aString])]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setPath:",{aString:aString},$globals.AmdPackageTransport)});
- },
- args: ["aString"],
- source: "setPath: aString\x0a\x09\x22Set the path the the receiver's `namespace`\x22\x0a\x09\x0a\x09(require basicAt: 'config') value: #{\x0a\x09\x09'paths' -> #{\x0a\x09\x09\x09self namespace -> aString\x0a\x09\x09}\x0a\x09}.",
- referencedClasses: [],
- messageSends: ["value:", "basicAt:", "namespace"]
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "setupFromJson:",
- protocol: "initialization",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._namespace_($recv(anObject)._at_("amdNamespace"));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setupFromJson:",{anObject:anObject},$globals.AmdPackageTransport)});
- },
- args: ["anObject"],
- source: "setupFromJson: anObject\x0a\x09self namespace: (anObject at: 'amdNamespace')",
- referencedClasses: [],
- messageSends: ["namespace:", "at:"]
- }),
- $globals.AmdPackageTransport);
- $core.addMethod(
- $core.method({
- selector: "namespace:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._namespace_(aString);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"namespace:",{aString:aString},$globals.AmdPackageTransport.klass)});
- },
- args: ["aString"],
- source: "namespace: aString\x0a\x09^ self new\x0a\x09\x09namespace: aString;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["namespace:", "new", "yourself"]
- }),
- $globals.AmdPackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "type",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "amd";
- },
- args: [],
- source: "type\x0a\x09^ 'amd'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AmdPackageTransport.klass);
- $core.addMethod(
- $core.method({
- selector: "commentStamp",
- protocol: "*Platform-ImportExport",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.ClassCommentReader)._new();
- $recv($1)._class_(self);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"commentStamp",{},$globals.BehaviorBody)});
- },
- args: [],
- source: "commentStamp\x0a\x09^ ClassCommentReader new\x0a\x09class: self;\x0a\x09yourself",
- referencedClasses: ["ClassCommentReader"],
- messageSends: ["class:", "new", "yourself"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "commentStamp:prior:",
- protocol: "*Platform-ImportExport",
- fn: function (aStamp,prior){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._commentStamp();
- }, function($ctx1) {$ctx1.fill(self,"commentStamp:prior:",{aStamp:aStamp,prior:prior},$globals.BehaviorBody)});
- },
- args: ["aStamp", "prior"],
- source: "commentStamp: aStamp prior: prior\x0a\x09\x09^ self commentStamp",
- referencedClasses: [],
- messageSends: ["commentStamp"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "exportBehaviorDefinitionTo:using:",
- protocol: "*Platform-ImportExport",
- fn: function (aStream,anExporter){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportBehaviorDefinitionTo:using:",{aStream:aStream,anExporter:anExporter},$globals.BehaviorBody)});
- },
- args: ["aStream", "anExporter"],
- source: "exportBehaviorDefinitionTo: aStream using: anExporter\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "methodsFor:",
- protocol: "*Platform-ImportExport",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.ClassProtocolReader)._new();
- $recv($1)._class_category_(self,aString);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"methodsFor:",{aString:aString},$globals.BehaviorBody)});
- },
- args: ["aString"],
- source: "methodsFor: aString\x0a\x09^ ClassProtocolReader new\x0a\x09\x09class: self category: aString;\x0a\x09\x09yourself",
- referencedClasses: ["ClassProtocolReader"],
- messageSends: ["class:category:", "new", "yourself"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "methodsFor:stamp:",
- protocol: "*Platform-ImportExport",
- fn: function (aString,aStamp){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._methodsFor_(aString);
- }, function($ctx1) {$ctx1.fill(self,"methodsFor:stamp:",{aString:aString,aStamp:aStamp},$globals.BehaviorBody)});
- },
- args: ["aString", "aStamp"],
- source: "methodsFor: aString stamp: aStamp\x0a\x09\x22Added for file-in compatibility, ignores stamp.\x22\x0a\x09^ self methodsFor: aString",
- referencedClasses: [],
- messageSends: ["methodsFor:"]
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "exportBehaviorDefinitionTo:using:",
- protocol: "*Platform-ImportExport",
- fn: function (aStream,anExporter){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anExporter)._exportDefinitionOf_on_(self,aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportBehaviorDefinitionTo:using:",{aStream:aStream,anExporter:anExporter},$globals.Class)});
- },
- args: ["aStream", "anExporter"],
- source: "exportBehaviorDefinitionTo: aStream using: anExporter\x0a\x09anExporter exportDefinitionOf: self on: aStream",
- referencedClasses: [],
- messageSends: ["exportDefinitionOf:on:"]
- }),
- $globals.Class);
- $core.addMethod(
- $core.method({
- selector: "exportBehaviorDefinitionTo:using:",
- protocol: "*Platform-ImportExport",
- fn: function (aStream,anExporter){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anExporter)._exportMetaDefinitionOf_on_(self._instanceClass(),aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportBehaviorDefinitionTo:using:",{aStream:aStream,anExporter:anExporter},$globals.Metaclass)});
- },
- args: ["aStream", "anExporter"],
- source: "exportBehaviorDefinitionTo: aStream using: anExporter\x0a\x09anExporter exportMetaDefinitionOf: self instanceClass on: aStream",
- referencedClasses: [],
- messageSends: ["exportMetaDefinitionOf:on:", "instanceClass"]
- }),
- $globals.Metaclass);
- $core.addMethod(
- $core.method({
- selector: "commit",
- protocol: "*Platform-ImportExport",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._transport())._commit();
- }, function($ctx1) {$ctx1.fill(self,"commit",{},$globals.Package)});
- },
- args: [],
- source: "commit\x0a\x09^ self transport commit",
- referencedClasses: [],
- messageSends: ["commit", "transport"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "load",
- protocol: "*Platform-ImportExport",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._transport())._load();
- }, function($ctx1) {$ctx1.fill(self,"load",{},$globals.Package)});
- },
- args: [],
- source: "load\x0a\x09^ self transport load",
- referencedClasses: [],
- messageSends: ["load", "transport"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "loadFromNamespace:",
- protocol: "*Platform-ImportExport",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._transport();
- $recv($1)._namespace_(aString);
- return $recv($1)._load();
- }, function($ctx1) {$ctx1.fill(self,"loadFromNamespace:",{aString:aString},$globals.Package)});
- },
- args: ["aString"],
- source: "loadFromNamespace: aString\x0a\x09^ self transport\x0a\x09\x09namespace: aString;\x0a\x09\x09load",
- referencedClasses: [],
- messageSends: ["namespace:", "transport", "load"]
- }),
- $globals.Package);
- $core.addMethod(
- $core.method({
- selector: "load:",
- protocol: "*Platform-ImportExport",
- fn: function (aPackageName){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._named_(aPackageName))._load();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"load:",{aPackageName:aPackageName},$globals.Package.klass)});
- },
- args: ["aPackageName"],
- source: "load: aPackageName\x0a\x09(self named: aPackageName) load",
- referencedClasses: [],
- messageSends: ["load", "named:"]
- }),
- $globals.Package.klass);
- $core.addMethod(
- $core.method({
- selector: "load:fromNamespace:",
- protocol: "*Platform-ImportExport",
- fn: function (aPackageName,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._named_(aPackageName))._loadFromNamespace_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"load:fromNamespace:",{aPackageName:aPackageName,aString:aString},$globals.Package.klass)});
- },
- args: ["aPackageName", "aString"],
- source: "load: aPackageName fromNamespace: aString\x0a\x09(self named: aPackageName) loadFromNamespace: aString",
- referencedClasses: [],
- messageSends: ["loadFromNamespace:", "named:"]
- }),
- $globals.Package.klass);
- $core.addMethod(
- $core.method({
- selector: "exportBehaviorDefinitionTo:using:",
- protocol: "*Platform-ImportExport",
- fn: function (aStream,anExporter){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anExporter)._exportTraitDefinitionOf_on_(self,aStream);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"exportBehaviorDefinitionTo:using:",{aStream:aStream,anExporter:anExporter},$globals.Trait)});
- },
- args: ["aStream", "anExporter"],
- source: "exportBehaviorDefinitionTo: aStream using: anExporter\x0a\x09anExporter exportTraitDefinitionOf: self on: aStream",
- referencedClasses: [],
- messageSends: ["exportTraitDefinitionOf:on:"]
- }),
- $globals.Trait);
- });
- define('amber_core/Compiler-Core',["amber/boot", "amber_core/Kernel-Collections", "amber_core/Kernel-Exceptions", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Compiler-Core");
- $core.packages["Compiler-Core"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Compiler-Core"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("AbstractCodeGenerator", $globals.Object, ["currentClass", "currentPackage", "source"], "Compiler-Core");
- $globals.AbstractCodeGenerator.comment="I am the abstract super class of all code generators and provide their common API.";
- $core.addMethod(
- $core.method({
- selector: "compileNode:",
- protocol: "compiling",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._transformers())._inject_into_(aNode,(function(input,transformer){
- return $core.withContext(function($ctx2) {
- return $recv(transformer)._value_(input);
- }, function($ctx2) {$ctx2.fillBlock({input:input,transformer:transformer},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode},$globals.AbstractCodeGenerator)});
- },
- args: ["aNode"],
- source: "compileNode: aNode\x0a\x09^ self transformers\x0a\x09\x09inject: aNode\x0a\x09\x09into: [ :input :transformer | transformer value: input ]",
- referencedClasses: [],
- messageSends: ["inject:into:", "transformers", "value:"]
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "currentClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@currentClass"];
- },
- args: [],
- source: "currentClass\x0a\x09^ currentClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "currentClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@currentClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "currentClass: aClass\x0a\x09currentClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "currentPackage",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@currentPackage"];
- },
- args: [],
- source: "currentPackage\x0a\x09^ currentPackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "currentPackage:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@currentPackage"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "currentPackage: anObject\x0a\x09currentPackage := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "pseudoVariables",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._pseudoVariableNames();
- }, function($ctx1) {$ctx1.fill(self,"pseudoVariables",{},$globals.AbstractCodeGenerator)});
- },
- args: [],
- source: "pseudoVariables\x0a\x09^ Smalltalk pseudoVariableNames",
- referencedClasses: ["Smalltalk"],
- messageSends: ["pseudoVariableNames"]
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@source"];
- if(($receiver = $1) == null || $receiver.isNil){
- return "";
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.AbstractCodeGenerator)});
- },
- args: [],
- source: "source\x0a\x09^ source ifNil: [ '' ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@source"]=aString;
- return self;
- },
- args: ["aString"],
- source: "source: aString\x0a\x09source := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "transformers",
- protocol: "compiling",
- fn: function (){
- var self=this;
- var dict;
- return $core.withContext(function($ctx1) {
- dict=self._transformersDictionary();
- return $recv($recv($recv($recv(dict)._keys())._asArray())._sort())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(dict)._at_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"transformers",{dict:dict},$globals.AbstractCodeGenerator)});
- },
- args: [],
- source: "transformers\x0a\x09| dict |\x0a\x09dict := self transformersDictionary.\x0a\x09^ dict keys asArray sort collect: [ :each | dict at: each ]",
- referencedClasses: [],
- messageSends: ["transformersDictionary", "collect:", "sort", "asArray", "keys", "at:"]
- }),
- $globals.AbstractCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "transformersDictionary",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"transformersDictionary",{},$globals.AbstractCodeGenerator)});
- },
- args: [],
- source: "transformersDictionary\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AbstractCodeGenerator);
- $core.addClass("CodeGenerator", $globals.AbstractCodeGenerator, ["transformersDictionary"], "Compiler-Core");
- $globals.CodeGenerator.comment="I am a basic code generator. I generate a valid JavaScript output, but no not perform any inlining.\x0aSee `InliningCodeGenerator` for an optimized JavaScript code generation.";
- $core.addMethod(
- $core.method({
- selector: "irTranslator",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._irTranslatorClass())._new();
- $recv($1)._currentClass_(self._currentClass());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"irTranslator",{},$globals.CodeGenerator)});
- },
- args: [],
- source: "irTranslator\x0a\x09^ self irTranslatorClass new\x0a\x09\x09currentClass: self currentClass;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["currentClass:", "new", "irTranslatorClass", "currentClass", "yourself"]
- }),
- $globals.CodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "irTranslatorClass",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $globals.IRJSTranslator;
- },
- args: [],
- source: "irTranslatorClass\x0a\x09^ IRJSTranslator",
- referencedClasses: ["IRJSTranslator"],
- messageSends: []
- }),
- $globals.CodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "semanticAnalyzer",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.SemanticAnalyzer)._on_(self._currentClass());
- $recv($1)._thePackage_(self._currentPackage());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"semanticAnalyzer",{},$globals.CodeGenerator)});
- },
- args: [],
- source: "semanticAnalyzer\x0a\x09^ (SemanticAnalyzer on: self currentClass)\x0a\x09\x09thePackage: self currentPackage;\x0a\x09\x09yourself",
- referencedClasses: ["SemanticAnalyzer"],
- messageSends: ["thePackage:", "on:", "currentClass", "currentPackage", "yourself"]
- }),
- $globals.CodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "transformersDictionary",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=self["@transformersDictionary"];
- if(($receiver = $1) == null || $receiver.isNil){
- $2=$recv($globals.Dictionary)._new();
- $recv($2)._at_put_("2000-semantic",self._semanticAnalyzer());
- $ctx1.sendIdx["at:put:"]=1;
- $recv($2)._at_put_("5000-astToIr",self._translator());
- $ctx1.sendIdx["at:put:"]=2;
- $recv($2)._at_put_("8000-irToJs",self._irTranslator());
- self["@transformersDictionary"]=$recv($2)._yourself();
- return self["@transformersDictionary"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"transformersDictionary",{},$globals.CodeGenerator)});
- },
- args: [],
- source: "transformersDictionary\x0a\x09^ transformersDictionary ifNil: [ transformersDictionary := Dictionary new\x0a\x09\x09at: '2000-semantic' put: self semanticAnalyzer;\x0a\x09\x09at: '5000-astToIr' put: self translator;\x0a\x09\x09at: '8000-irToJs' put: self irTranslator;\x0a\x09\x09yourself ]",
- referencedClasses: ["Dictionary"],
- messageSends: ["ifNil:", "at:put:", "new", "semanticAnalyzer", "translator", "irTranslator", "yourself"]
- }),
- $globals.CodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "translator",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRASTTranslator)._new();
- $recv($1)._source_(self._source());
- $recv($1)._theClass_(self._currentClass());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"translator",{},$globals.CodeGenerator)});
- },
- args: [],
- source: "translator\x0a\x09^ IRASTTranslator new\x0a\x09\x09source: self source;\x0a\x09\x09theClass: self currentClass;\x0a\x09\x09yourself",
- referencedClasses: ["IRASTTranslator"],
- messageSends: ["source:", "new", "source", "theClass:", "currentClass", "yourself"]
- }),
- $globals.CodeGenerator);
- $core.addClass("Compiler", $globals.Object, ["currentClass", "currentPackage", "source", "unknownVariables", "codeGeneratorClass"], "Compiler-Core");
- $globals.Compiler.comment="I provide the public interface for compiling Amber source code into JavaScript.\x0a\x0aThe code generator used to produce JavaScript can be plugged with `#codeGeneratorClass`.\x0aThe default code generator is an instance of `InlinedCodeGenerator`";
- $core.addMethod(
- $core.method({
- selector: "codeGeneratorClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@codeGeneratorClass"];
- if(($receiver = $1) == null || $receiver.isNil){
- return $globals.InliningCodeGenerator;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"codeGeneratorClass",{},$globals.Compiler)});
- },
- args: [],
- source: "codeGeneratorClass\x0a\x09^ codeGeneratorClass ifNil: [ InliningCodeGenerator ]",
- referencedClasses: ["InliningCodeGenerator"],
- messageSends: ["ifNil:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "codeGeneratorClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@codeGeneratorClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "codeGeneratorClass: aClass\x0a\x09codeGeneratorClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "compile:forClass:protocol:",
- protocol: "compiling",
- fn: function (aString,aClass,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._source_(aString);
- return self._compileNode_forClass_package_(self._parse_(aString),aClass,$recv(aClass)._packageOfProtocol_(anotherString));
- }, function($ctx1) {$ctx1.fill(self,"compile:forClass:protocol:",{aString:aString,aClass:aClass,anotherString:anotherString},$globals.Compiler)});
- },
- args: ["aString", "aClass", "anotherString"],
- source: "compile: aString forClass: aClass protocol: anotherString\x0a\x09^ self\x0a\x09\x09source: aString;\x0a\x09\x09compileNode: (self parse: aString)\x0a\x09\x09forClass: aClass\x0a\x09\x09package: (aClass packageOfProtocol: anotherString)",
- referencedClasses: [],
- messageSends: ["source:", "compileNode:forClass:package:", "parse:", "packageOfProtocol:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "compileExpression:on:",
- protocol: "compiling",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("xxxDoIt ^ [ ".__comma(aString)).__comma(" ] value");
- $ctx1.sendIdx[","]=1;
- return self._compile_forClass_protocol_($1,$recv(anObject)._class(),"**xxxDoIt");
- }, function($ctx1) {$ctx1.fill(self,"compileExpression:on:",{aString:aString,anObject:anObject},$globals.Compiler)});
- },
- args: ["aString", "anObject"],
- source: "compileExpression: aString on: anObject\x0a\x09^ self\x0a\x09\x09compile: 'xxxDoIt ^ [ ', aString, ' ] value'\x0a\x09\x09forClass: anObject class\x0a\x09\x09protocol: '**xxxDoIt'",
- referencedClasses: [],
- messageSends: ["compile:forClass:protocol:", ",", "class"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "compileNode:",
- protocol: "compiling",
- fn: function (aNode){
- var self=this;
- var generator,result;
- return $core.withContext(function($ctx1) {
- var $1;
- generator=$recv(self._codeGeneratorClass())._new();
- $1=generator;
- $recv($1)._source_(self._source());
- $recv($1)._currentClass_(self._currentClass());
- $recv($1)._currentPackage_(self._currentPackage());
- result=$recv(generator)._compileNode_(aNode);
- self._unknownVariables_([]);
- return result;
- }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode,generator:generator,result:result},$globals.Compiler)});
- },
- args: ["aNode"],
- source: "compileNode: aNode\x0a\x09| generator result |\x0a\x09generator := self codeGeneratorClass new.\x0a\x09generator\x0a\x09\x09source: self source;\x0a\x09\x09currentClass: self currentClass;\x0a\x09\x09currentPackage: self currentPackage.\x0a\x09result := generator compileNode: aNode.\x0a\x09self unknownVariables: #().\x0a\x09^ result",
- referencedClasses: [],
- messageSends: ["new", "codeGeneratorClass", "source:", "source", "currentClass:", "currentClass", "currentPackage:", "currentPackage", "compileNode:", "unknownVariables:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "compileNode:forClass:package:",
- protocol: "compiling",
- fn: function (aNode,aClass,aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._currentClass_(aClass);
- self._currentPackage_(aPackage);
- return self._compileNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"compileNode:forClass:package:",{aNode:aNode,aClass:aClass,aPackage:aPackage},$globals.Compiler)});
- },
- args: ["aNode", "aClass", "aPackage"],
- source: "compileNode: aNode forClass: aClass package: aPackage\x0a\x09^ self\x0a\x09\x09currentClass: aClass;\x0a\x09\x09currentPackage: aPackage;\x0a\x09\x09compileNode: aNode",
- referencedClasses: [],
- messageSends: ["currentClass:", "currentPackage:", "compileNode:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "currentClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@currentClass"];
- },
- args: [],
- source: "currentClass\x0a\x09^ currentClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "currentClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@currentClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "currentClass: aClass\x0a\x09currentClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "currentPackage",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@currentPackage"];
- },
- args: [],
- source: "currentPackage\x0a\x09^ currentPackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "currentPackage:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@currentPackage"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "currentPackage: anObject\x0a\x09currentPackage := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "eval:",
- protocol: "compiling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return eval(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"eval:",{aString:aString},$globals.Compiler)});
- },
- args: ["aString"],
- source: "eval: aString\x0a\x09<inlineJS: 'return eval(aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "eval:forPackage:",
- protocol: "compiling",
- fn: function (aString,aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- return aPackage && aPackage.innerEval
- ? aPackage.innerEval(aString)
- : eval(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"eval:forPackage:",{aString:aString,aPackage:aPackage},$globals.Compiler)});
- },
- args: ["aString", "aPackage"],
- source: "eval: aString forPackage: aPackage\x0a\x09<inlineJS: 'return aPackage && aPackage.innerEval\x0a\x09\x09? aPackage.innerEval(aString)\x0a\x09\x09: eval(aString)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "evaluateExpression:",
- protocol: "compiling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._evaluateExpression_on_(aString,$recv($globals.DoIt)._new());
- }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:",{aString:aString},$globals.Compiler)});
- },
- args: ["aString"],
- source: "evaluateExpression: aString\x0a\x09\x22Unlike #eval: evaluate a Smalltalk expression and answer the returned object\x22\x0a\x09^ self evaluateExpression: aString on: DoIt new",
- referencedClasses: ["DoIt"],
- messageSends: ["evaluateExpression:on:", "new"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "evaluateExpression:on:",
- protocol: "compiling",
- fn: function (aString,anObject){
- var self=this;
- var result,method;
- return $core.withContext(function($ctx1) {
- var $1;
- method=self._eval_(self._compileExpression_on_(aString,anObject));
- $recv(method)._protocol_("**xxxDoIt");
- $1=$recv(anObject)._class();
- $ctx1.sendIdx["class"]=1;
- $recv($1)._addCompiledMethod_(method);
- result=$recv(anObject)._xxxDoIt();
- $recv($recv(anObject)._class())._removeCompiledMethod_(method);
- return result;
- }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:on:",{aString:aString,anObject:anObject,result:result,method:method},$globals.Compiler)});
- },
- args: ["aString", "anObject"],
- source: "evaluateExpression: aString on: anObject\x0a\x09\x22Unlike #eval: evaluate a Smalltalk expression with anObject as the receiver and answer the returned object\x22\x0a\x09| result method |\x0a\x09method := self eval: (self compileExpression: aString on: anObject).\x0a\x09method protocol: '**xxxDoIt'.\x0a\x09anObject class addCompiledMethod: method.\x0a\x09result := anObject xxxDoIt.\x0a\x09anObject class removeCompiledMethod: method.\x0a\x09^ result",
- referencedClasses: [],
- messageSends: ["eval:", "compileExpression:on:", "protocol:", "addCompiledMethod:", "class", "xxxDoIt", "removeCompiledMethod:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "install:forClass:protocol:",
- protocol: "compiling",
- fn: function (aString,aBehavior,anotherString){
- var self=this;
- var compiledMethod;
- return $core.withContext(function($ctx1) {
- compiledMethod=self._eval_forPackage_(self._compile_forClass_protocol_(aString,aBehavior,anotherString),$recv(aBehavior)._packageOfProtocol_(anotherString));
- return $recv($recv($globals.ClassBuilder)._new())._installMethod_forClass_protocol_(compiledMethod,aBehavior,anotherString);
- }, function($ctx1) {$ctx1.fill(self,"install:forClass:protocol:",{aString:aString,aBehavior:aBehavior,anotherString:anotherString,compiledMethod:compiledMethod},$globals.Compiler)});
- },
- args: ["aString", "aBehavior", "anotherString"],
- source: "install: aString forClass: aBehavior protocol: anotherString\x0a\x09| compiledMethod |\x0a\x09compiledMethod := self\x0a\x09\x09eval: (self compile: aString forClass: aBehavior protocol: anotherString)\x0a\x09\x09forPackage: (aBehavior packageOfProtocol: anotherString).\x0a\x09^ ClassBuilder new\x0a\x09\x09installMethod: compiledMethod\x0a\x09\x09forClass: aBehavior\x0a\x09\x09protocol: anotherString",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["eval:forPackage:", "compile:forClass:protocol:", "packageOfProtocol:", "installMethod:forClass:protocol:", "new"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "parse:",
- protocol: "compiling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._parse_(aString);
- }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString},$globals.Compiler)});
- },
- args: ["aString"],
- source: "parse: aString\x0a\x09^ Smalltalk parse: aString",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "parseExpression:",
- protocol: "compiling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("doIt ^ [ ".__comma(aString)).__comma(" ] value");
- $ctx1.sendIdx[","]=1;
- return self._parse_($1);
- }, function($ctx1) {$ctx1.fill(self,"parseExpression:",{aString:aString},$globals.Compiler)});
- },
- args: ["aString"],
- source: "parseExpression: aString\x0a\x09^ self parse: 'doIt ^ [ ', aString, ' ] value'",
- referencedClasses: [],
- messageSends: ["parse:", ","]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "recompile:",
- protocol: "compiling",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- $recv($recv($recv(aClass)._methodDictionary())._values())._do_displayingProgress_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv($recv(each)._methodClass()).__eq(aClass);
- $ctx2.sendIdx["="]=1;
- if($core.assert($1)){
- return self._install_forClass_protocol_($recv(each)._source(),aClass,$recv(each)._protocol());
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),"Recompiling ".__comma($recv(aClass)._name()));
- $2=$recv(aClass)._theMetaClass();
- if(($receiver = $2) == null || $receiver.isNil){
- $2;
- } else {
- var meta;
- meta=$receiver;
- $3=$recv(meta).__eq(aClass);
- if(!$core.assert($3)){
- self._recompile_(meta);
- }
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},$globals.Compiler)});
- },
- args: ["aClass"],
- source: "recompile: aClass\x0a\x09aClass methodDictionary values\x0a\x09\x09do: [ :each | each methodClass = aClass ifTrue: [ \x0a\x09\x09\x09self \x0a\x09\x09\x09\x09install: each source \x0a\x09\x09\x09\x09forClass: aClass \x0a\x09\x09\x09\x09protocol: each protocol ] ]\x0a\x09\x09displayingProgress: 'Recompiling ', aClass name.\x0a\x09aClass theMetaClass ifNotNil: [ :meta |\x0a\x09\x09meta = aClass ifFalse: [ self recompile: meta ] ]",
- referencedClasses: [],
- messageSends: ["do:displayingProgress:", "values", "methodDictionary", "ifTrue:", "=", "methodClass", "install:forClass:protocol:", "source", "protocol", ",", "name", "ifNotNil:", "theMetaClass", "ifFalse:", "recompile:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "recompileAll",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.Smalltalk)._classes())._do_displayingProgress_((function(each){
- return $core.withContext(function($ctx2) {
- return self._recompile_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),"Compiling all classes...");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"recompileAll",{},$globals.Compiler)});
- },
- args: [],
- source: "recompileAll\x0a\x09Smalltalk classes \x0a\x09\x09do: [ :each | self recompile: each ]\x0a\x09\x09displayingProgress: 'Compiling all classes...'",
- referencedClasses: ["Smalltalk"],
- messageSends: ["do:displayingProgress:", "classes", "recompile:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@source"];
- if(($receiver = $1) == null || $receiver.isNil){
- return "";
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.Compiler)});
- },
- args: [],
- source: "source\x0a\x09^ source ifNil: [ '' ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@source"]=aString;
- return self;
- },
- args: ["aString"],
- source: "source: aString\x0a\x09source := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "unknownVariables",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@unknownVariables"];
- },
- args: [],
- source: "unknownVariables\x0a\x09^ unknownVariables",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "unknownVariables:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@unknownVariables"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "unknownVariables: aCollection\x0a\x09unknownVariables := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Compiler);
- $core.addMethod(
- $core.method({
- selector: "recompile:",
- protocol: "compiling",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._new())._recompile_(aClass);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},$globals.Compiler.klass)});
- },
- args: ["aClass"],
- source: "recompile: aClass\x0a\x09self new recompile: aClass",
- referencedClasses: [],
- messageSends: ["recompile:", "new"]
- }),
- $globals.Compiler.klass);
- $core.addMethod(
- $core.method({
- selector: "recompileAll",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.Smalltalk)._classes())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._recompile_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"recompileAll",{},$globals.Compiler.klass)});
- },
- args: [],
- source: "recompileAll\x0a\x09Smalltalk classes do: [ :each |\x0a\x09\x09self recompile: each ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["do:", "classes", "recompile:"]
- }),
- $globals.Compiler.klass);
- $core.addClass("CompilerError", $globals.Error, [], "Compiler-Core");
- $globals.CompilerError.comment="I am the common superclass of all compiling errors.";
- $core.addClass("DoIt", $globals.Object, [], "Compiler-Core");
- $globals.DoIt.comment="`DoIt` is the class used to compile and evaluate expressions. See `Compiler >> evaluateExpression:`.";
- $core.addClass("Evaluator", $globals.Object, [], "Compiler-Core");
- $globals.Evaluator.comment="I evaluate code against a receiver, dispatching #evaluate:on: to the receiver.";
- $core.addMethod(
- $core.method({
- selector: "evaluate:context:",
- protocol: "evaluating",
- fn: function (aString,aContext){
- var self=this;
- var compiler,ast;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- compiler=$recv($globals.Compiler)._new();
- $recv((function(){
- return $core.withContext(function($ctx2) {
- ast=$recv(compiler)._parseExpression_(aString);
- return ast;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(ex){
- return $core.withContext(function($ctx2) {
- throw $early=[$recv($globals.Terminal)._alert_($recv(ex)._messageText())];
- }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,2)});
- }));
- $1=$recv($globals.AISemanticAnalyzer)._on_($recv($recv(aContext)._receiver())._class());
- $recv($1)._context_(aContext);
- $recv($1)._visit_(ast);
- return $recv(aContext)._evaluateNode_(ast);
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"evaluate:context:",{aString:aString,aContext:aContext,compiler:compiler,ast:ast},$globals.Evaluator)});
- },
- args: ["aString", "aContext"],
- source: "evaluate: aString context: aContext\x0a\x09\x22Similar to #evaluate:for:, with the following differences:\x0a\x09- instead of compiling and running `aString`, `aString` is interpreted using an `ASTInterpreter`\x0a\x09- instead of evaluating against a receiver, evaluate in the context of `aContext`\x22\x0a\x0a\x09| compiler ast |\x0a\x09\x0a\x09compiler := Compiler new.\x0a\x09[ ast := compiler parseExpression: aString ] \x0a\x09\x09on: Error \x0a\x09\x09do: [ :ex | ^ Terminal alert: ex messageText ].\x0a\x09\x09\x0a\x09(AISemanticAnalyzer on: aContext receiver class)\x0a\x09\x09context: aContext;\x0a\x09\x09visit: ast.\x0a\x0a\x09^ aContext evaluateNode: ast",
- referencedClasses: ["Compiler", "Error", "Terminal", "AISemanticAnalyzer"],
- messageSends: ["new", "on:do:", "parseExpression:", "alert:", "messageText", "context:", "on:", "class", "receiver", "visit:", "evaluateNode:"]
- }),
- $globals.Evaluator);
- $core.addMethod(
- $core.method({
- selector: "evaluate:for:",
- protocol: "evaluating",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anObject)._evaluate_on_(aString,self);
- }, function($ctx1) {$ctx1.fill(self,"evaluate:for:",{aString:aString,anObject:anObject},$globals.Evaluator)});
- },
- args: ["aString", "anObject"],
- source: "evaluate: aString for: anObject\x0a\x09^ anObject evaluate: aString on: self",
- referencedClasses: [],
- messageSends: ["evaluate:on:"]
- }),
- $globals.Evaluator);
- $core.addMethod(
- $core.method({
- selector: "evaluate:receiver:",
- protocol: "evaluating",
- fn: function (aString,anObject){
- var self=this;
- var compiler;
- return $core.withContext(function($ctx1) {
- var $early={};
- try {
- compiler=$recv($globals.Compiler)._new();
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(compiler)._parseExpression_(aString);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(ex){
- return $core.withContext(function($ctx2) {
- throw $early=[$recv($globals.Terminal)._alert_($recv(ex)._messageText())];
- }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,2)});
- }));
- return $recv(compiler)._evaluateExpression_on_(aString,anObject);
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"evaluate:receiver:",{aString:aString,anObject:anObject,compiler:compiler},$globals.Evaluator)});
- },
- args: ["aString", "anObject"],
- source: "evaluate: aString receiver: anObject\x0a\x09| compiler |\x0a\x09\x0a\x09compiler := Compiler new.\x0a\x09[ compiler parseExpression: aString ] \x0a\x09\x09on: Error \x0a\x09\x09do: [ :ex | ^ Terminal alert: ex messageText ].\x0a\x0a\x09^ compiler evaluateExpression: aString on: anObject",
- referencedClasses: ["Compiler", "Error", "Terminal"],
- messageSends: ["new", "on:do:", "parseExpression:", "alert:", "messageText", "evaluateExpression:on:"]
- }),
- $globals.Evaluator);
- $core.addMethod(
- $core.method({
- selector: "evaluate:for:",
- protocol: "instance creation",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._new())._evaluate_for_(aString,anObject);
- }, function($ctx1) {$ctx1.fill(self,"evaluate:for:",{aString:aString,anObject:anObject},$globals.Evaluator.klass)});
- },
- args: ["aString", "anObject"],
- source: "evaluate: aString for: anObject\x0a\x09^ self new evaluate: aString for: anObject",
- referencedClasses: [],
- messageSends: ["evaluate:for:", "new"]
- }),
- $globals.Evaluator.klass);
- $core.addMethod(
- $core.method({
- selector: "asVariableName",
- protocol: "*Compiler-Core",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($recv($globals.Smalltalk)._reservedWords())._includes_(self);
- if($core.assert($1)){
- return self.__comma("_");
- } else {
- return self;
- }
- }, function($ctx1) {$ctx1.fill(self,"asVariableName",{},$globals.String)});
- },
- args: [],
- source: "asVariableName\x0a\x09^ (Smalltalk reservedWords includes: self)\x0a\x09\x09ifTrue: [ self, '_' ]\x0a\x09\x09ifFalse: [ self ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifTrue:ifFalse:", "includes:", "reservedWords", ","]
- }),
- $globals.String);
- });
- define('amber_core/Compiler-AST',["amber/boot", "amber_core/Kernel-Dag", "amber_core/Kernel-Methods"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Compiler-AST");
- $core.packages["Compiler-AST"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Compiler-AST"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("ASTNode", $globals.DagParentNode, ["parent", "position", "source", "shouldBeAliased"], "Compiler-AST");
- $globals.ASTNode.comment="I am the abstract root class of the abstract syntax tree.\x0a\x0aConcrete classes should implement `#accept:` to allow visiting.\x0a\x0a`position` holds a point containing line and column number of the symbol location in the original source file.";
- $core.addMethod(
- $core.method({
- selector: "inPosition:",
- protocol: "testing",
- fn: function (aPoint){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._positionStart()).__lt_eq(aPoint))._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._positionEnd()).__gt_eq(aPoint);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"inPosition:",{aPoint:aPoint},$globals.ASTNode)});
- },
- args: ["aPoint"],
- source: "inPosition: aPoint\x0a\x09^ (self positionStart <= aPoint and: [\x0a\x09\x09self positionEnd >= aPoint ])",
- referencedClasses: [],
- messageSends: ["and:", "<=", "positionStart", ">=", "positionEnd"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isAssignmentNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isAssignmentNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isBlockNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isBlockNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isBlockSequenceNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isBlockSequenceNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isCascadeNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isCascadeNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isImmutable\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isJSStatementNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isJSStatementNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isNavigationNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isNavigationNode\x0a\x09\x22Answer true if the node can be navigated to\x22\x0a\x09\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isReturnNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isReturnNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isSendNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isSendNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isSequenceNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isSequenceNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isSuperKeyword",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isSuperKeyword\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isValueNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isValueNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isVariableNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isVariableNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "location:",
- protocol: "accessing",
- fn: function (aLocation){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=$recv(aLocation)._start();
- $ctx1.sendIdx["start"]=1;
- $2=$recv($3)._line();
- $1=$recv($2).__at($recv($recv(aLocation)._start())._column());
- self._position_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"location:",{aLocation:aLocation},$globals.ASTNode)});
- },
- args: ["aLocation"],
- source: "location: aLocation\x0a\x09self position: aLocation start line @ aLocation start column",
- referencedClasses: [],
- messageSends: ["position:", "@", "line", "start", "column"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._parent();
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- var node;
- node=$receiver;
- return $recv(node)._method();
- }
- }, function($ctx1) {$ctx1.fill(self,"method",{},$globals.ASTNode)});
- },
- args: [],
- source: "method\x0a\x09^ self parent ifNotNil: [ :node | node method ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "parent", "method"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "navigationNodeAt:ifAbsent:",
- protocol: "accessing",
- fn: function (aPoint,aBlock){
- var self=this;
- var children;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- var $early={};
- try {
- children=$recv(self._allDagChildren())._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._isNavigationNode())._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(each)._inPosition_(aPoint);
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $recv(children)._ifEmpty_((function(){
- return $core.withContext(function($ctx2) {
- throw $early=[$recv(aBlock)._value()];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return $recv($recv($recv(children)._asArray())._sort_((function(a,b){
- return $core.withContext(function($ctx2) {
- $2=$recv(a)._positionStart();
- $ctx2.sendIdx["positionStart"]=1;
- $1=$recv($2)._dist_(aPoint);
- $ctx2.sendIdx["dist:"]=1;
- return $recv($1).__lt_eq($recv($recv(b)._positionStart())._dist_(aPoint));
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,4)});
- })))._first();
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"navigationNodeAt:ifAbsent:",{aPoint:aPoint,aBlock:aBlock,children:children},$globals.ASTNode)});
- },
- args: ["aPoint", "aBlock"],
- source: "navigationNodeAt: aPoint ifAbsent: aBlock\x0a\x09\x22Answer the navigation node in the receiver's tree at aPoint \x0a\x09or nil if no navigation node was found.\x0a\x09\x0a\x09See `node >> isNaviationNode`\x22\x0a\x09\x0a\x09| children |\x0a\x09\x0a\x09children := self allDagChildren select: [ :each | \x0a\x09\x09each isNavigationNode and: [ each inPosition: aPoint ] ].\x0a\x09\x0a\x09children ifEmpty: [ ^ aBlock value ].\x0a\x09\x0a\x09^ (children asArray sort: [ :a :b | \x0a\x09\x09(a positionStart dist: aPoint) <= \x0a\x09\x09(b positionStart dist: aPoint) ]) first",
- referencedClasses: [],
- messageSends: ["select:", "allDagChildren", "and:", "isNavigationNode", "inPosition:", "ifEmpty:", "value", "first", "sort:", "asArray", "<=", "dist:", "positionStart"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "parent",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@parent"];
- },
- args: [],
- source: "parent\x0a\x09^ parent",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "parent:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@parent"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "parent: aNode\x0a\x09parent := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "position",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=self["@position"];
- if(($receiver = $1) == null || $receiver.isNil){
- $2=self._parent();
- if(($receiver = $2) == null || $receiver.isNil){
- return $2;
- } else {
- var node;
- node=$receiver;
- return $recv(node)._position();
- }
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"position",{},$globals.ASTNode)});
- },
- args: [],
- source: "position\x0a\x09\x22answer the line and column of the receiver in the source code\x22\x0a\x09\x0a\x09^ position ifNil: [ \x0a\x09\x09self parent ifNotNil: [ :node | node position ] ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "ifNotNil:", "parent", "position"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "position:",
- protocol: "accessing",
- fn: function (aPosition){
- var self=this;
- self["@position"]=aPosition;
- return self;
- },
- args: ["aPosition"],
- source: "position: aPosition\x0a\x09position := aPosition",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "positionEnd",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$6,$5,$4,$3,$2;
- $1=self._positionStart();
- $6=self._source();
- $ctx1.sendIdx["source"]=1;
- $5=$recv($6)._lines();
- $ctx1.sendIdx["lines"]=1;
- $4=$recv($5)._size();
- $ctx1.sendIdx["size"]=1;
- $3=$recv($4).__minus((1));
- $ctx1.sendIdx["-"]=1;
- $2=$recv($3).__at($recv($recv($recv($recv(self._source())._lines())._last())._size()).__minus((1)));
- return $recv($1).__plus($2);
- }, function($ctx1) {$ctx1.fill(self,"positionEnd",{},$globals.ASTNode)});
- },
- args: [],
- source: "positionEnd\x0a\x09^ self positionStart + ((self source lines size - 1) @ (self source lines last size - 1))",
- referencedClasses: [],
- messageSends: ["+", "positionStart", "@", "-", "size", "lines", "source", "last"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "positionStart",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._position();
- }, function($ctx1) {$ctx1.fill(self,"positionStart",{},$globals.ASTNode)});
- },
- args: [],
- source: "positionStart\x0a\x09^ self position",
- referencedClasses: [],
- messageSends: ["position"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "requiresSmalltalkContext",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._dagChildren())._detect_ifNone_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._requiresSmalltalkContext();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return nil;
- })))._notNil();
- }, function($ctx1) {$ctx1.fill(self,"requiresSmalltalkContext",{},$globals.ASTNode)});
- },
- args: [],
- source: "requiresSmalltalkContext\x0a\x09\x22Answer true if the receiver requires a smalltalk context.\x0a\x09Only send nodes require a context.\x0a\x09\x0a\x09If no node requires a context, the method will be compiled without one.\x0a\x09See `IRJSTranslator` and `JSStream` for context creation\x22\x0a\x09\x0a\x09^ (self dagChildren \x0a\x09\x09detect: [ :each | each requiresSmalltalkContext ]\x0a\x09\x09ifNone: [ nil ]) notNil",
- referencedClasses: [],
- messageSends: ["notNil", "detect:ifNone:", "dagChildren", "requiresSmalltalkContext"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "shouldBeAliased",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@shouldBeAliased"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"shouldBeAliased",{},$globals.ASTNode)});
- },
- args: [],
- source: "shouldBeAliased\x0a\x09^ shouldBeAliased ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "shouldBeAliased:",
- protocol: "accessing",
- fn: function (aBoolean){
- var self=this;
- self["@shouldBeAliased"]=aBoolean;
- return self;
- },
- args: ["aBoolean"],
- source: "shouldBeAliased: aBoolean\x0a\x09shouldBeAliased := aBoolean",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "size",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._source())._size();
- }, function($ctx1) {$ctx1.fill(self,"size",{},$globals.ASTNode)});
- },
- args: [],
- source: "size\x0a\x09^ self source size",
- referencedClasses: [],
- messageSends: ["size", "source"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@source"];
- if(($receiver = $1) == null || $receiver.isNil){
- return "";
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.ASTNode)});
- },
- args: [],
- source: "source\x0a\x09^ source ifNil: [ '' ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@source"]=aString;
- return self;
- },
- args: ["aString"],
- source: "source: aString\x0a\x09source := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "withTail:",
- protocol: "building",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv(aCollection)._inject_into_(self,(function(receiver,send){
- return $core.withContext(function($ctx2) {
- $1=$recv($globals.SendNode)._new();
- $recv($1)._position_($recv(send)._position());
- $recv($1)._source_($recv(send)._source());
- $recv($1)._receiver_(receiver);
- $recv($1)._selector_($recv(send)._selector());
- $recv($1)._arguments_($recv(send)._arguments());
- return $recv($1)._yourself();
- }, function($ctx2) {$ctx2.fillBlock({receiver:receiver,send:send},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"withTail:",{aCollection:aCollection},$globals.ASTNode)});
- },
- args: ["aCollection"],
- source: "withTail: aCollection\x0a\x09^ aCollection inject: self into: [\x0a\x09\x09:receiver :send | SendNode new\x0a\x09\x09\x09position: send position;\x0a\x09\x09\x09source: send source;\x0a\x09\x09\x09receiver: receiver;\x0a\x09\x09\x09selector: send selector;\x0a\x09\x09\x09arguments: send arguments;\x0a\x09\x09\x09yourself ]",
- referencedClasses: ["SendNode"],
- messageSends: ["inject:into:", "position:", "new", "position", "source:", "source", "receiver:", "selector:", "selector", "arguments:", "arguments", "yourself"]
- }),
- $globals.ASTNode);
- $core.addClass("AssignmentNode", $globals.ASTNode, ["left", "right"], "Compiler-AST");
- $globals.AssignmentNode.comment="I represent an assignment node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitAssignmentNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.AssignmentNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitAssignmentNode: self",
- referencedClasses: [],
- messageSends: ["visitAssignmentNode:"]
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "dagChildren",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Array)._with_with_(self._left(),self._right());
- }, function($ctx1) {$ctx1.fill(self,"dagChildren",{},$globals.AssignmentNode)});
- },
- args: [],
- source: "dagChildren\x0a\x09^ Array with: self left with: self right",
- referencedClasses: ["Array"],
- messageSends: ["with:with:", "left", "right"]
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "isAssignmentNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isAssignmentNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "left",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@left"];
- },
- args: [],
- source: "left\x0a\x09^ left",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "left:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@left"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "left: aNode\x0a\x09left := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "right",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@right"];
- },
- args: [],
- source: "right\x0a\x09^ right",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "right:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@right"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "right: aNode\x0a\x09right := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AssignmentNode);
- $core.addClass("BlockNode", $globals.ASTNode, ["parameters", "scope"], "Compiler-AST");
- $globals.BlockNode.comment="I represent an block closure node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitBlockNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.BlockNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitBlockNode: self",
- referencedClasses: [],
- messageSends: ["visitBlockNode:"]
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "isBlockNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isBlockNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "parameters",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@parameters"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@parameters"]=$recv($globals.Array)._new();
- return self["@parameters"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"parameters",{},$globals.BlockNode)});
- },
- args: [],
- source: "parameters\x0a\x09^ parameters ifNil: [ parameters := Array new ]",
- referencedClasses: ["Array"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "parameters:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@parameters"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "parameters: aCollection\x0a\x09parameters := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@scope"];
- },
- args: [],
- source: "scope\x0a\x09^ scope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "scope:",
- protocol: "accessing",
- fn: function (aLexicalScope){
- var self=this;
- self["@scope"]=aLexicalScope;
- return self;
- },
- args: ["aLexicalScope"],
- source: "scope: aLexicalScope\x0a\x09scope := aLexicalScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockNode);
- $core.addClass("CascadeNode", $globals.ASTNode, ["receiver"], "Compiler-AST");
- $globals.CascadeNode.comment="I represent an cascade node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitCascadeNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.CascadeNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitCascadeNode: self",
- referencedClasses: [],
- messageSends: ["visitCascadeNode:"]
- }),
- $globals.CascadeNode);
- $core.addMethod(
- $core.method({
- selector: "isCascadeNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isCascadeNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CascadeNode);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@receiver"];
- },
- args: [],
- source: "receiver\x0a\x09^ receiver",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CascadeNode);
- $core.addMethod(
- $core.method({
- selector: "receiver:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@receiver"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "receiver: aNode\x0a\x09receiver := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CascadeNode);
- $core.addClass("DynamicArrayNode", $globals.ASTNode, [], "Compiler-AST");
- $globals.DynamicArrayNode.comment="I represent an dynamic array node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitDynamicArrayNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.DynamicArrayNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitDynamicArrayNode: self",
- referencedClasses: [],
- messageSends: ["visitDynamicArrayNode:"]
- }),
- $globals.DynamicArrayNode);
- $core.addClass("DynamicDictionaryNode", $globals.ASTNode, [], "Compiler-AST");
- $globals.DynamicDictionaryNode.comment="I represent an dynamic dictionary node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitDynamicDictionaryNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.DynamicDictionaryNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitDynamicDictionaryNode: self",
- referencedClasses: [],
- messageSends: ["visitDynamicDictionaryNode:"]
- }),
- $globals.DynamicDictionaryNode);
- $core.addClass("JSStatementNode", $globals.ASTNode, [], "Compiler-AST");
- $globals.JSStatementNode.comment="I represent an JavaScript statement node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitJSStatementNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.JSStatementNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitJSStatementNode: self",
- referencedClasses: [],
- messageSends: ["visitJSStatementNode:"]
- }),
- $globals.JSStatementNode);
- $core.addMethod(
- $core.method({
- selector: "isJSStatementNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isJSStatementNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSStatementNode);
- $core.addMethod(
- $core.method({
- selector: "requiresSmalltalkContext",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "requiresSmalltalkContext\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSStatementNode);
- $core.addClass("MethodNode", $globals.ASTNode, ["selector", "arguments", "source", "scope", "classReferences", "sendIndexes"], "Compiler-AST");
- $globals.MethodNode.comment="I represent an method node.\x0a\x0aA method node must be the root and only method node of a valid AST.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitMethodNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.MethodNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitMethodNode: self",
- referencedClasses: [],
- messageSends: ["visitMethodNode:"]
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@arguments"];
- if(($receiver = $1) == null || $receiver.isNil){
- return [];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"arguments",{},$globals.MethodNode)});
- },
- args: [],
- source: "arguments\x0a\x09^ arguments ifNil: [ #() ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "arguments:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@arguments"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "arguments: aCollection\x0a\x09arguments := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "classReferences",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@classReferences"];
- },
- args: [],
- source: "classReferences\x0a\x09^ classReferences",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "classReferences:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@classReferences"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "classReferences: aCollection\x0a\x09classReferences := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "messageSends",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._sendIndexes())._keys();
- }, function($ctx1) {$ctx1.fill(self,"messageSends",{},$globals.MethodNode)});
- },
- args: [],
- source: "messageSends\x0a\x09^ self sendIndexes keys",
- referencedClasses: [],
- messageSends: ["keys", "sendIndexes"]
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "method\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@scope"];
- },
- args: [],
- source: "scope\x0a\x09^ scope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "scope:",
- protocol: "accessing",
- fn: function (aMethodScope){
- var self=this;
- self["@scope"]=aMethodScope;
- return self;
- },
- args: ["aMethodScope"],
- source: "scope: aMethodScope\x0a\x09scope := aMethodScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@selector"];
- },
- args: [],
- source: "selector\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@selector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09selector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "sendIndexes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@sendIndexes"];
- },
- args: [],
- source: "sendIndexes\x0a\x09^ sendIndexes",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "sendIndexes:",
- protocol: "accessing",
- fn: function (aDictionary){
- var self=this;
- self["@sendIndexes"]=aDictionary;
- return self;
- },
- args: ["aDictionary"],
- source: "sendIndexes: aDictionary\x0a\x09sendIndexes := aDictionary",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "sequenceNode",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- $recv(self._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(each)._isSequenceNode();
- if($core.assert($1)){
- throw $early=[each];
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return nil;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"sequenceNode",{},$globals.MethodNode)});
- },
- args: [],
- source: "sequenceNode\x0a\x09self dagChildren do: [ :each |\x0a\x09\x09each isSequenceNode ifTrue: [ ^ each ] ].\x0a\x09\x09\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: ["do:", "dagChildren", "ifTrue:", "isSequenceNode"]
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@source"];
- },
- args: [],
- source: "source\x0a\x09^ source",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@source"]=aString;
- return self;
- },
- args: ["aString"],
- source: "source: aString\x0a\x09source := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodNode);
- $core.addClass("ReturnNode", $globals.ASTNode, ["scope"], "Compiler-AST");
- $globals.ReturnNode.comment="I represent an return node. At the AST level, there is not difference between a local return or non-local return.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitReturnNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.ReturnNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitReturnNode: self",
- referencedClasses: [],
- messageSends: ["visitReturnNode:"]
- }),
- $globals.ReturnNode);
- $core.addMethod(
- $core.method({
- selector: "isReturnNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isReturnNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ReturnNode);
- $core.addMethod(
- $core.method({
- selector: "nonLocalReturn",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._scope())._isMethodScope())._not();
- }, function($ctx1) {$ctx1.fill(self,"nonLocalReturn",{},$globals.ReturnNode)});
- },
- args: [],
- source: "nonLocalReturn\x0a\x09^ self scope isMethodScope not",
- referencedClasses: [],
- messageSends: ["not", "isMethodScope", "scope"]
- }),
- $globals.ReturnNode);
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@scope"];
- },
- args: [],
- source: "scope\x0a\x09^ scope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ReturnNode);
- $core.addMethod(
- $core.method({
- selector: "scope:",
- protocol: "accessing",
- fn: function (aLexicalScope){
- var self=this;
- self["@scope"]=aLexicalScope;
- return self;
- },
- args: ["aLexicalScope"],
- source: "scope: aLexicalScope\x0a\x09scope := aLexicalScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ReturnNode);
- $core.addClass("SendNode", $globals.ASTNode, ["selector", "arguments", "receiver", "index", "shouldBeInlined"], "Compiler-AST");
- $globals.SendNode.comment="I represent an message send node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitSendNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.SendNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitSendNode: self",
- referencedClasses: [],
- messageSends: ["visitSendNode:"]
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@arguments"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@arguments"]=[];
- return self["@arguments"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"arguments",{},$globals.SendNode)});
- },
- args: [],
- source: "arguments\x0a\x09^ arguments ifNil: [ arguments := #() ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "arguments:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@arguments"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "arguments: aCollection\x0a\x09arguments := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "dagChildren",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- $1=self._receiver();
- $ctx1.sendIdx["receiver"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $2=self._arguments();
- $ctx1.sendIdx["arguments"]=1;
- return $recv($2)._copy();
- } else {
- $1;
- }
- $3=$recv($globals.Array)._with_(self._receiver());
- $recv($3)._addAll_(self._arguments());
- return $recv($3)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"dagChildren",{},$globals.SendNode)});
- },
- args: [],
- source: "dagChildren\x0a\x09self receiver ifNil: [ ^ self arguments copy ].\x0a\x09\x0a\x09^ (Array with: self receiver)\x0a\x09\x09addAll: self arguments;\x0a\x09\x09yourself",
- referencedClasses: ["Array"],
- messageSends: ["ifNil:", "receiver", "copy", "arguments", "addAll:", "with:", "yourself"]
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "index",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@index"];
- },
- args: [],
- source: "index\x0a\x09^ index",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "index:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@index"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "index: anInteger\x0a\x09index := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "isNavigationNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isNavigationNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "isSendNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSendNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "navigationLink",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._selector();
- }, function($ctx1) {$ctx1.fill(self,"navigationLink",{},$globals.SendNode)});
- },
- args: [],
- source: "navigationLink\x0a\x09^ self selector",
- referencedClasses: [],
- messageSends: ["selector"]
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@receiver"];
- },
- args: [],
- source: "receiver\x0a\x09^ receiver",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "receiver:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@receiver"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "receiver: aNode\x0a\x09receiver := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "requiresSmalltalkContext",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "requiresSmalltalkContext\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@selector"];
- },
- args: [],
- source: "selector\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@selector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09selector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "shouldBeInlined",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@shouldBeInlined"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"shouldBeInlined",{},$globals.SendNode)});
- },
- args: [],
- source: "shouldBeInlined\x0a\x09^ shouldBeInlined ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "shouldBeInlined:",
- protocol: "accessing",
- fn: function (aBoolean){
- var self=this;
- self["@shouldBeInlined"]=aBoolean;
- return self;
- },
- args: ["aBoolean"],
- source: "shouldBeInlined: aBoolean\x0a\x09shouldBeInlined := aBoolean",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "superSend",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._receiver();
- $ctx1.sendIdx["receiver"]=1;
- $1=$recv($2)._notNil();
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._receiver())._isSuperKeyword();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"superSend",{},$globals.SendNode)});
- },
- args: [],
- source: "superSend\x0a\x09^ self receiver notNil and: [ self receiver isSuperKeyword ]",
- referencedClasses: [],
- messageSends: ["and:", "notNil", "receiver", "isSuperKeyword"]
- }),
- $globals.SendNode);
- $core.addClass("SequenceNode", $globals.ASTNode, ["temps", "scope"], "Compiler-AST");
- $globals.SequenceNode.comment="I represent an sequence node. A sequence represent a set of instructions inside the same scope (the method scope or a block scope).";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitSequenceNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.SequenceNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitSequenceNode: self",
- referencedClasses: [],
- messageSends: ["visitSequenceNode:"]
- }),
- $globals.SequenceNode);
- $core.addMethod(
- $core.method({
- selector: "asBlockSequenceNode",
- protocol: "building",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.BlockSequenceNode)._new();
- $recv($1)._position_(self._position());
- $recv($1)._source_(self._source());
- $recv($1)._dagChildren_(self._dagChildren());
- $recv($1)._temps_(self._temps());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"asBlockSequenceNode",{},$globals.SequenceNode)});
- },
- args: [],
- source: "asBlockSequenceNode\x0a\x09^ BlockSequenceNode new\x0a\x09\x09position: self position;\x0a\x09\x09source: self source;\x0a\x09\x09dagChildren: self dagChildren;\x0a\x09\x09temps: self temps;\x0a\x09\x09yourself",
- referencedClasses: ["BlockSequenceNode"],
- messageSends: ["position:", "new", "position", "source:", "source", "dagChildren:", "dagChildren", "temps:", "temps", "yourself"]
- }),
- $globals.SequenceNode);
- $core.addMethod(
- $core.method({
- selector: "isSequenceNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSequenceNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceNode);
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@scope"];
- },
- args: [],
- source: "scope\x0a\x09^ scope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceNode);
- $core.addMethod(
- $core.method({
- selector: "scope:",
- protocol: "accessing",
- fn: function (aLexicalScope){
- var self=this;
- self["@scope"]=aLexicalScope;
- return self;
- },
- args: ["aLexicalScope"],
- source: "scope: aLexicalScope\x0a\x09scope := aLexicalScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceNode);
- $core.addMethod(
- $core.method({
- selector: "temps",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@temps"];
- if(($receiver = $1) == null || $receiver.isNil){
- return [];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"temps",{},$globals.SequenceNode)});
- },
- args: [],
- source: "temps\x0a\x09^ temps ifNil: [ #() ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.SequenceNode);
- $core.addMethod(
- $core.method({
- selector: "temps:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@temps"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "temps: aCollection\x0a\x09temps := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SequenceNode);
- $core.addClass("BlockSequenceNode", $globals.SequenceNode, [], "Compiler-AST");
- $globals.BlockSequenceNode.comment="I represent an special sequence node for block scopes.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitBlockSequenceNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.BlockSequenceNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitBlockSequenceNode: self",
- referencedClasses: [],
- messageSends: ["visitBlockSequenceNode:"]
- }),
- $globals.BlockSequenceNode);
- $core.addMethod(
- $core.method({
- selector: "isBlockSequenceNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isBlockSequenceNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockSequenceNode);
- $core.addClass("ValueNode", $globals.ASTNode, ["value"], "Compiler-AST");
- $globals.ValueNode.comment="I represent a value node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitValueNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.ValueNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitValueNode: self",
- referencedClasses: [],
- messageSends: ["visitValueNode:"]
- }),
- $globals.ValueNode);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._value())._isImmutable();
- }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},$globals.ValueNode)});
- },
- args: [],
- source: "isImmutable\x0a\x09^ self value isImmutable",
- referencedClasses: [],
- messageSends: ["isImmutable", "value"]
- }),
- $globals.ValueNode);
- $core.addMethod(
- $core.method({
- selector: "isValueNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isValueNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ValueNode);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@value"];
- },
- args: [],
- source: "value\x0a\x09^ value",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ValueNode);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@value"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "value: anObject\x0a\x09value := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ValueNode);
- $core.addClass("VariableNode", $globals.ValueNode, ["assigned", "binding"], "Compiler-AST");
- $globals.VariableNode.comment="I represent an variable node.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitVariableNode_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.VariableNode)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitVariableNode: self",
- referencedClasses: [],
- messageSends: ["visitVariableNode:"]
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "alias",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._binding())._alias();
- }, function($ctx1) {$ctx1.fill(self,"alias",{},$globals.VariableNode)});
- },
- args: [],
- source: "alias\x0a\x09^ self binding alias",
- referencedClasses: [],
- messageSends: ["alias", "binding"]
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "assigned",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@assigned"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"assigned",{},$globals.VariableNode)});
- },
- args: [],
- source: "assigned\x0a\x09^ assigned ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "assigned:",
- protocol: "accessing",
- fn: function (aBoolean){
- var self=this;
- self["@assigned"]=aBoolean;
- return self;
- },
- args: ["aBoolean"],
- source: "assigned: aBoolean\x0a\x09assigned := aBoolean",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "beAssigned",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._binding())._validateAssignment();
- self["@assigned"]=true;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"beAssigned",{},$globals.VariableNode)});
- },
- args: [],
- source: "beAssigned\x0a\x09self binding validateAssignment.\x0a\x09assigned := true",
- referencedClasses: [],
- messageSends: ["validateAssignment", "binding"]
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "binding",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@binding"];
- },
- args: [],
- source: "binding\x0a\x09^ binding",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "binding:",
- protocol: "accessing",
- fn: function (aScopeVar){
- var self=this;
- self["@binding"]=aScopeVar;
- return self;
- },
- args: ["aScopeVar"],
- source: "binding: aScopeVar\x0a\x09binding := aScopeVar",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "isArgument",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._binding())._isArgVar();
- }, function($ctx1) {$ctx1.fill(self,"isArgument",{},$globals.VariableNode)});
- },
- args: [],
- source: "isArgument\x0a\x09^ self binding isArgVar",
- referencedClasses: [],
- messageSends: ["isArgVar", "binding"]
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._binding())._isImmutable();
- }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},$globals.VariableNode)});
- },
- args: [],
- source: "isImmutable\x0a\x09^ self binding isImmutable",
- referencedClasses: [],
- messageSends: ["isImmutable", "binding"]
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "isNavigationNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isNavigationNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "isSuperKeyword",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._value()).__eq("super");
- }, function($ctx1) {$ctx1.fill(self,"isSuperKeyword",{},$globals.VariableNode)});
- },
- args: [],
- source: "isSuperKeyword\x0a\x09^ self value = 'super'",
- referencedClasses: [],
- messageSends: ["=", "value"]
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "isVariableNode",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isVariableNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.VariableNode);
- $core.addMethod(
- $core.method({
- selector: "navigationLink",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._value();
- }, function($ctx1) {$ctx1.fill(self,"navigationLink",{},$globals.VariableNode)});
- },
- args: [],
- source: "navigationLink\x0a\x09^ self value",
- referencedClasses: [],
- messageSends: ["value"]
- }),
- $globals.VariableNode);
- $core.addClass("ParentFakingPathDagVisitor", $globals.PathDagVisitor, ["setParentSelector"], "Compiler-AST");
- $globals.ParentFakingPathDagVisitor.comment="I am base class of `DagNode` visitor.\x0a\x0aI hold the path of ancestors up to actual node\x0ain `self path`.";
- $core.addMethod(
- $core.method({
- selector: "visit:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(self._path())._ifNotEmpty_((function(p){
- return $core.withContext(function($ctx2) {
- return $recv(aNode)._parent_($recv(p)._last());
- }, function($ctx2) {$ctx2.fillBlock({p:p},$ctx1,1)});
- }));
- $1=(
- $ctx1.supercall = true,
- ($globals.ParentFakingPathDagVisitor.superclass||$boot.nilAsClass).fn.prototype._visit_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"visit:",{aNode:aNode},$globals.ParentFakingPathDagVisitor)});
- },
- args: ["aNode"],
- source: "visit: aNode\x0a\x09self path ifNotEmpty: [ :p | aNode parent: p last ].\x0a\x09^ super visit: aNode",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "path", "parent:", "last", "visit:"]
- }),
- $globals.ParentFakingPathDagVisitor);
- $core.addClass("NodeVisitor", $globals.ParentFakingPathDagVisitor, [], "Compiler-AST");
- $globals.NodeVisitor.comment="I am the abstract super class of all AST node visitors.";
- $core.addMethod(
- $core.method({
- selector: "visitAssignmentNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitAssignmentNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitAssignmentNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitBlockNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitBlockNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitBlockNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitBlockSequenceNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitSequenceNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitBlockSequenceNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitBlockSequenceNode: aNode\x0a\x09^ self visitSequenceNode: aNode",
- referencedClasses: [],
- messageSends: ["visitSequenceNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitCascadeNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitCascadeNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitCascadeNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitDagNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNodeVariantSimple_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitDagNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitDagNode: aNode\x0a\x09^ self visitDagNodeVariantSimple: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNodeVariantSimple:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitDynamicArrayNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitDynamicArrayNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitDynamicArrayNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitDynamicDictionaryNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitDynamicDictionaryNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitDynamicDictionaryNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitJSStatementNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitJSStatementNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitJSStatementNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitMethodNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitMethodNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitMethodNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitReturnNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitReturnNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitReturnNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitSendNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitSendNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitSequenceNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitSequenceNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitSequenceNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitValueNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitValueNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitValueNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitVariableNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode},$globals.NodeVisitor)});
- },
- args: ["aNode"],
- source: "visitVariableNode: aNode\x0a\x09^ self visitDagNode: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.NodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "ast",
- protocol: "*Compiler-AST",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._source();
- $ctx1.sendIdx["source"]=1;
- $recv($1)._ifEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return self._error_("Method source is empty");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return $recv($globals.Smalltalk)._parse_(self._source());
- }, function($ctx1) {$ctx1.fill(self,"ast",{},$globals.CompiledMethod)});
- },
- args: [],
- source: "ast\x0a\x09self source ifEmpty: [ self error: 'Method source is empty' ].\x0a\x09\x0a\x09^ Smalltalk parse: self source",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifEmpty:", "source", "error:", "parse:"]
- }),
- $globals.CompiledMethod);
- });
- define('amber_core/Compiler-Semantic',["amber/boot", "amber_core/Compiler-AST", "amber_core/Compiler-Core", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Compiler-Semantic");
- $core.packages["Compiler-Semantic"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Compiler-Semantic"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("LexicalScope", $globals.Object, ["node", "instruction", "temps", "args", "outerScope", "blockIndex"], "Compiler-Semantic");
- $globals.LexicalScope.comment="I represent a lexical scope where variable names are associated with ScopeVars\x0aInstances are used for block scopes. Method scopes are instances of MethodLexicalScope.\x0a\x0aI am attached to a ScopeVar and method/block nodes.\x0aEach context (method/closure) get a fresh scope that inherits from its outer scope.";
- $core.addMethod(
- $core.method({
- selector: "addArg:",
- protocol: "adding",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._args();
- $ctx1.sendIdx["args"]=1;
- $recv($1)._at_put_(aString,$recv($globals.ArgVar)._on_(aString));
- $recv($recv(self._args())._at_(aString))._scope_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addArg:",{aString:aString},$globals.LexicalScope)});
- },
- args: ["aString"],
- source: "addArg: aString\x0a\x09self args at: aString put: (ArgVar on: aString).\x0a\x09(self args at: aString) scope: self",
- referencedClasses: ["ArgVar"],
- messageSends: ["at:put:", "args", "on:", "scope:", "at:"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "addTemp:",
- protocol: "adding",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._temps();
- $ctx1.sendIdx["temps"]=1;
- $recv($1)._at_put_(aString,$recv($globals.TempVar)._on_(aString));
- $recv($recv(self._temps())._at_(aString))._scope_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addTemp:",{aString:aString},$globals.LexicalScope)});
- },
- args: ["aString"],
- source: "addTemp: aString\x0a\x09self temps at: aString put: (TempVar on: aString).\x0a\x09(self temps at: aString) scope: self",
- referencedClasses: ["TempVar"],
- messageSends: ["at:put:", "temps", "on:", "scope:", "at:"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "alias",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "$ctx".__comma($recv(self._scopeLevel())._asString());
- }, function($ctx1) {$ctx1.fill(self,"alias",{},$globals.LexicalScope)});
- },
- args: [],
- source: "alias\x0a\x09^ '$ctx', self scopeLevel asString",
- referencedClasses: [],
- messageSends: [",", "asString", "scopeLevel"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "allVariableNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._args())._keys();
- $ctx1.sendIdx["keys"]=1;
- return $recv($1).__comma($recv(self._temps())._keys());
- }, function($ctx1) {$ctx1.fill(self,"allVariableNames",{},$globals.LexicalScope)});
- },
- args: [],
- source: "allVariableNames\x0a\x09^ self args keys, self temps keys",
- referencedClasses: [],
- messageSends: [",", "keys", "args", "temps"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "args",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@args"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@args"]=$recv($globals.Dictionary)._new();
- return self["@args"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"args",{},$globals.LexicalScope)});
- },
- args: [],
- source: "args\x0a\x09^ args ifNil: [ args := Dictionary new ]",
- referencedClasses: ["Dictionary"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "bindingFor:",
- protocol: "accessing",
- fn: function (aStringOrNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$4,$5,$1;
- $2=self._pseudoVars();
- $3=$recv(aStringOrNode)._value();
- $ctx1.sendIdx["value"]=1;
- $1=$recv($2)._at_ifAbsent_($3,(function(){
- return $core.withContext(function($ctx2) {
- $4=self._args();
- $5=$recv(aStringOrNode)._value();
- $ctx2.sendIdx["value"]=2;
- return $recv($4)._at_ifAbsent_($5,(function(){
- return $core.withContext(function($ctx3) {
- return $recv(self._temps())._at_ifAbsent_($recv(aStringOrNode)._value(),(function(){
- return nil;
- }));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- $ctx2.sendIdx["at:ifAbsent:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["at:ifAbsent:"]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"bindingFor:",{aStringOrNode:aStringOrNode},$globals.LexicalScope)});
- },
- args: ["aStringOrNode"],
- source: "bindingFor: aStringOrNode\x0a\x09^ self pseudoVars at: aStringOrNode value ifAbsent: [\x0a\x09\x09self args at: aStringOrNode value ifAbsent: [\x0a\x09\x09\x09self temps at: aStringOrNode value ifAbsent: [ nil ]]]",
- referencedClasses: [],
- messageSends: ["at:ifAbsent:", "pseudoVars", "value", "args", "temps"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "blockIndex",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@blockIndex"];
- if(($receiver = $1) == null || $receiver.isNil){
- return (0);
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"blockIndex",{},$globals.LexicalScope)});
- },
- args: [],
- source: "blockIndex\x0a\x09^ blockIndex ifNil: [ 0 ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "blockIndex:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@blockIndex"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "blockIndex: anInteger \x0a\x09blockIndex := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "canInlineNonLocalReturns",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._isInlined())._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._outerScope())._canInlineNonLocalReturns();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"canInlineNonLocalReturns",{},$globals.LexicalScope)});
- },
- args: [],
- source: "canInlineNonLocalReturns\x0a\x09^ self isInlined and: [ self outerScope canInlineNonLocalReturns ]",
- referencedClasses: [],
- messageSends: ["and:", "isInlined", "canInlineNonLocalReturns", "outerScope"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "instruction",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@instruction"];
- },
- args: [],
- source: "instruction\x0a\x09^ instruction",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "instruction:",
- protocol: "accessing",
- fn: function (anIRInstruction){
- var self=this;
- self["@instruction"]=anIRInstruction;
- return self;
- },
- args: ["anIRInstruction"],
- source: "instruction: anIRInstruction\x0a\x09instruction := anIRInstruction",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "isBlockScope",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._isMethodScope())._not();
- }, function($ctx1) {$ctx1.fill(self,"isBlockScope",{},$globals.LexicalScope)});
- },
- args: [],
- source: "isBlockScope\x0a\x09^ self isMethodScope not",
- referencedClasses: [],
- messageSends: ["not", "isMethodScope"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "isInlined",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._instruction();
- $ctx1.sendIdx["instruction"]=1;
- $1=$recv($2)._notNil();
- return $recv($1)._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._instruction())._isInlined();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"isInlined",{},$globals.LexicalScope)});
- },
- args: [],
- source: "isInlined\x0a\x09^ self instruction notNil and: [\x0a\x09\x09self instruction isInlined ]",
- referencedClasses: [],
- messageSends: ["and:", "notNil", "instruction", "isInlined"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "isMethodScope",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isMethodScope\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "lookupVariable:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- var lookup;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- lookup=self._bindingFor_(aNode);
- $1=lookup;
- if(($receiver = $1) == null || $receiver.isNil){
- $2=self._outerScope();
- $ctx1.sendIdx["outerScope"]=1;
- if(($receiver = $2) == null || $receiver.isNil){
- lookup=$2;
- } else {
- lookup=$recv(self._outerScope())._lookupVariable_(aNode);
- }
- lookup;
- } else {
- $1;
- }
- return lookup;
- }, function($ctx1) {$ctx1.fill(self,"lookupVariable:",{aNode:aNode,lookup:lookup},$globals.LexicalScope)});
- },
- args: ["aNode"],
- source: "lookupVariable: aNode\x0a\x09| lookup |\x0a\x09lookup := (self bindingFor: aNode).\x0a\x09lookup ifNil: [\x0a\x09\x09lookup := self outerScope ifNotNil: [\x0a\x09\x09\x09(self outerScope lookupVariable: aNode) ]].\x0a\x09^ lookup",
- referencedClasses: [],
- messageSends: ["bindingFor:", "ifNil:", "ifNotNil:", "outerScope", "lookupVariable:"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "methodScope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._outerScope();
- $ctx1.sendIdx["outerScope"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- return $recv(self._outerScope())._methodScope();
- }
- }, function($ctx1) {$ctx1.fill(self,"methodScope",{},$globals.LexicalScope)});
- },
- args: [],
- source: "methodScope\x0a\x09^ self outerScope ifNotNil: [\x0a\x09\x09self outerScope methodScope ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "outerScope", "methodScope"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "node",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@node"];
- },
- args: [],
- source: "node\x0a\x09\x22Answer the node in which I am defined\x22\x0a\x09\x0a\x09^ node",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "node:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@node"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "node: aNode\x0a\x09node := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "outerScope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@outerScope"];
- },
- args: [],
- source: "outerScope\x0a\x09^ outerScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "outerScope:",
- protocol: "accessing",
- fn: function (aLexicalScope){
- var self=this;
- self["@outerScope"]=aLexicalScope;
- return self;
- },
- args: ["aLexicalScope"],
- source: "outerScope: aLexicalScope\x0a\x09outerScope := aLexicalScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "pseudoVars",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._methodScope())._pseudoVars();
- }, function($ctx1) {$ctx1.fill(self,"pseudoVars",{},$globals.LexicalScope)});
- },
- args: [],
- source: "pseudoVars\x0a\x09^ self methodScope pseudoVars",
- referencedClasses: [],
- messageSends: ["pseudoVars", "methodScope"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "scopeLevel",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$receiver;
- $1=self._outerScope();
- $ctx1.sendIdx["outerScope"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return (1);
- } else {
- $1;
- }
- $2=self._isInlined();
- if($core.assert($2)){
- $4=self._outerScope();
- $ctx1.sendIdx["outerScope"]=2;
- $3=$recv($4)._scopeLevel();
- $ctx1.sendIdx["scopeLevel"]=1;
- return $3;
- }
- return $recv($recv(self._outerScope())._scopeLevel()).__plus((1));
- }, function($ctx1) {$ctx1.fill(self,"scopeLevel",{},$globals.LexicalScope)});
- },
- args: [],
- source: "scopeLevel\x0a\x09self outerScope ifNil: [ ^ 1 ].\x0a\x09self isInlined ifTrue: [ ^ self outerScope scopeLevel ].\x0a\x09\x0a\x09^ self outerScope scopeLevel + 1",
- referencedClasses: [],
- messageSends: ["ifNil:", "outerScope", "ifTrue:", "isInlined", "scopeLevel", "+"]
- }),
- $globals.LexicalScope);
- $core.addMethod(
- $core.method({
- selector: "temps",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@temps"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@temps"]=$recv($globals.Dictionary)._new();
- return self["@temps"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"temps",{},$globals.LexicalScope)});
- },
- args: [],
- source: "temps\x0a\x09^ temps ifNil: [ temps := Dictionary new ]",
- referencedClasses: ["Dictionary"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.LexicalScope);
- $core.addClass("MethodLexicalScope", $globals.LexicalScope, ["iVars", "pseudoVars", "unknownVariables", "localReturn", "nonLocalReturns"], "Compiler-Semantic");
- $globals.MethodLexicalScope.comment="I represent a method scope.";
- $core.addMethod(
- $core.method({
- selector: "addIVar:",
- protocol: "adding",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._iVars();
- $ctx1.sendIdx["iVars"]=1;
- $recv($1)._at_put_(aString,$recv($globals.InstanceVar)._on_(aString));
- $recv($recv(self._iVars())._at_(aString))._scope_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addIVar:",{aString:aString},$globals.MethodLexicalScope)});
- },
- args: ["aString"],
- source: "addIVar: aString\x0a\x09self iVars at: aString put: (InstanceVar on: aString).\x0a\x09(self iVars at: aString) scope: self",
- referencedClasses: ["InstanceVar"],
- messageSends: ["at:put:", "iVars", "on:", "scope:", "at:"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "addNonLocalReturn:",
- protocol: "adding",
- fn: function (aScope){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._nonLocalReturns())._add_(aScope);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addNonLocalReturn:",{aScope:aScope},$globals.MethodLexicalScope)});
- },
- args: ["aScope"],
- source: "addNonLocalReturn: aScope\x0a\x09self nonLocalReturns add: aScope",
- referencedClasses: [],
- messageSends: ["add:", "nonLocalReturns"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "allVariableNames",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(
- $ctx1.supercall = true,
- ($globals.MethodLexicalScope.superclass||$boot.nilAsClass).fn.prototype._allVariableNames.apply($recv(self), []));
- $ctx1.supercall = false;
- return $recv($1).__comma($recv(self._iVars())._keys());
- }, function($ctx1) {$ctx1.fill(self,"allVariableNames",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "allVariableNames\x0a\x09^ super allVariableNames, self iVars keys",
- referencedClasses: [],
- messageSends: [",", "allVariableNames", "keys", "iVars"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "bindingFor:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=(
- $ctx1.supercall = true,
- ($globals.MethodLexicalScope.superclass||$boot.nilAsClass).fn.prototype._bindingFor_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- if(($receiver = $1) == null || $receiver.isNil){
- return $recv(self._iVars())._at_ifAbsent_($recv(aNode)._value(),(function(){
- return nil;
- }));
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"bindingFor:",{aNode:aNode},$globals.MethodLexicalScope)});
- },
- args: ["aNode"],
- source: "bindingFor: aNode\x0a\x09^ (super bindingFor: aNode) ifNil: [\x0a\x09\x09self iVars at: aNode value ifAbsent: [ nil ]]",
- referencedClasses: [],
- messageSends: ["ifNil:", "bindingFor:", "at:ifAbsent:", "iVars", "value"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "canInlineNonLocalReturns",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "canInlineNonLocalReturns\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "hasLocalReturn",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._localReturn();
- }, function($ctx1) {$ctx1.fill(self,"hasLocalReturn",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "hasLocalReturn\x0a\x09^ self localReturn",
- referencedClasses: [],
- messageSends: ["localReturn"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "hasNonLocalReturn",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._nonLocalReturns())._notEmpty();
- }, function($ctx1) {$ctx1.fill(self,"hasNonLocalReturn",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "hasNonLocalReturn\x0a\x09^ self nonLocalReturns notEmpty",
- referencedClasses: [],
- messageSends: ["notEmpty", "nonLocalReturns"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "iVars",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@iVars"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@iVars"]=$recv($globals.Dictionary)._new();
- return self["@iVars"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"iVars",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "iVars\x0a\x09^ iVars ifNil: [ iVars := Dictionary new ]",
- referencedClasses: ["Dictionary"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "isMethodScope",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isMethodScope\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "localReturn",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@localReturn"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"localReturn",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "localReturn\x0a\x09^ localReturn ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "localReturn:",
- protocol: "accessing",
- fn: function (aBoolean){
- var self=this;
- self["@localReturn"]=aBoolean;
- return self;
- },
- args: ["aBoolean"],
- source: "localReturn: aBoolean\x0a\x09localReturn := aBoolean",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "methodScope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "methodScope\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "nonLocalReturns",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@nonLocalReturns"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@nonLocalReturns"]=$recv($globals.OrderedCollection)._new();
- return self["@nonLocalReturns"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"nonLocalReturns",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "nonLocalReturns\x0a\x09^ nonLocalReturns ifNil: [ nonLocalReturns := OrderedCollection new ]",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "pseudoVars",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$receiver;
- $1=self["@pseudoVars"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@pseudoVars"]=$recv($globals.Dictionary)._new();
- self["@pseudoVars"];
- $recv($recv($globals.Smalltalk)._pseudoVariableNames())._do_((function(each){
- return $core.withContext(function($ctx2) {
- $2=self["@pseudoVars"];
- $4=$recv($globals.PseudoVar)._on_(each);
- $recv($4)._scope_(self._methodScope());
- $3=$recv($4)._yourself();
- return $recv($2)._at_put_(each,$3);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- } else {
- $1;
- }
- return self["@pseudoVars"];
- }, function($ctx1) {$ctx1.fill(self,"pseudoVars",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "pseudoVars\x0a\x09pseudoVars ifNil: [\x0a\x09\x09pseudoVars := Dictionary new.\x0a\x09\x09Smalltalk pseudoVariableNames do: [ :each |\x0a\x09\x09\x09pseudoVars at: each put: ((PseudoVar on: each)\x0a\x09\x09\x09\x09scope: self methodScope;\x0a\x09\x09\x09\x09yourself) ]].\x0a\x09^ pseudoVars",
- referencedClasses: ["Dictionary", "Smalltalk", "PseudoVar"],
- messageSends: ["ifNil:", "new", "do:", "pseudoVariableNames", "at:put:", "scope:", "on:", "methodScope", "yourself"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "removeNonLocalReturn:",
- protocol: "adding",
- fn: function (aScope){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._nonLocalReturns())._remove_ifAbsent_(aScope,(function(){
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"removeNonLocalReturn:",{aScope:aScope},$globals.MethodLexicalScope)});
- },
- args: ["aScope"],
- source: "removeNonLocalReturn: aScope\x0a\x09self nonLocalReturns remove: aScope ifAbsent: []",
- referencedClasses: [],
- messageSends: ["remove:ifAbsent:", "nonLocalReturns"]
- }),
- $globals.MethodLexicalScope);
- $core.addMethod(
- $core.method({
- selector: "unknownVariables",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@unknownVariables"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@unknownVariables"]=$recv($globals.OrderedCollection)._new();
- return self["@unknownVariables"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"unknownVariables",{},$globals.MethodLexicalScope)});
- },
- args: [],
- source: "unknownVariables\x0a\x09^ unknownVariables ifNil: [ unknownVariables := OrderedCollection new ]",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.MethodLexicalScope);
- $core.addClass("ScopeVar", $globals.Object, ["scope", "name"], "Compiler-Semantic");
- $globals.ScopeVar.comment="I am an entry in a LexicalScope that gets associated with variable nodes of the same name.\x0aThere are 4 different subclasses of vars: temp vars, local vars, args, and unknown/global vars.";
- $core.addMethod(
- $core.method({
- selector: "alias",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._name())._asVariableName();
- }, function($ctx1) {$ctx1.fill(self,"alias",{},$globals.ScopeVar)});
- },
- args: [],
- source: "alias\x0a\x09^ self name asVariableName",
- referencedClasses: [],
- messageSends: ["asVariableName", "name"]
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "isArgVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isArgVar\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "isClassRefVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isClassRefVar\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isImmutable\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "isInstanceVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isInstanceVar\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "isPseudoVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isPseudoVar\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "isTempVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isTempVar\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "isUnknownVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isUnknownVar\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "name",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@name"];
- },
- args: [],
- source: "name\x0a\x09^ name",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "name:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@name"]=aString;
- return self;
- },
- args: ["aString"],
- source: "name: aString\x0a\x09name := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@scope"];
- },
- args: [],
- source: "scope\x0a\x09^ scope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "scope:",
- protocol: "accessing",
- fn: function (aScope){
- var self=this;
- self["@scope"]=aScope;
- return self;
- },
- args: ["aScope"],
- source: "scope: aScope\x0a\x09scope := aScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "validateAssignment",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv(self._isArgVar())._or_((function(){
- return $core.withContext(function($ctx2) {
- return self._isPseudoVar();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- if($core.assert($1)){
- $2=$recv($globals.InvalidAssignmentError)._new();
- $recv($2)._variableName_(self._name());
- $recv($2)._signal();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"validateAssignment",{},$globals.ScopeVar)});
- },
- args: [],
- source: "validateAssignment\x0a\x09(self isArgVar or: [ self isPseudoVar ]) ifTrue: [\x0a\x09\x09InvalidAssignmentError new\x0a\x09\x09\x09variableName: self name;\x0a\x09\x09\x09signal]",
- referencedClasses: ["InvalidAssignmentError"],
- messageSends: ["ifTrue:", "or:", "isArgVar", "isPseudoVar", "variableName:", "new", "name", "signal"]
- }),
- $globals.ScopeVar);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._name_(aString);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{aString:aString},$globals.ScopeVar.klass)});
- },
- args: ["aString"],
- source: "on: aString\x0a\x09^ self new\x0a\x09\x09name: aString;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["name:", "new", "yourself"]
- }),
- $globals.ScopeVar.klass);
- $core.addClass("AliasVar", $globals.ScopeVar, ["node"], "Compiler-Semantic");
- $globals.AliasVar.comment="I am an internally defined variable by the compiler";
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AliasVar);
- $core.addMethod(
- $core.method({
- selector: "node",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@node"];
- },
- args: [],
- source: "node\x0a\x09^ node",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AliasVar);
- $core.addMethod(
- $core.method({
- selector: "node:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@node"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "node: aNode\x0a\x09node := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AliasVar);
- $core.addClass("ArgVar", $globals.ScopeVar, [], "Compiler-Semantic");
- $globals.ArgVar.comment="I am an argument of a method or block.";
- $core.addMethod(
- $core.method({
- selector: "isArgVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isArgVar\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArgVar);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArgVar);
- $core.addClass("ClassRefVar", $globals.ScopeVar, [], "Compiler-Semantic");
- $globals.ClassRefVar.comment="I am an class reference variable";
- $core.addMethod(
- $core.method({
- selector: "alias",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return "$globals.".__comma(self._name());
- }, function($ctx1) {$ctx1.fill(self,"alias",{},$globals.ClassRefVar)});
- },
- args: [],
- source: "alias\x0a\x09\x22Fixes issue #190.\x0a\x09A function is created in the method definition, answering the class or nil.\x0a\x09See JSStream >> #nextPutClassRefFunction:\x22\x0a\x09\x0a\x09^ '$globals.', self name",
- referencedClasses: [],
- messageSends: [",", "name"]
- }),
- $globals.ClassRefVar);
- $core.addMethod(
- $core.method({
- selector: "isClassRefVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isClassRefVar\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassRefVar);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassRefVar);
- $core.addClass("InstanceVar", $globals.ScopeVar, [], "Compiler-Semantic");
- $globals.InstanceVar.comment="I am an instance variable of a method or block.";
- $core.addMethod(
- $core.method({
- selector: "alias",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("self[\x22@".__comma(self._name())).__comma("\x22]");
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"alias",{},$globals.InstanceVar)});
- },
- args: [],
- source: "alias\x0a\x09^ 'self[\x22@', self name, '\x22]'",
- referencedClasses: [],
- messageSends: [",", "name"]
- }),
- $globals.InstanceVar);
- $core.addMethod(
- $core.method({
- selector: "isInstanceVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isInstanceVar\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.InstanceVar);
- $core.addClass("PseudoVar", $globals.ScopeVar, [], "Compiler-Semantic");
- $globals.PseudoVar.comment="I am an pseudo variable.\x0a\x0aThe five Smalltalk pseudo variables are: 'self', 'super', 'nil', 'true' and 'false'";
- $core.addMethod(
- $core.method({
- selector: "alias",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._name();
- }, function($ctx1) {$ctx1.fill(self,"alias",{},$globals.PseudoVar)});
- },
- args: [],
- source: "alias\x0a\x09^ self name",
- referencedClasses: [],
- messageSends: ["name"]
- }),
- $globals.PseudoVar);
- $core.addMethod(
- $core.method({
- selector: "isImmutable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PseudoVar);
- $core.addMethod(
- $core.method({
- selector: "isPseudoVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isPseudoVar\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PseudoVar);
- $core.addClass("TempVar", $globals.ScopeVar, [], "Compiler-Semantic");
- $globals.TempVar.comment="I am an temporary variable of a method or block.";
- $core.addMethod(
- $core.method({
- selector: "isTempVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isTempVar\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TempVar);
- $core.addClass("UnknownVar", $globals.ScopeVar, [], "Compiler-Semantic");
- $globals.UnknownVar.comment="I am an unknown variable. Amber uses unknown variables as JavaScript globals";
- $core.addMethod(
- $core.method({
- selector: "isUnknownVar",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isUnknownVar\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UnknownVar);
- $core.addClass("SemanticAnalyzer", $globals.NodeVisitor, ["currentScope", "blockIndex", "thePackage", "theClass", "classReferences", "messageSends"], "Compiler-Semantic");
- $globals.SemanticAnalyzer.comment="I semantically analyze the abstract syntax tree and annotate it with informations such as non local returns and variable scopes.";
- $core.addMethod(
- $core.method({
- selector: "classReferences",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@classReferences"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@classReferences"]=$recv($globals.Set)._new();
- return self["@classReferences"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"classReferences",{},$globals.SemanticAnalyzer)});
- },
- args: [],
- source: "classReferences\x0a\x09^ classReferences ifNil: [ classReferences := Set new ]",
- referencedClasses: ["Set"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "errorShadowingVariable:",
- protocol: "error handling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.ShadowingVariableError)._new();
- $recv($1)._variableName_(aString);
- $recv($1)._signal();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"errorShadowingVariable:",{aString:aString},$globals.SemanticAnalyzer)});
- },
- args: ["aString"],
- source: "errorShadowingVariable: aString\x0a\x09ShadowingVariableError new\x0a\x09\x09variableName: aString;\x0a\x09\x09signal",
- referencedClasses: ["ShadowingVariableError"],
- messageSends: ["variableName:", "new", "signal"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "errorUnknownVariable:",
- protocol: "error handling",
- fn: function (aNode){
- var self=this;
- var identifier;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- identifier=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=1;
- $1=$recv($recv($recv($recv($globals.Smalltalk)._globalJsVariables())._includes_(identifier))._not())._and_((function(){
- return $core.withContext(function($ctx2) {
- return self._isVariableUndefined_inPackage_(identifier,self._thePackage());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- if($core.assert($1)){
- $2=$recv($globals.UnknownVariableError)._new();
- $3=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=2;
- $recv($2)._variableName_($3);
- $recv($2)._signal();
- } else {
- $recv($recv($recv(self["@currentScope"])._methodScope())._unknownVariables())._add_($recv(aNode)._value());
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"errorUnknownVariable:",{aNode:aNode,identifier:identifier},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "errorUnknownVariable: aNode\x0a\x09\x22Throw an error if the variable is undeclared in the global JS scope (i.e. window).\x0a\x09We allow all variables listed by Smalltalk>>#globalJsVariables.\x0a\x09This list includes: `window`, `document`, `process` and `global`\x0a\x09for nodejs and browser environments.\x0a\x09\x0a\x09This is only to make sure compilation works on both browser-based and nodejs environments.\x0a\x09The ideal solution would be to use a pragma instead\x22\x0a\x0a\x09| identifier |\x0a\x09identifier := aNode value.\x0a\x09\x0a\x09((Smalltalk globalJsVariables includes: identifier) not\x0a\x09\x09and: [ self isVariableUndefined: identifier inPackage: self thePackage ])\x0a\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09UnknownVariableError new\x0a\x09\x09\x09\x09\x09variableName: aNode value;\x0a\x09\x09\x09\x09\x09signal ]\x0a\x09\x09\x09ifFalse: [\x0a\x09\x09\x09\x09currentScope methodScope unknownVariables add: aNode value ]",
- referencedClasses: ["Smalltalk", "UnknownVariableError"],
- messageSends: ["value", "ifTrue:ifFalse:", "and:", "not", "includes:", "globalJsVariables", "isVariableUndefined:inPackage:", "thePackage", "variableName:", "new", "signal", "add:", "unknownVariables", "methodScope"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "isVariableUndefined:inPackage:",
- protocol: "testing",
- fn: function (aString,aPackage){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- if(($receiver = aPackage) == null || $receiver.isNil){
- aPackage;
- } else {
- var packageKnownVars;
- packageKnownVars=$recv($recv($recv(aPackage)._imports())._reject_("isString"))._collect_("key");
- packageKnownVars;
- $1=$recv(packageKnownVars)._includes_(aString);
- if($core.assert($1)){
- return false;
- }
- }
- $2=$recv($globals.Compiler)._new();
- $3=$recv("typeof ".__comma(aString)).__comma(" == \x22undefined\x22");
- $ctx1.sendIdx[","]=1;
- return $recv($2)._eval_($3);
- }, function($ctx1) {$ctx1.fill(self,"isVariableUndefined:inPackage:",{aString:aString,aPackage:aPackage},$globals.SemanticAnalyzer)});
- },
- args: ["aString", "aPackage"],
- source: "isVariableUndefined: aString inPackage: aPackage\x0a\x09aPackage ifNotNil: [\x0a\x09\x09| packageKnownVars |\x0a\x09\x09packageKnownVars := (aPackage imports\x0a\x09\x09\x09reject: #isString)\x0a\x09\x09\x09collect: #key.\x0a\x09\x09(packageKnownVars includes: aString) ifTrue: [ ^ false ]].\x0a\x09^ Compiler new\x0a\x09\x09eval: 'typeof ', aString, ' == \x22undefined\x22'",
- referencedClasses: ["Compiler"],
- messageSends: ["ifNotNil:", "collect:", "reject:", "imports", "ifTrue:", "includes:", "eval:", "new", ","]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "messageSends",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@messageSends"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@messageSends"]=$recv($globals.Dictionary)._new();
- return self["@messageSends"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"messageSends",{},$globals.SemanticAnalyzer)});
- },
- args: [],
- source: "messageSends\x0a\x09^ messageSends ifNil: [ messageSends := Dictionary new ]",
- referencedClasses: ["Dictionary"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "newBlockScope",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._newScopeOfClass_($globals.LexicalScope);
- }, function($ctx1) {$ctx1.fill(self,"newBlockScope",{},$globals.SemanticAnalyzer)});
- },
- args: [],
- source: "newBlockScope\x0a\x09^ self newScopeOfClass: LexicalScope",
- referencedClasses: ["LexicalScope"],
- messageSends: ["newScopeOfClass:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "newMethodScope",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._newScopeOfClass_($globals.MethodLexicalScope);
- }, function($ctx1) {$ctx1.fill(self,"newMethodScope",{},$globals.SemanticAnalyzer)});
- },
- args: [],
- source: "newMethodScope\x0a\x09^ self newScopeOfClass: MethodLexicalScope",
- referencedClasses: ["MethodLexicalScope"],
- messageSends: ["newScopeOfClass:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "newScopeOfClass:",
- protocol: "factory",
- fn: function (aLexicalScopeClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(aLexicalScopeClass)._new();
- $recv($1)._outerScope_(self["@currentScope"]);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"newScopeOfClass:",{aLexicalScopeClass:aLexicalScopeClass},$globals.SemanticAnalyzer)});
- },
- args: ["aLexicalScopeClass"],
- source: "newScopeOfClass: aLexicalScopeClass\x0a\x09^ aLexicalScopeClass new\x0a\x09\x09outerScope: currentScope;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["outerScope:", "new", "yourself"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "nextBlockIndex",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@blockIndex"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@blockIndex"]=(0);
- self["@blockIndex"];
- } else {
- $1;
- }
- self["@blockIndex"]=$recv(self["@blockIndex"]).__plus((1));
- return self["@blockIndex"];
- }, function($ctx1) {$ctx1.fill(self,"nextBlockIndex",{},$globals.SemanticAnalyzer)});
- },
- args: [],
- source: "nextBlockIndex\x0a\x09blockIndex ifNil: [ blockIndex := 0 ].\x0a\x09\x0a\x09blockIndex := blockIndex + 1.\x0a\x09^ blockIndex",
- referencedClasses: [],
- messageSends: ["ifNil:", "+"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "popScope",
- protocol: "scope",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@currentScope"];
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- self["@currentScope"]=$recv(self["@currentScope"])._outerScope();
- self["@currentScope"];
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"popScope",{},$globals.SemanticAnalyzer)});
- },
- args: [],
- source: "popScope\x0a\x09currentScope ifNotNil: [\x0a\x09\x09currentScope := currentScope outerScope ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "outerScope"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "pushScope:",
- protocol: "scope",
- fn: function (aScope){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aScope)._outerScope_(self["@currentScope"]);
- self["@currentScope"]=aScope;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"pushScope:",{aScope:aScope},$globals.SemanticAnalyzer)});
- },
- args: ["aScope"],
- source: "pushScope: aScope\x0a\x09aScope outerScope: currentScope.\x0a\x09currentScope := aScope",
- referencedClasses: [],
- messageSends: ["outerScope:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@theClass"];
- },
- args: [],
- source: "theClass\x0a\x09^ theClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "theClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@theClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "theClass: aClass\x0a\x09theClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "thePackage",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@thePackage"];
- },
- args: [],
- source: "thePackage\x0a\x09^ thePackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "thePackage:",
- protocol: "accessing",
- fn: function (aPackage){
- var self=this;
- self["@thePackage"]=aPackage;
- return self;
- },
- args: ["aPackage"],
- source: "thePackage: aPackage\x0a\x09thePackage := aPackage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "validateVariableScope:",
- protocol: "scope",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=$recv(self["@currentScope"])._lookupVariable_(aString);
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- self._errorShadowingVariable_(aString);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"validateVariableScope:",{aString:aString},$globals.SemanticAnalyzer)});
- },
- args: ["aString"],
- source: "validateVariableScope: aString\x0a\x09\x22Validate the variable scope in by doing a recursive lookup, up to the method scope\x22\x0a\x0a\x09(currentScope lookupVariable: aString) ifNotNil: [\x0a\x09\x09self errorShadowingVariable: aString ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "lookupVariable:", "errorShadowingVariable:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitAssignmentNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.SemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitAssignmentNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- $recv($recv(aNode)._left())._beAssigned();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitAssignmentNode:",{aNode:aNode},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitAssignmentNode: aNode\x0a\x09super visitAssignmentNode: aNode.\x0a\x09aNode left beAssigned",
- referencedClasses: [],
- messageSends: ["visitAssignmentNode:", "beAssigned", "left"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitBlockNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._pushScope_(self._newBlockScope());
- $recv(aNode)._scope_(self["@currentScope"]);
- $recv(self["@currentScope"])._node_(aNode);
- $recv(self["@currentScope"])._blockIndex_(self._nextBlockIndex());
- $recv($recv(aNode)._parameters())._do_((function(each){
- return $core.withContext(function($ctx2) {
- self._validateVariableScope_(each);
- return $recv(self["@currentScope"])._addArg_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- (
- $ctx1.supercall = true,
- ($globals.SemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitBlockNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- self._popScope();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitBlockNode:",{aNode:aNode},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitBlockNode: aNode\x0a\x09self pushScope: self newBlockScope.\x0a\x09aNode scope: currentScope.\x0a\x09currentScope node: aNode.\x0a\x09currentScope blockIndex: self nextBlockIndex.\x0a\x0a\x09aNode parameters do: [ :each |\x0a\x09\x09self validateVariableScope: each.\x0a\x09\x09currentScope addArg: each ].\x0a\x0a\x09super visitBlockNode: aNode.\x0a\x09self popScope",
- referencedClasses: [],
- messageSends: ["pushScope:", "newBlockScope", "scope:", "node:", "blockIndex:", "nextBlockIndex", "do:", "parameters", "validateVariableScope:", "addArg:", "visitBlockNode:", "popScope"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitCascadeNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aNode)._receiver_($recv($recv($recv(aNode)._dagChildren())._first())._receiver());
- (
- $ctx1.supercall = true,
- ($globals.SemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitCascadeNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitCascadeNode:",{aNode:aNode},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitCascadeNode: aNode\x0a\x09aNode receiver: aNode dagChildren first receiver.\x0a\x09super visitCascadeNode: aNode",
- referencedClasses: [],
- messageSends: ["receiver:", "receiver", "first", "dagChildren", "visitCascadeNode:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitMethodNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._pushScope_(self._newMethodScope());
- $recv(aNode)._scope_(self["@currentScope"]);
- $recv(self["@currentScope"])._node_(aNode);
- $recv($recv(self._theClass())._allInstanceVariableNames())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self["@currentScope"])._addIVar_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- $recv($recv(aNode)._arguments())._do_((function(each){
- return $core.withContext(function($ctx2) {
- self._validateVariableScope_(each);
- return $recv(self["@currentScope"])._addArg_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- (
- $ctx1.supercall = true,
- ($globals.SemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitMethodNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- $recv(aNode)._classReferences_(self._classReferences());
- $recv(aNode)._sendIndexes_(self._messageSends());
- self._popScope();
- return aNode;
- }, function($ctx1) {$ctx1.fill(self,"visitMethodNode:",{aNode:aNode},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitMethodNode: aNode\x0a\x09self pushScope: self newMethodScope.\x0a\x09aNode scope: currentScope.\x0a\x09currentScope node: aNode.\x0a\x0a\x09self theClass allInstanceVariableNames do: [ :each |\x0a\x09\x09currentScope addIVar: each ].\x0a\x09aNode arguments do: [ :each |\x0a\x09\x09self validateVariableScope: each.\x0a\x09\x09currentScope addArg: each ].\x0a\x0a\x09super visitMethodNode: aNode.\x0a\x0a\x09aNode\x0a\x09\x09classReferences: self classReferences;\x0a\x09\x09sendIndexes: self messageSends.\x0a\x09self popScope.\x0a\x09^ aNode",
- referencedClasses: [],
- messageSends: ["pushScope:", "newMethodScope", "scope:", "node:", "do:", "allInstanceVariableNames", "theClass", "addIVar:", "arguments", "validateVariableScope:", "addArg:", "visitMethodNode:", "classReferences:", "classReferences", "sendIndexes:", "messageSends", "popScope"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitReturnNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(aNode)._scope_(self["@currentScope"]);
- $1=$recv(self["@currentScope"])._isMethodScope();
- if($core.assert($1)){
- $recv(self["@currentScope"])._localReturn_(true);
- } else {
- $recv($recv(self["@currentScope"])._methodScope())._addNonLocalReturn_(self["@currentScope"]);
- }
- (
- $ctx1.supercall = true,
- ($globals.SemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitReturnNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitReturnNode:",{aNode:aNode},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitReturnNode: aNode\x0a\x09aNode scope: currentScope.\x0a\x09currentScope isMethodScope\x0a\x09\x09ifTrue: [ currentScope localReturn: true ]\x0a\x09\x09ifFalse: [ currentScope methodScope addNonLocalReturn: currentScope ].\x0a\x09super visitReturnNode: aNode",
- referencedClasses: [],
- messageSends: ["scope:", "ifTrue:ifFalse:", "isMethodScope", "localReturn:", "addNonLocalReturn:", "methodScope", "visitReturnNode:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitSendNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var sends;
- return $core.withContext(function($ctx1) {
- sends=$recv(self._messageSends())._at_ifAbsentPut_($recv(aNode)._selector(),(function(){
- return $core.withContext(function($ctx2) {
- return $recv($globals.OrderedCollection)._new();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv(sends)._add_(aNode);
- $recv(aNode)._index_($recv(sends)._size());
- (
- $ctx1.supercall = true,
- ($globals.SemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitSendNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode,sends:sends},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitSendNode: aNode\x0a\x0a\x09| sends |\x0a\x09sends := self messageSends at: aNode selector ifAbsentPut: [ OrderedCollection new ].\x0a\x09sends add: aNode.\x0a\x0a\x09aNode index: sends size.\x0a\x0a\x09super visitSendNode: aNode",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["at:ifAbsentPut:", "messageSends", "selector", "new", "add:", "index:", "size", "visitSendNode:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitSequenceNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(aNode)._temps())._do_((function(each){
- return $core.withContext(function($ctx2) {
- self._validateVariableScope_(each);
- return $recv(self["@currentScope"])._addTemp_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- (
- $ctx1.supercall = true,
- ($globals.SemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitSequenceNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitSequenceNode:",{aNode:aNode},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitSequenceNode: aNode\x0a\x09aNode temps do: [ :each |\x0a\x09\x09self validateVariableScope: each.\x0a\x09\x09currentScope addTemp: each ].\x0a\x0a\x09super visitSequenceNode: aNode",
- referencedClasses: [],
- messageSends: ["do:", "temps", "validateVariableScope:", "addTemp:", "visitSequenceNode:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitVariableNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var binding;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$5,$6,$7,$8,$9,$receiver;
- binding=$recv(self["@currentScope"])._lookupVariable_(aNode);
- $1=binding;
- if(($receiver = $1) == null || $receiver.isNil){
- $3=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=1;
- $2=$recv($3)._isCapitalized();
- if($core.assert($2)){
- $4=$recv($globals.ClassRefVar)._new();
- $ctx1.sendIdx["new"]=1;
- $5=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=2;
- $recv($4)._name_($5);
- $ctx1.sendIdx["name:"]=1;
- $6=$recv($4)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- binding=$6;
- binding;
- $7=self._classReferences();
- $8=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=3;
- $recv($7)._add_($8);
- } else {
- self._errorUnknownVariable_(aNode);
- $9=$recv($globals.UnknownVar)._new();
- $recv($9)._name_($recv(aNode)._value());
- binding=$recv($9)._yourself();
- binding;
- }
- } else {
- $1;
- }
- $recv(aNode)._binding_(binding);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode,binding:binding},$globals.SemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitVariableNode: aNode\x0a\x09\x22Bind a ScopeVar to aNode by doing a lookup in the current scope.\x0a\x09If no ScopeVar is found, bind a UnknowVar and throw an error.\x22\x0a\x0a\x09| binding |\x0a\x09binding := currentScope lookupVariable: aNode.\x0a\x09\x0a\x09binding ifNil: [\x0a\x09\x09aNode value isCapitalized\x0a\x09\x09\x09ifTrue: [ \x22Capital letter variables might be globals.\x22\x0a\x09\x09\x09\x09binding := ClassRefVar new name: aNode value; yourself.\x0a\x09\x09\x09\x09self classReferences add: aNode value]\x0a\x09\x09\x09ifFalse: [\x0a\x09\x09\x09\x09self errorUnknownVariable: aNode.\x0a\x09\x09\x09\x09binding := UnknownVar new name: aNode value; yourself ] ].\x0a\x09\x09\x0a\x09aNode binding: binding.",
- referencedClasses: ["ClassRefVar", "UnknownVar"],
- messageSends: ["lookupVariable:", "ifNil:", "ifTrue:ifFalse:", "isCapitalized", "value", "name:", "new", "yourself", "add:", "classReferences", "errorUnknownVariable:", "binding:"]
- }),
- $globals.SemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._theClass_(aClass);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{aClass:aClass},$globals.SemanticAnalyzer.klass)});
- },
- args: ["aClass"],
- source: "on: aClass\x0a\x09^ self new\x0a\x09\x09theClass: aClass;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["theClass:", "new", "yourself"]
- }),
- $globals.SemanticAnalyzer.klass);
- $core.addClass("SemanticError", $globals.CompilerError, [], "Compiler-Semantic");
- $globals.SemanticError.comment="I represent an abstract semantic error thrown by the SemanticAnalyzer.\x0aSemantic errors can be unknown variable errors, etc.\x0aSee my subclasses for concrete errors.\x0a\x0aThe IDE should catch instances of Semantic error to deal with them when compiling";
- $core.addClass("InvalidAssignmentError", $globals.SemanticError, ["variableName"], "Compiler-Semantic");
- $globals.InvalidAssignmentError.comment="I get signaled when a pseudo variable gets assigned.";
- $core.addMethod(
- $core.method({
- selector: "messageText",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return " Invalid assignment to variable: ".__comma(self._variableName());
- }, function($ctx1) {$ctx1.fill(self,"messageText",{},$globals.InvalidAssignmentError)});
- },
- args: [],
- source: "messageText\x0a\x09^ ' Invalid assignment to variable: ', self variableName",
- referencedClasses: [],
- messageSends: [",", "variableName"]
- }),
- $globals.InvalidAssignmentError);
- $core.addMethod(
- $core.method({
- selector: "variableName",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@variableName"];
- },
- args: [],
- source: "variableName\x0a\x09^ variableName",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.InvalidAssignmentError);
- $core.addMethod(
- $core.method({
- selector: "variableName:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@variableName"]=aString;
- return self;
- },
- args: ["aString"],
- source: "variableName: aString\x0a\x09variableName := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.InvalidAssignmentError);
- $core.addClass("ShadowingVariableError", $globals.SemanticError, ["variableName"], "Compiler-Semantic");
- $globals.ShadowingVariableError.comment="I get signaled when a variable in a block or method scope shadows a variable of the same name in an outer scope.";
- $core.addMethod(
- $core.method({
- selector: "messageText",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("Variable shadowing error: ".__comma(self._variableName())).__comma(" is already defined");
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"messageText",{},$globals.ShadowingVariableError)});
- },
- args: [],
- source: "messageText\x0a\x09^ 'Variable shadowing error: ', self variableName, ' is already defined'",
- referencedClasses: [],
- messageSends: [",", "variableName"]
- }),
- $globals.ShadowingVariableError);
- $core.addMethod(
- $core.method({
- selector: "variableName",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@variableName"];
- },
- args: [],
- source: "variableName\x0a\x09^ variableName",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ShadowingVariableError);
- $core.addMethod(
- $core.method({
- selector: "variableName:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@variableName"]=aString;
- return self;
- },
- args: ["aString"],
- source: "variableName: aString\x0a\x09variableName := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ShadowingVariableError);
- $core.addClass("UnknownVariableError", $globals.SemanticError, ["variableName"], "Compiler-Semantic");
- $globals.UnknownVariableError.comment="I get signaled when a variable is not defined.\x0aThe default behavior is to allow it, as this is how Amber currently is able to seamlessly send messages to JavaScript objects.";
- $core.addMethod(
- $core.method({
- selector: "messageText",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv("Unknown Variable error: ".__comma(self._variableName())).__comma(" is not defined");
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"messageText",{},$globals.UnknownVariableError)});
- },
- args: [],
- source: "messageText\x0a\x09^ 'Unknown Variable error: ', self variableName, ' is not defined'",
- referencedClasses: [],
- messageSends: [",", "variableName"]
- }),
- $globals.UnknownVariableError);
- $core.addMethod(
- $core.method({
- selector: "variableName",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@variableName"];
- },
- args: [],
- source: "variableName\x0a\x09^ variableName",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UnknownVariableError);
- $core.addMethod(
- $core.method({
- selector: "variableName:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@variableName"]=aString;
- return self;
- },
- args: ["aString"],
- source: "variableName: aString\x0a\x09variableName := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.UnknownVariableError);
- });
- define('amber_core/Compiler-IR',["amber/boot", "amber_core/Compiler-AST", "amber_core/Kernel-Dag", "amber_core/Kernel-Methods", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Compiler-IR");
- $core.packages["Compiler-IR"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Compiler-IR"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("IRASTTranslator", $globals.NodeVisitor, ["source", "theClass", "method", "sequence", "nextAlias"], "Compiler-IR");
- $globals.IRASTTranslator.comment="I am the AST (abstract syntax tree) visitor responsible for building the intermediate representation graph.";
- $core.addMethod(
- $core.method({
- selector: "alias:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var variable;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4,$6,$7,$9,$8;
- $1=$recv(aNode)._isImmutable();
- if($core.assert($1)){
- $2=self._visit_(aNode);
- $ctx1.sendIdx["visit:"]=1;
- return $2;
- }
- $3=$recv($globals.IRVariable)._new();
- $ctx1.sendIdx["new"]=1;
- $5=$recv($globals.AliasVar)._new();
- $ctx1.sendIdx["new"]=2;
- $4=$recv($5)._name_("$".__comma(self._nextAlias()));
- $recv($3)._variable_($4);
- $6=$recv($3)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- variable=$6;
- $7=self._sequence();
- $9=$recv($globals.IRAssignment)._new();
- $recv($9)._add_(variable);
- $ctx1.sendIdx["add:"]=2;
- $recv($9)._add_(self._visit_(aNode));
- $ctx1.sendIdx["add:"]=3;
- $8=$recv($9)._yourself();
- $recv($7)._add_($8);
- $ctx1.sendIdx["add:"]=1;
- $recv($recv(self._method())._internalVariables())._add_(variable);
- return variable;
- }, function($ctx1) {$ctx1.fill(self,"alias:",{aNode:aNode,variable:variable},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "alias: aNode\x0a\x09| variable |\x0a\x0a\x09aNode isImmutable ifTrue: [ ^ self visit: aNode ].\x0a\x0a\x09variable := IRVariable new\x0a\x09\x09variable: (AliasVar new name: '$', self nextAlias);\x0a\x09\x09yourself.\x0a\x0a\x09self sequence add: (IRAssignment new\x0a\x09\x09add: variable;\x0a\x09\x09add: (self visit: aNode);\x0a\x09\x09yourself).\x0a\x0a\x09self method internalVariables add: variable.\x0a\x0a\x09^ variable",
- referencedClasses: ["IRVariable", "AliasVar", "IRAssignment"],
- messageSends: ["ifTrue:", "isImmutable", "visit:", "variable:", "new", "name:", ",", "nextAlias", "yourself", "add:", "sequence", "internalVariables", "method"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "aliasTemporally:",
- protocol: "visiting",
- fn: function (aCollection){
- var self=this;
- var threshold,result;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3;
- threshold=(0);
- $recv(aCollection)._withIndexDo_((function(each,i){
- return $core.withContext(function($ctx2) {
- $1=$recv(each)._subtreeNeedsAliasing();
- if($core.assert($1)){
- threshold=i;
- return threshold;
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1,1)});
- }));
- $ctx1.sendIdx["withIndexDo:"]=1;
- result=$recv($globals.OrderedCollection)._new();
- $recv(aCollection)._withIndexDo_((function(each,i){
- return $core.withContext(function($ctx2) {
- $2=result;
- $4=$recv(i).__lt_eq(threshold);
- if($core.assert($4)){
- $3=self._alias_(each);
- } else {
- $3=self._visit_(each);
- }
- return $recv($2)._add_($3);
- }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1,3)});
- }));
- return result;
- }, function($ctx1) {$ctx1.fill(self,"aliasTemporally:",{aCollection:aCollection,threshold:threshold,result:result},$globals.IRASTTranslator)});
- },
- args: ["aCollection"],
- source: "aliasTemporally: aCollection\x0a\x09\x22https://lolg.it/amber/amber/issues/296\x0a\x09\x0a\x09If a node is aliased, all preceding ones are aliased as well.\x0a\x09The tree is iterated twice. First we get the aliasing dependency,\x0a\x09then the aliasing itself is done\x22\x0a\x0a\x09| threshold result |\x0a\x09threshold := 0.\x0a\x09\x0a\x09aCollection withIndexDo: [ :each :i |\x0a\x09\x09each subtreeNeedsAliasing\x0a\x09\x09\x09ifTrue: [ threshold := i ] ].\x0a\x0a\x09result := OrderedCollection new.\x0a\x09aCollection withIndexDo: [ :each :i |\x0a\x09\x09result add: (i <= threshold\x0a\x09\x09\x09ifTrue: [ self alias: each ]\x0a\x09\x09\x09ifFalse: [ self visit: each ]) ].\x0a\x0a\x09^ result",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["withIndexDo:", "ifTrue:", "subtreeNeedsAliasing", "new", "add:", "ifTrue:ifFalse:", "<=", "alias:", "visit:"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@method"];
- },
- args: [],
- source: "method\x0a\x09^ method",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "method:",
- protocol: "accessing",
- fn: function (anIRMethod){
- var self=this;
- self["@method"]=anIRMethod;
- return self;
- },
- args: ["anIRMethod"],
- source: "method: anIRMethod\x0a\x09method := anIRMethod",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "nextAlias",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@nextAlias"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@nextAlias"]=(0);
- self["@nextAlias"];
- } else {
- $1;
- }
- self["@nextAlias"]=$recv(self["@nextAlias"]).__plus((1));
- return $recv(self["@nextAlias"])._asString();
- }, function($ctx1) {$ctx1.fill(self,"nextAlias",{},$globals.IRASTTranslator)});
- },
- args: [],
- source: "nextAlias\x0a\x09nextAlias ifNil: [ nextAlias := 0 ].\x0a\x09nextAlias := nextAlias + 1.\x0a\x09^ nextAlias asString",
- referencedClasses: [],
- messageSends: ["ifNil:", "+", "asString"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "sequence",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@sequence"];
- },
- args: [],
- source: "sequence\x0a\x09^ sequence",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "sequence:",
- protocol: "accessing",
- fn: function (anIRSequence){
- var self=this;
- self["@sequence"]=anIRSequence;
- return self;
- },
- args: ["anIRSequence"],
- source: "sequence: anIRSequence\x0a\x09sequence := anIRSequence",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@source"];
- },
- args: [],
- source: "source\x0a\x09^ source",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@source"]=aString;
- return self;
- },
- args: ["aString"],
- source: "source: aString\x0a\x09source := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@theClass"];
- },
- args: [],
- source: "theClass\x0a\x09^ theClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "theClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@theClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "theClass: aClass\x0a\x09theClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitAssignmentNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var left,right,assignment;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- right=self._visit_($recv(aNode)._right());
- $ctx1.sendIdx["visit:"]=1;
- left=self._visit_($recv(aNode)._left());
- $1=self._sequence();
- $3=$recv($globals.IRAssignment)._new();
- $recv($3)._add_(left);
- $ctx1.sendIdx["add:"]=2;
- $recv($3)._add_(right);
- $2=$recv($3)._yourself();
- $recv($1)._add_($2);
- $ctx1.sendIdx["add:"]=1;
- return left;
- }, function($ctx1) {$ctx1.fill(self,"visitAssignmentNode:",{aNode:aNode,left:left,right:right,assignment:assignment},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitAssignmentNode: aNode\x0a\x09| left right assignment |\x0a\x09right := self visit: aNode right.\x0a\x09left := self visit: aNode left.\x0a\x09self sequence add: (IRAssignment new\x0a\x09\x09add: left;\x0a\x09\x09add: right;\x0a\x09\x09yourself).\x0a\x09^ left",
- referencedClasses: ["IRAssignment"],
- messageSends: ["visit:", "right", "left", "add:", "sequence", "new", "yourself"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitBlockNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var closure;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4,$6,$8,$7;
- $1=$recv($globals.IRClosure)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._arguments_($recv(aNode)._parameters());
- $recv($1)._requiresSmalltalkContext_($recv(aNode)._requiresSmalltalkContext());
- $2=$recv(aNode)._scope();
- $ctx1.sendIdx["scope"]=1;
- $recv($1)._scope_($2);
- $ctx1.sendIdx["scope:"]=1;
- $3=$recv($1)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- closure=$3;
- $5=$recv(aNode)._scope();
- $ctx1.sendIdx["scope"]=2;
- $4=$recv($5)._temps();
- $recv($4)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $6=closure;
- $8=$recv($globals.IRTempDeclaration)._new();
- $recv($8)._name_($recv(each)._name());
- $recv($8)._scope_($recv(aNode)._scope());
- $7=$recv($8)._yourself();
- return $recv($6)._add_($7);
- $ctx2.sendIdx["add:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- $recv($recv(aNode)._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(closure)._add_(self._visit_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- return closure;
- }, function($ctx1) {$ctx1.fill(self,"visitBlockNode:",{aNode:aNode,closure:closure},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitBlockNode: aNode\x0a\x09| closure |\x0a\x09closure := IRClosure new\x0a\x09\x09arguments: aNode parameters;\x0a\x09\x09requiresSmalltalkContext: aNode requiresSmalltalkContext;\x0a\x09\x09scope: aNode scope;\x0a\x09\x09yourself.\x0a\x09aNode scope temps do: [ :each |\x0a\x09\x09closure add: (IRTempDeclaration new\x0a\x09\x09\x09name: each name;\x0a\x09\x09\x09scope: aNode scope;\x0a\x09\x09\x09yourself) ].\x0a\x09aNode dagChildren do: [ :each | closure add: (self visit: each) ].\x0a\x09^ closure",
- referencedClasses: ["IRClosure", "IRTempDeclaration"],
- messageSends: ["arguments:", "new", "parameters", "requiresSmalltalkContext:", "requiresSmalltalkContext", "scope:", "scope", "yourself", "do:", "temps", "add:", "name:", "name", "dagChildren", "visit:"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitBlockSequenceNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$5,$6,$9,$8,$7,$10,$12,$15,$14,$13,$11;
- $1=$recv($globals.IRBlockSequence)._new();
- $ctx1.sendIdx["new"]=1;
- return self._withSequence_do_($1,(function(){
- return $core.withContext(function($ctx2) {
- $2=$recv(aNode)._dagChildren();
- $ctx2.sendIdx["dagChildren"]=1;
- return $recv($2)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx3) {
- $4=$recv(aNode)._dagChildren();
- $ctx3.sendIdx["dagChildren"]=2;
- $3=$recv($4)._allButLast();
- $recv($3)._do_((function(each){
- return $core.withContext(function($ctx4) {
- $5=self._sequence();
- $ctx4.sendIdx["sequence"]=1;
- $6=self._visitOrAlias_(each);
- $ctx4.sendIdx["visitOrAlias:"]=1;
- return $recv($5)._add_($6);
- $ctx4.sendIdx["add:"]=1;
- }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3,3)});
- }));
- $9=$recv(aNode)._dagChildren();
- $ctx3.sendIdx["dagChildren"]=3;
- $8=$recv($9)._last();
- $ctx3.sendIdx["last"]=1;
- $7=$recv($8)._isReturnNode();
- if($core.assert($7)){
- return $recv(self._sequence())._add_(self._visitOrAlias_($recv($recv(aNode)._dagChildren())._last()));
- } else {
- $10=self._sequence();
- $ctx3.sendIdx["sequence"]=2;
- $12=$recv($globals.IRBlockReturn)._new();
- $15=$recv(aNode)._dagChildren();
- $ctx3.sendIdx["dagChildren"]=4;
- $14=$recv($15)._last();
- $ctx3.sendIdx["last"]=2;
- $13=self._visitOrAlias_($14);
- $ctx3.sendIdx["visitOrAlias:"]=2;
- $recv($12)._add_($13);
- $ctx3.sendIdx["add:"]=3;
- $11=$recv($12)._yourself();
- return $recv($10)._add_($11);
- $ctx3.sendIdx["add:"]=2;
- }
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"visitBlockSequenceNode:",{aNode:aNode},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitBlockSequenceNode: aNode\x0a\x09^ self\x0a\x09\x09withSequence: IRBlockSequence new\x0a\x09\x09do: [\x0a\x09\x09\x09aNode dagChildren ifNotEmpty: [\x0a\x09\x09\x09\x09aNode dagChildren allButLast do: [ :each |\x0a\x09\x09\x09\x09\x09self sequence add: (self visitOrAlias: each) ].\x0a\x09\x09\x09\x09aNode dagChildren last isReturnNode\x0a\x09\x09\x09\x09\x09ifFalse: [ self sequence add: (IRBlockReturn new add: (self visitOrAlias: aNode dagChildren last); yourself) ]\x0a\x09\x09\x09\x09\x09ifTrue: [ self sequence add: (self visitOrAlias: aNode dagChildren last) ] ]]",
- referencedClasses: ["IRBlockSequence", "IRBlockReturn"],
- messageSends: ["withSequence:do:", "new", "ifNotEmpty:", "dagChildren", "do:", "allButLast", "add:", "sequence", "visitOrAlias:", "ifFalse:ifTrue:", "isReturnNode", "last", "yourself"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitCascadeNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var receiver;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3;
- receiver=$recv(aNode)._receiver();
- $1=$recv(receiver)._isImmutable();
- if(!$core.assert($1)){
- var alias;
- alias=self._alias_(receiver);
- alias;
- receiver=$recv($recv($globals.VariableNode)._new())._binding_($recv(alias)._variable());
- receiver;
- }
- $2=$recv(aNode)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- $recv($2)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._receiver_(receiver);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- $ctx1.sendIdx["do:"]=1;
- $4=$recv(aNode)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=2;
- $3=$recv($4)._allButLast();
- $recv($3)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self._sequence())._add_(self._visit_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- return self._visitOrAlias_($recv($recv(aNode)._dagChildren())._last());
- }, function($ctx1) {$ctx1.fill(self,"visitCascadeNode:",{aNode:aNode,receiver:receiver},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitCascadeNode: aNode\x0a\x09| receiver |\x0a\x09receiver := aNode receiver.\x0a\x09receiver isImmutable ifFalse: [\x0a\x09\x09| alias |\x0a\x09\x09alias := self alias: receiver.\x0a\x09\x09receiver := VariableNode new binding: alias variable ].\x0a\x09aNode dagChildren do: [ :each | each receiver: receiver ].\x0a\x0a\x09aNode dagChildren allButLast do: [ :each |\x0a\x09\x09self sequence add: (self visit: each) ].\x0a\x0a\x09^ self visitOrAlias: aNode dagChildren last",
- referencedClasses: ["VariableNode"],
- messageSends: ["receiver", "ifFalse:", "isImmutable", "alias:", "binding:", "new", "variable", "do:", "dagChildren", "receiver:", "allButLast", "add:", "sequence", "visit:", "visitOrAlias:", "last"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitDynamicArrayNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- array=$recv($globals.IRDynamicArray)._new();
- $recv(self._aliasTemporally_($recv(aNode)._dagChildren()))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(array)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return array;
- }, function($ctx1) {$ctx1.fill(self,"visitDynamicArrayNode:",{aNode:aNode,array:array},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitDynamicArrayNode: aNode\x0a\x09| array |\x0a\x09array := IRDynamicArray new.\x0a\x09(self aliasTemporally: aNode dagChildren) do: [ :each | array add: each ].\x0a\x09^ array",
- referencedClasses: ["IRDynamicArray"],
- messageSends: ["new", "do:", "aliasTemporally:", "dagChildren", "add:"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitDynamicDictionaryNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var dictionary;
- return $core.withContext(function($ctx1) {
- dictionary=$recv($globals.IRDynamicDictionary)._new();
- $recv(self._aliasTemporally_($recv(aNode)._dagChildren()))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(dictionary)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return dictionary;
- }, function($ctx1) {$ctx1.fill(self,"visitDynamicDictionaryNode:",{aNode:aNode,dictionary:dictionary},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitDynamicDictionaryNode: aNode\x0a\x09| dictionary |\x0a\x09dictionary := IRDynamicDictionary new.\x0a\x09(self aliasTemporally: aNode dagChildren) do: [ :each | dictionary add: each ].\x0a\x09^ dictionary",
- referencedClasses: ["IRDynamicDictionary"],
- messageSends: ["new", "do:", "aliasTemporally:", "dagChildren", "add:"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitJSStatementNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRVerbatim)._new();
- $recv($1)._source_($recv($recv(aNode)._source())._crlfSanitized());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"visitJSStatementNode:",{aNode:aNode},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitJSStatementNode: aNode\x0a\x09^ IRVerbatim new\x0a\x09\x09source: aNode source crlfSanitized;\x0a\x09\x09yourself",
- referencedClasses: ["IRVerbatim"],
- messageSends: ["source:", "new", "crlfSanitized", "source", "yourself"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitMethodNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$4,$1,$6,$5,$7,$9,$10,$11,$8,$12,$14,$13,$15,$17,$19,$20,$18,$21,$16,$23,$22;
- $2=$recv($globals.IRMethod)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($2)._source_($recv(self._source())._crlfSanitized());
- $ctx1.sendIdx["source:"]=1;
- $recv($2)._theClass_(self._theClass());
- $recv($2)._arguments_($recv(aNode)._arguments());
- $recv($2)._selector_($recv(aNode)._selector());
- $recv($2)._sendIndexes_($recv(aNode)._sendIndexes());
- $recv($2)._requiresSmalltalkContext_($recv(aNode)._requiresSmalltalkContext());
- $recv($2)._classReferences_($recv(aNode)._classReferences());
- $3=$recv(aNode)._scope();
- $ctx1.sendIdx["scope"]=1;
- $recv($2)._scope_($3);
- $ctx1.sendIdx["scope:"]=1;
- $4=$recv($2)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $1=$4;
- self._method_($1);
- $6=$recv(aNode)._scope();
- $ctx1.sendIdx["scope"]=2;
- $5=$recv($6)._temps();
- $recv($5)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $7=self._method();
- $ctx2.sendIdx["method"]=1;
- $9=$recv($globals.IRTempDeclaration)._new();
- $ctx2.sendIdx["new"]=2;
- $recv($9)._name_($recv(each)._name());
- $10=$recv(aNode)._scope();
- $ctx2.sendIdx["scope"]=3;
- $recv($9)._scope_($10);
- $11=$recv($9)._yourself();
- $ctx2.sendIdx["yourself"]=2;
- $8=$11;
- return $recv($7)._add_($8);
- $ctx2.sendIdx["add:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- $recv($recv(aNode)._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- $12=self._method();
- $ctx2.sendIdx["method"]=2;
- return $recv($12)._add_(self._visit_(each));
- $ctx2.sendIdx["add:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- $14=$recv(aNode)._scope();
- $ctx1.sendIdx["scope"]=4;
- $13=$recv($14)._hasLocalReturn();
- if(!$core.assert($13)){
- $15=self._method();
- $ctx1.sendIdx["method"]=3;
- $17=$recv($globals.IRReturn)._new();
- $ctx1.sendIdx["new"]=3;
- $19=$recv($globals.IRVariable)._new();
- $ctx1.sendIdx["new"]=4;
- $recv($19)._variable_($recv($recv($recv(aNode)._scope())._pseudoVars())._at_("self"));
- $20=$recv($19)._yourself();
- $ctx1.sendIdx["yourself"]=3;
- $18=$20;
- $recv($17)._add_($18);
- $ctx1.sendIdx["add:"]=4;
- $21=$recv($17)._yourself();
- $ctx1.sendIdx["yourself"]=4;
- $16=$21;
- $recv($15)._add_($16);
- $ctx1.sendIdx["add:"]=3;
- $23=$recv($globals.IRVerbatim)._new();
- $recv($23)._source_("");
- $22=$recv($23)._yourself();
- $recv($15)._add_($22);
- }
- return self._method();
- }, function($ctx1) {$ctx1.fill(self,"visitMethodNode:",{aNode:aNode},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitMethodNode: aNode\x0a\x0a\x09self method: (IRMethod new\x0a\x09\x09source: self source crlfSanitized;\x0a\x09\x09theClass: self theClass;\x0a\x09\x09arguments: aNode arguments;\x0a\x09\x09selector: aNode selector;\x0a\x09\x09sendIndexes: aNode sendIndexes;\x0a\x09\x09requiresSmalltalkContext: aNode requiresSmalltalkContext;\x0a\x09\x09classReferences: aNode classReferences;\x0a\x09\x09scope: aNode scope;\x0a\x09\x09yourself).\x0a\x0a\x09aNode scope temps do: [ :each |\x0a\x09\x09self method add: (IRTempDeclaration new\x0a\x09\x09\x09name: each name;\x0a\x09\x09\x09scope: aNode scope;\x0a\x09\x09\x09yourself) ].\x0a\x0a\x09aNode dagChildren do: [ :each | self method add: (self visit: each) ].\x0a\x0a\x09aNode scope hasLocalReturn ifFalse: [self method\x0a\x09\x09add: (IRReturn new\x0a\x09\x09\x09add: (IRVariable new\x0a\x09\x09\x09\x09variable: (aNode scope pseudoVars at: 'self');\x0a\x09\x09\x09\x09yourself);\x0a\x09\x09\x09yourself);\x0a\x09\x09add: (IRVerbatim new source: ''; yourself) ].\x0a\x0a\x09^ self method",
- referencedClasses: ["IRMethod", "IRTempDeclaration", "IRReturn", "IRVariable", "IRVerbatim"],
- messageSends: ["method:", "source:", "new", "crlfSanitized", "source", "theClass:", "theClass", "arguments:", "arguments", "selector:", "selector", "sendIndexes:", "sendIndexes", "requiresSmalltalkContext:", "requiresSmalltalkContext", "classReferences:", "classReferences", "scope:", "scope", "yourself", "do:", "temps", "add:", "method", "name:", "name", "dagChildren", "visit:", "ifFalse:", "hasLocalReturn", "variable:", "at:", "pseudoVars"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitOrAlias:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(aNode)._shouldBeAliased();
- if($core.assert($1)){
- return self._alias_(aNode);
- } else {
- return self._visit_(aNode);
- }
- }, function($ctx1) {$ctx1.fill(self,"visitOrAlias:",{aNode:aNode},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitOrAlias: aNode\x0a\x09^ aNode shouldBeAliased\x0a\x09\x09ifTrue: [ self alias: aNode ]\x0a\x09\x09ifFalse: [ self visit: aNode ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "shouldBeAliased", "alias:", "visit:"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitReturnNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var return_;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(aNode)._nonLocalReturn();
- if($core.assert($1)){
- return_=$recv($globals.IRNonLocalReturn)._new();
- $ctx1.sendIdx["new"]=1;
- } else {
- return_=$recv($globals.IRReturn)._new();
- }
- $recv(return_)._scope_($recv(aNode)._scope());
- $recv($recv(aNode)._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(return_)._add_(self._visitOrAlias_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- return return_;
- }, function($ctx1) {$ctx1.fill(self,"visitReturnNode:",{aNode:aNode,return_:return_},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitReturnNode: aNode\x0a\x09| return |\x0a\x09return := aNode nonLocalReturn\x0a\x09\x09ifTrue: [ IRNonLocalReturn new ]\x0a\x09\x09ifFalse: [ IRReturn new ].\x0a\x09return scope: aNode scope.\x0a\x09aNode dagChildren do: [ :each |\x0a\x09\x09return add: (self visitOrAlias: each) ].\x0a\x09^ return",
- referencedClasses: ["IRNonLocalReturn", "IRReturn"],
- messageSends: ["ifTrue:ifFalse:", "nonLocalReturn", "new", "scope:", "scope", "do:", "dagChildren", "add:", "visitOrAlias:"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitSendNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var send;
- return $core.withContext(function($ctx1) {
- var $1;
- send=$recv($globals.IRSend)._new();
- $1=send;
- $recv($1)._selector_($recv(aNode)._selector());
- $recv($1)._index_($recv(aNode)._index());
- $recv(self._aliasTemporally_($recv(aNode)._dagChildren()))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(send)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return send;
- }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode,send:send},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitSendNode: aNode\x0a\x09| send |\x0a\x09send := IRSend new.\x0a\x09send\x0a\x09\x09selector: aNode selector;\x0a\x09\x09index: aNode index.\x0a\x09\x0a\x09(self aliasTemporally: aNode dagChildren) do: [ :each | send add: each ].\x0a\x0a\x09^ send",
- referencedClasses: ["IRSend"],
- messageSends: ["new", "selector:", "selector", "index:", "index", "do:", "aliasTemporally:", "dagChildren", "add:"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitSequenceNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return self._withSequence_do_($recv($globals.IRSequence)._new(),(function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv(aNode)._dagChildren())._do_((function(each){
- var instruction;
- return $core.withContext(function($ctx3) {
- instruction=self._visitOrAlias_(each);
- instruction;
- $1=$recv(instruction)._isVariable();
- if(!$core.assert($1)){
- return $recv(self._sequence())._add_(instruction);
- }
- }, function($ctx3) {$ctx3.fillBlock({each:each,instruction:instruction},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"visitSequenceNode:",{aNode:aNode},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitSequenceNode: aNode\x0a\x09^ self\x0a\x09\x09withSequence: IRSequence new\x0a\x09\x09do: [\x0a\x09\x09\x09aNode dagChildren do: [ :each | | instruction |\x0a\x09\x09\x09\x09instruction := self visitOrAlias: each.\x0a\x09\x09\x09\x09instruction isVariable ifFalse: [\x0a\x09\x09\x09\x09\x09self sequence add: instruction ] ]]",
- referencedClasses: ["IRSequence"],
- messageSends: ["withSequence:do:", "new", "do:", "dagChildren", "visitOrAlias:", "ifFalse:", "isVariable", "add:", "sequence"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitValueNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRValue)._new();
- $recv($1)._value_($recv(aNode)._value());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"visitValueNode:",{aNode:aNode},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitValueNode: aNode\x0a\x09^ IRValue new\x0a\x09\x09value: aNode value;\x0a\x09\x09yourself",
- referencedClasses: ["IRValue"],
- messageSends: ["value:", "new", "value", "yourself"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitVariableNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRVariable)._new();
- $recv($1)._variable_($recv(aNode)._binding());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode},$globals.IRASTTranslator)});
- },
- args: ["aNode"],
- source: "visitVariableNode: aNode\x0a\x09^ IRVariable new\x0a\x09\x09variable: aNode binding;\x0a\x09\x09yourself",
- referencedClasses: ["IRVariable"],
- messageSends: ["variable:", "new", "binding", "yourself"]
- }),
- $globals.IRASTTranslator);
- $core.addMethod(
- $core.method({
- selector: "withSequence:do:",
- protocol: "accessing",
- fn: function (aSequence,aBlock){
- var self=this;
- var outerSequence;
- return $core.withContext(function($ctx1) {
- outerSequence=self._sequence();
- self._sequence_(aSequence);
- $ctx1.sendIdx["sequence:"]=1;
- $recv(aBlock)._value();
- self._sequence_(outerSequence);
- return aSequence;
- }, function($ctx1) {$ctx1.fill(self,"withSequence:do:",{aSequence:aSequence,aBlock:aBlock,outerSequence:outerSequence},$globals.IRASTTranslator)});
- },
- args: ["aSequence", "aBlock"],
- source: "withSequence: aSequence do: aBlock\x0a\x09| outerSequence |\x0a\x09outerSequence := self sequence.\x0a\x09self sequence: aSequence.\x0a\x09aBlock value.\x0a\x09self sequence: outerSequence.\x0a\x09^ aSequence",
- referencedClasses: [],
- messageSends: ["sequence", "sequence:", "value"]
- }),
- $globals.IRASTTranslator);
- $core.addClass("IRInstruction", $globals.DagParentNode, ["parent"], "Compiler-IR");
- $globals.IRInstruction.comment="I am the abstract root class of the IR (intermediate representation) instructions class hierarchy.\x0aThe IR graph is used to emit JavaScript code using a JSStream.";
- $core.addMethod(
- $core.method({
- selector: "add:",
- protocol: "building",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anObject)._parent_(self);
- return $recv(self._dagChildren())._add_(anObject);
- }, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject},$globals.IRInstruction)});
- },
- args: ["anObject"],
- source: "add: anObject\x0a\x09anObject parent: self.\x0a\x09^ self dagChildren add: anObject",
- referencedClasses: [],
- messageSends: ["parent:", "add:", "dagChildren"]
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "isClosure",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isClosure\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "isInlined",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isInlined\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "isMethod",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isMethod\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "isSend",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isSend\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "isSequence",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isSequence\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "isTempDeclaration",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isTempDeclaration\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "isVariable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isVariable\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._parent())._method();
- }, function($ctx1) {$ctx1.fill(self,"method",{},$globals.IRInstruction)});
- },
- args: [],
- source: "method\x0a\x09^ self parent method",
- referencedClasses: [],
- messageSends: ["method", "parent"]
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "needsBoxingAsReceiver",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "needsBoxingAsReceiver\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "parent",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@parent"];
- },
- args: [],
- source: "parent\x0a\x09^ parent",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "parent:",
- protocol: "accessing",
- fn: function (anIRInstruction){
- var self=this;
- self["@parent"]=anIRInstruction;
- return self;
- },
- args: ["anIRInstruction"],
- source: "parent: anIRInstruction\x0a\x09parent := anIRInstruction",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "remove:",
- protocol: "building",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._dagChildren())._remove_(anIRInstruction);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"remove:",{anIRInstruction:anIRInstruction},$globals.IRInstruction)});
- },
- args: ["anIRInstruction"],
- source: "remove: anIRInstruction\x0a\x09self dagChildren remove: anIRInstruction",
- referencedClasses: [],
- messageSends: ["remove:", "dagChildren"]
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "replace:with:",
- protocol: "building",
- fn: function (anIRInstruction,anotherIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(anotherIRInstruction)._parent_(self);
- $1=self._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- $recv($1)._at_put_($recv(self._dagChildren())._indexOf_(anIRInstruction),anotherIRInstruction);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"replace:with:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},$globals.IRInstruction)});
- },
- args: ["anIRInstruction", "anotherIRInstruction"],
- source: "replace: anIRInstruction with: anotherIRInstruction\x0a\x09anotherIRInstruction parent: self.\x0a\x09self dagChildren\x0a\x09\x09at: (self dagChildren indexOf: anIRInstruction)\x0a\x09\x09put: anotherIRInstruction",
- referencedClasses: [],
- messageSends: ["parent:", "at:put:", "dagChildren", "indexOf:"]
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "replaceWith:",
- protocol: "building",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._parent())._replace_with_(self,anIRInstruction);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"replaceWith:",{anIRInstruction:anIRInstruction},$globals.IRInstruction)});
- },
- args: ["anIRInstruction"],
- source: "replaceWith: anIRInstruction\x0a\x09self parent replace: self with: anIRInstruction",
- referencedClasses: [],
- messageSends: ["replace:with:", "parent"]
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._parent();
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- var node;
- node=$receiver;
- return $recv(node)._scope();
- }
- }, function($ctx1) {$ctx1.fill(self,"scope",{},$globals.IRInstruction)});
- },
- args: [],
- source: "scope\x0a\x09^ self parent ifNotNil: [ :node | \x0a\x09\x09node scope ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "parent", "scope"]
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "yieldsValue",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "yieldsValue\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aBuilder){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._builder_(aBuilder);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{aBuilder:aBuilder},$globals.IRInstruction.klass)});
- },
- args: ["aBuilder"],
- source: "on: aBuilder\x0a\x09^ self new\x0a\x09\x09builder: aBuilder;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["builder:", "new", "yourself"]
- }),
- $globals.IRInstruction.klass);
- $core.addClass("IRAssignment", $globals.IRInstruction, [], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRAssignment_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRAssignment)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRAssignment: self",
- referencedClasses: [],
- messageSends: ["visitIRAssignment:"]
- }),
- $globals.IRAssignment);
- $core.addMethod(
- $core.method({
- selector: "left",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._dagChildren())._first();
- }, function($ctx1) {$ctx1.fill(self,"left",{},$globals.IRAssignment)});
- },
- args: [],
- source: "left\x0a\x09^ self dagChildren first",
- referencedClasses: [],
- messageSends: ["first", "dagChildren"]
- }),
- $globals.IRAssignment);
- $core.addMethod(
- $core.method({
- selector: "right",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._dagChildren())._last();
- }, function($ctx1) {$ctx1.fill(self,"right",{},$globals.IRAssignment)});
- },
- args: [],
- source: "right\x0a\x09^ self dagChildren last",
- referencedClasses: [],
- messageSends: ["last", "dagChildren"]
- }),
- $globals.IRAssignment);
- $core.addClass("IRDynamicArray", $globals.IRInstruction, [], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRDynamicArray_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRDynamicArray)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRDynamicArray: self",
- referencedClasses: [],
- messageSends: ["visitIRDynamicArray:"]
- }),
- $globals.IRDynamicArray);
- $core.addClass("IRDynamicDictionary", $globals.IRInstruction, [], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRDynamicDictionary_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRDynamicDictionary)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRDynamicDictionary: self",
- referencedClasses: [],
- messageSends: ["visitIRDynamicDictionary:"]
- }),
- $globals.IRDynamicDictionary);
- $core.addClass("IRScopedInstruction", $globals.IRInstruction, ["scope"], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@scope"];
- },
- args: [],
- source: "scope\x0a\x09^ scope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRScopedInstruction);
- $core.addMethod(
- $core.method({
- selector: "scope:",
- protocol: "accessing",
- fn: function (aScope){
- var self=this;
- self["@scope"]=aScope;
- return self;
- },
- args: ["aScope"],
- source: "scope: aScope\x0a\x09scope := aScope",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRScopedInstruction);
- $core.addClass("IRClosureInstruction", $globals.IRScopedInstruction, ["arguments", "requiresSmalltalkContext"], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@arguments"];
- if(($receiver = $1) == null || $receiver.isNil){
- return [];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"arguments",{},$globals.IRClosureInstruction)});
- },
- args: [],
- source: "arguments\x0a\x09^ arguments ifNil: [ #() ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.IRClosureInstruction);
- $core.addMethod(
- $core.method({
- selector: "arguments:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@arguments"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "arguments: aCollection\x0a\x09arguments := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRClosureInstruction);
- $core.addMethod(
- $core.method({
- selector: "locals",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._arguments())._copy();
- $recv($1)._addAll_($recv(self._tempDeclarations())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._name();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- })));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"locals",{},$globals.IRClosureInstruction)});
- },
- args: [],
- source: "locals\x0a\x09^ self arguments copy\x0a\x09\x09addAll: (self tempDeclarations collect: [ :each | each name ]);\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["addAll:", "copy", "arguments", "collect:", "tempDeclarations", "name", "yourself"]
- }),
- $globals.IRClosureInstruction);
- $core.addMethod(
- $core.method({
- selector: "requiresSmalltalkContext",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@requiresSmalltalkContext"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"requiresSmalltalkContext",{},$globals.IRClosureInstruction)});
- },
- args: [],
- source: "requiresSmalltalkContext\x0a\x09^ requiresSmalltalkContext ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.IRClosureInstruction);
- $core.addMethod(
- $core.method({
- selector: "requiresSmalltalkContext:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@requiresSmalltalkContext"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "requiresSmalltalkContext: anObject\x0a\x09requiresSmalltalkContext := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRClosureInstruction);
- $core.addMethod(
- $core.method({
- selector: "scope:",
- protocol: "accessing",
- fn: function (aScope){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.IRClosureInstruction.superclass||$boot.nilAsClass).fn.prototype._scope_.apply($recv(self), [aScope]));
- $ctx1.supercall = false;
- $recv(aScope)._instruction_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"scope:",{aScope:aScope},$globals.IRClosureInstruction)});
- },
- args: ["aScope"],
- source: "scope: aScope\x0a\x09super scope: aScope.\x0a\x09aScope instruction: self",
- referencedClasses: [],
- messageSends: ["scope:", "instruction:"]
- }),
- $globals.IRClosureInstruction);
- $core.addMethod(
- $core.method({
- selector: "tempDeclarations",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._dagChildren())._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._isTempDeclaration();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"tempDeclarations",{},$globals.IRClosureInstruction)});
- },
- args: [],
- source: "tempDeclarations\x0a\x09^ self dagChildren select: [ :each |\x0a\x09\x09each isTempDeclaration ]",
- referencedClasses: [],
- messageSends: ["select:", "dagChildren", "isTempDeclaration"]
- }),
- $globals.IRClosureInstruction);
- $core.addClass("IRClosure", $globals.IRClosureInstruction, [], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRClosure_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRClosure)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRClosure: self",
- referencedClasses: [],
- messageSends: ["visitIRClosure:"]
- }),
- $globals.IRClosure);
- $core.addMethod(
- $core.method({
- selector: "isClosure",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isClosure\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRClosure);
- $core.addMethod(
- $core.method({
- selector: "sequence",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._dagChildren())._last();
- }, function($ctx1) {$ctx1.fill(self,"sequence",{},$globals.IRClosure)});
- },
- args: [],
- source: "sequence\x0a\x09^ self dagChildren last",
- referencedClasses: [],
- messageSends: ["last", "dagChildren"]
- }),
- $globals.IRClosure);
- $core.addClass("IRMethod", $globals.IRClosureInstruction, ["theClass", "source", "selector", "classReferences", "sendIndexes", "requiresSmalltalkContext", "internalVariables"], "Compiler-IR");
- $globals.IRMethod.comment="I am a method instruction";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRMethod_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRMethod)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRMethod: self",
- referencedClasses: [],
- messageSends: ["visitIRMethod:"]
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "classReferences",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@classReferences"];
- },
- args: [],
- source: "classReferences\x0a\x09^ classReferences",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "classReferences:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@classReferences"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "classReferences: aCollection\x0a\x09classReferences := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "internalVariables",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@internalVariables"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@internalVariables"]=$recv($globals.Set)._new();
- return self["@internalVariables"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"internalVariables",{},$globals.IRMethod)});
- },
- args: [],
- source: "internalVariables\x0a\x09^ internalVariables ifNil: [ internalVariables := Set new ]",
- referencedClasses: ["Set"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "isMethod",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isMethod\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "messageSends",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._sendIndexes())._keys();
- }, function($ctx1) {$ctx1.fill(self,"messageSends",{},$globals.IRMethod)});
- },
- args: [],
- source: "messageSends\x0a\x09^ self sendIndexes keys",
- referencedClasses: [],
- messageSends: ["keys", "sendIndexes"]
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "method\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@selector"];
- },
- args: [],
- source: "selector\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@selector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09selector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "sendIndexes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@sendIndexes"];
- },
- args: [],
- source: "sendIndexes\x0a\x09^ sendIndexes",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "sendIndexes:",
- protocol: "accessing",
- fn: function (aDictionary){
- var self=this;
- self["@sendIndexes"]=aDictionary;
- return self;
- },
- args: ["aDictionary"],
- source: "sendIndexes: aDictionary\x0a\x09sendIndexes := aDictionary",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@source"];
- },
- args: [],
- source: "source\x0a\x09^ source",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@source"]=aString;
- return self;
- },
- args: ["aString"],
- source: "source: aString\x0a\x09source := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "theClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@theClass"];
- },
- args: [],
- source: "theClass\x0a\x09^ theClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addMethod(
- $core.method({
- selector: "theClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@theClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "theClass: aClass\x0a\x09theClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRMethod);
- $core.addClass("IRReturn", $globals.IRScopedInstruction, [], "Compiler-IR");
- $globals.IRReturn.comment="I am a local return instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRReturn_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRReturn)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRReturn: self",
- referencedClasses: [],
- messageSends: ["visitIRReturn:"]
- }),
- $globals.IRReturn);
- $core.addMethod(
- $core.method({
- selector: "expression",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._dagChildren())._single();
- }, function($ctx1) {$ctx1.fill(self,"expression",{},$globals.IRReturn)});
- },
- args: [],
- source: "expression\x0a\x09^ self dagChildren single",
- referencedClasses: [],
- messageSends: ["single", "dagChildren"]
- }),
- $globals.IRReturn);
- $core.addMethod(
- $core.method({
- selector: "scope",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@scope"];
- if(($receiver = $1) == null || $receiver.isNil){
- return $recv(self._parent())._scope();
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"scope",{},$globals.IRReturn)});
- },
- args: [],
- source: "scope\x0a\x09^ scope ifNil: [ self parent scope ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "scope", "parent"]
- }),
- $globals.IRReturn);
- $core.addMethod(
- $core.method({
- selector: "yieldsValue",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "yieldsValue\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRReturn);
- $core.addClass("IRBlockReturn", $globals.IRReturn, [], "Compiler-IR");
- $globals.IRBlockReturn.comment="Smalltalk blocks return their last statement. I am a implicit block return instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRBlockReturn_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRBlockReturn)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRBlockReturn: self",
- referencedClasses: [],
- messageSends: ["visitIRBlockReturn:"]
- }),
- $globals.IRBlockReturn);
- $core.addClass("IRNonLocalReturn", $globals.IRReturn, [], "Compiler-IR");
- $globals.IRNonLocalReturn.comment="I am a non local return instruction.\x0aNon local returns are handled using a try/catch JavaScript statement.\x0a\x0aSee `IRNonLocalReturnHandling` class.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRNonLocalReturn_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRNonLocalReturn)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRNonLocalReturn: self",
- referencedClasses: [],
- messageSends: ["visitIRNonLocalReturn:"]
- }),
- $globals.IRNonLocalReturn);
- $core.addClass("IRTempDeclaration", $globals.IRScopedInstruction, ["name"], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRTempDeclaration_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRTempDeclaration)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRTempDeclaration: self",
- referencedClasses: [],
- messageSends: ["visitIRTempDeclaration:"]
- }),
- $globals.IRTempDeclaration);
- $core.addMethod(
- $core.method({
- selector: "isTempDeclaration",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isTempDeclaration\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRTempDeclaration);
- $core.addMethod(
- $core.method({
- selector: "name",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@name"];
- },
- args: [],
- source: "name\x0a\x09^ name",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRTempDeclaration);
- $core.addMethod(
- $core.method({
- selector: "name:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@name"]=aString;
- return self;
- },
- args: ["aString"],
- source: "name: aString\x0a\x09name := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRTempDeclaration);
- $core.addClass("IRSend", $globals.IRInstruction, ["selector", "index"], "Compiler-IR");
- $globals.IRSend.comment="I am a message send instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRSend_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRSend)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRSend: self",
- referencedClasses: [],
- messageSends: ["visitIRSend:"]
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._dagChildren())._allButFirst();
- }, function($ctx1) {$ctx1.fill(self,"arguments",{},$globals.IRSend)});
- },
- args: [],
- source: "arguments\x0a\x09^ self dagChildren allButFirst",
- referencedClasses: [],
- messageSends: ["allButFirst", "dagChildren"]
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "index",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@index"];
- },
- args: [],
- source: "index\x0a\x09^ index",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "index:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@index"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "index: anInteger\x0a\x09index := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "isSend",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSend\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "isSuperSend",
- protocol: "testing",
- fn: function (){
- var self=this;
- var receiver;
- return $core.withContext(function($ctx1) {
- receiver=self._receiver();
- return $recv($recv(receiver)._isVariable())._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv($recv(receiver)._variable())._name()).__eq("super");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"isSuperSend",{receiver:receiver},$globals.IRSend)});
- },
- args: [],
- source: "isSuperSend\x0a\x09| receiver |\x0a\x09receiver := self receiver.\x0a\x09^ receiver isVariable and: [ receiver variable name = 'super' ]",
- referencedClasses: [],
- messageSends: ["receiver", "and:", "isVariable", "=", "name", "variable"]
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "receiver",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._dagChildren())._first();
- }, function($ctx1) {$ctx1.fill(self,"receiver",{},$globals.IRSend)});
- },
- args: [],
- source: "receiver\x0a\x09^ self dagChildren first",
- referencedClasses: [],
- messageSends: ["first", "dagChildren"]
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@selector"];
- },
- args: [],
- source: "selector\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSend);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@selector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09selector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSend);
- $core.addClass("IRSequence", $globals.IRInstruction, [], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRSequence_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRSequence)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRSequence: self",
- referencedClasses: [],
- messageSends: ["visitIRSequence:"]
- }),
- $globals.IRSequence);
- $core.addMethod(
- $core.method({
- selector: "isSequence",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSequence\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSequence);
- $core.addClass("IRBlockSequence", $globals.IRSequence, [], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRBlockSequence_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRBlockSequence)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRBlockSequence: self",
- referencedClasses: [],
- messageSends: ["visitIRBlockSequence:"]
- }),
- $globals.IRBlockSequence);
- $core.addClass("IRValue", $globals.IRInstruction, ["value"], "Compiler-IR");
- $globals.IRValue.comment="I am the simplest possible instruction. I represent a value.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRValue_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRValue)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRValue: self",
- referencedClasses: [],
- messageSends: ["visitIRValue:"]
- }),
- $globals.IRValue);
- $core.addMethod(
- $core.method({
- selector: "needsBoxingAsReceiver",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "needsBoxingAsReceiver\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRValue);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@value"];
- },
- args: [],
- source: "value\x0a\x09^ value",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRValue);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@value"]=aString;
- return self;
- },
- args: ["aString"],
- source: "value: aString\x0a\x09value := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRValue);
- $core.addClass("IRVariable", $globals.IRInstruction, ["variable"], "Compiler-IR");
- $globals.IRVariable.comment="I am a variable instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRVariable_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRVariable)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRVariable: self",
- referencedClasses: [],
- messageSends: ["visitIRVariable:"]
- }),
- $globals.IRVariable);
- $core.addMethod(
- $core.method({
- selector: "isVariable",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isVariable\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRVariable);
- $core.addMethod(
- $core.method({
- selector: "needsBoxingAsReceiver",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._variable())._isPseudoVar())._not();
- }, function($ctx1) {$ctx1.fill(self,"needsBoxingAsReceiver",{},$globals.IRVariable)});
- },
- args: [],
- source: "needsBoxingAsReceiver\x0a\x09^ self variable isPseudoVar not",
- referencedClasses: [],
- messageSends: ["not", "isPseudoVar", "variable"]
- }),
- $globals.IRVariable);
- $core.addMethod(
- $core.method({
- selector: "variable",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@variable"];
- },
- args: [],
- source: "variable\x0a\x09^ variable",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRVariable);
- $core.addMethod(
- $core.method({
- selector: "variable:",
- protocol: "accessing",
- fn: function (aScopeVariable){
- var self=this;
- self["@variable"]=aScopeVariable;
- return self;
- },
- args: ["aScopeVariable"],
- source: "variable: aScopeVariable\x0a\x09variable := aScopeVariable",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRVariable);
- $core.addClass("IRVerbatim", $globals.IRInstruction, ["source"], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aVisitor)._visitIRVerbatim_(self);
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRVerbatim)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09^ aVisitor visitIRVerbatim: self",
- referencedClasses: [],
- messageSends: ["visitIRVerbatim:"]
- }),
- $globals.IRVerbatim);
- $core.addMethod(
- $core.method({
- selector: "source",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@source"];
- },
- args: [],
- source: "source\x0a\x09^ source",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRVerbatim);
- $core.addMethod(
- $core.method({
- selector: "source:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@source"]=aString;
- return self;
- },
- args: ["aString"],
- source: "source: aString\x0a\x09source := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRVerbatim);
- $core.addClass("IRVisitor", $globals.ParentFakingPathDagVisitor, [], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "visitDagNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNodeVariantSimple_(aNode);
- }, function($ctx1) {$ctx1.fill(self,"visitDagNode:",{aNode:aNode},$globals.IRVisitor)});
- },
- args: ["aNode"],
- source: "visitDagNode: aNode\x0a\x09^ self visitDagNodeVariantSimple: aNode",
- referencedClasses: [],
- messageSends: ["visitDagNodeVariantSimple:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRAssignment:",
- protocol: "visiting",
- fn: function (anIRAssignment){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRAssignment);
- }, function($ctx1) {$ctx1.fill(self,"visitIRAssignment:",{anIRAssignment:anIRAssignment},$globals.IRVisitor)});
- },
- args: ["anIRAssignment"],
- source: "visitIRAssignment: anIRAssignment\x0a\x09^ self visitDagNode: anIRAssignment",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRBlockReturn:",
- protocol: "visiting",
- fn: function (anIRBlockReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitIRReturn_(anIRBlockReturn);
- }, function($ctx1) {$ctx1.fill(self,"visitIRBlockReturn:",{anIRBlockReturn:anIRBlockReturn},$globals.IRVisitor)});
- },
- args: ["anIRBlockReturn"],
- source: "visitIRBlockReturn: anIRBlockReturn\x0a\x09^ self visitIRReturn: anIRBlockReturn",
- referencedClasses: [],
- messageSends: ["visitIRReturn:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRBlockSequence:",
- protocol: "visiting",
- fn: function (anIRBlockSequence){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitIRSequence_(anIRBlockSequence);
- }, function($ctx1) {$ctx1.fill(self,"visitIRBlockSequence:",{anIRBlockSequence:anIRBlockSequence},$globals.IRVisitor)});
- },
- args: ["anIRBlockSequence"],
- source: "visitIRBlockSequence: anIRBlockSequence\x0a\x09^ self visitIRSequence: anIRBlockSequence",
- referencedClasses: [],
- messageSends: ["visitIRSequence:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRClosure:",
- protocol: "visiting",
- fn: function (anIRClosure){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRClosure);
- }, function($ctx1) {$ctx1.fill(self,"visitIRClosure:",{anIRClosure:anIRClosure},$globals.IRVisitor)});
- },
- args: ["anIRClosure"],
- source: "visitIRClosure: anIRClosure\x0a\x09^ self visitDagNode: anIRClosure",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRDynamicArray:",
- protocol: "visiting",
- fn: function (anIRDynamicArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRDynamicArray);
- }, function($ctx1) {$ctx1.fill(self,"visitIRDynamicArray:",{anIRDynamicArray:anIRDynamicArray},$globals.IRVisitor)});
- },
- args: ["anIRDynamicArray"],
- source: "visitIRDynamicArray: anIRDynamicArray\x0a\x09^ self visitDagNode: anIRDynamicArray",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRDynamicDictionary:",
- protocol: "visiting",
- fn: function (anIRDynamicDictionary){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRDynamicDictionary);
- }, function($ctx1) {$ctx1.fill(self,"visitIRDynamicDictionary:",{anIRDynamicDictionary:anIRDynamicDictionary},$globals.IRVisitor)});
- },
- args: ["anIRDynamicDictionary"],
- source: "visitIRDynamicDictionary: anIRDynamicDictionary\x0a\x09^ self visitDagNode: anIRDynamicDictionary",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRInlinedClosure:",
- protocol: "visiting",
- fn: function (anIRInlinedClosure){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitIRClosure_(anIRInlinedClosure);
- }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedClosure:",{anIRInlinedClosure:anIRInlinedClosure},$globals.IRVisitor)});
- },
- args: ["anIRInlinedClosure"],
- source: "visitIRInlinedClosure: anIRInlinedClosure\x0a\x09^ self visitIRClosure: anIRInlinedClosure",
- referencedClasses: [],
- messageSends: ["visitIRClosure:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRInlinedSequence:",
- protocol: "visiting",
- fn: function (anIRInlinedSequence){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitIRSequence_(anIRInlinedSequence);
- }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedSequence:",{anIRInlinedSequence:anIRInlinedSequence},$globals.IRVisitor)});
- },
- args: ["anIRInlinedSequence"],
- source: "visitIRInlinedSequence: anIRInlinedSequence\x0a\x09^ self visitIRSequence: anIRInlinedSequence",
- referencedClasses: [],
- messageSends: ["visitIRSequence:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRMethod:",
- protocol: "visiting",
- fn: function (anIRMethod){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRMethod);
- }, function($ctx1) {$ctx1.fill(self,"visitIRMethod:",{anIRMethod:anIRMethod},$globals.IRVisitor)});
- },
- args: ["anIRMethod"],
- source: "visitIRMethod: anIRMethod\x0a\x09^ self visitDagNode: anIRMethod",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRNonLocalReturn:",
- protocol: "visiting",
- fn: function (anIRNonLocalReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRNonLocalReturn);
- }, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturn:",{anIRNonLocalReturn:anIRNonLocalReturn},$globals.IRVisitor)});
- },
- args: ["anIRNonLocalReturn"],
- source: "visitIRNonLocalReturn: anIRNonLocalReturn\x0a\x09^ self visitDagNode: anIRNonLocalReturn",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRNonLocalReturnHandling:",
- protocol: "visiting",
- fn: function (anIRNonLocalReturnHandling){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRNonLocalReturnHandling);
- }, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturnHandling:",{anIRNonLocalReturnHandling:anIRNonLocalReturnHandling},$globals.IRVisitor)});
- },
- args: ["anIRNonLocalReturnHandling"],
- source: "visitIRNonLocalReturnHandling: anIRNonLocalReturnHandling\x0a\x09^ self visitDagNode: anIRNonLocalReturnHandling",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRReturn:",
- protocol: "visiting",
- fn: function (anIRReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRReturn);
- }, function($ctx1) {$ctx1.fill(self,"visitIRReturn:",{anIRReturn:anIRReturn},$globals.IRVisitor)});
- },
- args: ["anIRReturn"],
- source: "visitIRReturn: anIRReturn\x0a\x09^ self visitDagNode: anIRReturn",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRSend:",
- protocol: "visiting",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRSend);
- }, function($ctx1) {$ctx1.fill(self,"visitIRSend:",{anIRSend:anIRSend},$globals.IRVisitor)});
- },
- args: ["anIRSend"],
- source: "visitIRSend: anIRSend\x0a\x09^ self visitDagNode: anIRSend",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRSequence:",
- protocol: "visiting",
- fn: function (anIRSequence){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRSequence);
- }, function($ctx1) {$ctx1.fill(self,"visitIRSequence:",{anIRSequence:anIRSequence},$globals.IRVisitor)});
- },
- args: ["anIRSequence"],
- source: "visitIRSequence: anIRSequence\x0a\x09^ self visitDagNode: anIRSequence",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRTempDeclaration:",
- protocol: "visiting",
- fn: function (anIRTempDeclaration){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRTempDeclaration);
- }, function($ctx1) {$ctx1.fill(self,"visitIRTempDeclaration:",{anIRTempDeclaration:anIRTempDeclaration},$globals.IRVisitor)});
- },
- args: ["anIRTempDeclaration"],
- source: "visitIRTempDeclaration: anIRTempDeclaration\x0a\x09^ self visitDagNode: anIRTempDeclaration",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRValue:",
- protocol: "visiting",
- fn: function (anIRValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRValue);
- }, function($ctx1) {$ctx1.fill(self,"visitIRValue:",{anIRValue:anIRValue},$globals.IRVisitor)});
- },
- args: ["anIRValue"],
- source: "visitIRValue: anIRValue\x0a\x09^ self visitDagNode: anIRValue",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRVariable:",
- protocol: "visiting",
- fn: function (anIRVariable){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRVariable);
- }, function($ctx1) {$ctx1.fill(self,"visitIRVariable:",{anIRVariable:anIRVariable},$globals.IRVisitor)});
- },
- args: ["anIRVariable"],
- source: "visitIRVariable: anIRVariable\x0a\x09^ self visitDagNode: anIRVariable",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitIRVerbatim:",
- protocol: "visiting",
- fn: function (anIRVerbatim){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._visitDagNode_(anIRVerbatim);
- }, function($ctx1) {$ctx1.fill(self,"visitIRVerbatim:",{anIRVerbatim:anIRVerbatim},$globals.IRVisitor)});
- },
- args: ["anIRVerbatim"],
- source: "visitIRVerbatim: anIRVerbatim\x0a\x09^ self visitDagNode: anIRVerbatim",
- referencedClasses: [],
- messageSends: ["visitDagNode:"]
- }),
- $globals.IRVisitor);
- $core.addClass("IRJSTranslator", $globals.IRVisitor, ["stream", "currentClass"], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "contents",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._stream())._contents();
- }, function($ctx1) {$ctx1.fill(self,"contents",{},$globals.IRJSTranslator)});
- },
- args: [],
- source: "contents\x0a\x09^ self stream contents",
- referencedClasses: [],
- messageSends: ["contents", "stream"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "currentClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@currentClass"];
- },
- args: [],
- source: "currentClass\x0a\x09^ currentClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "currentClass:",
- protocol: "accessing",
- fn: function (aClass){
- var self=this;
- self["@currentClass"]=aClass;
- return self;
- },
- args: ["aClass"],
- source: "currentClass: aClass\x0a\x09currentClass := aClass",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.IRJSTranslator.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@stream"]=$recv($globals.JSStream)._new();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.IRJSTranslator)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09stream := JSStream new.",
- referencedClasses: ["JSStream"],
- messageSends: ["initialize", "new"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "stream",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@stream"];
- },
- args: [],
- source: "stream\x0a\x09^ stream",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "stream:",
- protocol: "accessing",
- fn: function (aStream){
- var self=this;
- self["@stream"]=aStream;
- return self;
- },
- args: ["aStream"],
- source: "stream: aStream\x0a\x09stream := aStream",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRAssignment:",
- protocol: "visiting",
- fn: function (anIRAssignment){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._stream())._nextPutAssignLhs_rhs_((function(){
- return $core.withContext(function($ctx2) {
- return self._visit_($recv(anIRAssignment)._left());
- $ctx2.sendIdx["visit:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return self._visit_($recv(anIRAssignment)._right());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRAssignment:",{anIRAssignment:anIRAssignment},$globals.IRJSTranslator)});
- },
- args: ["anIRAssignment"],
- source: "visitIRAssignment: anIRAssignment\x0a\x09self stream\x0a\x09\x09nextPutAssignLhs: [self visit: anIRAssignment left]\x0a\x09\x09rhs: [self visit: anIRAssignment right].",
- referencedClasses: [],
- messageSends: ["nextPutAssignLhs:rhs:", "stream", "visit:", "left", "right"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRClosure:",
- protocol: "visiting",
- fn: function (anIRClosure){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutClosureWith_arguments_((function(){
- return $core.withContext(function($ctx2) {
- $2=self._stream();
- $ctx2.sendIdx["stream"]=2;
- $recv($2)._nextPutVars_($recv($recv(anIRClosure)._tempDeclarations())._collect_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv($recv(each)._name())._asVariableName();
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)});
- })));
- return $recv(self._stream())._nextPutBlockContextFor_during_(anIRClosure,(function(){
- return $core.withContext(function($ctx3) {
- return (
- $ctx3.supercall = true,
- ($globals.IRJSTranslator.superclass||$boot.nilAsClass).fn.prototype._visitIRClosure_.apply($recv(self), [anIRClosure]));
- $ctx3.supercall = false;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$recv(anIRClosure)._arguments());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRClosure:",{anIRClosure:anIRClosure},$globals.IRJSTranslator)});
- },
- args: ["anIRClosure"],
- source: "visitIRClosure: anIRClosure\x0a\x09self stream\x0a\x09\x09nextPutClosureWith: [\x0a\x09\x09\x09self stream nextPutVars: (anIRClosure tempDeclarations collect: [ :each |\x0a\x09\x09\x09\x09\x09each name asVariableName ]).\x0a\x09\x09\x09self stream\x0a\x09\x09\x09\x09nextPutBlockContextFor: anIRClosure\x0a\x09\x09\x09\x09during: [ super visitIRClosure: anIRClosure ] ]\x0a\x09\x09arguments: anIRClosure arguments",
- referencedClasses: [],
- messageSends: ["nextPutClosureWith:arguments:", "stream", "nextPutVars:", "collect:", "tempDeclarations", "asVariableName", "name", "nextPutBlockContextFor:during:", "visitIRClosure:", "arguments"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRDynamicArray:",
- protocol: "visiting",
- fn: function (anIRDynamicArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._visitInstructionList_enclosedBetween_and_($recv(anIRDynamicArray)._dagChildren(),"[","]");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRDynamicArray:",{anIRDynamicArray:anIRDynamicArray},$globals.IRJSTranslator)});
- },
- args: ["anIRDynamicArray"],
- source: "visitIRDynamicArray: anIRDynamicArray\x0a\x09self\x0a\x09\x09visitInstructionList: anIRDynamicArray dagChildren\x0a\x09\x09enclosedBetween: '[' and: ']'",
- referencedClasses: [],
- messageSends: ["visitInstructionList:enclosedBetween:and:", "dagChildren"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRDynamicDictionary:",
- protocol: "visiting",
- fn: function (anIRDynamicDictionary){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._visitInstructionList_enclosedBetween_and_($recv(anIRDynamicDictionary)._dagChildren(),"$globals.HashedCollection._newFromPairs_([","])");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRDynamicDictionary:",{anIRDynamicDictionary:anIRDynamicDictionary},$globals.IRJSTranslator)});
- },
- args: ["anIRDynamicDictionary"],
- source: "visitIRDynamicDictionary: anIRDynamicDictionary\x0a\x09self\x0a\x09\x09visitInstructionList: anIRDynamicDictionary dagChildren\x0a\x09\x09enclosedBetween: '$globals.HashedCollection._newFromPairs_([' and: '])'",
- referencedClasses: [],
- messageSends: ["visitInstructionList:enclosedBetween:and:", "dagChildren"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRMethod:",
- protocol: "visiting",
- fn: function (anIRMethod){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutMethodDeclaration_with_(anIRMethod,(function(){
- return $core.withContext(function($ctx2) {
- $2=self._stream();
- $ctx2.sendIdx["stream"]=2;
- return $recv($2)._nextPutFunctionWith_arguments_((function(){
- return $core.withContext(function($ctx3) {
- $3=self._stream();
- $ctx3.sendIdx["stream"]=3;
- $4=$recv($recv(anIRMethod)._tempDeclarations())._collect_((function(each){
- return $core.withContext(function($ctx4) {
- return $recv($recv(each)._name())._asVariableName();
- }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3,3)});
- }));
- $ctx3.sendIdx["collect:"]=1;
- $recv($3)._nextPutVars_($4);
- $ctx3.sendIdx["nextPutVars:"]=1;
- $5=self._stream();
- $ctx3.sendIdx["stream"]=4;
- return $recv($5)._nextPutContextFor_during_(anIRMethod,(function(){
- return $core.withContext(function($ctx4) {
- $recv($recv(anIRMethod)._internalVariables())._ifNotEmpty_((function(internalVars){
- return $core.withContext(function($ctx5) {
- $6=self._stream();
- $ctx5.sendIdx["stream"]=5;
- return $recv($6)._nextPutVars_($recv($recv(internalVars)._asSet())._collect_((function(each){
- return $core.withContext(function($ctx6) {
- return $recv($recv(each)._variable())._alias();
- }, function($ctx6) {$ctx6.fillBlock({each:each},$ctx5,6)});
- })));
- }, function($ctx5) {$ctx5.fillBlock({internalVars:internalVars},$ctx4,5)});
- }));
- $7=$recv($recv(anIRMethod)._scope())._hasNonLocalReturn();
- if($core.assert($7)){
- return $recv(self._stream())._nextPutNonLocalReturnHandlingWith_((function(){
- return $core.withContext(function($ctx5) {
- return (
- $ctx5.supercall = true,
- ($globals.IRJSTranslator.superclass||$boot.nilAsClass).fn.prototype._visitIRMethod_.apply($recv(self), [anIRMethod]));
- $ctx5.supercall = false;
- $ctx5.sendIdx["visitIRMethod:"]=1;
- }, function($ctx5) {$ctx5.fillBlock({},$ctx4,8)});
- }));
- } else {
- return (
- $ctx4.supercall = true,
- ($globals.IRJSTranslator.superclass||$boot.nilAsClass).fn.prototype._visitIRMethod_.apply($recv(self), [anIRMethod]));
- $ctx4.supercall = false;
- }
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,4)});
- }));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }),$recv(anIRMethod)._arguments());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self._contents();
- }, function($ctx1) {$ctx1.fill(self,"visitIRMethod:",{anIRMethod:anIRMethod},$globals.IRJSTranslator)});
- },
- args: ["anIRMethod"],
- source: "visitIRMethod: anIRMethod\x0a\x0a\x09self stream\x0a\x09\x09nextPutMethodDeclaration: anIRMethod\x0a\x09\x09with: [ self stream\x0a\x09\x09\x09nextPutFunctionWith: [\x0a\x09\x09\x09\x09self stream nextPutVars: (anIRMethod tempDeclarations collect: [ :each |\x0a\x09\x09\x09\x09\x09each name asVariableName ]).\x0a\x09\x09\x09\x09self stream nextPutContextFor: anIRMethod during: [\x0a\x09\x09\x09\x09\x09anIRMethod internalVariables ifNotEmpty: [ :internalVars |\x0a\x09\x09\x09\x09\x09\x09self stream nextPutVars: \x0a\x09\x09\x09\x09\x09\x09\x09(internalVars asSet collect: [ :each | each variable alias ]) ].\x0a\x09\x09\x09\x09anIRMethod scope hasNonLocalReturn\x0a\x09\x09\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09\x09\x09self stream nextPutNonLocalReturnHandlingWith: [\x0a\x09\x09\x09\x09\x09\x09\x09super visitIRMethod: anIRMethod ] ]\x0a\x09\x09\x09\x09\x09ifFalse: [ super visitIRMethod: anIRMethod ] ]]\x0a\x09\x09\x09arguments: anIRMethod arguments ].\x0a\x09^ self contents",
- referencedClasses: [],
- messageSends: ["nextPutMethodDeclaration:with:", "stream", "nextPutFunctionWith:arguments:", "nextPutVars:", "collect:", "tempDeclarations", "asVariableName", "name", "nextPutContextFor:during:", "ifNotEmpty:", "internalVariables", "asSet", "alias", "variable", "ifTrue:ifFalse:", "hasNonLocalReturn", "scope", "nextPutNonLocalReturnHandlingWith:", "visitIRMethod:", "arguments", "contents"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRNonLocalReturn:",
- protocol: "visiting",
- fn: function (anIRNonLocalReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._stream())._nextPutNonLocalReturnWith_((function(){
- return $core.withContext(function($ctx2) {
- return (
- $ctx2.supercall = true,
- ($globals.IRJSTranslator.superclass||$boot.nilAsClass).fn.prototype._visitIRNonLocalReturn_.apply($recv(self), [anIRNonLocalReturn]));
- $ctx2.supercall = false;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturn:",{anIRNonLocalReturn:anIRNonLocalReturn},$globals.IRJSTranslator)});
- },
- args: ["anIRNonLocalReturn"],
- source: "visitIRNonLocalReturn: anIRNonLocalReturn\x0a\x09self stream nextPutNonLocalReturnWith: [\x0a\x09\x09super visitIRNonLocalReturn: anIRNonLocalReturn ]",
- referencedClasses: [],
- messageSends: ["nextPutNonLocalReturnWith:", "stream", "visitIRNonLocalReturn:"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRReturn:",
- protocol: "visiting",
- fn: function (anIRReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._stream())._nextPutReturnWith_((function(){
- return $core.withContext(function($ctx2) {
- return (
- $ctx2.supercall = true,
- ($globals.IRJSTranslator.superclass||$boot.nilAsClass).fn.prototype._visitIRReturn_.apply($recv(self), [anIRReturn]));
- $ctx2.supercall = false;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRReturn:",{anIRReturn:anIRReturn},$globals.IRJSTranslator)});
- },
- args: ["anIRReturn"],
- source: "visitIRReturn: anIRReturn\x0a\x09self stream nextPutReturnWith: [\x0a\x09\x09super visitIRReturn: anIRReturn ]",
- referencedClasses: [],
- messageSends: ["nextPutReturnWith:", "stream", "visitIRReturn:"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRSend:",
- protocol: "visiting",
- fn: function (anIRSend){
- var self=this;
- var sends,superclass;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- sends=$recv($recv($recv($recv(anIRSend)._method())._sendIndexes())._at_($recv(anIRSend)._selector()))._size();
- $1=$recv(anIRSend)._isSuperSend();
- if($core.assert($1)){
- self._visitSuperSend_(anIRSend);
- } else {
- self._visitSend_(anIRSend);
- }
- $2=$recv($recv(anIRSend)._index()).__lt(sends);
- if($core.assert($2)){
- $recv(self._stream())._nextPutSendIndexFor_(anIRSend);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRSend:",{anIRSend:anIRSend,sends:sends,superclass:superclass},$globals.IRJSTranslator)});
- },
- args: ["anIRSend"],
- source: "visitIRSend: anIRSend\x0a\x09| sends superclass |\x0a\x09sends := (anIRSend method sendIndexes at: anIRSend selector) size.\x0a\x09\x0a\x09anIRSend isSuperSend\x0a\x09\x09ifTrue: [ self visitSuperSend: anIRSend ]\x0a\x09\x09ifFalse: [ self visitSend: anIRSend ].\x0a\x09\x09\x0a\x09anIRSend index < sends\x0a\x09\x09ifTrue: [ self stream nextPutSendIndexFor: anIRSend ]",
- referencedClasses: [],
- messageSends: ["size", "at:", "sendIndexes", "method", "selector", "ifTrue:ifFalse:", "isSuperSend", "visitSuperSend:", "visitSend:", "ifTrue:", "<", "index", "nextPutSendIndexFor:", "stream"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRSequence:",
- protocol: "visiting",
- fn: function (anIRSequence){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(anIRSequence)._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self._stream())._nextPutStatementWith_((function(){
- return $core.withContext(function($ctx3) {
- return self._visit_(each);
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRSequence:",{anIRSequence:anIRSequence},$globals.IRJSTranslator)});
- },
- args: ["anIRSequence"],
- source: "visitIRSequence: anIRSequence\x0a\x09anIRSequence dagChildren do: [ :each |\x0a\x09\x09self stream nextPutStatementWith: [ self visit: each ] ]",
- referencedClasses: [],
- messageSends: ["do:", "dagChildren", "nextPutStatementWith:", "stream", "visit:"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRTempDeclaration:",
- protocol: "visiting",
- fn: function (anIRTempDeclaration){
- var self=this;
- return self;
- },
- args: ["anIRTempDeclaration"],
- source: "visitIRTempDeclaration: anIRTempDeclaration\x0a\x09\x22self stream\x0a\x09\x09nextPutAll: 'var ', anIRTempDeclaration name asVariableName, ';';\x0a\x09\x09lf\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRValue:",
- protocol: "visiting",
- fn: function (anIRValue){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._stream())._nextPutAll_($recv($recv(anIRValue)._value())._asJavaScriptSource());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRValue:",{anIRValue:anIRValue},$globals.IRJSTranslator)});
- },
- args: ["anIRValue"],
- source: "visitIRValue: anIRValue\x0a\x09self stream nextPutAll: anIRValue value asJavaScriptSource",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "stream", "asJavaScriptSource", "value"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRVariable:",
- protocol: "visiting",
- fn: function (anIRVariable){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$4;
- $3=$recv(anIRVariable)._variable();
- $ctx1.sendIdx["variable"]=1;
- $2=$recv($3)._name();
- $1=$recv($2).__eq("thisContext");
- if($core.assert($1)){
- $4=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($4)._nextPutAll_("$core.getThisContext()");
- $ctx1.sendIdx["nextPutAll:"]=1;
- } else {
- $recv(self._stream())._nextPutAll_($recv($recv(anIRVariable)._variable())._alias());
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRVariable:",{anIRVariable:anIRVariable},$globals.IRJSTranslator)});
- },
- args: ["anIRVariable"],
- source: "visitIRVariable: anIRVariable\x0a\x09anIRVariable variable name = 'thisContext'\x0a\x09\x09ifTrue: [ self stream nextPutAll: '$core.getThisContext()' ]\x0a\x09\x09ifFalse: [ self stream nextPutAll: anIRVariable variable alias ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "=", "name", "variable", "nextPutAll:", "stream", "alias"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRVerbatim:",
- protocol: "visiting",
- fn: function (anIRVerbatim){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutStatementWith_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._stream())._nextPutAll_($recv(anIRVerbatim)._source());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRVerbatim:",{anIRVerbatim:anIRVerbatim},$globals.IRJSTranslator)});
- },
- args: ["anIRVerbatim"],
- source: "visitIRVerbatim: anIRVerbatim\x0a\x09self stream nextPutStatementWith: [\x0a\x09\x09self stream nextPutAll: anIRVerbatim source ]",
- referencedClasses: [],
- messageSends: ["nextPutStatementWith:", "stream", "nextPutAll:", "source"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitInstructionList:enclosedBetween:and:",
- protocol: "visiting",
- fn: function (anArray,aString,anotherString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutAll_(aString);
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(anArray)._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- return self._visit_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._stream())._nextPutAll_(",");
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $recv(self["@stream"])._nextPutAll_(anotherString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitInstructionList:enclosedBetween:and:",{anArray:anArray,aString:aString,anotherString:anotherString},$globals.IRJSTranslator)});
- },
- args: ["anArray", "aString", "anotherString"],
- source: "visitInstructionList: anArray enclosedBetween: aString and: anotherString\x0a\x09self stream nextPutAll: aString.\x0a\x09anArray\x0a\x09\x09do: [ :each | self visit: each ]\x0a\x09\x09separatedBy: [ self stream nextPutAll: ',' ].\x0a\x09stream nextPutAll: anotherString",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "stream", "do:separatedBy:", "visit:"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitReceiver:",
- protocol: "visiting",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- $1=$recv(anIRInstruction)._needsBoxingAsReceiver();
- if(!$core.assert($1)){
- $2=self._visit_(anIRInstruction);
- $ctx1.sendIdx["visit:"]=1;
- return $2;
- }
- $3=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($3)._nextPutAll_("$recv(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._visit_(anIRInstruction);
- $recv(self._stream())._nextPutAll_(")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitReceiver:",{anIRInstruction:anIRInstruction},$globals.IRJSTranslator)});
- },
- args: ["anIRInstruction"],
- source: "visitReceiver: anIRInstruction\x0a\x09anIRInstruction needsBoxingAsReceiver ifFalse: [ ^ self visit: anIRInstruction ].\x0a\x09\x0a\x09self stream nextPutAll: '$recv('.\x0a\x09self visit: anIRInstruction.\x0a\x09self stream nextPutAll: ')'",
- referencedClasses: [],
- messageSends: ["ifFalse:", "needsBoxingAsReceiver", "visit:", "nextPutAll:", "stream"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitSend:",
- protocol: "visiting",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._visitReceiver_($recv(anIRSend)._receiver());
- $recv(self._stream())._nextPutAll_(".".__comma($recv($recv(anIRSend)._selector())._asJavaScriptMethodName()));
- self._visitInstructionList_enclosedBetween_and_($recv(anIRSend)._arguments(),"(",")");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitSend:",{anIRSend:anIRSend},$globals.IRJSTranslator)});
- },
- args: ["anIRSend"],
- source: "visitSend: anIRSend\x0a\x09self visitReceiver: anIRSend receiver.\x0a\x09self stream nextPutAll: '.', anIRSend selector asJavaScriptMethodName.\x0a\x09self\x0a\x09\x09visitInstructionList: anIRSend arguments\x0a\x09\x09enclosedBetween: '(' and: ')'",
- referencedClasses: [],
- messageSends: ["visitReceiver:", "receiver", "nextPutAll:", "stream", ",", "asJavaScriptMethodName", "selector", "visitInstructionList:enclosedBetween:and:", "arguments"]
- }),
- $globals.IRJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitSuperSend:",
- protocol: "visiting",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$4,$3,$2,$5,$6,$7,$8;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutAll_("(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv($1)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv($1)._nextPutAll_("//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);");
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv($1)._lf();
- $ctx1.sendIdx["lf"]=2;
- $4=$recv(anIRSend)._scope();
- $ctx1.sendIdx["scope"]=1;
- $3=$recv($4)._alias();
- $ctx1.sendIdx["alias"]=1;
- $2=$recv($3).__comma(".supercall = true,");
- $ctx1.sendIdx[","]=1;
- $recv($1)._nextPutAll_($2);
- $ctx1.sendIdx["nextPutAll:"]=3;
- $recv($1)._lf();
- $ctx1.sendIdx["lf"]=3;
- $recv($1)._nextPutAll_("//>>excludeEnd(\x22ctx\x22);");
- $ctx1.sendIdx["nextPutAll:"]=4;
- $recv($1)._lf();
- $ctx1.sendIdx["lf"]=4;
- $5="(".__comma($recv(self._currentClass())._asJavaScriptSource());
- $ctx1.sendIdx[","]=2;
- $recv($1)._nextPutAll_($5);
- $ctx1.sendIdx["nextPutAll:"]=5;
- $recv($1)._nextPutAll_(".superclass||$boot.nilAsClass).fn.prototype.");
- $ctx1.sendIdx["nextPutAll:"]=6;
- $6=$recv($recv($recv(anIRSend)._selector())._asJavaScriptMethodName()).__comma(".apply(");
- $ctx1.sendIdx[","]=3;
- $recv($1)._nextPutAll_($6);
- $ctx1.sendIdx["nextPutAll:"]=7;
- $7=$recv($1)._nextPutAll_("$recv(self), ");
- $ctx1.sendIdx["nextPutAll:"]=8;
- self._visitInstructionList_enclosedBetween_and_($recv(anIRSend)._arguments(),"[","]");
- $8=self._stream();
- $recv($8)._nextPutAll_("));");
- $ctx1.sendIdx["nextPutAll:"]=9;
- $recv($8)._lf();
- $ctx1.sendIdx["lf"]=5;
- $recv($8)._nextPutAll_("//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);");
- $ctx1.sendIdx["nextPutAll:"]=10;
- $recv($8)._lf();
- $ctx1.sendIdx["lf"]=6;
- $recv($8)._nextPutAll_($recv($recv($recv(anIRSend)._scope())._alias()).__comma(".supercall = false;"));
- $ctx1.sendIdx["nextPutAll:"]=11;
- $recv($8)._lf();
- $recv($8)._nextPutAll_("//>>excludeEnd(\x22ctx\x22);");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitSuperSend:",{anIRSend:anIRSend},$globals.IRJSTranslator)});
- },
- args: ["anIRSend"],
- source: "visitSuperSend: anIRSend\x0a\x09self stream\x0a\x09\x09nextPutAll: '('; lf;\x0a\x09\x09nextPutAll: '//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);'; lf;\x0a\x09\x09nextPutAll: anIRSend scope alias, '.supercall = true,'; lf;\x0a\x09\x09nextPutAll: '//>>excludeEnd(\x22ctx\x22);'; lf;\x0a\x09\x09nextPutAll: '(', self currentClass asJavaScriptSource;\x0a\x09\x09nextPutAll: '.superclass||$boot.nilAsClass).fn.prototype.';\x0a\x09\x09nextPutAll: anIRSend selector asJavaScriptMethodName, '.apply(';\x0a\x09\x09nextPutAll: '$recv(self), '.\x0a\x09self\x0a\x09\x09visitInstructionList: anIRSend arguments\x0a\x09\x09enclosedBetween: '[' and: ']'.\x0a\x09self stream \x0a\x09\x09nextPutAll: '));'; lf;\x0a\x09\x09nextPutAll: '//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);'; lf;\x0a\x09\x09nextPutAll: anIRSend scope alias, '.supercall = false;'; lf;\x0a\x09\x09nextPutAll: '//>>excludeEnd(\x22ctx\x22);'",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "stream", "lf", ",", "alias", "scope", "asJavaScriptSource", "currentClass", "asJavaScriptMethodName", "selector", "visitInstructionList:enclosedBetween:and:", "arguments"]
- }),
- $globals.IRJSTranslator);
- $core.addClass("JSStream", $globals.Object, ["stream", "omitSemicolon"], "Compiler-IR");
- $core.addMethod(
- $core.method({
- selector: "contents",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@stream"])._contents();
- }, function($ctx1) {$ctx1.fill(self,"contents",{},$globals.JSStream)});
- },
- args: [],
- source: "contents\x0a\x09^ stream contents",
- referencedClasses: [],
- messageSends: ["contents"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.JSStream.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@stream"]=""._writeStream();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.JSStream)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09stream := '' writeStream.",
- referencedClasses: [],
- messageSends: ["initialize", "writeStream"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "lf",
- protocol: "streaming",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@stream"])._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"lf",{},$globals.JSStream)});
- },
- args: [],
- source: "lf\x0a\x09stream lf",
- referencedClasses: [],
- messageSends: ["lf"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPut:",
- protocol: "streaming",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@stream"])._nextPut_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPut:",{aString:aString},$globals.JSStream)});
- },
- args: ["aString"],
- source: "nextPut: aString\x0a\x09stream nextPut: aString",
- referencedClasses: [],
- messageSends: ["nextPut:"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutAll:",
- protocol: "streaming",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@stream"])._nextPutAll_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutAll:",{aString:aString},$globals.JSStream)});
- },
- args: ["aString"],
- source: "nextPutAll: aString\x0a\x09stream nextPutAll: aString",
- referencedClasses: [],
- messageSends: ["nextPutAll:"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutAssignLhs:rhs:",
- protocol: "streaming",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aBlock)._value();
- $ctx1.sendIdx["value"]=1;
- $recv(self["@stream"])._nextPutAll_("=");
- $recv(anotherBlock)._value();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutAssignLhs:rhs:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.JSStream)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "nextPutAssignLhs: aBlock rhs: anotherBlock\x0a\x09aBlock value.\x0a\x09stream nextPutAll: '='.\x0a\x09anotherBlock value",
- referencedClasses: [],
- messageSends: ["value", "nextPutAll:"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutBlockContextFor:during:",
- protocol: "streaming",
- fn: function (anIRClosure,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$6,$5,$4,$3,$7,$11,$10,$9,$8,$15,$14,$13,$12,$16,$17,$23,$22,$21,$20,$19,$18;
- $1=$recv(anIRClosure)._requiresSmalltalkContext();
- if(!$core.assert($1)){
- $2=$recv(aBlock)._value();
- $ctx1.sendIdx["value"]=1;
- return $2;
- }
- self._nextPutAll_("//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._lf();
- $ctx1.sendIdx["lf"]=1;
- $6=$recv(anIRClosure)._scope();
- $ctx1.sendIdx["scope"]=1;
- $5=$recv($6)._alias();
- $ctx1.sendIdx["alias"]=1;
- $4="return $core.withContext(function(".__comma($5);
- $ctx1.sendIdx[","]=2;
- $3=$recv($4).__comma(") {");
- $ctx1.sendIdx[","]=1;
- self._nextPutAll_($3);
- $ctx1.sendIdx["nextPutAll:"]=2;
- self._lf();
- $ctx1.sendIdx["lf"]=2;
- self._nextPutAll_("//>>excludeEnd(\x22ctx\x22);");
- $ctx1.sendIdx["nextPutAll:"]=3;
- $7=self._lf();
- $ctx1.sendIdx["lf"]=3;
- $recv(aBlock)._value();
- self._nextPutAll_("//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);");
- $ctx1.sendIdx["nextPutAll:"]=4;
- self._lf();
- $ctx1.sendIdx["lf"]=4;
- $11=$recv(anIRClosure)._scope();
- $ctx1.sendIdx["scope"]=2;
- $10=$recv($11)._alias();
- $ctx1.sendIdx["alias"]=2;
- $9="}, function(".__comma($10);
- $ctx1.sendIdx[","]=4;
- $8=$recv($9).__comma(") {");
- $ctx1.sendIdx[","]=3;
- self._nextPutAll_($8);
- $ctx1.sendIdx["nextPutAll:"]=5;
- $15=$recv(anIRClosure)._scope();
- $ctx1.sendIdx["scope"]=3;
- $14=$recv($15)._alias();
- $ctx1.sendIdx["alias"]=3;
- $13=$recv($14).__comma(".fillBlock({");
- $ctx1.sendIdx[","]=5;
- $12=self._nextPutAll_($13);
- $ctx1.sendIdx["nextPutAll:"]=6;
- $recv($recv(anIRClosure)._locals())._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- $16=$recv(each)._asVariableName();
- $ctx2.sendIdx["asVariableName"]=1;
- self._nextPutAll_($16);
- $ctx2.sendIdx["nextPutAll:"]=7;
- self._nextPutAll_(":");
- $ctx2.sendIdx["nextPutAll:"]=8;
- $17=self._nextPutAll_($recv(each)._asVariableName());
- $ctx2.sendIdx["nextPutAll:"]=9;
- return $17;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return self._nextPutAll_(",");
- $ctx2.sendIdx["nextPutAll:"]=10;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- self._nextPutAll_("},");
- $ctx1.sendIdx["nextPutAll:"]=11;
- $23=$recv(anIRClosure)._scope();
- $ctx1.sendIdx["scope"]=4;
- $22=$recv($23)._outerScope();
- $21=$recv($22)._alias();
- $20=$recv($21).__comma(",");
- $19=$recv($20).__comma($recv($recv($recv(anIRClosure)._scope())._blockIndex())._asString());
- $ctx1.sendIdx[","]=7;
- $18=$recv($19).__comma(")});");
- $ctx1.sendIdx[","]=6;
- self._nextPutAll_($18);
- $ctx1.sendIdx["nextPutAll:"]=12;
- self._lf();
- self._nextPutAll_("//>>excludeEnd(\x22ctx\x22);");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutBlockContextFor:during:",{anIRClosure:anIRClosure,aBlock:aBlock},$globals.JSStream)});
- },
- args: ["anIRClosure", "aBlock"],
- source: "nextPutBlockContextFor: anIRClosure during: aBlock\x0a\x09anIRClosure requiresSmalltalkContext ifFalse: [ ^ aBlock value ].\x0a\x09self\x0a\x09\x09nextPutAll: '//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: 'return $core.withContext(function(', anIRClosure scope alias, ') {';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: '//>>excludeEnd(\x22ctx\x22);';\x0a\x09\x09lf.\x0a\x09\x0a\x09aBlock value.\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: '}, function(', anIRClosure scope alias, ') {';\x0a\x09\x09nextPutAll: anIRClosure scope alias, '.fillBlock({'.\x0a\x09\x0a\x09anIRClosure locals\x0a\x09\x09do: [ :each |\x0a\x09\x09\x09self\x0a\x09\x09\x09\x09nextPutAll: each asVariableName;\x0a\x09\x09\x09\x09nextPutAll: ':';\x0a\x09\x09\x09\x09nextPutAll: each asVariableName ]\x0a\x09\x09separatedBy: [ self nextPutAll: ',' ].\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '},';\x0a\x09\x09nextPutAll: anIRClosure scope outerScope alias, ',', anIRClosure scope blockIndex asString, ')});';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: '//>>excludeEnd(\x22ctx\x22);'",
- referencedClasses: [],
- messageSends: ["ifFalse:", "requiresSmalltalkContext", "value", "nextPutAll:", "lf", ",", "alias", "scope", "do:separatedBy:", "locals", "asVariableName", "outerScope", "asString", "blockIndex"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutClosureWith:arguments:",
- protocol: "streaming",
- fn: function (aBlock,anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- $recv(self["@stream"])._nextPutAll_("(function(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(anArray)._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self["@stream"])._nextPutAll_($recv(each)._asVariableName());
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@stream"])._nextPut_(",");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $1=self["@stream"];
- $recv($1)._nextPutAll_("){");
- $ctx1.sendIdx["nextPutAll:"]=3;
- $2=$recv($1)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(aBlock)._value();
- $3=self["@stream"];
- $recv($3)._lf();
- $recv($3)._nextPutAll_("})");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutClosureWith:arguments:",{aBlock:aBlock,anArray:anArray},$globals.JSStream)});
- },
- args: ["aBlock", "anArray"],
- source: "nextPutClosureWith: aBlock arguments: anArray\x0a\x09stream nextPutAll: '(function('.\x0a\x09anArray\x0a\x09\x09do: [ :each | stream nextPutAll: each asVariableName ]\x0a\x09\x09separatedBy: [ stream nextPut: ',' ].\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09aBlock value.\x0a\x09stream lf; nextPutAll: '})'",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "do:separatedBy:", "asVariableName", "nextPut:", "lf", "value"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutContextFor:during:",
- protocol: "streaming",
- fn: function (aMethod,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$6,$5,$4,$3,$7,$12,$11,$10,$9,$8,$16,$15,$14,$13,$17,$18;
- $1=$recv(aMethod)._requiresSmalltalkContext();
- if(!$core.assert($1)){
- $2=$recv(aBlock)._value();
- $ctx1.sendIdx["value"]=1;
- return $2;
- }
- self._nextPutAll_("//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._lf();
- $ctx1.sendIdx["lf"]=1;
- $6=$recv(aMethod)._scope();
- $ctx1.sendIdx["scope"]=1;
- $5=$recv($6)._alias();
- $ctx1.sendIdx["alias"]=1;
- $4="return $core.withContext(function(".__comma($5);
- $ctx1.sendIdx[","]=2;
- $3=$recv($4).__comma(") {");
- $ctx1.sendIdx[","]=1;
- self._nextPutAll_($3);
- $ctx1.sendIdx["nextPutAll:"]=2;
- self._lf();
- $ctx1.sendIdx["lf"]=2;
- self._nextPutAll_("//>>excludeEnd(\x22ctx\x22);");
- $ctx1.sendIdx["nextPutAll:"]=3;
- $7=self._lf();
- $ctx1.sendIdx["lf"]=3;
- $recv(aBlock)._value();
- self._nextPutAll_("//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);");
- $ctx1.sendIdx["nextPutAll:"]=4;
- self._lf();
- $ctx1.sendIdx["lf"]=4;
- $12=$recv(aMethod)._scope();
- $ctx1.sendIdx["scope"]=2;
- $11=$recv($12)._alias();
- $ctx1.sendIdx["alias"]=2;
- $10="}, function(".__comma($11);
- $ctx1.sendIdx[","]=5;
- $9=$recv($10).__comma(") {");
- $ctx1.sendIdx[","]=4;
- $8=$recv($9).__comma($recv($recv(aMethod)._scope())._alias());
- $ctx1.sendIdx[","]=3;
- self._nextPutAll_($8);
- $ctx1.sendIdx["nextPutAll:"]=5;
- $16=$recv($recv(aMethod)._selector())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=1;
- $15=".fill(self,".__comma($16);
- $14=$recv($15).__comma(",{");
- $ctx1.sendIdx[","]=6;
- $13=self._nextPutAll_($14);
- $ctx1.sendIdx["nextPutAll:"]=6;
- $recv($recv(aMethod)._locals())._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- $17=$recv(each)._asVariableName();
- $ctx2.sendIdx["asVariableName"]=1;
- self._nextPutAll_($17);
- $ctx2.sendIdx["nextPutAll:"]=7;
- self._nextPutAll_(":");
- $ctx2.sendIdx["nextPutAll:"]=8;
- $18=self._nextPutAll_($recv(each)._asVariableName());
- $ctx2.sendIdx["nextPutAll:"]=9;
- return $18;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return self._nextPutAll_(",");
- $ctx2.sendIdx["nextPutAll:"]=10;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- self._nextPutAll_("},");
- $ctx1.sendIdx["nextPutAll:"]=11;
- self._nextPutAll_($recv($recv(aMethod)._theClass())._asJavaScriptSource());
- $ctx1.sendIdx["nextPutAll:"]=12;
- self._nextPutAll_(")});");
- $ctx1.sendIdx["nextPutAll:"]=13;
- self._lf();
- self._nextPutAll_("//>>excludeEnd(\x22ctx\x22);");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutContextFor:during:",{aMethod:aMethod,aBlock:aBlock},$globals.JSStream)});
- },
- args: ["aMethod", "aBlock"],
- source: "nextPutContextFor: aMethod during: aBlock\x0a\x09aMethod requiresSmalltalkContext ifFalse: [ ^ aBlock value ].\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: 'return $core.withContext(function(', aMethod scope alias, ') {';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: '//>>excludeEnd(\x22ctx\x22);';\x0a\x09\x09lf.\x0a\x0a\x09aBlock value.\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: '}, function(', aMethod scope alias, ') {', aMethod scope alias;\x0a\x09\x09nextPutAll: '.fill(self,', aMethod selector asJavaScriptSource, ',{'.\x0a\x0a\x09aMethod locals\x0a\x09\x09do: [ :each |\x0a\x09\x09\x09self\x0a\x09\x09\x09\x09nextPutAll: each asVariableName;\x0a\x09\x09\x09\x09nextPutAll: ':';\x0a\x09\x09\x09\x09nextPutAll: each asVariableName ]\x0a\x09\x09separatedBy: [ self nextPutAll: ',' ].\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '},';\x0a\x09\x09nextPutAll: aMethod theClass asJavaScriptSource;\x0a\x09\x09nextPutAll: ')});';\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: '//>>excludeEnd(\x22ctx\x22);'",
- referencedClasses: [],
- messageSends: ["ifFalse:", "requiresSmalltalkContext", "value", "nextPutAll:", "lf", ",", "alias", "scope", "asJavaScriptSource", "selector", "do:separatedBy:", "locals", "asVariableName", "theClass"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutFunctionWith:arguments:",
- protocol: "streaming",
- fn: function (aBlock,anArray){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5;
- $recv(self["@stream"])._nextPutAll_("fn: function(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(anArray)._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self["@stream"])._nextPutAll_($recv(each)._asVariableName());
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@stream"])._nextPut_(",");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $1=self["@stream"];
- $recv($1)._nextPutAll_("){");
- $ctx1.sendIdx["nextPutAll:"]=3;
- $2=$recv($1)._lf();
- $ctx1.sendIdx["lf"]=1;
- $3=self["@stream"];
- $recv($3)._nextPutAll_("var self=this;");
- $ctx1.sendIdx["nextPutAll:"]=4;
- $4=$recv($3)._lf();
- $ctx1.sendIdx["lf"]=2;
- $recv(aBlock)._value();
- $5=self["@stream"];
- $recv($5)._lf();
- $recv($5)._nextPutAll_("}");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutFunctionWith:arguments:",{aBlock:aBlock,anArray:anArray},$globals.JSStream)});
- },
- args: ["aBlock", "anArray"],
- source: "nextPutFunctionWith: aBlock arguments: anArray\x0a\x09stream nextPutAll: 'fn: function('.\x0a\x09anArray\x0a\x09\x09do: [ :each | stream nextPutAll: each asVariableName ]\x0a\x09\x09separatedBy: [ stream nextPut: ',' ].\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09stream nextPutAll: 'var self=this;'; lf.\x0a\x09aBlock value.\x0a\x09stream lf; nextPutAll: '}'",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "do:separatedBy:", "asVariableName", "nextPut:", "lf", "value"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutIf:then:",
- protocol: "streaming",
- fn: function (aBlock,anotherBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(self["@stream"])._nextPutAll_("if(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aBlock)._value();
- $ctx1.sendIdx["value"]=1;
- $1=self["@stream"];
- $recv($1)._nextPutAll_("){");
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv($1)._lf();
- $recv(anotherBlock)._value();
- $recv(self["@stream"])._nextPutAll_("}");
- self._omitSemicolon_(true);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutIf:then:",{aBlock:aBlock,anotherBlock:anotherBlock},$globals.JSStream)});
- },
- args: ["aBlock", "anotherBlock"],
- source: "nextPutIf: aBlock then: anotherBlock\x0a\x09stream nextPutAll: 'if('.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09anotherBlock value.\x0a\x09stream nextPutAll: '}'.\x0a\x09self omitSemicolon: true",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "value", "lf", "omitSemicolon:"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutIf:then:else:",
- protocol: "streaming",
- fn: function (aBlock,ifBlock,elseBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- $recv(self["@stream"])._nextPutAll_("if(");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aBlock)._value();
- $ctx1.sendIdx["value"]=1;
- $1=self["@stream"];
- $recv($1)._nextPutAll_("){");
- $ctx1.sendIdx["nextPutAll:"]=2;
- $2=$recv($1)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv(ifBlock)._value();
- $ctx1.sendIdx["value"]=2;
- $3=self["@stream"];
- $recv($3)._nextPutAll_("} else {");
- $ctx1.sendIdx["nextPutAll:"]=3;
- $recv($3)._lf();
- $recv(elseBlock)._value();
- $recv(self["@stream"])._nextPutAll_("}");
- self._omitSemicolon_(true);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutIf:then:else:",{aBlock:aBlock,ifBlock:ifBlock,elseBlock:elseBlock},$globals.JSStream)});
- },
- args: ["aBlock", "ifBlock", "elseBlock"],
- source: "nextPutIf: aBlock then: ifBlock else: elseBlock\x0a\x09stream nextPutAll: 'if('.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09ifBlock value.\x0a\x09stream nextPutAll: '} else {'; lf.\x0a\x09elseBlock value.\x0a\x09stream nextPutAll: '}'.\x0a\x09self omitSemicolon: true",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "value", "lf", "omitSemicolon:"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutMethodDeclaration:with:",
- protocol: "streaming",
- fn: function (aMethod,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$4,$3,$2,$7,$6,$5,$8,$9,$12,$11,$10,$15,$14,$13,$18,$17,$16,$19,$20;
- $1=self["@stream"];
- $recv($1)._nextPutAll_("$core.method({");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv($1)._lf();
- $ctx1.sendIdx["lf"]=1;
- $4=$recv($recv(aMethod)._selector())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=1;
- $3="selector: ".__comma($4);
- $ctx1.sendIdx[","]=2;
- $2=$recv($3).__comma(",");
- $ctx1.sendIdx[","]=1;
- $recv($1)._nextPutAll_($2);
- $ctx1.sendIdx["nextPutAll:"]=2;
- $recv($1)._lf();
- $ctx1.sendIdx["lf"]=2;
- $7=$recv($recv(aMethod)._source())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=2;
- $6="source: ".__comma($7);
- $ctx1.sendIdx[","]=4;
- $5=$recv($6).__comma(",");
- $ctx1.sendIdx[","]=3;
- $recv($1)._nextPutAll_($5);
- $ctx1.sendIdx["nextPutAll:"]=3;
- $8=$recv($1)._lf();
- $ctx1.sendIdx["lf"]=3;
- $recv(aBlock)._value();
- $ctx1.sendIdx["value"]=1;
- $9=self["@stream"];
- $12=$recv($globals.String)._lf();
- $ctx1.sendIdx["lf"]=4;
- $11=",".__comma($12);
- $ctx1.sendIdx[","]=6;
- $10=$recv($11).__comma("messageSends: ");
- $ctx1.sendIdx[","]=5;
- $recv($9)._nextPutAll_($10);
- $ctx1.sendIdx["nextPutAll:"]=4;
- $15=$recv($recv(aMethod)._messageSends())._asArray();
- $ctx1.sendIdx["asArray"]=1;
- $14=$recv($15)._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=3;
- $13=$recv($14).__comma(",");
- $ctx1.sendIdx[","]=7;
- $recv($9)._nextPutAll_($13);
- $ctx1.sendIdx["nextPutAll:"]=5;
- $recv($9)._lf();
- $ctx1.sendIdx["lf"]=5;
- $18=$recv($recv($recv($recv(aMethod)._arguments())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._value();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- })))._asArray())._asJavaScriptSource();
- $ctx1.sendIdx["asJavaScriptSource"]=4;
- $17="args: ".__comma($18);
- $16=$recv($17).__comma(",");
- $ctx1.sendIdx[","]=8;
- $recv($9)._nextPutAll_($16);
- $ctx1.sendIdx["nextPutAll:"]=6;
- $recv($9)._lf();
- $19=$recv($9)._nextPutAll_("referencedClasses: [");
- $ctx1.sendIdx["nextPutAll:"]=7;
- $recv($recv(aMethod)._classReferences())._do_separatedBy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self["@stream"])._nextPutAll_($recv(each)._asJavaScriptSource());
- $ctx2.sendIdx["nextPutAll:"]=8;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@stream"])._nextPutAll_(",");
- $ctx2.sendIdx["nextPutAll:"]=9;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- $20=self["@stream"];
- $recv($20)._nextPutAll_("]");
- $ctx1.sendIdx["nextPutAll:"]=10;
- $recv($20)._nextPutAll_("})");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutMethodDeclaration:with:",{aMethod:aMethod,aBlock:aBlock},$globals.JSStream)});
- },
- args: ["aMethod", "aBlock"],
- source: "nextPutMethodDeclaration: aMethod with: aBlock\x0a\x09stream\x0a\x09\x09nextPutAll: '$core.method({'; lf;\x0a\x09\x09nextPutAll: 'selector: ', aMethod selector asJavaScriptSource, ','; lf;\x0a\x09\x09nextPutAll: 'source: ', aMethod source asJavaScriptSource, ',';lf.\x0a\x09aBlock value.\x0a\x09stream\x0a\x09\x09nextPutAll: ',', String lf, 'messageSends: ';\x0a\x09\x09nextPutAll: aMethod messageSends asArray asJavaScriptSource, ','; lf;\x0a\x09\x09nextPutAll: 'args: ', (aMethod arguments collect: [ :each | each value ]) asArray asJavaScriptSource, ','; lf;\x0a\x09\x09nextPutAll: 'referencedClasses: ['.\x0a\x09aMethod classReferences\x0a\x09\x09do: [ :each | stream nextPutAll: each asJavaScriptSource ]\x0a\x09\x09separatedBy: [ stream nextPutAll: ',' ].\x0a\x09stream\x0a\x09\x09nextPutAll: ']';\x0a\x09\x09nextPutAll: '})'",
- referencedClasses: ["String"],
- messageSends: ["nextPutAll:", "lf", ",", "asJavaScriptSource", "selector", "source", "value", "asArray", "messageSends", "collect:", "arguments", "do:separatedBy:", "classReferences"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutNonLocalReturnHandlingWith:",
- protocol: "streaming",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- $1=self["@stream"];
- $recv($1)._nextPutAll_("var $early={};");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv($1)._lf();
- $ctx1.sendIdx["lf"]=1;
- $recv($1)._nextPutAll_("try {");
- $ctx1.sendIdx["nextPutAll:"]=2;
- $2=$recv($1)._lf();
- $ctx1.sendIdx["lf"]=2;
- $recv(aBlock)._value();
- $3=self["@stream"];
- $recv($3)._nextPutAll_("}");
- $ctx1.sendIdx["nextPutAll:"]=3;
- $recv($3)._lf();
- $ctx1.sendIdx["lf"]=3;
- $recv($3)._nextPutAll_("catch(e) {if(e===$early)return e[0]; throw e}");
- $recv($3)._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutNonLocalReturnHandlingWith:",{aBlock:aBlock},$globals.JSStream)});
- },
- args: ["aBlock"],
- source: "nextPutNonLocalReturnHandlingWith: aBlock\x0a\x09stream\x0a\x09\x09nextPutAll: 'var $early={};'; lf;\x0a\x09\x09nextPutAll: 'try {'; lf.\x0a\x09aBlock value.\x0a\x09stream\x0a\x09\x09nextPutAll: '}'; lf;\x0a\x09\x09nextPutAll: 'catch(e) {if(e===$early)return e[0]; throw e}'; lf",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "lf", "value"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutNonLocalReturnWith:",
- protocol: "streaming",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@stream"])._nextPutAll_("throw $early=[");
- $ctx1.sendIdx["nextPutAll:"]=1;
- $recv(aBlock)._value();
- $recv(self["@stream"])._nextPutAll_("]");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutNonLocalReturnWith:",{aBlock:aBlock},$globals.JSStream)});
- },
- args: ["aBlock"],
- source: "nextPutNonLocalReturnWith: aBlock\x0a\x09stream nextPutAll: 'throw $early=['.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: ']'",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "value"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutReturnWith:",
- protocol: "streaming",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@stream"])._nextPutAll_("return ");
- $recv(aBlock)._value();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutReturnWith:",{aBlock:aBlock},$globals.JSStream)});
- },
- args: ["aBlock"],
- source: "nextPutReturnWith: aBlock\x0a\x09stream nextPutAll: 'return '.\x0a\x09aBlock value",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "value"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutSendIndexFor:",
- protocol: "streaming",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._nextPutAll_(";");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._lf();
- $ctx1.sendIdx["lf"]=1;
- self._nextPutAll_("//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);");
- $ctx1.sendIdx["nextPutAll:"]=2;
- self._lf();
- $ctx1.sendIdx["lf"]=2;
- self._nextPutAll_($recv($recv(anIRSend)._scope())._alias());
- $ctx1.sendIdx["nextPutAll:"]=3;
- self._nextPutAll_(".sendIdx[");
- $ctx1.sendIdx["nextPutAll:"]=4;
- self._nextPutAll_($recv($recv(anIRSend)._selector())._asJavaScriptSource());
- $ctx1.sendIdx["nextPutAll:"]=5;
- self._nextPutAll_("]=");
- $ctx1.sendIdx["nextPutAll:"]=6;
- self._nextPutAll_($recv($recv(anIRSend)._index())._asString());
- $ctx1.sendIdx["nextPutAll:"]=7;
- self._nextPutAll_(";");
- $ctx1.sendIdx["nextPutAll:"]=8;
- self._lf();
- self._nextPutAll_("//>>excludeEnd(\x22ctx\x22)");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutSendIndexFor:",{anIRSend:anIRSend},$globals.JSStream)});
- },
- args: ["anIRSend"],
- source: "nextPutSendIndexFor: anIRSend\x0a\x09self \x0a\x09\x09nextPutAll: ';'; lf;\x0a\x09\x09nextPutAll: '//>>excludeStart(\x22ctx\x22, pragmas.excludeDebugContexts);'; lf;\x0a\x09\x09nextPutAll: anIRSend scope alias;\x0a\x09\x09nextPutAll: '.sendIdx[';\x0a\x09\x09nextPutAll: anIRSend selector asJavaScriptSource;\x0a\x09\x09nextPutAll: ']=';\x0a\x09\x09nextPutAll: anIRSend index asString;\x0a\x09\x09nextPutAll: ';'; lf;\x0a\x09\x09nextPutAll: '//>>excludeEnd(\x22ctx\x22)'",
- referencedClasses: [],
- messageSends: ["nextPutAll:", "lf", "alias", "scope", "asJavaScriptSource", "selector", "asString", "index"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutStatementWith:",
- protocol: "streaming",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- self._omitSemicolon_(false);
- $ctx1.sendIdx["omitSemicolon:"]=1;
- $recv(aBlock)._value();
- $1=self._omitSemicolon();
- if(!$core.assert($1)){
- $recv(self["@stream"])._nextPutAll_(";");
- }
- self._omitSemicolon_(false);
- $recv(self["@stream"])._lf();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutStatementWith:",{aBlock:aBlock},$globals.JSStream)});
- },
- args: ["aBlock"],
- source: "nextPutStatementWith: aBlock\x0a\x09self omitSemicolon: false.\x0a\x09aBlock value.\x0a\x09self omitSemicolon ifFalse: [ stream nextPutAll: ';' ].\x0a\x09self omitSemicolon: false.\x0a\x09stream lf",
- referencedClasses: [],
- messageSends: ["omitSemicolon:", "value", "ifFalse:", "omitSemicolon", "nextPutAll:", "lf"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "nextPutVars:",
- protocol: "streaming",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(aCollection)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- $recv(self["@stream"])._nextPutAll_("var ");
- $ctx2.sendIdx["nextPutAll:"]=1;
- $recv(aCollection)._do_separatedBy_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(self["@stream"])._nextPutAll_(each);
- $ctx3.sendIdx["nextPutAll:"]=2;
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)});
- }),(function(){
- return $core.withContext(function($ctx3) {
- return $recv(self["@stream"])._nextPutAll_(",");
- $ctx3.sendIdx["nextPutAll:"]=3;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- $1=self["@stream"];
- $recv($1)._nextPutAll_(";");
- return $recv($1)._lf();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nextPutVars:",{aCollection:aCollection},$globals.JSStream)});
- },
- args: ["aCollection"],
- source: "nextPutVars: aCollection\x0a\x09aCollection ifNotEmpty: [\x0a\x09\x09stream nextPutAll: 'var '.\x0a\x09\x09aCollection\x0a\x09\x09\x09do: [ :each | stream nextPutAll: each ]\x0a\x09\x09\x09separatedBy: [ stream nextPutAll: ',' ].\x0a\x09\x09stream nextPutAll: ';'; lf ]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:", "nextPutAll:", "do:separatedBy:", "lf"]
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "omitSemicolon",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@omitSemicolon"];
- },
- args: [],
- source: "omitSemicolon\x0a\x09^ omitSemicolon",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "omitSemicolon:",
- protocol: "accessing",
- fn: function (aBoolean){
- var self=this;
- self["@omitSemicolon"]=aBoolean;
- return self;
- },
- args: ["aBoolean"],
- source: "omitSemicolon: aBoolean\x0a\x09omitSemicolon := aBoolean",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSStream);
- $core.addMethod(
- $core.method({
- selector: "isReferenced",
- protocol: "*Compiler-IR",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=self._parent();
- $ctx1.sendIdx["parent"]=1;
- $2=$recv($3)._isSequenceNode();
- $1=$recv($2)._or_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._parent())._isAssignmentNode();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return $recv($1)._not();
- }, function($ctx1) {$ctx1.fill(self,"isReferenced",{},$globals.ASTNode)});
- },
- args: [],
- source: "isReferenced\x0a\x09\x22Answer true if the receiver is referenced by other nodes.\x0a\x09Do not take sequences or assignments into account\x22\x0a\x09\x0a\x09^ (self parent isSequenceNode or: [\x0a\x09\x09self parent isAssignmentNode ]) not",
- referencedClasses: [],
- messageSends: ["not", "or:", "isSequenceNode", "parent", "isAssignmentNode"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "subtreeNeedsAliasing",
- protocol: "*Compiler-IR",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._shouldBeAliased())._or_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._dagChildren())._anySatisfy_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(each)._subtreeNeedsAliasing();
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"subtreeNeedsAliasing",{},$globals.ASTNode)});
- },
- args: [],
- source: "subtreeNeedsAliasing\x0a\x09^ self shouldBeAliased or: [\x0a\x09\x09self dagChildren anySatisfy: [ :each | each subtreeNeedsAliasing ] ]",
- referencedClasses: [],
- messageSends: ["or:", "shouldBeAliased", "anySatisfy:", "dagChildren", "subtreeNeedsAliasing"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "shouldBeAliased",
- protocol: "*Compiler-IR",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(
- $ctx1.supercall = true,
- ($globals.AssignmentNode.superclass||$boot.nilAsClass).fn.prototype._shouldBeAliased.apply($recv(self), []));
- $ctx1.supercall = false;
- return $recv($1)._or_((function(){
- return $core.withContext(function($ctx2) {
- return self._isReferenced();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"shouldBeAliased",{},$globals.AssignmentNode)});
- },
- args: [],
- source: "shouldBeAliased\x0a\x09^ super shouldBeAliased or: [ self isReferenced ]",
- referencedClasses: [],
- messageSends: ["or:", "shouldBeAliased", "isReferenced"]
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "appendToInstruction:",
- protocol: "*Compiler-IR",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anIRInstruction)._appendBlock_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"appendToInstruction:",{anIRInstruction:anIRInstruction},$globals.BlockClosure)});
- },
- args: ["anIRInstruction"],
- source: "appendToInstruction: anIRInstruction\x0a\x09anIRInstruction appendBlock: self",
- referencedClasses: [],
- messageSends: ["appendBlock:"]
- }),
- $globals.BlockClosure);
- $core.addMethod(
- $core.method({
- selector: "subtreeNeedsAliasing",
- protocol: "*Compiler-IR",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._shouldBeAliased();
- }, function($ctx1) {$ctx1.fill(self,"subtreeNeedsAliasing",{},$globals.BlockNode)});
- },
- args: [],
- source: "subtreeNeedsAliasing\x0a\x09^ self shouldBeAliased",
- referencedClasses: [],
- messageSends: ["shouldBeAliased"]
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "subtreeNeedsAliasing",
- protocol: "*Compiler-IR",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._parent())._isSequenceNode())._not();
- }, function($ctx1) {$ctx1.fill(self,"subtreeNeedsAliasing",{},$globals.CascadeNode)});
- },
- args: [],
- source: "subtreeNeedsAliasing\x0a\x09^ self parent isSequenceNode not",
- referencedClasses: [],
- messageSends: ["not", "isSequenceNode", "parent"]
- }),
- $globals.CascadeNode);
- $core.addMethod(
- $core.method({
- selector: "shouldBeAliased",
- protocol: "*Compiler-IR",
- fn: function (){
- var self=this;
- var sends;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- sends=$recv($recv($recv(self._method())._sendIndexes())._at_(self._selector()))._size();
- $2=(
- $ctx1.supercall = true,
- ($globals.SendNode.superclass||$boot.nilAsClass).fn.prototype._shouldBeAliased.apply($recv(self), []));
- $ctx1.supercall = false;
- $1=$recv($2)._or_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._isReferenced())._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv(self._index()).__lt(sends))._or_((function(){
- return $core.withContext(function($ctx4) {
- return self._superSend();
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,3)});
- }));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["or:"]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"shouldBeAliased",{sends:sends},$globals.SendNode)});
- },
- args: [],
- source: "shouldBeAliased\x0a\x09\x22Because we keep track of send indexes, some send nodes need additional care for aliasing. \x0a\x09See IRJSVisitor >> visitIRSend:\x22\x0a\x09\x0a\x09| sends |\x0a\x09\x0a\x09sends := (self method sendIndexes at: self selector) size.\x0a\x09\x0a\x09^ (super shouldBeAliased or: [\x0a\x09\x09self isReferenced and: [\x0a\x09\x09\x09self index < sends or: [\x0a\x09\x09\x09\x09self superSend ] ] ])",
- referencedClasses: [],
- messageSends: ["size", "at:", "sendIndexes", "method", "selector", "or:", "shouldBeAliased", "and:", "isReferenced", "<", "index", "superSend"]
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "subtreeNeedsAliasing",
- protocol: "*Compiler-IR",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._shouldBeInlined())._or_((function(){
- return $core.withContext(function($ctx2) {
- return (
- $ctx2.supercall = true,
- ($globals.SendNode.superclass||$boot.nilAsClass).fn.prototype._subtreeNeedsAliasing.apply($recv(self), []));
- $ctx2.supercall = false;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"subtreeNeedsAliasing",{},$globals.SendNode)});
- },
- args: [],
- source: "subtreeNeedsAliasing\x0a\x09^ self shouldBeInlined or: [ super subtreeNeedsAliasing ]",
- referencedClasses: [],
- messageSends: ["or:", "shouldBeInlined", "subtreeNeedsAliasing"]
- }),
- $globals.SendNode);
- });
- define('amber_core/Compiler-Inlining',["amber/boot", "amber_core/Compiler-AST", "amber_core/Compiler-Core", "amber_core/Compiler-IR", "amber_core/Compiler-Semantic", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Compiler-Inlining");
- $core.packages["Compiler-Inlining"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Compiler-Inlining"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("ASTPreInliner", $globals.NodeVisitor, [], "Compiler-Inlining");
- $core.addMethod(
- $core.method({
- selector: "visitSendNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$receiver;
- $1=$recv(aNode)._superSend();
- if(!$core.assert($1)){
- $2=$recv($recv($globals.IRSendInliner)._inlinedSelectors())._includes_($recv(aNode)._selector());
- if($core.assert($2)){
- $recv(aNode)._shouldBeInlined_(true);
- $3=$recv(aNode)._receiver();
- if(($receiver = $3) == null || $receiver.isNil){
- $3;
- } else {
- var receiver;
- receiver=$receiver;
- $recv(receiver)._shouldBeAliased_(true);
- }
- }
- }
- $4=(
- $ctx1.supercall = true,
- ($globals.ASTPreInliner.superclass||$boot.nilAsClass).fn.prototype._visitSendNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return $4;
- }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode},$globals.ASTPreInliner)});
- },
- args: ["aNode"],
- source: "visitSendNode: aNode\x0a\x0a\x09aNode superSend ifFalse: [ \x0a\x09\x09(IRSendInliner inlinedSelectors includes: aNode selector) ifTrue: [\x0a\x09\x09\x09aNode shouldBeInlined: true.\x0a\x09\x09\x09aNode receiver ifNotNil: [ :receiver |\x0a\x09\x09\x09\x09receiver shouldBeAliased: true ] ] ].\x0a\x0a\x09^ super visitSendNode: aNode",
- referencedClasses: ["IRSendInliner"],
- messageSends: ["ifFalse:", "superSend", "ifTrue:", "includes:", "inlinedSelectors", "selector", "shouldBeInlined:", "ifNotNil:", "receiver", "shouldBeAliased:", "visitSendNode:"]
- }),
- $globals.ASTPreInliner);
- $core.addClass("IRInlinedClosure", $globals.IRClosure, [], "Compiler-Inlining");
- $globals.IRInlinedClosure.comment="I represent an inlined closure instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aVisitor)._visitIRInlinedClosure_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRInlinedClosure)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09aVisitor visitIRInlinedClosure: self",
- referencedClasses: [],
- messageSends: ["visitIRInlinedClosure:"]
- }),
- $globals.IRInlinedClosure);
- $core.addMethod(
- $core.method({
- selector: "isInlined",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isInlined\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInlinedClosure);
- $core.addClass("IRInlinedSend", $globals.IRSend, [], "Compiler-Inlining");
- $globals.IRInlinedSend.comment="I am the abstract super class of inlined message send instructions.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aVisitor)._visitInlinedSend_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRInlinedSend)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09aVisitor visitInlinedSend: self",
- referencedClasses: [],
- messageSends: ["visitInlinedSend:"]
- }),
- $globals.IRInlinedSend);
- $core.addMethod(
- $core.method({
- selector: "internalVariables",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return [];
- },
- args: [],
- source: "internalVariables\x0a\x09\x22Answer a collection of internal variables required \x0a\x09to perform the inlining\x22\x0a\x09\x0a\x09^ #()",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInlinedSend);
- $core.addMethod(
- $core.method({
- selector: "isInlined",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isInlined\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInlinedSend);
- $core.addClass("IRInlinedIfFalse", $globals.IRInlinedSend, [], "Compiler-Inlining");
- $globals.IRInlinedIfFalse.comment="I represent an inlined `#ifFalse:` message send instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aVisitor)._visitIRInlinedIfFalse_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRInlinedIfFalse)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09aVisitor visitIRInlinedIfFalse: self",
- referencedClasses: [],
- messageSends: ["visitIRInlinedIfFalse:"]
- }),
- $globals.IRInlinedIfFalse);
- $core.addClass("IRInlinedIfNilIfNotNil", $globals.IRInlinedSend, [], "Compiler-Inlining");
- $globals.IRInlinedIfNilIfNotNil.comment="I represent an inlined `#ifNil:ifNotNil:` message send instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aVisitor)._visitIRInlinedIfNilIfNotNil_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRInlinedIfNilIfNotNil)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09aVisitor visitIRInlinedIfNilIfNotNil: self",
- referencedClasses: [],
- messageSends: ["visitIRInlinedIfNilIfNotNil:"]
- }),
- $globals.IRInlinedIfNilIfNotNil);
- $core.addMethod(
- $core.method({
- selector: "internalVariables",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Array)._with_(self._receiverInternalVariable());
- }, function($ctx1) {$ctx1.fill(self,"internalVariables",{},$globals.IRInlinedIfNilIfNotNil)});
- },
- args: [],
- source: "internalVariables\x0a\x09^ Array with: self receiverInternalVariable",
- referencedClasses: ["Array"],
- messageSends: ["with:", "receiverInternalVariable"]
- }),
- $globals.IRInlinedIfNilIfNotNil);
- $core.addMethod(
- $core.method({
- selector: "receiverInternalVariable",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRVariable)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._variable_($recv($recv($globals.AliasVar)._new())._name_(self._receiverInternalVariableName()));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"receiverInternalVariable",{},$globals.IRInlinedIfNilIfNotNil)});
- },
- args: [],
- source: "receiverInternalVariable\x0a\x09^ IRVariable new\x0a\x09\x09variable: (AliasVar new name: self receiverInternalVariableName);\x0a\x09\x09yourself.",
- referencedClasses: ["IRVariable", "AliasVar"],
- messageSends: ["variable:", "new", "name:", "receiverInternalVariableName", "yourself"]
- }),
- $globals.IRInlinedIfNilIfNotNil);
- $core.addMethod(
- $core.method({
- selector: "receiverInternalVariableName",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "$receiver";
- },
- args: [],
- source: "receiverInternalVariableName\x0a\x09^ '$receiver'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInlinedIfNilIfNotNil);
- $core.addClass("IRInlinedIfTrue", $globals.IRInlinedSend, [], "Compiler-Inlining");
- $globals.IRInlinedIfTrue.comment="I represent an inlined `#ifTrue:` message send instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aVisitor)._visitIRInlinedIfTrue_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRInlinedIfTrue)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09aVisitor visitIRInlinedIfTrue: self",
- referencedClasses: [],
- messageSends: ["visitIRInlinedIfTrue:"]
- }),
- $globals.IRInlinedIfTrue);
- $core.addClass("IRInlinedIfTrueIfFalse", $globals.IRInlinedSend, [], "Compiler-Inlining");
- $globals.IRInlinedIfTrueIfFalse.comment="I represent an inlined `#ifTrue:ifFalse:` message send instruction.";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aVisitor)._visitIRInlinedIfTrueIfFalse_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRInlinedIfTrueIfFalse)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09aVisitor visitIRInlinedIfTrueIfFalse: self",
- referencedClasses: [],
- messageSends: ["visitIRInlinedIfTrueIfFalse:"]
- }),
- $globals.IRInlinedIfTrueIfFalse);
- $core.addClass("IRInlinedSequence", $globals.IRBlockSequence, [], "Compiler-Inlining");
- $globals.IRInlinedSequence.comment="I represent a (block) sequence inside an inlined closure instruction (instance of `IRInlinedClosure`).";
- $core.addMethod(
- $core.method({
- selector: "acceptDagVisitor:",
- protocol: "visiting",
- fn: function (aVisitor){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aVisitor)._visitIRInlinedSequence_(self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"acceptDagVisitor:",{aVisitor:aVisitor},$globals.IRInlinedSequence)});
- },
- args: ["aVisitor"],
- source: "acceptDagVisitor: aVisitor\x0a\x09aVisitor visitIRInlinedSequence: self",
- referencedClasses: [],
- messageSends: ["visitIRInlinedSequence:"]
- }),
- $globals.IRInlinedSequence);
- $core.addMethod(
- $core.method({
- selector: "isInlined",
- protocol: "testing",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isInlined\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInlinedSequence);
- $core.addClass("IRInliner", $globals.IRVisitor, [], "Compiler-Inlining");
- $globals.IRInliner.comment="I visit an IR tree, inlining message sends and block closures.\x0a\x0aMessage selectors that can be inlined are answered by `IRSendInliner >> #inlinedSelectors`";
- $core.addMethod(
- $core.method({
- selector: "assignmentInliner",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRAssignmentInliner)._new();
- $recv($1)._translator_(self);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"assignmentInliner",{},$globals.IRInliner)});
- },
- args: [],
- source: "assignmentInliner\x0a\x09^ IRAssignmentInliner new\x0a\x09\x09translator: self;\x0a\x09\x09yourself",
- referencedClasses: ["IRAssignmentInliner"],
- messageSends: ["translator:", "new", "yourself"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "returnInliner",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRReturnInliner)._new();
- $recv($1)._translator_(self);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"returnInliner",{},$globals.IRInliner)});
- },
- args: [],
- source: "returnInliner\x0a\x09^ IRReturnInliner new\x0a\x09\x09translator: self;\x0a\x09\x09yourself",
- referencedClasses: ["IRReturnInliner"],
- messageSends: ["translator:", "new", "yourself"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "sendInliner",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.IRSendInliner)._new();
- $recv($1)._translator_(self);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"sendInliner",{},$globals.IRInliner)});
- },
- args: [],
- source: "sendInliner\x0a\x09^ IRSendInliner new\x0a\x09\x09translator: self;\x0a\x09\x09yourself",
- referencedClasses: ["IRSendInliner"],
- messageSends: ["translator:", "new", "yourself"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "shouldInlineAssignment:",
- protocol: "testing",
- fn: function (anIRAssignment){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $1=$recv($recv($recv(anIRAssignment)._isInlined())._not())._and_((function(){
- return $core.withContext(function($ctx2) {
- $3=$recv(anIRAssignment)._right();
- $ctx2.sendIdx["right"]=1;
- $2=$recv($3)._isSend();
- return $recv($2)._and_((function(){
- return $core.withContext(function($ctx3) {
- return self._shouldInlineSend_($recv(anIRAssignment)._right());
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["and:"]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"shouldInlineAssignment:",{anIRAssignment:anIRAssignment},$globals.IRInliner)});
- },
- args: ["anIRAssignment"],
- source: "shouldInlineAssignment: anIRAssignment\x0a\x09^ anIRAssignment isInlined not and: [\x0a\x09\x09anIRAssignment right isSend and: [\x0a\x09\x09\x09self shouldInlineSend: anIRAssignment right ]]",
- referencedClasses: [],
- messageSends: ["and:", "not", "isInlined", "isSend", "right", "shouldInlineSend:"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "shouldInlineReturn:",
- protocol: "testing",
- fn: function (anIRReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $1=$recv($recv($recv(anIRReturn)._isInlined())._not())._and_((function(){
- return $core.withContext(function($ctx2) {
- $3=$recv(anIRReturn)._expression();
- $ctx2.sendIdx["expression"]=1;
- $2=$recv($3)._isSend();
- return $recv($2)._and_((function(){
- return $core.withContext(function($ctx3) {
- return self._shouldInlineSend_($recv(anIRReturn)._expression());
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["and:"]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"shouldInlineReturn:",{anIRReturn:anIRReturn},$globals.IRInliner)});
- },
- args: ["anIRReturn"],
- source: "shouldInlineReturn: anIRReturn\x0a\x09^ anIRReturn isInlined not and: [\x0a\x09\x09anIRReturn expression isSend and: [\x0a\x09\x09\x09self shouldInlineSend: anIRReturn expression ]]",
- referencedClasses: [],
- messageSends: ["and:", "not", "isInlined", "isSend", "expression", "shouldInlineSend:"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "shouldInlineSend:",
- protocol: "testing",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($recv(anIRSend)._isInlined())._not())._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($globals.IRSendInliner)._shouldInline_(anIRSend);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"shouldInlineSend:",{anIRSend:anIRSend},$globals.IRInliner)});
- },
- args: ["anIRSend"],
- source: "shouldInlineSend: anIRSend\x0a\x09^ anIRSend isInlined not and: [\x0a\x09\x09IRSendInliner shouldInline: anIRSend ]",
- referencedClasses: ["IRSendInliner"],
- messageSends: ["and:", "not", "isInlined", "shouldInline:"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "visitIRAssignment:",
- protocol: "visiting",
- fn: function (anIRAssignment){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._shouldInlineAssignment_(anIRAssignment);
- if($core.assert($1)){
- return $recv(self._assignmentInliner())._inlineAssignment_(anIRAssignment);
- } else {
- return (
- $ctx1.supercall = true,
- ($globals.IRInliner.superclass||$boot.nilAsClass).fn.prototype._visitIRAssignment_.apply($recv(self), [anIRAssignment]));
- $ctx1.supercall = false;
- }
- }, function($ctx1) {$ctx1.fill(self,"visitIRAssignment:",{anIRAssignment:anIRAssignment},$globals.IRInliner)});
- },
- args: ["anIRAssignment"],
- source: "visitIRAssignment: anIRAssignment\x0a\x09^ (self shouldInlineAssignment: anIRAssignment)\x0a\x09\x09ifTrue: [ self assignmentInliner inlineAssignment: anIRAssignment ]\x0a\x09\x09ifFalse: [ super visitIRAssignment: anIRAssignment ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "shouldInlineAssignment:", "inlineAssignment:", "assignmentInliner", "visitIRAssignment:"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "visitIRNonLocalReturn:",
- protocol: "visiting",
- fn: function (anIRNonLocalReturn){
- var self=this;
- var localReturn;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5,$6,$7;
- $2=$recv(anIRNonLocalReturn)._scope();
- $ctx1.sendIdx["scope"]=1;
- $1=$recv($2)._canInlineNonLocalReturns();
- if($core.assert($1)){
- $4=$recv(anIRNonLocalReturn)._scope();
- $ctx1.sendIdx["scope"]=2;
- $3=$recv($4)._methodScope();
- $5=$recv(anIRNonLocalReturn)._scope();
- $ctx1.sendIdx["scope"]=3;
- $recv($3)._removeNonLocalReturn_($5);
- $6=$recv($globals.IRReturn)._new();
- $recv($6)._scope_($recv(anIRNonLocalReturn)._scope());
- localReturn=$recv($6)._yourself();
- localReturn;
- $recv($recv(anIRNonLocalReturn)._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(localReturn)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- $recv(anIRNonLocalReturn)._replaceWith_(localReturn);
- return self._visitIRReturn_(localReturn);
- }
- $7=(
- $ctx1.supercall = true,
- ($globals.IRInliner.superclass||$boot.nilAsClass).fn.prototype._visitIRNonLocalReturn_.apply($recv(self), [anIRNonLocalReturn]));
- $ctx1.supercall = false;
- return $7;
- }, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturn:",{anIRNonLocalReturn:anIRNonLocalReturn,localReturn:localReturn},$globals.IRInliner)});
- },
- args: ["anIRNonLocalReturn"],
- source: "visitIRNonLocalReturn: anIRNonLocalReturn\x0a\x09| localReturn |\x0a\x09anIRNonLocalReturn scope canInlineNonLocalReturns ifTrue: [\x0a\x09\x09anIRNonLocalReturn scope methodScope removeNonLocalReturn: anIRNonLocalReturn scope.\x0a\x09\x09localReturn := IRReturn new\x0a\x09\x09\x09scope: anIRNonLocalReturn scope;\x0a\x09\x09\x09yourself.\x0a\x09\x09anIRNonLocalReturn dagChildren do: [ :each |\x0a\x09\x09\x09localReturn add: each ].\x0a\x09\x09anIRNonLocalReturn replaceWith: localReturn.\x0a\x09\x09^ self visitIRReturn: localReturn ].\x0a\x09^ super visitIRNonLocalReturn: anIRNonLocalReturn",
- referencedClasses: ["IRReturn"],
- messageSends: ["ifTrue:", "canInlineNonLocalReturns", "scope", "removeNonLocalReturn:", "methodScope", "scope:", "new", "yourself", "do:", "dagChildren", "add:", "replaceWith:", "visitIRReturn:", "visitIRNonLocalReturn:"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "visitIRReturn:",
- protocol: "visiting",
- fn: function (anIRReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._shouldInlineReturn_(anIRReturn);
- if($core.assert($1)){
- return $recv(self._returnInliner())._inlineReturn_(anIRReturn);
- } else {
- return (
- $ctx1.supercall = true,
- ($globals.IRInliner.superclass||$boot.nilAsClass).fn.prototype._visitIRReturn_.apply($recv(self), [anIRReturn]));
- $ctx1.supercall = false;
- }
- }, function($ctx1) {$ctx1.fill(self,"visitIRReturn:",{anIRReturn:anIRReturn},$globals.IRInliner)});
- },
- args: ["anIRReturn"],
- source: "visitIRReturn: anIRReturn\x0a\x09^ (self shouldInlineReturn: anIRReturn)\x0a\x09\x09ifTrue: [ self returnInliner inlineReturn: anIRReturn ]\x0a\x09\x09ifFalse: [ super visitIRReturn: anIRReturn ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "shouldInlineReturn:", "inlineReturn:", "returnInliner", "visitIRReturn:"]
- }),
- $globals.IRInliner);
- $core.addMethod(
- $core.method({
- selector: "visitIRSend:",
- protocol: "visiting",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._shouldInlineSend_(anIRSend);
- if($core.assert($1)){
- return $recv(self._sendInliner())._inlineSend_(anIRSend);
- } else {
- return (
- $ctx1.supercall = true,
- ($globals.IRInliner.superclass||$boot.nilAsClass).fn.prototype._visitIRSend_.apply($recv(self), [anIRSend]));
- $ctx1.supercall = false;
- }
- }, function($ctx1) {$ctx1.fill(self,"visitIRSend:",{anIRSend:anIRSend},$globals.IRInliner)});
- },
- args: ["anIRSend"],
- source: "visitIRSend: anIRSend\x0a\x09^ (self shouldInlineSend: anIRSend)\x0a\x09\x09ifTrue: [ self sendInliner inlineSend: anIRSend ]\x0a\x09\x09ifFalse: [ super visitIRSend: anIRSend ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "shouldInlineSend:", "inlineSend:", "sendInliner", "visitIRSend:"]
- }),
- $globals.IRInliner);
- $core.addClass("IRInliningJSTranslator", $globals.IRJSTranslator, [], "Compiler-Inlining");
- $globals.IRInliningJSTranslator.comment="I am a specialized JavaScript translator able to write inlined IR instructions to JavaScript stream (`JSStream` instance).";
- $core.addMethod(
- $core.method({
- selector: "visitIRInlinedClosure:",
- protocol: "visiting",
- fn: function (anIRInlinedClosure){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._stream())._nextPutVars_($recv($recv(anIRInlinedClosure)._tempDeclarations())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._name())._asVariableName();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- })));
- self._visitAll_($recv(anIRInlinedClosure)._dagChildren());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedClosure:",{anIRInlinedClosure:anIRInlinedClosure},$globals.IRInliningJSTranslator)});
- },
- args: ["anIRInlinedClosure"],
- source: "visitIRInlinedClosure: anIRInlinedClosure\x0a\x09self stream nextPutVars: (anIRInlinedClosure tempDeclarations collect: [ :each |\x0a\x09\x09each name asVariableName ]).\x0a\x09self visitAll: anIRInlinedClosure dagChildren",
- referencedClasses: [],
- messageSends: ["nextPutVars:", "stream", "collect:", "tempDeclarations", "asVariableName", "name", "visitAll:", "dagChildren"]
- }),
- $globals.IRInliningJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRInlinedIfFalse:",
- protocol: "visiting",
- fn: function (anIRInlinedIfFalse){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutIf_then_((function(){
- return $core.withContext(function($ctx2) {
- $2=self._stream();
- $ctx2.sendIdx["stream"]=2;
- $recv($2)._nextPutAll_("!$core.assert(");
- $ctx2.sendIdx["nextPutAll:"]=1;
- $4=$recv(anIRInlinedIfFalse)._dagChildren();
- $ctx2.sendIdx["dagChildren"]=1;
- $3=$recv($4)._first();
- self._visit_($3);
- $ctx2.sendIdx["visit:"]=1;
- return $recv(self._stream())._nextPutAll_(")");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return self._visit_($recv($recv(anIRInlinedIfFalse)._dagChildren())._last());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfFalse:",{anIRInlinedIfFalse:anIRInlinedIfFalse},$globals.IRInliningJSTranslator)});
- },
- args: ["anIRInlinedIfFalse"],
- source: "visitIRInlinedIfFalse: anIRInlinedIfFalse\x0a\x09self stream nextPutIf: [\x0a\x09\x09self stream nextPutAll: '!$core.assert('.\x0a\x09\x09self visit: anIRInlinedIfFalse dagChildren first.\x0a\x09\x09self stream nextPutAll: ')' ]\x0a\x09\x09then: [ self visit: anIRInlinedIfFalse dagChildren last ]",
- referencedClasses: [],
- messageSends: ["nextPutIf:then:", "stream", "nextPutAll:", "visit:", "first", "dagChildren", "last"]
- }),
- $globals.IRInliningJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRInlinedIfNilIfNotNil:",
- protocol: "visiting",
- fn: function (anIRInlinedIfNilIfNotNil){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$6,$5,$7,$8,$10,$9;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutIf_then_else_((function(){
- var recvVarName;
- return $core.withContext(function($ctx2) {
- recvVarName=$recv(anIRInlinedIfNilIfNotNil)._receiverInternalVariableName();
- recvVarName;
- $2=self._stream();
- $ctx2.sendIdx["stream"]=2;
- $4="(".__comma(recvVarName);
- $ctx2.sendIdx[","]=2;
- $3=$recv($4).__comma(" = ");
- $ctx2.sendIdx[","]=1;
- $recv($2)._nextPutAll_($3);
- $ctx2.sendIdx["nextPutAll:"]=1;
- $6=$recv(anIRInlinedIfNilIfNotNil)._dagChildren();
- $ctx2.sendIdx["dagChildren"]=1;
- $5=$recv($6)._first();
- self._visit_($5);
- $ctx2.sendIdx["visit:"]=1;
- $7=self._stream();
- $8=$recv(") == null || ".__comma(recvVarName)).__comma(".isNil");
- $ctx2.sendIdx[","]=3;
- return $recv($7)._nextPutAll_($8);
- }, function($ctx2) {$ctx2.fillBlock({recvVarName:recvVarName},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- $10=$recv(anIRInlinedIfNilIfNotNil)._dagChildren();
- $ctx2.sendIdx["dagChildren"]=2;
- $9=$recv($10)._second();
- return self._visit_($9);
- $ctx2.sendIdx["visit:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return self._visit_($recv($recv(anIRInlinedIfNilIfNotNil)._dagChildren())._third());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfNilIfNotNil:",{anIRInlinedIfNilIfNotNil:anIRInlinedIfNilIfNotNil},$globals.IRInliningJSTranslator)});
- },
- args: ["anIRInlinedIfNilIfNotNil"],
- source: "visitIRInlinedIfNilIfNotNil: anIRInlinedIfNilIfNotNil\x0a\x09self stream\x0a\x09\x09nextPutIf: [\x0a\x09\x09\x09| recvVarName |\x0a\x09\x09\x09recvVarName := anIRInlinedIfNilIfNotNil receiverInternalVariableName.\x0a\x09\x09\x09self stream nextPutAll: '(', recvVarName, ' = '.\x0a\x09\x09\x09self visit: anIRInlinedIfNilIfNotNil dagChildren first.\x0a\x09\x09\x09self stream nextPutAll: ') == null || ', recvVarName, '.isNil' ]\x0a\x09\x09then: [ self visit: anIRInlinedIfNilIfNotNil dagChildren second ]\x0a\x09\x09else: [ self visit: anIRInlinedIfNilIfNotNil dagChildren third ]",
- referencedClasses: [],
- messageSends: ["nextPutIf:then:else:", "stream", "receiverInternalVariableName", "nextPutAll:", ",", "visit:", "first", "dagChildren", "second", "third"]
- }),
- $globals.IRInliningJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRInlinedIfTrue:",
- protocol: "visiting",
- fn: function (anIRInlinedIfTrue){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutIf_then_((function(){
- return $core.withContext(function($ctx2) {
- $2=self._stream();
- $ctx2.sendIdx["stream"]=2;
- $recv($2)._nextPutAll_("$core.assert(");
- $ctx2.sendIdx["nextPutAll:"]=1;
- $4=$recv(anIRInlinedIfTrue)._dagChildren();
- $ctx2.sendIdx["dagChildren"]=1;
- $3=$recv($4)._first();
- self._visit_($3);
- $ctx2.sendIdx["visit:"]=1;
- return $recv(self._stream())._nextPutAll_(")");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return self._visit_($recv($recv(anIRInlinedIfTrue)._dagChildren())._last());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfTrue:",{anIRInlinedIfTrue:anIRInlinedIfTrue},$globals.IRInliningJSTranslator)});
- },
- args: ["anIRInlinedIfTrue"],
- source: "visitIRInlinedIfTrue: anIRInlinedIfTrue\x0a\x09self stream nextPutIf: [\x0a\x09\x09self stream nextPutAll: '$core.assert('.\x0a\x09\x09self visit: anIRInlinedIfTrue dagChildren first.\x0a\x09\x09self stream nextPutAll: ')' ]\x0a\x09\x09then: [ self visit: anIRInlinedIfTrue dagChildren last ]",
- referencedClasses: [],
- messageSends: ["nextPutIf:then:", "stream", "nextPutAll:", "visit:", "first", "dagChildren", "last"]
- }),
- $globals.IRInliningJSTranslator);
- $core.addMethod(
- $core.method({
- selector: "visitIRInlinedIfTrueIfFalse:",
- protocol: "visiting",
- fn: function (anIRInlinedIfTrueIfFalse){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$6,$5;
- $1=self._stream();
- $ctx1.sendIdx["stream"]=1;
- $recv($1)._nextPutIf_then_else_((function(){
- return $core.withContext(function($ctx2) {
- $2=self._stream();
- $ctx2.sendIdx["stream"]=2;
- $recv($2)._nextPutAll_("$core.assert(");
- $ctx2.sendIdx["nextPutAll:"]=1;
- $4=$recv(anIRInlinedIfTrueIfFalse)._dagChildren();
- $ctx2.sendIdx["dagChildren"]=1;
- $3=$recv($4)._first();
- self._visit_($3);
- $ctx2.sendIdx["visit:"]=1;
- return $recv(self._stream())._nextPutAll_(")");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- $6=$recv(anIRInlinedIfTrueIfFalse)._dagChildren();
- $ctx2.sendIdx["dagChildren"]=2;
- $5=$recv($6)._second();
- return self._visit_($5);
- $ctx2.sendIdx["visit:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- return self._visit_($recv($recv(anIRInlinedIfTrueIfFalse)._dagChildren())._third());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfTrueIfFalse:",{anIRInlinedIfTrueIfFalse:anIRInlinedIfTrueIfFalse},$globals.IRInliningJSTranslator)});
- },
- args: ["anIRInlinedIfTrueIfFalse"],
- source: "visitIRInlinedIfTrueIfFalse: anIRInlinedIfTrueIfFalse\x0a\x09self stream\x0a\x09\x09nextPutIf: [\x0a\x09\x09\x09self stream nextPutAll: '$core.assert('.\x0a\x09\x09\x09self visit: anIRInlinedIfTrueIfFalse dagChildren first.\x0a\x09\x09\x09self stream nextPutAll: ')' ]\x0a\x09\x09then: [ self visit: anIRInlinedIfTrueIfFalse dagChildren second ]\x0a\x09\x09else: [ self visit: anIRInlinedIfTrueIfFalse dagChildren third ]",
- referencedClasses: [],
- messageSends: ["nextPutIf:then:else:", "stream", "nextPutAll:", "visit:", "first", "dagChildren", "second", "third"]
- }),
- $globals.IRInliningJSTranslator);
- $core.addClass("IRSendInliner", $globals.Object, ["send", "translator"], "Compiler-Inlining");
- $globals.IRSendInliner.comment="I inline some message sends and block closure arguments. I heavily rely on #perform: to dispatch inlining methods.";
- $core.addMethod(
- $core.method({
- selector: "ifFalse:",
- protocol: "inlining",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._inlinedSend_withBlock_($recv($globals.IRInlinedIfFalse)._new(),anIRInstruction);
- }, function($ctx1) {$ctx1.fill(self,"ifFalse:",{anIRInstruction:anIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction"],
- source: "ifFalse: anIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfFalse new withBlock: anIRInstruction",
- referencedClasses: ["IRInlinedIfFalse"],
- messageSends: ["inlinedSend:withBlock:", "new"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "ifFalse:ifTrue:",
- protocol: "inlining",
- fn: function (anIRInstruction,anotherIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._perform_withArguments_("ifTrue:ifFalse:",[anotherIRInstruction,anIRInstruction]);
- }, function($ctx1) {$ctx1.fill(self,"ifFalse:ifTrue:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction", "anotherIRInstruction"],
- source: "ifFalse: anIRInstruction ifTrue: anotherIRInstruction\x0a\x09^ self perform: #ifTrue:ifFalse: withArguments: { anotherIRInstruction. anIRInstruction }",
- referencedClasses: [],
- messageSends: ["perform:withArguments:"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "ifNil:",
- protocol: "inlining",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$5,$6,$4,$2;
- $1=$recv($globals.IRInlinedIfNilIfNotNil)._new();
- $ctx1.sendIdx["new"]=1;
- $3=$recv($globals.IRClosure)._new();
- $ctx1.sendIdx["new"]=2;
- $recv($3)._scope_($recv($recv(anIRInstruction)._scope())._copy());
- $5=$recv($globals.IRBlockSequence)._new();
- $recv($5)._add_($recv(self._send())._receiver());
- $6=$recv($5)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $4=$6;
- $recv($3)._add_($4);
- $ctx1.sendIdx["add:"]=1;
- $2=$recv($3)._yourself();
- return self._inlinedSend_withBlock_withBlock_($1,anIRInstruction,$2);
- }, function($ctx1) {$ctx1.fill(self,"ifNil:",{anIRInstruction:anIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction"],
- source: "ifNil: anIRInstruction\x0a\x09^ self\x0a\x09\x09inlinedSend: IRInlinedIfNilIfNotNil new\x0a\x09\x09withBlock: anIRInstruction\x0a\x09\x09withBlock: (IRClosure new\x0a\x09\x09\x09scope: anIRInstruction scope copy;\x0a\x09\x09\x09add: (IRBlockSequence new\x0a\x09\x09\x09\x09add: self send receiver;\x0a\x09\x09\x09\x09yourself);\x0a\x09\x09\x09yourself)",
- referencedClasses: ["IRInlinedIfNilIfNotNil", "IRClosure", "IRBlockSequence"],
- messageSends: ["inlinedSend:withBlock:withBlock:", "new", "scope:", "copy", "scope", "add:", "receiver", "send", "yourself"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "ifNil:ifNotNil:",
- protocol: "inlining",
- fn: function (anIRInstruction,anotherIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._inlinedSend_withBlock_withBlock_($recv($globals.IRInlinedIfNilIfNotNil)._new(),anIRInstruction,anotherIRInstruction);
- }, function($ctx1) {$ctx1.fill(self,"ifNil:ifNotNil:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction", "anotherIRInstruction"],
- source: "ifNil: anIRInstruction ifNotNil: anotherIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfNilIfNotNil new withBlock: anIRInstruction withBlock: anotherIRInstruction",
- referencedClasses: ["IRInlinedIfNilIfNotNil"],
- messageSends: ["inlinedSend:withBlock:withBlock:", "new"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "ifNotNil:",
- protocol: "inlining",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$5,$6,$4,$2;
- $1=$recv($globals.IRInlinedIfNilIfNotNil)._new();
- $ctx1.sendIdx["new"]=1;
- $3=$recv($globals.IRClosure)._new();
- $ctx1.sendIdx["new"]=2;
- $recv($3)._scope_($recv($recv(anIRInstruction)._scope())._copy());
- $5=$recv($globals.IRBlockSequence)._new();
- $recv($5)._add_($recv(self._send())._receiver());
- $6=$recv($5)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $4=$6;
- $recv($3)._add_($4);
- $ctx1.sendIdx["add:"]=1;
- $2=$recv($3)._yourself();
- return self._inlinedSend_withBlock_withBlock_($1,$2,anIRInstruction);
- }, function($ctx1) {$ctx1.fill(self,"ifNotNil:",{anIRInstruction:anIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction"],
- source: "ifNotNil: anIRInstruction\x0a\x09^ self\x0a\x09\x09inlinedSend: IRInlinedIfNilIfNotNil new\x0a\x09\x09withBlock: (IRClosure new\x0a\x09\x09\x09scope: anIRInstruction scope copy;\x0a\x09\x09\x09add: (IRBlockSequence new\x0a\x09\x09\x09\x09add: self send receiver;\x0a\x09\x09\x09\x09yourself);\x0a\x09\x09\x09yourself)\x0a\x09\x09withBlock: anIRInstruction",
- referencedClasses: ["IRInlinedIfNilIfNotNil", "IRClosure", "IRBlockSequence"],
- messageSends: ["inlinedSend:withBlock:withBlock:", "new", "scope:", "copy", "scope", "add:", "receiver", "send", "yourself"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "ifNotNil:ifNil:",
- protocol: "inlining",
- fn: function (anIRInstruction,anotherIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._inlinedSend_withBlock_withBlock_($recv($globals.IRInlinedIfNilIfNotNil)._new(),anotherIRInstruction,anIRInstruction);
- }, function($ctx1) {$ctx1.fill(self,"ifNotNil:ifNil:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction", "anotherIRInstruction"],
- source: "ifNotNil: anIRInstruction ifNil: anotherIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfNilIfNotNil new withBlock: anotherIRInstruction withBlock: anIRInstruction",
- referencedClasses: ["IRInlinedIfNilIfNotNil"],
- messageSends: ["inlinedSend:withBlock:withBlock:", "new"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "ifTrue:",
- protocol: "inlining",
- fn: function (anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._inlinedSend_withBlock_($recv($globals.IRInlinedIfTrue)._new(),anIRInstruction);
- }, function($ctx1) {$ctx1.fill(self,"ifTrue:",{anIRInstruction:anIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction"],
- source: "ifTrue: anIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfTrue new withBlock: anIRInstruction",
- referencedClasses: ["IRInlinedIfTrue"],
- messageSends: ["inlinedSend:withBlock:", "new"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "ifTrue:ifFalse:",
- protocol: "inlining",
- fn: function (anIRInstruction,anotherIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._inlinedSend_withBlock_withBlock_($recv($globals.IRInlinedIfTrueIfFalse)._new(),anIRInstruction,anotherIRInstruction);
- }, function($ctx1) {$ctx1.fill(self,"ifTrue:ifFalse:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRInstruction", "anotherIRInstruction"],
- source: "ifTrue: anIRInstruction ifFalse: anotherIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfTrueIfFalse new withBlock: anIRInstruction withBlock: anotherIRInstruction",
- referencedClasses: ["IRInlinedIfTrueIfFalse"],
- messageSends: ["inlinedSend:withBlock:withBlock:", "new"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlineClosure:",
- protocol: "inlining",
- fn: function (anIRClosure){
- var self=this;
- var inlinedClosure,sequence,statements;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$6,$4,$7,$9,$11,$13,$14,$15,$12,$10,$17,$19,$20,$18,$16,$8;
- inlinedClosure=self._inlinedClosure();
- $1=inlinedClosure;
- $2=$recv(anIRClosure)._scope();
- $ctx1.sendIdx["scope"]=1;
- $recv($1)._scope_($2);
- $ctx1.sendIdx["scope:"]=1;
- $recv($1)._parent_($recv(anIRClosure)._parent());
- $recv($recv(anIRClosure)._tempDeclarations())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(inlinedClosure)._add_(each);
- $ctx2.sendIdx["add:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- sequence=self._inlinedSequence();
- $recv($recv(anIRClosure)._arguments())._do_((function(each){
- return $core.withContext(function($ctx2) {
- $3=inlinedClosure;
- $5=$recv($globals.IRTempDeclaration)._new();
- $ctx2.sendIdx["new"]=1;
- $recv($5)._name_(each);
- $ctx2.sendIdx["name:"]=1;
- $6=$recv($5)._yourself();
- $ctx2.sendIdx["yourself"]=1;
- $4=$6;
- $recv($3)._add_($4);
- $ctx2.sendIdx["add:"]=2;
- $7=sequence;
- $9=$recv($globals.IRAssignment)._new();
- $ctx2.sendIdx["new"]=2;
- $11=$recv($globals.IRVariable)._new();
- $ctx2.sendIdx["new"]=3;
- $13=$recv($globals.AliasVar)._new();
- $ctx2.sendIdx["new"]=4;
- $14=$recv(inlinedClosure)._scope();
- $ctx2.sendIdx["scope"]=2;
- $recv($13)._scope_($14);
- $ctx2.sendIdx["scope:"]=2;
- $recv($13)._name_(each);
- $ctx2.sendIdx["name:"]=2;
- $15=$recv($13)._yourself();
- $ctx2.sendIdx["yourself"]=2;
- $12=$15;
- $10=$recv($11)._variable_($12);
- $ctx2.sendIdx["variable:"]=1;
- $recv($9)._add_($10);
- $ctx2.sendIdx["add:"]=4;
- $17=$recv($globals.IRVariable)._new();
- $ctx2.sendIdx["new"]=5;
- $19=$recv($globals.AliasVar)._new();
- $recv($19)._scope_($recv(inlinedClosure)._scope());
- $recv($19)._name_("$receiver");
- $20=$recv($19)._yourself();
- $ctx2.sendIdx["yourself"]=3;
- $18=$20;
- $16=$recv($17)._variable_($18);
- $recv($9)._add_($16);
- $ctx2.sendIdx["add:"]=5;
- $8=$recv($9)._yourself();
- return $recv($7)._add_($8);
- $ctx2.sendIdx["add:"]=3;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- $ctx1.sendIdx["do:"]=2;
- $recv(inlinedClosure)._add_(sequence);
- $ctx1.sendIdx["add:"]=6;
- statements=$recv($recv(anIRClosure)._sequence())._dagChildren();
- $recv(statements)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- $recv($recv(statements)._allButLast())._do_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(sequence)._add_(each);
- $ctx3.sendIdx["add:"]=7;
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,4)});
- }));
- return $recv(sequence)._add_($recv($recv(statements)._last())._asInlinedBlockResult());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return inlinedClosure;
- }, function($ctx1) {$ctx1.fill(self,"inlineClosure:",{anIRClosure:anIRClosure,inlinedClosure:inlinedClosure,sequence:sequence,statements:statements},$globals.IRSendInliner)});
- },
- args: ["anIRClosure"],
- source: "inlineClosure: anIRClosure\x0a\x09| inlinedClosure sequence statements |\x0a\x0a\x09inlinedClosure := self inlinedClosure.\x0a\x09inlinedClosure \x0a\x09\x09scope: anIRClosure scope;\x0a\x09\x09parent: anIRClosure parent.\x0a\x0a\x09\x22Add the possible temp declarations\x22\x0a\x09anIRClosure tempDeclarations do: [ :each |\x0a\x09\x09\x09inlinedClosure add: each ].\x0a\x0a\x09\x22Add a block sequence\x22\x0a\x09sequence := self inlinedSequence.\x0a\x0a\x09\x22Map the closure arguments to the receiver of the message send\x22\x0a\x09anIRClosure arguments do: [ :each |\x0a\x09\x09inlinedClosure add: (IRTempDeclaration new name: each; yourself).\x0a\x09\x09sequence add: (IRAssignment new\x0a\x09\x09\x09add: (IRVariable new variable: (AliasVar new scope: inlinedClosure scope; name: each; yourself));\x0a\x09\x09\x09add: (IRVariable new variable: (AliasVar new scope: inlinedClosure scope; name: '$receiver'; yourself));\x0a\x09\x09\x09yourself) ].\x0a\x09\x09\x09\x0a\x09\x22To ensure the correct order of the closure instructions: first the temps then the sequence\x22\x0a\x09inlinedClosure add: sequence.\x0a\x0a\x09\x22Get all the statements\x22\x0a\x09statements := anIRClosure sequence dagChildren.\x0a\x09\x0a\x09statements ifNotEmpty: [\x0a\x09\x09statements allButLast do: [ :each | sequence add: each ].\x0a\x0a\x09\x09\x22Inlined closures change local returns into result value itself\x22\x0a\x09\x09sequence add: statements last asInlinedBlockResult ].\x0a\x0a\x09^ inlinedClosure",
- referencedClasses: ["IRTempDeclaration", "IRAssignment", "IRVariable", "AliasVar"],
- messageSends: ["inlinedClosure", "scope:", "scope", "parent:", "parent", "do:", "tempDeclarations", "add:", "inlinedSequence", "arguments", "name:", "new", "yourself", "variable:", "dagChildren", "sequence", "ifNotEmpty:", "allButLast", "asInlinedBlockResult", "last"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlineSend:",
- protocol: "inlining",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- self._send_(anIRSend);
- $2=self._send();
- $ctx1.sendIdx["send"]=1;
- $1=$recv($2)._selector();
- return self._perform_withArguments_($1,$recv(self._send())._arguments());
- }, function($ctx1) {$ctx1.fill(self,"inlineSend:",{anIRSend:anIRSend},$globals.IRSendInliner)});
- },
- args: ["anIRSend"],
- source: "inlineSend: anIRSend\x0a\x09self send: anIRSend.\x0a\x09^ self\x0a\x09\x09perform: self send selector\x0a\x09\x09withArguments: self send arguments",
- referencedClasses: [],
- messageSends: ["send:", "perform:withArguments:", "selector", "send", "arguments"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlineSend:andReplace:",
- protocol: "private",
- fn: function (anIRSend,anIRInstruction){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(anIRInstruction)._replaceWith_(anIRSend);
- return self._inlineSend_(anIRSend);
- }, function($ctx1) {$ctx1.fill(self,"inlineSend:andReplace:",{anIRSend:anIRSend,anIRInstruction:anIRInstruction},$globals.IRSendInliner)});
- },
- args: ["anIRSend", "anIRInstruction"],
- source: "inlineSend: anIRSend andReplace: anIRInstruction\x0a\x09anIRInstruction replaceWith: anIRSend.\x0a\x09^ self inlineSend: anIRSend",
- referencedClasses: [],
- messageSends: ["replaceWith:", "inlineSend:"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlinedClosure",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.IRInlinedClosure)._new();
- }, function($ctx1) {$ctx1.fill(self,"inlinedClosure",{},$globals.IRSendInliner)});
- },
- args: [],
- source: "inlinedClosure\x0a\x09^ IRInlinedClosure new",
- referencedClasses: ["IRInlinedClosure"],
- messageSends: ["new"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlinedSend:withBlock:",
- protocol: "private",
- fn: function (inlinedSend,anIRInstruction){
- var self=this;
- var inlinedClosure;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$5;
- $1=$recv(anIRInstruction)._isClosure();
- if(!$core.assert($1)){
- self._inliningError_("Message argument should be a block");
- $ctx1.sendIdx["inliningError:"]=1;
- }
- $2=$recv($recv($recv(anIRInstruction)._arguments())._size()).__eq((0));
- if(!$core.assert($2)){
- self._inliningError_("Inlined block should have zero argument");
- }
- inlinedClosure=$recv(self._translator())._visit_(self._inlineClosure_(anIRInstruction));
- $4=self._send();
- $ctx1.sendIdx["send"]=1;
- $3=$recv($4)._receiver();
- $recv(inlinedSend)._add_($3);
- $ctx1.sendIdx["add:"]=1;
- $recv(inlinedSend)._add_(inlinedClosure);
- $recv(self._send())._replaceWith_(inlinedSend);
- $5=$recv($recv(inlinedSend)._method())._internalVariables();
- $ctx1.sendIdx["internalVariables"]=1;
- $recv($5)._addAll_($recv(inlinedSend)._internalVariables());
- return inlinedSend;
- }, function($ctx1) {$ctx1.fill(self,"inlinedSend:withBlock:",{inlinedSend:inlinedSend,anIRInstruction:anIRInstruction,inlinedClosure:inlinedClosure},$globals.IRSendInliner)});
- },
- args: ["inlinedSend", "anIRInstruction"],
- source: "inlinedSend: inlinedSend withBlock: anIRInstruction\x0a\x09| inlinedClosure |\x0a\x0a\x09anIRInstruction isClosure ifFalse: [ self inliningError: 'Message argument should be a block' ].\x0a\x09anIRInstruction arguments size = 0 ifFalse: [ self inliningError: 'Inlined block should have zero argument' ].\x0a\x0a\x09inlinedClosure := self translator visit: (self inlineClosure: anIRInstruction).\x0a\x0a\x09inlinedSend\x0a\x09\x09add: self send receiver;\x0a\x09\x09add: inlinedClosure.\x0a\x0a\x09self send replaceWith: inlinedSend.\x0a\x09inlinedSend method internalVariables \x0a\x09\x09addAll: inlinedSend internalVariables.\x0a\x0a\x09^ inlinedSend",
- referencedClasses: [],
- messageSends: ["ifFalse:", "isClosure", "inliningError:", "=", "size", "arguments", "visit:", "translator", "inlineClosure:", "add:", "receiver", "send", "replaceWith:", "addAll:", "internalVariables", "method"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlinedSend:withBlock:withBlock:",
- protocol: "private",
- fn: function (inlinedSend,anIRInstruction,anotherIRInstruction){
- var self=this;
- var inlinedClosure1,inlinedClosure2;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$6,$5,$7;
- $1=$recv(anIRInstruction)._isClosure();
- $ctx1.sendIdx["isClosure"]=1;
- if(!$core.assert($1)){
- self._inliningError_("Message argument should be a block");
- $ctx1.sendIdx["inliningError:"]=1;
- }
- $2=$recv(anotherIRInstruction)._isClosure();
- if(!$core.assert($2)){
- self._inliningError_("Message argument should be a block");
- }
- $3=self._translator();
- $ctx1.sendIdx["translator"]=1;
- $4=self._inlineClosure_(anIRInstruction);
- $ctx1.sendIdx["inlineClosure:"]=1;
- inlinedClosure1=$recv($3)._visit_($4);
- $ctx1.sendIdx["visit:"]=1;
- inlinedClosure2=$recv(self._translator())._visit_(self._inlineClosure_(anotherIRInstruction));
- $6=self._send();
- $ctx1.sendIdx["send"]=1;
- $5=$recv($6)._receiver();
- $recv(inlinedSend)._add_($5);
- $ctx1.sendIdx["add:"]=1;
- $recv(inlinedSend)._add_(inlinedClosure1);
- $ctx1.sendIdx["add:"]=2;
- $recv(inlinedSend)._add_(inlinedClosure2);
- $recv(self._send())._replaceWith_(inlinedSend);
- $7=$recv($recv(inlinedSend)._method())._internalVariables();
- $ctx1.sendIdx["internalVariables"]=1;
- $recv($7)._addAll_($recv(inlinedSend)._internalVariables());
- return inlinedSend;
- }, function($ctx1) {$ctx1.fill(self,"inlinedSend:withBlock:withBlock:",{inlinedSend:inlinedSend,anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction,inlinedClosure1:inlinedClosure1,inlinedClosure2:inlinedClosure2},$globals.IRSendInliner)});
- },
- args: ["inlinedSend", "anIRInstruction", "anotherIRInstruction"],
- source: "inlinedSend: inlinedSend withBlock: anIRInstruction withBlock: anotherIRInstruction\x0a\x09| inlinedClosure1 inlinedClosure2 |\x0a\x0a\x09anIRInstruction isClosure ifFalse: [ self inliningError: 'Message argument should be a block' ].\x0a\x09anotherIRInstruction isClosure ifFalse: [ self inliningError: 'Message argument should be a block' ].\x0a\x0a\x09inlinedClosure1 := self translator visit: (self inlineClosure: anIRInstruction).\x0a\x09inlinedClosure2 := self translator visit: (self inlineClosure: anotherIRInstruction).\x0a\x0a\x09inlinedSend\x0a\x09\x09add: self send receiver;\x0a\x09\x09add: inlinedClosure1;\x0a\x09\x09add: inlinedClosure2.\x0a\x0a\x09self send replaceWith: inlinedSend.\x0a\x09inlinedSend method internalVariables \x0a\x09\x09addAll: inlinedSend internalVariables.\x0a\x09\x09\x0a\x09^ inlinedSend",
- referencedClasses: [],
- messageSends: ["ifFalse:", "isClosure", "inliningError:", "visit:", "translator", "inlineClosure:", "add:", "receiver", "send", "replaceWith:", "addAll:", "internalVariables", "method"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlinedSequence",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.IRInlinedSequence)._new();
- }, function($ctx1) {$ctx1.fill(self,"inlinedSequence",{},$globals.IRSendInliner)});
- },
- args: [],
- source: "inlinedSequence\x0a\x09^ IRInlinedSequence new",
- referencedClasses: ["IRInlinedSequence"],
- messageSends: ["new"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inliningError:",
- protocol: "error handling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.InliningError)._signal_(aString);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"inliningError:",{aString:aString},$globals.IRSendInliner)});
- },
- args: ["aString"],
- source: "inliningError: aString\x0a\x09InliningError signal: aString",
- referencedClasses: ["InliningError"],
- messageSends: ["signal:"]
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "send",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@send"];
- },
- args: [],
- source: "send\x0a\x09^ send",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "send:",
- protocol: "accessing",
- fn: function (anIRSend){
- var self=this;
- self["@send"]=anIRSend;
- return self;
- },
- args: ["anIRSend"],
- source: "send: anIRSend\x0a\x09send := anIRSend",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "translator",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@translator"];
- },
- args: [],
- source: "translator\x0a\x09^ translator",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "translator:",
- protocol: "accessing",
- fn: function (anASTTranslator){
- var self=this;
- self["@translator"]=anASTTranslator;
- return self;
- },
- args: ["anASTTranslator"],
- source: "translator: anASTTranslator\x0a\x09translator := anASTTranslator",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSendInliner);
- $core.addMethod(
- $core.method({
- selector: "inlinedSelectors",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return ["ifTrue:", "ifFalse:", "ifTrue:ifFalse:", "ifFalse:ifTrue:", "ifNil:", "ifNotNil:", "ifNil:ifNotNil:", "ifNotNil:ifNil:"];
- },
- args: [],
- source: "inlinedSelectors\x0a\x09^ #('ifTrue:' 'ifFalse:' 'ifTrue:ifFalse:' 'ifFalse:ifTrue:' 'ifNil:' 'ifNotNil:' 'ifNil:ifNotNil:' 'ifNotNil:ifNil:')",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRSendInliner.klass);
- $core.addMethod(
- $core.method({
- selector: "shouldInline:",
- protocol: "accessing",
- fn: function (anIRSend){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._inlinedSelectors())._includes_($recv(anIRSend)._selector());
- if(!$core.assert($1)){
- return false;
- }
- return $recv($recv(anIRSend)._arguments())._allSatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._isClosure();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"shouldInline:",{anIRSend:anIRSend},$globals.IRSendInliner.klass)});
- },
- args: ["anIRSend"],
- source: "shouldInline: anIRSend\x0a\x09(self inlinedSelectors includes: anIRSend selector) ifFalse: [ ^ false ].\x0a\x09^ anIRSend arguments allSatisfy: [ :each | each isClosure ]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "includes:", "inlinedSelectors", "selector", "allSatisfy:", "arguments", "isClosure"]
- }),
- $globals.IRSendInliner.klass);
- $core.addClass("IRAssignmentInliner", $globals.IRSendInliner, ["target"], "Compiler-Inlining");
- $globals.IRAssignmentInliner.comment="I inline message sends together with assignments by moving them around into the inline closure instructions.\x0a\x0a##Example\x0a\x0a\x09foo\x0a\x09\x09| a |\x0a\x09\x09a := true ifTrue: [ 1 ]\x0a\x0aWill produce:\x0a\x0a\x09if($core.assert(true) {\x0a\x09\x09a = 1;\x0a\x09};";
- $core.addMethod(
- $core.method({
- selector: "inlineAssignment:",
- protocol: "inlining",
- fn: function (anIRAssignment){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._target_($recv(anIRAssignment)._left());
- return self._inlineSend_andReplace_($recv(anIRAssignment)._right(),anIRAssignment);
- }, function($ctx1) {$ctx1.fill(self,"inlineAssignment:",{anIRAssignment:anIRAssignment},$globals.IRAssignmentInliner)});
- },
- args: ["anIRAssignment"],
- source: "inlineAssignment: anIRAssignment\x0a\x09self target: anIRAssignment left.\x0a\x09^ self inlineSend: anIRAssignment right andReplace: anIRAssignment",
- referencedClasses: [],
- messageSends: ["target:", "left", "inlineSend:andReplace:", "right"]
- }),
- $globals.IRAssignmentInliner);
- $core.addMethod(
- $core.method({
- selector: "inlineClosure:",
- protocol: "inlining",
- fn: function (anIRClosure){
- var self=this;
- var closure,sequence,statements;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4;
- closure=(
- $ctx1.supercall = true,
- ($globals.IRAssignmentInliner.superclass||$boot.nilAsClass).fn.prototype._inlineClosure_.apply($recv(self), [anIRClosure]));
- $ctx1.supercall = false;
- sequence=$recv(closure)._sequence();
- statements=$recv(sequence)._dagChildren();
- $recv(statements)._ifNotEmpty_((function(){
- var final;
- return $core.withContext(function($ctx2) {
- final=$recv(statements)._last();
- final;
- $1=$recv(final)._yieldsValue();
- if($core.assert($1)){
- $2=sequence;
- $3=final;
- $5=$recv($globals.IRAssignment)._new();
- $recv($5)._add_(self._target());
- $ctx2.sendIdx["add:"]=1;
- $recv($5)._add_($recv(final)._copy());
- $4=$recv($5)._yourself();
- return $recv($2)._replace_with_($3,$4);
- }
- }, function($ctx2) {$ctx2.fillBlock({final:final},$ctx1,1)});
- }));
- return closure;
- }, function($ctx1) {$ctx1.fill(self,"inlineClosure:",{anIRClosure:anIRClosure,closure:closure,sequence:sequence,statements:statements},$globals.IRAssignmentInliner)});
- },
- args: ["anIRClosure"],
- source: "inlineClosure: anIRClosure\x0a\x09| closure sequence statements |\x0a\x0a\x09closure := super inlineClosure: anIRClosure.\x0a\x09sequence := closure sequence.\x0a\x09statements := sequence dagChildren.\x0a\x09\x0a\x09statements ifNotEmpty: [\x0a\x09\x09| final |\x0a\x09\x09final := statements last.\x0a\x09\x09final yieldsValue ifTrue: [\x0a\x09\x09\x09sequence replace: final with: (IRAssignment new\x0a\x09\x09\x09\x09add: self target;\x0a\x09\x09\x09\x09add: final copy;\x0a\x09\x09\x09\x09yourself) ] ].\x0a\x0a\x09^ closure",
- referencedClasses: ["IRAssignment"],
- messageSends: ["inlineClosure:", "sequence", "dagChildren", "ifNotEmpty:", "last", "ifTrue:", "yieldsValue", "replace:with:", "add:", "new", "target", "copy", "yourself"]
- }),
- $globals.IRAssignmentInliner);
- $core.addMethod(
- $core.method({
- selector: "target",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@target"];
- },
- args: [],
- source: "target\x0a\x09^ target",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRAssignmentInliner);
- $core.addMethod(
- $core.method({
- selector: "target:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@target"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "target: anObject\x0a\x09target := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRAssignmentInliner);
- $core.addClass("IRReturnInliner", $globals.IRSendInliner, [], "Compiler-Inlining");
- $globals.IRReturnInliner.comment="I inline message sends with inlined closure together with a return instruction.";
- $core.addMethod(
- $core.method({
- selector: "inlineClosure:",
- protocol: "inlining",
- fn: function (anIRClosure){
- var self=this;
- var closure,sequence,statements;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4;
- closure=(
- $ctx1.supercall = true,
- ($globals.IRReturnInliner.superclass||$boot.nilAsClass).fn.prototype._inlineClosure_.apply($recv(self), [anIRClosure]));
- $ctx1.supercall = false;
- sequence=$recv(closure)._sequence();
- statements=$recv(sequence)._dagChildren();
- $recv(statements)._ifNotEmpty_((function(){
- var final;
- return $core.withContext(function($ctx2) {
- final=$recv(statements)._last();
- final;
- $1=$recv(final)._yieldsValue();
- if($core.assert($1)){
- $2=sequence;
- $3=final;
- $5=$recv($globals.IRReturn)._new();
- $recv($5)._add_($recv(final)._copy());
- $4=$recv($5)._yourself();
- return $recv($2)._replace_with_($3,$4);
- }
- }, function($ctx2) {$ctx2.fillBlock({final:final},$ctx1,1)});
- }));
- return closure;
- }, function($ctx1) {$ctx1.fill(self,"inlineClosure:",{anIRClosure:anIRClosure,closure:closure,sequence:sequence,statements:statements},$globals.IRReturnInliner)});
- },
- args: ["anIRClosure"],
- source: "inlineClosure: anIRClosure\x0a\x09| closure sequence statements |\x0a\x0a\x09closure := super inlineClosure: anIRClosure.\x0a\x09sequence := closure sequence.\x0a\x09statements := sequence dagChildren.\x0a\x09\x0a\x09statements ifNotEmpty: [\x0a\x09\x09| final |\x0a\x09\x09final := statements last.\x0a\x09\x09final yieldsValue ifTrue: [\x0a\x09\x09\x09sequence replace: final with: (IRReturn new\x0a\x09\x09\x09\x09add: final copy;\x0a\x09\x09\x09\x09yourself) ] ].\x0a\x0a\x09^ closure",
- referencedClasses: ["IRReturn"],
- messageSends: ["inlineClosure:", "sequence", "dagChildren", "ifNotEmpty:", "last", "ifTrue:", "yieldsValue", "replace:with:", "add:", "new", "copy", "yourself"]
- }),
- $globals.IRReturnInliner);
- $core.addMethod(
- $core.method({
- selector: "inlineReturn:",
- protocol: "inlining",
- fn: function (anIRReturn){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._inlineSend_andReplace_($recv(anIRReturn)._expression(),anIRReturn);
- }, function($ctx1) {$ctx1.fill(self,"inlineReturn:",{anIRReturn:anIRReturn},$globals.IRReturnInliner)});
- },
- args: ["anIRReturn"],
- source: "inlineReturn: anIRReturn\x0a\x09^ self inlineSend: anIRReturn expression andReplace: anIRReturn",
- referencedClasses: [],
- messageSends: ["inlineSend:andReplace:", "expression"]
- }),
- $globals.IRReturnInliner);
- $core.addClass("InliningCodeGenerator", $globals.CodeGenerator, [], "Compiler-Inlining");
- $globals.InliningCodeGenerator.comment="I am a specialized code generator that uses inlining to produce more optimized JavaScript output";
- $core.addMethod(
- $core.method({
- selector: "inliner",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.IRInliner)._new();
- }, function($ctx1) {$ctx1.fill(self,"inliner",{},$globals.InliningCodeGenerator)});
- },
- args: [],
- source: "inliner\x0a\x09^ IRInliner new",
- referencedClasses: ["IRInliner"],
- messageSends: ["new"]
- }),
- $globals.InliningCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "irTranslatorClass",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $globals.IRInliningJSTranslator;
- },
- args: [],
- source: "irTranslatorClass\x0a\x09^ IRInliningJSTranslator",
- referencedClasses: ["IRInliningJSTranslator"],
- messageSends: []
- }),
- $globals.InliningCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "preInliner",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.ASTPreInliner)._new();
- }, function($ctx1) {$ctx1.fill(self,"preInliner",{},$globals.InliningCodeGenerator)});
- },
- args: [],
- source: "preInliner\x0a\x09^ ASTPreInliner new",
- referencedClasses: ["ASTPreInliner"],
- messageSends: ["new"]
- }),
- $globals.InliningCodeGenerator);
- $core.addMethod(
- $core.method({
- selector: "transformersDictionary",
- protocol: "compiling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=self["@transformersDictionary"];
- if(($receiver = $1) == null || $receiver.isNil){
- $2=(
- $ctx1.supercall = true,
- ($globals.InliningCodeGenerator.superclass||$boot.nilAsClass).fn.prototype._transformersDictionary.apply($recv(self), []));
- $ctx1.supercall = false;
- $recv($2)._at_put_("3000-inlinerTagging",self._preInliner());
- $ctx1.sendIdx["at:put:"]=1;
- $recv($2)._at_put_("6000-inliner",self._inliner());
- $ctx1.sendIdx["at:put:"]=2;
- $recv($2)._at_put_("8000-irToJs",self._irTranslator());
- self["@transformersDictionary"]=$recv($2)._yourself();
- return self["@transformersDictionary"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"transformersDictionary",{},$globals.InliningCodeGenerator)});
- },
- args: [],
- source: "transformersDictionary\x0a\x09^ transformersDictionary ifNil: [ transformersDictionary := super transformersDictionary\x0a\x09\x09at: '3000-inlinerTagging' put: self preInliner;\x0a\x09\x09at: '6000-inliner' put: self inliner;\x0a\x09\x09at: '8000-irToJs' put: self irTranslator;\x0a\x09\x09yourself ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "at:put:", "transformersDictionary", "preInliner", "inliner", "irTranslator", "yourself"]
- }),
- $globals.InliningCodeGenerator);
- $core.addClass("InliningError", $globals.SemanticError, [], "Compiler-Inlining");
- $globals.InliningError.comment="Instances of InliningError are signaled when using an `InliningCodeGenerator`in a `Compiler`.";
- $core.addClass("InliningSemanticAnalyzer", $globals.SemanticAnalyzer, [], "Compiler-Inlining");
- $core.addMethod(
- $core.method({
- selector: "visitSendNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- $1=$recv(aNode)._superSend();
- if(!$core.assert($1)){
- $2=$recv($recv($globals.IRSendInliner)._inlinedSelectors())._includes_($recv(aNode)._selector());
- if($core.assert($2)){
- $recv(aNode)._shouldBeInlined_(true);
- $3=$recv(aNode)._receiver();
- if(($receiver = $3) == null || $receiver.isNil){
- $3;
- } else {
- var receiver;
- receiver=$receiver;
- $recv(receiver)._shouldBeAliased_(true);
- }
- }
- }
- (
- $ctx1.supercall = true,
- ($globals.InliningSemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitSendNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode},$globals.InliningSemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitSendNode: aNode\x0a\x0a\x09aNode superSend ifFalse: [ \x0a\x09\x09(IRSendInliner inlinedSelectors includes: aNode selector) ifTrue: [\x0a\x09\x09\x09aNode shouldBeInlined: true.\x0a\x09\x09\x09aNode receiver ifNotNil: [ :receiver |\x0a\x09\x09\x09\x09receiver shouldBeAliased: true ] ] ].\x0a\x0a\x09super visitSendNode: aNode",
- referencedClasses: ["IRSendInliner"],
- messageSends: ["ifFalse:", "superSend", "ifTrue:", "includes:", "inlinedSelectors", "selector", "shouldBeInlined:", "ifNotNil:", "receiver", "shouldBeAliased:", "visitSendNode:"]
- }),
- $globals.InliningSemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "asInlinedBlockResult",
- protocol: "*Compiler-Inlining",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._expression();
- }, function($ctx1) {$ctx1.fill(self,"asInlinedBlockResult",{},$globals.IRBlockReturn)});
- },
- args: [],
- source: "asInlinedBlockResult\x0a\x09^ self expression",
- referencedClasses: [],
- messageSends: ["expression"]
- }),
- $globals.IRBlockReturn);
- $core.addMethod(
- $core.method({
- selector: "asInlinedBlockResult",
- protocol: "*Compiler-Inlining",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asInlinedBlockResult\x0a\x09^ self",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.IRInstruction);
- });
- define('amber_core/Compiler-Interpreter',["amber/boot", "amber_core/Compiler-AST", "amber_core/Compiler-Semantic", "amber_core/Kernel-Exceptions", "amber_core/Kernel-Methods", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Compiler-Interpreter");
- $core.packages["Compiler-Interpreter"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Compiler-Interpreter"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("AIBlockClosure", $globals.BlockClosure, ["node", "outerContext"], "Compiler-Interpreter");
- $globals.AIBlockClosure.comment="I am a special `BlockClosure` subclass used by an interpreter to interpret a block node.\x0a\x0aWhile I am polymorphic with `BlockClosure`, some methods such as `#new` will raise interpretation errors. Unlike a `BlockClosure`, my instance are not JavaScript functions.\x0a\x0aEvaluating an instance will result in interpreting the `node` instance variable (instance of `BlockNode`).";
- $core.addMethod(
- $core.method({
- selector: "applyTo:arguments:",
- protocol: "evaluating",
- fn: function (anObject,aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._interpreterError();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"applyTo:arguments:",{anObject:anObject,aCollection:aCollection},$globals.AIBlockClosure)});
- },
- args: ["anObject", "aCollection"],
- source: "applyTo: anObject arguments: aCollection\x0a\x09self interpreterError",
- referencedClasses: [],
- messageSends: ["interpreterError"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "compiledSource",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "[ AST Block closure ]";
- },
- args: [],
- source: "compiledSource\x0a\x09\x22Unlike blocks, the receiver doesn't represent a JS function\x22\x0a\x09\x0a\x09^ '[ AST Block closure ]'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "currySelf",
- protocol: "converting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._interpreterError();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"currySelf",{},$globals.AIBlockClosure)});
- },
- args: [],
- source: "currySelf\x0a\x09self interpreterError",
- referencedClasses: [],
- messageSends: ["interpreterError"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "initializeWithContext:node:",
- protocol: "initialization",
- fn: function (aContext,aNode){
- var self=this;
- self["@node"]=aNode;
- self["@outerContext"]=aContext;
- return self;
- },
- args: ["aContext", "aNode"],
- source: "initializeWithContext: aContext node: aNode\x0a\x09node := aNode.\x0a\x09outerContext := aContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "interpreterError",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.ASTInterpreterError)._signal_("Method cannot be interpreted by the interpreter.");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"interpreterError",{},$globals.AIBlockClosure)});
- },
- args: [],
- source: "interpreterError\x0a\x09ASTInterpreterError signal: 'Method cannot be interpreted by the interpreter.'",
- referencedClasses: ["ASTInterpreterError"],
- messageSends: ["signal:"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "numArgs",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self["@node"])._temps())._size();
- }, function($ctx1) {$ctx1.fill(self,"numArgs",{},$globals.AIBlockClosure)});
- },
- args: [],
- source: "numArgs\x0a\x09^ node temps size",
- referencedClasses: [],
- messageSends: ["size", "temps"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value",
- protocol: "evaluating",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._valueWithPossibleArguments_([]);
- }, function($ctx1) {$ctx1.fill(self,"value",{},$globals.AIBlockClosure)});
- },
- args: [],
- source: "value\x0a\x09^ self valueWithPossibleArguments: #()",
- referencedClasses: [],
- messageSends: ["valueWithPossibleArguments:"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value:",
- protocol: "evaluating",
- fn: function (anArgument){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._valueWithPossibleArguments_([anArgument]);
- }, function($ctx1) {$ctx1.fill(self,"value:",{anArgument:anArgument},$globals.AIBlockClosure)});
- },
- args: ["anArgument"],
- source: "value: anArgument\x0a\x09^ self valueWithPossibleArguments: {anArgument}",
- referencedClasses: [],
- messageSends: ["valueWithPossibleArguments:"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value:value:",
- protocol: "evaluating",
- fn: function (firstArgument,secondArgument){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._valueWithPossibleArguments_([firstArgument,secondArgument]);
- }, function($ctx1) {$ctx1.fill(self,"value:value:",{firstArgument:firstArgument,secondArgument:secondArgument},$globals.AIBlockClosure)});
- },
- args: ["firstArgument", "secondArgument"],
- source: "value: firstArgument value: secondArgument\x0a\x09^ self valueWithPossibleArguments: {firstArgument . secondArgument}",
- referencedClasses: [],
- messageSends: ["valueWithPossibleArguments:"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "value:value:value:",
- protocol: "evaluating",
- fn: function (firstArgument,secondArgument,thirdArgument){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._valueWithPossibleArguments_([firstArgument,secondArgument,thirdArgument]);
- }, function($ctx1) {$ctx1.fill(self,"value:value:value:",{firstArgument:firstArgument,secondArgument:secondArgument,thirdArgument:thirdArgument},$globals.AIBlockClosure)});
- },
- args: ["firstArgument", "secondArgument", "thirdArgument"],
- source: "value: firstArgument value: secondArgument value: thirdArgument\x0a\x09^ self valueWithPossibleArguments: {firstArgument . secondArgument . thirdArgument}",
- referencedClasses: [],
- messageSends: ["valueWithPossibleArguments:"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "valueWithPossibleArguments:",
- protocol: "evaluating",
- fn: function (aCollection){
- var self=this;
- var context,sequenceNode;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- context=$recv(self["@outerContext"])._newInnerContext();
- $1=$recv($recv($recv(self["@node"])._dagChildren())._first())._copy();
- $recv($1)._parent_(nil);
- sequenceNode=$recv($1)._yourself();
- $recv($recv(sequenceNode)._temps())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(context)._defineLocal_(each);
- $ctx2.sendIdx["defineLocal:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $recv($recv(self["@node"])._parameters())._withIndexDo_((function(each,index){
- return $core.withContext(function($ctx2) {
- $recv(context)._defineLocal_(each);
- return $recv(context)._localAt_put_(each,$recv(aCollection)._at_ifAbsent_(index,(function(){
- return nil;
- })));
- }, function($ctx2) {$ctx2.fillBlock({each:each,index:index},$ctx1,2)});
- }));
- $2=$recv(context)._interpreter();
- $ctx1.sendIdx["interpreter"]=1;
- $recv($2)._node_(sequenceNode);
- $recv($2)._enterNode();
- $recv($2)._proceed();
- $3=$recv(self["@outerContext"])._interpreter();
- $ctx1.sendIdx["interpreter"]=2;
- $recv($3)._setNonLocalReturnFromContext_(context);
- return $recv($recv(context)._interpreter())._pop();
- }, function($ctx1) {$ctx1.fill(self,"valueWithPossibleArguments:",{aCollection:aCollection,context:context,sequenceNode:sequenceNode},$globals.AIBlockClosure)});
- },
- args: ["aCollection"],
- source: "valueWithPossibleArguments: aCollection\x0a\x09| context sequenceNode |\x0a\x09context := outerContext newInnerContext.\x0a\x0a\x09\x22Interpret a copy of the sequence node to avoid creating a new AIBlockClosure\x22\x0a\x09sequenceNode := node dagChildren first copy\x0a\x09\x09parent: nil;\x0a\x09\x09yourself.\x0a\x09\x09\x0a\x09\x22Define locals in the context\x22\x0a\x09sequenceNode temps do: [ :each |\x0a\x09\x09context defineLocal: each ].\x0a\x09\x09\x0a\x09\x22Populate the arguments into the context locals\x22\x09\x0a\x09node parameters withIndexDo: [ :each :index |\x0a\x09\x09context defineLocal: each.\x0a\x09\x09context localAt: each put: (aCollection at: index ifAbsent: [ nil ]) ].\x0a\x0a\x09\x22Interpret the first node of the BlockSequenceNode\x22\x0a\x09context interpreter\x0a\x09\x09node: sequenceNode;\x0a\x09\x09enterNode;\x0a\x09\x09proceed.\x0a\x09\x09\x0a\x09outerContext interpreter\x0a\x09\x09setNonLocalReturnFromContext: context.\x0a\x09\x09\x0a\x09^ context interpreter pop",
- referencedClasses: [],
- messageSends: ["newInnerContext", "parent:", "copy", "first", "dagChildren", "yourself", "do:", "temps", "defineLocal:", "withIndexDo:", "parameters", "localAt:put:", "at:ifAbsent:", "node:", "interpreter", "enterNode", "proceed", "setNonLocalReturnFromContext:", "pop"]
- }),
- $globals.AIBlockClosure);
- $core.addMethod(
- $core.method({
- selector: "forContext:node:",
- protocol: "instance creation",
- fn: function (aContext,aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._initializeWithContext_node_(aContext,aNode);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"forContext:node:",{aContext:aContext,aNode:aNode},$globals.AIBlockClosure.klass)});
- },
- args: ["aContext", "aNode"],
- source: "forContext: aContext node: aNode\x0a\x09^ self new\x0a\x09\x09initializeWithContext: aContext node: aNode;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["initializeWithContext:node:", "new", "yourself"]
- }),
- $globals.AIBlockClosure.klass);
- $core.addClass("AIContext", $globals.MethodContext, ["outerContext", "innerContext", "pc", "locals", "selector", "index", "sendIndexes", "evaluatedSelector", "ast", "interpreter", "supercall"], "Compiler-Interpreter");
- $globals.AIContext.comment="I am like a `MethodContext`, used by the `ASTInterpreter`.\x0aUnlike a `MethodContext`, my instances are not read-only.\x0a\x0aWhen debugging, my instances are created by copying the current `MethodContext` (thisContext)";
- $core.addMethod(
- $core.method({
- selector: "arguments",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._ast())._arguments())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return self._localAt_ifAbsent_(each,(function(){
- return $core.withContext(function($ctx3) {
- return self._error_("Argument not in context");
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"arguments",{},$globals.AIContext)});
- },
- args: [],
- source: "arguments\x0a\x09^ self ast arguments collect: [ :each |\x0a\x09\x09self localAt: each ifAbsent: [ self error: 'Argument not in context' ] ]",
- referencedClasses: [],
- messageSends: ["collect:", "arguments", "ast", "localAt:ifAbsent:", "error:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "ast",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- $1=self._isBlockContext();
- if($core.assert($1)){
- $2=self._outerContext();
- if(($receiver = $2) == null || $receiver.isNil){
- return $2;
- } else {
- var context;
- context=$receiver;
- return $recv(context)._ast();
- }
- }
- $3=self["@ast"];
- if(($receiver = $3) == null || $receiver.isNil){
- self._initializeAST();
- } else {
- $3;
- }
- return self["@ast"];
- }, function($ctx1) {$ctx1.fill(self,"ast",{},$globals.AIContext)});
- },
- args: [],
- source: "ast\x0a\x09self isBlockContext ifTrue: [ \x0a\x09\x09^ self outerContext ifNotNil: [ :context | context ast ] ].\x0a\x0a\x09ast ifNil: [ self initializeAST ].\x0a\x09^ ast",
- referencedClasses: [],
- messageSends: ["ifTrue:", "isBlockContext", "ifNotNil:", "outerContext", "ast", "ifNil:", "initializeAST"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "basicLocalAt:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._locals())._at_(aString);
- }, function($ctx1) {$ctx1.fill(self,"basicLocalAt:",{aString:aString},$globals.AIContext)});
- },
- args: ["aString"],
- source: "basicLocalAt: aString\x0a\x09^ self locals at: aString",
- referencedClasses: [],
- messageSends: ["at:", "locals"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "basicLocalAt:put:",
- protocol: "private",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._locals())._at_put_(aString,anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basicLocalAt:put:",{aString:aString,anObject:anObject},$globals.AIContext)});
- },
- args: ["aString", "anObject"],
- source: "basicLocalAt: aString put: anObject\x0a\x09self locals at: aString put: anObject",
- referencedClasses: [],
- messageSends: ["at:put:", "locals"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "basicReceiver",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._localAt_("self");
- }, function($ctx1) {$ctx1.fill(self,"basicReceiver",{},$globals.AIContext)});
- },
- args: [],
- source: "basicReceiver\x0a\x09^ self localAt: 'self'",
- referencedClasses: [],
- messageSends: ["localAt:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "defineLocal:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._locals())._at_put_(aString,nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"defineLocal:",{aString:aString},$globals.AIContext)});
- },
- args: ["aString"],
- source: "defineLocal: aString\x0a\x09self locals at: aString put: nil",
- referencedClasses: [],
- messageSends: ["at:put:", "locals"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "evaluate:on:",
- protocol: "evaluating",
- fn: function (aString,anEvaluator){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(anEvaluator)._evaluate_context_(aString,self);
- }, function($ctx1) {$ctx1.fill(self,"evaluate:on:",{aString:aString,anEvaluator:anEvaluator},$globals.AIContext)});
- },
- args: ["aString", "anEvaluator"],
- source: "evaluate: aString on: anEvaluator\x0a\x09^ anEvaluator evaluate: aString context: self",
- referencedClasses: [],
- messageSends: ["evaluate:context:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "evaluateNode:",
- protocol: "evaluating",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.ASTInterpreter)._new();
- $recv($1)._context_(self);
- $recv($1)._node_(aNode);
- $recv($1)._enterNode();
- $recv($1)._proceed();
- return $recv($1)._result();
- }, function($ctx1) {$ctx1.fill(self,"evaluateNode:",{aNode:aNode},$globals.AIContext)});
- },
- args: ["aNode"],
- source: "evaluateNode: aNode\x0a\x09^ ASTInterpreter new\x0a\x09\x09context: self;\x0a\x09\x09node: aNode;\x0a\x09\x09enterNode;\x0a\x09\x09proceed;\x0a\x09\x09result",
- referencedClasses: ["ASTInterpreter"],
- messageSends: ["context:", "new", "node:", "enterNode", "proceed", "result"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "evaluatedSelector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@evaluatedSelector"];
- },
- args: [],
- source: "evaluatedSelector\x0a\x09^ evaluatedSelector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "evaluatedSelector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@evaluatedSelector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "evaluatedSelector: aString\x0a\x09evaluatedSelector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "index",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@index"];
- if(($receiver = $1) == null || $receiver.isNil){
- return (0);
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"index",{},$globals.AIContext)});
- },
- args: [],
- source: "index\x0a\x09^ index ifNil: [ 0 ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "index:",
- protocol: "accessing",
- fn: function (anInteger){
- var self=this;
- self["@index"]=anInteger;
- return self;
- },
- args: ["anInteger"],
- source: "index: anInteger\x0a\x09index := anInteger",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "initializeAST",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._method();
- $ctx1.sendIdx["method"]=1;
- self["@ast"]=$recv($1)._ast();
- $recv($recv($globals.SemanticAnalyzer)._on_($recv(self._method())._methodClass()))._visit_(self["@ast"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initializeAST",{},$globals.AIContext)});
- },
- args: [],
- source: "initializeAST\x0a\x09ast := self method ast.\x0a\x09(SemanticAnalyzer on: self method methodClass)\x0a\x09\x09visit: ast",
- referencedClasses: ["SemanticAnalyzer"],
- messageSends: ["ast", "method", "visit:", "on:", "methodClass"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "initializeFromMethodContext:",
- protocol: "initialization",
- fn: function (aMethodContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- self._evaluatedSelector_($recv(aMethodContext)._evaluatedSelector());
- self._index_($recv(aMethodContext)._index());
- self._sendIndexes_($recv(aMethodContext)._sendIndexes());
- self._receiver_($recv(aMethodContext)._receiver());
- self._supercall_($recv(aMethodContext)._supercall());
- self._selector_($recv(aMethodContext)._selector());
- $1=$recv(aMethodContext)._outerContext();
- $ctx1.sendIdx["outerContext"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- var outer;
- outer=$receiver;
- $2=$recv(outer)._methodContext();
- if(($receiver = $2) == null || $receiver.isNil){
- $2;
- } else {
- self._outerContext_($recv(self._class())._fromMethodContext_($recv(aMethodContext)._outerContext()));
- }
- $3=$recv(aMethodContext)._locals();
- $ctx1.sendIdx["locals"]=1;
- $recv($3)._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(self._locals())._at_put_(key,value);
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,3)});
- }));
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initializeFromMethodContext:",{aMethodContext:aMethodContext},$globals.AIContext)});
- },
- args: ["aMethodContext"],
- source: "initializeFromMethodContext: aMethodContext\x0a\x0a\x09self\x0a\x09\x09evaluatedSelector: aMethodContext evaluatedSelector;\x0a\x09\x09index: aMethodContext index;\x0a\x09\x09sendIndexes: aMethodContext sendIndexes;\x0a\x09\x09receiver: aMethodContext receiver;\x0a\x09\x09supercall: aMethodContext supercall;\x0a\x09\x09selector: aMethodContext selector.\x0a\x09\x09\x0a\x09aMethodContext outerContext ifNotNil: [ :outer |\x0a\x09\x09\x22If the method context is nil, the block was defined in JS, so ignore it\x22\x0a\x09\x09outer methodContext ifNotNil: [\x0a\x09\x09\x09self outerContext: (self class fromMethodContext: aMethodContext outerContext) ].\x0a\x09\x09\x09aMethodContext locals keysAndValuesDo: [ :key :value |\x0a\x09\x09\x09\x09self locals at: key put: value ] ]",
- referencedClasses: [],
- messageSends: ["evaluatedSelector:", "evaluatedSelector", "index:", "index", "sendIndexes:", "sendIndexes", "receiver:", "receiver", "supercall:", "supercall", "selector:", "selector", "ifNotNil:", "outerContext", "methodContext", "outerContext:", "fromMethodContext:", "class", "keysAndValuesDo:", "locals", "at:put:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "initializeInterpreter",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=$recv($globals.ASTInterpreter)._new();
- $recv($1)._context_(self);
- self["@interpreter"]=$recv($1)._yourself();
- $2=self._innerContext();
- if(($receiver = $2) == null || $receiver.isNil){
- $2;
- } else {
- self._setupInterpreter_(self["@interpreter"]);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initializeInterpreter",{},$globals.AIContext)});
- },
- args: [],
- source: "initializeInterpreter\x0a\x09interpreter := ASTInterpreter new\x0a\x09\x09context: self;\x0a\x09\x09yourself.\x0a\x09\x0a\x09self innerContext ifNotNil: [\x0a\x09\x09self setupInterpreter: interpreter ]",
- referencedClasses: ["ASTInterpreter"],
- messageSends: ["context:", "new", "yourself", "ifNotNil:", "innerContext", "setupInterpreter:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "initializeLocals",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@locals"]=$recv($globals.Dictionary)._new();
- $recv(self["@locals"])._at_put_("thisContext",self);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initializeLocals",{},$globals.AIContext)});
- },
- args: [],
- source: "initializeLocals\x0a\x09locals := Dictionary new.\x0a\x09locals at: 'thisContext' put: self.",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "innerContext",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@innerContext"];
- },
- args: [],
- source: "innerContext\x0a\x09^ innerContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "innerContext:",
- protocol: "accessing",
- fn: function (anAIContext){
- var self=this;
- self["@innerContext"]=anAIContext;
- return self;
- },
- args: ["anAIContext"],
- source: "innerContext: anAIContext\x0a\x09innerContext := anAIContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "interpreter",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@interpreter"];
- if(($receiver = $1) == null || $receiver.isNil){
- self._initializeInterpreter();
- } else {
- $1;
- }
- return self["@interpreter"];
- }, function($ctx1) {$ctx1.fill(self,"interpreter",{},$globals.AIContext)});
- },
- args: [],
- source: "interpreter\x0a\x09interpreter ifNil: [ self initializeInterpreter ].\x0a\x09^ interpreter",
- referencedClasses: [],
- messageSends: ["ifNil:", "initializeInterpreter"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "interpreter:",
- protocol: "interpreting",
- fn: function (anInterpreter){
- var self=this;
- self["@interpreter"]=anInterpreter;
- return self;
- },
- args: ["anInterpreter"],
- source: "interpreter: anInterpreter\x0a\x09interpreter := anInterpreter",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "isTopContext",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._innerContext())._isNil();
- }, function($ctx1) {$ctx1.fill(self,"isTopContext",{},$globals.AIContext)});
- },
- args: [],
- source: "isTopContext\x0a\x09^ self innerContext isNil",
- referencedClasses: [],
- messageSends: ["isNil", "innerContext"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "localAt:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- var context;
- return $core.withContext(function($ctx1) {
- context=self._lookupContextForLocal_(aString);
- return $recv(context)._basicLocalAt_(aString);
- }, function($ctx1) {$ctx1.fill(self,"localAt:",{aString:aString,context:context},$globals.AIContext)});
- },
- args: ["aString"],
- source: "localAt: aString\x0a\x09\x22Lookup the local value up to the method context\x22\x0a\x0a\x09| context |\x0a\x09\x0a\x09context := self lookupContextForLocal: aString.\x0a\x09^ context basicLocalAt: aString",
- referencedClasses: [],
- messageSends: ["lookupContextForLocal:", "basicLocalAt:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "localAt:ifAbsent:",
- protocol: "accessing",
- fn: function (aString,aBlock){
- var self=this;
- var context;
- return $core.withContext(function($ctx1) {
- var $early={};
- try {
- context=self._lookupContextForLocal_ifNone_(aString,(function(){
- return $core.withContext(function($ctx2) {
- throw $early=[$recv(aBlock)._value()];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return $recv(context)._basicLocalAt_(aString);
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"localAt:ifAbsent:",{aString:aString,aBlock:aBlock,context:context},$globals.AIContext)});
- },
- args: ["aString", "aBlock"],
- source: "localAt: aString ifAbsent: aBlock\x0a\x09\x22Lookup the local value up to the method context\x22\x0a\x0a\x09| context |\x0a\x09\x0a\x09context := self \x09\x0a\x09\x09lookupContextForLocal: aString \x0a\x09\x09ifNone: [ ^ aBlock value ].\x0a\x09\x0a\x09^ context basicLocalAt: aString",
- referencedClasses: [],
- messageSends: ["lookupContextForLocal:ifNone:", "value", "basicLocalAt:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "localAt:put:",
- protocol: "accessing",
- fn: function (aString,anObject){
- var self=this;
- var context;
- return $core.withContext(function($ctx1) {
- context=self._lookupContextForLocal_(aString);
- $recv(context)._basicLocalAt_put_(aString,anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"localAt:put:",{aString:aString,anObject:anObject,context:context},$globals.AIContext)});
- },
- args: ["aString", "anObject"],
- source: "localAt: aString put: anObject\x0a\x09| context |\x0a\x09\x0a\x09context := self lookupContextForLocal: aString.\x0a\x09context basicLocalAt: aString put: anObject",
- referencedClasses: [],
- messageSends: ["lookupContextForLocal:", "basicLocalAt:put:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "locals",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@locals"];
- if(($receiver = $1) == null || $receiver.isNil){
- self._initializeLocals();
- } else {
- $1;
- }
- return self["@locals"];
- }, function($ctx1) {$ctx1.fill(self,"locals",{},$globals.AIContext)});
- },
- args: [],
- source: "locals\x0a\x09locals ifNil: [ self initializeLocals ].\x0a\x09\x0a\x09^ locals",
- referencedClasses: [],
- messageSends: ["ifNil:", "initializeLocals"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "lookupContextForLocal:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._lookupContextForLocal_ifNone_(aString,(function(){
- return $core.withContext(function($ctx2) {
- return self._variableNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"lookupContextForLocal:",{aString:aString},$globals.AIContext)});
- },
- args: ["aString"],
- source: "lookupContextForLocal: aString\x0a\x09\x22Lookup the context defining the local named `aString` \x0a\x09up to the method context\x22\x0a\x0a\x09^ self \x0a\x09\x09lookupContextForLocal: aString \x0a\x09\x09ifNone: [ self variableNotFound ]",
- referencedClasses: [],
- messageSends: ["lookupContextForLocal:ifNone:", "variableNotFound"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "lookupContextForLocal:ifNone:",
- protocol: "private",
- fn: function (aString,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- return $recv(self._locals())._at_ifPresent_ifAbsent_(aString,(function(){
- return self;
- }),(function(){
- return $core.withContext(function($ctx2) {
- $1=self._outerContext();
- return $recv($1)._ifNil_ifNotNil_(aBlock,(function(context){
- return $core.withContext(function($ctx3) {
- return $recv(context)._lookupContextForLocal_(aString);
- }, function($ctx3) {$ctx3.fillBlock({context:context},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"lookupContextForLocal:ifNone:",{aString:aString,aBlock:aBlock},$globals.AIContext)});
- },
- args: ["aString", "aBlock"],
- source: "lookupContextForLocal: aString ifNone: aBlock\x0a\x09\x22Lookup the context defining the local named `aString` \x0a\x09up to the method context\x22\x0a\x0a\x09^ self locals \x0a\x09\x09at: aString\x0a\x09\x09ifPresent: [ self ]\x0a\x09\x09ifAbsent: [ \x0a\x09\x09\x09self outerContext \x0a\x09\x09\x09\x09ifNil: aBlock\x0a\x09\x09\x09\x09ifNotNil: [ :context | \x0a\x09\x09\x09\x09\x09context lookupContextForLocal: aString ] ]",
- referencedClasses: [],
- messageSends: ["at:ifPresent:ifAbsent:", "locals", "ifNil:ifNotNil:", "outerContext", "lookupContextForLocal:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "newInnerContext",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._class())._new();
- $recv($1)._outerContext_(self);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"newInnerContext",{},$globals.AIContext)});
- },
- args: [],
- source: "newInnerContext\x0a\x09^ self class new\x0a\x09\x09outerContext: self;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["outerContext:", "new", "class", "yourself"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "outerContext",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@outerContext"];
- },
- args: [],
- source: "outerContext\x0a\x09^ outerContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "outerContext:",
- protocol: "accessing",
- fn: function (anAIContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- self["@outerContext"]=anAIContext;
- $1=self["@outerContext"];
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- var context;
- context=$receiver;
- $recv(context)._innerContext_(self);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"outerContext:",{anAIContext:anAIContext},$globals.AIContext)});
- },
- args: ["anAIContext"],
- source: "outerContext: anAIContext\x0a\x09outerContext := anAIContext.\x0a\x09outerContext ifNotNil: [ :context | \x0a\x09\x09context innerContext: self ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "innerContext:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "receiver:",
- protocol: "interpreting",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._locals())._at_put_("self",anObject);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"receiver:",{anObject:anObject},$globals.AIContext)});
- },
- args: ["anObject"],
- source: "receiver: anObject\x0a\x09self locals at: 'self' put: anObject",
- referencedClasses: [],
- messageSends: ["at:put:", "locals"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@selector"];
- },
- args: [],
- source: "selector\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@selector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09selector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "sendIndexAt:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._sendIndexes())._at_ifAbsent_(aString,(function(){
- return (0);
- }));
- }, function($ctx1) {$ctx1.fill(self,"sendIndexAt:",{aString:aString},$globals.AIContext)});
- },
- args: ["aString"],
- source: "sendIndexAt: aString\x0a\x09^ self sendIndexes at: aString ifAbsent: [ 0 ]",
- referencedClasses: [],
- messageSends: ["at:ifAbsent:", "sendIndexes"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "sendIndexes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@sendIndexes"];
- if(($receiver = $1) == null || $receiver.isNil){
- return $recv($globals.Dictionary)._new();
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"sendIndexes",{},$globals.AIContext)});
- },
- args: [],
- source: "sendIndexes\x0a\x09^ sendIndexes ifNil: [ Dictionary new ]",
- referencedClasses: ["Dictionary"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "sendIndexes:",
- protocol: "accessing",
- fn: function (aDictionary){
- var self=this;
- self["@sendIndexes"]=aDictionary;
- return self;
- },
- args: ["aDictionary"],
- source: "sendIndexes: aDictionary\x0a\x09sendIndexes := aDictionary",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "setupInterpreter:",
- protocol: "interpreting",
- fn: function (anInterpreter){
- var self=this;
- var currentNode;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$7,$6,$5,$receiver;
- $1=$recv($globals.ASTPCNodeVisitor)._new();
- $2=self._evaluatedSelector();
- $ctx1.sendIdx["evaluatedSelector"]=1;
- $recv($1)._selector_($2);
- $recv($1)._index_(self._sendIndexAt_(self._evaluatedSelector()));
- $3=self._ast();
- $ctx1.sendIdx["ast"]=1;
- $recv($1)._visit_($3);
- currentNode=$recv($1)._currentNode();
- $4=$recv(self._ast())._sequenceNode();
- if(($receiver = $4) == null || $receiver.isNil){
- $4;
- } else {
- var sequence;
- sequence=$receiver;
- $recv($recv(sequence)._temps())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._defineLocal_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- $ctx1.sendIdx["do:"]=1;
- }
- $recv(anInterpreter)._node_(currentNode);
- $7=self._innerContext();
- $ctx1.sendIdx["innerContext"]=1;
- $6=$recv($7)._arguments();
- $5=$recv($6)._reversed();
- $recv($5)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(anInterpreter)._push_(each);
- $ctx2.sendIdx["push:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- $recv(anInterpreter)._push_($recv(self._innerContext())._receiver());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setupInterpreter:",{anInterpreter:anInterpreter,currentNode:currentNode},$globals.AIContext)});
- },
- args: ["anInterpreter"],
- source: "setupInterpreter: anInterpreter\x0a\x09| currentNode |\x0a\x09\x0a\x09\x22Retrieve the current node\x22\x0a\x09currentNode := ASTPCNodeVisitor new\x0a\x09\x09\x09selector: self evaluatedSelector;\x0a\x09\x09\x09index: (self sendIndexAt: self evaluatedSelector);\x0a\x09\x09\x09visit: self ast;\x0a\x09\x09\x09currentNode.\x0a\x09\x0a\x09\x22Define locals for the context\x22\x0a\x09self ast sequenceNode ifNotNil: [ :sequence |\x0a\x09\x09sequence temps do: [ :each |\x0a\x09\x09\x09self defineLocal: each ] ].\x0a\x09\x0a\x09anInterpreter node: currentNode.\x0a\x0a\x09\x22Push the send args and receiver to the interpreter stack\x22\x09\x0a\x09self innerContext arguments reversed do: [ :each | \x0a\x09\x09anInterpreter push: each ].\x0a\x09\x09\x0a\x09anInterpreter push: (self innerContext receiver)",
- referencedClasses: ["ASTPCNodeVisitor"],
- messageSends: ["selector:", "new", "evaluatedSelector", "index:", "sendIndexAt:", "visit:", "ast", "currentNode", "ifNotNil:", "sequenceNode", "do:", "temps", "defineLocal:", "node:", "reversed", "arguments", "innerContext", "push:", "receiver"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "supercall",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@supercall"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"supercall",{},$globals.AIContext)});
- },
- args: [],
- source: "supercall\x0a\x09^ supercall ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "supercall:",
- protocol: "interpreting",
- fn: function (aBoolean){
- var self=this;
- self["@supercall"]=aBoolean;
- return self;
- },
- args: ["aBoolean"],
- source: "supercall: aBoolean\x0a\x09supercall := aBoolean",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "variableNotFound",
- protocol: "error handling",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._error_("Variable missing");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"variableNotFound",{},$globals.AIContext)});
- },
- args: [],
- source: "variableNotFound\x0a\x09\x22Error thrown whenever a variable lookup fails\x22\x0a\x09\x0a\x09self error: 'Variable missing'",
- referencedClasses: [],
- messageSends: ["error:"]
- }),
- $globals.AIContext);
- $core.addMethod(
- $core.method({
- selector: "fromMethodContext:",
- protocol: "instance creation",
- fn: function (aMethodContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._initializeFromMethodContext_(aMethodContext);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"fromMethodContext:",{aMethodContext:aMethodContext},$globals.AIContext.klass)});
- },
- args: ["aMethodContext"],
- source: "fromMethodContext: aMethodContext\x0a\x09^ self new\x0a\x09\x09initializeFromMethodContext: aMethodContext;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["initializeFromMethodContext:", "new", "yourself"]
- }),
- $globals.AIContext.klass);
- $core.addClass("AISemanticAnalyzer", $globals.SemanticAnalyzer, ["context"], "Compiler-Interpreter");
- $globals.AISemanticAnalyzer.comment="I perform the same semantic analysis than `SemanticAnalyzer`, with the difference that provided an `AIContext` context, variables are bound with the context variables.";
- $core.addMethod(
- $core.method({
- selector: "context",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@context"];
- },
- args: [],
- source: "context\x0a\x09^ context",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AISemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "context:",
- protocol: "accessing",
- fn: function (anAIContext){
- var self=this;
- self["@context"]=anAIContext;
- return self;
- },
- args: ["anAIContext"],
- source: "context: anAIContext\x0a\x09context := anAIContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AISemanticAnalyzer);
- $core.addMethod(
- $core.method({
- selector: "visitVariableNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- $recv(self._context())._localAt_ifAbsent_($recv(aNode)._value(),(function(){
- return $core.withContext(function($ctx2) {
- $1=(
- $ctx2.supercall = true,
- ($globals.AISemanticAnalyzer.superclass||$boot.nilAsClass).fn.prototype._visitVariableNode_.apply($recv(self), [aNode]));
- $ctx2.supercall = false;
- throw $early=[$1];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $recv(aNode)._binding_($recv($globals.ASTContextVar)._new());
- return self;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode},$globals.AISemanticAnalyzer)});
- },
- args: ["aNode"],
- source: "visitVariableNode: aNode\x0a\x09self context \x0a\x09\x09localAt: aNode value \x0a\x09\x09ifAbsent: [ ^ super visitVariableNode: aNode ].\x0a\x0a\x09aNode binding: ASTContextVar new",
- referencedClasses: ["ASTContextVar"],
- messageSends: ["localAt:ifAbsent:", "context", "value", "visitVariableNode:", "binding:", "new"]
- }),
- $globals.AISemanticAnalyzer);
- $core.addClass("ASTContextVar", $globals.ScopeVar, ["context"], "Compiler-Interpreter");
- $globals.ASTContextVar.comment="I am a variable defined in a `context`.";
- $core.addMethod(
- $core.method({
- selector: "context",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@context"];
- },
- args: [],
- source: "context\x0a\x09^ context",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTContextVar);
- $core.addMethod(
- $core.method({
- selector: "context:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@context"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "context: anObject\x0a\x09context := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTContextVar);
- $core.addClass("ASTDebugger", $globals.Object, ["interpreter", "context", "result"], "Compiler-Interpreter");
- $globals.ASTDebugger.comment="I am a stepping debugger interface for Amber code.\x0aI internally use an instance of `ASTInterpreter` to actually step through node and interpret them.\x0a\x0aMy instances are created from an `AIContext` with `ASTDebugger class >> context:`.\x0aThey hold an `AIContext` instance internally, recursive copy of the `MethodContext`.\x0a\x0a## API\x0a\x0aUse the methods of the `'stepping'` protocol to do stepping.";
- $core.addMethod(
- $core.method({
- selector: "atEnd",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._context();
- $ctx1.sendIdx["context"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return true;
- } else {
- $1;
- }
- return $recv($recv(self._interpreter())._atEnd())._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._context())._isTopContext();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"atEnd",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "atEnd\x09\x0a\x09self context ifNil: [ ^ true ].\x0a\x09\x0a\x09^ self interpreter atEnd and: [ \x0a\x09\x09self context isTopContext ]",
- referencedClasses: [],
- messageSends: ["ifNil:", "context", "and:", "atEnd", "interpreter", "isTopContext"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "context",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@context"];
- },
- args: [],
- source: "context\x0a\x09^ context",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "context:",
- protocol: "accessing",
- fn: function (aContext){
- var self=this;
- self["@context"]=aContext;
- return self;
- },
- args: ["aContext"],
- source: "context: aContext\x0a\x09context := aContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "flushInnerContexts",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._context();
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- var cxt;
- cxt=$receiver;
- $recv(cxt)._innerContext_(nil);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"flushInnerContexts",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "flushInnerContexts\x0a\x09\x22When stepping, the inner contexts are not relevent anymore,\x0a\x09and can be flushed\x22\x0a\x09\x0a\x09self context ifNotNil: [ :cxt | \x0a\x09\x09cxt innerContext: nil ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "context", "innerContext:"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "interpreter",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._context();
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- var ctx;
- ctx=$receiver;
- return $recv(ctx)._interpreter();
- }
- }, function($ctx1) {$ctx1.fill(self,"interpreter",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "interpreter\x0a\x09^ self context ifNotNil: [ :ctx | \x0a\x09\x09ctx interpreter ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "context", "interpreter"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "method",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._context())._method();
- }, function($ctx1) {$ctx1.fill(self,"method",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "method\x0a\x09^ self context method",
- referencedClasses: [],
- messageSends: ["method", "context"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "node",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self._interpreter();
- $ctx1.sendIdx["interpreter"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return $1;
- } else {
- return $recv(self._interpreter())._node();
- }
- }, function($ctx1) {$ctx1.fill(self,"node",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "node\x0a\x09^ self interpreter ifNotNil: [\x0a\x09\x09self interpreter node ]",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "interpreter", "node"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "onStep",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$6,$5,$receiver;
- $1=self._interpreter();
- $ctx1.sendIdx["interpreter"]=1;
- self["@result"]=$recv($1)._result();
- $3=self._interpreter();
- $ctx1.sendIdx["interpreter"]=2;
- $2=$recv($3)._atEnd();
- $ctx1.sendIdx["atEnd"]=1;
- if($core.assert($2)){
- $4=$recv(self._context())._outerContext();
- if(($receiver = $4) == null || $receiver.isNil){
- $4;
- } else {
- var outerContext;
- outerContext=$receiver;
- self._context_(outerContext);
- }
- $6=self._interpreter();
- $ctx1.sendIdx["interpreter"]=3;
- $5=$recv($6)._atEnd();
- if(!$core.assert($5)){
- $recv(self._interpreter())._skip();
- }
- }
- self._flushInnerContexts();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"onStep",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "onStep\x0a\x09\x22After each step, check if the interpreter is at the end,\x0a\x09and if it is move to its outer context if any, skipping its \x0a\x09current node (which was just evaluated by the current \x0a\x09interpreter).\x0a\x09\x0a\x09After each step we also flush inner contexts.\x22\x0a\x09\x0a\x09result := self interpreter result.\x0a\x09\x0a\x09self interpreter atEnd ifTrue: [\x0a\x09\x09self context outerContext ifNotNil: [ :outerContext | \x0a\x09\x09\x09self context: outerContext ].\x0a\x09\x09self interpreter atEnd ifFalse: [ self interpreter skip ] ].\x0a\x09\x09\x0a\x09self flushInnerContexts",
- referencedClasses: [],
- messageSends: ["result", "interpreter", "ifTrue:", "atEnd", "ifNotNil:", "outerContext", "context", "context:", "ifFalse:", "skip", "flushInnerContexts"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "proceed",
- protocol: "stepping",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._atEnd();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- return self._stepOver();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"proceed",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "proceed\x0a\x09[ self atEnd ] whileFalse: [ self stepOver ]",
- referencedClasses: [],
- messageSends: ["whileFalse:", "atEnd", "stepOver"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "restart",
- protocol: "stepping",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._interpreter())._restart();
- self._flushInnerContexts();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"restart",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "restart\x0a\x09self interpreter restart.\x0a\x09self flushInnerContexts",
- referencedClasses: [],
- messageSends: ["restart", "interpreter", "flushInnerContexts"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "result",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@result"];
- },
- args: [],
- source: "result\x0a\x09^ result",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "stepInto",
- protocol: "stepping",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldBeImplemented();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"stepInto",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "stepInto\x0a\x09self shouldBeImplemented",
- referencedClasses: [],
- messageSends: ["shouldBeImplemented"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "stepOver",
- protocol: "stepping",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv(self._context())._isTopContext();
- if($core.assert($1)){
- $recv(self._interpreter())._stepOver();
- } else {
- $2=self._interpreter();
- $ctx1.sendIdx["interpreter"]=1;
- $recv($2)._skip();
- }
- self._onStep();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"stepOver",{},$globals.ASTDebugger)});
- },
- args: [],
- source: "stepOver\x0a\x09self context isTopContext \x0a\x09\x09ifFalse: [ self interpreter skip ]\x0a\x09\x09ifTrue: [ self interpreter stepOver ].\x0a\x09self onStep",
- referencedClasses: [],
- messageSends: ["ifFalse:ifTrue:", "isTopContext", "context", "skip", "interpreter", "stepOver", "onStep"]
- }),
- $globals.ASTDebugger);
- $core.addMethod(
- $core.method({
- selector: "context:",
- protocol: "instance creation",
- fn: function (aContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._context_(aContext);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"context:",{aContext:aContext},$globals.ASTDebugger.klass)});
- },
- args: ["aContext"],
- source: "context: aContext\x0a\x09^ self new\x0a\x09\x09context: aContext;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["context:", "new", "yourself"]
- }),
- $globals.ASTDebugger.klass);
- $core.addClass("ASTEnterNode", $globals.NodeVisitor, ["interpreter"], "Compiler-Interpreter");
- $core.addMethod(
- $core.method({
- selector: "interpreter",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@interpreter"];
- },
- args: [],
- source: "interpreter\x0a\x09^ interpreter",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTEnterNode);
- $core.addMethod(
- $core.method({
- selector: "interpreter:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@interpreter"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "interpreter: anObject\x0a\x09interpreter := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTEnterNode);
- $core.addMethod(
- $core.method({
- selector: "visitBlockNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return aNode;
- },
- args: ["aNode"],
- source: "visitBlockNode: aNode\x0a\x09\x22Answer the node as we want to avoid eager evaluation\x22\x0a\x09\x0a\x09^ aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTEnterNode);
- $core.addMethod(
- $core.method({
- selector: "visitDagNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $early={};
- try {
- $recv($recv(aNode)._dagChildren())._ifEmpty_ifNotEmpty_((function(){
- throw $early=[aNode];
- }),(function(nodes){
- return $core.withContext(function($ctx2) {
- throw $early=[self._visit_($recv(nodes)._first())];
- }, function($ctx2) {$ctx2.fillBlock({nodes:nodes},$ctx1,2)});
- }));
- return self;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"visitDagNode:",{aNode:aNode},$globals.ASTEnterNode)});
- },
- args: ["aNode"],
- source: "visitDagNode: aNode\x0a\x09aNode dagChildren\x0a\x09\x09ifEmpty: [ ^ aNode ]\x0a\x09\x09ifNotEmpty: [ :nodes | ^ self visit: nodes first ]",
- referencedClasses: [],
- messageSends: ["ifEmpty:ifNotEmpty:", "dagChildren", "visit:", "first"]
- }),
- $globals.ASTEnterNode);
- $core.addMethod(
- $core.method({
- selector: "visitSequenceNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv($recv(aNode)._temps())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(self._interpreter())._context())._defineLocal_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $1=(
- $ctx1.supercall = true,
- ($globals.ASTEnterNode.superclass||$boot.nilAsClass).fn.prototype._visitSequenceNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"visitSequenceNode:",{aNode:aNode},$globals.ASTEnterNode)});
- },
- args: ["aNode"],
- source: "visitSequenceNode: aNode\x0a\x09aNode temps do: [ :each |\x0a\x09\x09self interpreter context defineLocal: each ].\x0a\x09^ super visitSequenceNode: aNode",
- referencedClasses: [],
- messageSends: ["do:", "temps", "defineLocal:", "context", "interpreter", "visitSequenceNode:"]
- }),
- $globals.ASTEnterNode);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (anInterpreter){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._interpreter_(anInterpreter);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"on:",{anInterpreter:anInterpreter},$globals.ASTEnterNode.klass)});
- },
- args: ["anInterpreter"],
- source: "on: anInterpreter\x0a\x09^ self new\x0a\x09\x09interpreter: anInterpreter;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["interpreter:", "new", "yourself"]
- }),
- $globals.ASTEnterNode.klass);
- $core.addClass("ASTInterpreter", $globals.NodeVisitor, ["node", "context", "stack", "returnValue", "returned", "forceAtEnd"], "Compiler-Interpreter");
- $globals.ASTInterpreter.comment="I visit an AST, interpreting (evaluating) nodes one after the other, using a small stack machine.\x0a\x0a## API\x0a\x0aWhile my instances should be used from within an `ASTDebugger`, which provides a more high level interface,\x0ayou can use methods from the `interpreting` protocol:\x0a\x0a- `#step` evaluates the current `node` only\x0a- `#stepOver` evaluates the AST from the current `node` up to the next stepping node (most likely the next send node)\x0a- `#proceed` evaluates eagerly the AST\x0a- `#restart` select the first node of the AST\x0a- `#skip` skips the current node, moving to the next one if any";
- $core.addMethod(
- $core.method({
- selector: "assign:to:",
- protocol: "private",
- fn: function (aNode,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4;
- $1=$recv($recv(aNode)._binding())._isInstanceVar();
- if($core.assert($1)){
- $3=self._context();
- $ctx1.sendIdx["context"]=1;
- $2=$recv($3)._receiver();
- $4=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=1;
- $recv($2)._instVarAt_put_($4,anObject);
- } else {
- $recv(self._context())._localAt_put_($recv(aNode)._value(),anObject);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"assign:to:",{aNode:aNode,anObject:anObject},$globals.ASTInterpreter)});
- },
- args: ["aNode", "anObject"],
- source: "assign: aNode to: anObject\x0a\x09aNode binding isInstanceVar\x0a\x09\x09ifTrue: [ self context receiver instVarAt: aNode value put: anObject ]\x0a\x09\x09ifFalse: [ self context localAt: aNode value put: anObject ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "isInstanceVar", "binding", "instVarAt:put:", "receiver", "context", "value", "localAt:put:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "atEnd",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self["@forceAtEnd"];
- if($core.assert($1)){
- return true;
- }
- return $recv(self._hasReturned())._or_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._node())._isNil();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"atEnd",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "atEnd\x0a\x09forceAtEnd ifTrue: [ ^ true ].\x0a\x09\x0a\x09^ self hasReturned or: [ self node isNil ]",
- referencedClasses: [],
- messageSends: ["ifTrue:", "or:", "hasReturned", "isNil", "node"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "context",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@context"];
- },
- args: [],
- source: "context\x0a\x09^ context",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "context:",
- protocol: "accessing",
- fn: function (aContext){
- var self=this;
- self["@context"]=aContext;
- return self;
- },
- args: ["aContext"],
- source: "context: aContext\x0a\x09context := aContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "enterNode",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._node_($recv($recv($globals.ASTEnterNode)._on_(self))._visit_(self._node()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"enterNode",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "enterNode\x0a\x09self node: ((ASTEnterNode on: self) visit: self node)",
- referencedClasses: ["ASTEnterNode"],
- messageSends: ["node:", "visit:", "on:", "node"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "eval:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- var source,function_;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- source=$recv($globals.String)._streamContents_((function(str){
- return $core.withContext(function($ctx2) {
- $recv(str)._nextPutAll_("0,(function(");
- $ctx2.sendIdx["nextPutAll:"]=1;
- $3=self._context();
- $ctx2.sendIdx["context"]=1;
- $2=$recv($3)._locals();
- $ctx2.sendIdx["locals"]=1;
- $1=$recv($2)._keys();
- $recv($1)._do_separatedBy_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(str)._nextPutAll_(each);
- $ctx3.sendIdx["nextPutAll:"]=2;
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)});
- }),(function(){
- return $core.withContext(function($ctx3) {
- return $recv(str)._nextPutAll_(",");
- $ctx3.sendIdx["nextPutAll:"]=3;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- $recv(str)._nextPutAll_("){ return (function() {");
- $ctx2.sendIdx["nextPutAll:"]=4;
- $recv(str)._nextPutAll_(aString);
- $ctx2.sendIdx["nextPutAll:"]=5;
- return $recv(str)._nextPutAll_("})()})");
- }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1,1)});
- }));
- function_=$recv($recv($globals.Compiler)._new())._eval_(source);
- return $recv(function_)._valueWithPossibleArguments_($recv($recv(self._context())._locals())._values());
- }, function($ctx1) {$ctx1.fill(self,"eval:",{aString:aString,source:source,function_:function_},$globals.ASTInterpreter)});
- },
- args: ["aString"],
- source: "eval: aString\x0a\x09\x22Evaluate aString as JS source inside an JS function.\x0a\x09aString is not sandboxed.\x22\x0a\x09\x0a\x09| source function |\x0a\x09\x0a\x09source := String streamContents: [ :str |\x0a\x09\x09str nextPutAll: '0,(function('.\x0a\x09\x09self context locals keys\x0a\x09\x09\x09do: [ :each | str nextPutAll: each ]\x0a\x09\x09\x09separatedBy: [ str nextPutAll: ',' ].\x0a\x09\x09str\x0a\x09\x09\x09nextPutAll: '){ return (function() {';\x0a\x09\x09\x09nextPutAll: aString;\x0a\x09\x09\x09nextPutAll: '})()})' ].\x0a\x09\x09\x09\x0a\x09function := Compiler new eval: source.\x0a\x09\x0a\x09^ function valueWithPossibleArguments: self context locals values",
- referencedClasses: ["String", "Compiler"],
- messageSends: ["streamContents:", "nextPutAll:", "do:separatedBy:", "keys", "locals", "context", "eval:", "new", "valueWithPossibleArguments:", "values"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "hasReturned",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@returned"];
- if(($receiver = $1) == null || $receiver.isNil){
- return false;
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"hasReturned",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "hasReturned\x0a\x09^ returned ifNil: [ false ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.ASTInterpreter.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@forceAtEnd"]=false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x0a\x09forceAtEnd := false",
- referencedClasses: [],
- messageSends: ["initialize"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "interpret",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._visit_(self._node());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"interpret",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "interpret\x0a\x09\x22Interpret the next node to be evaluated\x22\x0a\x09\x0a\x09self visit: self node",
- referencedClasses: [],
- messageSends: ["visit:", "node"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "messageFromSendNode:arguments:",
- protocol: "private",
- fn: function (aSendNode,aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Message)._new();
- $recv($1)._selector_($recv(aSendNode)._selector());
- $recv($1)._arguments_(aCollection);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"messageFromSendNode:arguments:",{aSendNode:aSendNode,aCollection:aCollection},$globals.ASTInterpreter)});
- },
- args: ["aSendNode", "aCollection"],
- source: "messageFromSendNode: aSendNode arguments: aCollection\x0a\x09^ Message new\x0a\x09\x09selector: aSendNode selector;\x0a\x09\x09arguments: aCollection;\x0a\x09\x09yourself",
- referencedClasses: ["Message"],
- messageSends: ["selector:", "new", "selector", "arguments:", "yourself"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "messageNotUnderstood:receiver:",
- protocol: "private",
- fn: function (aMessage,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.MessageNotUnderstood)._new();
- $recv($1)._message_(aMessage);
- $recv($1)._receiver_(anObject);
- $recv($1)._signal();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"messageNotUnderstood:receiver:",{aMessage:aMessage,anObject:anObject},$globals.ASTInterpreter)});
- },
- args: ["aMessage", "anObject"],
- source: "messageNotUnderstood: aMessage receiver: anObject\x0a\x09MessageNotUnderstood new\x0a\x09\x09message: aMessage;\x0a\x09\x09receiver: anObject;\x0a\x09\x09signal",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["message:", "new", "receiver:", "signal"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "next",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- var nd,nextNode;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- nd=self._node();
- $1=$recv(nd)._parent();
- if(($receiver = $1) == null || $receiver.isNil){
- nextNode=$1;
- } else {
- var parent;
- parent=$receiver;
- $2=$recv(parent)._nextSiblingNode_(nd);
- if(($receiver = $2) == null || $receiver.isNil){
- nextNode=parent;
- } else {
- var sibling;
- sibling=$receiver;
- nextNode=$recv($recv($globals.ASTEnterNode)._on_(self))._visit_(sibling);
- }
- }
- self._node_(nextNode);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"next",{nd:nd,nextNode:nextNode},$globals.ASTInterpreter)});
- },
- args: [],
- source: "next\x0a\x09| nd nextNode |\x0a\x09nd := self node.\x0a\x09nextNode := nd parent ifNotNil: [ :parent |\x0a\x09\x09(parent nextSiblingNode: nd)\x0a\x09\x09\x09ifNil: [ parent ]\x0a\x09\x09\x09ifNotNil: [ :sibling | (ASTEnterNode on: self) visit: sibling ] ].\x0a\x09self node: nextNode",
- referencedClasses: ["ASTEnterNode"],
- messageSends: ["node", "ifNotNil:", "parent", "ifNil:ifNotNil:", "nextSiblingNode:", "visit:", "on:", "node:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "node",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@node"];
- },
- args: [],
- source: "node\x0a\x09\x22Answer the next node, ie the node to be evaluated in the next step\x22\x0a\x09\x0a\x09^ node",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "node:",
- protocol: "accessing",
- fn: function (aNode){
- var self=this;
- self["@node"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "node: aNode\x0a\x09node := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "peek",
- protocol: "stack",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- $1=self._stack();
- $ctx1.sendIdx["stack"]=1;
- $recv($1)._ifEmpty_((function(){
- throw $early=[nil];
- }));
- return $recv(self._stack())._last();
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"peek",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "peek\x0a\x09\x22Peek the top object of the context stack\x22\x0a\x09\x0a\x09self stack ifEmpty: [ ^ nil ].\x0a\x09\x0a\x09^ self stack last",
- referencedClasses: [],
- messageSends: ["ifEmpty:", "stack", "last"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "pop",
- protocol: "stack",
- fn: function (){
- var self=this;
- var peekedValue;
- return $core.withContext(function($ctx1) {
- peekedValue=self._peek();
- $recv(self._stack())._removeLast();
- return peekedValue;
- }, function($ctx1) {$ctx1.fill(self,"pop",{peekedValue:peekedValue},$globals.ASTInterpreter)});
- },
- args: [],
- source: "pop\x0a\x09\x22Pop an object from the context stack\x22\x0a\x09\x0a\x09| peekedValue |\x0a\x09\x0a\x09peekedValue := self peek.\x0a\x09self stack removeLast.\x0a\x09^ peekedValue",
- referencedClasses: [],
- messageSends: ["peek", "removeLast", "stack"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "proceed",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._atEnd();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- return self._step();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"proceed",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "proceed\x0a\x09\x22Eagerly evaluate the ast\x22\x0a\x09\x0a\x09[ self atEnd ] \x0a\x09\x09whileFalse: [ self step ]",
- referencedClasses: [],
- messageSends: ["whileFalse:", "atEnd", "step"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "push:",
- protocol: "stack",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._stack())._add_(anObject);
- }, function($ctx1) {$ctx1.fill(self,"push:",{anObject:anObject},$globals.ASTInterpreter)});
- },
- args: ["anObject"],
- source: "push: anObject\x0a\x09\x22Push an object to the context stack\x22\x0a\x09\x0a\x09^ self stack add: anObject",
- referencedClasses: [],
- messageSends: ["add:", "stack"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "restart",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._node_($recv(self._context())._ast());
- self._enterNode();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"restart",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "restart\x0a\x09self node: self context ast; enterNode",
- referencedClasses: [],
- messageSends: ["node:", "ast", "context", "enterNode"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "result",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._hasReturned();
- if($core.assert($1)){
- return self._returnValue();
- } else {
- return $recv(self._context())._receiver();
- }
- }, function($ctx1) {$ctx1.fill(self,"result",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "result\x0a\x09^ self hasReturned \x0a\x09\x09ifTrue: [ self returnValue ] \x0a\x09\x09ifFalse: [ self context receiver ]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "hasReturned", "returnValue", "receiver", "context"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "returnValue",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@returnValue"];
- },
- args: [],
- source: "returnValue\x0a\x09^ returnValue",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "returnValue:",
- protocol: "accessing",
- fn: function (anObject){
- var self=this;
- self["@returnValue"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "returnValue: anObject\x0a\x09returnValue := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "sendMessage:to:superSend:",
- protocol: "private",
- fn: function (aMessage,anObject,aBoolean){
- var self=this;
- var method;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$receiver;
- var $early={};
- try {
- if(!$core.assert(aBoolean)){
- return $recv(aMessage)._sendTo_(anObject);
- }
- $2=$recv(anObject)._class();
- $ctx1.sendIdx["class"]=1;
- $1=$recv($2)._superclass();
- $ctx1.sendIdx["superclass"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- $3=self._messageNotUnderstood_receiver_(aMessage,anObject);
- $ctx1.sendIdx["messageNotUnderstood:receiver:"]=1;
- return $3;
- } else {
- $1;
- }
- method=$recv($recv($recv($recv(anObject)._class())._superclass())._methodDictionary())._at_ifAbsent_($recv(aMessage)._selector(),(function(){
- return $core.withContext(function($ctx2) {
- throw $early=[self._messageNotUnderstood_receiver_(aMessage,anObject)];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return $recv(method)._sendTo_arguments_(anObject,$recv(aMessage)._arguments());
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"sendMessage:to:superSend:",{aMessage:aMessage,anObject:anObject,aBoolean:aBoolean,method:method},$globals.ASTInterpreter)});
- },
- args: ["aMessage", "anObject", "aBoolean"],
- source: "sendMessage: aMessage to: anObject superSend: aBoolean\x0a\x09| method |\x0a\x09\x0a\x09aBoolean ifFalse: [ ^ aMessage sendTo: anObject ].\x0a\x09anObject class superclass ifNil: [ ^ self messageNotUnderstood: aMessage receiver: anObject ].\x0a\x09\x0a\x09method := anObject class superclass methodDictionary\x0a\x09\x09at: aMessage selector\x0a\x09\x09ifAbsent: [ ^ self messageNotUnderstood: aMessage receiver: anObject ].\x0a\x09\x09\x0a\x09^ method sendTo: anObject arguments: aMessage arguments",
- referencedClasses: [],
- messageSends: ["ifFalse:", "sendTo:", "ifNil:", "superclass", "class", "messageNotUnderstood:receiver:", "at:ifAbsent:", "methodDictionary", "selector", "sendTo:arguments:", "arguments"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "setNonLocalReturnFromContext:",
- protocol: "interpreting",
- fn: function (aContext){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv(aContext)._interpreter();
- $ctx1.sendIdx["interpreter"]=1;
- $1=$recv($2)._hasReturned();
- if($core.assert($1)){
- self["@returned"]=true;
- self["@returned"];
- self._returnValue_($recv($recv(aContext)._interpreter())._returnValue());
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setNonLocalReturnFromContext:",{aContext:aContext},$globals.ASTInterpreter)});
- },
- args: ["aContext"],
- source: "setNonLocalReturnFromContext: aContext\x0a\x09aContext interpreter hasReturned ifTrue: [\x0a\x09\x09returned := true.\x0a\x09\x09self returnValue: aContext interpreter returnValue ]",
- referencedClasses: [],
- messageSends: ["ifTrue:", "hasReturned", "interpreter", "returnValue:", "returnValue"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "skip",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._next();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"skip",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "skip\x0a\x09self next",
- referencedClasses: [],
- messageSends: ["next"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "stack",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@stack"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@stack"]=$recv($globals.OrderedCollection)._new();
- return self["@stack"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"stack",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "stack\x0a\x09^ stack ifNil: [ stack := OrderedCollection new ]",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["ifNil:", "new"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "step",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._interpret();
- self._next();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"step",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "step\x0a\x09self \x0a\x09\x09interpret; \x0a\x09\x09next",
- referencedClasses: [],
- messageSends: ["interpret", "next"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "stepOver",
- protocol: "interpreting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- self._step();
- $ctx1.sendIdx["step"]=1;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- $2=self._node();
- $ctx2.sendIdx["node"]=1;
- $1=$recv($2)._isNil();
- return $recv($1)._or_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(self._node())._isSteppingNode();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- return self._step();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"stepOver",{},$globals.ASTInterpreter)});
- },
- args: [],
- source: "stepOver\x0a\x09self step.\x0a\x09\x0a\x09[ self node isNil or: [ self node isSteppingNode ] ] whileFalse: [ \x0a\x09\x09self step ]",
- referencedClasses: [],
- messageSends: ["step", "whileFalse:", "or:", "isNil", "node", "isSteppingNode"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visit:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._hasReturned();
- if(!$core.assert($1)){
- (
- $ctx1.supercall = true,
- ($globals.ASTInterpreter.superclass||$boot.nilAsClass).fn.prototype._visit_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visit:",{aNode:aNode},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visit: aNode\x0a\x09self hasReturned ifFalse: [ super visit: aNode ]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "hasReturned", "visit:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitAssignmentNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var poppedValue;
- return $core.withContext(function($ctx1) {
- poppedValue=self._pop();
- $ctx1.sendIdx["pop"]=1;
- self._pop();
- self._push_(poppedValue);
- self._assign_to_($recv(aNode)._left(),poppedValue);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitAssignmentNode:",{aNode:aNode,poppedValue:poppedValue},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitAssignmentNode: aNode\x0a\x09| poppedValue |\x0a\x09\x0a\x09poppedValue := self pop.\x0a\x09\x0a\x09\x22Pop the left side of the assignment.\x0a\x09It already has been visited, and we don't need its value.\x22\x0a\x09self pop.\x0a\x09\x0a\x09self push: poppedValue.\x0a\x09self assign: aNode left to: poppedValue",
- referencedClasses: [],
- messageSends: ["pop", "push:", "assign:to:", "left"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitBlockNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var block;
- return $core.withContext(function($ctx1) {
- block=$recv($globals.AIBlockClosure)._forContext_node_(self._context(),aNode);
- self._push_(block);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitBlockNode:",{aNode:aNode,block:block},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitBlockNode: aNode\x0a\x09\x22Do not evaluate the block node.\x0a\x09Instead, put all instructions into a block that we push to the stack for later evaluation\x22\x0a\x09\x0a\x09| block |\x0a\x09\x0a\x09block := AIBlockClosure forContext: self context node: aNode.\x0a\x09\x0a\x09self push: block",
- referencedClasses: ["AIBlockClosure"],
- messageSends: ["forContext:node:", "context", "push:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitBlockSequenceNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.ASTInterpreter.superclass||$boot.nilAsClass).fn.prototype._visitBlockSequenceNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- self["@forceAtEnd"]=true;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitBlockSequenceNode:",{aNode:aNode},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitBlockSequenceNode: aNode\x0a\x09\x22If the receiver is actually visiting a BlockSequenceNode,\x0a\x09it means the the context is a block context. Evaluation should \x0a\x09stop right after evaluating the block sequence and the outer\x0a\x09context's interpreter should take over. \x0a\x09Therefore we force #atEnd.\x22\x0a\x09\x0a\x09super visitBlockSequenceNode: aNode.\x0a\x09forceAtEnd := true",
- referencedClasses: [],
- messageSends: ["visitBlockSequenceNode:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitDagNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return self;
- },
- args: ["aNode"],
- source: "visitDagNode: aNode\x0a\x09\x22Do nothing by default. Especially, do not visit children recursively.\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitDynamicArrayNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- array=[];
- $recv($recv(aNode)._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(array)._addFirst_(self._pop());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._push_(array);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitDynamicArrayNode:",{aNode:aNode,array:array},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitDynamicArrayNode: aNode\x0a\x09| array |\x0a\x09\x0a\x09array := #().\x0a\x09aNode dagChildren do: [ :each |\x0a\x09\x09array addFirst: self pop ].\x0a\x09\x0a\x09self push: array",
- referencedClasses: [],
- messageSends: ["do:", "dagChildren", "addFirst:", "pop", "push:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitDynamicDictionaryNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var keyValueList;
- return $core.withContext(function($ctx1) {
- keyValueList=$recv($globals.OrderedCollection)._new();
- $recv($recv(aNode)._dagChildren())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(keyValueList)._add_(self._pop());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._push_($recv($globals.HashedCollection)._newFromPairs_($recv(keyValueList)._reversed()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitDynamicDictionaryNode:",{aNode:aNode,keyValueList:keyValueList},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitDynamicDictionaryNode: aNode\x0a\x09| keyValueList |\x0a\x09\x0a\x09keyValueList := OrderedCollection new.\x0a\x09\x0a\x09aNode dagChildren do: [ :each | \x0a\x09\x09keyValueList add: self pop ].\x0a\x09\x0a\x09self push: (HashedCollection newFromPairs: keyValueList reversed)",
- referencedClasses: ["OrderedCollection", "HashedCollection"],
- messageSends: ["new", "do:", "dagChildren", "add:", "pop", "push:", "newFromPairs:", "reversed"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitJSStatementNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@returned"]=true;
- self._returnValue_(self._eval_($recv(aNode)._source()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitJSStatementNode:",{aNode:aNode},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitJSStatementNode: aNode\x0a\x09returned := true.\x0a\x09self returnValue: (self eval: aNode source)",
- referencedClasses: [],
- messageSends: ["returnValue:", "eval:", "source"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitReturnNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@returned"]=true;
- self._returnValue_(self._pop());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitReturnNode:",{aNode:aNode},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitReturnNode: aNode\x0a\x09returned := true.\x0a\x09self returnValue: self pop",
- referencedClasses: [],
- messageSends: ["returnValue:", "pop"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitSendNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- var receiver,args,message,result;
- return $core.withContext(function($ctx1) {
- var $1;
- args=$recv($recv(aNode)._arguments())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return self._pop();
- $ctx2.sendIdx["pop"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- receiver=self._peek();
- message=self._messageFromSendNode_arguments_(aNode,$recv(args)._reversed());
- result=self._sendMessage_to_superSend_(message,receiver,$recv(aNode)._superSend());
- $1=$recv($recv(aNode)._isCascadeSendNode())._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv(aNode)._isLastChild())._not();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- if(!$core.assert($1)){
- self._pop();
- self._push_(result);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode,receiver:receiver,args:args,message:message,result:result},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitSendNode: aNode\x0a\x09| receiver args message result |\x0a\x09\x0a\x09args := aNode arguments collect: [ :each | self pop ].\x0a\x09receiver := self peek.\x0a\x09\x0a\x09message := self\x0a\x09\x09messageFromSendNode: aNode\x0a\x09\x09arguments: args reversed.\x0a\x09\x0a\x09result := self sendMessage: message to: receiver superSend: aNode superSend.\x0a\x09\x0a\x09\x22For cascade sends, push the reciever if the send is not the last one\x22\x0a\x09(aNode isCascadeSendNode and: [ aNode isLastChild not ])\x0a\x09\x09ifFalse: [ self pop; push: result ]",
- referencedClasses: [],
- messageSends: ["collect:", "arguments", "pop", "peek", "messageFromSendNode:arguments:", "reversed", "sendMessage:to:superSend:", "superSend", "ifFalse:", "and:", "isCascadeSendNode", "not", "isLastChild", "push:"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitValueNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._push_($recv(aNode)._value());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitValueNode:",{aNode:aNode},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitValueNode: aNode\x0a\x09self push: aNode value",
- referencedClasses: [],
- messageSends: ["push:", "value"]
- }),
- $globals.ASTInterpreter);
- $core.addMethod(
- $core.method({
- selector: "visitVariableNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$5,$6,$4,$3,$8,$10,$9,$11,$12,$13,$15,$14,$16,$17,$7;
- $2=$recv(aNode)._binding();
- $ctx1.sendIdx["binding"]=1;
- $1=$recv($2)._isUnknownVar();
- if($core.assert($1)){
- $5=$recv($globals.Platform)._globals();
- $ctx1.sendIdx["globals"]=1;
- $6=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=1;
- $4=$recv($5)._at_ifAbsent_($6,(function(){
- return $core.withContext(function($ctx2) {
- return self._error_("Unknown variable");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $ctx1.sendIdx["at:ifAbsent:"]=1;
- $3=self._push_($4);
- $ctx1.sendIdx["push:"]=1;
- return $3;
- }
- $8=$recv($recv(aNode)._binding())._isInstanceVar();
- if($core.assert($8)){
- $10=self._context();
- $ctx1.sendIdx["context"]=1;
- $9=$recv($10)._receiver();
- $11=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=2;
- $7=$recv($9)._instVarAt_($11);
- } else {
- $12=self._context();
- $13=$recv(aNode)._value();
- $ctx1.sendIdx["value"]=3;
- $7=$recv($12)._localAt_ifAbsent_($13,(function(){
- return $core.withContext(function($ctx2) {
- $15=$recv(aNode)._value();
- $ctx2.sendIdx["value"]=4;
- $14=$recv($15)._isCapitalized();
- if($core.assert($14)){
- $16=$recv($globals.Smalltalk)._globals();
- $ctx2.sendIdx["globals"]=2;
- $17=$recv(aNode)._value();
- $ctx2.sendIdx["value"]=5;
- return $recv($16)._at_ifAbsent_($17,(function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv($globals.Platform)._globals())._at_($recv(aNode)._value());
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,7)});
- }));
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,5)});
- }));
- }
- self._push_($7);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode},$globals.ASTInterpreter)});
- },
- args: ["aNode"],
- source: "visitVariableNode: aNode\x0a\x09aNode binding isUnknownVar ifTrue: [\x0a\x09\x09^ self push: (Platform globals at: aNode value ifAbsent: [ self error: 'Unknown variable' ]) ].\x0a\x09\x09\x0a\x09self push: (aNode binding isInstanceVar\x0a\x09\x09ifTrue: [ self context receiver instVarAt: aNode value ]\x0a\x09\x09ifFalse: [ self context \x0a\x09\x09\x09localAt: aNode value\x0a\x09\x09\x09ifAbsent: [\x0a\x09\x09\x09\x09aNode value isCapitalized\x0a\x09\x09\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09\x09\x09Smalltalk globals \x0a\x09\x09\x09\x09\x09\x09\x09at: aNode value \x0a\x09\x09\x09\x09\x09\x09\x09ifAbsent: [ Platform globals at: aNode value ] ] ] ])",
- referencedClasses: ["Platform", "Smalltalk"],
- messageSends: ["ifTrue:", "isUnknownVar", "binding", "push:", "at:ifAbsent:", "globals", "value", "error:", "ifTrue:ifFalse:", "isInstanceVar", "instVarAt:", "receiver", "context", "localAt:ifAbsent:", "isCapitalized", "at:"]
- }),
- $globals.ASTInterpreter);
- $core.addClass("ASTInterpreterError", $globals.Error, [], "Compiler-Interpreter");
- $globals.ASTInterpreterError.comment="I get signaled when an AST interpreter is unable to interpret a node.";
- $core.addClass("ASTPCNodeVisitor", $globals.NodeVisitor, ["index", "trackedIndex", "selector", "currentNode"], "Compiler-Interpreter");
- $globals.ASTPCNodeVisitor.comment="I visit an AST until I get to the current node for the `context` and answer it.\x0a\x0a## API\x0a\x0aMy instances must be filled with a context object using `#context:`.\x0a\x0aAfter visiting the AST the current node is answered by `#currentNode`";
- $core.addMethod(
- $core.method({
- selector: "currentNode",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@currentNode"];
- },
- args: [],
- source: "currentNode\x0a\x09^ currentNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "increaseTrackedIndex",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@trackedIndex"]=$recv(self._trackedIndex()).__plus((1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"increaseTrackedIndex",{},$globals.ASTPCNodeVisitor)});
- },
- args: [],
- source: "increaseTrackedIndex\x0a\x09trackedIndex := self trackedIndex + 1",
- referencedClasses: [],
- messageSends: ["+", "trackedIndex"]
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "index",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@index"];
- },
- args: [],
- source: "index\x0a\x09^ index",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "index:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- self["@index"]=aNumber;
- return self;
- },
- args: ["aNumber"],
- source: "index: aNumber\x0a\x09index := aNumber",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@selector"];
- },
- args: [],
- source: "selector\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@selector"]=aString;
- return self;
- },
- args: ["aString"],
- source: "selector: aString\x0a\x09selector := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "trackedIndex",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@trackedIndex"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@trackedIndex"]=(0);
- return self["@trackedIndex"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"trackedIndex",{},$globals.ASTPCNodeVisitor)});
- },
- args: [],
- source: "trackedIndex\x0a\x09^ trackedIndex ifNil: [ trackedIndex := 0 ]",
- referencedClasses: [],
- messageSends: ["ifNil:"]
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitJSStatementNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- self["@currentNode"]=aNode;
- return self;
- },
- args: ["aNode"],
- source: "visitJSStatementNode: aNode\x0a\x09\x22If a JSStatementNode is encountered, it always is the current node.\x0a\x09Stop visiting the AST there\x22\x0a\x09\x0a\x09currentNode := aNode",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "visitSendNode:",
- protocol: "visiting",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3;
- (
- $ctx1.supercall = true,
- ($globals.ASTPCNodeVisitor.superclass||$boot.nilAsClass).fn.prototype._visitSendNode_.apply($recv(self), [aNode]));
- $ctx1.supercall = false;
- $2=self._selector();
- $ctx1.sendIdx["selector"]=1;
- $1=$recv($2).__eq($recv(aNode)._selector());
- $ctx1.sendIdx["="]=1;
- if($core.assert($1)){
- $3=$recv(self._trackedIndex()).__eq(self._index());
- if($core.assert($3)){
- self["@currentNode"]=aNode;
- self["@currentNode"];
- }
- self._increaseTrackedIndex();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode},$globals.ASTPCNodeVisitor)});
- },
- args: ["aNode"],
- source: "visitSendNode: aNode\x0a\x09super visitSendNode: aNode.\x0a\x09\x0a\x09self selector = aNode selector ifTrue: [\x0a\x09\x09self trackedIndex = self index ifTrue: [ currentNode := aNode ].\x0a\x09\x09self increaseTrackedIndex ]",
- referencedClasses: [],
- messageSends: ["visitSendNode:", "ifTrue:", "=", "selector", "trackedIndex", "index", "increaseTrackedIndex"]
- }),
- $globals.ASTPCNodeVisitor);
- $core.addMethod(
- $core.method({
- selector: "isLastChild",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($recv(self._parent())._dagChildren())._last()).__eq(self);
- }, function($ctx1) {$ctx1.fill(self,"isLastChild",{},$globals.ASTNode)});
- },
- args: [],
- source: "isLastChild\x0a\x09^ self parent dagChildren last = self",
- referencedClasses: [],
- messageSends: ["=", "last", "dagChildren", "parent"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isSteppingNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isSteppingNode\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "nextSiblingNode:",
- protocol: "*Compiler-Interpreter",
- fn: function (aNode){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- $1=self._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- return $recv($1)._at_ifAbsent_($recv($recv(self._dagChildren())._indexOf_(aNode)).__plus((1)),(function(){
- throw $early=[nil];
- }));
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"nextSiblingNode:",{aNode:aNode},$globals.ASTNode)});
- },
- args: ["aNode"],
- source: "nextSiblingNode: aNode\x0a\x09\x22Answer the next node after aNode or nil\x22\x0a\x09\x0a\x09^ self dagChildren \x0a\x09\x09at: (self dagChildren indexOf: aNode) + 1\x0a\x09\x09ifAbsent: [ ^ nil ]",
- referencedClasses: [],
- messageSends: ["at:ifAbsent:", "dagChildren", "+", "indexOf:"]
- }),
- $globals.ASTNode);
- $core.addMethod(
- $core.method({
- selector: "isSteppingNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSteppingNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AssignmentNode);
- $core.addMethod(
- $core.method({
- selector: "isSteppingNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSteppingNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "nextSiblingNode:",
- protocol: "*Compiler-Interpreter",
- fn: function (aNode){
- var self=this;
- return nil;
- },
- args: ["aNode"],
- source: "nextSiblingNode: aNode\x0a\x09\x22Answer nil as we want to avoid eager evaluation\x22\x0a\x09\x0a\x09\x22In fact, this should not have been called, ever. IMO. -- herby\x22\x0a\x09\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockNode);
- $core.addMethod(
- $core.method({
- selector: "isSteppingNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSteppingNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.DynamicArrayNode);
- $core.addMethod(
- $core.method({
- selector: "isSteppingNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSteppingNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.DynamicDictionaryNode);
- $core.addMethod(
- $core.method({
- selector: "isSteppingNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSteppingNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSStatementNode);
- $core.addMethod(
- $core.method({
- selector: "isCascadeSendNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._parent())._isCascadeNode();
- }, function($ctx1) {$ctx1.fill(self,"isCascadeSendNode",{},$globals.SendNode)});
- },
- args: [],
- source: "isCascadeSendNode\x0a\x09^ self parent isCascadeNode",
- referencedClasses: [],
- messageSends: ["isCascadeNode", "parent"]
- }),
- $globals.SendNode);
- $core.addMethod(
- $core.method({
- selector: "isSteppingNode",
- protocol: "*Compiler-Interpreter",
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isSteppingNode\x0a\x09^ true",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SendNode);
- });
- define('amber/lang',[
- './deploy',
- './compatibility', // pre-fetch, dep of ./boot
- './boot', // pre-fetch, dep of ./helpers
- './helpers', // pre-fetch, dep of ./deploy
- './parser',
- // --- packages for the Amber reflection begin here ---
- 'amber_core/Platform-ImportExport',
- 'amber_core/Compiler-Core',
- 'amber_core/Compiler-AST',
- 'amber_core/Compiler-Semantic',
- 'amber_core/Compiler-IR',
- 'amber_core/Compiler-Inlining',
- 'amber_core/Compiler-Interpreter'
- // --- packages for the Amber reflection end here ---
- ], function (amber) {
- return amber;
- });
- define('amber_core/Platform-DOM',["amber/boot", "amber_core/Kernel-Collections", "amber_core/Kernel-Infrastructure", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Platform-DOM");
- $core.packages["Platform-DOM"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Platform-DOM"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("PlatformDom", $globals.Object, [], "Platform-DOM");
- $core.addMethod(
- $core.method({
- selector: "isDomNode:",
- protocol: "testing",
- fn: function (anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return anObject.nodeType > 0 &&
- Object.prototype.toString.call(anObject) !== "[object Object]";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"isDomNode:",{anObject:anObject},$globals.PlatformDom.klass)});
- },
- args: ["anObject"],
- source: "isDomNode: anObject\x0a<inlineJS: '\x0a\x09return anObject.nodeType > 0 &&\x0a\x09\x09Object.prototype.toString.call(anObject) !== \x22[object Object]\x22\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PlatformDom.klass);
- $core.addMethod(
- $core.method({
- selector: "isFeasible",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- if (typeof document === "undefined") return false;
- try {
- var d = document.createElement("div"),
- f = document.createDocumentFragment(),
- t = document.createTextNode("Hello, Amber!");
- f.appendChild(t);
- d.insertBefore(f, null);
- return d.innerHTML === "Hello, Amber!";
- } catch (e) {
- return false;
- };
- return self;
- }, function($ctx1) {$ctx1.fill(self,"isFeasible",{},$globals.PlatformDom.klass)});
- },
- args: [],
- source: "isFeasible\x0a<inlineJS: '\x0a if (typeof document === \x22undefined\x22) return false;\x0a try {\x0a var d = document.createElement(\x22div\x22),\x0a\x09 f = document.createDocumentFragment(),\x0a\x09 t = document.createTextNode(\x22Hello, Amber!\x22);\x0a\x09f.appendChild(t);\x0a\x09d.insertBefore(f, null);\x0a\x09return d.innerHTML === \x22Hello, Amber!\x22;\x0a } catch (e) {\x0a return false;\x0a }\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PlatformDom.klass);
- $core.addMethod(
- $core.method({
- selector: "newCustomEvent:detail:",
- protocol: "creation",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return new CustomEvent(aString, {detail: anObject});
- return self;
- }, function($ctx1) {$ctx1.fill(self,"newCustomEvent:detail:",{aString:aString,anObject:anObject},$globals.PlatformDom.klass)});
- },
- args: ["aString", "anObject"],
- source: "newCustomEvent: aString detail: anObject\x0a<inlineJS: 'return new CustomEvent(aString, {detail: anObject})'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PlatformDom.klass);
- $core.addMethod(
- $core.method({
- selector: "toArray:",
- protocol: "converting",
- fn: function (aDomList){
- var self=this;
- return $core.withContext(function($ctx1) {
- return Array.prototype.slice.call(aDomList);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"toArray:",{aDomList:aDomList},$globals.PlatformDom.klass)});
- },
- args: ["aDomList"],
- source: "toArray: aDomList\x0a<inlineJS: 'return Array.prototype.slice.call(aDomList)'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.PlatformDom.klass);
- $core.addMethod(
- $core.method({
- selector: "asDomNode",
- protocol: "*Platform-DOM",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(document)._createTextNode_(self._asString());
- }, function($ctx1) {$ctx1.fill(self,"asDomNode",{},$globals.CharacterArray)});
- },
- args: [],
- source: "asDomNode\x0a\x09^ document createTextNode: self asString",
- referencedClasses: [],
- messageSends: ["createTextNode:", "asString"]
- }),
- $globals.CharacterArray);
- $core.addMethod(
- $core.method({
- selector: "asDomNode",
- protocol: "*Platform-DOM",
- fn: function (){
- var self=this;
- var fragment;
- return $core.withContext(function($ctx1) {
- fragment=$recv(document)._createDocumentFragment();
- self._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(fragment)._appendChild_($recv(each)._asDomNode());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return fragment;
- }, function($ctx1) {$ctx1.fill(self,"asDomNode",{fragment:fragment},$globals.Collection)});
- },
- args: [],
- source: "asDomNode\x0a\x09| fragment |\x0a\x09fragment := document createDocumentFragment.\x0a\x09self do: [ :each | fragment appendChild: each asDomNode ].\x0a\x09^ fragment",
- referencedClasses: [],
- messageSends: ["createDocumentFragment", "do:", "appendChild:", "asDomNode"]
- }),
- $globals.Collection);
- $core.addMethod(
- $core.method({
- selector: "asDomNode",
- protocol: "*Platform-DOM",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv($globals.PlatformDom)._isDomNode_(self["@jsObject"]);
- if($core.assert($1)){
- return self["@jsObject"];
- } else {
- $2=(
- $ctx1.supercall = true,
- ($globals.JSObjectProxy.superclass||$boot.nilAsClass).fn.prototype._asDomNode.apply($recv(self), []));
- $ctx1.supercall = false;
- return $2;
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"asDomNode",{},$globals.JSObjectProxy)});
- },
- args: [],
- source: "asDomNode\x0a\x09(PlatformDom isDomNode: jsObject)\x0a\x09\x09ifTrue: [ ^ jsObject ]\x0a\x09\x09ifFalse: [ ^ super asDomNode ]",
- referencedClasses: ["PlatformDom"],
- messageSends: ["ifTrue:ifFalse:", "isDomNode:", "asDomNode"]
- }),
- $globals.JSObjectProxy);
- $core.addMethod(
- $core.method({
- selector: "htmlTextContent",
- protocol: "*Platform-DOM",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var d=document.createElement("div");d.innerHTML=self;return d.textContent||d.innerText;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"htmlTextContent",{},$globals.String)});
- },
- args: [],
- source: "htmlTextContent\x0a<inlineJS: 'var d=document.createElement(\x22div\x22);d.innerHTML=self;return d.textContent||d.innerText;'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.String);
- });
- define('amber_core/SUnit',["amber/boot", "amber_core/Kernel-Classes", "amber_core/Kernel-Exceptions", "amber_core/Kernel-Infrastructure", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("SUnit");
- $core.packages["SUnit"].innerEval = function (expr) { return eval(expr); };
- $core.packages["SUnit"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("ResultAnnouncement", $globals.Object, ["result"], "SUnit");
- $globals.ResultAnnouncement.comment="I get signaled when a `TestCase` has been run.\x0a\x0aMy instances hold the result (instance of `TestResult`) of the test run.";
- $core.addMethod(
- $core.method({
- selector: "result",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@result"];
- },
- args: [],
- source: "result\x0a\x09^ result",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ResultAnnouncement);
- $core.addMethod(
- $core.method({
- selector: "result:",
- protocol: "accessing",
- fn: function (aTestResult){
- var self=this;
- self["@result"]=aTestResult;
- return self;
- },
- args: ["aTestResult"],
- source: "result: aTestResult\x0a\x09result := aTestResult",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ResultAnnouncement);
- $core.addClass("TestCase", $globals.Object, ["testSelector", "asyncTimeout", "context"], "SUnit");
- $globals.TestCase.comment="I am an implementation of the command pattern to run a test.\x0a\x0a## API\x0a\x0aMy instances are created with the class method `#selector:`,\x0apassing the symbol that names the method to be executed when the test case runs.\x0a\x0aWhen you discover a new fixture, subclass `TestCase` and create a `#test...` method for the first test.\x0aAs that method develops and more `#test...` methods are added, you will find yourself refactoring temps\x0ainto instance variables for the objects in the fixture and overriding `#setUp` to initialize these variables.\x0aAs required, override `#tearDown` to nil references, release objects and deallocate.";
- $core.addMethod(
- $core.method({
- selector: "assert:",
- protocol: "testing",
- fn: function (aBoolean){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_description_(aBoolean,"Assertion failed");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"assert:",{aBoolean:aBoolean},$globals.TestCase)});
- },
- args: ["aBoolean"],
- source: "assert: aBoolean\x0a\x09self assert: aBoolean description: 'Assertion failed'",
- referencedClasses: [],
- messageSends: ["assert:description:"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "assert:description:",
- protocol: "testing",
- fn: function (aBoolean,aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- if(!$core.assert(aBoolean)){
- self._signalFailure_(aString);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"assert:description:",{aBoolean:aBoolean,aString:aString},$globals.TestCase)});
- },
- args: ["aBoolean", "aString"],
- source: "assert: aBoolean description: aString\x0a\x09aBoolean ifFalse: [ self signalFailure: aString ]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "signalFailure:"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "assert:equals:",
- protocol: "testing",
- fn: function (actual,expected){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$5,$4,$3,$2;
- $1=$recv(actual).__eq(expected);
- $5=$recv(expected)._printString();
- $ctx1.sendIdx["printString"]=1;
- $4="Expected: ".__comma($5);
- $3=$recv($4).__comma(" but was: ");
- $ctx1.sendIdx[","]=2;
- $2=$recv($3).__comma($recv(actual)._printString());
- $ctx1.sendIdx[","]=1;
- return self._assert_description_($1,$2);
- }, function($ctx1) {$ctx1.fill(self,"assert:equals:",{actual:actual,expected:expected},$globals.TestCase)});
- },
- args: ["actual", "expected"],
- source: "assert: actual equals: expected\x0a\x09^ self assert: (actual = expected) description: 'Expected: ', expected printString, ' but was: ', actual printString",
- referencedClasses: [],
- messageSends: ["assert:description:", "=", ",", "printString"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "async:",
- protocol: "async",
- fn: function (aBlock){
- var self=this;
- var c;
- return $core.withContext(function($ctx1) {
- var $1;
- self._errorIfNotAsync_("#async");
- c=self["@context"];
- return (function(){
- return $core.withContext(function($ctx2) {
- $1=self._isAsync();
- if($core.assert($1)){
- return $recv(c)._execute_(aBlock);
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- });
- }, function($ctx1) {$ctx1.fill(self,"async:",{aBlock:aBlock,c:c},$globals.TestCase)});
- },
- args: ["aBlock"],
- source: "async: aBlock\x0a\x09| c |\x0a\x09self errorIfNotAsync: '#async'.\x0a\x09c := context.\x0a\x09^ [ self isAsync ifTrue: [ c execute: aBlock ] ]",
- referencedClasses: [],
- messageSends: ["errorIfNotAsync:", "ifTrue:", "isAsync", "execute:"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "context:",
- protocol: "accessing",
- fn: function (aRunningTestContext){
- var self=this;
- self["@context"]=aRunningTestContext;
- return self;
- },
- args: ["aRunningTestContext"],
- source: "context: aRunningTestContext\x0a\x09context := aRunningTestContext",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "deny:",
- protocol: "testing",
- fn: function (aBoolean){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv(aBoolean)._not());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deny:",{aBoolean:aBoolean},$globals.TestCase)});
- },
- args: ["aBoolean"],
- source: "deny: aBoolean\x0a\x09self assert: aBoolean not",
- referencedClasses: [],
- messageSends: ["assert:", "not"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "errorIfNotAsync:",
- protocol: "error handling",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._isAsync();
- if(!$core.assert($1)){
- self._error_($recv(aString).__comma(" used without prior #timeout:"));
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"errorIfNotAsync:",{aString:aString},$globals.TestCase)});
- },
- args: ["aString"],
- source: "errorIfNotAsync: aString\x0a\x09self isAsync ifFalse: [\x0a\x09\x09self error: aString, ' used without prior #timeout:' ]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "isAsync", "error:", ","]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "finished",
- protocol: "async",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._errorIfNotAsync_("#finished");
- self["@asyncTimeout"]=nil;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"finished",{},$globals.TestCase)});
- },
- args: [],
- source: "finished\x0a\x09self errorIfNotAsync: '#finished'.\x0a\x09asyncTimeout := nil",
- referencedClasses: [],
- messageSends: ["errorIfNotAsync:"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "isAsync",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@asyncTimeout"])._notNil();
- }, function($ctx1) {$ctx1.fill(self,"isAsync",{},$globals.TestCase)});
- },
- args: [],
- source: "isAsync\x0a\x09^ asyncTimeout notNil",
- referencedClasses: [],
- messageSends: ["notNil"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "performTest",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@asyncTimeout"]=nil;
- self._perform_(self._selector());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"performTest",{},$globals.TestCase)});
- },
- args: [],
- source: "performTest\x0a\x09asyncTimeout := nil.\x0a\x09self perform: self selector",
- referencedClasses: [],
- messageSends: ["perform:", "selector"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "runCase",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.TestContext)._testCase_(self))._start();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"runCase",{},$globals.TestCase)});
- },
- args: [],
- source: "runCase\x0a\x09\x22Runs a test case in isolated context, leaking all errors.\x22\x0a\x0a\x09(TestContext testCase: self) start",
- referencedClasses: ["TestContext"],
- messageSends: ["start", "testCase:"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "selector",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@testSelector"];
- },
- args: [],
- source: "selector\x0a\x09^ testSelector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "setTestSelector:",
- protocol: "accessing",
- fn: function (aSelector){
- var self=this;
- self["@testSelector"]=aSelector;
- return self;
- },
- args: ["aSelector"],
- source: "setTestSelector: aSelector\x0a\x09testSelector := aSelector",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "running",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "setUp",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "should:",
- protocol: "testing",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv(aBlock)._value());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"should:",{aBlock:aBlock},$globals.TestCase)});
- },
- args: ["aBlock"],
- source: "should: aBlock\x0a\x09self assert: aBlock value",
- referencedClasses: [],
- messageSends: ["assert:", "value"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "should:raise:",
- protocol: "testing",
- fn: function (aBlock,anExceptionClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv((function(){
- return $core.withContext(function($ctx2) {
- $recv(aBlock)._value();
- return false;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_(anExceptionClass,(function(ex){
- return true;
- })));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"should:raise:",{aBlock:aBlock,anExceptionClass:anExceptionClass},$globals.TestCase)});
- },
- args: ["aBlock", "anExceptionClass"],
- source: "should: aBlock raise: anExceptionClass\x0a\x09self assert: ([ aBlock value. false ]\x0a\x09\x09on: anExceptionClass\x0a\x09\x09do: [ :ex | true ])",
- referencedClasses: [],
- messageSends: ["assert:", "on:do:", "value"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "shouldnt:raise:",
- protocol: "testing",
- fn: function (aBlock,anExceptionClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv((function(){
- return $core.withContext(function($ctx2) {
- $recv(aBlock)._value();
- return true;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_(anExceptionClass,(function(ex){
- return false;
- })));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldnt:raise:",{aBlock:aBlock,anExceptionClass:anExceptionClass},$globals.TestCase)});
- },
- args: ["aBlock", "anExceptionClass"],
- source: "shouldnt: aBlock raise: anExceptionClass\x0a\x09self assert: ([ aBlock value. true ]\x0a\x09\x09on: anExceptionClass\x0a\x09\x09do: [ :ex | false ])",
- referencedClasses: [],
- messageSends: ["assert:", "on:do:", "value"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "signalFailure:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.TestFailure)._new();
- $recv($1)._messageText_(aString);
- $recv($1)._signal();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"signalFailure:",{aString:aString},$globals.TestCase)});
- },
- args: ["aString"],
- source: "signalFailure: aString\x0a\x09TestFailure new\x0a\x09\x09messageText: aString;\x0a\x09\x09signal",
- referencedClasses: ["TestFailure"],
- messageSends: ["messageText:", "new", "signal"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "tearDown",
- protocol: "running",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "tearDown",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "timeout:",
- protocol: "async",
- fn: function (aNumber){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@asyncTimeout"];
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $recv(self["@asyncTimeout"])._clearTimeout();
- }
- self["@asyncTimeout"]=(0);
- self["@asyncTimeout"]=$recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- return self._assert_description_(false,"SUnit grace time exhausted");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- })))._valueWithTimeout_(aNumber);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"timeout:",{aNumber:aNumber},$globals.TestCase)});
- },
- args: ["aNumber"],
- source: "timeout: aNumber\x0a\x09\x22Set a grace time timeout in milliseconds to run the test asynchronously\x22\x0a\x09\x0a\x09asyncTimeout ifNotNil: [ asyncTimeout clearTimeout ].\x0a\x09\x0a\x09\x22to allow #async: message send without throwing an error\x22\x0a\x09asyncTimeout := 0.\x0a\x09\x0a\x09asyncTimeout := (self async: [\x0a\x09\x09self assert: false description: 'SUnit grace time exhausted' ])\x0a\x09\x09\x09valueWithTimeout: aNumber",
- referencedClasses: [],
- messageSends: ["ifNotNil:", "clearTimeout", "valueWithTimeout:", "async:", "assert:description:"]
- }),
- $globals.TestCase);
- $core.addMethod(
- $core.method({
- selector: "allTestSelectors",
- protocol: "accessing",
- fn: function (){
- var self=this;
- var selectors;
- return $core.withContext(function($ctx1) {
- var $1;
- selectors=self._testSelectors();
- $1=self._shouldInheritSelectors();
- if($core.assert($1)){
- $recv(selectors)._addAll_($recv(self._superclass())._allTestSelectors());
- }
- return selectors;
- }, function($ctx1) {$ctx1.fill(self,"allTestSelectors",{selectors:selectors},$globals.TestCase.klass)});
- },
- args: [],
- source: "allTestSelectors\x0a\x09| selectors |\x0a\x09selectors := self testSelectors.\x0a\x09self shouldInheritSelectors ifTrue: [\x0a\x09\x09selectors addAll: self superclass allTestSelectors ].\x0a\x09^ selectors",
- referencedClasses: [],
- messageSends: ["testSelectors", "ifTrue:", "shouldInheritSelectors", "addAll:", "allTestSelectors", "superclass"]
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "buildSuite",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._allTestSelectors())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return self._selector_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"buildSuite",{},$globals.TestCase.klass)});
- },
- args: [],
- source: "buildSuite\x0a\x09^ self allTestSelectors collect: [ :each | self selector: each ]",
- referencedClasses: [],
- messageSends: ["collect:", "allTestSelectors", "selector:"]
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "classTag",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "test";
- },
- args: [],
- source: "classTag\x0a\x09\x22Returns a tag or general category for this class.\x0a\x09Typically used to help tools do some reflection.\x0a\x09Helios, for example, uses this to decide what icon the class should display.\x22\x0a\x09\x0a\x09^ 'test'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "isAbstract",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._name()).__eq("TestCase");
- }, function($ctx1) {$ctx1.fill(self,"isAbstract",{},$globals.TestCase.klass)});
- },
- args: [],
- source: "isAbstract\x0a\x09^ self name = 'TestCase'",
- referencedClasses: [],
- messageSends: ["=", "name"]
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "isTestClass",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._isAbstract())._not();
- }, function($ctx1) {$ctx1.fill(self,"isTestClass",{},$globals.TestCase.klass)});
- },
- args: [],
- source: "isTestClass\x0a\x09^ self isAbstract not",
- referencedClasses: [],
- messageSends: ["not", "isAbstract"]
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "lookupHierarchyRoot",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.TestCase;
- },
- args: [],
- source: "lookupHierarchyRoot\x0a\x09^ TestCase",
- referencedClasses: ["TestCase"],
- messageSends: []
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "selector:",
- protocol: "accessing",
- fn: function (aSelector){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._setTestSelector_(aSelector);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"selector:",{aSelector:aSelector},$globals.TestCase.klass)});
- },
- args: ["aSelector"],
- source: "selector: aSelector\x0a\x09^ self new\x0a\x09\x09setTestSelector: aSelector;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["setTestSelector:", "new", "yourself"]
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "shouldInheritSelectors",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self.__tild_eq(self._lookupHierarchyRoot());
- }, function($ctx1) {$ctx1.fill(self,"shouldInheritSelectors",{},$globals.TestCase.klass)});
- },
- args: [],
- source: "shouldInheritSelectors\x0a\x09^ self ~= self lookupHierarchyRoot",
- referencedClasses: [],
- messageSends: ["~=", "lookupHierarchyRoot"]
- }),
- $globals.TestCase.klass);
- $core.addMethod(
- $core.method({
- selector: "testSelectors",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._methodDictionary())._keys())._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._match_("^test");
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"testSelectors",{},$globals.TestCase.klass)});
- },
- args: [],
- source: "testSelectors\x0a\x09^ self methodDictionary keys select: [ :each | each match: '^test' ]",
- referencedClasses: [],
- messageSends: ["select:", "keys", "methodDictionary", "match:"]
- }),
- $globals.TestCase.klass);
- $core.addClass("TestContext", $globals.Object, ["testCase"], "SUnit");
- $globals.TestContext.comment="I govern running a particular test case.\x0a\x0aMy main added value is `#execute:` method which runs a block as a part of test case (restores context, nilling it afterwards, cleaning/calling `#tearDown` as appropriate for sync/async scenario).";
- $core.addMethod(
- $core.method({
- selector: "execute:",
- protocol: "running",
- fn: function (aBlock){
- var self=this;
- var failed;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $recv(self["@testCase"])._context_(self);
- $ctx1.sendIdx["context:"]=1;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- failed=true;
- failed;
- $recv(aBlock)._value();
- failed=false;
- return failed;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._ensure_((function(){
- return $core.withContext(function($ctx2) {
- $recv(self["@testCase"])._context_(nil);
- $1=$recv(failed)._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(self["@testCase"])._isAsync();
- $ctx3.sendIdx["isAsync"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- if($core.assert($1)){
- $recv(self["@testCase"])._finished();
- }
- $2=$recv(self["@testCase"])._isAsync();
- if(!$core.assert($2)){
- return $recv(self["@testCase"])._tearDown();
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"execute:",{aBlock:aBlock,failed:failed},$globals.TestContext)});
- },
- args: ["aBlock"],
- source: "execute: aBlock\x0a\x09| failed |\x0a\x09\x0a\x09testCase context: self.\x0a\x09[\x0a\x09\x09failed := true.\x0a\x09\x09aBlock value.\x0a\x09\x09failed := false\x0a\x09]\x0a\x09\x09ensure: [\x0a\x09\x09\x09testCase context: nil.\x0a\x09\x09\x09\x0a\x09\x09\x09(failed and: [ testCase isAsync ]) ifTrue: [\x0a\x09\x09\x09\x09testCase finished ].\x0a\x09\x09\x09testCase isAsync ifFalse: [\x0a\x09\x09\x09\x09testCase tearDown ] ]",
- referencedClasses: [],
- messageSends: ["context:", "ensure:", "value", "ifTrue:", "and:", "isAsync", "finished", "ifFalse:", "tearDown"]
- }),
- $globals.TestContext);
- $core.addMethod(
- $core.method({
- selector: "start",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._execute_((function(){
- return $core.withContext(function($ctx2) {
- $recv(self["@testCase"])._setUp();
- return $recv(self["@testCase"])._performTest();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"start",{},$globals.TestContext)});
- },
- args: [],
- source: "start\x0a\x09self execute: [\x0a\x09\x09testCase setUp.\x0a\x09\x09testCase performTest ]",
- referencedClasses: [],
- messageSends: ["execute:", "setUp", "performTest"]
- }),
- $globals.TestContext);
- $core.addMethod(
- $core.method({
- selector: "testCase:",
- protocol: "accessing",
- fn: function (aTestCase){
- var self=this;
- self["@testCase"]=aTestCase;
- return self;
- },
- args: ["aTestCase"],
- source: "testCase: aTestCase\x0a\x09testCase := aTestCase",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestContext);
- $core.addMethod(
- $core.method({
- selector: "testCase:",
- protocol: "instance creation",
- fn: function (aTestCase){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- $recv($1)._testCase_(aTestCase);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"testCase:",{aTestCase:aTestCase},$globals.TestContext.klass)});
- },
- args: ["aTestCase"],
- source: "testCase: aTestCase\x0a\x09^ self new\x0a\x09\x09testCase: aTestCase;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["testCase:", "new", "yourself"]
- }),
- $globals.TestContext.klass);
- $core.addClass("ReportingTestContext", $globals.TestContext, ["finished", "result"], "SUnit");
- $globals.ReportingTestContext.comment="I add `TestResult` reporting to `TestContext`.\x0a\x0aErrors are caught and save into a `TestResult`,\x0aWhen test case is finished (which can be later for async tests), a callback block is executed; this is used by a `TestSuiteRunner`.";
- $core.addMethod(
- $core.method({
- selector: "execute:",
- protocol: "running",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._withErrorReporting_((function(){
- return $core.withContext(function($ctx3) {
- return (
- $ctx3.supercall = true,
- ($globals.ReportingTestContext.superclass||$boot.nilAsClass).fn.prototype._execute_.apply($recv(self), [aBlock]));
- $ctx3.supercall = false;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._ensure_((function(){
- return $core.withContext(function($ctx2) {
- $1=$recv(self["@testCase"])._isAsync();
- if(!$core.assert($1)){
- $recv(self["@result"])._increaseRuns();
- return $recv(self["@finished"])._value();
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"execute:",{aBlock:aBlock},$globals.ReportingTestContext)});
- },
- args: ["aBlock"],
- source: "execute: aBlock\x0a\x09[\x0a\x09\x09self withErrorReporting: [ super execute: aBlock ]\x0a\x09]\x0a\x09\x09ensure: [\x0a\x09\x09\x09testCase isAsync ifFalse: [\x0a\x09\x09\x09\x09result increaseRuns. finished value ] ]",
- referencedClasses: [],
- messageSends: ["ensure:", "withErrorReporting:", "execute:", "ifFalse:", "isAsync", "increaseRuns", "value"]
- }),
- $globals.ReportingTestContext);
- $core.addMethod(
- $core.method({
- selector: "finished:",
- protocol: "accessing",
- fn: function (aBlock){
- var self=this;
- self["@finished"]=aBlock;
- return self;
- },
- args: ["aBlock"],
- source: "finished: aBlock\x0a\x09finished := aBlock",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ReportingTestContext);
- $core.addMethod(
- $core.method({
- selector: "result:",
- protocol: "accessing",
- fn: function (aTestResult){
- var self=this;
- self["@result"]=aTestResult;
- return self;
- },
- args: ["aTestResult"],
- source: "result: aTestResult\x0a\x09result := aTestResult",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ReportingTestContext);
- $core.addMethod(
- $core.method({
- selector: "withErrorReporting:",
- protocol: "private",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(aBlock)._on_do_($globals.TestFailure,(function(ex){
- return $core.withContext(function($ctx3) {
- return $recv(self["@result"])._addFailure_(self["@testCase"]);
- }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,2)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(ex){
- return $core.withContext(function($ctx2) {
- return $recv(self["@result"])._addError_(self["@testCase"]);
- }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,3)});
- }));
- $ctx1.sendIdx["on:do:"]=1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"withErrorReporting:",{aBlock:aBlock},$globals.ReportingTestContext)});
- },
- args: ["aBlock"],
- source: "withErrorReporting: aBlock\x0a\x09[ aBlock\x0a\x09\x09on: TestFailure\x0a\x09\x09do: [ :ex | result addFailure: testCase ]\x0a\x09]\x0a\x09\x09on: Error\x0a\x09\x09do: [ :ex | result addError: testCase ]",
- referencedClasses: ["TestFailure", "Error"],
- messageSends: ["on:do:", "addFailure:", "addError:"]
- }),
- $globals.ReportingTestContext);
- $core.addMethod(
- $core.method({
- selector: "testCase:result:finished:",
- protocol: "instance creation",
- fn: function (aTestCase,aTestResult,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(
- $ctx1.supercall = true,
- ($globals.ReportingTestContext.klass.superclass||$boot.nilAsClass).fn.prototype._testCase_.apply($recv(self), [aTestCase]));
- $ctx1.supercall = false;
- $recv($1)._result_(aTestResult);
- $recv($1)._finished_(aBlock);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"testCase:result:finished:",{aTestCase:aTestCase,aTestResult:aTestResult,aBlock:aBlock},$globals.ReportingTestContext.klass)});
- },
- args: ["aTestCase", "aTestResult", "aBlock"],
- source: "testCase: aTestCase result: aTestResult finished: aBlock\x0a\x09^ (super testCase: aTestCase)\x0a\x09\x09result: aTestResult;\x0a\x09\x09finished: aBlock;\x0a\x09\x09yourself",
- referencedClasses: [],
- messageSends: ["result:", "testCase:", "finished:", "yourself"]
- }),
- $globals.ReportingTestContext.klass);
- $core.addClass("TestFailure", $globals.Error, [], "SUnit");
- $globals.TestFailure.comment="I am raised when the boolean parameter of an #`assert:` or `#deny:` call is the opposite of what the assertion claims.\x0a\x0aThe test framework distinguishes between failures and errors.\x0aA failure is an event whose possibiity is explicitly anticipated and checked for in an assertion,\x0awhereas an error is an unanticipated problem like a division by 0 or an index out of bounds.";
- $core.addClass("TestResult", $globals.Object, ["timestamp", "runs", "errors", "failures", "total"], "SUnit");
- $globals.TestResult.comment="I implement the collecting parameter pattern for running a bunch of tests.\x0a\x0aMy instances hold tests that have run, sorted into the result categories of passed, failures and errors.\x0a\x0a`TestResult` is an interesting object to subclass or substitute. `#runCase:` is the external protocol you need to reproduce";
- $core.addMethod(
- $core.method({
- selector: "addError:",
- protocol: "accessing",
- fn: function (anError){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._errors())._add_(anError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addError:",{anError:anError},$globals.TestResult)});
- },
- args: ["anError"],
- source: "addError: anError\x0a\x09self errors add: anError",
- referencedClasses: [],
- messageSends: ["add:", "errors"]
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "addFailure:",
- protocol: "accessing",
- fn: function (aFailure){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._failures())._add_(aFailure);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"addFailure:",{aFailure:aFailure},$globals.TestResult)});
- },
- args: ["aFailure"],
- source: "addFailure: aFailure\x0a\x09self failures add: aFailure",
- referencedClasses: [],
- messageSends: ["add:", "failures"]
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "errors",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@errors"];
- },
- args: [],
- source: "errors\x0a\x09^ errors",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "failures",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@failures"];
- },
- args: [],
- source: "failures\x0a\x09^ failures",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "increaseRuns",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@runs"]=$recv(self["@runs"]).__plus((1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"increaseRuns",{},$globals.TestResult)});
- },
- args: [],
- source: "increaseRuns\x0a\x09runs := runs + 1",
- referencedClasses: [],
- messageSends: ["+"]
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.TestResult.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@timestamp"]=$recv($globals.Date)._now();
- self["@runs"]=(0);
- self["@errors"]=$recv($globals.Array)._new();
- $ctx1.sendIdx["new"]=1;
- self["@failures"]=$recv($globals.Array)._new();
- self["@total"]=(0);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TestResult)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09timestamp := Date now.\x0a\x09runs := 0.\x0a\x09errors := Array new.\x0a\x09failures := Array new.\x0a\x09total := 0",
- referencedClasses: ["Date", "Array"],
- messageSends: ["initialize", "now", "new"]
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "nextRunDo:",
- protocol: "running",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._runs();
- $ctx1.sendIdx["runs"]=1;
- $1=$recv($2).__eq_eq(self._total());
- if(!$core.assert($1)){
- return $recv(aBlock)._value_($recv(self._runs()).__plus((1)));
- }
- }, function($ctx1) {$ctx1.fill(self,"nextRunDo:",{aBlock:aBlock},$globals.TestResult)});
- },
- args: ["aBlock"],
- source: "nextRunDo: aBlock\x0a\x09\x22Runs aBlock with index of next run or does nothing if no more runs\x22\x0a\x09^ self runs == self total\x0a\x09\x09ifFalse: [ aBlock value: self runs + 1 ]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "==", "runs", "total", "value:", "+"]
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "runCase:",
- protocol: "running",
- fn: function (aTestCase){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv((function(){
- return $core.withContext(function($ctx3) {
- self._increaseRuns();
- return $recv(aTestCase)._runCase();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }))._on_do_($globals.TestFailure,(function(ex){
- return $core.withContext(function($ctx3) {
- return self._addFailure_(aTestCase);
- }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(ex){
- return $core.withContext(function($ctx2) {
- return self._addError_(aTestCase);
- }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,4)});
- }));
- $ctx1.sendIdx["on:do:"]=1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"runCase:",{aTestCase:aTestCase},$globals.TestResult)});
- },
- args: ["aTestCase"],
- source: "runCase: aTestCase\x0a\x09[ [ self increaseRuns.\x0a\x09\x09aTestCase runCase ]\x0a\x09on: TestFailure do: [ :ex | self addFailure: aTestCase ]]\x0a\x09on: Error do: [ :ex | self addError: aTestCase ]",
- referencedClasses: ["TestFailure", "Error"],
- messageSends: ["on:do:", "increaseRuns", "runCase", "addFailure:", "addError:"]
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "runs",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@runs"];
- },
- args: [],
- source: "runs\x0a\x09^ runs",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "status",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._errors())._ifNotEmpty_ifEmpty_((function(){
- return "error";
- }),(function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._failures())._ifNotEmpty_ifEmpty_((function(){
- return "failure";
- }),(function(){
- return "success";
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $ctx1.sendIdx["ifNotEmpty:ifEmpty:"]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"status",{},$globals.TestResult)});
- },
- args: [],
- source: "status\x0a\x09^ self errors ifNotEmpty: [ 'error' ] ifEmpty: [\x0a\x09\x09self failures ifNotEmpty: [ 'failure' ] ifEmpty: [\x0a\x09\x09\x09'success' ]]",
- referencedClasses: [],
- messageSends: ["ifNotEmpty:ifEmpty:", "errors", "failures"]
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "timestamp",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@timestamp"];
- },
- args: [],
- source: "timestamp\x0a\x09^ timestamp",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "total",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@total"];
- },
- args: [],
- source: "total\x0a\x09^ total",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestResult);
- $core.addMethod(
- $core.method({
- selector: "total:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- self["@total"]=aNumber;
- return self;
- },
- args: ["aNumber"],
- source: "total: aNumber\x0a\x09total := aNumber",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestResult);
- $core.addClass("TestSuiteRunner", $globals.Object, ["suite", "result", "announcer", "runNextTest"], "SUnit");
- $globals.TestSuiteRunner.comment="I am responsible for running a collection (`suite`) of tests.\x0a\x0a## API\x0a\x0aInstances should be created using the class-side `#on:` method, taking a collection of tests to run as parameter.\x0aTo run the test suite, use `#run`.";
- $core.addMethod(
- $core.method({
- selector: "announcer",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@announcer"];
- },
- args: [],
- source: "announcer\x0a\x09^ announcer",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestSuiteRunner);
- $core.addMethod(
- $core.method({
- selector: "contextOf:",
- protocol: "private",
- fn: function (anInteger){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.ReportingTestContext)._testCase_result_finished_($recv(self["@suite"])._at_(anInteger),self["@result"],(function(){
- return $core.withContext(function($ctx2) {
- return self._resume();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"contextOf:",{anInteger:anInteger},$globals.TestSuiteRunner)});
- },
- args: ["anInteger"],
- source: "contextOf: anInteger\x0a\x09^ ReportingTestContext testCase: (suite at: anInteger) result: result finished: [ self resume ]",
- referencedClasses: ["ReportingTestContext"],
- messageSends: ["testCase:result:finished:", "at:", "resume"]
- }),
- $globals.TestSuiteRunner);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- (
- $ctx1.supercall = true,
- ($globals.TestSuiteRunner.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@announcer"]=$recv($globals.Announcer)._new();
- $ctx1.sendIdx["new"]=1;
- self["@result"]=$recv($globals.TestResult)._new();
- self["@runNextTest"]=(function(){
- var runs;
- return $core.withContext(function($ctx2) {
- runs=$recv(self["@result"])._runs();
- runs;
- $1=$recv(runs).__lt($recv(self["@result"])._total());
- if($core.assert($1)){
- return $recv(self._contextOf_($recv(runs).__plus((1))))._start();
- }
- }, function($ctx2) {$ctx2.fillBlock({runs:runs},$ctx1,1)});
- });
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.TestSuiteRunner)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09announcer := Announcer new.\x0a\x09result := TestResult new.\x0a\x09runNextTest := [ | runs | runs := result runs. runs < result total ifTrue: [ (self contextOf: runs + 1) start ] ].",
- referencedClasses: ["Announcer", "TestResult"],
- messageSends: ["initialize", "new", "runs", "ifTrue:", "<", "total", "start", "contextOf:", "+"]
- }),
- $globals.TestSuiteRunner);
- $core.addMethod(
- $core.method({
- selector: "result",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@result"];
- },
- args: [],
- source: "result\x0a\x09^ result",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestSuiteRunner);
- $core.addMethod(
- $core.method({
- selector: "resume",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@runNextTest"])._fork();
- $recv(self["@announcer"])._announce_($recv($recv($globals.ResultAnnouncement)._new())._result_(self["@result"]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"resume",{},$globals.TestSuiteRunner)});
- },
- args: [],
- source: "resume\x0a\x09runNextTest fork.\x0a\x09announcer announce: (ResultAnnouncement new result: result)",
- referencedClasses: ["ResultAnnouncement"],
- messageSends: ["fork", "announce:", "result:", "new"]
- }),
- $globals.TestSuiteRunner);
- $core.addMethod(
- $core.method({
- selector: "run",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@result"])._total_($recv(self["@suite"])._size());
- self._resume();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"run",{},$globals.TestSuiteRunner)});
- },
- args: [],
- source: "run\x0a\x09result total: suite size.\x0a\x09self resume",
- referencedClasses: [],
- messageSends: ["total:", "size", "resume"]
- }),
- $globals.TestSuiteRunner);
- $core.addMethod(
- $core.method({
- selector: "suite:",
- protocol: "accessing",
- fn: function (aCollection){
- var self=this;
- self["@suite"]=aCollection;
- return self;
- },
- args: ["aCollection"],
- source: "suite: aCollection\x0a\x09suite := aCollection",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.TestSuiteRunner);
- $core.addMethod(
- $core.method({
- selector: "new",
- protocol: "instance creation",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldNotImplement();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"new",{},$globals.TestSuiteRunner.klass)});
- },
- args: [],
- source: "new\x0a\x09self shouldNotImplement",
- referencedClasses: [],
- messageSends: ["shouldNotImplement"]
- }),
- $globals.TestSuiteRunner.klass);
- $core.addMethod(
- $core.method({
- selector: "on:",
- protocol: "instance creation",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(
- $ctx1.supercall = true,
- ($globals.TestSuiteRunner.klass.superclass||$boot.nilAsClass).fn.prototype._new.apply($recv(self), []));
- $ctx1.supercall = false;
- return $recv($1)._suite_(aCollection);
- }, function($ctx1) {$ctx1.fill(self,"on:",{aCollection:aCollection},$globals.TestSuiteRunner.klass)});
- },
- args: ["aCollection"],
- source: "on: aCollection\x0a\x09^ super new suite: aCollection",
- referencedClasses: [],
- messageSends: ["suite:", "new"]
- }),
- $globals.TestSuiteRunner.klass);
- $core.addMethod(
- $core.method({
- selector: "isTestClass",
- protocol: "*SUnit",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isTestClass\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BehaviorBody);
- $core.addMethod(
- $core.method({
- selector: "isTestPackage",
- protocol: "*SUnit",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._classes())._anySatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._isTestClass();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"isTestPackage",{},$globals.Package)});
- },
- args: [],
- source: "isTestPackage\x0a\x09^ self classes anySatisfy: [ :each | each isTestClass ]",
- referencedClasses: [],
- messageSends: ["anySatisfy:", "classes", "isTestClass"]
- }),
- $globals.Package);
- });
- define('amber_core/Compiler-Tests',["amber/boot", "amber_core/SUnit"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Compiler-Tests");
- $core.packages["Compiler-Tests"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Compiler-Tests"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("ASTParsingTest", $globals.TestCase, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "analyze:forClass:",
- protocol: "convenience",
- fn: function (aNode,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.SemanticAnalyzer)._on_(aClass))._visit_(aNode);
- return aNode;
- }, function($ctx1) {$ctx1.fill(self,"analyze:forClass:",{aNode:aNode,aClass:aClass},$globals.ASTParsingTest)});
- },
- args: ["aNode", "aClass"],
- source: "analyze: aNode forClass: aClass\x0a\x09(SemanticAnalyzer on: aClass) visit: aNode.\x0a\x09^ aNode",
- referencedClasses: ["SemanticAnalyzer"],
- messageSends: ["visit:", "on:"]
- }),
- $globals.ASTParsingTest);
- $core.addMethod(
- $core.method({
- selector: "parse:",
- protocol: "parsing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._parse_(aString);
- }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString},$globals.ASTParsingTest)});
- },
- args: ["aString"],
- source: "parse: aString\x0a\x09^ Smalltalk parse: aString",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:"]
- }),
- $globals.ASTParsingTest);
- $core.addMethod(
- $core.method({
- selector: "parse:forClass:",
- protocol: "parsing",
- fn: function (aString,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._analyze_forClass_(self._parse_(aString),aClass);
- }, function($ctx1) {$ctx1.fill(self,"parse:forClass:",{aString:aString,aClass:aClass},$globals.ASTParsingTest)});
- },
- args: ["aString", "aClass"],
- source: "parse: aString forClass: aClass\x0a\x09^ self analyze: (self parse: aString) forClass: aClass",
- referencedClasses: [],
- messageSends: ["analyze:forClass:", "parse:"]
- }),
- $globals.ASTParsingTest);
- $core.addClass("ASTPCNodeVisitorTest", $globals.ASTParsingTest, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "astPCNodeVisitor",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.ASTPCNodeVisitor)._new();
- $recv($1)._index_((0));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"astPCNodeVisitor",{},$globals.ASTPCNodeVisitorTest)});
- },
- args: [],
- source: "astPCNodeVisitor\x0a\x09^ ASTPCNodeVisitor new\x0a\x09\x09index: 0;\x0a\x09\x09yourself",
- referencedClasses: ["ASTPCNodeVisitor"],
- messageSends: ["index:", "new", "yourself"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addMethod(
- $core.method({
- selector: "astPCNodeVisitorForSelector:",
- protocol: "factory",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.ASTPCNodeVisitor)._new();
- $recv($1)._selector_(aString);
- $recv($1)._index_((0));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"astPCNodeVisitorForSelector:",{aString:aString},$globals.ASTPCNodeVisitorTest)});
- },
- args: ["aString"],
- source: "astPCNodeVisitorForSelector: aString\x0a\x09^ ASTPCNodeVisitor new\x0a\x09\x09selector: aString;\x0a\x09\x09index: 0;\x0a\x09\x09yourself",
- referencedClasses: ["ASTPCNodeVisitor"],
- messageSends: ["selector:", "new", "index:", "yourself"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addMethod(
- $core.method({
- selector: "testJSStatementNode",
- protocol: "tests",
- fn: function (){
- var self=this;
- var ast,visitor;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- ast=self._parse_forClass_("foo <inlineJS: 'consolee.log(1)'>",$globals.Object);
- $3=self._astPCNodeVisitor();
- $recv($3)._visit_(ast);
- $2=$recv($3)._currentNode();
- $1=$recv($2)._isJSStatementNode();
- self._assert_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testJSStatementNode",{ast:ast,visitor:visitor},$globals.ASTPCNodeVisitorTest)});
- },
- args: [],
- source: "testJSStatementNode\x0a\x09| ast visitor |\x0a\x09\x0a\x09ast := self parse: 'foo <inlineJS: ''consolee.log(1)''>' forClass: Object.\x0a\x09self assert: (self astPCNodeVisitor\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode) isJSStatementNode",
- referencedClasses: ["Object"],
- messageSends: ["parse:forClass:", "assert:", "isJSStatementNode", "visit:", "astPCNodeVisitor", "currentNode"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addMethod(
- $core.method({
- selector: "testLegacyJSStatementNode",
- protocol: "tests",
- fn: function (){
- var self=this;
- var ast,visitor;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- ast=self._parse_forClass_("foo <consolee.log(1)>",$globals.Object);
- $3=self._astPCNodeVisitor();
- $recv($3)._visit_(ast);
- $2=$recv($3)._currentNode();
- $1=$recv($2)._isJSStatementNode();
- self._assert_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLegacyJSStatementNode",{ast:ast,visitor:visitor},$globals.ASTPCNodeVisitorTest)});
- },
- args: [],
- source: "testLegacyJSStatementNode\x0a\x09| ast visitor |\x0a\x09\x0a\x09ast := self parse: 'foo <consolee.log(1)>' forClass: Object.\x0a\x09self assert: (self astPCNodeVisitor\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode) isJSStatementNode",
- referencedClasses: ["Object"],
- messageSends: ["parse:forClass:", "assert:", "isJSStatementNode", "visit:", "astPCNodeVisitor", "currentNode"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addMethod(
- $core.method({
- selector: "testMessageSend",
- protocol: "tests",
- fn: function (){
- var self=this;
- var ast;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- ast=self._parse_forClass_("foo self asString yourself. ^ self asBoolean",$globals.Object);
- $3=self._astPCNodeVisitorForSelector_("yourself");
- $recv($3)._visit_(ast);
- $2=$recv($3)._currentNode();
- $1=$recv($2)._selector();
- self._assert_equals_($1,"yourself");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMessageSend",{ast:ast},$globals.ASTPCNodeVisitorTest)});
- },
- args: [],
- source: "testMessageSend\x0a\x09| ast |\x0a\x09\x0a\x09ast := self parse: 'foo self asString yourself. ^ self asBoolean' forClass: Object.\x0a\x09self assert: ((self astPCNodeVisitorForSelector: 'yourself')\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode) selector equals: 'yourself'",
- referencedClasses: ["Object"],
- messageSends: ["parse:forClass:", "assert:equals:", "selector", "visit:", "astPCNodeVisitorForSelector:", "currentNode"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addMethod(
- $core.method({
- selector: "testMessageSendWithBlocks",
- protocol: "tests",
- fn: function (){
- var self=this;
- var ast;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- ast=self._parse_forClass_("foo true ifTrue: [ [ self asString yourself ] value. ]. ^ self asBoolean",$globals.Object);
- $3=self._astPCNodeVisitorForSelector_("yourself");
- $recv($3)._visit_(ast);
- $2=$recv($3)._currentNode();
- $1=$recv($2)._selector();
- self._assert_equals_($1,"yourself");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMessageSendWithBlocks",{ast:ast},$globals.ASTPCNodeVisitorTest)});
- },
- args: [],
- source: "testMessageSendWithBlocks\x0a\x09| ast |\x0a\x09\x0a\x09ast := self parse: 'foo true ifTrue: [ [ self asString yourself ] value. ]. ^ self asBoolean' forClass: Object.\x0a\x09self assert: ((self astPCNodeVisitorForSelector: 'yourself')\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode) selector equals: 'yourself'",
- referencedClasses: ["Object"],
- messageSends: ["parse:forClass:", "assert:equals:", "selector", "visit:", "astPCNodeVisitorForSelector:", "currentNode"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addMethod(
- $core.method({
- selector: "testMessageSendWithInlining",
- protocol: "tests",
- fn: function (){
- var self=this;
- var ast;
- return $core.withContext(function($ctx1) {
- var $3,$4,$2,$1,$7,$6,$5;
- ast=self._parse_forClass_("foo true ifTrue: [ self asString yourself ]. ^ self asBoolean",$globals.Object);
- $ctx1.sendIdx["parse:forClass:"]=1;
- $3=self._astPCNodeVisitorForSelector_("yourself");
- $ctx1.sendIdx["astPCNodeVisitorForSelector:"]=1;
- $recv($3)._visit_(ast);
- $ctx1.sendIdx["visit:"]=1;
- $4=$recv($3)._currentNode();
- $ctx1.sendIdx["currentNode"]=1;
- $2=$4;
- $1=$recv($2)._selector();
- $ctx1.sendIdx["selector"]=1;
- self._assert_equals_($1,"yourself");
- $ctx1.sendIdx["assert:equals:"]=1;
- ast=self._parse_forClass_("foo true ifTrue: [ self asString yourself ]. ^ self asBoolean",$globals.Object);
- $7=self._astPCNodeVisitorForSelector_("asBoolean");
- $recv($7)._visit_(ast);
- $6=$recv($7)._currentNode();
- $5=$recv($6)._selector();
- self._assert_equals_($5,"asBoolean");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMessageSendWithInlining",{ast:ast},$globals.ASTPCNodeVisitorTest)});
- },
- args: [],
- source: "testMessageSendWithInlining\x0a\x09| ast |\x0a\x09\x0a\x09ast := self parse: 'foo true ifTrue: [ self asString yourself ]. ^ self asBoolean' forClass: Object.\x0a\x09self assert: ((self astPCNodeVisitorForSelector: 'yourself')\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode) selector equals: 'yourself'.\x0a\x09\x09\x0a\x09ast := self parse: 'foo true ifTrue: [ self asString yourself ]. ^ self asBoolean' forClass: Object.\x0a\x09self assert: ((self astPCNodeVisitorForSelector: 'asBoolean')\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode) selector equals: 'asBoolean'",
- referencedClasses: ["Object"],
- messageSends: ["parse:forClass:", "assert:equals:", "selector", "visit:", "astPCNodeVisitorForSelector:", "currentNode"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addMethod(
- $core.method({
- selector: "testNoMessageSend",
- protocol: "tests",
- fn: function (){
- var self=this;
- var ast;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- ast=self._parse_forClass_("foo ^ self",$globals.Object);
- $3=self._astPCNodeVisitor();
- $recv($3)._visit_(ast);
- $2=$recv($3)._currentNode();
- $1=$recv($2)._isNil();
- self._assert_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNoMessageSend",{ast:ast},$globals.ASTPCNodeVisitorTest)});
- },
- args: [],
- source: "testNoMessageSend\x0a\x09| ast |\x0a\x09\x0a\x09ast := self parse: 'foo ^ self' forClass: Object.\x0a\x09self assert: (self astPCNodeVisitor\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode) isNil",
- referencedClasses: ["Object"],
- messageSends: ["parse:forClass:", "assert:", "isNil", "visit:", "astPCNodeVisitor", "currentNode"]
- }),
- $globals.ASTPCNodeVisitorTest);
- $core.addClass("ASTPositionTest", $globals.ASTParsingTest, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "testNodeAtPosition",
- protocol: "tests",
- fn: function (){
- var self=this;
- var node;
- return $core.withContext(function($ctx1) {
- var $3,$4,$2,$1,$7,$8,$6,$5;
- node=self._parse_("yourself\x0a\x09^ self");
- $ctx1.sendIdx["parse:"]=1;
- $3=node;
- $4=(2).__at((4));
- $ctx1.sendIdx["@"]=1;
- $2=$recv($3)._navigationNodeAt_ifAbsent_($4,(function(){
- return nil;
- }));
- $ctx1.sendIdx["navigationNodeAt:ifAbsent:"]=1;
- $1=$recv($2)._source();
- self._assert_equals_($1,"self");
- $ctx1.sendIdx["assert:equals:"]=1;
- node=self._parse_("foo\x0a\x09true ifTrue: [ 1 ]");
- $ctx1.sendIdx["parse:"]=2;
- $7=node;
- $8=(2).__at((7));
- $ctx1.sendIdx["@"]=2;
- $6=$recv($7)._navigationNodeAt_ifAbsent_($8,(function(){
- return nil;
- }));
- $ctx1.sendIdx["navigationNodeAt:ifAbsent:"]=2;
- $5=$recv($6)._selector();
- $ctx1.sendIdx["selector"]=1;
- self._assert_equals_($5,"ifTrue:");
- $ctx1.sendIdx["assert:equals:"]=2;
- node=self._parse_("foo\x0a\x09self foo; bar; baz");
- self._assert_equals_($recv($recv(node)._navigationNodeAt_ifAbsent_((2).__at((8)),(function(){
- return nil;
- })))._selector(),"foo");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNodeAtPosition",{node:node},$globals.ASTPositionTest)});
- },
- args: [],
- source: "testNodeAtPosition\x0a\x09| node |\x0a\x09\x0a\x09node := self parse: 'yourself\x0a\x09^ self'.\x0a\x09\x0a\x09self assert: (node navigationNodeAt: 2@4 ifAbsent: [ nil ]) source equals: 'self'.\x0a\x09\x0a\x09node := self parse: 'foo\x0a\x09true ifTrue: [ 1 ]'.\x0a\x09\x0a\x09self assert: (node navigationNodeAt: 2@7 ifAbsent: [ nil ]) selector equals: 'ifTrue:'.\x0a\x09\x0a\x09node := self parse: 'foo\x0a\x09self foo; bar; baz'.\x0a\x09\x0a\x09self assert: (node navigationNodeAt: 2@8 ifAbsent: [ nil ]) selector equals: 'foo'",
- referencedClasses: [],
- messageSends: ["parse:", "assert:equals:", "source", "navigationNodeAt:ifAbsent:", "@", "selector"]
- }),
- $globals.ASTPositionTest);
- $core.addClass("CodeGeneratorTest", $globals.ASTParsingTest, ["receiver"], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "codeGeneratorClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.CodeGenerator;
- },
- args: [],
- source: "codeGeneratorClass\x0a\x09^ CodeGenerator",
- referencedClasses: ["CodeGenerator"],
- messageSends: []
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "compiler",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Compiler)._new();
- $recv($1)._codeGeneratorClass_(self._codeGeneratorClass());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"compiler",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "compiler\x0a\x09^ Compiler new\x0a\x09\x09codeGeneratorClass: self codeGeneratorClass;\x0a\x09\x09yourself",
- referencedClasses: ["Compiler"],
- messageSends: ["codeGeneratorClass:", "new", "codeGeneratorClass", "yourself"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@receiver"]=$recv($globals.DoIt)._new();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "setUp\x0a\x09receiver := DoIt new",
- referencedClasses: ["DoIt"],
- messageSends: ["new"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "should:receiver:raise:",
- protocol: "testing",
- fn: function (aString,anObject,anErrorClass){
- var self=this;
- var method,result;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- self["@receiver"]=anObject;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._should_raise_((function(){
- return $core.withContext(function($ctx3) {
- $1=self._compiler();
- $2=$recv(anObject)._class();
- $ctx3.sendIdx["class"]=1;
- method=$recv($1)._install_forClass_protocol_(aString,$2,"tests");
- method;
- return $recv(self["@receiver"])._perform_($recv(method)._selector());
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }),anErrorClass);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._ensure_((function(){
- return $core.withContext(function($ctx2) {
- $3=method;
- if(($receiver = $3) == null || $receiver.isNil){
- return $3;
- } else {
- return $recv($recv(anObject)._class())._removeCompiledMethod_(method);
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"should:receiver:raise:",{aString:aString,anObject:anObject,anErrorClass:anErrorClass,method:method,result:result},$globals.CodeGeneratorTest)});
- },
- args: ["aString", "anObject", "anErrorClass"],
- source: "should: aString receiver: anObject raise: anErrorClass\x0a\x09| method result |\x0a\x0a\x09receiver := anObject.\x0a\x09[ self should: [\x0a\x09\x09method := self compiler install: aString forClass: anObject class protocol: 'tests'.\x0a\x09\x09receiver perform: method selector ] raise: anErrorClass ]\x0a\x09ensure: [ method ifNotNil: [ anObject class removeCompiledMethod: method ] ]",
- referencedClasses: [],
- messageSends: ["ensure:", "should:raise:", "install:forClass:protocol:", "compiler", "class", "perform:", "selector", "ifNotNil:", "removeCompiledMethod:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "should:receiver:return:",
- protocol: "testing",
- fn: function (aString,anObject,aResult){
- var self=this;
- var method,result;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- self["@receiver"]=anObject;
- $1=self._compiler();
- $2=$recv(anObject)._class();
- $ctx1.sendIdx["class"]=1;
- method=$recv($1)._install_forClass_protocol_(aString,$2,"tests");
- result=$recv(self["@receiver"])._perform_($recv(method)._selector());
- $recv($recv(anObject)._class())._removeCompiledMethod_(method);
- self._assert_equals_(aResult,result);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"should:receiver:return:",{aString:aString,anObject:anObject,aResult:aResult,method:method,result:result},$globals.CodeGeneratorTest)});
- },
- args: ["aString", "anObject", "aResult"],
- source: "should: aString receiver: anObject return: aResult\x0a\x09| method result |\x0a\x0a\x09receiver := anObject.\x0a\x09method := self compiler install: aString forClass: anObject class protocol: 'tests'.\x0a\x09result := receiver perform: method selector.\x0a\x09anObject class removeCompiledMethod: method.\x0a\x09self assert: aResult equals: result",
- referencedClasses: [],
- messageSends: ["install:forClass:protocol:", "compiler", "class", "perform:", "selector", "removeCompiledMethod:", "assert:equals:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "should:return:",
- protocol: "testing",
- fn: function (aString,anObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._should_receiver_return_(aString,self["@receiver"],anObject);
- }, function($ctx1) {$ctx1.fill(self,"should:return:",{aString:aString,anObject:anObject},$globals.CodeGeneratorTest)});
- },
- args: ["aString", "anObject"],
- source: "should: aString return: anObject\x0a\x09^ self \x0a\x09\x09should: aString \x0a\x09\x09receiver: receiver \x0a\x09\x09return: anObject",
- referencedClasses: [],
- messageSends: ["should:receiver:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "tearDown",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "tearDown\x0a\x09\x22receiver := nil\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testAssignment",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo | a | a := true ifTrue: [ 1 ]. ^ a",(1));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo | a | a := false ifTrue: [ 1 ]. ^ a",nil);
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo | a | ^ a := true ifTrue: [ 1 ]",(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAssignment",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testAssignment\x0a\x09self should: 'foo | a | a := true ifTrue: [ 1 ]. ^ a' return: 1.\x0a\x09self should: 'foo | a | a := false ifTrue: [ 1 ]. ^ a' return: nil.\x0a\x0a\x09self should: 'foo | a | ^ a := true ifTrue: [ 1 ]' return: 1",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testBackslashSelectors",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("\x5c arg ^ 4",(4));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("\x5c\x5c arg ^ 42",(42));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testBackslashSelectors",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testBackslashSelectors\x0a\x09\x0a\x09self should: '\x5c arg ^ 4' return: 4.\x0a\x09self should: '\x5c\x5c arg ^ 42' return: 42",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testBlockReturn",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ #(1 2 3) collect: [ :each | true ifTrue: [ each + 1 ] ]",[(2), (3), (4)]);
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ #(1 2 3) collect: [ :each | false ifFalse: [ each + 1 ] ]",[(2), (3), (4)]);
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ #(1 2 3) collect: [ :each | each odd ifTrue: [ each + 1 ] ifFalse: [ each - 1 ] ]",[(2), (1), (4)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testBlockReturn",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testBlockReturn\x0a\x09self should: 'foo ^ #(1 2 3) collect: [ :each | true ifTrue: [ each + 1 ] ]' return: #(2 3 4).\x0a\x09self should: 'foo ^ #(1 2 3) collect: [ :each | false ifFalse: [ each + 1 ] ]' return: #(2 3 4).\x0a\x09self should: 'foo ^ #(1 2 3) collect: [ :each | each odd ifTrue: [ each + 1 ] ifFalse: [ each - 1 ] ]' return: #(2 1 4).",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testCascades",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ Array new add: 3; add: 4; yourself",[(3), (4)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCascades",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testCascades\x0a\x09\x0a\x09self should: 'foo ^ Array new add: 3; add: 4; yourself' return: #(3 4)",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testCascadesInDynamicArray",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo | x | x := 1. ^ {x. [x:=2] value; in: [x]}",[(1), (2)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCascadesInDynamicArray",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testCascadesInDynamicArray\x0a\x09self should: 'foo | x | x := 1. ^ {x. [x:=2] value; in: [x]}' return: #(1 2)",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testCascadesInDynamicDictioary",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo | x | x := 1. ^ #{'one' -> x. 'two' -> ([x:=2] value; in: [x])}",$globals.HashedCollection._newFromPairs_(["one",(1),"two",(2)]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCascadesInDynamicDictioary",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testCascadesInDynamicDictioary\x0a\x09self should: 'foo | x | x := 1. ^ #{''one'' -> x. ''two'' -> ([x:=2] value; in: [x])}' return: #{'one' -> 1. 'two' -> 2}",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testCascadesInSend",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo | x | x := 1. ^ Array with: x with: ([x:=2] value; in: [x])",[(1), (2)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCascadesInSend",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testCascadesInSend\x0a\x09self should: 'foo | x | x := 1. ^ Array with: x with: ([x:=2] value; in: [x])' return: #(1 2)",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testCascadesWithInlining",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ true class; ifTrue: [ 1 ] ifFalse: [ 2 ]",(1));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ false class; ifTrue: [ 1 ] ifFalse: [ 2 ]",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCascadesWithInlining",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testCascadesWithInlining\x0a\x09\x0a\x09self should: 'foo ^ true class; ifTrue: [ 1 ] ifFalse: [ 2 ]' return: 1.\x0a\x09self should: 'foo ^ false class; ifTrue: [ 1 ] ifFalse: [ 2 ]' return: 2",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testDynamicArrayElementsOrdered",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ { x. x := 2 }\x0a",[(1), (2)]);
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ { x. true ifTrue: [ x := 2 ] }\x0a",[(1), (2)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDynamicArrayElementsOrdered",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testDynamicArrayElementsOrdered\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ { x. x := 2 }\x0a' return: #(1 2).\x0a\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ { x. true ifTrue: [ x := 2 ] }\x0a' return: #(1 2).",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testDynamicDictionaryElementsOrdered",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := 'foo'.\x0a\x09^ #{ x->1. 'bar'->(true ifTrue: [ 2 ]) }\x0a",$globals.HashedCollection._newFromPairs_(["foo",(1),"bar",(2)]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDynamicDictionaryElementsOrdered",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testDynamicDictionaryElementsOrdered\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := ''foo''.\x0a\x09^ #{ x->1. ''bar''->(true ifTrue: [ 2 ]) }\x0a' return: #{'foo'->1. 'bar'->2}.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testDynamicDictionaryWithMoreArrows",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv((1).__minus_gt((2))).__minus_gt((3));
- $ctx1.sendIdx["->"]=1;
- $1=$recv($globals.HashedCollection)._with_($2);
- self._should_return_("foo ^ #{1->2->3}",$1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDynamicDictionaryWithMoreArrows",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testDynamicDictionaryWithMoreArrows\x0a\x09self should: 'foo ^ #{1->2->3}' return: (HashedCollection with: 1->2->3)",
- referencedClasses: ["HashedCollection"],
- messageSends: ["should:return:", "with:", "->"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testGlobalVar",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ eval class",$globals.BlockClosure);
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ Math cos: 0",(1));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ NonExistingVar",nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testGlobalVar",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testGlobalVar\x0a\x09self should: 'foo ^ eval class' return: BlockClosure.\x0a\x09self should: 'foo ^ Math cos: 0' return: 1.\x0a\x09self should: 'foo ^ NonExistingVar' return: nil",
- referencedClasses: ["BlockClosure"],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testInnerTemporalDependentElementsOrdered",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$5,$6,$4,$8,$9,$7,$11,$10;
- $2="foo".__minus_gt($globals.Array);
- $ctx1.sendIdx["->"]=1;
- $3="bar".__minus_gt((2));
- $ctx1.sendIdx["->"]=2;
- $1=[$2,$3];
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := Array.\x0a\x09^ x with: 'foo'->x with: 'bar'->(x := 2)\x0a",$1);
- $ctx1.sendIdx["should:return:"]=1;
- $5="foo".__minus_gt($globals.Array);
- $ctx1.sendIdx["->"]=3;
- $6="bar".__minus_gt((2));
- $ctx1.sendIdx["->"]=4;
- $4=[$5,$6];
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := Array.\x0a\x09^ x with: 'foo'->x with: 'bar'->(true ifTrue: [ x := 2 ])\x0a",$4);
- $ctx1.sendIdx["should:return:"]=2;
- $8="foo".__minus_gt((1));
- $ctx1.sendIdx["->"]=5;
- $9="bar".__minus_gt((2));
- $ctx1.sendIdx["->"]=6;
- $7=[$8,$9];
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ Array with: 'foo'->x with: 'bar'->(true ifTrue: [ x := 2 ])\x0a",$7);
- $ctx1.sendIdx["should:return:"]=3;
- $11="foo".__minus_gt((1));
- $ctx1.sendIdx["->"]=7;
- $10=[$11,"bar".__minus_gt((2))];
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ { 'foo'->x. 'bar'->(true ifTrue: [ x := 2 ]) }\x0a",$10);
- $ctx1.sendIdx["should:return:"]=4;
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ #{ 'foo'->x. 'bar'->(true ifTrue: [ x := 2 ]) }\x0a",$globals.HashedCollection._newFromPairs_(["foo",(1),"bar",(2)]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testInnerTemporalDependentElementsOrdered",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testInnerTemporalDependentElementsOrdered\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := Array.\x0a\x09^ x with: ''foo''->x with: ''bar''->(x := 2)\x0a' return: {'foo'->Array. 'bar'->2}.\x0a\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := Array.\x0a\x09^ x with: ''foo''->x with: ''bar''->(true ifTrue: [ x := 2 ])\x0a' return: {'foo'->Array. 'bar'->2}.\x0a\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ Array with: ''foo''->x with: ''bar''->(true ifTrue: [ x := 2 ])\x0a' return: {'foo'->1. 'bar'->2}.\x0a\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ { ''foo''->x. ''bar''->(true ifTrue: [ x := 2 ]) }\x0a' return: {'foo'->1. 'bar'->2}.\x0a\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ #{ ''foo''->x. ''bar''->(true ifTrue: [ x := 2 ]) }\x0a' return: #{'foo'->1. 'bar'->2}.",
- referencedClasses: ["Array"],
- messageSends: ["should:return:", "->"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testJSStatement",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo <return 2+3>",(5));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testJSStatement",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testJSStatement\x0a\x09self should: 'foo <return 2+3>' return: 5",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testLexicalScope",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo | a | a := 1. [ a := 2 ] value. ^ a",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLexicalScope",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testLexicalScope\x0a\x09self should: 'foo | a | a := 1. [ a := 2 ] value. ^ a' return: 2",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testLiterals",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ 1",(1));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ 'hello'","hello");
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ #(1 2 3 4)",[(1), (2), (3), (4)]);
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo ^ {1. [:x | x ] value: 2. 3. [4] value}",[(1), (2), (3), (4)]);
- $ctx1.sendIdx["should:return:"]=4;
- self._should_return_("foo ^ true",true);
- $ctx1.sendIdx["should:return:"]=5;
- self._should_return_("foo ^ false",false);
- $ctx1.sendIdx["should:return:"]=6;
- self._should_return_("foo ^ #{1->2. 3->4}",$globals.HashedCollection._newFromPairs_([(1),(2),(3),(4)]));
- $ctx1.sendIdx["should:return:"]=7;
- self._should_return_("foo ^ #hello","hello");
- $ctx1.sendIdx["should:return:"]=8;
- self._should_return_("foo ^ $h","h");
- $ctx1.sendIdx["should:return:"]=9;
- self._should_return_("foo ^ -123.456",(-123.456));
- $ctx1.sendIdx["should:return:"]=10;
- self._should_return_("foo ^ -2.5e4",(-25000));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLiterals",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testLiterals\x0a\x09self should: 'foo ^ 1' return: 1.\x0a\x09self should: 'foo ^ ''hello''' return: 'hello'.\x0a\x09self should: 'foo ^ #(1 2 3 4)' return: #(1 2 3 4).\x0a\x09self should: 'foo ^ {1. [:x | x ] value: 2. 3. [4] value}' return: #(1 2 3 4).\x0a\x09self should: 'foo ^ true' return: true.\x0a\x09self should: 'foo ^ false' return: false.\x0a\x09self should: 'foo ^ #{1->2. 3->4}' return: #{1->2. 3->4}.\x0a\x09self should: 'foo ^ #hello' return: #hello.\x0a\x09self should: 'foo ^ $h' return: 'h'.\x0a\x09self should: 'foo ^ -123.456' return: -123.456.\x0a\x09self should: 'foo ^ -2.5e4' return: -25000.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testLocalReturn",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ 1",(1));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ 1 + 1",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ",self["@receiver"]);
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo self asString",self["@receiver"]);
- $ctx1.sendIdx["should:return:"]=4;
- self._should_return_("foo | a b | a := 1. b := 2. ^ a + b",(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLocalReturn",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testLocalReturn\x0a\x09self should: 'foo ^ 1' return: 1.\x0a\x09self should: 'foo ^ 1 + 1' return: 2.\x0a\x09self should: 'foo ' return: receiver.\x0a\x09self should: 'foo self asString' return: receiver.\x0a\x09self should: 'foo | a b | a := 1. b := 2. ^ a + b' return: 3",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testMessageSends",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ 1 asString","1");
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ 1 + 1",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ 1 + 2 * 3",(9));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo ^ 1 to: 3",[(1), (2), (3)]);
- $ctx1.sendIdx["should:return:"]=4;
- self._should_return_("foo ^ 1 to: 5 by: 2",[(1), (3), (5)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMessageSends",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testMessageSends\x0a\x09self should: 'foo ^ 1 asString' return: '1'.\x0a\x0a\x09self should: 'foo ^ 1 + 1' return: 2.\x0a\x09self should: 'foo ^ 1 + 2 * 3' return: 9.\x0a\x0a\x09self should: 'foo ^ 1 to: 3' return: #(1 2 3).\x0a\x09self should: 'foo ^ 1 to: 5 by: 2' return: #(1 3 5)",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testMistypedPragmaJSStatement",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_receiver_raise_("foo < inlineJS: 'return 'foo'' >",self["@receiver"],$globals.ParseError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMistypedPragmaJSStatement",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testMistypedPragmaJSStatement\x0a\x09self should: 'foo < inlineJS: ''return ''foo'''' >' receiver: receiver raise: ParseError",
- referencedClasses: ["ParseError"],
- messageSends: ["should:receiver:raise:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testMultipleSequences",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo | a b c | a := 2. b := 3. c := a + b. ^ c * 6",(30));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMultipleSequences",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testMultipleSequences\x0a\x09self should: 'foo | a b c | a := 2. b := 3. c := a + b. ^ c * 6' return: 30",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testMutableLiterals",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ #( 1 2 ) at: 1 put: 3; yourself",[(3), (2)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMutableLiterals",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testMutableLiterals\x0a\x09\x22Mutable literals must be aliased in cascades.\x0a\x09See https://lolg.it/amber/amber/issues/428\x22\x0a\x09\x0a\x09self \x0a\x09\x09should: 'foo ^ #( 1 2 ) at: 1 put: 3; yourself' \x0a\x09\x09return: #(3 2)",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testNestedIfTrue",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ true ifTrue: [ false ifFalse: [ 1 ] ]",(1));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ true ifTrue: [ false ifTrue: [ 1 ] ]",nil);
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo true ifTrue: [ false ifFalse: [ ^ 1 ] ]",(1));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo true ifTrue: [ false ifTrue: [ ^ 1 ] ]",self["@receiver"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNestedIfTrue",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testNestedIfTrue\x0a\x09self should: 'foo ^ true ifTrue: [ false ifFalse: [ 1 ] ]' return: 1.\x0a\x09self should: 'foo ^ true ifTrue: [ false ifTrue: [ 1 ] ]' return: nil.\x0a\x0a\x09self should: 'foo true ifTrue: [ false ifFalse: [ ^ 1 ] ]' return: 1.\x0a\x09self should: 'foo true ifTrue: [ false ifTrue: [ ^ 1 ] ]' return: receiver.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testNestedSends",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ (Point x: (Point x: 2 y: 3) y: 4) asString",$recv($recv($globals.Point)._x_y_((2).__at((3)),(4)))._asString());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNestedSends",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testNestedSends\x0a\x09self should: 'foo ^ (Point x: (Point x: 2 y: 3) y: 4) asString' return: (Point x: (2@3) y: 4) asString",
- referencedClasses: ["Point"],
- messageSends: ["should:return:", "asString", "x:y:", "@"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testNonLocalReturn",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo [ ^ 1 ] value",(1));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo [ ^ 1 + 1 ] value",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo | a b | a := 1. b := 2. [ ^ a + b ] value. self halt",(3));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo [ :x | ^ x + x ] value: 4. ^ 2",(8));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNonLocalReturn",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testNonLocalReturn\x0a\x09self should: 'foo [ ^ 1 ] value' return: 1.\x0a\x09self should: 'foo [ ^ 1 + 1 ] value' return: 2.\x0a\x09self should: 'foo | a b | a := 1. b := 2. [ ^ a + b ] value. self halt' return: 3.\x0a\x09self should: 'foo [ :x | ^ x + x ] value: 4. ^ 2' return: 8",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testPascalCaseGlobal",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^Object",$recv($recv($globals.Smalltalk)._globals())._at_("Object"));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^NonExistent",nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPascalCaseGlobal",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testPascalCaseGlobal\x0a\x09self should: 'foo ^Object' return: (Smalltalk globals at: 'Object').\x0a\x09self should: 'foo ^NonExistent' return: nil",
- referencedClasses: ["Smalltalk"],
- messageSends: ["should:return:", "at:", "globals"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testPragmaJSStatement",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo < inlineJS: 'return 2+3' >",(5));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPragmaJSStatement",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testPragmaJSStatement\x0a\x09self should: 'foo < inlineJS: ''return 2+3'' >' return: 5",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testRootSuperSend",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_receiver_raise_("foo ^ super class",$recv($globals.ProtoObject)._new(),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRootSuperSend",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testRootSuperSend\x0a\x09self \x0a\x09\x09should: 'foo ^ super class' \x0a\x09\x09receiver: ProtoObject new\x0a\x09\x09raise: MessageNotUnderstood",
- referencedClasses: ["ProtoObject", "MessageNotUnderstood"],
- messageSends: ["should:receiver:raise:", "new"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testSendReceiverAndArgumentsOrdered",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ Array with: x with: (true ifTrue: [ x := 2 ])\x0a",[(1), (2)]);
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo\x0a\x09| x |\x0a\x09x := Array.\x0a\x09^ x with: x with: (true ifTrue: [ x := 2 ])\x0a",[$globals.Array,(2)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSendReceiverAndArgumentsOrdered",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testSendReceiverAndArgumentsOrdered\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := 1.\x0a\x09^ Array with: x with: (true ifTrue: [ x := 2 ])\x0a' return: #(1 2).\x0a\x0a\x09self should: 'foo\x0a\x09| x |\x0a\x09x := Array.\x0a\x09^ x with: x with: (true ifTrue: [ x := 2 ])\x0a' return: {Array. 2}.",
- referencedClasses: ["Array"],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testSuperSend",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_receiver_return_("foo ^ super isBoolean",true,false);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSuperSend",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testSuperSend\x0a\x09self \x0a\x09\x09should: 'foo ^ super isBoolean' \x0a\x09\x09receiver: true\x0a\x09\x09return: false",
- referencedClasses: [],
- messageSends: ["should:receiver:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testTempVariables",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo | a | ^ a",nil);
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo | AVariable | ^ AVariable",nil);
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo | a b c | ^ c",nil);
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo | a | [ | d | ^ d ] value",nil);
- $ctx1.sendIdx["should:return:"]=4;
- self._should_return_("foo | a | a:= 1. ^ a",(1));
- $ctx1.sendIdx["should:return:"]=5;
- self._should_return_("foo | AVariable | AVariable := 1. ^ AVariable",(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTempVariables",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testTempVariables\x0a\x09self should: 'foo | a | ^ a' return: nil.\x0a\x09self should: 'foo | AVariable | ^ AVariable' return: nil.\x0a\x09self should: 'foo | a b c | ^ c' return: nil.\x0a\x09self should: 'foo | a | [ | d | ^ d ] value' return: nil.\x0a\x09\x0a\x09self should: 'foo | a | a:= 1. ^ a' return: 1.\x0a\x09self should: 'foo | AVariable | AVariable := 1. ^ AVariable' return: 1.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testThisContext",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ [ thisContext ] value outerContext == thisContext",true);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testThisContext",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testThisContext\x0a\x09self should: 'foo ^ [ thisContext ] value outerContext == thisContext' return: true",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifFalse",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo true ifFalse: [ ^ 1 ]",self["@receiver"]);
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo false ifFalse: [ ^ 2 ]",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ true ifFalse: [ 1 ]",nil);
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo ^ false ifFalse: [ 2 ]",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifFalse",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifFalse\x0a\x09self should: 'foo true ifFalse: [ ^ 1 ]' return: receiver.\x0a\x09self should: 'foo false ifFalse: [ ^ 2 ]' return: 2.\x0a\x09\x0a\x09self should: 'foo ^ true ifFalse: [ 1 ]' return: nil.\x0a\x09self should: 'foo ^ false ifFalse: [ 2 ]' return: 2.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifFalseIfTrue",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo true ifFalse: [ ^ 1 ] ifTrue: [ ^ 2 ]",(2));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo false ifFalse: [ ^ 2 ] ifTrue: [ ^1 ]",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ true ifFalse: [ 1 ] ifTrue: [ 2 ]",(2));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo ^ false ifFalse: [ 2 ] ifTrue: [ 1 ]",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifFalseIfTrue",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifFalseIfTrue\x0a\x09self should: 'foo true ifFalse: [ ^ 1 ] ifTrue: [ ^ 2 ]' return: 2.\x0a\x09self should: 'foo false ifFalse: [ ^ 2 ] ifTrue: [ ^1 ]' return: 2.\x0a\x09\x0a\x09self should: 'foo ^ true ifFalse: [ 1 ] ifTrue: [ 2 ]' return: 2.\x0a\x09self should: 'foo ^ false ifFalse: [ 2 ] ifTrue: [ 1 ]' return: 2.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifNil",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ 1 ifNil: [ 2 ]",(1));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ nil ifNil: [ 2 ]",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo 1 ifNil: [ ^ 2 ]",self["@receiver"]);
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo nil ifNil: [ ^ 2 ]",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifNil",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifNil\x0a\x09self should: 'foo ^ 1 ifNil: [ 2 ]' return: 1.\x0a\x09self should: 'foo ^ nil ifNil: [ 2 ]' return: 2.\x0a\x0a\x09self should: 'foo 1 ifNil: [ ^ 2 ]' return: receiver.\x0a\x09self should: 'foo nil ifNil: [ ^ 2 ]' return: 2.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifNilIfNotNil",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ 1 ifNil: [ 2 ] ifNotNil: [ 3 ]",(3));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ nil ifNil: [ 2 ] ifNotNil: [ 3 ]",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo 1 ifNil: [ ^ 2 ] ifNotNil: [ ^3 ]",(3));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo nil ifNil: [ ^ 2 ] ifNotNil: [ ^3 ]",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifNilIfNotNil",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifNilIfNotNil\x0a\x09self should: 'foo ^ 1 ifNil: [ 2 ] ifNotNil: [ 3 ]' return: 3.\x0a\x09self should: 'foo ^ nil ifNil: [ 2 ] ifNotNil: [ 3 ]' return: 2.\x0a\x0a\x09self should: 'foo 1 ifNil: [ ^ 2 ] ifNotNil: [ ^3 ]' return: 3.\x0a\x09self should: 'foo nil ifNil: [ ^ 2 ] ifNotNil: [ ^3 ]' return: 2.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifNotNil",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ 1 ifNotNil: [ 2 ]",(2));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ nil ifNotNil: [ 2 ]",nil);
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo 1 ifNotNil: [ ^ 2 ]",(2));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo nil ifNotNil: [ ^ 2 ]",self["@receiver"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifNotNil",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifNotNil\x0a\x09self should: 'foo ^ 1 ifNotNil: [ 2 ]' return: 2.\x0a\x09self should: 'foo ^ nil ifNotNil: [ 2 ]' return: nil.\x0a\x0a\x09self should: 'foo 1 ifNotNil: [ ^ 2 ]' return: 2.\x0a\x09self should: 'foo nil ifNotNil: [ ^ 2 ]' return: receiver.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifNotNilWithArgument",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo ^ 1 ifNotNil: [ :val | val + 2 ]",(3));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo ^ nil ifNotNil: [ :val | val + 2 ]",nil);
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ 1 ifNil: [ 5 ] ifNotNil: [ :val | val + 2 ]",(3));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo ^ nil ifNil: [ 5 ] ifNotNil: [ :val | val + 2 ]",(5));
- $ctx1.sendIdx["should:return:"]=4;
- self._should_return_("foo ^ 1 ifNotNil: [ :val | val + 2 ] ifNil: [ 5 ]",(3));
- $ctx1.sendIdx["should:return:"]=5;
- self._should_return_("foo ^ nil ifNotNil: [ :val | val + 2 ] ifNil: [ 5 ]",(5));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifNotNilWithArgument",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifNotNilWithArgument\x0a\x09self should: 'foo ^ 1 ifNotNil: [ :val | val + 2 ]' return: 3.\x0a\x09self should: 'foo ^ nil ifNotNil: [ :val | val + 2 ]' return: nil.\x0a\x09\x0a\x09self should: 'foo ^ 1 ifNil: [ 5 ] ifNotNil: [ :val | val + 2 ]' return: 3.\x0a\x09self should: 'foo ^ nil ifNil: [ 5 ] ifNotNil: [ :val | val + 2 ]' return: 5.\x0a\x09\x0a\x09self should: 'foo ^ 1 ifNotNil: [ :val | val + 2 ] ifNil: [ 5 ]' return: 3.\x0a\x09self should: 'foo ^ nil ifNotNil: [ :val | val + 2 ] ifNil: [ 5 ]' return: 5",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifTrue",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo false ifTrue: [ ^ 1 ]",self["@receiver"]);
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo true ifTrue: [ ^ 2 ]",(2));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ false ifTrue: [ 1 ]",nil);
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo ^ true ifTrue: [ 2 ]",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifTrue",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifTrue\x0a\x09self should: 'foo false ifTrue: [ ^ 1 ]' return: receiver.\x0a\x09self should: 'foo true ifTrue: [ ^ 2 ]' return: 2.\x0a\x09\x0a\x09self should: 'foo ^ false ifTrue: [ 1 ]' return: nil.\x0a\x09self should: 'foo ^ true ifTrue: [ 2 ]' return: 2.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addMethod(
- $core.method({
- selector: "testifTrueIfFalse",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_return_("foo false ifTrue: [ ^ 1 ] ifFalse: [ ^2 ]",(2));
- $ctx1.sendIdx["should:return:"]=1;
- self._should_return_("foo true ifTrue: [ ^ 1 ] ifFalse: [ ^ 2 ]",(1));
- $ctx1.sendIdx["should:return:"]=2;
- self._should_return_("foo ^ false ifTrue: [ 2 ] ifFalse: [ 1 ]",(1));
- $ctx1.sendIdx["should:return:"]=3;
- self._should_return_("foo ^ true ifTrue: [ 2 ] ifFalse: [ 1 ]",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testifTrueIfFalse",{},$globals.CodeGeneratorTest)});
- },
- args: [],
- source: "testifTrueIfFalse\x0a\x09self should: 'foo false ifTrue: [ ^ 1 ] ifFalse: [ ^2 ]' return: 2.\x0a\x09self should: 'foo true ifTrue: [ ^ 1 ] ifFalse: [ ^ 2 ]' return: 1.\x0a\x09\x0a\x09self should: 'foo ^ false ifTrue: [ 2 ] ifFalse: [ 1 ]' return: 1.\x0a\x09self should: 'foo ^ true ifTrue: [ 2 ] ifFalse: [ 1 ]' return: 2.",
- referencedClasses: [],
- messageSends: ["should:return:"]
- }),
- $globals.CodeGeneratorTest);
- $core.addClass("ASTInterpreterTest", $globals.CodeGeneratorTest, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "analyze:forClass:",
- protocol: "parsing",
- fn: function (aNode,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.SemanticAnalyzer)._on_(aClass))._visit_(aNode);
- return aNode;
- }, function($ctx1) {$ctx1.fill(self,"analyze:forClass:",{aNode:aNode,aClass:aClass},$globals.ASTInterpreterTest)});
- },
- args: ["aNode", "aClass"],
- source: "analyze: aNode forClass: aClass\x0a\x09(SemanticAnalyzer on: aClass) visit: aNode.\x0a\x09^ aNode",
- referencedClasses: ["SemanticAnalyzer"],
- messageSends: ["visit:", "on:"]
- }),
- $globals.ASTInterpreterTest);
- $core.addMethod(
- $core.method({
- selector: "interpret:receiver:withArguments:",
- protocol: "private",
- fn: function (aString,anObject,aDictionary){
- var self=this;
- var ctx,ast,interpreter;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$receiver;
- interpreter=$recv($globals.ASTInterpreter)._new();
- $ctx1.sendIdx["new"]=1;
- ast=self._parse_forClass_(aString,$recv(anObject)._class());
- $1=$recv($globals.AIContext)._new();
- $recv($1)._receiver_(anObject);
- $recv($1)._interpreter_(interpreter);
- ctx=$recv($1)._yourself();
- $2=$recv(ast)._sequenceNode();
- if(($receiver = $2) == null || $receiver.isNil){
- $2;
- } else {
- var sequence;
- sequence=$receiver;
- $recv($recv(sequence)._temps())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(ctx)._defineLocal_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- }
- $recv(aDictionary)._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(ctx)._localAt_put_(key,value);
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,3)});
- }));
- $3=interpreter;
- $recv($3)._context_(ctx);
- $recv($3)._node_(ast);
- $recv($3)._enterNode();
- $recv($3)._proceed();
- return $recv($3)._result();
- }, function($ctx1) {$ctx1.fill(self,"interpret:receiver:withArguments:",{aString:aString,anObject:anObject,aDictionary:aDictionary,ctx:ctx,ast:ast,interpreter:interpreter},$globals.ASTInterpreterTest)});
- },
- args: ["aString", "anObject", "aDictionary"],
- source: "interpret: aString receiver: anObject withArguments: aDictionary\x0a\x09\x22The food is a methodNode. Interpret the sequenceNode only\x22\x0a\x09\x0a\x09| ctx ast interpreter |\x0a\x09\x0a\x09interpreter := ASTInterpreter new.\x0a\x09ast := self parse: aString forClass: anObject class.\x0a\x09\x0a\x09ctx := AIContext new\x0a\x09\x09receiver: anObject;\x0a\x09\x09interpreter: interpreter;\x0a\x09\x09yourself.\x0a\x09\x09\x0a\x09\x22Define locals for the context\x22\x0a\x09ast sequenceNode ifNotNil: [ :sequence |\x0a\x09\x09sequence temps do: [ :each |\x0a\x09\x09\x09ctx defineLocal: each ] ].\x0a\x09\x09\x0a\x09aDictionary keysAndValuesDo: [ :key :value |\x0a\x09\x09ctx localAt: key put: value ].\x0a\x09\x0a\x09^ interpreter\x0a\x09\x09context: ctx;\x0a\x09\x09node: ast;\x0a\x09\x09enterNode;\x0a\x09\x09proceed;\x0a\x09\x09result",
- referencedClasses: ["ASTInterpreter", "AIContext"],
- messageSends: ["new", "parse:forClass:", "class", "receiver:", "interpreter:", "yourself", "ifNotNil:", "sequenceNode", "do:", "temps", "defineLocal:", "keysAndValuesDo:", "localAt:put:", "context:", "node:", "enterNode", "proceed", "result"]
- }),
- $globals.ASTInterpreterTest);
- $core.addMethod(
- $core.method({
- selector: "parse:",
- protocol: "parsing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($globals.Smalltalk)._parse_(aString);
- }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString},$globals.ASTInterpreterTest)});
- },
- args: ["aString"],
- source: "parse: aString\x0a\x09^ Smalltalk parse: aString",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:"]
- }),
- $globals.ASTInterpreterTest);
- $core.addMethod(
- $core.method({
- selector: "parse:forClass:",
- protocol: "parsing",
- fn: function (aString,aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._analyze_forClass_(self._parse_(aString),aClass);
- }, function($ctx1) {$ctx1.fill(self,"parse:forClass:",{aString:aString,aClass:aClass},$globals.ASTInterpreterTest)});
- },
- args: ["aString", "aClass"],
- source: "parse: aString forClass: aClass\x0a\x09^ self analyze: (self parse: aString) forClass: aClass",
- referencedClasses: [],
- messageSends: ["analyze:forClass:", "parse:"]
- }),
- $globals.ASTInterpreterTest);
- $core.addMethod(
- $core.method({
- selector: "should:receiver:return:",
- protocol: "testing",
- fn: function (aString,anObject,aResult){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@receiver"]=anObject;
- return self._assert_equals_(self._interpret_receiver_withArguments_(aString,self["@receiver"],$globals.HashedCollection._newFromPairs_([])),aResult);
- }, function($ctx1) {$ctx1.fill(self,"should:receiver:return:",{aString:aString,anObject:anObject,aResult:aResult},$globals.ASTInterpreterTest)});
- },
- args: ["aString", "anObject", "aResult"],
- source: "should: aString receiver: anObject return: aResult\x0a\x09receiver := anObject.\x0a\x09\x0a\x09^ self \x0a\x09\x09assert: (self interpret: aString receiver: receiver withArguments: #{})\x0a\x09\x09equals: aResult",
- referencedClasses: [],
- messageSends: ["assert:equals:", "interpret:receiver:withArguments:"]
- }),
- $globals.ASTInterpreterTest);
- $core.addClass("ASTDebuggerTest", $globals.ASTInterpreterTest, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "interpret:receiver:withArguments:",
- protocol: "private",
- fn: function (aString,anObject,aDictionary){
- var self=this;
- var ctx,ast,debugger_;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$receiver;
- $1=$recv($globals.AIContext)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._receiver_(anObject);
- $recv($1)._interpreter_($recv($globals.ASTInterpreter)._new());
- ctx=$recv($1)._yourself();
- ast=self._parse_forClass_(aString,$recv(anObject)._class());
- $2=$recv(ast)._sequenceNode();
- if(($receiver = $2) == null || $receiver.isNil){
- $2;
- } else {
- var sequence;
- sequence=$receiver;
- $recv($recv(sequence)._temps())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(ctx)._defineLocal_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- }
- $recv(aDictionary)._keysAndValuesDo_((function(key,value){
- return $core.withContext(function($ctx2) {
- return $recv(ctx)._localAt_put_(key,value);
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,3)});
- }));
- $3=$recv(ctx)._interpreter();
- $ctx1.sendIdx["interpreter"]=1;
- $recv($3)._context_(ctx);
- $ctx1.sendIdx["context:"]=1;
- $4=$recv(ctx)._interpreter();
- $recv($4)._node_(ast);
- $recv($4)._enterNode();
- debugger_=$recv($globals.ASTDebugger)._context_(ctx);
- $5=debugger_;
- $recv($5)._proceed();
- return $recv($5)._result();
- }, function($ctx1) {$ctx1.fill(self,"interpret:receiver:withArguments:",{aString:aString,anObject:anObject,aDictionary:aDictionary,ctx:ctx,ast:ast,debugger_:debugger_},$globals.ASTDebuggerTest)});
- },
- args: ["aString", "anObject", "aDictionary"],
- source: "interpret: aString receiver: anObject withArguments: aDictionary\x0a\x09| ctx ast debugger |\x0a\x09\x0a\x09ctx := AIContext new\x0a\x09\x09receiver: anObject;\x0a\x09\x09interpreter: ASTInterpreter new;\x0a\x09\x09yourself.\x0a\x09ast := self parse: aString forClass: anObject class.\x0a\x09\x09\x0a\x09\x22Define locals for the context\x22\x0a\x09ast sequenceNode ifNotNil: [ :sequence |\x0a\x09\x09sequence temps do: [ :each |\x0a\x09\x09\x09ctx defineLocal: each ] ].\x0a\x09\x0a\x09aDictionary keysAndValuesDo: [ :key :value |\x0a\x09\x09ctx localAt: key put: value ].\x0a\x09ctx interpreter context: ctx.\x0a\x09\x0a\x09ctx interpreter node: ast; enterNode.\x0a\x09\x0a\x09debugger := ASTDebugger context: ctx.\x0a\x09\x0a\x09^ debugger \x0a\x09\x09proceed; \x0a\x09\x09result",
- referencedClasses: ["AIContext", "ASTInterpreter", "ASTDebugger"],
- messageSends: ["receiver:", "new", "interpreter:", "yourself", "parse:forClass:", "class", "ifNotNil:", "sequenceNode", "do:", "temps", "defineLocal:", "keysAndValuesDo:", "localAt:put:", "context:", "interpreter", "node:", "enterNode", "proceed", "result"]
- }),
- $globals.ASTDebuggerTest);
- $core.addClass("InliningCodeGeneratorTest", $globals.CodeGeneratorTest, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "codeGeneratorClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.InliningCodeGenerator;
- },
- args: [],
- source: "codeGeneratorClass\x0a\x09^ InliningCodeGenerator",
- referencedClasses: ["InliningCodeGenerator"],
- messageSends: []
- }),
- $globals.InliningCodeGeneratorTest);
- $core.addClass("ScopeVarTest", $globals.TestCase, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "testClassRefVar",
- protocol: "tests",
- fn: function (){
- var self=this;
- var node;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv($globals.VariableNode)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._value_("Object");
- node=$recv($1)._yourself();
- $2=$recv($globals.SemanticAnalyzer)._new();
- $ctx1.sendIdx["new"]=2;
- $recv($2)._pushScope_($recv($globals.MethodLexicalScope)._new());
- $recv($2)._visit_(node);
- self._assert_($recv($recv(node)._binding())._isClassRefVar());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testClassRefVar",{node:node},$globals.ScopeVarTest)});
- },
- args: [],
- source: "testClassRefVar\x0a\x09| node |\x0a\x09node := VariableNode new\x0a\x09\x09value: 'Object';\x0a\x09\x09yourself.\x0a\x09SemanticAnalyzer new \x0a\x09\x09pushScope: MethodLexicalScope new;\x0a\x09\x09visit: node.\x0a\x09self assert: node binding isClassRefVar",
- referencedClasses: ["VariableNode", "SemanticAnalyzer", "MethodLexicalScope"],
- messageSends: ["value:", "new", "yourself", "pushScope:", "visit:", "assert:", "isClassRefVar", "binding"]
- }),
- $globals.ScopeVarTest);
- $core.addMethod(
- $core.method({
- selector: "testInstanceVar",
- protocol: "tests",
- fn: function (){
- var self=this;
- var node,scope;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.VariableNode)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._value_("bzzz");
- node=$recv($1)._yourself();
- scope=$recv($globals.MethodLexicalScope)._new();
- $recv(scope)._addIVar_("bzzz");
- self._assert_($recv($recv(scope)._bindingFor_(node))._isInstanceVar());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testInstanceVar",{node:node,scope:scope},$globals.ScopeVarTest)});
- },
- args: [],
- source: "testInstanceVar\x0a\x09| node scope |\x0a\x09node := VariableNode new\x0a\x09\x09value: 'bzzz';\x0a\x09\x09yourself.\x0a\x09scope := MethodLexicalScope new.\x0a\x09scope addIVar: 'bzzz'.\x0a\x09self assert: (scope bindingFor: node) isInstanceVar",
- referencedClasses: ["VariableNode", "MethodLexicalScope"],
- messageSends: ["value:", "new", "yourself", "addIVar:", "assert:", "isInstanceVar", "bindingFor:"]
- }),
- $globals.ScopeVarTest);
- $core.addMethod(
- $core.method({
- selector: "testPseudoVar",
- protocol: "tests",
- fn: function (){
- var self=this;
- var node,pseudoVars;
- return $core.withContext(function($ctx1) {
- var $1;
- pseudoVars=["self", "super", "true", "false", "nil"];
- $recv(pseudoVars)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv($globals.VariableNode)._new();
- $ctx2.sendIdx["new"]=1;
- $recv($1)._value_(each);
- node=$recv($1)._yourself();
- node;
- return self._assert_($recv($recv($recv($globals.MethodLexicalScope)._new())._bindingFor_(node))._isPseudoVar());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPseudoVar",{node:node,pseudoVars:pseudoVars},$globals.ScopeVarTest)});
- },
- args: [],
- source: "testPseudoVar\x0a\x09| node pseudoVars |\x0a\x09pseudoVars := #('self' 'super' 'true' 'false' 'nil').\x0a\x09pseudoVars do: [:each |\x0a\x09\x09node := VariableNode new\x0a\x09\x09value: each;\x0a\x09\x09yourself.\x0a\x09\x09self assert: (MethodLexicalScope new bindingFor: node) isPseudoVar]",
- referencedClasses: ["VariableNode", "MethodLexicalScope"],
- messageSends: ["do:", "value:", "new", "yourself", "assert:", "isPseudoVar", "bindingFor:"]
- }),
- $globals.ScopeVarTest);
- $core.addMethod(
- $core.method({
- selector: "testTempVar",
- protocol: "tests",
- fn: function (){
- var self=this;
- var node,scope;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.VariableNode)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._value_("bzzz");
- node=$recv($1)._yourself();
- scope=$recv($globals.MethodLexicalScope)._new();
- $recv(scope)._addTemp_("bzzz");
- self._assert_($recv($recv(scope)._bindingFor_(node))._isTempVar());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTempVar",{node:node,scope:scope},$globals.ScopeVarTest)});
- },
- args: [],
- source: "testTempVar\x0a\x09| node scope |\x0a\x09node := VariableNode new\x0a\x09\x09value: 'bzzz';\x0a\x09\x09yourself.\x0a\x09scope := MethodLexicalScope new.\x0a\x09scope addTemp: 'bzzz'.\x0a\x09self assert: (scope bindingFor: node) isTempVar",
- referencedClasses: ["VariableNode", "MethodLexicalScope"],
- messageSends: ["value:", "new", "yourself", "addTemp:", "assert:", "isTempVar", "bindingFor:"]
- }),
- $globals.ScopeVarTest);
- $core.addMethod(
- $core.method({
- selector: "testUnknownVar",
- protocol: "tests",
- fn: function (){
- var self=this;
- var node;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.VariableNode)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._value_("bzzz");
- node=$recv($1)._yourself();
- self._assert_($recv($recv($recv($globals.MethodLexicalScope)._new())._bindingFor_(node))._isNil());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testUnknownVar",{node:node},$globals.ScopeVarTest)});
- },
- args: [],
- source: "testUnknownVar\x0a\x09| node |\x0a\x09node := VariableNode new\x0a\x09\x09value: 'bzzz';\x0a\x09\x09yourself.\x0a\x09self assert: (MethodLexicalScope new bindingFor: node) isNil",
- referencedClasses: ["VariableNode", "MethodLexicalScope"],
- messageSends: ["value:", "new", "yourself", "assert:", "isNil", "bindingFor:"]
- }),
- $globals.ScopeVarTest);
- $core.addClass("SemanticAnalyzerTest", $globals.TestCase, ["analyzer"], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@analyzer"]=$recv($globals.SemanticAnalyzer)._on_($globals.Object);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "setUp\x0a\x09analyzer := SemanticAnalyzer on: Object",
- referencedClasses: ["SemanticAnalyzer", "Object"],
- messageSends: ["on:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testAssignment",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo self := 1";
- ast=$recv($globals.Smalltalk)._parse_(src);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@analyzer"])._visit_(ast);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.InvalidAssignmentError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAssignment",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testAssignment\x0a\x09| src ast |\x0a\x0a\x09src := 'foo self := 1'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09self should: [analyzer visit: ast] raise: InvalidAssignmentError",
- referencedClasses: ["Smalltalk", "InvalidAssignmentError"],
- messageSends: ["parse:", "should:raise:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testNonLocalReturn",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | a + 1. ^ a";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- self._deny_($recv($recv(ast)._scope())._hasNonLocalReturn());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNonLocalReturn",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testNonLocalReturn\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a | a + 1. ^ a'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast.\x0a\x0a\x09self deny: ast scope hasNonLocalReturn",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:", "deny:", "hasNonLocalReturn", "scope"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testNonLocalReturn2",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | a + 1. [ [ ^ a] ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- self._assert_($recv($recv(ast)._scope())._hasNonLocalReturn());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNonLocalReturn2",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testNonLocalReturn2\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a | a + 1. [ [ ^ a] ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast.\x0a\x0a\x09self assert: ast scope hasNonLocalReturn",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:", "assert:", "hasNonLocalReturn", "scope"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testScope",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- var $4,$3,$2,$1;
- src="foo | a | a + 1. [ | b | b := a ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- $4=$recv($recv($recv(ast)._dagChildren())._first())._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- $3=$recv($4)._last();
- $2=$recv($3)._scope();
- $ctx1.sendIdx["scope"]=1;
- $1=$recv($2).__eq_eq($recv(ast)._scope());
- self._deny_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testScope",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testScope\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a | a + 1. [ | b | b := a ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast.\x0a\x0a\x09self deny: ast dagChildren first dagChildren last scope == ast scope.",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:", "deny:", "==", "scope", "last", "dagChildren", "first"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testScope2",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- var $8,$7,$6,$5,$4,$3,$2,$1;
- src="foo | a | a + 1. [ [ | b | b := a ] ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- $8=$recv($recv($recv(ast)._dagChildren())._first())._dagChildren();
- $ctx1.sendIdx["dagChildren"]=3;
- $7=$recv($8)._last();
- $6=$recv($7)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=2;
- $5=$recv($6)._first();
- $ctx1.sendIdx["first"]=2;
- $4=$recv($5)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- $3=$recv($4)._first();
- $ctx1.sendIdx["first"]=1;
- $2=$recv($3)._scope();
- $ctx1.sendIdx["scope"]=1;
- $1=$recv($2).__eq_eq($recv(ast)._scope());
- self._deny_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testScope2",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testScope2\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a | a + 1. [ [ | b | b := a ] ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast.\x0a\x0a\x09self deny: ast dagChildren first dagChildren last dagChildren first dagChildren first scope == ast scope.",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:", "deny:", "==", "scope", "first", "dagChildren", "last"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testScopeLevel",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- var $2,$1,$10,$9,$8,$7,$6,$5,$4,$3;
- src="foo | a | a + 1. [ [ | b | b := a ] ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- $2=$recv(ast)._scope();
- $ctx1.sendIdx["scope"]=1;
- $1=$recv($2)._scopeLevel();
- $ctx1.sendIdx["scopeLevel"]=1;
- self._assert_equals_($1,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $10=$recv($recv($recv(ast)._dagChildren())._first())._dagChildren();
- $ctx1.sendIdx["dagChildren"]=3;
- $9=$recv($10)._last();
- $8=$recv($9)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=2;
- $7=$recv($8)._first();
- $ctx1.sendIdx["first"]=2;
- $6=$recv($7)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- $5=$recv($6)._first();
- $ctx1.sendIdx["first"]=1;
- $4=$recv($5)._scope();
- $3=$recv($4)._scopeLevel();
- self._assert_equals_($3,(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testScopeLevel",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testScopeLevel\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a | a + 1. [ [ | b | b := a ] ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast.\x0a\x0a\x09self assert: ast scope scopeLevel equals: 1.\x0a\x09self assert: ast dagChildren first dagChildren last dagChildren first dagChildren first scope scopeLevel equals: 3",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:", "assert:equals:", "scopeLevel", "scope", "first", "dagChildren", "last"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testUnknownVariables",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | b + a";
- ast=$recv($globals.Smalltalk)._parse_(src);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@analyzer"])._visit_(ast);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.UnknownVariableError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testUnknownVariables",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testUnknownVariables\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a | b + a'.\x0a\x09ast := Smalltalk parse: src.\x0a\x0a\x09self should: [ analyzer visit: ast ] raise: UnknownVariableError",
- referencedClasses: ["Smalltalk", "UnknownVariableError"],
- messageSends: ["parse:", "should:raise:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testUnknownVariablesWithScope",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a b | [ c + 1. [ a + 1. d + 1 ]]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@analyzer"])._visit_(ast);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.UnknownVariableError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testUnknownVariablesWithScope",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testUnknownVariablesWithScope\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a b | [ c + 1. [ a + 1. d + 1 ]]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09\x0a\x09self should: [ analyzer visit: ast ] raise: UnknownVariableError",
- referencedClasses: ["Smalltalk", "UnknownVariableError"],
- messageSends: ["parse:", "should:raise:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testVariableShadowing",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | a + 1";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testVariableShadowing",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testVariableShadowing\x0a\x09| src ast |\x0a\x09src := 'foo | a | a + 1'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testVariableShadowing2",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | a + 1. [ | a | a := 2 ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@analyzer"])._visit_(ast);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.ShadowingVariableError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testVariableShadowing2",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testVariableShadowing2\x0a\x09| src ast |\x0a\x09src := 'foo | a | a + 1. [ | a | a := 2 ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09self should: [analyzer visit: ast] raise: ShadowingVariableError",
- referencedClasses: ["Smalltalk", "ShadowingVariableError"],
- messageSends: ["parse:", "should:raise:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testVariableShadowing3",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | a + 1. [ | b | b := 2 ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testVariableShadowing3",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testVariableShadowing3\x0a\x09| src ast |\x0a\x09src := 'foo | a | a + 1. [ | b | b := 2 ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testVariableShadowing4",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | a + 1. [ [ [ | b | b := 2 ] ] ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testVariableShadowing4",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testVariableShadowing4\x0a\x09| src ast |\x0a\x09src := 'foo | a | a + 1. [ [ [ | b | b := 2 ] ] ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testVariableShadowing5",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | a + 1. [ [ [ | a | a := 2 ] ] ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@analyzer"])._visit_(ast);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.ShadowingVariableError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testVariableShadowing5",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testVariableShadowing5\x0a\x09| src ast |\x0a\x09src := 'foo | a | a + 1. [ [ [ | a | a := 2 ] ] ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09self should: [analyzer visit: ast] raise: ShadowingVariableError",
- referencedClasses: ["Smalltalk", "ShadowingVariableError"],
- messageSends: ["parse:", "should:raise:", "visit:"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testVariablesLookup",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- var $7,$6,$5,$4,$3,$2,$1,$15,$14,$13,$12,$11,$10,$9,$16,$8,$27,$26,$25,$24,$23,$22,$21,$20,$19,$18,$17,$39,$38,$37,$36,$35,$34,$33,$32,$31,$30,$29,$42,$41,$40,$28;
- src="foo | a | a + 1. [ | b | b := a ]";
- ast=$recv($globals.Smalltalk)._parse_(src);
- $recv(self["@analyzer"])._visit_(ast);
- $7=$recv(ast)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=2;
- $6=$recv($7)._first();
- $ctx1.sendIdx["first"]=2;
- $5=$recv($6)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=1;
- $4=$recv($5)._first();
- $ctx1.sendIdx["first"]=1;
- $3=$recv($4)._receiver();
- $ctx1.sendIdx["receiver"]=1;
- $2=$recv($3)._binding();
- $ctx1.sendIdx["binding"]=1;
- $1=$recv($2)._isTempVar();
- $ctx1.sendIdx["isTempVar"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $15=$recv(ast)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=4;
- $14=$recv($15)._first();
- $ctx1.sendIdx["first"]=4;
- $13=$recv($14)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=3;
- $12=$recv($13)._first();
- $ctx1.sendIdx["first"]=3;
- $11=$recv($12)._receiver();
- $10=$recv($11)._binding();
- $ctx1.sendIdx["binding"]=2;
- $9=$recv($10)._scope();
- $ctx1.sendIdx["scope"]=1;
- $16=$recv(ast)._scope();
- $ctx1.sendIdx["scope"]=2;
- $8=$recv($9).__eq_eq($16);
- $ctx1.sendIdx["=="]=1;
- self._assert_($8);
- $ctx1.sendIdx["assert:"]=2;
- $27=$recv(ast)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=8;
- $26=$recv($27)._first();
- $ctx1.sendIdx["first"]=7;
- $25=$recv($26)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=7;
- $24=$recv($25)._last();
- $ctx1.sendIdx["last"]=1;
- $23=$recv($24)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=6;
- $22=$recv($23)._first();
- $ctx1.sendIdx["first"]=6;
- $21=$recv($22)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=5;
- $20=$recv($21)._first();
- $ctx1.sendIdx["first"]=5;
- $19=$recv($20)._left();
- $ctx1.sendIdx["left"]=1;
- $18=$recv($19)._binding();
- $ctx1.sendIdx["binding"]=3;
- $17=$recv($18)._isTempVar();
- self._assert_($17);
- $ctx1.sendIdx["assert:"]=3;
- $39=$recv(ast)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=12;
- $38=$recv($39)._first();
- $ctx1.sendIdx["first"]=10;
- $37=$recv($38)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=11;
- $36=$recv($37)._last();
- $ctx1.sendIdx["last"]=2;
- $35=$recv($36)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=10;
- $34=$recv($35)._first();
- $ctx1.sendIdx["first"]=9;
- $33=$recv($34)._dagChildren();
- $ctx1.sendIdx["dagChildren"]=9;
- $32=$recv($33)._first();
- $ctx1.sendIdx["first"]=8;
- $31=$recv($32)._left();
- $30=$recv($31)._binding();
- $29=$recv($30)._scope();
- $ctx1.sendIdx["scope"]=3;
- $42=$recv($recv($recv(ast)._dagChildren())._first())._dagChildren();
- $ctx1.sendIdx["dagChildren"]=13;
- $41=$recv($42)._last();
- $40=$recv($41)._scope();
- $28=$recv($29).__eq_eq($40);
- self._assert_($28);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testVariablesLookup",{src:src,ast:ast},$globals.SemanticAnalyzerTest)});
- },
- args: [],
- source: "testVariablesLookup\x0a\x09| src ast |\x0a\x0a\x09src := 'foo | a | a + 1. [ | b | b := a ]'.\x0a\x09ast := Smalltalk parse: src.\x0a\x09analyzer visit: ast.\x0a\x0a\x09\x22Binding for `a` in the message send\x22\x0a\x09self assert: ast dagChildren first dagChildren first receiver binding isTempVar.\x0a\x09self assert: ast dagChildren first dagChildren first receiver binding scope == ast scope.\x0a\x0a\x09\x22Binding for `b`\x22\x0a\x09self assert: ast dagChildren first dagChildren last dagChildren first dagChildren first left binding isTempVar.\x0a\x09self assert: ast dagChildren first dagChildren last dagChildren first dagChildren first left binding scope == ast dagChildren first dagChildren last scope.",
- referencedClasses: ["Smalltalk"],
- messageSends: ["parse:", "visit:", "assert:", "isTempVar", "binding", "receiver", "first", "dagChildren", "==", "scope", "left", "last"]
- }),
- $globals.SemanticAnalyzerTest);
- $core.addClass("AISemanticAnalyzerTest", $globals.SemanticAnalyzerTest, [], "Compiler-Tests");
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$4,$2;
- $1=$recv($globals.AISemanticAnalyzer)._on_($globals.Object);
- $3=$recv($globals.AIContext)._new();
- $recv($3)._defineLocal_("local");
- $recv($3)._localAt_put_("local",(3));
- $4=$recv($3)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $2=$4;
- $recv($1)._context_($2);
- self["@analyzer"]=$recv($1)._yourself();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.AISemanticAnalyzerTest)});
- },
- args: [],
- source: "setUp\x0a\x09analyzer := (AISemanticAnalyzer on: Object)\x0a\x09\x09context: (AIContext new\x0a\x09\x09\x09defineLocal: 'local';\x0a\x09\x09\x09localAt: 'local' put: 3;\x0a\x09\x09\x09yourself);\x0a\x09\x09yourself",
- referencedClasses: ["AISemanticAnalyzer", "Object", "AIContext"],
- messageSends: ["context:", "on:", "defineLocal:", "new", "localAt:put:", "yourself"]
- }),
- $globals.AISemanticAnalyzerTest);
- $core.addMethod(
- $core.method({
- selector: "testContextVariables",
- protocol: "tests",
- fn: function (){
- var self=this;
- var src,ast;
- return $core.withContext(function($ctx1) {
- src="foo | a | local + a";
- ast=$recv($globals.Smalltalk)._parse_(src);
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@analyzer"])._visit_(ast);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.UnknownVariableError);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testContextVariables",{src:src,ast:ast},$globals.AISemanticAnalyzerTest)});
- },
- args: [],
- source: "testContextVariables\x0a\x09| src ast |\x0a\x09\x0a\x09src := 'foo | a | local + a'.\x0a\x09ast := Smalltalk parse: src.\x0a\x0a\x09self shouldnt: [ analyzer visit: ast ] raise: UnknownVariableError",
- referencedClasses: ["Smalltalk", "UnknownVariableError"],
- messageSends: ["parse:", "shouldnt:raise:", "visit:"]
- }),
- $globals.AISemanticAnalyzerTest);
- });
- define('amber_core/Kernel-Tests',["amber/boot", "amber_core/Kernel-Objects", "amber_core/SUnit"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Kernel-Tests");
- $core.packages["Kernel-Tests"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Kernel-Tests"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("AnnouncementSubscriptionTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testAddExtensionMethod",
- protocol: "tests",
- fn: function (){
- var self=this;
- var method,dirty;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5,$8,$7,$6,$9,$10;
- $2=self._class();
- $ctx1.sendIdx["class"]=1;
- $1=$recv($2)._package();
- $ctx1.sendIdx["package"]=1;
- dirty=$recv($1)._isDirty();
- $ctx1.sendIdx["isDirty"]=1;
- $4=self._class();
- $ctx1.sendIdx["class"]=2;
- $3=$recv($4)._package();
- $ctx1.sendIdx["package"]=2;
- $recv($3)._beClean();
- $5=self._class();
- $ctx1.sendIdx["class"]=3;
- method=$recv($5)._compile_protocol_("doNothing","**not-a-package");
- $8=self._class();
- $ctx1.sendIdx["class"]=4;
- $7=$recv($8)._package();
- $ctx1.sendIdx["package"]=3;
- $6=$recv($7)._isDirty();
- self._deny_($6);
- $9=self._class();
- $ctx1.sendIdx["class"]=5;
- $recv($9)._removeCompiledMethod_(method);
- $10=dirty;
- if($core.assert($10)){
- $recv($recv(self._class())._package())._beDirty();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddExtensionMethod",{method:method,dirty:dirty},$globals.AnnouncementSubscriptionTest)});
- },
- args: [],
- source: "testAddExtensionMethod\x0a\x09| method dirty |\x0a\x09dirty := self class package isDirty.\x0a\x09self class package beClean.\x0a\x09method := self class compile: 'doNothing' protocol: '**not-a-package'.\x0a\x09self deny: self class package isDirty.\x0a\x09\x0a\x09self class removeCompiledMethod: method.\x0a\x09dirty ifTrue: [ self class package beDirty ]",
- referencedClasses: [],
- messageSends: ["isDirty", "package", "class", "beClean", "compile:protocol:", "deny:", "removeCompiledMethod:", "ifTrue:", "beDirty"]
- }),
- $globals.AnnouncementSubscriptionTest);
- $core.addMethod(
- $core.method({
- selector: "testHandlesAnnouncement",
- protocol: "tests",
- fn: function (){
- var self=this;
- var subscription,announcementClass1,announcementClass2,classBuilder;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- classBuilder=$recv($globals.ClassBuilder)._new();
- $ctx1.sendIdx["new"]=1;
- announcementClass1=$recv(classBuilder)._basicAddSubclassOf_named_instanceVariableNames_package_($globals.SystemAnnouncement,"TestAnnouncement1",[],"Kernel-Tests");
- subscription=$recv($recv($globals.AnnouncementSubscription)._new())._announcementClass_($globals.SystemAnnouncement);
- $1=$recv(subscription)._handlesAnnouncement_($globals.SystemAnnouncement);
- $ctx1.sendIdx["handlesAnnouncement:"]=1;
- self._assert_equals_($1,true);
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=$recv(subscription)._handlesAnnouncement_(announcementClass1);
- $ctx1.sendIdx["handlesAnnouncement:"]=2;
- self._assert_equals_($2,true);
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv(subscription)._handlesAnnouncement_($globals.Object),false);
- $recv(classBuilder)._basicRemoveClass_(announcementClass1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testHandlesAnnouncement",{subscription:subscription,announcementClass1:announcementClass1,announcementClass2:announcementClass2,classBuilder:classBuilder},$globals.AnnouncementSubscriptionTest)});
- },
- args: [],
- source: "testHandlesAnnouncement\x0a\x09| subscription announcementClass1 announcementClass2 classBuilder |\x0a\x09\x0a\x09classBuilder := ClassBuilder new.\x0a\x09announcementClass1 := classBuilder basicAddSubclassOf: SystemAnnouncement named: 'TestAnnouncement1' instanceVariableNames: #() package: 'Kernel-Tests'.\x0a\x09\x0a\x09subscription := AnnouncementSubscription new announcementClass: SystemAnnouncement.\x0a\x09\x22Test whether the same class triggers the announcement\x22\x0a\x09self assert: (subscription handlesAnnouncement: SystemAnnouncement) equals: true.\x0a\x09\x22Test whether a subclass triggers the announcement\x22\x0a\x09self assert: (subscription handlesAnnouncement: announcementClass1) equals: true.\x0a\x09\x22Test whether an unrelated class does not trigger the announcement\x22\x0a\x09self assert: (subscription handlesAnnouncement: Object) equals: false.\x0a\x09\x0a\x09classBuilder basicRemoveClass: announcementClass1.",
- referencedClasses: ["ClassBuilder", "SystemAnnouncement", "AnnouncementSubscription", "Object"],
- messageSends: ["new", "basicAddSubclassOf:named:instanceVariableNames:package:", "announcementClass:", "assert:equals:", "handlesAnnouncement:", "basicRemoveClass:"]
- }),
- $globals.AnnouncementSubscriptionTest);
- $core.addClass("AnnouncerTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testOnDo",
- protocol: "tests",
- fn: function (){
- var self=this;
- var counter,announcer;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- counter=(0);
- announcer=$recv($globals.Announcer)._new();
- $ctx1.sendIdx["new"]=1;
- $recv(announcer)._on_do_($globals.SystemAnnouncement,(function(){
- return $core.withContext(function($ctx2) {
- counter=$recv(counter).__plus((1));
- return counter;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $1=announcer;
- $2=$recv($globals.SystemAnnouncement)._new();
- $ctx1.sendIdx["new"]=2;
- $recv($1)._announce_($2);
- $ctx1.sendIdx["announce:"]=1;
- self._assert_equals_(counter,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(announcer)._announce_($recv($globals.SystemAnnouncement)._new());
- self._assert_equals_(counter,(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testOnDo",{counter:counter,announcer:announcer},$globals.AnnouncerTest)});
- },
- args: [],
- source: "testOnDo\x0a\x09| counter announcer |\x0a\x09\x0a\x09counter := 0.\x0a\x09announcer := Announcer new.\x0a\x09announcer on: SystemAnnouncement do: [ counter := counter + 1 ].\x0a\x0a\x09announcer announce: (SystemAnnouncement new).\x0a\x09self assert: counter equals: 1.\x0a\x0a\x09announcer announce: (SystemAnnouncement new).\x0a\x09self assert: counter equals: 2.",
- referencedClasses: ["Announcer", "SystemAnnouncement"],
- messageSends: ["new", "on:do:", "+", "announce:", "assert:equals:"]
- }),
- $globals.AnnouncerTest);
- $core.addMethod(
- $core.method({
- selector: "testOnDoFor",
- protocol: "tests",
- fn: function (){
- var self=this;
- var counter,announcer;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- counter=(0);
- announcer=$recv($globals.Announcer)._new();
- $ctx1.sendIdx["new"]=1;
- $recv(announcer)._on_do_for_($globals.SystemAnnouncement,(function(){
- return $core.withContext(function($ctx2) {
- counter=$recv(counter).__plus((1));
- return counter;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),self);
- $1=announcer;
- $2=$recv($globals.SystemAnnouncement)._new();
- $ctx1.sendIdx["new"]=2;
- $recv($1)._announce_($2);
- $ctx1.sendIdx["announce:"]=1;
- self._assert_equals_(counter,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $3=announcer;
- $4=$recv($globals.SystemAnnouncement)._new();
- $ctx1.sendIdx["new"]=3;
- $recv($3)._announce_($4);
- $ctx1.sendIdx["announce:"]=2;
- self._assert_equals_(counter,(2));
- $ctx1.sendIdx["assert:equals:"]=2;
- $recv(announcer)._unsubscribe_(self);
- $recv(announcer)._announce_($recv($globals.SystemAnnouncement)._new());
- self._assert_equals_(counter,(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testOnDoFor",{counter:counter,announcer:announcer},$globals.AnnouncerTest)});
- },
- args: [],
- source: "testOnDoFor\x0a\x09| counter announcer |\x0a\x09\x0a\x09counter := 0.\x0a\x09announcer := Announcer new.\x0a\x09announcer on: SystemAnnouncement do: [ counter := counter + 1 ] for: self.\x0a\x0a\x09announcer announce: (SystemAnnouncement new).\x0a\x09self assert: counter equals: 1.\x0a\x0a\x09announcer announce: (SystemAnnouncement new).\x0a\x09self assert: counter equals: 2.\x0a\x09\x0a\x09announcer unsubscribe: self.\x0a\x09\x0a\x09announcer announce: (SystemAnnouncement new).\x0a\x09self assert: counter equals: 2.",
- referencedClasses: ["Announcer", "SystemAnnouncement"],
- messageSends: ["new", "on:do:for:", "+", "announce:", "assert:equals:", "unsubscribe:"]
- }),
- $globals.AnnouncerTest);
- $core.addMethod(
- $core.method({
- selector: "testOnDoOnce",
- protocol: "tests",
- fn: function (){
- var self=this;
- var counter,announcer;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- counter=(0);
- announcer=$recv($globals.Announcer)._new();
- $ctx1.sendIdx["new"]=1;
- $recv(announcer)._on_doOnce_($globals.SystemAnnouncement,(function(){
- return $core.withContext(function($ctx2) {
- counter=$recv(counter).__plus((1));
- return counter;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $1=announcer;
- $2=$recv($globals.SystemAnnouncement)._new();
- $ctx1.sendIdx["new"]=2;
- $recv($1)._announce_($2);
- $ctx1.sendIdx["announce:"]=1;
- self._assert_equals_(counter,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(announcer)._announce_($recv($globals.SystemAnnouncement)._new());
- self._assert_equals_(counter,(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testOnDoOnce",{counter:counter,announcer:announcer},$globals.AnnouncerTest)});
- },
- args: [],
- source: "testOnDoOnce\x0a\x09| counter announcer |\x0a\x09\x0a\x09counter := 0.\x0a\x09announcer := Announcer new.\x0a\x09announcer on: SystemAnnouncement doOnce: [ counter := counter + 1 ].\x0a\x0a\x09announcer announce: (SystemAnnouncement new).\x0a\x09self assert: counter equals: 1.\x0a\x0a\x09announcer announce: (SystemAnnouncement new).\x0a\x09self assert: counter equals: 1.",
- referencedClasses: ["Announcer", "SystemAnnouncement"],
- messageSends: ["new", "on:doOnce:", "+", "announce:", "assert:equals:"]
- }),
- $globals.AnnouncerTest);
- $core.addClass("BlockClosureTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "localReturnOnDoCatch",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $early={};
- try {
- $recv((function(){
- throw $early=[(2)];
- }))._on_do_($globals.Error,(function(){
- }));
- return (3);
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"localReturnOnDoCatch",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "localReturnOnDoCatch\x0a [ ^ 2 ] on: Error do: [].\x0a ^ 3",
- referencedClasses: ["Error"],
- messageSends: ["on:do:"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "localReturnOnDoMiss",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $early={};
- try {
- $recv((function(){
- throw $early=[(2)];
- }))._on_do_($globals.Class,(function(){
- }));
- return (3);
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"localReturnOnDoMiss",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "localReturnOnDoMiss\x0a [ ^ 2 ] on: Class do: [].\x0a ^ 3",
- referencedClasses: ["Class"],
- messageSends: ["on:do:"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testCanClearInterval",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv($globals.Error)._new())._signal();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }))._valueWithInterval_((0)))._clearInterval();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCanClearInterval",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testCanClearInterval\x0a\x09self shouldnt: [ ([ Error new signal ] valueWithInterval: 0) clearInterval ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["shouldnt:raise:", "clearInterval", "valueWithInterval:", "signal", "new"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testCanClearTimeout",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv($globals.Error)._new())._signal();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }))._valueWithTimeout_((0)))._clearTimeout();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCanClearTimeout",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testCanClearTimeout\x0a\x09self shouldnt: [ ([ Error new signal ] valueWithTimeout: 0) clearTimeout ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["shouldnt:raise:", "clearTimeout", "valueWithTimeout:", "signal", "new"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testCompiledSource",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv($recv((function(){
- return $core.withContext(function($ctx2) {
- return (1).__plus((1));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._compiledSource())._includesSubString_("function"));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCompiledSource",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testCompiledSource\x0a\x09self assert: ([ 1+1 ] compiledSource includesSubString: 'function')",
- referencedClasses: [],
- messageSends: ["assert:", "includesSubString:", "compiledSource", "+"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testCurrySelf",
- protocol: "tests",
- fn: function (){
- var self=this;
- var curriedMethod,array;
- return $core.withContext(function($ctx1) {
- curriedMethod=$recv($recv((function(selfarg,x){
- return $core.withContext(function($ctx2) {
- return $recv(selfarg)._at_(x);
- }, function($ctx2) {$ctx2.fillBlock({selfarg:selfarg,x:x},$ctx1,1)});
- }))._currySelf())._asCompiledMethod_("foo:");
- array=[(3), (1), (4)];
- $recv($recv($globals.ClassBuilder)._new())._installMethod_forClass_protocol_(curriedMethod,$globals.Array,"**test helper");
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._assert_equals_($recv(array)._foo_((2)),(1));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }))._ensure_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($globals.Array)._removeCompiledMethod_(curriedMethod);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCurrySelf",{curriedMethod:curriedMethod,array:array},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testCurrySelf\x0a\x09| curriedMethod array |\x0a\x09curriedMethod := [ :selfarg :x | selfarg at: x ] currySelf asCompiledMethod: 'foo:'.\x0a\x09array := #(3 1 4).\x0a\x09ClassBuilder new installMethod: curriedMethod forClass: Array protocol: '**test helper'.\x0a\x09[ self assert: (array foo: 2) equals: 1 ]\x0a\x09ensure: [ Array removeCompiledMethod: curriedMethod ]",
- referencedClasses: ["ClassBuilder", "Array"],
- messageSends: ["asCompiledMethod:", "currySelf", "at:", "installMethod:forClass:protocol:", "new", "ensure:", "assert:equals:", "foo:", "removeCompiledMethod:"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testEnsure",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv((function(){
- return (3);
- }))._ensure_((function(){
- return (4);
- })),(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEnsure",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testEnsure\x0a\x09self assert: ([ 3 ] ensure: [ 4 ]) equals: 3",
- referencedClasses: [],
- messageSends: ["assert:equals:", "ensure:"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testEnsureRaises",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv((function(){
- return $core.withContext(function($ctx3) {
- return $recv($recv($globals.Error)._new())._signal();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }))._ensure_((function(){
- return true;
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEnsureRaises",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testEnsureRaises\x0a\x09self should: [ [Error new signal ] ensure: [ true ]] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "ensure:", "signal", "new"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testExceptionSemantics",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._timeout_((100));
- $recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- return $recv((function(){
- return $core.withContext(function($ctx3) {
- self._assert_(true);
- $recv($globals.Error)._signal();
- self._deny_(true);
- return self._finished();
- $ctx3.sendIdx["finished"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }))._on_do_($globals.Error,(function(ex){
- return $core.withContext(function($ctx3) {
- return self._finished();
- }, function($ctx3) {$ctx3.fillBlock({ex:ex},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- })))._valueWithTimeout_((0));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testExceptionSemantics",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testExceptionSemantics\x0a\x09\x22See https://lolg.it/amber/amber/issues/314\x22\x0a\x09self timeout: 100.\x0a\x09\x0a\x09(self async: [\x0a\x09\x09[\x0a\x09\x09\x09self assert: true.\x0a\x09\x09\x09Error signal.\x0a\x09\x09\x09\x22The following should *not* be run\x22\x0a\x09\x09\x09self deny: true.\x0a\x09\x09\x09self finished.\x0a\x09\x09] on: Error do: [ :ex | self finished ]\x0a\x09]) valueWithTimeout: 0",
- referencedClasses: ["Error"],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "on:do:", "assert:", "signal", "deny:", "finished"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testLocalReturnOnDoCatch",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_(self._localReturnOnDoCatch(),(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLocalReturnOnDoCatch",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testLocalReturnOnDoCatch\x0a\x09self assert: self localReturnOnDoCatch equals: 2",
- referencedClasses: [],
- messageSends: ["assert:equals:", "localReturnOnDoCatch"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testLocalReturnOnDoMiss",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_(self._localReturnOnDoMiss(),(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLocalReturnOnDoMiss",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testLocalReturnOnDoMiss\x0a\x09self assert: self localReturnOnDoMiss equals: 2",
- referencedClasses: [],
- messageSends: ["assert:equals:", "localReturnOnDoMiss"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testNewWithValues",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- function TestConstructor(arg1, arg2, arg3) {}
- TestConstructor.prototype.name = "theTestPrototype";
- var wrappedConstructor = $recv(TestConstructor);
- var result = wrappedConstructor._newWithValues_([1, 2, 3]);
- self._assert_(result instanceof TestConstructor);
- self._assert_equals_(result.name, "theTestPrototype");
- /* newWithValues: cannot help if the argument list is wrong, and should warn that a mistake was made. */
- self._should_raise_(function () {wrappedConstructor._newWithValues_("single argument");}, $globals.Error);;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNewWithValues",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testNewWithValues\x0a<inlineJS: '\x0a\x09function TestConstructor(arg1, arg2, arg3) {}\x0a\x09TestConstructor.prototype.name = \x22theTestPrototype\x22;\x0a\x0a\x09var wrappedConstructor = $recv(TestConstructor);\x0a\x09var result = wrappedConstructor._newWithValues_([1, 2, 3]);\x0a\x09self._assert_(result instanceof TestConstructor);\x0a\x09self._assert_equals_(result.name, \x22theTestPrototype\x22);\x0a\x0a\x09/* newWithValues: cannot help if the argument list is wrong, and should warn that a mistake was made. */\x0a\x09self._should_raise_(function () {wrappedConstructor._newWithValues_(\x22single argument\x22);}, $globals.Error);\x0a'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testNumArgs",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv((function(){
- }))._numArgs();
- $ctx1.sendIdx["numArgs"]=1;
- self._assert_equals_($1,(0));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv((function(a,b){
- }))._numArgs(),(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNumArgs",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testNumArgs\x0a\x09self assert: [] numArgs equals: 0.\x0a\x09self assert: [ :a :b | ] numArgs equals: 2",
- referencedClasses: [],
- messageSends: ["assert:equals:", "numArgs"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testOnDo",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv($globals.Error)._new())._signal();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(ex){
- return true;
- })));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testOnDo",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testOnDo\x0a\x09self assert: ([ Error new signal ] on: Error do: [ :ex | true ])",
- referencedClasses: ["Error"],
- messageSends: ["assert:", "on:do:", "signal", "new"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testValue",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv((function(){
- return $core.withContext(function($ctx2) {
- return (1).__plus((1));
- $ctx2.sendIdx["+"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._value();
- $ctx1.sendIdx["value"]=1;
- self._assert_equals_($1,(2));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv((function(x){
- return $core.withContext(function($ctx2) {
- return $recv(x).__plus((1));
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,2)});
- }))._value_((2)),(3));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv((function(x,y){
- return $core.withContext(function($ctx2) {
- return $recv(x).__star(y);
- }, function($ctx2) {$ctx2.fillBlock({x:x,y:y},$ctx1,3)});
- }))._value_value_((2),(4)),(8));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_($recv((function(a,b,c){
- return (1);
- }))._value(),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testValue",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testValue\x0a\x09self assert: ([ 1+1 ] value) equals: 2.\x0a\x09self assert: ([ :x | x +1 ] value: 2) equals: 3.\x0a\x09self assert: ([ :x :y | x*y ] value: 2 value: 4) equals: 8.\x0a\x0a\x09\x22Arguments are optional in Amber. This isn't ANSI compliant.\x22\x0a\x0a\x09self assert: ([ :a :b :c | 1 ] value) equals: 1",
- referencedClasses: [],
- messageSends: ["assert:equals:", "value", "+", "value:", "value:value:", "*"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testValueWithPossibleArguments",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv((function(){
- return (1);
- }))._valueWithPossibleArguments_([(3), (4)]);
- $ctx1.sendIdx["valueWithPossibleArguments:"]=1;
- self._assert_equals_($1,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=$recv((function(a){
- return $core.withContext(function($ctx2) {
- return $recv(a).__plus((4));
- $ctx2.sendIdx["+"]=1;
- }, function($ctx2) {$ctx2.fillBlock({a:a},$ctx1,2)});
- }))._valueWithPossibleArguments_([(3), (4)]);
- $ctx1.sendIdx["valueWithPossibleArguments:"]=2;
- self._assert_equals_($2,(7));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv((function(a,b){
- return $core.withContext(function($ctx2) {
- return $recv(a).__plus(b);
- }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1,3)});
- }))._valueWithPossibleArguments_([(3), (4), (5)]),(7));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testValueWithPossibleArguments",{},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testValueWithPossibleArguments\x0a\x09self assert: ([ 1 ] valueWithPossibleArguments: #(3 4)) equals: 1.\x0a\x09self assert: ([ :a | a + 4 ] valueWithPossibleArguments: #(3 4)) equals: 7.\x0a\x09self assert: ([ :a :b | a + b ] valueWithPossibleArguments: #(3 4 5)) equals: 7.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "valueWithPossibleArguments:", "+"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testWhileFalse",
- protocol: "tests",
- fn: function (){
- var self=this;
- var i;
- return $core.withContext(function($ctx1) {
- i=(0);
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(i).__gt((5));
- $ctx2.sendIdx[">"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- i=$recv(i).__plus((1));
- $ctx2.sendIdx["+"]=1;
- return i;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- self._assert_equals_(i,(6));
- $ctx1.sendIdx["assert:equals:"]=1;
- i=(0);
- $recv((function(){
- return $core.withContext(function($ctx2) {
- i=$recv(i).__plus((1));
- i;
- return $recv(i).__gt((5));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }))._whileFalse();
- self._assert_equals_(i,(6));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testWhileFalse",{i:i},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testWhileFalse\x0a\x09| i |\x0a\x09i := 0.\x0a\x09[ i > 5 ] whileFalse: [ i := i + 1 ].\x0a\x09self assert: i equals: 6.\x0a\x0a\x09i := 0.\x0a\x09[ i := i + 1. i > 5 ] whileFalse.\x0a\x09self assert: i equals: 6",
- referencedClasses: [],
- messageSends: ["whileFalse:", ">", "+", "assert:equals:", "whileFalse"]
- }),
- $globals.BlockClosureTest);
- $core.addMethod(
- $core.method({
- selector: "testWhileTrue",
- protocol: "tests",
- fn: function (){
- var self=this;
- var i;
- return $core.withContext(function($ctx1) {
- i=(0);
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(i).__lt((5));
- $ctx2.sendIdx["<"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- i=$recv(i).__plus((1));
- $ctx2.sendIdx["+"]=1;
- return i;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- self._assert_equals_(i,(5));
- $ctx1.sendIdx["assert:equals:"]=1;
- i=(0);
- $recv((function(){
- return $core.withContext(function($ctx2) {
- i=$recv(i).__plus((1));
- i;
- return $recv(i).__lt((5));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }))._whileTrue();
- self._assert_equals_(i,(5));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testWhileTrue",{i:i},$globals.BlockClosureTest)});
- },
- args: [],
- source: "testWhileTrue\x0a\x09| i |\x0a\x09i := 0.\x0a\x09[ i < 5 ] whileTrue: [ i := i + 1 ].\x0a\x09self assert: i equals: 5.\x0a\x0a\x09i := 0.\x0a\x09[ i := i + 1. i < 5 ] whileTrue.\x0a\x09self assert: i equals: 5",
- referencedClasses: [],
- messageSends: ["whileTrue:", "<", "+", "assert:equals:", "whileTrue"]
- }),
- $globals.BlockClosureTest);
- $core.addClass("BooleanTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testEquality",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$8,$10,$9,$12,$11;
- $1=(0).__eq(false);
- $ctx1.sendIdx["="]=1;
- self._deny_($1);
- $ctx1.sendIdx["deny:"]=1;
- $2=false.__eq((0));
- $ctx1.sendIdx["="]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=2;
- $3="".__eq(false);
- $ctx1.sendIdx["="]=3;
- self._deny_($3);
- $ctx1.sendIdx["deny:"]=3;
- $4=false.__eq("");
- $ctx1.sendIdx["="]=4;
- self._deny_($4);
- $ctx1.sendIdx["deny:"]=4;
- $5=true.__eq(true);
- $ctx1.sendIdx["="]=5;
- self._assert_($5);
- $ctx1.sendIdx["assert:"]=1;
- $6=false.__eq(true);
- $ctx1.sendIdx["="]=6;
- self._deny_($6);
- $ctx1.sendIdx["deny:"]=5;
- $7=true.__eq(false);
- $ctx1.sendIdx["="]=7;
- self._deny_($7);
- $8=false.__eq(false);
- $ctx1.sendIdx["="]=8;
- self._assert_($8);
- $ctx1.sendIdx["assert:"]=2;
- $10=true._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $9=$recv($10).__eq(true);
- $ctx1.sendIdx["="]=9;
- self._assert_($9);
- $ctx1.sendIdx["assert:"]=3;
- $12=true._yourself();
- $ctx1.sendIdx["yourself"]=2;
- $11=$recv($12).__eq(true._yourself());
- self._assert_($11);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEquality",{},$globals.BooleanTest)});
- },
- args: [],
- source: "testEquality\x0a\x09\x22We're on top of JS...just be sure to check the basics!\x22\x0a\x0a\x09self deny: 0 = false.\x0a\x09self deny: false = 0.\x0a\x09self deny: '' = false.\x0a\x09self deny: false = ''.\x0a\x0a\x09self assert: (true = true).\x0a\x09self deny: false = true.\x0a\x09self deny: true = false.\x0a\x09self assert: (false = false).\x0a\x0a\x09\x22JS may do some type coercing after sending a message\x22\x0a\x09self assert: (true yourself = true).\x0a\x09self assert: (true yourself = true yourself)",
- referencedClasses: [],
- messageSends: ["deny:", "=", "assert:", "yourself"]
- }),
- $globals.BooleanTest);
- $core.addMethod(
- $core.method({
- selector: "testIdentity",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$8,$10,$9,$12,$11;
- $1=(0).__eq_eq(false);
- $ctx1.sendIdx["=="]=1;
- self._deny_($1);
- $ctx1.sendIdx["deny:"]=1;
- $2=false.__eq_eq((0));
- $ctx1.sendIdx["=="]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=2;
- $3="".__eq_eq(false);
- $ctx1.sendIdx["=="]=3;
- self._deny_($3);
- $ctx1.sendIdx["deny:"]=3;
- $4=false.__eq_eq("");
- $ctx1.sendIdx["=="]=4;
- self._deny_($4);
- $ctx1.sendIdx["deny:"]=4;
- $5=true.__eq_eq(true);
- $ctx1.sendIdx["=="]=5;
- self._assert_($5);
- $ctx1.sendIdx["assert:"]=1;
- $6=false.__eq_eq(true);
- $ctx1.sendIdx["=="]=6;
- self._deny_($6);
- $ctx1.sendIdx["deny:"]=5;
- $7=true.__eq_eq(false);
- $ctx1.sendIdx["=="]=7;
- self._deny_($7);
- $8=false.__eq_eq(false);
- $ctx1.sendIdx["=="]=8;
- self._assert_($8);
- $ctx1.sendIdx["assert:"]=2;
- $10=true._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $9=$recv($10).__eq_eq(true);
- $ctx1.sendIdx["=="]=9;
- self._assert_($9);
- $ctx1.sendIdx["assert:"]=3;
- $12=true._yourself();
- $ctx1.sendIdx["yourself"]=2;
- $11=$recv($12).__eq_eq(true._yourself());
- self._assert_($11);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIdentity",{},$globals.BooleanTest)});
- },
- args: [],
- source: "testIdentity\x0a\x09\x22We're on top of JS...just be sure to check the basics!\x22\x0a\x0a\x09self deny: 0 == false.\x0a\x09self deny: false == 0.\x0a\x09self deny: '' == false.\x0a\x09self deny: false == ''.\x0a\x0a\x09self assert: true == true.\x0a\x09self deny: false == true.\x0a\x09self deny: true == false.\x0a\x09self assert: false == false.\x0a\x0a\x09\x22JS may do some type coercing after sending a message\x22\x0a\x09self assert: true yourself == true.\x0a\x09self assert: true yourself == true yourself",
- referencedClasses: [],
- messageSends: ["deny:", "==", "assert:", "yourself"]
- }),
- $globals.BooleanTest);
- $core.addMethod(
- $core.method({
- selector: "testIfTrueIfFalse",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$8;
- if($core.assert(true)){
- $1="alternative block";
- }
- self._assert_equals_($1,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=1;
- if(!$core.assert(true)){
- $2="alternative block";
- }
- self._assert_equals_($2,nil);
- $ctx1.sendIdx["assert:equals:"]=2;
- if($core.assert(false)){
- $3="alternative block";
- }
- self._assert_equals_($3,nil);
- $ctx1.sendIdx["assert:equals:"]=3;
- if(!$core.assert(false)){
- $4="alternative block";
- }
- self._assert_equals_($4,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=4;
- if($core.assert(false)){
- $5="alternative block";
- } else {
- $5="alternative block2";
- }
- self._assert_equals_($5,"alternative block2");
- $ctx1.sendIdx["assert:equals:"]=5;
- if($core.assert(false)){
- $6="alternative block2";
- } else {
- $6="alternative block";
- }
- self._assert_equals_($6,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=6;
- if($core.assert(true)){
- $7="alternative block";
- } else {
- $7="alternative block2";
- }
- self._assert_equals_($7,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=7;
- if($core.assert(true)){
- $8="alternative block2";
- } else {
- $8="alternative block";
- }
- self._assert_equals_($8,"alternative block2");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIfTrueIfFalse",{},$globals.BooleanTest)});
- },
- args: [],
- source: "testIfTrueIfFalse\x0a\x0a\x09self assert: (true ifTrue: [ 'alternative block' ]) equals: 'alternative block'.\x0a\x09self assert: (true ifFalse: [ 'alternative block' ]) equals: nil.\x0a\x0a\x09self assert: (false ifTrue: [ 'alternative block' ]) equals: nil.\x0a\x09self assert: (false ifFalse: [ 'alternative block' ]) equals: 'alternative block'.\x0a\x0a\x09self assert: (false ifTrue: [ 'alternative block' ] ifFalse: [ 'alternative block2' ]) equals: 'alternative block2'.\x0a\x09self assert: (false ifFalse: [ 'alternative block' ] ifTrue: [ 'alternative block2' ]) equals: 'alternative block'.\x0a\x0a\x09self assert: (true ifTrue: [ 'alternative block' ] ifFalse: [ 'alternative block2' ]) equals: 'alternative block'.\x0a\x09self assert: (true ifFalse: [ 'alternative block' ] ifTrue: [ 'alternative block2' ]) equals: 'alternative block2'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "ifTrue:", "ifFalse:", "ifTrue:ifFalse:", "ifFalse:ifTrue:"]
- }),
- $globals.BooleanTest);
- $core.addMethod(
- $core.method({
- selector: "testIfTrueIfFalseWithBoxing",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$8,$7,$10,$9,$12,$11,$14,$13,$16,$15;
- $2=true._yourself();
- $ctx1.sendIdx["yourself"]=1;
- if($core.assert($2)){
- $1="alternative block";
- }
- self._assert_equals_($1,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=1;
- $4=true._yourself();
- $ctx1.sendIdx["yourself"]=2;
- if(!$core.assert($4)){
- $3="alternative block";
- }
- self._assert_equals_($3,nil);
- $ctx1.sendIdx["assert:equals:"]=2;
- $6=false._yourself();
- $ctx1.sendIdx["yourself"]=3;
- if($core.assert($6)){
- $5="alternative block";
- }
- self._assert_equals_($5,nil);
- $ctx1.sendIdx["assert:equals:"]=3;
- $8=false._yourself();
- $ctx1.sendIdx["yourself"]=4;
- if(!$core.assert($8)){
- $7="alternative block";
- }
- self._assert_equals_($7,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=4;
- $10=false._yourself();
- $ctx1.sendIdx["yourself"]=5;
- if($core.assert($10)){
- $9="alternative block";
- } else {
- $9="alternative block2";
- }
- self._assert_equals_($9,"alternative block2");
- $ctx1.sendIdx["assert:equals:"]=5;
- $12=false._yourself();
- $ctx1.sendIdx["yourself"]=6;
- if($core.assert($12)){
- $11="alternative block2";
- } else {
- $11="alternative block";
- }
- self._assert_equals_($11,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=6;
- $14=true._yourself();
- $ctx1.sendIdx["yourself"]=7;
- if($core.assert($14)){
- $13="alternative block";
- } else {
- $13="alternative block2";
- }
- self._assert_equals_($13,"alternative block");
- $ctx1.sendIdx["assert:equals:"]=7;
- $16=true._yourself();
- if($core.assert($16)){
- $15="alternative block2";
- } else {
- $15="alternative block";
- }
- self._assert_equals_($15,"alternative block2");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIfTrueIfFalseWithBoxing",{},$globals.BooleanTest)});
- },
- args: [],
- source: "testIfTrueIfFalseWithBoxing\x0a\x0a\x09self assert: (true yourself ifTrue: [ 'alternative block' ]) equals: 'alternative block'.\x0a\x09self assert: (true yourself ifFalse: [ 'alternative block' ]) equals: nil.\x0a\x0a\x09self assert: (false yourself ifTrue: [ 'alternative block' ]) equals: nil.\x0a\x09self assert: (false yourself ifFalse: [ 'alternative block' ]) equals: 'alternative block'.\x0a\x0a\x09self assert: (false yourself ifTrue: [ 'alternative block' ] ifFalse: [ 'alternative block2' ]) equals: 'alternative block2'.\x0a\x09self assert: (false yourself ifFalse: [ 'alternative block' ] ifTrue: [ 'alternative block2' ]) equals: 'alternative block'.\x0a\x0a\x09self assert: (true yourself ifTrue: [ 'alternative block' ] ifFalse: [ 'alternative block2' ]) equals: 'alternative block'.\x0a\x09self assert: (true yourself ifFalse: [ 'alternative block' ] ifTrue: [ 'alternative block2' ]) equals: 'alternative block2'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "ifTrue:", "yourself", "ifFalse:", "ifTrue:ifFalse:", "ifFalse:ifTrue:"]
- }),
- $globals.BooleanTest);
- $core.addMethod(
- $core.method({
- selector: "testLogic",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4,$6,$7,$8,$10,$9,$12,$11,$14,$13,$16,$17,$15,$19,$18,$21,$20,$23,$22;
- $1=true.__and(true);
- $ctx1.sendIdx["&"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $2=true.__and(false);
- $ctx1.sendIdx["&"]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=1;
- $3=false.__and(true);
- $ctx1.sendIdx["&"]=3;
- self._deny_($3);
- $ctx1.sendIdx["deny:"]=2;
- $5=false.__and(false);
- $ctx1.sendIdx["&"]=4;
- $4=self._deny_($5);
- $ctx1.sendIdx["deny:"]=3;
- $6=true.__or(true);
- $ctx1.sendIdx["|"]=1;
- self._assert_($6);
- $ctx1.sendIdx["assert:"]=2;
- $7=true.__or(false);
- $ctx1.sendIdx["|"]=2;
- self._assert_($7);
- $ctx1.sendIdx["assert:"]=3;
- $8=false.__or(true);
- $ctx1.sendIdx["|"]=3;
- self._assert_($8);
- $ctx1.sendIdx["assert:"]=4;
- $10=false.__or(false);
- $ctx1.sendIdx["|"]=4;
- $9=self._deny_($10);
- $ctx1.sendIdx["deny:"]=4;
- $12=(1).__gt((0));
- $ctx1.sendIdx[">"]=1;
- $11=true.__and($12);
- $ctx1.sendIdx["&"]=5;
- self._assert_($11);
- $ctx1.sendIdx["assert:"]=5;
- $14=(1).__gt((0));
- $ctx1.sendIdx[">"]=2;
- $13=$recv($14).__and(false);
- $ctx1.sendIdx["&"]=6;
- self._deny_($13);
- $ctx1.sendIdx["deny:"]=5;
- $16=(1).__gt((0));
- $ctx1.sendIdx[">"]=3;
- $17=(1).__gt((2));
- $ctx1.sendIdx[">"]=4;
- $15=$recv($16).__and($17);
- self._deny_($15);
- $19=(1).__gt((0));
- $ctx1.sendIdx[">"]=5;
- $18=false.__or($19);
- $ctx1.sendIdx["|"]=5;
- self._assert_($18);
- $ctx1.sendIdx["assert:"]=6;
- $21=(1).__gt((0));
- $ctx1.sendIdx[">"]=6;
- $20=$recv($21).__or(false);
- $ctx1.sendIdx["|"]=6;
- self._assert_($20);
- $ctx1.sendIdx["assert:"]=7;
- $23=(1).__gt((0));
- $ctx1.sendIdx[">"]=7;
- $22=$recv($23).__or((1).__gt((2)));
- self._assert_($22);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLogic",{},$globals.BooleanTest)});
- },
- args: [],
- source: "testLogic\x0a\x09\x22Trivial logic table\x22\x0a\x09self assert: (true & true);\x0a\x09\x09deny: (true & false);\x0a\x09\x09deny: (false & true);\x0a\x09\x09deny: (false & false).\x0a\x09self assert: (true | true);\x0a\x09\x09assert: (true | false);\x0a\x09\x09assert: (false | true);\x0a\x09\x09deny: (false | false).\x0a\x09\x22Checking that expressions work fine too\x22\x0a\x09self assert: (true & (1 > 0));\x0a\x09\x09deny: ((1 > 0) & false);\x0a\x09\x09deny: ((1 > 0) & (1 > 2)).\x0a\x09self assert: (false | (1 > 0));\x0a\x09\x09assert: ((1 > 0) | false);\x0a\x09\x09assert: ((1 > 0) | (1 > 2))",
- referencedClasses: [],
- messageSends: ["assert:", "&", "deny:", "|", ">"]
- }),
- $globals.BooleanTest);
- $core.addMethod(
- $core.method({
- selector: "testLogicKeywords",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4,$6,$7,$8,$10,$9,$11,$13,$12,$15,$14,$16,$18,$17,$20,$19;
- $1=true._and_((function(){
- return true;
- }));
- $ctx1.sendIdx["and:"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $2=true._and_((function(){
- return false;
- }));
- $ctx1.sendIdx["and:"]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=1;
- $3=false._and_((function(){
- return true;
- }));
- $ctx1.sendIdx["and:"]=3;
- self._deny_($3);
- $ctx1.sendIdx["deny:"]=2;
- $5=false._and_((function(){
- return false;
- }));
- $ctx1.sendIdx["and:"]=4;
- $4=self._deny_($5);
- $ctx1.sendIdx["deny:"]=3;
- $6=true._or_((function(){
- return true;
- }));
- $ctx1.sendIdx["or:"]=1;
- self._assert_($6);
- $ctx1.sendIdx["assert:"]=2;
- $7=true._or_((function(){
- return false;
- }));
- $ctx1.sendIdx["or:"]=2;
- self._assert_($7);
- $ctx1.sendIdx["assert:"]=3;
- $8=false._or_((function(){
- return true;
- }));
- $ctx1.sendIdx["or:"]=3;
- self._assert_($8);
- $ctx1.sendIdx["assert:"]=4;
- $10=false._or_((function(){
- return false;
- }));
- $ctx1.sendIdx["or:"]=4;
- $9=self._deny_($10);
- $ctx1.sendIdx["deny:"]=4;
- $11=true._and_((function(){
- return $core.withContext(function($ctx2) {
- return (1).__gt((0));
- $ctx2.sendIdx[">"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,9)});
- }));
- $ctx1.sendIdx["and:"]=5;
- self._assert_($11);
- $ctx1.sendIdx["assert:"]=5;
- $13=(1).__gt((0));
- $ctx1.sendIdx[">"]=2;
- $12=$recv($13)._and_((function(){
- return false;
- }));
- $ctx1.sendIdx["and:"]=6;
- self._deny_($12);
- $ctx1.sendIdx["deny:"]=5;
- $15=(1).__gt((0));
- $ctx1.sendIdx[">"]=3;
- $14=$recv($15)._and_((function(){
- return $core.withContext(function($ctx2) {
- return (1).__gt((2));
- $ctx2.sendIdx[">"]=4;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,11)});
- }));
- self._deny_($14);
- $16=false._or_((function(){
- return $core.withContext(function($ctx2) {
- return (1).__gt((0));
- $ctx2.sendIdx[">"]=5;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,12)});
- }));
- $ctx1.sendIdx["or:"]=5;
- self._assert_($16);
- $ctx1.sendIdx["assert:"]=6;
- $18=(1).__gt((0));
- $ctx1.sendIdx[">"]=6;
- $17=$recv($18)._or_((function(){
- return false;
- }));
- $ctx1.sendIdx["or:"]=6;
- self._assert_($17);
- $ctx1.sendIdx["assert:"]=7;
- $20=(1).__gt((0));
- $ctx1.sendIdx[">"]=7;
- $19=$recv($20)._or_((function(){
- return $core.withContext(function($ctx2) {
- return (1).__gt((2));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,14)});
- }));
- self._assert_($19);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLogicKeywords",{},$globals.BooleanTest)});
- },
- args: [],
- source: "testLogicKeywords\x0a\x09\x22Trivial logic table\x22\x0a\x09self\x0a\x09\x09assert: (true and: [ true ]);\x0a\x09\x09deny: (true and: [ false ]);\x0a\x09\x09deny: (false and: [ true ]);\x0a\x09\x09deny: (false and: [ false ]).\x0a\x09self\x0a\x09\x09assert: (true or: [ true ]);\x0a\x09\x09assert: (true or: [ false ]);\x0a\x09\x09assert: (false or: [ true ]);\x0a\x09\x09deny: (false or: [ false ]).\x0a\x09\x09\x0a\x09\x22Checking that expressions work fine too\x22\x0a\x09self\x0a\x09\x09assert: (true and: [ 1 > 0 ]);\x0a\x09\x09deny: ((1 > 0) and: [ false ]);\x0a\x09\x09deny: ((1 > 0) and: [ 1 > 2 ]).\x0a\x09self\x0a\x09\x09assert: (false or: [ 1 > 0 ]);\x0a\x09\x09assert: ((1 > 0) or: [ false ]);\x0a\x09\x09assert: ((1 > 0) or: [ 1 > 2 ])",
- referencedClasses: [],
- messageSends: ["assert:", "and:", "deny:", "or:", ">"]
- }),
- $globals.BooleanTest);
- $core.addMethod(
- $core.method({
- selector: "testNonBooleanError",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- if($core.assert("")){
- } else {
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.NonBooleanReceiver);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNonBooleanError",{},$globals.BooleanTest)});
- },
- args: [],
- source: "testNonBooleanError\x0a\x09self should: [ '' ifTrue: [] ifFalse: [] ] raise: NonBooleanReceiver",
- referencedClasses: ["NonBooleanReceiver"],
- messageSends: ["should:raise:", "ifTrue:ifFalse:"]
- }),
- $globals.BooleanTest);
- $core.addClass("ClassBuilderTest", $globals.TestCase, ["builder", "theClass"], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@builder"]=$recv($globals.ClassBuilder)._new();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.ClassBuilderTest)});
- },
- args: [],
- source: "setUp\x0a\x09builder := ClassBuilder new",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["new"]
- }),
- $globals.ClassBuilderTest);
- $core.addMethod(
- $core.method({
- selector: "tearDown",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@theClass"];
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $recv($globals.Smalltalk)._removeClass_(self["@theClass"]);
- self["@theClass"]=nil;
- self["@theClass"];
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tearDown",{},$globals.ClassBuilderTest)});
- },
- args: [],
- source: "tearDown\x0a\x09theClass ifNotNil: [ Smalltalk removeClass: theClass. theClass := nil ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifNotNil:", "removeClass:"]
- }),
- $globals.ClassBuilderTest);
- $core.addMethod(
- $core.method({
- selector: "testClassCopy",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$8,$7;
- self["@theClass"]=$recv(self["@builder"])._copyClass_named_($globals.ObjectMock,"ObjectMock2");
- $2=$recv(self["@theClass"])._superclass();
- $ctx1.sendIdx["superclass"]=1;
- $1=$recv($2).__eq_eq($recv($globals.ObjectMock)._superclass());
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $4=$recv(self["@theClass"])._instanceVariableNames();
- $ctx1.sendIdx["instanceVariableNames"]=1;
- $3=$recv($4).__eq_eq($recv($globals.ObjectMock)._instanceVariableNames());
- $ctx1.sendIdx["=="]=2;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- self._assert_equals_($recv(self["@theClass"])._name(),"ObjectMock2");
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=$recv(self["@theClass"])._package();
- $ctx1.sendIdx["package"]=1;
- $5=$recv($6).__eq_eq($recv($globals.ObjectMock)._package());
- self._assert_($5);
- $8=$recv(self["@theClass"])._methodDictionary();
- $ctx1.sendIdx["methodDictionary"]=1;
- $7=$recv($8)._keys();
- $ctx1.sendIdx["keys"]=1;
- self._assert_equals_($7,$recv($recv($globals.ObjectMock)._methodDictionary())._keys());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testClassCopy",{},$globals.ClassBuilderTest)});
- },
- args: [],
- source: "testClassCopy\x0a\x09theClass := builder copyClass: ObjectMock named: 'ObjectMock2'.\x0a\x09self assert: theClass superclass == ObjectMock superclass.\x0a\x09self assert: theClass instanceVariableNames == ObjectMock instanceVariableNames.\x0a\x09self assert: theClass name equals: 'ObjectMock2'.\x0a\x09self assert: theClass package == ObjectMock package.\x0a\x09self assert: theClass methodDictionary keys equals: ObjectMock methodDictionary keys",
- referencedClasses: ["ObjectMock"],
- messageSends: ["copyClass:named:", "assert:", "==", "superclass", "instanceVariableNames", "assert:equals:", "name", "package", "keys", "methodDictionary"]
- }),
- $globals.ClassBuilderTest);
- $core.addMethod(
- $core.method({
- selector: "testClassMigration",
- protocol: "tests",
- fn: function (){
- var self=this;
- var instance,oldClass;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5,$6,$7,$8,$9,$11,$10;
- oldClass=$recv(self["@builder"])._copyClass_named_($globals.ObjectMock,"ObjectMock2");
- $2=$recv($globals.Smalltalk)._globals();
- $ctx1.sendIdx["globals"]=1;
- $1=$recv($2)._at_("ObjectMock2");
- $ctx1.sendIdx["at:"]=1;
- instance=$recv($1)._new();
- $4=$recv($globals.Smalltalk)._globals();
- $ctx1.sendIdx["globals"]=2;
- $3=$recv($4)._at_("ObjectMock2");
- $ctx1.sendIdx["at:"]=2;
- $recv($globals.ObjectMock)._subclass_instanceVariableNames_package_($3,"","Kernel-Tests");
- $5=$recv(oldClass).__eq_eq($globals.ObjectMock2);
- $ctx1.sendIdx["=="]=1;
- self._deny_($5);
- $ctx1.sendIdx["deny:"]=1;
- $6=$recv($recv($globals.ObjectMock2)._superclass()).__eq_eq($globals.ObjectMock);
- $ctx1.sendIdx["=="]=2;
- self._assert_($6);
- $ctx1.sendIdx["assert:"]=1;
- self._assert_($recv($recv($globals.ObjectMock2)._instanceVariableNames())._isEmpty());
- $ctx1.sendIdx["assert:"]=2;
- $7=$recv($globals.ObjectMock2)._selectors();
- $ctx1.sendIdx["selectors"]=1;
- self._assert_equals_($7,$recv(oldClass)._selectors());
- $ctx1.sendIdx["assert:equals:"]=1;
- $8=$recv($globals.ObjectMock2)._comment();
- $ctx1.sendIdx["comment"]=1;
- self._assert_equals_($8,$recv(oldClass)._comment());
- $ctx1.sendIdx["assert:equals:"]=2;
- $9=$recv($recv($globals.ObjectMock2)._package())._name();
- $ctx1.sendIdx["name"]=1;
- self._assert_equals_($9,"Kernel-Tests");
- $11=$recv(instance)._class();
- $ctx1.sendIdx["class"]=1;
- $10=$recv($11).__eq_eq($globals.ObjectMock2);
- self._deny_($10);
- self._assert_($recv($recv($recv($globals.Smalltalk)._globals())._at_($recv($recv(instance)._class())._name()))._isNil());
- $recv($globals.Smalltalk)._removeClass_($globals.ObjectMock2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testClassMigration",{instance:instance,oldClass:oldClass},$globals.ClassBuilderTest)});
- },
- args: [],
- source: "testClassMigration\x0a\x09| instance oldClass |\x0a\x09\x0a\x09oldClass := builder copyClass: ObjectMock named: 'ObjectMock2'.\x0a\x09instance := (Smalltalk globals at: 'ObjectMock2') new.\x0a\x09\x0a\x09\x22Change the superclass of ObjectMock2\x22\x0a\x09ObjectMock subclass: (Smalltalk globals at: 'ObjectMock2')\x0a\x09\x09instanceVariableNames: ''\x0a\x09\x09package: 'Kernel-Tests'.\x0a\x09\x0a\x09self deny: oldClass == ObjectMock2.\x0a\x09\x0a\x09self assert: ObjectMock2 superclass == ObjectMock.\x0a\x09self assert: ObjectMock2 instanceVariableNames isEmpty.\x0a\x09self assert: ObjectMock2 selectors equals: oldClass selectors.\x0a\x09self assert: ObjectMock2 comment equals: oldClass comment.\x0a\x09self assert: ObjectMock2 package name equals: 'Kernel-Tests'.\x0a\x09\x0a\x09self deny: instance class == ObjectMock2.\x0a\x09\x22Commeting this out. Tests implementation detail.\x22\x0a\x09\x22self assert: instance class name equals: 'OldObjectMock2'.\x22\x0a\x09\x0a\x09self assert: (Smalltalk globals at: instance class name) isNil.\x0a\x09\x0a\x09Smalltalk removeClass: ObjectMock2",
- referencedClasses: ["ObjectMock", "Smalltalk", "ObjectMock2"],
- messageSends: ["copyClass:named:", "new", "at:", "globals", "subclass:instanceVariableNames:package:", "deny:", "==", "assert:", "superclass", "isEmpty", "instanceVariableNames", "assert:equals:", "selectors", "comment", "name", "package", "class", "isNil", "removeClass:"]
- }),
- $globals.ClassBuilderTest);
- $core.addMethod(
- $core.method({
- selector: "testClassMigrationWithClassInstanceVariables",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(self["@builder"])._copyClass_named_($globals.ObjectMock,"ObjectMock2");
- $1=$recv($globals.ObjectMock2)._class();
- $ctx1.sendIdx["class"]=1;
- $recv($1)._instanceVariableNames_("foo bar");
- $recv($globals.ObjectMock)._subclass_instanceVariableNames_package_($recv($recv($globals.Smalltalk)._globals())._at_("ObjectMock2"),"","Kernel-Tests");
- self._assert_equals_($recv($recv($globals.ObjectMock2)._class())._instanceVariableNames(),["foo", "bar"]);
- $recv($globals.Smalltalk)._removeClass_($globals.ObjectMock2);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testClassMigrationWithClassInstanceVariables",{},$globals.ClassBuilderTest)});
- },
- args: [],
- source: "testClassMigrationWithClassInstanceVariables\x0a\x09\x0a\x09builder copyClass: ObjectMock named: 'ObjectMock2'.\x0a\x09ObjectMock2 class instanceVariableNames: 'foo bar'.\x0a\x09\x0a\x09\x22Change the superclass of ObjectMock2\x22\x0a\x09ObjectMock subclass: (Smalltalk globals at: 'ObjectMock2')\x0a\x09\x09instanceVariableNames: ''\x0a\x09\x09package: 'Kernel-Tests'.\x0a\x09\x0a\x09self assert: ObjectMock2 class instanceVariableNames equals: #('foo' 'bar').\x0a\x09\x0a\x09Smalltalk removeClass: ObjectMock2",
- referencedClasses: ["ObjectMock", "ObjectMock2", "Smalltalk"],
- messageSends: ["copyClass:named:", "instanceVariableNames:", "class", "subclass:instanceVariableNames:package:", "at:", "globals", "assert:equals:", "instanceVariableNames", "removeClass:"]
- }),
- $globals.ClassBuilderTest);
- $core.addMethod(
- $core.method({
- selector: "testClassMigrationWithSubclasses",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3;
- $recv(self["@builder"])._copyClass_named_($globals.ObjectMock,"ObjectMock2");
- $recv($globals.ObjectMock2)._subclass_instanceVariableNames_package_("ObjectMock3","","Kernel-Tests");
- $ctx1.sendIdx["subclass:instanceVariableNames:package:"]=1;
- $recv($globals.ObjectMock3)._subclass_instanceVariableNames_package_("ObjectMock4","","Kernel-Tests");
- $ctx1.sendIdx["subclass:instanceVariableNames:package:"]=2;
- $recv($globals.ObjectMock)._subclass_instanceVariableNames_package_($recv($recv($globals.Smalltalk)._globals())._at_("ObjectMock2"),"","Kernel-Tests");
- $2=$recv($globals.ObjectMock)._subclasses();
- $ctx1.sendIdx["subclasses"]=1;
- $1=$recv($2)._includes_($globals.ObjectMock2);
- $ctx1.sendIdx["includes:"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $4=$recv($globals.ObjectMock2)._subclasses();
- $ctx1.sendIdx["subclasses"]=2;
- $3=$recv($4)._includes_($globals.ObjectMock3);
- $ctx1.sendIdx["includes:"]=2;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- self._assert_($recv($recv($globals.ObjectMock3)._subclasses())._includes_($globals.ObjectMock4));
- $recv($recv($globals.ObjectMock)._allSubclasses())._reverseDo_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($globals.Smalltalk)._removeClass_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testClassMigrationWithSubclasses",{},$globals.ClassBuilderTest)});
- },
- args: [],
- source: "testClassMigrationWithSubclasses\x0a\x09\x0a\x09builder copyClass: ObjectMock named: 'ObjectMock2'.\x0a\x09ObjectMock2 subclass: 'ObjectMock3' instanceVariableNames: '' package: 'Kernel-Tests'.\x0a\x09ObjectMock3 subclass: 'ObjectMock4' instanceVariableNames: '' package: 'Kernel-Tests'.\x0a\x09\x0a\x09\x22Change the superclass of ObjectMock2\x22\x0a\x09ObjectMock subclass: (Smalltalk globals at: 'ObjectMock2')\x0a\x09\x09instanceVariableNames: ''\x0a\x09\x09package: 'Kernel-Tests'.\x0a\x09\x0a\x09self assert: (ObjectMock subclasses includes: ObjectMock2).\x0a\x09self assert: (ObjectMock2 subclasses includes: ObjectMock3).\x0a\x09self assert: (ObjectMock3 subclasses includes: ObjectMock4).\x0a\x09\x0a\x09ObjectMock allSubclasses reverseDo: [ :each | Smalltalk removeClass: each ]",
- referencedClasses: ["ObjectMock", "ObjectMock2", "ObjectMock3", "Smalltalk", "ObjectMock4"],
- messageSends: ["copyClass:named:", "subclass:instanceVariableNames:package:", "at:", "globals", "assert:", "includes:", "subclasses", "reverseDo:", "allSubclasses", "removeClass:"]
- }),
- $globals.ClassBuilderTest);
- $core.addMethod(
- $core.method({
- selector: "testInstanceVariableNames",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv(self["@builder"])._instanceVariableNamesFor_(" hello world "),["hello", "world"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testInstanceVariableNames",{},$globals.ClassBuilderTest)});
- },
- args: [],
- source: "testInstanceVariableNames\x0a\x09self assert: (builder instanceVariableNamesFor: ' hello world ') equals: #('hello' 'world')",
- referencedClasses: [],
- messageSends: ["assert:equals:", "instanceVariableNamesFor:"]
- }),
- $globals.ClassBuilderTest);
- $core.addClass("ClassTest", $globals.TestCase, ["builder", "theClass"], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "jsConstructor",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- function Foo(){}
- Foo.prototype.valueOf = function () {return 4;};
- return Foo;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"jsConstructor",{},$globals.ClassTest)});
- },
- args: [],
- source: "jsConstructor\x0a\x09<inlineJS: '\x0a\x09\x09function Foo(){}\x0a\x09\x09Foo.prototype.valueOf = function () {return 4;};\x0a\x09\x09return Foo;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassTest);
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@builder"]=$recv($globals.ClassBuilder)._new();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.ClassTest)});
- },
- args: [],
- source: "setUp\x0a\x09builder := ClassBuilder new",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["new"]
- }),
- $globals.ClassTest);
- $core.addMethod(
- $core.method({
- selector: "tearDown",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@theClass"];
- if(($receiver = $1) == null || $receiver.isNil){
- $1;
- } else {
- $recv($recv(self["@theClass"])._allSubclasses())._reverseDo_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($globals.Smalltalk)._removeClass_(each);
- $ctx2.sendIdx["removeClass:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- $recv($globals.Smalltalk)._removeClass_(self["@theClass"]);
- self["@theClass"]=nil;
- self["@theClass"];
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tearDown",{},$globals.ClassTest)});
- },
- args: [],
- source: "tearDown\x0a\x09theClass ifNotNil: [\x0a\x09\x09theClass allSubclasses reverseDo: [ :each | Smalltalk removeClass: each ].\x0a\x09\x09Smalltalk removeClass: theClass.\x0a\x09\x09theClass := nil ]",
- referencedClasses: ["Smalltalk"],
- messageSends: ["ifNotNil:", "reverseDo:", "allSubclasses", "removeClass:"]
- }),
- $globals.ClassTest);
- $core.addMethod(
- $core.method({
- selector: "testAllSubclasses",
- protocol: "tests",
- fn: function (){
- var self=this;
- var subclasses,index;
- return $core.withContext(function($ctx1) {
- subclasses=$recv($globals.Object)._subclasses();
- $ctx1.sendIdx["subclasses"]=1;
- index=(1);
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(index).__gt($recv(subclasses)._size());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._whileFalse_((function(){
- return $core.withContext(function($ctx2) {
- $recv(subclasses)._addAll_($recv($recv(subclasses)._at_(index))._subclasses());
- index=$recv(index).__plus((1));
- return index;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- self._assert_equals_($recv($globals.Object)._allSubclasses(),subclasses);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAllSubclasses",{subclasses:subclasses,index:index},$globals.ClassTest)});
- },
- args: [],
- source: "testAllSubclasses\x0a\x09| subclasses index |\x0a\x0a\x09subclasses := Object subclasses.\x0a\x09index := 1.\x0a\x09[ index > subclasses size ]\x0a\x09\x09whileFalse: [ subclasses addAll: (subclasses at: index) subclasses.\x0a\x09\x09\x09index := index + 1 ].\x0a\x0a\x09self assert: Object allSubclasses equals: subclasses",
- referencedClasses: ["Object"],
- messageSends: ["subclasses", "whileFalse:", ">", "size", "addAll:", "at:", "+", "assert:equals:", "allSubclasses"]
- }),
- $globals.ClassTest);
- $core.addMethod(
- $core.method({
- selector: "testMetaclassSubclasses",
- protocol: "tests",
- fn: function (){
- var self=this;
- var subclasses;
- return $core.withContext(function($ctx1) {
- var $4,$3,$2,$1;
- $4=$recv($globals.Object)._class();
- $ctx1.sendIdx["class"]=1;
- $3=$recv($4)._instanceClass();
- $2=$recv($3)._subclasses();
- $ctx1.sendIdx["subclasses"]=1;
- $1=$recv($2)._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._isMetaclass())._not();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- subclasses=$recv($1)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._theMetaClass();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- self._assert_equals_($recv($recv($globals.Object)._class())._subclasses(),subclasses);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMetaclassSubclasses",{subclasses:subclasses},$globals.ClassTest)});
- },
- args: [],
- source: "testMetaclassSubclasses\x0a\x09| subclasses |\x0a\x0a\x09subclasses := (Object class instanceClass subclasses \x0a\x09\x09select: [ :each | each isMetaclass not ])\x0a\x09\x09collect: [ :each | each theMetaClass ].\x0a\x0a\x09self assert: Object class subclasses equals: subclasses",
- referencedClasses: ["Object"],
- messageSends: ["collect:", "select:", "subclasses", "instanceClass", "class", "not", "isMetaclass", "theMetaClass", "assert:equals:"]
- }),
- $globals.ClassTest);
- $core.addMethod(
- $core.method({
- selector: "testSetJavaScriptConstructor",
- protocol: "tests",
- fn: function (){
- var self=this;
- var instance;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$8,$7;
- self["@theClass"]=$recv(self["@builder"])._copyClass_named_($globals.ObjectMock,"ObjectMock2");
- $recv(self["@theClass"])._javascriptConstructor_(self._jsConstructor());
- $2=$recv(self["@theClass"])._superclass();
- $ctx1.sendIdx["superclass"]=1;
- $1=$recv($2).__eq_eq($recv($globals.ObjectMock)._superclass());
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $4=$recv(self["@theClass"])._instanceVariableNames();
- $ctx1.sendIdx["instanceVariableNames"]=1;
- $3=$recv($4).__eq_eq($recv($globals.ObjectMock)._instanceVariableNames());
- $ctx1.sendIdx["=="]=2;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- self._assert_equals_($recv(self["@theClass"])._name(),"ObjectMock2");
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=$recv(self["@theClass"])._package();
- $ctx1.sendIdx["package"]=1;
- $5=$recv($6).__eq_eq($recv($globals.ObjectMock)._package());
- $ctx1.sendIdx["=="]=3;
- self._assert_($5);
- $ctx1.sendIdx["assert:"]=3;
- $8=$recv(self["@theClass"])._methodDictionary();
- $ctx1.sendIdx["methodDictionary"]=1;
- $7=$recv($8)._keys();
- $ctx1.sendIdx["keys"]=1;
- self._assert_equals_($7,$recv($recv($globals.ObjectMock)._methodDictionary())._keys());
- $ctx1.sendIdx["assert:equals:"]=2;
- instance=$recv(self["@theClass"])._new();
- self._assert_($recv($recv(instance)._class()).__eq_eq(self["@theClass"]));
- self._assert_equals_($recv(instance)._value(),(4));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(instance)._foo_((9));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- self._assert_equals_($recv(instance)._foo(),(9));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSetJavaScriptConstructor",{instance:instance},$globals.ClassTest)});
- },
- args: [],
- source: "testSetJavaScriptConstructor\x0a\x09| instance |\x0a\x09theClass := builder copyClass: ObjectMock named: 'ObjectMock2'.\x0a\x09theClass javascriptConstructor: self jsConstructor.\x0a\x09\x22part took from copy class test\x22\x0a\x09self assert: theClass superclass == ObjectMock superclass.\x0a\x09self assert: theClass instanceVariableNames == ObjectMock instanceVariableNames.\x0a\x09self assert: theClass name equals: 'ObjectMock2'.\x0a\x09self assert: theClass package == ObjectMock package.\x0a\x09self assert: theClass methodDictionary keys equals: ObjectMock methodDictionary keys.\x0a\x09\x22testing specific to late-coupled detached root class\x22\x0a\x09instance := theClass new.\x0a\x09self assert: instance class == theClass.\x0a\x09self assert: instance value equals: 4.\x0a\x09self shouldnt: [ instance foo: 9 ] raise: Error.\x0a\x09self assert: instance foo equals: 9",
- referencedClasses: ["ObjectMock", "Error"],
- messageSends: ["copyClass:named:", "javascriptConstructor:", "jsConstructor", "assert:", "==", "superclass", "instanceVariableNames", "assert:equals:", "name", "package", "keys", "methodDictionary", "new", "class", "value", "shouldnt:raise:", "foo:", "foo"]
- }),
- $globals.ClassTest);
- $core.addMethod(
- $core.method({
- selector: "testTrickySetJavaScriptConstructor",
- protocol: "tests",
- fn: function (){
- var self=this;
- var instance;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$8,$7;
- self["@theClass"]=$recv(self["@builder"])._copyClass_named_($globals.ObjectMock,"ObjectMock2");
- $recv(self["@theClass"])._javascriptConstructor_(self._trickyJsConstructor());
- $2=$recv(self["@theClass"])._superclass();
- $ctx1.sendIdx["superclass"]=1;
- $1=$recv($2).__eq_eq($recv($globals.ObjectMock)._superclass());
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $4=$recv(self["@theClass"])._instanceVariableNames();
- $ctx1.sendIdx["instanceVariableNames"]=1;
- $3=$recv($4).__eq_eq($recv($globals.ObjectMock)._instanceVariableNames());
- $ctx1.sendIdx["=="]=2;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- self._assert_equals_($recv(self["@theClass"])._name(),"ObjectMock2");
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=$recv(self["@theClass"])._package();
- $ctx1.sendIdx["package"]=1;
- $5=$recv($6).__eq_eq($recv($globals.ObjectMock)._package());
- $ctx1.sendIdx["=="]=3;
- self._assert_($5);
- $ctx1.sendIdx["assert:"]=3;
- $8=$recv(self["@theClass"])._methodDictionary();
- $ctx1.sendIdx["methodDictionary"]=1;
- $7=$recv($8)._keys();
- $ctx1.sendIdx["keys"]=1;
- self._assert_equals_($7,$recv($recv($globals.ObjectMock)._methodDictionary())._keys());
- $ctx1.sendIdx["assert:equals:"]=2;
- instance=$recv(self["@theClass"])._new();
- self._assert_($recv($recv(instance)._class()).__eq_eq(self["@theClass"]));
- self._assert_equals_($recv(instance)._value(),(4));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(instance)._foo_((9));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- self._assert_equals_($recv(instance)._foo(),(9));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTrickySetJavaScriptConstructor",{instance:instance},$globals.ClassTest)});
- },
- args: [],
- source: "testTrickySetJavaScriptConstructor\x0a\x09| instance |\x0a\x09theClass := builder copyClass: ObjectMock named: 'ObjectMock2'.\x0a\x09theClass javascriptConstructor: self trickyJsConstructor.\x0a\x09\x22part took from copy class test\x22\x0a\x09self assert: theClass superclass == ObjectMock superclass.\x0a\x09self assert: theClass instanceVariableNames == ObjectMock instanceVariableNames.\x0a\x09self assert: theClass name equals: 'ObjectMock2'.\x0a\x09self assert: theClass package == ObjectMock package.\x0a\x09self assert: theClass methodDictionary keys equals: ObjectMock methodDictionary keys.\x0a\x09\x22testing specific to late-coupled detached root class\x22\x0a\x09instance := theClass new.\x0a\x09self assert: instance class == theClass.\x0a\x09self assert: instance value equals: 4.\x0a\x09self shouldnt: [ instance foo: 9 ] raise: Error.\x0a\x09self assert: instance foo equals: 9",
- referencedClasses: ["ObjectMock", "Error"],
- messageSends: ["copyClass:named:", "javascriptConstructor:", "trickyJsConstructor", "assert:", "==", "superclass", "instanceVariableNames", "assert:equals:", "name", "package", "keys", "methodDictionary", "new", "class", "value", "shouldnt:raise:", "foo:", "foo"]
- }),
- $globals.ClassTest);
- $core.addMethod(
- $core.method({
- selector: "trickyJsConstructor",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- function Foo(){}
- Foo.prototype.valueOf = function () {return 4;};
- Foo.prototype._foo = function () {return "bar";};
- return Foo;
- ;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"trickyJsConstructor",{},$globals.ClassTest)});
- },
- args: [],
- source: "trickyJsConstructor\x0a\x09<inlineJS: '\x0a\x09\x09function Foo(){}\x0a\x09\x09Foo.prototype.valueOf = function () {return 4;};\x0a\x09\x09Foo.prototype._foo = function () {return \x22bar\x22;};\x0a\x09\x09return Foo;\x0a\x09'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ClassTest);
- $core.addClass("CollectionTest", $globals.TestCase, ["sampleBlock"], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "assertSameContents:as:",
- protocol: "convenience",
- fn: function (aCollection,anotherCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3;
- $2=$recv(aCollection)._size();
- $ctx1.sendIdx["size"]=1;
- $1=$recv($2).__eq($recv(anotherCollection)._size());
- $ctx1.sendIdx["="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $recv(aCollection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $4=$recv(aCollection)._occurrencesOf_(each);
- $ctx2.sendIdx["occurrencesOf:"]=1;
- $3=$recv($4).__eq($recv(anotherCollection)._occurrencesOf_(each));
- return self._assert_($3);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"assertSameContents:as:",{aCollection:aCollection,anotherCollection:anotherCollection},$globals.CollectionTest)});
- },
- args: ["aCollection", "anotherCollection"],
- source: "assertSameContents: aCollection as: anotherCollection\x0a\x09self assert: (aCollection size = anotherCollection size).\x0a\x09aCollection do: [ :each |\x0a\x09\x09self assert: ((aCollection occurrencesOf: each) = (anotherCollection occurrencesOf: each)) ]",
- referencedClasses: [],
- messageSends: ["assert:", "=", "size", "do:", "occurrencesOf:"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collection",{},$globals.CollectionTest)});
- },
- args: [],
- source: "collection\x0a\x09\x22Answers pre-filled collection of type tested.\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._collectionClass();
- }, function($ctx1) {$ctx1.fill(self,"collectionClass",{},$globals.CollectionTest)});
- },
- args: [],
- source: "collectionClass\x0a\x09\x22Answers class of collection type tested\x22\x0a\x0a\x09^ self class collectionClass",
- referencedClasses: [],
- messageSends: ["collectionClass", "class"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionOfPrintStrings",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionOfPrintStrings",{},$globals.CollectionTest)});
- },
- args: [],
- source: "collectionOfPrintStrings\x0a\x09\x22Answers self collection but with values\x0a\x09changed to their printStrings\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionSize",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionSize",{},$globals.CollectionTest)});
- },
- args: [],
- source: "collectionSize\x0a\x09\x22Answers size of self collection.\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithDuplicates",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionWithDuplicates",{},$globals.CollectionTest)});
- },
- args: [],
- source: "collectionWithDuplicates\x0a\x09\x22Answers pre-filled collection of type tested,\x0a\x09with exactly five distinct elements,\x0a\x09some of them appearing multiple times, if possible.\x22\x0a\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionWithNewValue",{},$globals.CollectionTest)});
- },
- args: [],
- source: "collectionWithNewValue\x0a\x09\x22Answers a collection which shows how\x0a\x09self collection would look after adding\x0a\x09self sampleNewValue\x22\x0a\x09\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.CollectionTest.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@sampleBlock"]=(function(){
- });
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.CollectionTest)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x0a\x09sampleBlock := []",
- referencedClasses: [],
- messageSends: ["initialize"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "isCollectionReadOnly",
- protocol: "testing",
- fn: function (){
- var self=this;
- return false;
- },
- args: [],
- source: "isCollectionReadOnly\x0a\x09^ false",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "N";
- },
- args: [],
- source: "sampleNewValue\x0a\x09\x22Answers a value that is not yet there\x0a\x09and can be put into a tested collection\x22\x0a\x09\x0a\x09^ 'N'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewValueAsCollection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._collectionClass())._with_(self._sampleNewValue());
- }, function($ctx1) {$ctx1.fill(self,"sampleNewValueAsCollection",{},$globals.CollectionTest)});
- },
- args: [],
- source: "sampleNewValueAsCollection\x0a\x09\x22Answers self sampleNewValue\x0a\x09wrapped in single element collection\x0a\x09of tested type\x22\x0a\x09\x0a\x09^ self collectionClass with: self sampleNewValue",
- referencedClasses: [],
- messageSends: ["with:", "collectionClass", "sampleNewValue"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAddAll",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$4,$3,$5,$1,$6,$9,$8,$10,$11,$7,$12,$15,$14,$17,$16,$18,$13,$20,$21,$22,$19,$23,$25,$24;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $4=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $3=$recv($4)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($2)._addAll_($3);
- $ctx1.sendIdx["addAll:"]=1;
- $5=$recv($2)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $1=$5;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=2;
- self._assert_equals_($1,$6);
- $ctx1.sendIdx["assert:equals:"]=1;
- $9=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=2;
- $8=$recv($9)._new();
- $ctx1.sendIdx["new"]=2;
- $10=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $recv($8)._addAll_($10);
- $ctx1.sendIdx["addAll:"]=2;
- $11=$recv($8)._yourself();
- $ctx1.sendIdx["yourself"]=2;
- $7=$11;
- $12=self._collection();
- $ctx1.sendIdx["collection"]=4;
- self._assert_equals_($7,$12);
- $ctx1.sendIdx["assert:equals:"]=2;
- $15=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=3;
- $14=$recv($15)._new();
- $ctx1.sendIdx["new"]=3;
- $17=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=4;
- $16=$recv($17)._new();
- $ctx1.sendIdx["new"]=4;
- $recv($14)._addAll_($16);
- $ctx1.sendIdx["addAll:"]=3;
- $18=$recv($14)._yourself();
- $ctx1.sendIdx["yourself"]=3;
- $13=$18;
- self._assert_equals_($13,$recv(self._collectionClass())._new());
- $ctx1.sendIdx["assert:equals:"]=3;
- $20=self._collection();
- $ctx1.sendIdx["collection"]=5;
- $21=self._sampleNewValueAsCollection();
- $ctx1.sendIdx["sampleNewValueAsCollection"]=1;
- $recv($20)._addAll_($21);
- $ctx1.sendIdx["addAll:"]=4;
- $22=$recv($20)._yourself();
- $ctx1.sendIdx["yourself"]=4;
- $19=$22;
- $23=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- self._assert_equals_($19,$23);
- $25=self._sampleNewValueAsCollection();
- $recv($25)._addAll_(self._collection());
- $24=$recv($25)._yourself();
- self._assertSameContents_as_($24,self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddAll",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testAddAll\x0a\x09self assert: (self collection addAll: self collectionClass new; yourself) equals: self collection.\x0a\x09self assert: (self collectionClass new addAll: self collection; yourself) equals: self collection.\x0a\x09self assert: (self collectionClass new addAll: self collectionClass new; yourself) equals: self collectionClass new.\x0a\x09self assert: (self collection addAll: self sampleNewValueAsCollection; yourself) equals: self collectionWithNewValue.\x0a\x09self assertSameContents: (self sampleNewValueAsCollection addAll: self collection; yourself) as: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["assert:equals:", "addAll:", "collection", "new", "collectionClass", "yourself", "sampleNewValueAsCollection", "collectionWithNewValue", "assertSameContents:as:"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAllSatisfy",
- protocol: "tests",
- fn: function (){
- var self=this;
- var collection,anyOne;
- return $core.withContext(function($ctx1) {
- var $1;
- collection=self._collection();
- anyOne=$recv(collection)._anyOne();
- $1=$recv(collection)._allSatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(collection)._includes_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["allSatisfy:"]=1;
- self._assert_($1);
- self._deny_($recv(collection)._allSatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__tild_eq(anyOne);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- })));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAllSatisfy",{collection:collection,anyOne:anyOne},$globals.CollectionTest)});
- },
- args: [],
- source: "testAllSatisfy\x0a\x09| collection anyOne |\x0a\x09collection := self collection.\x0a\x09anyOne := collection anyOne.\x0a\x09self assert: (collection allSatisfy: [ :each | collection includes: each ]).\x0a\x09self deny: (collection allSatisfy: [ :each | each ~= anyOne ])",
- referencedClasses: [],
- messageSends: ["collection", "anyOne", "assert:", "allSatisfy:", "includes:", "deny:", "~="]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAnyOne",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv(self._collectionClass())._new())._anyOne();
- $ctx2.sendIdx["anyOne"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._includes_($recv(self._collection())._anyOne());
- self._assert_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAnyOne",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testAnyOne\x0a\x09self should: [ self collectionClass new anyOne ] raise: Error.\x0a\x09self assert: (self collection includes: self collection anyOne)",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "anyOne", "new", "collectionClass", "assert:", "includes:", "collection"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAnySatisfy",
- protocol: "tests",
- fn: function (){
- var self=this;
- var anyOne;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- $1=self._collection();
- $ctx1.sendIdx["collection"]=1;
- anyOne=$recv($1)._anyOne();
- $3=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $2=$recv($3)._anySatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__eq(anyOne);
- $ctx2.sendIdx["="]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["anySatisfy:"]=1;
- self._assert_($2);
- self._deny_($recv(self._collection())._anySatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__eq($recv($globals.Object)._new());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- })));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAnySatisfy",{anyOne:anyOne},$globals.CollectionTest)});
- },
- args: [],
- source: "testAnySatisfy\x0a\x09| anyOne |\x0a\x09anyOne := self collection anyOne.\x0a\x09self assert: (self collection anySatisfy: [ :each | each = anyOne ]).\x0a\x09self deny: (self collection anySatisfy: [ :each | each = Object new ])",
- referencedClasses: ["Object"],
- messageSends: ["anyOne", "collection", "assert:", "anySatisfy:", "=", "deny:", "new"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAsArray",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._collection();
- $ctx1.sendIdx["collection"]=1;
- self._assertSameContents_as_($1,$recv(self._collection())._asArray());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsArray",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testAsArray\x0a\x09self\x0a\x09\x09assertSameContents: self collection\x0a\x09\x09as: self collection asArray",
- referencedClasses: [],
- messageSends: ["assertSameContents:as:", "collection", "asArray"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAsOrderedCollection",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._collection();
- $ctx1.sendIdx["collection"]=1;
- self._assertSameContents_as_($1,$recv(self._collection())._asOrderedCollection());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsOrderedCollection",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testAsOrderedCollection\x0a\x09self\x0a\x09\x09assertSameContents: self collection\x0a\x09\x09as: self collection asOrderedCollection",
- referencedClasses: [],
- messageSends: ["assertSameContents:as:", "collection", "asOrderedCollection"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAsSet",
- protocol: "tests",
- fn: function (){
- var self=this;
- var c,set;
- return $core.withContext(function($ctx1) {
- c=self._collectionWithDuplicates();
- set=$recv(c)._asSet();
- self._assert_equals_($recv(set)._size(),(6));
- $recv(c)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return self._assert_($recv(set)._includes_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsSet",{c:c,set:set},$globals.CollectionTest)});
- },
- args: [],
- source: "testAsSet\x0a\x09| c set |\x0a\x09c := self collectionWithDuplicates.\x0a\x09set := c asSet.\x0a\x09self assert: set size equals: 6.\x0a\x09c do: [ :each |\x0a\x09\x09self assert: (set includes: each) ]",
- referencedClasses: [],
- messageSends: ["collectionWithDuplicates", "asSet", "assert:equals:", "size", "do:", "assert:", "includes:"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testCollect",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$5,$4,$8,$7,$6,$11,$10,$9;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._collect_((function(each){
- return each;
- }));
- $ctx1.sendIdx["collect:"]=1;
- $3=self._collection();
- $ctx1.sendIdx["collection"]=2;
- self._assert_equals_($1,$3);
- $ctx1.sendIdx["assert:equals:"]=1;
- $5=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $4=$recv($5)._collect_((function(each){
- return each;
- }));
- $ctx1.sendIdx["collect:"]=2;
- self._assert_equals_($4,self._collectionWithNewValue());
- $ctx1.sendIdx["assert:equals:"]=2;
- $8=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $7=$recv($8)._new();
- $ctx1.sendIdx["new"]=1;
- $6=$recv($7)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._printString();
- $ctx2.sendIdx["printString"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- $ctx1.sendIdx["collect:"]=3;
- self._assert_equals_($6,$recv(self._collectionClass())._new());
- $ctx1.sendIdx["assert:equals:"]=3;
- $11=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $10=$recv($11)._collect_((function(){
- return $core.withContext(function($ctx2) {
- return self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,4)});
- }));
- $ctx1.sendIdx["collect:"]=4;
- $9=$recv($10)._detect_((function(){
- return true;
- }));
- self._assert_equals_($9,self._sampleNewValue());
- $ctx1.sendIdx["assert:equals:"]=4;
- self._assert_equals_($recv(self._collection())._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._printString();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,6)});
- })),self._collectionOfPrintStrings());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCollect",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testCollect\x0a\x09self assert: (self collection collect: [ :each | each ]) equals: self collection.\x0a\x09self assert: (self collectionWithNewValue collect: [ :each | each ]) equals: self collectionWithNewValue.\x0a\x09self assert: (self collectionClass new collect: [ :each | each printString ]) equals: self collectionClass new.\x0a\x09self assert: ((self collection collect: [ self sampleNewValue ]) detect: [ true ]) equals: self sampleNewValue.\x0a\x09self assert: (self collection collect: [ :each | each printString ]) equals: self collectionOfPrintStrings",
- referencedClasses: [],
- messageSends: ["assert:equals:", "collect:", "collection", "collectionWithNewValue", "new", "collectionClass", "printString", "detect:", "sampleNewValue", "collectionOfPrintStrings"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testComma",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$4,$3,$1,$5,$8,$7,$9,$6,$10,$13,$12,$15,$14,$11,$17,$18,$16,$19;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $4=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $3=$recv($4)._new();
- $ctx1.sendIdx["new"]=1;
- $1=$recv($2).__comma($3);
- $ctx1.sendIdx[","]=1;
- $5=self._collection();
- $ctx1.sendIdx["collection"]=2;
- self._assert_equals_($1,$5);
- $ctx1.sendIdx["assert:equals:"]=1;
- $8=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=2;
- $7=$recv($8)._new();
- $ctx1.sendIdx["new"]=2;
- $9=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $6=$recv($7).__comma($9);
- $ctx1.sendIdx[","]=2;
- $10=self._collection();
- $ctx1.sendIdx["collection"]=4;
- self._assert_equals_($6,$10);
- $ctx1.sendIdx["assert:equals:"]=2;
- $13=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=3;
- $12=$recv($13)._new();
- $ctx1.sendIdx["new"]=3;
- $15=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=4;
- $14=$recv($15)._new();
- $ctx1.sendIdx["new"]=4;
- $11=$recv($12).__comma($14);
- $ctx1.sendIdx[","]=3;
- self._assert_equals_($11,$recv(self._collectionClass())._new());
- $ctx1.sendIdx["assert:equals:"]=3;
- $17=self._collection();
- $ctx1.sendIdx["collection"]=5;
- $18=self._sampleNewValueAsCollection();
- $ctx1.sendIdx["sampleNewValueAsCollection"]=1;
- $16=$recv($17).__comma($18);
- $ctx1.sendIdx[","]=4;
- $19=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- self._assert_equals_($16,$19);
- self._assertSameContents_as_($recv(self._sampleNewValueAsCollection()).__comma(self._collection()),self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testComma",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testComma\x0a\x09self assert: self collection, self collectionClass new equals: self collection.\x0a\x09self assert: self collectionClass new, self collection equals: self collection.\x0a\x09self assert: self collectionClass new, self collectionClass new equals: self collectionClass new.\x0a\x09self assert: self collection, self sampleNewValueAsCollection equals: self collectionWithNewValue.\x0a\x09self assertSameContents: self sampleNewValueAsCollection, self collection as: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["assert:equals:", ",", "collection", "new", "collectionClass", "sampleNewValueAsCollection", "collectionWithNewValue", "assertSameContents:as:"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testCopy",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$5,$4,$7,$6,$8,$10,$9,$11,$15,$14,$13,$16,$12,$19,$18,$17;
- $3=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $2=$recv($3)._new();
- $ctx1.sendIdx["new"]=1;
- $1=$recv($2)._copy();
- $ctx1.sendIdx["copy"]=1;
- $5=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=2;
- $4=$recv($5)._new();
- $ctx1.sendIdx["new"]=2;
- self._assert_equals_($1,$4);
- $ctx1.sendIdx["assert:equals:"]=1;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $6=$recv($7)._copy();
- $ctx1.sendIdx["copy"]=2;
- $8=self._collection();
- $ctx1.sendIdx["collection"]=2;
- self._assert_equals_($6,$8);
- $ctx1.sendIdx["assert:equals:"]=2;
- $10=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $9=$recv($10)._copy();
- $ctx1.sendIdx["copy"]=3;
- $11=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=2;
- self._assert_equals_($9,$11);
- $15=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=3;
- $14=$recv($15)._new();
- $ctx1.sendIdx["new"]=3;
- $13=$recv($14)._copy();
- $ctx1.sendIdx["copy"]=4;
- $16=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $12=$recv($13).__eq($16);
- $ctx1.sendIdx["="]=1;
- self._deny_($12);
- $ctx1.sendIdx["deny:"]=1;
- $19=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $18=$recv($19)._copy();
- $ctx1.sendIdx["copy"]=5;
- $17=$recv($18).__eq($recv(self._collectionClass())._new());
- $ctx1.sendIdx["="]=2;
- self._deny_($17);
- $ctx1.sendIdx["deny:"]=2;
- self._deny_($recv($recv(self._collection())._copy()).__eq(self._collectionWithNewValue()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCopy",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testCopy\x0a\x09self assert: self collectionClass new copy equals: self collectionClass new.\x0a\x09self assert: self collection copy equals: self collection.\x0a\x09self assert: self collectionWithNewValue copy equals: self collectionWithNewValue.\x0a\x09\x0a\x09self deny: self collectionClass new copy = self collection.\x0a\x09self deny: self collection copy = self collectionClass new.\x0a\x09self deny: self collection copy = self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["assert:equals:", "copy", "new", "collectionClass", "collection", "collectionWithNewValue", "deny:", "="]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testCopySeparates",
- protocol: "tests",
- fn: function (){
- var self=this;
- var original,copy;
- return $core.withContext(function($ctx1) {
- original=self._collection();
- $ctx1.sendIdx["collection"]=1;
- copy=$recv(original)._copy();
- $recv(copy)._addAll_(self._sampleNewValueAsCollection());
- self._assert_($recv(original).__eq(self._collection()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCopySeparates",{original:original,copy:copy},$globals.CollectionTest)});
- },
- args: [],
- source: "testCopySeparates\x0a\x09| original copy |\x0a\x09original := self collection.\x0a\x09copy := original copy.\x0a\x09copy addAll: self sampleNewValueAsCollection.\x0a\x09self assert: original = self collection",
- referencedClasses: [],
- messageSends: ["collection", "copy", "addAll:", "sampleNewValueAsCollection", "assert:", "="]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testDetect",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$6,$5,$7;
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- $1=self._collection();
- $ctx2.sendIdx["collection"]=1;
- return $recv($1)._detect_((function(){
- return true;
- }));
- $ctx2.sendIdx["detect:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- $2=self._collection();
- $ctx2.sendIdx["collection"]=2;
- return $recv($2)._detect_((function(){
- return false;
- }));
- $ctx2.sendIdx["detect:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }),$globals.Error);
- $ctx1.sendIdx["should:raise:"]=1;
- $3=$recv(self._sampleNewValueAsCollection())._detect_((function(){
- return true;
- }));
- $ctx1.sendIdx["detect:"]=3;
- $4=self._sampleNewValue();
- $ctx1.sendIdx["sampleNewValue"]=1;
- self._assert_equals_($3,$4);
- $ctx1.sendIdx["assert:equals:"]=1;
- $5=$recv(self._collectionWithNewValue())._detect_((function(each){
- return $core.withContext(function($ctx2) {
- $6=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=2;
- return $recv(each).__eq($6);
- $ctx2.sendIdx["="]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,6)});
- }));
- $ctx1.sendIdx["detect:"]=4;
- $7=self._sampleNewValue();
- $ctx1.sendIdx["sampleNewValue"]=3;
- self._assert_equals_($5,$7);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._collection())._detect_((function(each){
- return $core.withContext(function($ctx3) {
- return $recv(each).__eq(self._sampleNewValue());
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,8)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,7)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDetect",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testDetect\x0a\x09self\x0a\x09\x09shouldnt: [ self collection detect: [ true ] ]\x0a\x09\x09raise: Error.\x0a\x09self\x0a\x09\x09should: [ self collection detect: [ false ] ]\x0a\x09\x09raise: Error.\x0a\x09self assert: (self sampleNewValueAsCollection detect: [ true ]) equals: self sampleNewValue.\x0a\x09self assert: (self collectionWithNewValue detect: [ :each | each = self sampleNewValue ]) equals: self sampleNewValue.\x0a\x09self\x0a\x09\x09should: [ self collection detect: [ :each | each = self sampleNewValue ] ]\x0a\x09\x09raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["shouldnt:raise:", "detect:", "collection", "should:raise:", "assert:equals:", "sampleNewValueAsCollection", "sampleNewValue", "collectionWithNewValue", "="]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testDetectIfNone",
- protocol: "tests",
- fn: function (){
- var self=this;
- var sentinel;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$5,$4,$6,$7,$9,$8,$10;
- sentinel=$recv($globals.Object)._new();
- $3=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $2=$recv($3)._detect_ifNone_((function(){
- return true;
- }),(function(){
- return sentinel;
- }));
- $ctx1.sendIdx["detect:ifNone:"]=1;
- $1=$recv($2).__tild_eq(sentinel);
- self._assert_($1);
- $5=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $4=$recv($5)._detect_ifNone_((function(){
- return false;
- }),(function(){
- return sentinel;
- }));
- $ctx1.sendIdx["detect:ifNone:"]=2;
- self._assert_equals_($4,sentinel);
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=$recv(self._sampleNewValueAsCollection())._detect_ifNone_((function(){
- return true;
- }),(function(){
- return sentinel;
- }));
- $ctx1.sendIdx["detect:ifNone:"]=3;
- $7=self._sampleNewValue();
- $ctx1.sendIdx["sampleNewValue"]=1;
- self._assert_equals_($6,$7);
- $ctx1.sendIdx["assert:equals:"]=2;
- $8=$recv(self._collectionWithNewValue())._detect_ifNone_((function(each){
- return $core.withContext(function($ctx2) {
- $9=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=2;
- return $recv(each).__eq($9);
- $ctx2.sendIdx["="]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,7)});
- }),(function(){
- return sentinel;
- }));
- $ctx1.sendIdx["detect:ifNone:"]=4;
- $10=self._sampleNewValue();
- $ctx1.sendIdx["sampleNewValue"]=3;
- self._assert_equals_($8,$10);
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_($recv(self._collection())._detect_ifNone_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__eq(self._sampleNewValue());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,9)});
- }),(function(){
- return sentinel;
- })),sentinel);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDetectIfNone",{sentinel:sentinel},$globals.CollectionTest)});
- },
- args: [],
- source: "testDetectIfNone\x0a\x09| sentinel |\x0a\x09sentinel := Object new.\x0a\x09self assert: (self collection detect: [ true ] ifNone: [ sentinel ]) ~= sentinel.\x0a\x09self assert: (self collection detect: [ false ] ifNone: [ sentinel ]) equals: sentinel.\x0a\x09self assert: (self sampleNewValueAsCollection detect: [ true ] ifNone: [ sentinel ]) equals: self sampleNewValue.\x0a\x09self assert: (self collectionWithNewValue detect: [ :each | each = self sampleNewValue ] ifNone: [ sentinel ]) equals: self sampleNewValue.\x0a\x09self assert: (self collection detect: [ :each | each = self sampleNewValue ] ifNone: [ sentinel ]) equals: sentinel",
- referencedClasses: ["Object"],
- messageSends: ["new", "assert:", "~=", "detect:ifNone:", "collection", "assert:equals:", "sampleNewValueAsCollection", "sampleNewValue", "collectionWithNewValue", "="]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testDo",
- protocol: "tests",
- fn: function (){
- var self=this;
- var newCollection;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- newCollection=$recv($globals.OrderedCollection)._new();
- $ctx1.sendIdx["new"]=1;
- $1=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $recv($1)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(newCollection)._add_(each);
- $ctx2.sendIdx["add:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["do:"]=1;
- self._assertSameContents_as_(self._collection(),newCollection);
- $ctx1.sendIdx["assertSameContents:as:"]=1;
- newCollection=$recv($globals.OrderedCollection)._new();
- $2=self._collectionWithDuplicates();
- $ctx1.sendIdx["collectionWithDuplicates"]=1;
- $recv($2)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(newCollection)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- self._assertSameContents_as_(self._collectionWithDuplicates(),newCollection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDo",{newCollection:newCollection},$globals.CollectionTest)});
- },
- args: [],
- source: "testDo\x0a\x09| newCollection |\x0a\x09newCollection := OrderedCollection new.\x0a\x09self collection do: [ :each |\x0a\x09\x09newCollection add: each ].\x0a\x09self\x0a\x09\x09assertSameContents: self collection\x0a\x09\x09as: newCollection.\x0a\x09newCollection := OrderedCollection new.\x0a\x09self collectionWithDuplicates do: [ :each |\x0a\x09\x09newCollection add: each ].\x0a\x09self\x0a\x09\x09assertSameContents: self collectionWithDuplicates\x0a\x09\x09as: newCollection",
- referencedClasses: ["OrderedCollection"],
- messageSends: ["new", "do:", "collection", "add:", "assertSameContents:as:", "collectionWithDuplicates"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testEquality",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5,$6,$7,$8,$11,$10,$12,$9,$14,$13;
- $2=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $1=$recv($2)._new();
- $ctx1.sendIdx["new"]=1;
- $4=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=2;
- $3=$recv($4)._new();
- $ctx1.sendIdx["new"]=2;
- self._assert_equals_($1,$3);
- $ctx1.sendIdx["assert:equals:"]=1;
- $5=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=2;
- self._assert_equals_($5,$6);
- $ctx1.sendIdx["assert:equals:"]=2;
- $7=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $8=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=2;
- self._assert_equals_($7,$8);
- $11=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=3;
- $10=$recv($11)._new();
- $ctx1.sendIdx["new"]=3;
- $12=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $9=$recv($10).__eq($12);
- $ctx1.sendIdx["="]=1;
- self._deny_($9);
- $ctx1.sendIdx["deny:"]=1;
- $14=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $13=$recv($14).__eq($recv(self._collectionClass())._new());
- $ctx1.sendIdx["="]=2;
- self._deny_($13);
- $ctx1.sendIdx["deny:"]=2;
- self._deny_($recv(self._collection()).__eq(self._collectionWithNewValue()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEquality",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testEquality\x0a\x09self assert: self collectionClass new equals: self collectionClass new.\x0a\x09self assert: self collection equals: self collection.\x0a\x09self assert: self collectionWithNewValue equals: self collectionWithNewValue.\x0a\x09\x0a\x09self deny: self collectionClass new = self collection.\x0a\x09self deny: self collection = self collectionClass new.\x0a\x09self deny: self collection = self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["assert:equals:", "new", "collectionClass", "collection", "collectionWithNewValue", "deny:", "="]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testIfEmptyFamily",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$5,$4,$6,$9,$8,$7,$11,$10,$13,$12,$15,$14,$16,$19,$18,$17,$21,$20,$23,$22,$24,$25,$27,$26,$29,$28;
- $3=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $2=$recv($3)._new();
- $ctx1.sendIdx["new"]=1;
- $1=$recv($2)._ifEmpty_((function(){
- return (42);
- }));
- $ctx1.sendIdx["ifEmpty:"]=1;
- self._assert_equals_($1,(42));
- $ctx1.sendIdx["assert:equals:"]=1;
- $5=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $4=$recv($5)._ifEmpty_((function(){
- return (42);
- }));
- $6=self._collection();
- $ctx1.sendIdx["collection"]=2;
- self._assert_equals_($4,$6);
- $ctx1.sendIdx["assert:equals:"]=2;
- $9=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=2;
- $8=$recv($9)._new();
- $ctx1.sendIdx["new"]=2;
- $7=$recv($8)._ifNotEmpty_((function(){
- return (42);
- }));
- $ctx1.sendIdx["ifNotEmpty:"]=1;
- $11=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=3;
- $10=$recv($11)._new();
- $ctx1.sendIdx["new"]=3;
- self._assert_equals_($7,$10);
- $ctx1.sendIdx["assert:equals:"]=3;
- $13=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $12=$recv($13)._ifNotEmpty_((function(){
- return (42);
- }));
- $ctx1.sendIdx["ifNotEmpty:"]=2;
- self._assert_equals_($12,(42));
- $ctx1.sendIdx["assert:equals:"]=4;
- $15=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $14=$recv($15)._ifNotEmpty_((function(col){
- return col;
- }));
- $16=self._collection();
- $ctx1.sendIdx["collection"]=5;
- self._assert_equals_($14,$16);
- $ctx1.sendIdx["assert:equals:"]=5;
- $19=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=4;
- $18=$recv($19)._new();
- $ctx1.sendIdx["new"]=4;
- $17=$recv($18)._ifEmpty_ifNotEmpty_((function(){
- return (42);
- }),(function(){
- return (999);
- }));
- $ctx1.sendIdx["ifEmpty:ifNotEmpty:"]=1;
- self._assert_equals_($17,(42));
- $ctx1.sendIdx["assert:equals:"]=6;
- $21=self._collection();
- $ctx1.sendIdx["collection"]=6;
- $20=$recv($21)._ifEmpty_ifNotEmpty_((function(){
- return (42);
- }),(function(){
- return (999);
- }));
- $ctx1.sendIdx["ifEmpty:ifNotEmpty:"]=2;
- self._assert_equals_($20,(999));
- $ctx1.sendIdx["assert:equals:"]=7;
- $23=self._collection();
- $ctx1.sendIdx["collection"]=7;
- $22=$recv($23)._ifEmpty_ifNotEmpty_((function(){
- return (42);
- }),(function(col){
- return col;
- }));
- $24=self._collection();
- $ctx1.sendIdx["collection"]=8;
- self._assert_equals_($22,$24);
- $ctx1.sendIdx["assert:equals:"]=8;
- $25=$recv($recv(self._collectionClass())._new())._ifNotEmpty_ifEmpty_((function(){
- return (42);
- }),(function(){
- return (999);
- }));
- $ctx1.sendIdx["ifNotEmpty:ifEmpty:"]=1;
- self._assert_equals_($25,(999));
- $ctx1.sendIdx["assert:equals:"]=9;
- $27=self._collection();
- $ctx1.sendIdx["collection"]=9;
- $26=$recv($27)._ifNotEmpty_ifEmpty_((function(){
- return (42);
- }),(function(){
- return (999);
- }));
- $ctx1.sendIdx["ifNotEmpty:ifEmpty:"]=2;
- self._assert_equals_($26,(42));
- $ctx1.sendIdx["assert:equals:"]=10;
- $29=self._collection();
- $ctx1.sendIdx["collection"]=10;
- $28=$recv($29)._ifNotEmpty_ifEmpty_((function(col){
- return col;
- }),(function(){
- return (999);
- }));
- self._assert_equals_($28,self._collection());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIfEmptyFamily",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testIfEmptyFamily\x0a\x09self assert: (self collectionClass new ifEmpty: [ 42 ]) equals: 42.\x0a\x09self assert: (self collection ifEmpty: [ 42 ]) equals: self collection.\x0a\x0a\x09self assert: (self collectionClass new ifNotEmpty: [ 42 ]) equals: self collectionClass new.\x0a\x09self assert: (self collection ifNotEmpty: [ 42 ]) equals: 42.\x0a\x09self assert: (self collection ifNotEmpty: [ :col | col ]) equals: self collection.\x0a\x09\x0a\x09self assert: (self collectionClass new ifEmpty: [ 42 ] ifNotEmpty: [ 999 ]) equals: 42.\x0a\x09self assert: (self collection ifEmpty: [ 42 ] ifNotEmpty: [ 999 ]) equals: 999.\x0a\x09self assert: (self collection ifEmpty: [ 42 ] ifNotEmpty: [ :col | col ]) equals: self collection.\x0a\x0a\x09self assert: (self collectionClass new ifNotEmpty: [ 42 ] ifEmpty: [ 999 ]) equals: 999.\x0a\x09self assert: (self collection ifNotEmpty: [ 42 ] ifEmpty: [ 999 ]) equals: 42.\x0a\x09self assert: (self collection ifNotEmpty: [ :col | col ] ifEmpty: [ 999 ]) equals: self collection.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "ifEmpty:", "new", "collectionClass", "collection", "ifNotEmpty:", "ifEmpty:ifNotEmpty:", "ifNotEmpty:ifEmpty:"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testIsEmpty",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($recv(self._collectionClass())._new())._isEmpty();
- $ctx1.sendIdx["isEmpty"]=1;
- self._assert_($1);
- self._deny_($recv(self._collection())._isEmpty());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIsEmpty",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testIsEmpty\x0a\x09self assert: self collectionClass new isEmpty.\x0a\x09self deny: self collection isEmpty",
- referencedClasses: [],
- messageSends: ["assert:", "isEmpty", "new", "collectionClass", "deny:", "collection"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testNoneSatisfy",
- protocol: "tests",
- fn: function (){
- var self=this;
- var anyOne;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- $1=self._collection();
- $ctx1.sendIdx["collection"]=1;
- anyOne=$recv($1)._anyOne();
- $3=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $2=$recv($3)._noneSatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__eq(anyOne);
- $ctx2.sendIdx["="]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["noneSatisfy:"]=1;
- self._deny_($2);
- self._assert_($recv(self._collection())._noneSatisfy_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__eq($recv($globals.Object)._new());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- })));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNoneSatisfy",{anyOne:anyOne},$globals.CollectionTest)});
- },
- args: [],
- source: "testNoneSatisfy\x0a\x09| anyOne |\x0a\x09anyOne := self collection anyOne.\x0a\x09self deny: (self collection noneSatisfy: [ :each | each = anyOne ]).\x0a\x09self assert: (self collection noneSatisfy: [ :each | each = Object new ])",
- referencedClasses: ["Object"],
- messageSends: ["anyOne", "collection", "deny:", "noneSatisfy:", "=", "assert:", "new"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testRemoveAll",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._collection();
- $recv($2)._removeAll();
- $1=$recv($2)._yourself();
- self._assert_equals_($1,$recv(self._collectionClass())._new());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemoveAll",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testRemoveAll\x0a\x09self assert: (self collection removeAll; yourself) equals: self collectionClass new",
- referencedClasses: [],
- messageSends: ["assert:equals:", "removeAll", "collection", "yourself", "new", "collectionClass"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testSelect",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$7,$9,$10,$8,$12,$13,$11,$14,$16,$17,$15;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._select_((function(){
- return false;
- }));
- $ctx1.sendIdx["select:"]=1;
- $4=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $3=$recv($4)._new();
- $ctx1.sendIdx["new"]=1;
- self._assert_equals_($1,$3);
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $5=$recv($6)._select_((function(){
- return true;
- }));
- $ctx1.sendIdx["select:"]=2;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=3;
- self._assert_equals_($5,$7);
- $ctx1.sendIdx["assert:equals:"]=2;
- $9=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $8=$recv($9)._select_((function(each){
- return $core.withContext(function($ctx2) {
- $10=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=1;
- return $recv(each).__eq($10);
- $ctx2.sendIdx["="]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- $ctx1.sendIdx["select:"]=3;
- self._assert_equals_($8,self._sampleNewValueAsCollection());
- $ctx1.sendIdx["assert:equals:"]=3;
- $12=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=2;
- $11=$recv($12)._select_((function(each){
- return $core.withContext(function($ctx2) {
- $13=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=2;
- return $recv(each).__tild_eq($13);
- $ctx2.sendIdx["~="]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,4)});
- }));
- $ctx1.sendIdx["select:"]=4;
- $14=self._collection();
- $ctx1.sendIdx["collection"]=4;
- self._assert_equals_($11,$14);
- $ctx1.sendIdx["assert:equals:"]=4;
- $16=self._collection();
- $ctx1.sendIdx["collection"]=5;
- $15=$recv($16)._select_((function(each){
- return $core.withContext(function($ctx2) {
- $17=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=3;
- return $recv(each).__eq($17);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,5)});
- }));
- $ctx1.sendIdx["select:"]=5;
- self._assert_equals_($15,$recv(self._collectionClass())._new());
- $ctx1.sendIdx["assert:equals:"]=5;
- self._assert_equals_($recv(self._collectionWithNewValue())._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__tild_eq(self._sampleNewValue());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,6)});
- })),self._collection());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSelect",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testSelect\x0a\x09self assert: (self collection select: [ false ]) equals: self collectionClass new.\x0a\x09self assert: (self collection select: [ true ]) equals: self collection.\x0a\x09self assert: (self collectionWithNewValue select: [ :each | each = self sampleNewValue ]) equals: self sampleNewValueAsCollection.\x0a\x09self assert: (self collectionWithNewValue select: [ :each | each ~= self sampleNewValue ]) equals: self collection.\x0a\x09self assert: (self collection select: [ :each | each = self sampleNewValue ]) equals: self collectionClass new.\x0a\x09self assert: (self collectionWithNewValue select: [ :each | each ~= self sampleNewValue ]) equals: self collection",
- referencedClasses: [],
- messageSends: ["assert:equals:", "select:", "collection", "new", "collectionClass", "collectionWithNewValue", "=", "sampleNewValue", "sampleNewValueAsCollection", "~="]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testSelectThenCollect",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$7,$9,$8;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._select_thenCollect_((function(){
- return false;
- }),"isString");
- $ctx1.sendIdx["select:thenCollect:"]=1;
- $4=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $3=$recv($4)._new();
- $ctx1.sendIdx["new"]=1;
- self._assert_equals_($1,$3);
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $5=$recv($6)._select_thenCollect_((function(){
- return true;
- }),(function(x){
- return x;
- }));
- $ctx1.sendIdx["select:thenCollect:"]=2;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=3;
- self._assert_equals_($5,$7);
- $ctx1.sendIdx["assert:equals:"]=2;
- $8=$recv(self._collection())._select_thenCollect_((function(each){
- return $core.withContext(function($ctx2) {
- $9=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=1;
- return $recv(each).__eq($9);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,4)});
- }),(function(x){
- return x;
- }));
- $ctx1.sendIdx["select:thenCollect:"]=3;
- self._assert_equals_($8,$recv(self._collectionClass())._new());
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_($recv(self._collectionWithNewValue())._select_thenCollect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each).__tild_eq(self._sampleNewValue());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,6)});
- }),"printString"),self._collectionOfPrintStrings());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSelectThenCollect",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testSelectThenCollect\x0a\x09self assert: (self collection select: [ false ] thenCollect: #isString) equals: self collectionClass new.\x0a\x09self assert: (self collection select: [ true ] thenCollect: [:x|x]) equals: self collection.\x0a\x09self assert: (self collection select: [ :each | each = self sampleNewValue ] thenCollect: [:x|x]) equals: self collectionClass new.\x0a\x09self assert: (self collectionWithNewValue select: [ :each | each ~= self sampleNewValue ] thenCollect: #printString) equals: self collectionOfPrintStrings",
- referencedClasses: [],
- messageSends: ["assert:equals:", "select:thenCollect:", "collection", "new", "collectionClass", "=", "sampleNewValue", "collectionWithNewValue", "~=", "collectionOfPrintStrings"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testSingle",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv(self._collectionClass())._new())._single();
- $ctx2.sendIdx["single"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- $ctx1.sendIdx["should:raise:"]=1;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._collection())._single();
- $ctx2.sendIdx["single"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- self._assert_equals_($recv(self._sampleNewValueAsCollection())._single(),self._sampleNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSingle",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testSingle\x0a\x09self should: [ self collectionClass new single ] raise: Error.\x0a\x09self should: [ self collection single ] raise: Error.\x0a\x09self assert: self sampleNewValueAsCollection single equals: self sampleNewValue",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "single", "new", "collectionClass", "collection", "assert:equals:", "sampleNewValueAsCollection", "sampleNewValue"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testSize",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv($recv(self._collectionClass())._new())._size();
- $ctx1.sendIdx["size"]=1;
- self._assert_equals_($1,(0));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=$recv(self._sampleNewValueAsCollection())._size();
- $ctx1.sendIdx["size"]=2;
- self._assert_equals_($2,(1));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv(self._collection())._size(),self._collectionSize());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSize",{},$globals.CollectionTest)});
- },
- args: [],
- source: "testSize\x0a\x09self assert: self collectionClass new size equals: 0.\x0a\x09self assert: self sampleNewValueAsCollection size equals: 1.\x0a\x09self assert: self collection size equals: self collectionSize",
- referencedClasses: [],
- messageSends: ["assert:equals:", "size", "new", "collectionClass", "sampleNewValueAsCollection", "collection", "collectionSize"]
- }),
- $globals.CollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return nil;
- },
- args: [],
- source: "collectionClass\x0a\x09\x22Answers class of collection type tested,\x0a\x09or nil if test is abstract\x22\x0a\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.CollectionTest.klass);
- $core.addMethod(
- $core.method({
- selector: "isAbstract",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._collectionClass())._isNil();
- }, function($ctx1) {$ctx1.fill(self,"isAbstract",{},$globals.CollectionTest.klass)});
- },
- args: [],
- source: "isAbstract\x0a\x09^ self collectionClass isNil",
- referencedClasses: [],
- messageSends: ["isNil", "collectionClass"]
- }),
- $globals.CollectionTest.klass);
- $core.addClass("IndexableCollectionTest", $globals.CollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collectionWithNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionWithNewValue",{},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "collectionWithNewValue\x0a\x09\x22Answers a collection which shows how\x0a\x09self collection would look after adding\x0a\x09self sampleNewValue at self sampleNewIndex\x22\x0a\x09\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewIndex",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sampleNewIndex",{},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "sampleNewIndex\x0a\x09\x22Answers a value that can be used as index in at:put: or at:ifAbsentPut:\x22\x0a\x09\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNonIndexesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"sampleNonIndexesDo:",{aBlock:aBlock},$globals.IndexableCollectionTest)});
- },
- args: ["aBlock"],
- source: "sampleNonIndexesDo: aBlock\x0a\x09\x22Executes block a few times,\x0a\x09each time passing value that is known\x0a\x09not to be an index, as the first parameter\x22\x0a\x09\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "samplesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"samplesDo:",{aBlock:aBlock},$globals.IndexableCollectionTest)});
- },
- args: ["aBlock"],
- source: "samplesDo: aBlock\x0a\x09\x22Executes block a few times,\x0a\x09each time passing known index and value stored\x0a\x09under that index as the parameters\x22\x0a\x09\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAt",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- self._nonIndexesDo_((function(each){
- return $core.withContext(function($ctx2) {
- return self._should_raise_((function(){
- return $core.withContext(function($ctx3) {
- $1=self._collection();
- $ctx3.sendIdx["collection"]=1;
- return $recv($1)._at_(each);
- $ctx3.sendIdx["at:"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }),$globals.Error);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- return self._assert_equals_($recv(self._collection())._at_(index),value);
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAt",{},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testAt\x0a\x09self nonIndexesDo: [ :each |\x0a\x09\x09self should: [ self collection at: each ] raise: Error ].\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09self assert: (self collection at: index) equals: value ]",
- referencedClasses: ["Error"],
- messageSends: ["nonIndexesDo:", "should:raise:", "at:", "collection", "samplesDo:", "assert:equals:"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfAbsent",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3;
- self._nonIndexesDo_((function(each){
- return $core.withContext(function($ctx2) {
- $2=self._collection();
- $ctx2.sendIdx["collection"]=1;
- $1=$recv($2)._at_ifAbsent_(each,(function(){
- return $core.withContext(function($ctx3) {
- return self._sampleNewValue();
- $ctx3.sendIdx["sampleNewValue"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- $ctx2.sendIdx["at:ifAbsent:"]=1;
- $3=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=2;
- return self._assert_equals_($1,$3);
- $ctx2.sendIdx["assert:equals:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- return self._assert_equals_($recv(self._collection())._at_ifAbsent_(index,(function(){
- return $core.withContext(function($ctx3) {
- return self._sampleNewValue();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,4)});
- })),value);
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfAbsent",{},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testAtIfAbsent\x0a\x09self nonIndexesDo: [ :each |\x0a\x09\x09self assert: (self collection at: each ifAbsent: [ self sampleNewValue ]) equals: self sampleNewValue ].\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09self assert: (self collection at: index ifAbsent: [ self sampleNewValue ]) equals: value ].",
- referencedClasses: [],
- messageSends: ["nonIndexesDo:", "assert:equals:", "at:ifAbsent:", "collection", "sampleNewValue", "samplesDo:"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfAbsentPut",
- protocol: "tests",
- fn: function (){
- var self=this;
- var newCollection;
- return $core.withContext(function($ctx1) {
- var $1;
- newCollection=self._collection();
- $ctx1.sendIdx["collection"]=1;
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- $1=$recv(newCollection)._at_ifAbsentPut_(index,(function(){
- return $core.withContext(function($ctx3) {
- return self._sampleNewValue();
- $ctx3.sendIdx["sampleNewValue"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- $ctx2.sendIdx["at:ifAbsentPut:"]=1;
- return self._assert_equals_($1,value);
- $ctx2.sendIdx["assert:equals:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,1)});
- }));
- self._assert_equals_(newCollection,self._collection());
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv(newCollection)._at_ifAbsentPut_(self._sampleNewIndex(),(function(){
- return $core.withContext(function($ctx2) {
- return self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- })),self._sampleNewValue());
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_(newCollection,self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfAbsentPut",{newCollection:newCollection},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testAtIfAbsentPut\x0a\x09| newCollection |\x0a\x09newCollection := self collection.\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09self assert: (newCollection at: index ifAbsentPut: [ self sampleNewValue ]) equals: value ].\x0a\x09self assert: newCollection equals: self collection.\x0a\x09self assert: (newCollection at: self sampleNewIndex ifAbsentPut: [ self sampleNewValue ]) equals: self sampleNewValue.\x0a\x09self assert: newCollection equals: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["collection", "samplesDo:", "assert:equals:", "at:ifAbsentPut:", "sampleNewValue", "sampleNewIndex", "collectionWithNewValue"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfPresent",
- protocol: "tests",
- fn: function (){
- var self=this;
- var visited,sentinel;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3;
- sentinel=$recv($globals.Object)._new();
- self._nonIndexesDo_((function(each){
- return $core.withContext(function($ctx2) {
- visited=nil;
- visited;
- $2=self._collection();
- $ctx2.sendIdx["collection"]=1;
- $1=$recv($2)._at_ifPresent_(each,(function(value1){
- visited=value1;
- visited;
- return sentinel;
- }));
- $ctx2.sendIdx["at:ifPresent:"]=1;
- self._assert_equals_($1,nil);
- $ctx2.sendIdx["assert:equals:"]=1;
- return self._assert_($recv(visited)._isNil());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- visited=nil;
- visited;
- $4=self._collection();
- $ctx2.sendIdx["collection"]=2;
- $3=$recv($4)._at_ifPresent_(index,(function(value2){
- visited=value2;
- visited;
- return sentinel;
- }));
- self._assert_equals_($3,sentinel);
- $ctx2.sendIdx["assert:equals:"]=2;
- return self._assert_equals_(visited,$recv(self._collection())._at_(index));
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,3)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfPresent",{visited:visited,sentinel:sentinel},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testAtIfPresent\x0a\x09| visited sentinel |\x0a\x09sentinel := Object new.\x0a\x09self nonIndexesDo: [ :each |\x0a\x09\x09visited := nil.\x0a\x09\x09self assert: (self collection at: each ifPresent: [ :value1 | visited := value1. sentinel ]) equals: nil.\x0a\x09\x09self assert: visited isNil ].\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09visited := nil.\x0a\x09\x09self assert: (self collection at: index ifPresent: [ :value2 | visited := value2. sentinel ]) equals: sentinel.\x0a\x09\x09self assert: visited equals: (self collection at: index) ]",
- referencedClasses: ["Object"],
- messageSends: ["new", "nonIndexesDo:", "assert:equals:", "at:ifPresent:", "collection", "assert:", "isNil", "samplesDo:", "at:"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfPresentIfAbsent",
- protocol: "tests",
- fn: function (){
- var self=this;
- var visited,sentinel;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$5,$4;
- sentinel=$recv($globals.Object)._new();
- self._nonIndexesDo_((function(each){
- return $core.withContext(function($ctx2) {
- visited=nil;
- visited;
- $2=self._collection();
- $ctx2.sendIdx["collection"]=1;
- $1=$recv($2)._at_ifPresent_ifAbsent_(each,(function(value1){
- visited=value1;
- visited;
- return sentinel;
- }),(function(){
- return $core.withContext(function($ctx3) {
- return self._sampleNewValue();
- $ctx3.sendIdx["sampleNewValue"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }));
- $ctx2.sendIdx["at:ifPresent:ifAbsent:"]=1;
- $3=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=2;
- self._assert_equals_($1,$3);
- $ctx2.sendIdx["assert:equals:"]=1;
- return self._assert_($recv(visited)._isNil());
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- visited=nil;
- visited;
- $5=self._collection();
- $ctx2.sendIdx["collection"]=2;
- $4=$recv($5)._at_ifPresent_ifAbsent_(index,(function(value2){
- visited=value2;
- visited;
- return sentinel;
- }),(function(){
- return $core.withContext(function($ctx3) {
- return self._sampleNewValue();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,6)});
- }));
- self._assert_equals_($4,sentinel);
- $ctx2.sendIdx["assert:equals:"]=2;
- return self._assert_equals_(visited,$recv(self._collection())._at_(index));
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,4)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfPresentIfAbsent",{visited:visited,sentinel:sentinel},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testAtIfPresentIfAbsent\x0a\x09| visited sentinel |\x0a\x09sentinel := Object new.\x0a\x09self nonIndexesDo: [ :each |\x0a\x09\x09visited := nil.\x0a\x09\x09self assert: (self collection at: each ifPresent: [ :value1 | visited := value1. sentinel ] ifAbsent: [ self sampleNewValue ] ) equals: self sampleNewValue.\x0a\x09\x09self assert: visited isNil ].\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09visited := nil.\x0a\x09\x09self assert: (self collection at: index ifPresent: [ :value2 | visited := value2. sentinel ] ifAbsent: [ self sampleNewValue ]) equals: sentinel.\x0a\x09\x09self assert: visited equals: (self collection at: index) ]",
- referencedClasses: ["Object"],
- messageSends: ["new", "nonIndexesDo:", "assert:equals:", "at:ifPresent:ifAbsent:", "collection", "sampleNewValue", "assert:", "isNil", "samplesDo:", "at:"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAtPut",
- protocol: "tests",
- fn: function (){
- var self=this;
- var newCollection;
- return $core.withContext(function($ctx1) {
- newCollection=self._collection();
- $ctx1.sendIdx["collection"]=1;
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- return $recv(newCollection)._at_put_(index,value);
- $ctx2.sendIdx["at:put:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,1)});
- }));
- self._assert_equals_(newCollection,self._collection());
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(newCollection)._at_put_(self._sampleNewIndex(),self._sampleNewValue());
- self._assert_equals_(newCollection,self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtPut",{newCollection:newCollection},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testAtPut\x0a\x09| newCollection |\x0a\x09newCollection := self collection.\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09newCollection at: index put: value ].\x0a\x09self assert: newCollection equals: self collection.\x0a\x09newCollection at: self sampleNewIndex put: self sampleNewValue.\x0a\x09self assert: newCollection equals: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["collection", "samplesDo:", "at:put:", "assert:equals:", "sampleNewIndex", "sampleNewValue", "collectionWithNewValue"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testIndexOf",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- $1=self._collection();
- $ctx2.sendIdx["collection"]=1;
- return $recv($1)._indexOf_(self._sampleNewValue());
- $ctx2.sendIdx["indexOf:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- return self._assert_equals_($recv(self._collection())._indexOf_(value),index);
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIndexOf",{},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testIndexOf\x0a\x09self should: [ self collection indexOf: self sampleNewValue ] raise: Error.\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09self assert: (self collection indexOf: value) equals: index ]",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "indexOf:", "collection", "sampleNewValue", "samplesDo:", "assert:equals:"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testIndexOfWithNull",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsNull;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- jsNull=$recv($globals.JSON)._parse_("null");
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- $2=self._collection();
- $recv($2)._at_put_(index,jsNull);
- $1=$recv($2)._indexOf_(jsNull);
- return self._assert_equals_($1,index);
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIndexOfWithNull",{jsNull:jsNull},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testIndexOfWithNull\x0a\x09| jsNull |\x0a\x09jsNull := JSON parse: 'null'.\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09self assert: (self collection at: index put: jsNull; indexOf: jsNull) equals: index ]",
- referencedClasses: ["JSON"],
- messageSends: ["parse:", "samplesDo:", "assert:equals:", "at:put:", "collection", "indexOf:"]
- }),
- $globals.IndexableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testWithIndexDo",
- protocol: "tests",
- fn: function (){
- var self=this;
- var collection;
- return $core.withContext(function($ctx1) {
- collection=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $recv(self._collection())._withIndexDo_((function(each,index){
- return $core.withContext(function($ctx2) {
- return self._assert_equals_($recv(collection)._at_(index),each);
- }, function($ctx2) {$ctx2.fillBlock({each:each,index:index},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testWithIndexDo",{collection:collection},$globals.IndexableCollectionTest)});
- },
- args: [],
- source: "testWithIndexDo\x0a\x09| collection |\x0a\x09collection := self collection.\x0a\x09\x0a\x09self collection withIndexDo: [ :each :index |\x0a\x09\x09self assert: (collection at: index) equals: each ]",
- referencedClasses: [],
- messageSends: ["collection", "withIndexDo:", "assert:equals:", "at:"]
- }),
- $globals.IndexableCollectionTest);
- $core.addClass("AssociativeCollectionTest", $globals.IndexableCollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collectionKeys",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionKeys",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "collectionKeys\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionValues",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionValues",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "collectionValues\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "nonIndexesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aBlock)._value_((5));
- $ctx1.sendIdx["value:"]=1;
- $recv(aBlock)._value_((function(){
- }));
- $ctx1.sendIdx["value:"]=2;
- $recv(aBlock)._value_($recv($globals.Object)._new());
- $ctx1.sendIdx["value:"]=3;
- $recv(aBlock)._value_("z");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nonIndexesDo:",{aBlock:aBlock},$globals.AssociativeCollectionTest)});
- },
- args: ["aBlock"],
- source: "nonIndexesDo: aBlock\x0a\x09aBlock value: 5.\x0a\x09aBlock value: [].\x0a\x09aBlock value: Object new.\x0a\x09aBlock value: 'z'",
- referencedClasses: ["Object"],
- messageSends: ["value:", "new"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewIndex",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "new";
- },
- args: [],
- source: "sampleNewIndex\x0a\x09^ 'new'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "samplesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aBlock)._value_value_("a",(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"samplesDo:",{aBlock:aBlock},$globals.AssociativeCollectionTest)});
- },
- args: ["aBlock"],
- source: "samplesDo: aBlock\x0a\x09aBlock value: 'a' value: 2",
- referencedClasses: [],
- messageSends: ["value:value:"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAddAll",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$4,$1,$5,$7,$8,$9,$6,$10,$12,$11;
- (
- $ctx1.supercall = true,
- ($globals.AssociativeCollectionTest.superclass||$boot.nilAsClass).fn.prototype._testAddAll.apply($recv(self), []));
- $ctx1.supercall = false;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $3=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $recv($2)._addAll_($3);
- $ctx1.sendIdx["addAll:"]=1;
- $4=$recv($2)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $1=$4;
- $5=self._collection();
- $ctx1.sendIdx["collection"]=3;
- self._assert_equals_($1,$5);
- $ctx1.sendIdx["assert:equals:"]=1;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $8=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $recv($7)._addAll_($8);
- $ctx1.sendIdx["addAll:"]=2;
- $9=$recv($7)._yourself();
- $ctx1.sendIdx["yourself"]=2;
- $6=$9;
- $10=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=2;
- self._assert_equals_($6,$10);
- $ctx1.sendIdx["assert:equals:"]=2;
- $12=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=3;
- $recv($12)._addAll_(self._collection());
- $11=$recv($12)._yourself();
- self._assert_equals_($11,self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddAll",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testAddAll\x0a\x09super testAddAll.\x0a\x09self assert: (self collection addAll: self collection; yourself) equals: self collection.\x0a\x09self assert: (self collection addAll: self collectionWithNewValue; yourself) equals: self collectionWithNewValue.\x0a\x09self assert: (self collectionWithNewValue addAll: self collection; yourself) equals: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["testAddAll", "assert:equals:", "addAll:", "collection", "yourself", "collectionWithNewValue"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAsDictionary",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv($recv($recv(self._collectionClass())._new())._asDictionary())._isMemberOf_($globals.Dictionary));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsDictionary",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testAsDictionary\x0aself assert: ( self collectionClass new asDictionary isMemberOf: Dictionary ).",
- referencedClasses: ["Dictionary"],
- messageSends: ["assert:", "isMemberOf:", "asDictionary", "new", "collectionClass"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testAsHashedCollection",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv($recv($recv(self._collectionClass())._new())._asHashedCollection())._isMemberOf_($globals.HashedCollection));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsHashedCollection",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testAsHashedCollection\x0aself assert: ( self collectionClass new asHashedCollection isMemberOf: HashedCollection ).",
- referencedClasses: ["HashedCollection"],
- messageSends: ["assert:", "isMemberOf:", "asHashedCollection", "new", "collectionClass"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testComma",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$4,$6,$7,$5,$8,$10,$9;
- (
- $ctx1.supercall = true,
- ($globals.AssociativeCollectionTest.superclass||$boot.nilAsClass).fn.prototype._testComma.apply($recv(self), []));
- $ctx1.supercall = false;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $3=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $1=$recv($2).__comma($3);
- $ctx1.sendIdx[","]=1;
- $4=self._collection();
- $ctx1.sendIdx["collection"]=3;
- self._assert_equals_($1,$4);
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $7=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $5=$recv($6).__comma($7);
- $ctx1.sendIdx[","]=2;
- $8=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=2;
- self._assert_equals_($5,$8);
- $ctx1.sendIdx["assert:equals:"]=2;
- $10=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=3;
- $9=$recv($10).__comma(self._collection());
- self._assert_equals_($9,self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testComma",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testComma\x0a\x09super testComma.\x0a\x09self assert: self collection, self collection equals: self collection.\x0a\x09self assert: self collection, self collectionWithNewValue equals: self collectionWithNewValue.\x0a\x09self assert: self collectionWithNewValue, self collection equals: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["testComma", "assert:equals:", ",", "collection", "collectionWithNewValue"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testFrom",
- protocol: "tests",
- fn: function (){
- var self=this;
- var associations;
- return $core.withContext(function($ctx1) {
- var $1;
- $1="a".__minus_gt((1));
- $ctx1.sendIdx["->"]=1;
- associations=[$1,"b".__minus_gt((2))];
- self._assertSameContents_as_($recv($recv(self._class())._collectionClass())._from_(associations),$globals.HashedCollection._newFromPairs_(["a",(1),"b",(2)]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testFrom",{associations:associations},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testFrom\x0a\x22Accept a collection of associations.\x22\x0a| associations |\x0aassociations := { 'a' -> 1. 'b' -> 2 }.\x0aself assertSameContents: ( self class collectionClass from: associations ) as: #{ 'a' -> 1. 'b' -> 2 }.",
- referencedClasses: [],
- messageSends: ["->", "assertSameContents:as:", "from:", "collectionClass", "class"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testKeys",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$4;
- $2=$recv($recv(self._collectionClass())._new())._keys();
- $ctx1.sendIdx["keys"]=1;
- $1=$recv($2)._isEmpty();
- self._assert_($1);
- $3=$recv(self._collection())._keys();
- $ctx1.sendIdx["keys"]=2;
- $4=self._collectionKeys();
- $ctx1.sendIdx["collectionKeys"]=1;
- self._assertSameContents_as_($3,$4);
- $ctx1.sendIdx["assertSameContents:as:"]=1;
- self._assertSameContents_as_($recv(self._collectionWithNewValue())._keys(),$recv(self._collectionKeys()).__comma([self._sampleNewIndex()]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testKeys",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testKeys\x0a\x09self assert:self collectionClass new keys isEmpty.\x0a\x09self assertSameContents:self collection keys as: self collectionKeys.\x0a\x09self assertSameContents:self collectionWithNewValue keys as: self collectionKeys, { self sampleNewIndex }",
- referencedClasses: [],
- messageSends: ["assert:", "isEmpty", "keys", "new", "collectionClass", "assertSameContents:as:", "collection", "collectionKeys", "collectionWithNewValue", ",", "sampleNewIndex"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testNewFromPairs",
- protocol: "tests",
- fn: function (){
- var self=this;
- var flattenedAssociations;
- return $core.withContext(function($ctx1) {
- flattenedAssociations=["a",(1),"b",(2)];
- self._assertSameContents_as_($recv($recv(self._class())._collectionClass())._newFromPairs_(flattenedAssociations),$globals.HashedCollection._newFromPairs_(["a",(1),"b",(2)]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNewFromPairs",{flattenedAssociations:flattenedAssociations},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testNewFromPairs\x0a\x22Accept an array in which all odd indexes are keys and evens are values.\x22\x0a| flattenedAssociations |\x0aflattenedAssociations := { 'a'. 1. 'b'. 2 }.\x0aself assertSameContents: ( self class collectionClass newFromPairs: flattenedAssociations ) as: #{ 'a' -> 1. 'b' -> 2 }.",
- referencedClasses: [],
- messageSends: ["assertSameContents:as:", "newFromPairs:", "collectionClass", "class"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testPrintString",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$4;
- $3=self._collectionClass();
- $ctx1.sendIdx["collectionClass"]=1;
- $2=$recv($3)._new();
- $recv($2)._at_put_("firstname","James");
- $ctx1.sendIdx["at:put:"]=1;
- $recv($2)._at_put_("lastname","Bond");
- $1=$recv($2)._printString();
- $4=$recv("a ".__comma($recv(self._collectionClass())._name())).__comma(" ('firstname' -> 'James' , 'lastname' -> 'Bond')");
- $ctx1.sendIdx[","]=1;
- self._assert_equals_($1,$4);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPrintString",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testPrintString\x0a\x09self\x0a\x09\x09assert: (self collectionClass new\x0a\x09\x09\x09\x09\x09\x09\x09at:'firstname' put: 'James';\x0a\x09\x09\x09\x09\x09\x09\x09at:'lastname' put: 'Bond';\x0a\x09\x09\x09\x09\x09\x09\x09printString)\x0a\x09\x09equals: 'a ', self collectionClass name, ' (''firstname'' -> ''James'' , ''lastname'' -> ''Bond'')'",
- referencedClasses: [],
- messageSends: ["assert:equals:", "at:put:", "new", "collectionClass", "printString", ",", "name"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testRemoveKey",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$6,$4,$8,$7;
- self._nonIndexesDo_((function(each){
- var collection;
- return $core.withContext(function($ctx2) {
- collection=self._collection();
- $ctx2.sendIdx["collection"]=1;
- collection;
- self._should_raise_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(collection)._removeKey_(each);
- $ctx3.sendIdx["removeKey:"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }),$globals.Error);
- $1=collection;
- $2=self._collection();
- $ctx2.sendIdx["collection"]=2;
- return self._assert_equals_($1,$2);
- $ctx2.sendIdx["assert:equals:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each,collection:collection},$ctx1,1)});
- }));
- self._samplesDo_((function(index,value){
- var collection;
- return $core.withContext(function($ctx2) {
- collection=self._collection();
- $ctx2.sendIdx["collection"]=3;
- collection;
- $3=$recv(collection)._removeKey_(index);
- $ctx2.sendIdx["removeKey:"]=2;
- self._assert_equals_($3,value);
- $ctx2.sendIdx["assert:equals:"]=2;
- $5=collection;
- $6=self._collection();
- $ctx2.sendIdx["collection"]=4;
- $4=$recv($5).__eq($6);
- return self._deny_($4);
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value,collection:collection},$ctx1,3)});
- }));
- $8=self._collectionWithNewValue();
- $recv($8)._removeKey_(self._sampleNewIndex());
- $7=$recv($8)._yourself();
- self._assert_equals_($7,self._collection());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemoveKey",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testRemoveKey\x0a\x09self nonIndexesDo: [ :each |\x0a\x09\x09| collection |\x0a\x09\x09collection := self collection.\x0a\x09\x09self should: [ collection removeKey: each ] raise: Error.\x0a\x09\x09self assert: collection equals: self collection ].\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09| collection |\x0a\x09\x09collection := self collection.\x0a\x09\x09self assert: (collection removeKey: index) equals: value.\x0a\x09\x09self deny: collection = self collection ].\x0a\x09self\x0a\x09\x09assert: (self collectionWithNewValue removeKey: self sampleNewIndex; yourself)\x0a\x09\x09equals: self collection",
- referencedClasses: ["Error"],
- messageSends: ["nonIndexesDo:", "collection", "should:raise:", "removeKey:", "assert:equals:", "samplesDo:", "deny:", "=", "collectionWithNewValue", "sampleNewIndex", "yourself"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testRemoveKeyIfAbsent",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$7,$8,$6,$10,$9;
- self._nonIndexesDo_((function(each){
- var collection;
- return $core.withContext(function($ctx2) {
- collection=self._collection();
- $ctx2.sendIdx["collection"]=1;
- collection;
- $1=$recv(collection)._removeKey_ifAbsent_(each,(function(){
- return $core.withContext(function($ctx3) {
- return self._sampleNewValue();
- $ctx3.sendIdx["sampleNewValue"]=1;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }));
- $ctx2.sendIdx["removeKey:ifAbsent:"]=1;
- $2=self._sampleNewValue();
- $ctx2.sendIdx["sampleNewValue"]=2;
- self._assert_equals_($1,$2);
- $ctx2.sendIdx["assert:equals:"]=1;
- $3=collection;
- $4=self._collection();
- $ctx2.sendIdx["collection"]=2;
- return self._assert_equals_($3,$4);
- $ctx2.sendIdx["assert:equals:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({each:each,collection:collection},$ctx1,1)});
- }));
- self._samplesDo_((function(index,value){
- var collection;
- return $core.withContext(function($ctx2) {
- collection=self._collection();
- $ctx2.sendIdx["collection"]=3;
- collection;
- $5=$recv(collection)._removeKey_ifAbsent_(index,(function(){
- return $core.withContext(function($ctx3) {
- return self._sampleNewValue();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,4)});
- }));
- $ctx2.sendIdx["removeKey:ifAbsent:"]=2;
- self._assert_equals_($5,value);
- $ctx2.sendIdx["assert:equals:"]=3;
- $7=collection;
- $8=self._collection();
- $ctx2.sendIdx["collection"]=4;
- $6=$recv($7).__eq($8);
- return self._deny_($6);
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value,collection:collection},$ctx1,3)});
- }));
- $10=self._collectionWithNewValue();
- $recv($10)._removeKey_ifAbsent_(self._sampleNewIndex(),(function(){
- return $core.withContext(function($ctx2) {
- return self._assert_(false);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,5)});
- }));
- $9=$recv($10)._yourself();
- self._assert_equals_($9,self._collection());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemoveKeyIfAbsent",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testRemoveKeyIfAbsent\x0a\x09self nonIndexesDo: [ :each |\x0a\x09\x09| collection |\x0a\x09\x09collection := self collection.\x0a\x09\x09self assert: (collection removeKey: each ifAbsent: [ self sampleNewValue ]) equals: self sampleNewValue.\x0a\x09\x09self assert: collection equals: self collection ].\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09| collection |\x0a\x09\x09collection := self collection.\x0a\x09\x09self assert: (collection removeKey: index ifAbsent: [ self sampleNewValue ]) equals: value.\x0a\x09\x09self deny: collection = self collection ].\x0a\x09self\x0a\x09\x09assert: (self collectionWithNewValue removeKey: self sampleNewIndex ifAbsent: [ self assert: false ]; yourself)\x0a\x09\x09equals: self collection",
- referencedClasses: [],
- messageSends: ["nonIndexesDo:", "collection", "assert:equals:", "removeKey:ifAbsent:", "sampleNewValue", "samplesDo:", "deny:", "=", "collectionWithNewValue", "sampleNewIndex", "assert:", "yourself"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testValues",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$4;
- $2=$recv($recv(self._collectionClass())._new())._values();
- $ctx1.sendIdx["values"]=1;
- $1=$recv($2)._isEmpty();
- self._assert_($1);
- $3=$recv(self._collection())._values();
- $ctx1.sendIdx["values"]=2;
- $4=self._collectionValues();
- $ctx1.sendIdx["collectionValues"]=1;
- self._assertSameContents_as_($3,$4);
- $ctx1.sendIdx["assertSameContents:as:"]=1;
- self._assertSameContents_as_($recv(self._collectionWithNewValue())._values(),$recv(self._collectionValues()).__comma([self._sampleNewValue()]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testValues",{},$globals.AssociativeCollectionTest)});
- },
- args: [],
- source: "testValues\x0a\x09self assert:self collectionClass new values isEmpty.\x0a\x09self assertSameContents:self collection values as: self collectionValues.\x0a\x09self assertSameContents:self collectionWithNewValue values as: self collectionValues, { self sampleNewValue }",
- referencedClasses: [],
- messageSends: ["assert:", "isEmpty", "values", "new", "collectionClass", "assertSameContents:as:", "collection", "collectionValues", "collectionWithNewValue", ",", "sampleNewValue"]
- }),
- $globals.AssociativeCollectionTest);
- $core.addClass("DictionaryTest", $globals.AssociativeCollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Dictionary)._new();
- $recv($1)._at_put_((1),(1));
- $ctx1.sendIdx["at:put:"]=1;
- $recv($1)._at_put_("a",(2));
- $ctx1.sendIdx["at:put:"]=2;
- $recv($1)._at_put_(true,(3));
- $ctx1.sendIdx["at:put:"]=3;
- $recv($1)._at_put_((1).__at((3)),(-4));
- $ctx1.sendIdx["at:put:"]=4;
- $recv($1)._at_put_(self["@sampleBlock"],(9));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collection",{},$globals.DictionaryTest)});
- },
- args: [],
- source: "collection\x0a\x09^ Dictionary new\x0a\x09\x09at: 1 put: 1;\x0a\x09\x09at: 'a' put: 2;\x0a\x09\x09at: true put: 3;\x0a\x09\x09at: 1@3 put: -4;\x0a\x09\x09at: sampleBlock put: 9;\x0a\x09\x09yourself",
- referencedClasses: ["Dictionary"],
- messageSends: ["at:put:", "new", "@", "yourself"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "collectionKeys",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return [(1),"a",true,(1).__at((3)),self["@sampleBlock"]];
- }, function($ctx1) {$ctx1.fill(self,"collectionKeys",{},$globals.DictionaryTest)});
- },
- args: [],
- source: "collectionKeys\x0a\x09^ {1. 'a'. true. 1@3. sampleBlock}",
- referencedClasses: [],
- messageSends: ["@"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "collectionOfPrintStrings",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Dictionary)._new();
- $recv($1)._at_put_((1),"1");
- $ctx1.sendIdx["at:put:"]=1;
- $recv($1)._at_put_("a","2");
- $ctx1.sendIdx["at:put:"]=2;
- $recv($1)._at_put_(true,"3");
- $ctx1.sendIdx["at:put:"]=3;
- $recv($1)._at_put_((1).__at((3)),"-4");
- $ctx1.sendIdx["at:put:"]=4;
- $recv($1)._at_put_(self["@sampleBlock"],"9");
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collectionOfPrintStrings",{},$globals.DictionaryTest)});
- },
- args: [],
- source: "collectionOfPrintStrings\x0a\x09^ Dictionary new\x0a\x09\x09at: 1 put: '1';\x0a\x09\x09at: 'a' put: '2';\x0a\x09\x09at: true put: '3';\x0a\x09\x09at: 1@3 put: '-4';\x0a\x09\x09at: sampleBlock put: '9';\x0a\x09\x09yourself",
- referencedClasses: ["Dictionary"],
- messageSends: ["at:put:", "new", "@", "yourself"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "collectionSize",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (5);
- },
- args: [],
- source: "collectionSize\x0a\x09^ 5",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "collectionValues",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return [(1),(2),(3),(-4),(9)];
- },
- args: [],
- source: "collectionValues\x0a\x09^ {1. 2. 3. -4. 9}",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithDuplicates",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Dictionary)._new();
- $recv($1)._at_put_((1),(1));
- $ctx1.sendIdx["at:put:"]=1;
- $recv($1)._at_put_("a",(2));
- $ctx1.sendIdx["at:put:"]=2;
- $recv($1)._at_put_(true,(3));
- $ctx1.sendIdx["at:put:"]=3;
- $recv($1)._at_put_((4),(-4));
- $ctx1.sendIdx["at:put:"]=4;
- $recv($1)._at_put_(self["@sampleBlock"],(9));
- $ctx1.sendIdx["at:put:"]=5;
- $recv($1)._at_put_("b",(1));
- $ctx1.sendIdx["at:put:"]=6;
- $recv($1)._at_put_((3),(3));
- $ctx1.sendIdx["at:put:"]=7;
- $recv($1)._at_put_(false,(12));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collectionWithDuplicates",{},$globals.DictionaryTest)});
- },
- args: [],
- source: "collectionWithDuplicates\x0a\x09^ Dictionary new\x0a\x09\x09at: 1 put: 1;\x0a\x09\x09at: 'a' put: 2;\x0a\x09\x09at: true put: 3;\x0a\x09\x09at: 4 put: -4;\x0a\x09\x09at: sampleBlock put: 9;\x0a\x09\x09at: 'b' put: 1;\x0a\x09\x09at: 3 put: 3;\x0a\x09\x09at: false put: 12;\x0a\x09\x09yourself",
- referencedClasses: ["Dictionary"],
- messageSends: ["at:put:", "new", "yourself"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Dictionary)._new();
- $recv($1)._at_put_((1),(1));
- $ctx1.sendIdx["at:put:"]=1;
- $recv($1)._at_put_("a",(2));
- $ctx1.sendIdx["at:put:"]=2;
- $recv($1)._at_put_(true,(3));
- $ctx1.sendIdx["at:put:"]=3;
- $recv($1)._at_put_((1).__at((3)),(-4));
- $ctx1.sendIdx["at:put:"]=4;
- $recv($1)._at_put_(self["@sampleBlock"],(9));
- $ctx1.sendIdx["at:put:"]=5;
- $recv($1)._at_put_("new","N");
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collectionWithNewValue",{},$globals.DictionaryTest)});
- },
- args: [],
- source: "collectionWithNewValue\x0a\x09^ Dictionary new\x0a\x09\x09at: 1 put: 1;\x0a\x09\x09at: 'a' put: 2;\x0a\x09\x09at: true put: 3;\x0a\x09\x09at: 1@3 put: -4;\x0a\x09\x09at: sampleBlock put: 9;\x0a\x09\x09at: 'new' put: 'N';\x0a\x09\x09yourself",
- referencedClasses: ["Dictionary"],
- messageSends: ["at:put:", "new", "@", "yourself"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewValueAsCollection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Dictionary)._new();
- $recv($1)._at_put_("new","N");
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"sampleNewValueAsCollection",{},$globals.DictionaryTest)});
- },
- args: [],
- source: "sampleNewValueAsCollection\x0a\x09^ Dictionary new\x0a\x09\x09at: 'new' put: 'N';\x0a\x09\x09yourself",
- referencedClasses: ["Dictionary"],
- messageSends: ["at:put:", "new", "yourself"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "samplesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.DictionaryTest.superclass||$boot.nilAsClass).fn.prototype._samplesDo_.apply($recv(self), [aBlock]));
- $ctx1.supercall = false;
- $recv(aBlock)._value_value_(true,(3));
- $ctx1.sendIdx["value:value:"]=1;
- $recv(aBlock)._value_value_((1).__at((3)),(-4));
- $ctx1.sendIdx["value:value:"]=2;
- $recv(aBlock)._value_value_(self["@sampleBlock"],(9));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"samplesDo:",{aBlock:aBlock},$globals.DictionaryTest)});
- },
- args: ["aBlock"],
- source: "samplesDo: aBlock\x0a\x09super samplesDo: aBlock.\x0a\x09aBlock value: true value: 3.\x0a\x09aBlock value: 1@3 value: -4.\x0a\x09aBlock value: sampleBlock value: 9",
- referencedClasses: [],
- messageSends: ["samplesDo:", "value:value:", "@"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "testAccessing",
- protocol: "tests",
- fn: function (){
- var self=this;
- var d;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$9,$10,$8,$12,$13,$11;
- d=$recv($globals.Dictionary)._new();
- $recv(d)._at_put_("hello","world");
- $ctx1.sendIdx["at:put:"]=1;
- $1=$recv(d)._at_("hello");
- $ctx1.sendIdx["at:"]=1;
- self._assert_equals_($1,"world");
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=$recv(d)._at_ifAbsent_("hello",(function(){
- return nil;
- }));
- $ctx1.sendIdx["at:ifAbsent:"]=1;
- self._assert_equals_($2,"world");
- $ctx1.sendIdx["assert:equals:"]=2;
- self._deny_($recv($recv(d)._at_ifAbsent_("foo",(function(){
- return nil;
- }))).__eq("world"));
- $ctx1.sendIdx["deny:"]=1;
- $3=$recv(d)._includesKey_("hello");
- $ctx1.sendIdx["includesKey:"]=1;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=1;
- $4=$recv(d)._includesKey_("foo");
- $ctx1.sendIdx["includesKey:"]=2;
- self._deny_($4);
- $ctx1.sendIdx["deny:"]=2;
- $recv(d)._at_put_((1),(2));
- $ctx1.sendIdx["at:put:"]=2;
- $5=$recv(d)._at_((1));
- $ctx1.sendIdx["at:"]=2;
- self._assert_equals_($5,(2));
- $ctx1.sendIdx["assert:equals:"]=3;
- $6=d;
- $7=(1).__at((3));
- $ctx1.sendIdx["@"]=1;
- $recv($6)._at_put_($7,(3));
- $9=d;
- $10=(1).__at((3));
- $ctx1.sendIdx["@"]=2;
- $8=$recv($9)._at_($10);
- self._assert_equals_($8,(3));
- $12=d;
- $13=(1).__at((3));
- $ctx1.sendIdx["@"]=3;
- $11=$recv($12)._includesKey_($13);
- $ctx1.sendIdx["includesKey:"]=3;
- self._assert_($11);
- self._deny_($recv(d)._includesKey_((3).__at((1))));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAccessing",{d:d},$globals.DictionaryTest)});
- },
- args: [],
- source: "testAccessing\x0a\x09| d |\x0a\x0a\x09d := Dictionary new.\x0a\x0a\x09d at: 'hello' put: 'world'.\x0a\x09self assert: (d at: 'hello') equals: 'world'.\x0a\x09self assert: (d at: 'hello' ifAbsent: [ nil ]) equals: 'world'.\x0a\x09self deny: (d at: 'foo' ifAbsent: [ nil ]) = 'world'.\x0a\x0a\x09self assert: (d includesKey: 'hello').\x0a\x09self deny: (d includesKey: 'foo').\x0a\x0a\x09d at: 1 put: 2.\x0a\x09self assert: (d at: 1) equals: 2.\x0a\x0a\x09d at: 1@3 put: 3.\x0a\x09self assert: (d at: 1@3) equals: 3.\x0a\x0a\x09self assert: (d includesKey: 1@3).\x0a\x09self deny: (d includesKey: 3@1)",
- referencedClasses: ["Dictionary"],
- messageSends: ["new", "at:put:", "assert:equals:", "at:", "at:ifAbsent:", "deny:", "=", "assert:", "includesKey:", "@"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "testDynamicDictionaries",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv($globals.HashedCollection._newFromPairs_(["hello",(1)]))._asDictionary(),$recv($globals.Dictionary)._with_("hello".__minus_gt((1))));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDynamicDictionaries",{},$globals.DictionaryTest)});
- },
- args: [],
- source: "testDynamicDictionaries\x0a\x09self assert: #{'hello' -> 1} asDictionary equals: (Dictionary with: 'hello' -> 1)",
- referencedClasses: ["Dictionary"],
- messageSends: ["assert:equals:", "asDictionary", "with:", "->"]
- }),
- $globals.DictionaryTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.Dictionary;
- },
- args: [],
- source: "collectionClass\x0a\x09^ Dictionary",
- referencedClasses: ["Dictionary"],
- messageSends: []
- }),
- $globals.DictionaryTest.klass);
- $core.addClass("HashedCollectionTest", $globals.AssociativeCollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.HashedCollection._newFromPairs_(["b",(1),"a",(2),"c",(3),"d",(-4)]);
- },
- args: [],
- source: "collection\x0a\x09^ #{ 'b' -> 1. 'a' -> 2. 'c' -> 3. 'd' -> -4 }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionKeys",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return ["b","a","c","d"];
- },
- args: [],
- source: "collectionKeys\x0a\x09^ { 'b'. 'a'. 'c'. 'd' }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionOfPrintStrings",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.HashedCollection._newFromPairs_(["b","1","a","2","c","3","d","-4"]);
- },
- args: [],
- source: "collectionOfPrintStrings\x0a\x09^ #{ 'b' -> '1'. 'a' -> '2'. 'c' -> '3'. 'd' -> '-4' }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionSize",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (4);
- },
- args: [],
- source: "collectionSize\x0a\x09^ 4",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionValues",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return [(1),(2),(3),(-4)];
- },
- args: [],
- source: "collectionValues\x0a\x09^ { 1. 2. 3. -4 }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithDuplicates",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.HashedCollection._newFromPairs_(["b",(1),"a",(2),"c",(3),"d",(-4),"e",(1),"f",(2),"g",(10),"h",(0)]);
- },
- args: [],
- source: "collectionWithDuplicates\x0a\x09^ #{ 'b' -> 1. 'a' -> 2. 'c' -> 3. 'd' -> -4. 'e' -> 1. 'f' -> 2. 'g' -> 10. 'h' -> 0 }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.HashedCollection._newFromPairs_(["b",(1),"a",(2),"c",(3),"d",(-4),"new","N"]);
- },
- args: [],
- source: "collectionWithNewValue\x0a\x09^ #{ 'b' -> 1. 'a' -> 2. 'c' -> 3. 'd' -> -4. 'new' -> 'N' }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewValueAsCollection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.HashedCollection._newFromPairs_(["new","N"]);
- },
- args: [],
- source: "sampleNewValueAsCollection\x0a\x09^ #{ 'new' -> 'N' }",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testDynamicDictionaries",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv($globals.HashedCollection._newFromPairs_(["hello",(1)]))._asHashedCollection(),$recv($globals.HashedCollection)._with_("hello".__minus_gt((1))));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDynamicDictionaries",{},$globals.HashedCollectionTest)});
- },
- args: [],
- source: "testDynamicDictionaries\x0a\x09self assert: #{'hello' -> 1} asHashedCollection equals: (HashedCollection with: 'hello' -> 1)",
- referencedClasses: ["HashedCollection"],
- messageSends: ["assert:equals:", "asHashedCollection", "with:", "->"]
- }),
- $globals.HashedCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.HashedCollection;
- },
- args: [],
- source: "collectionClass\x0a\x09^ HashedCollection",
- referencedClasses: ["HashedCollection"],
- messageSends: []
- }),
- $globals.HashedCollectionTest.klass);
- $core.addClass("SequenceableCollectionTest", $globals.IndexableCollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collectionFirst",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionFirst",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "collectionFirst\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionFirstTwo",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionFirstTwo",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "collectionFirstTwo\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionLast",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionLast",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "collectionLast\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "collectionLastTwo",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"collectionLastTwo",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "collectionLastTwo\x0a\x09self subclassResponsibility",
- referencedClasses: [],
- messageSends: ["subclassResponsibility"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "nonIndexesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aBlock)._value_((0));
- $ctx1.sendIdx["value:"]=1;
- $recv(aBlock)._value_($recv(self._collectionSize()).__plus((1)));
- $ctx1.sendIdx["value:"]=2;
- $recv(aBlock)._value_("z");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"nonIndexesDo:",{aBlock:aBlock},$globals.SequenceableCollectionTest)});
- },
- args: ["aBlock"],
- source: "nonIndexesDo: aBlock\x0a\x09aBlock value: 0.\x0a\x09aBlock value: self collectionSize + 1.\x0a\x09aBlock value: 'z'",
- referencedClasses: [],
- messageSends: ["value:", "+", "collectionSize"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "samplesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aBlock)._value_value_((1),self._collectionFirst());
- $ctx1.sendIdx["value:value:"]=1;
- $recv(aBlock)._value_value_(self._collectionSize(),self._collectionLast());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"samplesDo:",{aBlock:aBlock},$globals.SequenceableCollectionTest)});
- },
- args: ["aBlock"],
- source: "samplesDo: aBlock\x0a\x09aBlock value: 1 value: self collectionFirst.\x0a\x09aBlock value: self collectionSize value: self collectionLast",
- referencedClasses: [],
- messageSends: ["value:value:", "collectionFirst", "collectionSize", "collectionLast"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testBeginsWith",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$5,$3,$7,$6;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._beginsWith_($recv(self._collectionClass())._new());
- $ctx1.sendIdx["beginsWith:"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $4=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $5=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $3=$recv($4)._beginsWith_($5);
- $ctx1.sendIdx["beginsWith:"]=2;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $6=$recv($7)._beginsWith_(self._collectionFirstTwo());
- $ctx1.sendIdx["beginsWith:"]=3;
- self._assert_($6);
- self._deny_($recv(self._collection())._beginsWith_(self._collectionLastTwo()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testBeginsWith",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testBeginsWith\x0a\x09self assert: (self collection beginsWith: self collectionClass new).\x0a\x09self assert: (self collection beginsWith: self collection).\x0a\x09self assert: (self collection beginsWith: self collectionFirstTwo).\x0a\x09self deny: (self collection beginsWith: self collectionLastTwo)",
- referencedClasses: [],
- messageSends: ["assert:", "beginsWith:", "collection", "new", "collectionClass", "collectionFirstTwo", "deny:", "collectionLastTwo"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testEndsWith",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$5,$3,$7,$6;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._endsWith_($recv(self._collectionClass())._new());
- $ctx1.sendIdx["endsWith:"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $4=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $5=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $3=$recv($4)._endsWith_($5);
- $ctx1.sendIdx["endsWith:"]=2;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $6=$recv($7)._endsWith_(self._collectionLastTwo());
- $ctx1.sendIdx["endsWith:"]=3;
- self._assert_($6);
- self._deny_($recv(self._collection())._endsWith_(self._collectionFirstTwo()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEndsWith",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testEndsWith\x0a\x09self assert: (self collection endsWith: self collectionClass new).\x0a\x09self assert: (self collection endsWith: self collection).\x0a\x09self assert: (self collection endsWith: self collectionLastTwo).\x0a\x09self deny: (self collection endsWith: self collectionFirstTwo)",
- referencedClasses: [],
- messageSends: ["assert:", "endsWith:", "collection", "new", "collectionClass", "collectionLastTwo", "deny:", "collectionFirstTwo"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testFirst",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv(self._collection())._first(),self._collectionFirst());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testFirst",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testFirst\x0a\x09self assert: self collection first equals: self collectionFirst",
- referencedClasses: [],
- messageSends: ["assert:equals:", "first", "collection", "collectionFirst"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testFirstN",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$7;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._first_((2));
- $ctx1.sendIdx["first:"]=1;
- self._assert_equals_($1,self._collectionFirstTwo());
- $ctx1.sendIdx["assert:equals:"]=1;
- $4=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $3=$recv($4)._first_((0));
- $ctx1.sendIdx["first:"]=2;
- self._assert_equals_($3,$recv(self._collectionClass())._new());
- $ctx1.sendIdx["assert:equals:"]=2;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $5=$recv($6)._first_(self._collectionSize());
- $ctx1.sendIdx["first:"]=3;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=4;
- self._assert_equals_($5,$7);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._collection())._first_((33));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testFirstN",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testFirstN\x0a\x09self \x0a\x09\x09assert: (self collection first: 2)\x0a\x09\x09equals: self collectionFirstTwo.\x0a\x09\x09\x0a\x09self\x0a\x09\x09assert: (self collection first: 0)\x0a\x09\x09equals: self collectionClass new.\x0a\x09\x09\x0a\x09self\x0a\x09\x09assert: (self collection first: self collectionSize)\x0a\x09\x09equals: self collection.\x0a\x09\x09\x0a\x09self should: [ self collection first: 33 ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["assert:equals:", "first:", "collection", "collectionFirstTwo", "new", "collectionClass", "collectionSize", "should:raise:"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testFourth",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._fourth();
- self._assert_equals_($1,$recv(self._collection())._at_((4)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testFourth",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testFourth\x0a\x09self assert: (self collection fourth) equals: (self collection at: 4)",
- referencedClasses: [],
- messageSends: ["assert:equals:", "fourth", "collection", "at:"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testIndexOfStartingAt",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsNull;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3;
- jsNull=$recv($globals.JSON)._parse_("null");
- self._samplesDo_((function(index,value){
- return $core.withContext(function($ctx2) {
- $2=self._collection();
- $ctx2.sendIdx["collection"]=1;
- $1=$recv($2)._indexOf_startingAt_(value,(1));
- $ctx2.sendIdx["indexOf:startingAt:"]=1;
- self._assert_equals_($1,index);
- $ctx2.sendIdx["assert:equals:"]=1;
- $4=self._collection();
- $ctx2.sendIdx["collection"]=2;
- $3=$recv($4)._indexOf_startingAt_(value,index);
- $ctx2.sendIdx["indexOf:startingAt:"]=2;
- self._assert_equals_($3,index);
- $ctx2.sendIdx["assert:equals:"]=2;
- return self._assert_equals_($recv(self._collection())._indexOf_startingAt_(value,$recv(index).__plus((1))),(0));
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIndexOfStartingAt",{jsNull:jsNull},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testIndexOfStartingAt\x0a\x09| jsNull |\x0a\x09jsNull := JSON parse: 'null'.\x0a\x09self samplesDo: [ :index :value |\x0a\x09\x09self assert: (self collection indexOf: value startingAt: 1) equals: index.\x0a\x09\x09self assert: (self collection indexOf: value startingAt: index) equals: index.\x0a\x09\x09self assert: (self collection indexOf: value startingAt: index+1) equals: 0 ]",
- referencedClasses: ["JSON"],
- messageSends: ["parse:", "samplesDo:", "assert:equals:", "indexOf:startingAt:", "collection", "+"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testIndexOfStartingAtWithNull",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsNull;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- jsNull=$recv($globals.JSON)._parse_("null");
- self._samplesDo_((function(index,value){
- var collection;
- return $core.withContext(function($ctx2) {
- collection=self._collection();
- collection;
- $recv(collection)._at_put_(index,jsNull);
- $1=$recv(collection)._indexOf_startingAt_(jsNull,(1));
- $ctx2.sendIdx["indexOf:startingAt:"]=1;
- self._assert_equals_($1,index);
- $ctx2.sendIdx["assert:equals:"]=1;
- $2=$recv(collection)._indexOf_startingAt_(jsNull,index);
- $ctx2.sendIdx["indexOf:startingAt:"]=2;
- self._assert_equals_($2,index);
- $ctx2.sendIdx["assert:equals:"]=2;
- return self._assert_equals_($recv(collection)._indexOf_startingAt_(jsNull,$recv(index).__plus((1))),(0));
- }, function($ctx2) {$ctx2.fillBlock({index:index,value:value,collection:collection},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIndexOfStartingAtWithNull",{jsNull:jsNull},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testIndexOfStartingAtWithNull\x0a\x09| jsNull |\x0a\x09jsNull := JSON parse: 'null'.\x0a\x09self samplesDo: [ :index :value | | collection |\x0a\x09\x09collection := self collection.\x0a\x09\x09collection at: index put: jsNull.\x0a\x09\x09self assert: (collection indexOf: jsNull startingAt: 1) equals: index.\x0a\x09\x09self assert: (collection indexOf: jsNull startingAt: index) equals: index.\x0a\x09\x09self assert: (collection indexOf: jsNull startingAt: index+1) equals: 0 ]",
- referencedClasses: ["JSON"],
- messageSends: ["parse:", "samplesDo:", "collection", "at:put:", "assert:equals:", "indexOf:startingAt:", "+"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testLast",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv(self._collection())._last(),self._collectionLast());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLast",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testLast\x0a\x09self assert: self collection last equals: self collectionLast",
- referencedClasses: [],
- messageSends: ["assert:equals:", "last", "collection", "collectionLast"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testLastN",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5,$7;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._last_((2));
- $ctx1.sendIdx["last:"]=1;
- self._assert_equals_($1,self._collectionLastTwo());
- $ctx1.sendIdx["assert:equals:"]=1;
- $4=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $3=$recv($4)._last_((0));
- $ctx1.sendIdx["last:"]=2;
- self._assert_equals_($3,$recv(self._collectionClass())._new());
- $ctx1.sendIdx["assert:equals:"]=2;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=3;
- $5=$recv($6)._last_(self._collectionSize());
- $ctx1.sendIdx["last:"]=3;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=4;
- self._assert_equals_($5,$7);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._collection())._last_((33));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLastN",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testLastN\x0a\x09self \x0a\x09\x09assert: (self collection last: 2) \x0a\x09\x09equals: self collectionLastTwo.\x0a\x09\x09\x0a\x09self\x0a\x09\x09assert: (self collection last: 0)\x0a\x09\x09equals: self collectionClass new.\x0a\x0a\x09self\x0a\x09\x09assert: (self collection last: self collectionSize)\x0a\x09\x09equals: self collection.\x0a\x0a\x09self should: [ self collection last: 33 ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["assert:equals:", "last:", "collection", "collectionLastTwo", "new", "collectionClass", "collectionSize", "should:raise:"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testSecond",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._second();
- self._assert_equals_($1,$recv(self._collection())._at_((2)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSecond",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testSecond\x0a\x09self assert: (self collection second) equals: (self collection at: 2)",
- referencedClasses: [],
- messageSends: ["assert:equals:", "second", "collection", "at:"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addMethod(
- $core.method({
- selector: "testThird",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $1=$recv($2)._third();
- self._assert_equals_($1,$recv(self._collection())._at_((3)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testThird",{},$globals.SequenceableCollectionTest)});
- },
- args: [],
- source: "testThird\x0a\x09self assert: (self collection third) equals: (self collection at: 3)",
- referencedClasses: [],
- messageSends: ["assert:equals:", "third", "collection", "at:"]
- }),
- $globals.SequenceableCollectionTest);
- $core.addClass("ArrayTest", $globals.SequenceableCollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return [(1), (2), (3), (-4)];
- },
- args: [],
- source: "collection\x0a\x09^ #(1 2 3 -4)",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionFirst",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (1);
- },
- args: [],
- source: "collectionFirst\x0a\x09^ 1",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionFirstTwo",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return [(1), (2)];
- },
- args: [],
- source: "collectionFirstTwo\x0a\x09^ #(1 2)",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionLast",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (-4);
- },
- args: [],
- source: "collectionLast\x0a\x09^ -4",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionLastTwo",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return [(3), (-4)];
- },
- args: [],
- source: "collectionLastTwo\x0a\x09^ #(3 -4)",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionOfPrintStrings",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return ["1", "2", "3", "-4"];
- },
- args: [],
- source: "collectionOfPrintStrings\x0a\x09^ #('1' '2' '3' '-4')",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionSize",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (4);
- },
- args: [],
- source: "collectionSize\x0a\x09^ 4",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithDuplicates",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return ["a", "b", "c", (1), (2), (1), "a", []];
- },
- args: [],
- source: "collectionWithDuplicates\x0a\x09^ #('a' 'b' 'c' 1 2 1 'a' ())",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return [(1), (2), (3), (-4), "N"];
- },
- args: [],
- source: "collectionWithNewValue\x0a\x09^ #(1 2 3 -4 'N')",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewIndex",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (5);
- },
- args: [],
- source: "sampleNewIndex\x0a\x09^ 5",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "samplesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.ArrayTest.superclass||$boot.nilAsClass).fn.prototype._samplesDo_.apply($recv(self), [aBlock]));
- $ctx1.supercall = false;
- $recv(aBlock)._value_value_((3),(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"samplesDo:",{aBlock:aBlock},$globals.ArrayTest)});
- },
- args: ["aBlock"],
- source: "samplesDo: aBlock\x0a\x09super samplesDo: aBlock.\x0a\x09aBlock value: 3 value: 3.",
- referencedClasses: [],
- messageSends: ["samplesDo:", "value:value:"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testAdd",
- protocol: "tests",
- fn: function (){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- array=self._collection();
- $recv(array)._add_((6));
- self._assert_equals_($recv(array)._last(),(6));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAdd",{array:array},$globals.ArrayTest)});
- },
- args: [],
- source: "testAdd \x0a\x09| array | \x0a\x09array := self collection. \x0a\x09array add: 6.\x0a\x09\x0a\x09self assert: array last equals: 6",
- referencedClasses: [],
- messageSends: ["collection", "add:", "assert:equals:", "last"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testAddFirst",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=self._collection();
- $recv($3)._addFirst_((0));
- $2=$recv($3)._yourself();
- $1=$recv($2)._first();
- self._assert_equals_($1,(0));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddFirst",{},$globals.ArrayTest)});
- },
- args: [],
- source: "testAddFirst\x0a\x09self assert: (self collection addFirst: 0; yourself) first equals: 0",
- referencedClasses: [],
- messageSends: ["assert:equals:", "first", "addFirst:", "collection", "yourself"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testPrintString",
- protocol: "tests",
- fn: function (){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$8;
- array=$recv($globals.Array)._new();
- $1=$recv(array)._printString();
- $ctx1.sendIdx["printString"]=1;
- self._assert_equals_($1,"an Array ()");
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=array;
- $recv($2)._add_((1));
- $ctx1.sendIdx["add:"]=1;
- $3=$recv($2)._add_((3));
- $ctx1.sendIdx["add:"]=2;
- $4=$recv(array)._printString();
- $ctx1.sendIdx["printString"]=2;
- self._assert_equals_($4,"an Array (1 3)");
- $ctx1.sendIdx["assert:equals:"]=2;
- $recv(array)._add_("foo");
- $5=$recv(array)._printString();
- $ctx1.sendIdx["printString"]=3;
- self._assert_equals_($5,"an Array (1 3 'foo')");
- $ctx1.sendIdx["assert:equals:"]=3;
- $6=array;
- $recv($6)._remove_((1));
- $ctx1.sendIdx["remove:"]=1;
- $recv($6)._remove_((3));
- $7=$recv(array)._printString();
- $ctx1.sendIdx["printString"]=4;
- self._assert_equals_($7,"an Array ('foo')");
- $ctx1.sendIdx["assert:equals:"]=4;
- $recv(array)._addLast_((3));
- $ctx1.sendIdx["addLast:"]=1;
- $8=$recv(array)._printString();
- $ctx1.sendIdx["printString"]=5;
- self._assert_equals_($8,"an Array ('foo' 3)");
- $ctx1.sendIdx["assert:equals:"]=5;
- $recv(array)._addLast_((3));
- self._assert_equals_($recv(array)._printString(),"an Array ('foo' 3 3)");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPrintString",{array:array},$globals.ArrayTest)});
- },
- args: [],
- source: "testPrintString\x0a\x09| array |\x0a\x09array := Array new.\x0a\x09self assert: array printString equals: 'an Array ()'.\x0a\x09array add: 1; add: 3.\x0a\x09self assert: array printString equals: 'an Array (1 3)'.\x0a\x09array add: 'foo'.\x0a\x09self assert: array printString equals: 'an Array (1 3 ''foo'')'.\x0a\x09array remove: 1; remove: 3.\x0a\x09self assert: array printString equals: 'an Array (''foo'')'.\x0a\x09array addLast: 3.\x0a\x09self assert: array printString equals: 'an Array (''foo'' 3)'.\x0a\x09array addLast: 3.\x0a\x09self assert: array printString equals: 'an Array (''foo'' 3 3)'.",
- referencedClasses: ["Array"],
- messageSends: ["new", "assert:equals:", "printString", "add:", "remove:", "addLast:"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testRemove",
- protocol: "tests",
- fn: function (){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- array=[(1), (2), (3), (4), (5)];
- $recv(array)._remove_((3));
- $ctx1.sendIdx["remove:"]=1;
- self._assert_equals_(array,[(1), (2), (4), (5)]);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(array)._remove_((3));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemove",{array:array},$globals.ArrayTest)});
- },
- args: [],
- source: "testRemove \x0a\x09| array |\x0a\x09array := #(1 2 3 4 5). \x0a\x09array remove: 3.\x0a\x0a\x09self assert: array equals: #(1 2 4 5).\x0a\x09self should: [ array remove: 3 ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["remove:", "assert:equals:", "should:raise:"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testRemoveFromTo",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=[(1), (2), (3), (4)]._removeFrom_to_((1),(3));
- $ctx1.sendIdx["removeFrom:to:"]=1;
- self._assert_equals_($1,[(4)]);
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=[(1), (2), (3), (4)]._removeFrom_to_((2),(3));
- $ctx1.sendIdx["removeFrom:to:"]=2;
- self._assert_equals_($2,[(1), (4)]);
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_([(1), (2), (3), (4)]._removeFrom_to_((2),(4)),[(1)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemoveFromTo",{},$globals.ArrayTest)});
- },
- args: [],
- source: "testRemoveFromTo\x0a\x09\x0a\x09self assert: (#(1 2 3 4) removeFrom: 1 to: 3) equals: #(4).\x0a\x09self assert: (#(1 2 3 4) removeFrom: 2 to: 3) equals: #(1 4).\x0a\x09self assert: (#(1 2 3 4) removeFrom: 2 to: 4) equals: #(1)",
- referencedClasses: [],
- messageSends: ["assert:equals:", "removeFrom:to:"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testRemoveIndex",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=[(1), (2), (3), (4)]._removeIndex_((2));
- $ctx1.sendIdx["removeIndex:"]=1;
- self._assert_equals_($1,[(1), (3), (4)]);
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=[(1), (2), (3), (4)]._removeIndex_((1));
- $ctx1.sendIdx["removeIndex:"]=2;
- self._assert_equals_($2,[(2), (3), (4)]);
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_(["hello"]._removeIndex_((1)),[]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemoveIndex",{},$globals.ArrayTest)});
- },
- args: [],
- source: "testRemoveIndex\x0a\x09\x0a\x09self assert: (#(1 2 3 4) removeIndex: 2) equals: #(1 3 4).\x0a\x09self assert: (#(1 2 3 4) removeIndex: 1) equals: #(2 3 4).\x0a\x09self assert: (#('hello') removeIndex: 1) equals: #()",
- referencedClasses: [],
- messageSends: ["assert:equals:", "removeIndex:"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testRemoveLast",
- protocol: "tests",
- fn: function (){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- array=[(1), (2)];
- $recv(array)._removeLast();
- self._assert_equals_($recv(array)._last(),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemoveLast",{array:array},$globals.ArrayTest)});
- },
- args: [],
- source: "testRemoveLast \x0a\x09| array |\x0a\x09array := #(1 2). \x0a\x09array removeLast.\x0a\x09\x0a\x09self assert: array last equals: 1",
- referencedClasses: [],
- messageSends: ["removeLast", "assert:equals:", "last"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testReversed",
- protocol: "tests",
- fn: function (){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- array=[(5), (4), (3), (2), (1)];
- self._assert_equals_($recv(array)._reversed(),[(1), (2), (3), (4), (5)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testReversed",{array:array},$globals.ArrayTest)});
- },
- args: [],
- source: "testReversed\x0a\x09|array|\x0a\x09array := #(5 4 3 2 1). \x0a\x09self assert: (array reversed) equals: #(1 2 3 4 5)",
- referencedClasses: [],
- messageSends: ["assert:equals:", "reversed"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "testSort",
- protocol: "tests",
- fn: function (){
- var self=this;
- var array;
- return $core.withContext(function($ctx1) {
- array=[(10), (1), (5)];
- $recv(array)._sort();
- self._assert_equals_(array,[(1), (5), (10)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSort",{array:array},$globals.ArrayTest)});
- },
- args: [],
- source: "testSort\x0a\x09| array |\x0a\x09array := #(10 1 5). \x0a\x09array sort.\x0a\x09self assert: array equals: #(1 5 10)",
- referencedClasses: [],
- messageSends: ["sort", "assert:equals:"]
- }),
- $globals.ArrayTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.Array;
- },
- args: [],
- source: "collectionClass\x0a\x09^ Array",
- referencedClasses: ["Array"],
- messageSends: []
- }),
- $globals.ArrayTest.klass);
- $core.addClass("StringTest", $globals.SequenceableCollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "helLo";
- },
- args: [],
- source: "collection\x0a\x09^ 'helLo'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionFirst",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "h";
- },
- args: [],
- source: "collectionFirst\x0a\x09^ 'h'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionFirstTwo",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "he";
- },
- args: [],
- source: "collectionFirstTwo\x0a\x09^ 'he'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionLast",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "o";
- },
- args: [],
- source: "collectionLast\x0a\x09^ 'o'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionLastTwo",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "Lo";
- },
- args: [],
- source: "collectionLastTwo\x0a\x09^ 'Lo'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionOfPrintStrings",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "'h''e''l''L''o'";
- },
- args: [],
- source: "collectionOfPrintStrings\x0a\x09^ '''h''''e''''l''''L''''o'''",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionSize",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (5);
- },
- args: [],
- source: "collectionSize\x0a\x09^ 5",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithDuplicates",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "abbaerten";
- },
- args: [],
- source: "collectionWithDuplicates\x0a\x09^ 'abbaerten'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "helLoN";
- },
- args: [],
- source: "collectionWithNewValue\x0a\x09^ 'helLoN'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "sampleNewValueAsCollection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return "N";
- },
- args: [],
- source: "sampleNewValueAsCollection\x0a\x09^ 'N'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "samplesDo:",
- protocol: "fixture",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.StringTest.superclass||$boot.nilAsClass).fn.prototype._samplesDo_.apply($recv(self), [aBlock]));
- $ctx1.supercall = false;
- $recv(aBlock)._value_value_((3),"l");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"samplesDo:",{aBlock:aBlock},$globals.StringTest)});
- },
- args: ["aBlock"],
- source: "samplesDo: aBlock\x0a\x09super samplesDo: aBlock.\x0a\x09aBlock value: 3 value: 'l'",
- referencedClasses: [],
- messageSends: ["samplesDo:", "value:value:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAddAll",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- $1=self._collection();
- $ctx2.sendIdx["collection"]=1;
- return $recv($1)._addAll_(self._collection());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddAll",{},$globals.StringTest)});
- },
- args: [],
- source: "testAddAll\x0a\x09\x22String instances are read-only\x22\x0a\x09self should: [ self collection addAll: self collection ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "addAll:", "collection"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAddRemove",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return "hello"._add_("a");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- $ctx1.sendIdx["should:raise:"]=1;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return "hello"._remove_("h");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddRemove",{},$globals.StringTest)});
- },
- args: [],
- source: "testAddRemove\x0a\x09self should: [ 'hello' add: 'a' ] raise: Error.\x0a\x09self should: [ 'hello' remove: 'h' ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "add:", "remove:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAsArray",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("hello"._asArray(),["h", "e", "l", "l", "o"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsArray",{},$globals.StringTest)});
- },
- args: [],
- source: "testAsArray\x0a\x09self assert: 'hello' asArray equals: #('h' 'e' 'l' 'l' 'o').",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asArray"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAsLowerCase",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("JACKIE"._asLowercase(),"jackie");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsLowerCase",{},$globals.StringTest)});
- },
- args: [],
- source: "testAsLowerCase\x0a\x09self assert: 'JACKIE' asLowercase equals: 'jackie'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asLowercase"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAsNumber",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1="3"._asNumber();
- $ctx1.sendIdx["asNumber"]=1;
- self._assert_equals_($1,(3));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2="-3"._asNumber();
- $ctx1.sendIdx["asNumber"]=2;
- self._assert_equals_($2,(-3));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_("-1.5"._asNumber(),(-1.5));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsNumber",{},$globals.StringTest)});
- },
- args: [],
- source: "testAsNumber\x0a\x09self assert: '3' asNumber equals: 3.\x0a\x09self assert: '-3' asNumber equals: -3.\x0a\x09self assert: '-1.5' asNumber equals: -1.5.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asNumber"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAsUpperCase",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("jackie"._asUppercase(),"JACKIE");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsUpperCase",{},$globals.StringTest)});
- },
- args: [],
- source: "testAsUpperCase\x0a\x09self assert: 'jackie' asUppercase equals: 'JACKIE'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asUppercase"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAsciiValue",
- protocol: "tests",
- fn: function (){
- var self=this;
- var characterA,characterU;
- return $core.withContext(function($ctx1) {
- var $1;
- characterA="A";
- characterU="U";
- $1=$recv(characterA)._asciiValue();
- $ctx1.sendIdx["asciiValue"]=1;
- self._assert_equals_($1,(65));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv(characterU)._asciiValue(),(85));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsciiValue",{characterA:characterA,characterU:characterU},$globals.StringTest)});
- },
- args: [],
- source: "testAsciiValue\x0a | characterA characterU |\x0a characterA := 'A'.\x0a characterU := 'U'.\x0a self assert: (characterA asciiValue) equals:65.\x0a self assert: (characterU asciiValue) equals:85",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asciiValue"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfAbsentPut",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return "hello"._at_ifAbsentPut_((6),(function(){
- return "a";
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfAbsentPut",{},$globals.StringTest)});
- },
- args: [],
- source: "testAtIfAbsentPut\x0a\x09\x22String instances are read-only\x22\x0a\x09self should: [ 'hello' at: 6 ifAbsentPut: [ 'a' ] ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "at:ifAbsentPut:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testAtPut",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return "hello"._at_put_((1),"a");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtPut",{},$globals.StringTest)});
- },
- args: [],
- source: "testAtPut\x0a\x09\x22String instances are read-only\x22\x0a\x09self should: [ 'hello' at: 1 put: 'a' ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "at:put:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testCapitalized",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- $1="test"._capitalized();
- $ctx1.sendIdx["capitalized"]=1;
- self._assert_equals_($1,"Test");
- $ctx1.sendIdx["assert:equals:"]=1;
- $2="Test"._capitalized();
- $ctx1.sendIdx["capitalized"]=2;
- self._assert_equals_($2,"Test");
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_(""._capitalized(),"");
- $ctx1.sendIdx["assert:equals:"]=3;
- $3="Test"._isCapitalized();
- $ctx1.sendIdx["isCapitalized"]=1;
- self._assert_equals_($3,true);
- $ctx1.sendIdx["assert:equals:"]=4;
- self._assert_equals_("test"._isCapitalized(),false);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCapitalized",{},$globals.StringTest)});
- },
- args: [],
- source: "testCapitalized\x0a\x09self assert: 'test' capitalized equals: 'Test'.\x0a\x09self assert: 'Test' capitalized equals: 'Test'.\x0a\x09self assert: '' capitalized equals: ''.\x0a\x09self assert: 'Test' isCapitalized equals: true.\x0a\x09self assert: 'test' isCapitalized equals: false.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "capitalized", "isCapitalized"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testCharCodeAt",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5;
- $1="jackie"._charCodeAt_((1));
- $ctx1.sendIdx["charCodeAt:"]=1;
- self._assert_equals_($1,(106));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2="jackie"._charCodeAt_((2));
- $ctx1.sendIdx["charCodeAt:"]=2;
- self._assert_equals_($2,(97));
- $ctx1.sendIdx["assert:equals:"]=2;
- $3="jackie"._charCodeAt_((3));
- $ctx1.sendIdx["charCodeAt:"]=3;
- self._assert_equals_($3,(99));
- $ctx1.sendIdx["assert:equals:"]=3;
- $4="jackie"._charCodeAt_((4));
- $ctx1.sendIdx["charCodeAt:"]=4;
- self._assert_equals_($4,(107));
- $ctx1.sendIdx["assert:equals:"]=4;
- $5="jackie"._charCodeAt_((5));
- $ctx1.sendIdx["charCodeAt:"]=5;
- self._assert_equals_($5,(105));
- $ctx1.sendIdx["assert:equals:"]=5;
- self._assert_equals_("jackie"._charCodeAt_((6)),(101));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCharCodeAt",{},$globals.StringTest)});
- },
- args: [],
- source: "testCharCodeAt\x0a\x09self assert: ('jackie' charCodeAt:1) equals: 106.\x0a\x09self assert: ('jackie' charCodeAt:2) equals: 97.\x0a\x09self assert: ('jackie' charCodeAt:3) equals: 99.\x0a\x09self assert: ('jackie' charCodeAt:4) equals: 107.\x0a\x09self assert: ('jackie' charCodeAt:5) equals: 105.\x0a\x09self assert: ('jackie' charCodeAt:6) equals: 101",
- referencedClasses: [],
- messageSends: ["assert:equals:", "charCodeAt:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testCopyFromTo",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1="jackie"._copyFrom_to_((1),(3));
- $ctx1.sendIdx["copyFrom:to:"]=1;
- self._assert_equals_($1,"jac");
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_("jackie"._copyFrom_to_((4),(6)),"kie");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCopyFromTo",{},$globals.StringTest)});
- },
- args: [],
- source: "testCopyFromTo\x0a\x09self assert: ('jackie' copyFrom: 1 to: 3) equals: 'jac'.\x0a\x09self assert: ('jackie' copyFrom: 4 to: 6) equals: 'kie'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "copyFrom:to:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testCopySeparates",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $2=$recv($3)._copy();
- $1=$recv($2).__eq_eq(self._collection());
- self._assert_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCopySeparates",{},$globals.StringTest)});
- },
- args: [],
- source: "testCopySeparates\x0a\x09\x22String instances are immutable\x22\x0a\x09self assert: self collection copy == self collection",
- referencedClasses: [],
- messageSends: ["assert:", "==", "copy", "collection"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testCopyWithoutAll",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("*hello* *world*"._copyWithoutAll_("*"),"hello world");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCopyWithoutAll",{},$globals.StringTest)});
- },
- args: [],
- source: "testCopyWithoutAll\x0a\x09self\x0a\x09\x09assert: ('*hello* *world*' copyWithoutAll: '*')\x0a\x09\x09equals: 'hello world'",
- referencedClasses: [],
- messageSends: ["assert:equals:", "copyWithoutAll:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testEquality",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- self._assert_equals_("hello","hello");
- $ctx1.sendIdx["assert:equals:"]=1;
- $1="hello".__eq("world");
- $ctx1.sendIdx["="]=1;
- self._deny_($1);
- $ctx1.sendIdx["deny:"]=1;
- $2="hello".__eq([]._at_ifAbsent_((1),(function(){
- })));
- $ctx1.sendIdx["="]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=2;
- $3="hello"._yourself();
- $ctx1.sendIdx["yourself"]=1;
- self._assert_equals_("hello",$3);
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_("hello"._yourself(),"hello");
- self._deny_("".__eq((0)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEquality",{},$globals.StringTest)});
- },
- args: [],
- source: "testEquality\x0a\x09self assert: 'hello' equals: 'hello'.\x0a\x09self deny: 'hello' = 'world'.\x0a\x09\x0a\x09\x22Test for issue 459\x22\x0a\x09self deny: 'hello' = (#() at: 1 ifAbsent: [ ]).\x0a\x0a\x09self assert: 'hello' equals: 'hello' yourself.\x0a\x09self assert: 'hello' yourself equals: 'hello'.\x0a\x0a\x09\x22test JS falsy value\x22\x0a\x09self deny: '' = 0",
- referencedClasses: [],
- messageSends: ["assert:equals:", "deny:", "=", "at:ifAbsent:", "yourself"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testIdentity",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$5;
- $1="hello".__eq_eq("hello");
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $2="hello".__eq_eq("world");
- $ctx1.sendIdx["=="]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=1;
- $4="hello"._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $3="hello".__eq_eq($4);
- $ctx1.sendIdx["=="]=3;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- $5=$recv("hello"._yourself()).__eq_eq("hello");
- $ctx1.sendIdx["=="]=4;
- self._assert_($5);
- self._deny_("".__eq_eq((0)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIdentity",{},$globals.StringTest)});
- },
- args: [],
- source: "testIdentity\x0a\x09self assert: 'hello' == 'hello'.\x0a\x09self deny: 'hello' == 'world'.\x0a\x0a\x09self assert: 'hello' == 'hello' yourself.\x0a\x09self assert: 'hello' yourself == 'hello'.\x0a\x0a\x09\x22test JS falsy value\x22\x0a\x09self deny: '' == 0",
- referencedClasses: [],
- messageSends: ["assert:", "==", "deny:", "yourself"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testIncludesSubString",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1="amber"._includesSubString_("ber");
- $ctx1.sendIdx["includesSubString:"]=1;
- self._assert_($1);
- self._deny_("amber"._includesSubString_("zork"));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIncludesSubString",{},$globals.StringTest)});
- },
- args: [],
- source: "testIncludesSubString\x0a\x09self assert: ('amber' includesSubString: 'ber').\x0a\x09self deny: ('amber' includesSubString: 'zork').",
- referencedClasses: [],
- messageSends: ["assert:", "includesSubString:", "deny:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testIndexOfStartingAtWithNull",
- protocol: "tests",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "testIndexOfStartingAtWithNull\x0a\x09\x22String cannot hold JS null\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testIndexOfWithNull",
- protocol: "tests",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "testIndexOfWithNull\x0a\x09\x22String cannot hold JS null\x22",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testIsVowel",
- protocol: "tests",
- fn: function (){
- var self=this;
- var vowel,consonant;
- return $core.withContext(function($ctx1) {
- var $1;
- vowel="u";
- consonant="z";
- $1=$recv(vowel)._isVowel();
- $ctx1.sendIdx["isVowel"]=1;
- self._assert_equals_($1,true);
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv(consonant)._isVowel(),false);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIsVowel",{vowel:vowel,consonant:consonant},$globals.StringTest)});
- },
- args: [],
- source: "testIsVowel\x0a |vowel consonant|\x0a vowel := 'u'.\x0a consonant := 'z'.\x0a self assert: vowel isVowel equals: true.\x0a self assert: consonant isVowel equals: false",
- referencedClasses: [],
- messageSends: ["assert:equals:", "isVowel"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testJoin",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_(","._join_(["hello", "world"]),"hello,world");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testJoin",{},$globals.StringTest)});
- },
- args: [],
- source: "testJoin\x0a\x09self assert: (',' join: #('hello' 'world')) equals: 'hello,world'",
- referencedClasses: [],
- messageSends: ["assert:equals:", "join:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testRemoveAll",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._collection())._removeAll();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemoveAll",{},$globals.StringTest)});
- },
- args: [],
- source: "testRemoveAll\x0a\x09self should: [ self collection removeAll ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "removeAll", "collection"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testReversed",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("jackiechan"._reversed(),"nahceikcaj");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testReversed",{},$globals.StringTest)});
- },
- args: [],
- source: "testReversed\x0a\x09self assert: 'jackiechan' reversed equals: 'nahceikcaj'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "reversed"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testStreamContents",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv($globals.String)._streamContents_((function(aStream){
- return $core.withContext(function($ctx2) {
- $recv(aStream)._nextPutAll_("hello");
- $ctx2.sendIdx["nextPutAll:"]=1;
- $recv(aStream)._space();
- return $recv(aStream)._nextPutAll_("world");
- }, function($ctx2) {$ctx2.fillBlock({aStream:aStream},$ctx1,1)});
- })),"hello world");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testStreamContents",{},$globals.StringTest)});
- },
- args: [],
- source: "testStreamContents\x0a\x09self\x0a\x09\x09assert: (String streamContents: [ :aStream |\x0a\x09\x09\x09aStream\x0a\x09\x09\x09\x09nextPutAll: 'hello'; space;\x0a\x09\x09\x09\x09nextPutAll: 'world' ])\x0a\x09\x09equals: 'hello world'",
- referencedClasses: ["String"],
- messageSends: ["assert:equals:", "streamContents:", "nextPutAll:", "space"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testSubStrings",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("jackiechan"._subStrings_("ie"),["jack", "chan"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSubStrings",{},$globals.StringTest)});
- },
- args: [],
- source: "testSubStrings\x0a\x09self assert: ('jackiechan' subStrings: 'ie') equals: #( 'jack' 'chan' ).",
- referencedClasses: [],
- messageSends: ["assert:equals:", "subStrings:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testTrim",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_(" jackie"._trimLeft(),"jackie");
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_("jackie "._trimRight(),"jackie");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTrim",{},$globals.StringTest)});
- },
- args: [],
- source: "testTrim\x0a\x09self assert: ' jackie' trimLeft equals: 'jackie'.\x0a\x09self assert: 'jackie ' trimRight equals: 'jackie'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "trimLeft", "trimRight"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "testValue",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("asString"._value_((1)),"1");
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_([(1), (2), (3)]._collect_("asString"),["1", "2", "3"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testValue",{},$globals.StringTest)});
- },
- args: [],
- source: "testValue\x0a\x0a\x09self assert: (#asString value: 1) equals: '1'.\x0a\x0a\x09\x22Which (since String and BlockClosure are now polymorphic) enables the nice idiom...\x22\x0a\x09self assert: (#(1 2 3) collect: #asString) equals: #('1' '2' '3')",
- referencedClasses: [],
- messageSends: ["assert:equals:", "value:", "collect:"]
- }),
- $globals.StringTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.String;
- },
- args: [],
- source: "collectionClass\x0a\x09^ String",
- referencedClasses: ["String"],
- messageSends: []
- }),
- $globals.StringTest.klass);
- $core.addClass("SetTest", $globals.CollectionTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collection",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Set)._new();
- $recv($1)._add_($globals.Smalltalk);
- $ctx1.sendIdx["add:"]=1;
- $recv($1)._add_(nil);
- $ctx1.sendIdx["add:"]=2;
- $recv($1)._add_((3).__at((3)));
- $ctx1.sendIdx["add:"]=3;
- $recv($1)._add_(false);
- $ctx1.sendIdx["add:"]=4;
- $recv($1)._add_(self["@sampleBlock"]);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collection",{},$globals.SetTest)});
- },
- args: [],
- source: "collection\x0a\x09^ Set new\x0a\x09\x09add: Smalltalk;\x0a\x09\x09add: nil;\x0a\x09\x09add: 3@3;\x0a\x09\x09add: false;\x0a\x09\x09add: sampleBlock;\x0a\x09\x09yourself",
- referencedClasses: ["Set", "Smalltalk"],
- messageSends: ["add:", "new", "@", "yourself"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "collectionOfPrintStrings",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Set)._new();
- $recv($1)._add_("a SmalltalkImage");
- $ctx1.sendIdx["add:"]=1;
- $recv($1)._add_("nil");
- $ctx1.sendIdx["add:"]=2;
- $recv($1)._add_("3@3");
- $ctx1.sendIdx["add:"]=3;
- $recv($1)._add_("false");
- $ctx1.sendIdx["add:"]=4;
- $recv($1)._add_("a BlockClosure");
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collectionOfPrintStrings",{},$globals.SetTest)});
- },
- args: [],
- source: "collectionOfPrintStrings\x0a\x09^ Set new\x0a\x09\x09add: 'a SmalltalkImage';\x0a\x09\x09add: 'nil';\x0a\x09\x09add: '3@3';\x0a\x09\x09add: 'false';\x0a\x09\x09add: 'a BlockClosure';\x0a\x09\x09yourself",
- referencedClasses: ["Set"],
- messageSends: ["add:", "new", "yourself"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "collectionSize",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return (5);
- },
- args: [],
- source: "collectionSize\x0a\x09^ 5",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithDuplicates",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._collection();
- $recv($1)._add_((0));
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collectionWithDuplicates",{},$globals.SetTest)});
- },
- args: [],
- source: "collectionWithDuplicates\x0a\x09\x22Set has no duplicates\x22\x0a\x09^ self collection add: 0; yourself",
- referencedClasses: [],
- messageSends: ["add:", "collection", "yourself"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "collectionWithNewValue",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Set)._new();
- $recv($1)._add_($globals.Smalltalk);
- $ctx1.sendIdx["add:"]=1;
- $recv($1)._add_(nil);
- $ctx1.sendIdx["add:"]=2;
- $recv($1)._add_((3).__at((3)));
- $ctx1.sendIdx["add:"]=3;
- $recv($1)._add_("N");
- $ctx1.sendIdx["add:"]=4;
- $recv($1)._add_(false);
- $ctx1.sendIdx["add:"]=5;
- $recv($1)._add_(self["@sampleBlock"]);
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"collectionWithNewValue",{},$globals.SetTest)});
- },
- args: [],
- source: "collectionWithNewValue\x0a\x09^ Set new\x0a\x09\x09add: Smalltalk;\x0a\x09\x09add: nil;\x0a\x09\x09add: 3@3;\x0a\x09\x09add: 'N';\x0a\x09\x09add: false;\x0a\x09\x09add: sampleBlock;\x0a\x09\x09yourself",
- referencedClasses: ["Set", "Smalltalk"],
- messageSends: ["add:", "new", "@", "yourself"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testAddAll",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$4,$1,$5,$7,$8,$9,$6,$10,$12,$11;
- (
- $ctx1.supercall = true,
- ($globals.SetTest.superclass||$boot.nilAsClass).fn.prototype._testAddAll.apply($recv(self), []));
- $ctx1.supercall = false;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $3=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $recv($2)._addAll_($3);
- $ctx1.sendIdx["addAll:"]=1;
- $4=$recv($2)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $1=$4;
- $5=self._collection();
- $ctx1.sendIdx["collection"]=3;
- self._assert_equals_($1,$5);
- $ctx1.sendIdx["assert:equals:"]=1;
- $7=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $8=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $recv($7)._addAll_($8);
- $ctx1.sendIdx["addAll:"]=2;
- $9=$recv($7)._yourself();
- $ctx1.sendIdx["yourself"]=2;
- $6=$9;
- $10=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=2;
- self._assert_equals_($6,$10);
- $ctx1.sendIdx["assert:equals:"]=2;
- $12=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=3;
- $recv($12)._addAll_(self._collection());
- $11=$recv($12)._yourself();
- self._assert_equals_($11,self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddAll",{},$globals.SetTest)});
- },
- args: [],
- source: "testAddAll\x0a\x09super testAddAll.\x0a\x09self assert: (self collection addAll: self collection; yourself) equals: self collection.\x0a\x09self assert: (self collection addAll: self collectionWithNewValue; yourself) equals: self collectionWithNewValue.\x0a\x09self assert: (self collectionWithNewValue addAll: self collection; yourself) equals: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["testAddAll", "assert:equals:", "addAll:", "collection", "yourself", "collectionWithNewValue"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testAddRemove",
- protocol: "tests",
- fn: function (){
- var self=this;
- var set;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- set=$recv($globals.Set)._new();
- self._assert_($recv(set)._isEmpty());
- $ctx1.sendIdx["assert:"]=1;
- $recv(set)._add_((3));
- $ctx1.sendIdx["add:"]=1;
- $1=$recv(set)._includes_((3));
- $ctx1.sendIdx["includes:"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=2;
- $recv(set)._add_((5));
- $2=$recv(set)._includes_((5));
- $ctx1.sendIdx["includes:"]=2;
- self._assert_($2);
- $recv(set)._remove_((3));
- self._deny_($recv(set)._includes_((3)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAddRemove",{set:set},$globals.SetTest)});
- },
- args: [],
- source: "testAddRemove\x0a\x09| set |\x0a\x09set := Set new.\x0a\x09\x0a\x09self assert: set isEmpty.\x0a\x0a\x09set add: 3.\x0a\x09self assert: (set includes: 3).\x0a\x0a\x09set add: 5.\x0a\x09self assert: (set includes: 5).\x0a\x0a\x09set remove: 3.\x0a\x09self deny: (set includes: 3)",
- referencedClasses: ["Set"],
- messageSends: ["new", "assert:", "isEmpty", "add:", "includes:", "remove:", "deny:"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testAt",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv($globals.Set)._new())._at_put_((1),(2));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAt",{},$globals.SetTest)});
- },
- args: [],
- source: "testAt\x0a\x09self should: [ Set new at: 1 put: 2 ] raise: Error",
- referencedClasses: ["Set", "Error"],
- messageSends: ["should:raise:", "at:put:", "new"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testCollect",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- (
- $ctx1.supercall = true,
- ($globals.SetTest.superclass||$boot.nilAsClass).fn.prototype._testCollect.apply($recv(self), []));
- $ctx1.supercall = false;
- $2=[(5), (6), (8)]._asSet();
- $ctx1.sendIdx["asSet"]=1;
- $1=$recv($2)._collect_((function(x){
- return $core.withContext(function($ctx2) {
- return $recv(x).__backslash_backslash((3));
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
- }));
- self._assert_equals_($1,[(0), (2)]._asSet());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCollect",{},$globals.SetTest)});
- },
- args: [],
- source: "testCollect\x0a\x09super testCollect.\x0a\x09self assert: (#(5 6 8) asSet collect: [ :x | x \x5c\x5c 3 ]) equals: #(0 2) asSet",
- referencedClasses: [],
- messageSends: ["testCollect", "assert:equals:", "collect:", "asSet", "\x5c\x5c"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testComma",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$4,$6,$7,$5,$8,$10,$9;
- (
- $ctx1.supercall = true,
- ($globals.SetTest.superclass||$boot.nilAsClass).fn.prototype._testComma.apply($recv(self), []));
- $ctx1.supercall = false;
- $2=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $3=self._collection();
- $ctx1.sendIdx["collection"]=2;
- $1=$recv($2).__comma($3);
- $ctx1.sendIdx[","]=1;
- $4=self._collection();
- $ctx1.sendIdx["collection"]=3;
- self._assert_equals_($1,$4);
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=self._collection();
- $ctx1.sendIdx["collection"]=4;
- $7=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=1;
- $5=$recv($6).__comma($7);
- $ctx1.sendIdx[","]=2;
- $8=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=2;
- self._assert_equals_($5,$8);
- $ctx1.sendIdx["assert:equals:"]=2;
- $10=self._collectionWithNewValue();
- $ctx1.sendIdx["collectionWithNewValue"]=3;
- $9=$recv($10).__comma(self._collection());
- self._assert_equals_($9,self._collectionWithNewValue());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testComma",{},$globals.SetTest)});
- },
- args: [],
- source: "testComma\x0a\x09super testComma.\x0a\x09self assert: self collection, self collection equals: self collection.\x0a\x09self assert: self collection, self collectionWithNewValue equals: self collectionWithNewValue.\x0a\x09self assert: self collectionWithNewValue, self collection equals: self collectionWithNewValue",
- referencedClasses: [],
- messageSends: ["testComma", "assert:equals:", ",", "collection", "collectionWithNewValue"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testComparing",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$6,$7,$5,$9,$8;
- $1=[(0), (2)]._asSet();
- $ctx1.sendIdx["asSet"]=1;
- $2=[(0), (2)]._asSet();
- $ctx1.sendIdx["asSet"]=2;
- self._assert_equals_($1,$2);
- $ctx1.sendIdx["assert:equals:"]=1;
- $3=[(2), (0)]._asSet();
- $ctx1.sendIdx["asSet"]=3;
- $4=[(0), (2)]._asSet();
- $ctx1.sendIdx["asSet"]=4;
- self._assert_equals_($3,$4);
- $6=[(0), (2), (3)]._asSet();
- $ctx1.sendIdx["asSet"]=5;
- $7=[(0), (2)]._asSet();
- $ctx1.sendIdx["asSet"]=6;
- $5=$recv($6).__eq($7);
- $ctx1.sendIdx["="]=1;
- self._deny_($5);
- $ctx1.sendIdx["deny:"]=1;
- $9=[(1), (2)]._asSet();
- $ctx1.sendIdx["asSet"]=7;
- $8=$recv($9).__eq([(0), (2)]._asSet());
- self._deny_($8);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testComparing",{},$globals.SetTest)});
- },
- args: [],
- source: "testComparing\x0a\x09self assert: #(0 2) asSet equals: #(0 2) asSet.\x0a\x09self assert: #(2 0) asSet equals: #(0 2) asSet.\x0a\x09self deny: #(0 2 3) asSet = #(0 2) asSet.\x0a\x09self deny: #(1 2) asSet = #(0 2) asSet",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asSet", "deny:", "="]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testPrintString",
- protocol: "tests",
- fn: function (){
- var self=this;
- var set;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$8;
- set=$recv($globals.Set)._new();
- $1=$recv(set)._printString();
- $ctx1.sendIdx["printString"]=1;
- self._assert_equals_($1,"a Set ()");
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=set;
- $recv($2)._add_((1));
- $ctx1.sendIdx["add:"]=1;
- $3=$recv($2)._add_((3));
- $ctx1.sendIdx["add:"]=2;
- $4=$recv(set)._printString();
- $ctx1.sendIdx["printString"]=2;
- self._assert_equals_($4,"a Set (1 3)");
- $ctx1.sendIdx["assert:equals:"]=2;
- $recv(set)._add_("foo");
- $ctx1.sendIdx["add:"]=3;
- $5=$recv(set)._printString();
- $ctx1.sendIdx["printString"]=3;
- self._assert_equals_($5,"a Set (1 3 'foo')");
- $ctx1.sendIdx["assert:equals:"]=3;
- $6=set;
- $recv($6)._remove_((1));
- $ctx1.sendIdx["remove:"]=1;
- $recv($6)._remove_((3));
- $7=$recv(set)._printString();
- $ctx1.sendIdx["printString"]=4;
- self._assert_equals_($7,"a Set ('foo')");
- $ctx1.sendIdx["assert:equals:"]=4;
- $recv(set)._add_((3));
- $ctx1.sendIdx["add:"]=4;
- $8=$recv(set)._printString();
- $ctx1.sendIdx["printString"]=5;
- self._assert_equals_($8,"a Set (3 'foo')");
- $ctx1.sendIdx["assert:equals:"]=5;
- $recv(set)._add_((3));
- self._assert_equals_($recv(set)._printString(),"a Set (3 'foo')");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPrintString",{set:set},$globals.SetTest)});
- },
- args: [],
- source: "testPrintString\x0a\x09| set |\x0a\x09set := Set new.\x0a\x09self assert: set printString equals: 'a Set ()'.\x0a\x09set add: 1; add: 3.\x0a\x09self assert: set printString equals: 'a Set (1 3)'.\x0a\x09set add: 'foo'.\x0a\x09self assert: set printString equals: 'a Set (1 3 ''foo'')'.\x0a\x09set remove: 1; remove: 3.\x0a\x09self assert: set printString equals: 'a Set (''foo'')'.\x0a\x09set add: 3.\x0a\x09self assert: set printString equals: 'a Set (3 ''foo'')'.\x0a\x09set add: 3.\x0a\x09self assert: set printString equals: 'a Set (3 ''foo'')'",
- referencedClasses: ["Set"],
- messageSends: ["new", "assert:equals:", "printString", "add:", "remove:"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testUnboxedObjects",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $4,$3,$2,$1;
- $4="foo"._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $3=[$4,"foo"._yourself()];
- $2=$recv($3)._asSet();
- $1=$recv($2)._asArray();
- self._assert_equals_($1,["foo"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testUnboxedObjects",{},$globals.SetTest)});
- },
- args: [],
- source: "testUnboxedObjects\x0a\x09self assert: {'foo' yourself. 'foo' yourself} asSet asArray equals: #('foo')",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asArray", "asSet", "yourself"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "testUnicity",
- protocol: "tests",
- fn: function (){
- var self=this;
- var set;
- return $core.withContext(function($ctx1) {
- var $1;
- set=$recv($globals.Set)._new();
- $recv(set)._add_((21));
- $ctx1.sendIdx["add:"]=1;
- $recv(set)._add_("hello");
- $ctx1.sendIdx["add:"]=2;
- $recv(set)._add_((21));
- $ctx1.sendIdx["add:"]=3;
- $1=$recv(set)._size();
- $ctx1.sendIdx["size"]=1;
- self._assert_equals_($1,(2));
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(set)._add_("hello");
- self._assert_equals_($recv(set)._size(),(2));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv(set)._asArray(),[(21), "hello"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testUnicity",{set:set},$globals.SetTest)});
- },
- args: [],
- source: "testUnicity\x0a\x09| set |\x0a\x09set := Set new.\x0a\x09set add: 21.\x0a\x09set add: 'hello'.\x0a\x0a\x09set add: 21.\x0a\x09self assert: set size equals: 2.\x0a\x09\x0a\x09set add: 'hello'.\x0a\x09self assert: set size equals: 2.\x0a\x0a\x09self assert: set asArray equals: #(21 'hello')",
- referencedClasses: ["Set"],
- messageSends: ["new", "add:", "assert:equals:", "size", "asArray"]
- }),
- $globals.SetTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "fixture",
- fn: function (){
- var self=this;
- return $globals.Set;
- },
- args: [],
- source: "collectionClass\x0a\x09^ Set",
- referencedClasses: ["Set"],
- messageSends: []
- }),
- $globals.SetTest.klass);
- $core.addClass("ConsoleTranscriptTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testShow",
- protocol: "tests",
- fn: function (){
- var self=this;
- var originalTranscript;
- return $core.withContext(function($ctx1) {
- originalTranscript=$recv($globals.Transcript)._current();
- $recv($globals.Transcript)._register_($recv($globals.ConsoleTranscript)._new());
- $ctx1.sendIdx["register:"]=1;
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($globals.Transcript)._show_("Hello console!");
- $ctx2.sendIdx["show:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- $ctx1.sendIdx["shouldnt:raise:"]=1;
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($globals.Transcript)._show_(console);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- $recv($globals.Transcript)._register_(originalTranscript);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testShow",{originalTranscript:originalTranscript},$globals.ConsoleTranscriptTest)});
- },
- args: [],
- source: "testShow\x0a| originalTranscript |\x0aoriginalTranscript := Transcript current.\x0aTranscript register: ConsoleTranscript new.\x0a\x0aself shouldnt: [ Transcript show: 'Hello console!' ] raise: Error.\x0aself shouldnt: [ Transcript show: console ] raise: Error.\x0a\x0aTranscript register: originalTranscript.",
- referencedClasses: ["Transcript", "ConsoleTranscript", "Error"],
- messageSends: ["current", "register:", "new", "shouldnt:raise:", "show:"]
- }),
- $globals.ConsoleTranscriptTest);
- $core.addClass("DateTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testEquality",
- protocol: "tests",
- fn: function (){
- var self=this;
- var now;
- return $core.withContext(function($ctx1) {
- var $1,$3,$4,$2,$6,$7,$5,$9,$11,$10,$8;
- now=$recv($globals.Date)._new();
- $1=$recv(now).__eq(now);
- $ctx1.sendIdx["="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $3=now;
- $4=$recv($globals.Date)._fromMilliseconds_((0));
- $ctx1.sendIdx["fromMilliseconds:"]=1;
- $2=$recv($3).__eq($4);
- $ctx1.sendIdx["="]=2;
- self._deny_($2);
- $6=$recv($globals.Date)._fromMilliseconds_((12345678));
- $ctx1.sendIdx["fromMilliseconds:"]=2;
- $7=$recv($globals.Date)._fromMilliseconds_((12345678));
- $ctx1.sendIdx["fromMilliseconds:"]=3;
- $5=$recv($6).__eq($7);
- $ctx1.sendIdx["="]=3;
- self._assert_($5);
- $ctx1.sendIdx["assert:"]=2;
- $9=now;
- $11=$recv(now)._asMilliseconds();
- $ctx1.sendIdx["asMilliseconds"]=1;
- $10=$recv($globals.Date)._fromMilliseconds_($11);
- $ctx1.sendIdx["fromMilliseconds:"]=4;
- $8=$recv($9).__eq($10);
- $ctx1.sendIdx["="]=4;
- self._assert_($8);
- $ctx1.sendIdx["assert:"]=3;
- self._assert_($recv($recv($globals.Date)._fromMilliseconds_($recv(now)._asMilliseconds())).__eq(now));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEquality",{now:now},$globals.DateTest)});
- },
- args: [],
- source: "testEquality\x0a\x09| now |\x0a\x09now := Date new.\x0a\x0a\x09self assert: now = now.\x0a\x0a\x09self deny: now = (Date fromMilliseconds: 0).\x0a\x0a\x09self assert: (Date fromMilliseconds: 12345678) = (Date fromMilliseconds: 12345678).\x0a\x09self assert: now = (Date fromMilliseconds: now asMilliseconds).\x0a\x09self assert: (Date fromMilliseconds: now asMilliseconds) = now",
- referencedClasses: ["Date"],
- messageSends: ["new", "assert:", "=", "deny:", "fromMilliseconds:", "asMilliseconds"]
- }),
- $globals.DateTest);
- $core.addMethod(
- $core.method({
- selector: "testIdentity",
- protocol: "tests",
- fn: function (){
- var self=this;
- var now;
- return $core.withContext(function($ctx1) {
- var $1,$3,$4,$2,$6,$7,$5,$9,$11,$10,$8;
- now=$recv($globals.Date)._new();
- $1=$recv(now).__eq_eq(now);
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $3=now;
- $4=$recv($globals.Date)._fromMilliseconds_((0));
- $ctx1.sendIdx["fromMilliseconds:"]=1;
- $2=$recv($3).__eq_eq($4);
- $ctx1.sendIdx["=="]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=1;
- $6=$recv($globals.Date)._fromMilliseconds_((12345678));
- $ctx1.sendIdx["fromMilliseconds:"]=2;
- $7=$recv($globals.Date)._fromMilliseconds_((12345678));
- $ctx1.sendIdx["fromMilliseconds:"]=3;
- $5=$recv($6).__eq_eq($7);
- $ctx1.sendIdx["=="]=3;
- self._deny_($5);
- $ctx1.sendIdx["deny:"]=2;
- $9=now;
- $11=$recv(now)._asMilliseconds();
- $ctx1.sendIdx["asMilliseconds"]=1;
- $10=$recv($globals.Date)._fromMilliseconds_($11);
- $ctx1.sendIdx["fromMilliseconds:"]=4;
- $8=$recv($9).__eq_eq($10);
- $ctx1.sendIdx["=="]=4;
- self._deny_($8);
- $ctx1.sendIdx["deny:"]=3;
- self._deny_($recv($recv($globals.Date)._fromMilliseconds_($recv(now)._asMilliseconds())).__eq_eq(now));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIdentity",{now:now},$globals.DateTest)});
- },
- args: [],
- source: "testIdentity\x0a\x09| now |\x0a\x09now := Date new.\x0a\x0a\x09self assert: now == now.\x0a\x0a\x09self deny: now == (Date fromMilliseconds: 0).\x0a\x0a\x09self deny: (Date fromMilliseconds: 12345678) == (Date fromMilliseconds: 12345678).\x0a\x09self deny: now == (Date fromMilliseconds: now asMilliseconds).\x0a\x09self deny: (Date fromMilliseconds: now asMilliseconds) == now",
- referencedClasses: ["Date"],
- messageSends: ["new", "assert:", "==", "deny:", "fromMilliseconds:", "asMilliseconds"]
- }),
- $globals.DateTest);
- $core.addClass("JSObjectProxyTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "jsNull",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return null;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"jsNull",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "jsNull\x0a\x09<inlineJS: 'return null'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "jsObject",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return {a: 1, b: function() {return 2;}, c: function(object) {return object;}, d: "", "e": null, "f": void 0};
- return self;
- }, function($ctx1) {$ctx1.fill(self,"jsObject",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "jsObject\x0a\x09<inlineJS: \x0a\x09\x09'return {a: 1, b: function() {return 2;}, c: function(object) {return object;}, d: \x22\x22, \x22e\x22: null, \x22f\x22: void 0}'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "jsUndefined",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"jsUndefined",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "jsUndefined\x0a\x09<inlineJS: 'return'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfAbsent",
- protocol: "tests",
- fn: function (){
- var self=this;
- var testObject;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- testObject=self._jsObject();
- $1=$recv(testObject)._at_ifAbsent_("abc",(function(){
- return "Property does not exist";
- }));
- $ctx1.sendIdx["at:ifAbsent:"]=1;
- self._assert_equals_($1,"Property does not exist");
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=$recv(testObject)._at_ifAbsent_("e",(function(){
- return "Property does not exist";
- }));
- $ctx1.sendIdx["at:ifAbsent:"]=2;
- self._assert_equals_($2,nil);
- $ctx1.sendIdx["assert:equals:"]=2;
- $3=$recv(testObject)._at_ifAbsent_("a",(function(){
- return "Property does not exist";
- }));
- $ctx1.sendIdx["at:ifAbsent:"]=3;
- self._assert_equals_($3,(1));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_($recv(testObject)._at_ifAbsent_("f",(function(){
- return "Property does not exist";
- })),nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfAbsent",{testObject:testObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testAtIfAbsent\x0a\x09| testObject |\x0a\x09testObject := self jsObject.\x0a\x09self assert: (testObject at: 'abc' ifAbsent: [ 'Property does not exist' ]) equals: 'Property does not exist'.\x0a\x09self assert: (testObject at: 'e' ifAbsent: [ 'Property does not exist' ]) equals: nil.\x0a\x09self assert: (testObject at: 'a' ifAbsent: [ 'Property does not exist' ]) equals: 1.\x0a\x09self assert: (testObject at: 'f' ifAbsent: [ 'Property does not exist' ]) equals: nil.",
- referencedClasses: [],
- messageSends: ["jsObject", "assert:equals:", "at:ifAbsent:"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfPresent",
- protocol: "tests",
- fn: function (){
- var self=this;
- var testObject;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5;
- testObject=self._jsObject();
- $1=$recv(testObject)._at_ifPresent_("abc",(function(x){
- return $core.withContext(function($ctx2) {
- $2=$recv(x)._asString();
- $ctx2.sendIdx["asString"]=1;
- return "hello ".__comma($2);
- $ctx2.sendIdx[","]=1;
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
- }));
- $ctx1.sendIdx["at:ifPresent:"]=1;
- self._assert_equals_($1,nil);
- $ctx1.sendIdx["assert:equals:"]=1;
- $3=$recv(testObject)._at_ifPresent_("e",(function(x){
- return $core.withContext(function($ctx2) {
- $4=$recv(x)._asString();
- $ctx2.sendIdx["asString"]=2;
- return "hello ".__comma($4);
- $ctx2.sendIdx[","]=2;
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,2)});
- }));
- $ctx1.sendIdx["at:ifPresent:"]=2;
- self._assert_equals_($3,"hello nil");
- $ctx1.sendIdx["assert:equals:"]=2;
- $5=$recv(testObject)._at_ifPresent_("a",(function(x){
- return $core.withContext(function($ctx2) {
- $6=$recv(x)._asString();
- $ctx2.sendIdx["asString"]=3;
- return "hello ".__comma($6);
- $ctx2.sendIdx[","]=3;
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,3)});
- }));
- $ctx1.sendIdx["at:ifPresent:"]=3;
- self._assert_equals_($5,"hello 1");
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_($recv(testObject)._at_ifPresent_("f",(function(x){
- return $core.withContext(function($ctx2) {
- return "hello ".__comma($recv(x)._asString());
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,4)});
- })),"hello nil");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfPresent",{testObject:testObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testAtIfPresent\x0a\x09| testObject |\x0a\x09\x0a\x09testObject := self jsObject.\x0a\x09\x0a\x09self assert: (testObject at: 'abc' ifPresent: [ :x | 'hello ',x asString ]) equals: nil.\x0a\x09self assert: (testObject at: 'e' ifPresent: [ :x | 'hello ',x asString ]) equals: 'hello nil'.\x0a\x09self assert: (testObject at: 'a' ifPresent: [ :x | 'hello ',x asString ]) equals: 'hello 1'.\x0a\x09self assert: (testObject at: 'f' ifPresent: [ :x | 'hello ',x asString ]) equals: 'hello nil'.",
- referencedClasses: [],
- messageSends: ["jsObject", "assert:equals:", "at:ifPresent:", ",", "asString"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testAtIfPresentIfAbsent",
- protocol: "tests",
- fn: function (){
- var self=this;
- var testObject;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5;
- testObject=self._jsObject();
- $1=$recv(testObject)._at_ifPresent_ifAbsent_("abc",(function(x){
- return $core.withContext(function($ctx2) {
- $2=$recv(x)._asString();
- $ctx2.sendIdx["asString"]=1;
- return "hello ".__comma($2);
- $ctx2.sendIdx[","]=1;
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
- }),(function(){
- return "not present";
- }));
- $ctx1.sendIdx["at:ifPresent:ifAbsent:"]=1;
- self._assert_equals_($1,"not present");
- $ctx1.sendIdx["assert:equals:"]=1;
- $3=$recv(testObject)._at_ifPresent_ifAbsent_("e",(function(x){
- return $core.withContext(function($ctx2) {
- $4=$recv(x)._asString();
- $ctx2.sendIdx["asString"]=2;
- return "hello ".__comma($4);
- $ctx2.sendIdx[","]=2;
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,3)});
- }),(function(){
- return "not present";
- }));
- $ctx1.sendIdx["at:ifPresent:ifAbsent:"]=2;
- self._assert_equals_($3,"hello nil");
- $ctx1.sendIdx["assert:equals:"]=2;
- $5=$recv(testObject)._at_ifPresent_ifAbsent_("a",(function(x){
- return $core.withContext(function($ctx2) {
- $6=$recv(x)._asString();
- $ctx2.sendIdx["asString"]=3;
- return "hello ".__comma($6);
- $ctx2.sendIdx[","]=3;
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,5)});
- }),(function(){
- return "not present";
- }));
- $ctx1.sendIdx["at:ifPresent:ifAbsent:"]=3;
- self._assert_equals_($5,"hello 1");
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_($recv(testObject)._at_ifPresent_ifAbsent_("f",(function(x){
- return $core.withContext(function($ctx2) {
- return "hello ".__comma($recv(x)._asString());
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,7)});
- }),(function(){
- return "not present";
- })),"hello nil");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtIfPresentIfAbsent",{testObject:testObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testAtIfPresentIfAbsent\x0a\x09| testObject |\x0a\x09testObject := self jsObject.\x0a\x09self assert: (testObject at: 'abc' ifPresent: [ :x|'hello ',x asString ] ifAbsent: [ 'not present' ]) equals: 'not present'.\x0a\x09self assert: (testObject at: 'e' ifPresent: [ :x|'hello ',x asString ] ifAbsent: [ 'not present' ]) equals: 'hello nil'.\x0a\x09self assert: (testObject at: 'a' ifPresent: [ :x|'hello ',x asString ] ifAbsent: [ 'not present' ]) equals: 'hello 1'.\x0a\x09self assert: (testObject at: 'f' ifPresent: [ :x|'hello ',x asString ] ifAbsent: [ 'not present' ]) equals: 'hello nil'.",
- referencedClasses: [],
- messageSends: ["jsObject", "assert:equals:", "at:ifPresent:ifAbsent:", ",", "asString"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testAtPut",
- protocol: "tests",
- fn: function (){
- var self=this;
- var testObject;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- testObject=self._jsObject();
- $2=$recv(testObject)._at_("abc");
- $ctx1.sendIdx["at:"]=1;
- $1=$recv($2).__tild_eq("xyz");
- self._assert_($1);
- self._assert_equals_($recv(testObject)._at_put_("abc","xyz"),"xyz");
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv(testObject)._at_("abc"),"xyz");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtPut",{testObject:testObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testAtPut\x0a\x09| testObject |\x0a\x09testObject := self jsObject.\x0a\x09\x0a\x09self assert: (testObject at: 'abc') ~= 'xyz'.\x0a\x09self assert: (testObject at: 'abc' put: 'xyz') equals: 'xyz'.\x0a\x09self assert: (testObject at: 'abc') equals: 'xyz'",
- referencedClasses: [],
- messageSends: ["jsObject", "assert:", "~=", "at:", "assert:equals:", "at:put:"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testComparison",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- self._assert_equals_($recv([console,(2)])._indexOf_(console),(1));
- $1=$recv(console).__eq(console);
- $ctx1.sendIdx["="]=1;
- self._assert_($1);
- $2=$recv(console).__eq($recv($globals.Object)._new());
- $ctx1.sendIdx["="]=2;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=1;
- self._deny_($recv(console).__eq(self._jsObject()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testComparison",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testComparison\x0a\x09self assert: ({ console. 2 } indexOf: console) equals: 1.\x0a\x09self assert: console = console.\x0a\x09self deny: console = Object new.\x0a\x09self deny: console = self jsObject",
- referencedClasses: ["Object"],
- messageSends: ["assert:equals:", "indexOf:", "assert:", "=", "deny:", "new", "jsObject"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testDNU",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self._jsObject())._foo();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDNU",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testDNU\x0a\x09self should: [ self jsObject foo ] raise: MessageNotUnderstood",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["should:raise:", "foo", "jsObject"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testDNURegression1057",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsObject;
- return $core.withContext(function($ctx1) {
- var $1;
- jsObject=[];
- $recv(jsObject)._basicAt_put_("allowJavaScriptCalls",true);
- $ctx1.sendIdx["basicAt:put:"]=1;
- $recv(jsObject)._basicAt_put_("foo",(3));
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(jsObject)._foo();
- $ctx2.sendIdx["foo"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- $ctx1.sendIdx["shouldnt:raise:"]=1;
- $1=$recv(jsObject)._foo();
- $ctx1.sendIdx["foo"]=2;
- self._assert_equals_($1,(3));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(jsObject)._foo_((4));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- self._assert_equals_($recv(jsObject)._foo(),(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDNURegression1057",{jsObject:jsObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testDNURegression1057\x0a\x09| jsObject |\x0a\x09jsObject := #().\x0a\x09jsObject basicAt: 'allowJavaScriptCalls' put: true.\x0a\x09jsObject basicAt: 'foo' put: 3.\x0a\x09self shouldnt: [ jsObject foo ] raise: Error.\x0a\x09self assert: jsObject foo equals: 3.\x0a\x09self shouldnt: [ jsObject foo: 4 ] raise: Error.\x0a\x09self assert: jsObject foo equals: 4",
- referencedClasses: ["Error"],
- messageSends: ["basicAt:put:", "shouldnt:raise:", "foo", "assert:equals:", "foo:"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testDNURegression1059",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsObject;
- return $core.withContext(function($ctx1) {
- jsObject=[];
- $recv(jsObject)._basicAt_put_("allowJavaScriptCalls",true);
- $ctx1.sendIdx["basicAt:put:"]=1;
- $recv(jsObject)._basicAt_put_("x",(3));
- $ctx1.sendIdx["basicAt:put:"]=2;
- $recv(jsObject)._basicAt_put_("x:",(function(){
- return $core.withContext(function($ctx2) {
- return self._error();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(jsObject)._x_((4));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- self._assert_equals_($recv(jsObject)._x(),(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDNURegression1059",{jsObject:jsObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testDNURegression1059\x0a\x09| jsObject |\x0a\x09jsObject := #().\x0a\x09jsObject basicAt: 'allowJavaScriptCalls' put: true.\x0a\x09jsObject basicAt: 'x' put: 3.\x0a\x09jsObject basicAt: 'x:' put: [ self error ].\x0a\x09self shouldnt: [ jsObject x: 4 ] raise: Error.\x0a\x09self assert: jsObject x equals: 4",
- referencedClasses: ["Error"],
- messageSends: ["basicAt:put:", "error", "shouldnt:raise:", "x:", "assert:equals:", "x"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testDNURegression1062",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsObject,stored;
- return $core.withContext(function($ctx1) {
- jsObject=[];
- $recv(jsObject)._basicAt_put_("allowJavaScriptCalls",true);
- $ctx1.sendIdx["basicAt:put:"]=1;
- $recv(jsObject)._basicAt_put_("x",(function(v){
- stored=v;
- return stored;
- }));
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(jsObject)._x_((4));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- self._assert_equals_(stored,(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDNURegression1062",{jsObject:jsObject,stored:stored},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testDNURegression1062\x0a\x09| jsObject stored |\x0a\x09jsObject := #().\x0a\x09jsObject basicAt: 'allowJavaScriptCalls' put: true.\x0a\x09jsObject basicAt: 'x' put: [ :v | stored := v ].\x0a\x09self shouldnt: [ jsObject x: 4 ] raise: Error.\x0a\x09self assert: stored equals: 4",
- referencedClasses: ["Error"],
- messageSends: ["basicAt:put:", "shouldnt:raise:", "x:", "assert:equals:"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testDNUWithAllowJavaScriptCalls",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsObject;
- return $core.withContext(function($ctx1) {
- jsObject=[];
- $recv(jsObject)._basicAt_put_("allowJavaScriptCalls",true);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(jsObject)._foo();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDNUWithAllowJavaScriptCalls",{jsObject:jsObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testDNUWithAllowJavaScriptCalls\x0a\x09| jsObject |\x0a\x09jsObject := #().\x0a\x09jsObject basicAt: 'allowJavaScriptCalls' put: true.\x0a\x09self should: [ jsObject foo ] raise: MessageNotUnderstood",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["basicAt:put:", "should:raise:", "foo"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testMessageSend",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3;
- $2=self._jsObject();
- $ctx1.sendIdx["jsObject"]=1;
- $1=$recv($2)._a();
- self._assert_equals_($1,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $4=self._jsObject();
- $ctx1.sendIdx["jsObject"]=2;
- $3=$recv($4)._b();
- self._assert_equals_($3,(2));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv(self._jsObject())._c_((3)),(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMessageSend",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testMessageSend\x0a\x0a\x09self assert: self jsObject a equals: 1.\x0a\x09self assert: self jsObject b equals: 2.\x0a\x09self assert: (self jsObject c: 3) equals: 3",
- referencedClasses: [],
- messageSends: ["assert:equals:", "a", "jsObject", "b", "c:"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testMethodWithArguments",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv(self._jsObject())._c_((1)),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMethodWithArguments",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testMethodWithArguments\x0a\x09self assert: (self jsObject c: 1) equals: 1",
- referencedClasses: [],
- messageSends: ["assert:equals:", "c:", "jsObject"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testPrinting",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_($recv(self._jsObject())._printString(),"[object Object]");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPrinting",{},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testPrinting\x0a\x09self assert: self jsObject printString equals: '[object Object]'",
- referencedClasses: [],
- messageSends: ["assert:equals:", "printString", "jsObject"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testPropertyThatReturnsEmptyString",
- protocol: "tests",
- fn: function (){
- var self=this;
- var object;
- return $core.withContext(function($ctx1) {
- var $1;
- object=self._jsObject();
- $1=$recv(object)._d();
- $ctx1.sendIdx["d"]=1;
- self._assert_equals_($1,"");
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(object)._d_("hello");
- self._assert_equals_($recv(object)._d(),"hello");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPropertyThatReturnsEmptyString",{object:object},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testPropertyThatReturnsEmptyString\x0a\x09| object |\x0a\x0a\x09object := self jsObject.\x0a\x09self assert: object d equals: ''.\x0a\x0a\x09object d: 'hello'.\x0a\x09self assert: object d equals: 'hello'",
- referencedClasses: [],
- messageSends: ["jsObject", "assert:equals:", "d", "d:"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testPropertyThatReturnsUndefined",
- protocol: "tests",
- fn: function (){
- var self=this;
- var object;
- return $core.withContext(function($ctx1) {
- object=self._jsObject();
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(object)._e();
- $ctx2.sendIdx["e"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- self._assert_($recv($recv(object)._e())._isNil());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPropertyThatReturnsUndefined",{object:object},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testPropertyThatReturnsUndefined\x0a\x09| object |\x0a\x0a\x09object := self jsObject.\x0a\x09self shouldnt: [ object e ] raise: MessageNotUnderstood.\x0a\x09self assert: object e isNil",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["jsObject", "shouldnt:raise:", "e", "assert:", "isNil"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testSetPropertyWithFalsyValue",
- protocol: "tests",
- fn: function (){
- var self=this;
- var jsObject;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5;
- jsObject=self._jsObject();
- $1=$recv(jsObject)._a();
- $ctx1.sendIdx["a"]=1;
- self._assert_equals_($1,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(jsObject)._a_(self._jsNull());
- $ctx1.sendIdx["a:"]=1;
- $2=$recv(jsObject)._a();
- $ctx1.sendIdx["a"]=2;
- self._assert_equals_($2,nil);
- $ctx1.sendIdx["assert:equals:"]=2;
- $recv(jsObject)._a_((0));
- $ctx1.sendIdx["a:"]=2;
- $3=$recv(jsObject)._a();
- $ctx1.sendIdx["a"]=3;
- self._assert_equals_($3,(0));
- $ctx1.sendIdx["assert:equals:"]=3;
- $recv(jsObject)._a_(self._jsUndefined());
- $ctx1.sendIdx["a:"]=3;
- $4=$recv(jsObject)._a();
- $ctx1.sendIdx["a"]=4;
- self._assert_equals_($4,nil);
- $ctx1.sendIdx["assert:equals:"]=4;
- $recv(jsObject)._a_("");
- $ctx1.sendIdx["a:"]=4;
- $5=$recv(jsObject)._a();
- $ctx1.sendIdx["a"]=5;
- self._assert_equals_($5,"");
- $ctx1.sendIdx["assert:equals:"]=5;
- $recv(jsObject)._a_(false);
- self._assert_equals_($recv(jsObject)._a(),false);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSetPropertyWithFalsyValue",{jsObject:jsObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testSetPropertyWithFalsyValue\x0a\x09| jsObject |\x0a\x09jsObject := self jsObject.\x0a\x09self assert: (jsObject a) equals: 1.\x0a\x0a\x09jsObject a: self jsNull.\x0a\x09self assert: (jsObject a) equals: nil.\x0a\x09jsObject a: 0.\x0a\x09self assert: (jsObject a) equals: 0.\x0a\x09jsObject a: self jsUndefined.\x0a\x09self assert: (jsObject a) equals: nil.\x0a\x09jsObject a: ''.\x0a\x09self assert: (jsObject a) equals: ''.\x0a\x09jsObject a: false.\x0a\x09self assert: (jsObject a) equals: false",
- referencedClasses: [],
- messageSends: ["jsObject", "assert:equals:", "a", "a:", "jsNull", "jsUndefined"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testValue",
- protocol: "tests",
- fn: function (){
- var self=this;
- var testObject;
- return $core.withContext(function($ctx1) {
- testObject=self._jsObject();
- $recv(testObject)._at_put_("value","aValue");
- self._assert_equals_($recv(testObject)._value(),"aValue");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testValue",{testObject:testObject},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testValue\x0a\x09| testObject |\x0a\x09testObject := self jsObject.\x0a\x09testObject at: 'value' put: 'aValue'.\x0a\x09self assert: testObject value equals: 'aValue'",
- referencedClasses: [],
- messageSends: ["jsObject", "at:put:", "assert:equals:", "value"]
- }),
- $globals.JSObjectProxyTest);
- $core.addMethod(
- $core.method({
- selector: "testYourself",
- protocol: "tests",
- fn: function (){
- var self=this;
- var object;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=self._jsObject();
- $recv($1)._d_("test");
- object=$recv($1)._yourself();
- self._assert_equals_($recv(object)._d(),"test");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testYourself",{object:object},$globals.JSObjectProxyTest)});
- },
- args: [],
- source: "testYourself\x0a\x09| object |\x0a\x09object := self jsObject\x0a\x09\x09d: 'test';\x0a\x09\x09yourself.\x0a\x0a\x09self assert: object d equals: 'test'",
- referencedClasses: [],
- messageSends: ["d:", "jsObject", "yourself", "assert:equals:", "d"]
- }),
- $globals.JSObjectProxyTest);
- $core.addClass("JavaScriptExceptionTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testCatchingException",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._throwException();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(error){
- return $core.withContext(function($ctx2) {
- return self._assert_($recv($recv(error)._exception()).__eq("test"));
- }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1,2)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCatchingException",{},$globals.JavaScriptExceptionTest)});
- },
- args: [],
- source: "testCatchingException\x0a\x09[ self throwException ]\x0a\x09\x09on: Error\x0a\x09\x09do: [ :error |\x0a\x09\x09\x09self assert: error exception = 'test' ]",
- referencedClasses: ["Error"],
- messageSends: ["on:do:", "throwException", "assert:", "=", "exception"]
- }),
- $globals.JavaScriptExceptionTest);
- $core.addMethod(
- $core.method({
- selector: "testRaisingException",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return self._throwException();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.JavaScriptException);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRaisingException",{},$globals.JavaScriptExceptionTest)});
- },
- args: [],
- source: "testRaisingException\x0a\x09self should: [ self throwException ] raise: JavaScriptException",
- referencedClasses: ["JavaScriptException"],
- messageSends: ["should:raise:", "throwException"]
- }),
- $globals.JavaScriptExceptionTest);
- $core.addMethod(
- $core.method({
- selector: "throwException",
- protocol: "helpers",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- throw "test";
- return self;
- }, function($ctx1) {$ctx1.fill(self,"throwException",{},$globals.JavaScriptExceptionTest)});
- },
- args: [],
- source: "throwException\x0a\x09<inlineJS: 'throw \x22test\x22'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.JavaScriptExceptionTest);
- $core.addClass("MessageSendTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testValue",
- protocol: "tests",
- fn: function (){
- var self=this;
- var messageSend;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.MessageSend)._new();
- $ctx1.sendIdx["new"]=1;
- $recv($1)._receiver_($recv($globals.Object)._new());
- $recv($1)._selector_("asString");
- messageSend=$recv($1)._yourself();
- self._assert_equals_($recv(messageSend)._value(),"an Object");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testValue",{messageSend:messageSend},$globals.MessageSendTest)});
- },
- args: [],
- source: "testValue\x0a\x09| messageSend |\x0a\x09\x0a\x09messageSend := MessageSend new\x0a\x09\x09receiver: Object new;\x0a\x09\x09selector: #asString;\x0a\x09\x09yourself.\x0a\x09\x09\x0a\x09self assert: messageSend value equals: 'an Object'",
- referencedClasses: ["MessageSend", "Object"],
- messageSends: ["receiver:", "new", "selector:", "yourself", "assert:equals:", "value"]
- }),
- $globals.MessageSendTest);
- $core.addMethod(
- $core.method({
- selector: "testValueWithArguments",
- protocol: "tests",
- fn: function (){
- var self=this;
- var messageSend;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.MessageSend)._new();
- $recv($1)._receiver_((2));
- $recv($1)._selector_("+");
- messageSend=$recv($1)._yourself();
- self._assert_equals_($recv(messageSend)._value_((3)),(5));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv(messageSend)._valueWithPossibleArguments_([(4)]),(6));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testValueWithArguments",{messageSend:messageSend},$globals.MessageSendTest)});
- },
- args: [],
- source: "testValueWithArguments\x0a\x09| messageSend |\x0a\x09\x0a\x09messageSend := MessageSend new\x0a\x09\x09receiver: 2;\x0a\x09\x09selector: '+';\x0a\x09\x09yourself.\x0a\x09\x09\x0a\x09self assert: (messageSend value: 3) equals: 5.\x0a\x09\x0a\x09self assert: (messageSend valueWithPossibleArguments: #(4)) equals: 6",
- referencedClasses: ["MessageSend"],
- messageSends: ["receiver:", "new", "selector:", "yourself", "assert:equals:", "value:", "valueWithPossibleArguments:"]
- }),
- $globals.MessageSendTest);
- $core.addClass("MethodInheritanceTest", $globals.TestCase, ["receiverTop", "receiverMiddle", "receiverBottom", "method", "performBlock"], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "codeGeneratorClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.CodeGenerator;
- },
- args: [],
- source: "codeGeneratorClass\x0a\x09^ CodeGenerator",
- referencedClasses: ["CodeGenerator"],
- messageSends: []
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "compiler",
- protocol: "factory",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.Compiler)._new();
- $recv($1)._codeGeneratorClass_(self._codeGeneratorClass());
- return $recv($1)._yourself();
- }, function($ctx1) {$ctx1.fill(self,"compiler",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "compiler\x0a\x09^ Compiler new\x0a\x09\x09codeGeneratorClass: self codeGeneratorClass;\x0a\x09\x09yourself",
- referencedClasses: ["Compiler"],
- messageSends: ["codeGeneratorClass:", "new", "codeGeneratorClass", "yourself"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "deinstallBottom",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._targetClassBottom())._removeCompiledMethod_(self["@method"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deinstallBottom",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "deinstallBottom\x0a\x09self targetClassBottom removeCompiledMethod: method",
- referencedClasses: [],
- messageSends: ["removeCompiledMethod:", "targetClassBottom"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "deinstallMiddle",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._targetClassMiddle())._removeCompiledMethod_(self["@method"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deinstallMiddle",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "deinstallMiddle\x0a\x09self targetClassMiddle removeCompiledMethod: method",
- referencedClasses: [],
- messageSends: ["removeCompiledMethod:", "targetClassMiddle"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "deinstallTop",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._targetClassTop())._removeCompiledMethod_(self["@method"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"deinstallTop",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "deinstallTop\x0a\x09self targetClassTop removeCompiledMethod: method",
- referencedClasses: [],
- messageSends: ["removeCompiledMethod:", "targetClassTop"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "installBottom:",
- protocol: "testing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@method"]=$recv(self._compiler())._install_forClass_protocol_(aString,self._targetClassBottom(),"tests");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"installBottom:",{aString:aString},$globals.MethodInheritanceTest)});
- },
- args: ["aString"],
- source: "installBottom: aString\x0a\x09method := self compiler install: aString forClass: self targetClassBottom protocol: 'tests'",
- referencedClasses: [],
- messageSends: ["install:forClass:protocol:", "compiler", "targetClassBottom"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "installMiddle:",
- protocol: "testing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@method"]=$recv(self._compiler())._install_forClass_protocol_(aString,self._targetClassMiddle(),"tests");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"installMiddle:",{aString:aString},$globals.MethodInheritanceTest)});
- },
- args: ["aString"],
- source: "installMiddle: aString\x0a\x09method := self compiler install: aString forClass: self targetClassMiddle protocol: 'tests'",
- referencedClasses: [],
- messageSends: ["install:forClass:protocol:", "compiler", "targetClassMiddle"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "installTop:",
- protocol: "testing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@method"]=$recv(self._compiler())._install_forClass_protocol_(aString,self._targetClassTop(),"tests");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"installTop:",{aString:aString},$globals.MethodInheritanceTest)});
- },
- args: ["aString"],
- source: "installTop: aString\x0a\x09method := self compiler install: aString forClass: self targetClassTop protocol: 'tests'",
- referencedClasses: [],
- messageSends: ["install:forClass:protocol:", "compiler", "targetClassTop"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@receiverTop"]=$recv(self._targetClassTop())._new();
- $ctx1.sendIdx["new"]=1;
- self["@receiverMiddle"]=$recv(self._targetClassMiddle())._new();
- $ctx1.sendIdx["new"]=2;
- self["@receiverBottom"]=$recv(self._targetClassBottom())._new();
- self["@method"]=nil;
- self["@performBlock"]=(function(){
- return $core.withContext(function($ctx2) {
- return self._error_("performBlock not initialized");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- });
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "setUp\x0a\x09receiverTop := self targetClassTop new.\x0a\x09receiverMiddle := self targetClassMiddle new.\x0a\x09receiverBottom := self targetClassBottom new.\x0a\x09method := nil.\x0a\x09performBlock := [ self error: 'performBlock not initialized' ]",
- referencedClasses: [],
- messageSends: ["new", "targetClassTop", "targetClassMiddle", "targetClassBottom", "error:"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "shouldMNU",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._shouldMNUTop();
- self._shouldMNUMiddle();
- self._shouldMNUBottom();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldMNU",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "shouldMNU\x0a\x09self shouldMNUTop.\x0a\x09self shouldMNUMiddle.\x0a\x09self shouldMNUBottom",
- referencedClasses: [],
- messageSends: ["shouldMNUTop", "shouldMNUMiddle", "shouldMNUBottom"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "shouldMNUBottom",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@performBlock"])._value_(self["@receiverBottom"]);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldMNUBottom",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "shouldMNUBottom\x0a\x09self should: [ performBlock value: receiverBottom ] raise: MessageNotUnderstood",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["should:raise:", "value:"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "shouldMNUMiddle",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@performBlock"])._value_(self["@receiverMiddle"]);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldMNUMiddle",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "shouldMNUMiddle\x0a\x09self should: [ performBlock value: receiverMiddle ] raise: MessageNotUnderstood",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["should:raise:", "value:"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "shouldMNUTop",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@performBlock"])._value_(self["@receiverTop"]);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldMNUTop",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "shouldMNUTop\x0a\x09self should: [ performBlock value: receiverTop ] raise: MessageNotUnderstood",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["should:raise:", "value:"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "shouldReturn:",
- protocol: "testing",
- fn: function (anObject){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- result=$recv(self["@performBlock"])._value_(self["@receiverTop"]);
- $ctx1.sendIdx["value:"]=1;
- self._assert_equals_(["top",anObject],["top",result]);
- $ctx1.sendIdx["assert:equals:"]=1;
- result=$recv(self["@performBlock"])._value_(self["@receiverMiddle"]);
- $ctx1.sendIdx["value:"]=2;
- self._assert_equals_(["middle",anObject],["middle",result]);
- $ctx1.sendIdx["assert:equals:"]=2;
- result=$recv(self["@performBlock"])._value_(self["@receiverBottom"]);
- self._assert_equals_(["bottom",anObject],["bottom",result]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldReturn:",{anObject:anObject,result:result},$globals.MethodInheritanceTest)});
- },
- args: ["anObject"],
- source: "shouldReturn: anObject\x0a\x09| result |\x0a\x0a\x09result := performBlock value: receiverTop.\x0a\x09self assert: { 'top'. anObject } equals: { 'top'. result }.\x0a\x09result := performBlock value: receiverMiddle.\x0a\x09self assert: { 'middle'. anObject } equals: { 'middle'. result }.\x0a\x09result := performBlock value: receiverBottom.\x0a\x09self assert: { 'bottom'. anObject } equals: { 'bottom'. result }",
- referencedClasses: [],
- messageSends: ["value:", "assert:equals:"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "shouldReturn:and:and:",
- protocol: "testing",
- fn: function (anObject,anObject2,anObject3){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- result=$recv(self["@performBlock"])._value_(self["@receiverTop"]);
- $ctx1.sendIdx["value:"]=1;
- self._assert_equals_(["top",anObject],["top",result]);
- $ctx1.sendIdx["assert:equals:"]=1;
- result=$recv(self["@performBlock"])._value_(self["@receiverMiddle"]);
- $ctx1.sendIdx["value:"]=2;
- self._assert_equals_(["middle",anObject2],["middle",result]);
- $ctx1.sendIdx["assert:equals:"]=2;
- result=$recv(self["@performBlock"])._value_(self["@receiverBottom"]);
- self._assert_equals_(["bottom",anObject3],["bottom",result]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"shouldReturn:and:and:",{anObject:anObject,anObject2:anObject2,anObject3:anObject3,result:result},$globals.MethodInheritanceTest)});
- },
- args: ["anObject", "anObject2", "anObject3"],
- source: "shouldReturn: anObject and: anObject2 and: anObject3\x0a\x09| result |\x0a\x0a\x09result := performBlock value: receiverTop.\x0a\x09self assert: { 'top'. anObject } equals: { 'top'. result }.\x0a\x09result := performBlock value: receiverMiddle.\x0a\x09self assert: { 'middle'. anObject2 } equals: { 'middle'. result }.\x0a\x09result := performBlock value: receiverBottom.\x0a\x09self assert: { 'bottom'. anObject3 } equals: { 'bottom'. result }",
- referencedClasses: [],
- messageSends: ["value:", "assert:equals:"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "targetClassBottom",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.JavaScriptException;
- },
- args: [],
- source: "targetClassBottom\x0a\x09^ JavaScriptException",
- referencedClasses: ["JavaScriptException"],
- messageSends: []
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "targetClassMiddle",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.Error;
- },
- args: [],
- source: "targetClassMiddle\x0a\x09^ Error",
- referencedClasses: ["Error"],
- messageSends: []
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "targetClassTop",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.Object;
- },
- args: [],
- source: "targetClassTop\x0a\x09^ Object",
- referencedClasses: ["Object"],
- messageSends: []
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "tearDown",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._deinstallTop();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }))._on_do_($globals.Error,(function(){
- }));
- $ctx1.sendIdx["on:do:"]=1;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._deinstallMiddle();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }))._on_do_($globals.Error,(function(){
- }));
- $ctx1.sendIdx["on:do:"]=2;
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return self._deinstallBottom();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,5)});
- }))._on_do_($globals.Error,(function(){
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tearDown",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "tearDown\x0a\x09[ self deinstallTop ] on: Error do: [ ].\x0a\x09[ self deinstallMiddle ] on: Error do: [ ].\x0a\x09[ self deinstallBottom ] on: Error do: [ ]",
- referencedClasses: ["Error"],
- messageSends: ["on:do:", "deinstallTop", "deinstallMiddle", "deinstallBottom"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "testMNU11",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@performBlock"]=(function(x){
- return $core.withContext(function($ctx2) {
- return $recv(x)._foo();
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
- });
- self._shouldMNU();
- $ctx1.sendIdx["shouldMNU"]=1;
- self._installTop_("foo ^ false");
- $ctx1.sendIdx["installTop:"]=1;
- self._installTop_("foo ^ true");
- self._deinstallTop();
- self._shouldMNU();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMNU11",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "testMNU11\x0a\x09performBlock := [ :x | x foo ].\x0a\x09self shouldMNU.\x0a\x09self installTop: 'foo ^ false'.\x0a\x09self installTop: 'foo ^ true'.\x0a\x09self deinstallTop.\x0a\x09self shouldMNU",
- referencedClasses: [],
- messageSends: ["foo", "shouldMNU", "installTop:", "deinstallTop"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "testMNU22",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@performBlock"]=(function(x){
- return $core.withContext(function($ctx2) {
- return $recv(x)._foo();
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
- });
- self._shouldMNU();
- $ctx1.sendIdx["shouldMNU"]=1;
- self._installMiddle_("foo ^ false");
- $ctx1.sendIdx["installMiddle:"]=1;
- self._installMiddle_("foo ^ true");
- self._deinstallMiddle();
- self._shouldMNU();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMNU22",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "testMNU22\x0a\x09performBlock := [ :x | x foo ].\x0a\x09self shouldMNU.\x0a\x09self installMiddle: 'foo ^ false'.\x0a\x09self installMiddle: 'foo ^ true'.\x0a\x09self deinstallMiddle.\x0a\x09self shouldMNU",
- referencedClasses: [],
- messageSends: ["foo", "shouldMNU", "installMiddle:", "deinstallMiddle"]
- }),
- $globals.MethodInheritanceTest);
- $core.addMethod(
- $core.method({
- selector: "testReturns1",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@performBlock"]=(function(x){
- return $core.withContext(function($ctx2) {
- return $recv(x)._foo();
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)});
- });
- self._installTop_("foo ^ false");
- $ctx1.sendIdx["installTop:"]=1;
- self._shouldReturn_(false);
- $ctx1.sendIdx["shouldReturn:"]=1;
- self._installTop_("foo ^ true");
- self._shouldReturn_(true);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testReturns1",{},$globals.MethodInheritanceTest)});
- },
- args: [],
- source: "testReturns1\x0a\x09performBlock := [ :x | x foo ].\x0a\x09self installTop: 'foo ^ false'.\x0a\x09self shouldReturn: false.\x0a\x09self installTop: 'foo ^ true'.\x0a\x09self shouldReturn: true",
- referencedClasses: [],
- messageSends: ["foo", "installTop:", "shouldReturn:"]
- }),
- $globals.MethodInheritanceTest);
- $core.addClass("NumberTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testAbs",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(4)._abs();
- $ctx1.sendIdx["abs"]=1;
- self._assert_equals_($1,(4));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_((-4)._abs(),(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAbs",{},$globals.NumberTest)});
- },
- args: [],
- source: "testAbs\x0a\x09self assert: 4 abs equals: 4.\x0a\x09self assert: -4 abs equals: 4",
- referencedClasses: [],
- messageSends: ["assert:equals:", "abs"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testArithmetic",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4;
- $1=(1.5).__plus((1));
- $ctx1.sendIdx["+"]=1;
- self._assert_equals_($1,(2.5));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(2).__minus((1));
- $ctx1.sendIdx["-"]=1;
- self._assert_equals_($2,(1));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_((-2).__minus((1)),(-3));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_((12).__slash((2)),(6));
- $ctx1.sendIdx["assert:equals:"]=4;
- $3=(3).__star((4));
- $ctx1.sendIdx["*"]=1;
- self._assert_equals_($3,(12));
- $ctx1.sendIdx["assert:equals:"]=5;
- self._assert_equals_((7).__slash_slash((2)),(3));
- $ctx1.sendIdx["assert:equals:"]=6;
- self._assert_equals_((7).__backslash_backslash((2)),(1));
- $ctx1.sendIdx["assert:equals:"]=7;
- $5=(1).__plus((2));
- $ctx1.sendIdx["+"]=2;
- $4=$recv($5).__star((3));
- $ctx1.sendIdx["*"]=2;
- self._assert_equals_($4,(9));
- $ctx1.sendIdx["assert:equals:"]=8;
- self._assert_equals_((1).__plus((2).__star((3))),(7));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testArithmetic",{},$globals.NumberTest)});
- },
- args: [],
- source: "testArithmetic\x0a\x09\x0a\x09\x22We rely on JS here, so we won't test complex behavior, just check if\x0a\x09message sends are corrects\x22\x0a\x0a\x09self assert: 1.5 + 1 equals: 2.5.\x0a\x09self assert: 2 - 1 equals: 1.\x0a\x09self assert: -2 - 1 equals: -3.\x0a\x09self assert: 12 / 2 equals: 6.\x0a\x09self assert: 3 * 4 equals: 12.\x0a\x09self assert: 7 // 2 equals: 3.\x0a\x09self assert: 7 \x5c\x5c 2 equals: 1.\x0a\x0a\x09\x22Simple parenthesis and execution order\x22\x0a\x09self assert: 1 + 2 * 3 equals: 9.\x0a\x09self assert: 1 + (2 * 3) equals: 7",
- referencedClasses: [],
- messageSends: ["assert:equals:", "+", "-", "/", "*", "//", "\x5c\x5c"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testAsNumber",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_((3)._asNumber(),(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsNumber",{},$globals.NumberTest)});
- },
- args: [],
- source: "testAsNumber\x0a\x09self assert: 3 asNumber equals: 3.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "asNumber"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testCeiling",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=(1.2)._ceiling();
- $ctx1.sendIdx["ceiling"]=1;
- self._assert_equals_($1,(2));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(-1.2)._ceiling();
- $ctx1.sendIdx["ceiling"]=2;
- self._assert_equals_($2,(-1));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_((1)._ceiling(),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCeiling",{},$globals.NumberTest)});
- },
- args: [],
- source: "testCeiling\x0a\x09self assert: 1.2 ceiling equals: 2.\x0a\x09self assert: -1.2 ceiling equals: -1.\x0a\x09self assert: 1.0 ceiling equals: 1.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "ceiling"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testComparison",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- $1=(3).__gt((2));
- $ctx1.sendIdx[">"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $2=(2).__lt((3));
- $ctx1.sendIdx["<"]=1;
- self._assert_($2);
- $ctx1.sendIdx["assert:"]=2;
- self._deny_((3).__lt((2)));
- $ctx1.sendIdx["deny:"]=1;
- self._deny_((2).__gt((3)));
- $3=(3).__gt_eq((3));
- $ctx1.sendIdx[">="]=1;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=3;
- self._assert_((3.1).__gt_eq((3)));
- $ctx1.sendIdx["assert:"]=4;
- $4=(3).__lt_eq((3));
- $ctx1.sendIdx["<="]=1;
- self._assert_($4);
- $ctx1.sendIdx["assert:"]=5;
- self._assert_((3).__lt_eq((3.1)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testComparison",{},$globals.NumberTest)});
- },
- args: [],
- source: "testComparison\x0a\x0a\x09self assert: 3 > 2.\x0a\x09self assert: 2 < 3.\x0a\x09\x0a\x09self deny: 3 < 2.\x0a\x09self deny: 2 > 3.\x0a\x0a\x09self assert: 3 >= 3.\x0a\x09self assert: 3.1 >= 3.\x0a\x09self assert: 3 <= 3.\x0a\x09self assert: 3 <= 3.1",
- referencedClasses: [],
- messageSends: ["assert:", ">", "<", "deny:", ">=", "<="]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testCopying",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv((1)._copy()).__eq_eq((1));
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- self._assert_($recv((1)._deepCopy()).__eq_eq((1)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCopying",{},$globals.NumberTest)});
- },
- args: [],
- source: "testCopying\x0a\x09self assert: 1 copy == 1.\x0a\x09self assert: 1 deepCopy == 1",
- referencedClasses: [],
- messageSends: ["assert:", "==", "copy", "deepCopy"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testEquality",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4,$7,$6,$9,$8,$10,$11,$12;
- $1=(1).__eq((1));
- $ctx1.sendIdx["="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $2=(0).__eq((0));
- $ctx1.sendIdx["="]=2;
- self._assert_($2);
- $ctx1.sendIdx["assert:"]=2;
- $3=(1).__eq((0));
- $ctx1.sendIdx["="]=3;
- self._deny_($3);
- $ctx1.sendIdx["deny:"]=1;
- $5=(1)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $4=$recv($5).__eq((1));
- $ctx1.sendIdx["="]=4;
- self._assert_($4);
- $ctx1.sendIdx["assert:"]=3;
- $7=(1)._yourself();
- $ctx1.sendIdx["yourself"]=2;
- $6=(1).__eq($7);
- $ctx1.sendIdx["="]=5;
- self._assert_($6);
- $ctx1.sendIdx["assert:"]=4;
- $9=(1)._yourself();
- $ctx1.sendIdx["yourself"]=3;
- $8=$recv($9).__eq((1)._yourself());
- $ctx1.sendIdx["="]=6;
- self._assert_($8);
- $10=(0).__eq(false);
- $ctx1.sendIdx["="]=7;
- self._deny_($10);
- $ctx1.sendIdx["deny:"]=2;
- $11=false.__eq((0));
- $ctx1.sendIdx["="]=8;
- self._deny_($11);
- $ctx1.sendIdx["deny:"]=3;
- $12="".__eq((0));
- $ctx1.sendIdx["="]=9;
- self._deny_($12);
- $ctx1.sendIdx["deny:"]=4;
- self._deny_((0).__eq(""));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEquality",{},$globals.NumberTest)});
- },
- args: [],
- source: "testEquality\x0a\x09self assert: (1 = 1).\x0a\x09self assert: (0 = 0).\x0a\x09self deny: (1 = 0).\x0a\x0a\x09self assert: (1 yourself = 1).\x0a\x09self assert: (1 = 1 yourself).\x0a\x09self assert: (1 yourself = 1 yourself).\x0a\x09\x0a\x09self deny: 0 = false.\x0a\x09self deny: false = 0.\x0a\x09self deny: '' = 0.\x0a\x09self deny: 0 = ''",
- referencedClasses: [],
- messageSends: ["assert:", "=", "deny:", "yourself"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testFloor",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=(1.2)._floor();
- $ctx1.sendIdx["floor"]=1;
- self._assert_equals_($1,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(-1.2)._floor();
- $ctx1.sendIdx["floor"]=2;
- self._assert_equals_($2,(-2));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_((1)._floor(),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testFloor",{},$globals.NumberTest)});
- },
- args: [],
- source: "testFloor\x0a\x09self assert: 1.2 floor equals: 1.\x0a\x09self assert: -1.2 floor equals: -2.\x0a\x09self assert: 1.0 floor equals: 1.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "floor"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testHexNumbers",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5;
- self._assert_equals_((9),(9));
- $ctx1.sendIdx["assert:equals:"]=1;
- $1=(10)._truncated();
- $ctx1.sendIdx["truncated"]=1;
- self._assert_equals_($1,(10));
- $ctx1.sendIdx["assert:equals:"]=2;
- $2=(11)._truncated();
- $ctx1.sendIdx["truncated"]=2;
- self._assert_equals_($2,(11));
- $ctx1.sendIdx["assert:equals:"]=3;
- $3=(12)._truncated();
- $ctx1.sendIdx["truncated"]=3;
- self._assert_equals_($3,(12));
- $ctx1.sendIdx["assert:equals:"]=4;
- $4=(13)._truncated();
- $ctx1.sendIdx["truncated"]=4;
- self._assert_equals_($4,(13));
- $ctx1.sendIdx["assert:equals:"]=5;
- $5=(14)._truncated();
- $ctx1.sendIdx["truncated"]=5;
- self._assert_equals_($5,(14));
- $ctx1.sendIdx["assert:equals:"]=6;
- self._assert_equals_((15)._truncated(),(15));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testHexNumbers",{},$globals.NumberTest)});
- },
- args: [],
- source: "testHexNumbers\x0a\x0a\x09self assert: 16r9 equals: 9.\x0a\x09self assert: 16rA truncated equals: 10.\x0a\x09self assert: 16rB truncated equals: 11.\x0a\x09self assert: 16rC truncated equals: 12.\x0a\x09self assert: 16rD truncated equals: 13.\x0a\x09self assert: 16rE truncated equals: 14.\x0a\x09self assert: 16rF truncated equals: 15",
- referencedClasses: [],
- messageSends: ["assert:equals:", "truncated"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testIdentity",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$5,$4,$7,$6,$9,$8;
- $1=(1).__eq_eq((1));
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $2=(0).__eq_eq((0));
- $ctx1.sendIdx["=="]=2;
- self._assert_($2);
- $ctx1.sendIdx["assert:"]=2;
- $3=(1).__eq_eq((0));
- $ctx1.sendIdx["=="]=3;
- self._deny_($3);
- $ctx1.sendIdx["deny:"]=1;
- $5=(1)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $4=$recv($5).__eq_eq((1));
- $ctx1.sendIdx["=="]=4;
- self._assert_($4);
- $ctx1.sendIdx["assert:"]=3;
- $7=(1)._yourself();
- $ctx1.sendIdx["yourself"]=2;
- $6=(1).__eq_eq($7);
- $ctx1.sendIdx["=="]=5;
- self._assert_($6);
- $ctx1.sendIdx["assert:"]=4;
- $9=(1)._yourself();
- $ctx1.sendIdx["yourself"]=3;
- $8=$recv($9).__eq_eq((1)._yourself());
- $ctx1.sendIdx["=="]=6;
- self._assert_($8);
- self._deny_((1).__eq_eq((2)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIdentity",{},$globals.NumberTest)});
- },
- args: [],
- source: "testIdentity\x0a\x09self assert: 1 == 1.\x0a\x09self assert: 0 == 0.\x0a\x09self deny: 1 == 0.\x0a\x0a\x09self assert: 1 yourself == 1.\x0a\x09self assert: 1 == 1 yourself.\x0a\x09self assert: 1 yourself == 1 yourself.\x0a\x09\x0a\x09self deny: 1 == 2",
- referencedClasses: [],
- messageSends: ["assert:", "==", "deny:", "yourself"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testInvalidHexNumbers",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rG();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=1;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rg();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=2;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rH();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=3;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rh();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,4)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=4;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rI();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,5)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=5;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._ri();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,6)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=6;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rJ();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,7)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=7;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rj();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,8)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=8;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rK();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,9)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=9;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rk();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,10)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=10;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rL();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,11)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=11;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rl();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,12)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=12;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rM();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,13)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=13;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rm();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,14)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=14;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rN();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,15)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=15;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rn();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,16)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=16;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rO();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,17)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=17;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._ro();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,18)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=18;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rP();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,19)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=19;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rp();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,20)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=20;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rQ();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,21)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=21;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rq();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,22)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=22;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rR();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,23)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=23;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rr();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,24)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=24;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rS();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,25)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=25;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rs();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,26)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=26;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rT();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,27)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=27;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rt();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,28)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=28;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rU();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,29)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=29;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._ru();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,30)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=30;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rV();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,31)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=31;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rv();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,32)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=32;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rW();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,33)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=33;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rw();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,34)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=34;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rX();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,35)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=35;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rx();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,36)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=36;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rY();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,37)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=37;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._ry();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,38)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=38;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rZ();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,39)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=39;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (16)._rz();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,40)});
- }),$globals.MessageNotUnderstood);
- $ctx1.sendIdx["should:raise:"]=40;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (11259375)._Z();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,41)});
- }),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testInvalidHexNumbers",{},$globals.NumberTest)});
- },
- args: [],
- source: "testInvalidHexNumbers\x0a\x0a\x09self should: [ 16rG ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rg ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rH ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rh ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rI ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16ri ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rJ ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rj ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rK ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rk ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rL ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rl ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rM ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rm ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rN ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rn ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rO ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16ro ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rP ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rp ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rQ ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rq ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rR ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rr ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rS ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rs ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rT ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rt ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rU ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16ru ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rV ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rv ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rW ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rw ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rX ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rx ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rY ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16ry ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rZ ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rz ] raise: MessageNotUnderstood.\x0a\x09self should: [ 16rABcdEfZ ] raise: MessageNotUnderstood.",
- referencedClasses: ["MessageNotUnderstood"],
- messageSends: ["should:raise:", "rG", "rg", "rH", "rh", "rI", "ri", "rJ", "rj", "rK", "rk", "rL", "rl", "rM", "rm", "rN", "rn", "rO", "ro", "rP", "rp", "rQ", "rq", "rR", "rr", "rS", "rs", "rT", "rt", "rU", "ru", "rV", "rv", "rW", "rw", "rX", "rx", "rY", "ry", "rZ", "rz", "Z"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testLog",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_((10000)._log(),(4));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_((512)._log_((2)),(9));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv($recv($globals.Number)._e())._ln(),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testLog",{},$globals.NumberTest)});
- },
- args: [],
- source: "testLog\x0a\x09self assert: 10000 log equals: 4.\x0a\x09self assert: (512 log: 2) equals: 9.\x0a\x09self assert: Number e ln equals: 1.",
- referencedClasses: ["Number"],
- messageSends: ["assert:equals:", "log", "log:", "ln", "e"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testMinMax",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_((2)._max_((5)),(5));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_((2)._min_((5)),(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testMinMax",{},$globals.NumberTest)});
- },
- args: [],
- source: "testMinMax\x0a\x09\x0a\x09self assert: (2 max: 5) equals: 5.\x0a\x09self assert: (2 min: 5) equals: 2",
- referencedClasses: [],
- messageSends: ["assert:equals:", "max:", "min:"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testNegated",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(3)._negated();
- $ctx1.sendIdx["negated"]=1;
- self._assert_equals_($1,(-3));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_((-3)._negated(),(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNegated",{},$globals.NumberTest)});
- },
- args: [],
- source: "testNegated\x0a\x09self assert: 3 negated equals: -3.\x0a\x09self assert: -3 negated equals: 3",
- referencedClasses: [],
- messageSends: ["assert:equals:", "negated"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testPrintShowingDecimalPlaces",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3,$5,$6,$8,$7,$10,$9,$11,$12,$13,$14,$15;
- $1=(23)._printShowingDecimalPlaces_((2));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=1;
- self._assert_equals_($1,"23.00");
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(23.5698)._printShowingDecimalPlaces_((2));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=2;
- self._assert_equals_($2,"23.57");
- $ctx1.sendIdx["assert:equals:"]=2;
- $4=(234.567)._negated();
- $ctx1.sendIdx["negated"]=1;
- $3=$recv($4)._printShowingDecimalPlaces_((5));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=3;
- self._assert_equals_($3,"-234.56700");
- $ctx1.sendIdx["assert:equals:"]=3;
- $5=(23.4567)._printShowingDecimalPlaces_((0));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=4;
- self._assert_equals_($5,"23");
- $ctx1.sendIdx["assert:equals:"]=4;
- $6=(23.5567)._printShowingDecimalPlaces_((0));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=5;
- self._assert_equals_($6,"24");
- $ctx1.sendIdx["assert:equals:"]=5;
- $8=(23.4567)._negated();
- $ctx1.sendIdx["negated"]=2;
- $7=$recv($8)._printShowingDecimalPlaces_((0));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=6;
- self._assert_equals_($7,"-23");
- $ctx1.sendIdx["assert:equals:"]=6;
- $10=(23.5567)._negated();
- $ctx1.sendIdx["negated"]=3;
- $9=$recv($10)._printShowingDecimalPlaces_((0));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=7;
- self._assert_equals_($9,"-24");
- $ctx1.sendIdx["assert:equals:"]=7;
- $11=(100000000)._printShowingDecimalPlaces_((1));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=8;
- self._assert_equals_($11,"100000000.0");
- $ctx1.sendIdx["assert:equals:"]=8;
- $12=(0.98)._printShowingDecimalPlaces_((5));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=9;
- self._assert_equals_($12,"0.98000");
- $ctx1.sendIdx["assert:equals:"]=9;
- $13=$recv((0.98)._negated())._printShowingDecimalPlaces_((2));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=10;
- self._assert_equals_($13,"-0.98");
- $ctx1.sendIdx["assert:equals:"]=10;
- $14=(2.567)._printShowingDecimalPlaces_((2));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=11;
- self._assert_equals_($14,"2.57");
- $ctx1.sendIdx["assert:equals:"]=11;
- $15=(-2.567)._printShowingDecimalPlaces_((2));
- $ctx1.sendIdx["printShowingDecimalPlaces:"]=12;
- self._assert_equals_($15,"-2.57");
- $ctx1.sendIdx["assert:equals:"]=12;
- self._assert_equals_((0)._printShowingDecimalPlaces_((2)),"0.00");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPrintShowingDecimalPlaces",{},$globals.NumberTest)});
- },
- args: [],
- source: "testPrintShowingDecimalPlaces\x0a\x09self assert: (23 printShowingDecimalPlaces: 2) equals: '23.00'.\x0a\x09self assert: (23.5698 printShowingDecimalPlaces: 2) equals: '23.57'.\x0a\x09self assert: (234.567 negated printShowingDecimalPlaces: 5) equals: '-234.56700'.\x0a\x09self assert: (23.4567 printShowingDecimalPlaces: 0) equals: '23'.\x0a\x09self assert: (23.5567 printShowingDecimalPlaces: 0) equals: '24'.\x0a\x09self assert: (23.4567 negated printShowingDecimalPlaces: 0) equals: '-23'.\x0a\x09self assert: (23.5567 negated printShowingDecimalPlaces: 0) equals: '-24'.\x0a\x09self assert: (100000000 printShowingDecimalPlaces: 1) equals: '100000000.0'.\x0a\x09self assert: (0.98 printShowingDecimalPlaces: 5) equals: '0.98000'.\x0a\x09self assert: (0.98 negated printShowingDecimalPlaces: 2) equals: '-0.98'.\x0a\x09self assert: (2.567 printShowingDecimalPlaces: 2) equals: '2.57'.\x0a\x09self assert: (-2.567 printShowingDecimalPlaces: 2) equals: '-2.57'.\x0a\x09self assert: (0 printShowingDecimalPlaces: 2) equals: '0.00'.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "printShowingDecimalPlaces:", "negated"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testRaisedTo",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- $1=(2)._raisedTo_((4));
- $ctx1.sendIdx["raisedTo:"]=1;
- self._assert_equals_($1,(16));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(2)._raisedTo_((0));
- $ctx1.sendIdx["raisedTo:"]=2;
- self._assert_equals_($2,(1));
- $ctx1.sendIdx["assert:equals:"]=2;
- $3=(2)._raisedTo_((-3));
- $ctx1.sendIdx["raisedTo:"]=3;
- self._assert_equals_($3,(0.125));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_((4)._raisedTo_((0.5)),(2));
- $ctx1.sendIdx["assert:equals:"]=4;
- self._assert_equals_((2).__star_star((4)),(16));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRaisedTo",{},$globals.NumberTest)});
- },
- args: [],
- source: "testRaisedTo\x0a\x09self assert: (2 raisedTo: 4) equals: 16.\x0a\x09self assert: (2 raisedTo: 0) equals: 1.\x0a\x09self assert: (2 raisedTo: -3) equals: 0.125.\x0a\x09self assert: (4 raisedTo: 0.5) equals: 2.\x0a\x09\x0a\x09self assert: 2 ** 4 equals: 16.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "raisedTo:", "**"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testRounded",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=(3)._rounded();
- $ctx1.sendIdx["rounded"]=1;
- self._assert_equals_($1,(3));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(3.212)._rounded();
- $ctx1.sendIdx["rounded"]=2;
- self._assert_equals_($2,(3));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_((3.51)._rounded(),(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRounded",{},$globals.NumberTest)});
- },
- args: [],
- source: "testRounded\x0a\x09\x0a\x09self assert: 3 rounded equals: 3.\x0a\x09self assert: 3.212 rounded equals: 3.\x0a\x09self assert: 3.51 rounded equals: 4",
- referencedClasses: [],
- messageSends: ["assert:equals:", "rounded"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testSign",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=(5)._sign();
- $ctx1.sendIdx["sign"]=1;
- self._assert_equals_($1,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(0)._sign();
- $ctx1.sendIdx["sign"]=2;
- self._assert_equals_($2,(0));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_((-1.4)._sign(),(-1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSign",{},$globals.NumberTest)});
- },
- args: [],
- source: "testSign\x0a\x09self assert: 5 sign equals: 1.\x0a\x09self assert: 0 sign equals: 0.\x0a\x09self assert: -1.4 sign equals: -1.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "sign"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testSqrt",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(4)._sqrt();
- $ctx1.sendIdx["sqrt"]=1;
- self._assert_equals_($1,(2));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_((16)._sqrt(),(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSqrt",{},$globals.NumberTest)});
- },
- args: [],
- source: "testSqrt\x0a\x09\x0a\x09self assert: 4 sqrt equals: 2.\x0a\x09self assert: 16 sqrt equals: 4",
- referencedClasses: [],
- messageSends: ["assert:equals:", "sqrt"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testSquared",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_((4)._squared(),(16));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testSquared",{},$globals.NumberTest)});
- },
- args: [],
- source: "testSquared\x0a\x09\x0a\x09self assert: 4 squared equals: 16",
- referencedClasses: [],
- messageSends: ["assert:equals:", "squared"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testTimesRepeat",
- protocol: "tests",
- fn: function (){
- var self=this;
- var i;
- return $core.withContext(function($ctx1) {
- i=(0);
- (0)._timesRepeat_((function(){
- return $core.withContext(function($ctx2) {
- i=$recv(i).__plus((1));
- $ctx2.sendIdx["+"]=1;
- return i;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["timesRepeat:"]=1;
- self._assert_equals_(i,(0));
- $ctx1.sendIdx["assert:equals:"]=1;
- (5)._timesRepeat_((function(){
- return $core.withContext(function($ctx2) {
- i=$recv(i).__plus((1));
- return i;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- self._assert_equals_(i,(5));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTimesRepeat",{i:i},$globals.NumberTest)});
- },
- args: [],
- source: "testTimesRepeat\x0a\x09| i |\x0a\x0a\x09i := 0.\x0a\x090 timesRepeat: [ i := i + 1 ].\x0a\x09self assert: i equals: 0.\x0a\x0a\x095 timesRepeat: [ i := i + 1 ].\x0a\x09self assert: i equals: 5",
- referencedClasses: [],
- messageSends: ["timesRepeat:", "+", "assert:equals:"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testTo",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_((1)._to_((5)),[(1), (2), (3), (4), (5)]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTo",{},$globals.NumberTest)});
- },
- args: [],
- source: "testTo\x0a\x09self assert: (1 to: 5) equals: #(1 2 3 4 5)",
- referencedClasses: [],
- messageSends: ["assert:equals:", "to:"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testToBy",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=(0)._to_by_((6),(2));
- $ctx1.sendIdx["to:by:"]=1;
- self._assert_equals_($1,[(0), (2), (4), (6)]);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return (1)._to_by_((4),(0));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testToBy",{},$globals.NumberTest)});
- },
- args: [],
- source: "testToBy\x0a\x09self assert: (0 to: 6 by: 2) equals: #(0 2 4 6).\x0a\x0a\x09self should: [ 1 to: 4 by: 0 ] raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["assert:equals:", "to:by:", "should:raise:"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testTrigonometry",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_((0)._cos(),(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_((0)._sin(),(0));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_((0)._tan(),(0));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_((1)._arcCos(),(0));
- $ctx1.sendIdx["assert:equals:"]=4;
- self._assert_equals_((0)._arcSin(),(0));
- $ctx1.sendIdx["assert:equals:"]=5;
- self._assert_equals_((0)._arcTan(),(0));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTrigonometry",{},$globals.NumberTest)});
- },
- args: [],
- source: "testTrigonometry\x0a\x09self assert: 0 cos equals: 1.\x0a\x09self assert: 0 sin equals: 0.\x0a\x09self assert: 0 tan equals: 0.\x0a\x09self assert: 1 arcCos equals: 0.\x0a\x09self assert: 0 arcSin equals: 0.\x0a\x09self assert: 0 arcTan equals: 0.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "cos", "sin", "tan", "arcCos", "arcSin", "arcTan"]
- }),
- $globals.NumberTest);
- $core.addMethod(
- $core.method({
- selector: "testTruncated",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=(3)._truncated();
- $ctx1.sendIdx["truncated"]=1;
- self._assert_equals_($1,(3));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=(3.212)._truncated();
- $ctx1.sendIdx["truncated"]=2;
- self._assert_equals_($2,(3));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_((3.51)._truncated(),(3));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTruncated",{},$globals.NumberTest)});
- },
- args: [],
- source: "testTruncated\x0a\x09\x0a\x09self assert: 3 truncated equals: 3.\x0a\x09self assert: 3.212 truncated equals: 3.\x0a\x09self assert: 3.51 truncated equals: 3",
- referencedClasses: [],
- messageSends: ["assert:equals:", "truncated"]
- }),
- $globals.NumberTest);
- $core.addClass("ObjectMock", $globals.Object, ["foo", "bar"], "Kernel-Tests");
- $globals.ObjectMock.comment="ObjectMock is there only to perform tests on classes.";
- $core.addMethod(
- $core.method({
- selector: "foo",
- protocol: "not yet classified",
- fn: function (){
- var self=this;
- return self["@foo"];
- },
- args: [],
- source: "foo\x0a\x09^ foo",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ObjectMock);
- $core.addMethod(
- $core.method({
- selector: "foo:",
- protocol: "not yet classified",
- fn: function (anObject){
- var self=this;
- self["@foo"]=anObject;
- return self;
- },
- args: ["anObject"],
- source: "foo: anObject\x0a\x09foo := anObject",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ObjectMock);
- $core.addClass("ObjectTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "notDefined",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return void 0;;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"notDefined",{},$globals.ObjectTest)});
- },
- args: [],
- source: "notDefined\x0a\x09<inlineJS: 'return void 0;'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testBasicAccess",
- protocol: "tests",
- fn: function (){
- var self=this;
- var o;
- return $core.withContext(function($ctx1) {
- var $1;
- o=$recv($globals.Object)._new();
- $recv(o)._basicAt_put_("a",(1));
- $1=$recv(o)._basicAt_("a");
- $ctx1.sendIdx["basicAt:"]=1;
- self._assert_equals_($1,(1));
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv(o)._basicAt_("b"),nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testBasicAccess",{o:o},$globals.ObjectTest)});
- },
- args: [],
- source: "testBasicAccess\x0a\x09| o |\x0a\x09o := Object new.\x0a\x09o basicAt: 'a' put: 1.\x0a\x09self assert: (o basicAt: 'a') equals: 1.\x0a\x09self assert: (o basicAt: 'b') equals: nil",
- referencedClasses: ["Object"],
- messageSends: ["new", "basicAt:put:", "assert:equals:", "basicAt:"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testBasicPerform",
- protocol: "tests",
- fn: function (){
- var self=this;
- var o;
- return $core.withContext(function($ctx1) {
- o=$recv($globals.Object)._new();
- $recv(o)._basicAt_put_("func",(function(){
- return "hello";
- }));
- $ctx1.sendIdx["basicAt:put:"]=1;
- $recv(o)._basicAt_put_("func2",(function(a){
- return $core.withContext(function($ctx2) {
- return $recv(a).__plus((1));
- }, function($ctx2) {$ctx2.fillBlock({a:a},$ctx1,2)});
- }));
- self._assert_equals_($recv(o)._basicPerform_("func"),"hello");
- $ctx1.sendIdx["assert:equals:"]=1;
- self._assert_equals_($recv(o)._basicPerform_withArguments_("func2",[(3)]),(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testBasicPerform",{o:o},$globals.ObjectTest)});
- },
- args: [],
- source: "testBasicPerform\x0a\x09| o |\x0a\x09o := Object new.\x0a\x09o basicAt: 'func' put: [ 'hello' ].\x0a\x09o basicAt: 'func2' put: [ :a | a + 1 ].\x0a\x0a\x09self assert: (o basicPerform: 'func') equals: 'hello'.\x0a\x09self assert: (o basicPerform: 'func2' withArguments: #(3)) equals: 4",
- referencedClasses: ["Object"],
- messageSends: ["new", "basicAt:put:", "+", "assert:equals:", "basicPerform:", "basicPerform:withArguments:"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testDNU",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv($globals.Object)._new())._foo();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.MessageNotUnderstood);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDNU",{},$globals.ObjectTest)});
- },
- args: [],
- source: "testDNU\x0a\x09self should: [ Object new foo ] raise: MessageNotUnderstood",
- referencedClasses: ["Object", "MessageNotUnderstood"],
- messageSends: ["should:raise:", "foo", "new"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testEquality",
- protocol: "tests",
- fn: function (){
- var self=this;
- var o;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3;
- o=$recv($globals.Object)._new();
- $ctx1.sendIdx["new"]=1;
- $1=$recv(o).__eq($recv($globals.Object)._new());
- $ctx1.sendIdx["="]=1;
- self._deny_($1);
- $2=$recv(o).__eq(o);
- $ctx1.sendIdx["="]=2;
- self._assert_($2);
- $ctx1.sendIdx["assert:"]=1;
- $4=$recv(o)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $3=$recv($4).__eq(o);
- $ctx1.sendIdx["="]=3;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- self._assert_($recv(o).__eq($recv(o)._yourself()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEquality",{o:o},$globals.ObjectTest)});
- },
- args: [],
- source: "testEquality\x0a\x09| o |\x0a\x09o := Object new.\x0a\x09self deny: o = Object new.\x0a\x09self assert: (o = o).\x0a\x09self assert: (o yourself = o).\x0a\x09self assert: (o = o yourself)",
- referencedClasses: ["Object"],
- messageSends: ["new", "deny:", "=", "assert:", "yourself"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testHalt",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv($globals.Object)._new())._halt();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testHalt",{},$globals.ObjectTest)});
- },
- args: [],
- source: "testHalt\x0a\x09self should: [ Object new halt ] raise: Error",
- referencedClasses: ["Object", "Error"],
- messageSends: ["should:raise:", "halt", "new"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testIdentity",
- protocol: "tests",
- fn: function (){
- var self=this;
- var o;
- return $core.withContext(function($ctx1) {
- var $1,$2,$4,$3;
- o=$recv($globals.Object)._new();
- $ctx1.sendIdx["new"]=1;
- $1=$recv(o).__eq_eq($recv($globals.Object)._new());
- $ctx1.sendIdx["=="]=1;
- self._deny_($1);
- $2=$recv(o).__eq_eq(o);
- $ctx1.sendIdx["=="]=2;
- self._assert_($2);
- $ctx1.sendIdx["assert:"]=1;
- $4=$recv(o)._yourself();
- $ctx1.sendIdx["yourself"]=1;
- $3=$recv($4).__eq_eq(o);
- $ctx1.sendIdx["=="]=3;
- self._assert_($3);
- $ctx1.sendIdx["assert:"]=2;
- self._assert_($recv(o).__eq_eq($recv(o)._yourself()));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIdentity",{o:o},$globals.ObjectTest)});
- },
- args: [],
- source: "testIdentity\x0a\x09| o |\x0a\x09o := Object new.\x0a\x09self deny: o == Object new.\x0a\x09self assert: o == o.\x0a\x09self assert: o yourself == o.\x0a\x09self assert: o == o yourself",
- referencedClasses: ["Object"],
- messageSends: ["new", "deny:", "==", "assert:", "yourself"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testIfNil",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$5,$4,$3,$7,$6,$9,$8,$11,$10,$receiver;
- $2=$recv($globals.Object)._new();
- $ctx1.sendIdx["new"]=1;
- $1=$recv($2)._isNil();
- self._deny_($1);
- $ctx1.sendIdx["deny:"]=1;
- $5=$recv($globals.Object)._new();
- $ctx1.sendIdx["new"]=2;
- if(($receiver = $5) == null || $receiver.isNil){
- $4=true;
- } else {
- $4=$5;
- }
- $3=$recv($4).__eq(true);
- self._deny_($3);
- $7=$recv($globals.Object)._new();
- $ctx1.sendIdx["new"]=3;
- if(($receiver = $7) == null || $receiver.isNil){
- $6=$7;
- } else {
- $6=true;
- }
- self._assert_equals_($6,true);
- $ctx1.sendIdx["assert:equals:"]=1;
- $9=$recv($globals.Object)._new();
- $ctx1.sendIdx["new"]=4;
- if(($receiver = $9) == null || $receiver.isNil){
- $8=false;
- } else {
- $8=true;
- }
- self._assert_equals_($8,true);
- $ctx1.sendIdx["assert:equals:"]=2;
- $11=$recv($globals.Object)._new();
- if(($receiver = $11) == null || $receiver.isNil){
- $10=false;
- } else {
- $10=true;
- }
- self._assert_equals_($10,true);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIfNil",{},$globals.ObjectTest)});
- },
- args: [],
- source: "testIfNil\x0a\x09self deny: Object new isNil.\x0a\x09self deny: (Object new ifNil: [ true ]) = true.\x0a\x09self assert: (Object new ifNotNil: [ true ]) equals: true.\x0a\x0a\x09self assert: (Object new ifNil: [ false ] ifNotNil: [ true ]) equals: true.\x0a\x09self assert: (Object new ifNotNil: [ true ] ifNil: [ false ]) equals: true",
- referencedClasses: ["Object"],
- messageSends: ["deny:", "isNil", "new", "=", "ifNil:", "assert:equals:", "ifNotNil:", "ifNil:ifNotNil:", "ifNotNil:ifNil:"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testInstVars",
- protocol: "tests",
- fn: function (){
- var self=this;
- var o;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- o=$recv($globals.ObjectMock)._new();
- $1=$recv(o)._instVarAt_("foo");
- $ctx1.sendIdx["instVarAt:"]=1;
- self._assert_equals_($1,nil);
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(o)._instVarAt_put_("foo",(1));
- $2=$recv(o)._instVarAt_("foo");
- $ctx1.sendIdx["instVarAt:"]=2;
- self._assert_equals_($2,(1));
- $ctx1.sendIdx["assert:equals:"]=2;
- self._assert_equals_($recv(o)._instVarAt_("foo"),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testInstVars",{o:o},$globals.ObjectTest)});
- },
- args: [],
- source: "testInstVars\x0a\x09| o |\x0a\x09o := ObjectMock new.\x0a\x09self assert: (o instVarAt: #foo) equals: nil.\x0a\x0a\x09o instVarAt: #foo put: 1.\x0a\x09self assert: (o instVarAt: #foo) equals: 1.\x0a\x09self assert: (o instVarAt: 'foo') equals: 1",
- referencedClasses: ["ObjectMock"],
- messageSends: ["new", "assert:equals:", "instVarAt:", "instVarAt:put:"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testNilUndefined",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_(self._notDefined(),nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNilUndefined",{},$globals.ObjectTest)});
- },
- args: [],
- source: "testNilUndefined\x0a\x09\x22nil in Smalltalk is the undefined object in JS\x22\x0a\x0a\x09self assert: self notDefined equals: nil",
- referencedClasses: [],
- messageSends: ["assert:equals:", "notDefined"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testYourself",
- protocol: "tests",
- fn: function (){
- var self=this;
- var o;
- return $core.withContext(function($ctx1) {
- o=$recv($globals.ObjectMock)._new();
- self._assert_($recv($recv(o)._yourself()).__eq_eq(o));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testYourself",{o:o},$globals.ObjectTest)});
- },
- args: [],
- source: "testYourself\x0a\x09| o |\x0a\x09o := ObjectMock new.\x0a\x09self assert: o yourself == o",
- referencedClasses: ["ObjectMock"],
- messageSends: ["new", "assert:", "==", "yourself"]
- }),
- $globals.ObjectTest);
- $core.addMethod(
- $core.method({
- selector: "testidentityHash",
- protocol: "tests",
- fn: function (){
- var self=this;
- var o1,o2;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$5,$4;
- o1=$recv($globals.Object)._new();
- $ctx1.sendIdx["new"]=1;
- o2=$recv($globals.Object)._new();
- $2=$recv(o1)._identityHash();
- $ctx1.sendIdx["identityHash"]=1;
- $3=$recv(o1)._identityHash();
- $ctx1.sendIdx["identityHash"]=2;
- $1=$recv($2).__eq_eq($3);
- $ctx1.sendIdx["=="]=1;
- self._assert_($1);
- $5=$recv(o1)._identityHash();
- $ctx1.sendIdx["identityHash"]=3;
- $4=$recv($5).__eq_eq($recv(o2)._identityHash());
- self._deny_($4);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testidentityHash",{o1:o1,o2:o2},$globals.ObjectTest)});
- },
- args: [],
- source: "testidentityHash\x0a\x09| o1 o2 |\x0a\x09\x0a\x09o1 := Object new.\x0a\x09o2 := Object new.\x0a\x0a\x09self assert: o1 identityHash == o1 identityHash.\x0a\x09self deny: o1 identityHash == o2 identityHash",
- referencedClasses: ["Object"],
- messageSends: ["new", "assert:", "==", "identityHash", "deny:"]
- }),
- $globals.ObjectTest);
- $core.addClass("PointTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testAccessing",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$6,$5,$4;
- $2=$recv($globals.Point)._x_y_((3),(4));
- $ctx1.sendIdx["x:y:"]=1;
- $1=$recv($2)._x();
- $ctx1.sendIdx["x"]=1;
- self._assert_equals_($1,(3));
- $ctx1.sendIdx["assert:equals:"]=1;
- $3=$recv($recv($globals.Point)._x_y_((3),(4)))._y();
- $ctx1.sendIdx["y"]=1;
- self._assert_equals_($3,(4));
- $ctx1.sendIdx["assert:equals:"]=2;
- $6=$recv($globals.Point)._new();
- $ctx1.sendIdx["new"]=1;
- $5=$recv($6)._x_((3));
- $4=$recv($5)._x();
- self._assert_equals_($4,(3));
- $ctx1.sendIdx["assert:equals:"]=3;
- self._assert_equals_($recv($recv($recv($globals.Point)._new())._y_((4)))._y(),(4));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAccessing",{},$globals.PointTest)});
- },
- args: [],
- source: "testAccessing\x0a\x09self assert: (Point x: 3 y: 4) x equals: 3.\x0a\x09self assert: (Point x: 3 y: 4) y equals: 4.\x0a\x09self assert: (Point new x: 3) x equals: 3.\x0a\x09self assert: (Point new y: 4) y equals: 4",
- referencedClasses: ["Point"],
- messageSends: ["assert:equals:", "x", "x:y:", "y", "x:", "new", "y:"]
- }),
- $globals.PointTest);
- $core.addMethod(
- $core.method({
- selector: "testArithmetic",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$4,$6,$7,$5,$8,$10,$11,$9,$12,$14,$13;
- $2=(3).__at((4));
- $ctx1.sendIdx["@"]=1;
- $3=(3).__at((4));
- $ctx1.sendIdx["@"]=2;
- $1=$recv($2).__star($3);
- $4=$recv($globals.Point)._x_y_((9),(16));
- $ctx1.sendIdx["x:y:"]=1;
- self._assert_equals_($1,$4);
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=(3).__at((4));
- $ctx1.sendIdx["@"]=3;
- $7=(3).__at((4));
- $ctx1.sendIdx["@"]=4;
- $5=$recv($6).__plus($7);
- $8=$recv($globals.Point)._x_y_((6),(8));
- $ctx1.sendIdx["x:y:"]=2;
- self._assert_equals_($5,$8);
- $ctx1.sendIdx["assert:equals:"]=2;
- $10=(3).__at((4));
- $ctx1.sendIdx["@"]=5;
- $11=(3).__at((4));
- $ctx1.sendIdx["@"]=6;
- $9=$recv($10).__minus($11);
- $12=$recv($globals.Point)._x_y_((0),(0));
- $ctx1.sendIdx["x:y:"]=3;
- self._assert_equals_($9,$12);
- $ctx1.sendIdx["assert:equals:"]=3;
- $14=(6).__at((8));
- $ctx1.sendIdx["@"]=7;
- $13=$recv($14).__slash((3).__at((4)));
- self._assert_equals_($13,$recv($globals.Point)._x_y_((2),(2)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testArithmetic",{},$globals.PointTest)});
- },
- args: [],
- source: "testArithmetic\x0a\x09self assert: 3@4 * (3@4 ) equals: (Point x: 9 y: 16).\x0a\x09self assert: 3@4 + (3@4 ) equals: (Point x: 6 y: 8).\x0a\x09self assert: 3@4 - (3@4 ) equals: (Point x: 0 y: 0).\x0a\x09self assert: 6@8 / (3@4 ) equals: (Point x: 2 y: 2)",
- referencedClasses: ["Point"],
- messageSends: ["assert:equals:", "*", "@", "x:y:", "+", "-", "/"]
- }),
- $globals.PointTest);
- $core.addMethod(
- $core.method({
- selector: "testAt",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_((3).__at((4)),$recv($globals.Point)._x_y_((3),(4)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAt",{},$globals.PointTest)});
- },
- args: [],
- source: "testAt\x0a\x09self assert: 3@4 equals: (Point x: 3 y: 4)",
- referencedClasses: ["Point"],
- messageSends: ["assert:equals:", "@", "x:y:"]
- }),
- $globals.PointTest);
- $core.addMethod(
- $core.method({
- selector: "testComparison",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$5,$6,$4,$8,$9,$7,$11,$12,$10,$14,$15,$13,$17,$18,$16,$20,$21,$19,$23,$22;
- $2=(3).__at((4));
- $ctx1.sendIdx["@"]=1;
- $3=(4).__at((5));
- $ctx1.sendIdx["@"]=2;
- $1=$recv($2).__lt($3);
- $ctx1.sendIdx["<"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $5=(3).__at((4));
- $ctx1.sendIdx["@"]=3;
- $6=(4).__at((4));
- $ctx1.sendIdx["@"]=4;
- $4=$recv($5).__lt($6);
- self._deny_($4);
- $ctx1.sendIdx["deny:"]=1;
- $8=(4).__at((5));
- $ctx1.sendIdx["@"]=5;
- $9=(4).__at((5));
- $ctx1.sendIdx["@"]=6;
- $7=$recv($8).__lt_eq($9);
- $ctx1.sendIdx["<="]=1;
- self._assert_($7);
- $ctx1.sendIdx["assert:"]=2;
- $11=(4).__at((5));
- $ctx1.sendIdx["@"]=7;
- $12=(3).__at((5));
- $ctx1.sendIdx["@"]=8;
- $10=$recv($11).__lt_eq($12);
- self._deny_($10);
- $ctx1.sendIdx["deny:"]=2;
- $14=(5).__at((6));
- $ctx1.sendIdx["@"]=9;
- $15=(4).__at((5));
- $ctx1.sendIdx["@"]=10;
- $13=$recv($14).__gt($15);
- $ctx1.sendIdx[">"]=1;
- self._assert_($13);
- $ctx1.sendIdx["assert:"]=3;
- $17=(5).__at((6));
- $ctx1.sendIdx["@"]=11;
- $18=(6).__at((6));
- $ctx1.sendIdx["@"]=12;
- $16=$recv($17).__gt($18);
- self._deny_($16);
- $ctx1.sendIdx["deny:"]=3;
- $20=(4).__at((5));
- $ctx1.sendIdx["@"]=13;
- $21=(4).__at((5));
- $ctx1.sendIdx["@"]=14;
- $19=$recv($20).__gt_eq($21);
- $ctx1.sendIdx[">="]=1;
- self._assert_($19);
- $23=(4).__at((5));
- $ctx1.sendIdx["@"]=15;
- $22=$recv($23).__gt_eq((5).__at((5)));
- self._deny_($22);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testComparison",{},$globals.PointTest)});
- },
- args: [],
- source: "testComparison\x0a\x09self assert: 3@4 < (4@5).\x0a\x09self deny: 3@4 < (4@4).\x0a\x09\x0a\x09self assert: 4@5 <= (4@5).\x0a\x09self deny: 4@5 <= (3@5).\x0a\x09\x0a\x09self assert: 5@6 > (4@5).\x0a\x09self deny: 5@6 > (6@6).\x0a\x09\x0a\x09self assert: 4@5 >= (4@5).\x0a\x09self deny: 4@5 >= (5@5)",
- referencedClasses: [],
- messageSends: ["assert:", "<", "@", "deny:", "<=", ">", ">="]
- }),
- $globals.PointTest);
- $core.addMethod(
- $core.method({
- selector: "testEgality",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$5,$4;
- $2=(3).__at((4));
- $ctx1.sendIdx["@"]=1;
- $3=(3).__at((4));
- $ctx1.sendIdx["@"]=2;
- $1=$recv($2).__eq($3);
- $ctx1.sendIdx["="]=1;
- self._assert_($1);
- $5=(3).__at((5));
- $ctx1.sendIdx["@"]=3;
- $4=$recv($5).__eq((3).__at((6)));
- self._deny_($4);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEgality",{},$globals.PointTest)});
- },
- args: [],
- source: "testEgality\x0a\x09self assert: (3@4 = (3@4)).\x0a\x09self deny: 3@5 = (3@6)",
- referencedClasses: [],
- messageSends: ["assert:", "=", "@", "deny:"]
- }),
- $globals.PointTest);
- $core.addMethod(
- $core.method({
- selector: "testNew",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1,$7,$6,$5,$4,$10,$9,$8;
- $3=$recv($globals.Point)._new();
- $ctx1.sendIdx["new"]=1;
- $2=$recv($3)._x_((3));
- $ctx1.sendIdx["x:"]=1;
- $1=$recv($2)._y();
- $ctx1.sendIdx["y"]=1;
- self._assert_equals_($1,nil);
- $ctx1.sendIdx["assert:equals:"]=1;
- $7=$recv($globals.Point)._new();
- $ctx1.sendIdx["new"]=2;
- $6=$recv($7)._x_((3));
- $5=$recv($6)._x();
- $ctx1.sendIdx["x"]=1;
- $4=$recv($5).__eq((0));
- $ctx1.sendIdx["="]=1;
- self._deny_($4);
- $ctx1.sendIdx["deny:"]=1;
- $10=$recv($globals.Point)._new();
- $ctx1.sendIdx["new"]=3;
- $9=$recv($10)._y_((4));
- $ctx1.sendIdx["y:"]=1;
- $8=$recv($9)._x();
- self._assert_equals_($8,nil);
- self._deny_($recv($recv($recv($recv($globals.Point)._new())._y_((4)))._y()).__eq((0)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNew",{},$globals.PointTest)});
- },
- args: [],
- source: "testNew\x0a\x0a\x09self assert: (Point new x: 3) y equals: nil.\x0a\x09self deny: (Point new x: 3) x = 0.\x0a\x09self assert: (Point new y: 4) x equals: nil.\x0a\x09self deny: (Point new y: 4) y = 0",
- referencedClasses: ["Point"],
- messageSends: ["assert:equals:", "y", "x:", "new", "deny:", "=", "x", "y:"]
- }),
- $globals.PointTest);
- $core.addMethod(
- $core.method({
- selector: "testTranslateBy",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$4,$6,$8,$7,$5,$9,$11,$12,$10,$13,$15,$16,$14;
- $2=(3).__at((3));
- $ctx1.sendIdx["@"]=1;
- $3=(0).__at((1));
- $ctx1.sendIdx["@"]=2;
- $1=$recv($2)._translateBy_($3);
- $ctx1.sendIdx["translateBy:"]=1;
- $4=(3).__at((4));
- $ctx1.sendIdx["@"]=3;
- self._assert_equals_($1,$4);
- $ctx1.sendIdx["assert:equals:"]=1;
- $6=(3).__at((3));
- $ctx1.sendIdx["@"]=4;
- $8=(1)._negated();
- $ctx1.sendIdx["negated"]=1;
- $7=(0).__at($8);
- $ctx1.sendIdx["@"]=5;
- $5=$recv($6)._translateBy_($7);
- $ctx1.sendIdx["translateBy:"]=2;
- $9=(3).__at((2));
- $ctx1.sendIdx["@"]=6;
- self._assert_equals_($5,$9);
- $ctx1.sendIdx["assert:equals:"]=2;
- $11=(3).__at((3));
- $ctx1.sendIdx["@"]=7;
- $12=(2).__at((3));
- $ctx1.sendIdx["@"]=8;
- $10=$recv($11)._translateBy_($12);
- $ctx1.sendIdx["translateBy:"]=3;
- $13=(5).__at((6));
- $ctx1.sendIdx["@"]=9;
- self._assert_equals_($10,$13);
- $ctx1.sendIdx["assert:equals:"]=3;
- $15=(3).__at((3));
- $ctx1.sendIdx["@"]=10;
- $16=$recv((3)._negated()).__at((0));
- $ctx1.sendIdx["@"]=11;
- $14=$recv($15)._translateBy_($16);
- self._assert_equals_($14,(0).__at((3)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTranslateBy",{},$globals.PointTest)});
- },
- args: [],
- source: "testTranslateBy\x0a\x09self assert: (3@3 translateBy: 0@1) equals: 3@4.\x0a\x09self assert: (3@3 translateBy: 0@1 negated) equals: 3@2.\x0a\x09self assert: (3@3 translateBy: 2@3) equals: 5@6.\x0a\x09self assert: (3@3 translateBy: 3 negated @0) equals: 0@3.",
- referencedClasses: [],
- messageSends: ["assert:equals:", "translateBy:", "@", "negated"]
- }),
- $globals.PointTest);
- $core.addClass("QueueTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testNextIfAbsent",
- protocol: "tests",
- fn: function (){
- var self=this;
- var queue;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- queue=$recv($globals.Queue)._new();
- $recv(queue)._nextPut_("index1");
- $2=$recv(queue)._nextIfAbsent_("empty");
- $ctx1.sendIdx["nextIfAbsent:"]=1;
- $1=$recv($2).__eq("index1");
- $ctx1.sendIdx["="]=1;
- self._assert_($1);
- self._deny_($recv($recv(queue)._nextIfAbsent_("empty")).__eq("index1"));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testNextIfAbsent",{queue:queue},$globals.QueueTest)});
- },
- args: [],
- source: "testNextIfAbsent\x0a\x09| queue |\x0a\x09queue := Queue new.\x0a\x09queue nextPut: 'index1'. \x0a\x0a\x09self assert: (queue nextIfAbsent: 'empty') = 'index1'.\x0a\x09self deny: (queue nextIfAbsent: 'empty') = 'index1'",
- referencedClasses: ["Queue"],
- messageSends: ["new", "nextPut:", "assert:", "=", "nextIfAbsent:", "deny:"]
- }),
- $globals.QueueTest);
- $core.addMethod(
- $core.method({
- selector: "testQueueNext",
- protocol: "tests",
- fn: function (){
- var self=this;
- var queue;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$5,$4;
- queue=$recv($globals.Queue)._new();
- $1=queue;
- $recv($1)._nextPut_("index1");
- $ctx1.sendIdx["nextPut:"]=1;
- $recv($1)._nextPut_("index2");
- $3=$recv(queue)._next();
- $ctx1.sendIdx["next"]=1;
- $2=$recv($3).__eq("index1");
- $ctx1.sendIdx["="]=1;
- self._assert_($2);
- $5=$recv(queue)._next();
- $ctx1.sendIdx["next"]=2;
- $4=$recv($5).__eq("index");
- self._deny_($4);
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(queue)._next();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testQueueNext",{queue:queue},$globals.QueueTest)});
- },
- args: [],
- source: "testQueueNext\x0a\x09| queue | \x0a\x09queue := Queue new.\x0a\x09queue \x0a\x09\x09nextPut: 'index1';\x0a\x09\x09nextPut: 'index2'.\x0a\x0a\x09self assert: queue next = 'index1'.\x0a\x09self deny: queue next = 'index'.\x0a\x09self should: [ queue next ] raise: Error",
- referencedClasses: ["Queue", "Error"],
- messageSends: ["new", "nextPut:", "assert:", "=", "next", "deny:", "should:raise:"]
- }),
- $globals.QueueTest);
- $core.addClass("RandomTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testAtRandomNumber",
- protocol: "tests",
- fn: function (){
- var self=this;
- var val;
- return $core.withContext(function($ctx1) {
- (100)._timesRepeat_((function(){
- return $core.withContext(function($ctx2) {
- val=(10)._atRandom();
- val;
- self._assert_($recv(val).__gt((0)));
- $ctx2.sendIdx["assert:"]=1;
- return self._assert_($recv(val).__lt((11)));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtRandomNumber",{val:val},$globals.RandomTest)});
- },
- args: [],
- source: "testAtRandomNumber\x0a\x09|val|\x09\x0a\x0a\x09100 timesRepeat: [\x0a\x09\x09val := 10 atRandom.\x09\x0a\x09\x09self assert: (val > 0).\x0a\x09\x09self assert: (val <11)\x0a\x09]",
- referencedClasses: [],
- messageSends: ["timesRepeat:", "atRandom", "assert:", ">", "<"]
- }),
- $globals.RandomTest);
- $core.addMethod(
- $core.method({
- selector: "testAtRandomSequenceableCollection",
- protocol: "tests",
- fn: function (){
- var self=this;
- var val;
- return $core.withContext(function($ctx1) {
- var $3,$4,$2,$1;
- (100)._timesRepeat_((function(){
- return $core.withContext(function($ctx2) {
- val="abc"._atRandom();
- val;
- $3=$recv(val).__eq("a");
- $ctx2.sendIdx["="]=1;
- $4=$recv(val).__eq("b");
- $ctx2.sendIdx["="]=2;
- $2=$recv($3).__or($4);
- $1=$recv($2).__or($recv(val).__eq("c"));
- $ctx2.sendIdx["|"]=1;
- return self._assert_($1);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtRandomSequenceableCollection",{val:val},$globals.RandomTest)});
- },
- args: [],
- source: "testAtRandomSequenceableCollection\x0a\x09|val|\x0a\x09\x0a\x09100 timesRepeat: [\x0a\x09\x09val := 'abc' atRandom.\x0a\x09\x09self assert: ((val = 'a') | (val = 'b') | (val = 'c' )).\x0a\x09].",
- referencedClasses: [],
- messageSends: ["timesRepeat:", "atRandom", "assert:", "|", "="]
- }),
- $globals.RandomTest);
- $core.addMethod(
- $core.method({
- selector: "textNext",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- (10000)._timesRepeat_((function(){
- var current,next;
- return $core.withContext(function($ctx2) {
- next=$recv($recv($globals.Random)._new())._next();
- next;
- self._assert_($recv(next).__gt_eq((0)));
- $ctx2.sendIdx["assert:"]=1;
- self._assert_($recv(next).__lt((1)));
- $1=$recv(current).__eq(next);
- $ctx2.sendIdx["="]=1;
- self._deny_($1);
- return $recv(next).__eq(current);
- }, function($ctx2) {$ctx2.fillBlock({current:current,next:next},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"textNext",{},$globals.RandomTest)});
- },
- args: [],
- source: "textNext\x0a\x0a\x0910000 timesRepeat: [\x0a\x09\x09\x09| current next |\x0a\x09\x09\x09next := Random new next.\x0a\x09\x09\x09self assert: (next >= 0).\x0a\x09\x09\x09self assert: (next < 1).\x0a\x09\x09\x09self deny: current = next.\x0a\x09\x09\x09next = current ]",
- referencedClasses: ["Random"],
- messageSends: ["timesRepeat:", "next", "new", "assert:", ">=", "<", "deny:", "="]
- }),
- $globals.RandomTest);
- $core.addClass("StreamTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._class())._collectionClass();
- }, function($ctx1) {$ctx1.fill(self,"collectionClass",{},$globals.StreamTest)});
- },
- args: [],
- source: "collectionClass\x0a\x09^ self class collectionClass",
- referencedClasses: [],
- messageSends: ["collectionClass", "class"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "newCollection",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._collectionClass())._new();
- }, function($ctx1) {$ctx1.fill(self,"newCollection",{},$globals.StreamTest)});
- },
- args: [],
- source: "newCollection\x0a\x09^ self collectionClass new",
- referencedClasses: [],
- messageSends: ["new", "collectionClass"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "newStream",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(self._collectionClass())._new())._stream();
- }, function($ctx1) {$ctx1.fill(self,"newStream",{},$globals.StreamTest)});
- },
- args: [],
- source: "newStream\x0a\x09^ self collectionClass new stream",
- referencedClasses: [],
- messageSends: ["stream", "new", "collectionClass"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testAtStartAtEnd",
- protocol: "tests",
- fn: function (){
- var self=this;
- var stream;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- stream=self._newStream();
- $1=$recv(stream)._atStart();
- $ctx1.sendIdx["atStart"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- $2=$recv(stream)._atEnd();
- $ctx1.sendIdx["atEnd"]=1;
- self._assert_($2);
- $ctx1.sendIdx["assert:"]=2;
- $recv(stream)._nextPutAll_(self._newCollection());
- $3=$recv(stream)._atEnd();
- $ctx1.sendIdx["atEnd"]=2;
- self._assert_($3);
- $4=$recv(stream)._atStart();
- $ctx1.sendIdx["atStart"]=2;
- self._deny_($4);
- $ctx1.sendIdx["deny:"]=1;
- $recv(stream)._position_((1));
- self._deny_($recv(stream)._atEnd());
- $ctx1.sendIdx["deny:"]=2;
- self._deny_($recv(stream)._atStart());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAtStartAtEnd",{stream:stream},$globals.StreamTest)});
- },
- args: [],
- source: "testAtStartAtEnd\x0a\x09| stream |\x0a\x09\x0a\x09stream := self newStream.\x0a\x09self assert: stream atStart.\x0a\x09self assert: stream atEnd.\x0a\x09\x0a\x09stream nextPutAll: self newCollection.\x0a\x09self assert: stream atEnd.\x0a\x09self deny: stream atStart.\x0a\x09\x0a\x09stream position: 1.\x0a\x09self deny: stream atEnd.\x0a\x09self deny: stream atStart",
- referencedClasses: [],
- messageSends: ["newStream", "assert:", "atStart", "atEnd", "nextPutAll:", "newCollection", "deny:", "position:"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testContents",
- protocol: "tests",
- fn: function (){
- var self=this;
- var stream;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- stream=self._newStream();
- $1=stream;
- $2=self._newCollection();
- $ctx1.sendIdx["newCollection"]=1;
- $recv($1)._nextPutAll_($2);
- self._assert_equals_($recv(stream)._contents(),self._newCollection());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testContents",{stream:stream},$globals.StreamTest)});
- },
- args: [],
- source: "testContents\x0a\x09| stream |\x0a\x09\x0a\x09stream := self newStream.\x0a\x09stream nextPutAll: self newCollection.\x0a\x09\x0a\x09self assert: stream contents equals: self newCollection",
- referencedClasses: [],
- messageSends: ["newStream", "nextPutAll:", "newCollection", "assert:equals:", "contents"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testIsEmpty",
- protocol: "tests",
- fn: function (){
- var self=this;
- var stream;
- return $core.withContext(function($ctx1) {
- var $1;
- stream=self._newStream();
- $1=$recv(stream)._isEmpty();
- $ctx1.sendIdx["isEmpty"]=1;
- self._assert_($1);
- $recv(stream)._nextPutAll_(self._newCollection());
- self._deny_($recv(stream)._isEmpty());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIsEmpty",{stream:stream},$globals.StreamTest)});
- },
- args: [],
- source: "testIsEmpty\x0a\x09| stream |\x0a\x09\x0a\x09stream := self newStream.\x0a\x09self assert: stream isEmpty.\x0a\x09\x0a\x09stream nextPutAll: self newCollection.\x0a\x09self deny: stream isEmpty",
- referencedClasses: [],
- messageSends: ["newStream", "assert:", "isEmpty", "nextPutAll:", "newCollection", "deny:"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testPosition",
- protocol: "tests",
- fn: function (){
- var self=this;
- var collection,stream;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- collection=self._newCollection();
- stream=self._newStream();
- $recv(stream)._nextPutAll_(collection);
- $1=$recv(stream)._position();
- $ctx1.sendIdx["position"]=1;
- self._assert_equals_($1,$recv(collection)._size());
- $ctx1.sendIdx["assert:equals:"]=1;
- $recv(stream)._position_((0));
- $2=$recv(stream)._position();
- $ctx1.sendIdx["position"]=2;
- self._assert_equals_($2,(0));
- $ctx1.sendIdx["assert:equals:"]=2;
- $recv(stream)._next();
- $ctx1.sendIdx["next"]=1;
- $3=$recv(stream)._position();
- $ctx1.sendIdx["position"]=3;
- self._assert_equals_($3,(1));
- $ctx1.sendIdx["assert:equals:"]=3;
- $recv(stream)._next();
- self._assert_equals_($recv(stream)._position(),(2));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPosition",{collection:collection,stream:stream},$globals.StreamTest)});
- },
- args: [],
- source: "testPosition\x0a\x09| collection stream |\x0a\x09\x0a\x09collection := self newCollection.\x0a\x09stream := self newStream.\x0a\x09\x0a\x09stream nextPutAll: collection.\x0a\x09self assert: stream position equals: collection size.\x0a\x09\x0a\x09stream position: 0.\x0a\x09self assert: stream position equals: 0.\x0a\x09\x0a\x09stream next.\x0a\x09self assert: stream position equals: 1.\x0a\x09\x0a\x09stream next.\x0a\x09self assert: stream position equals: 2",
- referencedClasses: [],
- messageSends: ["newCollection", "newStream", "nextPutAll:", "assert:equals:", "position", "size", "position:", "next"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testReading",
- protocol: "tests",
- fn: function (){
- var self=this;
- var stream,collection;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- collection=self._newCollection();
- stream=self._newStream();
- $1=stream;
- $recv($1)._nextPutAll_(collection);
- $recv($1)._position_((0));
- $recv(collection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- $2=$recv(stream)._next();
- $ctx2.sendIdx["next"]=1;
- return self._assert_equals_($2,each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._assert_($recv($recv(stream)._next())._isNil());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testReading",{stream:stream,collection:collection},$globals.StreamTest)});
- },
- args: [],
- source: "testReading\x0a\x09| stream collection |\x0a\x09\x0a\x09collection := self newCollection.\x0a\x09stream := self newStream.\x0a\x09\x0a\x09stream \x0a\x09\x09nextPutAll: collection;\x0a\x09\x09position: 0.\x0a\x09\x0a\x09collection do: [ :each |\x0a\x09\x09self assert: stream next equals: each ].\x0a\x09\x09\x0a\x09self assert: stream next isNil",
- referencedClasses: [],
- messageSends: ["newCollection", "newStream", "nextPutAll:", "position:", "do:", "assert:equals:", "next", "assert:", "isNil"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testStreamContents",
- protocol: "tests",
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "testStreamContents",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testWrite",
- protocol: "tests",
- fn: function (){
- var self=this;
- var stream,collection;
- return $core.withContext(function($ctx1) {
- collection=self._newCollection();
- stream=self._newStream();
- $recv(collection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(stream).__lt_lt(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- self._assert_equals_($recv(stream)._contents(),collection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testWrite",{stream:stream,collection:collection},$globals.StreamTest)});
- },
- args: [],
- source: "testWrite\x0a\x09| stream collection |\x0a\x09\x0a\x09collection := self newCollection.\x0a\x09stream := self newStream.\x0a\x09\x0a\x09collection do: [ :each | stream << each ].\x0a\x09self assert: stream contents equals: collection",
- referencedClasses: [],
- messageSends: ["newCollection", "newStream", "do:", "<<", "assert:equals:", "contents"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "testWriting",
- protocol: "tests",
- fn: function (){
- var self=this;
- var stream,collection;
- return $core.withContext(function($ctx1) {
- var $1;
- collection=self._newCollection();
- stream=self._newStream();
- $ctx1.sendIdx["newStream"]=1;
- $recv(collection)._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(stream)._nextPut_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $1=$recv(stream)._contents();
- $ctx1.sendIdx["contents"]=1;
- self._assert_equals_($1,collection);
- $ctx1.sendIdx["assert:equals:"]=1;
- stream=self._newStream();
- $recv(stream)._nextPutAll_(collection);
- self._assert_equals_($recv(stream)._contents(),collection);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testWriting",{stream:stream,collection:collection},$globals.StreamTest)});
- },
- args: [],
- source: "testWriting\x0a\x09| stream collection |\x0a\x09\x0a\x09collection := self newCollection.\x0a\x09stream := self newStream.\x0a\x09\x0a\x09collection do: [ :each | stream nextPut: each ].\x0a\x09self assert: stream contents equals: collection.\x0a\x09\x0a\x09stream := self newStream.\x0a\x09stream nextPutAll: collection.\x0a\x09self assert: stream contents equals: collection",
- referencedClasses: [],
- messageSends: ["newCollection", "newStream", "do:", "nextPut:", "assert:equals:", "contents", "nextPutAll:"]
- }),
- $globals.StreamTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return nil;
- },
- args: [],
- source: "collectionClass\x0a\x09^ nil",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StreamTest.klass);
- $core.addMethod(
- $core.method({
- selector: "isAbstract",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._collectionClass())._isNil();
- }, function($ctx1) {$ctx1.fill(self,"isAbstract",{},$globals.StreamTest.klass)});
- },
- args: [],
- source: "isAbstract\x0a\x09^ self collectionClass isNil",
- referencedClasses: [],
- messageSends: ["isNil", "collectionClass"]
- }),
- $globals.StreamTest.klass);
- $core.addClass("ArrayStreamTest", $globals.StreamTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "newCollection",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return [true,(1),(3).__at((4)),"foo"];
- }, function($ctx1) {$ctx1.fill(self,"newCollection",{},$globals.ArrayStreamTest)});
- },
- args: [],
- source: "newCollection\x0a\x09^ { true. 1. 3@4. 'foo' }",
- referencedClasses: [],
- messageSends: ["@"]
- }),
- $globals.ArrayStreamTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.Array;
- },
- args: [],
- source: "collectionClass\x0a\x09^ Array",
- referencedClasses: ["Array"],
- messageSends: []
- }),
- $globals.ArrayStreamTest.klass);
- $core.addClass("StringStreamTest", $globals.StreamTest, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "newCollection",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "hello world";
- },
- args: [],
- source: "newCollection\x0a\x09^ 'hello world'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.StringStreamTest);
- $core.addMethod(
- $core.method({
- selector: "collectionClass",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.String;
- },
- args: [],
- source: "collectionClass\x0a\x09^ String",
- referencedClasses: ["String"],
- messageSends: []
- }),
- $globals.StringStreamTest.klass);
- $core.addClass("UndefinedTest", $globals.TestCase, [], "Kernel-Tests");
- $core.addMethod(
- $core.method({
- selector: "testCopying",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_(nil._copy(),nil);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testCopying",{},$globals.UndefinedTest)});
- },
- args: [],
- source: "testCopying\x0a\x09self assert: nil copy equals: nil",
- referencedClasses: [],
- messageSends: ["assert:equals:", "copy"]
- }),
- $globals.UndefinedTest);
- $core.addMethod(
- $core.method({
- selector: "testDeepCopy",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_($recv(nil._deepCopy()).__eq(nil));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testDeepCopy",{},$globals.UndefinedTest)});
- },
- args: [],
- source: "testDeepCopy\x0a\x09self assert: nil deepCopy = nil",
- referencedClasses: [],
- messageSends: ["assert:", "=", "deepCopy"]
- }),
- $globals.UndefinedTest);
- $core.addMethod(
- $core.method({
- selector: "testIfNil",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2,$4,$6,$5,$receiver;
- if(($receiver = nil) == null || $receiver.isNil){
- $1=true;
- } else {
- $1=nil;
- }
- self._assert_equals_($1,true);
- $ctx1.sendIdx["assert:equals:"]=1;
- if(($receiver = nil) == null || $receiver.isNil){
- $3=nil;
- } else {
- $3=true;
- }
- $2=$recv($3).__eq(true);
- $ctx1.sendIdx["="]=1;
- self._deny_($2);
- $ctx1.sendIdx["deny:"]=1;
- if(($receiver = nil) == null || $receiver.isNil){
- $4=true;
- } else {
- $4=false;
- }
- self._assert_equals_($4,true);
- if(($receiver = nil) == null || $receiver.isNil){
- $6=false;
- } else {
- $6=true;
- }
- $5=$recv($6).__eq(true);
- self._deny_($5);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIfNil",{},$globals.UndefinedTest)});
- },
- args: [],
- source: "testIfNil\x0a\x09self assert: (nil ifNil: [ true ]) equals: true.\x0a\x09self deny: (nil ifNotNil: [ true ]) = true.\x0a\x09self assert: (nil ifNil: [ true ] ifNotNil: [ false ]) equals: true.\x0a\x09self deny: (nil ifNotNil: [ true ] ifNil: [ false ]) = true",
- referencedClasses: [],
- messageSends: ["assert:equals:", "ifNil:", "deny:", "=", "ifNotNil:", "ifNil:ifNotNil:", "ifNotNil:ifNil:"]
- }),
- $globals.UndefinedTest);
- $core.addMethod(
- $core.method({
- selector: "testIsNil",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_(nil._isNil());
- self._deny_(nil._notNil());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIsNil",{},$globals.UndefinedTest)});
- },
- args: [],
- source: "testIsNil\x0a\x09self assert: nil isNil.\x0a\x09self deny: nil notNil.",
- referencedClasses: [],
- messageSends: ["assert:", "isNil", "deny:", "notNil"]
- }),
- $globals.UndefinedTest);
- });
- define('amber_core/Platform-DOM-Tests',["amber/boot", "amber_core/SUnit"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("Platform-DOM-Tests");
- $core.packages["Platform-DOM-Tests"].innerEval = function (expr) { return eval(expr); };
- $core.packages["Platform-DOM-Tests"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("PlatformDomTest", $globals.TestCase, ["fixtureDiv"], "Platform-DOM-Tests");
- $core.addMethod(
- $core.method({
- selector: "testEntityConversion",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.PlatformDom)._isFeasible();
- if($core.assert($1)){
- self._assert_equals_("©"._htmlTextContent(),"©");
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testEntityConversion",{},$globals.PlatformDomTest)});
- },
- args: [],
- source: "testEntityConversion\x0a\x09PlatformDom isFeasible ifTrue: [ self assert: '©' htmlTextContent equals: '©' ]",
- referencedClasses: ["PlatformDom"],
- messageSends: ["ifTrue:", "isFeasible", "assert:equals:", "htmlTextContent"]
- }),
- $globals.PlatformDomTest);
- $core.addMethod(
- $core.method({
- selector: "testTextContentDoesNotRunScript",
- protocol: "testing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($globals.PlatformDom)._isFeasible();
- if($core.assert($1)){
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return "<script>throw new Error(\x22Intentional\x22)</script>"._htmlTextContent();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTextContentDoesNotRunScript",{},$globals.PlatformDomTest)});
- },
- args: [],
- source: "testTextContentDoesNotRunScript\x0a\x09PlatformDom isFeasible ifTrue: [\x0a\x09\x09self shouldnt: [ '<script>throw new Error(\x22Intentional\x22)</script>' htmlTextContent ] raise: Error ]",
- referencedClasses: ["PlatformDom", "Error"],
- messageSends: ["ifTrue:", "isFeasible", "shouldnt:raise:", "htmlTextContent"]
- }),
- $globals.PlatformDomTest);
- });
- define('amber_core/SUnit-Tests',["amber/boot", "amber_core/SUnit"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("SUnit-Tests");
- $core.packages["SUnit-Tests"].innerEval = function (expr) { return eval(expr); };
- $core.packages["SUnit-Tests"].transport = {"type":"amd","amdNamespace":"amber_core"};
- $core.addClass("ExampleSetTest", $globals.TestCase, ["empty", "full"], "SUnit-Tests");
- $globals.ExampleSetTest.comment="ExampleSetTest is taken from Pharo 1.4.\x0a\x0aTHe purpose of this class is to demonstrate a simple use case of the test framework.";
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@empty"]=$recv($globals.Set)._new();
- self["@full"]=$recv($globals.Set)._with_with_((5),"abc");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setUp",{},$globals.ExampleSetTest)});
- },
- args: [],
- source: "setUp\x0a\x09empty := Set new.\x0a\x09full := Set with: 5 with: #abc",
- referencedClasses: ["Set"],
- messageSends: ["new", "with:with:"]
- }),
- $globals.ExampleSetTest);
- $core.addMethod(
- $core.method({
- selector: "testAdd",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@empty"])._add_((5));
- self._assert_($recv(self["@empty"])._includes_((5)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAdd",{},$globals.ExampleSetTest)});
- },
- args: [],
- source: "testAdd\x0a\x09empty add: 5.\x0a\x09self assert: (empty includes: 5)",
- referencedClasses: [],
- messageSends: ["add:", "assert:", "includes:"]
- }),
- $globals.ExampleSetTest);
- $core.addMethod(
- $core.method({
- selector: "testGrow",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@empty"])._addAll_((1)._to_((100)));
- self._assert_equals_($recv(self["@empty"])._size(),(100));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testGrow",{},$globals.ExampleSetTest)});
- },
- args: [],
- source: "testGrow\x0a\x09empty addAll: (1 to: 100).\x0a\x09self assert: empty size equals: 100",
- referencedClasses: [],
- messageSends: ["addAll:", "to:", "assert:equals:", "size"]
- }),
- $globals.ExampleSetTest);
- $core.addMethod(
- $core.method({
- selector: "testIllegal",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@empty"])._at_((5));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- $ctx1.sendIdx["should:raise:"]=1;
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@empty"])._at_put_((5),"abc");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIllegal",{},$globals.ExampleSetTest)});
- },
- args: [],
- source: "testIllegal\x0a\x09self\x0a\x09\x09should: [ empty at: 5 ]\x0a\x09\x09raise: Error.\x0a\x09self\x0a\x09\x09should: [ empty at: 5 put: #abc ]\x0a\x09\x09raise: Error",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "at:", "at:put:"]
- }),
- $globals.ExampleSetTest);
- $core.addMethod(
- $core.method({
- selector: "testIncludes",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self["@full"])._includes_((5));
- $ctx1.sendIdx["includes:"]=1;
- self._assert_($1);
- $ctx1.sendIdx["assert:"]=1;
- self._assert_($recv(self["@full"])._includes_("abc"));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIncludes",{},$globals.ExampleSetTest)});
- },
- args: [],
- source: "testIncludes\x0a\x09self assert: (full includes: 5).\x0a\x09self assert: (full includes: #abc)",
- referencedClasses: [],
- messageSends: ["assert:", "includes:"]
- }),
- $globals.ExampleSetTest);
- $core.addMethod(
- $core.method({
- selector: "testOccurrences",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=$recv(self["@empty"])._occurrencesOf_((0));
- $ctx1.sendIdx["occurrencesOf:"]=1;
- self._assert_equals_($1,(0));
- $ctx1.sendIdx["assert:equals:"]=1;
- $2=$recv(self["@full"])._occurrencesOf_((5));
- $ctx1.sendIdx["occurrencesOf:"]=2;
- self._assert_equals_($2,(1));
- $ctx1.sendIdx["assert:equals:"]=2;
- $recv(self["@full"])._add_((5));
- self._assert_equals_($recv(self["@full"])._occurrencesOf_((5)),(1));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testOccurrences",{},$globals.ExampleSetTest)});
- },
- args: [],
- source: "testOccurrences\x0a\x09self assert: (empty occurrencesOf: 0) equals: 0.\x0a\x09self assert: (full occurrencesOf: 5) equals: 1.\x0a\x09full add: 5.\x0a\x09self assert: (full occurrencesOf: 5) equals: 1",
- referencedClasses: [],
- messageSends: ["assert:equals:", "occurrencesOf:", "add:"]
- }),
- $globals.ExampleSetTest);
- $core.addMethod(
- $core.method({
- selector: "testRemove",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(self["@full"])._remove_((5));
- $1=$recv(self["@full"])._includes_("abc");
- $ctx1.sendIdx["includes:"]=1;
- self._assert_($1);
- self._deny_($recv(self["@full"])._includes_((5)));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testRemove",{},$globals.ExampleSetTest)});
- },
- args: [],
- source: "testRemove\x0a\x09full remove: 5.\x0a\x09self assert: (full includes: #abc).\x0a\x09self deny: (full includes: 5)",
- referencedClasses: [],
- messageSends: ["remove:", "assert:", "includes:", "deny:"]
- }),
- $globals.ExampleSetTest);
- $core.addClass("SUnitAsyncTest", $globals.TestCase, ["flag"], "SUnit-Tests");
- $core.addMethod(
- $core.method({
- selector: "fakeError",
- protocol: "helpers",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@flag"]="bad";
- self._timeout_((30));
- self["@flag"]=$recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- self["@flag"]="ok";
- self["@flag"];
- return self._error_("Intentional");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- })))._valueWithTimeout_((20));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fakeError",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "fakeError\x0a\x09flag := 'bad'.\x0a\x09self timeout: 30.\x0a\x09flag := (self async: [ flag := 'ok'. self error: 'Intentional' ]) valueWithTimeout: 20",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "error:"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "fakeErrorFailingInTearDown",
- protocol: "helpers",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@flag"]="bad";
- self._timeout_((30));
- self["@flag"]=$recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- return self._error_("Intentional");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- })))._valueWithTimeout_((20));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fakeErrorFailingInTearDown",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "fakeErrorFailingInTearDown\x0a\x09flag := 'bad'.\x0a\x09self timeout: 30.\x0a\x09flag := (self async: [ self error: 'Intentional' ]) valueWithTimeout: 20",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "error:"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "fakeFailure",
- protocol: "helpers",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@flag"]="bad";
- self._timeout_((30));
- self["@flag"]=$recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- self["@flag"]="ok";
- self["@flag"];
- return self._assert_(false);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- })))._valueWithTimeout_((20));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fakeFailure",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "fakeFailure\x0a\x09flag := 'bad'.\x0a\x09self timeout: 30.\x0a\x09flag := (self async: [ flag := 'ok'. self assert: false ]) valueWithTimeout: 20",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "assert:"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "fakeMultipleTimeoutFailing",
- protocol: "helpers",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- self._timeout_((100));
- $ctx1.sendIdx["timeout:"]=1;
- $1=self._async_((function(){
- return $core.withContext(function($ctx2) {
- self._timeout_((20));
- return $recv(self._async_((function(){
- return $core.withContext(function($ctx3) {
- return self._finished();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- })))._valueWithTimeout_((30));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["async:"]=1;
- $recv($1)._valueWithTimeout_((20));
- $ctx1.sendIdx["valueWithTimeout:"]=1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fakeMultipleTimeoutFailing",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "fakeMultipleTimeoutFailing\x0a\x09self timeout: 100.\x0a\x09(self async: [ \x0a\x09\x09self timeout: 20.\x0a\x09\x09(self async: [ self finished ]) valueWithTimeout: 30\x0a\x09]) valueWithTimeout: 20",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "finished"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "fakeMultipleTimeoutPassing",
- protocol: "helpers",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- self._timeout_((20));
- $ctx1.sendIdx["timeout:"]=1;
- $1=self._async_((function(){
- return $core.withContext(function($ctx2) {
- self._timeout_((40));
- return $recv(self._async_((function(){
- return $core.withContext(function($ctx3) {
- return self._finished();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- })))._valueWithTimeout_((20));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["async:"]=1;
- $recv($1)._valueWithTimeout_((10));
- $ctx1.sendIdx["valueWithTimeout:"]=1;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fakeMultipleTimeoutPassing",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "fakeMultipleTimeoutPassing\x0a\x09self timeout: 20.\x0a\x09(self async: [\x0a\x09\x09self timeout: 40.\x0a\x09\x09(self async: [ self finished ]) valueWithTimeout: 20\x0a\x09]) valueWithTimeout: 10",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "finished"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "fakeTimeout",
- protocol: "helpers",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._timeout_((10));
- $recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- return self._finished();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- })))._valueWithTimeout_((20));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"fakeTimeout",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "fakeTimeout\x0a\x09self timeout: 10.\x0a\x09(self async: [ self finished ]) valueWithTimeout: 20",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "finished"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "selectorSetOf:",
- protocol: "private",
- fn: function (aCollection){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv(aCollection)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._selector();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- })))._asSet();
- }, function($ctx1) {$ctx1.fill(self,"selectorSetOf:",{aCollection:aCollection},$globals.SUnitAsyncTest)});
- },
- args: ["aCollection"],
- source: "selectorSetOf: aCollection\x0a\x09^ (aCollection collect: [ :each | each selector ]) asSet",
- referencedClasses: [],
- messageSends: ["asSet", "collect:", "selector"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "setUp",
- protocol: "running",
- fn: function (){
- var self=this;
- self["@flag"]="ok";
- return self;
- },
- args: [],
- source: "setUp\x0a\x09flag := 'ok'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "tearDown",
- protocol: "running",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._assert_equals_("ok",self["@flag"]);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"tearDown",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "tearDown\x0a\x09self assert: 'ok' equals: flag",
- referencedClasses: [],
- messageSends: ["assert:equals:"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "testAsyncErrorsAndFailures",
- protocol: "tests",
- fn: function (){
- var self=this;
- var suite,runner,result,assertBlock;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- suite=["fakeError", "fakeErrorFailingInTearDown", "fakeFailure", "testPass"]._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self._class())._selector_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- runner=$recv($globals.TestSuiteRunner)._on_(suite);
- self._timeout_((200));
- result=$recv(runner)._result();
- $ctx1.sendIdx["result"]=1;
- assertBlock=self._async_((function(){
- return $core.withContext(function($ctx2) {
- $1=self._selectorSetOf_($recv(result)._errors());
- $ctx2.sendIdx["selectorSetOf:"]=1;
- $2=["fakeError"]._asSet();
- $ctx2.sendIdx["asSet"]=1;
- self._assert_equals_($1,$2);
- $ctx2.sendIdx["assert:equals:"]=1;
- self._assert_equals_(self._selectorSetOf_($recv(result)._failures()),["fakeErrorFailingInTearDown", "fakeFailure"]._asSet());
- return self._finished();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $recv($recv(runner)._announcer())._on_do_($globals.ResultAnnouncement,(function(ann){
- return $core.withContext(function($ctx2) {
- $3=$recv($recv(ann)._result()).__eq_eq(result);
- if($core.assert($3)){
- $4=$recv($recv(result)._runs()).__eq($recv(result)._total());
- return $recv($4)._ifTrue_(assertBlock);
- }
- }, function($ctx2) {$ctx2.fillBlock({ann:ann},$ctx1,3)});
- }));
- $recv(runner)._run();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsyncErrorsAndFailures",{suite:suite,runner:runner,result:result,assertBlock:assertBlock},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "testAsyncErrorsAndFailures\x0a\x09| suite runner result assertBlock |\x0a\x09suite := #('fakeError' 'fakeErrorFailingInTearDown' 'fakeFailure' 'testPass') collect: [ :each | self class selector: each ].\x0a\x09runner := TestSuiteRunner on: suite.\x0a\x09self timeout: 200.\x0a\x09result := runner result.\x0a\x09assertBlock := self async: [\x0a\x09\x09self assert: (self selectorSetOf: result errors) equals: #('fakeError') asSet.\x0a\x09\x09self assert: (self selectorSetOf: result failures) equals: #('fakeErrorFailingInTearDown' 'fakeFailure') asSet.\x0a\x09\x09self finished\x0a\x09].\x0a\x09runner announcer on: ResultAnnouncement do: [ :ann |\x0a\x09\x09ann result == result ifTrue: [ result runs = result total ifTrue: assertBlock ] ].\x0a\x09runner run",
- referencedClasses: ["TestSuiteRunner", "ResultAnnouncement"],
- messageSends: ["collect:", "selector:", "class", "on:", "timeout:", "result", "async:", "assert:equals:", "selectorSetOf:", "errors", "asSet", "failures", "finished", "on:do:", "announcer", "ifTrue:", "==", "=", "runs", "total", "run"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "testAsyncNeedsTimeout",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return self._async_((function(){
- }));
- $ctx2.sendIdx["async:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- self._timeout_((0));
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return self._async_((function(){
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }),$globals.Error);
- self._finished();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testAsyncNeedsTimeout",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "testAsyncNeedsTimeout\x0a\x09self should: [ self async: [ ] ] raise: Error.\x0a\x09self timeout: 0.\x0a\x09self shouldnt: [ self async: [ ] ] raise: Error.\x0a\x09self finished",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "async:", "timeout:", "shouldnt:raise:", "finished"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "testFinishedNeedsTimeout",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._should_raise_((function(){
- return $core.withContext(function($ctx2) {
- return self._finished();
- $ctx2.sendIdx["finished"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),$globals.Error);
- self._timeout_((0));
- self._shouldnt_raise_((function(){
- return $core.withContext(function($ctx2) {
- return self._finished();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }),$globals.Error);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testFinishedNeedsTimeout",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "testFinishedNeedsTimeout\x0a\x09self should: [ self finished ] raise: Error.\x0a\x09self timeout: 0.\x0a\x09self shouldnt: [ self finished ] raise: Error.",
- referencedClasses: ["Error"],
- messageSends: ["should:raise:", "finished", "timeout:", "shouldnt:raise:"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "testIsAsyncReturnsCorrectValues",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- $1=self._isAsync();
- $ctx1.sendIdx["isAsync"]=1;
- self._deny_($1);
- $ctx1.sendIdx["deny:"]=1;
- self._timeout_((0));
- $2=self._isAsync();
- $ctx1.sendIdx["isAsync"]=2;
- self._assert_($2);
- self._finished();
- self._deny_(self._isAsync());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testIsAsyncReturnsCorrectValues",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "testIsAsyncReturnsCorrectValues\x0a\x09self deny: self isAsync.\x0a\x09self timeout: 0.\x0a\x09self assert: self isAsync.\x0a\x09self finished.\x0a\x09self deny: self isAsync",
- referencedClasses: [],
- messageSends: ["deny:", "isAsync", "timeout:", "assert:", "finished"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "testPass",
- protocol: "tests",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@flag"]="bad";
- self._timeout_((10));
- self["@flag"]=$recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- self._assert_(true);
- self._finished();
- self["@flag"]="ok";
- return self["@flag"];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- })))._valueWithTimeout_((5));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testPass",{},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "testPass\x0a\x09flag := 'bad'.\x0a\x09self timeout: 10.\x0a\x09flag := (self async: [ self assert: true. self finished. flag := 'ok' ]) valueWithTimeout: 5",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "assert:", "finished"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "testTimeouts",
- protocol: "tests",
- fn: function (){
- var self=this;
- var suite,runner,result,assertBlock;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3;
- suite=["fakeTimeout", "fakeMultipleTimeoutFailing", "fakeMultipleTimeoutPassing", "testPass"]._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(self._class())._selector_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- runner=$recv($globals.TestSuiteRunner)._on_(suite);
- self._timeout_((200));
- result=$recv(runner)._result();
- $ctx1.sendIdx["result"]=1;
- assertBlock=self._async_((function(){
- return $core.withContext(function($ctx2) {
- $1=self._selectorSetOf_($recv(result)._errors());
- $ctx2.sendIdx["selectorSetOf:"]=1;
- self._assert_equals_($1,$recv($globals.Set)._new());
- $ctx2.sendIdx["assert:equals:"]=1;
- self._assert_equals_(self._selectorSetOf_($recv(result)._failures()),["fakeMultipleTimeoutFailing", "fakeTimeout"]._asSet());
- return self._finished();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- $recv($recv(runner)._announcer())._on_do_($globals.ResultAnnouncement,(function(ann){
- return $core.withContext(function($ctx2) {
- $2=$recv($recv(ann)._result()).__eq_eq(result);
- if($core.assert($2)){
- $3=$recv($recv(result)._runs()).__eq($recv(result)._total());
- return $recv($3)._ifTrue_(assertBlock);
- }
- }, function($ctx2) {$ctx2.fillBlock({ann:ann},$ctx1,3)});
- }));
- $recv(runner)._run();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTimeouts",{suite:suite,runner:runner,result:result,assertBlock:assertBlock},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "testTimeouts\x0a\x09| suite runner result assertBlock |\x0a\x09suite := #('fakeTimeout' 'fakeMultipleTimeoutFailing' 'fakeMultipleTimeoutPassing' 'testPass') collect: [ :each | self class selector: each ].\x0a\x09runner := TestSuiteRunner on: suite.\x0a\x09self timeout: 200.\x0a\x09result := runner result.\x0a\x09assertBlock := self async: [\x0a\x09\x09self assert: (self selectorSetOf: result errors) equals: Set new.\x0a\x09\x09self assert: (self selectorSetOf: result failures) equals: #('fakeMultipleTimeoutFailing' 'fakeTimeout') asSet.\x0a\x09\x09self finished\x0a\x09].\x0a\x09runner announcer on: ResultAnnouncement do: [ :ann |\x0a\x09\x09ann result == result ifTrue: [ result runs = result total ifTrue: assertBlock ] ].\x0a\x09runner run",
- referencedClasses: ["TestSuiteRunner", "Set", "ResultAnnouncement"],
- messageSends: ["collect:", "selector:", "class", "on:", "timeout:", "result", "async:", "assert:equals:", "selectorSetOf:", "errors", "new", "failures", "asSet", "finished", "on:do:", "announcer", "ifTrue:", "==", "=", "runs", "total", "run"]
- }),
- $globals.SUnitAsyncTest);
- $core.addMethod(
- $core.method({
- selector: "testTwoAsyncPassesWithFinishedOnlyOneIsRun",
- protocol: "tests",
- fn: function (){
- var self=this;
- var x;
- return $core.withContext(function($ctx1) {
- var $1;
- self["@flag"]="bad";
- self._timeout_((10));
- x=(0);
- $1=self._async_((function(){
- return $core.withContext(function($ctx2) {
- self._finished();
- $ctx2.sendIdx["finished"]=1;
- self["@flag"]="ok";
- self["@flag"];
- x=$recv(x).__plus((1));
- $ctx2.sendIdx["+"]=1;
- x;
- return self._assert_equals_(x,(1));
- $ctx2.sendIdx["assert:equals:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["async:"]=1;
- self["@flag"]=$recv($1)._valueWithTimeout_((0));
- $ctx1.sendIdx["valueWithTimeout:"]=1;
- self["@flag"]=$recv(self._async_((function(){
- return $core.withContext(function($ctx2) {
- self._finished();
- self["@flag"]="ok";
- self["@flag"];
- x=$recv(x).__plus((1));
- x;
- return self._assert_equals_(x,(1));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- })))._valueWithTimeout_((0));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"testTwoAsyncPassesWithFinishedOnlyOneIsRun",{x:x},$globals.SUnitAsyncTest)});
- },
- args: [],
- source: "testTwoAsyncPassesWithFinishedOnlyOneIsRun\x0a\x09| x |\x0a\x09flag := 'bad'.\x0a\x09self timeout: 10.\x0a\x09x := 0.\x0a\x09flag := (self async: [ self finished. flag := 'ok'. x := x+1. self assert: x equals: 1 ]) valueWithTimeout: 0.\x0a\x09flag := (self async: [ self finished. flag := 'ok'. x := x+1. self assert: x equals: 1 ]) valueWithTimeout: 0.",
- referencedClasses: [],
- messageSends: ["timeout:", "valueWithTimeout:", "async:", "finished", "+", "assert:equals:"]
- }),
- $globals.SUnitAsyncTest);
- });
- define('amber/devel',[
- './lang',
- './compatibility', // pre-fetch, dep of ./boot
- './kernel-fundamentals', // pre-fetch, dep of ./boot
- './kernel-language', // pre-fetch, dep of ./boot
- './boot', // pre-fetch, dep of ./helpers
- './helpers', // pre-fetch, dep of ./deploy
- './deploy', // pre-fetch, dep of ./lang
- // --- packages of the development only Amber begin here ---
- 'amber_core/Platform-DOM',
- 'amber_core/SUnit',
- 'amber_core/Compiler-Tests',
- 'amber_core/Kernel-Tests',
- 'amber_core/Platform-DOM-Tests',
- 'amber_core/SUnit-Tests'
- // --- packages of the development only Amber end here ---
- ], function (amber) {
- return amber;
- });
- define('amber_cli/AmberCli',["amber/boot", "amber_core/Kernel-Objects"], function($boot){"use strict";
- if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
- var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
- if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
- $core.addPackage("AmberCli");
- $core.packages["AmberCli"].innerEval = function (expr) { return eval(expr); };
- $core.packages["AmberCli"].transport = {"type":"amd","amdNamespace":"amber_cli"};
- $core.addClass("AmberCli", $globals.Object, [], "AmberCli");
- $globals.AmberCli.comment="I am the Amber CLI (CommandLine Interface) tool which runs on Node.js.\x0a\x0aMy responsibility is to start different Amber programs like the FileServer or the Repl.\x0aWhich program to start is determined by the first commandline parameters passed to the AmberCli executable.\x0aUse `help` to get a list of all available options.\x0aAny further commandline parameters are passed to the specific program.\x0a\x0a## Commands\x0a\x0aNew commands can be added by creating a class side method in the `commands` protocol which takes one parameter.\x0aThis parameter is an array of all commandline options + values passed on to the program.\x0aAny `camelCaseCommand` is transformed into a commandline parameter of the form `camel-case-command` and vice versa.";
- $core.addMethod(
- $core.method({
- selector: "commandLineSwitches",
- protocol: "commandline",
- fn: function (){
- var self=this;
- var switches;
- return $core.withContext(function($ctx1) {
- switches=$recv($recv(self._class())._methodsInProtocol_("commands"))._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._selector();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["collect:"]=1;
- switches=$recv(switches)._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._match_("^[^:]*:$");
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- switches=$recv(switches)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv($recv(each)._allButLast())._replace_with_("([A-Z])","-$1"))._asLowercase();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- return switches;
- }, function($ctx1) {$ctx1.fill(self,"commandLineSwitches",{switches:switches},$globals.AmberCli.klass)});
- },
- args: [],
- source: "commandLineSwitches\x0a\x09\x22Collect all methodnames from the 'commands' protocol of the class\x0a\x09 and select the ones with only one parameter.\x0a\x09 Then remove the ':' at the end of the name.\x0a\x09 Additionally all uppercase letters are made lowercase and preceded by a '-'.\x0a\x09 Example: fallbackPage: becomes --fallback-page.\x0a\x09 Return the Array containing the commandline switches.\x22\x0a\x09| switches |\x0a\x09switches := ((self class methodsInProtocol: 'commands') collect: [ :each | each selector]).\x0a\x09switches := switches select: [ :each | each match: '^[^:]*:$'].\x0a\x09switches :=switches collect: [ :each |\x0a\x09\x09(each allButLast replace: '([A-Z])' with: '-$1') asLowercase].\x0a\x09^ switches",
- referencedClasses: [],
- messageSends: ["collect:", "methodsInProtocol:", "class", "selector", "select:", "match:", "asLowercase", "replace:with:", "allButLast"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "config:",
- protocol: "commands",
- fn: function (args){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.Configurator)._new())._start();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"config:",{args:args},$globals.AmberCli.klass)});
- },
- args: ["args"],
- source: "config: args\x0a\x09Configurator new start",
- referencedClasses: ["Configurator"],
- messageSends: ["start", "new"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "handleArguments:",
- protocol: "commandline",
- fn: function (args){
- var self=this;
- var selector;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(args)._first();
- $ctx1.sendIdx["first"]=1;
- selector=self._selectorForCommandLineSwitch_($1);
- $recv(args)._remove_($recv(args)._first());
- self._perform_withArguments_(selector,$recv($globals.Array)._with_(args));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"handleArguments:",{args:args,selector:selector},$globals.AmberCli.klass)});
- },
- args: ["args"],
- source: "handleArguments: args\x0a\x09| selector |\x0a\x0a\x09selector := self selectorForCommandLineSwitch: (args first).\x0a\x09args remove: args first.\x0a\x09self perform: selector withArguments: (Array with: args)",
- referencedClasses: ["Array"],
- messageSends: ["selectorForCommandLineSwitch:", "first", "remove:", "perform:withArguments:", "with:"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "help:",
- protocol: "commands",
- fn: function (args){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Transcript)._show_("Available commands");
- $recv(self._commandLineSwitches())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(console)._log_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"help:",{args:args},$globals.AmberCli.klass)});
- },
- args: ["args"],
- source: "help: args\x0a\x09Transcript show: 'Available commands'.\x0a\x09self commandLineSwitches do: [ :each | console log: each ]",
- referencedClasses: ["Transcript"],
- messageSends: ["show:", "do:", "commandLineSwitches", "log:"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "init:",
- protocol: "commands",
- fn: function (args){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($globals.Initer)._new())._start();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"init:",{args:args},$globals.AmberCli.klass)});
- },
- args: ["args"],
- source: "init: args\x0a\x09Initer new start",
- referencedClasses: ["Initer"],
- messageSends: ["start", "new"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "main",
- protocol: "startup",
- fn: function (){
- var self=this;
- var args,packageJSON;
- return $core.withContext(function($ctx1) {
- var $7,$6,$5,$4,$3,$2,$1;
- var $early={};
- try {
- packageJSON=$recv(require)._value_("../package.json");
- $7=$recv(packageJSON)._version();
- $ctx1.sendIdx["version"]=1;
- $6="Welcome to Amber CLI version ".__comma($7);
- $5=$recv($6).__comma(" (Amber ");
- $ctx1.sendIdx[","]=5;
- $4=$recv($5).__comma($recv($globals.Smalltalk)._version());
- $ctx1.sendIdx[","]=4;
- $3=$recv($4).__comma(", NodeJS ");
- $ctx1.sendIdx[","]=3;
- $2=$recv($3).__comma($recv($recv(process)._versions())._node());
- $ctx1.sendIdx[","]=2;
- $1=$recv($2).__comma(").");
- $ctx1.sendIdx[","]=1;
- $recv($globals.Transcript)._show_($1);
- args=$recv(process)._argv();
- $recv(args)._removeFrom_to_((1),(2));
- $recv(args)._ifEmpty_ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return self._help_(nil);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- throw $early=[self._handleArguments_(args)];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- return self;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"main",{args:args,packageJSON:packageJSON},$globals.AmberCli.klass)});
- },
- args: [],
- source: "main\x0a\x09\x22Main entry point for Amber applications.\x0a\x09Parses commandline arguments and starts the according subprogram.\x22\x0a\x09| args packageJSON |\x0a\x09\x0a\x09packageJSON := require value: '../package.json'.\x0a\x09Transcript show: 'Welcome to Amber CLI version ', packageJSON version, ' (Amber ', Smalltalk version, ', NodeJS ', process versions node, ').'.\x0a\x0a\x09args := process argv.\x0a\x09\x22Remove the first args which contain the path to the node executable and the script file.\x22\x0a\x09args removeFrom: 1 to: 2.\x0a\x09\x0a\x09args\x0a\x09\x09ifEmpty: [self help: nil]\x0a\x09\x09ifNotEmpty: [^self handleArguments: args]",
- referencedClasses: ["Transcript", "Smalltalk"],
- messageSends: ["value:", "show:", ",", "version", "node", "versions", "argv", "removeFrom:to:", "ifEmpty:ifNotEmpty:", "help:", "handleArguments:"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "repl:",
- protocol: "commands",
- fn: function (args){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.Repl)._new())._createInterface();
- }, function($ctx1) {$ctx1.fill(self,"repl:",{args:args},$globals.AmberCli.klass)});
- },
- args: ["args"],
- source: "repl: args\x0a\x09^ Repl new createInterface",
- referencedClasses: ["Repl"],
- messageSends: ["createInterface", "new"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "selectorForCommandLineSwitch:",
- protocol: "commandline",
- fn: function (aSwitch){
- var self=this;
- var command,selector;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self._commandLineSwitches())._includes_(aSwitch);
- if($core.assert($1)){
- selector=$recv($recv(aSwitch)._replace_with_("-[a-z]",(function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._second())._asUppercase();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }))).__comma(":");
- selector;
- } else {
- selector="help:";
- selector;
- }
- return selector;
- }, function($ctx1) {$ctx1.fill(self,"selectorForCommandLineSwitch:",{aSwitch:aSwitch,command:command,selector:selector},$globals.AmberCli.klass)});
- },
- args: ["aSwitch"],
- source: "selectorForCommandLineSwitch: aSwitch\x0a\x09\x22Add ':' at the end and replace all occurences of a lowercase letter preceded by a '-' with the Uppercase letter.\x0a\x09 Example: fallback-page becomes fallbackPage:.\x0a\x09 If no correct selector is found return 'help:'\x22\x0a\x09 | command selector |\x0a\x0a\x09 (self commandLineSwitches includes: aSwitch)\x0a\x09 ifTrue: [ selector := (aSwitch replace: '-[a-z]' with: [ :each | each second asUppercase ]), ':']\x0a\x09 ifFalse: [ selector := 'help:' ].\x0a\x09^ selector",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "includes:", "commandLineSwitches", ",", "replace:with:", "asUppercase", "second"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "serve:",
- protocol: "commands",
- fn: function (args){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.FileServer)._createServerWithArguments_(args))._start();
- }, function($ctx1) {$ctx1.fill(self,"serve:",{args:args},$globals.AmberCli.klass)});
- },
- args: ["args"],
- source: "serve: args\x0a\x09^ (FileServer createServerWithArguments: args) start",
- referencedClasses: ["FileServer"],
- messageSends: ["start", "createServerWithArguments:"]
- }),
- $globals.AmberCli.klass);
- $core.addMethod(
- $core.method({
- selector: "version:",
- protocol: "commands",
- fn: function (arguments_){
- var self=this;
- return self;
- },
- args: ["arguments"],
- source: "version: arguments",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.AmberCli.klass);
- $core.addClass("BaseFileManipulator", $globals.Object, ["path", "fs"], "AmberCli");
- $core.addMethod(
- $core.method({
- selector: "dirname",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return __dirname;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"dirname",{},$globals.BaseFileManipulator)});
- },
- args: [],
- source: "dirname\x0a\x09<inlineJS: 'return __dirname'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.BaseFileManipulator);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.BaseFileManipulator.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@path"]=$recv(require)._value_("path");
- $ctx1.sendIdx["value:"]=1;
- self["@fs"]=$recv(require)._value_("fs");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.BaseFileManipulator)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09path := require value: 'path'.\x0a\x09fs := require value: 'fs'",
- referencedClasses: [],
- messageSends: ["initialize", "value:"]
- }),
- $globals.BaseFileManipulator);
- $core.addMethod(
- $core.method({
- selector: "rootDirname",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@path"])._join_with_(self._dirname(),"..");
- }, function($ctx1) {$ctx1.fill(self,"rootDirname",{},$globals.BaseFileManipulator)});
- },
- args: [],
- source: "rootDirname\x0a\x09^ path join: self dirname with: '..'",
- referencedClasses: [],
- messageSends: ["join:with:", "dirname"]
- }),
- $globals.BaseFileManipulator);
- $core.addClass("Configurator", $globals.BaseFileManipulator, [], "AmberCli");
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Configurator.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Configurator)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize",
- referencedClasses: [],
- messageSends: ["initialize"]
- }),
- $globals.Configurator);
- $core.addMethod(
- $core.method({
- selector: "start",
- protocol: "action",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $receiver;
- self._writeConfigThenDo_((function(err){
- return $core.withContext(function($ctx2) {
- if(($receiver = err) == null || $receiver.isNil){
- return $recv(process)._exit();
- } else {
- return $recv(process)._exit_((111));
- }
- }, function($ctx2) {$ctx2.fillBlock({err:err},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"start",{},$globals.Configurator)});
- },
- args: [],
- source: "start\x0a\x09self writeConfigThenDo: [ :err | err\x0a\x09\x09ifNotNil: [ process exit: 111 ]\x0a\x09\x09ifNil: [ process exit ]]",
- referencedClasses: [],
- messageSends: ["writeConfigThenDo:", "ifNotNil:ifNil:", "exit:", "exit"]
- }),
- $globals.Configurator);
- $core.addMethod(
- $core.method({
- selector: "writeConfigThenDo:",
- protocol: "action",
- fn: function (aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv($recv(require)._value_("amber-dev"))._configBuilder())._writeConfig_toFile_thenDo_($recv(process)._cwd(),"config.js",aBlock);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"writeConfigThenDo:",{aBlock:aBlock},$globals.Configurator)});
- },
- args: ["aBlock"],
- source: "writeConfigThenDo: aBlock\x0a\x09(require value: 'amber-dev') configBuilder\x0a\x09\x09writeConfig: process cwd\x0a\x09\x09toFile: 'config.js'\x0a\x09\x09thenDo: aBlock",
- referencedClasses: [],
- messageSends: ["writeConfig:toFile:thenDo:", "configBuilder", "value:", "cwd"]
- }),
- $globals.Configurator);
- $core.addClass("FileServer", $globals.BaseFileManipulator, ["http", "url", "host", "port", "basePath", "util", "username", "password", "fallbackPage"], "AmberCli");
- $globals.FileServer.comment="I am the Amber Smalltalk FileServer.\x0aMy runtime requirement is a functional Node.js executable.\x0a\x0aTo start a FileServer instance on port `4000` use the following code:\x0a\x0a FileServer new start\x0a\x0aA parameterized instance can be created with the following code:\x0a\x0a FileServer createServerWithArguments: options\x0a\x0aHere, `options` is an array of commandline style strings each followed by a value e.g. `#('--port', '6000', '--host', '0.0.0.0')`.\x0aA list of all available parameters can be printed to the commandline by passing `--help` as parameter.\x0aSee the `Options` section for further details on how options are mapped to instance methods.\x0a\x0aAfter startup FileServer checks if the directory layout required by Amber is present and logs a warning on absence.\x0a\x0a\x0a## Options\x0a\x0aEach option is of the form `--some-option-string` which is transformed into a selector of the format `someOptionString:`.\x0aThe trailing `--` gets removed, each `-[a-z]` gets transformed into the according uppercase letter, and a `:` is appended to create a selector which takes a single argument.\x0aAfterwards, the selector gets executed on the `FileServer` instance with the value following in the options array as parameter.\x0a\x0a## Adding new commandline parameters\x0a\x0aAdding new commandline parameters to `FileServer` is as easy as adding a new single parameter method to the `accessing` protocol.";
- $core.addMethod(
- $core.method({
- selector: "base64Decode:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return (new Buffer(aString, "base64").toString());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"base64Decode:",{aString:aString},$globals.FileServer)});
- },
- args: ["aString"],
- source: "base64Decode: aString\x0a\x09<inlineJS: 'return (new Buffer(aString, \x22base64\x22).toString())'>",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "basePath",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@basePath"];
- if(($receiver = $1) == null || $receiver.isNil){
- return $recv(self._class())._defaultBasePath();
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"basePath",{},$globals.FileServer)});
- },
- args: [],
- source: "basePath\x0a\x09^ basePath ifNil: [self class defaultBasePath]",
- referencedClasses: [],
- messageSends: ["ifNil:", "defaultBasePath", "class"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "basePath:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@basePath"]=aString;
- self._validateBasePath();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"basePath:",{aString:aString},$globals.FileServer)});
- },
- args: ["aString"],
- source: "basePath: aString\x0a\x09basePath := aString.\x0a\x09self validateBasePath.",
- referencedClasses: [],
- messageSends: ["validateBasePath"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "checkDirectoryLayout",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv(self["@fs"])._existsSync_(self._withBasePath_("index.html"));
- if(!$core.assert($1)){
- $recv(console)._warn_("Warning: project directory does not contain index.html.");
- $ctx1.sendIdx["warn:"]=1;
- $recv(console)._warn_(" You can specify the directory containing index.html with --base-path.");
- $ctx1.sendIdx["warn:"]=2;
- $recv(console)._warn_(" You can also specify a page to be served by default,");
- $ctx1.sendIdx["warn:"]=3;
- $recv(console)._warn_(" for all paths that do not map to a file, with --fallback-page.");
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"checkDirectoryLayout",{},$globals.FileServer)});
- },
- args: [],
- source: "checkDirectoryLayout\x0a\x09(fs existsSync:\x09(self withBasePath: 'index.html')) ifFalse: [\x0a\x09\x09console warn: 'Warning: project directory does not contain index.html.'.\x0a\x09\x09console warn: ' You can specify the directory containing index.html with --base-path.'.\x0a\x09\x09console warn: ' You can also specify a page to be served by default,'.\x0a\x09\x09console warn: ' for all paths that do not map to a file, with --fallback-page.'].",
- referencedClasses: [],
- messageSends: ["ifFalse:", "existsSync:", "withBasePath:", "warn:"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "fallbackPage",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@fallbackPage"];
- },
- args: [],
- source: "fallbackPage\x0a\x09^ fallbackPage",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "fallbackPage:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- self["@fallbackPage"]=aString;
- return self;
- },
- args: ["aString"],
- source: "fallbackPage: aString\x0a\x09fallbackPage := aString",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "handleGETRequest:respondTo:",
- protocol: "request handling",
- fn: function (aRequest,aResponse){
- var self=this;
- var uri,filename;
- return $core.withContext(function($ctx1) {
- var $1;
- uri=$recv(self["@url"])._parse_($recv(aRequest)._url());
- filename=$recv(self["@path"])._join_with_(self._basePath(),$recv(uri)._pathname());
- $recv(self["@fs"])._exists_do_(filename,(function(aBoolean){
- return $core.withContext(function($ctx2) {
- if($core.assert(aBoolean)){
- $1=$recv($recv(self["@fs"])._statSync_(filename))._isDirectory();
- if($core.assert($1)){
- return self._respondDirectoryNamed_from_to_(filename,uri,aResponse);
- } else {
- return self._respondFileNamed_to_(filename,aResponse);
- }
- } else {
- return self._respondNotFoundTo_(aResponse);
- }
- }, function($ctx2) {$ctx2.fillBlock({aBoolean:aBoolean},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"handleGETRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse,uri:uri,filename:filename},$globals.FileServer)});
- },
- args: ["aRequest", "aResponse"],
- source: "handleGETRequest: aRequest respondTo: aResponse\x0a\x09| uri filename |\x0a\x09uri := url parse: aRequest url.\x0a\x09filename := path join: self basePath with: uri pathname.\x0a\x09fs exists: filename do: [:aBoolean |\x0a\x09\x09aBoolean\x0a\x09\x09\x09ifFalse: [self respondNotFoundTo: aResponse]\x0a\x09\x09\x09ifTrue: [(fs statSync: filename) isDirectory\x0a\x09\x09\x09\x09ifTrue: [self respondDirectoryNamed: filename from: uri to: aResponse]\x0a\x09\x09\x09\x09ifFalse: [self respondFileNamed: filename to: aResponse]]]",
- referencedClasses: [],
- messageSends: ["parse:", "url", "join:with:", "basePath", "pathname", "exists:do:", "ifFalse:ifTrue:", "respondNotFoundTo:", "ifTrue:ifFalse:", "isDirectory", "statSync:", "respondDirectoryNamed:from:to:", "respondFileNamed:to:"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "handleOPTIONSRequest:respondTo:",
- protocol: "request handling",
- fn: function (aRequest,aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aResponse)._writeHead_options_((200),$globals.HashedCollection._newFromPairs_(["Access-Control-Allow-Origin","*","Access-Control-Allow-Methods","GET, PUT, POST, DELETE, OPTIONS","Access-Control-Allow-Headers","Content-Type, Accept","Content-Length",(0),"Access-Control-Max-Age",(10)]));
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"handleOPTIONSRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aRequest", "aResponse"],
- source: "handleOPTIONSRequest: aRequest respondTo: aResponse\x0a\x09aResponse writeHead: 200 options: #{'Access-Control-Allow-Origin' -> '*'.\x0a\x09\x09\x09\x09\x09'Access-Control-Allow-Methods' -> 'GET, PUT, POST, DELETE, OPTIONS'.\x0a\x09\x09\x09\x09\x09'Access-Control-Allow-Headers' -> 'Content-Type, Accept'.\x0a\x09\x09\x09\x09\x09'Content-Length' -> 0.\x0a\x09\x09\x09\x09\x09'Access-Control-Max-Age' -> 10}.\x0a\x09aResponse end",
- referencedClasses: [],
- messageSends: ["writeHead:options:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "handlePUTRequest:respondTo:",
- protocol: "request handling",
- fn: function (aRequest,aResponse){
- var self=this;
- var file,stream;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- $1=self._isAuthenticated_(aRequest);
- if(!$core.assert($1)){
- self._respondAuthenticationRequiredTo_(aResponse);
- return nil;
- }
- file=".".__comma($recv(aRequest)._url());
- $ctx1.sendIdx[","]=1;
- stream=$recv(self["@fs"])._createWriteStream_(file);
- $recv(stream)._on_do_("error",(function(error){
- return $core.withContext(function($ctx2) {
- $2=console;
- $3="Error creating WriteStream for file ".__comma(file);
- $ctx2.sendIdx[","]=2;
- $recv($2)._warn_($3);
- $ctx2.sendIdx["warn:"]=1;
- $recv(console)._warn_(" Did you forget to create the necessary directory in your project (often /src)?");
- $ctx2.sendIdx["warn:"]=2;
- $recv(console)._warn_(" The exact error is: ".__comma(error));
- return self._respondNotCreatedTo_(aResponse);
- }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1,2)});
- }));
- $ctx1.sendIdx["on:do:"]=1;
- $recv(stream)._on_do_("close",(function(){
- return $core.withContext(function($ctx2) {
- return self._respondCreatedTo_(aResponse);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- $ctx1.sendIdx["on:do:"]=2;
- $recv(aRequest)._setEncoding_("utf8");
- $recv(aRequest)._on_do_("data",(function(data){
- return $core.withContext(function($ctx2) {
- return $recv(stream)._write_(data);
- }, function($ctx2) {$ctx2.fillBlock({data:data},$ctx1,4)});
- }));
- $ctx1.sendIdx["on:do:"]=3;
- $recv(aRequest)._on_do_("end",(function(){
- return $core.withContext(function($ctx2) {
- $4=$recv(stream)._writable();
- if($core.assert($4)){
- return $recv(stream)._end();
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,5)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"handlePUTRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse,file:file,stream:stream},$globals.FileServer)});
- },
- args: ["aRequest", "aResponse"],
- source: "handlePUTRequest: aRequest respondTo: aResponse\x0a\x09| file stream |\x0a\x09(self isAuthenticated: aRequest)\x0a\x09\x09ifFalse: [self respondAuthenticationRequiredTo: aResponse. ^ nil].\x0a\x0a\x09file := '.', aRequest url.\x0a\x09stream := fs createWriteStream: file.\x0a\x0a\x09stream on: 'error' do: [:error |\x0a\x09\x09console warn: 'Error creating WriteStream for file ', file.\x0a\x09\x09console warn: ' Did you forget to create the necessary directory in your project (often /src)?'.\x0a\x09\x09console warn: ' The exact error is: ', error.\x0a\x09\x09self respondNotCreatedTo: aResponse].\x0a\x0a\x09stream on: 'close' do: [\x0a\x09\x09self respondCreatedTo: aResponse].\x0a\x0a\x09aRequest setEncoding: 'utf8'.\x0a\x09aRequest on: 'data' do: [:data |\x0a\x09\x09stream write: data].\x0a\x0a\x09aRequest on: 'end' do: [\x0a\x09\x09stream writable ifTrue: [stream end]]",
- referencedClasses: [],
- messageSends: ["ifFalse:", "isAuthenticated:", "respondAuthenticationRequiredTo:", ",", "url", "createWriteStream:", "on:do:", "warn:", "respondNotCreatedTo:", "respondCreatedTo:", "setEncoding:", "write:", "ifTrue:", "writable", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "handleRequest:respondTo:",
- protocol: "request handling",
- fn: function (aRequest,aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5;
- $2=$recv(aRequest)._method();
- $ctx1.sendIdx["method"]=1;
- $1=$recv($2).__eq("PUT");
- $ctx1.sendIdx["="]=1;
- if($core.assert($1)){
- self._handlePUTRequest_respondTo_(aRequest,aResponse);
- }
- $4=$recv(aRequest)._method();
- $ctx1.sendIdx["method"]=2;
- $3=$recv($4).__eq("GET");
- $ctx1.sendIdx["="]=2;
- if($core.assert($3)){
- self._handleGETRequest_respondTo_(aRequest,aResponse);
- }
- $5=$recv($recv(aRequest)._method()).__eq("OPTIONS");
- if($core.assert($5)){
- self._handleOPTIONSRequest_respondTo_(aRequest,aResponse);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"handleRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aRequest", "aResponse"],
- source: "handleRequest: aRequest respondTo: aResponse\x0a\x09aRequest method = 'PUT'\x0a\x09\x09ifTrue: [self handlePUTRequest: aRequest respondTo: aResponse].\x0a\x09aRequest method = 'GET'\x0a\x09\x09ifTrue:[self handleGETRequest: aRequest respondTo: aResponse].\x0a\x09aRequest method = 'OPTIONS'\x0a\x09\x09ifTrue:[self handleOPTIONSRequest: aRequest respondTo: aResponse]",
- referencedClasses: [],
- messageSends: ["ifTrue:", "=", "method", "handlePUTRequest:respondTo:", "handleGETRequest:respondTo:", "handleOPTIONSRequest:respondTo:"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "host",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@host"];
- },
- args: [],
- source: "host\x0a\x09^ host",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "host:",
- protocol: "accessing",
- fn: function (hostname){
- var self=this;
- self["@host"]=hostname;
- return self;
- },
- args: ["hostname"],
- source: "host: hostname\x0a\x09host := hostname",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- (
- $ctx1.supercall = true,
- ($globals.FileServer.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@http"]=self._require_("http");
- $ctx1.sendIdx["require:"]=1;
- self["@util"]=self._require_("util");
- $ctx1.sendIdx["require:"]=2;
- self["@url"]=self._require_("url");
- $1=self._class();
- $ctx1.sendIdx["class"]=1;
- self["@host"]=$recv($1)._defaultHost();
- self["@port"]=$recv(self._class())._defaultPort();
- self["@username"]=nil;
- self["@password"]=nil;
- self["@fallbackPage"]=nil;
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.FileServer)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09http := self require: 'http'.\x0a\x09util := self require: 'util'.\x0a\x09url := self require: 'url'.\x0a\x09host := self class defaultHost.\x0a\x09port := self class defaultPort.\x0a\x09username := nil.\x0a\x09password := nil.\x0a\x09fallbackPage := nil.",
- referencedClasses: [],
- messageSends: ["initialize", "require:", "defaultHost", "class", "defaultPort"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "isAuthenticated:",
- protocol: "private",
- fn: function (aRequest){
- var self=this;
- var header,token,auth,parts;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$4,$5,$8,$9,$7,$6,$receiver;
- var $early={};
- try {
- $2=$recv(self["@username"])._isNil();
- $ctx1.sendIdx["isNil"]=1;
- $1=$recv($2)._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@password"])._isNil();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["and:"]=1;
- if($core.assert($1)){
- return true;
- }
- $3=$recv($recv(aRequest)._headers())._at_("authorization");
- $ctx1.sendIdx["at:"]=1;
- if(($receiver = $3) == null || $receiver.isNil){
- header="";
- } else {
- header=$3;
- }
- $recv(header)._ifEmpty_ifNotEmpty_((function(){
- throw $early=[false];
- }),(function(){
- return $core.withContext(function($ctx2) {
- $4=$recv(header)._tokenize_(" ");
- $ctx2.sendIdx["tokenize:"]=1;
- if(($receiver = $4) == null || $receiver.isNil){
- token="";
- } else {
- token=$4;
- }
- token;
- $5=$recv(token)._at_((2));
- $ctx2.sendIdx["at:"]=2;
- auth=self._base64Decode_($5);
- auth;
- parts=$recv(auth)._tokenize_(":");
- parts;
- $8=self["@username"];
- $9=$recv(parts)._at_((1));
- $ctx2.sendIdx["at:"]=3;
- $7=$recv($8).__eq($9);
- $ctx2.sendIdx["="]=1;
- $6=$recv($7)._and_((function(){
- return $core.withContext(function($ctx3) {
- return $recv(self["@password"]).__eq($recv(parts)._at_((2)));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,7)});
- }));
- if($core.assert($6)){
- throw $early=[true];
- } else {
- throw $early=[false];
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,5)});
- }));
- return self;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"isAuthenticated:",{aRequest:aRequest,header:header,token:token,auth:auth,parts:parts},$globals.FileServer)});
- },
- args: ["aRequest"],
- source: "isAuthenticated: aRequest\x0a\x09\x22Basic HTTP Auth: http://stackoverflow.com/a/5957629/293175\x0a\x09 and https://gist.github.com/1686663\x22\x0a\x09| header token auth parts|\x0a\x0a\x09(username isNil and: [password isNil]) ifTrue: [^ true].\x0a\x0a\x09\x22get authentication header\x22\x0a\x09header := (aRequest headers at: 'authorization') ifNil:[''].\x0a\x09header\x0a\x09ifEmpty: [^ false]\x0a\x09ifNotEmpty: [\x0a\x09\x09\x22get authentication token\x22\x0a\x09\x09token := (header tokenize: ' ') ifNil:[''].\x0a\x09\x09\x22convert back from base64\x22\x0a\x09\x09auth := self base64Decode: (token at: 2).\x0a\x09\x09\x22split token at colon\x22\x0a\x09\x09parts := auth tokenize: ':'.\x0a\x0a\x09\x09((username = (parts at: 1)) and: [password = (parts at: 2)])\x0a\x09\x09\x09ifTrue: [^ true]\x0a\x09\x09\x09ifFalse: [^ false]\x0a\x09].",
- referencedClasses: [],
- messageSends: ["ifTrue:", "and:", "isNil", "ifNil:", "at:", "headers", "ifEmpty:ifNotEmpty:", "tokenize:", "base64Decode:", "ifTrue:ifFalse:", "="]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "password:",
- protocol: "accessing",
- fn: function (aPassword){
- var self=this;
- self["@password"]=aPassword;
- return self;
- },
- args: ["aPassword"],
- source: "password: aPassword\x0a\x09password := aPassword.",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "port",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@port"];
- },
- args: [],
- source: "port\x0a\x09^ port",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "port:",
- protocol: "accessing",
- fn: function (aNumber){
- var self=this;
- self["@port"]=aNumber;
- return self;
- },
- args: ["aNumber"],
- source: "port: aNumber\x0a\x09port := aNumber",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "require:",
- protocol: "private",
- fn: function (aModuleString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(require)._value_(aModuleString);
- }, function($ctx1) {$ctx1.fill(self,"require:",{aModuleString:aModuleString},$globals.FileServer)});
- },
- args: ["aModuleString"],
- source: "require: aModuleString\x0a\x09\x22call to the require function\x22\x0a\x09^require value: aModuleString",
- referencedClasses: [],
- messageSends: ["value:"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondAuthenticationRequiredTo:",
- protocol: "request handling",
- fn: function (aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aResponse)._writeHead_options_((401),$globals.HashedCollection._newFromPairs_(["WWW-Authenticate","Basic realm=\x22Secured Developer Area\x22"]));
- $recv(aResponse)._write_("<html><body>Authentication needed</body></html>");
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondAuthenticationRequiredTo:",{aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aResponse"],
- source: "respondAuthenticationRequiredTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 401 options: #{'WWW-Authenticate' -> 'Basic realm=\x22Secured Developer Area\x22'};\x0a\x09\x09write: '<html><body>Authentication needed</body></html>';\x0a\x09\x09end.",
- referencedClasses: [],
- messageSends: ["writeHead:options:", "write:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondCreatedTo:",
- protocol: "request handling",
- fn: function (aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aResponse)._writeHead_options_((201),$globals.HashedCollection._newFromPairs_(["Content-Type","text/plain","Access-Control-Allow-Origin","*"]));
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondCreatedTo:",{aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aResponse"],
- source: "respondCreatedTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 201 options: #{'Content-Type' -> 'text/plain'. 'Access-Control-Allow-Origin' -> '*'};\x0a\x09\x09end.",
- referencedClasses: [],
- messageSends: ["writeHead:options:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondDirectoryNamed:from:to:",
- protocol: "request handling",
- fn: function (aDirname,aUrl,aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$3,$5,$7,$6,$4,$receiver;
- $2=$recv(aUrl)._pathname();
- $ctx1.sendIdx["pathname"]=1;
- $1=$recv($2)._endsWith_("/");
- if($core.assert($1)){
- $3=$recv(aDirname).__comma("index.html");
- $ctx1.sendIdx[","]=1;
- self._respondFileNamed_to_($3,aResponse);
- } else {
- $5=$recv($recv(aUrl)._pathname()).__comma("/");
- $7=$recv(aUrl)._search();
- if(($receiver = $7) == null || $receiver.isNil){
- $6="";
- } else {
- $6=$7;
- }
- $4=$recv($5).__comma($6);
- $ctx1.sendIdx[","]=2;
- self._respondRedirect_to_($4,aResponse);
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondDirectoryNamed:from:to:",{aDirname:aDirname,aUrl:aUrl,aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aDirname", "aUrl", "aResponse"],
- source: "respondDirectoryNamed: aDirname from: aUrl to: aResponse\x0a\x09(aUrl pathname endsWith: '/')\x0a\x09\x09ifTrue: [self respondFileNamed: aDirname, 'index.html' to: aResponse]\x0a\x09\x09ifFalse: [self respondRedirect: aUrl pathname, '/', (aUrl search ifNil: ['']) to: aResponse]",
- referencedClasses: [],
- messageSends: ["ifTrue:ifFalse:", "endsWith:", "pathname", "respondFileNamed:to:", ",", "respondRedirect:to:", "ifNil:", "search"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondFileNamed:to:",
- protocol: "request handling",
- fn: function (aFilename,aResponse){
- var self=this;
- var type,filename;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- filename=aFilename;
- $recv(self["@fs"])._readFile_do_(filename,(function(ex,file){
- return $core.withContext(function($ctx2) {
- $1=$recv(ex)._notNil();
- if($core.assert($1)){
- $2=console;
- $3=$recv(filename).__comma(" does not exist");
- $ctx2.sendIdx[","]=1;
- $recv($2)._log_($3);
- return self._respondNotFoundTo_(aResponse);
- } else {
- type=$recv(self._class())._mimeTypeFor_(filename);
- type;
- $4=$recv(type).__eq("application/javascript");
- if($core.assert($4)){
- type=$recv(type).__comma(";charset=utf-8");
- type;
- }
- $recv(aResponse)._writeHead_options_((200),$globals.HashedCollection._newFromPairs_(["Content-Type",type]));
- $recv(aResponse)._write_encoding_(file,"binary");
- return $recv(aResponse)._end();
- }
- }, function($ctx2) {$ctx2.fillBlock({ex:ex,file:file},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondFileNamed:to:",{aFilename:aFilename,aResponse:aResponse,type:type,filename:filename},$globals.FileServer)});
- },
- args: ["aFilename", "aResponse"],
- source: "respondFileNamed: aFilename to: aResponse\x0a\x09| type filename |\x0a\x0a\x09filename := aFilename.\x0a\x0a\x09fs readFile: filename do: [:ex :file |\x0a\x09\x09ex notNil \x0a\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09console log: filename, ' does not exist'.\x0a\x09\x09\x09\x09self respondNotFoundTo: aResponse]\x0a\x09\x09\x09ifFalse: [\x0a\x09\x09\x09\x09type := self class mimeTypeFor: filename.\x0a\x09\x09\x09\x09type = 'application/javascript'\x0a\x09\x09\x09\x09\x09ifTrue: [ type:=type,';charset=utf-8' ].\x0a\x09\x09\x09\x09aResponse \x0a\x09\x09\x09\x09\x09writeHead: 200 options: #{'Content-Type' -> type};\x0a\x09\x09\x09\x09\x09write: file encoding: 'binary';\x0a\x09\x09\x09\x09\x09end]]",
- referencedClasses: [],
- messageSends: ["readFile:do:", "ifTrue:ifFalse:", "notNil", "log:", ",", "respondNotFoundTo:", "mimeTypeFor:", "class", "ifTrue:", "=", "writeHead:options:", "write:encoding:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondInternalErrorTo:",
- protocol: "request handling",
- fn: function (aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aResponse)._writeHead_options_((500),$globals.HashedCollection._newFromPairs_(["Content-Type","text/plain"]));
- $recv(aResponse)._write_("500 Internal server error");
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondInternalErrorTo:",{aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aResponse"],
- source: "respondInternalErrorTo: aResponse\x0a\x09aResponse \x0a\x09\x09writeHead: 500 options: #{'Content-Type' -> 'text/plain'};\x0a\x09\x09write: '500 Internal server error';\x0a\x09\x09end",
- referencedClasses: [],
- messageSends: ["writeHead:options:", "write:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondNotCreatedTo:",
- protocol: "request handling",
- fn: function (aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aResponse)._writeHead_options_((400),$globals.HashedCollection._newFromPairs_(["Content-Type","text/plain"]));
- $recv(aResponse)._write_("File could not be created. Did you forget to create the src directory on the server?");
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondNotCreatedTo:",{aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aResponse"],
- source: "respondNotCreatedTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 400 options: #{'Content-Type' -> 'text/plain'};\x0a\x09\x09write: 'File could not be created. Did you forget to create the src directory on the server?';\x0a\x09\x09end.",
- referencedClasses: [],
- messageSends: ["writeHead:options:", "write:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondNotFoundTo:",
- protocol: "request handling",
- fn: function (aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=self._fallbackPage();
- $ctx1.sendIdx["fallbackPage"]=1;
- $1=$recv($2)._isNil();
- if(!$core.assert($1)){
- return self._respondFileNamed_to_(self._fallbackPage(),aResponse);
- }
- $recv(aResponse)._writeHead_options_((404),$globals.HashedCollection._newFromPairs_(["Content-Type","text/html"]));
- $recv(aResponse)._write_("<html><body><p>404 Not found</p>");
- $ctx1.sendIdx["write:"]=1;
- $recv(aResponse)._write_("<p>Did you forget to put an index.html file into the directory which is served by \x22bin/amber serve\x22? To solve this you can:<ul>");
- $ctx1.sendIdx["write:"]=2;
- $recv(aResponse)._write_("<li>create an index.html in the served directory.</li>");
- $ctx1.sendIdx["write:"]=3;
- $recv(aResponse)._write_("<li>can also specify the location of a page to be served whenever path does not resolve to a file with the \x22--fallback-page\x22 option.</li>");
- $ctx1.sendIdx["write:"]=4;
- $recv(aResponse)._write_("<li>change the directory to be served with the \x22--base-path\x22 option.</li>");
- $ctx1.sendIdx["write:"]=5;
- $recv(aResponse)._write_("</ul></p></body></html>");
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondNotFoundTo:",{aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aResponse"],
- source: "respondNotFoundTo: aResponse\x0a\x09self fallbackPage isNil ifFalse: [^self respondFileNamed: self fallbackPage to: aResponse].\x0a\x09aResponse \x0a\x09\x09writeHead: 404 options: #{'Content-Type' -> 'text/html'};\x0a\x09\x09write: '<html><body><p>404 Not found</p>';\x0a\x09\x09write: '<p>Did you forget to put an index.html file into the directory which is served by \x22bin/amber serve\x22? To solve this you can:<ul>';\x0a\x09\x09write: '<li>create an index.html in the served directory.</li>';\x0a\x09\x09write: '<li>can also specify the location of a page to be served whenever path does not resolve to a file with the \x22--fallback-page\x22 option.</li>';\x0a\x09\x09write: '<li>change the directory to be served with the \x22--base-path\x22 option.</li>';\x0a\x09\x09write: '</ul></p></body></html>';\x0a\x09\x09end",
- referencedClasses: [],
- messageSends: ["ifFalse:", "isNil", "fallbackPage", "respondFileNamed:to:", "writeHead:options:", "write:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondOKTo:",
- protocol: "request handling",
- fn: function (aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aResponse)._writeHead_options_((200),$globals.HashedCollection._newFromPairs_(["Content-Type","text/plain","Access-Control-Allow-Origin","*"]));
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondOKTo:",{aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aResponse"],
- source: "respondOKTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 200 options: #{'Content-Type' -> 'text/plain'. 'Access-Control-Allow-Origin' -> '*'};\x0a\x09\x09end.",
- referencedClasses: [],
- messageSends: ["writeHead:options:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "respondRedirect:to:",
- protocol: "request handling",
- fn: function (aString,aResponse){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(aResponse)._writeHead_options_((303),$globals.HashedCollection._newFromPairs_(["Location",aString]));
- $recv(aResponse)._end();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"respondRedirect:to:",{aString:aString,aResponse:aResponse},$globals.FileServer)});
- },
- args: ["aString", "aResponse"],
- source: "respondRedirect: aString to: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 303 options: #{'Location' -> aString};\x0a\x09\x09end.",
- referencedClasses: [],
- messageSends: ["writeHead:options:", "end"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "start",
- protocol: "starting",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$8,$7,$6,$10,$9,$5;
- self._checkDirectoryLayout();
- $1=$recv(self["@http"])._createServer_((function(request,response){
- return $core.withContext(function($ctx2) {
- return self._handleRequest_respondTo_(request,response);
- }, function($ctx2) {$ctx2.fillBlock({request:request,response:response},$ctx1,1)});
- }));
- $recv($1)._on_do_("error",(function(error){
- return $core.withContext(function($ctx2) {
- $2=console;
- $3="Error starting server: ".__comma(error);
- $ctx2.sendIdx[","]=1;
- return $recv($2)._log_($3);
- $ctx2.sendIdx["log:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1,2)});
- }));
- $ctx1.sendIdx["on:do:"]=1;
- $recv($1)._on_do_("listening",(function(){
- return $core.withContext(function($ctx2) {
- $4=console;
- $8=self._host();
- $ctx2.sendIdx["host"]=1;
- $7="Starting file server on http://".__comma($8);
- $6=$recv($7).__comma(":");
- $ctx2.sendIdx[","]=3;
- $10=self._port();
- $ctx2.sendIdx["port"]=1;
- $9=$recv($10)._asString();
- $5=$recv($6).__comma($9);
- $ctx2.sendIdx[","]=2;
- return $recv($4)._log_($5);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- $recv($1)._listen_host_(self._port(),self._host());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"start",{},$globals.FileServer)});
- },
- args: [],
- source: "start\x0a\x09\x22Checks if required directory layout is present (issue warning if not).\x0a\x09 Afterwards start the server.\x22\x0a\x09self checkDirectoryLayout.\x0a\x09(http createServer: [:request :response |\x0a\x09 self handleRequest: request respondTo: response])\x0a\x09 on: 'error' do: [:error | console log: 'Error starting server: ', error];\x0a\x09 on: 'listening' do: [console log: 'Starting file server on http://', self host, ':', self port asString];\x0a\x09 listen: self port host: self host.",
- referencedClasses: [],
- messageSends: ["checkDirectoryLayout", "on:do:", "createServer:", "handleRequest:respondTo:", "log:", ",", "host", "asString", "port", "listen:host:"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "startOn:",
- protocol: "starting",
- fn: function (aPort){
- var self=this;
- return $core.withContext(function($ctx1) {
- self._port_(aPort);
- self._start();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"startOn:",{aPort:aPort},$globals.FileServer)});
- },
- args: ["aPort"],
- source: "startOn: aPort\x0a\x09self port: aPort.\x0a\x09self start",
- referencedClasses: [],
- messageSends: ["port:", "start"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "username:",
- protocol: "accessing",
- fn: function (aUsername){
- var self=this;
- self["@username"]=aUsername;
- return self;
- },
- args: ["aUsername"],
- source: "username: aUsername\x0a\x09username := aUsername.",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "validateBasePath",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$7,$6,$5,$8,$9,$receiver;
- $1=self["@fs"];
- $2=self._basePath();
- $ctx1.sendIdx["basePath"]=1;
- $recv($1)._stat_then_($2,(function(err,stat){
- return $core.withContext(function($ctx2) {
- if(($receiver = err) == null || $receiver.isNil){
- $3=$recv(stat)._isDirectory();
- if(!$core.assert($3)){
- $4=console;
- $7=self._basePath();
- $ctx2.sendIdx["basePath"]=2;
- $6="Warning: --base-path parameter ".__comma($7);
- $ctx2.sendIdx[","]=2;
- $5=$recv($6).__comma(" is not a directory.");
- $ctx2.sendIdx[","]=1;
- return $recv($4)._warn_($5);
- $ctx2.sendIdx["warn:"]=1;
- }
- } else {
- $8=console;
- $9=$recv("Warning: path at --base-path parameter ".__comma(self._basePath())).__comma(" does not exist.");
- $ctx2.sendIdx[","]=3;
- return $recv($8)._warn_($9);
- }
- }, function($ctx2) {$ctx2.fillBlock({err:err,stat:stat},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"validateBasePath",{},$globals.FileServer)});
- },
- args: [],
- source: "validateBasePath\x0a\x09\x22The basePath must be an existing directory. \x22\x0a\x09fs stat: self basePath then: [ :err :stat | err\x0a\x09\x09ifNil: [ stat isDirectory ifFalse: [ console warn: 'Warning: --base-path parameter ' , self basePath , ' is not a directory.' ]]\x0a\x09\x09ifNotNil: [ console warn: 'Warning: path at --base-path parameter ' , self basePath , ' does not exist.' ]].",
- referencedClasses: [],
- messageSends: ["stat:then:", "basePath", "ifNil:ifNotNil:", "ifFalse:", "isDirectory", "warn:", ","]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "withBasePath:",
- protocol: "private",
- fn: function (aBaseRelativePath){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self["@path"])._join_with_(self._basePath(),aBaseRelativePath);
- }, function($ctx1) {$ctx1.fill(self,"withBasePath:",{aBaseRelativePath:aBaseRelativePath},$globals.FileServer)});
- },
- args: ["aBaseRelativePath"],
- source: "withBasePath: aBaseRelativePath\x0a\x09\x22return a file path which is relative to the basePath.\x22\x0a\x09^ path join: self basePath with: aBaseRelativePath",
- referencedClasses: [],
- messageSends: ["join:with:", "basePath"]
- }),
- $globals.FileServer);
- $core.addMethod(
- $core.method({
- selector: "writeData:toFileNamed:",
- protocol: "private",
- fn: function (data,aFilename){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(console)._log_(aFilename);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"writeData:toFileNamed:",{data:data,aFilename:aFilename},$globals.FileServer)});
- },
- args: ["data", "aFilename"],
- source: "writeData: data toFileNamed: aFilename\x0a\x09console log: aFilename",
- referencedClasses: [],
- messageSends: ["log:"]
- }),
- $globals.FileServer);
- $globals.FileServer.klass.iVarNames = ["mimeTypes"];
- $core.addMethod(
- $core.method({
- selector: "commandLineSwitches",
- protocol: "accessing",
- fn: function (){
- var self=this;
- var switches;
- return $core.withContext(function($ctx1) {
- switches=$recv(self._methodsInProtocol_("accessing"))._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._selector();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["collect:"]=1;
- switches=$recv(switches)._select_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(each)._match_("^[^:]*:$");
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)});
- }));
- switches=$recv(switches)._collect_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv($recv($recv(each)._allButLast())._replace_with_("([A-Z])","-$1"))._asLowercase())._replace_with_("^([a-z])","--$1");
- $ctx2.sendIdx["replace:with:"]=1;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,3)});
- }));
- return switches;
- }, function($ctx1) {$ctx1.fill(self,"commandLineSwitches",{switches:switches},$globals.FileServer.klass)});
- },
- args: [],
- source: "commandLineSwitches\x0a\x09\x22Collect all methodnames from the 'accessing' protocol\x0a\x09 and select the ones with only one parameter.\x0a\x09 Then remove the ':' at the end of the name\x0a\x09 and add a '--' at the beginning.\x0a\x09 Additionally all uppercase letters are made lowercase and preceded by a '-'.\x0a\x09 Example: fallbackPage: becomes --fallback-page.\x0a\x09 Return the Array containing the commandline switches.\x22\x0a\x09| switches |\x0a\x09switches := ((self methodsInProtocol: 'accessing') collect: [ :each | each selector]).\x0a\x09switches := switches select: [ :each | each match: '^[^:]*:$'].\x0a\x09switches :=switches collect: [ :each |\x0a\x09\x09(each allButLast replace: '([A-Z])' with: '-$1') asLowercase replace: '^([a-z])' with: '--$1' ].\x0a\x09^ switches",
- referencedClasses: [],
- messageSends: ["collect:", "methodsInProtocol:", "selector", "select:", "match:", "replace:with:", "asLowercase", "allButLast"]
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "createServerWithArguments:",
- protocol: "initialization",
- fn: function (options){
- var self=this;
- var server,popFront,front,optionName,optionValue,switches;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$8;
- var $early={};
- try {
- switches=self._commandLineSwitches();
- server=self._new();
- $recv(options)._ifEmpty_((function(){
- throw $early=[server];
- }));
- $1=$recv($recv(options)._size())._even();
- if(!$core.assert($1)){
- $recv(console)._log_("Using default parameters.");
- $ctx1.sendIdx["log:"]=1;
- $2=console;
- $3="Wrong commandline options or not enough arguments for: ".__comma(options);
- $ctx1.sendIdx[","]=1;
- $recv($2)._log_($3);
- $ctx1.sendIdx["log:"]=2;
- $4=console;
- $5="Use any of the following ones: ".__comma(switches);
- $ctx1.sendIdx[","]=2;
- $recv($4)._log_($5);
- $ctx1.sendIdx["log:"]=3;
- return server;
- }
- popFront=(function(args){
- return $core.withContext(function($ctx2) {
- front=$recv(args)._first();
- front;
- $recv(args)._remove_(front);
- return front;
- }, function($ctx2) {$ctx2.fillBlock({args:args},$ctx1,3)});
- });
- $recv((function(){
- return $core.withContext(function($ctx2) {
- return $recv(options)._notEmpty();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,4)});
- }))._whileTrue_((function(){
- return $core.withContext(function($ctx2) {
- optionName=$recv(popFront)._value_(options);
- $ctx2.sendIdx["value:"]=1;
- optionName;
- optionValue=$recv(popFront)._value_(options);
- optionValue;
- $6=$recv(switches)._includes_(optionName);
- if($core.assert($6)){
- optionName=self._selectorForCommandLineSwitch_(optionName);
- optionName;
- return $recv(server)._perform_withArguments_(optionName,$recv($globals.Array)._with_(optionValue));
- } else {
- $7=console;
- $8=$recv(optionName).__comma(" is not a valid commandline option");
- $ctx2.sendIdx[","]=3;
- $recv($7)._log_($8);
- $ctx2.sendIdx["log:"]=4;
- return $recv(console)._log_("Use any of the following ones: ".__comma(switches));
- }
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,5)});
- }));
- return server;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"createServerWithArguments:",{options:options,server:server,popFront:popFront,front:front,optionName:optionName,optionValue:optionValue,switches:switches},$globals.FileServer.klass)});
- },
- args: ["options"],
- source: "createServerWithArguments: options\x0a\x09\x22If options are empty return a default FileServer instance.\x0a\x09 If options are given loop through them and set the passed in values\x0a\x09 on the FileServer instance.\x0a\x09 \x0a\x09 Commanline options map directly to methods in the 'accessing' protocol\x0a\x09 taking one parameter.\x0a\x09 Adding a method to this protocol makes it directly settable through\x0a\x09 command line options.\x0a\x09 \x22\x0a\x09| server popFront front optionName optionValue switches |\x0a\x0a\x09switches := self commandLineSwitches.\x0a\x0a\x09server := self new.\x0a\x0a\x09options ifEmpty: [^server].\x0a\x0a\x09(options size even) ifFalse: [\x0a\x09\x09console log: 'Using default parameters.'.\x0a\x09\x09console log: 'Wrong commandline options or not enough arguments for: ' , options.\x0a\x09\x09console log: 'Use any of the following ones: ', switches.\x0a\x09\x09^server].\x0a\x0a\x09popFront := [:args |\x0a\x09\x09front := args first.\x0a\x09\x09args remove: front.\x0a\x09\x09front].\x0a\x0a\x09[options notEmpty] whileTrue: [\x0a\x09\x09optionName := popFront value: options.\x0a\x09\x09optionValue := popFront value: options.\x0a\x0a\x09\x09(switches includes: optionName) ifTrue: [\x0a\x09\x09\x09optionName := self selectorForCommandLineSwitch: optionName.\x0a\x09\x09\x09server perform: optionName withArguments: (Array with: optionValue)]\x0a\x09\x09\x09ifFalse: [\x0a\x09\x09\x09\x09console log: optionName, ' is not a valid commandline option'.\x0a\x09\x09\x09\x09console log: 'Use any of the following ones: ', switches ]].\x0a\x09^ server.",
- referencedClasses: ["Array"],
- messageSends: ["commandLineSwitches", "new", "ifEmpty:", "ifFalse:", "even", "size", "log:", ",", "first", "remove:", "whileTrue:", "notEmpty", "value:", "ifTrue:ifFalse:", "includes:", "selectorForCommandLineSwitch:", "perform:withArguments:", "with:"]
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "defaultBasePath",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "./";
- },
- args: [],
- source: "defaultBasePath\x0a\x09^ './'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "defaultHost",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "127.0.0.1";
- },
- args: [],
- source: "defaultHost\x0a\x09^ '127.0.0.1'",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "defaultMimeTypes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $globals.HashedCollection._newFromPairs_(["%","application/x-trash","323","text/h323","abw","application/x-abiword","ai","application/postscript","aif","audio/x-aiff","aifc","audio/x-aiff","aiff","audio/x-aiff","alc","chemical/x-alchemy","art","image/x-jg","asc","text/plain","asf","video/x-ms-asf","asn","chemical/x-ncbi-asn1-spec","aso","chemical/x-ncbi-asn1-binary","asx","video/x-ms-asf","au","audio/basic","avi","video/x-msvideo","b","chemical/x-molconn-Z","bak","application/x-trash","bat","application/x-msdos-program","bcpio","application/x-bcpio","bib","text/x-bibtex","bin","application/octet-stream","bmp","image/x-ms-bmp","book","application/x-maker","bsd","chemical/x-crossfire","c","text/x-csrc","c++","text/x-c++src","c3d","chemical/x-chem3d","cac","chemical/x-cache","cache","chemical/x-cache","cascii","chemical/x-cactvs-binary","cat","application/vnd.ms-pki.seccat","cbin","chemical/x-cactvs-binary","cc","text/x-c++src","cdf","application/x-cdf","cdr","image/x-coreldraw","cdt","image/x-coreldrawtemplate","cdx","chemical/x-cdx","cdy","application/vnd.cinderella","cef","chemical/x-cxf","cer","chemical/x-cerius","chm","chemical/x-chemdraw","chrt","application/x-kchart","cif","chemical/x-cif","class","application/java-vm","cls","text/x-tex","cmdf","chemical/x-cmdf","cml","chemical/x-cml","cod","application/vnd.rim.cod","com","application/x-msdos-program","cpa","chemical/x-compass","cpio","application/x-cpio","cpp","text/x-c++src","cpt","image/x-corelphotopaint","crl","application/x-pkcs7-crl","crt","application/x-x509-ca-cert","csf","chemical/x-cache-csf","csh","text/x-csh","csm","chemical/x-csml","csml","chemical/x-csml","css","text/css","csv","text/comma-separated-values","ctab","chemical/x-cactvs-binary","ctx","chemical/x-ctx","cu","application/cu-seeme","cub","chemical/x-gaussian-cube","cxf","chemical/x-cxf","cxx","text/x-c++src","dat","chemical/x-mopac-input","dcr","application/x-director","deb","application/x-debian-package","dif","video/dv","diff","text/plain","dir","application/x-director","djv","image/vnd.djvu","djvu","image/vnd.djvu","dl","video/dl","dll","application/x-msdos-program","dmg","application/x-apple-diskimage","dms","application/x-dms","doc","application/msword","dot","application/msword","dv","video/dv","dvi","application/x-dvi","dx","chemical/x-jcamp-dx","dxr","application/x-director","emb","chemical/x-embl-dl-nucleotide","embl","chemical/x-embl-dl-nucleotide","ent","chemical/x-pdb","eps","application/postscript","etx","text/x-setext","exe","application/x-msdos-program","ez","application/andrew-inset","fb","application/x-maker","fbdoc","application/x-maker","fch","chemical/x-gaussian-checkpoint","fchk","chemical/x-gaussian-checkpoint","fig","application/x-xfig","flac","application/x-flac","fli","video/fli","fm","application/x-maker","frame","application/x-maker","frm","application/x-maker","gal","chemical/x-gaussian-log","gam","chemical/x-gamess-input","gamin","chemical/x-gamess-input","gau","chemical/x-gaussian-input","gcd","text/x-pcs-gcd","gcf","application/x-graphing-calculator","gcg","chemical/x-gcg8-sequence","gen","chemical/x-genbank","gf","application/x-tex-gf","gif","image/gif","gjc","chemical/x-gaussian-input","gjf","chemical/x-gaussian-input","gl","video/gl","gnumeric","application/x-gnumeric","gpt","chemical/x-mopac-graph","gsf","application/x-font","gsm","audio/x-gsm","gtar","application/x-gtar","h","text/x-chdr","h++","text/x-c++hdr","hdf","application/x-hdf","hh","text/x-c++hdr","hin","chemical/x-hin","hpp","text/x-c++hdr","hqx","application/mac-binhex40","hs","text/x-haskell","hta","application/hta","htc","text/x-component","htm","text/html","html","text/html","hxx","text/x-c++hdr","ica","application/x-ica","ice","x-conference/x-cooltalk","ico","image/x-icon","ics","text/calendar","icz","text/calendar","ief","image/ief","iges","model/iges","igs","model/iges","iii","application/x-iphone","inp","chemical/x-gamess-input","ins","application/x-internet-signup","iso","application/x-iso9660-image","isp","application/x-internet-signup","ist","chemical/x-isostar","istr","chemical/x-isostar","jad","text/vnd.sun.j2me.app-descriptor","jar","application/java-archive","java","text/x-java","jdx","chemical/x-jcamp-dx","jmz","application/x-jmol","jng","image/x-jng","jnlp","application/x-java-jnlp-file","jpe","image/jpeg","jpeg","image/jpeg","jpg","image/jpeg","js","application/javascript","kar","audio/midi","key","application/pgp-keys","kil","application/x-killustrator","kin","chemical/x-kinemage","kpr","application/x-kpresenter","kpt","application/x-kpresenter","ksp","application/x-kspread","kwd","application/x-kword","kwt","application/x-kword","latex","application/x-latex","lha","application/x-lha","lhs","text/x-literate-haskell","lsf","video/x-la-asf","lsx","video/x-la-asf","ltx","text/x-tex","lzh","application/x-lzh","lzx","application/x-lzx","m3u","audio/x-mpegurl","m4a","audio/mpeg","maker","application/x-maker","man","application/x-troff-man","mcif","chemical/x-mmcif","mcm","chemical/x-macmolecule","mdb","application/msaccess","me","application/x-troff-me","mesh","model/mesh","mid","audio/midi","midi","audio/midi","mif","application/x-mif","mm","application/x-freemind","mmd","chemical/x-macromodel-input","mmf","application/vnd.smaf","mml","text/mathml","mmod","chemical/x-macromodel-input","mng","video/x-mng","moc","text/x-moc","mol","chemical/x-mdl-molfile","mol2","chemical/x-mol2","moo","chemical/x-mopac-out","mop","chemical/x-mopac-input","mopcrt","chemical/x-mopac-input","mov","video/quicktime","movie","video/x-sgi-movie","mp2","audio/mpeg","mp3","audio/mpeg","mp4","video/mp4","mpc","chemical/x-mopac-input","mpe","video/mpeg","mpeg","video/mpeg","mpega","audio/mpeg","mpg","video/mpeg","mpga","audio/mpeg","ms","application/x-troff-ms","msh","model/mesh","msi","application/x-msi","mvb","chemical/x-mopac-vib","mxu","video/vnd.mpegurl","nb","application/mathematica","nc","application/x-netcdf","nwc","application/x-nwc","o","application/x-object","oda","application/oda","odb","application/vnd.oasis.opendocument.database","odc","application/vnd.oasis.opendocument.chart","odf","application/vnd.oasis.opendocument.formula","odg","application/vnd.oasis.opendocument.graphics","odi","application/vnd.oasis.opendocument.image","odm","application/vnd.oasis.opendocument.text-master","odp","application/vnd.oasis.opendocument.presentation","ods","application/vnd.oasis.opendocument.spreadsheet","odt","application/vnd.oasis.opendocument.text","ogg","application/ogg","old","application/x-trash","oth","application/vnd.oasis.opendocument.text-web","oza","application/x-oz-application","p","text/x-pascal","p7r","application/x-pkcs7-certreqresp","pac","application/x-ns-proxy-autoconfig","pas","text/x-pascal","pat","image/x-coreldrawpattern","pbm","image/x-portable-bitmap","pcf","application/x-font","pcf.Z","application/x-font","pcx","image/pcx","pdb","chemical/x-pdb","pdf","application/pdf","pfa","application/x-font","pfb","application/x-font","pgm","image/x-portable-graymap","pgn","application/x-chess-pgn","pgp","application/pgp-signature","pk","application/x-tex-pk","pl","text/x-perl","pls","audio/x-scpls","pm","text/x-perl","png","image/png","pnm","image/x-portable-anymap","pot","text/plain","ppm","image/x-portable-pixmap","pps","application/vnd.ms-powerpoint","ppt","application/vnd.ms-powerpoint","prf","application/pics-rules","prt","chemical/x-ncbi-asn1-ascii","ps","application/postscript","psd","image/x-photoshop","psp","text/x-psp","py","text/x-python","pyc","application/x-python-code","pyo","application/x-python-code","qt","video/quicktime","qtl","application/x-quicktimeplayer","ra","audio/x-realaudio","ram","audio/x-pn-realaudio","rar","application/rar","ras","image/x-cmu-raster","rd","chemical/x-mdl-rdfile","rdf","application/rdf+xml","rgb","image/x-rgb","rm","audio/x-pn-realaudio","roff","application/x-troff","ros","chemical/x-rosdal","rpm","application/x-redhat-package-manager","rss","application/rss+xml","rtf","text/rtf","rtx","text/richtext","rxn","chemical/x-mdl-rxnfile","sct","text/scriptlet","sd","chemical/x-mdl-sdfile","sd2","audio/x-sd2","sda","application/vnd.stardivision.draw","sdc","application/vnd.stardivision.calc","sdd","application/vnd.stardivision.impress","sdf","chemical/x-mdl-sdfile","sdp","application/vnd.stardivision.impress","sdw","application/vnd.stardivision.writer","ser","application/java-serialized-object","sgf","application/x-go-sgf","sgl","application/vnd.stardivision.writer-global","sh","text/x-sh","shar","application/x-shar","shtml","text/html","sid","audio/prs.sid","sik","application/x-trash","silo","model/mesh","sis","application/vnd.symbian.install","sit","application/x-stuffit","skd","application/x-koan","skm","application/x-koan","skp","application/x-koan","skt","application/x-koan","smf","application/vnd.stardivision.math","smi","application/smil","smil","application/smil","snd","audio/basic","spc","chemical/x-galactic-spc","spl","application/x-futuresplash","src","application/x-wais-source","stc","application/vnd.sun.xml.calc.template","std","application/vnd.sun.xml.draw.template","sti","application/vnd.sun.xml.impress.template","stl","application/vnd.ms-pki.stl","stw","application/vnd.sun.xml.writer.template","sty","text/x-tex","sv4cpio","application/x-sv4cpio","sv4crc","application/x-sv4crc","svg","image/svg+xml","svgz","image/svg+xml","sw","chemical/x-swissprot","swf","application/x-shockwave-flash","swfl","application/x-shockwave-flash","sxc","application/vnd.sun.xml.calc","sxd","application/vnd.sun.xml.draw","sxg","application/vnd.sun.xml.writer.global","sxi","application/vnd.sun.xml.impress","sxm","application/vnd.sun.xml.math","sxw","application/vnd.sun.xml.writer","t","application/x-troff","tar","application/x-tar","taz","application/x-gtar","tcl","text/x-tcl","tex","text/x-tex","texi","application/x-texinfo","texinfo","application/x-texinfo","text","text/plain","tgf","chemical/x-mdl-tgf","tgz","application/x-gtar","tif","image/tiff","tiff","image/tiff","tk","text/x-tcl","tm","text/texmacs","torrent","application/x-bittorrent","tr","application/x-troff","ts","text/texmacs","tsp","application/dsptype","tsv","text/tab-separated-values","txt","text/plain","udeb","application/x-debian-package","uls","text/iuls","ustar","application/x-ustar","val","chemical/x-ncbi-asn1-binary","vcd","application/x-cdlink","vcf","text/x-vcard","vcs","text/x-vcalendar","vmd","chemical/x-vmd","vms","chemical/x-vamas-iso14976","vor","application/vnd.stardivision.writer","vrm","x-world/x-vrml","vrml","x-world/x-vrml","vsd","application/vnd.visio","wad","application/x-doom","wav","audio/x-wav","wax","audio/x-ms-wax","wbmp","image/vnd.wap.wbmp","wbxml","application/vnd.wap.wbxml","wk","application/x-123","wm","video/x-ms-wm","wma","audio/x-ms-wma","wmd","application/x-ms-wmd","wml","text/vnd.wap.wml","wmlc","application/vnd.wap.wmlc","wmls","text/vnd.wap.wmlscript","wmlsc","application/vnd.wap.wmlscriptc","wmv","video/x-ms-wmv","wmx","video/x-ms-wmx","wmz","application/x-ms-wmz","wp5","application/wordperfect5.1","wpd","application/wordperfect","wrl","x-world/x-vrml","wsc","text/scriptlet","wvx","video/x-ms-wvx","wz","application/x-wingz","xbm","image/x-xbitmap","xcf","application/x-xcf","xht","application/xhtml+xml","xhtml","application/xhtml+xml","xlb","application/vnd.ms-excel","xls","application/vnd.ms-excel","xlt","application/vnd.ms-excel","xml","application/xml","xpi","application/x-xpinstall","xpm","image/x-xpixmap","xsl","application/xml","xtel","chemical/x-xtel","xul","application/vnd.mozilla.xul+xml","xwd","image/x-xwindowdump","xyz","chemical/x-xyz","zip","application/zip","zmt","chemical/x-mopac-input","~","application/x-trash"]);
- },
- args: [],
- source: "defaultMimeTypes\x0a\x09^ #{\x0a\x09\x09'%' -> 'application/x-trash'.\x0a\x09\x09'323' -> 'text/h323'.\x0a\x09\x09'abw' -> 'application/x-abiword'.\x0a\x09\x09'ai' -> 'application/postscript'.\x0a\x09\x09'aif' -> 'audio/x-aiff'.\x0a\x09\x09'aifc' -> 'audio/x-aiff'.\x0a\x09\x09'aiff' -> 'audio/x-aiff'.\x0a\x09\x09'alc' -> 'chemical/x-alchemy'.\x0a\x09\x09'art' -> 'image/x-jg'.\x0a\x09\x09'asc' -> 'text/plain'.\x0a\x09\x09'asf' -> 'video/x-ms-asf'.\x0a\x09\x09'asn' -> 'chemical/x-ncbi-asn1-spec'.\x0a\x09\x09'aso' -> 'chemical/x-ncbi-asn1-binary'.\x0a\x09\x09'asx' -> 'video/x-ms-asf'.\x0a\x09\x09'au' -> 'audio/basic'.\x0a\x09\x09'avi' -> 'video/x-msvideo'.\x0a\x09\x09'b' -> 'chemical/x-molconn-Z'.\x0a\x09\x09'bak' -> 'application/x-trash'.\x0a\x09\x09'bat' -> 'application/x-msdos-program'.\x0a\x09\x09'bcpio' -> 'application/x-bcpio'.\x0a\x09\x09'bib' -> 'text/x-bibtex'.\x0a\x09\x09'bin' -> 'application/octet-stream'.\x0a\x09\x09'bmp' -> 'image/x-ms-bmp'.\x0a\x09\x09'book' -> 'application/x-maker'.\x0a\x09\x09'bsd' -> 'chemical/x-crossfire'.\x0a\x09\x09'c' -> 'text/x-csrc'.\x0a\x09\x09'c++' -> 'text/x-c++src'.\x0a\x09\x09'c3d' -> 'chemical/x-chem3d'.\x0a\x09\x09'cac' -> 'chemical/x-cache'.\x0a\x09\x09'cache' -> 'chemical/x-cache'.\x0a\x09\x09'cascii' -> 'chemical/x-cactvs-binary'.\x0a\x09\x09'cat' -> 'application/vnd.ms-pki.seccat'.\x0a\x09\x09'cbin' -> 'chemical/x-cactvs-binary'.\x0a\x09\x09'cc' -> 'text/x-c++src'.\x0a\x09\x09'cdf' -> 'application/x-cdf'.\x0a\x09\x09'cdr' -> 'image/x-coreldraw'.\x0a\x09\x09'cdt' -> 'image/x-coreldrawtemplate'.\x0a\x09\x09'cdx' -> 'chemical/x-cdx'.\x0a\x09\x09'cdy' -> 'application/vnd.cinderella'.\x0a\x09\x09'cef' -> 'chemical/x-cxf'.\x0a\x09\x09'cer' -> 'chemical/x-cerius'.\x0a\x09\x09'chm' -> 'chemical/x-chemdraw'.\x0a\x09\x09'chrt' -> 'application/x-kchart'.\x0a\x09\x09'cif' -> 'chemical/x-cif'.\x0a\x09\x09'class' -> 'application/java-vm'.\x0a\x09\x09'cls' -> 'text/x-tex'.\x0a\x09\x09'cmdf' -> 'chemical/x-cmdf'.\x0a\x09\x09'cml' -> 'chemical/x-cml'.\x0a\x09\x09'cod' -> 'application/vnd.rim.cod'.\x0a\x09\x09'com' -> 'application/x-msdos-program'.\x0a\x09\x09'cpa' -> 'chemical/x-compass'.\x0a\x09\x09'cpio' -> 'application/x-cpio'.\x0a\x09\x09'cpp' -> 'text/x-c++src'.\x0a\x09\x09'cpt' -> 'image/x-corelphotopaint'.\x0a\x09\x09'crl' -> 'application/x-pkcs7-crl'.\x0a\x09\x09'crt' -> 'application/x-x509-ca-cert'.\x0a\x09\x09'csf' -> 'chemical/x-cache-csf'.\x0a\x09\x09'csh' -> 'text/x-csh'.\x0a\x09\x09'csm' -> 'chemical/x-csml'.\x0a\x09\x09'csml' -> 'chemical/x-csml'.\x0a\x09\x09'css' -> 'text/css'.\x0a\x09\x09'csv' -> 'text/comma-separated-values'.\x0a\x09\x09'ctab' -> 'chemical/x-cactvs-binary'.\x0a\x09\x09'ctx' -> 'chemical/x-ctx'.\x0a\x09\x09'cu' -> 'application/cu-seeme'.\x0a\x09\x09'cub' -> 'chemical/x-gaussian-cube'.\x0a\x09\x09'cxf' -> 'chemical/x-cxf'.\x0a\x09\x09'cxx' -> 'text/x-c++src'.\x0a\x09\x09'dat' -> 'chemical/x-mopac-input'.\x0a\x09\x09'dcr' -> 'application/x-director'.\x0a\x09\x09'deb' -> 'application/x-debian-package'.\x0a\x09\x09'dif' -> 'video/dv'.\x0a\x09\x09'diff' -> 'text/plain'.\x0a\x09\x09'dir' -> 'application/x-director'.\x0a\x09\x09'djv' -> 'image/vnd.djvu'.\x0a\x09\x09'djvu' -> 'image/vnd.djvu'.\x0a\x09\x09'dl' -> 'video/dl'.\x0a\x09\x09'dll' -> 'application/x-msdos-program'.\x0a\x09\x09'dmg' -> 'application/x-apple-diskimage'.\x0a\x09\x09'dms' -> 'application/x-dms'.\x0a\x09\x09'doc' -> 'application/msword'.\x0a\x09\x09'dot' -> 'application/msword'.\x0a\x09\x09'dv' -> 'video/dv'.\x0a\x09\x09'dvi' -> 'application/x-dvi'.\x0a\x09\x09'dx' -> 'chemical/x-jcamp-dx'.\x0a\x09\x09'dxr' -> 'application/x-director'.\x0a\x09\x09'emb' -> 'chemical/x-embl-dl-nucleotide'.\x0a\x09\x09'embl' -> 'chemical/x-embl-dl-nucleotide'.\x0a\x09\x09'ent' -> 'chemical/x-pdb'.\x0a\x09\x09'eps' -> 'application/postscript'.\x0a\x09\x09'etx' -> 'text/x-setext'.\x0a\x09\x09'exe' -> 'application/x-msdos-program'.\x0a\x09\x09'ez' -> 'application/andrew-inset'.\x0a\x09\x09'fb' -> 'application/x-maker'.\x0a\x09\x09'fbdoc' -> 'application/x-maker'.\x0a\x09\x09'fch' -> 'chemical/x-gaussian-checkpoint'.\x0a\x09\x09'fchk' -> 'chemical/x-gaussian-checkpoint'.\x0a\x09\x09'fig' -> 'application/x-xfig'.\x0a\x09\x09'flac' -> 'application/x-flac'.\x0a\x09\x09'fli' -> 'video/fli'.\x0a\x09\x09'fm' -> 'application/x-maker'.\x0a\x09\x09'frame' -> 'application/x-maker'.\x0a\x09\x09'frm' -> 'application/x-maker'.\x0a\x09\x09'gal' -> 'chemical/x-gaussian-log'.\x0a\x09\x09'gam' -> 'chemical/x-gamess-input'.\x0a\x09\x09'gamin' -> 'chemical/x-gamess-input'.\x0a\x09\x09'gau' -> 'chemical/x-gaussian-input'.\x0a\x09\x09'gcd' -> 'text/x-pcs-gcd'.\x0a\x09\x09'gcf' -> 'application/x-graphing-calculator'.\x0a\x09\x09'gcg' -> 'chemical/x-gcg8-sequence'.\x0a\x09\x09'gen' -> 'chemical/x-genbank'.\x0a\x09\x09'gf' -> 'application/x-tex-gf'.\x0a\x09\x09'gif' -> 'image/gif'.\x0a\x09\x09'gjc' -> 'chemical/x-gaussian-input'.\x0a\x09\x09'gjf' -> 'chemical/x-gaussian-input'.\x0a\x09\x09'gl' -> 'video/gl'.\x0a\x09\x09'gnumeric' -> 'application/x-gnumeric'.\x0a\x09\x09'gpt' -> 'chemical/x-mopac-graph'.\x0a\x09\x09'gsf' -> 'application/x-font'.\x0a\x09\x09'gsm' -> 'audio/x-gsm'.\x0a\x09\x09'gtar' -> 'application/x-gtar'.\x0a\x09\x09'h' -> 'text/x-chdr'.\x0a\x09\x09'h++' -> 'text/x-c++hdr'.\x0a\x09\x09'hdf' -> 'application/x-hdf'.\x0a\x09\x09'hh' -> 'text/x-c++hdr'.\x0a\x09\x09'hin' -> 'chemical/x-hin'.\x0a\x09\x09'hpp' -> 'text/x-c++hdr'.\x0a\x09\x09'hqx' -> 'application/mac-binhex40'.\x0a\x09\x09'hs' -> 'text/x-haskell'.\x0a\x09\x09'hta' -> 'application/hta'.\x0a\x09\x09'htc' -> 'text/x-component'.\x0a\x09\x09'htm' -> 'text/html'.\x0a\x09\x09'html' -> 'text/html'.\x0a\x09\x09'hxx' -> 'text/x-c++hdr'.\x0a\x09\x09'ica' -> 'application/x-ica'.\x0a\x09\x09'ice' -> 'x-conference/x-cooltalk'.\x0a\x09\x09'ico' -> 'image/x-icon'.\x0a\x09\x09'ics' -> 'text/calendar'.\x0a\x09\x09'icz' -> 'text/calendar'.\x0a\x09\x09'ief' -> 'image/ief'.\x0a\x09\x09'iges' -> 'model/iges'.\x0a\x09\x09'igs' -> 'model/iges'.\x0a\x09\x09'iii' -> 'application/x-iphone'.\x0a\x09\x09'inp' -> 'chemical/x-gamess-input'.\x0a\x09\x09'ins' -> 'application/x-internet-signup'.\x0a\x09\x09'iso' -> 'application/x-iso9660-image'.\x0a\x09\x09'isp' -> 'application/x-internet-signup'.\x0a\x09\x09'ist' -> 'chemical/x-isostar'.\x0a\x09\x09'istr' -> 'chemical/x-isostar'.\x0a\x09\x09'jad' -> 'text/vnd.sun.j2me.app-descriptor'.\x0a\x09\x09'jar' -> 'application/java-archive'.\x0a\x09\x09'java' -> 'text/x-java'.\x0a\x09\x09'jdx' -> 'chemical/x-jcamp-dx'.\x0a\x09\x09'jmz' -> 'application/x-jmol'.\x0a\x09\x09'jng' -> 'image/x-jng'.\x0a\x09\x09'jnlp' -> 'application/x-java-jnlp-file'.\x0a\x09\x09'jpe' -> 'image/jpeg'.\x0a\x09\x09'jpeg' -> 'image/jpeg'.\x0a\x09\x09'jpg' -> 'image/jpeg'.\x0a\x09\x09'js' -> 'application/javascript'.\x0a\x09\x09'kar' -> 'audio/midi'.\x0a\x09\x09'key' -> 'application/pgp-keys'.\x0a\x09\x09'kil' -> 'application/x-killustrator'.\x0a\x09\x09'kin' -> 'chemical/x-kinemage'.\x0a\x09\x09'kpr' -> 'application/x-kpresenter'.\x0a\x09\x09'kpt' -> 'application/x-kpresenter'.\x0a\x09\x09'ksp' -> 'application/x-kspread'.\x0a\x09\x09'kwd' -> 'application/x-kword'.\x0a\x09\x09'kwt' -> 'application/x-kword'.\x0a\x09\x09'latex' -> 'application/x-latex'.\x0a\x09\x09'lha' -> 'application/x-lha'.\x0a\x09\x09'lhs' -> 'text/x-literate-haskell'.\x0a\x09\x09'lsf' -> 'video/x-la-asf'.\x0a\x09\x09'lsx' -> 'video/x-la-asf'.\x0a\x09\x09'ltx' -> 'text/x-tex'.\x0a\x09\x09'lzh' -> 'application/x-lzh'.\x0a\x09\x09'lzx' -> 'application/x-lzx'.\x0a\x09\x09'm3u' -> 'audio/x-mpegurl'.\x0a\x09\x09'm4a' -> 'audio/mpeg'.\x0a\x09\x09'maker' -> 'application/x-maker'.\x0a\x09\x09'man' -> 'application/x-troff-man'.\x0a\x09\x09'mcif' -> 'chemical/x-mmcif'.\x0a\x09\x09'mcm' -> 'chemical/x-macmolecule'.\x0a\x09\x09'mdb' -> 'application/msaccess'.\x0a\x09\x09'me' -> 'application/x-troff-me'.\x0a\x09\x09'mesh' -> 'model/mesh'.\x0a\x09\x09'mid' -> 'audio/midi'.\x0a\x09\x09'midi' -> 'audio/midi'.\x0a\x09\x09'mif' -> 'application/x-mif'.\x0a\x09\x09'mm' -> 'application/x-freemind'.\x0a\x09\x09'mmd' -> 'chemical/x-macromodel-input'.\x0a\x09\x09'mmf' -> 'application/vnd.smaf'.\x0a\x09\x09'mml' -> 'text/mathml'.\x0a\x09\x09'mmod' -> 'chemical/x-macromodel-input'.\x0a\x09\x09'mng' -> 'video/x-mng'.\x0a\x09\x09'moc' -> 'text/x-moc'.\x0a\x09\x09'mol' -> 'chemical/x-mdl-molfile'.\x0a\x09\x09'mol2' -> 'chemical/x-mol2'.\x0a\x09\x09'moo' -> 'chemical/x-mopac-out'.\x0a\x09\x09'mop' -> 'chemical/x-mopac-input'.\x0a\x09\x09'mopcrt' -> 'chemical/x-mopac-input'.\x0a\x09\x09'mov' -> 'video/quicktime'.\x0a\x09\x09'movie' -> 'video/x-sgi-movie'.\x0a\x09\x09'mp2' -> 'audio/mpeg'.\x0a\x09\x09'mp3' -> 'audio/mpeg'.\x0a\x09\x09'mp4' -> 'video/mp4'.\x0a\x09\x09'mpc' -> 'chemical/x-mopac-input'.\x0a\x09\x09'mpe' -> 'video/mpeg'.\x0a\x09\x09'mpeg' -> 'video/mpeg'.\x0a\x09\x09'mpega' -> 'audio/mpeg'.\x0a\x09\x09'mpg' -> 'video/mpeg'.\x0a\x09\x09'mpga' -> 'audio/mpeg'.\x0a\x09\x09'ms' -> 'application/x-troff-ms'.\x0a\x09\x09'msh' -> 'model/mesh'.\x0a\x09\x09'msi' -> 'application/x-msi'.\x0a\x09\x09'mvb' -> 'chemical/x-mopac-vib'.\x0a\x09\x09'mxu' -> 'video/vnd.mpegurl'.\x0a\x09\x09'nb' -> 'application/mathematica'.\x0a\x09\x09'nc' -> 'application/x-netcdf'.\x0a\x09\x09'nwc' -> 'application/x-nwc'.\x0a\x09\x09'o' -> 'application/x-object'.\x0a\x09\x09'oda' -> 'application/oda'.\x0a\x09\x09'odb' -> 'application/vnd.oasis.opendocument.database'.\x0a\x09\x09'odc' -> 'application/vnd.oasis.opendocument.chart'.\x0a\x09\x09'odf' -> 'application/vnd.oasis.opendocument.formula'.\x0a\x09\x09'odg' -> 'application/vnd.oasis.opendocument.graphics'.\x0a\x09\x09'odi' -> 'application/vnd.oasis.opendocument.image'.\x0a\x09\x09'odm' -> 'application/vnd.oasis.opendocument.text-master'.\x0a\x09\x09'odp' -> 'application/vnd.oasis.opendocument.presentation'.\x0a\x09\x09'ods' -> 'application/vnd.oasis.opendocument.spreadsheet'.\x0a\x09\x09'odt' -> 'application/vnd.oasis.opendocument.text'.\x0a\x09\x09'ogg' -> 'application/ogg'.\x0a\x09\x09'old' -> 'application/x-trash'.\x0a\x09\x09'oth' -> 'application/vnd.oasis.opendocument.text-web'.\x0a\x09\x09'oza' -> 'application/x-oz-application'.\x0a\x09\x09'p' -> 'text/x-pascal'.\x0a\x09\x09'p7r' -> 'application/x-pkcs7-certreqresp'.\x0a\x09\x09'pac' -> 'application/x-ns-proxy-autoconfig'.\x0a\x09\x09'pas' -> 'text/x-pascal'.\x0a\x09\x09'pat' -> 'image/x-coreldrawpattern'.\x0a\x09\x09'pbm' -> 'image/x-portable-bitmap'.\x0a\x09\x09'pcf' -> 'application/x-font'.\x0a\x09\x09'pcf.Z' -> 'application/x-font'.\x0a\x09\x09'pcx' -> 'image/pcx'.\x0a\x09\x09'pdb' -> 'chemical/x-pdb'.\x0a\x09\x09'pdf' -> 'application/pdf'.\x0a\x09\x09'pfa' -> 'application/x-font'.\x0a\x09\x09'pfb' -> 'application/x-font'.\x0a\x09\x09'pgm' -> 'image/x-portable-graymap'.\x0a\x09\x09'pgn' -> 'application/x-chess-pgn'.\x0a\x09\x09'pgp' -> 'application/pgp-signature'.\x0a\x09\x09'pk' -> 'application/x-tex-pk'.\x0a\x09\x09'pl' -> 'text/x-perl'.\x0a\x09\x09'pls' -> 'audio/x-scpls'.\x0a\x09\x09'pm' -> 'text/x-perl'.\x0a\x09\x09'png' -> 'image/png'.\x0a\x09\x09'pnm' -> 'image/x-portable-anymap'.\x0a\x09\x09'pot' -> 'text/plain'.\x0a\x09\x09'ppm' -> 'image/x-portable-pixmap'.\x0a\x09\x09'pps' -> 'application/vnd.ms-powerpoint'.\x0a\x09\x09'ppt' -> 'application/vnd.ms-powerpoint'.\x0a\x09\x09'prf' -> 'application/pics-rules'.\x0a\x09\x09'prt' -> 'chemical/x-ncbi-asn1-ascii'.\x0a\x09\x09'ps' -> 'application/postscript'.\x0a\x09\x09'psd' -> 'image/x-photoshop'.\x0a\x09\x09'psp' -> 'text/x-psp'.\x0a\x09\x09'py' -> 'text/x-python'.\x0a\x09\x09'pyc' -> 'application/x-python-code'.\x0a\x09\x09'pyo' -> 'application/x-python-code'.\x0a\x09\x09'qt' -> 'video/quicktime'.\x0a\x09\x09'qtl' -> 'application/x-quicktimeplayer'.\x0a\x09\x09'ra' -> 'audio/x-realaudio'.\x0a\x09\x09'ram' -> 'audio/x-pn-realaudio'.\x0a\x09\x09'rar' -> 'application/rar'.\x0a\x09\x09'ras' -> 'image/x-cmu-raster'.\x0a\x09\x09'rd' -> 'chemical/x-mdl-rdfile'.\x0a\x09\x09'rdf' -> 'application/rdf+xml'.\x0a\x09\x09'rgb' -> 'image/x-rgb'.\x0a\x09\x09'rm' -> 'audio/x-pn-realaudio'.\x0a\x09\x09'roff' -> 'application/x-troff'.\x0a\x09\x09'ros' -> 'chemical/x-rosdal'.\x0a\x09\x09'rpm' -> 'application/x-redhat-package-manager'.\x0a\x09\x09'rss' -> 'application/rss+xml'.\x0a\x09\x09'rtf' -> 'text/rtf'.\x0a\x09\x09'rtx' -> 'text/richtext'.\x0a\x09\x09'rxn' -> 'chemical/x-mdl-rxnfile'.\x0a\x09\x09'sct' -> 'text/scriptlet'.\x0a\x09\x09'sd' -> 'chemical/x-mdl-sdfile'.\x0a\x09\x09'sd2' -> 'audio/x-sd2'.\x0a\x09\x09'sda' -> 'application/vnd.stardivision.draw'.\x0a\x09\x09'sdc' -> 'application/vnd.stardivision.calc'.\x0a\x09\x09'sdd' -> 'application/vnd.stardivision.impress'.\x0a\x09\x09'sdf' -> 'chemical/x-mdl-sdfile'.\x0a\x09\x09'sdp' -> 'application/vnd.stardivision.impress'.\x0a\x09\x09'sdw' -> 'application/vnd.stardivision.writer'.\x0a\x09\x09'ser' -> 'application/java-serialized-object'.\x0a\x09\x09'sgf' -> 'application/x-go-sgf'.\x0a\x09\x09'sgl' -> 'application/vnd.stardivision.writer-global'.\x0a\x09\x09'sh' -> 'text/x-sh'.\x0a\x09\x09'shar' -> 'application/x-shar'.\x0a\x09\x09'shtml' -> 'text/html'.\x0a\x09\x09'sid' -> 'audio/prs.sid'.\x0a\x09\x09'sik' -> 'application/x-trash'.\x0a\x09\x09'silo' -> 'model/mesh'.\x0a\x09\x09'sis' -> 'application/vnd.symbian.install'.\x0a\x09\x09'sit' -> 'application/x-stuffit'.\x0a\x09\x09'skd' -> 'application/x-koan'.\x0a\x09\x09'skm' -> 'application/x-koan'.\x0a\x09\x09'skp' -> 'application/x-koan'.\x0a\x09\x09'skt' -> 'application/x-koan'.\x0a\x09\x09'smf' -> 'application/vnd.stardivision.math'.\x0a\x09\x09'smi' -> 'application/smil'.\x0a\x09\x09'smil' -> 'application/smil'.\x0a\x09\x09'snd' -> 'audio/basic'.\x0a\x09\x09'spc' -> 'chemical/x-galactic-spc'.\x0a\x09\x09'spl' -> 'application/x-futuresplash'.\x0a\x09\x09'src' -> 'application/x-wais-source'.\x0a\x09\x09'stc' -> 'application/vnd.sun.xml.calc.template'.\x0a\x09\x09'std' -> 'application/vnd.sun.xml.draw.template'.\x0a\x09\x09'sti' -> 'application/vnd.sun.xml.impress.template'.\x0a\x09\x09'stl' -> 'application/vnd.ms-pki.stl'.\x0a\x09\x09'stw' -> 'application/vnd.sun.xml.writer.template'.\x0a\x09\x09'sty' -> 'text/x-tex'.\x0a\x09\x09'sv4cpio' -> 'application/x-sv4cpio'.\x0a\x09\x09'sv4crc' -> 'application/x-sv4crc'.\x0a\x09\x09'svg' -> 'image/svg+xml'.\x0a\x09\x09'svgz' -> 'image/svg+xml'.\x0a\x09\x09'sw' -> 'chemical/x-swissprot'.\x0a\x09\x09'swf' -> 'application/x-shockwave-flash'.\x0a\x09\x09'swfl' -> 'application/x-shockwave-flash'.\x0a\x09\x09'sxc' -> 'application/vnd.sun.xml.calc'.\x0a\x09\x09'sxd' -> 'application/vnd.sun.xml.draw'.\x0a\x09\x09'sxg' -> 'application/vnd.sun.xml.writer.global'.\x0a\x09\x09'sxi' -> 'application/vnd.sun.xml.impress'.\x0a\x09\x09'sxm' -> 'application/vnd.sun.xml.math'.\x0a\x09\x09'sxw' -> 'application/vnd.sun.xml.writer'.\x0a\x09\x09't' -> 'application/x-troff'.\x0a\x09\x09'tar' -> 'application/x-tar'.\x0a\x09\x09'taz' -> 'application/x-gtar'.\x0a\x09\x09'tcl' -> 'text/x-tcl'.\x0a\x09\x09'tex' -> 'text/x-tex'.\x0a\x09\x09'texi' -> 'application/x-texinfo'.\x0a\x09\x09'texinfo' -> 'application/x-texinfo'.\x0a\x09\x09'text' -> 'text/plain'.\x0a\x09\x09'tgf' -> 'chemical/x-mdl-tgf'.\x0a\x09\x09'tgz' -> 'application/x-gtar'.\x0a\x09\x09'tif' -> 'image/tiff'.\x0a\x09\x09'tiff' -> 'image/tiff'.\x0a\x09\x09'tk' -> 'text/x-tcl'.\x0a\x09\x09'tm' -> 'text/texmacs'.\x0a\x09\x09'torrent' -> 'application/x-bittorrent'.\x0a\x09\x09'tr' -> 'application/x-troff'.\x0a\x09\x09'ts' -> 'text/texmacs'.\x0a\x09\x09'tsp' -> 'application/dsptype'.\x0a\x09\x09'tsv' -> 'text/tab-separated-values'.\x0a\x09\x09'txt' -> 'text/plain'.\x0a\x09\x09'udeb' -> 'application/x-debian-package'.\x0a\x09\x09'uls' -> 'text/iuls'.\x0a\x09\x09'ustar' -> 'application/x-ustar'.\x0a\x09\x09'val' -> 'chemical/x-ncbi-asn1-binary'.\x0a\x09\x09'vcd' -> 'application/x-cdlink'.\x0a\x09\x09'vcf' -> 'text/x-vcard'.\x0a\x09\x09'vcs' -> 'text/x-vcalendar'.\x0a\x09\x09'vmd' -> 'chemical/x-vmd'.\x0a\x09\x09'vms' -> 'chemical/x-vamas-iso14976'.\x0a\x09\x09'vor' -> 'application/vnd.stardivision.writer'.\x0a\x09\x09'vrm' -> 'x-world/x-vrml'.\x0a\x09\x09'vrml' -> 'x-world/x-vrml'.\x0a\x09\x09'vsd' -> 'application/vnd.visio'.\x0a\x09\x09'wad' -> 'application/x-doom'.\x0a\x09\x09'wav' -> 'audio/x-wav'.\x0a\x09\x09'wax' -> 'audio/x-ms-wax'.\x0a\x09\x09'wbmp' -> 'image/vnd.wap.wbmp'.\x0a\x09\x09'wbxml' -> 'application/vnd.wap.wbxml'.\x0a\x09\x09'wk' -> 'application/x-123'.\x0a\x09\x09'wm' -> 'video/x-ms-wm'.\x0a\x09\x09'wma' -> 'audio/x-ms-wma'.\x0a\x09\x09'wmd' -> 'application/x-ms-wmd'.\x0a\x09\x09'wml' -> 'text/vnd.wap.wml'.\x0a\x09\x09'wmlc' -> 'application/vnd.wap.wmlc'.\x0a\x09\x09'wmls' -> 'text/vnd.wap.wmlscript'.\x0a\x09\x09'wmlsc' -> 'application/vnd.wap.wmlscriptc'.\x0a\x09\x09'wmv' -> 'video/x-ms-wmv'.\x0a\x09\x09'wmx' -> 'video/x-ms-wmx'.\x0a\x09\x09'wmz' -> 'application/x-ms-wmz'.\x0a\x09\x09'wp5' -> 'application/wordperfect5.1'.\x0a\x09\x09'wpd' -> 'application/wordperfect'.\x0a\x09\x09'wrl' -> 'x-world/x-vrml'.\x0a\x09\x09'wsc' -> 'text/scriptlet'.\x0a\x09\x09'wvx' -> 'video/x-ms-wvx'.\x0a\x09\x09'wz' -> 'application/x-wingz'.\x0a\x09\x09'xbm' -> 'image/x-xbitmap'.\x0a\x09\x09'xcf' -> 'application/x-xcf'.\x0a\x09\x09'xht' -> 'application/xhtml+xml'.\x0a\x09\x09'xhtml' -> 'application/xhtml+xml'.\x0a\x09\x09'xlb' -> 'application/vnd.ms-excel'.\x0a\x09\x09'xls' -> 'application/vnd.ms-excel'.\x0a\x09\x09'xlt' -> 'application/vnd.ms-excel'.\x0a\x09\x09'xml' -> 'application/xml'.\x0a\x09\x09'xpi' -> 'application/x-xpinstall'.\x0a\x09\x09'xpm' -> 'image/x-xpixmap'.\x0a\x09\x09'xsl' -> 'application/xml'.\x0a\x09\x09'xtel' -> 'chemical/x-xtel'.\x0a\x09\x09'xul' -> 'application/vnd.mozilla.xul+xml'.\x0a\x09\x09'xwd' -> 'image/x-xwindowdump'.\x0a\x09\x09'xyz' -> 'chemical/x-xyz'.\x0a\x09\x09'zip' -> 'application/zip'.\x0a\x09\x09'zmt' -> 'chemical/x-mopac-input'.\x0a\x09\x09'~' -> 'application/x-trash'\x0a\x09}",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "defaultPort",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return (4000);
- },
- args: [],
- source: "defaultPort\x0a\x09^ 4000",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "main",
- protocol: "initialization",
- fn: function (){
- var self=this;
- var fileServer,args;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- args=$recv(process)._argv();
- $recv(args)._removeFrom_to_((1),(3));
- $recv(args)._detect_ifNone_((function(each){
- return $core.withContext(function($ctx2) {
- $1=$recv(each).__eq("--help");
- if($core.assert($1)){
- return $recv($globals.FileServer)._printHelp();
- }
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }),(function(){
- return $core.withContext(function($ctx2) {
- fileServer=$recv($globals.FileServer)._createServerWithArguments_(args);
- fileServer;
- throw $early=[$recv(fileServer)._start()];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,3)});
- }));
- return self;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"main",{fileServer:fileServer,args:args},$globals.FileServer.klass)});
- },
- args: [],
- source: "main\x0a\x09\x22Main entry point for Amber applications.\x0a\x09 Creates and starts a FileServer instance.\x22\x0a\x09| fileServer args |\x0a\x09args := process argv.\x0a\x09\x22Remove the first args which contain the path to the node executable and the script file.\x22\x0a\x09args removeFrom: 1 to: 3.\x0a\x0a\x09args detect: [ :each |\x0a\x09\x09(each = '--help') ifTrue: [FileServer printHelp]]\x0a\x09ifNone: [\x0a\x09\x09fileServer := FileServer createServerWithArguments: args.\x0a\x09\x09^ fileServer start]",
- referencedClasses: ["FileServer"],
- messageSends: ["argv", "removeFrom:to:", "detect:ifNone:", "ifTrue:", "=", "printHelp", "createServerWithArguments:", "start"]
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "mimeTypeFor:",
- protocol: "accessing",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._mimeTypes())._at_ifAbsent_($recv(aString)._replace_with_(".*[\x5c.]",""),(function(){
- return "text/plain";
- }));
- }, function($ctx1) {$ctx1.fill(self,"mimeTypeFor:",{aString:aString},$globals.FileServer.klass)});
- },
- args: ["aString"],
- source: "mimeTypeFor: aString\x0a\x09^ self mimeTypes at: (aString replace: '.*[\x5c.]' with: '') ifAbsent: ['text/plain']",
- referencedClasses: [],
- messageSends: ["at:ifAbsent:", "mimeTypes", "replace:with:"]
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "mimeTypes",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@mimeTypes"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@mimeTypes"]=self._defaultMimeTypes();
- return self["@mimeTypes"];
- } else {
- return $1;
- }
- }, function($ctx1) {$ctx1.fill(self,"mimeTypes",{},$globals.FileServer.klass)});
- },
- args: [],
- source: "mimeTypes\x0a\x09^ mimeTypes ifNil: [mimeTypes := self defaultMimeTypes]",
- referencedClasses: [],
- messageSends: ["ifNil:", "defaultMimeTypes"]
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "printHelp",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(console)._log_("Available commandline options are:");
- $ctx1.sendIdx["log:"]=1;
- $recv(console)._log_("--help");
- $ctx1.sendIdx["log:"]=2;
- $recv(self._commandLineSwitches())._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(console)._log_($recv(each).__comma(" <parameter>"));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printHelp",{},$globals.FileServer.klass)});
- },
- args: [],
- source: "printHelp\x0a\x09console log: 'Available commandline options are:'.\x0a\x09console log: '--help'.\x0a\x09self commandLineSwitches do: [ :each |\x0a\x09\x09console log: each, ' <parameter>']",
- referencedClasses: [],
- messageSends: ["log:", "do:", "commandLineSwitches", ","]
- }),
- $globals.FileServer.klass);
- $core.addMethod(
- $core.method({
- selector: "selectorForCommandLineSwitch:",
- protocol: "accessing",
- fn: function (aSwitch){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($recv(aSwitch)._replace_with_("^--",""))._replace_with_("-[a-z]",(function(each){
- return $core.withContext(function($ctx2) {
- return $recv($recv(each)._second())._asUppercase();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- $ctx1.sendIdx["replace:with:"]=1;
- return $recv($1).__comma(":");
- }, function($ctx1) {$ctx1.fill(self,"selectorForCommandLineSwitch:",{aSwitch:aSwitch},$globals.FileServer.klass)});
- },
- args: ["aSwitch"],
- source: "selectorForCommandLineSwitch: aSwitch\x0a\x09\x22Remove the trailing '--', add ':' at the end\x0a\x09 and replace all occurences of a lowercase letter preceded by a '-' with\x0a\x09 the Uppercase letter.\x0a\x09 Example: --fallback-page becomes fallbackPage:\x22\x0a\x09^ ((aSwitch replace: '^--' with: '')\x0a\x09\x09replace: '-[a-z]' with: [ :each | each second asUppercase ]), ':'",
- referencedClasses: [],
- messageSends: [",", "replace:with:", "asUppercase", "second"]
- }),
- $globals.FileServer.klass);
- $core.addClass("Initer", $globals.BaseFileManipulator, ["childProcess", "nmPath"], "AmberCli");
- $core.addMethod(
- $core.method({
- selector: "bowerInstallThenDo:",
- protocol: "action",
- fn: function (aBlock){
- var self=this;
- var child;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- child=$recv(self["@childProcess"])._fork_args_(self._npmScriptForModule_named_("bower","bower"),["install"]);
- $1=child;
- $recv($1)._on_do_("error",aBlock);
- $ctx1.sendIdx["on:do:"]=1;
- $recv($1)._on_do_("close",(function(code){
- return $core.withContext(function($ctx2) {
- $3=$recv(code).__eq((0));
- if($core.assert($3)){
- $2=nil;
- } else {
- $2=code;
- }
- return $recv(aBlock)._value_($2);
- }, function($ctx2) {$ctx2.fillBlock({code:code},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"bowerInstallThenDo:",{aBlock:aBlock,child:child},$globals.Initer)});
- },
- args: ["aBlock"],
- source: "bowerInstallThenDo: aBlock\x0a\x09| child |\x0a\x09child := childProcess\x0a\x09\x09fork: (self npmScriptForModule: 'bower' named: 'bower')\x0a\x09\x09args: #('install').\x0a\x09child\x0a\x09\x09on: 'error' do: aBlock;\x0a\x09\x09on: 'close' do: [ :code |\x0a\x09\x09\x09aBlock value: (code = 0 ifTrue: [ nil ] ifFalse: [ code ]) ]",
- referencedClasses: [],
- messageSends: ["fork:args:", "npmScriptForModule:named:", "on:do:", "value:", "ifTrue:ifFalse:", "="]
- }),
- $globals.Initer);
- $core.addMethod(
- $core.method({
- selector: "finishMessage",
- protocol: "action",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(console)._log_([" ", "The project should now be set up.", " ", " "]._join_($recv($globals.String)._lf()));
- $recv((function(){
- }))._valueWithTimeout_((600));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"finishMessage",{},$globals.Initer)});
- },
- args: [],
- source: "finishMessage\x0a\x09console log: (#(\x0a\x09\x09' '\x0a\x09\x09'The project should now be set up.'\x0a\x09\x09' '\x0a\x09\x09' '\x0a\x09) join: String lf).\x0a\x09[] valueWithTimeout: 600",
- referencedClasses: ["String"],
- messageSends: ["log:", "join:", "lf", "valueWithTimeout:"]
- }),
- $globals.Initer);
- $core.addMethod(
- $core.method({
- selector: "gruntInitThenDo:",
- protocol: "action",
- fn: function (aBlock){
- var self=this;
- var child,sanitizedTemplatePath;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- sanitizedTemplatePath=$recv($recv($recv(self["@path"])._join_with_(self["@nmPath"],"grunt-init-amber"))._replace_with_("\x5c\x5c","\x5c\x5c"))._replace_with_(":","\x5c:");
- $ctx1.sendIdx["replace:with:"]=1;
- child=$recv(self["@childProcess"])._fork_args_(self._npmScriptForModule_named_("grunt-init","grunt-init"),[sanitizedTemplatePath]);
- $1=child;
- $recv($1)._on_do_("error",aBlock);
- $ctx1.sendIdx["on:do:"]=1;
- $recv($1)._on_do_("close",(function(code){
- return $core.withContext(function($ctx2) {
- $3=$recv(code).__eq((0));
- if($core.assert($3)){
- $2=nil;
- } else {
- $2=code;
- }
- return $recv(aBlock)._value_($2);
- }, function($ctx2) {$ctx2.fillBlock({code:code},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"gruntInitThenDo:",{aBlock:aBlock,child:child,sanitizedTemplatePath:sanitizedTemplatePath},$globals.Initer)});
- },
- args: ["aBlock"],
- source: "gruntInitThenDo: aBlock\x0a\x09| child sanitizedTemplatePath |\x0a\x09sanitizedTemplatePath := ((path join: nmPath with: 'grunt-init-amber')\x0a\x09\x09replace: '\x5c\x5c' with: '\x5c\x5c') replace: ':' with: '\x5c:'.\x0a\x09child := childProcess\x0a\x09\x09fork: (self npmScriptForModule: 'grunt-init' named: 'grunt-init')\x0a\x09\x09args: {sanitizedTemplatePath}.\x0a\x09child\x0a\x09\x09on: 'error' do: aBlock;\x0a\x09\x09on: 'close' do: [ :code |\x0a\x09\x09\x09aBlock value: (code = 0 ifTrue: [ nil ] ifFalse: [ code ]) ]",
- referencedClasses: [],
- messageSends: ["replace:with:", "join:with:", "fork:args:", "npmScriptForModule:named:", "on:do:", "value:", "ifTrue:ifFalse:", "="]
- }),
- $globals.Initer);
- $core.addMethod(
- $core.method({
- selector: "gruntThenDo:",
- protocol: "action",
- fn: function (aBlock){
- var self=this;
- var child;
- return $core.withContext(function($ctx1) {
- var $1,$3,$2;
- child=$recv(self["@childProcess"])._fork_args_(self._npmScriptForModule_named_("grunt-cli","grunt"),["default", "devel"]);
- $1=child;
- $recv($1)._on_do_("error",aBlock);
- $ctx1.sendIdx["on:do:"]=1;
- $recv($1)._on_do_("close",(function(code){
- return $core.withContext(function($ctx2) {
- $3=$recv(code).__eq((0));
- if($core.assert($3)){
- $2=nil;
- } else {
- $2=code;
- }
- return $recv(aBlock)._value_($2);
- }, function($ctx2) {$ctx2.fillBlock({code:code},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"gruntThenDo:",{aBlock:aBlock,child:child},$globals.Initer)});
- },
- args: ["aBlock"],
- source: "gruntThenDo: aBlock\x0a\x09| child |\x0a\x09child := childProcess\x0a\x09\x09fork: (self npmScriptForModule: 'grunt-cli' named: 'grunt')\x0a\x09\x09args: #('default' 'devel').\x0a\x09child\x0a\x09\x09on: 'error' do: aBlock;\x0a\x09\x09on: 'close' do: [ :code |\x0a\x09\x09\x09aBlock value: (code = 0 ifTrue: [ nil ] ifFalse: [ code ]) ]",
- referencedClasses: [],
- messageSends: ["fork:args:", "npmScriptForModule:named:", "on:do:", "value:", "ifTrue:ifFalse:", "="]
- }),
- $globals.Initer);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Initer.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@childProcess"]=$recv(require)._value_("child_process");
- self["@nmPath"]=$recv(self["@path"])._join_with_(self._rootDirname(),"node_modules");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Initer)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09childProcess := require value: 'child_process'.\x0a\x09nmPath := path join: self rootDirname with: 'node_modules'",
- referencedClasses: [],
- messageSends: ["initialize", "value:", "join:with:", "rootDirname"]
- }),
- $globals.Initer);
- $core.addMethod(
- $core.method({
- selector: "npmInstallThenDo:",
- protocol: "action",
- fn: function (aBlock){
- var self=this;
- var child;
- return $core.withContext(function($ctx1) {
- var $1;
- child=$recv(self["@childProcess"])._exec_thenDo_("npm install",aBlock);
- $1=$recv(child)._stdout();
- $ctx1.sendIdx["stdout"]=1;
- $recv($1)._pipe_options_($recv(process)._stdout(),$globals.HashedCollection._newFromPairs_(["end",false]));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"npmInstallThenDo:",{aBlock:aBlock,child:child},$globals.Initer)});
- },
- args: ["aBlock"],
- source: "npmInstallThenDo: aBlock\x0a\x09| child |\x0a\x09child := childProcess\x0a\x09\x09exec: 'npm install'\x0a\x09\x09thenDo: aBlock.\x0a\x09child stdout pipe: process stdout options: #{ 'end' -> false }",
- referencedClasses: [],
- messageSends: ["exec:thenDo:", "pipe:options:", "stdout"]
- }),
- $globals.Initer);
- $core.addMethod(
- $core.method({
- selector: "npmScriptForModule:named:",
- protocol: "npm",
- fn: function (aString,anotherString){
- var self=this;
- var modulePath,packageJson,binSection,scriptPath;
- return $core.withContext(function($ctx1) {
- var $1,$3,$4,$2,$5;
- $1=self["@path"];
- $3=$recv($globals.JSObjectProxy)._on_(require);
- $4=$recv(aString).__comma("/package.json");
- $ctx1.sendIdx[","]=1;
- $2=$recv($3)._resolve_($4);
- modulePath=$recv($1)._dirname_($2);
- packageJson=$recv($globals.Smalltalk)._readJSObject_($recv(require)._value_($recv(aString).__comma("/package.json")));
- binSection=$recv(packageJson)._at_("bin");
- $ctx1.sendIdx["at:"]=1;
- $5=$recv(binSection)._isString();
- if($core.assert($5)){
- scriptPath=binSection;
- } else {
- scriptPath=$recv(binSection)._at_(anotherString);
- }
- return $recv(self["@path"])._join_with_(modulePath,scriptPath);
- }, function($ctx1) {$ctx1.fill(self,"npmScriptForModule:named:",{aString:aString,anotherString:anotherString,modulePath:modulePath,packageJson:packageJson,binSection:binSection,scriptPath:scriptPath},$globals.Initer)});
- },
- args: ["aString", "anotherString"],
- source: "npmScriptForModule: aString named: anotherString\x0a\x09| modulePath packageJson binSection scriptPath |\x0a\x09modulePath := path dirname: (\x0a\x09\x09(JSObjectProxy on: require)\x0a\x09\x09\x09resolve: aString, '/package.json').\x0a\x09packageJson := Smalltalk readJSObject: (\x0a\x09\x09require value: aString, '/package.json').\x0a\x09binSection := packageJson at: 'bin'.\x0a\x09scriptPath := binSection isString\x0a\x09\x09ifTrue: [ binSection ]\x0a\x09\x09ifFalse: [ binSection at: anotherString ].\x0a\x09^ path join: modulePath with: scriptPath",
- referencedClasses: ["JSObjectProxy", "Smalltalk"],
- messageSends: ["dirname:", "resolve:", "on:", ",", "readJSObject:", "value:", "at:", "ifTrue:ifFalse:", "isString", "join:with:"]
- }),
- $globals.Initer);
- $core.addMethod(
- $core.method({
- selector: "start",
- protocol: "action",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$3,$4,$5,$6,$7,$receiver;
- self._gruntInitThenDo_((function(error){
- return $core.withContext(function($ctx2) {
- if(($receiver = error) == null || $receiver.isNil){
- return self._bowerInstallThenDo_((function(error2){
- return $core.withContext(function($ctx3) {
- if(($receiver = error2) == null || $receiver.isNil){
- return self._npmInstallThenDo_((function(error3){
- return $core.withContext(function($ctx4) {
- if(($receiver = error3) == null || $receiver.isNil){
- return self._gruntThenDo_((function(error4){
- return $core.withContext(function($ctx5) {
- if(($receiver = error4) == null || $receiver.isNil){
- self._finishMessage();
- return $recv(process)._exit();
- } else {
- $7=console;
- $recv($7)._log_("grunt exec error:");
- $ctx5.sendIdx["log:"]=7;
- $recv($7)._log_(error4);
- return $recv(process)._exit_((104));
- }
- }, function($ctx5) {$ctx5.fillBlock({error4:error4},$ctx4,10)});
- }));
- } else {
- $5=console;
- $recv($5)._log_("npm install exec error:");
- $ctx4.sendIdx["log:"]=5;
- $6=$recv($5)._log_(error3);
- $ctx4.sendIdx["log:"]=6;
- $6;
- return $recv(process)._exit_((103));
- $ctx4.sendIdx["exit:"]=3;
- }
- }, function($ctx4) {$ctx4.fillBlock({error3:error3},$ctx3,7)});
- }));
- } else {
- $3=console;
- $recv($3)._log_("bower install exec error:");
- $ctx3.sendIdx["log:"]=3;
- $4=$recv($3)._log_(error2);
- $ctx3.sendIdx["log:"]=4;
- $4;
- return $recv(process)._exit_((102));
- $ctx3.sendIdx["exit:"]=2;
- }
- }, function($ctx3) {$ctx3.fillBlock({error2:error2},$ctx2,4)});
- }));
- } else {
- $1=console;
- $recv($1)._log_("grunt-init exec error:");
- $ctx2.sendIdx["log:"]=1;
- $2=$recv($1)._log_(error);
- $ctx2.sendIdx["log:"]=2;
- $2;
- return $recv(process)._exit_((101));
- $ctx2.sendIdx["exit:"]=1;
- }
- }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"start",{},$globals.Initer)});
- },
- args: [],
- source: "start\x0a\x09self gruntInitThenDo: [ :error | error\x0a\x09ifNotNil: [\x0a\x09\x09console log: 'grunt-init exec error:'; log: error.\x0a\x09\x09process exit: 101 ]\x0a\x09ifNil: [\x0a\x0a\x09self bowerInstallThenDo: [ :error2 | error2\x0a\x09ifNotNil: [\x0a\x09\x09console log: 'bower install exec error:'; log: error2.\x0a\x09\x09process exit: 102 ]\x0a\x09ifNil: [\x0a\x0a\x09self npmInstallThenDo: [ :error3 | error3\x0a\x09ifNotNil: [\x0a\x09\x09console log: 'npm install exec error:'; log: error3.\x0a\x09\x09process exit: 103 ]\x0a\x09ifNil: [\x0a\x0a\x09self gruntThenDo: [ :error4 | error4\x0a\x09ifNotNil: [\x0a\x09\x09console log: 'grunt exec error:'; log: error4.\x0a\x09\x09process exit: 104 ]\x0a\x09ifNil: [\x0a\x0a\x09self finishMessage.\x0a\x09process exit ]]]]]]]]",
- referencedClasses: [],
- messageSends: ["gruntInitThenDo:", "ifNotNil:ifNil:", "log:", "exit:", "bowerInstallThenDo:", "npmInstallThenDo:", "gruntThenDo:", "finishMessage", "exit"]
- }),
- $globals.Initer);
- $core.addClass("Repl", $globals.Object, ["readline", "interface", "util", "session", "resultCount", "commands"], "AmberCli");
- $globals.Repl.comment="I am a class representing a REPL (Read Evaluate Print Loop) and provide a command line interface to Amber Smalltalk.\x0aOn the prompt you can type Amber statements which will be evaluated after pressing <Enter>.\x0aThe evaluation is comparable with executing a 'DoIt' in a workspace.\x0a\x0aMy runtime requirement is a functional Node.js executable with working Readline support.";
- $core.addMethod(
- $core.method({
- selector: "addVariableNamed:to:",
- protocol: "private",
- fn: function (aString,anObject){
- var self=this;
- var newClass,newObject;
- return $core.withContext(function($ctx1) {
- newClass=self._subclass_withVariable_($recv(anObject)._class(),aString);
- self._encapsulateVariable_withValue_in_(aString,anObject,newClass);
- newObject=$recv(newClass)._new();
- self._setPreviousVariablesFor_from_(newObject,anObject);
- return newObject;
- }, function($ctx1) {$ctx1.fill(self,"addVariableNamed:to:",{aString:aString,anObject:anObject,newClass:newClass,newObject:newObject},$globals.Repl)});
- },
- args: ["aString", "anObject"],
- source: "addVariableNamed: aString to: anObject\x0a\x09| newClass newObject |\x0a\x09newClass := self subclass: anObject class withVariable: aString.\x0a\x09self encapsulateVariable: aString withValue: anObject in: newClass.\x0a\x09newObject := newClass new.\x0a\x09self setPreviousVariablesFor: newObject from: anObject.\x0a\x09^ newObject",
- referencedClasses: [],
- messageSends: ["subclass:withVariable:", "class", "encapsulateVariable:withValue:in:", "new", "setPreviousVariablesFor:from:"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "assignNewVariable:do:",
- protocol: "private",
- fn: function (buffer,aBlock){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$3,$1,$receiver;
- return self._parseAssignment_do_(buffer,(function(name,expr){
- var varName,value;
- return $core.withContext(function($ctx2) {
- if(($receiver = name) == null || $receiver.isNil){
- varName=self._nextResultName();
- } else {
- varName=name;
- }
- varName;
- self["@session"]=self._addVariableNamed_to_(varName,self["@session"]);
- self["@session"];
- $recv((function(){
- return $core.withContext(function($ctx3) {
- $2=$recv(varName).__comma(" := ");
- if(($receiver = expr) == null || $receiver.isNil){
- $3=buffer;
- } else {
- $3=expr;
- }
- $1=$recv($2).__comma($3);
- $ctx3.sendIdx[","]=1;
- value=self._eval_on_($1,self["@session"]);
- return value;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)});
- }))._on_do_($globals.Error,(function(e){
- return $core.withContext(function($ctx3) {
- $recv($recv($globals.ConsoleErrorHandler)._new())._logError_(e);
- value=nil;
- return value;
- }, function($ctx3) {$ctx3.fillBlock({e:e},$ctx2,5)});
- }));
- return $recv(aBlock)._value_value_(varName,value);
- }, function($ctx2) {$ctx2.fillBlock({name:name,expr:expr,varName:varName,value:value},$ctx1,1)});
- }));
- }, function($ctx1) {$ctx1.fill(self,"assignNewVariable:do:",{buffer:buffer,aBlock:aBlock},$globals.Repl)});
- },
- args: ["buffer", "aBlock"],
- source: "assignNewVariable: buffer do: aBlock\x0a\x09\x22Assigns a new variable and calls the given block with the variable's name and value\x0a\x09 if buffer contains an assignment expression. If it doesn't the block is called with nil for\x0a\x09 both arguments.\x22\x0a\x09^ self parseAssignment: buffer do: [ :name :expr || varName value |\x0a\x09\x09varName := name ifNil: [self nextResultName].\x0a\x09\x09session := self addVariableNamed: varName to: session.\x0a\x09\x09[ value := self eval: varName, ' := ', (expr ifNil: [buffer]) on: session ]\x0a\x09\x09\x09on: Error\x0a\x09\x09\x09do: [ :e | ConsoleErrorHandler new logError: e. value := nil].\x0a\x09\x09aBlock value: varName value: value]",
- referencedClasses: ["Error", "ConsoleErrorHandler"],
- messageSends: ["parseAssignment:do:", "ifNil:", "nextResultName", "addVariableNamed:to:", "on:do:", "eval:on:", ",", "logError:", "new", "value:value:"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "clearScreen",
- protocol: "actions",
- fn: function (){
- var self=this;
- var esc,cls;
- return $core.withContext(function($ctx1) {
- var $1;
- esc=$recv($globals.String)._fromCharCode_((27));
- $1=$recv($recv(esc).__comma("[2J")).__comma(esc);
- $ctx1.sendIdx[","]=2;
- cls=$recv($1).__comma("[0;0f");
- $ctx1.sendIdx[","]=1;
- $recv($recv(process)._stdout())._write_(cls);
- $recv(self["@interface"])._prompt();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"clearScreen",{esc:esc,cls:cls},$globals.Repl)});
- },
- args: [],
- source: "clearScreen\x0a\x09| esc cls |\x0a\x09esc := String fromCharCode: 27.\x0a\x09cls := esc, '[2J', esc, '[0;0f'.\x0a\x09process stdout write: cls.\x0a\x09interface prompt",
- referencedClasses: ["String"],
- messageSends: ["fromCharCode:", ",", "write:", "stdout", "prompt"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "close",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($recv(process)._stdin())._destroy();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"close",{},$globals.Repl)});
- },
- args: [],
- source: "close\x0a\x09process stdin destroy",
- referencedClasses: [],
- messageSends: ["destroy", "stdin"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "commands",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return self["@commands"];
- },
- args: [],
- source: "commands\x0a\x09^ commands",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "createInterface",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- self["@interface"]=$recv(self["@readline"])._createInterface_stdout_($recv(process)._stdin(),$recv(process)._stdout());
- $recv(self["@interface"])._on_do_("line",(function(buffer){
- return $core.withContext(function($ctx2) {
- return self._processLine_(buffer);
- }, function($ctx2) {$ctx2.fillBlock({buffer:buffer},$ctx1,1)});
- }));
- $ctx1.sendIdx["on:do:"]=1;
- $recv(self["@interface"])._on_do_("close",(function(){
- return $core.withContext(function($ctx2) {
- return self._close();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- self._printWelcome();
- self._setupHotkeys();
- self._setPrompt();
- $recv(self["@interface"])._prompt();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"createInterface",{},$globals.Repl)});
- },
- args: [],
- source: "createInterface\x0a\x09interface := readline createInterface: process stdin stdout: process stdout.\x0a\x09interface on: 'line' do: [:buffer | self processLine: buffer].\x0a\x09interface on: 'close' do: [self close].\x0a\x09self printWelcome; setupHotkeys; setPrompt.\x0a\x09interface prompt",
- referencedClasses: [],
- messageSends: ["createInterface:stdout:", "stdin", "stdout", "on:do:", "processLine:", "close", "printWelcome", "setupHotkeys", "setPrompt", "prompt"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "encapsulateVariable:withValue:in:",
- protocol: "private",
- fn: function (aString,anObject,aClass){
- var self=this;
- var compiler;
- return $core.withContext(function($ctx1) {
- var $1,$4,$3,$2,$5,$6;
- compiler=$recv($globals.Compiler)._new();
- $1=compiler;
- $4=$recv(aString).__comma(": anObject ^ ");
- $ctx1.sendIdx[","]=3;
- $3=$recv($4).__comma(aString);
- $ctx1.sendIdx[","]=2;
- $2=$recv($3).__comma(" := anObject");
- $ctx1.sendIdx[","]=1;
- $recv($1)._install_forClass_protocol_($2,aClass,"session");
- $ctx1.sendIdx["install:forClass:protocol:"]=1;
- $5=compiler;
- $6=$recv($recv(aString).__comma(" ^ ")).__comma(aString);
- $ctx1.sendIdx[","]=4;
- $recv($5)._install_forClass_protocol_($6,aClass,"session");
- return self;
- }, function($ctx1) {$ctx1.fill(self,"encapsulateVariable:withValue:in:",{aString:aString,anObject:anObject,aClass:aClass,compiler:compiler},$globals.Repl)});
- },
- args: ["aString", "anObject", "aClass"],
- source: "encapsulateVariable: aString withValue: anObject in: aClass\x0a\x09\x22Add getter and setter for given variable to session.\x22\x0a\x09| compiler |\x0a\x09compiler := Compiler new.\x0a\x09compiler install: aString, ': anObject ^ ', aString, ' := anObject' forClass: aClass protocol: 'session'.\x0a\x09compiler install: aString, ' ^ ', aString forClass: aClass protocol: 'session'.",
- referencedClasses: ["Compiler"],
- messageSends: ["new", "install:forClass:protocol:", ","]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "eval:",
- protocol: "actions",
- fn: function (buffer){
- var self=this;
- return $core.withContext(function($ctx1) {
- return self._eval_on_(buffer,$recv($globals.DoIt)._new());
- }, function($ctx1) {$ctx1.fill(self,"eval:",{buffer:buffer},$globals.Repl)});
- },
- args: ["buffer"],
- source: "eval: buffer\x0a\x09^ self eval: buffer on: DoIt new.",
- referencedClasses: ["DoIt"],
- messageSends: ["eval:on:", "new"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "eval:on:",
- protocol: "actions",
- fn: function (buffer,anObject){
- var self=this;
- var result;
- return $core.withContext(function($ctx1) {
- var $1;
- $recv(buffer)._ifNotEmpty_((function(){
- return $core.withContext(function($ctx2) {
- return $recv((function(){
- return $core.withContext(function($ctx3) {
- result=$recv($recv($globals.Compiler)._new())._evaluateExpression_on_(buffer,anObject);
- return result;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)});
- }))._tryCatch_((function(e){
- return $core.withContext(function($ctx3) {
- $1=$recv(e)._isSmalltalkError();
- if($core.assert($1)){
- return $recv(e)._resignal();
- } else {
- return $recv($recv(process)._stdout())._write_($recv(e)._jsStack());
- }
- }, function($ctx3) {$ctx3.fillBlock({e:e},$ctx2,3)});
- }));
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- return result;
- }, function($ctx1) {$ctx1.fill(self,"eval:on:",{buffer:buffer,anObject:anObject,result:result},$globals.Repl)});
- },
- args: ["buffer", "anObject"],
- source: "eval: buffer on: anObject\x0a\x09| result |\x0a\x09buffer ifNotEmpty: [\x0a\x09\x09[result := Compiler new evaluateExpression: buffer on: anObject]\x0a\x09\x09\x09tryCatch: [:e |\x0a\x09\x09\x09\x09e isSmalltalkError\x0a\x09\x09\x09\x09\x09ifTrue: [ e resignal ]\x0a\x09\x09\x09\x09\x09ifFalse: [ process stdout write: e jsStack ]]].\x0a\x09^ result",
- referencedClasses: ["Compiler"],
- messageSends: ["ifNotEmpty:", "tryCatch:", "evaluateExpression:on:", "new", "ifTrue:ifFalse:", "isSmalltalkError", "resignal", "write:", "stdout", "jsStack"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "executeCommand:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- $recv(self._commands())._keysAndValuesDo_((function(names,cmd){
- return $core.withContext(function($ctx2) {
- $1=$recv(names)._includes_(aString);
- if($core.assert($1)){
- $recv(cmd)._value();
- throw $early=[true];
- }
- }, function($ctx2) {$ctx2.fillBlock({names:names,cmd:cmd},$ctx1,1)});
- }));
- return false;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- }, function($ctx1) {$ctx1.fill(self,"executeCommand:",{aString:aString},$globals.Repl)});
- },
- args: ["aString"],
- source: "executeCommand: aString\x0a\x09\x22Tries to process the given string as a command. Returns true if it was a command, false if not.\x22\x0a\x09self commands keysAndValuesDo: [:names :cmd |\x0a\x09\x09(names includes: aString) ifTrue: [\x0a\x09\x09\x09cmd value.\x0a\x09\x09\x09^ true]].\x0a\x09^ false",
- referencedClasses: [],
- messageSends: ["keysAndValuesDo:", "commands", "ifTrue:", "includes:", "value"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "initialize",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- (
- $ctx1.supercall = true,
- ($globals.Repl.superclass||$boot.nilAsClass).fn.prototype._initialize.apply($recv(self), []));
- $ctx1.supercall = false;
- self["@session"]=$recv($globals.DoIt)._new();
- self["@readline"]=$recv(require)._value_("readline");
- $ctx1.sendIdx["value:"]=1;
- self["@util"]=$recv(require)._value_("util");
- self._setupCommands();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"initialize",{},$globals.Repl)});
- },
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09session := DoIt new.\x0a\x09readline := require value: 'readline'.\x0a\x09util := require value: 'util'.\x0a\x09self setupCommands",
- referencedClasses: ["DoIt"],
- messageSends: ["initialize", "new", "value:", "setupCommands"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "instanceVariableNamesFor:",
- protocol: "private",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$2,$receiver;
- $1=$recv(aClass)._superclass();
- $ctx1.sendIdx["superclass"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return $recv(aClass)._instanceVariableNames();
- } else {
- $2=$recv(aClass)._instanceVariableNames();
- $ctx1.sendIdx["instanceVariableNames"]=1;
- return $recv($2)._copyWithAll_(self._instanceVariableNamesFor_($recv(aClass)._superclass()));
- }
- }, function($ctx1) {$ctx1.fill(self,"instanceVariableNamesFor:",{aClass:aClass},$globals.Repl)});
- },
- args: ["aClass"],
- source: "instanceVariableNamesFor: aClass\x0a\x09\x22Yields all instance variable names for the given class, including inherited ones.\x22\x0a\x09^ aClass superclass\x0a\x09\x09ifNotNil: [\x0a\x09\x09\x09aClass instanceVariableNames copyWithAll: (self instanceVariableNamesFor: aClass superclass)]\x0a\x09\x09ifNil: [\x0a\x09\x09\x09aClass instanceVariableNames]",
- referencedClasses: [],
- messageSends: ["ifNotNil:ifNil:", "superclass", "copyWithAll:", "instanceVariableNames", "instanceVariableNamesFor:"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "isIdentifier:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(aString)._match_("^[a-z_]\x5cw*$"._asRegexp());
- }, function($ctx1) {$ctx1.fill(self,"isIdentifier:",{aString:aString},$globals.Repl)});
- },
- args: ["aString"],
- source: "isIdentifier: aString\x0a\x09^ aString match: '^[a-z_]\x5cw*$' asRegexp",
- referencedClasses: [],
- messageSends: ["match:", "asRegexp"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "isVariableDefined:",
- protocol: "private",
- fn: function (aString){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv(self._instanceVariableNamesFor_($recv(self["@session"])._class()))._includes_(aString);
- }, function($ctx1) {$ctx1.fill(self,"isVariableDefined:",{aString:aString},$globals.Repl)});
- },
- args: ["aString"],
- source: "isVariableDefined: aString\x0a\x09^ (self instanceVariableNamesFor: session class) includes: aString",
- referencedClasses: [],
- messageSends: ["includes:", "instanceVariableNamesFor:", "class"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "nextResultName",
- protocol: "private",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1,$receiver;
- $1=self["@resultCount"];
- if(($receiver = $1) == null || $receiver.isNil){
- self["@resultCount"]=(1);
- } else {
- self["@resultCount"]=$recv(self["@resultCount"]).__plus((1));
- }
- return "res".__comma($recv(self["@resultCount"])._asString());
- }, function($ctx1) {$ctx1.fill(self,"nextResultName",{},$globals.Repl)});
- },
- args: [],
- source: "nextResultName\x0a\x09resultCount := resultCount\x0a \x09ifNotNil: [resultCount + 1]\x0a \x09ifNil: [1].\x0a ^ 'res', resultCount asString",
- referencedClasses: [],
- messageSends: ["ifNotNil:ifNil:", "+", ",", "asString"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "onKeyPress:",
- protocol: "private",
- fn: function (key){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $1;
- $1=$recv($recv(key)._ctrl())._and_((function(){
- return $core.withContext(function($ctx2) {
- return $recv($recv(key)._name()).__eq("l");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- if($core.assert($1)){
- self._clearScreen();
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"onKeyPress:",{key:key},$globals.Repl)});
- },
- args: ["key"],
- source: "onKeyPress: key\x0a\x09(key ctrl and: [key name = 'l'])\x0a\x09\x09ifTrue: [self clearScreen]",
- referencedClasses: [],
- messageSends: ["ifTrue:", "and:", "ctrl", "=", "name", "clearScreen"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "parseAssignment:do:",
- protocol: "private",
- fn: function (aString,aBlock){
- var self=this;
- var assignment;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- assignment=$recv($recv(aString)._tokenize_(":="))._collect_((function(s){
- return $core.withContext(function($ctx2) {
- return $recv(s)._trimBoth();
- }, function($ctx2) {$ctx2.fillBlock({s:s},$ctx1,1)});
- }));
- $1=$recv($recv($recv(assignment)._size()).__eq((2)))._and_((function(){
- return $core.withContext(function($ctx2) {
- $2=$recv(assignment)._first();
- $ctx2.sendIdx["first"]=1;
- return self._isIdentifier_($2);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }));
- if($core.assert($1)){
- return $recv(aBlock)._value_value_($recv(assignment)._first(),$recv(assignment)._last());
- $ctx1.sendIdx["value:value:"]=1;
- } else {
- return $recv(aBlock)._value_value_(nil,nil);
- }
- }, function($ctx1) {$ctx1.fill(self,"parseAssignment:do:",{aString:aString,aBlock:aBlock,assignment:assignment},$globals.Repl)});
- },
- args: ["aString", "aBlock"],
- source: "parseAssignment: aString do: aBlock\x0a\x09\x22Assigns a new variable if the given string is an assignment expression. Calls the given block with name and value.\x0a\x09 If the string is not one no variable will be assigned and the block will be called with nil for both arguments.\x22\x0a\x09| assignment |\x0a\x09assignment := (aString tokenize: ':=') collect: [:s | s trimBoth].\x0a\x09^ (assignment size = 2 and: [self isIdentifier: assignment first])\x0a\x09\x09ifTrue: [ aBlock value: assignment first value: assignment last ]\x0a\x09\x09ifFalse: [ aBlock value: nil value: nil ]",
- referencedClasses: [],
- messageSends: ["collect:", "tokenize:", "trimBoth", "ifTrue:ifFalse:", "and:", "=", "size", "isIdentifier:", "first", "value:value:", "last"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "presentResultNamed:withValue:",
- protocol: "private",
- fn: function (varName,value){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=$recv($recv(varName).__comma(": ")).__comma($recv($recv(value)._class())._name());
- $ctx1.sendIdx[","]=3;
- $2=$recv($3).__comma(" = ");
- $ctx1.sendIdx[","]=2;
- $1=$recv($2).__comma($recv(value)._asString());
- $ctx1.sendIdx[","]=1;
- $recv($globals.Transcript)._show_($1);
- $recv($globals.Transcript)._cr();
- $recv(self["@interface"])._prompt();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"presentResultNamed:withValue:",{varName:varName,value:value},$globals.Repl)});
- },
- args: ["varName", "value"],
- source: "presentResultNamed: varName withValue: value\x0a\x09Transcript show: varName, ': ', value class name, ' = ', value asString; cr.\x0a\x09interface prompt",
- referencedClasses: ["Transcript"],
- messageSends: ["show:", ",", "name", "class", "asString", "cr", "prompt"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "printWelcome",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv($globals.Transcript)._show_("Type :q to exit.");
- $recv($globals.Transcript)._cr();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"printWelcome",{},$globals.Repl)});
- },
- args: [],
- source: "printWelcome\x0a\x09Transcript show: 'Type :q to exit.'; cr.",
- referencedClasses: ["Transcript"],
- messageSends: ["show:", "cr"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "processLine:",
- protocol: "private",
- fn: function (buffer){
- var self=this;
- var show;
- return $core.withContext(function($ctx1) {
- var $1,$2;
- show=(function(varName,value){
- return $core.withContext(function($ctx2) {
- return self._presentResultNamed_withValue_(varName,value);
- }, function($ctx2) {$ctx2.fillBlock({varName:varName,value:value},$ctx1,1)});
- });
- $1=self._executeCommand_(buffer);
- if(!$core.assert($1)){
- $2=self._isVariableDefined_(buffer);
- if($core.assert($2)){
- $recv(show)._value_value_(buffer,$recv(self["@session"])._perform_(buffer));
- } else {
- self._assignNewVariable_do_(buffer,show);
- }
- }
- return self;
- }, function($ctx1) {$ctx1.fill(self,"processLine:",{buffer:buffer,show:show},$globals.Repl)});
- },
- args: ["buffer"],
- source: "processLine: buffer\x0a\x09\x22Processes lines entered through the readline interface.\x22\x0a\x09| show |\x0a\x09show := [:varName :value | self presentResultNamed: varName withValue: value].\x0a\x09(self executeCommand: buffer) ifFalse: [\x0a\x09\x09(self isVariableDefined: buffer)\x0a\x09\x09\x09ifTrue: [show value: buffer value: (session perform: buffer)]\x0a\x09\x09\x09ifFalse: [self assignNewVariable: buffer do: show]]",
- referencedClasses: [],
- messageSends: ["presentResultNamed:withValue:", "ifFalse:", "executeCommand:", "ifTrue:ifFalse:", "isVariableDefined:", "value:value:", "perform:", "assignNewVariable:do:"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "prompt",
- protocol: "accessing",
- fn: function (){
- var self=this;
- return "amber >> ";
- },
- args: [],
- source: "prompt\x0a\x09^ 'amber >> '",
- referencedClasses: [],
- messageSends: []
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "setPreviousVariablesFor:from:",
- protocol: "private",
- fn: function (newObject,oldObject){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._instanceVariableNamesFor_($recv(oldObject)._class()))._do_((function(each){
- return $core.withContext(function($ctx2) {
- return $recv(newObject)._perform_withArguments_($recv(each).__comma(":"),[$recv(oldObject)._perform_(each)]);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setPreviousVariablesFor:from:",{newObject:newObject,oldObject:oldObject},$globals.Repl)});
- },
- args: ["newObject", "oldObject"],
- source: "setPreviousVariablesFor: newObject from: oldObject\x0a\x09(self instanceVariableNamesFor: oldObject class) do: [:each |\x0a\x09\x09newObject perform: each, ':' withArguments: {oldObject perform: each}].",
- referencedClasses: [],
- messageSends: ["do:", "instanceVariableNamesFor:", "class", "perform:withArguments:", ",", "perform:"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "setPrompt",
- protocol: "actions",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self["@interface"])._setPrompt_(self._prompt());
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setPrompt",{},$globals.Repl)});
- },
- args: [],
- source: "setPrompt\x0a\x09interface setPrompt: self prompt",
- referencedClasses: [],
- messageSends: ["setPrompt:", "prompt"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "setupCommands",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1;
- $2=$recv([":q"]).__minus_gt((function(){
- return $core.withContext(function($ctx2) {
- return $recv(process)._exit();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
- }));
- $ctx1.sendIdx["->"]=1;
- $1=[$2,$recv([""]).__minus_gt((function(){
- return $core.withContext(function($ctx2) {
- return $recv(self["@interface"])._prompt();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)});
- }))];
- self["@commands"]=$recv($globals.Dictionary)._from_($1);
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setupCommands",{},$globals.Repl)});
- },
- args: [],
- source: "setupCommands\x0a\x09commands := Dictionary from: {\x0a\x09\x09{':q'} -> [process exit].\x0a\x09\x09{''} -> [interface prompt]}",
- referencedClasses: ["Dictionary"],
- messageSends: ["from:", "->", "exit", "prompt"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "setupHotkeys",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $receiver;
- $recv($recv(process)._stdin())._on_do_("keypress",(function(s,key){
- return $core.withContext(function($ctx2) {
- if(($receiver = key) == null || $receiver.isNil){
- return key;
- } else {
- return self._onKeyPress_(key);
- }
- }, function($ctx2) {$ctx2.fillBlock({s:s,key:key},$ctx1,1)});
- }));
- return self;
- }, function($ctx1) {$ctx1.fill(self,"setupHotkeys",{},$globals.Repl)});
- },
- args: [],
- source: "setupHotkeys\x0a\x09process stdin on: 'keypress' do: [:s :key | key ifNotNil: [self onKeyPress: key]].",
- referencedClasses: [],
- messageSends: ["on:do:", "stdin", "ifNotNil:", "onKeyPress:"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "subclass:withVariable:",
- protocol: "private",
- fn: function (aClass,varName){
- var self=this;
- return $core.withContext(function($ctx1) {
- return $recv($recv($globals.ClassBuilder)._new())._addSubclassOf_named_instanceVariableNames_package_(aClass,$recv(self._subclassNameFor_(aClass))._asSymbol(),[varName],"Compiler-Core");
- }, function($ctx1) {$ctx1.fill(self,"subclass:withVariable:",{aClass:aClass,varName:varName},$globals.Repl)});
- },
- args: ["aClass", "varName"],
- source: "subclass: aClass withVariable: varName\x0a\x09\x22Create subclass with new variable.\x22\x0a\x09^ ClassBuilder new\x0a\x09\x09addSubclassOf: aClass\x0a\x09\x09named: (self subclassNameFor: aClass) asSymbol\x0a\x09\x09instanceVariableNames: {varName}\x0a\x09\x09package: 'Compiler-Core'",
- referencedClasses: ["ClassBuilder"],
- messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "new", "asSymbol", "subclassNameFor:"]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "subclassNameFor:",
- protocol: "private",
- fn: function (aClass){
- var self=this;
- return $core.withContext(function($ctx1) {
- var $2,$1,$6,$5,$4,$3,$7,$receiver;
- $2=$recv(aClass)._name();
- $ctx1.sendIdx["name"]=1;
- $1=$recv($2)._matchesOf_("\x5cd+$");
- $ctx1.sendIdx["matchesOf:"]=1;
- if(($receiver = $1) == null || $receiver.isNil){
- return $recv($recv(aClass)._name()).__comma("2");
- } else {
- var counter;
- $6=$recv(aClass)._name();
- $ctx1.sendIdx["name"]=2;
- $5=$recv($6)._matchesOf_("\x5cd+$");
- $4=$recv($5)._first();
- $3=$recv($4)._asNumber();
- counter=$recv($3).__plus((1));
- counter;
- $7=$recv(aClass)._name();
- $ctx1.sendIdx["name"]=3;
- return $recv($7)._replaceRegexp_with_("\x5cd+$"._asRegexp(),$recv(counter)._asString());
- }
- }, function($ctx1) {$ctx1.fill(self,"subclassNameFor:",{aClass:aClass},$globals.Repl)});
- },
- args: ["aClass"],
- source: "subclassNameFor: aClass\x0a\x09^ (aClass name matchesOf: '\x5cd+$')\x0a\x09\x09ifNotNil: [ | counter |\x0a\x09\x09\x09counter := (aClass name matchesOf: '\x5cd+$') first asNumber + 1.\x0a\x09\x09\x09aClass name replaceRegexp: '\x5cd+$' asRegexp with: counter asString]\x0a\x09\x09ifNil: [\x0a\x09\x09\x09aClass name, '2'].",
- referencedClasses: [],
- messageSends: ["ifNotNil:ifNil:", "matchesOf:", "name", "+", "asNumber", "first", "replaceRegexp:with:", "asRegexp", "asString", ","]
- }),
- $globals.Repl);
- $core.addMethod(
- $core.method({
- selector: "main",
- protocol: "initialization",
- fn: function (){
- var self=this;
- return $core.withContext(function($ctx1) {
- $recv(self._new())._createInterface();
- return self;
- }, function($ctx1) {$ctx1.fill(self,"main",{},$globals.Repl.klass)});
- },
- args: [],
- source: "main\x0a\x09self new createInterface",
- referencedClasses: [],
- messageSends: ["createInterface", "new"]
- }),
- $globals.Repl.klass);
- });
- (function () {
- define('app',["amber/devel", "amber_cli/AmberCli"], function (amber) {
- amber.initialize().then(function () {
- amber.globals.AmberCli._main();
- });
- });
- }());
- //jshint eqnull:true
- define('amber/kernel-runtime',[],function () {
- "use strict";
- function defineMethod (klass, name, method) {
- Object.defineProperty(klass.prototype, name, {
- value: method,
- enumerable: false, configurable: true, writable: true
- });
- }
- DNUBrik.deps = ["selectors", "messageSend", "manipulation", "classes"];
- function DNUBrik (brikz, st) {
- var selectorsBrik = brikz.selectors;
- var messageNotUnderstood = brikz.messageSend.messageNotUnderstood;
- var installJSMethod = brikz.manipulation.installJSMethod;
- var nilAsClass = brikz.classes.nilAsClass;
- /* Method not implemented handlers */
- function makeDnuHandler (pair, targetClasses) {
- var jsSelector = pair.js;
- var fn = createHandler(pair.st);
- installJSMethod(nilAsClass.fn.prototype, jsSelector, fn);
- targetClasses.forEach(function (target) {
- installJSMethod(target.fn.prototype, jsSelector, fn);
- });
- }
- this.makeDnuHandler = makeDnuHandler;
- /* Dnu handler method */
- function createHandler (stSelector) {
- return function () {
- return messageNotUnderstood(this, stSelector, arguments);
- };
- }
- selectorsBrik.selectorPairs.forEach(function (pair) {
- makeDnuHandler(pair, []);
- });
- }
- function ManipulationBrik (brikz, st) {
- function installJSMethod (obj, jsSelector, fn) {
- Object.defineProperty(obj, jsSelector, {
- value: fn,
- enumerable: false, configurable: true, writable: true
- });
- }
- function installMethod (method, klass) {
- installJSMethod(klass.fn.prototype, method.jsSelector, method.fn);
- }
- this.installMethod = installMethod;
- this.installJSMethod = installJSMethod;
- }
- RuntimeClassesBrik.deps = ["selectors", "dnu", "behaviors", "classes", "manipulation"];
- function RuntimeClassesBrik (brikz, st) {
- var selectors = brikz.selectors;
- var classes = brikz.behaviors.classes;
- var wireKlass = brikz.classes.wireKlass;
- var installMethod = brikz.manipulation.installMethod;
- var installJSMethod = brikz.manipulation.installJSMethod;
- var detachedRootClasses = [];
- function markClassDetachedRoot (klass) {
- klass.detachedRoot = true;
- detachedRootClasses = classes().filter(function (klass) {
- return klass.detachedRoot;
- });
- }
- this.detachedRootClasses = function () {
- return detachedRootClasses;
- };
- /* Initialize a class in its class hierarchy. Handle both classes and
- metaclasses. */
- function initClassAndMetaclass (klass) {
- initClass(klass);
- if (klass.klass && !klass.meta) {
- initClass(klass.klass);
- }
- }
- classes().forEach(function (klass) {
- if (!klass.trait) initClassAndMetaclass(klass);
- });
- st._classAdded = initClassAndMetaclass;
- function initClass (klass) {
- wireKlass(klass);
- if (klass.detachedRoot) {
- copySuperclass(klass);
- }
- installMethods(klass);
- }
- function copySuperclass (klass) {
- var myproto = klass.fn.prototype,
- superproto = klass.superclass.fn.prototype;
- selectors.selectorPairs.forEach(function (selectorPair) {
- var jsSelector = selectorPair.js;
- installJSMethod(myproto, jsSelector, superproto[jsSelector]);
- });
- }
- function installMethods (klass) {
- var methods = klass.methods;
- Object.keys(methods).forEach(function (selector) {
- installMethod(methods[selector], klass);
- });
- }
- /* Manually set the constructor of an existing Smalltalk klass, making it a detached root class. */
- st.setClassConstructor = this.setClassConstructor = function (klass, constructor) {
- markClassDetachedRoot(klass);
- klass.fn = constructor;
- initClass(klass);
- };
- }
- FrameBindingBrik.deps = ["smalltalkGlobals", "runtimeClasses"];
- function FrameBindingBrik (brikz, st) {
- var globals = brikz.smalltalkGlobals.globals;
- var setClassConstructor = brikz.runtimeClasses.setClassConstructor;
- setClassConstructor(globals.Number, Number);
- setClassConstructor(globals.BlockClosure, Function);
- setClassConstructor(globals.Boolean, Boolean);
- setClassConstructor(globals.Date, Date);
- setClassConstructor(globals.String, String);
- setClassConstructor(globals.Array, Array);
- setClassConstructor(globals.RegularExpression, RegExp);
- setClassConstructor(globals.Error, Error);
- setClassConstructor(globals.Promise, Promise);
- this.__init__ = function () {
- st.alias(globals.Array, "OrderedCollection");
- st.alias(globals.Date, "Time");
- }
- }
- RuntimeMethodsBrik.deps = ["manipulation", "dnu", "runtimeClasses"];
- function RuntimeMethodsBrik (brikz, st) {
- var installMethod = brikz.manipulation.installMethod;
- var installJSMethod = brikz.manipulation.installJSMethod;
- var makeDnuHandler = brikz.dnu.makeDnuHandler;
- var detachedRootClasses = brikz.runtimeClasses.detachedRootClasses;
- st._methodAdded = function (method, klass) {
- installMethod(method, klass);
- propagateMethodChange(klass, method, klass);
- };
- st._selectorsAdded = function (newSelectors) {
- var targetClasses = detachedRootClasses();
- newSelectors.forEach(function (pair) {
- makeDnuHandler(pair, targetClasses);
- });
- };
- st._methodRemoved = function (method, klass) {
- delete klass.fn.prototype[method.jsSelector];
- propagateMethodChange(klass, method, null);
- };
- function propagateMethodChange (klass, method, exclude) {
- var selector = method.selector;
- var jsSelector = method.jsSelector;
- st.traverseClassTree(klass, function (subclass, sentinel) {
- if (subclass != exclude) {
- if (initMethodInClass(subclass, selector, jsSelector)) return sentinel;
- }
- });
- }
- function initMethodInClass (klass, selector, jsSelector) {
- if (klass.methods[selector]) return true;
- if (klass.detachedRoot) {
- installJSMethod(klass.fn.prototype, jsSelector, klass.superclass.fn.prototype[jsSelector]);
- }
- }
- }
- PrimitivesBrik.deps = ["smalltalkGlobals"];
- function PrimitivesBrik (brikz, st) {
- var globals = brikz.smalltalkGlobals.globals;
- var oid = 0;
- /* Unique ID number generator */
- st.nextId = function () {
- oid += 1;
- return oid;
- };
- /* Converts a JavaScript object to valid Smalltalk Object */
- st.readJSObject = function (js) {
- if (js == null)
- return null;
- var readObject = js.constructor === Object;
- var readArray = js.constructor === Array;
- var object = readObject ? globals.Dictionary._new() : readArray ? [] : js;
- for (var i in js) {
- if (readObject) {
- object._at_put_(i, st.readJSObject(js[i]));
- }
- if (readArray) {
- object[i] = st.readJSObject(js[i]);
- }
- }
- return object;
- };
- /* Boolean assertion */
- st.assert = function (shouldBeBoolean) {
- if (typeof shouldBeBoolean === "boolean") return shouldBeBoolean;
- else if (shouldBeBoolean != null && typeof shouldBeBoolean === "object") {
- shouldBeBoolean = shouldBeBoolean.valueOf();
- if (typeof shouldBeBoolean === "boolean") return shouldBeBoolean;
- }
- globals.NonBooleanReceiver._new()._object_(shouldBeBoolean)._signal();
- };
- /* List of all reserved words in JavaScript. They may not be used as variables
- in Smalltalk. */
- // list of reserved JavaScript keywords as of
- // http://es5.github.com/#x7.6.1.1
- // and
- // http://people.mozilla.org/~jorendorff/es6-draft.html#sec-7.6.1
- st.reservedWords = ['break', 'case', 'catch', 'continue', 'debugger',
- 'default', 'delete', 'do', 'else', 'finally', 'for', 'function',
- 'if', 'in', 'instanceof', 'new', 'return', 'switch', 'this', 'throw',
- 'try', 'typeof', 'var', 'void', 'while', 'with',
- // Amber protected words: these should not be compiled as-is when in code
- 'arguments',
- // ES5: future use: http://es5.github.com/#x7.6.1.2
- 'class', 'const', 'enum', 'export', 'extends', 'import', 'super',
- // ES5: future use in strict mode
- 'implements', 'interface', 'let', 'package', 'private', 'protected',
- 'public', 'static', 'yield'];
- st.globalJsVariables = ['window', 'document', 'process', 'global'];
- }
- RuntimeBrik.deps = ["selectorConversion", "smalltalkGlobals", "runtimeClasses"];
- function RuntimeBrik (brikz, st) {
- var globals = brikz.smalltalkGlobals.globals;
- var setClassConstructor = brikz.runtimeClasses.setClassConstructor;
- function SmalltalkMethodContext (home, setup) {
- this.sendIdx = {};
- this.homeContext = home;
- this.setup = setup || function () {
- };
- this.supercall = false;
- }
- // Fallbacks
- SmalltalkMethodContext.prototype.locals = {};
- SmalltalkMethodContext.prototype.receiver = null;
- SmalltalkMethodContext.prototype.selector = null;
- SmalltalkMethodContext.prototype.lookupClass = null;
- defineMethod(SmalltalkMethodContext, "fill", function (receiver, selector, locals, lookupClass) {
- this.receiver = receiver;
- this.selector = selector;
- this.locals = locals || {};
- this.lookupClass = lookupClass;
- if (this.homeContext) {
- this.homeContext.evaluatedSelector = selector;
- }
- });
- defineMethod(SmalltalkMethodContext, "fillBlock", function (locals, ctx, index) {
- this.locals = locals || {};
- this.outerContext = ctx;
- this.index = index || 0;
- });
- defineMethod(SmalltalkMethodContext, "init", function () {
- var home = this.homeContext;
- if (home) {
- home.init();
- }
- this.setup(this);
- });
- defineMethod(SmalltalkMethodContext, "method", function () {
- var method;
- var lookup = this.lookupClass || this.receiver.klass;
- while (!method && lookup) {
- method = lookup.methods[st.js2st(this.selector)];
- lookup = lookup.superclass;
- }
- return method;
- });
- setClassConstructor(globals.MethodContext, SmalltalkMethodContext);
- /* This is the current call context object.
- In Smalltalk code, it is accessible just by using 'thisContext' variable.
- In JS code, use api.getThisContext() (see below).
- */
- var thisContext = null;
- st.withContext = function (worker, setup) {
- if (thisContext) {
- return inContext(worker, setup);
- } else {
- return inContextWithErrorHandling(worker, setup);
- }
- };
- /*
- Runs worker function so that error handler is not set up
- if there isn't one. This is accomplished by unconditional
- wrapping inside a context of a simulated `nil seamlessDoIt` call,
- which then stops error handler setup (see st.withContext above).
- The effect is, $core.seamless(fn)'s exceptions are not
- handed into ST error handler and caller should process them.
- */
- st.seamless = function (worker) {
- return inContext(worker, function (ctx) {
- ctx.fill(null, "seamlessDoIt", {}, globals.UndefinedObject);
- });
- };
- function inContextWithErrorHandling (worker, setup) {
- try {
- return inContext(worker, setup);
- } catch (error) {
- handleError(error);
- thisContext = null;
- // Rethrow the error in any case.
- error.amberHandled = true;
- throw error;
- }
- }
- function inContext (worker, setup) {
- var oldContext = thisContext;
- thisContext = new SmalltalkMethodContext(thisContext, setup);
- var result = worker(thisContext);
- thisContext = oldContext;
- return result;
- }
- /* Wrap a JavaScript exception in a Smalltalk Exception.
- In case of a RangeError, stub the stack after 100 contexts to
- avoid another RangeError later when the stack is manipulated. */
- function wrappedError (error) {
- var errorWrapper = globals.JavaScriptException._on_(error);
- // Add the error to the context, so it is visible in the stack
- try {
- errorWrapper._signal();
- } catch (ex) {
- }
- var context = st.getThisContext();
- if (isRangeError(error)) {
- stubContextStack(context);
- }
- errorWrapper._context_(context);
- return errorWrapper;
- }
- /* Stub the context stack after 100 contexts */
- function stubContextStack (context) {
- var currentContext = context;
- var contexts = 0;
- while (contexts < 100) {
- if (currentContext) {
- currentContext = currentContext.homeContext;
- }
- contexts++;
- }
- if (currentContext) {
- currentContext.homeContext = undefined;
- }
- }
- function isRangeError (error) {
- return error instanceof RangeError;
- }
- /* Handles Smalltalk errors. Triggers the registered ErrorHandler
- (See the Smalltalk class ErrorHandler and its subclasses */
- function handleError (error) {
- if (!error.smalltalkError) {
- error = wrappedError(error);
- }
- globals.ErrorHandler._handleError_(error);
- }
- /* Handle thisContext pseudo variable */
- st.getThisContext = function () {
- if (thisContext) {
- thisContext.init();
- return thisContext;
- } else {
- return null;
- }
- };
- }
- MessageSendBrik.deps = ["smalltalkGlobals", "selectorConversion", "root"];
- function MessageSendBrik (brikz, st) {
- var globals = brikz.smalltalkGlobals.globals;
- var nilAsReceiver = brikz.root.nilAsReceiver;
- /* Send message programmatically. Used to implement #perform: & Co. */
- st.send2 = function (receiver, selector, args, klass) {
- var method, jsSelector = st.st2js(selector);
- if (receiver == null) {
- receiver = nilAsReceiver;
- }
- method = klass ? klass.fn.prototype[jsSelector] : receiver.klass && receiver[jsSelector];
- if (method) {
- return method.apply(receiver, args || []);
- } else {
- return messageNotUnderstood(receiver, selector, args);
- }
- };
- function invokeDnuMethod (receiver, stSelector, args) {
- return receiver._doesNotUnderstand_(
- globals.Message._new()
- ._selector_(stSelector)
- ._arguments_([].slice.call(args))
- );
- }
- function wrapJavaScript (o) {
- return globals.JSObjectProxy._on_(o);
- }
- st.wrapJavaScript = wrapJavaScript;
- /* Handles #dnu: *and* JavaScript method calls.
- if the receiver has no klass, we consider it a JS object (outside of the
- Amber system). Else assume that the receiver understands #doesNotUnderstand: */
- function messageNotUnderstood (receiver, stSelector, args) {
- if (receiver.klass != null && !receiver.allowJavaScriptCalls) {
- return invokeDnuMethod(receiver, stSelector, args);
- }
- /* Call a method of a JS object, or answer a property if it exists.
- Converts keyword-based selectors by using the first
- keyword only, but keeping all message arguments.
- Example:
- "self do: aBlock with: anObject" -> "self.do(aBlock, anObject)"
- Else try wrapping a JSObjectProxy around the receiver. */
- var propertyName = st.st2prop(stSelector);
- if (!(propertyName in receiver)) {
- return invokeDnuMethod(wrapJavaScript(receiver), stSelector, args);
- }
- return accessJavaScript(receiver, propertyName, args);
- }
- /* If the object property is a function, then call it, except if it starts with
- an uppercase character (we probably want to answer the function itself in this
- case and send it #new from Amber).
- */
- function accessJavaScript (receiver, propertyName, args) {
- var propertyValue = receiver[propertyName];
- if (typeof propertyValue === "function" && !/^[A-Z]/.test(propertyName)) {
- return propertyValue.apply(receiver, args || []);
- } else if (args.length > 0) {
- receiver[propertyName] = args[0];
- return receiver;
- } else {
- return propertyValue;
- }
- }
- st.accessJavaScript = accessJavaScript;
- this.messageNotUnderstood = messageNotUnderstood;
- }
- StartImageBrik.deps = ["frameBinding", "runtimeMethods", "runtime", "primitives"];
- function StartImageBrik (brikz, st) {
- this.__init__ = function () {
- var classes = brikz.behaviors.classes;
- classes().forEach(function (klass) {
- klass._initialize();
- });
- };
- this.__init__.once = true;
- }
- /* Making smalltalk that can run */
- function configureWithRuntime (brikz) {
- brikz.dnu = DNUBrik;
- brikz.manipulation = ManipulationBrik;
- brikz.runtimeClasses = RuntimeClassesBrik;
- brikz.frameBinding = FrameBindingBrik;
- brikz.runtimeMethods = RuntimeMethodsBrik;
- brikz.messageSend = MessageSendBrik;
- brikz.runtime = RuntimeBrik;
- brikz.primitives = PrimitivesBrik;
- brikz.startImage = StartImageBrik;
- brikz.rebuild();
- }
- return configureWithRuntime;
- });
- // Depend on each module that is loaded lazily.
- // Add to packager tasks as dependency,
- // so the lazy-loaded modules are included.
- define('amber/lazypack',['./kernel-runtime'], {});
- require(["app"]);
- });
- define.require('__wrap__');
- }((function amdefine(module, requireFn) {
- 'use strict';
- var defineCache = {},
- loaderCache = {},
- alreadyCalled = false,
- path = require('path'),
- makeRequire, stringRequire;
- /**
- * Trims the . and .. from an array of path segments.
- * It will keep a leading path segment if a .. will become
- * the first path segment, to help with module name lookups,
- * which act like paths, but can be remapped. But the end result,
- * all paths that use this function should look normalized.
- * NOTE: this method MODIFIES the input array.
- * @param {Array} ary the array of path segments.
- */
- function trimDots(ary) {
- var i, part;
- for (i = 0; ary[i]; i+= 1) {
- part = ary[i];
- if (part === '.') {
- ary.splice(i, 1);
- i -= 1;
- } else if (part === '..') {
- if (i === 1 && (ary[2] === '..' || ary[0] === '..')) {
- //End of the line. Keep at least one non-dot
- //path segment at the front so it can be mapped
- //correctly to disk. Otherwise, there is likely
- //no path mapping for a path starting with '..'.
- //This can still fail, but catches the most reasonable
- //uses of ..
- break;
- } else if (i > 0) {
- ary.splice(i - 1, 2);
- i -= 2;
- }
- }
- }
- }
- function normalize(name, baseName) {
- var baseParts;
- //Adjust any relative paths.
- if (name && name.charAt(0) === '.') {
- //If have a base name, try to normalize against it,
- //otherwise, assume it is a top-level require that will
- //be relative to baseUrl in the end.
- if (baseName) {
- baseParts = baseName.split('/');
- baseParts = baseParts.slice(0, baseParts.length - 1);
- baseParts = baseParts.concat(name.split('/'));
- trimDots(baseParts);
- name = baseParts.join('/');
- }
- }
- return name;
- }
- /**
- * Create the normalize() function passed to a loader plugin's
- * normalize method.
- */
- function makeNormalize(relName) {
- return function (name) {
- return normalize(name, relName);
- };
- }
- function makeLoad(id) {
- function load(value) {
- loaderCache[id] = value;
- }
- load.fromText = function (id, text) {
- //This one is difficult because the text can/probably uses
- //define, and any relative paths and requires should be relative
- //to that id was it would be found on disk. But this would require
- //bootstrapping a module/require fairly deeply from node core.
- //Not sure how best to go about that yet.
- throw new Error('amdefine does not implement load.fromText');
- };
- return load;
- }
- makeRequire = function (systemRequire, exports, module, relId) {
- function amdRequire(deps, callback) {
- if (typeof deps === 'string') {
- //Synchronous, single module require('')
- return stringRequire(systemRequire, exports, module, deps, relId);
- } else {
- //Array of dependencies with a callback.
- //Convert the dependencies to modules.
- deps = deps.map(function (depName) {
- return stringRequire(systemRequire, exports, module, depName, relId);
- });
- //Wait for next tick to call back the require call.
- if (callback) {
- process.nextTick(function () {
- callback.apply(null, deps);
- });
- }
- }
- }
- amdRequire.toUrl = function (filePath) {
- if (filePath.indexOf('.') === 0) {
- return normalize(filePath, path.dirname(module.filename));
- } else {
- return filePath;
- }
- };
- return amdRequire;
- };
- //Favor explicit value, passed in if the module wants to support Node 0.4.
- requireFn = requireFn || function req() {
- return module.require.apply(module, arguments);
- };
- function runFactory(id, deps, factory) {
- var r, e, m, result;
- if (id) {
- e = loaderCache[id] = {};
- m = {
- id: id,
- uri: __filename,
- exports: e
- };
- r = makeRequire(requireFn, e, m, id);
- } else {
- //Only support one define call per file
- if (alreadyCalled) {
- throw new Error('amdefine with no module ID cannot be called more than once per file.');
- }
- alreadyCalled = true;
- //Use the real variables from node
- //Use module.exports for exports, since
- //the exports in here is amdefine exports.
- e = module.exports;
- m = module;
- r = makeRequire(requireFn, e, m, module.id);
- }
- //If there are dependencies, they are strings, so need
- //to convert them to dependency values.
- if (deps) {
- deps = deps.map(function (depName) {
- return r(depName);
- });
- }
- //Call the factory with the right dependencies.
- if (typeof factory === 'function') {
- result = factory.apply(m.exports, deps);
- } else {
- result = factory;
- }
- if (result !== undefined) {
- m.exports = result;
- if (id) {
- loaderCache[id] = m.exports;
- }
- }
- }
- stringRequire = function (systemRequire, exports, module, id, relId) {
- //Split the ID by a ! so that
- var index = id.indexOf('!'),
- originalId = id,
- prefix, plugin;
- if (index === -1) {
- id = normalize(id, relId);
- //Straight module lookup. If it is one of the special dependencies,
- //deal with it, otherwise, delegate to node.
- if (id === 'require') {
- return makeRequire(systemRequire, exports, module, relId);
- } else if (id === 'exports') {
- return exports;
- } else if (id === 'module') {
- return module;
- } else if (loaderCache.hasOwnProperty(id)) {
- return loaderCache[id];
- } else if (defineCache[id]) {
- runFactory.apply(null, defineCache[id]);
- return loaderCache[id];
- } else {
- if(systemRequire) {
- return systemRequire(originalId);
- } else {
- throw new Error('No module with ID: ' + id);
- }
- }
- } else {
- //There is a plugin in play.
- prefix = id.substring(0, index);
- id = id.substring(index + 1, id.length);
- plugin = stringRequire(systemRequire, exports, module, prefix, relId);
- if (plugin.normalize) {
- id = plugin.normalize(id, makeNormalize(relId));
- } else {
- //Normalize the ID normally.
- id = normalize(id, relId);
- }
- if (loaderCache[id]) {
- return loaderCache[id];
- } else {
- plugin.load(id, makeRequire(systemRequire, exports, module, relId), makeLoad(id), {});
- return loaderCache[id];
- }
- }
- };
- //Create a define function specific to the module asking for amdefine.
- function define(id, deps, factory) {
- if (Array.isArray(id)) {
- factory = deps;
- deps = id;
- id = undefined;
- } else if (typeof id !== 'string') {
- factory = id;
- id = deps = undefined;
- }
- if (deps && !Array.isArray(deps)) {
- factory = deps;
- deps = undefined;
- }
- if (!deps) {
- deps = ['require', 'exports', 'module'];
- }
- //Set up properties for this module. If an ID, then use
- //internal cache. If no ID, then use the external variables
- //for this node module.
- if (id) {
- //Put the module in deep freeze until there is a
- //require call for it.
- defineCache[id] = [id, deps, factory];
- } else {
- runFactory(id, deps, factory);
- }
- }
- //define.require, which has access to all the values in the
- //cache. Useful for AMD modules that all have IDs in the file,
- //but need to finally export a value to node based on one of those
- //IDs.
- define.require = function (id) {
- if (loaderCache[id]) {
- return loaderCache[id];
- }
- if (defineCache[id]) {
- runFactory.apply(null, defineCache[id]);
- return loaderCache[id];
- }
- };
- define.amd = {};
- return define;
- }(module)), require));
|